@sbb-esta/lyne-elements 4.6.0 → 4.7.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/autocomplete/autocomplete-base-element.js +34 -34
- package/chip/chip-group/chip-group.component.js +69 -49
- package/core/styles/core.scss +45 -73
- package/core/styles/mixins/overlay.scss +25 -15
- package/core/styles/mixins/pearl-chain-bullet.scss +12 -6
- package/core.css +113 -49
- package/custom-elements.json +351 -225
- package/datepicker/common/datepicker-button.js +18 -14
- package/datepicker/datepicker-next-day/datepicker-next-day.component.js +18 -26
- package/datepicker/datepicker-previous-day/datepicker-previous-day.component.js +20 -28
- package/development/autocomplete/autocomplete-base-element.d.ts +2 -0
- package/development/autocomplete/autocomplete-base-element.d.ts.map +1 -1
- package/development/autocomplete/autocomplete-base-element.js +37 -34
- package/development/calendar/calendar/calendar.component.d.ts +1 -1
- package/development/calendar/calendar/calendar.component.d.ts.map +1 -1
- package/development/calendar/calendar/calendar.component.js +1 -1
- package/development/calendar/calendar-day/calendar-day.component.d.ts +1 -1
- package/development/calendar/calendar-day/calendar-day.component.d.ts.map +1 -1
- package/development/calendar/calendar-day/calendar-day.component.js +1 -1
- package/development/chip/chip-group/chip-group.component.d.ts +6 -0
- package/development/chip/chip-group/chip-group.component.d.ts.map +1 -1
- package/development/chip/chip-group/chip-group.component.js +33 -4
- package/development/container/container/container.component.d.ts +2 -0
- package/development/container/container/container.component.d.ts.map +1 -1
- package/development/container/container/container.component.js +1 -1
- package/development/datepicker/common/datepicker-button.d.ts +3 -1
- package/development/datepicker/common/datepicker-button.d.ts.map +1 -1
- package/development/datepicker/common/datepicker-button.js +8 -4
- package/development/datepicker/datepicker-next-day/datepicker-next-day.component.d.ts +1 -1
- package/development/datepicker/datepicker-next-day/datepicker-next-day.component.d.ts.map +1 -1
- package/development/datepicker/datepicker-next-day/datepicker-next-day.component.js +3 -12
- package/development/datepicker/datepicker-previous-day/datepicker-previous-day.component.d.ts +1 -1
- package/development/datepicker/datepicker-previous-day/datepicker-previous-day.component.d.ts.map +1 -1
- package/development/datepicker/datepicker-previous-day/datepicker-previous-day.component.js +3 -12
- package/development/dialog/dialog/dialog.component.js +24 -37
- package/development/dialog/dialog-actions/dialog-actions.component.js +2 -2
- package/development/dialog/dialog-close-button/dialog-close-button.component.js +2 -2
- package/development/footer/footer.component.js +4 -19
- package/development/form-field/form-field/form-field.component.js +2 -1
- package/development/mini-calendar/mini-calendar-month/mini-calendar-month.component.d.ts +1 -1
- package/development/mini-calendar/mini-calendar-month/mini-calendar-month.component.d.ts.map +1 -1
- package/development/mini-calendar/mini-calendar-month/mini-calendar-month.component.js +2 -2
- package/development/option/optgroup/optgroup-base-element.js +4 -13
- package/development/option/option/option-base-element.d.ts.map +1 -1
- package/development/option/option/option-base-element.js +12 -14
- package/development/option/option/option.component.js +4 -28
- package/development/option/option-hint/option-hint.component.d.ts.map +1 -1
- package/development/option/option-hint/option-hint.component.js +11 -26
- package/development/select/select.component.js +11 -16
- package/development/status/status.component.d.ts.map +1 -1
- package/development/status/status.component.js +20 -26
- package/dialog/dialog/dialog.component.js +19 -19
- package/dialog/dialog-actions/dialog-actions.component.js +6 -6
- package/dialog/dialog-close-button/dialog-close-button.component.js +9 -9
- package/footer/footer.component.js +22 -22
- package/form-field/form-field/form-field.component.js +1 -1
- package/mini-calendar/mini-calendar-month/mini-calendar-month.component.js +1 -1
- package/off-brand-theme.css +113 -49
- package/option/optgroup/optgroup-base-element.js +22 -22
- package/option/option/option-base-element.js +11 -13
- package/option/option/option.component.js +15 -15
- package/option/option-hint/option-hint.component.js +16 -18
- package/package.json +1 -1
- package/safety-theme.css +113 -49
- package/select/select.component.js +18 -18
- package/standard-theme.css +113 -49
- package/status/status.component.js +27 -29
|
@@ -8,7 +8,7 @@ declare const SbbCalendarDayElement_base: import('../../core/mixins.ts').Abstrac
|
|
|
8
8
|
*
|
|
9
9
|
* @slot - Use the unnamed slot to add some custom content to the day.
|
|
10
10
|
*/
|
|
11
|
-
export declare class SbbCalendarDayElement<T
|
|
11
|
+
export declare class SbbCalendarDayElement<T = Date> extends SbbCalendarDayElement_base {
|
|
12
12
|
static styles: CSSResultGroup;
|
|
13
13
|
protected dateAdapter: DateAdapter;
|
|
14
14
|
set slot(value: string);
|
|
@@ -1 +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,
|
|
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,GAAG,IAAI,CAAE,SAAQ,0BAA0C;IACtF,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"}
|
|
@@ -252,4 +252,4 @@ let SbbCalendarDayElement = (() => {
|
|
|
252
252
|
export {
|
|
253
253
|
SbbCalendarDayElement
|
|
254
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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"}
|
|
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 = Date> extends SbbDisabledMixin(SbbButtonLikeBaseElement) {\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<T> | null {\n    return (\n      this.closest?.<SbbCalendarElement<T>>('sbb-calendar') ??\n      (this.getRootNode?.() as ShadowRoot)?.host?.closest<SbbCalendarElement<T>>('sbb-calendar')\n    );\n  }\n\n  private _setSelectedState(component: SbbCalendarElement<T>): 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<T>): 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: T | null) => boolean) | null): boolean {\n    return dateFilter?.(this.value) ?? true;\n  }\n\n  private _isDayInRange(min: T | null, max: T | 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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"}
|
|
@@ -37,6 +37,8 @@ export declare class SbbChipGroupElement<T = string> extends SbbChipGroupElement
|
|
|
37
37
|
accessor displayWith: ((value: T) => string) | null;
|
|
38
38
|
/** The array of keys that will trigger a `chipinputtokenend` event. Default `['Enter']` */
|
|
39
39
|
accessor separatorKeys: string[];
|
|
40
|
+
/** Whether to automatically add a chip when the input loses focus if there's a value. */
|
|
41
|
+
accessor addOnBlur: boolean;
|
|
40
42
|
/**
|
|
41
43
|
* Listens to the changes on `readonly` and `disabled` attributes of `<input>`.
|
|
42
44
|
*/
|
|
@@ -69,6 +71,10 @@ export declare class SbbChipGroupElement<T = string> extends SbbChipGroupElement
|
|
|
69
71
|
* Listen for keyboard events on the input
|
|
70
72
|
**/
|
|
71
73
|
private _onInputKeyDown;
|
|
74
|
+
/**
|
|
75
|
+
* Handle blur event on the input
|
|
76
|
+
**/
|
|
77
|
+
private _onInputBlur;
|
|
72
78
|
/**
|
|
73
79
|
* If the input is not empty, create a chip with its value
|
|
74
80
|
*/
|
|
@@ -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;
|
|
1
|
+
{"version":3,"file":"chip-group.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/chip/chip-group/chip-group.component.ts"],"names":[],"mappings":"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"}
|
|
@@ -10,6 +10,7 @@ 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
12
|
import { SbbLanguageController, SbbPropertyWatcherController } from "../../core/controllers.js";
|
|
13
|
+
import { forceType } from "../../core/decorators.js";
|
|
13
14
|
import { isLean } from "../../core/dom/lean-context.js";
|
|
14
15
|
import { i18nSelectionRequired, i18nChipGroupInputDescription } from "../../core/i18n.js";
|
|
15
16
|
import { SbbRequiredMixin, SbbDisabledMixin, SbbNegativeMixin, SbbFormAssociatedMixin, SbbElementInternalsMixin } from "../../core/mixins.js";
|
|
@@ -114,7 +115,7 @@ const style = css`:host {
|
|
|
114
115
|
max-width: 100%;
|
|
115
116
|
}`;
|
|
116
117
|
let SbbChipGroupElement = (() => {
|
|
117
|
-
var _displayWith_accessor_storage, _separatorKeys_accessor_storage, _a;
|
|
118
|
+
var _displayWith_accessor_storage, _separatorKeys_accessor_storage, _addOnBlur_accessor_storage, _a;
|
|
118
119
|
let _classDecorators = [customElement("sbb-chip-group")];
|
|
119
120
|
let _classDescriptor;
|
|
120
121
|
let _classExtraInitializers = [];
|
|
@@ -128,14 +129,19 @@ let SbbChipGroupElement = (() => {
|
|
|
128
129
|
let _separatorKeys_decorators;
|
|
129
130
|
let _separatorKeys_initializers = [];
|
|
130
131
|
let _separatorKeys_extraInitializers = [];
|
|
132
|
+
let _addOnBlur_decorators;
|
|
133
|
+
let _addOnBlur_initializers = [];
|
|
134
|
+
let _addOnBlur_extraInitializers = [];
|
|
131
135
|
_a = class extends _classSuper {
|
|
132
136
|
constructor() {
|
|
133
137
|
super();
|
|
134
138
|
__privateAdd(this, _displayWith_accessor_storage);
|
|
135
139
|
__privateAdd(this, _separatorKeys_accessor_storage);
|
|
140
|
+
__privateAdd(this, _addOnBlur_accessor_storage);
|
|
136
141
|
__privateSet(this, _displayWith_accessor_storage, (__runInitializers(this, _instanceExtraInitializers), __runInitializers(this, _displayWith_initializers, null)));
|
|
137
142
|
__privateSet(this, _separatorKeys_accessor_storage, (__runInitializers(this, _displayWith_extraInitializers), __runInitializers(this, _separatorKeys_initializers, ["Enter"])));
|
|
138
|
-
this
|
|
143
|
+
__privateSet(this, _addOnBlur_accessor_storage, (__runInitializers(this, _separatorKeys_extraInitializers), __runInitializers(this, _addOnBlur_initializers, false)));
|
|
144
|
+
this._inputAttributeObserver = (__runInitializers(this, _addOnBlur_extraInitializers), !isServer ? new MutationObserver(() => this._reactToInputChanges()) : null);
|
|
139
145
|
this._language = new SbbLanguageController(this);
|
|
140
146
|
this.addEventListener?.(SbbChipElement.events.requestdelete, (ev) => this._deleteChip(ev.target));
|
|
141
147
|
this.addEventListener?.("keydown", (ev) => this._onChipKeyDown(ev));
|
|
@@ -181,6 +187,13 @@ let SbbChipGroupElement = (() => {
|
|
|
181
187
|
set separatorKeys(value) {
|
|
182
188
|
__privateSet(this, _separatorKeys_accessor_storage, value);
|
|
183
189
|
}
|
|
190
|
+
/** Whether to automatically add a chip when the input loses focus if there's a value. */
|
|
191
|
+
get addOnBlur() {
|
|
192
|
+
return __privateGet(this, _addOnBlur_accessor_storage);
|
|
193
|
+
}
|
|
194
|
+
set addOnBlur(value) {
|
|
195
|
+
__privateSet(this, _addOnBlur_accessor_storage, value);
|
|
196
|
+
}
|
|
184
197
|
_updateLabelState(formField) {
|
|
185
198
|
this.toggleState("without-label", !formField.label || formField.hiddenLabel);
|
|
186
199
|
}
|
|
@@ -238,6 +251,10 @@ let SbbChipGroupElement = (() => {
|
|
|
238
251
|
this._inputElement.addEventListener("keydown", (ev) => this._onInputKeyDown(ev), {
|
|
239
252
|
signal: this._inputAbortController.signal
|
|
240
253
|
});
|
|
254
|
+
this._inputElement.addEventListener("blur", () => this._onInputBlur(), {
|
|
255
|
+
signal: this._inputAbortController.signal,
|
|
256
|
+
capture: true
|
|
257
|
+
});
|
|
241
258
|
this._inputElement.addEventListener("inputAutocomplete", (event) => {
|
|
242
259
|
this._createChipFromInput("autocomplete", event.detail?.option.value);
|
|
243
260
|
}, {
|
|
@@ -300,6 +317,14 @@ let SbbChipGroupElement = (() => {
|
|
|
300
317
|
this._createChipFromInput("input");
|
|
301
318
|
}
|
|
302
319
|
}
|
|
320
|
+
/**
|
|
321
|
+
* Handle blur event on the input
|
|
322
|
+
**/
|
|
323
|
+
_onInputBlur() {
|
|
324
|
+
if (this.addOnBlur) {
|
|
325
|
+
this._createChipFromInput("input");
|
|
326
|
+
}
|
|
327
|
+
}
|
|
303
328
|
/**
|
|
304
329
|
* If the input is not empty, create a chip with its value
|
|
305
330
|
*/
|
|
@@ -394,11 +419,12 @@ let SbbChipGroupElement = (() => {
|
|
|
394
419
|
render() {
|
|
395
420
|
return html`<slot @slotchange=${this._setupComponent}></slot>`;
|
|
396
421
|
}
|
|
397
|
-
}, _displayWith_accessor_storage = new WeakMap(), _separatorKeys_accessor_storage = new WeakMap(), _classThis = _a, (() => {
|
|
422
|
+
}, _displayWith_accessor_storage = new WeakMap(), _separatorKeys_accessor_storage = new WeakMap(), _addOnBlur_accessor_storage = new WeakMap(), _classThis = _a, (() => {
|
|
398
423
|
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
|
|
399
424
|
_set_value_decorators = [property({ type: Array })];
|
|
400
425
|
_displayWith_decorators = [property({ attribute: false })];
|
|
401
426
|
_separatorKeys_decorators = [property({ attribute: "separator-keys", type: Array })];
|
|
427
|
+
_addOnBlur_decorators = [forceType(), property({ attribute: "add-on-blur", type: Boolean })];
|
|
402
428
|
__esDecorate(_a, null, _set_value_decorators, { kind: "setter", name: "value", static: false, private: false, access: { has: (obj) => "value" in obj, set: (obj, value) => {
|
|
403
429
|
obj.value = value;
|
|
404
430
|
} }, metadata: _metadata }, null, _instanceExtraInitializers);
|
|
@@ -408,6 +434,9 @@ let SbbChipGroupElement = (() => {
|
|
|
408
434
|
__esDecorate(_a, null, _separatorKeys_decorators, { kind: "accessor", name: "separatorKeys", static: false, private: false, access: { has: (obj) => "separatorKeys" in obj, get: (obj) => obj.separatorKeys, set: (obj, value) => {
|
|
409
435
|
obj.separatorKeys = value;
|
|
410
436
|
} }, metadata: _metadata }, _separatorKeys_initializers, _separatorKeys_extraInitializers);
|
|
437
|
+
__esDecorate(_a, null, _addOnBlur_decorators, { kind: "accessor", name: "addOnBlur", static: false, private: false, access: { has: (obj) => "addOnBlur" in obj, get: (obj) => obj.addOnBlur, set: (obj, value) => {
|
|
438
|
+
obj.addOnBlur = value;
|
|
439
|
+
} }, metadata: _metadata }, _addOnBlur_initializers, _addOnBlur_extraInitializers);
|
|
411
440
|
__esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
|
|
412
441
|
_classThis = _classDescriptor.value;
|
|
413
442
|
if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
|
|
@@ -421,4 +450,4 @@ let SbbChipGroupElement = (() => {
|
|
|
421
450
|
export {
|
|
422
451
|
SbbChipGroupElement
|
|
423
452
|
};
|
|
424
|
-
//# 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`<slot @slotchange=${this._setupComponent}></slot>`;\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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"}
|
|
453
|
+
//# 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 { forceType } from '../../core/decorators.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  /** Whether to automatically add a chip when the input loses focus if there's a value. */\n  @forceType()\n  @property({ attribute: 'add-on-blur', type: Boolean })\n  public accessor addOnBlur: boolean = false;\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('blur', () => this._onInputBlur(), {\n        signal: this._inputAbortController.signal,\n        capture: true,\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   * Handle blur event on the input\n   **/\n  private _onInputBlur(): void {\n    if (this.addOnBlur) {\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`<slot @slotchange=${this._setupComponent}></slot>`;\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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"}
|
|
@@ -6,6 +6,8 @@ declare const SbbContainerElement_base: import('../../core/mixins.ts').AbstractC
|
|
|
6
6
|
* @slot - Use the unnamed slot to add anything to the container.
|
|
7
7
|
* @slot sticky-bar - The slot used by the sbb-sticky-bar component.
|
|
8
8
|
* @slot image - The slot used to slot an `sbb-image` to use as background.
|
|
9
|
+
* @cssprop --sbb-page-spacing-padding - Use this variable to override the default page spacing.
|
|
10
|
+
* Note that overriding this will disable the standard responsive spacing behavior of the container.
|
|
9
11
|
*/
|
|
10
12
|
export declare class SbbContainerElement extends SbbContainerElement_base {
|
|
11
13
|
static styles: CSSResultGroup;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"container.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/container/container/container.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAEnB,UAAU,EACV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;;AASb
|
|
1
|
+
{"version":3,"file":"container.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/container/container/container.component.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,cAAc,EAEnB,UAAU,EACV,KAAK,cAAc,EACnB,KAAK,cAAc,EACpB,MAAM,KAAK,CAAC;;AASb;;;;;;;;GAQG;AACH,qBAEM,mBAAoB,SAAQ,wBAAoC;IACpE,OAAuB,MAAM,EAAE,cAAc,CAA4B;IAEzE,yCAAyC;IACzC,SAEgB,QAAQ,EAAE,OAAO,CAAS;IAE1C,sFAAsF;IACtF,SAEgB,kBAAkB,EAAE,OAAO,CAAS;IAEpD,2DAA2D;IAC3D,SAA6C,KAAK,EAC9C,aAAa,GACb,OAAO,GACP,MAAM,GACN,UAAU,GACV,UAAU,CAAW;cAEN,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cASzD,MAAM,IAAI,cAAc;CAW5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,eAAe,EAAE,mBAAmB,CAAC;KACtC;CACF"}
|
|
@@ -185,4 +185,4 @@ let SbbContainerElement = (() => {
|
|
|
185
185
|
export {
|
|
186
186
|
SbbContainerElement
|
|
187
187
|
};
|
|
188
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
188
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29udGFpbmVyLmNvbXBvbmVudC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzL2NvbnRhaW5lci9jb250YWluZXIvY29udGFpbmVyLmNvbXBvbmVudC50cyJdLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xuICB0eXBlIENTU1Jlc3VsdEdyb3VwLFxuICBodG1sLFxuICBMaXRFbGVtZW50LFxuICB0eXBlIFByb3BlcnR5VmFsdWVzLFxuICB0eXBlIFRlbXBsYXRlUmVzdWx0LFxufSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgY3VzdG9tRWxlbWVudCwgcHJvcGVydHkgfSBmcm9tICdsaXQvZGVjb3JhdG9ycy5qcyc7XG5cbmltcG9ydCB7IGZvcmNlVHlwZSB9IGZyb20gJy4uLy4uL2NvcmUvZGVjb3JhdG9ycy50cyc7XG5pbXBvcnQgeyBTYmJFbGVtZW50SW50ZXJuYWxzTWl4aW4sIMm1c3RhdGVDb250cm9sbGVyIH0gZnJvbSAnLi4vLi4vY29yZS9taXhpbnMudHMnO1xuaW1wb3J0IHsgYm94U2l6aW5nU3R5bGVzIH0gZnJvbSAnLi4vLi4vY29yZS9zdHlsZXMudHMnO1xuXG5pbXBvcnQgc3R5bGUgZnJvbSAnLi9jb250YWluZXIuc2Nzcz9saXQmaW5saW5lJztcblxuLyoqXG4gKiBJdCBkaXNwbGF5cyBpdHMgY29udGVudCB3aXRoIHRoZSBkZWZhdWx0IHBhZ2Ugc3BhY2luZy5cbiAqXG4gKiBAc2xvdCAtIFVzZSB0aGUgdW5uYW1lZCBzbG90IHRvIGFkZCBhbnl0aGluZyB0byB0aGUgY29udGFpbmVyLlxuICogQHNsb3Qgc3RpY2t5LWJhciAtIFRoZSBzbG90IHVzZWQgYnkgdGhlIHNiYi1zdGlja3ktYmFyIGNvbXBvbmVudC5cbiAqIEBzbG90IGltYWdlIC0gVGhlIHNsb3QgdXNlZCB0byBzbG90IGFuIGBzYmItaW1hZ2VgIHRvIHVzZSBhcyBiYWNrZ3JvdW5kLlxuICogQGNzc3Byb3AgLS1zYmItcGFnZS1zcGFjaW5nLXBhZGRpbmcgLSBVc2UgdGhpcyB2YXJpYWJsZSB0byBvdmVycmlkZSB0aGUgZGVmYXVsdCBwYWdlIHNwYWNpbmcuXG4gKiBOb3RlIHRoYXQgb3ZlcnJpZGluZyB0aGlzIHdpbGwgZGlzYWJsZSB0aGUgc3RhbmRhcmQgcmVzcG9uc2l2ZSBzcGFjaW5nIGJlaGF2aW9yIG9mIHRoZSBjb250YWluZXIuXG4gKi9cbmV4cG9ydFxuQGN1c3RvbUVsZW1lbnQoJ3NiYi1jb250YWluZXInKVxuY2xhc3MgU2JiQ29udGFpbmVyRWxlbWVudCBleHRlbmRzIFNiYkVsZW1lbnRJbnRlcm5hbHNNaXhpbihMaXRFbGVtZW50KSB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IFtib3hTaXppbmdTdHlsZXMsIHN0eWxlXTtcblxuICAvKiogV2hldGhlciB0aGUgY29udGFpbmVyIGlzIGV4cGFuZGVkLiAqL1xuICBAZm9yY2VUeXBlKClcbiAgQHByb3BlcnR5KHsgdHlwZTogQm9vbGVhbiwgcmVmbGVjdDogdHJ1ZSB9KVxuICBwdWJsaWMgYWNjZXNzb3IgZXhwYW5kZWQ6IGJvb2xlYW4gPSBmYWxzZTtcblxuICAvKiogV2hldGhlciB0aGUgYmFja2dyb3VuZCBjb2xvciBpcyBzaG93biBvbiBmdWxsIGNvbnRhaW5lciB3aWR0aCBvbiBsYXJnZSBzY3JlZW5zLiAqL1xuICBAZm9yY2VUeXBlKClcbiAgQHByb3BlcnR5KHsgdHlwZTogQm9vbGVhbiwgcmVmbGVjdDogdHJ1ZSwgYXR0cmlidXRlOiAnYmFja2dyb3VuZC1leHBhbmRlZCcgfSlcbiAgcHVibGljIGFjY2Vzc29yIGJhY2tncm91bmRFeHBhbmRlZDogYm9vbGVhbiA9IGZhbHNlO1xuXG4gIC8qKiBDb2xvciBvZiB0aGUgY29udGFpbmVyLCBsaWtlIHRyYW5zcGFyZW50LCB3aGl0ZSBldGMuICovXG4gIEBwcm9wZXJ0eSh7IHJlZmxlY3Q6IHRydWUgfSkgcHVibGljIGFjY2Vzc29yIGNvbG9yOlxuICAgIHwgJ3RyYW5zcGFyZW50J1xuICAgIHwgJ3doaXRlJ1xuICAgIHwgJ21pbGsnXG4gICAgfCAnbWlkbmlnaHQnXG4gICAgfCAnY2hhcmNvYWwnID0gJ3doaXRlJztcblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgd2lsbFVwZGF0ZShjaGFuZ2VkUHJvcGVydGllczogUHJvcGVydHlWYWx1ZXM8dGhpcz4pOiB2b2lkIHtcbiAgICBzdXBlci53aWxsVXBkYXRlKGNoYW5nZWRQcm9wZXJ0aWVzKTtcblxuICAgIGlmIChjaGFuZ2VkUHJvcGVydGllcy5oYXMoJ2V4cGFuZGVkJykpIHtcbiAgICAgIGNvbnN0IHN0aWNreUJhciA9IHRoaXMucXVlcnlTZWxlY3Rvcj8uKCdzYmItc3RpY2t5LWJhcicpO1xuICAgICAgybVzdGF0ZUNvbnRyb2xsZXIoc3RpY2t5QmFyKT8udG9nZ2xlKCdleHBhbmRlZCcsIHRoaXMuZXhwYW5kZWQpO1xuICAgIH1cbiAgfVxuXG4gIHByb3RlY3RlZCBvdmVycmlkZSByZW5kZXIoKTogVGVtcGxhdGVSZXN1bHQge1xuICAgIHJldHVybiBodG1sYFxuICAgICAgPGRpdiBjbGFzcz1cInNiYi1jb250YWluZXJcIj5cbiAgICAgICAgPHNsb3QgbmFtZT1cImltYWdlXCI+PC9zbG90PlxuICAgICAgICA8ZGl2IGNsYXNzPVwic2JiLWNvbnRhaW5lcl9fY29udGVudFwiPlxuICAgICAgICAgIDxzbG90Pjwvc2xvdD5cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L2Rpdj5cbiAgICAgIDxzbG90IG5hbWU9XCJzdGlja3ktYmFyXCI+PC9zbG90PlxuICAgIGA7XG4gIH1cbn1cblxuZGVjbGFyZSBnbG9iYWwge1xuICBpbnRlcmZhY2UgSFRNTEVsZW1lbnRUYWdOYW1lTWFwIHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25hbWluZy1jb252ZW50aW9uXG4gICAgJ3NiYi1jb250YWluZXInOiBTYmJDb250YWluZXJFbGVtZW50O1xuICB9XG59XG4iXSwibmFtZXMiOlsiybVzdGF0ZUNvbnRyb2xsZXIiXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0lBMEJNLHVCQUFtQixNQUFBOzswQkFEeEIsY0FBYyxlQUFlLENBQUM7Ozs7b0JBQ0cseUJBQXlCLFVBQVU7Ozs7Ozs7Ozs7QUFBM0MsRUFBQSxtQkFBUSxZQUFvQztBQUFBOztBQU1wRSxxREFBQSxrQkFBQSxNQUFBLHdCQUFvQyxLQUFLO0FBS3pDLGdFQUFBLGtCQUFBLE1BQUEsMkJBQUEsR0FBQSxrQkFBQSxNQUFBLGtDQUE4QyxLQUFLO0FBR3RCLG1EQUFBLGtCQUFBLE1BQUEscUNBQUEsR0FBQSxrQkFBQSxNQUFBLHFCQUtaLE9BQU87Ozs7SUFieEIsSUFBZ0IsV0FBUTtBQUFBLGFBQUEsbUJBQUE7QUFBQSxJQUFBO0FBQUEsSUFBeEIsSUFBZ0IsU0FBUSxPQUFBO0FBQUEseUJBQUEsNEJBQUE7QUFBQSxJQUFBO0FBQUE7QUFBQSxJQUt4QixJQUFnQixxQkFBa0I7QUFBQSxhQUFBLG1CQUFBO0FBQUEsSUFBQTtBQUFBLElBQWxDLElBQWdCLG1CQUFrQixPQUFBO0FBQUEseUJBQUEsc0NBQUE7QUFBQSxJQUFBO0FBQUE7QUFBQSxJQUdMLElBQWdCLFFBQUs7QUFBQSxhQUFBLG1CQUFBO0FBQUEsSUFBQTtBQUFBLElBQXJCLElBQWdCLE1BQUssT0FBQTtBQUFBLHlCQUFBLHlCQUFBO0FBQUEsSUFBQTtBQUFBLElBTy9CLFdBQVcsbUJBQXVDO0FBQ25FLFlBQU0sV0FBVyxpQkFBaUI7QUFFbEMsVUFBSSxrQkFBa0IsSUFBSSxVQUFVLEdBQUc7QUFDckMsY0FBTSxZQUFZLEtBQUssZ0JBQWdCLGdCQUFnQjtBQUN2REEseUJBQWlCLFNBQVMsR0FBRyxPQUFPLFlBQVksS0FBSyxRQUFRO0FBQUEsTUFDL0Q7QUFBQSxJQUNGO0FBQUEsSUFFbUIsU0FBTTtBQUN2QixhQUFPO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLElBU1Q7QUFBQSxLQWxDQSw0Q0FLQSxzREFHNkI7O0FBVjVCLDJCQUFBLENBQUEsVUFBQSxHQUNBLFNBQVMsRUFBRSxNQUFNLFNBQVMsU0FBUyxLQUFBLENBQU0sQ0FBQztBQUkxQyxxQ0FBQSxDQUFBLGFBQ0EsU0FBUyxFQUFFLE1BQU0sU0FBUyxTQUFTLE1BQU0sV0FBVyxzQkFBQSxDQUF1QixDQUFDO0FBSTVFLHdCQUFBLENBQUEsU0FBUyxFQUFFLFNBQVMsS0FBQSxDQUFNLENBQUM7QUFSNUIsaUJBQUEsSUFBQSxNQUFBLHNCQUFBLEVBQUEsTUFBQSxZQUFBLE1BQUEsWUFBQSxRQUFBLE9BQUEsU0FBQSxPQUFBLFFBQUEsRUFBQSxLQUFBLENBQUEsUUFBQSxjQUFBLEtBQUEsS0FBQSxDQUFBLFFBQUEsSUFBZ0IsVUFBUSxLQUFBLENBQUEsS0FBQSxVQUFBO0FBQUEsVUFBUixXQUFRO0FBQUEsSUFBQSxLQUFBLFVBQUEsVUFBQSxHQUFBLHdCQUFBLDJCQUFBO0FBS3hCLGlCQUFBLElBQUEsTUFBQSxnQ0FBQSxFQUFBLE1BQUEsWUFBQSxNQUFBLHNCQUFBLFFBQUEsT0FBQSxTQUFBLE9BQUEsUUFBQSxFQUFBLEtBQUEsQ0FBQSxRQUFBLHdCQUFBLEtBQUEsS0FBQSxDQUFBLFFBQUEsSUFBZ0Isb0JBQWtCLEtBQUEsQ0FBQSxLQUFBLFVBQUE7QUFBQSxVQUFsQixxQkFBa0I7QUFBQSxJQUFBLEtBQUEsVUFBQSxVQUFBLEdBQUEsa0NBQUEscUNBQUE7QUFHTCxpQkFBQSxJQUFBLE1BQUEsbUJBQUEsRUFBQSxNQUFBLFlBQUEsTUFBQSxTQUFBLFFBQUEsT0FBQSxTQUFBLE9BQUEsUUFBQSxFQUFBLEtBQUEsQ0FBQSxRQUFBLFdBQUEsS0FBQSxLQUFBLENBQUEsUUFBQSxJQUFnQixPQUFLLEtBQUEsQ0FBQSxLQUFBLFVBQUE7QUFBQSxVQUFMLFFBQUs7QUFBQSxJQUFBLEtBQUEsVUFBQSxVQUFBLEdBQUEscUJBQUEsd0JBQUE7QUFkcEQsaUJBQUEsTUFBQSxtQkFBQSxFQUFBLE9BQUEsV0FBQSxHQUFBLGtCQUFBLEVBQUEsTUFBQSxTQUFBLE1BQUEsV0FBQSxNQUFBLFVBQUEsVUFBQSxHQUFBLE1BQUEsdUJBQUE7OztRQUN5QixHQUFBLFNBQXlCLENBQUMsaUJBQWlCLEtBQUssR0FEbkUsa0JBQUEsWUFBQSx1QkFBQSxHQUFvQjs7OyJ9
|
|
@@ -34,7 +34,9 @@ export declare abstract class SbbDatepickerButton<T = Date> extends SbbDatepicke
|
|
|
34
34
|
protected abstract i18nSelectOffBoundaryDay: (_currentDate: string) => Record<string, string>;
|
|
35
35
|
get disabled(): boolean;
|
|
36
36
|
constructor();
|
|
37
|
-
|
|
37
|
+
/** @deprecated Use `getFollowingDate(date: T)` instead. */
|
|
38
|
+
protected findAvailableDate(_date: T): T | null;
|
|
39
|
+
protected abstract getFollowingDate(_date: T): T | null;
|
|
38
40
|
private _handleClick;
|
|
39
41
|
protected syncDateInputState(): void;
|
|
40
42
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"datepicker-button.d.ts","sourceRoot":"","sources":["../../../../../src/elements/datepicker/common/datepicker-button.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,KAAK,mBAAmB,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAG1E,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAEnE,OAAO,EAAE,qBAAqB,EAAE,MAAM,2BAA2B,CAAC;AAClE,OAAO,EAAE,KAAK,WAAW,EAAsB,MAAM,wBAAwB,CAAC;AAI9E,OAAO,EAAE,mBAAmB,EAAE,KAAK,sBAAsB,EAAE,MAAM,qBAAqB,CAAC;AAEvF,OAAO,eAAe,CAAC;;AAEvB,8BAAsB,uBAAuB,CAAC,CAAC,GAAG,IAAI,CACpD,SAAQ,4BACR,YAAW,sBAAsB,CAAC,CAAC,CAAC;IAEpC,gBAAuB,sBAAsB,QAAQ;IAErD;;;;OAIG;IACH,SAEgB,KAAK,EAAE,mBAAmB,CAAC,CAAC,CAAC,GAAG,IAAI,CAAQ;IAE5D,uCAAuC;IACvC,IAAW,QAAQ,IAAI,OAAO,CAE7B;IAED,0EAA0E;IAC1E,OAAO,CAAC,cAAc,CAAQ;IAE9B,OAAO,CAAC,qBAAqB,CAAC,CAAkB;IAEhD,SAAS,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC,CAAC,CAA4D;IACjG,SAAS,CAAC,QAAQ,wBAAmC;IACrD,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAEpB,iBAAiB,IAAI,IAAI;IAYzB,aAAa,CAC3B,IAAI,CAAC,EAAE,WAAW,EAClB,QAAQ,CAAC,EAAE,OAAO,EAClB,OAAO,CAAC,EAAE,mBAAmB,GAC5B,IAAI;IAuBP,OAAO,CAAC,iBAAiB;IAOzB,OAAO,CAAC,KAAK;IAUb,SAAS,CAAC,kBAAkB,IAAI,IAAI;cAIjB,cAAc,IAAI,cAAc;CAGpD;AAED,8BAAsB,mBAAmB,CAAC,CAAC,GAAG,IAAI,CAAE,SAAQ,uBAAuB,CAAC,CAAC,CAAC;IACpF,0EAA0E;IAC1E,OAAO,CAAC,SAAS,CAAQ;IAEzB,SAAS,CAAC,QAAQ,CAAC,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC9D,SAAS,CAAC,QAAQ,CAAC,wBAAwB,EAAE,CAAC,YAAY,EAAE,MAAM,KAAK,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAE9F,IAAoB,QAAQ,IAAI,OAAO,CAEtC;;IAOD,SAAS,CAAC,QAAQ,CAAC,
|
|
1
|
+
{"version":3,"file":"datepicker-button.d.ts","sourceRoot":"","sources":["../../../../../src/elements/datepicker/common/datepicker-button.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,KAAK,mBAAmB,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAG1E,OAAO,EAAE,oBAAoB,EAAE,MAAM,6BAA6B,CAAC;AAEnE,OAAO,EAAE,qBAAqB,EAAE,MAAM,2BAA2B,CAAC;AAClE,OAAO,EAAE,KAAK,WAAW,EAAsB,MAAM,wBAAwB,CAAC;AAI9E,OAAO,EAAE,mBAAmB,EAAE,KAAK,sBAAsB,EAAE,MAAM,qBAAqB,CAAC;AAEvF,OAAO,eAAe,CAAC;;AAEvB,8BAAsB,uBAAuB,CAAC,CAAC,GAAG,IAAI,CACpD,SAAQ,4BACR,YAAW,sBAAsB,CAAC,CAAC,CAAC;IAEpC,gBAAuB,sBAAsB,QAAQ;IAErD;;;;OAIG;IACH,SAEgB,KAAK,EAAE,mBAAmB,CAAC,CAAC,CAAC,GAAG,IAAI,CAAQ;IAE5D,uCAAuC;IACvC,IAAW,QAAQ,IAAI,OAAO,CAE7B;IAED,0EAA0E;IAC1E,OAAO,CAAC,cAAc,CAAQ;IAE9B,OAAO,CAAC,qBAAqB,CAAC,CAAkB;IAEhD,SAAS,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC,CAAC,CAA4D;IACjG,SAAS,CAAC,QAAQ,wBAAmC;IACrD,SAAS,CAAC,QAAQ,CAAC,QAAQ,EAAE,MAAM,CAAC;IAEpB,iBAAiB,IAAI,IAAI;IAYzB,aAAa,CAC3B,IAAI,CAAC,EAAE,WAAW,EAClB,QAAQ,CAAC,EAAE,OAAO,EAClB,OAAO,CAAC,EAAE,mBAAmB,GAC5B,IAAI;IAuBP,OAAO,CAAC,iBAAiB;IAOzB,OAAO,CAAC,KAAK;IAUb,SAAS,CAAC,kBAAkB,IAAI,IAAI;cAIjB,cAAc,IAAI,cAAc;CAGpD;AAED,8BAAsB,mBAAmB,CAAC,CAAC,GAAG,IAAI,CAAE,SAAQ,uBAAuB,CAAC,CAAC,CAAC;IACpF,0EAA0E;IAC1E,OAAO,CAAC,SAAS,CAAQ;IAEzB,SAAS,CAAC,QAAQ,CAAC,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC9D,SAAS,CAAC,QAAQ,CAAC,wBAAwB,EAAE,CAAC,YAAY,EAAE,MAAM,KAAK,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAE9F,IAAoB,QAAQ,IAAI,OAAO,CAEtC;;IAOD,2DAA2D;IAC3D,SAAS,CAAC,iBAAiB,CAAC,KAAK,EAAE,CAAC,GAAG,CAAC,GAAG,IAAI;IAI/C,SAAS,CAAC,QAAQ,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC,GAAG,CAAC,GAAG,IAAI;IAEvD,OAAO,CAAC,YAAY;cAgBD,kBAAkB,IAAI,IAAI;CAmB9C"}
|
|
@@ -113,12 +113,16 @@ class SbbDatepickerButton extends SbbDatepickerButtonBase {
|
|
|
113
113
|
this._disabled = true;
|
|
114
114
|
this.addEventListener?.("click", () => this._handleClick());
|
|
115
115
|
}
|
|
116
|
+
/** @deprecated Use `getFollowingDate(date: T)` instead. */
|
|
117
|
+
findAvailableDate(_date) {
|
|
118
|
+
return this.getFollowingDate(_date);
|
|
119
|
+
}
|
|
116
120
|
_handleClick() {
|
|
117
121
|
if (!this.input || this.disabled) {
|
|
118
122
|
return;
|
|
119
123
|
}
|
|
120
124
|
const startingDate = this.input.valueAsDate ?? this.dateAdapter.today();
|
|
121
|
-
const date = this.
|
|
125
|
+
const date = this.getFollowingDate(startingDate);
|
|
122
126
|
if (this.dateAdapter.isValid(date) && this.dateAdapter.compareDate(date, startingDate) !== 0) {
|
|
123
127
|
this.input.valueAsDate = date;
|
|
124
128
|
this.input.dispatchEvent(new InputEvent("input", { bubbles: true, composed: true }));
|
|
@@ -133,8 +137,8 @@ class SbbDatepickerButton extends SbbDatepickerButtonBase {
|
|
|
133
137
|
this.internals.ariaLabel = this.i18nOffBoundaryDay[this.language.current];
|
|
134
138
|
return;
|
|
135
139
|
}
|
|
136
|
-
const
|
|
137
|
-
this._disabled = !this.dateAdapter.isValid(
|
|
140
|
+
const date = this.getFollowingDate(this.input.valueAsDate);
|
|
141
|
+
this._disabled = !this.dateAdapter.isValid(date) || this.dateAdapter.compareDate(date, this.input.valueAsDate) === 0;
|
|
138
142
|
const currentDateString = this.dateAdapter.compareDate(this.dateAdapter.today(), this.input.valueAsDate) === 0 ? i18nToday[this.language.current].toLowerCase() : this.dateAdapter.getAccessibilityFormatDate(this.input.valueAsDate);
|
|
139
143
|
this.internals.ariaLabel = this.i18nSelectOffBoundaryDay(currentDateString)[this.language.current];
|
|
140
144
|
}
|
|
@@ -143,4 +147,4 @@ export {
|
|
|
143
147
|
SbbDatepickerButton,
|
|
144
148
|
SbbDatepickerButtonBase
|
|
145
149
|
};
|
|
146
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"datepicker-button.js","sources":["../../../../../src/elements/datepicker/common/datepicker-button.ts"],"sourcesContent":["import { html, type PropertyDeclaration, type TemplateResult } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { SbbButtonBaseElement } from '../../core/base-elements.ts';\nimport { readConfig } from '../../core/config.ts';\nimport { SbbLanguageController } from '../../core/controllers.ts';\nimport { type DateAdapter, defaultDateAdapter } from '../../core/datetime.ts';\nimport { idReference } from '../../core/decorators.ts';\nimport { i18nToday } from '../../core/i18n.ts';\nimport { SbbNegativeMixin } from '../../core/mixins.ts';\nimport { SbbDateInputElement, type SbbDateInputAssociated } from '../../date-input.ts';\n\nimport '../../icon.ts';\n\nexport abstract class SbbDatepickerButtonBase<T = Date>\n  extends SbbNegativeMixin(SbbButtonBaseElement)\n  implements SbbDateInputAssociated<T>\n{\n  public static readonly sbbDateInputAssociated = true;\n\n  /**\n   * The associated date input element.\n   *\n   * For attribute usage, provide an id reference.\n   */\n  @idReference()\n  @property()\n  public accessor input: SbbDateInputElement<T> | null = null;\n\n  /** Whether this button is disabled. */\n  public get disabled(): boolean {\n    return !!this._inputDisabled;\n  }\n\n  /** Whether the component is disabled due date-picker's input disabled. */\n  private _inputDisabled = true;\n\n  private _inputAbortController?: AbortController;\n\n  protected dateAdapter: DateAdapter<T> = readConfig().datetime?.dateAdapter ?? defaultDateAdapter;\n  protected language = new SbbLanguageController(this);\n  protected abstract iconName: string;\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.toggleAttribute('disabled', this.disabled);\n    const formField = this.closest?.('sbb-form-field');\n    if (formField) {\n      customElements.upgrade?.(formField);\n      this.negative = formField.negative;\n      SbbDateInputElement.resolveAssociation(this);\n      this.slot ||= this._findSlotPosition();\n    }\n  }\n\n  public override requestUpdate(\n    name?: PropertyKey,\n    oldValue?: unknown,\n    options?: PropertyDeclaration,\n  ): void {\n    super.requestUpdate(name, oldValue, options);\n    if (name === 'input' && this.input !== oldValue) {\n      this._inputAbortController?.abort();\n      this._inputDisabled = true;\n      if (this.input) {\n        this._inputAbortController = new AbortController();\n        this.slot = this._findSlotPosition();\n        // The sbb-date-input instance must be upgraded in order\n        // for properties to be accessible.\n        customElements.upgrade?.(this.input);\n        this._sync();\n        this.input.addEventListener('ɵchange', () => this._sync());\n      }\n      if (this.hasUpdated) {\n        this.toggleAttribute('disabled', this.disabled);\n      }\n    } else if (!name && this.hasUpdated && this.input) {\n      // If language changes, we need to update related aria properties.\n      this._sync();\n    }\n  }\n\n  private _findSlotPosition(): string {\n    return !this.input ||\n      this.compareDocumentPosition(this.input) & Node.DOCUMENT_POSITION_FOLLOWING\n      ? 'prefix'\n      : 'suffix';\n  }\n\n  private _sync(): void {\n    this.syncDateInputState();\n    this.toggleAttribute('disabled', this.disabled);\n    if (this.disabled) {\n      this.removeAttribute('tabindex');\n    } else {\n      this.setAttribute('tabindex', '0');\n    }\n  }\n\n  protected syncDateInputState(): void {\n    this._inputDisabled = this.input!.disabled || this.input!.readOnly;\n  }\n\n  protected override renderTemplate(): TemplateResult {\n    return html`<sbb-icon name=${this.iconName}></sbb-icon>`;\n  }\n}\n\nexport abstract class SbbDatepickerButton<T = Date> extends SbbDatepickerButtonBase<T> {\n  /** Whether the component is disabled due date equals to boundary date. */\n  private _disabled = true;\n\n  protected abstract i18nOffBoundaryDay: Record<string, string>;\n  protected abstract i18nSelectOffBoundaryDay: (_currentDate: string) => Record<string, string>;\n\n  public override get disabled(): boolean {\n    return this._disabled || super.disabled;\n  }\n\n  public constructor() {\n    super();\n    this.addEventListener?.('click', () => this._handleClick());\n  }\n\n  protected abstract findAvailableDate(_date: T): T | null;\n\n  private _handleClick(): void {\n    if (!this.input || this.disabled) {\n      return;\n    }\n    const startingDate: T = this.input.valueAsDate ?? this.dateAdapter.today();\n    const date = this.findAvailableDate(startingDate);\n    if (this.dateAdapter.isValid(date) && this.dateAdapter.compareDate(date, startingDate) !== 0) {\n      this.input.valueAsDate = date;\n      this.input.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));\n      this.input.dispatchEvent(new Event('change', { bubbles: true, composed: true }));\n      // Emit blur event when value is changed programmatically to notify\n      // frameworks that rely on that event to update form status.\n      this.input.dispatchEvent(new Event('blur', { composed: true }));\n    }\n  }\n\n  protected override syncDateInputState(): void {\n    super.syncDateInputState();\n    if (!this.dateAdapter.isValid(this.input!.valueAsDate)) {\n      this._disabled = true;\n      this.internals.ariaLabel = this.i18nOffBoundaryDay[this.language.current];\n      return;\n    }\n\n    const availableDate = this.findAvailableDate(this.input!.valueAsDate);\n    this._disabled =\n      !this.dateAdapter.isValid(availableDate) ||\n      this.dateAdapter.compareDate(availableDate, this.input!.valueAsDate) === 0;\n    const currentDateString =\n      this.dateAdapter.compareDate(this.dateAdapter.today(), this.input!.valueAsDate) === 0\n        ? i18nToday[this.language.current].toLowerCase()\n        : this.dateAdapter.getAccessibilityFormatDate(this.input!.valueAsDate);\n    this.internals.ariaLabel =\n      this.i18nSelectOffBoundaryDay(currentDateString)[this.language.current];\n  }\n}\n"],"names":[],"mappings":"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"}
|
|
150
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"datepicker-button.js","sources":["../../../../../src/elements/datepicker/common/datepicker-button.ts"],"sourcesContent":["import { html, type PropertyDeclaration, type TemplateResult } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { SbbButtonBaseElement } from '../../core/base-elements.ts';\nimport { readConfig } from '../../core/config.ts';\nimport { SbbLanguageController } from '../../core/controllers.ts';\nimport { type DateAdapter, defaultDateAdapter } from '../../core/datetime.ts';\nimport { idReference } from '../../core/decorators.ts';\nimport { i18nToday } from '../../core/i18n.ts';\nimport { SbbNegativeMixin } from '../../core/mixins.ts';\nimport { SbbDateInputElement, type SbbDateInputAssociated } from '../../date-input.ts';\n\nimport '../../icon.ts';\n\nexport abstract class SbbDatepickerButtonBase<T = Date>\n  extends SbbNegativeMixin(SbbButtonBaseElement)\n  implements SbbDateInputAssociated<T>\n{\n  public static readonly sbbDateInputAssociated = true;\n\n  /**\n   * The associated date input element.\n   *\n   * For attribute usage, provide an id reference.\n   */\n  @idReference()\n  @property()\n  public accessor input: SbbDateInputElement<T> | null = null;\n\n  /** Whether this button is disabled. */\n  public get disabled(): boolean {\n    return !!this._inputDisabled;\n  }\n\n  /** Whether the component is disabled due date-picker's input disabled. */\n  private _inputDisabled = true;\n\n  private _inputAbortController?: AbortController;\n\n  protected dateAdapter: DateAdapter<T> = readConfig().datetime?.dateAdapter ?? defaultDateAdapter;\n  protected language = new SbbLanguageController(this);\n  protected abstract iconName: string;\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    this.toggleAttribute('disabled', this.disabled);\n    const formField = this.closest?.('sbb-form-field');\n    if (formField) {\n      customElements.upgrade?.(formField);\n      this.negative = formField.negative;\n      SbbDateInputElement.resolveAssociation(this);\n      this.slot ||= this._findSlotPosition();\n    }\n  }\n\n  public override requestUpdate(\n    name?: PropertyKey,\n    oldValue?: unknown,\n    options?: PropertyDeclaration,\n  ): void {\n    super.requestUpdate(name, oldValue, options);\n    if (name === 'input' && this.input !== oldValue) {\n      this._inputAbortController?.abort();\n      this._inputDisabled = true;\n      if (this.input) {\n        this._inputAbortController = new AbortController();\n        this.slot = this._findSlotPosition();\n        // The sbb-date-input instance must be upgraded in order\n        // for properties to be accessible.\n        customElements.upgrade?.(this.input);\n        this._sync();\n        this.input.addEventListener('ɵchange', () => this._sync());\n      }\n      if (this.hasUpdated) {\n        this.toggleAttribute('disabled', this.disabled);\n      }\n    } else if (!name && this.hasUpdated && this.input) {\n      // If language changes, we need to update related aria properties.\n      this._sync();\n    }\n  }\n\n  private _findSlotPosition(): string {\n    return !this.input ||\n      this.compareDocumentPosition(this.input) & Node.DOCUMENT_POSITION_FOLLOWING\n      ? 'prefix'\n      : 'suffix';\n  }\n\n  private _sync(): void {\n    this.syncDateInputState();\n    this.toggleAttribute('disabled', this.disabled);\n    if (this.disabled) {\n      this.removeAttribute('tabindex');\n    } else {\n      this.setAttribute('tabindex', '0');\n    }\n  }\n\n  protected syncDateInputState(): void {\n    this._inputDisabled = this.input!.disabled || this.input!.readOnly;\n  }\n\n  protected override renderTemplate(): TemplateResult {\n    return html`<sbb-icon name=${this.iconName}></sbb-icon>`;\n  }\n}\n\nexport abstract class SbbDatepickerButton<T = Date> extends SbbDatepickerButtonBase<T> {\n  /** Whether the component is disabled due date equals to boundary date. */\n  private _disabled = true;\n\n  protected abstract i18nOffBoundaryDay: Record<string, string>;\n  protected abstract i18nSelectOffBoundaryDay: (_currentDate: string) => Record<string, string>;\n\n  public override get disabled(): boolean {\n    return this._disabled || super.disabled;\n  }\n\n  public constructor() {\n    super();\n    this.addEventListener?.('click', () => this._handleClick());\n  }\n\n  /** @deprecated Use `getFollowingDate(date: T)` instead. */\n  protected findAvailableDate(_date: T): T | null {\n    return this.getFollowingDate(_date);\n  }\n\n  protected abstract getFollowingDate(_date: T): T | null;\n\n  private _handleClick(): void {\n    if (!this.input || this.disabled) {\n      return;\n    }\n    const startingDate: T = this.input.valueAsDate ?? this.dateAdapter.today();\n    const date = this.getFollowingDate(startingDate);\n    if (this.dateAdapter.isValid(date) && this.dateAdapter.compareDate(date, startingDate) !== 0) {\n      this.input.valueAsDate = date;\n      this.input.dispatchEvent(new InputEvent('input', { bubbles: true, composed: true }));\n      this.input.dispatchEvent(new Event('change', { bubbles: true, composed: true }));\n      // Emit blur event when value is changed programmatically to notify\n      // frameworks that rely on that event to update form status.\n      this.input.dispatchEvent(new Event('blur', { composed: true }));\n    }\n  }\n\n  protected override syncDateInputState(): void {\n    super.syncDateInputState();\n    if (!this.dateAdapter.isValid(this.input!.valueAsDate)) {\n      this._disabled = true;\n      this.internals.ariaLabel = this.i18nOffBoundaryDay[this.language.current];\n      return;\n    }\n\n    const date = this.getFollowingDate(this.input!.valueAsDate);\n    this._disabled =\n      !this.dateAdapter.isValid(date) ||\n      this.dateAdapter.compareDate(date, this.input!.valueAsDate) === 0;\n    const currentDateString =\n      this.dateAdapter.compareDate(this.dateAdapter.today(), this.input!.valueAsDate) === 0\n        ? i18nToday[this.language.current].toLowerCase()\n        : this.dateAdapter.getAccessibilityFormatDate(this.input!.valueAsDate);\n    this.internals.ariaLabel =\n      this.i18nSelectOffBoundaryDay(currentDateString)[this.language.current];\n  }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -8,7 +8,7 @@ export declare class SbbDatepickerNextDayElement<T = Date> extends SbbDatepicker
|
|
|
8
8
|
protected iconName: string;
|
|
9
9
|
protected i18nOffBoundaryDay: Record<string, string>;
|
|
10
10
|
protected i18nSelectOffBoundaryDay: (currentDate: string) => Record<string, string>;
|
|
11
|
-
protected
|
|
11
|
+
protected getFollowingDate(date: T): T | null;
|
|
12
12
|
private _isAfterMaxDate;
|
|
13
13
|
}
|
|
14
14
|
declare global {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"datepicker-next-day.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/datepicker/datepicker-next-day/datepicker-next-day.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAM1C,OAAO,EAAyB,mBAAmB,EAAE,MAAM,cAAc,CAAC;AAE1E;;GAEG;AACH,qBAEM,2BAA2B,CAAC,CAAC,GAAG,IAAI,CAAE,SAAQ,mBAAmB,CAAC,CAAC,CAAC;IACxE,OAAuB,MAAM,EAAE,cAAc,CAI3C;IAEF,SAAS,CAAC,QAAQ,EAAE,MAAM,CAA+B;IACzD,SAAS,CAAC,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAe;IACnE,SAAS,CAAC,wBAAwB,kDAAqB;IAEvD,SAAS,CAAC,
|
|
1
|
+
{"version":3,"file":"datepicker-next-day.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/datepicker/datepicker-next-day/datepicker-next-day.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAM1C,OAAO,EAAyB,mBAAmB,EAAE,MAAM,cAAc,CAAC;AAE1E;;GAEG;AACH,qBAEM,2BAA2B,CAAC,CAAC,GAAG,IAAI,CAAE,SAAQ,mBAAmB,CAAC,CAAC,CAAC;IACxE,OAAuB,MAAM,EAAE,cAAc,CAI3C;IAEF,SAAS,CAAC,QAAQ,EAAE,MAAM,CAA+B;IACzD,SAAS,CAAC,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAe;IACnE,SAAS,CAAC,wBAAwB,kDAAqB;IAEvD,SAAS,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC,GAAG,CAAC,GAAG,IAAI;IAS7C,OAAO,CAAC,eAAe;CAGxB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,yBAAyB,EAAE,2BAA2B,CAAC;KACxD;CACF"}
|
|
@@ -18,20 +18,11 @@ let SbbDatepickerNextDayElement = (() => {
|
|
|
18
18
|
this.i18nOffBoundaryDay = i18nNextDay;
|
|
19
19
|
this.i18nSelectOffBoundaryDay = i18nSelectNextDay;
|
|
20
20
|
}
|
|
21
|
-
|
|
22
|
-
|
|
21
|
+
getFollowingDate(date) {
|
|
22
|
+
const availableDate = this.dateAdapter.addCalendarDays(date, 1);
|
|
23
23
|
if (this._isAfterMaxDate(availableDate)) {
|
|
24
24
|
return null;
|
|
25
25
|
}
|
|
26
|
-
const dateFilter = this.input.dateFilter;
|
|
27
|
-
if (dateFilter) {
|
|
28
|
-
while (!dateFilter(availableDate)) {
|
|
29
|
-
availableDate = this.dateAdapter.addCalendarDays(availableDate, 1);
|
|
30
|
-
if (this._isAfterMaxDate(availableDate)) {
|
|
31
|
-
return null;
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
}
|
|
35
26
|
return availableDate;
|
|
36
27
|
}
|
|
37
28
|
_isAfterMaxDate(date) {
|
|
@@ -52,4 +43,4 @@ let SbbDatepickerNextDayElement = (() => {
|
|
|
52
43
|
export {
|
|
53
44
|
SbbDatepickerNextDayElement
|
|
54
45
|
};
|
|
55
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXBpY2tlci1uZXh0LWRheS5jb21wb25lbnQuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9lbGVtZW50cy9kYXRlcGlja2VyL2RhdGVwaWNrZXItbmV4dC1kYXkvZGF0ZXBpY2tlci1uZXh0LWRheS5jb21wb25lbnQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBDU1NSZXN1bHRHcm91cCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgeyBtaW5pQnV0dG9uU3R5bGUgfSBmcm9tICcuLi8uLi9idXR0b24vY29tbW9uLnRzJztcbmltcG9ydCB7IGkxOG5OZXh0RGF5LCBpMThuU2VsZWN0TmV4dERheSB9IGZyb20gJy4uLy4uL2NvcmUvaTE4bi50cyc7XG5pbXBvcnQgeyBib3hTaXppbmdTdHlsZXMgfSBmcm9tICcuLi8uLi9jb3JlL3N0eWxlcy50cyc7XG5pbXBvcnQgeyBkYXRlcGlja2VyQnV0dG9uU3R5bGUsIFNiYkRhdGVwaWNrZXJCdXR0b24gfSBmcm9tICcuLi9jb21tb24udHMnO1xuXG4vKipcbiAqIENvbWJpbmVkIHdpdGggYSBgc2JiLWRhdGVwaWNrZXJgLCBpdCBjYW4gYmUgdXNlZCB0byBtb3ZlIHRoZSBkYXRlIGFoZWFkLlxuICovXG5leHBvcnRcbkBjdXN0b21FbGVtZW50KCdzYmItZGF0ZXBpY2tlci1uZXh0LWRheScpXG5jbGFzcyBTYmJEYXRlcGlja2VyTmV4dERheUVsZW1lbnQ8VCA9IERhdGU+
|
|
46
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZXBpY2tlci1uZXh0LWRheS5jb21wb25lbnQuanMiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3NyYy9lbGVtZW50cy9kYXRlcGlja2VyL2RhdGVwaWNrZXItbmV4dC1kYXkvZGF0ZXBpY2tlci1uZXh0LWRheS5jb21wb25lbnQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBDU1NSZXN1bHRHcm91cCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgeyBtaW5pQnV0dG9uU3R5bGUgfSBmcm9tICcuLi8uLi9idXR0b24vY29tbW9uLnRzJztcbmltcG9ydCB7IGkxOG5OZXh0RGF5LCBpMThuU2VsZWN0TmV4dERheSB9IGZyb20gJy4uLy4uL2NvcmUvaTE4bi50cyc7XG5pbXBvcnQgeyBib3hTaXppbmdTdHlsZXMgfSBmcm9tICcuLi8uLi9jb3JlL3N0eWxlcy50cyc7XG5pbXBvcnQgeyBkYXRlcGlja2VyQnV0dG9uU3R5bGUsIFNiYkRhdGVwaWNrZXJCdXR0b24gfSBmcm9tICcuLi9jb21tb24udHMnO1xuXG4vKipcbiAqIENvbWJpbmVkIHdpdGggYSBgc2JiLWRhdGVwaWNrZXJgLCBpdCBjYW4gYmUgdXNlZCB0byBtb3ZlIHRoZSBkYXRlIGFoZWFkLlxuICovXG5leHBvcnRcbkBjdXN0b21FbGVtZW50KCdzYmItZGF0ZXBpY2tlci1uZXh0LWRheScpXG5jbGFzcyBTYmJEYXRlcGlja2VyTmV4dERheUVsZW1lbnQ8VCA9IERhdGU+IGV4dGVuZHMgU2JiRGF0ZXBpY2tlckJ1dHRvbjxUPiB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IFtcbiAgICBib3hTaXppbmdTdHlsZXMsXG4gICAgbWluaUJ1dHRvblN0eWxlLFxuICAgIGRhdGVwaWNrZXJCdXR0b25TdHlsZSxcbiAgXTtcblxuICBwcm90ZWN0ZWQgaWNvbk5hbWU6IHN0cmluZyA9ICdjaGV2cm9uLXNtYWxsLXJpZ2h0LXNtYWxsJztcbiAgcHJvdGVjdGVkIGkxOG5PZmZCb3VuZGFyeURheTogUmVjb3JkPHN0cmluZywgc3RyaW5nPiA9IGkxOG5OZXh0RGF5O1xuICBwcm90ZWN0ZWQgaTE4blNlbGVjdE9mZkJvdW5kYXJ5RGF5ID0gaTE4blNlbGVjdE5leHREYXk7XG5cbiAgcHJvdGVjdGVkIGdldEZvbGxvd2luZ0RhdGUoZGF0ZTogVCk6IFQgfCBudWxsIHtcbiAgICBjb25zdCBhdmFpbGFibGVEYXRlID0gdGhpcy5kYXRlQWRhcHRlci5hZGRDYWxlbmRhckRheXMoZGF0ZSwgMSk7XG4gICAgaWYgKHRoaXMuX2lzQWZ0ZXJNYXhEYXRlKGF2YWlsYWJsZURhdGUpKSB7XG4gICAgICByZXR1cm4gbnVsbDtcbiAgICB9XG5cbiAgICByZXR1cm4gYXZhaWxhYmxlRGF0ZTtcbiAgfVxuXG4gIHByaXZhdGUgX2lzQWZ0ZXJNYXhEYXRlKGRhdGU6IFQpOiBib29sZWFuIHtcbiAgICByZXR1cm4gISF0aGlzLmlucHV0IS5tYXggJiYgdGhpcy5kYXRlQWRhcHRlci5jb21wYXJlRGF0ZShkYXRlLCB0aGlzLmlucHV0IS5tYXgpID4gMDtcbiAgfVxufVxuXG5kZWNsYXJlIGdsb2JhbCB7XG4gIGludGVyZmFjZSBIVE1MRWxlbWVudFRhZ05hbWVNYXAge1xuICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbmFtaW5nLWNvbnZlbnRpb25cbiAgICAnc2JiLWRhdGVwaWNrZXItbmV4dC1kYXknOiBTYmJEYXRlcGlja2VyTmV4dERheUVsZW1lbnQ7XG4gIH1cbn1cbiJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7SUFhTSwrQkFBMkIsTUFBQTs7MEJBRGhDLGNBQWMseUJBQXlCLENBQUM7Ozs7b0JBQ1c7QUFBUixFQUFBLG1CQUFRLFlBQXNCO0FBQUE7O0FBTzlELFdBQUEsV0FBbUI7QUFDbkIsV0FBQSxxQkFBNkM7QUFDN0MsV0FBQSwyQkFBMkI7QUFBQSxJQWN2QztBQUFBLElBWlksaUJBQWlCLE1BQU87QUFDaEMsWUFBTSxnQkFBZ0IsS0FBSyxZQUFZLGdCQUFnQixNQUFNLENBQUM7QUFDOUQsVUFBSSxLQUFLLGdCQUFnQixhQUFhLEdBQUc7QUFDdkMsZUFBTztBQUFBLE1BQ1Q7QUFFQSxhQUFPO0FBQUEsSUFDVDtBQUFBLElBRVEsZ0JBQWdCLE1BQU87QUFDN0IsYUFBTyxDQUFDLENBQUMsS0FBSyxNQUFPLE9BQU8sS0FBSyxZQUFZLFlBQVksTUFBTSxLQUFLLE1BQU8sR0FBRyxJQUFJO0FBQUEsSUFDcEY7QUFBQTs7QUF0QkYsaUJBQUEsTUFBQSxtQkFBQSxFQUFBLE9BQUEsV0FBQSxHQUFBLGtCQUFBLEVBQUEsTUFBQSxTQUFBLE1BQUEsV0FBQSxNQUFBLFVBQUEsVUFBQSxHQUFBLE1BQUEsdUJBQUE7OztRQUN5QixHQUFBLFNBQXlCO0FBQUEsSUFDOUM7QUFBQSxJQUNBO0FBQUEsSUFDQTtBQUFBLEVBQUEsR0FKRSxrQkFBQSxZQUFBLHVCQUFBLEdBQXNDOzs7In0=
|
package/development/datepicker/datepicker-previous-day/datepicker-previous-day.component.d.ts
CHANGED
|
@@ -8,7 +8,7 @@ export declare class SbbDatepickerPreviousDayElement<T = Date> extends SbbDatepi
|
|
|
8
8
|
protected iconName: string;
|
|
9
9
|
protected i18nOffBoundaryDay: Record<string, string>;
|
|
10
10
|
protected i18nSelectOffBoundaryDay: (currentDate: string) => Record<string, string>;
|
|
11
|
-
protected
|
|
11
|
+
protected getFollowingDate(date: T): T | null;
|
|
12
12
|
private _isBeforeMinDate;
|
|
13
13
|
}
|
|
14
14
|
declare global {
|
package/development/datepicker/datepicker-previous-day/datepicker-previous-day.component.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"datepicker-previous-day.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/datepicker/datepicker-previous-day/datepicker-previous-day.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAM1C,OAAO,EAAyB,mBAAmB,EAAE,MAAM,cAAc,CAAC;AAE1E;;GAEG;AACH,qBAEM,+BAA+B,CAAC,CAAC,GAAG,IAAI,CAAE,SAAQ,mBAAmB,CAAC,CAAC,CAAC;IAC5E,OAAuB,MAAM,EAAE,cAAc,CAI3C;IAEF,SAAS,CAAC,QAAQ,EAAE,MAAM,CAA8B;IACxD,SAAS,CAAC,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAmB;IACvE,SAAS,CAAC,wBAAwB,kDAAyB;IAE3D,SAAS,CAAC,
|
|
1
|
+
{"version":3,"file":"datepicker-previous-day.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/datepicker/datepicker-previous-day/datepicker-previous-day.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAM1C,OAAO,EAAyB,mBAAmB,EAAE,MAAM,cAAc,CAAC;AAE1E;;GAEG;AACH,qBAEM,+BAA+B,CAAC,CAAC,GAAG,IAAI,CAAE,SAAQ,mBAAmB,CAAC,CAAC,CAAC;IAC5E,OAAuB,MAAM,EAAE,cAAc,CAI3C;IAEF,SAAS,CAAC,QAAQ,EAAE,MAAM,CAA8B;IACxD,SAAS,CAAC,kBAAkB,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAmB;IACvE,SAAS,CAAC,wBAAwB,kDAAyB;IAE3D,SAAS,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC,GAAG,CAAC,GAAG,IAAI;IAS7C,OAAO,CAAC,gBAAgB;CAGzB;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,6BAA6B,EAAE,+BAA+B,CAAC;KAChE;CACF"}
|