@sbb-esta/lyne-elements 3.2.0 → 3.3.2
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.d.ts +3 -4
- package/autocomplete/autocomplete-base-element.d.ts.map +1 -1
- package/autocomplete/autocomplete-base-element.js +88 -83
- package/autocomplete/autocomplete.component.d.ts +0 -1
- package/autocomplete/autocomplete.component.d.ts.map +1 -1
- package/autocomplete/autocomplete.component.js +26 -26
- package/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.d.ts +0 -2
- package/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.d.ts.map +1 -1
- package/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.js +34 -44
- package/calendar/calendar.component.d.ts +54 -8
- package/calendar/calendar.component.d.ts.map +1 -1
- package/calendar/calendar.component.js +543 -256
- package/checkbox/checkbox-panel/checkbox-panel.component.d.ts +3 -2
- package/checkbox/checkbox-panel/checkbox-panel.component.d.ts.map +1 -1
- package/checkbox/checkbox-panel/checkbox-panel.component.js +36 -33
- package/core/i18n/i18n.d.ts +1 -0
- package/core/i18n/i18n.d.ts.map +1 -1
- package/core/i18n/i18n.js +22 -16
- package/core/i18n.js +79 -78
- package/core/mixins/element-internals-mixin.js +6 -6
- package/core/mixins/form-associated-mixin.d.ts.map +1 -1
- package/core/mixins/form-associated-mixin.js +22 -16
- package/core.css +7 -7
- package/custom-elements.json +1065 -56
- package/date-input/date-input.component.d.ts +5 -1
- package/date-input/date-input.component.d.ts.map +1 -1
- package/date-input/date-input.component.js +24 -15
- package/development/autocomplete/autocomplete-base-element.d.ts +3 -4
- package/development/autocomplete/autocomplete-base-element.d.ts.map +1 -1
- package/development/autocomplete/autocomplete-base-element.js +30 -15
- package/development/autocomplete/autocomplete.component.d.ts +0 -1
- package/development/autocomplete/autocomplete.component.d.ts.map +1 -1
- package/development/autocomplete/autocomplete.component.js +16 -21
- package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.d.ts +0 -2
- package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.d.ts.map +1 -1
- package/development/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.js +26 -35
- package/development/calendar/calendar.component.d.ts +54 -8
- package/development/calendar/calendar.component.d.ts.map +1 -1
- package/development/calendar/calendar.component.js +496 -81
- package/development/checkbox/checkbox-panel/checkbox-panel.component.d.ts +3 -2
- package/development/checkbox/checkbox-panel/checkbox-panel.component.d.ts.map +1 -1
- package/development/checkbox/checkbox-panel/checkbox-panel.component.js +10 -4
- package/development/core/i18n/i18n.d.ts +1 -0
- package/development/core/i18n/i18n.d.ts.map +1 -1
- package/development/core/i18n/i18n.js +8 -1
- package/development/core/i18n.js +2 -1
- package/development/core/mixins/element-internals-mixin.js +2 -2
- package/development/core/mixins/form-associated-mixin.d.ts.map +1 -1
- package/development/core/mixins/form-associated-mixin.js +14 -7
- package/development/date-input/date-input.component.d.ts +5 -1
- package/development/date-input/date-input.component.d.ts.map +1 -1
- package/development/date-input/date-input.component.js +11 -1
- package/development/form-field/form-field/form-field.component.d.ts +6 -3
- package/development/form-field/form-field/form-field.component.d.ts.map +1 -1
- package/development/form-field/form-field/form-field.component.js +1 -3
- package/development/header/common/header-action-common.js +4 -1
- package/development/icon/icon-request.js +2 -2
- package/development/notification/notification.component.js +1 -1
- package/development/option/option/option-base-element.d.ts.map +1 -1
- package/development/option/option/option-base-element.js +2 -1
- package/development/sbb-tokens-CVLcOi-S.js +1 -1
- package/development/time-input/time-input.component.d.ts +5 -1
- package/development/time-input/time-input.component.d.ts.map +1 -1
- package/development/time-input/time-input.component.js +11 -1
- package/development/toggle-check/toggle-check.component.d.ts +2 -2
- package/development/toggle-check/toggle-check.component.d.ts.map +1 -1
- package/development/toggle-check/toggle-check.component.js +4 -4
- package/form-field/form-field/form-field.component.d.ts +6 -3
- package/form-field/form-field/form-field.component.d.ts.map +1 -1
- package/form-field/form-field/form-field.component.js +0 -2
- package/header/common/header-action-common.js +1 -1
- package/icon/icon-request.js +3 -3
- package/notification/notification.component.js +1 -1
- package/option/option/option-base-element.d.ts.map +1 -1
- package/option/option/option-base-element.js +18 -18
- package/package.json +1 -1
- package/standard-theme.css +7 -7
- package/time-input/time-input.component.d.ts +5 -1
- package/time-input/time-input.component.d.ts.map +1 -1
- package/time-input/time-input.component.js +24 -16
- package/toggle-check/toggle-check.component.d.ts +2 -2
- package/toggle-check/toggle-check.component.d.ts.map +1 -1
- package/toggle-check/toggle-check.component.js +28 -28
|
@@ -18,14 +18,10 @@ let SbbAutocompleteGridElement = (() => {
|
|
|
18
18
|
get options() {
|
|
19
19
|
return Array.from(this.querySelectorAll?.("sbb-autocomplete-grid-option") ?? []);
|
|
20
20
|
}
|
|
21
|
-
get _row() {
|
|
22
|
-
return Array.from(this.querySelectorAll?.("sbb-autocomplete-grid-row")).filter((row) => !row.hasAttribute("data-disabled")) ?? [];
|
|
23
|
-
}
|
|
24
21
|
constructor() {
|
|
25
22
|
super();
|
|
26
23
|
this.overlayId = `sbb-autocomplete-grid-${++nextId}`;
|
|
27
24
|
this.panelRole = "grid";
|
|
28
|
-
this._activeItemIndex = -1;
|
|
29
25
|
this._activeColumnIndex = 0;
|
|
30
26
|
this.addEventListener?.("optionselected", (e) => this.onOptionSelected(e));
|
|
31
27
|
}
|
|
@@ -64,41 +60,40 @@ let SbbAutocompleteGridElement = (() => {
|
|
|
64
60
|
selectByKeyboard(event) {
|
|
65
61
|
event.preventDefault();
|
|
66
62
|
if (this._activeColumnIndex !== 0) {
|
|
67
|
-
this.
|
|
63
|
+
this.activeOption?.closest("sbb-autocomplete-grid-row")?.querySelectorAll("sbb-autocomplete-grid-button")[
|
|
64
|
+
// We ignore the option in the selector. Therefore, we have to shift the activeColumnIndex by one.
|
|
65
|
+
this._activeColumnIndex - 1
|
|
66
|
+
]?.click();
|
|
68
67
|
} else {
|
|
69
|
-
this.
|
|
68
|
+
this.activeOption?.["selectViaUserInteraction"](true);
|
|
70
69
|
}
|
|
71
70
|
}
|
|
72
71
|
setNextActiveOption(event) {
|
|
73
|
-
const
|
|
74
|
-
|
|
75
|
-
|
|
72
|
+
const enabledOptions = this.options.filter((opt) => !opt.disabled && !opt.hasAttribute("data-group-disabled"));
|
|
73
|
+
this.activeOption?.setActive(false);
|
|
74
|
+
this.triggerElement?.removeAttribute("aria-activedescendant");
|
|
75
|
+
Array.from(this.querySelectorAll?.("sbb-autocomplete-grid-row [data-focus-visible]") ?? []).forEach((row) => row.removeAttribute("data-focus-visible"));
|
|
76
|
+
this._activeColumnIndex = 0;
|
|
77
|
+
if (!enabledOptions.length) {
|
|
78
|
+
this.activeOption = null;
|
|
76
79
|
return;
|
|
77
80
|
}
|
|
78
|
-
const
|
|
79
|
-
|
|
80
|
-
this.
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
} else {
|
|
85
|
-
const lastActiveOption = filteredOptions[this._activeItemIndex];
|
|
86
|
-
if (lastActiveOption) {
|
|
87
|
-
lastActiveOption.setActive(false);
|
|
88
|
-
}
|
|
89
|
-
}
|
|
90
|
-
this._activeItemIndex = next;
|
|
91
|
-
this._activeColumnIndex = 0;
|
|
81
|
+
const activeItemIndex = this.activeOption ? enabledOptions.indexOf(this.activeOption) : -1;
|
|
82
|
+
const next = getNextElementIndex(event, activeItemIndex, enabledOptions.length);
|
|
83
|
+
this.activeOption = enabledOptions[next];
|
|
84
|
+
this.activeOption.setActive(true);
|
|
85
|
+
this.triggerElement?.setAttribute("aria-activedescendant", this.activeOption.id);
|
|
86
|
+
this.activeOption.scrollIntoView({ block: "nearest" });
|
|
92
87
|
}
|
|
93
88
|
_setNextHorizontalActiveElement(event) {
|
|
94
|
-
if (this.
|
|
89
|
+
if (!this.activeOption) {
|
|
95
90
|
return;
|
|
96
91
|
}
|
|
97
|
-
const elementsInRow = Array.from(this.
|
|
98
|
-
|
|
99
|
-
if (isNaN(next)) {
|
|
92
|
+
const elementsInRow = Array.from(this.activeOption?.closest("sbb-autocomplete-grid-row")?.querySelectorAll("sbb-autocomplete-grid-option, sbb-autocomplete-grid-button") ?? [])?.filter((el) => !el.disabled && !el.hasAttribute("data-group-disabled"));
|
|
93
|
+
if (!elementsInRow.length) {
|
|
100
94
|
return;
|
|
101
95
|
}
|
|
96
|
+
const next = getNextElementIndex(event, this._activeColumnIndex, elementsInRow.length);
|
|
102
97
|
const nextElement = elementsInRow[next];
|
|
103
98
|
if (nextElement instanceof SbbAutocompleteGridOptionElement) {
|
|
104
99
|
nextElement.setActive(true);
|
|
@@ -117,14 +112,10 @@ let SbbAutocompleteGridElement = (() => {
|
|
|
117
112
|
}
|
|
118
113
|
resetActiveElement() {
|
|
119
114
|
if (this._activeColumnIndex !== 0) {
|
|
120
|
-
this.
|
|
121
|
-
} else {
|
|
122
|
-
const activeElement = this.options.filter((opt) => !opt.disabled && !opt.hasAttribute("data-group-disabled"))[this._activeItemIndex];
|
|
123
|
-
if (activeElement) {
|
|
124
|
-
activeElement.setActive(false);
|
|
125
|
-
}
|
|
115
|
+
this.activeOption?.closest("sbb-autocomplete-grid-row")?.querySelectorAll("sbb-autocomplete-grid-button").forEach((e) => e.toggleAttribute("data-focus-visible", false));
|
|
126
116
|
}
|
|
127
|
-
this.
|
|
117
|
+
this.activeOption?.setActive(false);
|
|
118
|
+
this.activeOption = null;
|
|
128
119
|
this._activeColumnIndex = 0;
|
|
129
120
|
this.triggerElement?.removeAttribute("aria-activedescendant");
|
|
130
121
|
}
|
|
@@ -142,4 +133,4 @@ let SbbAutocompleteGridElement = (() => {
|
|
|
142
133
|
export {
|
|
143
134
|
SbbAutocompleteGridElement
|
|
144
135
|
};
|
|
145
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"autocomplete-grid.component.js","sources":["../../../../../src/elements/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.ts"],"sourcesContent":["import { customElement } from 'lit/decorators.js';\n\nimport { SbbAutocompleteBaseElement } from '../../autocomplete.js';\nimport { getNextElementIndex } from '../../core/a11y.js';\nimport { isSafari } from '../../core/dom.js';\nimport { setAriaComboBoxAttributes } from '../../core/overlay.js';\nimport type { SbbDividerElement } from '../../divider.js';\nimport type { SbbOptGroupElement, SbbOptionHintElement } from '../../option.js';\nimport type { SbbAutocompleteGridButtonElement } from '../autocomplete-grid-button.js';\nimport { SbbAutocompleteGridOptionElement } from '../autocomplete-grid-option.js';\nimport type { SbbAutocompleteGridRowElement } from '../autocomplete-grid-row.js';\n\nlet nextId = 0;\n\n/**\n * On Safari, the aria role 'listbox' must be on the host element, or else VoiceOver won't work at all.\n * On the other hand, JAWS and NVDA need the role to be \"closer\" to the options, or else optgroups won't work.\n */\nconst ariaRoleOnHost = isSafari;\n\n/**\n * Combined with a native input, it displays a panel with a list of available options with connected buttons.\n *\n * @slot - Use the unnamed slot to add `sbb-autocomplete-grid-row` or `sbb-autocomplete-grid-optgroup` elements to the `sbb-autocomplete-grid`.\n * @cssprop [--sbb-autocomplete-z-index=var(--sbb-overlay-default-z-index)] - To specify a custom stack order,\n * the `z-index` can be overridden by defining this CSS variable. The default `z-index` of the\n * component is set to `var(--sbb-overlay-default-z-index)` with a value of `1000`.\n */\nexport\n@customElement('sbb-autocomplete-grid')\nclass SbbAutocompleteGridElement<T = string> extends SbbAutocompleteBaseElement<T> {\n  public static override readonly role = ariaRoleOnHost ? 'grid' : null;\n  protected overlayId = `sbb-autocomplete-grid-${++nextId}`;\n  protected panelRole = 'grid';\n  private _activeItemIndex = -1;\n  private _activeColumnIndex = 0;\n\n  protected get options(): SbbAutocompleteGridOptionElement<T>[] {\n    return Array.from(\n      this.querySelectorAll?.<SbbAutocompleteGridOptionElement<T>>(\n        'sbb-autocomplete-grid-option',\n      ) ?? [],\n    );\n  }\n\n  private get _row(): SbbAutocompleteGridRowElement[] {\n    return (\n      Array.from(this.querySelectorAll?.('sbb-autocomplete-grid-row')).filter(\n        (row) => !row.hasAttribute('data-disabled'),\n      ) ?? []\n    );\n  }\n\n  public constructor() {\n    super();\n    this.addEventListener?.('optionselected', (e: Event) => this.onOptionSelected(e));\n  }\n\n  protected syncNegative(): void {\n    this.querySelectorAll?.<\n      SbbDividerElement | SbbAutocompleteGridButtonElement | SbbOptionHintElement\n    >('sbb-divider, sbb-autocomplete-grid-button, sbb-option-hint').forEach(\n      (e) => (e.negative = this.negative),\n    );\n\n    this.querySelectorAll?.<SbbAutocompleteGridOptionElement<T> | SbbOptGroupElement>(\n      'sbb-autocomplete-grid-row, sbb-autocomplete-grid-option, sbb-autocomplete-grid-optgroup',\n    ).forEach((element) => element.toggleAttribute('data-negative', this.negative));\n  }\n\n  protected openedPanelKeyboardInteraction(event: KeyboardEvent): void {\n    if (this.state !== 'opened') {\n      return;\n    }\n\n    switch (event.key) {\n      case 'Tab':\n        this.close();\n        break;\n\n      case 'Enter':\n        this.selectByKeyboard(event);\n        break;\n\n      case 'ArrowDown':\n      case 'ArrowUp':\n        this.setNextActiveOption(event);\n        break;\n\n      case 'ArrowRight':\n      case 'ArrowLeft':\n        this._setNextHorizontalActiveElement(event);\n        break;\n    }\n  }\n\n  /**\n   * Select an element on 'Enter' keypress.\n   *\n   * Due to keyboard navigation code, the `_activeColumnIndex` is zero when an option is 'focused'\n   * and greater than zero when a button is 'focused', so asking for `querySelectorAll(...)[this._activeColumnIndex]`\n   * would always return a `SbbAutocompleteGridButtonElement`.\n   */\n  protected selectByKeyboard(event: KeyboardEvent): void {\n    event.preventDefault();\n\n    if (this._activeColumnIndex !== 0) {\n      (\n        this._row[this._activeItemIndex].querySelectorAll(\n          'sbb-autocomplete-grid-option, sbb-autocomplete-grid-button',\n        )[this._activeColumnIndex] as SbbAutocompleteGridButtonElement\n      ).click();\n    } else {\n      this.options[this._activeItemIndex]?.['selectViaUserInteraction'](true);\n    }\n  }\n\n  protected setNextActiveOption(event?: KeyboardEvent): void {\n    const filteredOptions = this.options.filter(\n      (opt) => !opt.disabled && !opt.hasAttribute('data-group-disabled'),\n    );\n\n    // Get and activate the next active option\n    const next = getNextElementIndex(event, this._activeItemIndex, filteredOptions.length);\n    if (isNaN(next)) {\n      return;\n    }\n    const nextActiveOption = filteredOptions[next];\n    nextActiveOption.setActive(true);\n    this.triggerElement?.setAttribute('aria-activedescendant', nextActiveOption.id);\n    nextActiveOption.scrollIntoView({ block: 'nearest' });\n\n    // Reset the previous active option/button\n    if (this._activeColumnIndex !== 0) {\n      this._row[this._activeItemIndex]\n        .querySelectorAll('sbb-autocomplete-grid-button')\n        .forEach((e) => e.toggleAttribute('data-focus-visible', false));\n    } else {\n      const lastActiveOption = filteredOptions[this._activeItemIndex];\n      if (lastActiveOption) {\n        lastActiveOption.setActive(false);\n      }\n    }\n    this._activeItemIndex = next;\n    this._activeColumnIndex = 0;\n  }\n\n  private _setNextHorizontalActiveElement(event: KeyboardEvent): void {\n    if (this._activeItemIndex < 0) {\n      return;\n    }\n\n    const elementsInRow: (\n      | SbbAutocompleteGridOptionElement<T>\n      | SbbAutocompleteGridButtonElement\n    )[] = Array.from(\n      this._row[this._activeItemIndex].querySelectorAll<\n        SbbAutocompleteGridOptionElement<T> | SbbAutocompleteGridButtonElement\n      >('sbb-autocomplete-grid-option, sbb-autocomplete-grid-button'),\n    ).filter((el) => !el.disabled && !el.hasAttribute('data-group-disabled'));\n    const next: number = getNextElementIndex(event, this._activeColumnIndex, elementsInRow.length);\n    if (isNaN(next)) {\n      return;\n    }\n    const nextElement: SbbAutocompleteGridOptionElement<T> | SbbAutocompleteGridButtonElement =\n      elementsInRow[next];\n    if (nextElement instanceof SbbAutocompleteGridOptionElement) {\n      nextElement.setActive(true);\n    } else {\n      nextElement.toggleAttribute('data-focus-visible', true);\n    }\n\n    const lastActiveElement:\n      | SbbAutocompleteGridOptionElement<T>\n      | SbbAutocompleteGridButtonElement = elementsInRow[this._activeColumnIndex];\n    if (lastActiveElement instanceof SbbAutocompleteGridOptionElement) {\n      lastActiveElement.setActive(false);\n    } else {\n      lastActiveElement.toggleAttribute('data-focus-visible', false);\n    }\n    this.triggerElement?.setAttribute('aria-activedescendant', nextElement.id);\n    nextElement.scrollIntoView({ block: 'nearest' });\n    this._activeColumnIndex = next;\n  }\n\n  protected resetActiveElement(): void {\n    if (this._activeColumnIndex !== 0) {\n      this._row[this._activeItemIndex]\n        .querySelectorAll('sbb-autocomplete-grid-button')\n        .forEach((e) => e.toggleAttribute('data-focus-visible', false));\n    } else {\n      const activeElement = this.options.filter(\n        (opt) => !opt.disabled && !opt.hasAttribute('data-group-disabled'),\n      )[this._activeItemIndex];\n      if (activeElement) {\n        activeElement.setActive(false);\n      }\n    }\n    this._activeItemIndex = -1;\n    this._activeColumnIndex = 0;\n    this.triggerElement?.removeAttribute('aria-activedescendant');\n  }\n\n  protected setTriggerAttributes(element: HTMLInputElement): void {\n    setAriaComboBoxAttributes(element, ariaRoleOnHost ? this.id : this.overlayId, false, 'grid');\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-autocomplete-grid': SbbAutocompleteGridElement;\n  }\n}\n"],"names":[],"mappings":"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"}
|
|
136
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"autocomplete-grid.component.js","sources":["../../../../../src/elements/autocomplete-grid/autocomplete-grid/autocomplete-grid.component.ts"],"sourcesContent":["import { customElement } from 'lit/decorators.js';\n\nimport { SbbAutocompleteBaseElement } from '../../autocomplete.js';\nimport { getNextElementIndex } from '../../core/a11y.js';\nimport { isSafari } from '../../core/dom.js';\nimport { setAriaComboBoxAttributes } from '../../core/overlay.js';\nimport type { SbbDividerElement } from '../../divider.js';\nimport type { SbbOptGroupElement, SbbOptionHintElement } from '../../option.js';\nimport type { SbbAutocompleteGridButtonElement } from '../autocomplete-grid-button.js';\nimport { SbbAutocompleteGridOptionElement } from '../autocomplete-grid-option.js';\n\nlet nextId = 0;\n\n/**\n * On Safari, the aria role 'listbox' must be on the host element, or else VoiceOver won't work at all.\n * On the other hand, JAWS and NVDA need the role to be \"closer\" to the options, or else optgroups won't work.\n */\nconst ariaRoleOnHost = isSafari;\n\n/**\n * Combined with a native input, it displays a panel with a list of available options with connected buttons.\n *\n * @slot - Use the unnamed slot to add `sbb-autocomplete-grid-row` or `sbb-autocomplete-grid-optgroup` elements to the `sbb-autocomplete-grid`.\n * @cssprop [--sbb-autocomplete-z-index=var(--sbb-overlay-default-z-index)] - To specify a custom stack order,\n * the `z-index` can be overridden by defining this CSS variable. The default `z-index` of the\n * component is set to `var(--sbb-overlay-default-z-index)` with a value of `1000`.\n */\nexport\n@customElement('sbb-autocomplete-grid')\nclass SbbAutocompleteGridElement<T = string> extends SbbAutocompleteBaseElement<T> {\n  public static override readonly role = ariaRoleOnHost ? 'grid' : null;\n  protected overlayId = `sbb-autocomplete-grid-${++nextId}`;\n  protected panelRole = 'grid';\n  private _activeColumnIndex = 0;\n\n  protected get options(): SbbAutocompleteGridOptionElement<T>[] {\n    return Array.from(\n      this.querySelectorAll?.<SbbAutocompleteGridOptionElement<T>>(\n        'sbb-autocomplete-grid-option',\n      ) ?? [],\n    );\n  }\n\n  public constructor() {\n    super();\n    this.addEventListener?.('optionselected', (e: Event) => this.onOptionSelected(e));\n  }\n\n  protected syncNegative(): void {\n    this.querySelectorAll?.<\n      SbbDividerElement | SbbAutocompleteGridButtonElement | SbbOptionHintElement\n    >('sbb-divider, sbb-autocomplete-grid-button, sbb-option-hint').forEach(\n      (e) => (e.negative = this.negative),\n    );\n\n    this.querySelectorAll?.<SbbAutocompleteGridOptionElement<T> | SbbOptGroupElement>(\n      'sbb-autocomplete-grid-row, sbb-autocomplete-grid-option, sbb-autocomplete-grid-optgroup',\n    ).forEach((element) => element.toggleAttribute('data-negative', this.negative));\n  }\n\n  protected openedPanelKeyboardInteraction(event: KeyboardEvent): void {\n    if (this.state !== 'opened') {\n      return;\n    }\n\n    switch (event.key) {\n      case 'Tab':\n        this.close();\n        break;\n\n      case 'Enter':\n        this.selectByKeyboard(event);\n        break;\n\n      case 'ArrowDown':\n      case 'ArrowUp':\n        this.setNextActiveOption(event);\n        break;\n\n      case 'ArrowRight':\n      case 'ArrowLeft':\n        this._setNextHorizontalActiveElement(event);\n        break;\n    }\n  }\n\n  /**\n   * Select an element on 'Enter' keypress.\n   *\n   * Due to keyboard navigation code, the `_activeColumnIndex` is zero when an option is 'focused'\n   * and greater than zero when a button is 'focused', so asking for `querySelectorAll(...)[this._activeColumnIndex]`\n   * would always return a `SbbAutocompleteGridButtonElement`.\n   */\n  protected selectByKeyboard(event: KeyboardEvent): void {\n    event.preventDefault();\n\n    if (this._activeColumnIndex !== 0) {\n      this.activeOption\n        ?.closest('sbb-autocomplete-grid-row')\n        ?.querySelectorAll('sbb-autocomplete-grid-button')\n        [\n          // We ignore the option in the selector. Therefore, we have to shift the activeColumnIndex by one.\n          this._activeColumnIndex - 1\n        ]?.click();\n    } else {\n      this.activeOption?.['selectViaUserInteraction'](true);\n    }\n  }\n\n  protected setNextActiveOption(event?: KeyboardEvent): void {\n    const enabledOptions = this.options.filter(\n      (opt) => !opt.disabled && !opt.hasAttribute('data-group-disabled'),\n    );\n\n    // Reset potentially active option\n    this.activeOption?.setActive(false);\n    this.triggerElement?.removeAttribute('aria-activedescendant');\n    Array.from(\n      this.querySelectorAll?.('sbb-autocomplete-grid-row [data-focus-visible]') ?? [],\n    ).forEach((row) => row.removeAttribute('data-focus-visible'));\n    this._activeColumnIndex = 0;\n\n    if (!enabledOptions.length) {\n      this.activeOption = null;\n      return;\n    }\n\n    const activeItemIndex = this.activeOption\n      ? enabledOptions.indexOf(this.activeOption as SbbAutocompleteGridOptionElement<T>)\n      : -1;\n\n    // Get and activate the next active option\n    const next = getNextElementIndex(event, activeItemIndex, enabledOptions.length);\n    this.activeOption = enabledOptions[next];\n    this.activeOption.setActive(true);\n    this.triggerElement?.setAttribute('aria-activedescendant', this.activeOption.id);\n    this.activeOption.scrollIntoView({ block: 'nearest' });\n  }\n\n  private _setNextHorizontalActiveElement(event: KeyboardEvent): void {\n    if (!this.activeOption) {\n      return;\n    }\n\n    const elementsInRow = Array.from(\n      this.activeOption\n        ?.closest('sbb-autocomplete-grid-row')\n        ?.querySelectorAll<\n          SbbAutocompleteGridOptionElement<T> | SbbAutocompleteGridButtonElement\n        >('sbb-autocomplete-grid-option, sbb-autocomplete-grid-button') ?? [],\n    )?.filter((el) => !el.disabled && !el.hasAttribute('data-group-disabled'));\n\n    if (!elementsInRow.length) {\n      return;\n    }\n\n    const next: number = getNextElementIndex(event, this._activeColumnIndex, elementsInRow.length);\n    const nextElement: SbbAutocompleteGridOptionElement<T> | SbbAutocompleteGridButtonElement =\n      elementsInRow[next];\n    if (nextElement instanceof SbbAutocompleteGridOptionElement) {\n      nextElement.setActive(true);\n    } else {\n      nextElement.toggleAttribute('data-focus-visible', true);\n    }\n\n    const lastActiveElement = elementsInRow[this._activeColumnIndex];\n    if (lastActiveElement instanceof SbbAutocompleteGridOptionElement) {\n      lastActiveElement.setActive(false);\n    } else {\n      lastActiveElement.toggleAttribute('data-focus-visible', false);\n    }\n    this.triggerElement?.setAttribute('aria-activedescendant', nextElement.id);\n    nextElement.scrollIntoView({ block: 'nearest' });\n    this._activeColumnIndex = next;\n  }\n\n  protected resetActiveElement(): void {\n    if (this._activeColumnIndex !== 0) {\n      this.activeOption\n        ?.closest('sbb-autocomplete-grid-row')\n        ?.querySelectorAll('sbb-autocomplete-grid-button')\n        .forEach((e) => e.toggleAttribute('data-focus-visible', false));\n    }\n    this.activeOption?.setActive(false);\n    this.activeOption = null;\n    this._activeColumnIndex = 0;\n    this.triggerElement?.removeAttribute('aria-activedescendant');\n  }\n\n  protected setTriggerAttributes(element: HTMLInputElement): void {\n    setAriaComboBoxAttributes(element, ariaRoleOnHost ? this.id : this.overlayId, false, 'grid');\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-autocomplete-grid': SbbAutocompleteGridElement;\n  }\n}\n"],"names":[],"mappings":"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"}
|
|
@@ -1,10 +1,13 @@
|
|
|
1
1
|
import { CSSResultGroup, LitElement, PropertyValues, TemplateResult } from 'lit';
|
|
2
2
|
export interface Day<T = Date> {
|
|
3
|
+
/** Date as ISO string. */
|
|
3
4
|
value: string;
|
|
4
5
|
dayValue: string;
|
|
5
6
|
monthValue: string;
|
|
6
7
|
yearValue: string;
|
|
7
8
|
dateValue?: T;
|
|
9
|
+
weekValue?: number;
|
|
10
|
+
weekDayValue?: number;
|
|
8
11
|
}
|
|
9
12
|
export interface Month {
|
|
10
13
|
value: string;
|
|
@@ -18,7 +21,7 @@ export interface Weekday {
|
|
|
18
21
|
export type CalendarView = 'day' | 'month' | 'year';
|
|
19
22
|
declare const SbbCalendarElement_base: import('../core/mixins.js').AbstractConstructor<import('../core/mixins.js').SbbHydrationMixinType> & typeof LitElement;
|
|
20
23
|
/**
|
|
21
|
-
* It displays a calendar which allows
|
|
24
|
+
* It displays a calendar which allows choosing a date.
|
|
22
25
|
*/
|
|
23
26
|
export declare class SbbCalendarElement<T = Date> extends SbbCalendarElement_base {
|
|
24
27
|
static styles: CSSResultGroup;
|
|
@@ -39,19 +42,23 @@ export declare class SbbCalendarElement<T = Date> extends SbbCalendarElement_bas
|
|
|
39
42
|
* Accepts an ISO8601 formatted string (e.g. 2024-12-24) as attribute.
|
|
40
43
|
*/
|
|
41
44
|
accessor max: T | null;
|
|
42
|
-
/**
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
45
|
+
/** Whether the calendar allows for multiple date selection. */
|
|
46
|
+
accessor multiple: boolean;
|
|
47
|
+
/**
|
|
48
|
+
* The selected date: accepts a date object, or, if `multiple`, an array of dates.
|
|
49
|
+
*/
|
|
50
|
+
set selected(value: T | T[] | null);
|
|
51
|
+
get selected(): T | T[] | null;
|
|
52
|
+
private accessor _selected;
|
|
46
53
|
/** A function used to filter out dates. */
|
|
47
54
|
accessor dateFilter: ((date: T | null) => boolean) | null;
|
|
48
55
|
/** The orientation of days in the calendar. */
|
|
49
56
|
accessor orientation: 'horizontal' | 'vertical';
|
|
57
|
+
/** Whether it has to display the week numbers in addition to week days. */
|
|
58
|
+
accessor weekNumbers: boolean;
|
|
50
59
|
private _dateAdapter;
|
|
51
60
|
/** The currently active date. */
|
|
52
61
|
private accessor _activeDate;
|
|
53
|
-
/** The selected date as ISOString. */
|
|
54
|
-
private accessor _selected;
|
|
55
62
|
/** The current wide property considering property value and breakpoints. From zero to small `wide` has always to be false. */
|
|
56
63
|
private set _wide(value);
|
|
57
64
|
private get _wide();
|
|
@@ -73,6 +80,10 @@ export declare class SbbCalendarElement<T = Date> extends SbbCalendarElement_bas
|
|
|
73
80
|
private _nextMonthWeeks;
|
|
74
81
|
/** An array containing all the month names in the current language. */
|
|
75
82
|
private _monthNames;
|
|
83
|
+
/** An array containing the weeks' numbers for the current month. */
|
|
84
|
+
private _weekNumbers;
|
|
85
|
+
/** An array containing the weeks' numbers for the next month in wide mode. */
|
|
86
|
+
private _nextMonthWeekNumbers;
|
|
76
87
|
/** A list of buttons corresponding to days, months or years depending on the view. */
|
|
77
88
|
private get _cells();
|
|
78
89
|
/** The chosen year in the year selection view. */
|
|
@@ -93,13 +104,31 @@ export declare class SbbCalendarElement<T = Date> extends SbbCalendarElement_bas
|
|
|
93
104
|
focus(): void;
|
|
94
105
|
protected willUpdate(changedProperties: PropertyValues<this>): void;
|
|
95
106
|
protected updated(changedProperties: PropertyValues<this>): void;
|
|
107
|
+
/**
|
|
108
|
+
* The `_selected` state should be adapted when the `multiple` property changes:
|
|
109
|
+
* - if it changes to true, the '_selected' is set to an array;
|
|
110
|
+
* - if it changes to false, the first available option is set as 'value' otherwise it's set to null.
|
|
111
|
+
*/
|
|
112
|
+
private _onMultipleChanged;
|
|
96
113
|
/** Initializes the component. */
|
|
97
114
|
private _init;
|
|
98
115
|
/** Focuses on a day cell prioritizing the selected day, the current day, and lastly, the first selectable day. */
|
|
99
116
|
private _focusCell;
|
|
100
117
|
/** Creates the array of weekdays. */
|
|
101
118
|
private _setWeekdays;
|
|
102
|
-
/**
|
|
119
|
+
/**
|
|
120
|
+
* Given a date, it returns the week numbers for the month the date belongs to.
|
|
121
|
+
* TODO: check if date-fns can be replaced with custom logic.
|
|
122
|
+
*
|
|
123
|
+
* Since the calculation is not simple (see https://en.wikipedia.org/wiki/Week#Numbering),
|
|
124
|
+
* the date-fns library has been used this way:
|
|
125
|
+
* the first and the last day of the month are calculated and then passed to the `eachWeekOfInterval` function,
|
|
126
|
+
* which returns an array containing the starting day of every ISO week of the month,
|
|
127
|
+
* considering Monday as the first day.
|
|
128
|
+
* Then, this array is mapped via the `getWeek` function, which returns the ISO week number for that date.
|
|
129
|
+
*/
|
|
130
|
+
private _createWeekNumbers;
|
|
131
|
+
/** Creates the rows along the horizontal direction and sets the parameters used in keyboard navigation. */
|
|
103
132
|
private _createWeekRows;
|
|
104
133
|
/**
|
|
105
134
|
* Creates the rows for each week in orientation='horizontal'.
|
|
@@ -150,6 +179,23 @@ export declare class SbbCalendarElement<T = Date> extends SbbCalendarElement_bas
|
|
|
150
179
|
private _isYearFilteredOut;
|
|
151
180
|
/** Emits the selected date and sets it internally. */
|
|
152
181
|
private _selectDate;
|
|
182
|
+
/**
|
|
183
|
+
* Handle multiple dates selection via weekNumber / weekDay buttons:
|
|
184
|
+
* - if Cmd or Ctrl are pressed, add the new date to the current ones;
|
|
185
|
+
* - if not,
|
|
186
|
+
* - if the new dates are the same of the current ones, it means that the same button has been clicked twice, so do nothing;
|
|
187
|
+
* - if not, the selected dates are the new ones.
|
|
188
|
+
*/
|
|
189
|
+
private _selectMultipleDates;
|
|
190
|
+
/**
|
|
191
|
+
* Emits the dateselected event given the detail (as T or T[] based on the value of the multiple flag).
|
|
192
|
+
*/
|
|
193
|
+
private _emitDateSelectedEvent;
|
|
194
|
+
/**
|
|
195
|
+
* In case of multiple selection, newly added days must be added to the existing ones, without duplication.
|
|
196
|
+
* If the days to add are exactly the same as the selected ones, the set must be emptied.
|
|
197
|
+
*/
|
|
198
|
+
private _updateSelectedWithMultipleDates;
|
|
153
199
|
private _setChosenYear;
|
|
154
200
|
private _assignActiveDate;
|
|
155
201
|
/** Goes to the month identified by the shift. */
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"calendar.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/calendar/calendar.component.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"calendar.component.d.ts","sourceRoot":"","sources":["../../../../src/elements/calendar/calendar.component.ts"],"names":[],"mappings":"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"}
|