@sbb-esta/lyne-elements 2.5.0 → 2.6.0

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 (245) hide show
  1. package/autocomplete/autocomplete-base-element.d.ts +19 -21
  2. package/autocomplete/autocomplete-base-element.d.ts.map +1 -1
  3. package/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.d.ts.map +1 -1
  4. package/autocomplete-grid/autocomplete-grid-button.js +7 -7
  5. package/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.d.ts +2 -2
  6. package/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.d.ts.map +1 -1
  7. package/autocomplete.js +145 -136
  8. package/chip/chip/chip.d.ts +32 -0
  9. package/chip/chip/chip.d.ts.map +1 -0
  10. package/chip/chip-group/chip-group.d.ts +100 -0
  11. package/chip/chip-group/chip-group.d.ts.map +1 -0
  12. package/chip/chip-group.d.ts +2 -0
  13. package/chip/chip-group.d.ts.map +1 -0
  14. package/chip/chip-group.js +225 -0
  15. package/chip/chip.d.ts +2 -0
  16. package/chip/chip.d.ts.map +1 -0
  17. package/chip/chip.js +85 -0
  18. package/chip.d.ts +3 -0
  19. package/chip.d.ts.map +1 -0
  20. package/chip.js +2 -0
  21. package/clock/clock.d.ts.map +1 -1
  22. package/clock.js +1 -1
  23. package/core/base-elements/button-base-element.d.ts +5 -0
  24. package/core/base-elements/button-base-element.d.ts.map +1 -1
  25. package/core/base-elements.js +94 -79
  26. package/core/controllers/id-observer-controller.d.ts +21 -0
  27. package/core/controllers/id-observer-controller.d.ts.map +1 -0
  28. package/core/controllers/media-matchers-controller.d.ts.map +1 -1
  29. package/core/controllers.d.ts +2 -1
  30. package/core/controllers.d.ts.map +1 -1
  31. package/core/controllers.js +135 -80
  32. package/core/datetime/native-date-adapter.d.ts.map +1 -1
  33. package/core/datetime.js +8 -3
  34. package/core/dom/find-referenced-element.d.ts +1 -0
  35. package/core/dom/find-referenced-element.d.ts.map +1 -1
  36. package/core/dom/input-element.d.ts +3 -1
  37. package/core/dom/input-element.d.ts.map +1 -1
  38. package/core/dom/platform.d.ts +5 -0
  39. package/core/dom/platform.d.ts.map +1 -1
  40. package/core/dom.js +10 -9
  41. package/core/i18n/i18n.d.ts +3 -0
  42. package/core/i18n/i18n.d.ts.map +1 -1
  43. package/core/i18n.js +135 -117
  44. package/core/mixins/form-associated-input-mixin.d.ts.map +1 -1
  45. package/core/mixins/form-associated-radio-button-mixin.d.ts.map +1 -1
  46. package/core/mixins.js +71 -63
  47. package/core/overlay/overlay-trigger-attributes.d.ts +1 -1
  48. package/core/overlay/overlay-trigger-attributes.d.ts.map +1 -1
  49. package/core/overlay/position.d.ts +1 -1
  50. package/core/overlay/position.d.ts.map +1 -1
  51. package/core/styles/core.scss +89 -24
  52. package/core/styles/image.scss +1 -1
  53. package/core/styles/mixins/table.scss +63 -26
  54. package/core/styles/table.scss +16 -0
  55. package/core/testing/scroll.d.ts +1 -0
  56. package/core/testing/scroll.d.ts.map +1 -1
  57. package/core/testing/wait-for-image-ready.d.ts.map +1 -1
  58. package/core/testing.js +8 -5
  59. package/core.css +90 -34
  60. package/custom-elements.json +2568 -740
  61. package/datepicker/datepicker/datepicker.d.ts +4 -4
  62. package/datepicker/datepicker/datepicker.d.ts.map +1 -1
  63. package/datepicker/datepicker-toggle/datepicker-toggle.d.ts +0 -3
  64. package/datepicker/datepicker-toggle/datepicker-toggle.d.ts.map +1 -1
  65. package/datepicker/datepicker-toggle.js +30 -34
  66. package/datepicker/datepicker.js +103 -105
  67. package/development/autocomplete/autocomplete-base-element.d.ts +19 -21
  68. package/development/autocomplete/autocomplete-base-element.d.ts.map +1 -1
  69. package/development/autocomplete-grid/autocomplete-grid-button/autocomplete-grid-button.d.ts.map +1 -1
  70. package/development/autocomplete-grid/autocomplete-grid-button.js +3 -3
  71. package/development/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.d.ts +2 -2
  72. package/development/autocomplete-grid/autocomplete-grid-optgroup/autocomplete-grid-optgroup.d.ts.map +1 -1
  73. package/development/autocomplete-grid/autocomplete-grid-optgroup.js +1 -1
  74. package/development/autocomplete.js +104 -82
  75. package/development/chip/chip/chip.d.ts +32 -0
  76. package/development/chip/chip/chip.d.ts.map +1 -0
  77. package/development/chip/chip-group/chip-group.d.ts +100 -0
  78. package/development/chip/chip-group/chip-group.d.ts.map +1 -0
  79. package/development/chip/chip-group.d.ts +2 -0
  80. package/development/chip/chip-group.d.ts.map +1 -0
  81. package/development/chip/chip-group.js +349 -0
  82. package/development/chip/chip.d.ts +2 -0
  83. package/development/chip/chip.d.ts.map +1 -0
  84. package/development/chip/chip.js +212 -0
  85. package/development/chip.d.ts +3 -0
  86. package/development/chip.d.ts.map +1 -0
  87. package/development/chip.js +3 -0
  88. package/development/clock/clock.d.ts.map +1 -1
  89. package/development/clock.js +5 -2
  90. package/development/core/base-elements/button-base-element.d.ts +5 -0
  91. package/development/core/base-elements/button-base-element.d.ts.map +1 -1
  92. package/development/core/base-elements.js +38 -10
  93. package/development/core/controllers/id-observer-controller.d.ts +21 -0
  94. package/development/core/controllers/id-observer-controller.d.ts.map +1 -0
  95. package/development/core/controllers/media-matchers-controller.d.ts.map +1 -1
  96. package/development/core/controllers.d.ts +2 -1
  97. package/development/core/controllers.d.ts.map +1 -1
  98. package/development/core/controllers.js +116 -44
  99. package/development/core/datetime/native-date-adapter.d.ts.map +1 -1
  100. package/development/core/datetime.js +6 -2
  101. package/development/core/dom/find-referenced-element.d.ts +1 -0
  102. package/development/core/dom/find-referenced-element.d.ts.map +1 -1
  103. package/development/core/dom/input-element.d.ts +3 -1
  104. package/development/core/dom/input-element.d.ts.map +1 -1
  105. package/development/core/dom/platform.d.ts +5 -0
  106. package/development/core/dom/platform.d.ts.map +1 -1
  107. package/development/core/dom.js +3 -1
  108. package/development/core/i18n/i18n.d.ts +3 -0
  109. package/development/core/i18n/i18n.d.ts.map +1 -1
  110. package/development/core/i18n.js +23 -2
  111. package/development/core/mixins/form-associated-input-mixin.d.ts.map +1 -1
  112. package/development/core/mixins/form-associated-radio-button-mixin.d.ts.map +1 -1
  113. package/development/core/mixins.js +19 -6
  114. package/development/core/overlay/overlay-trigger-attributes.d.ts +1 -1
  115. package/development/core/overlay/overlay-trigger-attributes.d.ts.map +1 -1
  116. package/development/core/overlay/position.d.ts +1 -1
  117. package/development/core/overlay/position.d.ts.map +1 -1
  118. package/development/core/overlay.js +1 -1
  119. package/development/core/testing/scroll.d.ts +1 -0
  120. package/development/core/testing/scroll.d.ts.map +1 -1
  121. package/development/core/testing/wait-for-image-ready.d.ts.map +1 -1
  122. package/development/core/testing.js +6 -2
  123. package/development/datepicker/datepicker/datepicker.d.ts +4 -4
  124. package/development/datepicker/datepicker/datepicker.d.ts.map +1 -1
  125. package/development/datepicker/datepicker-toggle/datepicker-toggle.d.ts +0 -3
  126. package/development/datepicker/datepicker-toggle/datepicker-toggle.d.ts.map +1 -1
  127. package/development/datepicker/datepicker-toggle.js +4 -12
  128. package/development/datepicker/datepicker.js +46 -43
  129. package/development/dialog/dialog-title/dialog-title.d.ts +0 -1
  130. package/development/dialog/dialog-title/dialog-title.d.ts.map +1 -1
  131. package/development/dialog/dialog-title.js +2 -5
  132. package/development/expansion-panel/expansion-panel/expansion-panel.d.ts +0 -2
  133. package/development/expansion-panel/expansion-panel/expansion-panel.d.ts.map +1 -1
  134. package/development/expansion-panel/expansion-panel.js +2 -7
  135. package/development/flip-card/flip-card-details/flip-card-details.d.ts.map +1 -1
  136. package/development/flip-card/flip-card-details.js +3 -3
  137. package/development/form-field/form-field/form-field.d.ts.map +1 -1
  138. package/development/form-field/form-field.js +13 -146
  139. package/development/header/header/header.d.ts +6 -7
  140. package/development/header/header/header.d.ts.map +1 -1
  141. package/development/header/header.js +45 -34
  142. package/development/menu/menu/menu.d.ts +7 -8
  143. package/development/menu/menu/menu.d.ts.map +1 -1
  144. package/development/menu/menu.js +42 -41
  145. package/development/navigation/navigation/navigation.d.ts +7 -8
  146. package/development/navigation/navigation/navigation.d.ts.map +1 -1
  147. package/development/navigation/navigation-marker/navigation-marker.d.ts.map +1 -1
  148. package/development/navigation/navigation-marker.js +3 -3
  149. package/development/navigation/navigation-section/navigation-section.d.ts +8 -9
  150. package/development/navigation/navigation-section/navigation-section.d.ts.map +1 -1
  151. package/development/navigation/navigation-section.js +50 -47
  152. package/development/navigation/navigation.js +42 -40
  153. package/development/option/optgroup/optgroup-base-element.d.ts.map +1 -1
  154. package/development/option/optgroup/optgroup.d.ts +2 -2
  155. package/development/option/optgroup/optgroup.d.ts.map +1 -1
  156. package/development/option/optgroup.js +3 -3
  157. package/development/option/option/option-base-element.d.ts.map +1 -1
  158. package/development/option/option.js +3 -3
  159. package/development/paginator/paginator.js +12 -1
  160. package/development/popover/popover/popover.d.ts +8 -7
  161. package/development/popover/popover/popover.d.ts.map +1 -1
  162. package/development/popover/popover.js +28 -35
  163. package/development/radio-button/radio-button-group/radio-button-group.d.ts +0 -1
  164. package/development/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
  165. package/development/radio-button/radio-button-group.js +3 -5
  166. package/development/select/select.d.ts +6 -3
  167. package/development/select/select.d.ts.map +1 -1
  168. package/development/select.js +20 -18
  169. package/development/selection-expansion-panel/selection-expansion-panel.d.ts +0 -2
  170. package/development/selection-expansion-panel/selection-expansion-panel.d.ts.map +1 -1
  171. package/development/selection-expansion-panel.js +2 -7
  172. package/development/sidebar/sidebar/sidebar.d.ts.map +1 -1
  173. package/development/sidebar/sidebar.js +3 -3
  174. package/development/stepper/step/step.d.ts +13 -1
  175. package/development/stepper/step/step.d.ts.map +1 -1
  176. package/development/stepper/step-label.js +2 -2
  177. package/development/stepper/step.js +21 -6
  178. package/development/stepper/stepper/stepper.d.ts +1 -0
  179. package/development/stepper/stepper/stepper.d.ts.map +1 -1
  180. package/development/stepper/stepper.js +5 -1
  181. package/development/table/table-wrapper.js +2 -1
  182. package/development/time-input/time-input.d.ts +6 -8
  183. package/development/time-input/time-input.d.ts.map +1 -1
  184. package/development/time-input.js +42 -44
  185. package/dialog/dialog-title/dialog-title.d.ts +0 -1
  186. package/dialog/dialog-title/dialog-title.d.ts.map +1 -1
  187. package/dialog/dialog-title.js +18 -21
  188. package/expansion-panel/expansion-panel/expansion-panel.d.ts +0 -2
  189. package/expansion-panel/expansion-panel/expansion-panel.d.ts.map +1 -1
  190. package/expansion-panel/expansion-panel.js +53 -56
  191. package/flip-card/flip-card-details/flip-card-details.d.ts.map +1 -1
  192. package/flip-card/flip-card-details.js +8 -8
  193. package/form-field/form-field/form-field.d.ts.map +1 -1
  194. package/form-field/form-field.js +103 -98
  195. package/header/header/header.d.ts +6 -7
  196. package/header/header/header.d.ts.map +1 -1
  197. package/header/header.js +72 -70
  198. package/index.d.ts +4 -0
  199. package/index.js +4 -0
  200. package/menu/menu/menu.d.ts +7 -8
  201. package/menu/menu/menu.d.ts.map +1 -1
  202. package/menu/menu.js +73 -73
  203. package/navigation/navigation/navigation.d.ts +7 -8
  204. package/navigation/navigation/navigation.d.ts.map +1 -1
  205. package/navigation/navigation-marker/navigation-marker.d.ts.map +1 -1
  206. package/navigation/navigation-marker.js +4 -4
  207. package/navigation/navigation-section/navigation-section.d.ts +8 -9
  208. package/navigation/navigation-section/navigation-section.d.ts.map +1 -1
  209. package/navigation/navigation-section.js +75 -77
  210. package/navigation/navigation.js +70 -70
  211. package/option/optgroup/optgroup-base-element.d.ts.map +1 -1
  212. package/option/optgroup/optgroup.d.ts +2 -2
  213. package/option/optgroup/optgroup.d.ts.map +1 -1
  214. package/option/optgroup.js +13 -13
  215. package/option/option/option-base-element.d.ts.map +1 -1
  216. package/option/option.js +2 -2
  217. package/package.json +16 -1
  218. package/paginator/paginator.js +44 -44
  219. package/popover/popover/popover.d.ts +8 -7
  220. package/popover/popover/popover.d.ts.map +1 -1
  221. package/popover/popover.js +73 -73
  222. package/radio-button/radio-button-group/radio-button-group.d.ts +0 -1
  223. package/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
  224. package/radio-button/radio-button-group.js +8 -8
  225. package/select/select.d.ts +6 -3
  226. package/select/select.d.ts.map +1 -1
  227. package/select.js +73 -73
  228. package/selection-expansion-panel/selection-expansion-panel.d.ts +0 -2
  229. package/selection-expansion-panel/selection-expansion-panel.d.ts.map +1 -1
  230. package/selection-expansion-panel.js +10 -13
  231. package/sidebar/sidebar/sidebar.d.ts.map +1 -1
  232. package/sidebar/sidebar.js +2 -2
  233. package/standard-theme.css +166 -79
  234. package/stepper/step/step.d.ts +13 -1
  235. package/stepper/step/step.d.ts.map +1 -1
  236. package/stepper/step-label.js +1 -1
  237. package/stepper/step.js +34 -23
  238. package/stepper/stepper/stepper.d.ts +1 -0
  239. package/stepper/stepper/stepper.d.ts.map +1 -1
  240. package/stepper/stepper.js +19 -16
  241. package/table/table-wrapper.js +4 -4
  242. package/table.css +75 -44
  243. package/time-input/time-input.d.ts +6 -8
  244. package/time-input/time-input.d.ts.map +1 -1
  245. package/time-input.js +66 -73
@@ -0,0 +1,100 @@
1
+ import { CSSResultGroup, LitElement, PropertyValues, TemplateResult } from 'lit';
2
+ import { FormRestoreReason, FormRestoreState } from '../../core/mixins.js';
3
+ export interface SbbChipInputTokenEndEventDetails {
4
+ /** The element that triggered the chip creation */
5
+ origin: 'input' | 'autocomplete';
6
+ /** The value of the new chip. Either the input or the option value depending on the origin */
7
+ value: string;
8
+ label?: string;
9
+ /** Set a new value for the chip that will be created */
10
+ setValue(value: string): void;
11
+ /** Set a label for the chip that will be created */
12
+ setLabel(value: string): void;
13
+ }
14
+ declare const SbbChipGroupElement_base: import('../../core/mixins.js').AbstractConstructor<import('../../core/mixins.js').SbbRequiredMixinType> & import('../../core/mixins.js').AbstractConstructor<import('../../core/mixins.js').SbbDisabledMixinType> & import('../../core/mixins.js').AbstractConstructor<import('../../core/mixins.js').SbbNegativeMixinType> & import('../../core/mixins.js').AbstractConstructor<import('../../core/mixins.js').SbbFormAssociatedMixinType<string[]>> & typeof LitElement;
15
+ /**
16
+ * The `sbb-chip-group` component is used as a container for one or multiple `sbb-chip`.
17
+ *
18
+ * @event {CustomEvent<void>} change - Notifies that the component's value has changed.
19
+ * @event {CustomEvent<void>} input - Notifies that the component's value has changed.
20
+ * @event {CustomEvent<SbbChipInputTokenEndEventDetails>} chipInputTokenEnd - Notifies that a chip is about to be created. Can be used to customize the value and the label. Can be prevented.
21
+ * @slot - Use the unnamed slot to add `sbb-chip` elements.
22
+ * @overrideType value - string[] | null
23
+ */
24
+ export declare class SbbChipGroupElement extends SbbChipGroupElement_base {
25
+ static styles: CSSResultGroup;
26
+ static readonly events: {
27
+ readonly input: "input";
28
+ readonly change: "change";
29
+ readonly chipInputTokenEnd: "chipInputTokenEnd";
30
+ };
31
+ /** Value of the form element. */
32
+ set value(value: string[] | null);
33
+ get value(): string[];
34
+ /** The array of keys that will trigger a `chipInputTokenEnd` event. Default `['Enter']` */
35
+ accessor separatorKeys: string[];
36
+ /** Notifies that the component's value has changed. */
37
+ private _change;
38
+ /** Notifies that the component's value has changed. */
39
+ private _input;
40
+ /** Notifies that a chip is about to be created. Can be prevented. */
41
+ private _chipInputTokenEnd;
42
+ /**
43
+ * Listens to the changes on `readonly` and `disabled` attributes of `<input>`.
44
+ */
45
+ private _inputAttributeObserver;
46
+ /**
47
+ * Listens to the 'size' changes on the `sbb-form-field`.
48
+ */
49
+ private _formFieldAttributeObserver;
50
+ private _inputElement;
51
+ private _inputAbortController;
52
+ private _language;
53
+ constructor();
54
+ connectedCallback(): void;
55
+ protected willUpdate(changedProperties: PropertyValues): void;
56
+ /** @internal */
57
+ formResetCallback(): void;
58
+ /** @internal */
59
+ formStateRestoreCallback(state: FormRestoreState | null, _reason: FormRestoreReason): void;
60
+ protected updateFormValue(): void;
61
+ protected shouldValidate(name: PropertyKey | undefined): boolean;
62
+ protected validate(): void;
63
+ /** Return the list of chip elements **/
64
+ private _chipElements;
65
+ /** Return the list of enabled chip elements **/
66
+ private _enabledChipElements;
67
+ private _setupComponent;
68
+ /**
69
+ * Listen for keyboard events on the chip elements
70
+ **/
71
+ private _onChipKeyDown;
72
+ /**
73
+ * Listen for keyboard events on the input
74
+ **/
75
+ private _onInputKeyDown;
76
+ /**
77
+ * If the input is not empty, create a chip with its value
78
+ */
79
+ private _createChipFromInput;
80
+ private _deleteChip;
81
+ /**
82
+ * Focus an enabled chip. If none are present, focus the input
83
+ * @param index The index of the enabled chip. If null, focus the last one.
84
+ */
85
+ private _focusChip;
86
+ private _emitInputEvents;
87
+ private _createChipElement;
88
+ private _reactToInputChanges;
89
+ private _proxyStateToChips;
90
+ private _inheritSize;
91
+ private _updateInputDescription;
92
+ protected render(): TemplateResult;
93
+ }
94
+ declare global {
95
+ interface HTMLElementTagNameMap {
96
+ 'sbb-chip-group': SbbChipGroupElement;
97
+ }
98
+ }
99
+ export {};
100
+ //# sourceMappingURL=chip-group.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chip-group.d.ts","sourceRoot":"","sources":["../../../../../src/elements/chip/chip-group/chip-group.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAGnB,UAAU,EACV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AASb,OAAO,EACL,KAAK,iBAAiB,EACtB,KAAK,gBAAgB,EAKtB,MAAM,sBAAsB,CAAC;AAK9B,MAAM,WAAW,gCAAgC;IAC/C,mDAAmD;IACnD,MAAM,EAAE,OAAO,GAAG,cAAc,CAAC;IACjC,8FAA8F;IAC9F,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,wDAAwD;IACxD,QAAQ,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IAC9B,oDAAoD;IACpD,QAAQ,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;CAC/B;;AAED;;;;;;;;GAQG;AACH,qBAEM,mBAAoB,SAAQ,wBAIjC;IACC,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;;;MAIlB;IAEX,iCAAiC;IACjC,IACoB,KAAK,CAAC,KAAK,EAAE,MAAM,EAAE,GAAG,IAAI,EA4B/C;IACD,IAAoB,KAAK,IAAI,MAAM,EAAE,CAEpC;IAED,2FAA2F;IAC3F,SACgB,aAAa,EAAE,MAAM,EAAE,CAAa;IAEpD,uDAAuD;IACvD,OAAO,CAAC,OAAO,CAA2E;IAE1F,uDAAuD;IACvD,OAAO,CAAC,MAAM,CAA0E;IAExF,qEAAqE;IACrE,OAAO,CAAC,kBAAkB,CAGxB;IAEF;;OAEG;IACH,OAAO,CAAC,uBAAuB,CAEtB;IAET;;OAEG;IACH,OAAO,CAAC,2BAA2B,CAE1B;IAET,OAAO,CAAC,aAAa,CAA+B;IACpD,OAAO,CAAC,qBAAqB,CAA8B;IAC3D,OAAO,CAAC,SAAS,CAAmC;;IAepC,iBAAiB,IAAI,IAAI;cAKtB,UAAU,CAAC,iBAAiB,EAAE,cAAc,GAAG,IAAI;IAYtE,gBAAgB;IACT,iBAAiB,IAAI,IAAI;IAIhC,gBAAgB;IACT,wBAAwB,CAC7B,KAAK,EAAE,gBAAgB,GAAG,IAAI,EAC9B,OAAO,EAAE,iBAAiB,GACzB,IAAI;IAUP,SAAS,CAAC,eAAe,IAAI,IAAI;cAQd,cAAc,CAAC,IAAI,EAAE,WAAW,GAAG,SAAS,GAAG,OAAO;cAItD,QAAQ,IAAI,IAAI;IASnC,wCAAwC;IACxC,OAAO,CAAC,aAAa;IAIrB,gDAAgD;IAChD,OAAO,CAAC,oBAAoB;IAI5B,OAAO,CAAC,eAAe;IA2CvB;;QAEI;IACJ,OAAO,CAAC,cAAc;IAyBtB;;QAEI;IACJ,OAAO,CAAC,eAAe;IAoBvB;;OAEG;IACH,OAAO,CAAC,oBAAoB;IAuB5B,OAAO,CAAC,WAAW;IAOnB;;;OAGG;IACH,OAAO,CAAC,UAAU;IAgBlB,OAAO,CAAC,gBAAgB;IAKxB,OAAO,CAAC,kBAAkB;IAO1B,OAAO,CAAC,oBAAoB;IAK5B,OAAO,CAAC,kBAAkB;IAQ1B,OAAO,CAAC,YAAY;IAIpB,OAAO,CAAC,uBAAuB;cAUZ,MAAM,IAAI,cAAc;CAO5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,gBAAgB,EAAE,mBAAmB,CAAC;KACvC;CACF"}
@@ -0,0 +1,2 @@
1
+ export * from './chip-group/chip-group.js';
2
+ //# sourceMappingURL=chip-group.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chip-group.d.ts","sourceRoot":"","sources":["../../../../src/elements/chip/chip-group.ts"],"names":[],"mappings":"AAAA,cAAc,4BAA4B,CAAC"}
@@ -0,0 +1,349 @@
1
+ var __typeError = (msg) => {
2
+ throw TypeError(msg);
3
+ };
4
+ var __accessCheck = (obj, member, msg) => member.has(obj) || __typeError("Cannot " + msg);
5
+ var __privateGet = (obj, member, getter) => (__accessCheck(obj, member, "read from private field"), getter ? getter.call(obj) : member.get(obj));
6
+ var __privateAdd = (obj, member, value) => member.has(obj) ? __typeError("Cannot add the same private member more than once") : member instanceof WeakSet ? member.add(obj) : member.set(obj, value);
7
+ var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "write to private field"), setter ? setter.call(obj, value) : member.set(obj, value), value);
8
+ import { __esDecorate, __runInitializers } from "tslib";
9
+ import { css, LitElement, isServer, html } from "lit";
10
+ import { customElement, property } from "lit/decorators.js";
11
+ import { inputAutocompleteEvent } from "../autocomplete.js";
12
+ import { isArrowKeyPressed, getNextElementIndex } from "../core/a11y.js";
13
+ import { SbbLanguageController } from "../core/controllers.js";
14
+ import { isLean } from "../core/dom.js";
15
+ import { EventEmitter } from "../core/eventing.js";
16
+ import { i18nSelectionRequired, i18nChipGroupInputDescription } from "../core/i18n.js";
17
+ import { SbbRequiredMixin, SbbDisabledMixin, SbbNegativeMixin, SbbFormAssociatedMixin } from "../core/mixins.js";
18
+ import { SbbChipElement } from "./chip.js";
19
+ const style = css`*,
20
+ ::before,
21
+ ::after {
22
+ box-sizing: border-box;
23
+ }
24
+
25
+ :host {
26
+ --sbb-chip-group-input-min-width: 9.375rem;
27
+ max-width: 100%;
28
+ }
29
+
30
+ :host([data-size=s]:not([data-empty])) {
31
+ --sbb-chip-group-margin-block: 0.375rem 0.3125rem;
32
+ }
33
+ @media (min-width: calc(52.5rem)) {
34
+ :host([data-size=s]:not([data-empty])) {
35
+ --sbb-chip-group-margin-block: 0.3125rem 0.1875rem;
36
+ }
37
+ }
38
+
39
+ ::slotted(input) {
40
+ flex: 1 1 var(--sbb-chip-group-input-min-width);
41
+ }
42
+
43
+ ::slotted(sbb-chip) {
44
+ max-width: 100%;
45
+ }
46
+
47
+ .sbb-chip-group {
48
+ width: 100%;
49
+ display: flex;
50
+ flex-wrap: wrap;
51
+ gap: var(--sbb-spacing-fixed-1x);
52
+ align-items: center;
53
+ margin-block: var(--sbb-chip-group-margin-block);
54
+ }`;
55
+ let SbbChipGroupElement = (() => {
56
+ var _separatorKeys_accessor_storage, _a;
57
+ let _classDecorators = [customElement("sbb-chip-group")];
58
+ let _classDescriptor;
59
+ let _classExtraInitializers = [];
60
+ let _classThis;
61
+ let _classSuper = SbbRequiredMixin(SbbDisabledMixin(SbbNegativeMixin(SbbFormAssociatedMixin(LitElement))));
62
+ let _instanceExtraInitializers = [];
63
+ let _set_value_decorators;
64
+ let _separatorKeys_decorators;
65
+ let _separatorKeys_initializers = [];
66
+ let _separatorKeys_extraInitializers = [];
67
+ var SbbChipGroupElement2 = (_a = class extends _classSuper {
68
+ constructor() {
69
+ super();
70
+ __privateAdd(this, _separatorKeys_accessor_storage);
71
+ __privateSet(this, _separatorKeys_accessor_storage, (__runInitializers(this, _instanceExtraInitializers), __runInitializers(this, _separatorKeys_initializers, ["Enter"])));
72
+ this._change = (__runInitializers(this, _separatorKeys_extraInitializers), new EventEmitter(this, SbbChipGroupElement2.events.change));
73
+ this._input = new EventEmitter(this, SbbChipGroupElement2.events.input);
74
+ this._chipInputTokenEnd = new EventEmitter(this, SbbChipGroupElement2.events.chipInputTokenEnd);
75
+ this._inputAttributeObserver = !isServer ? new MutationObserver(() => this._reactToInputChanges()) : null;
76
+ this._formFieldAttributeObserver = !isServer ? new MutationObserver(() => this._inheritSize()) : null;
77
+ this._language = new SbbLanguageController(this);
78
+ this.internals.role = "listbox";
79
+ this.addEventListener(SbbChipElement.events.requestDelete, (ev) => this._deleteChip(ev.target));
80
+ this.addEventListener("keydown", (ev) => this._onChipKeyDown(ev));
81
+ }
82
+ /** Value of the form element. */
83
+ set value(value) {
84
+ value = value ?? [];
85
+ super.value = value;
86
+ const oldValue = this.value;
87
+ const toRemove = [...oldValue];
88
+ for (const c of value) {
89
+ if (toRemove.includes(c)) {
90
+ toRemove.splice(toRemove.indexOf(c), 1);
91
+ }
92
+ }
93
+ toRemove.forEach((value2) => {
94
+ var _a2;
95
+ return (_a2 = this._chipElements().find((c) => c.value === value2)) == null ? void 0 : _a2.remove();
96
+ });
97
+ const toAdd = [...value];
98
+ for (const c of oldValue) {
99
+ if (toAdd.includes(c)) {
100
+ toAdd.splice(toAdd.indexOf(c), 1);
101
+ }
102
+ }
103
+ toAdd.forEach((c) => this._createChipElement(c));
104
+ }
105
+ get value() {
106
+ return this._chipElements().map((c) => c.value);
107
+ }
108
+ /** The array of keys that will trigger a `chipInputTokenEnd` event. Default `['Enter']` */
109
+ get separatorKeys() {
110
+ return __privateGet(this, _separatorKeys_accessor_storage);
111
+ }
112
+ set separatorKeys(value) {
113
+ __privateSet(this, _separatorKeys_accessor_storage, value);
114
+ }
115
+ connectedCallback() {
116
+ super.connectedCallback();
117
+ this._setupComponent();
118
+ }
119
+ willUpdate(changedProperties) {
120
+ super.willUpdate(changedProperties);
121
+ if (changedProperties.has("disabled") || changedProperties.has("formDisabled") || changedProperties.has("negative")) {
122
+ this._proxyStateToChips();
123
+ }
124
+ }
125
+ /** @internal */
126
+ formResetCallback() {
127
+ this.value = null;
128
+ }
129
+ /** @internal */
130
+ formStateRestoreCallback(state, _reason) {
131
+ if (!state) {
132
+ this.value = null;
133
+ return;
134
+ }
135
+ this.value = state.map((entries) => entries[1]);
136
+ }
137
+ updateFormValue() {
138
+ const data = new FormData();
139
+ this.value.forEach((el) => data.append(this.name, el));
140
+ this.internals.setFormValue(data);
141
+ this.validate();
142
+ this._updateInputDescription();
143
+ }
144
+ shouldValidate(name) {
145
+ return super.shouldValidate(name) || name === "required";
146
+ }
147
+ validate() {
148
+ super.validate();
149
+ if (this.required && this.value.length === 0) {
150
+ this.setValidityFlag("valueMissing", i18nSelectionRequired[this._language.current]);
151
+ } else {
152
+ this.removeValidityFlag("valueMissing");
153
+ }
154
+ }
155
+ /** Return the list of chip elements **/
156
+ _chipElements() {
157
+ var _a2;
158
+ return Array.from(((_a2 = this.querySelectorAll) == null ? void 0 : _a2.call(this, "sbb-chip")) ?? []);
159
+ }
160
+ /** Return the list of enabled chip elements **/
161
+ _enabledChipElements() {
162
+ var _a2;
163
+ return Array.from(((_a2 = this.querySelectorAll) == null ? void 0 : _a2.call(this, "sbb-chip:not([disabled])")) ?? []);
164
+ }
165
+ _setupComponent() {
166
+ var _a2, _b, _c, _d, _e;
167
+ const input = this.querySelector("input");
168
+ if (input && input !== this._inputElement) {
169
+ (_a2 = this._inputAbortController) == null ? void 0 : _a2.abort();
170
+ (_b = this._inputAttributeObserver) == null ? void 0 : _b.disconnect();
171
+ this._inputElement = input;
172
+ this._inputAbortController = new AbortController();
173
+ this._inputElement.addEventListener("keydown", (ev) => this._onInputKeyDown(ev), {
174
+ signal: this._inputAbortController.signal
175
+ });
176
+ this._inputElement.addEventListener(inputAutocompleteEvent, () => this._createChipFromInput("autocomplete"), {
177
+ signal: this._inputAbortController.signal
178
+ });
179
+ (_c = this._inputAttributeObserver) == null ? void 0 : _c.observe(this._inputElement, {
180
+ attributes: true,
181
+ attributeFilter: ["readonly", "disabled"]
182
+ });
183
+ }
184
+ this._inheritSize();
185
+ (_d = this._formFieldAttributeObserver) == null ? void 0 : _d.disconnect();
186
+ const formField = this.closest("sbb-form-field");
187
+ if (formField) {
188
+ (_e = this._formFieldAttributeObserver) == null ? void 0 : _e.observe(formField, {
189
+ attributes: true,
190
+ attributeFilter: ["size"]
191
+ });
192
+ }
193
+ this.toggleAttribute("data-empty", this.value.length === 0);
194
+ this._reactToInputChanges();
195
+ this.updateFormValue();
196
+ }
197
+ /**
198
+ * Listen for keyboard events on the chip elements
199
+ **/
200
+ _onChipKeyDown(event) {
201
+ const eventTarget = event.target;
202
+ if (eventTarget.localName !== "sbb-chip") {
203
+ return;
204
+ }
205
+ if (isArrowKeyPressed(event)) {
206
+ const focusSteps = this._enabledChipElements();
207
+ const next = getNextElementIndex(event, focusSteps.indexOf(eventTarget), focusSteps.length);
208
+ focusSteps[next].focus();
209
+ return;
210
+ }
211
+ switch (event.key) {
212
+ case "Backspace":
213
+ case "Delete":
214
+ if (!eventTarget.readonly && !eventTarget.disabled) {
215
+ event.preventDefault();
216
+ this._deleteChip(eventTarget);
217
+ }
218
+ break;
219
+ }
220
+ }
221
+ /**
222
+ * Listen for keyboard events on the input
223
+ **/
224
+ _onInputKeyDown(event) {
225
+ switch (event.key) {
226
+ case "Backspace":
227
+ case "ArrowLeft":
228
+ if (!this._inputElement.value) {
229
+ this._focusChip();
230
+ }
231
+ break;
232
+ case "Enter":
233
+ event.preventDefault();
234
+ break;
235
+ }
236
+ if (this.separatorKeys.includes(event.key)) {
237
+ event.preventDefault();
238
+ this._createChipFromInput("input");
239
+ }
240
+ }
241
+ /**
242
+ * If the input is not empty, create a chip with its value
243
+ */
244
+ _createChipFromInput(origin = "input") {
245
+ const inputValue = this._inputElement.value.trim();
246
+ if (!inputValue) {
247
+ return;
248
+ }
249
+ const eventDetail = {
250
+ origin,
251
+ value: inputValue,
252
+ label: void 0,
253
+ setValue: (value) => eventDetail.value = value,
254
+ setLabel: (label) => eventDetail.label = label
255
+ };
256
+ if (!this._chipInputTokenEnd.emit(eventDetail)) {
257
+ return;
258
+ }
259
+ this._createChipElement(eventDetail.value, eventDetail.label);
260
+ this._inputElement.value = "";
261
+ this._emitInputEvents();
262
+ }
263
+ _deleteChip(chip) {
264
+ const chips = this._enabledChipElements();
265
+ chip.remove();
266
+ this._emitInputEvents();
267
+ this._focusChip(chips.indexOf(chip));
268
+ }
269
+ /**
270
+ * Focus an enabled chip. If none are present, focus the input
271
+ * @param index The index of the enabled chip. If null, focus the last one.
272
+ */
273
+ _focusChip(index) {
274
+ var _a2;
275
+ const enabledChips = this._enabledChipElements();
276
+ if (index !== void 0 && enabledChips[index]) {
277
+ enabledChips[index].focus();
278
+ return;
279
+ }
280
+ if (enabledChips.length > 0) {
281
+ enabledChips[enabledChips.length - 1].focus();
282
+ return;
283
+ }
284
+ (_a2 = this._inputElement) == null ? void 0 : _a2.focus();
285
+ }
286
+ _emitInputEvents() {
287
+ this._input.emit();
288
+ this._change.emit();
289
+ }
290
+ _createChipElement(value, label) {
291
+ const newChip = document.createElement("sbb-chip");
292
+ newChip.setAttribute("value", value);
293
+ newChip.innerText = label ?? "";
294
+ this.insertBefore(newChip, this._inputElement);
295
+ }
296
+ _reactToInputChanges() {
297
+ var _a2;
298
+ this.disabled = ((_a2 = this._inputElement) == null ? void 0 : _a2.disabled) ?? false;
299
+ this._proxyStateToChips();
300
+ }
301
+ _proxyStateToChips() {
302
+ this._chipElements().forEach((c) => {
303
+ var _a2;
304
+ c.disabled = this.disabled || this.formDisabled;
305
+ c.readonly = ((_a2 = this._inputElement) == null ? void 0 : _a2.hasAttribute("readonly")) ?? false;
306
+ c.negative = this.negative;
307
+ });
308
+ }
309
+ _inheritSize() {
310
+ var _a2;
311
+ this.setAttribute("data-size", ((_a2 = this.closest("sbb-form-field")) == null ? void 0 : _a2.size) ?? (isLean() ? "s" : "m"));
312
+ }
313
+ _updateInputDescription() {
314
+ if (!this._inputElement) {
315
+ return;
316
+ }
317
+ this._inputElement.setAttribute("aria-description", `${i18nChipGroupInputDescription[this._language.current]} ${this.value.length}`);
318
+ }
319
+ render() {
320
+ return html`
321
+ <div class="sbb-chip-group">
322
+ <slot @slotchange=${this._setupComponent}></slot>
323
+ </div>
324
+ `;
325
+ }
326
+ }, _separatorKeys_accessor_storage = new WeakMap(), _classThis = _a, (() => {
327
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
328
+ _set_value_decorators = [property({ type: Array })];
329
+ _separatorKeys_decorators = [property({ attribute: "separator-keys", type: Array })];
330
+ __esDecorate(_a, null, _set_value_decorators, { kind: "setter", name: "value", static: false, private: false, access: { has: (obj) => "value" in obj, set: (obj, value) => {
331
+ obj.value = value;
332
+ } }, metadata: _metadata }, null, _instanceExtraInitializers);
333
+ __esDecorate(_a, null, _separatorKeys_decorators, { kind: "accessor", name: "separatorKeys", static: false, private: false, access: { has: (obj) => "separatorKeys" in obj, get: (obj) => obj.separatorKeys, set: (obj, value) => {
334
+ obj.separatorKeys = value;
335
+ } }, metadata: _metadata }, _separatorKeys_initializers, _separatorKeys_extraInitializers);
336
+ __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
337
+ SbbChipGroupElement2 = _classThis = _classDescriptor.value;
338
+ if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
339
+ })(), _a.styles = style, _a.events = {
340
+ input: "input",
341
+ change: "change",
342
+ chipInputTokenEnd: "chipInputTokenEnd"
343
+ }, __runInitializers(_classThis, _classExtraInitializers), _a);
344
+ return SbbChipGroupElement2 = _classThis;
345
+ })();
346
+ export {
347
+ SbbChipGroupElement
348
+ };
349
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"chip-group.js","sources":["../../../../src/elements/chip/chip-group/chip-group.ts"],"sourcesContent":["import {\n  type CSSResultGroup,\n  html,\n  isServer,\n  LitElement,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\n\nimport { inputAutocompleteEvent } from '../../autocomplete.js';\nimport { getNextElementIndex, isArrowKeyPressed } from '../../core/a11y.js';\nimport { SbbLanguageController } from '../../core/controllers.js';\nimport { isLean } from '../../core/dom.js';\nimport { EventEmitter } from '../../core/eventing.js';\nimport { i18nChipGroupInputDescription, i18nSelectionRequired } from '../../core/i18n.js';\nimport {\n  type FormRestoreReason,\n  type FormRestoreState,\n  SbbDisabledMixin,\n  SbbFormAssociatedMixin,\n  SbbNegativeMixin,\n  SbbRequiredMixin,\n} from '../../core/mixins.js';\nimport { SbbChipElement } from '../chip.js';\n\nimport style from './chip-group.scss?lit&inline';\n\nexport interface SbbChipInputTokenEndEventDetails {\n  /** The element that triggered the chip creation */\n  origin: 'input' | 'autocomplete';\n  /** The value of the new chip. Either the input or the option value depending on the origin */\n  value: string;\n  label?: string;\n  /** Set a new value for the chip that will be created */\n  setValue(value: string): void;\n  /** Set a label for the chip that will be created */\n  setLabel(value: string): void;\n}\n\n/**\n * The `sbb-chip-group` component is used as a container for one or multiple `sbb-chip`.\n *\n * @event {CustomEvent<void>} change - Notifies that the component's value has changed.\n * @event {CustomEvent<void>} input - Notifies that the component's value has changed.\n * @event {CustomEvent<SbbChipInputTokenEndEventDetails>} chipInputTokenEnd - Notifies that a chip is about to be created. Can be used to customize the value and the label. Can be prevented.\n * @slot - Use the unnamed slot to add `sbb-chip` elements.\n * @overrideType value - string[] | null\n */\nexport\n@customElement('sbb-chip-group')\nclass SbbChipGroupElement extends SbbRequiredMixin(\n  SbbDisabledMixin(\n    SbbNegativeMixin(SbbFormAssociatedMixin<typeof LitElement, string[]>(LitElement)),\n  ),\n) {\n  public static override styles: CSSResultGroup = style;\n  public static readonly events = {\n    input: 'input',\n    change: 'change',\n    chipInputTokenEnd: 'chipInputTokenEnd',\n  } as const;\n\n  /** Value of the form element. */\n  @property({ type: Array })\n  public override set value(value: string[] | null) {\n    value = value ?? [];\n    super.value = value;\n    const oldValue = this.value;\n\n    // Subtract from 'oldValue' the new 'value'\n    // The result are the chips to remove (handle duplicates)\n    const toRemove = [...oldValue];\n    for (const c of value) {\n      if (toRemove.includes(c)) {\n        toRemove.splice(toRemove.indexOf(c), 1);\n      }\n    }\n    toRemove.forEach((value) =>\n      this._chipElements()\n        .find((c) => c.value === value)\n        ?.remove(),\n    );\n\n    // Subtract from the new 'value' what was already present\n    // The result are the new chips to add (handle duplicates)\n    const toAdd = [...value];\n    for (const c of oldValue) {\n      if (toAdd.includes(c)) {\n        toAdd.splice(toAdd.indexOf(c), 1);\n      }\n    }\n    toAdd.forEach((c) => this._createChipElement(c));\n  }\n  public override get value(): string[] {\n    return this._chipElements().map((c) => c.value);\n  }\n\n  /** The array of keys that will trigger a `chipInputTokenEnd` event. Default `['Enter']` */\n  @property({ attribute: 'separator-keys', type: Array })\n  public accessor separatorKeys: string[] = ['Enter'];\n\n  /** Notifies that the component's value has changed. */\n  private _change: EventEmitter = new EventEmitter(this, SbbChipGroupElement.events.change);\n\n  /** Notifies that the component's value has changed. */\n  private _input: EventEmitter = new EventEmitter(this, SbbChipGroupElement.events.input);\n\n  /** Notifies that a chip is about to be created. Can be prevented. */\n  private _chipInputTokenEnd = new EventEmitter<SbbChipInputTokenEndEventDetails>(\n    this,\n    SbbChipGroupElement.events.chipInputTokenEnd,\n  );\n\n  /**\n   * Listens to the changes on `readonly` and `disabled` attributes of `<input>`.\n   */\n  private _inputAttributeObserver = !isServer\n    ? new MutationObserver(() => this._reactToInputChanges())\n    : null;\n\n  /**\n   * Listens to the 'size' changes on the `sbb-form-field`.\n   */\n  private _formFieldAttributeObserver = !isServer\n    ? new MutationObserver(() => this._inheritSize())\n    : null;\n\n  private _inputElement: HTMLInputElement | undefined;\n  private _inputAbortController: AbortController | undefined;\n  private _language = new SbbLanguageController(this);\n\n  public constructor() {\n    super();\n\n    /** @internal */\n    this.internals.role = 'listbox';\n\n    this.addEventListener(SbbChipElement.events.requestDelete, (ev) =>\n      this._deleteChip(ev.target as SbbChipElement),\n    );\n\n    this.addEventListener('keydown', (ev) => this._onChipKeyDown(ev));\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this._setupComponent();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues): void {\n    super.willUpdate(changedProperties);\n\n    if (\n      changedProperties.has('disabled') ||\n      changedProperties.has('formDisabled') ||\n      changedProperties.has('negative')\n    ) {\n      this._proxyStateToChips();\n    }\n  }\n\n  /** @internal */\n  public formResetCallback(): void {\n    this.value = null;\n  }\n\n  /** @internal */\n  public formStateRestoreCallback(\n    state: FormRestoreState | null,\n    _reason: FormRestoreReason,\n  ): void {\n    if (!state) {\n      this.value = null;\n      return;\n    }\n\n    // the state format is ['field-name', 'value'][]\n    this.value = (state as [string, string][]).map((entries) => entries[1]);\n  }\n\n  protected updateFormValue(): void {\n    const data = new FormData();\n    this.value.forEach((el) => data.append(this.name, el));\n    this.internals.setFormValue(data);\n    this.validate();\n    this._updateInputDescription();\n  }\n\n  protected override shouldValidate(name: PropertyKey | undefined): boolean {\n    return super.shouldValidate(name) || name === 'required';\n  }\n\n  protected override validate(): void {\n    super.validate();\n    if (this.required && this.value.length === 0) {\n      this.setValidityFlag('valueMissing', i18nSelectionRequired[this._language.current]);\n    } else {\n      this.removeValidityFlag('valueMissing');\n    }\n  }\n\n  /** Return the list of chip elements **/\n  private _chipElements(): SbbChipElement[] {\n    return Array.from(this.querySelectorAll?.('sbb-chip') ?? []);\n  }\n\n  /** Return the list of enabled chip elements **/\n  private _enabledChipElements(): SbbChipElement[] {\n    return Array.from(this.querySelectorAll?.('sbb-chip:not([disabled])') ?? []);\n  }\n\n  private _setupComponent(): void {\n    const input = this.querySelector('input');\n\n    // Connect to the input\n    if (input && input !== this._inputElement) {\n      this._inputAbortController?.abort();\n      this._inputAttributeObserver?.disconnect();\n      this._inputElement = input;\n\n      this._inputAbortController = new AbortController();\n      this._inputElement.addEventListener('keydown', (ev) => this._onInputKeyDown(ev), {\n        signal: this._inputAbortController.signal,\n      });\n      this._inputElement.addEventListener(\n        inputAutocompleteEvent,\n        () => this._createChipFromInput('autocomplete'),\n        {\n          signal: this._inputAbortController.signal,\n        },\n      );\n\n      this._inputAttributeObserver?.observe(this._inputElement, {\n        attributes: true,\n        attributeFilter: ['readonly', 'disabled'],\n      });\n    }\n\n    // Inherit size from the form-field and observe for changes\n    this._inheritSize();\n    this._formFieldAttributeObserver?.disconnect();\n    const formField = this.closest('sbb-form-field');\n    if (formField) {\n      this._formFieldAttributeObserver?.observe(formField, {\n        attributes: true,\n        attributeFilter: ['size'],\n      });\n    }\n\n    this.toggleAttribute('data-empty', this.value.length === 0);\n    this._reactToInputChanges();\n    this.updateFormValue();\n  }\n\n  /**\n   * Listen for keyboard events on the chip elements\n   **/\n  private _onChipKeyDown(event: KeyboardEvent): void {\n    const eventTarget = event.target as SbbChipElement;\n    if (eventTarget.localName !== 'sbb-chip') {\n      return;\n    }\n\n    // Arrow keys allow navigation between chips focus steps\n    if (isArrowKeyPressed(event)) {\n      const focusSteps = this._enabledChipElements();\n      const next = getNextElementIndex(event, focusSteps.indexOf(eventTarget), focusSteps.length);\n      focusSteps[next].focus();\n      return;\n    }\n\n    switch (event.key) {\n      case 'Backspace':\n      case 'Delete':\n        if (!eventTarget.readonly && !eventTarget.disabled) {\n          event.preventDefault();\n          this._deleteChip(eventTarget);\n        }\n        break;\n    }\n  }\n\n  /**\n   * Listen for keyboard events on the input\n   **/\n  private _onInputKeyDown(event: KeyboardEvent): void {\n    switch (event.key) {\n      case 'Backspace':\n      case 'ArrowLeft':\n        if (!this._inputElement!.value) {\n          this._focusChip();\n        }\n        break;\n      case 'Enter':\n        event.preventDefault(); // Prevents the form submit\n        break;\n    }\n\n    // if the user typed one of the separator keys, trigger a chipInputTokenEnd event\n    if (this.separatorKeys.includes(event.key)) {\n      event.preventDefault(); // prevent typing the separator key into the input\n      this._createChipFromInput('input');\n    }\n  }\n\n  /**\n   * If the input is not empty, create a chip with its value\n   */\n  private _createChipFromInput(origin: 'input' | 'autocomplete' = 'input'): void {\n    const inputValue = this._inputElement!.value.trim();\n    if (!inputValue) {\n      return;\n    }\n\n    const eventDetail: SbbChipInputTokenEndEventDetails = {\n      origin: origin,\n      value: inputValue,\n      label: undefined,\n      setValue: (value: string) => (eventDetail.value = value),\n      setLabel: (label: string) => (eventDetail.label = label),\n    };\n\n    if (!this._chipInputTokenEnd.emit(eventDetail)) {\n      return; // event prevented; do nothing (the consumer has to create the chip)\n    }\n\n    this._createChipElement(eventDetail.value, eventDetail.label);\n    this._inputElement!.value = ''; // Empty the input\n    this._emitInputEvents();\n  }\n\n  private _deleteChip(chip: SbbChipElement): void {\n    const chips = this._enabledChipElements();\n    chip.remove();\n    this._emitInputEvents();\n    this._focusChip(chips.indexOf(chip)); // Focus the next chip\n  }\n\n  /**\n   * Focus an enabled chip. If none are present, focus the input\n   * @param index The index of the enabled chip. If null, focus the last one.\n   */\n  private _focusChip(index?: number): void {\n    const enabledChips = this._enabledChipElements();\n\n    if (index !== undefined && enabledChips[index]) {\n      enabledChips[index].focus();\n      return;\n    }\n\n    if (enabledChips.length > 0) {\n      enabledChips[enabledChips.length - 1].focus();\n      return;\n    }\n\n    this._inputElement?.focus();\n  }\n\n  private _emitInputEvents(): void {\n    this._input.emit();\n    this._change.emit();\n  }\n\n  private _createChipElement(value: string, label?: string): void {\n    const newChip = document.createElement('sbb-chip');\n    newChip.setAttribute('value', value);\n    newChip.innerText = label ?? '';\n    this.insertBefore(newChip, this._inputElement!);\n  }\n\n  private _reactToInputChanges(): void {\n    this.disabled = this._inputElement?.disabled ?? false;\n    this._proxyStateToChips();\n  }\n\n  private _proxyStateToChips(): void {\n    this._chipElements().forEach((c) => {\n      c.disabled = this.disabled || this.formDisabled;\n      c.readonly = this._inputElement?.hasAttribute('readonly') ?? false;\n      c.negative = this.negative;\n    });\n  }\n\n  private _inheritSize(): void {\n    this.setAttribute('data-size', this.closest('sbb-form-field')?.size ?? (isLean() ? 's' : 'm'));\n  }\n\n  private _updateInputDescription(): void {\n    if (!this._inputElement) {\n      return;\n    }\n    this._inputElement.setAttribute(\n      'aria-description',\n      `${i18nChipGroupInputDescription[this._language.current]} ${this.value.length}`,\n    );\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-chip-group\">\n        <slot @slotchange=${this._setupComponent}></slot>\n      </div>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-chip-group': SbbChipGroupElement;\n  }\n}\n"],"names":["SbbChipGroupElement","value","_a"],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export * from './chip/chip.js';
2
+ //# sourceMappingURL=chip.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"chip.d.ts","sourceRoot":"","sources":["../../../../src/elements/chip/chip.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAC"}