@sbb-esta/lyne-elements 2.4.1 → 2.5.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 (260) hide show
  1. package/autocomplete/autocomplete-base-element.d.ts +0 -1
  2. package/autocomplete/autocomplete-base-element.d.ts.map +1 -1
  3. package/autocomplete.js +13 -13
  4. package/button/common/button-common.d.ts +1 -2
  5. package/button/common/button-common.d.ts.map +1 -1
  6. package/button/common.js +4 -4
  7. package/clock/clock.d.ts +8 -0
  8. package/clock/clock.d.ts.map +1 -1
  9. package/clock.js +40 -31
  10. package/core/a11y/focus.d.ts.map +1 -1
  11. package/core/base-elements/button-base-element.d.ts +5 -0
  12. package/core/base-elements/button-base-element.d.ts.map +1 -1
  13. package/core/base-elements.js +113 -98
  14. package/core/controllers/inert-controller.d.ts +3 -3
  15. package/core/controllers/inert-controller.d.ts.map +1 -1
  16. package/core/controllers.js +13 -12
  17. package/core/decorators/force-type.d.ts +1 -1
  18. package/core/decorators/force-type.d.ts.map +1 -1
  19. package/core/decorators.js +39 -40
  20. package/core/dom/platform.d.ts +5 -0
  21. package/core/dom/platform.d.ts.map +1 -1
  22. package/core/dom.js +10 -9
  23. package/core/i18n/i18n.d.ts +1 -0
  24. package/core/i18n/i18n.d.ts.map +1 -1
  25. package/core/i18n.js +95 -89
  26. package/core/mixins/animation-complete-mixin.d.ts +13 -0
  27. package/core/mixins/animation-complete-mixin.d.ts.map +1 -0
  28. package/core/mixins/form-associated-input-mixin.d.ts.map +1 -1
  29. package/core/mixins/form-associated-radio-button-mixin.d.ts.map +1 -1
  30. package/core/mixins.d.ts +1 -0
  31. package/core/mixins.d.ts.map +1 -1
  32. package/core/mixins.js +195 -152
  33. package/core/styles/core.scss +81 -0
  34. package/core/styles/mixins/link.scss +14 -0
  35. package/core/styles/node_modules_@sbb-esta_lyne-design-tokens_dist_scss_sbb-variables.scss +3 -0
  36. package/core/styles/node_modules_@sbb-esta_lyne-design-tokens_dist_scss_sbb-variables_css--mixin.scss +4 -1
  37. package/core.css +51 -1
  38. package/custom-elements.json +4330 -291
  39. package/date-input/date-input.d.ts +11 -3
  40. package/date-input/date-input.d.ts.map +1 -1
  41. package/date-input.js +44 -38
  42. package/datepicker/datepicker/datepicker.d.ts.map +1 -1
  43. package/datepicker/datepicker.js +12 -12
  44. package/development/autocomplete/autocomplete-base-element.d.ts +0 -1
  45. package/development/autocomplete/autocomplete-base-element.d.ts.map +1 -1
  46. package/development/autocomplete.js +2 -4
  47. package/development/button/common/button-common.d.ts +1 -2
  48. package/development/button/common/button-common.d.ts.map +1 -1
  49. package/development/button/common.js +26 -24
  50. package/development/clock/clock.d.ts +8 -0
  51. package/development/clock/clock.d.ts.map +1 -1
  52. package/development/clock.js +20 -2
  53. package/development/core/a11y/focus.d.ts.map +1 -1
  54. package/development/core/a11y.js +1 -1
  55. package/development/core/base-elements/button-base-element.d.ts +5 -0
  56. package/development/core/base-elements/button-base-element.d.ts.map +1 -1
  57. package/development/core/base-elements.js +43 -15
  58. package/development/core/controllers/inert-controller.d.ts +3 -3
  59. package/development/core/controllers/inert-controller.d.ts.map +1 -1
  60. package/development/core/controllers.js +6 -7
  61. package/development/core/decorators/force-type.d.ts +1 -1
  62. package/development/core/decorators/force-type.d.ts.map +1 -1
  63. package/development/core/decorators.js +5 -5
  64. package/development/core/dom/platform.d.ts +5 -0
  65. package/development/core/dom/platform.d.ts.map +1 -1
  66. package/development/core/dom.js +3 -1
  67. package/development/core/i18n/i18n.d.ts +1 -0
  68. package/development/core/i18n/i18n.d.ts.map +1 -1
  69. package/development/core/i18n.js +8 -1
  70. package/development/core/mixins/animation-complete-mixin.d.ts +13 -0
  71. package/development/core/mixins/animation-complete-mixin.d.ts.map +1 -0
  72. package/development/core/mixins/form-associated-input-mixin.d.ts.map +1 -1
  73. package/development/core/mixins/form-associated-radio-button-mixin.d.ts.map +1 -1
  74. package/development/core/mixins.d.ts +1 -0
  75. package/development/core/mixins.d.ts.map +1 -1
  76. package/development/core/mixins.js +57 -4
  77. package/development/date-input/date-input.d.ts +11 -3
  78. package/development/date-input/date-input.d.ts.map +1 -1
  79. package/development/date-input.js +26 -18
  80. package/development/datepicker/datepicker/datepicker.d.ts.map +1 -1
  81. package/development/datepicker/datepicker.js +2 -1
  82. package/development/dialog/dialog-title/dialog-title.d.ts +3 -1
  83. package/development/dialog/dialog-title/dialog-title.d.ts.map +1 -1
  84. package/development/dialog/dialog-title.js +7 -2
  85. package/development/flip-card/flip-card-details/flip-card-details.d.ts.map +1 -1
  86. package/development/flip-card/flip-card-details.js +5 -3
  87. package/development/form-field/form-field.js +2 -2
  88. package/development/header/common.js +2 -2
  89. package/development/link/common.js +13 -1
  90. package/development/menu/menu/menu.d.ts.map +1 -1
  91. package/development/menu/menu.js +4 -1
  92. package/development/navigation/navigation/navigation.d.ts.map +1 -1
  93. package/development/navigation/navigation.js +4 -1
  94. package/development/overlay/overlay-base-element.d.ts.map +1 -1
  95. package/development/overlay.js +4 -1
  96. package/development/radio-button/radio-button-group/radio-button-group.d.ts +0 -1
  97. package/development/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
  98. package/development/radio-button/radio-button-group.js +3 -5
  99. package/development/sbb-tokens-CSAKTXUi.js +1 -1
  100. package/development/select/select.d.ts +5 -2
  101. package/development/select/select.d.ts.map +1 -1
  102. package/development/select.js +6 -4
  103. package/development/sidebar/common.d.ts +1 -0
  104. package/development/sidebar/common.d.ts.map +1 -0
  105. package/development/sidebar/common.js +114 -0
  106. package/development/sidebar/icon-sidebar/icon-sidebar.d.ts +23 -0
  107. package/development/sidebar/icon-sidebar/icon-sidebar.d.ts.map +1 -0
  108. package/development/sidebar/icon-sidebar-button/icon-sidebar-button.d.ts +19 -0
  109. package/development/sidebar/icon-sidebar-button/icon-sidebar-button.d.ts.map +1 -0
  110. package/development/sidebar/icon-sidebar-button.d.ts +2 -0
  111. package/development/sidebar/icon-sidebar-button.d.ts.map +1 -0
  112. package/development/sidebar/icon-sidebar-button.js +28 -0
  113. package/development/sidebar/icon-sidebar-container/icon-sidebar-container.d.ts +23 -0
  114. package/development/sidebar/icon-sidebar-container/icon-sidebar-container.d.ts.map +1 -0
  115. package/development/sidebar/icon-sidebar-container.d.ts +2 -0
  116. package/development/sidebar/icon-sidebar-container.d.ts.map +1 -0
  117. package/development/sidebar/icon-sidebar-container.js +45 -0
  118. package/development/sidebar/icon-sidebar-content/icon-sidebar-content.d.ts +17 -0
  119. package/development/sidebar/icon-sidebar-content/icon-sidebar-content.d.ts.map +1 -0
  120. package/development/sidebar/icon-sidebar-content.d.ts +2 -0
  121. package/development/sidebar/icon-sidebar-content.d.ts.map +1 -0
  122. package/development/sidebar/icon-sidebar-content.js +34 -0
  123. package/development/sidebar/icon-sidebar-link/icon-sidebar-link.d.ts +19 -0
  124. package/development/sidebar/icon-sidebar-link/icon-sidebar-link.d.ts.map +1 -0
  125. package/development/sidebar/icon-sidebar-link.d.ts +2 -0
  126. package/development/sidebar/icon-sidebar-link.d.ts.map +1 -0
  127. package/development/sidebar/icon-sidebar-link.js +28 -0
  128. package/development/sidebar/icon-sidebar.d.ts +2 -0
  129. package/development/sidebar/icon-sidebar.d.ts.map +1 -0
  130. package/development/sidebar/icon-sidebar.js +85 -0
  131. package/development/sidebar/sidebar/sidebar.d.ts +76 -0
  132. package/development/sidebar/sidebar/sidebar.d.ts.map +1 -0
  133. package/development/sidebar/sidebar-close-button/sidebar-close-button.d.ts +22 -0
  134. package/development/sidebar/sidebar-close-button/sidebar-close-button.d.ts.map +1 -0
  135. package/development/sidebar/sidebar-close-button.d.ts +2 -0
  136. package/development/sidebar/sidebar-close-button.d.ts.map +1 -0
  137. package/development/sidebar/sidebar-close-button.js +55 -0
  138. package/development/sidebar/sidebar-container/sidebar-container.d.ts +34 -0
  139. package/development/sidebar/sidebar-container/sidebar-container.d.ts.map +1 -0
  140. package/development/sidebar/sidebar-container.d.ts +2 -0
  141. package/development/sidebar/sidebar-container.d.ts.map +1 -0
  142. package/development/sidebar/sidebar-container.js +153 -0
  143. package/development/sidebar/sidebar-content/sidebar-content.d.ts +18 -0
  144. package/development/sidebar/sidebar-content/sidebar-content.d.ts.map +1 -0
  145. package/development/sidebar/sidebar-content.d.ts +2 -0
  146. package/development/sidebar/sidebar-content.d.ts.map +1 -0
  147. package/development/sidebar/sidebar-content.js +37 -0
  148. package/development/sidebar/sidebar-title/sidebar-title.d.ts +17 -0
  149. package/development/sidebar/sidebar-title/sidebar-title.d.ts.map +1 -0
  150. package/development/sidebar/sidebar-title.d.ts +2 -0
  151. package/development/sidebar/sidebar-title.d.ts.map +1 -0
  152. package/development/sidebar/sidebar-title.js +63 -0
  153. package/development/sidebar/sidebar.d.ts +2 -0
  154. package/development/sidebar/sidebar.d.ts.map +1 -0
  155. package/development/sidebar/sidebar.js +523 -0
  156. package/development/sidebar.d.ts +12 -0
  157. package/development/sidebar.d.ts.map +1 -0
  158. package/development/sidebar.js +12 -0
  159. package/development/stepper/step/step.d.ts +1 -3
  160. package/development/stepper/step/step.d.ts.map +1 -1
  161. package/development/stepper/step.js +20 -14
  162. package/development/time-input/time-input.d.ts +3 -2
  163. package/development/time-input/time-input.d.ts.map +1 -1
  164. package/development/time-input.js +19 -10
  165. package/development/title/title-base.d.ts +2 -4
  166. package/development/title/title-base.d.ts.map +1 -1
  167. package/development/title/title.d.ts +3 -1
  168. package/development/title/title.d.ts.map +1 -1
  169. package/development/title.js +8 -8
  170. package/dialog/dialog-title/dialog-title.d.ts +3 -1
  171. package/dialog/dialog-title/dialog-title.d.ts.map +1 -1
  172. package/dialog/dialog-title.js +16 -15
  173. package/flip-card/flip-card-details/flip-card-details.d.ts.map +1 -1
  174. package/flip-card/flip-card-details.js +14 -13
  175. package/form-field/form-field.js +1 -1
  176. package/header/common.js +6 -6
  177. package/index.d.ts +20 -0
  178. package/index.js +20 -0
  179. package/link/common.js +12 -12
  180. package/menu/menu/menu.d.ts.map +1 -1
  181. package/menu/menu.js +1 -1
  182. package/navigation/navigation/navigation.d.ts.map +1 -1
  183. package/navigation/navigation.js +7 -7
  184. package/overlay/overlay-base-element.d.ts.map +1 -1
  185. package/overlay.js +1 -1
  186. package/package.json +61 -1
  187. package/radio-button/radio-button-group/radio-button-group.d.ts +0 -1
  188. package/radio-button/radio-button-group/radio-button-group.d.ts.map +1 -1
  189. package/radio-button/radio-button-group.js +8 -8
  190. package/select/select.d.ts +5 -2
  191. package/select/select.d.ts.map +1 -1
  192. package/select.js +8 -9
  193. package/sidebar/common.d.ts +1 -0
  194. package/sidebar/common.d.ts.map +1 -0
  195. package/sidebar/common.js +7 -0
  196. package/sidebar/icon-sidebar/icon-sidebar.d.ts +23 -0
  197. package/sidebar/icon-sidebar/icon-sidebar.d.ts.map +1 -0
  198. package/sidebar/icon-sidebar-button/icon-sidebar-button.d.ts +19 -0
  199. package/sidebar/icon-sidebar-button/icon-sidebar-button.d.ts.map +1 -0
  200. package/sidebar/icon-sidebar-button.d.ts +2 -0
  201. package/sidebar/icon-sidebar-button.d.ts.map +1 -0
  202. package/sidebar/icon-sidebar-button.js +20 -0
  203. package/sidebar/icon-sidebar-container/icon-sidebar-container.d.ts +23 -0
  204. package/sidebar/icon-sidebar-container/icon-sidebar-container.d.ts.map +1 -0
  205. package/sidebar/icon-sidebar-container.d.ts +2 -0
  206. package/sidebar/icon-sidebar-container.d.ts.map +1 -0
  207. package/sidebar/icon-sidebar-container.js +35 -0
  208. package/sidebar/icon-sidebar-content/icon-sidebar-content.d.ts +17 -0
  209. package/sidebar/icon-sidebar-content/icon-sidebar-content.d.ts.map +1 -0
  210. package/sidebar/icon-sidebar-content.d.ts +2 -0
  211. package/sidebar/icon-sidebar-content.d.ts.map +1 -0
  212. package/sidebar/icon-sidebar-content.js +23 -0
  213. package/sidebar/icon-sidebar-link/icon-sidebar-link.d.ts +19 -0
  214. package/sidebar/icon-sidebar-link/icon-sidebar-link.d.ts.map +1 -0
  215. package/sidebar/icon-sidebar-link.d.ts +2 -0
  216. package/sidebar/icon-sidebar-link.d.ts.map +1 -0
  217. package/sidebar/icon-sidebar-link.js +20 -0
  218. package/sidebar/icon-sidebar.d.ts +2 -0
  219. package/sidebar/icon-sidebar.d.ts.map +1 -0
  220. package/sidebar/icon-sidebar.js +47 -0
  221. package/sidebar/sidebar/sidebar.d.ts +76 -0
  222. package/sidebar/sidebar/sidebar.d.ts.map +1 -0
  223. package/sidebar/sidebar-close-button/sidebar-close-button.d.ts +22 -0
  224. package/sidebar/sidebar-close-button/sidebar-close-button.d.ts.map +1 -0
  225. package/sidebar/sidebar-close-button.d.ts +2 -0
  226. package/sidebar/sidebar-close-button.d.ts.map +1 -0
  227. package/sidebar/sidebar-close-button.js +29 -0
  228. package/sidebar/sidebar-container/sidebar-container.d.ts +34 -0
  229. package/sidebar/sidebar-container/sidebar-container.d.ts.map +1 -0
  230. package/sidebar/sidebar-container.d.ts +2 -0
  231. package/sidebar/sidebar-container.d.ts.map +1 -0
  232. package/sidebar/sidebar-container.js +78 -0
  233. package/sidebar/sidebar-content/sidebar-content.d.ts +18 -0
  234. package/sidebar/sidebar-content/sidebar-content.d.ts.map +1 -0
  235. package/sidebar/sidebar-content.d.ts +2 -0
  236. package/sidebar/sidebar-content.d.ts.map +1 -0
  237. package/sidebar/sidebar-content.js +23 -0
  238. package/sidebar/sidebar-title/sidebar-title.d.ts +17 -0
  239. package/sidebar/sidebar-title/sidebar-title.d.ts.map +1 -0
  240. package/sidebar/sidebar-title.d.ts +2 -0
  241. package/sidebar/sidebar-title.d.ts.map +1 -0
  242. package/sidebar/sidebar-title.js +37 -0
  243. package/sidebar/sidebar.d.ts +2 -0
  244. package/sidebar/sidebar.d.ts.map +1 -0
  245. package/sidebar/sidebar.js +214 -0
  246. package/sidebar.d.ts +12 -0
  247. package/sidebar.d.ts.map +1 -0
  248. package/sidebar.js +11 -0
  249. package/standard-theme.css +51 -1
  250. package/stepper/step/step.d.ts +1 -3
  251. package/stepper/step/step.d.ts.map +1 -1
  252. package/stepper/step.js +12 -15
  253. package/time-input/time-input.d.ts +3 -2
  254. package/time-input/time-input.d.ts.map +1 -1
  255. package/time-input.js +44 -36
  256. package/title/title-base.d.ts +2 -4
  257. package/title/title-base.d.ts.map +1 -1
  258. package/title/title.d.ts +3 -1
  259. package/title/title.d.ts.map +1 -1
  260. package/title.js +11 -11
@@ -1,13 +1,12 @@
1
1
  import { LitElement, CSSResultGroup, PropertyDeclaration } from 'lit';
2
2
  import { FormRestoreReason, FormRestoreState } from '../core/mixins.js';
3
+ import { SbbDatepickerElement } from '../datepicker.js';
3
4
  declare const SbbDateInputElement_base: import('../core/mixins.js').Constructor<import('../core/mixins.js').SbbFormAssociatedInputMixinType> & typeof LitElement;
4
5
  /**
5
6
  * Custom input for a date.
6
7
  */
7
8
  export declare class SbbDateInputElement<T = Date> extends SbbDateInputElement_base {
8
9
  static styles: CSSResultGroup;
9
- private _dateAdapter;
10
- private _placeholderMutable;
11
10
  /**
12
11
  * The value of the date input. Reflects the current text value
13
12
  * of this input.
@@ -22,7 +21,8 @@ export declare class SbbDateInputElement<T = Date> extends SbbDateInputElement_b
22
21
  accessor min: T | null;
23
22
  accessor max: T | null;
24
23
  /** A function used to filter out dates. */
25
- accessor dateFilter: (date: T | null) => boolean;
24
+ set dateFilter(value: (date: T | null) => boolean);
25
+ get dateFilter(): (date: T | null) => boolean;
26
26
  /**
27
27
  * How to format the displayed date.
28
28
  * `short`: Two letter abbreviation of the week day (e.g. Fr).
@@ -34,7 +34,15 @@ export declare class SbbDateInputElement<T = Date> extends SbbDateInputElement_b
34
34
  * parsing of the string value.
35
35
  */
36
36
  private _valueCache?;
37
+ private _dateAdapter;
38
+ private _placeholderMutable;
39
+ /**
40
+ * Gets the associated datepicker, if any.
41
+ * The sbb-date-input and the sbb-datepicker are assumed to be in the same parent container.
42
+ */
43
+ get datepicker(): SbbDatepickerElement<T> | null;
37
44
  constructor();
45
+ private _dateFilter;
38
46
  connectedCallback(): void;
39
47
  requestUpdate(name?: PropertyKey, oldValue?: unknown, options?: PropertyDeclaration): void;
40
48
  /**
@@ -1 +1 @@
1
- {"version":3,"file":"date-input.d.ts","sourceRoot":"","sources":["../../../src/elements/date-input/date-input.ts"],"names":[],"mappings":"AAAA,OAAO,EAAY,UAAU,EAAE,KAAK,cAAc,EAAE,KAAK,mBAAmB,EAAE,MAAM,KAAK,CAAC;AAY1F,OAAO,EAEL,KAAK,iBAAiB,EACtB,KAAK,gBAAgB,EACtB,MAAM,mBAAmB,CAAC;;AAY3B;;GAEG;AACH,qBAEM,mBAAmB,CAAC,CAAC,GAAG,IAAI,CAAE,SAAQ,wBAAuC;IACjF,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,OAAO,CAAC,YAAY,CAA4E;IAChG,OAAO,CAAC,mBAAmB,CAAS;IAEpC;;;;;OAKG;IACH,IAAoB,KAAK,CAAC,KAAK,EAAE,MAAM,EAQtC;IACD,IAAoB,KAAK,IAAI,MAAM,CAElC;IAED,IAEW,WAAW,CAAC,KAAK,EAAE,CAAC,GAAG,IAAI,EAmBrC;IACD,IAAW,WAAW,IAAI,CAAC,GAAG,IAAI,CAEjC;IACD,OAAO,CAAC,YAAY,CAAC,CAAW;IAEhC,SAEgB,GAAG,EAAE,CAAC,GAAG,IAAI,CAAQ;IAErC,SAEgB,GAAG,EAAE,CAAC,GAAG,IAAI,CAAQ;IAErC,2CAA2C;IAC3C,SAAgD,UAAU,EAAE,CAAC,IAAI,EAAE,CAAC,GAAG,IAAI,KAAK,OAAO,CAChF;IAEP;;;;OAIG;IACH,SACgB,YAAY,EAAE,OAAO,GAAG,MAAM,CAAW;IAEzD;;;OAGG;IACH,OAAO,CAAC,WAAW,CAAC,CAAqB;;IAOzB,iBAAiB,IAAI,IAAI;IAQzB,aAAa,CAC3B,IAAI,CAAC,EAAE,WAAW,EAClB,QAAQ,CAAC,EAAE,OAAO,EAClB,OAAO,CAAC,EAAE,mBAAmB,GAC5B,IAAI;IAYP;;;;;;;;OAQG;IACa,wBAAwB,CACtC,KAAK,EAAE,gBAAgB,GAAG,IAAI,EAC9B,OAAO,EAAE,iBAAiB,GACzB,IAAI;cAMY,eAAe,IAAI,IAAI;IAO1C,OAAO,CAAC,cAAc;IAOtB,OAAO,CAAC,sBAAsB;IAS9B,OAAO,CAAC,WAAW;cAIA,cAAc,CAAC,IAAI,EAAE,WAAW,GAAG,SAAS,GAAG,OAAO;cAItD,QAAQ,IAAI,IAAI;IAiCnC,OAAO,CAAC,qBAAqB;CAK9B;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,gBAAgB,EAAE,mBAAmB,CAAC;KACvC;IAED,UAAU,mBAAmB;QAC3B,aAAa,EAAE,OAAO,CAAC;KACxB;CACF"}
1
+ {"version":3,"file":"date-input.d.ts","sourceRoot":"","sources":["../../../src/elements/date-input/date-input.ts"],"names":[],"mappings":"AAAA,OAAO,EAAY,UAAU,EAAE,KAAK,cAAc,EAAE,KAAK,mBAAmB,EAAE,MAAM,KAAK,CAAC;AAY1F,OAAO,EAEL,KAAK,iBAAiB,EACtB,KAAK,gBAAgB,EACtB,MAAM,mBAAmB,CAAC;AAC3B,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,kBAAkB,CAAC;;AAY7D;;GAEG;AACH,qBAEM,mBAAmB,CAAC,CAAC,GAAG,IAAI,CAAE,SAAQ,wBAAuC;IACjF,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD;;;;;OAKG;IACH,IAAoB,KAAK,CAAC,KAAK,EAAE,MAAM,EAQtC;IACD,IAAoB,KAAK,IAAI,MAAM,CAElC;IAED,IAEW,WAAW,CAAC,KAAK,EAAE,CAAC,GAAG,IAAI,EAmBrC;IACD,IAAW,WAAW,IAAI,CAAC,GAAG,IAAI,CAEjC;IACD,OAAO,CAAC,YAAY,CAAC,CAAW;IAEhC,SAEgB,GAAG,EAAE,CAAC,GAAG,IAAI,CAAQ;IAErC,SAEgB,GAAG,EAAE,CAAC,GAAG,IAAI,CAAQ;IAErC,2CAA2C;IAC3C,IACW,UAAU,CAAC,KAAK,EAAE,CAAC,IAAI,EAAE,CAAC,GAAG,IAAI,KAAK,OAAO,EAKvD;IACD,IAAW,UAAU,IAAI,CAAC,IAAI,EAAE,CAAC,GAAG,IAAI,KAAK,OAAO,CAEnD;IAED;;;;OAIG;IACH,SACgB,YAAY,EAAE,OAAO,GAAG,MAAM,CAAW;IAEzD;;;OAGG;IACH,OAAO,CAAC,WAAW,CAAC,CAAqB;IACzC,OAAO,CAAC,YAAY,CAA4E;IAChG,OAAO,CAAC,mBAAmB,CAAS;IAEpC;;;OAGG;IACH,IAAW,UAAU,IAAI,oBAAoB,CAAC,CAAC,CAAC,GAAG,IAAI,CAEtD;;IAOD,OAAO,CAAC,WAAW,CAA2C;IAE9C,iBAAiB,IAAI,IAAI;IAQzB,aAAa,CAC3B,IAAI,CAAC,EAAE,WAAW,EAClB,QAAQ,CAAC,EAAE,OAAO,EAClB,OAAO,CAAC,EAAE,mBAAmB,GAC5B,IAAI;IAYP;;;;;;;;OAQG;IACa,wBAAwB,CACtC,KAAK,EAAE,gBAAgB,GAAG,IAAI,EAC9B,OAAO,EAAE,iBAAiB,GACzB,IAAI;cAMY,eAAe,IAAI,IAAI;IAO1C,OAAO,CAAC,cAAc;IAOtB,OAAO,CAAC,sBAAsB;IAS9B,OAAO,CAAC,WAAW;cAIA,cAAc,CAAC,IAAI,EAAE,WAAW,GAAG,SAAS,GAAG,OAAO;cAItD,QAAQ,IAAI,IAAI;IAiCnC,OAAO,CAAC,qBAAqB;CAK9B;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,gBAAgB,EAAE,mBAAmB,CAAC;KACvC;IAED,UAAU,mBAAmB;QAC3B,aAAa,EAAE,OAAO,CAAC;KACxB;CACF"}
package/date-input.js CHANGED
@@ -1,34 +1,33 @@
1
- var P = (a) => {
1
+ var z = (a) => {
2
2
  throw TypeError(a);
3
3
  };
4
- var T = (a, s, i) => s.has(a) || P("Cannot " + i);
5
- var p = (a, s, i) => (T(a, s, "read from private field"), i ? i.call(a) : s.get(a)), f = (a, s, i) => s.has(a) ? P("Cannot add the same private member more than once") : s instanceof WeakSet ? s.add(a) : s.set(a, i), d = (a, s, i, o) => (T(a, s, "write to private field"), o ? o.call(a, i) : s.set(a, i), i);
6
- import { __esDecorate as _, __runInitializers as n } from "tslib";
7
- import { css as L, LitElement as G, isServer as R } from "lit";
8
- import { customElement as B, property as y } from "lit/decorators.js";
9
- import { readConfig as H } from "./core/config.js";
10
- import { defaultDateAdapter as J } from "./core/datetime.js";
11
- import { forceType as v, DateOnlyType as D, dateConverter as U } from "./core/decorators.js";
12
- import { i18nDatePickerPlaceholder as j, i18nDateInvalid as q, i18nDateMin as K, i18nDateMax as N } from "./core/i18n.js";
13
- import { SbbFormAssociatedInputMixin as Q } from "./core/mixins.js";
14
- const W = L`:host{display:inline-block;min-width:9.375rem;max-width:100%;cursor:text}@media (forced-colors: active){:host{color:FieldText}}:host(:disabled){cursor:default}:host(:focus){text-overflow:initial!important}:host(:empty):after{content:attr(placeholder);color:var(--sbb-color-metal);-webkit-text-fill-color:var(--sbb-color-metal);opacity:1}@media (forced-colors: active){:host(:empty):after{color:GrayText}}`;
4
+ var M = (a, s, i) => s.has(a) || z("Cannot " + i);
5
+ var p = (a, s, i) => (M(a, s, "read from private field"), i ? i.call(a) : s.get(a)), f = (a, s, i) => s.has(a) ? z("Cannot add the same private member more than once") : s instanceof WeakSet ? s.add(a) : s.set(a, i), d = (a, s, i, o) => (M(a, s, "write to private field"), o ? o.call(a, i) : s.set(a, i), i);
6
+ import { __esDecorate as m, __runInitializers as n } from "tslib";
7
+ import { css as U, LitElement as j, isServer as q } from "lit";
8
+ import { customElement as L, property as _ } from "lit/decorators.js";
9
+ import { readConfig as G } from "./core/config.js";
10
+ import { defaultDateAdapter as R } from "./core/datetime.js";
11
+ import { forceType as v, DateOnlyType as D, dateConverter as O } from "./core/decorators.js";
12
+ import { i18nDatePickerPlaceholder as P, i18nDateInvalid as T, i18nDateMin as B, i18nDateMax as H } from "./core/i18n.js";
13
+ import { SbbFormAssociatedInputMixin as J } from "./core/mixins.js";
14
+ const K = U`:host{display:inline-block;min-width:9.375rem;max-width:100%;cursor:text}@media (forced-colors: active){:host{color:FieldText}}:host(:disabled){cursor:default}:host(:focus){text-overflow:initial!important}:host(:empty):after{content:attr(placeholder);color:var(--sbb-color-metal);-webkit-text-fill-color:var(--sbb-color-metal);opacity:1}@media (forced-colors: active){:host(:empty):after{color:GrayText}}`;
15
15
  Object.assign(ValidityState.prototype, {
16
16
  get sbbDateFilter() {
17
17
  return !1;
18
18
  }
19
19
  });
20
- let re = (() => {
21
- var h, u, c, m, l;
22
- let a = [B("sbb-date-input")], s, i = [], o, g = Q(G), b = [], A, x, k = [], F = [], w, S = [], V = [], I, z = [], C = [], E, M = [], O = [];
23
- return l = class extends g {
20
+ let se = (() => {
21
+ var h, u, c, l;
22
+ let a = [L("sbb-date-input")], s, i = [], o, b = J(j), y = [], g, A, k = [], x = [], F, S = [], w = [], V, I, E = [], C = [];
23
+ return l = class extends b {
24
24
  constructor() {
25
25
  var e, t;
26
26
  super();
27
27
  f(this, h);
28
28
  f(this, u);
29
29
  f(this, c);
30
- f(this, m);
31
- this._dateAdapter = (n(this, b), ((e = H().datetime) == null ? void 0 : e.dateAdapter) ?? J), this._placeholderMutable = !1, d(this, h, n(this, k, null)), d(this, u, (n(this, F), n(this, S, null))), d(this, c, (n(this, V), n(this, z, () => !0))), d(this, m, (n(this, C), n(this, M, "short"))), this._valueCache = n(this, O), (t = this.addEventListener) == null || t.call(this, "change", () => this._updateValueDateFormat(), { capture: !0 });
30
+ this._valueAsDate = n(this, y), d(this, h, n(this, k, null)), d(this, u, (n(this, x), n(this, S, null))), d(this, c, (n(this, w), n(this, E, "short"))), this._valueCache = n(this, C), this._dateAdapter = ((e = G().datetime) == null ? void 0 : e.dateAdapter) ?? R, this._placeholderMutable = !1, this._dateFilter = () => !0, (t = this.addEventListener) == null || t.call(this, "change", () => this._updateValueDateFormat(), { capture: !0 });
32
31
  }
33
32
  /**
34
33
  * The value of the date input. Reflects the current text value
@@ -37,7 +36,7 @@ let re = (() => {
37
36
  * formatted according to the current locale.
38
37
  */
39
38
  set value(e) {
40
- this._tryParseValue(e), !R && !this.matches(":focus") && this.valueAsDate !== null && (e = this._formatDate()), super.value = e;
39
+ this._tryParseValue(e), !q && !this.matches(":focus") && this.valueAsDate !== null && (e = this._formatDate()), super.value = e;
41
40
  }
42
41
  get value() {
43
42
  return super.value ?? "";
@@ -67,11 +66,11 @@ let re = (() => {
67
66
  d(this, u, e);
68
67
  }
69
68
  /** A function used to filter out dates. */
70
- get dateFilter() {
71
- return p(this, c);
72
- }
73
69
  set dateFilter(e) {
74
- d(this, c, e);
70
+ this._dateFilter = e, this.datepicker && (this.datepicker.dateFilter = e);
71
+ }
72
+ get dateFilter() {
73
+ return this._dateFilter;
75
74
  }
76
75
  /**
77
76
  * How to format the displayed date.
@@ -79,16 +78,23 @@ let re = (() => {
79
78
  * `none`: The weekday is not displayed.
80
79
  */
81
80
  get weekdayStyle() {
82
- return p(this, m);
81
+ return p(this, c);
83
82
  }
84
83
  set weekdayStyle(e) {
85
- d(this, m, e);
84
+ d(this, c, e);
85
+ }
86
+ /**
87
+ * Gets the associated datepicker, if any.
88
+ * The sbb-date-input and the sbb-datepicker are assumed to be in the same parent container.
89
+ */
90
+ get datepicker() {
91
+ return this.parentElement.querySelector("sbb-datepicker");
86
92
  }
87
93
  connectedCallback() {
88
- super.connectedCallback(), this.placeholder || (this._placeholderMutable = !0, this.placeholder = j[this.language.current]);
94
+ super.connectedCallback(), this.placeholder || (this._placeholderMutable = !0, this.placeholder = P[this.language.current]);
89
95
  }
90
96
  requestUpdate(e, t, r) {
91
- super.requestUpdate(e, t, r), this.hasUpdated && !e ? (this._updateValueDateFormat(), this._placeholderMutable && (this.placeholder = j[this.language.current])) : e === "weekdayStyle" && this._updateValueDateFormat();
97
+ super.requestUpdate(e, t, r), this.hasUpdated && !e ? (this._updateValueDateFormat(), this._placeholderMutable && (this.placeholder = P[this.language.current])) : e === "weekdayStyle" && this._updateValueDateFormat();
92
98
  }
93
99
  /**
94
100
  * Called when the browser is trying to restore element’s state to state in which case
@@ -124,26 +130,26 @@ let re = (() => {
124
130
  return super.shouldValidate(e) || ["valueAsDate", "min", "max"].includes(e);
125
131
  }
126
132
  validate() {
127
- super.validate(), this.value ? this._dateAdapter.isValid(this.valueAsDate) ? this._dateAdapter.isValid(this.min) && this._dateAdapter.compareDate(this.min, this.valueAsDate) > 0 ? this.setValidityFlag("rangeUnderflow", K(this._dateAdapter.format(this.min, { weekdayStyle: "none" }))[this.language.current]) : this._dateAdapter.isValid(this.max) && this._dateAdapter.compareDate(this.valueAsDate, this.max) > 0 ? this.setValidityFlag("rangeOverflow", N(this._dateAdapter.format(this.max, { weekdayStyle: "none" }))[this.language.current]) : this.dateFilter && !this.dateFilter(this.valueAsDate) ? this.setValidityFlag("sbbDateFilter", q[this.language.current]) : this._removeValidityErrors() : this.setValidityFlag("badInput", q[this.language.current]) : this._removeValidityErrors();
133
+ super.validate(), this.value ? this._dateAdapter.isValid(this.valueAsDate) ? this._dateAdapter.isValid(this.min) && this._dateAdapter.compareDate(this.min, this.valueAsDate) > 0 ? this.setValidityFlag("rangeUnderflow", B(this._dateAdapter.format(this.min, { weekdayStyle: "none" }))[this.language.current]) : this._dateAdapter.isValid(this.max) && this._dateAdapter.compareDate(this.valueAsDate, this.max) > 0 ? this.setValidityFlag("rangeOverflow", H(this._dateAdapter.format(this.max, { weekdayStyle: "none" }))[this.language.current]) : this.dateFilter && !this.dateFilter(this.valueAsDate) ? this.setValidityFlag("sbbDateFilter", T[this.language.current]) : this._removeValidityErrors() : this.setValidityFlag("badInput", T[this.language.current]) : this._removeValidityErrors();
128
134
  }
129
135
  _removeValidityErrors() {
130
136
  ["badInput", "rangeUnderflow", "rangeOverflow", "sbbDateFilter"].forEach((e) => this.removeValidityFlag(e));
131
137
  }
132
- }, h = new WeakMap(), u = new WeakMap(), c = new WeakMap(), m = new WeakMap(), o = l, (() => {
133
- const e = typeof Symbol == "function" && Symbol.metadata ? Object.create(g[Symbol.metadata] ?? null) : void 0;
134
- A = [v(), y({ attribute: !1, type: D })], x = [v(), y({ converter: U, reflect: !0, type: D })], w = [v(), y({ converter: U, reflect: !0, type: D })], I = [y({ attribute: !1 })], E = [y({ attribute: "weekday-style" })], _(l, null, A, { kind: "setter", name: "valueAsDate", static: !1, private: !1, access: { has: (t) => "valueAsDate" in t, set: (t, r) => {
138
+ }, h = new WeakMap(), u = new WeakMap(), c = new WeakMap(), o = l, (() => {
139
+ const e = typeof Symbol == "function" && Symbol.metadata ? Object.create(b[Symbol.metadata] ?? null) : void 0;
140
+ g = [v(), _({ attribute: !1, type: D })], A = [v(), _({ converter: O, reflect: !0, type: D })], F = [v(), _({ converter: O, reflect: !0, type: D })], V = [_({ attribute: !1 })], I = [_({ attribute: "weekday-style" })], m(l, null, g, { kind: "setter", name: "valueAsDate", static: !1, private: !1, access: { has: (t) => "valueAsDate" in t, set: (t, r) => {
135
141
  t.valueAsDate = r;
136
- } }, metadata: e }, null, b), _(l, null, x, { kind: "accessor", name: "min", static: !1, private: !1, access: { has: (t) => "min" in t, get: (t) => t.min, set: (t, r) => {
142
+ } }, metadata: e }, null, y), m(l, null, A, { kind: "accessor", name: "min", static: !1, private: !1, access: { has: (t) => "min" in t, get: (t) => t.min, set: (t, r) => {
137
143
  t.min = r;
138
- } }, metadata: e }, k, F), _(l, null, w, { kind: "accessor", name: "max", static: !1, private: !1, access: { has: (t) => "max" in t, get: (t) => t.max, set: (t, r) => {
144
+ } }, metadata: e }, k, x), m(l, null, F, { kind: "accessor", name: "max", static: !1, private: !1, access: { has: (t) => "max" in t, get: (t) => t.max, set: (t, r) => {
139
145
  t.max = r;
140
- } }, metadata: e }, S, V), _(l, null, I, { kind: "accessor", name: "dateFilter", static: !1, private: !1, access: { has: (t) => "dateFilter" in t, get: (t) => t.dateFilter, set: (t, r) => {
146
+ } }, metadata: e }, S, w), m(l, null, V, { kind: "setter", name: "dateFilter", static: !1, private: !1, access: { has: (t) => "dateFilter" in t, set: (t, r) => {
141
147
  t.dateFilter = r;
142
- } }, metadata: e }, z, C), _(l, null, E, { kind: "accessor", name: "weekdayStyle", static: !1, private: !1, access: { has: (t) => "weekdayStyle" in t, get: (t) => t.weekdayStyle, set: (t, r) => {
148
+ } }, metadata: e }, null, y), m(l, null, I, { kind: "accessor", name: "weekdayStyle", static: !1, private: !1, access: { has: (t) => "weekdayStyle" in t, get: (t) => t.weekdayStyle, set: (t, r) => {
143
149
  t.weekdayStyle = r;
144
- } }, metadata: e }, M, O), _(null, s = { value: o }, a, { kind: "class", name: o.name, metadata: e }, null, i), o = s.value, e && Object.defineProperty(o, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: e });
145
- })(), l.styles = W, n(o, i), o;
150
+ } }, metadata: e }, E, C), m(null, s = { value: o }, a, { kind: "class", name: o.name, metadata: e }, null, i), o = s.value, e && Object.defineProperty(o, Symbol.metadata, { enumerable: !0, configurable: !0, writable: !0, value: e });
151
+ })(), l.styles = K, n(o, i), o;
146
152
  })();
147
153
  export {
148
- re as SbbDateInputElement
154
+ se as SbbDateInputElement
149
155
  };
@@ -1 +1 @@
1
- {"version":3,"file":"datepicker.d.ts","sourceRoot":"","sources":["../../../../src/elements/datepicker/datepicker/datepicker.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"datepicker.d.ts","sourceRoot":"","sources":["../../../../src/elements/datepicker/datepicker/datepicker.ts"],"names":[],"mappings":"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"}
@@ -2,7 +2,7 @@ var T = (i) => {
2
2
  throw TypeError(i);
3
3
  };
4
4
  var L = (i, n, r) => n.has(i) || T("Cannot " + r);
5
- var D = (i, n, r) => (L(i, n, "read from private field"), r ? r.call(i) : n.get(i)), g = (i, n, r) => n.has(i) ? T("Cannot add the same private member more than once") : n instanceof WeakSet ? n.add(i) : n.set(i, r), o = (i, n, r, d) => (L(i, n, "write to private field"), d ? d.call(i, r) : n.set(i, r), r);
5
+ var D = (i, n, r) => (L(i, n, "read from private field"), r ? r.call(i) : n.get(i)), g = (i, n, r) => n.has(i) ? T("Cannot add the same private member more than once") : n instanceof WeakSet ? n.add(i) : n.set(i, r), p = (i, n, r, d) => (L(i, n, "write to private field"), d ? d.call(i, r) : n.set(i, r), r);
6
6
  import { __esDecorate as h, __runInitializers as u } from "tslib";
7
7
  import { css as j, LitElement as $, isServer as H, html as B } from "lit";
8
8
  import { customElement as G, property as b, state as J } from "lit/decorators.js";
@@ -35,7 +35,7 @@ let Et = (() => {
35
35
  g(this, m);
36
36
  g(this, v);
37
37
  g(this, f);
38
- o(this, m, (u(this, A), u(this, k, !1))), this._dateFilter = u(this, I), o(this, v, u(this, U, null)), this._now = u(this, z), o(this, f, u(this, P, null)), this._change = (u(this, S), new w(this, _.events.change, {
38
+ p(this, m, (u(this, A), u(this, k, !1))), this._dateFilter = u(this, I), p(this, v, u(this, U, null)), this._now = u(this, z), p(this, f, u(this, P, null)), this._change = (u(this, S), new w(this, _.events.change, {
39
39
  bubbles: !0
40
40
  })), this._inputUpdated = new w(this, _.events.inputUpdated, { bubbles: !0, cancelable: !0 }), this._datePickerUpdated = new w(this, _.events.datePickerUpdated, {
41
41
  bubbles: !0,
@@ -53,7 +53,7 @@ let Et = (() => {
53
53
  return D(this, m);
54
54
  }
55
55
  set wide(t) {
56
- o(this, m, t);
56
+ p(this, m, t);
57
57
  }
58
58
  /**
59
59
  * A function used to filter out dates.
@@ -75,7 +75,7 @@ let Et = (() => {
75
75
  return D(this, v);
76
76
  }
77
77
  set input(t) {
78
- o(this, v, t);
78
+ p(this, v, t);
79
79
  }
80
80
  /**
81
81
  * A configured date which acts as the current date instead of the real current date.
@@ -109,7 +109,7 @@ let Et = (() => {
109
109
  return D(this, f);
110
110
  }
111
111
  set _inputElement(t) {
112
- o(this, f, t);
112
+ p(this, f, t);
113
113
  }
114
114
  connectedCallback() {
115
115
  this.id || (this.id = `sbb-datepicker-${++st}`), super.connectedCallback(), this._attachInput();
@@ -118,7 +118,7 @@ let Et = (() => {
118
118
  super.requestUpdate(t, e, a), this.hasUpdated && !t && this.inputElement && (this._inputElementPlaceholderMutable && (this.inputElement.placeholder = q[this._language.current]), this.valueAsDate && (this.inputElement.value = this._dateAdapter.format(this.valueAsDate)));
119
119
  }
120
120
  willUpdate(t) {
121
- super.willUpdate(t), t.has("input") && this._attachInput(), (t.has("wide") || t.has("dateFilter") || t.has("now")) && this._datePickerUpdated.emit(), t.has("valueAsDate") && this._setAriaLiveMessage();
121
+ super.willUpdate(t), t.has("input") && this._attachInput(), (t.has("wide") || t.has("dateFilter") || t.has("now")) && (this._associationController.updateControls(), this._datePickerUpdated.emit()), t.has("valueAsDate") && this._setAriaLiveMessage();
122
122
  }
123
123
  disconnectedCallback() {
124
124
  var t, e;
@@ -135,14 +135,14 @@ let Et = (() => {
135
135
  return !!this._now;
136
136
  }
137
137
  _attachInput() {
138
- var a, s, p, E;
138
+ var a, s, o, E;
139
139
  const t = Y(this, this.input, "input,sbb-date-input");
140
140
  if (this.inputElement === t)
141
141
  return;
142
142
  this.inputElement && ((a = this._datePickerController) == null || a.abort(), (s = this._inputObserver) == null || s.disconnect());
143
143
  const e = !c(t);
144
144
  if (this._inputElement = t, t) {
145
- this._datePickerController = new AbortController(), (p = this._inputObserver) == null || p.observe(t, {
145
+ this._datePickerController = new AbortController(), (o = this._inputObserver) == null || o.observe(t, {
146
146
  attributeFilter: ["disabled", "readonly", "min", "max", "value"]
147
147
  }), e && (this._inputElementPlaceholderMutable = !t.placeholder, t.type = "text", this._inputElementPlaceholderMutable && (t.placeholder = q[this._language.current]));
148
148
  const N = { signal: this._datePickerController.signal };
@@ -152,8 +152,8 @@ let Et = (() => {
152
152
  }
153
153
  }
154
154
  _emitInputUpdated() {
155
- const { disabled: t, readOnly: e, min: a, max: s } = this.inputElement ?? {}, p = a && typeof a != "string" ? this._dateAdapter.toIso8601(a) : a, E = s && typeof s != "string" ? this._dateAdapter.toIso8601(s) : s;
156
- this._inputUpdated.emit({ disabled: t, readonly: e, min: p, max: E });
155
+ const { disabled: t, readOnly: e, min: a, max: s } = this.inputElement ?? {}, o = a && typeof a != "string" ? this._dateAdapter.toIso8601(a) : a, E = s && typeof s != "string" ? this._dateAdapter.toIso8601(s) : s;
156
+ this._inputUpdated.emit({ disabled: t, readonly: e, min: o, max: E });
157
157
  }
158
158
  _handleInputChange() {
159
159
  var t;
@@ -229,11 +229,11 @@ let Et = (() => {
229
229
  * and `min` and `max` parameters (e.g. from the self-named input's attributes).
230
230
  */
231
231
  _isDateAvailable() {
232
- var a, s, p;
232
+ var a, s, o;
233
233
  if (!this.valueAsDate)
234
234
  return !1;
235
235
  const t = this._dateAdapter.deserialize((a = this.inputElement) == null ? void 0 : a.min), e = this._dateAdapter.deserialize((s = this.inputElement) == null ? void 0 : s.max);
236
- return this._dateAdapter.isValid(t) && this._dateAdapter.compareDate(this.valueAsDate, t) < 0 || this._dateAdapter.isValid(e) && this._dateAdapter.compareDate(this.valueAsDate, e) > 0 ? !1 : ((p = this.dateFilter) == null ? void 0 : p.call(this, this.valueAsDate)) ?? !0;
236
+ return this._dateAdapter.isValid(t) && this._dateAdapter.compareDate(this.valueAsDate, t) < 0 || this._dateAdapter.isValid(e) && this._dateAdapter.compareDate(this.valueAsDate, e) > 0 ? !1 : ((o = this.dateFilter) == null ? void 0 : o.call(this, this.valueAsDate)) ?? !0;
237
237
  }
238
238
  }, m = new WeakMap(), v = new WeakMap(), f = new WeakMap(), d = l, (() => {
239
239
  const t = typeof Symbol == "function" && Symbol.metadata ? Object.create(y[Symbol.metadata] ?? null) : void 0;
@@ -32,7 +32,6 @@ export declare abstract class SbbAutocompleteBaseElement extends SbbAutocomplete
32
32
  private _optionContainer;
33
33
  private _triggerEventsController;
34
34
  private _openPanelEventsController;
35
- private _didLoad;
36
35
  private _isPointerDownEventOnMenu;
37
36
  private _sbbEscapableOverlayController;
38
37
  protected abstract get options(): SbbOptionBaseElement[];
@@ -1 +1 @@
1
- {"version":3,"file":"autocomplete-base-element.d.ts","sourceRoot":"","sources":["../../../../src/elements/autocomplete/autocomplete-base-element.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"autocomplete-base-element.d.ts","sourceRoot":"","sources":["../../../../src/elements/autocomplete/autocomplete-base-element.ts"],"names":[],"mappings":"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"}
@@ -322,7 +322,6 @@ let SbbAutocompleteBaseElement = (() => {
322
322
  __privateSet(this, _preserveIconSpace_accessor_storage, (__runInitializers(this, _trigger_extraInitializers), __runInitializers(this, _preserveIconSpace_initializers, false)));
323
323
  this._originElement = __runInitializers(this, _preserveIconSpace_extraInitializers);
324
324
  this.abort = new SbbConnectedAbortController(this);
325
- this._didLoad = false;
326
325
  this._isPointerDownEventOnMenu = false;
327
326
  this._sbbEscapableOverlayController = new SbbEscapableOverlayController(this);
328
327
  this._pointerDownListener = (event) => {
@@ -418,7 +417,7 @@ let SbbAutocompleteBaseElement = (() => {
418
417
  if (formField) {
419
418
  this.negative = formField.hasAttribute("negative");
420
419
  }
421
- if (this._didLoad) {
420
+ if (this.hasUpdated) {
422
421
  this._componentSetup();
423
422
  }
424
423
  this.syncNegative();
@@ -435,7 +434,6 @@ let SbbAutocompleteBaseElement = (() => {
435
434
  firstUpdated(changedProperties) {
436
435
  super.firstUpdated(changedProperties);
437
436
  this._componentSetup();
438
- this._didLoad = true;
439
437
  }
440
438
  disconnectedCallback() {
441
439
  var _a2, _b;
@@ -765,4 +763,4 @@ export {
765
763
  SbbAutocompleteBaseElement,
766
764
  SbbAutocompleteElement
767
765
  };
768
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"autocomplete.js","sources":["../../../src/elements/autocomplete/autocomplete-base-element.ts","../../../src/elements/autocomplete/autocomplete.ts"],"sourcesContent":["import {\n  type CSSResultGroup,\n  html,\n  isServer,\n  nothing,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\n\nimport { SbbOpenCloseBaseElement } from '../core/base-elements.js';\nimport { SbbConnectedAbortController, SbbEscapableOverlayController } from '../core/controllers.js';\nimport { forceType, hostAttributes } from '../core/decorators.js';\nimport { findReferencedElement, isSafari, isZeroAnimationDuration } from '../core/dom.js';\nimport { SbbNegativeMixin, SbbHydrationMixin } from '../core/mixins.js';\nimport {\n  isEventOnElement,\n  overlayGapFixCorners,\n  removeAriaComboBoxAttributes,\n  setOverlayPosition,\n} from '../core/overlay.js';\nimport type { SbbOptionBaseElement } from '../option.js';\n\nimport style from './autocomplete-base-element.scss?lit&inline';\n\n/**\n * On Safari, the aria role 'listbox' must be on the host element, or else VoiceOver won't work at all.\n * On the other hand, JAWS and NVDA need the role to be \"closer\" to the options, or else optgroups won't work.\n */\nconst ariaRoleOnHost = isSafari;\n\nexport\n@hostAttributes({\n  popover: 'manual',\n})\nabstract class SbbAutocompleteBaseElement extends SbbNegativeMixin(\n  SbbHydrationMixin(SbbOpenCloseBaseElement),\n) {\n  public static override styles: CSSResultGroup = style;\n\n  /**\n   * The element where the autocomplete will attach; accepts both an element's id or an HTMLElement.\n   * If not set, it will search for the first 'sbb-form-field' ancestor.\n   */\n  @property() public accessor origin: string | HTMLElement | null = null;\n\n  /**\n   * The input element that will trigger the autocomplete opening; accepts both an element's id or an HTMLElement.\n   * By default, the autocomplete will open on focus, click, input or `ArrowDown` keypress of the 'trigger' element.\n   * If not set, will search for the first 'input' child of a 'sbb-form-field' ancestor.\n   */\n  @property() public accessor trigger: string | HTMLInputElement | null = null;\n\n  /** Whether the icon space is preserved when no icon is set. */\n  @forceType()\n  @property({ attribute: 'preserve-icon-space', reflect: true, type: Boolean })\n  public accessor preserveIconSpace: boolean = false;\n\n  /** Returns the element where autocomplete overlay is attached to. */\n  public get originElement(): HTMLElement {\n    if (!this._originElement) {\n      this._originElement = this._findOriginElement();\n    }\n    return this._originElement;\n  }\n  private _originElement?: HTMLElement;\n\n  /** Returns the trigger element. */\n  public get triggerElement(): HTMLInputElement | undefined {\n    return this._triggerElement;\n  }\n  private _triggerElement: HTMLInputElement | undefined;\n\n  protected abstract overlayId: string;\n  protected abstract panelRole: string;\n  /** @deprecated No longer used internally. */\n  protected abort = new SbbConnectedAbortController(this);\n  private _overlay!: HTMLElement;\n  private _optionContainer!: HTMLElement;\n  private _triggerEventsController!: AbortController;\n  private _openPanelEventsController!: AbortController;\n  private _didLoad = false;\n  private _isPointerDownEventOnMenu: boolean = false;\n  private _sbbEscapableOverlayController = new SbbEscapableOverlayController(this);\n\n  protected abstract get options(): SbbOptionBaseElement[];\n  protected abstract syncNegative(): void;\n  protected abstract setTriggerAttributes(element: HTMLInputElement): void;\n  protected abstract openedPanelKeyboardInteraction(event: KeyboardEvent): void;\n  protected abstract selectByKeyboard(event: KeyboardEvent): void;\n  protected abstract setNextActiveOption(event: KeyboardEvent): void;\n  protected abstract resetActiveElement(): void;\n\n  /** Opens the autocomplete. */\n  public open(): void {\n    if (\n      this.state !== 'closed' ||\n      !this._overlay ||\n      this.options.length === 0 ||\n      this._readonly()\n    ) {\n      return;\n    }\n    if (!this.willOpen.emit()) {\n      return;\n    }\n\n    this.showPopover?.();\n    this.state = 'opening';\n    this._triggerElement?.toggleAttribute('data-expanded', true);\n    this._setOverlayPosition();\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `opened` state.\n    if (this._isZeroAnimationDuration()) {\n      this._handleOpening();\n    }\n  }\n\n  /** Closes the autocomplete. */\n  public close(): void {\n    if (this.state !== 'opened') {\n      return;\n    }\n    if (!this.willClose.emit()) {\n      return;\n    }\n\n    this.state = 'closing';\n    this._triggerElement?.toggleAttribute('data-expanded', false);\n    this._openPanelEventsController.abort();\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `closed` state.\n    if (this._isZeroAnimationDuration()) {\n      this._handleClosing();\n    }\n  }\n\n  private _isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-options-panel-animation-duration');\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    if (ariaRoleOnHost) {\n      this.id ||= this.overlayId;\n    }\n    const formField = this.closest('sbb-form-field') ?? this.closest('[data-form-field]');\n\n    if (formField) {\n      this.negative = formField.hasAttribute('negative');\n    }\n\n    if (this._didLoad) {\n      this._componentSetup();\n    }\n    this.syncNegative();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (\n      (changedProperties.has('origin') && this.origin !== changedProperties.get('origin')) ||\n      (changedProperties.has('trigger') && this.trigger !== changedProperties.get('trigger'))\n    ) {\n      this._componentSetup();\n    }\n    if (changedProperties.has('negative')) {\n      this.syncNegative();\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this._componentSetup();\n    this._didLoad = true;\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._triggerEventsController?.abort();\n    this._openPanelEventsController?.abort();\n  }\n\n  /** When an option is selected, update the input value and close the autocomplete. */\n  protected onOptionSelected(event: CustomEvent): void {\n    const target = event.target as SbbOptionBaseElement;\n    if (!target.selected) {\n      return;\n    }\n\n    // Deselect the previous options\n    this.options\n      .filter((option) => option.id !== target.id && option.selected)\n      .forEach((option) => (option.selected = false));\n\n    if (this.triggerElement) {\n      // Set the option value\n      // In order to support React onChange event, we have to get the setter and call it.\n      // https://github.com/facebook/react/issues/11600#issuecomment-345813130\n      const setValue = Object.getOwnPropertyDescriptor(HTMLInputElement.prototype, 'value')!.set!;\n      setValue.call(this.triggerElement, target.value);\n\n      // Manually trigger the change events\n      this.triggerElement.dispatchEvent(new Event('change', { bubbles: true }));\n      this.triggerElement.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));\n      this.triggerElement.focus();\n    }\n\n    this.close();\n  }\n\n  private _handleSlotchange(): void {\n    this._highlightOptions(this.triggerElement?.value);\n    this._openOnNewOptions();\n  }\n\n  /**\n   * If the 'input' is focused and there's a change in the number of options, open the autocomplete\n   */\n  private _openOnNewOptions(): void {\n    if (document?.activeElement === this.triggerElement) {\n      if (this.options.length > 0) {\n        this.open();\n      } else {\n        this.close();\n      }\n    }\n  }\n\n  /** The autocomplete should inherit 'readonly' state from the trigger. */\n  private _readonly(): boolean {\n    return this.triggerElement?.hasAttribute('readonly') ?? false;\n  }\n\n  private _componentSetup(): void {\n    if (isServer) {\n      return;\n    }\n    this._triggerEventsController?.abort();\n    this._openPanelEventsController?.abort();\n\n    this._originElement = undefined;\n    this.toggleAttribute(\n      'data-option-panel-origin-borderless',\n      !!this.closest?.('sbb-form-field')?.hasAttribute('borderless'),\n    );\n\n    this._bindTo(this._getTriggerElement());\n  }\n\n  /**\n   * Retrieve the element where the autocomplete will be attached.\n   * @returns 'origin' or the first 'sbb-form-field' ancestor.\n   */\n  private _findOriginElement(): HTMLElement {\n    let result: HTMLElement | undefined | null;\n\n    if (!this.origin) {\n      result = this.closest?.('sbb-form-field')?.shadowRoot?.querySelector?.('#overlay-anchor');\n    } else {\n      result = findReferencedElement(this.origin);\n    }\n\n    if (!result) {\n      throw new Error(\n        'Cannot find the origin element. Please specify a valid element or read the \"origin\" prop documentation',\n      );\n    }\n\n    return result;\n  }\n\n  /**\n   * Retrieve the element that will trigger the autocomplete opening.\n   * @returns 'trigger' or the first 'input' inside the origin element.\n   */\n  private _getTriggerElement(): HTMLInputElement {\n    if (!this.trigger) {\n      return this.closest?.('sbb-form-field')?.querySelector('input') as HTMLInputElement;\n    }\n\n    const result = findReferencedElement<HTMLInputElement>(this.trigger);\n\n    if (!result) {\n      throw new Error(\n        'Cannot find the trigger element. Please specify a valid element or read the \"trigger\" prop documentation',\n      );\n    }\n\n    return result;\n  }\n\n  private _bindTo(triggerElem: HTMLInputElement): void {\n    if (!triggerElem) {\n      return;\n    }\n\n    // Reset attributes to the old trigger and add them to the new one\n    this._removeTriggerAttributes(this.triggerElement);\n    this.setTriggerAttributes(triggerElem);\n\n    this._triggerElement = triggerElem;\n\n    this._setupTriggerEvents();\n  }\n\n  private _setupTriggerEvents(): void {\n    this._triggerEventsController = new AbortController();\n\n    // Open the overlay on focus, click, input and `ArrowDown` event\n    this.triggerElement?.addEventListener('focus', () => this.open(), {\n      signal: this._triggerEventsController.signal,\n    });\n    this.triggerElement?.addEventListener('click', () => this.open(), {\n      signal: this._triggerEventsController.signal,\n    });\n    this.triggerElement?.addEventListener(\n      'input',\n      (event) => {\n        this.open();\n        this._highlightOptions((event.target as HTMLInputElement).value);\n      },\n      { signal: this._triggerEventsController.signal },\n    );\n    this.triggerElement?.addEventListener(\n      'keydown',\n      (event: KeyboardEvent) => this._closedPanelKeyboardInteraction(event),\n      { signal: this._triggerEventsController.signal },\n    );\n  }\n\n  // Set overlay position, width and max height\n  private _setOverlayPosition(): void {\n    setOverlayPosition(\n      this._overlay,\n      this.originElement,\n      this._optionContainer,\n      this.shadowRoot!.querySelector('.sbb-autocomplete__container')!,\n      this,\n    );\n  }\n\n  /**\n   * On open/close animation end.\n   * In rare cases it can be that the animationEnd event is triggered twice.\n   * To avoid entering a corrupt state, exit when state is not expected.\n   */\n  private _onAnimationEnd(event: AnimationEvent): void {\n    if (event.animationName === 'open' && this.state === 'opening') {\n      this._handleOpening();\n    } else if (event.animationName === 'close' && this.state === 'closing') {\n      this._handleClosing();\n    }\n  }\n\n  private _handleOpening(): void {\n    this.state = 'opened';\n    this._attachOpenPanelEvents();\n    this.triggerElement?.setAttribute('aria-expanded', 'true');\n    this._sbbEscapableOverlayController.connect();\n    this.didOpen.emit();\n  }\n\n  private _handleClosing(): void {\n    this.state = 'closed';\n    this.hidePopover?.();\n    this.triggerElement?.setAttribute('aria-expanded', 'false');\n    this.resetActiveElement();\n    this._optionContainer.scrollTop = 0;\n    this._sbbEscapableOverlayController.disconnect();\n    this.didClose.emit();\n  }\n\n  private _attachOpenPanelEvents(): void {\n    this._openPanelEventsController = new AbortController();\n\n    // Recalculate the overlay position on scroll and window resize\n    document.addEventListener('scroll', () => this._setOverlayPosition(), {\n      passive: true,\n      signal: this._openPanelEventsController.signal,\n      // Without capture, other scroll contexts would not bubble to this event listener.\n      // Capture allows us to react to all scroll contexts in this DOM.\n      capture: true,\n    });\n    window.addEventListener('resize', () => this._setOverlayPosition(), {\n      passive: true,\n      signal: this._openPanelEventsController.signal,\n    });\n\n    // Close autocomplete on backdrop click\n    window.addEventListener('pointerdown', (ev) => this._pointerDownListener(ev), {\n      signal: this._openPanelEventsController.signal,\n    });\n    window.addEventListener('pointerup', (ev) => this._closeOnBackdropClick(ev), {\n      signal: this._openPanelEventsController.signal,\n    });\n\n    // Keyboard interactions\n    this.triggerElement?.addEventListener(\n      'keydown',\n      (event: KeyboardEvent) => this.openedPanelKeyboardInteraction(event),\n      {\n        signal: this._openPanelEventsController.signal,\n      },\n    );\n  }\n\n  // Check if the pointerdown event target is triggered on the menu.\n  private _pointerDownListener = (event: PointerEvent): void => {\n    this._isPointerDownEventOnMenu = isEventOnElement(this._overlay, event);\n  };\n\n  // If the click is outside the autocomplete, closes the panel.\n  private _closeOnBackdropClick = (event: PointerEvent): void => {\n    if (\n      !this._isPointerDownEventOnMenu &&\n      !isEventOnElement(this._overlay, event) &&\n      !isEventOnElement(this.originElement, event)\n    ) {\n      this.close();\n    }\n  };\n\n  private _closedPanelKeyboardInteraction(event: KeyboardEvent): void {\n    if (this.state !== 'closed') {\n      return;\n    }\n\n    switch (event.key) {\n      case 'Enter':\n      case 'ArrowDown':\n      case 'ArrowUp':\n        this.open();\n        break;\n    }\n  }\n\n  /** Highlight the searched text on the options. */\n  private _highlightOptions(searchTerm?: string): void {\n    if (searchTerm === null || searchTerm === undefined) {\n      return;\n    }\n    this.options.forEach((option) => option.highlight(searchTerm));\n  }\n\n  private _removeTriggerAttributes(element?: HTMLInputElement): void {\n    removeAriaComboBoxAttributes(element);\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-autocomplete__gap-fix\"></div>\n      <div class=\"sbb-autocomplete__container\">\n        <div class=\"sbb-autocomplete__gap-fix\">${overlayGapFixCorners()}</div>\n        <div\n          @animationend=${this._onAnimationEnd}\n          class=\"sbb-autocomplete__panel\"\n          ?data-open=${this.state === 'opened' || this.state === 'opening'}\n          ${ref((overlayRef?: Element) => (this._overlay = overlayRef as HTMLElement))}\n        >\n          <div class=\"sbb-autocomplete__wrapper\">\n            <div\n              class=\"sbb-autocomplete__options\"\n              role=${!ariaRoleOnHost ? this.panelRole : nothing}\n              id=${!ariaRoleOnHost ? this.overlayId : nothing}\n              ${ref((containerRef) => (this._optionContainer = containerRef as HTMLElement))}\n            >\n              <slot @slotchange=${this._handleSlotchange}></slot>\n            </div>\n          </div>\n        </div>\n      </div>\n    `;\n  }\n}\n","import { customElement } from 'lit/decorators.js';\n\nimport { getNextElementIndex } from '../core/a11y.js';\nimport { hostAttributes } from '../core/decorators.js';\nimport { isSafari } from '../core/dom.js';\nimport { setAriaComboBoxAttributes } from '../core/overlay.js';\nimport type { SbbOptGroupElement, SbbOptionElement } from '../option.js';\n\nimport { SbbAutocompleteBaseElement } from './autocomplete-base-element.js';\n\nlet nextId = 0;\n\n/**\n * On Safari, the aria role 'listbox' must be on the host element, or else VoiceOver won't work at all.\n * On the other hand, JAWS and NVDA need the role to be \"closer\" to the options, or else optgroups won't work.\n */\nconst ariaRoleOnHost = isSafari;\n\n/**\n * Combined with a native input, it displays a panel with a list of available options.\n *\n * @slot - Use the unnamed slot to add `sbb-option` or `sbb-optgroup` elements to the `sbb-autocomplete`.\n * @event {CustomEvent<void>} willOpen - Emits whenever the `sbb-autocomplete` starts the opening transition. Can be canceled.\n * @event {CustomEvent<void>} didOpen - Emits whenever the `sbb-autocomplete` is opened.\n * @event {CustomEvent<void>} willClose - Emits whenever the `sbb-autocomplete` begins the closing transition. Can be canceled.\n * @event {CustomEvent<void>} didClose - Emits whenever the `sbb-autocomplete` is closed.\n * @cssprop [--sbb-autocomplete-z-index=var(--sbb-overlay-default-z-index)] - To specify a custom stack order,\n * the `z-index` can be overridden by defining this CSS variable. The default `z-index` of the\n * component is set to `var(--sbb-overlay-default-z-index)` with a value of `1000`.\n */\nexport\n@customElement('sbb-autocomplete')\n@hostAttributes({\n  role: ariaRoleOnHost ? 'listbox' : null,\n})\nclass SbbAutocompleteElement extends SbbAutocompleteBaseElement {\n  protected overlayId = `sbb-autocomplete-${++nextId}`;\n  protected panelRole = 'listbox';\n  private _activeItemIndex = -1;\n\n  protected get options(): SbbOptionElement[] {\n    return Array.from(this.querySelectorAll?.('sbb-option') ?? []);\n  }\n\n  public constructor() {\n    super();\n    this.addEventListener?.('optionSelectionChange', (e: CustomEvent<void>) =>\n      this.onOptionSelected(e),\n    );\n  }\n\n  protected syncNegative(): void {\n    this.querySelectorAll?.('sbb-divider').forEach((divider) => (divider.negative = this.negative));\n\n    this.querySelectorAll?.<SbbOptionElement | SbbOptGroupElement>(\n      'sbb-option, sbb-optgroup',\n    ).forEach((element) => element.toggleAttribute('data-negative', this.negative));\n  }\n\n  protected openedPanelKeyboardInteraction(event: KeyboardEvent): void {\n    if (this.state !== 'opened') {\n      return;\n    }\n\n    switch (event.key) {\n      case 'Tab':\n        this.close();\n        break;\n\n      case 'Enter':\n        this.selectByKeyboard(event);\n        break;\n\n      case 'ArrowDown':\n      case 'ArrowUp':\n        this.setNextActiveOption(event);\n        break;\n    }\n  }\n\n  protected selectByKeyboard(event: KeyboardEvent): void {\n    event.preventDefault();\n    const activeOption = this.options[this._activeItemIndex];\n\n    if (activeOption) {\n      activeOption.setSelectedViaUserInteraction(true);\n    }\n  }\n\n  protected setNextActiveOption(event: KeyboardEvent): void {\n    const filteredOptions = this.options.filter(\n      (opt) => !opt.disabled && !opt.hasAttribute('data-group-disabled'),\n    );\n\n    // Get and activate the next active option\n    const next = getNextElementIndex(event, this._activeItemIndex, filteredOptions.length);\n    const nextActiveOption = filteredOptions[next];\n    nextActiveOption.setActive(true);\n    this.triggerElement?.setAttribute('aria-activedescendant', nextActiveOption.id);\n    nextActiveOption.scrollIntoView({ block: 'nearest' });\n\n    // Reset the previous active option\n    const lastActiveOption = filteredOptions[this._activeItemIndex];\n    if (lastActiveOption) {\n      lastActiveOption.setActive(false);\n    }\n\n    this._activeItemIndex = next;\n  }\n\n  protected resetActiveElement(): void {\n    const activeElement = this.options[this._activeItemIndex];\n\n    if (activeElement) {\n      activeElement.setActive(false);\n    }\n    this._activeItemIndex = -1;\n    this.triggerElement?.removeAttribute('aria-activedescendant');\n  }\n\n  protected setTriggerAttributes(element: HTMLInputElement): void {\n    setAriaComboBoxAttributes(element, ariaRoleOnHost ? this.id : this.overlayId, false);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-autocomplete': SbbAutocompleteElement;\n  }\n}\n"],"names":["ariaRoleOnHost","_a"],"mappings":"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"}
766
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"autocomplete.js","sources":["../../../src/elements/autocomplete/autocomplete-base-element.ts","../../../src/elements/autocomplete/autocomplete.ts"],"sourcesContent":["import {\n  type CSSResultGroup,\n  html,\n  isServer,\n  nothing,\n  type PropertyValues,\n  type TemplateResult,\n} from 'lit';\nimport { property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\n\nimport { SbbOpenCloseBaseElement } from '../core/base-elements.js';\nimport { SbbConnectedAbortController, SbbEscapableOverlayController } from '../core/controllers.js';\nimport { forceType, hostAttributes } from '../core/decorators.js';\nimport { findReferencedElement, isSafari, isZeroAnimationDuration } from '../core/dom.js';\nimport { SbbHydrationMixin, SbbNegativeMixin } from '../core/mixins.js';\nimport {\n  isEventOnElement,\n  overlayGapFixCorners,\n  removeAriaComboBoxAttributes,\n  setOverlayPosition,\n} from '../core/overlay.js';\nimport type { SbbOptionBaseElement } from '../option.js';\n\nimport style from './autocomplete-base-element.scss?lit&inline';\n\n/**\n * On Safari, the aria role 'listbox' must be on the host element, or else VoiceOver won't work at all.\n * On the other hand, JAWS and NVDA need the role to be \"closer\" to the options, or else optgroups won't work.\n */\nconst ariaRoleOnHost = isSafari;\n\nexport\n@hostAttributes({\n  popover: 'manual',\n})\nabstract class SbbAutocompleteBaseElement extends SbbNegativeMixin(\n  SbbHydrationMixin(SbbOpenCloseBaseElement),\n) {\n  public static override styles: CSSResultGroup = style;\n\n  /**\n   * The element where the autocomplete will attach; accepts both an element's id or an HTMLElement.\n   * If not set, it will search for the first 'sbb-form-field' ancestor.\n   */\n  @property() public accessor origin: string | HTMLElement | null = null;\n\n  /**\n   * The input element that will trigger the autocomplete opening; accepts both an element's id or an HTMLElement.\n   * By default, the autocomplete will open on focus, click, input or `ArrowDown` keypress of the 'trigger' element.\n   * If not set, will search for the first 'input' child of a 'sbb-form-field' ancestor.\n   */\n  @property() public accessor trigger: string | HTMLInputElement | null = null;\n\n  /** Whether the icon space is preserved when no icon is set. */\n  @forceType()\n  @property({ attribute: 'preserve-icon-space', reflect: true, type: Boolean })\n  public accessor preserveIconSpace: boolean = false;\n\n  /** Returns the element where autocomplete overlay is attached to. */\n  public get originElement(): HTMLElement {\n    if (!this._originElement) {\n      this._originElement = this._findOriginElement();\n    }\n    return this._originElement;\n  }\n  private _originElement?: HTMLElement;\n\n  /** Returns the trigger element. */\n  public get triggerElement(): HTMLInputElement | undefined {\n    return this._triggerElement;\n  }\n  private _triggerElement: HTMLInputElement | undefined;\n\n  protected abstract overlayId: string;\n  protected abstract panelRole: string;\n  /** @deprecated No longer used internally. */\n  protected abort = new SbbConnectedAbortController(this);\n  private _overlay!: HTMLElement;\n  private _optionContainer!: HTMLElement;\n  private _triggerEventsController!: AbortController;\n  private _openPanelEventsController!: AbortController;\n  private _isPointerDownEventOnMenu: boolean = false;\n  private _sbbEscapableOverlayController = new SbbEscapableOverlayController(this);\n\n  protected abstract get options(): SbbOptionBaseElement[];\n  protected abstract syncNegative(): void;\n  protected abstract setTriggerAttributes(element: HTMLInputElement): void;\n  protected abstract openedPanelKeyboardInteraction(event: KeyboardEvent): void;\n  protected abstract selectByKeyboard(event: KeyboardEvent): void;\n  protected abstract setNextActiveOption(event: KeyboardEvent): void;\n  protected abstract resetActiveElement(): void;\n\n  /** Opens the autocomplete. */\n  public open(): void {\n    if (\n      this.state !== 'closed' ||\n      !this._overlay ||\n      this.options.length === 0 ||\n      this._readonly()\n    ) {\n      return;\n    }\n    if (!this.willOpen.emit()) {\n      return;\n    }\n\n    this.showPopover?.();\n    this.state = 'opening';\n    this._triggerElement?.toggleAttribute('data-expanded', true);\n    this._setOverlayPosition();\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `opened` state.\n    if (this._isZeroAnimationDuration()) {\n      this._handleOpening();\n    }\n  }\n\n  /** Closes the autocomplete. */\n  public close(): void {\n    if (this.state !== 'opened') {\n      return;\n    }\n    if (!this.willClose.emit()) {\n      return;\n    }\n\n    this.state = 'closing';\n    this._triggerElement?.toggleAttribute('data-expanded', false);\n    this._openPanelEventsController.abort();\n\n    // If the animation duration is zero, the animationend event is not always fired reliably.\n    // In this case we directly set the `closed` state.\n    if (this._isZeroAnimationDuration()) {\n      this._handleClosing();\n    }\n  }\n\n  private _isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-options-panel-animation-duration');\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    if (ariaRoleOnHost) {\n      this.id ||= this.overlayId;\n    }\n    const formField = this.closest('sbb-form-field') ?? this.closest('[data-form-field]');\n\n    if (formField) {\n      this.negative = formField.hasAttribute('negative');\n    }\n\n    if (this.hasUpdated) {\n      this._componentSetup();\n    }\n    this.syncNegative();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (\n      (changedProperties.has('origin') && this.origin !== changedProperties.get('origin')) ||\n      (changedProperties.has('trigger') && this.trigger !== changedProperties.get('trigger'))\n    ) {\n      this._componentSetup();\n    }\n    if (changedProperties.has('negative')) {\n      this.syncNegative();\n    }\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    this._componentSetup();\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._triggerEventsController?.abort();\n    this._openPanelEventsController?.abort();\n  }\n\n  /** When an option is selected, update the input value and close the autocomplete. */\n  protected onOptionSelected(event: CustomEvent): void {\n    const target = event.target as SbbOptionBaseElement;\n    if (!target.selected) {\n      return;\n    }\n\n    // Deselect the previous options\n    this.options\n      .filter((option) => option.id !== target.id && option.selected)\n      .forEach((option) => (option.selected = false));\n\n    if (this.triggerElement) {\n      // Set the option value\n      // In order to support React onChange event, we have to get the setter and call it.\n      // https://github.com/facebook/react/issues/11600#issuecomment-345813130\n      const setValue = Object.getOwnPropertyDescriptor(HTMLInputElement.prototype, 'value')!.set!;\n      setValue.call(this.triggerElement, target.value);\n\n      // Manually trigger the change events\n      this.triggerElement.dispatchEvent(new Event('change', { bubbles: true }));\n      this.triggerElement.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));\n      this.triggerElement.focus();\n    }\n\n    this.close();\n  }\n\n  private _handleSlotchange(): void {\n    this._highlightOptions(this.triggerElement?.value);\n    this._openOnNewOptions();\n  }\n\n  /**\n   * If the 'input' is focused and there's a change in the number of options, open the autocomplete\n   */\n  private _openOnNewOptions(): void {\n    if (document?.activeElement === this.triggerElement) {\n      if (this.options.length > 0) {\n        this.open();\n      } else {\n        this.close();\n      }\n    }\n  }\n\n  /** The autocomplete should inherit 'readonly' state from the trigger. */\n  private _readonly(): boolean {\n    return this.triggerElement?.hasAttribute('readonly') ?? false;\n  }\n\n  private _componentSetup(): void {\n    if (isServer) {\n      return;\n    }\n    this._triggerEventsController?.abort();\n    this._openPanelEventsController?.abort();\n\n    this._originElement = undefined;\n    this.toggleAttribute(\n      'data-option-panel-origin-borderless',\n      !!this.closest?.('sbb-form-field')?.hasAttribute('borderless'),\n    );\n\n    this._bindTo(this._getTriggerElement());\n  }\n\n  /**\n   * Retrieve the element where the autocomplete will be attached.\n   * @returns 'origin' or the first 'sbb-form-field' ancestor.\n   */\n  private _findOriginElement(): HTMLElement {\n    let result: HTMLElement | undefined | null;\n\n    if (!this.origin) {\n      result = this.closest?.('sbb-form-field')?.shadowRoot?.querySelector?.('#overlay-anchor');\n    } else {\n      result = findReferencedElement(this.origin);\n    }\n\n    if (!result) {\n      throw new Error(\n        'Cannot find the origin element. Please specify a valid element or read the \"origin\" prop documentation',\n      );\n    }\n\n    return result;\n  }\n\n  /**\n   * Retrieve the element that will trigger the autocomplete opening.\n   * @returns 'trigger' or the first 'input' inside the origin element.\n   */\n  private _getTriggerElement(): HTMLInputElement {\n    if (!this.trigger) {\n      return this.closest?.('sbb-form-field')?.querySelector('input') as HTMLInputElement;\n    }\n\n    const result = findReferencedElement<HTMLInputElement>(this.trigger);\n\n    if (!result) {\n      throw new Error(\n        'Cannot find the trigger element. Please specify a valid element or read the \"trigger\" prop documentation',\n      );\n    }\n\n    return result;\n  }\n\n  private _bindTo(triggerElem: HTMLInputElement): void {\n    if (!triggerElem) {\n      return;\n    }\n\n    // Reset attributes to the old trigger and add them to the new one\n    this._removeTriggerAttributes(this.triggerElement);\n    this.setTriggerAttributes(triggerElem);\n\n    this._triggerElement = triggerElem;\n\n    this._setupTriggerEvents();\n  }\n\n  private _setupTriggerEvents(): void {\n    this._triggerEventsController = new AbortController();\n\n    // Open the overlay on focus, click, input and `ArrowDown` event\n    this.triggerElement?.addEventListener('focus', () => this.open(), {\n      signal: this._triggerEventsController.signal,\n    });\n    this.triggerElement?.addEventListener('click', () => this.open(), {\n      signal: this._triggerEventsController.signal,\n    });\n    this.triggerElement?.addEventListener(\n      'input',\n      (event) => {\n        this.open();\n        this._highlightOptions((event.target as HTMLInputElement).value);\n      },\n      { signal: this._triggerEventsController.signal },\n    );\n    this.triggerElement?.addEventListener(\n      'keydown',\n      (event: KeyboardEvent) => this._closedPanelKeyboardInteraction(event),\n      { signal: this._triggerEventsController.signal },\n    );\n  }\n\n  // Set overlay position, width and max height\n  private _setOverlayPosition(): void {\n    setOverlayPosition(\n      this._overlay,\n      this.originElement,\n      this._optionContainer,\n      this.shadowRoot!.querySelector('.sbb-autocomplete__container')!,\n      this,\n    );\n  }\n\n  /**\n   * On open/close animation end.\n   * In rare cases it can be that the animationEnd event is triggered twice.\n   * To avoid entering a corrupt state, exit when state is not expected.\n   */\n  private _onAnimationEnd(event: AnimationEvent): void {\n    if (event.animationName === 'open' && this.state === 'opening') {\n      this._handleOpening();\n    } else if (event.animationName === 'close' && this.state === 'closing') {\n      this._handleClosing();\n    }\n  }\n\n  private _handleOpening(): void {\n    this.state = 'opened';\n    this._attachOpenPanelEvents();\n    this.triggerElement?.setAttribute('aria-expanded', 'true');\n    this._sbbEscapableOverlayController.connect();\n    this.didOpen.emit();\n  }\n\n  private _handleClosing(): void {\n    this.state = 'closed';\n    this.hidePopover?.();\n    this.triggerElement?.setAttribute('aria-expanded', 'false');\n    this.resetActiveElement();\n    this._optionContainer.scrollTop = 0;\n    this._sbbEscapableOverlayController.disconnect();\n    this.didClose.emit();\n  }\n\n  private _attachOpenPanelEvents(): void {\n    this._openPanelEventsController = new AbortController();\n\n    // Recalculate the overlay position on scroll and window resize\n    document.addEventListener('scroll', () => this._setOverlayPosition(), {\n      passive: true,\n      signal: this._openPanelEventsController.signal,\n      // Without capture, other scroll contexts would not bubble to this event listener.\n      // Capture allows us to react to all scroll contexts in this DOM.\n      capture: true,\n    });\n    window.addEventListener('resize', () => this._setOverlayPosition(), {\n      passive: true,\n      signal: this._openPanelEventsController.signal,\n    });\n\n    // Close autocomplete on backdrop click\n    window.addEventListener('pointerdown', (ev) => this._pointerDownListener(ev), {\n      signal: this._openPanelEventsController.signal,\n    });\n    window.addEventListener('pointerup', (ev) => this._closeOnBackdropClick(ev), {\n      signal: this._openPanelEventsController.signal,\n    });\n\n    // Keyboard interactions\n    this.triggerElement?.addEventListener(\n      'keydown',\n      (event: KeyboardEvent) => this.openedPanelKeyboardInteraction(event),\n      {\n        signal: this._openPanelEventsController.signal,\n      },\n    );\n  }\n\n  // Check if the pointerdown event target is triggered on the menu.\n  private _pointerDownListener = (event: PointerEvent): void => {\n    this._isPointerDownEventOnMenu = isEventOnElement(this._overlay, event);\n  };\n\n  // If the click is outside the autocomplete, closes the panel.\n  private _closeOnBackdropClick = (event: PointerEvent): void => {\n    if (\n      !this._isPointerDownEventOnMenu &&\n      !isEventOnElement(this._overlay, event) &&\n      !isEventOnElement(this.originElement, event)\n    ) {\n      this.close();\n    }\n  };\n\n  private _closedPanelKeyboardInteraction(event: KeyboardEvent): void {\n    if (this.state !== 'closed') {\n      return;\n    }\n\n    switch (event.key) {\n      case 'Enter':\n      case 'ArrowDown':\n      case 'ArrowUp':\n        this.open();\n        break;\n    }\n  }\n\n  /** Highlight the searched text on the options. */\n  private _highlightOptions(searchTerm?: string): void {\n    if (searchTerm === null || searchTerm === undefined) {\n      return;\n    }\n    this.options.forEach((option) => option.highlight(searchTerm));\n  }\n\n  private _removeTriggerAttributes(element?: HTMLInputElement): void {\n    removeAriaComboBoxAttributes(element);\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-autocomplete__gap-fix\"></div>\n      <div class=\"sbb-autocomplete__container\">\n        <div class=\"sbb-autocomplete__gap-fix\">${overlayGapFixCorners()}</div>\n        <div\n          @animationend=${this._onAnimationEnd}\n          class=\"sbb-autocomplete__panel\"\n          ?data-open=${this.state === 'opened' || this.state === 'opening'}\n          ${ref((overlayRef?: Element) => (this._overlay = overlayRef as HTMLElement))}\n        >\n          <div class=\"sbb-autocomplete__wrapper\">\n            <div\n              class=\"sbb-autocomplete__options\"\n              role=${!ariaRoleOnHost ? this.panelRole : nothing}\n              id=${!ariaRoleOnHost ? this.overlayId : nothing}\n              ${ref((containerRef) => (this._optionContainer = containerRef as HTMLElement))}\n            >\n              <slot @slotchange=${this._handleSlotchange}></slot>\n            </div>\n          </div>\n        </div>\n      </div>\n    `;\n  }\n}\n","import { customElement } from 'lit/decorators.js';\n\nimport { getNextElementIndex } from '../core/a11y.js';\nimport { hostAttributes } from '../core/decorators.js';\nimport { isSafari } from '../core/dom.js';\nimport { setAriaComboBoxAttributes } from '../core/overlay.js';\nimport type { SbbOptGroupElement, SbbOptionElement } from '../option.js';\n\nimport { SbbAutocompleteBaseElement } from './autocomplete-base-element.js';\n\nlet nextId = 0;\n\n/**\n * On Safari, the aria role 'listbox' must be on the host element, or else VoiceOver won't work at all.\n * On the other hand, JAWS and NVDA need the role to be \"closer\" to the options, or else optgroups won't work.\n */\nconst ariaRoleOnHost = isSafari;\n\n/**\n * Combined with a native input, it displays a panel with a list of available options.\n *\n * @slot - Use the unnamed slot to add `sbb-option` or `sbb-optgroup` elements to the `sbb-autocomplete`.\n * @event {CustomEvent<void>} willOpen - Emits whenever the `sbb-autocomplete` starts the opening transition. Can be canceled.\n * @event {CustomEvent<void>} didOpen - Emits whenever the `sbb-autocomplete` is opened.\n * @event {CustomEvent<void>} willClose - Emits whenever the `sbb-autocomplete` begins the closing transition. Can be canceled.\n * @event {CustomEvent<void>} didClose - Emits whenever the `sbb-autocomplete` is closed.\n * @cssprop [--sbb-autocomplete-z-index=var(--sbb-overlay-default-z-index)] - To specify a custom stack order,\n * the `z-index` can be overridden by defining this CSS variable. The default `z-index` of the\n * component is set to `var(--sbb-overlay-default-z-index)` with a value of `1000`.\n */\nexport\n@customElement('sbb-autocomplete')\n@hostAttributes({\n  role: ariaRoleOnHost ? 'listbox' : null,\n})\nclass SbbAutocompleteElement extends SbbAutocompleteBaseElement {\n  protected overlayId = `sbb-autocomplete-${++nextId}`;\n  protected panelRole = 'listbox';\n  private _activeItemIndex = -1;\n\n  protected get options(): SbbOptionElement[] {\n    return Array.from(this.querySelectorAll?.('sbb-option') ?? []);\n  }\n\n  public constructor() {\n    super();\n    this.addEventListener?.('optionSelectionChange', (e: CustomEvent<void>) =>\n      this.onOptionSelected(e),\n    );\n  }\n\n  protected syncNegative(): void {\n    this.querySelectorAll?.('sbb-divider').forEach((divider) => (divider.negative = this.negative));\n\n    this.querySelectorAll?.<SbbOptionElement | SbbOptGroupElement>(\n      'sbb-option, sbb-optgroup',\n    ).forEach((element) => element.toggleAttribute('data-negative', this.negative));\n  }\n\n  protected openedPanelKeyboardInteraction(event: KeyboardEvent): void {\n    if (this.state !== 'opened') {\n      return;\n    }\n\n    switch (event.key) {\n      case 'Tab':\n        this.close();\n        break;\n\n      case 'Enter':\n        this.selectByKeyboard(event);\n        break;\n\n      case 'ArrowDown':\n      case 'ArrowUp':\n        this.setNextActiveOption(event);\n        break;\n    }\n  }\n\n  protected selectByKeyboard(event: KeyboardEvent): void {\n    event.preventDefault();\n    const activeOption = this.options[this._activeItemIndex];\n\n    if (activeOption) {\n      activeOption.setSelectedViaUserInteraction(true);\n    }\n  }\n\n  protected setNextActiveOption(event: KeyboardEvent): void {\n    const filteredOptions = this.options.filter(\n      (opt) => !opt.disabled && !opt.hasAttribute('data-group-disabled'),\n    );\n\n    // Get and activate the next active option\n    const next = getNextElementIndex(event, this._activeItemIndex, filteredOptions.length);\n    const nextActiveOption = filteredOptions[next];\n    nextActiveOption.setActive(true);\n    this.triggerElement?.setAttribute('aria-activedescendant', nextActiveOption.id);\n    nextActiveOption.scrollIntoView({ block: 'nearest' });\n\n    // Reset the previous active option\n    const lastActiveOption = filteredOptions[this._activeItemIndex];\n    if (lastActiveOption) {\n      lastActiveOption.setActive(false);\n    }\n\n    this._activeItemIndex = next;\n  }\n\n  protected resetActiveElement(): void {\n    const activeElement = this.options[this._activeItemIndex];\n\n    if (activeElement) {\n      activeElement.setActive(false);\n    }\n    this._activeItemIndex = -1;\n    this.triggerElement?.removeAttribute('aria-activedescendant');\n  }\n\n  protected setTriggerAttributes(element: HTMLInputElement): void {\n    setAriaComboBoxAttributes(element, ariaRoleOnHost ? this.id : this.overlayId, false);\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-autocomplete': SbbAutocompleteElement;\n  }\n}\n"],"names":["ariaRoleOnHost","_a"],"mappings":"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"}
@@ -3,10 +3,9 @@ import { AbstractConstructor, SbbDisabledMixinType, SbbNegativeMixinType } from
3
3
  import { SbbIconNameMixinType } from '../../icon.js';
4
4
  export type SbbButtonCommonElement = SbbButtonCommonElementMixinType & SbbActionBaseElement;
5
5
  export type SbbButtonSize = 'l' | 'm' | 's';
6
- export declare class SbbButtonCommonElementMixinType implements SbbNegativeMixinType, Partial<SbbDisabledMixinType>, Partial<SbbIconNameMixinType> {
6
+ export declare class SbbButtonCommonElementMixinType extends SbbIconNameMixinType implements SbbNegativeMixinType, Partial<SbbDisabledMixinType> {
7
7
  accessor size: SbbButtonSize;
8
8
  accessor disabled: boolean;
9
- accessor iconName: string;
10
9
  accessor negative: boolean;
11
10
  }
12
11
  export declare const SbbButtonCommonElementMixin: <T extends AbstractConstructor<SbbActionBaseElement>>(superClass: T) => AbstractConstructor<SbbButtonCommonElementMixinType> & T;
@@ -1 +1 @@
1
- {"version":3,"file":"button-common.d.ts","sourceRoot":"","sources":["../../../../../src/elements/button/common/button-common.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAGxE,OAAO,KAAK,EACV,mBAAmB,EACnB,oBAAoB,EACpB,oBAAoB,EACrB,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EAAoB,KAAK,oBAAoB,EAAE,MAAM,eAAe,CAAC;AAE5E,MAAM,MAAM,sBAAsB,GAAG,+BAA+B,GAAG,oBAAoB,CAAC;AAE5F,MAAM,MAAM,aAAa,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AAE5C,MAAM,CAAC,OAAO,OAAO,+BACnB,YAAW,oBAAoB,EAAE,OAAO,CAAC,oBAAoB,CAAC,EAAE,OAAO,CAAC,oBAAoB,CAAC;IAE7F,SAAgB,IAAI,EAAE,aAAa,CAAC;IACpC,SAAgB,QAAQ,EAAE,OAAO,CAAC;IAClC,SAAgB,QAAQ,EAAE,MAAM,CAAC;IACjC,SAAgB,QAAQ,EAAE,OAAO,CAAC;CACnC;AAGD,eAAO,MAAM,2BAA2B,GAAI,CAAC,SAAS,mBAAmB,CAAC,oBAAoB,CAAC,EAC7F,YAAY,CAAC,KACZ,mBAAmB,CAAC,+BAA+B,CAAC,GAAG,CA0BzD,CAAC"}
1
+ {"version":3,"file":"button-common.d.ts","sourceRoot":"","sources":["../../../../../src/elements/button/common/button-common.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAGxE,OAAO,KAAK,EACV,mBAAmB,EACnB,oBAAoB,EACpB,oBAAoB,EACrB,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EAAoB,KAAK,oBAAoB,EAAE,MAAM,eAAe,CAAC;AAE5E,MAAM,MAAM,sBAAsB,GAAG,+BAA+B,GAAG,oBAAoB,CAAC;AAE5F,MAAM,MAAM,aAAa,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AAE5C,MAAM,CAAC,OAAO,OAAO,+BACnB,SAAQ,oBACR,YAAW,oBAAoB,EAAE,OAAO,CAAC,oBAAoB,CAAC;IAE9D,SAAgB,IAAI,EAAE,aAAa,CAAC;IACpC,SAAgB,QAAQ,EAAE,OAAO,CAAC;IAClC,SAAgB,QAAQ,EAAE,OAAO,CAAC;CACnC;AAGD,eAAO,MAAM,2BAA2B,GAAI,CAAC,SAAS,mBAAmB,CAAC,oBAAoB,CAAC,EAC7F,YAAY,CAAC,KACZ,mBAAmB,CAAC,+BAA+B,CAAC,GAAG,CA0BzD,CAAC"}