@sbb-esta/lyne-elements 4.5.0 → 4.6.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (65) hide show
  1. package/autocomplete/autocomplete-base-element.js +5 -5
  2. package/calendar/{calendar.component.js → calendar/calendar.component.js} +413 -401
  3. package/calendar/calendar-day/calendar-day.component.js +98 -0
  4. package/calendar/calendar-day.js +4 -0
  5. package/calendar/calendar.js +5 -0
  6. package/calendar.js +5 -2
  7. package/chip-label/chip-label.component.js +13 -13
  8. package/container/container/container.component.js +9 -9
  9. package/container/sticky-bar/sticky-bar.component.js +12 -12
  10. package/core/datetime/temporal-date-adapter.js +12 -6
  11. package/core/datetime.js +12 -13
  12. package/core/styles/core.scss +14 -12
  13. package/core/styles/mixins/chip.scss +6 -6
  14. package/core.css +22 -8
  15. package/custom-elements.json +18264 -17381
  16. package/datepicker/datepicker/datepicker.component.js +1 -1
  17. package/development/autocomplete/autocomplete-base-element.d.ts.map +1 -1
  18. package/development/autocomplete/autocomplete-base-element.js +8 -6
  19. package/development/calendar/{calendar.component.d.ts → calendar/calendar.component.d.ts} +23 -3
  20. package/development/calendar/calendar/calendar.component.d.ts.map +1 -0
  21. package/development/calendar/calendar/calendar.component.js +1990 -0
  22. package/development/calendar/calendar-day/calendar-day.component.d.ts +49 -0
  23. package/development/calendar/calendar-day/calendar-day.component.d.ts.map +1 -0
  24. package/development/calendar/calendar-day/calendar-day.component.js +255 -0
  25. package/development/calendar/calendar-day.d.ts +5 -0
  26. package/development/calendar/calendar-day.d.ts.map +1 -0
  27. package/development/calendar/calendar-day.js +5 -0
  28. package/development/calendar/calendar.d.ts +5 -0
  29. package/development/calendar/calendar.d.ts.map +1 -0
  30. package/development/calendar/calendar.js +6 -0
  31. package/development/calendar.d.ts +2 -1
  32. package/development/calendar.d.ts.map +1 -1
  33. package/development/calendar.js +6 -3
  34. package/development/chip-label/chip-label.component.js +6 -15
  35. package/development/container/container/container.component.js +1 -3
  36. package/development/container/sticky-bar/sticky-bar.component.js +9 -14
  37. package/development/core/datetime/native-date-adapter.js +1 -1
  38. package/development/core/datetime/temporal-date-adapter.d.ts +7 -1
  39. package/development/core/datetime/temporal-date-adapter.d.ts.map +1 -1
  40. package/development/core/datetime/temporal-date-adapter.js +14 -7
  41. package/development/core/datetime.js +2 -3
  42. package/development/datepicker/datepicker/datepicker.component.d.ts.map +1 -1
  43. package/development/datepicker/datepicker/datepicker.component.js +2 -1
  44. package/development/dialog/dialog-title/dialog-title.component.js +2 -1
  45. package/development/expansion-panel/expansion-panel/expansion-panel.component.js +6 -5
  46. package/development/form-field/form-field/form-field.component.js +7 -5
  47. package/development/radio-button/radio-button-group/radio-button-group.component.js +2 -2
  48. package/development/tabs/tab/tab.component.js +5 -4
  49. package/development/tabs/tab-group/tab-group.component.d.ts +1 -0
  50. package/development/tabs/tab-group/tab-group.component.d.ts.map +1 -1
  51. package/development/tabs/tab-group/tab-group.component.js +7 -1
  52. package/dialog/dialog-title/dialog-title.component.js +7 -7
  53. package/expansion-panel/expansion-panel/expansion-panel.component.js +9 -9
  54. package/form-field/form-field/form-field.component.js +11 -11
  55. package/index.d.ts +3 -1
  56. package/index.js +3 -1
  57. package/off-brand-theme.css +22 -8
  58. package/package.json +11 -1
  59. package/radio-button/radio-button-group/radio-button-group.component.js +1 -1
  60. package/safety-theme.css +22 -8
  61. package/standard-theme.css +22 -8
  62. package/tabs/tab/tab.component.js +1 -1
  63. package/tabs/tab-group/tab-group.component.js +21 -18
  64. package/development/calendar/calendar.component.d.ts.map +0 -1
  65. package/development/calendar/calendar.component.js +0 -1957
@@ -0,0 +1,49 @@
1
+ import { CSSResultGroup, TemplateResult } from 'lit';
2
+ import { SbbButtonLikeBaseElement } from '../../core/base-elements.ts';
3
+ import { DateAdapter } from '../../core/datetime/date-adapter.ts';
4
+ import { FormRestoreReason, FormRestoreState } from '../../core/mixins.ts';
5
+ declare const SbbCalendarDayElement_base: import('../../core/mixins.ts').AbstractConstructor<import('../../core/mixins.ts').SbbDisabledMixinType> & typeof SbbButtonLikeBaseElement;
6
+ /**
7
+ * It displays a single day cell in the `sbb-calendar` component.
8
+ *
9
+ * @slot - Use the unnamed slot to add some custom content to the day.
10
+ */
11
+ export declare class SbbCalendarDayElement<T extends Date = Date> extends SbbCalendarDayElement_base {
12
+ static styles: CSSResultGroup;
13
+ protected dateAdapter: DateAdapter;
14
+ set slot(value: string);
15
+ get slot(): string;
16
+ /** Value of the calendar-day element. */
17
+ set value(value: T | null);
18
+ get value(): T | null;
19
+ private _value;
20
+ constructor();
21
+ /**
22
+ * Intentionally empty, as buttons are not targeted by form reset.
23
+ * @internal
24
+ */
25
+ formResetCallback(): void;
26
+ /**
27
+ * Intentionally empty, as buttons are not targeted by form restore.
28
+ * @internal
29
+ */
30
+ formStateRestoreCallback(_state: FormRestoreState | null, _reason: FormRestoreReason): void;
31
+ connectedCallback(): void;
32
+ /**
33
+ * The component is used as the default day cell within the `sbb-calendar`,
34
+ * or, if extra content is needed, it can be slotted.
35
+ */
36
+ private _getParent;
37
+ private _setSelectedState;
38
+ private _setDisabledFilteredState;
39
+ private _isActiveDate;
40
+ private _isDayInRange;
41
+ protected renderTemplate(): TemplateResult;
42
+ }
43
+ declare global {
44
+ interface HTMLElementTagNameMap {
45
+ 'sbb-calendar-day': SbbCalendarDayElement;
46
+ }
47
+ }
48
+ export {};
49
+ //# sourceMappingURL=calendar-day.component.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"calendar-day.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/calendar/calendar-day/calendar-day.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAI1D,OAAO,EAAE,wBAAwB,EAAE,MAAM,6BAA6B,CAAC;AAGvE,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,qCAAqC,CAAC;AAEvE,OAAO,EACL,KAAK,iBAAiB,EACtB,KAAK,gBAAgB,EAEtB,MAAM,sBAAsB,CAAC;;AAM9B;;;;GAIG;AACH,qBAEM,qBAAqB,CAAC,CAAC,SAAS,IAAI,GAAG,IAAI,CAAE,SAAQ,0BAE1D;IACC,OAAuB,MAAM,EAAE,cAAc,CAA4B;IACzE,SAAS,CAAC,WAAW,EAAE,WAAW,CAA4D;IAE9F,IACoB,IAAI,CAAC,KAAK,EAAE,MAAM,EAGrC;IACD,IAAoB,IAAI,IAAI,MAAM,CAEjC;IAED,yCAAyC;IACzC,IACW,KAAK,CAAC,KAAK,EAAE,CAAC,GAAG,IAAI,EAc/B;IACD,IAAW,KAAK,IAAI,CAAC,GAAG,IAAI,CAE3B;IACD,OAAO,CAAC,MAAM,CAAkB;;IAchC;;;OAGG;IACa,iBAAiB,IAAI,IAAI;IAEzC;;;OAGG;IACa,wBAAwB,CACtC,MAAM,EAAE,gBAAgB,GAAG,IAAI,EAC/B,OAAO,EAAE,iBAAiB,GACzB,IAAI;IAES,iBAAiB,IAAI,IAAI;IAKzC;;;OAGG;IACH,OAAO,CAAC,UAAU;IAOlB,OAAO,CAAC,iBAAiB;IAUzB,OAAO,CAAC,yBAAyB;IAQjC,OAAO,CAAC,aAAa;IAIrB,OAAO,CAAC,aAAa;cAOF,cAAc,IAAI,cAAc;CAQpD;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,kBAAkB,EAAE,qBAAqB,CAAC;KAC3C;CACF"}
@@ -0,0 +1,255 @@
1
+ import { __esDecorate, __runInitializers } from "tslib";
2
+ import { css, html } from "lit";
3
+ import { customElement, property, state } from "lit/decorators.js";
4
+ import { SbbButtonLikeBaseElement } from "../../core/base-elements.js";
5
+ import { readConfig } from "../../core/config/config.js";
6
+ import { SbbPropertyWatcherController } from "../../core/controllers.js";
7
+ import { defaultDateAdapter } from "../../core/datetime/native-date-adapter.js";
8
+ import { SbbDisabledMixin } from "../../core/mixins.js";
9
+ import { boxSizingStyles } from "../../core/styles.js";
10
+ const style = css`:host {
11
+ display: block;
12
+ --sbb-calendar-day-width: 2.75rem;
13
+ --sbb-calendar-day-height: 3rem;
14
+ --sbb-calendar-day-cell-background-color: var(--sbb-calendar-cell-background-color);
15
+ --sbb-calendar-day-selected-border: none;
16
+ --sbb-calendar-day-transition-duration: var(
17
+ --sbb-disable-animation-duration,
18
+ var(--sbb-animation-duration-2x)
19
+ );
20
+ --sbb-calendar-day-transition-easing-function: var(--sbb-animation-easing);
21
+ --sbb-calendar-day-cursor: var(--sbb-cursor-pointer);
22
+ --sbb-calendar-day-border-radius: var(--sbb-border-radius-4x);
23
+ --sbb-calendar-day-flex-direction: column;
24
+ --sbb-calendar-day-justify-content: initial;
25
+ --sbb-calendar-day-align-items: initial;
26
+ --sbb-calendar-day-value-height: var(--sbb-spacing-fixed-6x);
27
+ --sbb-calendar-day-extra-display: block;
28
+ --sbb-calendar-day-extra-height: var(--sbb-spacing-fixed-4x);
29
+ --sbb-calendar-day-crossed-out-top: 33%;
30
+ --sbb-calendar-day-crossed-out-translate: translate(-50%, -33%) rotate(-45deg);
31
+ }
32
+
33
+ :host(:is(:state(selected),[state--selected])) {
34
+ --sbb-calendar-day-selected-border: var(--sbb-border-width-2x) solid var(--sbb-border-color-2);
35
+ }
36
+
37
+ :host(:disabled) {
38
+ --sbb-calendar-cell-color: var(--sbb-calendar-cell-disabled-color);
39
+ --sbb-calendar-day-cursor: unset;
40
+ }
41
+
42
+ :host(:focus-visible) {
43
+ outline: 0;
44
+ }
45
+
46
+ :host(:not(:disabled):active) {
47
+ --sbb-calendar-day-cell-background-color: var(--sbb-calendar-cell-background-color-active);
48
+ }
49
+
50
+ .sbb-calendar-day {
51
+ --sbb-text-font-size: var(--sbb-text-font-size-s);
52
+ font-family: var(--sbb-typo-font-family);
53
+ font-weight: normal;
54
+ line-height: var(--sbb-typo-line-height-text);
55
+ letter-spacing: var(--sbb-typo-letter-spacing-text);
56
+ font-size: var(--sbb-text-font-size);
57
+ display: flex;
58
+ flex-direction: var(--sbb-calendar-day-flex-direction);
59
+ justify-content: var(--sbb-calendar-day-justify-content);
60
+ align-items: var(--sbb-calendar-day-align-items);
61
+ height: var(--sbb-calendar-day-height);
62
+ width: var(--sbb-calendar-day-width);
63
+ padding: var(--sbb-calendar-cell-padding);
64
+ padding-block-end: var(--sbb-calendar-day-cell-padding-hover, var(--sbb-calendar-cell-padding));
65
+ margin: auto;
66
+ color: var(--sbb-calendar-cell-color);
67
+ cursor: var(--sbb-calendar-day-cursor);
68
+ position: relative;
69
+ z-index: 0;
70
+ }
71
+ .sbb-calendar-day::before {
72
+ content: "";
73
+ position: absolute;
74
+ inset: 0;
75
+ background-color: var(--sbb-calendar-day-cell-background-color);
76
+ border: var(--sbb-calendar-day-selected-border);
77
+ border-radius: var(--sbb-calendar-day-border-radius);
78
+ z-index: -1;
79
+ transition-duration: var(--sbb-calendar-day-transition-duration);
80
+ transition-timing-function: var(--sbb-calendar-day-transition-easing-function);
81
+ transition-property: background-color;
82
+ }
83
+ :host(:focus-visible) .sbb-calendar-day::before {
84
+ outline-offset: var(--sbb-focus-outline-offset);
85
+ outline: var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);
86
+ }
87
+ @media (forced-colors: active) {
88
+ :host(:not(:disabled):active) .sbb-calendar-day::before {
89
+ outline-offset: var(--sbb-focus-outline-offset);
90
+ outline: var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);
91
+ --sbb-focus-outline-style: initial;
92
+ }
93
+ }
94
+ @media (any-hover: hover) {
95
+ :host(:not(:active, :disabled):hover) .sbb-calendar-day {
96
+ --sbb-calendar-day-cell-background-color: var(--sbb-calendar-cell-background-color-hover);
97
+ --sbb-calendar-day-cell-padding-hover: calc(
98
+ 0.0625rem + var(--sbb-calendar-cell-padding)
99
+ );
100
+ }
101
+ }
102
+ @media (any-hover: hover) and (forced-colors: active) {
103
+ :host(:not(:active, :disabled):hover) .sbb-calendar-day::before {
104
+ outline-offset: var(--sbb-focus-outline-offset);
105
+ outline: var(--sbb-focus-outline-color) var(--sbb-focus-outline-style, solid) var(--sbb-focus-outline-width);
106
+ --sbb-focus-outline-style: initial;
107
+ }
108
+ }
109
+
110
+ .sbb-calendar-day__value {
111
+ height: var(--sbb-calendar-day-value-height);
112
+ }
113
+ :host(:is(:state(current),[state--current])) .sbb-calendar-day__value {
114
+ font-weight: bold;
115
+ }
116
+ :host(:is(:state(crossed-out),[state--crossed-out])) .sbb-calendar-day__value::after {
117
+ content: "";
118
+ height: var(--sbb-calendar-cell-disabled-height);
119
+ width: var(--sbb-calendar-cell-disabled-width);
120
+ position: absolute;
121
+ background-color: var(--sbb-calendar-cell-disabled-color);
122
+ inset-block-start: var(--sbb-calendar-day-crossed-out-top);
123
+ inset-inline-start: 50%;
124
+ transform: var(--sbb-calendar-day-crossed-out-translate);
125
+ }
126
+
127
+ .sbb-calendar-day__extra {
128
+ display: var(--sbb-calendar-day-extra-display);
129
+ height: var(--sbb-calendar-day-extra-height);
130
+ padding: var(--sbb-calendar-cell-padding);
131
+ }
132
+
133
+ ::slotted(*) {
134
+ height: 1rem;
135
+ }`;
136
+ let SbbCalendarDayElement = (() => {
137
+ var _a;
138
+ let _classDecorators = [customElement("sbb-calendar-day")];
139
+ let _classDescriptor;
140
+ let _classExtraInitializers = [];
141
+ let _classThis;
142
+ let _classSuper = SbbDisabledMixin(SbbButtonLikeBaseElement);
143
+ let _instanceExtraInitializers = [];
144
+ let _set_slot_decorators;
145
+ let _set_value_decorators;
146
+ _a = class extends _classSuper {
147
+ set slot(value) {
148
+ super.slot = value;
149
+ this.value = this.dateAdapter.deserialize(value);
150
+ }
151
+ get slot() {
152
+ return super.slot;
153
+ }
154
+ /** Value of the calendar-day element. */
155
+ set value(value) {
156
+ const date = this.dateAdapter.getValidDateOrNull(this.dateAdapter.deserialize(value));
157
+ if (date) {
158
+ this._value = date;
159
+ const isToday = this.dateAdapter.sameDate(date, this.dateAdapter.today());
160
+ this.toggleState("current", isToday);
161
+ this.internals.ariaCurrent = isToday ? "date" : null;
162
+ this.internals.ariaLabel = this.dateAdapter.getAccessibilityFormatDate(date);
163
+ const parent = this._getParent();
164
+ if (parent) {
165
+ this._setDisabledFilteredState(parent);
166
+ this._setSelectedState(parent);
167
+ }
168
+ }
169
+ }
170
+ get value() {
171
+ return this._value;
172
+ }
173
+ constructor() {
174
+ super();
175
+ this.dateAdapter = (__runInitializers(this, _instanceExtraInitializers), readConfig().datetime?.dateAdapter ?? defaultDateAdapter);
176
+ this._value = null;
177
+ this.addController(new SbbPropertyWatcherController(this, () => this._getParent(), {
178
+ dateFilter: (component) => this._setDisabledFilteredState(component),
179
+ min: (component) => this._setDisabledFilteredState(component),
180
+ max: (component) => this._setDisabledFilteredState(component),
181
+ selected: (component) => this._setSelectedState(component)
182
+ }));
183
+ }
184
+ /**
185
+ * Intentionally empty, as buttons are not targeted by form reset.
186
+ * @internal
187
+ */
188
+ formResetCallback() {
189
+ }
190
+ /**
191
+ * Intentionally empty, as buttons are not targeted by form restore.
192
+ * @internal
193
+ */
194
+ formStateRestoreCallback(_state, _reason) {
195
+ }
196
+ connectedCallback() {
197
+ super.connectedCallback();
198
+ this.tabIndex = -1;
199
+ }
200
+ /**
201
+ * The component is used as the default day cell within the `sbb-calendar`,
202
+ * or, if extra content is needed, it can be slotted.
203
+ */
204
+ _getParent() {
205
+ return this.closest?.("sbb-calendar") ?? this.getRootNode?.()?.host?.closest("sbb-calendar");
206
+ }
207
+ _setSelectedState(component) {
208
+ const selected = component.multiple ? component.selected.some((selDay) => this.dateAdapter.sameDate(this.value, selDay)) : !!component.selected && this.dateAdapter.compareDate(this.value, component.selected) === 0;
209
+ this.toggleState("selected", selected);
210
+ this.internals.ariaPressed = String(selected);
211
+ }
212
+ _setDisabledFilteredState(component) {
213
+ const isFilteredOut = !this._isActiveDate(component.dateFilter);
214
+ const isOutOfRange = !this._isDayInRange(component.min, component.max);
215
+ this.disabled = isFilteredOut || isOutOfRange;
216
+ this.internals.ariaDisabled = String(this.disabled);
217
+ this.toggleState("crossed-out", isFilteredOut && !isOutOfRange);
218
+ }
219
+ _isActiveDate(dateFilter) {
220
+ return dateFilter?.(this.value) ?? true;
221
+ }
222
+ _isDayInRange(min, max) {
223
+ if (!min && !max) {
224
+ return true;
225
+ }
226
+ return this.dateAdapter.sameDate(this.value, this.dateAdapter.clampDate(this.value, min, max));
227
+ }
228
+ renderTemplate() {
229
+ return html` <span class="sbb-calendar-day__value" aria-hidden="true">
230
+ ${this.dateAdapter.getDate(this.value)}
231
+ </span>
232
+ <span class="sbb-calendar-day__extra">
233
+ <slot></slot>
234
+ </span>`;
235
+ }
236
+ }, _classThis = _a, (() => {
237
+ const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
238
+ _set_slot_decorators = [property()];
239
+ _set_value_decorators = [state()];
240
+ __esDecorate(_a, null, _set_slot_decorators, { kind: "setter", name: "slot", static: false, private: false, access: { has: (obj) => "slot" in obj, set: (obj, value) => {
241
+ obj.slot = value;
242
+ } }, metadata: _metadata }, null, _instanceExtraInitializers);
243
+ __esDecorate(_a, null, _set_value_decorators, { kind: "setter", name: "value", static: false, private: false, access: { has: (obj) => "value" in obj, set: (obj, value) => {
244
+ obj.value = value;
245
+ } }, metadata: _metadata }, null, _instanceExtraInitializers);
246
+ __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
247
+ _classThis = _classDescriptor.value;
248
+ if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
249
+ })(), _a.styles = [boxSizingStyles, style], __runInitializers(_classThis, _classExtraInitializers), _a;
250
+ return _classThis;
251
+ })();
252
+ export {
253
+ SbbCalendarDayElement
254
+ };
255
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"calendar-day.component.js","sources":["../../../../../src/elements/calendar/calendar-day/calendar-day.component.ts"],"sourcesContent":["import type { CSSResultGroup, TemplateResult } from 'lit';\nimport { html } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\n\nimport { SbbButtonLikeBaseElement } from '../../core/base-elements.ts';\nimport { readConfig } from '../../core/config/config.ts';\nimport { SbbPropertyWatcherController } from '../../core/controllers.ts';\nimport type { DateAdapter } from '../../core/datetime/date-adapter.ts';\nimport { defaultDateAdapter } from '../../core/datetime/native-date-adapter.ts';\nimport {\n  type FormRestoreReason,\n  type FormRestoreState,\n  SbbDisabledMixin,\n} from '../../core/mixins.ts';\nimport { boxSizingStyles } from '../../core/styles.ts';\nimport type { SbbCalendarElement } from '../calendar/calendar.component.ts';\n\nimport style from './calendar-day.scss?lit&inline';\n\n/**\n * It displays a single day cell in the `sbb-calendar` component.\n *\n * @slot - Use the unnamed slot to add some custom content to the day.\n */\nexport\n@customElement('sbb-calendar-day')\nclass SbbCalendarDayElement<T extends Date = Date> extends SbbDisabledMixin(\n  SbbButtonLikeBaseElement,\n) {\n  public static override styles: CSSResultGroup = [boxSizingStyles, style];\n  protected dateAdapter: DateAdapter = readConfig().datetime?.dateAdapter ?? defaultDateAdapter;\n\n  @property()\n  public override set slot(value: string) {\n    super.slot = value;\n    this.value = this.dateAdapter.deserialize(value);\n  }\n  public override get slot(): string {\n    return super.slot;\n  }\n\n  /** Value of the calendar-day element. */\n  @state()\n  public set value(value: T | null) {\n    const date = this.dateAdapter.getValidDateOrNull(this.dateAdapter.deserialize(value));\n    if (date) {\n      this._value = date;\n      const isToday = this.dateAdapter.sameDate(date, this.dateAdapter.today());\n      this.toggleState('current', isToday);\n      this.internals.ariaCurrent = isToday ? 'date' : null;\n      this.internals.ariaLabel = this.dateAdapter.getAccessibilityFormatDate(date);\n      const parent = this._getParent();\n      if (parent) {\n        this._setDisabledFilteredState(parent);\n        this._setSelectedState(parent);\n      }\n    }\n  }\n  public get value(): T | null {\n    return this._value;\n  }\n  private _value: T | null = null;\n\n  public constructor() {\n    super();\n    this.addController(\n      new SbbPropertyWatcherController(this, () => this._getParent(), {\n        dateFilter: (component) => this._setDisabledFilteredState(component),\n        min: (component) => this._setDisabledFilteredState(component),\n        max: (component) => this._setDisabledFilteredState(component),\n        selected: (component) => this._setSelectedState(component),\n      }),\n    );\n  }\n\n  /**\n   * Intentionally empty, as buttons are not targeted by form reset.\n   * @internal\n   */\n  public override formResetCallback(): void {}\n\n  /**\n   * Intentionally empty, as buttons are not targeted by form restore.\n   * @internal\n   */\n  public override formStateRestoreCallback(\n    _state: FormRestoreState | null,\n    _reason: FormRestoreReason,\n  ): void {}\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.tabIndex = -1;\n  }\n\n  /**\n   * The component is used as the default day cell within the `sbb-calendar`,\n   * or, if extra content is needed, it can be slotted.\n   */\n  private _getParent(): SbbCalendarElement | null {\n    return (\n      this.closest?.<SbbCalendarElement>('sbb-calendar') ??\n      (this.getRootNode?.() as ShadowRoot)?.host?.closest('sbb-calendar')\n    );\n  }\n\n  private _setSelectedState(component: SbbCalendarElement): void {\n    const selected = component.multiple\n      ? (component.selected as Date[]).some((selDay) =>\n          this.dateAdapter.sameDate(this.value, selDay),\n        )\n      : !!component.selected && this.dateAdapter.compareDate(this.value, component.selected) === 0;\n    this.toggleState('selected', selected);\n    this.internals.ariaPressed = String(selected);\n  }\n\n  private _setDisabledFilteredState(component: SbbCalendarElement): void {\n    const isFilteredOut = !this._isActiveDate(component.dateFilter);\n    const isOutOfRange = !this._isDayInRange(component.min, component.max);\n    this.disabled = isFilteredOut || isOutOfRange;\n    this.internals.ariaDisabled = String(this.disabled);\n    this.toggleState('crossed-out', isFilteredOut && !isOutOfRange);\n  }\n\n  private _isActiveDate(dateFilter: ((date: Date | null) => boolean) | null): boolean {\n    return dateFilter?.(this.value) ?? true;\n  }\n\n  private _isDayInRange(min: Date | null, max: Date | null): boolean {\n    if (!min && !max) {\n      return true;\n    }\n    return this.dateAdapter.sameDate(this.value, this.dateAdapter.clampDate(this.value, min, max));\n  }\n\n  protected override renderTemplate(): TemplateResult {\n    return html` <span class=\"sbb-calendar-day__value\" aria-hidden=\"true\">\n        ${this.dateAdapter.getDate(this.value)}\n      </span>\n      <span class=\"sbb-calendar-day__extra\">\n        <slot></slot>\n      </span>`;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-calendar-day': SbbCalendarDayElement;\n  }\n}\n"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ /**
2
+ * @entrypoint
3
+ */
4
+ export * from './calendar-day/calendar-day.component.ts';
5
+ //# sourceMappingURL=calendar-day.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"calendar-day.d.ts","sourceRoot":"","sources":["../../../../src/elements/calendar/calendar-day.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,cAAc,0CAA0C,CAAC"}
@@ -0,0 +1,5 @@
1
+ import { SbbCalendarDayElement } from "./calendar-day/calendar-day.component.js";
2
+ export {
3
+ SbbCalendarDayElement
4
+ };
5
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXItZGF5LmpzIiwic291cmNlcyI6W10sInNvdXJjZXNDb250ZW50IjpbXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjsifQ==
@@ -0,0 +1,5 @@
1
+ /**
2
+ * @entrypoint
3
+ */
4
+ export * from './calendar/calendar.component.ts';
5
+ //# sourceMappingURL=calendar.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"calendar.d.ts","sourceRoot":"","sources":["../../../../src/elements/calendar/calendar.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,cAAc,kCAAkC,CAAC"}
@@ -0,0 +1,6 @@
1
+ import { SbbCalendarElement, SbbMonthChangeEvent } from "./calendar/calendar.component.js";
2
+ export {
3
+ SbbCalendarElement,
4
+ SbbMonthChangeEvent
5
+ };
6
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIuanMiLCJzb3VyY2VzIjpbXSwic291cmNlc0NvbnRlbnQiOltdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOyJ9
@@ -1,5 +1,6 @@
1
1
  /**
2
2
  * @entrypoint
3
3
  */
4
- export * from './calendar/calendar.component.ts';
4
+ export * from './calendar/calendar.ts';
5
+ export * from './calendar/calendar-day.ts';
5
6
  //# sourceMappingURL=calendar.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"calendar.d.ts","sourceRoot":"","sources":["../../../src/elements/calendar.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,cAAc,kCAAkC,CAAC"}
1
+ {"version":3,"file":"calendar.d.ts","sourceRoot":"","sources":["../../../src/elements/calendar.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,cAAc,wBAAwB,CAAC;AACvC,cAAc,4BAA4B,CAAC"}
@@ -1,5 +1,8 @@
1
- import { SbbCalendarElement } from "./calendar/calendar.component.js";
1
+ import { SbbCalendarElement, SbbMonthChangeEvent } from "./calendar/calendar/calendar.component.js";
2
+ import { SbbCalendarDayElement } from "./calendar/calendar-day/calendar-day.component.js";
2
3
  export {
3
- SbbCalendarElement
4
+ SbbCalendarDayElement,
5
+ SbbCalendarElement,
6
+ SbbMonthChangeEvent
4
7
  };
5
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIuanMiLCJzb3VyY2VzIjpbXSwic291cmNlc0NvbnRlbnQiOltdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOyJ9
8
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXIuanMiLCJzb3VyY2VzIjpbXSwic291cmNlc0NvbnRlbnQiOltdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzsifQ==
@@ -11,12 +11,6 @@ import { customElement, property } from "lit/decorators.js";
11
11
  import { boxSizingStyles } from "../core/styles.js";
12
12
  const style = css`:host {
13
13
  display: inline-block;
14
- --sbb-chip-label-color: var(--sbb-color-granite);
15
- --sbb-chip-label-color: light-dark(var(--sbb-color-granite), var(--sbb-color-cloud));
16
- --sbb-chip-label-background-color: var(--sbb-background-color-3);
17
- --sbb-chip-label-padding-block: 0em;
18
- --sbb-chip-label-padding-inline: var(--sbb-spacing-fixed-2x);
19
- --sbb-text-font-size: var(--sbb-text-font-size-xxs);
20
14
  }
21
15
 
22
16
  :host([color=charcoal]) {
@@ -39,30 +33,27 @@ const style = css`:host {
39
33
  :host([size=xs]) {
40
34
  --sbb-chip-label-padding-block: var(--sbb-spacing-fixed-1x);
41
35
  --sbb-chip-label-padding-inline: var(--sbb-spacing-fixed-3x);
42
- --sbb-text-font-size: var(--sbb-text-font-size-xs);
36
+ --sbb-chip-label-font-size: var(--sbb-text-font-size-xs);
43
37
  }
44
38
 
45
39
  :host([size=s]) {
46
40
  --sbb-chip-label-padding-block: var(--sbb-spacing-fixed-1x);
47
41
  --sbb-chip-label-padding-inline: var(--sbb-spacing-fixed-4x);
48
- --sbb-text-font-size: var(--sbb-text-font-size-s);
42
+ --sbb-chip-label-font-size: var(--sbb-text-font-size-s);
49
43
  }
50
44
 
51
45
  .sbb-chip-label {
52
- font-family: var(--sbb-typo-font-family);
53
- font-weight: normal;
54
- line-height: var(--sbb-typo-line-height-text);
55
- letter-spacing: var(--sbb-typo-letter-spacing-text);
56
- font-size: var(--sbb-text-font-size);
57
46
  line-height: 2;
58
47
  display: inline-flex;
59
48
  align-items: center;
60
49
  justify-content: center;
61
- height: calc(var(--sbb-typo-line-height-text) * var(--sbb-text-font-size) + var(--sbb-chip-label-padding-block) * 2);
50
+ height: calc(var(--sbb-typo-line-height-text) * var(--sbb-chip-label-font-size) + var(--sbb-chip-label-padding-block) * 2);
62
51
  background-color: var(--sbb-chip-label-background-color);
63
52
  padding-inline: var(--sbb-chip-label-padding-inline);
64
53
  border-radius: var(--sbb-border-radius-infinity);
65
54
  color: var(--sbb-chip-label-color);
55
+ font-size: var(--sbb-chip-label-font-size);
56
+ letter-spacing: var(--sbb-typo-letter-spacing-text);
66
57
  overflow: hidden;
67
58
  }
68
59
  @media (forced-colors: active) {
@@ -143,4 +134,4 @@ let SbbChipLabelElement = (() => {
143
134
  export {
144
135
  SbbChipLabelElement
145
136
  };
146
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hpcC1sYWJlbC5jb21wb25lbnQuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9lbGVtZW50cy9jaGlwLWxhYmVsL2NoaXAtbGFiZWwuY29tcG9uZW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgQ1NTUmVzdWx0R3JvdXAsIFRlbXBsYXRlUmVzdWx0IH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGh0bWwsIExpdEVsZW1lbnQgfSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgY3VzdG9tRWxlbWVudCwgcHJvcGVydHkgfSBmcm9tICdsaXQvZGVjb3JhdG9ycy5qcyc7XG5cbmltcG9ydCB7IGJveFNpemluZ1N0eWxlcyB9IGZyb20gJy4uL2NvcmUvc3R5bGVzLnRzJztcblxuaW1wb3J0IHN0eWxlIGZyb20gJy4vY2hpcC1sYWJlbC5zY3NzP2xpdCZpbmxpbmUnO1xuXG4vKipcbiAqIEl0IGRpc3BsYXlzIGJyaWVmIGFuZCBjb21wYWN0IGluZm9ybWF0aW9uLlxuICpcbiAqIEBzbG90IC0gVXNlIHRoZSB1bm5hbWVkIHNsb3QgdG8gYWRkIGNvbnRlbnQgdG8gdGhlIGBzYmItY2hpcC1sYWJlbGAuXG4gKi9cbmV4cG9ydFxuQGN1c3RvbUVsZW1lbnQoJ3NiYi1jaGlwLWxhYmVsJylcbmNsYXNzIFNiYkNoaXBMYWJlbEVsZW1lbnQgZXh0ZW5kcyBMaXRFbGVtZW50IHtcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSBzdHlsZXM6IENTU1Jlc3VsdEdyb3VwID0gW2JveFNpemluZ1N0eWxlcywgc3R5bGVdO1xuXG4gIC8qKiBTaXplIG9mIHRoZSBjaGlwLiAqL1xuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlIH0pXG4gIHB1YmxpYyBhY2Nlc3NvciBzaXplOiAneHhzJyB8ICd4cycgfCAncycgPSAneHhzJztcblxuICAvKiogQ29sb3Igb2YgdGhlIGNoaXAuICovXG4gIEBwcm9wZXJ0eSh7IHJlZmxlY3Q6IHRydWUgfSlcbiAgcHVibGljIGFjY2Vzc29yIGNvbG9yOiAnbWlsaycgfCAnY2hhcmNvYWwnIHwgJ3doaXRlJyB8ICdncmFuaXRlJyA9ICdtaWxrJztcblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVyKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICByZXR1cm4gaHRtbGBcbiAgICAgIDxzcGFuIGNsYXNzPVwic2JiLWNoaXAtbGFiZWxcIj5cbiAgICAgICAgPHNwYW4gY2xhc3M9XCJzYmItY2hpcF9fdGV4dC13cmFwcGVyXCI+XG4gICAgICAgICAgPHNsb3Q+PC9zbG90PlxuICAgICAgICA8L3NwYW4+XG4gICAgICA8L3NwYW4+XG4gICAgYDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLWNoaXAtbGFiZWwnOiBTYmJDaGlwTGFiZWxFbGVtZW50O1xuICB9XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7SUFlTSx1QkFBbUIsTUFBQTs7MEJBRHhCLGNBQWMsZ0JBQWdCLENBQUM7Ozs7b0JBQ0U7Ozs7Ozs7QUFBUixFQUFBLG1CQUFRLFlBQVU7QUFBQTs7QUFLMUMsaURBQUEsa0JBQUEsTUFBQSxvQkFBMkMsS0FBSztBQUloRCxtREFBQSxrQkFBQSxNQUFBLHVCQUFBLEdBQUEsa0JBQUEsTUFBQSxxQkFBbUUsTUFBTTs7OztJQUp6RSxJQUFnQixPQUFJO0FBQUEsYUFBQSxtQkFBQTtBQUFBLElBQUE7QUFBQSxJQUFwQixJQUFnQixLQUFJLE9BQUE7QUFBQSx5QkFBQSx3QkFBQTtBQUFBLElBQUE7QUFBQTtBQUFBLElBSXBCLElBQWdCLFFBQUs7QUFBQSxhQUFBLG1CQUFBO0FBQUEsSUFBQTtBQUFBLElBQXJCLElBQWdCLE1BQUssT0FBQTtBQUFBLHlCQUFBLHlCQUFBO0FBQUEsSUFBQTtBQUFBLElBRUYsU0FBTTtBQUN2QixhQUFPO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsSUFPVDtBQUFBLEtBZEEsd0NBSUE7O0FBTEMsdUJBQUEsQ0FBQSxTQUFTLEVBQUUsU0FBUyxLQUFBLENBQU0sQ0FBQztBQUkzQix3QkFBQSxDQUFBLFNBQVMsRUFBRSxTQUFTLEtBQUEsQ0FBTSxDQUFDO0FBSDVCLGlCQUFBLElBQUEsTUFBQSxrQkFBQSxFQUFBLE1BQUEsWUFBQSxNQUFBLFFBQUEsUUFBQSxPQUFBLFNBQUEsT0FBQSxRQUFBLEVBQUEsS0FBQSxDQUFBLFFBQUEsVUFBQSxLQUFBLEtBQUEsQ0FBQSxRQUFBLElBQWdCLE1BQUksS0FBQSxDQUFBLEtBQUEsVUFBQTtBQUFBLFVBQUosT0FBSTtBQUFBLElBQUEsS0FBQSxVQUFBLFVBQUEsR0FBQSxvQkFBQSx1QkFBQTtBQUlwQixpQkFBQSxJQUFBLE1BQUEsbUJBQUEsRUFBQSxNQUFBLFlBQUEsTUFBQSxTQUFBLFFBQUEsT0FBQSxTQUFBLE9BQUEsUUFBQSxFQUFBLEtBQUEsQ0FBQSxRQUFBLFdBQUEsS0FBQSxLQUFBLENBQUEsUUFBQSxJQUFnQixPQUFLLEtBQUEsQ0FBQSxLQUFBLFVBQUE7QUFBQSxVQUFMLFFBQUs7QUFBQSxJQUFBLEtBQUEsVUFBQSxVQUFBLEdBQUEscUJBQUEsd0JBQUE7QUFUdkIsaUJBQUEsTUFBQSxtQkFBQSxFQUFBLE9BQUEsV0FBQSxHQUFBLGtCQUFBLEVBQUEsTUFBQSxTQUFBLE1BQUEsV0FBQSxNQUFBLFVBQUEsVUFBQSxHQUFBLE1BQUEsdUJBQUE7OztRQUN5QixHQUFBLFNBQXlCLENBQUMsaUJBQWlCLEtBQUssR0FEbkUsa0JBQUEsWUFBQSx1QkFBQSxHQUFvQjs7OyJ9
137
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2hpcC1sYWJlbC5jb21wb25lbnQuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9lbGVtZW50cy9jaGlwLWxhYmVsL2NoaXAtbGFiZWwuY29tcG9uZW50LnRzIl0sInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgQ1NTUmVzdWx0R3JvdXAsIFRlbXBsYXRlUmVzdWx0IH0gZnJvbSAnbGl0JztcbmltcG9ydCB7IGh0bWwsIExpdEVsZW1lbnQgfSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgY3VzdG9tRWxlbWVudCwgcHJvcGVydHkgfSBmcm9tICdsaXQvZGVjb3JhdG9ycy5qcyc7XG5cbmltcG9ydCB7IGJveFNpemluZ1N0eWxlcyB9IGZyb20gJy4uL2NvcmUvc3R5bGVzLnRzJztcblxuaW1wb3J0IHN0eWxlIGZyb20gJy4vY2hpcC1sYWJlbC5zY3NzP2xpdCZpbmxpbmUnO1xuXG4vKipcbiAqIEl0IGRpc3BsYXlzIGJyaWVmIGFuZCBjb21wYWN0IGluZm9ybWF0aW9uLlxuICpcbiAqIEBzbG90IC0gVXNlIHRoZSB1bm5hbWVkIHNsb3QgdG8gYWRkIGNvbnRlbnQgdG8gdGhlIGBzYmItY2hpcC1sYWJlbGAuXG4gKi9cbmV4cG9ydFxuQGN1c3RvbUVsZW1lbnQoJ3NiYi1jaGlwLWxhYmVsJylcbmNsYXNzIFNiYkNoaXBMYWJlbEVsZW1lbnQgZXh0ZW5kcyBMaXRFbGVtZW50IHtcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSBzdHlsZXM6IENTU1Jlc3VsdEdyb3VwID0gW2JveFNpemluZ1N0eWxlcywgc3R5bGVdO1xuXG4gIC8qKiBTaXplIG9mIHRoZSBjaGlwLiAqL1xuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlIH0pXG4gIHB1YmxpYyBhY2Nlc3NvciBzaXplOiAneHhzJyB8ICd4cycgfCAncycgPSAneHhzJztcblxuICAvKiogQ29sb3Igb2YgdGhlIGNoaXAuICovXG4gIEBwcm9wZXJ0eSh7IHJlZmxlY3Q6IHRydWUgfSlcbiAgcHVibGljIGFjY2Vzc29yIGNvbG9yOiAnbWlsaycgfCAnY2hhcmNvYWwnIHwgJ3doaXRlJyB8ICdncmFuaXRlJyA9ICdtaWxrJztcblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVyKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICByZXR1cm4gaHRtbGBcbiAgICAgIDxzcGFuIGNsYXNzPVwic2JiLWNoaXAtbGFiZWxcIj5cbiAgICAgICAgPHNwYW4gY2xhc3M9XCJzYmItY2hpcF9fdGV4dC13cmFwcGVyXCI+XG4gICAgICAgICAgPHNsb3Q+PC9zbG90PlxuICAgICAgICA8L3NwYW4+XG4gICAgICA8L3NwYW4+XG4gICAgYDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLWNoaXAtbGFiZWwnOiBTYmJDaGlwTGFiZWxFbGVtZW50O1xuICB9XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7SUFlTSx1QkFBbUIsTUFBQTs7MEJBRHhCLGNBQWMsZ0JBQWdCLENBQUM7Ozs7b0JBQ0U7Ozs7Ozs7QUFBUixFQUFBLG1CQUFRLFlBQVU7QUFBQTs7QUFLMUMsaURBQUEsa0JBQUEsTUFBQSxvQkFBMkMsS0FBSztBQUloRCxtREFBQSxrQkFBQSxNQUFBLHVCQUFBLEdBQUEsa0JBQUEsTUFBQSxxQkFBbUUsTUFBTTs7OztJQUp6RSxJQUFnQixPQUFJO0FBQUEsYUFBQSxtQkFBQTtBQUFBLElBQUE7QUFBQSxJQUFwQixJQUFnQixLQUFJLE9BQUE7QUFBQSx5QkFBQSx3QkFBQTtBQUFBLElBQUE7QUFBQTtBQUFBLElBSXBCLElBQWdCLFFBQUs7QUFBQSxhQUFBLG1CQUFBO0FBQUEsSUFBQTtBQUFBLElBQXJCLElBQWdCLE1BQUssT0FBQTtBQUFBLHlCQUFBLHlCQUFBO0FBQUEsSUFBQTtBQUFBLElBRUYsU0FBTTtBQUN2QixhQUFPO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsSUFPVDtBQUFBLEtBZEEsd0NBSUE7O0FBTEMsdUJBQUEsQ0FBQSxTQUFTLEVBQUUsU0FBUyxLQUFBLENBQU0sQ0FBQztBQUkzQix3QkFBQSxDQUFBLFNBQVMsRUFBRSxTQUFTLEtBQUEsQ0FBTSxDQUFDO0FBSDVCLGlCQUFBLElBQUEsTUFBQSxrQkFBQSxFQUFBLE1BQUEsWUFBQSxNQUFBLFFBQUEsUUFBQSxPQUFBLFNBQUEsT0FBQSxRQUFBLEVBQUEsS0FBQSxDQUFBLFFBQUEsVUFBQSxLQUFBLEtBQUEsQ0FBQSxRQUFBLElBQWdCLE1BQUksS0FBQSxDQUFBLEtBQUEsVUFBQTtBQUFBLFVBQUosT0FBSTtBQUFBLElBQUEsS0FBQSxVQUFBLFVBQUEsR0FBQSxvQkFBQSx1QkFBQTtBQUlwQixpQkFBQSxJQUFBLE1BQUEsbUJBQUEsRUFBQSxNQUFBLFlBQUEsTUFBQSxTQUFBLFFBQUEsT0FBQSxTQUFBLE9BQUEsUUFBQSxFQUFBLEtBQUEsQ0FBQSxRQUFBLFdBQUEsS0FBQSxLQUFBLENBQUEsUUFBQSxJQUFnQixPQUFLLEtBQUEsQ0FBQSxLQUFBLFVBQUE7QUFBQSxVQUFMLFFBQUs7QUFBQSxJQUFBLEtBQUEsVUFBQSxVQUFBLEdBQUEscUJBQUEsd0JBQUE7QUFUdkIsaUJBQUEsTUFBQSxtQkFBQSxFQUFBLE9BQUEsV0FBQSxHQUFBLGtCQUFBLEVBQUEsTUFBQSxTQUFBLE1BQUEsV0FBQSxNQUFBLFVBQUEsVUFBQSxHQUFBLE1BQUEsdUJBQUE7OztRQUN5QixHQUFBLFNBQXlCLENBQUMsaUJBQWlCLEtBQUssR0FEbkUsa0JBQUEsWUFBQSx1QkFBQSxHQUFvQjs7OyJ9
@@ -13,8 +13,6 @@ import { SbbElementInternalsMixin, ɵstateController as _stateController } from
13
13
  import { boxSizingStyles } from "../../core/styles.js";
14
14
  const style = css`@charset "UTF-8";
15
15
  :host {
16
- --sbb-container-background-border-radius: 0;
17
- --sbb-container-color: inherit;
18
16
  display: block;
19
17
  }
20
18
 
@@ -187,4 +185,4 @@ let SbbContainerElement = (() => {
187
185
  export {
188
186
  SbbContainerElement
189
187
  };
190
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGFpbmVyLmNvbXBvbmVudC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzL2NvbnRhaW5lci9jb250YWluZXIvY29udGFpbmVyLmNvbXBvbmVudC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICB0eXBlIENTU1Jlc3VsdEdyb3VwLFxuICBodG1sLFxuICBMaXRFbGVtZW50LFxuICB0eXBlIFByb3BlcnR5VmFsdWVzLFxuICB0eXBlIFRlbXBsYXRlUmVzdWx0LFxufSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgY3VzdG9tRWxlbWVudCwgcHJvcGVydHkgfSBmcm9tICdsaXQvZGVjb3JhdG9ycy5qcyc7XG5cbmltcG9ydCB7IGZvcmNlVHlwZSB9IGZyb20gJy4uLy4uL2NvcmUvZGVjb3JhdG9ycy50cyc7XG5pbXBvcnQgeyBTYmJFbGVtZW50SW50ZXJuYWxzTWl4aW4sIMm1c3RhdGVDb250cm9sbGVyIH0gZnJvbSAnLi4vLi4vY29yZS9taXhpbnMudHMnO1xuaW1wb3J0IHsgYm94U2l6aW5nU3R5bGVzIH0gZnJvbSAnLi4vLi4vY29yZS9zdHlsZXMudHMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9jb250YWluZXIuc2Nzcz9saXQmaW5saW5lJztcblxuLyoqXG4gKiBJdCBkaXNwbGF5cyBpdHMgY29udGVudCB3aXRoIHRoZSBkZWZhdWx0IHBhZ2Ugc3BhY2luZy5cbiAqXG4gKiBAc2xvdCAtIFVzZSB0aGUgdW5uYW1lZCBzbG90IHRvIGFkZCBhbnl0aGluZyB0byB0aGUgY29udGFpbmVyLlxuICogQHNsb3Qgc3RpY2t5LWJhciAtIFRoZSBzbG90IHVzZWQgYnkgdGhlIHNiYi1zdGlja3ktYmFyIGNvbXBvbmVudC5cbiAqIEBzbG90IGltYWdlIC0gVGhlIHNsb3QgdXNlZCB0byBzbG90IGFuIGBzYmItaW1hZ2VgIHRvIHVzZSBhcyBiYWNrZ3JvdW5kLlxuICovXG5leHBvcnRcbkBjdXN0b21FbGVtZW50KCdzYmItY29udGFpbmVyJylcbmNsYXNzIFNiYkNvbnRhaW5lckVsZW1lbnQgZXh0ZW5kcyBTYmJFbGVtZW50SW50ZXJuYWxzTWl4aW4oTGl0RWxlbWVudCkge1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIHN0eWxlczogQ1NTUmVzdWx0R3JvdXAgPSBbYm94U2l6aW5nU3R5bGVzLCBzdHlsZV07XG5cbiAgLyoqIFdoZXRoZXIgdGhlIGNvbnRhaW5lciBpcyBleHBhbmRlZC4gKi9cbiAgQGZvcmNlVHlwZSgpXG4gIEBwcm9wZXJ0eSh7IHR5cGU6IEJvb2xlYW4sIHJlZmxlY3Q6IHRydWUgfSlcbiAgcHVibGljIGFjY2Vzc29yIGV4cGFuZGVkOiBib29sZWFuID0gZmFsc2U7XG5cbiAgLyoqIFdoZXRoZXIgdGhlIGJhY2tncm91bmQgY29sb3IgaXMgc2hvd24gb24gZnVsbCBjb250YWluZXIgd2lkdGggb24gbGFyZ2Ugc2NyZWVucy4gKi9cbiAgQGZvcmNlVHlwZSgpXG4gIEBwcm9wZXJ0eSh7IHR5cGU6IEJvb2xlYW4sIHJlZmxlY3Q6IHRydWUsIGF0dHJpYnV0ZTogJ2JhY2tncm91bmQtZXhwYW5kZWQnIH0pXG4gIHB1YmxpYyBhY2Nlc3NvciBiYWNrZ3JvdW5kRXhwYW5kZWQ6IGJvb2xlYW4gPSBmYWxzZTtcblxuICAvKiogQ29sb3Igb2YgdGhlIGNvbnRhaW5lciwgbGlrZSB0cmFuc3BhcmVudCwgd2hpdGUgZXRjLiAqL1xuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlIH0pIHB1YmxpYyBhY2Nlc3NvciBjb2xvcjpcbiAgICB8ICd0cmFuc3BhcmVudCdcbiAgICB8ICd3aGl0ZSdcbiAgICB8ICdtaWxrJ1xuICAgIHwgJ21pZG5pZ2h0J1xuICAgIHwgJ2NoYXJjb2FsJyA9ICd3aGl0ZSc7XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHdpbGxVcGRhdGUoY2hhbmdlZFByb3BlcnRpZXM6IFByb3BlcnR5VmFsdWVzPHRoaXM+KTogdm9pZCB7XG4gICAgc3VwZXIud2lsbFVwZGF0ZShjaGFuZ2VkUHJvcGVydGllcyk7XG5cbiAgICBpZiAoY2hhbmdlZFByb3BlcnRpZXMuaGFzKCdleHBhbmRlZCcpKSB7XG4gICAgICBjb25zdCBzdGlja3lCYXIgPSB0aGlzLnF1ZXJ5U2VsZWN0b3I/Lignc2JiLXN0aWNreS1iYXInKTtcbiAgICAgIMm1c3RhdGVDb250cm9sbGVyKHN0aWNreUJhcik/LnRvZ2dsZSgnZXhwYW5kZWQnLCB0aGlzLmV4cGFuZGVkKTtcbiAgICB9XG4gIH1cblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVyKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICByZXR1cm4gaHRtbGBcbiAgICAgIDxkaXYgY2xhc3M9XCJzYmItY29udGFpbmVyXCI+XG4gICAgICAgIDxzbG90IG5hbWU9XCJpbWFnZVwiPjwvc2xvdD5cbiAgICAgICAgPGRpdiBjbGFzcz1cInNiYi1jb250YWluZXJfX2NvbnRlbnRcIj5cbiAgICAgICAgICA8c2xvdD48L3Nsb3Q+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgICA8c2xvdCBuYW1lPVwic3RpY2t5LWJhclwiPjwvc2xvdD5cbiAgICBgO1xuICB9XG59XG5cbmRlY2xhcmUgZ2xvYmFsIHtcbiAgaW50ZXJmYWNlIEhUTUxFbGVtZW50VGFnTmFtZU1hcCB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uYW1pbmctY29udmVudGlvblxuICAgICdzYmItY29udGFpbmVyJzogU2JiQ29udGFpbmVyRWxlbWVudDtcbiAgfVxufVxuIl0sIm5hbWVzIjpbIsm1c3RhdGVDb250cm9sbGVyIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0lBd0JNLHVCQUFtQixNQUFBOzswQkFEeEIsY0FBYyxlQUFlLENBQUM7Ozs7b0JBQ0cseUJBQXlCLFVBQVU7Ozs7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
188
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGFpbmVyLmNvbXBvbmVudC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzL2NvbnRhaW5lci9jb250YWluZXIvY29udGFpbmVyLmNvbXBvbmVudC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICB0eXBlIENTU1Jlc3VsdEdyb3VwLFxuICBodG1sLFxuICBMaXRFbGVtZW50LFxuICB0eXBlIFByb3BlcnR5VmFsdWVzLFxuICB0eXBlIFRlbXBsYXRlUmVzdWx0LFxufSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgY3VzdG9tRWxlbWVudCwgcHJvcGVydHkgfSBmcm9tICdsaXQvZGVjb3JhdG9ycy5qcyc7XG5cbmltcG9ydCB7IGZvcmNlVHlwZSB9IGZyb20gJy4uLy4uL2NvcmUvZGVjb3JhdG9ycy50cyc7XG5pbXBvcnQgeyBTYmJFbGVtZW50SW50ZXJuYWxzTWl4aW4sIMm1c3RhdGVDb250cm9sbGVyIH0gZnJvbSAnLi4vLi4vY29yZS9taXhpbnMudHMnO1xuaW1wb3J0IHsgYm94U2l6aW5nU3R5bGVzIH0gZnJvbSAnLi4vLi4vY29yZS9zdHlsZXMudHMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9jb250YWluZXIuc2Nzcz9saXQmaW5saW5lJztcblxuLyoqXG4gKiBJdCBkaXNwbGF5cyBpdHMgY29udGVudCB3aXRoIHRoZSBkZWZhdWx0IHBhZ2Ugc3BhY2luZy5cbiAqXG4gKiBAc2xvdCAtIFVzZSB0aGUgdW5uYW1lZCBzbG90IHRvIGFkZCBhbnl0aGluZyB0byB0aGUgY29udGFpbmVyLlxuICogQHNsb3Qgc3RpY2t5LWJhciAtIFRoZSBzbG90IHVzZWQgYnkgdGhlIHNiYi1zdGlja3ktYmFyIGNvbXBvbmVudC5cbiAqIEBzbG90IGltYWdlIC0gVGhlIHNsb3QgdXNlZCB0byBzbG90IGFuIGBzYmItaW1hZ2VgIHRvIHVzZSBhcyBiYWNrZ3JvdW5kLlxuICovXG5leHBvcnRcbkBjdXN0b21FbGVtZW50KCdzYmItY29udGFpbmVyJylcbmNsYXNzIFNiYkNvbnRhaW5lckVsZW1lbnQgZXh0ZW5kcyBTYmJFbGVtZW50SW50ZXJuYWxzTWl4aW4oTGl0RWxlbWVudCkge1xuICBwdWJsaWMgc3RhdGljIG92ZXJyaWRlIHN0eWxlczogQ1NTUmVzdWx0R3JvdXAgPSBbYm94U2l6aW5nU3R5bGVzLCBzdHlsZV07XG5cbiAgLyoqIFdoZXRoZXIgdGhlIGNvbnRhaW5lciBpcyBleHBhbmRlZC4gKi9cbiAgQGZvcmNlVHlwZSgpXG4gIEBwcm9wZXJ0eSh7IHR5cGU6IEJvb2xlYW4sIHJlZmxlY3Q6IHRydWUgfSlcbiAgcHVibGljIGFjY2Vzc29yIGV4cGFuZGVkOiBib29sZWFuID0gZmFsc2U7XG5cbiAgLyoqIFdoZXRoZXIgdGhlIGJhY2tncm91bmQgY29sb3IgaXMgc2hvd24gb24gZnVsbCBjb250YWluZXIgd2lkdGggb24gbGFyZ2Ugc2NyZWVucy4gKi9cbiAgQGZvcmNlVHlwZSgpXG4gIEBwcm9wZXJ0eSh7IHR5cGU6IEJvb2xlYW4sIHJlZmxlY3Q6IHRydWUsIGF0dHJpYnV0ZTogJ2JhY2tncm91bmQtZXhwYW5kZWQnIH0pXG4gIHB1YmxpYyBhY2Nlc3NvciBiYWNrZ3JvdW5kRXhwYW5kZWQ6IGJvb2xlYW4gPSBmYWxzZTtcblxuICAvKiogQ29sb3Igb2YgdGhlIGNvbnRhaW5lciwgbGlrZSB0cmFuc3BhcmVudCwgd2hpdGUgZXRjLiAqL1xuICBAcHJvcGVydHkoeyByZWZsZWN0OiB0cnVlIH0pIHB1YmxpYyBhY2Nlc3NvciBjb2xvcjpcbiAgICB8ICd0cmFuc3BhcmVudCdcbiAgICB8ICd3aGl0ZSdcbiAgICB8ICdtaWxrJ1xuICAgIHwgJ21pZG5pZ2h0J1xuICAgIHwgJ2NoYXJjb2FsJyA9ICd3aGl0ZSc7XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHdpbGxVcGRhdGUoY2hhbmdlZFByb3BlcnRpZXM6IFByb3BlcnR5VmFsdWVzPHRoaXM+KTogdm9pZCB7XG4gICAgc3VwZXIud2lsbFVwZGF0ZShjaGFuZ2VkUHJvcGVydGllcyk7XG5cbiAgICBpZiAoY2hhbmdlZFByb3BlcnRpZXMuaGFzKCdleHBhbmRlZCcpKSB7XG4gICAgICBjb25zdCBzdGlja3lCYXIgPSB0aGlzLnF1ZXJ5U2VsZWN0b3I/Lignc2JiLXN0aWNreS1iYXInKTtcbiAgICAgIMm1c3RhdGVDb250cm9sbGVyKHN0aWNreUJhcik/LnRvZ2dsZSgnZXhwYW5kZWQnLCB0aGlzLmV4cGFuZGVkKTtcbiAgICB9XG4gIH1cblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVyKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICByZXR1cm4gaHRtbGBcbiAgICAgIDxkaXYgY2xhc3M9XCJzYmItY29udGFpbmVyXCI+XG4gICAgICAgIDxzbG90IG5hbWU9XCJpbWFnZVwiPjwvc2xvdD5cbiAgICAgICAgPGRpdiBjbGFzcz1cInNiYi1jb250YWluZXJfX2NvbnRlbnRcIj5cbiAgICAgICAgICA8c2xvdD48L3Nsb3Q+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgICA8c2xvdCBuYW1lPVwic3RpY2t5LWJhclwiPjwvc2xvdD5cbiAgICBgO1xuICB9XG59XG5cbmRlY2xhcmUgZ2xvYmFsIHtcbiAgaW50ZXJmYWNlIEhUTUxFbGVtZW50VGFnTmFtZU1hcCB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uYW1pbmctY29udmVudGlvblxuICAgICdzYmItY29udGFpbmVyJzogU2JiQ29udGFpbmVyRWxlbWVudDtcbiAgfVxufVxuIl0sIm5hbWVzIjpbIsm1c3RhdGVDb250cm9sbGVyIl0sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztJQXdCTSx1QkFBbUIsTUFBQTs7MEJBRHhCLGNBQWMsZUFBZSxDQUFDOzs7O29CQUNHLHlCQUF5QixVQUFVOzs7Ozs7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