@progressive-development/pd-forms 0.8.6 → 0.9.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (195) hide show
  1. package/dist/{pd-base-input-element.d.ts → base/pd-base-input-element.d.ts} +2 -3
  2. package/dist/base/pd-base-input-element.d.ts.map +1 -0
  3. package/dist/{pd-base-input-element.js → base/pd-base-input-element.js} +20 -23
  4. package/dist/{pd-base-ui-input.d.ts → base/pd-base-ui-input.d.ts} +3 -3
  5. package/dist/base/pd-base-ui-input.d.ts.map +1 -0
  6. package/dist/{pd-base-ui-input.js → base/pd-base-ui-input.js} +35 -42
  7. package/dist/base/pd-base-ui.d.ts.map +1 -0
  8. package/dist/{pd-base-ui.js → base/pd-base-ui.js} +10 -9
  9. package/dist/index.d.ts +11 -10
  10. package/dist/index.d.ts.map +1 -1
  11. package/dist/index.js +27 -32
  12. package/dist/locales/be.js +4 -4
  13. package/dist/locales/de.js +4 -4
  14. package/dist/locales/en.js +4 -4
  15. package/dist/pd-button/PdButton.d.ts +57 -0
  16. package/dist/pd-button/PdButton.d.ts.map +1 -0
  17. package/dist/pd-button/PdButton.js +152 -0
  18. package/dist/pd-button/pd-button.d.ts +3 -0
  19. package/dist/pd-button/pd-button.d.ts.map +1 -0
  20. package/dist/pd-button/pd-button.spec.d.ts +2 -0
  21. package/dist/pd-button/pd-button.spec.d.ts.map +1 -0
  22. package/dist/pd-button/pd-button.stories.d.ts +12 -0
  23. package/dist/pd-button/pd-button.stories.d.ts.map +1 -0
  24. package/dist/pd-button-group/PdButtonGroup.d.ts +14 -0
  25. package/dist/pd-button-group/PdButtonGroup.d.ts.map +1 -0
  26. package/dist/pd-button-group/PdButtonGroup.js +115 -0
  27. package/dist/pd-button-group/pd-button-group.d.ts +3 -0
  28. package/dist/pd-button-group/pd-button-group.d.ts.map +1 -0
  29. package/dist/pd-button-group/pd-button-group.stories.d.ts.map +1 -0
  30. package/dist/pd-button-group.d.ts +2 -14
  31. package/dist/pd-button-group.js +6 -116
  32. package/dist/{pd-icon-button-select-group.d.ts → pd-button-select-group/PdButtonSelectGroup.d.ts} +8 -5
  33. package/dist/pd-button-select-group/PdButtonSelectGroup.d.ts.map +1 -0
  34. package/dist/{pd-icon-button-select-group.js → pd-button-select-group/PdButtonSelectGroup.js} +38 -40
  35. package/dist/pd-button-select-group/pd-button-select-group.d.ts +3 -0
  36. package/dist/pd-button-select-group/pd-button-select-group.d.ts.map +1 -0
  37. package/dist/{stories/pd-icon-button-select-group.stories.d.ts → pd-button-select-group/pd-button-select-group.stories.d.ts} +2 -2
  38. package/dist/pd-button-select-group/pd-button-select-group.stories.d.ts.map +1 -0
  39. package/dist/pd-button-select-group.d.ts +2 -0
  40. package/dist/pd-button-select-group.js +8 -0
  41. package/dist/pd-button.d.ts +2 -16
  42. package/dist/pd-button.js +6 -152
  43. package/dist/pd-checkbox/PdCheckbox.d.ts +18 -0
  44. package/dist/pd-checkbox/PdCheckbox.d.ts.map +1 -0
  45. package/dist/pd-checkbox/PdCheckbox.js +279 -0
  46. package/dist/pd-checkbox/pd-checkbox.d.ts +3 -0
  47. package/dist/pd-checkbox/pd-checkbox.d.ts.map +1 -0
  48. package/dist/{stories/checkbox.stories.d.ts → pd-checkbox/pd-checkbox.stories.d.ts} +1 -1
  49. package/dist/pd-checkbox/pd-checkbox.stories.d.ts.map +1 -0
  50. package/dist/pd-checkbox.d.ts +2 -15
  51. package/dist/pd-checkbox.js +6 -279
  52. package/dist/pd-form-container/PdFormContainer.d.ts +42 -0
  53. package/dist/pd-form-container/PdFormContainer.d.ts.map +1 -0
  54. package/dist/pd-form-container/PdFormContainer.js +269 -0
  55. package/dist/pd-form-container/form-container.stories.d.ts.map +1 -0
  56. package/dist/pd-form-container/form-container2.stories.d.ts.map +1 -0
  57. package/dist/pd-form-container/form-container3.stories.d.ts.map +1 -0
  58. package/dist/pd-form-container/pd-form-container.d.ts +3 -0
  59. package/dist/pd-form-container/pd-form-container.d.ts.map +1 -0
  60. package/dist/pd-form-container.d.ts +2 -36
  61. package/dist/pd-form-container.js +6 -271
  62. package/dist/pd-form-row/PdFormRow.d.ts +15 -0
  63. package/dist/pd-form-row/PdFormRow.d.ts.map +1 -0
  64. package/dist/pd-form-row/PdFormRow.js +110 -0
  65. package/dist/pd-form-row/pd-form-row.d.ts +3 -0
  66. package/dist/pd-form-row/pd-form-row.d.ts.map +1 -0
  67. package/dist/{stories/form-row.stories.d.ts → pd-form-row/pd-form-row.stories.d.ts} +1 -1
  68. package/dist/pd-form-row/pd-form-row.stories.d.ts.map +1 -0
  69. package/dist/pd-form-row.d.ts +2 -12
  70. package/dist/pd-form-row.js +6 -114
  71. package/dist/pd-hover-box/PdHoverBox.d.ts +31 -0
  72. package/dist/pd-hover-box/PdHoverBox.d.ts.map +1 -0
  73. package/dist/pd-hover-box/PdHoverBox.js +119 -0
  74. package/dist/pd-hover-box/pd-hover-box.d.ts +3 -0
  75. package/dist/pd-hover-box/pd-hover-box.d.ts.map +1 -0
  76. package/dist/pd-hover-box/pd-hover-box.stories.d.ts.map +1 -0
  77. package/dist/pd-hover-box.d.ts +2 -23
  78. package/dist/pd-hover-box.js +6 -120
  79. package/dist/pd-input/PdInput.d.ts +35 -0
  80. package/dist/pd-input/PdInput.d.ts.map +1 -0
  81. package/dist/pd-input/PdInput.js +123 -0
  82. package/dist/pd-input/pd-input.d.ts +3 -0
  83. package/dist/pd-input/pd-input.d.ts.map +1 -0
  84. package/dist/{stories/input.stories.d.ts → pd-input/pd-input.stories.d.ts} +1 -1
  85. package/dist/pd-input/pd-input.stories.d.ts.map +1 -0
  86. package/dist/pd-input-area/PdInputArea.d.ts +23 -0
  87. package/dist/pd-input-area/PdInputArea.d.ts.map +1 -0
  88. package/dist/pd-input-area/PdInputArea.js +99 -0
  89. package/dist/pd-input-area/pd-input-area.d.ts +3 -0
  90. package/dist/pd-input-area/pd-input-area.d.ts.map +1 -0
  91. package/dist/{stories/input-area.stories.d.ts → pd-input-area/pd-input-area.stories.d.ts} +1 -1
  92. package/dist/pd-input-area/pd-input-area.stories.d.ts.map +1 -0
  93. package/dist/pd-input-area.d.ts +2 -20
  94. package/dist/pd-input-area.js +8 -101
  95. package/dist/pd-input-file/PdInputFile.d.ts +19 -0
  96. package/dist/pd-input-file/PdInputFile.d.ts.map +1 -0
  97. package/dist/pd-input-file/PdInputFile.js +93 -0
  98. package/dist/pd-input-file/pd-input-file.d.ts +3 -0
  99. package/dist/pd-input-file/pd-input-file.d.ts.map +1 -0
  100. package/dist/{stories/input-file.stories.d.ts → pd-input-file/pd-input-file.stories.d.ts} +1 -1
  101. package/dist/pd-input-file/pd-input-file.stories.d.ts.map +1 -0
  102. package/dist/pd-input-file.d.ts +2 -16
  103. package/dist/pd-input-file.js +8 -96
  104. package/dist/pd-input-time/PdInputTime.d.ts +14 -0
  105. package/dist/pd-input-time/PdInputTime.d.ts.map +1 -0
  106. package/dist/pd-input-time/PdInputTime.js +77 -0
  107. package/dist/pd-input-time/pd-input-time.d.ts +3 -0
  108. package/dist/pd-input-time/pd-input-time.d.ts.map +1 -0
  109. package/dist/pd-input-time.d.ts +2 -11
  110. package/dist/pd-input-time.js +8 -81
  111. package/dist/pd-input.d.ts +2 -32
  112. package/dist/pd-input.js +8 -126
  113. package/dist/pd-panel-button/PdPanelButton.d.ts +49 -0
  114. package/dist/pd-panel-button/PdPanelButton.d.ts.map +1 -0
  115. package/dist/{pd-icon-panel-button.js → pd-panel-button/PdPanelButton.js} +110 -112
  116. package/dist/pd-panel-button/pd-panel-button.d.ts +3 -0
  117. package/dist/pd-panel-button/pd-panel-button.d.ts.map +1 -0
  118. package/dist/{stories/pd-icon-button.stories.d.ts → pd-panel-button/pd-panel-button.stories.d.ts} +3 -13
  119. package/dist/{stories/pd-icon-button.stories.d.ts.map → pd-panel-button/pd-panel-button.stories.d.ts.map} +1 -1
  120. package/dist/pd-panel-button.d.ts +2 -0
  121. package/dist/pd-panel-button.js +8 -0
  122. package/dist/pd-radio-group/PdRadioGroup.d.ts +16 -0
  123. package/dist/pd-radio-group/PdRadioGroup.d.ts.map +1 -0
  124. package/dist/pd-radio-group/PdRadioGroup.js +114 -0
  125. package/dist/pd-radio-group/pd-radio-group.d.ts +3 -0
  126. package/dist/pd-radio-group/pd-radio-group.d.ts.map +1 -0
  127. package/dist/{stories/radio-group.stories.d.ts → pd-radio-group/pd-radio-group.stories.d.ts} +1 -1
  128. package/dist/pd-radio-group/pd-radio-group.stories.d.ts.map +1 -0
  129. package/dist/pd-radio-group.d.ts +2 -13
  130. package/dist/pd-radio-group.js +7 -113
  131. package/dist/pd-range/PdRange.d.ts +25 -0
  132. package/dist/pd-range/PdRange.d.ts.map +1 -0
  133. package/dist/pd-range/PdRange.js +280 -0
  134. package/dist/pd-range/pd-range.d.ts +3 -0
  135. package/dist/pd-range/pd-range.d.ts.map +1 -0
  136. package/dist/{stories/range.stories.d.ts → pd-range/pd-range.stories.d.ts} +1 -1
  137. package/dist/pd-range/pd-range.stories.d.ts.map +1 -0
  138. package/dist/pd-range.d.ts +2 -22
  139. package/dist/pd-range.js +6 -285
  140. package/dist/pd-select/PdSelect.d.ts +21 -0
  141. package/dist/pd-select/PdSelect.d.ts.map +1 -0
  142. package/dist/pd-select/PdSelect.js +142 -0
  143. package/dist/pd-select/pd-select.d.ts +3 -0
  144. package/dist/pd-select/pd-select.d.ts.map +1 -0
  145. package/dist/{stories/select.stories.d.ts → pd-select/pd-select.stories.d.ts} +1 -1
  146. package/dist/pd-select/pd-select.stories.d.ts.map +1 -0
  147. package/dist/pd-select.d.ts +2 -18
  148. package/dist/pd-select.js +6 -144
  149. package/dist/stories/01_index.stories.d.ts.map +1 -1
  150. package/dist/styles/shared-input-field-styles.js +4 -4
  151. package/dist/styles/shared-input-styles.js +4 -4
  152. package/dist/types.js +2 -3
  153. package/dist/validators.js +5 -12
  154. package/package.json +21 -41
  155. package/dist/pd-base-input-element.d.ts.map +0 -1
  156. package/dist/pd-base-ui-input.d.ts.map +0 -1
  157. package/dist/pd-base-ui.d.ts.map +0 -1
  158. package/dist/pd-button-group.d.ts.map +0 -1
  159. package/dist/pd-button.d.ts.map +0 -1
  160. package/dist/pd-checkbox.d.ts.map +0 -1
  161. package/dist/pd-form-container.d.ts.map +0 -1
  162. package/dist/pd-form-row.d.ts.map +0 -1
  163. package/dist/pd-hover-box.d.ts.map +0 -1
  164. package/dist/pd-icon-button-select-group.d.ts.map +0 -1
  165. package/dist/pd-icon-panel-button.d.ts +0 -24
  166. package/dist/pd-icon-panel-button.d.ts.map +0 -1
  167. package/dist/pd-input-area.d.ts.map +0 -1
  168. package/dist/pd-input-file.d.ts.map +0 -1
  169. package/dist/pd-input-time.d.ts.map +0 -1
  170. package/dist/pd-input.d.ts.map +0 -1
  171. package/dist/pd-radio-group.d.ts.map +0 -1
  172. package/dist/pd-range.d.ts.map +0 -1
  173. package/dist/pd-select.d.ts.map +0 -1
  174. package/dist/stories/button.stories.d.ts +0 -22
  175. package/dist/stories/button.stories.d.ts.map +0 -1
  176. package/dist/stories/checkbox.stories.d.ts.map +0 -1
  177. package/dist/stories/form-container.stories.d.ts.map +0 -1
  178. package/dist/stories/form-container2.stories.d.ts.map +0 -1
  179. package/dist/stories/form-container3.stories.d.ts.map +0 -1
  180. package/dist/stories/form-row.stories.d.ts.map +0 -1
  181. package/dist/stories/input-area.stories.d.ts.map +0 -1
  182. package/dist/stories/input-file.stories.d.ts.map +0 -1
  183. package/dist/stories/input.stories.d.ts.map +0 -1
  184. package/dist/stories/pd-button-group.stories.d.ts.map +0 -1
  185. package/dist/stories/pd-hover-box.stories.d.ts.map +0 -1
  186. package/dist/stories/pd-icon-button-select-group.stories.d.ts.map +0 -1
  187. package/dist/stories/radio-group.stories.d.ts.map +0 -1
  188. package/dist/stories/range.stories.d.ts.map +0 -1
  189. package/dist/stories/select.stories.d.ts.map +0 -1
  190. /package/dist/{pd-base-ui.d.ts → base/pd-base-ui.d.ts} +0 -0
  191. /package/dist/{stories → pd-button-group}/pd-button-group.stories.d.ts +0 -0
  192. /package/dist/{stories → pd-form-container}/form-container.stories.d.ts +0 -0
  193. /package/dist/{stories → pd-form-container}/form-container2.stories.d.ts +0 -0
  194. /package/dist/{stories → pd-form-container}/form-container3.stories.d.ts +0 -0
  195. /package/dist/{stories → pd-hover-box}/pd-hover-box.stories.d.ts +0 -0
@@ -1,281 +1,8 @@
1
- import { css, html } from "lit";
2
- import { property, customElement } from "lit/decorators.js";
3
- import { classMap } from "lit/directives/class-map.js";
4
- import "@progressive-development/pd-icon/pd-icon";
5
- import { PdBaseUIInput, INPUT_TYPE_CHECK } from "./pd-base-ui-input.js";
6
- import { pdIcons } from "@progressive-development/pd-icon";
7
- var __defProp = Object.defineProperty;
8
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
9
- var __decorateClass = (decorators, target, key, kind) => {
10
- var result = kind > 1 ? void 0 : kind ? __getOwnPropDesc(target, key) : target;
11
- for (var i = decorators.length - 1, decorator; i >= 0; i--)
12
- if (decorator = decorators[i])
13
- result = (kind ? decorator(target, key, result) : decorator(result)) || result;
14
- if (kind && result) __defProp(target, key, result);
15
- return result;
16
- };
17
- let PdCheckbox = class extends PdBaseUIInput {
18
- constructor() {
19
- super();
20
- this.checkType = "CHECK";
21
- this._inputType = INPUT_TYPE_CHECK;
22
- }
23
- setCheckedState(newValue) {
24
- this._value = newValue;
25
- }
26
- render() {
27
- const checked = this._value === "true";
28
- const inputId = `${this.id}Check`;
29
- const classMapVal = {
30
- disabled: this.disabled,
31
- switch: this.checkType === "SWITCH",
32
- "radio-outer": this.checkType === "RADIO",
33
- readonly: this.readonly,
34
- "div-container": true
35
- };
36
- const aClassMap = {
37
- "switch-paddle": this.checkType === "SWITCH",
38
- checkbox: this.checkType === "CHECK",
39
- radio: this.checkType === "RADIO",
40
- isChecked: checked,
41
- isUnchecked: !checked
42
- };
43
- return html`
44
- ${this._renderLabel(inputId)}
45
- <div @click=${this._onClick} class=${classMap(classMapVal)}>
46
- <div class=${classMap(aClassMap)}>
47
- <pd-icon
48
- icon=${this.checkType === "SWITCH" ? pdIcons.ICON_CHECKBOX : this.checkType === "RADIO" ? pdIcons.ICON_CIRCLE : pdIcons.ICON_CHECKBOX_ONLY_CHECK}
49
- class="${this.checkType === "RADIO" ? "round" : ""}"
50
- ?activeIcon=${checked}
51
- ></pd-icon>
52
- </div>
53
- <span class="label"><slot></slot></span>
54
- </div>
55
- ${this._renderErrorMsg()}
56
- `;
57
- }
58
- _onClick(event) {
59
- if (this.disabled || this.readonly) return;
60
- const checked = this._value === "true";
61
- this._handleChangedValue(!checked ? "true" : "false", event, true);
62
- }
63
- _onKeyPress(event) {
64
- event.preventDefault();
65
- if (event.key === " " || event.code === "Space") {
66
- this._onClick(event);
67
- }
68
- }
69
- _onLinkClick(event) {
70
- event.preventDefault();
71
- }
72
- _getInitialValue(reset) {
73
- return reset ? this.initValue || "false" : this.initValue || this._value || "false";
74
- }
75
- clear() {
76
- this.reset();
77
- }
78
- };
79
- PdCheckbox.styles = [
80
- PdBaseUIInput.styles,
81
- css`
82
- :host {
83
- display: inline-block;
1
+ import { PdCheckbox } from './pd-checkbox/PdCheckbox.js';
84
2
 
85
- /* active checkbox */
86
- --pd-icon-bg-col-active: var(
87
- --pd-cb-bg-col,
88
- var(--pd-default-lightest-col)
89
- );
90
- --pd-icon-col-active: var(
91
- --pd-cb-col,
92
- var(--pd-default-success-dark-col)
93
- );
3
+ const tag = "pd-checkbox";
4
+ if (!customElements.get(tag)) {
5
+ customElements.define(tag, PdCheckbox);
6
+ }
94
7
 
95
- /* inactive checkbox */
96
- --pd-icon-bg-col: var(
97
- --pd-cb-unset-bg-col,
98
- var(--pd-default-lightest-col)
99
- );
100
- --pd-icon-col: var(--pd-cb-col, var(--pd-default-error-dark-col));
101
-
102
- --pd-icon-bg-col-hover: var(
103
- --pd-cb-bg-col,
104
- var(--pd-default-light-col)
105
- );
106
- }
107
-
108
- :host([checkType="SWITCH"]) {
109
- /* derzeit keine Angaben */
110
- }
111
-
112
- .div-container {
113
- display: flex;
114
- align-items: center;
115
- cursor: pointer;
116
- }
117
-
118
- .div-container.disabled {
119
- opacity: 0.7;
120
- cursor: auto;
121
- }
122
-
123
- .div-container.readonly {
124
- cursor: auto;
125
- }
126
-
127
- .label {
128
- margin-left: 0.1rem;
129
- color: var(--pd-cb-font-col, var(--pd-default-font-input-col));
130
- font-family: var(--pd-default-font-input-family);
131
- text-align: left;
132
- font-size: var(--pd-default-font-input-size);
133
- }
134
-
135
- .readonly .label {
136
- color: var(--pd-cb-font-col-readonly, #4d4d4d);
137
- }
138
-
139
- .disabled .label {
140
- color: var(--pd-cb-font-col-disabled, #4d4d4d);
141
- }
142
-
143
- /*
144
- * Class checkbox for icon and a element (checkbox case)
145
- */
146
- .checkbox {
147
- display: flex;
148
- border-radius: 4px;
149
- line-height: 0;
150
- align-items: center;
151
- justify-content: center;
152
- }
153
-
154
- .checkbox pd-icon {
155
- --pd-icon-size: 1.3rem;
156
- margin-right: 0.2rem;
157
- margin-bottom: 0.2rem;
158
- border: 2px solid var(--pd-cb-border-col, var(--pd-default-col));
159
- border-radius: var(--pd-cb-border-radius, 3px);
160
- }
161
-
162
- .readonly .checkbox pd-icon,
163
- .disabled .checkbox pd-icon {
164
- border-color: var(--pd-cb-border-col-readonly, darkgrey);
165
- }
166
-
167
- /*
168
- * Class Radio for icon and a element (radio group case)
169
- */
170
- .radio-outer .label {
171
- margin-left: 0.7rem;
172
- }
173
-
174
- .radio {
175
- display: flex;
176
- align-items: center;
177
- justify-content: center;
178
- }
179
-
180
- .radio pd-icon {
181
- --pd-icon-size: 1.5rem;
182
- --pd-icon-round-padding: 0.1rem;
183
- border: 2px solid var(--pd-cb-border-col, var(--pd-default-col));
184
- }
185
-
186
- .readonly .radio pd-icon,
187
- .disabled .radio pd-icon {
188
- border-color: var(--pd-cb-border-col-readonly, darkgrey);
189
- }
190
-
191
- /* Switch styles */
192
- .switch {
193
- height: var(--pd-cb-switch-height);
194
- position: relative;
195
- outline: 0;
196
- -webkit-user-select: none;
197
- -moz-user-select: none;
198
- -ms-user-select: none;
199
- user-select: none;
200
- }
201
-
202
- .switch .label {
203
- margin-left: 0.5rem;
204
- }
205
-
206
- .switch-paddle {
207
- display: inline-block;
208
- vertical-align: baseline;
209
- margin: 0;
210
- position: relative;
211
- min-width: 4.1rem;
212
- max-width: 4.1rem;
213
- height: 1.9rem;
214
- border-radius: 0;
215
- background: var(--pd-cb-switch-paddle-col, var(--pd-default-col));
216
- cursor: pointer;
217
- }
218
-
219
- .switch-paddle pd-icon {
220
- --pd-icon-size: 1.25rem;
221
- position: absolute;
222
- top: 0;
223
- left: 0;
224
- display: block;
225
- -webkit-transform: translate3d(0, 0, 0);
226
- transform: translate3d(0, 0, 0);
227
- border: 2px solid var(--pd-cb-border-col, var(--pd-default-col));
228
- box-shadow: rgba(0, 0, 0, 0.15) 1.95px 1.95px 2.6px;
229
- border-radius: var(--pd-cb-border-radius, 4px);
230
- -webkit-transition: all 0.25s ease-out;
231
- transition: all 0.25s ease-out;
232
- content: "";
233
- }
234
-
235
- .disabled .switch-paddle {
236
- cursor: auto;
237
- }
238
-
239
- .readonly .switch-paddle {
240
- cursor: auto;
241
- max-width: 2rem;
242
- min-width: 2rem;
243
- background: none;
244
-
245
- /* Prüfen TODO
246
- --pd-icon-bg: transparent;
247
- --pd-icon-fill: var(--card-dark-red);
248
- --pd-icon-fill-hover: var(--pd-icon-fill);
249
- --pd-icon-fill-active: var(--card-medium-green);
250
- */
251
- }
252
-
253
- .readonly .switch-paddle pd-icon {
254
- border-color: var(--pd-cb-border-col-readonly, transparent);
255
- }
256
-
257
- .readonly .isChecked.switch-paddle pd-icon {
258
- transform: translate3d(0, 0, 0);
259
- left: 0rem;
260
- }
261
-
262
- .isChecked.switch-paddle pd-icon {
263
- left: 2.25rem;
264
- }
265
-
266
- @media (min-width: 580px) {
267
- :host {
268
- font-size: 1rem;
269
- }
270
- }
271
- `
272
- ];
273
- __decorateClass([
274
- property({ type: String, reflect: true })
275
- ], PdCheckbox.prototype, "checkType", 2);
276
- PdCheckbox = __decorateClass([
277
- customElement("pd-checkbox")
278
- ], PdCheckbox);
279
- export {
280
- PdCheckbox
281
- };
8
+ export { PdCheckbox };
@@ -0,0 +1,42 @@
1
+ import { CSSResultGroup, TemplateResult } from 'lit';
2
+ import { PdBaseUI } from '../base/pd-base-ui.js';
3
+ import { PdFormElementStatus } from '../types.js';
4
+ /**
5
+ * @tagname pd-form-container
6
+ */
7
+ export declare class PdFormContainer extends PdBaseUI {
8
+ /**
9
+ * If true, display info about required fields
10
+ */
11
+ requiredFieldInfo: boolean;
12
+ /**
13
+ * If true, trim fields when values are returned.
14
+ */
15
+ autoTrimm: boolean;
16
+ /**
17
+ * Optional general error message
18
+ */
19
+ commonError: string;
20
+ private _fields;
21
+ static styles: CSSResultGroup;
22
+ connectedCallback(): void;
23
+ disconnectedCallback(): void;
24
+ render(): TemplateResult;
25
+ private _renderValidationInfo;
26
+ private _onRegister;
27
+ private _onUnRegister;
28
+ private _onUnRegisterBound;
29
+ private _onChange;
30
+ private _onBlur;
31
+ private _onFocus;
32
+ private _getOverallValidity;
33
+ triggerValidate(): Promise<boolean>;
34
+ getValues(): {
35
+ origin: Record<string, any>;
36
+ parsed: Record<string, any>;
37
+ };
38
+ reset(): void;
39
+ getStatus(): Map<string, PdFormElementStatus>;
40
+ get valid(): boolean;
41
+ }
42
+ //# sourceMappingURL=PdFormContainer.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PdFormContainer.d.ts","sourceRoot":"","sources":["../../src/pd-form-container/PdFormContainer.ts"],"names":[],"mappings":"AACA;;;;;;;;;GASG;AAEH,OAAO,EAAa,KAAK,cAAc,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAI1E,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACjD,OAAO,EAAE,mBAAmB,EAAE,MAAM,aAAa,CAAC;AAElD;;GAEG;AACH,qBAAa,eAAgB,SAAQ,QAAQ;IAC3C;;OAEG;IAEH,iBAAiB,UAAS;IAE1B;;OAEG;IAEH,SAAS,UAAS;IAElB;;OAEG;IAEH,WAAW,SAAM;IAGjB,OAAO,CAAC,OAAO,CAA+C;IAE9D,OAAgB,MAAM,EAAE,cAAc,CA8BpC;IAEO,iBAAiB,IAAI,IAAI;IA0BzB,oBAAoB,IAAI,IAAI;IA0B5B,MAAM,IAAI,cAAc;IAWjC,OAAO,CAAC,qBAAqB;IAc7B,OAAO,CAAC,WAAW,CA8BjB;IAEF,OAAO,CAAC,aAAa,CAkBnB;IAEF,OAAO,CAAC,kBAAkB,CAAiC;IAE3D,OAAO,CAAC,SAAS,CA2Bf;IAEF,OAAO,CAAC,OAAO,CAQb;IAEF,OAAO,CAAC,QAAQ,CAOd;IAEF,OAAO,CAAC,mBAAmB;IAad,eAAe,IAAI,OAAO,CAAC,OAAO,CAAC;IAYzC,SAAS,IAAI;QAClB,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;QAC5B,MAAM,EAAE,MAAM,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC;KAC7B;IAcM,KAAK,IAAI,IAAI;IAMb,SAAS,IAAI,GAAG,CAAC,MAAM,EAAE,mBAAmB,CAAC;IAIpD,IAAI,KAAK,YAER;CACF"}
@@ -0,0 +1,269 @@
1
+ import { css, html } from 'lit';
2
+ import { property, state } from 'lit/decorators.js';
3
+ import { msg } from '@lit/localize';
4
+ import { PdBaseUI } from '../base/pd-base-ui.js';
5
+
6
+ var __defProp = Object.defineProperty;
7
+ var __decorateClass = (decorators, target, key, kind) => {
8
+ var result = void 0 ;
9
+ for (var i = decorators.length - 1, decorator; i >= 0; i--)
10
+ if (decorator = decorators[i])
11
+ result = (decorator(target, key, result) ) || result;
12
+ if (result) __defProp(target, key, result);
13
+ return result;
14
+ };
15
+ class PdFormContainer extends PdBaseUI {
16
+ constructor() {
17
+ super(...arguments);
18
+ this.requiredFieldInfo = false;
19
+ this.autoTrimm = false;
20
+ this.commonError = "";
21
+ this._fields = /* @__PURE__ */ new Map();
22
+ this._onRegister = (e) => {
23
+ const { name, value, parsedValue, state: state2 } = e.detail;
24
+ console.debug("###### _onRegister", name, value, state2);
25
+ if (!this._fields.has(name)) {
26
+ this._fields.set(name, {
27
+ name,
28
+ value,
29
+ parsedValue,
30
+ valid: state2.valid,
31
+ invalid: state2.invalid,
32
+ pristine: state2.pristine,
33
+ dirty: state2.dirty,
34
+ touched: state2.touched,
35
+ focused: state2.focus,
36
+ errors: {},
37
+ element: e.target
38
+ });
39
+ this.requestUpdate();
40
+ this.dispatchEvent(
41
+ new CustomEvent("pd-form-change", {
42
+ detail: {
43
+ overallValidity: this._getOverallValidity()
44
+ }
45
+ })
46
+ );
47
+ }
48
+ e.stopPropagation();
49
+ };
50
+ this._onUnRegister = (e) => {
51
+ const { name, value } = e.detail;
52
+ console.debug("###### _onUnRegister", name, value);
53
+ if (this._fields.has(name)) {
54
+ this._fields.delete(name);
55
+ this.requestUpdate();
56
+ this.dispatchEvent(
57
+ new CustomEvent("pd-form-change", {
58
+ detail: {
59
+ overallValidity: this._getOverallValidity()
60
+ }
61
+ })
62
+ );
63
+ }
64
+ e.stopPropagation();
65
+ };
66
+ this._onUnRegisterBound = this._onUnRegister.bind(this);
67
+ this._onChange = (e) => {
68
+ const { name, value, parsedValue, state: state2 } = e.detail;
69
+ console.debug("###### _onChange", name, value, state2);
70
+ const field = this._fields.get(name);
71
+ if (field) {
72
+ const oldValue = field.value;
73
+ field.value = value;
74
+ field.parsedValue = parsedValue;
75
+ field.pristine = state2.pristine;
76
+ field.dirty = state2.dirty;
77
+ field.touched = state2.touched;
78
+ field.focused = state2.focused;
79
+ field.valid = state2.valid;
80
+ field.invalid = state2.invalid;
81
+ this.requestUpdate();
82
+ if (value !== oldValue) {
83
+ this.dispatchEvent(
84
+ new CustomEvent("pd-form-change", {
85
+ detail: {
86
+ overallValidity: this._getOverallValidity()
87
+ }
88
+ })
89
+ );
90
+ }
91
+ }
92
+ e.stopPropagation();
93
+ };
94
+ this._onBlur = (e) => {
95
+ const { name } = e.detail;
96
+ const field = this._fields.get(name);
97
+ if (field) {
98
+ field.touched = true;
99
+ field.focused = false;
100
+ }
101
+ e.stopPropagation();
102
+ };
103
+ this._onFocus = (e) => {
104
+ const { name } = e.detail;
105
+ const field = this._fields.get(name);
106
+ if (field) {
107
+ field.focused = true;
108
+ }
109
+ e.stopPropagation();
110
+ };
111
+ }
112
+ static {
113
+ this.styles = [
114
+ PdBaseUI.styles,
115
+ css`
116
+ :host {
117
+ display: flex;
118
+ flex-direction: column;
119
+ align-items: flex-start;
120
+ }
121
+
122
+ .validation-info {
123
+ font-family: var(--pd-default-font-content-family);
124
+ font-size: var(--pd-form-info-font-size, 0.8em);
125
+ padding-top: 0.8em;
126
+ color: var(--pd-form-container-default-col, var(--pd-default-dark-col));
127
+ }
128
+
129
+ .valid {
130
+ color: var(
131
+ --pd-form-container-valid-col,
132
+ var(--pd-default-success-dark-col)
133
+ );
134
+ }
135
+
136
+ .invalid {
137
+ color: var(
138
+ --pd-form-container-invalid-col,
139
+ var(--pd-default-error-dark-col)
140
+ );
141
+ }
142
+ `
143
+ ];
144
+ }
145
+ connectedCallback() {
146
+ super.connectedCallback();
147
+ this.addEventListener(
148
+ "pd-form-element-register",
149
+ this._onRegister
150
+ );
151
+ this.addEventListener(
152
+ "pd-form-element-change",
153
+ this._onChange
154
+ );
155
+ this.addEventListener(
156
+ "pd-form-element-blur",
157
+ this._onBlur
158
+ );
159
+ this.addEventListener(
160
+ "pd-form-element-focus",
161
+ this._onFocus
162
+ );
163
+ document.addEventListener(
164
+ "pd-form-element-unregister",
165
+ this._onUnRegisterBound
166
+ );
167
+ }
168
+ disconnectedCallback() {
169
+ super.disconnectedCallback();
170
+ this.removeEventListener(
171
+ "pd-form-element-register",
172
+ this._onRegister
173
+ );
174
+ this.removeEventListener(
175
+ "pd-form-element-change",
176
+ this._onChange
177
+ );
178
+ this.removeEventListener(
179
+ "pd-form-element-blur",
180
+ this._onBlur
181
+ );
182
+ this.removeEventListener(
183
+ "pd-form-element-focus",
184
+ this._onFocus
185
+ );
186
+ document.removeEventListener(
187
+ "pd-form-element-unregister",
188
+ this._onUnRegisterBound
189
+ );
190
+ }
191
+ render() {
192
+ return html`
193
+ <form>
194
+ <slot></slot>
195
+ ${this.requiredFieldInfo || this.commonError ? this._renderValidationInfo() : ""}
196
+ </form>
197
+ `;
198
+ }
199
+ _renderValidationInfo() {
200
+ const allValid = this._getOverallValidity() && !this.commonError;
201
+ return html`
202
+ <p class="validation-info ${allValid ? "valid" : "invalid"}">
203
+ ${allValid ? msg("* Felder ausgefüllt", { id: "pd.form.required.valid" }) : this.commonError || msg("* Pflichtfeld fehlt oder fehlerhaft", {
204
+ id: "pd.form.required.missing"
205
+ })}
206
+ </p>
207
+ `;
208
+ }
209
+ _getOverallValidity() {
210
+ if (this._fields.size === 0) {
211
+ return false;
212
+ }
213
+ for (const field of this._fields.values()) {
214
+ if (field.invalid) {
215
+ return false;
216
+ }
217
+ }
218
+ return true;
219
+ }
220
+ async triggerValidate() {
221
+ const validations = [];
222
+ this._fields.forEach((field) => {
223
+ const result = field.element?.runValidators();
224
+ if (result instanceof Promise) {
225
+ validations.push(result);
226
+ }
227
+ });
228
+ await Promise.all(validations);
229
+ return this._getOverallValidity();
230
+ }
231
+ getValues() {
232
+ const origin = {};
233
+ const parsed = {};
234
+ this._fields.forEach((field, key) => {
235
+ let value = field.value;
236
+ if (this.autoTrimm === true && typeof value === "string") {
237
+ value = value.trim();
238
+ }
239
+ origin[key] = value;
240
+ parsed[key] = field.parsedValue;
241
+ });
242
+ return { origin, parsed };
243
+ }
244
+ reset() {
245
+ this._fields.forEach((field) => {
246
+ field.element?.reset();
247
+ });
248
+ }
249
+ getStatus() {
250
+ return this._fields;
251
+ }
252
+ get valid() {
253
+ return this._getOverallValidity();
254
+ }
255
+ }
256
+ __decorateClass([
257
+ property({ type: Boolean })
258
+ ], PdFormContainer.prototype, "requiredFieldInfo");
259
+ __decorateClass([
260
+ property({ type: Boolean })
261
+ ], PdFormContainer.prototype, "autoTrimm");
262
+ __decorateClass([
263
+ property({ type: String })
264
+ ], PdFormContainer.prototype, "commonError");
265
+ __decorateClass([
266
+ state()
267
+ ], PdFormContainer.prototype, "_fields");
268
+
269
+ export { PdFormContainer };
@@ -0,0 +1 @@
1
+ {"version":3,"file":"form-container.stories.d.ts","sourceRoot":"","sources":["../../src/pd-form-container/form-container.stories.ts"],"names":[],"mappings":"AAEA,OAAO,EAAQ,QAAQ,EAAE,MAAM,2BAA2B,CAAC;AAE3D,OAAO,wBAAwB,CAAC;AAChC,OAAO,+BAA+B,CAAC;AACvC,OAAO,yBAAyB,CAAC;AACjC,OAAO,mCAAmC,CAAC;AAC3C,OAAO,mCAAmC,CAAC;AAC3C,OAAO,yBAAyB,CAAC;AAGjC,QAAA,MAAM,IAAI;;;;;;;;;;;;;;;;;;;;;CAeM,CAAC;AAEjB,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC;AAUtB,eAAO,MAAM,aAAa,EAAE,KAwI3B,CAAC;AAEF,eAAO,MAAM,4BAA4B,EAAE,KAiH1C,CAAC"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"form-container2.stories.d.ts","sourceRoot":"","sources":["../../src/pd-form-container/form-container2.stories.ts"],"names":[],"mappings":"AACA,OAAO,EAAQ,QAAQ,EAAE,MAAM,2BAA2B,CAAC;AAM3D,OAAO,wBAAwB,CAAC;AAChC,OAAO,+BAA+B,CAAC;AACvC,OAAO,yBAAyB,CAAC;AACjC,OAAO,mCAAmC,CAAC;AAC3C,OAAO,yBAAyB,CAAC;AACjC,OAAO,2BAA2B,CAAC;AACnC,OAAO,qCAAqC,CAAC;AAC7C,OAAO,+BAA+B,CAAC;AACvC,OAAO,mCAAmC,CAAC;AAC3C,OAAO,mCAAmC,CAAC;AAE3C,QAAA,MAAM,IAAI;;CAEM,CAAC;AAEjB,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC;AAStB,eAAO,MAAM,qBAAqB,EAAE,KA0RnC,CAAC"}
@@ -0,0 +1 @@
1
+ {"version":3,"file":"form-container3.stories.d.ts","sourceRoot":"","sources":["../../src/pd-form-container/form-container3.stories.ts"],"names":[],"mappings":"AACA,OAAO,EAAQ,QAAQ,EAAE,MAAM,2BAA2B,CAAC;AAK3D,OAAO,wBAAwB,CAAC;AAChC,OAAO,+BAA+B,CAAC;AACvC,OAAO,yBAAyB,CAAC;AACjC,OAAO,mCAAmC,CAAC;AAC3C,OAAO,yBAAyB,CAAC;AACjC,OAAO,2BAA2B,CAAC;AACnC,OAAO,qCAAqC,CAAC;AAC7C,OAAO,+BAA+B,CAAC;AACvC,OAAO,mCAAmC,CAAC;AAC3C,OAAO,mCAAmC,CAAC;AAE3C,QAAA,MAAM,IAAI;;CAEM,CAAC;AAEjB,eAAe,IAAI,CAAC;AACpB,KAAK,KAAK,GAAG,QAAQ,CAAC;AAStB,eAAO,MAAM,uBAAuB,EAAE,KA8DrC,CAAC;AAEF,eAAO,MAAM,2BAA2B,EAAE,KAiEzC,CAAC;AAEF,eAAO,MAAM,iCAAiC,EAAE,KAiF/C,CAAC;AAEF,eAAO,MAAM,4BAA4B,EAAE,KA4D1C,CAAC"}
@@ -0,0 +1,3 @@
1
+ import { PdFormContainer } from './PdFormContainer.js';
2
+ export { PdFormContainer };
3
+ //# sourceMappingURL=pd-form-container.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pd-form-container.d.ts","sourceRoot":"","sources":["../../src/pd-form-container/pd-form-container.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,sBAAsB,CAAC;AAOvD,OAAO,EAAE,eAAe,EAAE,CAAC"}
@@ -1,36 +1,2 @@
1
- import { CSSResultGroup, TemplateResult } from 'lit';
2
- import { PdBaseUI } from './pd-base-ui.js';
3
- import { PdFormElementStatus } from './types.js';
4
- export declare class PdFormContainer extends PdBaseUI {
5
- /**
6
- * If true, display info about required fields
7
- */
8
- requiredFieldInfo: boolean;
9
- /**
10
- * If true, trim fields when values are returned.
11
- */
12
- autoTrimm: boolean;
13
- /**
14
- * Optional general error message
15
- */
16
- commonError: string;
17
- private _fields;
18
- static styles: CSSResultGroup;
19
- connectedCallback(): void;
20
- disconnectedCallback(): void;
21
- render(): TemplateResult;
22
- private _renderValidationInfo;
23
- private _onRegister;
24
- private _onUnRegister;
25
- private _onUnRegisterBound;
26
- private _onChange;
27
- private _onBlur;
28
- private _onFocus;
29
- private _getOverallValidity;
30
- triggerValidate(): Promise<boolean>;
31
- getValues(): Record<string, any>;
32
- reset(): void;
33
- getStatus(): Map<string, PdFormElementStatus>;
34
- get valid(): boolean;
35
- }
36
- //# sourceMappingURL=pd-form-container.d.ts.map
1
+ export * from './pd-form-container/pd-form-container'
2
+ export {}