@sbb-esta/lyne-elements 4.1.0 → 4.3.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.
- package/accordion/accordion.component.d.ts.map +1 -1
- package/accordion/accordion.component.js +12 -16
- package/action-group/action-group.component.d.ts.map +1 -1
- package/action-group/action-group.component.js +18 -21
- package/autocomplete/autocomplete-base-element.d.ts.map +1 -1
- package/autocomplete/autocomplete-base-element.js +25 -26
- package/autocomplete/autocomplete.component.d.ts.map +1 -1
- package/autocomplete/autocomplete.component.js +1 -1
- package/breadcrumb/breadcrumb-group/breadcrumb-group.component.d.ts +3 -1
- package/breadcrumb/breadcrumb-group/breadcrumb-group.component.d.ts.map +1 -1
- package/breadcrumb/breadcrumb-group/breadcrumb-group.component.js +45 -52
- package/button/common.d.ts.map +1 -1
- package/button/common.js +5 -4
- package/button/mini-button/mini-button.component.d.ts +2 -2
- package/button/mini-button/mini-button.component.d.ts.map +1 -1
- package/button/mini-button/mini-button.component.js +22 -20
- package/button/mini-button-group/mini-button-group.component.d.ts.map +1 -1
- package/button/mini-button-group/mini-button-group.component.js +14 -10
- package/button/mini-button-link/mini-button-link.component.d.ts +21 -0
- package/button/mini-button-link/mini-button-link.component.d.ts.map +1 -0
- package/button/mini-button-link/mini-button-link.component.js +35 -0
- package/button/mini-button-link.d.ts +5 -0
- package/button/mini-button-link.d.ts.map +1 -0
- package/button/mini-button-link.js +4 -0
- package/button.d.ts +1 -0
- package/button.d.ts.map +1 -1
- package/button.js +28 -25
- package/calendar/calendar.component.js +52 -52
- package/card/card/card.component.js +14 -14
- package/chip/chip-group/chip-group.component.d.ts +2 -5
- package/chip/chip-group/chip-group.component.d.ts.map +1 -1
- package/chip/chip-group/chip-group.component.js +70 -68
- package/core/controllers/media-matchers-controller.js +2 -2
- package/core/interfaces/overlay-close-details.d.ts +1 -0
- package/core/interfaces/overlay-close-details.d.ts.map +1 -1
- package/core/styles/core.scss +19 -0
- package/core/styles/mixins/buttons.scss +1 -2
- package/core/styles/mixins/card.scss +9 -3
- package/core/styles/mixins/inputs.scss +1 -1
- package/core/styles/normalize.scss +4 -6
- package/core.css +32 -4
- package/custom-elements.json +2080 -1104
- package/development/accordion/accordion.component.d.ts.map +1 -1
- package/development/accordion/accordion.component.js +2 -6
- package/development/action-group/action-group.component.d.ts.map +1 -1
- package/development/action-group/action-group.component.js +13 -22
- package/development/autocomplete/autocomplete-base-element.d.ts.map +1 -1
- package/development/autocomplete/autocomplete-base-element.js +4 -2
- package/development/autocomplete/autocomplete.component.d.ts.map +1 -1
- package/development/autocomplete/autocomplete.component.js +2 -2
- package/development/breadcrumb/breadcrumb-group/breadcrumb-group.component.d.ts +3 -1
- package/development/breadcrumb/breadcrumb-group/breadcrumb-group.component.d.ts.map +1 -1
- package/development/breadcrumb/breadcrumb-group/breadcrumb-group.component.js +27 -31
- package/development/button/common.d.ts.map +1 -1
- package/development/button/common.js +3 -2
- package/development/button/mini-button/mini-button.component.d.ts +2 -2
- package/development/button/mini-button/mini-button.component.d.ts.map +1 -1
- package/development/button/mini-button/mini-button.component.js +7 -35
- package/development/button/mini-button-group/mini-button-group.component.d.ts.map +1 -1
- package/development/button/mini-button-group/mini-button-group.component.js +8 -4
- package/development/button/mini-button-link/mini-button-link.component.d.ts +21 -0
- package/development/button/mini-button-link/mini-button-link.component.d.ts.map +1 -0
- package/development/button/mini-button-link/mini-button-link.component.js +47 -0
- package/development/button/mini-button-link.d.ts +5 -0
- package/development/button/mini-button-link.d.ts.map +1 -0
- package/development/button/mini-button-link.js +5 -0
- package/development/button.d.ts +1 -0
- package/development/button.d.ts.map +1 -1
- package/development/button.js +6 -3
- package/development/calendar/calendar.component.js +3 -5
- package/development/card/card/card.component.js +11 -1
- package/development/chip/chip-group/chip-group.component.d.ts +2 -5
- package/development/chip/chip-group/chip-group.component.d.ts.map +1 -1
- package/development/chip/chip-group/chip-group.component.js +78 -14
- package/development/core/controllers/media-matchers-controller.js +1 -1
- package/development/core/interfaces/overlay-close-details.d.ts +1 -0
- package/development/core/interfaces/overlay-close-details.d.ts.map +1 -1
- package/development/dialog/dialog/dialog.component.d.ts +4 -0
- package/development/dialog/dialog/dialog.component.d.ts.map +1 -1
- package/development/dialog/dialog/dialog.component.js +23 -3
- package/development/dialog/dialog-actions/dialog-actions.component.js +2 -1
- package/development/dialog/dialog.js +5 -2
- package/development/dialog.js +5 -2
- package/development/divider/divider.component.d.ts +2 -2
- package/development/divider/divider.component.d.ts.map +1 -1
- package/development/divider/divider.component.js +4 -6
- package/development/expansion-panel/expansion-panel/expansion-panel.component.d.ts.map +1 -1
- package/development/expansion-panel/expansion-panel/expansion-panel.component.js +39 -34
- package/development/expansion-panel/expansion-panel-content/expansion-panel-content.component.d.ts.map +1 -1
- package/development/expansion-panel/expansion-panel-content/expansion-panel-content.component.js +15 -13
- package/development/expansion-panel/expansion-panel-header/expansion-panel-header.component.js +23 -21
- package/development/flip-card/flip-card/flip-card.component.js +2 -3
- package/development/form-field/form-field/form-field.component.d.ts +2 -0
- package/development/form-field/form-field/form-field.component.d.ts.map +1 -1
- package/development/form-field/form-field/form-field.component.js +6 -2
- package/development/image/image.component.js +1 -1
- package/development/lead-container/lead-container.component.d.ts +3 -1
- package/development/lead-container/lead-container.component.d.ts.map +1 -1
- package/development/lead-container/lead-container.component.js +7 -2
- package/development/{mini-button-common-CWTMR_Lu.js → mini-button-label-common-DzMdb-kV.js} +37 -3
- package/development/navigation/navigation-section/navigation-section.component.js +4 -4
- package/development/option/option-hint/option-hint.component.js +2 -1
- package/development/overlay/overlay-base-element.d.ts +29 -3
- package/development/overlay/overlay-base-element.d.ts.map +1 -1
- package/development/overlay/overlay-base-element.js +19 -15
- package/development/overlay/overlay.component.d.ts +3 -0
- package/development/overlay/overlay.component.d.ts.map +1 -1
- package/development/overlay/overlay.component.js +19 -2
- package/development/overlay.js +3 -1
- package/development/paginator/paginator/paginator.component.js +2 -3
- package/development/{sbb-tokens-CZCt5L4q.js → sbb-tokens-DQT_xEIZ.js} +7 -7
- package/development/stepper/step/step.component.d.ts +4 -0
- package/development/stepper/step/step.component.d.ts.map +1 -1
- package/development/stepper/step/step.component.js +5 -1
- package/development/stepper/stepper/stepper.component.d.ts +15 -0
- package/development/stepper/stepper/stepper.component.d.ts.map +1 -1
- package/development/stepper/stepper/stepper.component.js +19 -4
- package/development/stepper/stepper.js +2 -1
- package/development/stepper.js +2 -1
- package/dialog/dialog/dialog.component.d.ts +4 -0
- package/dialog/dialog/dialog.component.d.ts.map +1 -1
- package/dialog/dialog/dialog.component.js +46 -26
- package/dialog/dialog-actions/dialog-actions.component.js +1 -1
- package/dialog/dialog.js +5 -2
- package/dialog.js +9 -6
- package/divider/divider.component.d.ts +2 -2
- package/divider/divider.component.d.ts.map +1 -1
- package/divider/divider.component.js +12 -12
- package/expansion-panel/expansion-panel/expansion-panel.component.d.ts.map +1 -1
- package/expansion-panel/expansion-panel/expansion-panel.component.js +31 -31
- package/expansion-panel/expansion-panel-content/expansion-panel-content.component.d.ts.map +1 -1
- package/expansion-panel/expansion-panel-content/expansion-panel-content.component.js +10 -14
- package/expansion-panel/expansion-panel-header/expansion-panel-header.component.js +19 -19
- package/flip-card/flip-card/flip-card.component.js +11 -11
- package/form-field/form-field/form-field.component.d.ts +2 -0
- package/form-field/form-field/form-field.component.d.ts.map +1 -1
- package/form-field/form-field/form-field.component.js +5 -1
- package/image/image.component.js +1 -1
- package/index.d.ts +2 -0
- package/index.js +2 -0
- package/lead-container/lead-container.component.d.ts +3 -1
- package/lead-container/lead-container.component.d.ts.map +1 -1
- package/lead-container/lead-container.component.js +9 -8
- package/{mini-button-common-Bb4ri3Rn.js → mini-button-label-common-ps7PVXtB.js} +4 -3
- package/navigation/navigation-section/navigation-section.component.js +1 -1
- package/normalize.css +4 -6
- package/off-brand-theme.css +36 -10
- package/option/option-hint/option-hint.component.js +7 -7
- package/overlay/overlay-base-element.d.ts +29 -3
- package/overlay/overlay-base-element.d.ts.map +1 -1
- package/overlay/overlay-base-element.js +51 -54
- package/overlay/overlay.component.d.ts +3 -0
- package/overlay/overlay.component.d.ts.map +1 -1
- package/overlay/overlay.component.js +48 -31
- package/overlay.js +7 -5
- package/package.json +6 -1
- package/paginator/paginator/paginator.component.js +1 -1
- package/safety-theme.css +36 -10
- package/{sbb-tokens-DruExozg.js → sbb-tokens-HiNSQasB.js} +6 -6
- package/standard-theme.css +36 -10
- package/stepper/step/step.component.d.ts +4 -0
- package/stepper/step/step.component.d.ts.map +1 -1
- package/stepper/step/step.component.js +4 -0
- package/stepper/stepper/stepper.component.d.ts +15 -0
- package/stepper/stepper/stepper.component.d.ts.map +1 -1
- package/stepper/stepper/stepper.component.js +41 -33
- package/stepper/stepper.js +3 -2
- package/stepper.js +4 -3
|
@@ -40,6 +40,11 @@ const style = css`:host {
|
|
|
40
40
|
border-radius: var(--sbb-card-border-radius);
|
|
41
41
|
pointer-events: none;
|
|
42
42
|
}
|
|
43
|
+
:host {
|
|
44
|
+
--sbb-card-padding-block: var(--sbb-card-padding-block-default);
|
|
45
|
+
--sbb-card-with-badge-padding-block: var(--sbb-card-with-badge-padding-block-default);
|
|
46
|
+
--sbb-card-padding-inline: var(--sbb-card-padding-inline-default);
|
|
47
|
+
}
|
|
43
48
|
|
|
44
49
|
:host(:where([color=white])) {
|
|
45
50
|
--sbb-card-background-color: var(--sbb-background-color-1);
|
|
@@ -67,6 +72,11 @@ const style = css`:host {
|
|
|
67
72
|
--sbb-focus-outline-color: inherit;
|
|
68
73
|
}
|
|
69
74
|
|
|
75
|
+
:host(:where(:not([color]))) {
|
|
76
|
+
--sbb-card-background-color: var(--sbb-background-color-1);
|
|
77
|
+
--sbb-card-border-color: transparent;
|
|
78
|
+
}
|
|
79
|
+
|
|
70
80
|
:host(:is(:state(has-active-action),[state--has-active-action])) {
|
|
71
81
|
--sbb-card-border-color: var(--sbb-border-color-3);
|
|
72
82
|
--sbb-card-border-width: var(--sbb-border-width-2x);
|
|
@@ -227,4 +237,4 @@ let SbbCardElement = (() => {
|
|
|
227
237
|
export {
|
|
228
238
|
SbbCardElement
|
|
229
239
|
};
|
|
230
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FyZC5jb21wb25lbnQuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9lbGVtZW50cy9jYXJkL2NhcmQvY2FyZC5jb21wb25lbnQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBDU1NSZXN1bHRHcm91cCwgVGVtcGxhdGVSZXN1bHQgfSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgaHRtbCwgTGl0RWxlbWVudCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50LCBwcm9wZXJ0eSB9IGZyb20gJ2xpdC9kZWNvcmF0b3JzLmpzJztcblxuaW1wb3J0IHsgU2JiRWxlbWVudEludGVybmFsc01peGluIH0gZnJvbSAnLi4vLi4vY29yZS9taXhpbnMudHMnO1xuaW1wb3J0IHsgYm94U2l6aW5nU3R5bGVzIH0gZnJvbSAnLi4vLi4vY29yZS9zdHlsZXMudHMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9jYXJkLnNjc3M/bGl0JmlubGluZSc7XG5cbi8qKlxuICogSXQgZGlzcGxheXMgY29udGVudCByZWxhdGVkIHRvIGEgc2luZ2xlIHN1YmplY3QuXG4gKlxuICogQHNsb3QgLSBVc2UgdGhlIHVubmFtZWQgc2xvdCB0byBhZGQgY29udGVudCB0byB0aGUgY2FyZC5cbiAqIEBzbG90IGJhZGdlIC0gVXNlIHRoaXMgc2xvdCB0byByZW5kZXIgYSBgc2JiLWNhcmQtYmFkZ2VgIGNvbXBvbmVudC5cbiAqIEBzbG90IGFjdGlvbiAtIFVzZSB0aGlzIHNsb3QgdG8gcmVuZGVyIGEgYHNiYi1jYXJkLWJ1dHRvbmAgb3IgYSBgc2JiLWNhcmQtbGlua2AgY29tcG9uZW50LlxuICovXG5leHBvcnRcbkBjdXN0b21FbGVtZW50KCdzYmItY2FyZCcpXG5jbGFzcyBTYmJDYXJkRWxlbWVudCBleHRlbmRzIFNiYkVsZW1lbnRJbnRlcm5hbHNNaXhpbihMaXRFbGVtZW50KSB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IFtib3hTaXppbmdTdHlsZXMsIHN0eWxlXTtcblxuICAvKiogT3B0aW9uIHRvIHNldCB0aGUgY29tcG9uZW50J3MgYmFja2dyb3VuZCBjb2xvci4gKi9cbiAgQHByb3BlcnR5KHsgcmVmbGVjdDogdHJ1ZSB9KSBwdWJsaWMgYWNjZXNzb3IgY29sb3I6XG4gICAgfCAnd2hpdGUnXG4gICAgfCAnbWlsaydcbiAgICB8ICd0cmFuc3BhcmVudC1ib3JkZXJlZCdcbiAgICB8ICd0cmFuc3BhcmVudC1ib3JkZXJlZC1kYXNoZWQnID0gJ3doaXRlJztcblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVyKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICByZXR1cm4gaHRtbGBcbiAgICAgIDxzbG90IG5hbWU9XCJhY3Rpb25cIj48L3Nsb3Q+XG4gICAgICA8c3BhbiBjbGFzcz1cInNiYi1jYXJkX193cmFwcGVyXCI+XG4gICAgICAgIDxzbG90Pjwvc2xvdD5cbiAgICAgIDwvc3Bhbj5cbiAgICAgIDxzcGFuIGNsYXNzPVwic2JiLWNhcmRfX2JhZGdlLXdyYXBwZXJcIj5cbiAgICAgICAgPHNsb3QgbmFtZT1cImJhZGdlXCI+
|
|
240
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FyZC5jb21wb25lbnQuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9lbGVtZW50cy9jYXJkL2NhcmQvY2FyZC5jb21wb25lbnQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBDU1NSZXN1bHRHcm91cCwgVGVtcGxhdGVSZXN1bHQgfSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgaHRtbCwgTGl0RWxlbWVudCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50LCBwcm9wZXJ0eSB9IGZyb20gJ2xpdC9kZWNvcmF0b3JzLmpzJztcblxuaW1wb3J0IHsgU2JiRWxlbWVudEludGVybmFsc01peGluIH0gZnJvbSAnLi4vLi4vY29yZS9taXhpbnMudHMnO1xuaW1wb3J0IHsgYm94U2l6aW5nU3R5bGVzIH0gZnJvbSAnLi4vLi4vY29yZS9zdHlsZXMudHMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9jYXJkLnNjc3M/bGl0JmlubGluZSc7XG5cbi8qKlxuICogSXQgZGlzcGxheXMgY29udGVudCByZWxhdGVkIHRvIGEgc2luZ2xlIHN1YmplY3QuXG4gKlxuICogQHNsb3QgLSBVc2UgdGhlIHVubmFtZWQgc2xvdCB0byBhZGQgY29udGVudCB0byB0aGUgY2FyZC5cbiAqIEBzbG90IGJhZGdlIC0gVXNlIHRoaXMgc2xvdCB0byByZW5kZXIgYSBgc2JiLWNhcmQtYmFkZ2VgIGNvbXBvbmVudC5cbiAqIEBzbG90IGFjdGlvbiAtIFVzZSB0aGlzIHNsb3QgdG8gcmVuZGVyIGEgYHNiYi1jYXJkLWJ1dHRvbmAgb3IgYSBgc2JiLWNhcmQtbGlua2AgY29tcG9uZW50LlxuICovXG5leHBvcnRcbkBjdXN0b21FbGVtZW50KCdzYmItY2FyZCcpXG5jbGFzcyBTYmJDYXJkRWxlbWVudCBleHRlbmRzIFNiYkVsZW1lbnRJbnRlcm5hbHNNaXhpbihMaXRFbGVtZW50KSB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IFtib3hTaXppbmdTdHlsZXMsIHN0eWxlXTtcblxuICAvKiogT3B0aW9uIHRvIHNldCB0aGUgY29tcG9uZW50J3MgYmFja2dyb3VuZCBjb2xvci4gKi9cbiAgQHByb3BlcnR5KHsgcmVmbGVjdDogdHJ1ZSB9KSBwdWJsaWMgYWNjZXNzb3IgY29sb3I6XG4gICAgfCAnd2hpdGUnXG4gICAgfCAnbWlsaydcbiAgICB8ICd0cmFuc3BhcmVudC1ib3JkZXJlZCdcbiAgICB8ICd0cmFuc3BhcmVudC1ib3JkZXJlZC1kYXNoZWQnID0gJ3doaXRlJztcblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVyKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICByZXR1cm4gaHRtbGBcbiAgICAgIDxzbG90IG5hbWU9XCJhY3Rpb25cIj48L3Nsb3Q+XG4gICAgICA8c3BhbiBjbGFzcz1cInNiYi1jYXJkX193cmFwcGVyXCI+XG4gICAgICAgIDxzbG90Pjwvc2xvdD5cbiAgICAgIDwvc3Bhbj5cbiAgICAgIDxzcGFuIGNsYXNzPVwic2JiLWNhcmRfX2JhZGdlLXdyYXBwZXJcIj5cbiAgICAgICAgPHNsb3QgbmFtZT1cImJhZGdlXCI+PC9zbG90PlxuICAgICAgPC9zcGFuPlxuICAgIGA7XG4gIH1cbn1cblxuZGVjbGFyZSBnbG9iYWwge1xuICBpbnRlcmZhY2UgSFRNTEVsZW1lbnRUYWdOYW1lTWFwIHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25hbWluZy1jb252ZW50aW9uXG4gICAgJ3NiYi1jYXJkJzogU2JiQ2FyZEVsZW1lbnQ7XG4gIH1cbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0lBa0JNLGtCQUFjLE1BQUE7OzBCQURuQixjQUFjLFVBQVUsQ0FBQzs7OztvQkFDRyx5QkFBeUIsVUFBVTs7OztBQUEzQyxFQUFBLG1CQUFRLFlBQW9DO0FBQUE7O0FBSWxDLGtEQUFBLGtCQUFBLE1BQUEscUJBSU8sT0FBTzs7OztJQUpkLElBQWdCLFFBQUs7QUFBQSxhQUFBLG1CQUFBO0FBQUEsSUFBQTtBQUFBLElBQXJCLElBQWdCLE1BQUssT0FBQTtBQUFBLHlCQUFBLHlCQUFBO0FBQUEsSUFBQTtBQUFBLElBTS9CLFNBQU07QUFDdkIsYUFBTztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQSxJQVNUO0FBQUEsS0FoQjZCOztBQUE1Qix3QkFBQSxDQUFBLFNBQVMsRUFBRSxTQUFTLEtBQUEsQ0FBTSxDQUFDO0FBQUMsaUJBQUEsSUFBQSxNQUFBLG1CQUFBLEVBQUEsTUFBQSxZQUFBLE1BQUEsU0FBQSxRQUFBLE9BQUEsU0FBQSxPQUFBLFFBQUEsRUFBQSxLQUFBLENBQUEsUUFBQSxXQUFBLEtBQUEsS0FBQSxDQUFBLFFBQUEsSUFBZ0IsT0FBSyxLQUFBLENBQUEsS0FBQSxVQUFBO0FBQUEsVUFBTCxRQUFLO0FBQUEsSUFBQSxLQUFBLFVBQUEsVUFBQSxHQUFBLHFCQUFBLHdCQUFBO0FBSnBELGlCQUFBLE1BQUEsbUJBQUEsRUFBQSxPQUFBLFdBQUEsR0FBQSxrQkFBQSxFQUFBLE1BQUEsU0FBQSxNQUFBLFdBQUEsTUFBQSxVQUFBLFVBQUEsR0FBQSxNQUFBLHVCQUFBOzs7UUFDeUIsR0FBQSxTQUF5QixDQUFDLGlCQUFpQixLQUFLLEdBRG5FLGtCQUFBLFlBQUEsdUJBQUEsR0FBZTs7OyJ9
|
|
@@ -41,15 +41,12 @@ export declare class SbbChipGroupElement<T = string> extends SbbChipGroupElement
|
|
|
41
41
|
* Listens to the changes on `readonly` and `disabled` attributes of `<input>`.
|
|
42
42
|
*/
|
|
43
43
|
private _inputAttributeObserver;
|
|
44
|
-
/**
|
|
45
|
-
* Listens to the 'size' changes on the `sbb-form-field`.
|
|
46
|
-
*/
|
|
47
|
-
private _formFieldAttributeObserver;
|
|
48
44
|
private _inputElement;
|
|
49
45
|
private _inputAbortController;
|
|
50
46
|
private _language;
|
|
51
47
|
private _previousSize?;
|
|
52
48
|
constructor();
|
|
49
|
+
private _updateLabelState;
|
|
53
50
|
connectedCallback(): void;
|
|
54
51
|
protected willUpdate(changedProperties: PropertyValues): void;
|
|
55
52
|
/** @internal */
|
|
@@ -87,7 +84,7 @@ export declare class SbbChipGroupElement<T = string> extends SbbChipGroupElement
|
|
|
87
84
|
private _createChipElement;
|
|
88
85
|
private _reactToInputChanges;
|
|
89
86
|
private _proxyStateToChips;
|
|
90
|
-
private
|
|
87
|
+
private _updateSize;
|
|
91
88
|
private _updateInputDescription;
|
|
92
89
|
protected render(): TemplateResult;
|
|
93
90
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"chip-group.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/chip/chip-group/chip-group.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAGnB,UAAU,EACV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAOb,OAAO,EACL,KAAK,iBAAiB,EACtB,KAAK,gBAAgB,EAMtB,MAAM,sBAAsB,CAAC;AAU9B,MAAM,WAAW,gCAAgC,CAAC,CAAC,GAAG,MAAM;IAC1D,mDAAmD;IACnD,MAAM,EAAE,OAAO,GAAG,cAAc,CAAC;IACjC;;;;OAIG;IACH,KAAK,EAAE,CAAC,GAAG,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,wDAAwD;IACxD,QAAQ,CAAC,KAAK,EAAE,CAAC,GAAG,IAAI,CAAC;IACzB,oDAAoD;IACpD,QAAQ,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;CAC/B;;AAED;;;;;GAKG;AACH,qBAEM,mBAAmB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,wBAE7C;IACC,gBAAgC,IAAI,aAAa;IACjD,OAAuB,MAAM,EAAE,cAAc,CAA4B;IACzE,gBAAuB,MAAM;;;;MAIlB;IAEX,iCAAiC;IACjC,IACW,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,GAAG,IAAI,EA2B1C;IACD,IAAW,KAAK,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,CAE/B;IAED,8DAA8D;IAC9D,SACgB,WAAW,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC,KAAK,MAAM,CAAC,GAAG,IAAI,CAAQ;IAElE,2FAA2F;IAC3F,SACgB,aAAa,EAAE,MAAM,EAAE,CAAa;IAEpD;;OAEG;IACH,OAAO,CAAC,uBAAuB,CAEtB;IAET
|
|
1
|
+
{"version":3,"file":"chip-group.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/chip/chip-group/chip-group.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAGnB,UAAU,EACV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAOb,OAAO,EACL,KAAK,iBAAiB,EACtB,KAAK,gBAAgB,EAMtB,MAAM,sBAAsB,CAAC;AAU9B,MAAM,WAAW,gCAAgC,CAAC,CAAC,GAAG,MAAM;IAC1D,mDAAmD;IACnD,MAAM,EAAE,OAAO,GAAG,cAAc,CAAC;IACjC;;;;OAIG;IACH,KAAK,EAAE,CAAC,GAAG,MAAM,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,wDAAwD;IACxD,QAAQ,CAAC,KAAK,EAAE,CAAC,GAAG,IAAI,CAAC;IACzB,oDAAoD;IACpD,QAAQ,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;CAC/B;;AAED;;;;;GAKG;AACH,qBAEM,mBAAmB,CAAC,CAAC,GAAG,MAAM,CAAE,SAAQ,wBAE7C;IACC,gBAAgC,IAAI,aAAa;IACjD,OAAuB,MAAM,EAAE,cAAc,CAA4B;IACzE,gBAAuB,MAAM;;;;MAIlB;IAEX,iCAAiC;IACjC,IACW,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,GAAG,IAAI,EA2B1C;IACD,IAAW,KAAK,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,CAE/B;IAED,8DAA8D;IAC9D,SACgB,WAAW,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC,KAAK,MAAM,CAAC,GAAG,IAAI,CAAQ;IAElE,2FAA2F;IAC3F,SACgB,aAAa,EAAE,MAAM,EAAE,CAAa;IAEpD;;OAEG;IACH,OAAO,CAAC,uBAAuB,CAEtB;IAET,OAAO,CAAC,aAAa,CAA+B;IACpD,OAAO,CAAC,qBAAqB,CAA8B;IAC3D,OAAO,CAAC,SAAS,CAAmC;IACpD,OAAO,CAAC,aAAa,CAAC,CAA8B;;IAoBpD,OAAO,CAAC,iBAAiB;IAIT,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;YASO,aAAa;cAUR,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;IAwCvB;;QAEI;IACJ,OAAO,CAAC,cAAc;IAyBtB;;QAEI;IACJ,OAAO,CAAC,eAAe;IAoBvB;;OAEG;IACH,OAAO,CAAC,oBAAoB;IAuB5B,OAAO,CAAC,0BAA0B;IAelC,OAAO,CAAC,WAAW;IAOnB;;;OAGG;IACH,OAAO,CAAC,UAAU;IAgBlB,OAAO,CAAC,gBAAgB;IAYxB,OAAO,CAAC,kBAAkB;IAwB1B,OAAO,CAAC,oBAAoB;IAK5B,OAAO,CAAC,kBAAkB;IAQ1B,OAAO,CAAC,WAAW;IAUnB,OAAO,CAAC,uBAAuB;cAUZ,MAAM,IAAI,cAAc;CAO5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,gBAAgB,EAAE,mBAAmB,CAAC;KACvC;CACF;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,mBAAmB;QAC3B,iBAAiB,EAAE,WAAW,CAAC,gCAAgC,CAAC,GAAG,CAAC,CAAC,CAAC;KACvE;CACF"}
|
|
@@ -9,14 +9,16 @@ import { __esDecorate, __runInitializers } from "tslib";
|
|
|
9
9
|
import { css, LitElement, isServer, html } from "lit";
|
|
10
10
|
import { customElement, property } from "lit/decorators.js";
|
|
11
11
|
import { isArrowKeyPressed, getNextElementIndex } from "../../core/a11y.js";
|
|
12
|
-
import { SbbLanguageController } from "../../core/controllers.js";
|
|
13
|
-
import { isLean } from "../../core/dom.js";
|
|
12
|
+
import { SbbLanguageController, SbbPropertyWatcherController } from "../../core/controllers.js";
|
|
13
|
+
import { isLean } from "../../core/dom/lean-context.js";
|
|
14
14
|
import { i18nSelectionRequired, i18nChipGroupInputDescription } from "../../core/i18n.js";
|
|
15
15
|
import { SbbRequiredMixin, SbbDisabledMixin, SbbNegativeMixin, SbbFormAssociatedMixin, SbbElementInternalsMixin } from "../../core/mixins.js";
|
|
16
16
|
import { boxSizingStyles } from "../../core/styles.js";
|
|
17
17
|
import { SbbChipElement } from "../chip.js";
|
|
18
18
|
const style = css`:host {
|
|
19
19
|
--sbb-chip-group-input-min-width: 9.375rem;
|
|
20
|
+
--_sbb-chip-group-margin-block-start-default: 0.125rem;
|
|
21
|
+
--_sbb-chip-group-margin-block-start-default-large: 0.21875rem;
|
|
20
22
|
max-width: 100%;
|
|
21
23
|
}
|
|
22
24
|
|
|
@@ -29,8 +31,69 @@ const style = css`:host {
|
|
|
29
31
|
}
|
|
30
32
|
}
|
|
31
33
|
|
|
34
|
+
:host(:is(:state(without-label),[state--without-label]):is(:state(size-s),[state--size-s]):not(:is(:state(empty),[state--empty]))) {
|
|
35
|
+
--sbb-chip-group-margin-block: 0 0.4375rem;
|
|
36
|
+
}
|
|
37
|
+
@media (min-width: calc(64rem)) {
|
|
38
|
+
:host(:is(:state(without-label),[state--without-label]):is(:state(size-s),[state--size-s]):not(:is(:state(empty),[state--empty]))) {
|
|
39
|
+
--sbb-chip-group-margin-block: 0 0.3125rem;
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
:host(:is(:is(:state(size-l),[state--size-l]), :is(:state(size-m),[state--size-m]))) {
|
|
44
|
+
--sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default) var(0);
|
|
45
|
+
}
|
|
46
|
+
@media (min-width: calc(64rem)) {
|
|
47
|
+
:host(:is(:is(:state(size-l),[state--size-l]), :is(:state(size-m),[state--size-m]))) {
|
|
48
|
+
--sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default-large) var(0);
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
:host(:is(:state(without-label),[state--without-label]):is(:state(size-m),[state--size-m]):not(:is(:state(empty),[state--empty]))) {
|
|
53
|
+
--sbb-chip-group-margin-block: 0.1875rem 0.6875rem;
|
|
54
|
+
}
|
|
55
|
+
@media (min-width: calc(64rem)) {
|
|
56
|
+
:host(:is(:state(without-label),[state--without-label]):is(:state(size-m),[state--size-m]):not(:is(:state(empty),[state--empty]))) {
|
|
57
|
+
--sbb-chip-group-margin-block: 0.1875rem 0.875rem;
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
:host(:not(:is(:state(without-label),[state--without-label])):is(:state(size-m),[state--size-m]):not(:is(:state(empty),[state--empty]))) {
|
|
62
|
+
--sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default)
|
|
63
|
+
var(--_sbb-chip-group-margin-block-start-default-large);
|
|
64
|
+
}
|
|
65
|
+
@media (min-width: calc(64rem)) {
|
|
66
|
+
:host(:not(:is(:state(without-label),[state--without-label])):is(:state(size-m),[state--size-m]):not(:is(:state(empty),[state--empty]))) {
|
|
67
|
+
--sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default-large)
|
|
68
|
+
var(--_sbb-chip-group-margin-block-start-default-large);
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
:host(:is(:state(without-label),[state--without-label]):is(:state(size-l),[state--size-l]):not(:is(:state(empty),[state--empty]))) {
|
|
73
|
+
--sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default)
|
|
74
|
+
1rem;
|
|
75
|
+
}
|
|
76
|
+
@media (min-width: calc(64rem)) {
|
|
77
|
+
:host(:is(:state(without-label),[state--without-label]):is(:state(size-l),[state--size-l]):not(:is(:state(empty),[state--empty]))) {
|
|
78
|
+
--sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default-large)
|
|
79
|
+
1.25rem;
|
|
80
|
+
}
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
:host(:not(:is(:state(without-label),[state--without-label])):is(:state(size-l),[state--size-l]):not(:is(:state(empty),[state--empty]))) {
|
|
84
|
+
--sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default)
|
|
85
|
+
0.46875rem;
|
|
86
|
+
}
|
|
87
|
+
@media (min-width: calc(64rem)) {
|
|
88
|
+
:host(:not(:is(:state(without-label),[state--without-label])):is(:state(size-l),[state--size-l]):not(:is(:state(empty),[state--empty]))) {
|
|
89
|
+
--sbb-chip-group-margin-block: var(--_sbb-chip-group-margin-block-start-default-large)
|
|
90
|
+
0.46875rem;
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
|
|
32
94
|
::slotted(input) {
|
|
33
95
|
flex: 1 1 var(--sbb-chip-group-input-min-width);
|
|
96
|
+
max-height: 1.5rem;
|
|
34
97
|
}
|
|
35
98
|
|
|
36
99
|
::slotted(sbb-chip) {
|
|
@@ -69,10 +132,14 @@ let SbbChipGroupElement = (() => {
|
|
|
69
132
|
__privateSet(this, _displayWith_accessor_storage, (__runInitializers(this, _instanceExtraInitializers), __runInitializers(this, _displayWith_initializers, null)));
|
|
70
133
|
__privateSet(this, _separatorKeys_accessor_storage, (__runInitializers(this, _displayWith_extraInitializers), __runInitializers(this, _separatorKeys_initializers, ["Enter"])));
|
|
71
134
|
this._inputAttributeObserver = (__runInitializers(this, _separatorKeys_extraInitializers), !isServer ? new MutationObserver(() => this._reactToInputChanges()) : null);
|
|
72
|
-
this._formFieldAttributeObserver = !isServer ? new MutationObserver(() => this._inheritSize()) : null;
|
|
73
135
|
this._language = new SbbLanguageController(this);
|
|
74
136
|
this.addEventListener?.(SbbChipElement.events.requestdelete, (ev) => this._deleteChip(ev.target));
|
|
75
137
|
this.addEventListener?.("keydown", (ev) => this._onChipKeyDown(ev));
|
|
138
|
+
this.addController(new SbbPropertyWatcherController(this, () => this.closest("sbb-form-field"), {
|
|
139
|
+
size: (formField) => this._updateSize(formField.size),
|
|
140
|
+
label: (formField) => this._updateLabelState(formField),
|
|
141
|
+
hiddenLabel: (formField) => this._updateLabelState(formField)
|
|
142
|
+
}));
|
|
76
143
|
}
|
|
77
144
|
/** Value of the form element. */
|
|
78
145
|
set value(value) {
|
|
@@ -110,6 +177,9 @@ let SbbChipGroupElement = (() => {
|
|
|
110
177
|
set separatorKeys(value) {
|
|
111
178
|
__privateSet(this, _separatorKeys_accessor_storage, value);
|
|
112
179
|
}
|
|
180
|
+
_updateLabelState(formField) {
|
|
181
|
+
this.toggleState("without-label", !formField.label || formField.hiddenLabel);
|
|
182
|
+
}
|
|
113
183
|
connectedCallback() {
|
|
114
184
|
super.connectedCallback();
|
|
115
185
|
this._setupComponent();
|
|
@@ -174,14 +244,8 @@ let SbbChipGroupElement = (() => {
|
|
|
174
244
|
attributeFilter: ["readonly", "disabled"]
|
|
175
245
|
});
|
|
176
246
|
}
|
|
177
|
-
this.
|
|
178
|
-
|
|
179
|
-
const formField = this.closest("sbb-form-field");
|
|
180
|
-
if (formField) {
|
|
181
|
-
this._formFieldAttributeObserver?.observe(formField, {
|
|
182
|
-
attributes: true,
|
|
183
|
-
attributeFilter: ["size"]
|
|
184
|
-
});
|
|
247
|
+
if (!this._previousSize || !this.closest("sbb-form-field")) {
|
|
248
|
+
this._updateSize(isLean() ? "s" : "m");
|
|
185
249
|
}
|
|
186
250
|
this.toggleState("empty", this.value.length === 0);
|
|
187
251
|
this._reactToInputChanges();
|
|
@@ -314,11 +378,11 @@ let SbbChipGroupElement = (() => {
|
|
|
314
378
|
c.negative = this.negative;
|
|
315
379
|
});
|
|
316
380
|
}
|
|
317
|
-
|
|
381
|
+
_updateSize(size) {
|
|
318
382
|
if (this._previousSize) {
|
|
319
383
|
this.internals.states.delete(`size-${this._previousSize}`);
|
|
320
384
|
}
|
|
321
|
-
this._previousSize =
|
|
385
|
+
this._previousSize = size;
|
|
322
386
|
if (this._previousSize) {
|
|
323
387
|
this.internals.states.add(`size-${this._previousSize}`);
|
|
324
388
|
}
|
|
@@ -363,4 +427,4 @@ let SbbChipGroupElement = (() => {
|
|
|
363
427
|
export {
|
|
364
428
|
SbbChipGroupElement
|
|
365
429
|
};
|
|
366
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"chip-group.component.js","sources":["../../../../../src/elements/chip/chip-group/chip-group.component.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 { getNextElementIndex, isArrowKeyPressed } from '../../core/a11y.ts';\nimport { SbbLanguageController } from '../../core/controllers.ts';\nimport { isLean } from '../../core/dom.ts';\nimport { i18nChipGroupInputDescription, i18nSelectionRequired } from '../../core/i18n.ts';\nimport {\n  type FormRestoreReason,\n  type FormRestoreState,\n  SbbDisabledMixin,\n  SbbElementInternalsMixin,\n  SbbFormAssociatedMixin,\n  SbbNegativeMixin,\n  SbbRequiredMixin,\n} from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport type { SbbFormFieldElement } from '../../form-field/form-field/form-field.component.ts';\nimport type { SbbOptionBaseElement } from '../../option/option/option-base-element.ts';\nimport { SbbChipElement } from '../chip.ts';\n\nimport style from './chip-group.scss?lit&inline';\n\nlet displayWithWarningLogged = false;\n\nexport interface SbbChipInputTokenEndEventDetails<T = string> {\n  /** The element that triggered the chip creation */\n  origin: 'input' | 'autocomplete';\n  /**\n   * The value of the new chip. Either the input or the option value depending on the origin.\n   * Either the value from the input which is always `string` or the value from the selected option\n   * from an autocomplete, which can be either a string or any other type.\n   */\n  value: T | string;\n  label?: string;\n  /** Set a new value for the chip that will be created */\n  setValue(value: T): 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 * @slot - Use the unnamed slot to add `sbb-chip` elements.\n * @overrideType value - (T = string[]) | null\n */\nexport\n@customElement('sbb-chip-group')\nclass SbbChipGroupElement<T = string> extends SbbRequiredMixin(\n  SbbDisabledMixin(SbbNegativeMixin(SbbFormAssociatedMixin(SbbElementInternalsMixin(LitElement)))),\n) {\n  public static override readonly role = 'listbox';\n  public static override styles: CSSResultGroup = [boxSizingStyles, 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 set value(value: (T | null)[] | null) {\n    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 get value(): (T | null)[] {\n    return this._chipElements().map((c) => c.value);\n  }\n\n  /** Function that maps a chip's value to its display value. */\n  @property({ attribute: false })\n  public accessor displayWith: ((value: T) => string) | null = null;\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  /**\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  private _previousSize?: SbbFormFieldElement['size'];\n\n  public constructor() {\n    super();\n\n    this.addEventListener?.(SbbChipElement.events.requestdelete, (ev) =>\n      this._deleteChip(ev.target as SbbChipElement<T>),\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    this._readFormData(state as FormData).then((array) => (this.value = array));\n  }\n\n  private async _readFormData(formData: FormData): Promise<T[]> {\n    return Promise.all(\n      formData\n        .getAll(this.name)\n        .map(async (entry) =>\n          entry instanceof Blob ? JSON.parse(await entry.text()) : (entry as T),\n        ),\n    );\n  }\n\n  protected override shouldValidate(name: PropertyKey | undefined): boolean {\n    return super.shouldValidate(name) || name === 'required' || name === 'value';\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<T>[] {\n    return Array.from(this.querySelectorAll?.<SbbChipElement<T>>('sbb-chip') ?? []);\n  }\n\n  /** Return the list of enabled chip elements **/\n  private _enabledChipElements(): SbbChipElement<T>[] {\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        'inputAutocomplete',\n        (event: CustomEvent<{ option: SbbOptionBaseElement<T> }>) => {\n          this._createChipFromInput('autocomplete', event.detail?.option.value);\n        },\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.toggleState('empty', this.value.length === 0);\n    this._reactToInputChanges();\n    this._updateInputDescription();\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<T>;\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', value?: T): void {\n    const inputValue = value ?? this._inputElement!.value.trim();\n    if (!inputValue) {\n      return;\n    }\n\n    const eventDetail: SbbChipInputTokenEndEventDetails<T> = {\n      origin: origin,\n      value: inputValue,\n      label: (value ? this.displayWith?.(value) : null) ?? undefined,\n      setValue: (value: T) => (eventDetail.value = value),\n      setLabel: (label: string) => (eventDetail.label = label),\n    };\n\n    if (!this._dispatchChipInputTokenEnd(eventDetail)) {\n      return; // event prevented; do nothing (the consumer has to create the chip)\n    }\n\n    this._createChipElement(eventDetail.value as T, eventDetail.label);\n    this._inputElement!.value = ''; // Empty the input\n    this._emitInputEvents();\n  }\n\n  private _dispatchChipInputTokenEnd(eventDetail: SbbChipInputTokenEndEventDetails<T>): boolean {\n    /**\n     * @type {CustomEvent<SbbChipInputTokenEndEventDetails>}\n     * Notifies that a chip is about to be created. Can be prevented.\n     */\n    return this.dispatchEvent(\n      new CustomEvent<SbbChipInputTokenEndEventDetails<T>>('chipinputtokenend', {\n        detail: eventDetail,\n        cancelable: true,\n        bubbles: true,\n        composed: true,\n      }),\n    );\n  }\n\n  private _deleteChip(chip: SbbChipElement<T>): 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    /** The input event fires when the value has been changed as a direct result of a user action. */\n    this.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));\n\n    /**\n     * The change event is fired when the user modifies the element's value.\n     * Unlike the input event, the change event is not necessarily fired\n     * for each alteration to an element's value.\n     */\n    this.dispatchEvent(new Event('change', { bubbles: true }));\n  }\n\n  private _createChipElement(value: T | null, label?: string): void {\n    if (isServer) {\n      return;\n    }\n    const newChip = document.createElement('sbb-chip') as SbbChipElement<T>;\n    newChip.value = value;\n    newChip.innerText = label ?? (value ? this.displayWith?.(value) : null) ?? '';\n    if (\n      import.meta.env.DEV &&\n      !displayWithWarningLogged &&\n      !label &&\n      typeof value === 'object' &&\n      !this.displayWith\n    ) {\n      console.warn(\n        `displayWith has not been set yet for sbb-chip-group and value is an object.\n         If you are using object values, you need to provide displayWidth before\n         setting or selecting any value.`,\n      );\n      displayWithWarningLogged = true;\n    }\n    this.insertBefore(newChip, this._inputElement ?? this.querySelector('input'));\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    if (this._previousSize) {\n      this.internals.states.delete(`size-${this._previousSize}`);\n    }\n    this._previousSize = this.closest('sbb-form-field')?.size ?? (isLean() ? 's' : 'm');\n    if (this._previousSize) {\n      this.internals.states.add(`size-${this._previousSize}`);\n    }\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\ndeclare global {\n  interface HTMLElementEventMap {\n    chipinputtokenend: CustomEvent<SbbChipInputTokenEndEventDetails<any>>;\n  }\n}\n"],"names":["value"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA8BA,IAAI,2BAA2B;IA0BzB,uBAAmB,MAAA;;0BADxB,cAAc,gBAAgB,CAAC;;;;AACc,MAAA,cAAA,iBAC5C,iBAAiB,iBAAiB,uBAAuB,yBAAyB,UAAU,CAAC,CAAC,CAAC,CAAC;;;;;;;;;AAD5D,EAAA,mBAAQ,YAE7C;AAAA,IAsEC,cAAA;AACE,YAAA;AA1BF;AAIA;AAJgB,yBAAA,gCA/CZ,kBAAA,MAAA,0BAAA,GAAmB,kBAAA,MAAA,2BA+CsC,IAAI;AAIjD,yBAAA,kCAAA,kBAAA,MAAA,8BAAA,GAAA,kBAAA,MAAA,6BAA0B,CAAC,OAAO,CAAC;AAK3C,WAAA,2BAAuB,kBAAA,MAAA,gCAAA,GAAG,CAAC,WAC/B,IAAI,iBAAiB,MAAM,KAAK,qBAAA,CAAsB,IACtD;AAKI,WAAA,8BAA8B,CAAC,WACnC,IAAI,iBAAiB,MAAM,KAAK,aAAA,CAAc,IAC9C;AAII,WAAA,YAAY,IAAI,sBAAsB,IAAI;AAMhD,WAAK,mBAAmB,eAAe,OAAO,eAAe,CAAC,OAC5D,KAAK,YAAY,GAAG,MAA2B,CAAC;AAGlD,WAAK,mBAAmB,WAAW,CAAC,OAAO,KAAK,eAAe,EAAE,CAAC;AAAA,IACpE;AAAA;AAAA,IAnEA,IAAW,MAAM,OAA0B;AACzC,cAAQ,SAAS,CAAA;AACjB,YAAM,WAAW,KAAK;AAItB,YAAM,WAAW,CAAC,GAAG,QAAQ;AAC7B,iBAAW,KAAK,OAAO;AACrB,YAAI,SAAS,SAAS,CAAC,GAAG;AACxB,mBAAS,OAAO,SAAS,QAAQ,CAAC,GAAG,CAAC;AAAA,QACxC;AAAA,MACF;AACA,eAAS,QAAQ,CAACA,WAChB,KAAK,gBACF,KAAK,CAAC,MAAM,EAAE,UAAUA,MAAK,GAC5B,QAAQ;AAKd,YAAM,QAAQ,CAAC,GAAG,KAAK;AACvB,iBAAW,KAAK,UAAU;AACxB,YAAI,MAAM,SAAS,CAAC,GAAG;AACrB,gBAAM,OAAO,MAAM,QAAQ,CAAC,GAAG,CAAC;AAAA,QAClC;AAAA,MACF;AACA,YAAM,QAAQ,CAAC,MAAM,KAAK,mBAAmB,CAAC,CAAC;AAAA,IACjD;AAAA,IACA,IAAW,QAAK;AACd,aAAO,KAAK,gBAAgB,IAAI,CAAC,MAAM,EAAE,KAAK;AAAA,IAChD;AAAA;AAAA,IAIA,IAAgB,cAAW;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAA3B,IAAgB,YAAW,OAAA;AAAA,yBAAA,+BAAA;AAAA,IAAA;AAAA;AAAA,IAI3B,IAAgB,gBAAa;AAAA,aAAA,mBAAA;AAAA,IAAA;AAAA,IAA7B,IAAgB,cAAa,OAAA;AAAA,yBAAA,iCAAA;AAAA,IAAA;AAAA,IA+Bb,oBAAiB;AAC/B,YAAM,kBAAA;AACN,WAAK,gBAAA;AAAA,IACP;AAAA,IAEmB,WAAW,mBAAiC;AAC7D,YAAM,WAAW,iBAAiB;AAElC,UACE,kBAAkB,IAAI,UAAU,KAChC,kBAAkB,IAAI,cAAc,KACpC,kBAAkB,IAAI,UAAU,GAChC;AACA,aAAK,mBAAA;AAAA,MACP;AAAA,IACF;AAAA;AAAA,IAGO,oBAAiB;AACtB,WAAK,QAAQ;AAAA,IACf;AAAA;AAAA,IAGO,yBACL,OACA,SAA0B;AAE1B,UAAI,CAAC,OAAO;AACV,aAAK,QAAQ;AACb;AAAA,MACF;AAEA,WAAK,cAAc,KAAiB,EAAE,KAAK,CAAC,UAAW,KAAK,QAAQ,KAAM;AAAA,IAC5E;AAAA,IAEQ,MAAM,cAAc,UAAkB;AAC5C,aAAO,QAAQ,IACb,SACG,OAAO,KAAK,IAAI,EAChB,IAAI,OAAO,UACV,iBAAiB,OAAO,KAAK,MAAM,MAAM,MAAM,MAAM,IAAK,KAAW,CACtE;AAAA,IAEP;AAAA,IAEmB,eAAe,MAA6B;AAC7D,aAAO,MAAM,eAAe,IAAI,KAAK,SAAS,cAAc,SAAS;AAAA,IACvE;AAAA,IAEmB,WAAQ;AACzB,YAAM,SAAA;AACN,UAAI,KAAK,YAAY,KAAK,MAAM,WAAW,GAAG;AAC5C,aAAK,gBAAgB,gBAAgB,sBAAsB,KAAK,UAAU,OAAO,CAAC;AAAA,MACpF,OAAO;AACL,aAAK,mBAAmB,cAAc;AAAA,MACxC;AAAA,IACF;AAAA;AAAA,IAGQ,gBAAa;AACnB,aAAO,MAAM,KAAK,KAAK,mBAAsC,UAAU,KAAK,EAAE;AAAA,IAChF;AAAA;AAAA,IAGQ,uBAAoB;AAC1B,aAAO,MAAM,KAAK,KAAK,mBAAmB,0BAA0B,KAAK,EAAE;AAAA,IAC7E;AAAA,IAEQ,kBAAe;AACrB,YAAM,QAAQ,KAAK,cAAc,OAAO;AAGxC,UAAI,SAAS,UAAU,KAAK,eAAe;AACzC,aAAK,uBAAuB,MAAA;AAC5B,aAAK,yBAAyB,WAAA;AAC9B,aAAK,gBAAgB;AAErB,aAAK,wBAAwB,IAAI,gBAAA;AACjC,aAAK,cAAc,iBAAiB,WAAW,CAAC,OAAO,KAAK,gBAAgB,EAAE,GAAG;AAAA,UAC/E,QAAQ,KAAK,sBAAsB;AAAA,QAAA,CACpC;AACD,aAAK,cAAc,iBACjB,qBACA,CAAC,UAA2D;AAC1D,eAAK,qBAAqB,gBAAgB,MAAM,QAAQ,OAAO,KAAK;AAAA,QACtE,GACA;AAAA,UACE,QAAQ,KAAK,sBAAsB;AAAA,QAAA,CACpC;AAGH,aAAK,yBAAyB,QAAQ,KAAK,eAAe;AAAA,UACxD,YAAY;AAAA,UACZ,iBAAiB,CAAC,YAAY,UAAU;AAAA,QAAA,CACzC;AAAA,MACH;AAGA,WAAK,aAAA;AACL,WAAK,6BAA6B,WAAA;AAClC,YAAM,YAAY,KAAK,QAAQ,gBAAgB;AAC/C,UAAI,WAAW;AACb,aAAK,6BAA6B,QAAQ,WAAW;AAAA,UACnD,YAAY;AAAA,UACZ,iBAAiB,CAAC,MAAM;AAAA,QAAA,CACzB;AAAA,MACH;AAEA,WAAK,YAAY,SAAS,KAAK,MAAM,WAAW,CAAC;AACjD,WAAK,qBAAA;AACL,WAAK,wBAAA;AACL,WAAK,gBAAA;AAAA,IACP;AAAA;AAAA;AAAA;AAAA,IAKQ,eAAe,OAAoB;AACzC,YAAM,cAAc,MAAM;AAC1B,UAAI,YAAY,cAAc,YAAY;AACxC;AAAA,MACF;AAGA,UAAI,kBAAkB,KAAK,GAAG;AAC5B,cAAM,aAAa,KAAK,qBAAA;AACxB,cAAM,OAAO,oBAAoB,OAAO,WAAW,QAAQ,WAAW,GAAG,WAAW,MAAM;AAC1F,mBAAW,IAAI,EAAE,MAAA;AACjB;AAAA,MACF;AAEA,cAAQ,MAAM,KAAA;AAAA,QACZ,KAAK;AAAA,QACL,KAAK;AACH,cAAI,CAAC,YAAY,YAAY,CAAC,YAAY,UAAU;AAClD,kBAAM,eAAA;AACN,iBAAK,YAAY,WAAW;AAAA,UAC9B;AACA;AAAA,MAAA;AAAA,IAEN;AAAA;AAAA;AAAA;AAAA,IAKQ,gBAAgB,OAAoB;AAC1C,cAAQ,MAAM,KAAA;AAAA,QACZ,KAAK;AAAA,QACL,KAAK;AACH,cAAI,CAAC,KAAK,cAAe,OAAO;AAC9B,iBAAK,WAAA;AAAA,UACP;AACA;AAAA,QACF,KAAK;AACH,gBAAM,eAAA;AACN;AAAA,MAAA;AAIJ,UAAI,KAAK,cAAc,SAAS,MAAM,GAAG,GAAG;AAC1C,cAAM,eAAA;AACN,aAAK,qBAAqB,OAAO;AAAA,MACnC;AAAA,IACF;AAAA;AAAA;AAAA;AAAA,IAKQ,qBAAqB,SAAmC,SAAS,OAAS;AAChF,YAAM,aAAa,SAAS,KAAK,cAAe,MAAM,KAAA;AACtD,UAAI,CAAC,YAAY;AACf;AAAA,MACF;AAEA,YAAM,cAAmD;AAAA,QACvD;AAAA,QACA,OAAO;AAAA,QACP,QAAQ,QAAQ,KAAK,cAAc,KAAK,IAAI,SAAS;AAAA,QACrD,UAAU,CAACA,WAAc,YAAY,QAAQA;AAAAA,QAC7C,UAAU,CAAC,UAAmB,YAAY,QAAQ;AAAA,MAAA;AAGpD,UAAI,CAAC,KAAK,2BAA2B,WAAW,GAAG;AACjD;AAAA,MACF;AAEA,WAAK,mBAAmB,YAAY,OAAY,YAAY,KAAK;AACjE,WAAK,cAAe,QAAQ;AAC5B,WAAK,iBAAA;AAAA,IACP;AAAA,IAEQ,2BAA2B,aAAgD;AAKjF,aAAO,KAAK,cACV,IAAI,YAAiD,qBAAqB;AAAA,QACxE,QAAQ;AAAA,QACR,YAAY;AAAA,QACZ,SAAS;AAAA,QACT,UAAU;AAAA,MAAA,CACX,CAAC;AAAA,IAEN;AAAA,IAEQ,YAAY,MAAuB;AACzC,YAAM,QAAQ,KAAK,qBAAA;AACnB,WAAK,OAAA;AACL,WAAK,iBAAA;AACL,WAAK,WAAW,MAAM,QAAQ,IAAI,CAAC;AAAA,IACrC;AAAA;AAAA;AAAA;AAAA;AAAA,IAMQ,WAAW,OAAc;AAC/B,YAAM,eAAe,KAAK,qBAAA;AAE1B,UAAI,UAAU,UAAa,aAAa,KAAK,GAAG;AAC9C,qBAAa,KAAK,EAAE,MAAA;AACpB;AAAA,MACF;AAEA,UAAI,aAAa,SAAS,GAAG;AAC3B,qBAAa,aAAa,SAAS,CAAC,EAAE,MAAA;AACtC;AAAA,MACF;AAEA,WAAK,eAAe,MAAA;AAAA,IACtB;AAAA,IAEQ,mBAAgB;AAEtB,WAAK,cAAc,IAAI,WAAW,SAAS,EAAE,SAAS,MAAM,UAAU,KAAA,CAAM,CAAC;AAO7E,WAAK,cAAc,IAAI,MAAM,UAAU,EAAE,SAAS,KAAA,CAAM,CAAC;AAAA,IAC3D;AAAA,IAEQ,mBAAmB,OAAiB,OAAc;AACxD,UAAI,UAAU;AACZ;AAAA,MACF;AACA,YAAM,UAAU,SAAS,cAAc,UAAU;AACjD,cAAQ,QAAQ;AAChB,cAAQ,YAAY,UAAU,QAAQ,KAAK,cAAc,KAAK,IAAI,SAAS;AAC3E,UAEE,CAAC,4BACD,CAAC,SACD,OAAO,UAAU,YACjB,CAAC,KAAK,aACN;AACA,gBAAQ,KACN;AAAA;AAAA,yCAEiC;AAEnC,mCAA2B;AAAA,MAC7B;AACA,WAAK,aAAa,SAAS,KAAK,iBAAiB,KAAK,cAAc,OAAO,CAAC;AAAA,IAC9E;AAAA,IAEQ,uBAAoB;AAC1B,WAAK,WAAW,KAAK,eAAe,YAAY;AAChD,WAAK,mBAAA;AAAA,IACP;AAAA,IAEQ,qBAAkB;AACxB,WAAK,cAAA,EAAgB,QAAQ,CAAC,MAAK;AACjC,UAAE,WAAW,KAAK,YAAY,KAAK;AACnC,UAAE,WAAW,KAAK,eAAe,aAAa,UAAU,KAAK;AAC7D,UAAE,WAAW,KAAK;AAAA,MACpB,CAAC;AAAA,IACH;AAAA,IAEQ,eAAY;AAClB,UAAI,KAAK,eAAe;AACtB,aAAK,UAAU,OAAO,OAAO,QAAQ,KAAK,aAAa,EAAE;AAAA,MAC3D;AACA,WAAK,gBAAgB,KAAK,QAAQ,gBAAgB,GAAG,SAAS,OAAA,IAAW,MAAM;AAC/E,UAAI,KAAK,eAAe;AACtB,aAAK,UAAU,OAAO,IAAI,QAAQ,KAAK,aAAa,EAAE;AAAA,MACxD;AAAA,IACF;AAAA,IAEQ,0BAAuB;AAC7B,UAAI,CAAC,KAAK,eAAe;AACvB;AAAA,MACF;AACA,WAAK,cAAc,aACjB,oBACA,GAAG,8BAA8B,KAAK,UAAU,OAAO,CAAC,IAAI,KAAK,MAAM,MAAM,EAAE;AAAA,IAEnF;AAAA,IAEmB,SAAM;AACvB,aAAO;AAAA;AAAA,4BAEiB,KAAK,eAAe;AAAA;AAAA;AAAA,IAG9C;AAAA,KAvVA,+CAIA;;AAvCC,4BAAA,CAAA,SAAS,EAAE,MAAM,MAAA,CAAO,CAAC;AAkCzB,8BAAA,CAAA,SAAS,EAAE,WAAW,MAAA,CAAO,CAAC;iCAI9B,SAAS,EAAE,WAAW,kBAAkB,MAAM,MAAA,CAAO,CAAC;AArCvD,iBAAA,IAAA,MAAA,uBAAA,EAAA,MAAA,UAAA,MAAA,SAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,WAAA,KAAA,KAAA,CAAA,KAAA,UAAA;AAAA,UAAW,QAAK;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,MAAA,0BAAA;AAkChB,iBAAA,IAAA,MAAA,yBAAA,EAAA,MAAA,YAAA,MAAA,eAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,iBAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,aAAW,KAAA,CAAA,KAAA,UAAA;AAAA,UAAX,cAAW;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,2BAAA,8BAAA;AAI3B,iBAAA,IAAA,MAAA,2BAAA,EAAA,MAAA,YAAA,MAAA,iBAAA,QAAA,OAAA,SAAA,OAAA,QAAA,EAAA,KAAA,CAAA,QAAA,mBAAA,KAAA,KAAA,CAAA,QAAA,IAAgB,eAAa,KAAA,CAAA,KAAA,UAAA;AAAA,UAAb,gBAAa;AAAA,IAAA,KAAA,UAAA,UAAA,GAAA,6BAAA,gCAAA;AAnD/B,iBAAA,MAAA,mBAAA,EAAA,OAAA,WAAA,GAAA,kBAAA,EAAA,MAAA,SAAA,MAAA,WAAA,MAAA,UAAA,UAAA,GAAA,MAAA,uBAAA;;;QAGkC,GAAA,OAAO,WAChB,GAAA,SAAyB,CAAC,iBAAiB,KAAK,GAChD,GAAA,SAAS;AAAA,IAC9B,OAAO;AAAA,IACP,QAAQ;AAAA,IACR,mBAAmB;AAAA,EAAA,GARjB,kBAAA,YAAA,uBAAA,GAAgC;;;"}
|
|
430
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"chip-group.component.js","sources":["../../../../../src/elements/chip/chip-group/chip-group.component.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 { getNextElementIndex, isArrowKeyPressed } from '../../core/a11y.ts';\nimport { SbbLanguageController, SbbPropertyWatcherController } from '../../core/controllers.ts';\nimport { isLean } from '../../core/dom/lean-context.ts';\nimport { i18nChipGroupInputDescription, i18nSelectionRequired } from '../../core/i18n.ts';\nimport {\n  type FormRestoreReason,\n  type FormRestoreState,\n  SbbDisabledMixin,\n  SbbElementInternalsMixin,\n  SbbFormAssociatedMixin,\n  SbbNegativeMixin,\n  SbbRequiredMixin,\n} from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport type { SbbFormFieldElement } from '../../form-field/form-field/form-field.component.ts';\nimport type { SbbOptionBaseElement } from '../../option/option/option-base-element.ts';\nimport { SbbChipElement } from '../chip.ts';\n\nimport style from './chip-group.scss?lit&inline';\n\nlet displayWithWarningLogged = false;\n\nexport interface SbbChipInputTokenEndEventDetails<T = string> {\n  /** The element that triggered the chip creation */\n  origin: 'input' | 'autocomplete';\n  /**\n   * The value of the new chip. Either the input or the option value depending on the origin.\n   * Either the value from the input which is always `string` or the value from the selected option\n   * from an autocomplete, which can be either a string or any other type.\n   */\n  value: T | string;\n  label?: string;\n  /** Set a new value for the chip that will be created */\n  setValue(value: T): 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 * @slot - Use the unnamed slot to add `sbb-chip` elements.\n * @overrideType value - (T = string[]) | null\n */\nexport\n@customElement('sbb-chip-group')\nclass SbbChipGroupElement<T = string> extends SbbRequiredMixin(\n  SbbDisabledMixin(SbbNegativeMixin(SbbFormAssociatedMixin(SbbElementInternalsMixin(LitElement)))),\n) {\n  public static override readonly role = 'listbox';\n  public static override styles: CSSResultGroup = [boxSizingStyles, 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 set value(value: (T | null)[] | null) {\n    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 get value(): (T | null)[] {\n    return this._chipElements().map((c) => c.value);\n  }\n\n  /** Function that maps a chip's value to its display value. */\n  @property({ attribute: false })\n  public accessor displayWith: ((value: T) => string) | null = null;\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  /**\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  private _inputElement: HTMLInputElement | undefined;\n  private _inputAbortController: AbortController | undefined;\n  private _language = new SbbLanguageController(this);\n  private _previousSize?: SbbFormFieldElement['size'];\n\n  public constructor() {\n    super();\n\n    this.addEventListener?.(SbbChipElement.events.requestdelete, (ev) =>\n      this._deleteChip(ev.target as SbbChipElement<T>),\n    );\n\n    this.addEventListener?.('keydown', (ev) => this._onChipKeyDown(ev));\n\n    this.addController(\n      new SbbPropertyWatcherController(this, () => this.closest('sbb-form-field'), {\n        size: (formField) => this._updateSize(formField.size),\n        label: (formField) => this._updateLabelState(formField),\n        hiddenLabel: (formField) => this._updateLabelState(formField),\n      }),\n    );\n  }\n\n  private _updateLabelState(formField: SbbFormFieldElement): void {\n    this.toggleState('without-label', !formField.label || formField.hiddenLabel);\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    this._readFormData(state as FormData).then((array) => (this.value = array));\n  }\n\n  private async _readFormData(formData: FormData): Promise<T[]> {\n    return Promise.all(\n      formData\n        .getAll(this.name)\n        .map(async (entry) =>\n          entry instanceof Blob ? JSON.parse(await entry.text()) : (entry as T),\n        ),\n    );\n  }\n\n  protected override shouldValidate(name: PropertyKey | undefined): boolean {\n    return super.shouldValidate(name) || name === 'required' || name === 'value';\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<T>[] {\n    return Array.from(this.querySelectorAll?.<SbbChipElement<T>>('sbb-chip') ?? []);\n  }\n\n  /** Return the list of enabled chip elements **/\n  private _enabledChipElements(): SbbChipElement<T>[] {\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        'inputAutocomplete',\n        (event: CustomEvent<{ option: SbbOptionBaseElement<T> }>) => {\n          this._createChipFromInput('autocomplete', event.detail?.option.value);\n        },\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    if (!this._previousSize || !this.closest('sbb-form-field')) {\n      this._updateSize(isLean() ? 's' : 'm');\n    }\n\n    this.toggleState('empty', this.value.length === 0);\n    this._reactToInputChanges();\n    this._updateInputDescription();\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<T>;\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', value?: T): void {\n    const inputValue = value ?? this._inputElement!.value.trim();\n    if (!inputValue) {\n      return;\n    }\n\n    const eventDetail: SbbChipInputTokenEndEventDetails<T> = {\n      origin: origin,\n      value: inputValue,\n      label: (value ? this.displayWith?.(value) : null) ?? undefined,\n      setValue: (value: T) => (eventDetail.value = value),\n      setLabel: (label: string) => (eventDetail.label = label),\n    };\n\n    if (!this._dispatchChipInputTokenEnd(eventDetail)) {\n      return; // event prevented; do nothing (the consumer has to create the chip)\n    }\n\n    this._createChipElement(eventDetail.value as T, eventDetail.label);\n    this._inputElement!.value = ''; // Empty the input\n    this._emitInputEvents();\n  }\n\n  private _dispatchChipInputTokenEnd(eventDetail: SbbChipInputTokenEndEventDetails<T>): boolean {\n    /**\n     * @type {CustomEvent<SbbChipInputTokenEndEventDetails>}\n     * Notifies that a chip is about to be created. Can be prevented.\n     */\n    return this.dispatchEvent(\n      new CustomEvent<SbbChipInputTokenEndEventDetails<T>>('chipinputtokenend', {\n        detail: eventDetail,\n        cancelable: true,\n        bubbles: true,\n        composed: true,\n      }),\n    );\n  }\n\n  private _deleteChip(chip: SbbChipElement<T>): 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    /** The input event fires when the value has been changed as a direct result of a user action. */\n    this.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));\n\n    /**\n     * The change event is fired when the user modifies the element's value.\n     * Unlike the input event, the change event is not necessarily fired\n     * for each alteration to an element's value.\n     */\n    this.dispatchEvent(new Event('change', { bubbles: true }));\n  }\n\n  private _createChipElement(value: T | null, label?: string): void {\n    if (isServer) {\n      return;\n    }\n    const newChip = document.createElement('sbb-chip') as SbbChipElement<T>;\n    newChip.value = value;\n    newChip.innerText = label ?? (value ? this.displayWith?.(value) : null) ?? '';\n    if (\n      import.meta.env.DEV &&\n      !displayWithWarningLogged &&\n      !label &&\n      typeof value === 'object' &&\n      !this.displayWith\n    ) {\n      console.warn(\n        `displayWith has not been set yet for sbb-chip-group and value is an object.\n         If you are using object values, you need to provide displayWidth before\n         setting or selecting any value.`,\n      );\n      displayWithWarningLogged = true;\n    }\n    this.insertBefore(newChip, this._inputElement ?? this.querySelector('input'));\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 _updateSize(size: SbbFormFieldElement['size']): void {\n    if (this._previousSize) {\n      this.internals.states.delete(`size-${this._previousSize}`);\n    }\n    this._previousSize = size;\n    if (this._previousSize) {\n      this.internals.states.add(`size-${this._previousSize}`);\n    }\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\ndeclare global {\n  interface HTMLElementEventMap {\n    chipinputtokenend: CustomEvent<SbbChipInputTokenEndEventDetails<any>>;\n  }\n}\n"],"names":["value"],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { S as
|
|
1
|
+
import { S as SbbBreakpointLargeMin, a as SbbBreakpointLargeMax, b as SbbBreakpointSmallMin, c as SbbBreakpointSmallMax, d as SbbBreakpointUltraMin, e as SbbBreakpointZeroMin } from "../../sbb-tokens-DQT_xEIZ.js";
|
|
2
2
|
import { isServer } from "lit";
|
|
3
3
|
import { ɵstateController as _stateController } from "../mixins/element-internals-mixin.js";
|
|
4
4
|
const SbbMediaQueryForcedColors = "(forced-colors: active)";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"overlay-close-details.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/interfaces/overlay-close-details.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,2BAA2B,GAAG;IACxC,WAAW,CAAC,EAAE,GAAG,CAAC;IAClB,WAAW,CAAC,EAAE,WAAW,CAAC;CAC3B,CAAC"}
|
|
1
|
+
{"version":3,"file":"overlay-close-details.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/interfaces/overlay-close-details.ts"],"names":[],"mappings":"AAAA,kBAAkB;AAClB,MAAM,MAAM,2BAA2B,GAAG;IACxC,WAAW,CAAC,EAAE,GAAG,CAAC;IAClB,WAAW,CAAC,EAAE,WAAW,CAAC;CAC3B,CAAC"}
|
|
@@ -1,5 +1,7 @@
|
|
|
1
1
|
import { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';
|
|
2
|
+
import { SbbOverlayCloseEventDetails } from '../../core/interfaces/overlay-close-details.ts';
|
|
2
3
|
import { SbbOverlayBaseElement } from '../../overlay.ts';
|
|
4
|
+
export { assignOverlayResult as assignDialogResult, SbbOverlayCloseEvent as SbbDialogCloseEvent, } from '../../overlay/overlay-base-element.ts';
|
|
3
5
|
/**
|
|
4
6
|
* It displays an interactive overlay element.
|
|
5
7
|
*
|
|
@@ -37,6 +39,8 @@ export declare class SbbDialogElement extends SbbOverlayBaseElement {
|
|
|
37
39
|
private _closeOnBackdropClick;
|
|
38
40
|
private _updateOverflowState;
|
|
39
41
|
private _contentElement;
|
|
42
|
+
protected dispatchBeforeCloseEvent(_detail?: SbbOverlayCloseEventDetails): boolean;
|
|
43
|
+
protected dispatchCloseEvent(_detail?: SbbOverlayCloseEventDetails): boolean;
|
|
40
44
|
protected render(): TemplateResult;
|
|
41
45
|
}
|
|
42
46
|
declare global {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"dialog.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/dialog/dialog/dialog.component.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;
|
|
1
|
+
{"version":3,"file":"dialog.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/dialog/dialog/dialog.component.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAM1E,OAAO,KAAK,EAAE,2BAA2B,EAAE,MAAM,gDAAgD,CAAC;AAElG,OAAO,EAEL,qBAAqB,EAEtB,MAAM,kBAAkB,CAAC;AAK1B,OAAO,6BAA6B,CAAC;AAErC,OAAO,EACL,mBAAmB,IAAI,kBAAkB,EACzC,oBAAoB,IAAI,mBAAmB,GAC5C,MAAM,uCAAuC,CAAC;AAI/C;;;;;;;GAOG;AACH,qBAEM,gBAAiB,SAAQ,qBAAqB;IAClD,OAAuB,MAAM,EAAE,cAAc,CAA4B;IAEzE,6BAA6B;IAC7B,SAA4D,cAAc,EAAE,OAAO,GAAG,MAAM,CAClF;IAEV,wBAAwB;IACxB,SAAoE,QAAQ,EACxE,QAAQ,GACR,aAAa,CAAY;IAM7B,OAAO,CAAC,4BAA4B,CAIjC;IAEH,OAAO,CAAC,cAAc,CAAC,CAAc;IACrC,OAAO,CAAC,2BAA2B,CAAkB;IACrD,SAAS,CAAC,cAAc,EAAE,MAAM,CAAsB;IACtD,UAAmB,QAAQ,EAAE,MAAM,CAA6B;;IAahD,iBAAiB,IAAI,IAAI;IAKzC,2EAA2E;IACpE,aAAa,IAAI,IAAI;IAM5B,SAAS,CAAC,uBAAuB,IAAI,OAAO;IAI5C,SAAS,CAAC,aAAa,IAAI,IAAI;IA6B/B,SAAS,CAAC,aAAa,IAAI,IAAI;cAeZ,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAW3D,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAQ5E,OAAO,CAAC,iBAAiB;IAKzB,OAAO,CAAC,kBAAkB;IAa1B,OAAO,CAAC,0BAA0B;IASlC,wEAAwE;IACxE,OAAO,CAAC,oBAAoB,CAO1B;IAEF,sCAAsC;IACtC,OAAO,CAAC,qBAAqB,CAS3B;IAEF,OAAO,CAAC,oBAAoB;IAU5B,OAAO,CAAC,eAAe;cAKJ,wBAAwB,CAAC,OAAO,CAAC,EAAE,2BAA2B,GAAG,OAAO;cAaxE,kBAAkB,CAAC,OAAO,CAAC,EAAE,2BAA2B,GAAG,OAAO;cAWlE,MAAM,IAAI,cAAc;CAmB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,YAAY,EAAE,gBAAgB,CAAC;KAChC;CACF"}
|
|
@@ -12,9 +12,10 @@ import { ref } from "lit/directives/ref.js";
|
|
|
12
12
|
import { html } from "lit/static-html.js";
|
|
13
13
|
import { isZeroAnimationDuration } from "../../core/dom.js";
|
|
14
14
|
import { boxSizingStyles } from "../../core/styles.js";
|
|
15
|
-
import { SbbOverlayBaseElement, overlayRefs } from "../../overlay.js";
|
|
15
|
+
import { SbbOverlayBaseElement, overlayRefs, SbbOverlayCloseEvent } from "../../overlay.js";
|
|
16
16
|
import { css } from "lit";
|
|
17
17
|
import "../../screen-reader-only.js";
|
|
18
|
+
import { SbbOverlayCloseEvent as SbbOverlayCloseEvent2, assignOverlayResult } from "../../overlay/overlay-base-element.js";
|
|
18
19
|
const style = css`:host {
|
|
19
20
|
--sbb-dialog-padding-inline: var(--sbb-spacing-fixed-5x);
|
|
20
21
|
--sbb-dialog-color: var(--sbb-color-2);
|
|
@@ -342,6 +343,23 @@ let SbbDialogElement = (() => {
|
|
|
342
343
|
_contentElement() {
|
|
343
344
|
return this.querySelector("sbb-dialog-content");
|
|
344
345
|
}
|
|
346
|
+
// TODO: remove parameter `detail`
|
|
347
|
+
dispatchBeforeCloseEvent(_detail) {
|
|
348
|
+
return this.dispatchEvent(new SbbOverlayCloseEvent("beforeclose", {
|
|
349
|
+
cancelable: true,
|
|
350
|
+
closeAttribute: this.closeAttribute,
|
|
351
|
+
closeTarget: this.overlayCloseElement,
|
|
352
|
+
result: this.returnValue
|
|
353
|
+
}));
|
|
354
|
+
}
|
|
355
|
+
// TODO: remove parameter `detail`
|
|
356
|
+
dispatchCloseEvent(_detail) {
|
|
357
|
+
return this.dispatchEvent(new SbbOverlayCloseEvent("close", {
|
|
358
|
+
closeAttribute: this.closeAttribute,
|
|
359
|
+
closeTarget: this.overlayCloseElement,
|
|
360
|
+
result: this.returnValue
|
|
361
|
+
}));
|
|
362
|
+
}
|
|
345
363
|
render() {
|
|
346
364
|
return html`
|
|
347
365
|
<div class="sbb-dialog__container">
|
|
@@ -378,6 +396,8 @@ let SbbDialogElement = (() => {
|
|
|
378
396
|
return _classThis;
|
|
379
397
|
})();
|
|
380
398
|
export {
|
|
381
|
-
|
|
399
|
+
SbbOverlayCloseEvent2 as SbbDialogCloseEvent,
|
|
400
|
+
SbbDialogElement,
|
|
401
|
+
assignOverlayResult as assignDialogResult
|
|
382
402
|
};
|
|
383
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"dialog.component.js","sources":["../../../../../src/elements/dialog/dialog/dialog.component.ts"],"sourcesContent":["import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\nimport { html } from 'lit/static-html.js';\n\nimport { isZeroAnimationDuration } from '../../core/dom.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport { overlayRefs, SbbOverlayBaseElement } from '../../overlay.ts';\nimport type { SbbDialogContentElement } from '../dialog-content/dialog-content.component.ts';\n\nimport style from './dialog.scss?lit&inline';\n\nimport '../../screen-reader-only.ts';\n\nlet nextId = 0;\n\n/**\n * It displays an interactive overlay element.\n *\n * @slot - Use the unnamed slot to provide a `sbb-dialog-title`, `sbb-dialog-content` and an optional `sbb-dialog-actions`.\n * @cssprop [--sbb-dialog-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-dialog')\nclass SbbDialogElement extends SbbOverlayBaseElement {\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n\n  /** Backdrop click action. */\n  @property({ attribute: 'backdrop-action' }) public accessor backdropAction: 'close' | 'none' =\n    'close';\n\n  /** Backdrop density. */\n  @property({ attribute: 'backdrop', reflect: true }) public accessor backdrop:\n    | 'opaque'\n    | 'translucent' = 'opaque';\n\n  // We use a timeout as a workaround to the \"ResizeObserver loop completed with undelivered notifications\" error.\n  // For more details:\n  // - https://github.com/WICG/resize-observer/issues/38#issuecomment-422126006\n  // - https://github.com/juggle/resize-observer/issues/103#issuecomment-1711148285\n  private _dialogContentResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: () => setTimeout(() => this._updateOverflowState()),\n  });\n\n  private _dialogElement?: HTMLElement;\n  private _isPointerDownEventOnDialog: boolean = false;\n  protected closeAttribute: string = 'sbb-dialog-close';\n  protected override closeTag: string = 'sbb-dialog-close-button';\n\n  public constructor() {\n    super();\n    // Close dialog on backdrop click\n    this.addEventListener?.('pointerdown', this._pointerDownListener);\n    this.addEventListener?.('pointerup', this._closeOnBackdropClick);\n    this.addEventListener('scroll', () => this._updateOverflowState(), {\n      passive: true,\n      capture: true,\n    });\n  }\n\n  public override connectedCallback(): void {\n    this.id ||= `sbb-dialog-${nextId++}`;\n    super.connectedCallback();\n  }\n\n  /** Announce the accessibility label or dialog title for screen readers. */\n  public announceTitle(): void {\n    this.setAriaLiveRefContent(\n      this.accessibilityLabel || this.querySelector('sbb-dialog-title')?.innerText.trim(),\n    );\n  }\n\n  protected isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-dialog-animation-duration');\n  }\n\n  protected handleClosing(): void {\n    const contentElement = this._contentElement();\n\n    contentElement?.scrollTo(0, 0);\n    this.state = 'closed';\n    this.hidePopover?.();\n\n    this.inertController.deactivate();\n    if (!this.skipFocusRestoration) {\n      // Manually focus last focused element\n      this.lastFocusedElement?.focus();\n    }\n    this.openOverlayController?.abort();\n    this.focusTrapController.enabled = false;\n    if (contentElement) {\n      this._dialogContentResizeObserver.hostDisconnected();\n    }\n    this.removeInstanceFromGlobalCollection();\n    // Enable scrolling for content below the dialog if no dialog is open\n    if (!overlayRefs.length) {\n      this.scrollHandler.enableScroll();\n    }\n    this.escapableOverlayController.disconnect();\n    this.dispatchCloseEvent({\n      returnValue: this.returnValue,\n      closeTarget: this.overlayCloseElement,\n    });\n  }\n\n  protected handleOpening(): void {\n    this.state = 'opened';\n    this.inertController.activate();\n    this.focusTrapController.focusInitialElement();\n    this.focusTrapController.enabled = true;\n    // Use timeout to read label after focused element\n    setTimeout(() => this.announceTitle());\n\n    const contentElement = this._contentElement();\n    if (contentElement) {\n      this._dialogContentResizeObserver.observe(contentElement);\n    }\n    this.dispatchOpenEvent();\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    // If the component is already open on firstUpdate, announce the title\n    if (this.isOpen) {\n      this.announceTitle();\n    }\n\n    this._syncTitleNegative();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('negative')) {\n      this._syncTitleNegative();\n    }\n  }\n\n  private _handleSlotChange(): void {\n    this._syncTitleNegative();\n    this._detectIntermediateElement();\n  }\n\n  private _syncTitleNegative(): void {\n    const dialogTitle = this.querySelector?.('sbb-dialog-title');\n    const closeButton = this.querySelector?.('sbb-dialog-close-button');\n\n    if (dialogTitle) {\n      dialogTitle.negative = this.negative;\n    }\n\n    if (closeButton) {\n      closeButton.negative = this.negative;\n    }\n  }\n\n  private _detectIntermediateElement(): void {\n    const hasNoExpectedDirectChildren =\n      this.querySelector(\n        ':scope > :is(sbb-dialog-title, sbb-dialog-close-button, sbb-dialog-content, sbb-dialog-actions)',\n      ) === null;\n\n    this.toggleState('has-intermediate-element', hasNoExpectedDirectChildren);\n  }\n\n  /** Check if the pointerdown event target is triggered on the dialog. */\n  private _pointerDownListener = (event: PointerEvent): void => {\n    if (this.backdropAction !== 'close') {\n      return;\n    }\n\n    this._isPointerDownEventOnDialog =\n      !!this._dialogElement && event.composedPath().includes(this._dialogElement);\n  };\n\n  /** Close dialog on backdrop click. */\n  private _closeOnBackdropClick = (event: PointerEvent): void => {\n    if (\n      this.backdropAction === 'close' &&\n      !this._isPointerDownEventOnDialog &&\n      this._dialogElement &&\n      !event.composedPath().includes(this._dialogElement)\n    ) {\n      this.close();\n    }\n  };\n\n  private _updateOverflowState(): void {\n    const contentElement = this._contentElement();\n    this.toggleState('top-shadow', (contentElement?.scrollTop ?? 0) > 0);\n    this.toggleState(\n      'bottom-shadow',\n      (contentElement?.scrollTop ?? 0) + (contentElement?.offsetHeight ?? 0) <\n        (contentElement?.scrollHeight ?? 0),\n    );\n  }\n\n  private _contentElement(): SbbDialogContentElement | null {\n    return this.querySelector('sbb-dialog-content');\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-dialog__container\">\n        <div\n          @animationend=${this.onOverlayAnimationEnd}\n          class=\"sbb-dialog\"\n          ${ref((el?: Element) => (this._dialogElement = el as HTMLDivElement))}\n        >\n          <div\n            @click=${(event: Event) => this.closeOnSbbOverlayCloseClick(event)}\n            class=\"sbb-dialog__wrapper\"\n          >\n            <slot @slotchange=${() => this._handleSlotChange()}></slot>\n          </div>\n        </div>\n      </div>\n      <sbb-screen-reader-only aria-live=\"polite\"></sbb-screen-reader-only>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-dialog': SbbDialogElement;\n  }\n}\n"],"names":[],"mappings":"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"}
|
|
403
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"dialog.component.js","sources":["../../../../../src/elements/dialog/dialog/dialog.component.ts"],"sourcesContent":["import { ResizeController } from '@lit-labs/observers/resize-controller.js';\nimport type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\nimport { html } from 'lit/static-html.js';\n\nimport { isZeroAnimationDuration } from '../../core/dom.ts';\nimport type { SbbOverlayCloseEventDetails } from '../../core/interfaces/overlay-close-details.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport {\n  overlayRefs,\n  SbbOverlayBaseElement,\n  SbbOverlayCloseEvent as SbbDialogCloseEvent,\n} from '../../overlay.ts';\nimport type { SbbDialogContentElement } from '../dialog-content/dialog-content.component.ts';\n\nimport style from './dialog.scss?lit&inline';\n\nimport '../../screen-reader-only.ts';\n\nexport {\n  assignOverlayResult as assignDialogResult,\n  SbbOverlayCloseEvent as SbbDialogCloseEvent,\n} from '../../overlay/overlay-base-element.ts';\n\nlet nextId = 0;\n\n/**\n * It displays an interactive overlay element.\n *\n * @slot - Use the unnamed slot to provide a `sbb-dialog-title`, `sbb-dialog-content` and an optional `sbb-dialog-actions`.\n * @cssprop [--sbb-dialog-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-dialog')\nclass SbbDialogElement extends SbbOverlayBaseElement {\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n\n  /** Backdrop click action. */\n  @property({ attribute: 'backdrop-action' }) public accessor backdropAction: 'close' | 'none' =\n    'close';\n\n  /** Backdrop density. */\n  @property({ attribute: 'backdrop', reflect: true }) public accessor backdrop:\n    | 'opaque'\n    | 'translucent' = 'opaque';\n\n  // We use a timeout as a workaround to the \"ResizeObserver loop completed with undelivered notifications\" error.\n  // For more details:\n  // - https://github.com/WICG/resize-observer/issues/38#issuecomment-422126006\n  // - https://github.com/juggle/resize-observer/issues/103#issuecomment-1711148285\n  private _dialogContentResizeObserver = new ResizeController(this, {\n    target: null,\n    skipInitial: true,\n    callback: () => setTimeout(() => this._updateOverflowState()),\n  });\n\n  private _dialogElement?: HTMLElement;\n  private _isPointerDownEventOnDialog: boolean = false;\n  protected closeAttribute: string = 'sbb-dialog-close';\n  protected override closeTag: string = 'sbb-dialog-close-button';\n\n  public constructor() {\n    super();\n    // Close dialog on backdrop click\n    this.addEventListener?.('pointerdown', this._pointerDownListener);\n    this.addEventListener?.('pointerup', this._closeOnBackdropClick);\n    this.addEventListener('scroll', () => this._updateOverflowState(), {\n      passive: true,\n      capture: true,\n    });\n  }\n\n  public override connectedCallback(): void {\n    this.id ||= `sbb-dialog-${nextId++}`;\n    super.connectedCallback();\n  }\n\n  /** Announce the accessibility label or dialog title for screen readers. */\n  public announceTitle(): void {\n    this.setAriaLiveRefContent(\n      this.accessibilityLabel || this.querySelector('sbb-dialog-title')?.innerText.trim(),\n    );\n  }\n\n  protected isZeroAnimationDuration(): boolean {\n    return isZeroAnimationDuration(this, '--sbb-dialog-animation-duration');\n  }\n\n  protected handleClosing(): void {\n    const contentElement = this._contentElement();\n\n    contentElement?.scrollTo(0, 0);\n    this.state = 'closed';\n    this.hidePopover?.();\n\n    this.inertController.deactivate();\n    if (!this.skipFocusRestoration) {\n      // Manually focus last focused element\n      this.lastFocusedElement?.focus();\n    }\n    this.openOverlayController?.abort();\n    this.focusTrapController.enabled = false;\n    if (contentElement) {\n      this._dialogContentResizeObserver.hostDisconnected();\n    }\n    this.removeInstanceFromGlobalCollection();\n    // Enable scrolling for content below the dialog if no dialog is open\n    if (!overlayRefs.length) {\n      this.scrollHandler.enableScroll();\n    }\n    this.escapableOverlayController.disconnect();\n    this.dispatchCloseEvent({\n      returnValue: this.returnValue,\n      closeTarget: this.overlayCloseElement,\n    });\n  }\n\n  protected handleOpening(): void {\n    this.state = 'opened';\n    this.inertController.activate();\n    this.focusTrapController.focusInitialElement();\n    this.focusTrapController.enabled = true;\n    // Use timeout to read label after focused element\n    setTimeout(() => this.announceTitle());\n\n    const contentElement = this._contentElement();\n    if (contentElement) {\n      this._dialogContentResizeObserver.observe(contentElement);\n    }\n    this.dispatchOpenEvent();\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    super.firstUpdated(changedProperties);\n\n    // If the component is already open on firstUpdate, announce the title\n    if (this.isOpen) {\n      this.announceTitle();\n    }\n\n    this._syncTitleNegative();\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('negative')) {\n      this._syncTitleNegative();\n    }\n  }\n\n  private _handleSlotChange(): void {\n    this._syncTitleNegative();\n    this._detectIntermediateElement();\n  }\n\n  private _syncTitleNegative(): void {\n    const dialogTitle = this.querySelector?.('sbb-dialog-title');\n    const closeButton = this.querySelector?.('sbb-dialog-close-button');\n\n    if (dialogTitle) {\n      dialogTitle.negative = this.negative;\n    }\n\n    if (closeButton) {\n      closeButton.negative = this.negative;\n    }\n  }\n\n  private _detectIntermediateElement(): void {\n    const hasNoExpectedDirectChildren =\n      this.querySelector(\n        ':scope > :is(sbb-dialog-title, sbb-dialog-close-button, sbb-dialog-content, sbb-dialog-actions)',\n      ) === null;\n\n    this.toggleState('has-intermediate-element', hasNoExpectedDirectChildren);\n  }\n\n  /** Check if the pointerdown event target is triggered on the dialog. */\n  private _pointerDownListener = (event: PointerEvent): void => {\n    if (this.backdropAction !== 'close') {\n      return;\n    }\n\n    this._isPointerDownEventOnDialog =\n      !!this._dialogElement && event.composedPath().includes(this._dialogElement);\n  };\n\n  /** Close dialog on backdrop click. */\n  private _closeOnBackdropClick = (event: PointerEvent): void => {\n    if (\n      this.backdropAction === 'close' &&\n      !this._isPointerDownEventOnDialog &&\n      this._dialogElement &&\n      !event.composedPath().includes(this._dialogElement)\n    ) {\n      this.close();\n    }\n  };\n\n  private _updateOverflowState(): void {\n    const contentElement = this._contentElement();\n    this.toggleState('top-shadow', (contentElement?.scrollTop ?? 0) > 0);\n    this.toggleState(\n      'bottom-shadow',\n      (contentElement?.scrollTop ?? 0) + (contentElement?.offsetHeight ?? 0) <\n        (contentElement?.scrollHeight ?? 0),\n    );\n  }\n\n  private _contentElement(): SbbDialogContentElement | null {\n    return this.querySelector('sbb-dialog-content');\n  }\n\n  // TODO: remove parameter `detail`\n  protected override dispatchBeforeCloseEvent(_detail?: SbbOverlayCloseEventDetails): boolean {\n    /** @type {SbbDialogCloseEvent} Emits whenever the component begins the closing transition. Can be canceled. */\n    return this.dispatchEvent(\n      new SbbDialogCloseEvent('beforeclose', {\n        cancelable: true,\n        closeAttribute: this.closeAttribute,\n        closeTarget: this.overlayCloseElement,\n        result: this.returnValue,\n      }),\n    );\n  }\n\n  // TODO: remove parameter `detail`\n  protected override dispatchCloseEvent(_detail?: SbbOverlayCloseEventDetails): boolean {\n    /** @type {SbbDialogCloseEvent} Emits whenever the component is closed. */\n    return this.dispatchEvent(\n      new SbbDialogCloseEvent('close', {\n        closeAttribute: this.closeAttribute,\n        closeTarget: this.overlayCloseElement,\n        result: this.returnValue,\n      }),\n    );\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-dialog__container\">\n        <div\n          @animationend=${this.onOverlayAnimationEnd}\n          class=\"sbb-dialog\"\n          ${ref((el?: Element) => (this._dialogElement = el as HTMLDivElement))}\n        >\n          <div\n            @click=${(event: Event) => this.closeOnSbbOverlayCloseClick(event)}\n            class=\"sbb-dialog__wrapper\"\n          >\n            <slot @slotchange=${() => this._handleSlotChange()}></slot>\n          </div>\n        </div>\n      </div>\n      <sbb-screen-reader-only aria-live=\"polite\"></sbb-screen-reader-only>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-dialog': SbbDialogElement;\n  }\n}\n"],"names":["SbbDialogCloseEvent"],"mappings":"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"}
|
|
@@ -16,6 +16,7 @@ const style = css`:host {
|
|
|
16
16
|
content: "";
|
|
17
17
|
display: block;
|
|
18
18
|
position: absolute;
|
|
19
|
+
align-self: start;
|
|
19
20
|
border-block-start: var(--sbb-border-width-1x) solid var(--sbb-dialog-actions-border-color);
|
|
20
21
|
transition: border-color var(--sbb-animation-easing) var(--sbb-dialog-shadow-animation-duration);
|
|
21
22
|
width: 100%;
|
|
@@ -51,4 +52,4 @@ let SbbDialogActionsElement = (() => {
|
|
|
51
52
|
export {
|
|
52
53
|
SbbDialogActionsElement
|
|
53
54
|
};
|
|
54
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
55
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLWFjdGlvbnMuY29tcG9uZW50LmpzIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9zcmMvZWxlbWVudHMvZGlhbG9nL2RpYWxvZy1hY3Rpb25zL2RpYWxvZy1hY3Rpb25zLmNvbXBvbmVudC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IENTU1Jlc3VsdEdyb3VwIH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGN1c3RvbUVsZW1lbnQgfSBmcm9tICdsaXQvZGVjb3JhdG9ycy5qcyc7XG5cbmltcG9ydCB7IFNiYkFjdGlvbkdyb3VwRWxlbWVudCB9IGZyb20gJy4uLy4uL2FjdGlvbi1ncm91cC50cyc7XG5pbXBvcnQgeyBpc0xlYW4gfSBmcm9tICcuLi8uLi9jb3JlL2RvbS9sZWFuLWNvbnRleHQudHMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9kaWFsb2ctYWN0aW9ucy5zY3NzP2xpdCZpbmxpbmUnO1xuXG4vKipcbiAqIFVzZSB0aGlzIGNvbXBvbmVudCB0byBkaXNwbGF5IGEgZm9vdGVyIGludG8gYW4gYHNiYi1kaWFsb2dgIHdpdGggYW4gYWN0aW9uIGdyb3VwLlxuICpcbiAqIEBzbG90IC0gVXNlIHRoZSB1bm5hbWVkIHNsb3QgdG8gYWRkIGBzYmItYmxvY2stbGlua2Agb3IgYHNiYi1idXR0b25gIGVsZW1lbnRzIHRvIHRoZSBgc2JiLWRpYWxvZy1hY3Rpb25zYC5cbiAqL1xuZXhwb3J0XG5AY3VzdG9tRWxlbWVudCgnc2JiLWRpYWxvZy1hY3Rpb25zJylcbmNsYXNzIFNiYkRpYWxvZ0FjdGlvbnNFbGVtZW50IGV4dGVuZHMgU2JiQWN0aW9uR3JvdXBFbGVtZW50IHtcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSBzdHlsZXM6IENTU1Jlc3VsdEdyb3VwID0gW1NiYkFjdGlvbkdyb3VwRWxlbWVudC5zdHlsZXMsIHN0eWxlXTtcblxuICBwdWJsaWMgY29uc3RydWN0b3IoKSB7XG4gICAgc3VwZXIoKTtcbiAgICAvKiogQGRlZmF1bHQgJ20nIC8gJ3MnIChsZWFuKSAqL1xuICAgIHRoaXMuYnV0dG9uU2l6ZSA9IGlzTGVhbigpID8gJ3MnIDogJ20nO1xuXG4gICAgLyoqIEBkZWZhdWx0ICdzJyAvICd4cycgKGxlYW4pICovXG4gICAgdGhpcy5saW5rU2l6ZSA9IGlzTGVhbigpID8gJ3hzJyA6ICdzJztcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLWRpYWxvZy1hY3Rpb25zJzogU2JiRGlhbG9nQWN0aW9uc0VsZW1lbnQ7XG4gIH1cbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7SUFlTSwyQkFBdUIsTUFBQTs7MEJBRDVCLGNBQWMsb0JBQW9CLENBQUM7Ozs7b0JBQ0U7QUFBUixFQUFBLG1CQUFRLFlBQXFCO0FBQUEsSUFHekQsY0FBQTtBQUNFLFlBQUE7QUFFQSxXQUFLLGFBQWEsT0FBQSxJQUFXLE1BQU07QUFHbkMsV0FBSyxXQUFXLE9BQUEsSUFBVyxPQUFPO0FBQUEsSUFDcEM7QUFBQTs7QUFWRixpQkFBQSxNQUFBLG1CQUFBLEVBQUEsT0FBQSxXQUFBLEdBQUEsa0JBQUEsRUFBQSxNQUFBLFNBQUEsTUFBQSxXQUFBLE1BQUEsVUFBQSxVQUFBLEdBQUEsTUFBQSx1QkFBQTs7O1FBQ3lCLEdBQUEsU0FBeUIsQ0FBQyxzQkFBc0IsUUFBUSxLQUFLLEdBRGhGLGtCQUFBLFlBQUEsdUJBQUEsR0FBd0I7OzsifQ==
|
|
@@ -1,5 +1,8 @@
|
|
|
1
1
|
import { SbbDialogElement } from "./dialog/dialog.component.js";
|
|
2
|
+
import { SbbOverlayCloseEvent, assignOverlayResult } from "../overlay/overlay-base-element.js";
|
|
2
3
|
export {
|
|
3
|
-
|
|
4
|
+
SbbOverlayCloseEvent as SbbDialogCloseEvent,
|
|
5
|
+
SbbDialogElement,
|
|
6
|
+
assignOverlayResult as assignDialogResult
|
|
4
7
|
};
|
|
5
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
8
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLmpzIiwic291cmNlcyI6W10sInNvdXJjZXNDb250ZW50IjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7In0=
|
package/development/dialog.js
CHANGED
|
@@ -3,11 +3,14 @@ import { SbbDialogContentElement } from "./dialog/dialog-content/dialog-content.
|
|
|
3
3
|
import { SbbDialogCloseButtonElement } from "./dialog/dialog-close-button/dialog-close-button.component.js";
|
|
4
4
|
import { SbbDialogTitleElement } from "./dialog/dialog-title/dialog-title.component.js";
|
|
5
5
|
import { SbbDialogElement } from "./dialog/dialog/dialog.component.js";
|
|
6
|
+
import { SbbOverlayCloseEvent, assignOverlayResult } from "./overlay/overlay-base-element.js";
|
|
6
7
|
export {
|
|
7
8
|
SbbDialogActionsElement,
|
|
8
9
|
SbbDialogCloseButtonElement,
|
|
10
|
+
SbbOverlayCloseEvent as SbbDialogCloseEvent,
|
|
9
11
|
SbbDialogContentElement,
|
|
10
12
|
SbbDialogElement,
|
|
11
|
-
SbbDialogTitleElement
|
|
13
|
+
SbbDialogTitleElement,
|
|
14
|
+
assignOverlayResult as assignDialogResult
|
|
12
15
|
};
|
|
13
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
16
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLmpzIiwic291cmNlcyI6W10sInNvdXJjZXNDb250ZW50IjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7OyJ9
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
import { CSSResultGroup, PropertyValues, TemplateResult
|
|
1
|
+
import { CSSResultGroup, LitElement, PropertyValues, TemplateResult } from 'lit';
|
|
2
2
|
import { SbbOrientation } from '../core/interfaces.ts';
|
|
3
3
|
declare const SbbDividerElement_base: import('../core/mixins.ts').AbstractConstructor<import('../core/mixins.ts').SbbNegativeMixinType> & import('../core/mixins.ts').AbstractConstructor<import('../core/mixins.ts').SbbElementInternalsMixinType> & typeof LitElement & import('../core/mixins.ts').SbbElementInternalsConstructor;
|
|
4
4
|
/**
|
|
5
|
-
*
|
|
5
|
+
* Displays a divider between sections.
|
|
6
6
|
*/
|
|
7
7
|
export declare class SbbDividerElement extends SbbDividerElement_base {
|
|
8
8
|
static readonly role = "separator";
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"divider.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/divider/divider.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,
|
|
1
|
+
{"version":3,"file":"divider.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/divider/divider.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAEnB,UAAU,EACV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;AAGb,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;;AAM5D;;GAEG;AACH,qBAEM,iBAAkB,SAAQ,sBAAsD;IACpF,gBAAgC,IAAI,eAAe;IACnD,OAAuB,MAAM,EAAE,cAAc,CAA4B;IAEzE,mGAAmG;IACnG,SAA6C,WAAW,EAAE,cAAc,CAAgB;cAErE,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAQzD,MAAM,IAAI,cAAc;CAG5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,aAAa,EAAE,iBAAiB,CAAC;KAClC;CACF"}
|