@sbb-esta/lyne-elements 3.8.0 → 3.10.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (81) hide show
  1. package/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.component.js +1 -1
  2. package/autocomplete-grid/autocomplete-grid-row/autocomplete-grid-row.component.js +1 -1
  3. package/calendar/calendar.component.d.ts.map +1 -1
  4. package/calendar/calendar.component.js +211 -225
  5. package/carousel/carousel/carousel.component.d.ts.map +1 -1
  6. package/carousel/carousel/carousel.component.js +5 -5
  7. package/core/base-elements/open-close-base-element.d.ts +2 -0
  8. package/core/base-elements/open-close-base-element.d.ts.map +1 -1
  9. package/core/base-elements/open-close-base-element.js +4 -0
  10. package/core/controllers/escapable-overlay-controller.js +3 -3
  11. package/core/controllers/inert-controller.d.ts +8 -1
  12. package/core/controllers/inert-controller.d.ts.map +1 -1
  13. package/core/controllers/inert-controller.js +25 -13
  14. package/core/overlay/position.d.ts +20 -0
  15. package/core/overlay/position.d.ts.map +1 -1
  16. package/core/overlay/position.js +34 -23
  17. package/core/overlay.js +11 -10
  18. package/core/styles/core.scss +7 -0
  19. package/core.css +6 -0
  20. package/custom-elements.json +1152 -661
  21. package/development/autocomplete-grid/autocomplete-grid-option/autocomplete-grid-option.component.js +7 -1
  22. package/development/autocomplete-grid/autocomplete-grid-row/autocomplete-grid-row.component.js +2 -1
  23. package/development/calendar/calendar.component.d.ts.map +1 -1
  24. package/development/calendar/calendar.component.js +20 -36
  25. package/development/carousel/carousel/carousel.component.d.ts.map +1 -1
  26. package/development/carousel/carousel/carousel.component.js +2 -2
  27. package/development/core/base-elements/open-close-base-element.d.ts +2 -0
  28. package/development/core/base-elements/open-close-base-element.d.ts.map +1 -1
  29. package/development/core/base-elements/open-close-base-element.js +5 -1
  30. package/development/core/controllers/escapable-overlay-controller.js +2 -2
  31. package/development/core/controllers/inert-controller.d.ts +8 -1
  32. package/development/core/controllers/inert-controller.d.ts.map +1 -1
  33. package/development/core/controllers/inert-controller.js +49 -30
  34. package/development/core/overlay/position.d.ts +20 -0
  35. package/development/core/overlay/position.d.ts.map +1 -1
  36. package/development/core/overlay/position.js +41 -1
  37. package/development/core/overlay.js +2 -1
  38. package/development/menu/common/menu-action-common.d.ts.map +1 -1
  39. package/development/menu/common/menu-action-common.js +20 -3
  40. package/development/menu/menu/menu.component.d.ts +21 -10
  41. package/development/menu/menu/menu.component.d.ts.map +1 -1
  42. package/development/menu/menu/menu.component.js +203 -61
  43. package/development/option/option/option.component.js +4 -2
  44. package/development/paginator/common/paginator-common.d.ts.map +1 -1
  45. package/development/paginator/common/paginator-common.js +14 -3
  46. package/development/tabs/tab/tab.component.d.ts +10 -4
  47. package/development/tabs/tab/tab.component.d.ts.map +1 -1
  48. package/development/tabs/tab/tab.component.js +15 -16
  49. package/development/tabs/tab-group/tab-group.component.d.ts +15 -14
  50. package/development/tabs/tab-group/tab-group.component.d.ts.map +1 -1
  51. package/development/tabs/tab-group/tab-group.component.js +46 -175
  52. package/development/tabs/tab-label/tab-label.component.d.ts +21 -2
  53. package/development/tabs/tab-label/tab-label.component.d.ts.map +1 -1
  54. package/development/tabs/tab-label/tab-label.component.js +91 -6
  55. package/development/tooltip/tooltip.component.d.ts +6 -6
  56. package/development/tooltip/tooltip.component.d.ts.map +1 -1
  57. package/development/tooltip/tooltip.component.js +14 -7
  58. package/menu/common/menu-action-common.d.ts.map +1 -1
  59. package/menu/common/menu-action-common.js +15 -12
  60. package/menu/menu/menu.component.d.ts +21 -10
  61. package/menu/menu/menu.component.d.ts.map +1 -1
  62. package/menu/menu/menu.component.js +144 -80
  63. package/off-brand-theme.css +6 -0
  64. package/option/option/option.component.js +1 -1
  65. package/package.json +1 -1
  66. package/paginator/common/paginator-common.d.ts.map +1 -1
  67. package/paginator/common/paginator-common.js +30 -25
  68. package/safety-theme.css +6 -0
  69. package/standard-theme.css +6 -0
  70. package/tabs/tab/tab.component.d.ts +10 -4
  71. package/tabs/tab/tab.component.d.ts.map +1 -1
  72. package/tabs/tab/tab.component.js +22 -24
  73. package/tabs/tab-group/tab-group.component.d.ts +15 -14
  74. package/tabs/tab-group/tab-group.component.d.ts.map +1 -1
  75. package/tabs/tab-group/tab-group.component.js +68 -122
  76. package/tabs/tab-label/tab-label.component.d.ts +21 -2
  77. package/tabs/tab-label/tab-label.component.d.ts.map +1 -1
  78. package/tabs/tab-label/tab-label.component.js +88 -46
  79. package/tooltip/tooltip.component.d.ts +6 -6
  80. package/tooltip/tooltip.component.d.ts.map +1 -1
  81. package/tooltip/tooltip.component.js +59 -54
@@ -148,7 +148,9 @@ const style = css`*,
148
148
  }
149
149
 
150
150
  .sbb-option__label {
151
- white-space: initial;
151
+ text-overflow: var(--sbb-option-text-overflow);
152
+ overflow: var(--sbb-option-overflow);
153
+ white-space: var(--sbb-option-white-space, initial);
152
154
  }`;
153
155
  let SbbOptionElement = (() => {
154
156
  var _a;
@@ -260,4 +262,4 @@ let SbbOptionElement = (() => {
260
262
  export {
261
263
  SbbOptionElement
262
264
  };
263
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"option.component.js","sources":["../../../../../src/elements/option/option/option.component.ts"],"sourcesContent":["import type { CSSResultGroup, TemplateResult } from 'lit';\nimport { html, nothing } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\nimport { SbbOptionBaseElement } from './option-base-element.js';\nimport style from './option.scss?lit&inline';\nimport '../../visual-checkbox.js';\n\nexport type SbbOptionVariant = 'autocomplete' | 'select' | null;\n\n/**\n * It displays on option item which can be used in `sbb-select` or `sbb-autocomplete`.\n *\n * @slot - Use the unnamed slot to add content to the option label.\n * @slot icon - Use this slot to provide an icon. If `icon-name` is set, a sbb-icon will be used.\n * @cssprop [--sbb-option-icon-container-display=none] - Can be used to reserve space even\n * when preserve-icon-space on autocomplete is not set or iconName is not set.\n * @overrideType value - (T = string) | null\n */\nexport\n@customElement('sbb-option')\nclass SbbOptionElement<T = string> extends SbbOptionBaseElement<T> {\n  public static override readonly role = 'option';\n  public static override styles: CSSResultGroup = style;\n  public static override readonly events = {\n    optionselectionchange: 'optionselectionchange',\n    optionselected: 'optionselected',\n  } as const;\n\n  protected optionId = `sbb-option`;\n\n  private set _variant(state: SbbOptionVariant) {\n    if (state) {\n      this.setAttribute('data-variant', state);\n    }\n  }\n  private get _variant(): SbbOptionVariant {\n    return this.getAttribute('data-variant') as SbbOptionVariant;\n  }\n\n  private set _isMultiple(isMultiple: boolean) {\n    this.toggleAttribute('data-multiple', isMultiple);\n  }\n  private get _isMultiple(): boolean {\n    return !this.hydrationRequired && this.hasAttribute('data-multiple');\n  }\n\n  protected setAttributeFromParent(): void {\n    const parentGroup = this.closest?.('sbb-optgroup');\n    if (parentGroup) {\n      this.disabledFromGroup = parentGroup.disabled;\n      this.updateAriaDisabled();\n    }\n\n    this.negative = !!this.closest?.(\n      // :is() selector not possible due to test environment\n      `sbb-autocomplete[negative],sbb-form-field[negative]`,\n    );\n    this.toggleAttribute('data-negative', this.negative);\n\n    this.toggleAttribute('data-multiple', this._isMultiple);\n  }\n\n  protected selectByClick(event: MouseEvent): void {\n    if (this.disabled || this.disabledFromGroup) {\n      event.stopPropagation();\n      return;\n    }\n\n    if (this._isMultiple) {\n      event.stopPropagation();\n      this.selectViaUserInteraction(!this.selected);\n    } else {\n      this.selectViaUserInteraction(true);\n    }\n  }\n\n  protected override selectViaUserInteraction(selected: boolean): void {\n    super.selectViaUserInteraction(selected);\n    /** The optionselectionchange event is dispatched when the option selection status changes. */\n    this.dispatchEvent(new Event('optionselectionchange', { bubbles: true, composed: true }));\n  }\n\n  protected override init(): void {\n    super.init();\n    this._setVariantByContext();\n    // We need to check highlight state both on slot change, but also when connecting\n    // the element to the DOM. The slot change events might be swallowed when using declarative\n    // shadow DOM with SSR or if the DOM is changed when disconnected.\n    this.handleHighlightState();\n  }\n\n  private _setVariantByContext(): void {\n    if (this.closest?.('sbb-autocomplete')) {\n      this._variant = 'autocomplete';\n    } else if (this.closest?.('sbb-select')) {\n      this._variant = 'select';\n    }\n    this._isMultiple = !!this.closest?.('sbb-select[multiple]');\n  }\n\n  protected override handleHighlightState(): void {\n    if (this._variant !== 'autocomplete') {\n      this.updateDisableHighlight(true);\n      return;\n    }\n\n    super.handleHighlightState();\n  }\n\n  protected override renderIcon(): TemplateResult {\n    return html`\n      <!-- Icon -->\n      ${!this._isMultiple\n        ? html` <span class=\"sbb-option__icon\"> ${this.renderIconSlot()} </span>`\n        : nothing}\n\n      <!-- Checkbox -->\n      ${this._isMultiple\n        ? html`\n            <sbb-visual-checkbox\n              ?checked=${this.selected}\n              ?disabled=${this.disabled || this.disabledFromGroup}\n              ?negative=${this.negative}\n            ></sbb-visual-checkbox>\n          `\n        : nothing}\n    `;\n  }\n\n  protected override renderLabel(): TemplateResult | typeof nothing {\n    return this._variant === 'autocomplete' && this.label && !this.disableLabelHighlight\n      ? this.getHighlightedLabel()\n      : nothing;\n  }\n\n  protected override renderTick(): TemplateResult | typeof nothing {\n    return this._variant === 'select' && !this._isMultiple && this.selected\n      ? html`<sbb-icon name=\"tick-small\"></sbb-icon>`\n      : nothing;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-option': SbbOptionElement;\n  }\n\n  interface GlobalEventHandlersEventMap {\n    optionselectionchange: Event;\n  }\n}\n"],"names":[],"mappings":"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"}
265
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"option.component.js","sources":["../../../../../src/elements/option/option/option.component.ts"],"sourcesContent":["import type { CSSResultGroup, TemplateResult } from 'lit';\nimport { html, nothing } from 'lit';\nimport { customElement } from 'lit/decorators.js';\n\nimport { SbbOptionBaseElement } from './option-base-element.js';\nimport style from './option.scss?lit&inline';\nimport '../../visual-checkbox.js';\n\nexport type SbbOptionVariant = 'autocomplete' | 'select' | null;\n\n/**\n * It displays on option item which can be used in `sbb-select` or `sbb-autocomplete`.\n *\n * @slot - Use the unnamed slot to add content to the option label.\n * @slot icon - Use this slot to provide an icon. If `icon-name` is set, a sbb-icon will be used.\n * @cssprop [--sbb-option-icon-container-display=none] - Can be used to reserve space even\n * when preserve-icon-space on autocomplete is not set or iconName is not set.\n * @overrideType value - (T = string) | null\n */\nexport\n@customElement('sbb-option')\nclass SbbOptionElement<T = string> extends SbbOptionBaseElement<T> {\n  public static override readonly role = 'option';\n  public static override styles: CSSResultGroup = style;\n  public static override readonly events = {\n    optionselectionchange: 'optionselectionchange',\n    optionselected: 'optionselected',\n  } as const;\n\n  protected optionId = `sbb-option`;\n\n  private set _variant(state: SbbOptionVariant) {\n    if (state) {\n      this.setAttribute('data-variant', state);\n    }\n  }\n  private get _variant(): SbbOptionVariant {\n    return this.getAttribute('data-variant') as SbbOptionVariant;\n  }\n\n  private set _isMultiple(isMultiple: boolean) {\n    this.toggleAttribute('data-multiple', isMultiple);\n  }\n  private get _isMultiple(): boolean {\n    return !this.hydrationRequired && this.hasAttribute('data-multiple');\n  }\n\n  protected setAttributeFromParent(): void {\n    const parentGroup = this.closest?.('sbb-optgroup');\n    if (parentGroup) {\n      this.disabledFromGroup = parentGroup.disabled;\n      this.updateAriaDisabled();\n    }\n\n    this.negative = !!this.closest?.(\n      // :is() selector not possible due to test environment\n      `sbb-autocomplete[negative],sbb-form-field[negative]`,\n    );\n    this.toggleAttribute('data-negative', this.negative);\n\n    this.toggleAttribute('data-multiple', this._isMultiple);\n  }\n\n  protected selectByClick(event: MouseEvent): void {\n    if (this.disabled || this.disabledFromGroup) {\n      event.stopPropagation();\n      return;\n    }\n\n    if (this._isMultiple) {\n      event.stopPropagation();\n      this.selectViaUserInteraction(!this.selected);\n    } else {\n      this.selectViaUserInteraction(true);\n    }\n  }\n\n  protected override selectViaUserInteraction(selected: boolean): void {\n    super.selectViaUserInteraction(selected);\n    /** The optionselectionchange event is dispatched when the option selection status changes. */\n    this.dispatchEvent(new Event('optionselectionchange', { bubbles: true, composed: true }));\n  }\n\n  protected override init(): void {\n    super.init();\n    this._setVariantByContext();\n    // We need to check highlight state both on slot change, but also when connecting\n    // the element to the DOM. The slot change events might be swallowed when using declarative\n    // shadow DOM with SSR or if the DOM is changed when disconnected.\n    this.handleHighlightState();\n  }\n\n  private _setVariantByContext(): void {\n    if (this.closest?.('sbb-autocomplete')) {\n      this._variant = 'autocomplete';\n    } else if (this.closest?.('sbb-select')) {\n      this._variant = 'select';\n    }\n    this._isMultiple = !!this.closest?.('sbb-select[multiple]');\n  }\n\n  protected override handleHighlightState(): void {\n    if (this._variant !== 'autocomplete') {\n      this.updateDisableHighlight(true);\n      return;\n    }\n\n    super.handleHighlightState();\n  }\n\n  protected override renderIcon(): TemplateResult {\n    return html`\n      <!-- Icon -->\n      ${!this._isMultiple\n        ? html` <span class=\"sbb-option__icon\"> ${this.renderIconSlot()} </span>`\n        : nothing}\n\n      <!-- Checkbox -->\n      ${this._isMultiple\n        ? html`\n            <sbb-visual-checkbox\n              ?checked=${this.selected}\n              ?disabled=${this.disabled || this.disabledFromGroup}\n              ?negative=${this.negative}\n            ></sbb-visual-checkbox>\n          `\n        : nothing}\n    `;\n  }\n\n  protected override renderLabel(): TemplateResult | typeof nothing {\n    return this._variant === 'autocomplete' && this.label && !this.disableLabelHighlight\n      ? this.getHighlightedLabel()\n      : nothing;\n  }\n\n  protected override renderTick(): TemplateResult | typeof nothing {\n    return this._variant === 'select' && !this._isMultiple && this.selected\n      ? html`<sbb-icon name=\"tick-small\"></sbb-icon>`\n      : nothing;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-option': SbbOptionElement;\n  }\n\n  interface GlobalEventHandlersEventMap {\n    optionselectionchange: Event;\n  }\n}\n"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"paginator-common.d.ts","sourceRoot":"","sources":["../../../../../src/elements/paginator/common/paginator-common.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,KAAK,UAAU,EAAuB,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAGtF,OAAO,EAAE,qBAAqB,EAAE,MAAM,2BAA2B,CAAC;AASlE,OAAO,KAAK,EAAE,4BAA4B,EAAE,MAAM,0BAA0B,CAAC;AAC7E,OAAO,EACL,KAAK,mBAAmB,EAIzB,MAAM,sBAAsB,CAAC;AAE9B,OAAO,6BAA6B,CAAC;AACrC,OAAO,mCAAmC,CAAC;AAC3C,OAAO,kBAAkB,CAAC;;AAE1B,MAAM,CAAC,OAAO,CAAC,QAAQ,OAAO,kCAAmC,SAAQ,uCAExE;IACC,SAAgB,MAAM,EAAE,MAAM,CAAC;IAC/B,SAAgB,QAAQ,EAAE,MAAM,CAAC;IACjC,SAAgB,SAAS,EAAE,MAAM,CAAC;IAClC,SAAgB,aAAa,EAAE,OAAO,GAAG,KAAK,CAAC;IAC/C,SAAgB,IAAI,EAAE,GAAG,GAAG,GAAG,CAAC;IAChC,SAAgB,sBAAsB,EAAE,MAAM,CAAC;IAC/C,SAAgB,8BAA8B,EAAE,MAAM,CAAC;IACvD,SAAgB,0BAA0B,EAAE,MAAM,CAAC;IAC5C,QAAQ,IAAI,IAAI;IAChB,YAAY,IAAI,IAAI;IACpB,SAAS,IAAI,IAAI;IACjB,QAAQ,IAAI,IAAI;IAChB,UAAU,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAC/B,eAAe,IAAI,OAAO;IAC1B,WAAW,IAAI,OAAO;IACtB,aAAa,IAAI,MAAM;IAC9B,SAAS,CAAC,QAAQ,EAAE,qBAAqB,CAAC;IAC1C,SAAS,CAAC,aAAa,CAAC,iBAAiB,EAAE,MAAM,GAAG,IAAI;IACxD,SAAS,CAAC,qBAAqB,IAAI,cAAc;IACjD,SAAS,CAAC,QAAQ,CAAC,eAAe,IAAI,cAAc;CACrD;AAGD,eAAO,MAAM,8BAA8B,GAAI,CAAC,SAAS,mBAAmB,CAAC,UAAU,CAAC,EACtF,YAAY,CAAC,KACZ,mBAAmB,CAAC,kCAAkC,CAAC,GAAG,CA4N5D,CAAC;AAEF,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,mBAAmB;QAC3B,IAAI,EAAE,WAAW,CAAC,4BAA4B,CAAC,CAAC;KACjD;CACF"}
1
+ {"version":3,"file":"paginator-common.d.ts","sourceRoot":"","sources":["../../../../../src/elements/paginator/common/paginator-common.ts"],"names":[],"mappings":"AAAA,OAAO,EAAQ,KAAK,UAAU,EAAuB,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAItF,OAAO,EAAE,qBAAqB,EAAE,MAAM,2BAA2B,CAAC;AASlE,OAAO,KAAK,EAAE,4BAA4B,EAAE,MAAM,0BAA0B,CAAC;AAC7E,OAAO,EACL,KAAK,mBAAmB,EAIzB,MAAM,sBAAsB,CAAC;AAE9B,OAAO,6BAA6B,CAAC;AACrC,OAAO,mCAAmC,CAAC;AAC3C,OAAO,kBAAkB,CAAC;;AAE1B,MAAM,CAAC,OAAO,CAAC,QAAQ,OAAO,kCAAmC,SAAQ,uCAExE;IACC,SAAgB,MAAM,EAAE,MAAM,CAAC;IAC/B,SAAgB,QAAQ,EAAE,MAAM,CAAC;IACjC,SAAgB,SAAS,EAAE,MAAM,CAAC;IAClC,SAAgB,aAAa,EAAE,OAAO,GAAG,KAAK,CAAC;IAC/C,SAAgB,IAAI,EAAE,GAAG,GAAG,GAAG,CAAC;IAChC,SAAgB,sBAAsB,EAAE,MAAM,CAAC;IAC/C,SAAgB,8BAA8B,EAAE,MAAM,CAAC;IACvD,SAAgB,0BAA0B,EAAE,MAAM,CAAC;IAC5C,QAAQ,IAAI,IAAI;IAChB,YAAY,IAAI,IAAI;IACpB,SAAS,IAAI,IAAI;IACjB,QAAQ,IAAI,IAAI;IAChB,UAAU,CAAC,KAAK,EAAE,MAAM,GAAG,IAAI;IAC/B,eAAe,IAAI,OAAO;IAC1B,WAAW,IAAI,OAAO;IACtB,aAAa,IAAI,MAAM;IAC9B,SAAS,CAAC,QAAQ,EAAE,qBAAqB,CAAC;IAC1C,SAAS,CAAC,aAAa,CAAC,iBAAiB,EAAE,MAAM,GAAG,IAAI;IACxD,SAAS,CAAC,qBAAqB,IAAI,cAAc;IACjD,SAAS,CAAC,QAAQ,CAAC,eAAe,IAAI,cAAc;CACrD;AAGD,eAAO,MAAM,8BAA8B,GAAI,CAAC,SAAS,mBAAmB,CAAC,UAAU,CAAC,EACtF,YAAY,CAAC,KACZ,mBAAmB,CAAC,kCAAkC,CAAC,GAAG,CA4O5D,CAAC;AAEF,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,mBAAmB;QAC3B,IAAI,EAAE,WAAW,CAAC,4BAA4B,CAAC,CAAC;KACjD;CACF"}
@@ -8,6 +8,7 @@ var __privateSet = (obj, member, value, setter) => (__accessCheck(obj, member, "
8
8
  import { __runInitializers, __esDecorate } from "tslib";
9
9
  import { html } from "lit";
10
10
  import { property } from "lit/decorators.js";
11
+ import { sbbInputModalityDetector } from "../../core/a11y/input-modality-detector.js";
11
12
  import { SbbLanguageController } from "../../core/controllers.js";
12
13
  import { forceType } from "../../core/decorators.js";
13
14
  import { isLean } from "../../core/dom.js";
@@ -202,7 +203,12 @@ const SbbPaginatorCommonElementMixin = (superClass) => {
202
203
  aria-label=${this.accessibilityPreviousPageLabel ? this.accessibilityPreviousPageLabel : i18nPreviousPage[this.language.current]}
203
204
  icon-name="chevron-small-left-small"
204
205
  ?disabled=${this.disabled || !this.hasPreviousPage()}
205
- @click=${() => this.previousPage()}
206
+ @click=${() => {
207
+ this.previousPage();
208
+ if (!this.hasPreviousPage() && sbbInputModalityDetector.mostRecentModality === "keyboard") {
209
+ this.shadowRoot?.getElementById("sbb-paginator-next-page").focus();
210
+ }
211
+ }}
206
212
  ></sbb-mini-button>
207
213
  <sbb-divider orientation="vertical"></sbb-divider>
208
214
  <sbb-mini-button
@@ -210,7 +216,12 @@ const SbbPaginatorCommonElementMixin = (superClass) => {
210
216
  aria-label=${this.accessibilityNextPageLabel ? this.accessibilityNextPageLabel : i18nNextPage[this.language.current]}
211
217
  icon-name="chevron-small-right-small"
212
218
  ?disabled=${this.disabled || !this.hasNextPage()}
213
- @click=${() => this.nextPage()}
219
+ @click=${() => {
220
+ this.nextPage();
221
+ if (!this.hasNextPage() && sbbInputModalityDetector.mostRecentModality === "keyboard") {
222
+ this.shadowRoot?.getElementById("sbb-paginator-prev-page").focus();
223
+ }
224
+ }}
214
225
  ></sbb-mini-button>
215
226
  </sbb-mini-button-group>
216
227
  `;
@@ -265,4 +276,4 @@ const SbbPaginatorCommonElementMixin = (superClass) => {
265
276
  export {
266
277
  SbbPaginatorCommonElementMixin
267
278
  };
268
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"paginator-common.js","sources":["../../../../../src/elements/paginator/common/paginator-common.ts"],"sourcesContent":["import { html, type LitElement, type PropertyValues, type TemplateResult } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { SbbLanguageController } from '../../core/controllers.js';\nimport { forceType } from '../../core/decorators.js';\nimport { isLean } from '../../core/dom.js';\nimport {\n  i18nNextPage,\n  i18nPage,\n  i18nPaginatorSelected,\n  i18nPreviousPage,\n} from '../../core/i18n.js';\nimport type { SbbPaginatorPageEventDetails } from '../../core/interfaces.js';\nimport {\n  type AbstractConstructor,\n  SbbDisabledMixin,\n  SbbElementInternalsMixin,\n  SbbNegativeMixin,\n} from '../../core/mixins.js';\n\nimport '../../button/mini-button.js';\nimport '../../button/mini-button-group.js';\nimport '../../divider.js';\n\nexport declare abstract class SbbPaginatorCommonElementMixinType extends SbbNegativeMixin(\n  SbbDisabledMixin(SbbElementInternalsMixin(LitElement)),\n) {\n  public accessor length: number;\n  public accessor pageSize: number;\n  public accessor pageIndex: number;\n  public accessor pagerPosition: 'start' | 'end';\n  public accessor size: 'm' | 's';\n  public accessor accessibilityPageLabel: string;\n  public accessor accessibilityPreviousPageLabel: string;\n  public accessor accessibilityNextPageLabel: string;\n  public nextPage(): void;\n  public previousPage(): void;\n  public firstPage(): void;\n  public lastPage(): void;\n  public selectPage(index: number): void;\n  public hasPreviousPage(): boolean;\n  public hasNextPage(): boolean;\n  public numberOfPages(): number;\n  protected language: SbbLanguageController;\n  protected emitPageEvent(previousPageIndex: number): void;\n  protected renderPrevNextButtons(): TemplateResult;\n  protected abstract renderPaginator(): TemplateResult;\n}\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbPaginatorCommonElementMixin = <T extends AbstractConstructor<LitElement>>(\n  superClass: T,\n): AbstractConstructor<SbbPaginatorCommonElementMixinType> & T => {\n  abstract class SbbPaginatorCommonElement\n    extends SbbNegativeMixin(SbbDisabledMixin(SbbElementInternalsMixin(superClass)))\n    implements Partial<SbbPaginatorCommonElementMixinType>\n  {\n    public static override role = 'group';\n    public static readonly events: Record<string, string> = {\n      page: 'page',\n    } as const;\n\n    /** Total number of items. */\n    @property({ type: Number })\n    public set length(value: number) {\n      this._length = isNaN(value) || value < 0 ? 0 : value;\n      // Call setter of pageIndex to ensure bounds\n      // eslint-disable-next-line no-self-assign\n      this.pageIndex = this.pageIndex;\n    }\n    public get length(): number {\n      return this._length;\n    }\n    private _length: number = 0;\n\n    /** Number of items per page. */\n    @property({ attribute: 'page-size', type: Number })\n    public set pageSize(value: number) {\n      // Current page needs to be updated to reflect the new page size. Navigate to the page\n      // containing the previous page's first item.\n      this._previousPageSize = this.pageSize;\n      this._pageSize = Math.max(value, 0);\n      this.pageIndex = Math.floor((this.pageIndex * this._previousPageSize) / this.pageSize) || 0;\n    }\n    public get pageSize(): number {\n      return this._pageSize;\n    }\n    private _pageSize: number = 10;\n\n    /** Current page index. */\n    @property({ attribute: 'page-index', type: Number })\n    public set pageIndex(value: number) {\n      const previousPageIndex = this._pageIndex;\n      this._pageIndex = this._coercePageIndexInRange(value);\n      this.emitPageEvent(previousPageIndex);\n    }\n    public get pageIndex(): number {\n      return this._pageIndex;\n    }\n    private _pageIndex: number = 0;\n\n    /** Position of the prev/next buttons. */\n    @property({ attribute: 'pager-position', reflect: true }) public accessor pagerPosition:\n      | 'start'\n      | 'end' = 'start';\n\n    /**\n     * Size variant, either m or s.\n     * @default 'm' / 's' (lean)\n     */\n    @property({ reflect: true }) public accessor size: 'm' | 's' = isLean() ? 's' : 'm';\n\n    /**\n     * Accessibility label for the page. Defaults to `page`.\n     * Can be set for cases like a carousel, where `slide` or `image` fits better.\n     */\n    @forceType()\n    @property({ attribute: 'accessibility-page-label' })\n    public accessor accessibilityPageLabel: string = '';\n\n    /**\n     * Accessibility label for the previous page. Defaults to `previous page`.\n     * Can be set for cases like a carousel, where `slide` or `image` fits better.\n     */\n    @forceType()\n    @property({ attribute: 'accessibility-previous-page-label' })\n    public accessor accessibilityPreviousPageLabel: string = '';\n\n    /**\n     * Accessibility label for the next page. Defaults to `next page`.\n     * Can be set for cases like a carousel, where `slide` or `image` fits better.\n     */\n    @forceType()\n    @property({ attribute: 'accessibility-next-page-label' })\n    public accessor accessibilityNextPageLabel: string = '';\n\n    protected language = new SbbLanguageController(this);\n    private _previousPageSize: number = this._pageSize;\n    protected abstract renderPaginator(): TemplateResult;\n\n    protected override updated(changedProperties: PropertyValues<this>): void {\n      super.updated(changedProperties);\n\n      // To reliably announce page change, we have to set the label in updated() (a tick later than the other changes).\n      this.shadowRoot!.querySelector('sbb-screen-reader-only#status')!.textContent =\n        this._currentPageLabel();\n    }\n\n    /** Evaluate `pageIndex` by excluding edge cases. */\n    private _coercePageIndexInRange(pageIndex: number): number {\n      return Math.max(\n        Math.min(Math.max(isNaN(pageIndex) ? 0 : pageIndex, 0), this.numberOfPages() - 1),\n        0,\n      );\n    }\n\n    private _currentPageLabel(): string {\n      return `${this.accessibilityPageLabel ? this.accessibilityPageLabel : i18nPage[this.language.current]} ${this.pageIndex + 1} ${i18nPaginatorSelected[this.language.current]}.`;\n    }\n\n    /** Advances to the next page if it exists. */\n    public nextPage(): void {\n      this.pageIndex = this.pageIndex + 1;\n    }\n\n    /** Move back to the previous page if it exists. */\n    public previousPage(): void {\n      this.pageIndex = this.pageIndex - 1;\n    }\n\n    /** Move to the first page if not already there. */\n    public firstPage(): void {\n      this.pageIndex = 0;\n    }\n\n    /** Move to the last page if not already there. */\n    public lastPage(): void {\n      this.pageIndex = this.numberOfPages() - 1;\n    }\n\n    /** Move to a specific page index. */\n    public selectPage(index: number): void {\n      this.pageIndex = index;\n    }\n\n    /** Whether there is a previous page. */\n    public hasPreviousPage(): boolean {\n      return this.pageIndex >= 1 && this.pageSize !== 0;\n    }\n\n    /** Whether there is a next page. */\n    public hasNextPage(): boolean {\n      const maxPageIndex = this.numberOfPages() - 1;\n      return this.pageIndex < maxPageIndex && this.pageSize !== 0;\n    }\n\n    /**\n     * Calculates the current number of pages based on the `length` and the `pageSize`;\n     * value must be rounded up (e.g. `length = 21` and `pageSize = 10` means 3 pages).\n     */\n    public numberOfPages(): number {\n      return this.pageSize ? Math.ceil(this.length / this.pageSize) : 0;\n    }\n\n    protected emitPageEvent(previousPageIndex: number): void {\n      if (\n        !this.hasUpdated ||\n        (this.pageIndex === previousPageIndex && this._previousPageSize === this.pageSize)\n      ) {\n        // When emitting the page event is skipped during initialization,\n        // we have to update the previous page size.\n        // Otherwise, it could trigger an unnecessary page event when other prop\n        // is re-assigned with the e.g. the same value.\n        this._previousPageSize = this.pageSize; // Update the previous page size for next comparison\n\n        // Do not emit the event if the page event details did not change\n        return;\n      }\n\n      /**\n       * @type {CustomEvent<SbbPaginatorPageEventDetails>}\n       * The page event is dispatched when the page index changes.\n       */\n      this.dispatchEvent(\n        new CustomEvent<SbbPaginatorPageEventDetails>('page', {\n          bubbles: true,\n          composed: true,\n          detail: {\n            previousPageIndex,\n            pageIndex: this.pageIndex,\n            length: this.length,\n            pageSize: this.pageSize,\n          },\n        }),\n      );\n    }\n\n    protected renderPrevNextButtons(): TemplateResult {\n      return html`\n        <sbb-mini-button-group ?negative=${this.negative} size=${this.size === 's' ? 's' : 'l'}>\n          <sbb-mini-button\n            id=\"sbb-paginator-prev-page\"\n            aria-label=${this.accessibilityPreviousPageLabel\n              ? this.accessibilityPreviousPageLabel\n              : i18nPreviousPage[this.language.current]}\n            icon-name=\"chevron-small-left-small\"\n            ?disabled=${this.disabled || !this.hasPreviousPage()}\n            @click=${() => this.previousPage()}\n          ></sbb-mini-button>\n          <sbb-divider orientation=\"vertical\"></sbb-divider>\n          <sbb-mini-button\n            id=\"sbb-paginator-next-page\"\n            aria-label=${this.accessibilityNextPageLabel\n              ? this.accessibilityNextPageLabel\n              : i18nNextPage[this.language.current]}\n            icon-name=\"chevron-small-right-small\"\n            ?disabled=${this.disabled || !this.hasNextPage()}\n            @click=${() => this.nextPage()}\n          ></sbb-mini-button>\n        </sbb-mini-button-group>\n      `;\n    }\n\n    protected override render(): TemplateResult {\n      return html`\n        ${this.renderPaginator()}\n        <sbb-screen-reader-only id=\"status\" role=\"status\"></sbb-screen-reader-only>\n      `;\n    }\n  }\n  return SbbPaginatorCommonElement as unknown as AbstractConstructor<SbbPaginatorCommonElementMixinType> &\n    T;\n};\n\ndeclare global {\n  interface HTMLElementEventMap {\n    page: CustomEvent<SbbPaginatorPageEventDetails>;\n  }\n}\n"],"names":[],"mappings":"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"}
279
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"paginator-common.js","sources":["../../../../../src/elements/paginator/common/paginator-common.ts"],"sourcesContent":["import { html, type LitElement, type PropertyValues, type TemplateResult } from 'lit';\nimport { property } from 'lit/decorators.js';\n\nimport { sbbInputModalityDetector } from '../../core/a11y/input-modality-detector.js';\nimport { SbbLanguageController } from '../../core/controllers.js';\nimport { forceType } from '../../core/decorators.js';\nimport { isLean } from '../../core/dom.js';\nimport {\n  i18nNextPage,\n  i18nPage,\n  i18nPaginatorSelected,\n  i18nPreviousPage,\n} from '../../core/i18n.js';\nimport type { SbbPaginatorPageEventDetails } from '../../core/interfaces.js';\nimport {\n  type AbstractConstructor,\n  SbbDisabledMixin,\n  SbbElementInternalsMixin,\n  SbbNegativeMixin,\n} from '../../core/mixins.js';\n\nimport '../../button/mini-button.js';\nimport '../../button/mini-button-group.js';\nimport '../../divider.js';\n\nexport declare abstract class SbbPaginatorCommonElementMixinType extends SbbNegativeMixin(\n  SbbDisabledMixin(SbbElementInternalsMixin(LitElement)),\n) {\n  public accessor length: number;\n  public accessor pageSize: number;\n  public accessor pageIndex: number;\n  public accessor pagerPosition: 'start' | 'end';\n  public accessor size: 'm' | 's';\n  public accessor accessibilityPageLabel: string;\n  public accessor accessibilityPreviousPageLabel: string;\n  public accessor accessibilityNextPageLabel: string;\n  public nextPage(): void;\n  public previousPage(): void;\n  public firstPage(): void;\n  public lastPage(): void;\n  public selectPage(index: number): void;\n  public hasPreviousPage(): boolean;\n  public hasNextPage(): boolean;\n  public numberOfPages(): number;\n  protected language: SbbLanguageController;\n  protected emitPageEvent(previousPageIndex: number): void;\n  protected renderPrevNextButtons(): TemplateResult;\n  protected abstract renderPaginator(): TemplateResult;\n}\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbPaginatorCommonElementMixin = <T extends AbstractConstructor<LitElement>>(\n  superClass: T,\n): AbstractConstructor<SbbPaginatorCommonElementMixinType> & T => {\n  abstract class SbbPaginatorCommonElement\n    extends SbbNegativeMixin(SbbDisabledMixin(SbbElementInternalsMixin(superClass)))\n    implements Partial<SbbPaginatorCommonElementMixinType>\n  {\n    public static override role = 'group';\n    public static readonly events: Record<string, string> = {\n      page: 'page',\n    } as const;\n\n    /** Total number of items. */\n    @property({ type: Number })\n    public set length(value: number) {\n      this._length = isNaN(value) || value < 0 ? 0 : value;\n      // Call setter of pageIndex to ensure bounds\n      // eslint-disable-next-line no-self-assign\n      this.pageIndex = this.pageIndex;\n    }\n    public get length(): number {\n      return this._length;\n    }\n    private _length: number = 0;\n\n    /** Number of items per page. */\n    @property({ attribute: 'page-size', type: Number })\n    public set pageSize(value: number) {\n      // Current page needs to be updated to reflect the new page size. Navigate to the page\n      // containing the previous page's first item.\n      this._previousPageSize = this.pageSize;\n      this._pageSize = Math.max(value, 0);\n      this.pageIndex = Math.floor((this.pageIndex * this._previousPageSize) / this.pageSize) || 0;\n    }\n    public get pageSize(): number {\n      return this._pageSize;\n    }\n    private _pageSize: number = 10;\n\n    /** Current page index. */\n    @property({ attribute: 'page-index', type: Number })\n    public set pageIndex(value: number) {\n      const previousPageIndex = this._pageIndex;\n      this._pageIndex = this._coercePageIndexInRange(value);\n      this.emitPageEvent(previousPageIndex);\n    }\n    public get pageIndex(): number {\n      return this._pageIndex;\n    }\n    private _pageIndex: number = 0;\n\n    /** Position of the prev/next buttons. */\n    @property({ attribute: 'pager-position', reflect: true }) public accessor pagerPosition:\n      | 'start'\n      | 'end' = 'start';\n\n    /**\n     * Size variant, either m or s.\n     * @default 'm' / 's' (lean)\n     */\n    @property({ reflect: true }) public accessor size: 'm' | 's' = isLean() ? 's' : 'm';\n\n    /**\n     * Accessibility label for the page. Defaults to `page`.\n     * Can be set for cases like a carousel, where `slide` or `image` fits better.\n     */\n    @forceType()\n    @property({ attribute: 'accessibility-page-label' })\n    public accessor accessibilityPageLabel: string = '';\n\n    /**\n     * Accessibility label for the previous page. Defaults to `previous page`.\n     * Can be set for cases like a carousel, where `slide` or `image` fits better.\n     */\n    @forceType()\n    @property({ attribute: 'accessibility-previous-page-label' })\n    public accessor accessibilityPreviousPageLabel: string = '';\n\n    /**\n     * Accessibility label for the next page. Defaults to `next page`.\n     * Can be set for cases like a carousel, where `slide` or `image` fits better.\n     */\n    @forceType()\n    @property({ attribute: 'accessibility-next-page-label' })\n    public accessor accessibilityNextPageLabel: string = '';\n\n    protected language = new SbbLanguageController(this);\n    private _previousPageSize: number = this._pageSize;\n    protected abstract renderPaginator(): TemplateResult;\n\n    protected override updated(changedProperties: PropertyValues<this>): void {\n      super.updated(changedProperties);\n\n      // To reliably announce page change, we have to set the label in updated() (a tick later than the other changes).\n      this.shadowRoot!.querySelector('sbb-screen-reader-only#status')!.textContent =\n        this._currentPageLabel();\n    }\n\n    /** Evaluate `pageIndex` by excluding edge cases. */\n    private _coercePageIndexInRange(pageIndex: number): number {\n      return Math.max(\n        Math.min(Math.max(isNaN(pageIndex) ? 0 : pageIndex, 0), this.numberOfPages() - 1),\n        0,\n      );\n    }\n\n    private _currentPageLabel(): string {\n      return `${this.accessibilityPageLabel ? this.accessibilityPageLabel : i18nPage[this.language.current]} ${this.pageIndex + 1} ${i18nPaginatorSelected[this.language.current]}.`;\n    }\n\n    /** Advances to the next page if it exists. */\n    public nextPage(): void {\n      this.pageIndex = this.pageIndex + 1;\n    }\n\n    /** Move back to the previous page if it exists. */\n    public previousPage(): void {\n      this.pageIndex = this.pageIndex - 1;\n    }\n\n    /** Move to the first page if not already there. */\n    public firstPage(): void {\n      this.pageIndex = 0;\n    }\n\n    /** Move to the last page if not already there. */\n    public lastPage(): void {\n      this.pageIndex = this.numberOfPages() - 1;\n    }\n\n    /** Move to a specific page index. */\n    public selectPage(index: number): void {\n      this.pageIndex = index;\n    }\n\n    /** Whether there is a previous page. */\n    public hasPreviousPage(): boolean {\n      return this.pageIndex >= 1 && this.pageSize !== 0;\n    }\n\n    /** Whether there is a next page. */\n    public hasNextPage(): boolean {\n      const maxPageIndex = this.numberOfPages() - 1;\n      return this.pageIndex < maxPageIndex && this.pageSize !== 0;\n    }\n\n    /**\n     * Calculates the current number of pages based on the `length` and the `pageSize`;\n     * value must be rounded up (e.g. `length = 21` and `pageSize = 10` means 3 pages).\n     */\n    public numberOfPages(): number {\n      return this.pageSize ? Math.ceil(this.length / this.pageSize) : 0;\n    }\n\n    protected emitPageEvent(previousPageIndex: number): void {\n      if (\n        !this.hasUpdated ||\n        (this.pageIndex === previousPageIndex && this._previousPageSize === this.pageSize)\n      ) {\n        // When emitting the page event is skipped during initialization,\n        // we have to update the previous page size.\n        // Otherwise, it could trigger an unnecessary page event when other prop\n        // is re-assigned with the e.g. the same value.\n        this._previousPageSize = this.pageSize; // Update the previous page size for next comparison\n\n        // Do not emit the event if the page event details did not change\n        return;\n      }\n\n      /**\n       * @type {CustomEvent<SbbPaginatorPageEventDetails>}\n       * The page event is dispatched when the page index changes.\n       */\n      this.dispatchEvent(\n        new CustomEvent<SbbPaginatorPageEventDetails>('page', {\n          bubbles: true,\n          composed: true,\n          detail: {\n            previousPageIndex,\n            pageIndex: this.pageIndex,\n            length: this.length,\n            pageSize: this.pageSize,\n          },\n        }),\n      );\n    }\n\n    protected renderPrevNextButtons(): TemplateResult {\n      return html`\n        <sbb-mini-button-group ?negative=${this.negative} size=${this.size === 's' ? 's' : 'l'}>\n          <sbb-mini-button\n            id=\"sbb-paginator-prev-page\"\n            aria-label=${this.accessibilityPreviousPageLabel\n              ? this.accessibilityPreviousPageLabel\n              : i18nPreviousPage[this.language.current]}\n            icon-name=\"chevron-small-left-small\"\n            ?disabled=${this.disabled || !this.hasPreviousPage()}\n            @click=${() => {\n              this.previousPage();\n              if (\n                !this.hasPreviousPage() &&\n                sbbInputModalityDetector.mostRecentModality === 'keyboard'\n              ) {\n                this.shadowRoot?.getElementById('sbb-paginator-next-page')!.focus();\n              }\n            }}\n          ></sbb-mini-button>\n          <sbb-divider orientation=\"vertical\"></sbb-divider>\n          <sbb-mini-button\n            id=\"sbb-paginator-next-page\"\n            aria-label=${this.accessibilityNextPageLabel\n              ? this.accessibilityNextPageLabel\n              : i18nNextPage[this.language.current]}\n            icon-name=\"chevron-small-right-small\"\n            ?disabled=${this.disabled || !this.hasNextPage()}\n            @click=${() => {\n              this.nextPage();\n              if (\n                !this.hasNextPage() &&\n                sbbInputModalityDetector.mostRecentModality === 'keyboard'\n              ) {\n                this.shadowRoot?.getElementById('sbb-paginator-prev-page')!.focus();\n              }\n            }}\n          ></sbb-mini-button>\n        </sbb-mini-button-group>\n      `;\n    }\n\n    protected override render(): TemplateResult {\n      return html`\n        ${this.renderPaginator()}\n        <sbb-screen-reader-only id=\"status\" role=\"status\"></sbb-screen-reader-only>\n      `;\n    }\n  }\n  return SbbPaginatorCommonElement as unknown as AbstractConstructor<SbbPaginatorCommonElementMixinType> &\n    T;\n};\n\ndeclare global {\n  interface HTMLElementEventMap {\n    page: CustomEvent<SbbPaginatorPageEventDetails>;\n  }\n}\n"],"names":[],"mappings":"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"}
@@ -2,19 +2,25 @@ import { CSSResultGroup, TemplateResult, LitElement } from 'lit';
2
2
  import { SbbTabLabelElement } from '../tab-label.js';
3
3
  declare const SbbTabElement_base: import('../../core/mixins.js').AbstractConstructor<import('../../core/mixins.js').SbbElementInternalsMixinType> & typeof LitElement & import('../../core/mixins.js').SbbElementInternalsConstructor;
4
4
  /**
5
- * Combined with a `sbb-tab-group`, it displays a tab's content.
5
+ * Combined with a `sbb-tab-group` and `sbb-tab-label`, it displays a tab's content.
6
6
  *
7
7
  * @slot - Use the unnamed slot to provide content.
8
+ * @event {Event} active - The `active` event fires when the sbb-tab has been activated via user selection on the sbb-tab-label.
8
9
  */
9
10
  export declare class SbbTabElement extends SbbTabElement_base {
10
11
  static role: string;
11
12
  static styles: CSSResultGroup;
13
+ static readonly events: {
14
+ readonly active: "active";
15
+ };
12
16
  /** The `sbb-tab-label` associated with the tab. */
13
17
  get label(): SbbTabLabelElement | null;
14
- private _label;
15
- private _getTabLabel;
16
- /** @internal */
18
+ /**
19
+ * @internal
20
+ * @deprecated
21
+ */
17
22
  configure(): void;
23
+ connectedCallback(): void;
18
24
  protected render(): TemplateResult;
19
25
  }
20
26
  declare global {
@@ -1 +1 @@
1
- {"version":3,"file":"tab.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/tabs/tab/tab.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1D,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AAIvC,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;;AAI1D;;;;GAIG;AACH,qBAEM,aAAc,SAAQ,kBAAoC;IAC9D,OAAuB,IAAI,SAAc;IACzC,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,mDAAmD;IACnD,IAAW,KAAK,IAAI,kBAAkB,GAAG,IAAI,CAE5C;IACD,OAAO,CAAC,MAAM,CAAmC;IAEjD,OAAO,CAAC,YAAY;IAQpB,gBAAgB;IACT,SAAS,IAAI,IAAI;cAIL,MAAM,IAAI,cAAc;CAO5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,SAAS,EAAE,aAAa,CAAC;KAC1B;CACF"}
1
+ {"version":3,"file":"tab.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/tabs/tab/tab.component.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1D,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AAIvC,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;;AAM1D;;;;;GAKG;AACH,qBAEM,aAAc,SAAQ,kBAAoC;IAC9D,OAAuB,IAAI,SAAc;IACzC,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;MAElB;IAEX,mDAAmD;IACnD,IAAW,KAAK,IAAI,kBAAkB,GAAG,IAAI,CAI5C;IAED;;;OAGG;IACI,SAAS,IAAI,IAAI;IAER,iBAAiB,IAAI,IAAI;cAOtB,MAAM,IAAI,cAAc;CAO5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,SAAS,EAAE,aAAa,CAAC;KAC1B;CACF"}
@@ -19,6 +19,7 @@ const style = css`@charset "UTF-8";
19
19
  height: 0;
20
20
  overflow: hidden;
21
21
  }`;
22
+ let nextId = 0;
22
23
  let SbbTabElement = (() => {
23
24
  var _a;
24
25
  let _classDecorators = [customElement("sbb-tab")];
@@ -27,24 +28,20 @@ let SbbTabElement = (() => {
27
28
  let _classThis;
28
29
  let _classSuper = SbbElementInternalsMixin(LitElement);
29
30
  _a = class extends _classSuper {
30
- constructor() {
31
- super(...arguments);
32
- this._label = null;
33
- }
34
31
  /** The `sbb-tab-label` associated with the tab. */
35
32
  get label() {
36
- return this._label;
37
- }
38
- _getTabLabel() {
39
- let previousSibling = this.previousElementSibling;
40
- while (previousSibling && previousSibling.localName !== "sbb-tab-label") {
41
- previousSibling = previousSibling.previousElementSibling;
42
- }
43
- return previousSibling;
33
+ return this.previousElementSibling?.localName === "sbb-tab-label" ? this.previousElementSibling : null;
44
34
  }
45
- /** @internal */
35
+ /**
36
+ * @internal
37
+ * @deprecated
38
+ */
46
39
  configure() {
47
- this._label = this._getTabLabel();
40
+ }
41
+ connectedCallback() {
42
+ super.connectedCallback();
43
+ this.id ||= `sbb-tab-${nextId++}`;
44
+ this.tabIndex = 0;
48
45
  }
49
46
  render() {
50
47
  return html`
@@ -58,10 +55,12 @@ let SbbTabElement = (() => {
58
55
  __esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
59
56
  _classThis = _classDescriptor.value;
60
57
  if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
61
- })(), _a.role = "tabpanel", _a.styles = style, __runInitializers(_classThis, _classExtraInitializers), _a;
58
+ })(), _a.role = "tabpanel", _a.styles = style, _a.events = {
59
+ active: "active"
60
+ }, __runInitializers(_classThis, _classExtraInitializers), _a;
62
61
  return _classThis;
63
62
  })();
64
63
  export {
65
64
  SbbTabElement
66
65
  };
67
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLmNvbXBvbmVudC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzL3RhYnMvdGFiL3RhYi5jb21wb25lbnQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBDU1NSZXN1bHRHcm91cCwgVGVtcGxhdGVSZXN1bHQgfSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgaHRtbCwgTGl0RWxlbWVudCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgeyBTYmJFbGVtZW50SW50ZXJuYWxzTWl4aW4gfSBmcm9tICcuLi8uLi9jb3JlL21peGlucy5qcyc7XG5pbXBvcnQgdHlwZSB7IFNiYlRhYkxhYmVsRWxlbWVudCB9IGZyb20gJy4uL3RhYi1sYWJlbC5qcyc7XG5cbmltcG9ydCBzdHlsZSBmcm9tICcuL3RhYi5zY3NzP2xpdCZpbmxpbmUnO1xuXG4vKipcbiAqIENvbWJpbmVkIHdpdGggYSBgc2JiLXRhYi1ncm91cGAsIGl0IGRpc3BsYXlzIGEgdGFiJ3MgY29udGVudC5cbiAqXG4gKiBAc2xvdCAtIFVzZSB0aGUgdW5uYW1lZCBzbG90IHRvIHByb3ZpZGUgY29udGVudC5cbiAqL1xuZXhwb3J0XG5AY3VzdG9tRWxlbWVudCgnc2JiLXRhYicpXG5jbGFzcyBTYmJUYWJFbGVtZW50IGV4dGVuZHMgU2JiRWxlbWVudEludGVybmFsc01peGluKExpdEVsZW1lbnQpIHtcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSByb2xlID0gJ3RhYnBhbmVsJztcbiAgcHVibGljIHN0YXRpYyBvdmVycmlkZSBzdHlsZXM6IENTU1Jlc3VsdEdyb3VwID0gc3R5bGU7XG5cbiAgLyoqIFRoZSBgc2JiLXRhYi1sYWJlbGAgYXNzb2NpYXRlZCB3aXRoIHRoZSB0YWIuICovXG4gIHB1YmxpYyBnZXQgbGFiZWwoKTogU2JiVGFiTGFiZWxFbGVtZW50IHwgbnVsbCB7XG4gICAgcmV0dXJuIHRoaXMuX2xhYmVsO1xuICB9XG4gIHByaXZhdGUgX2xhYmVsOiBTYmJUYWJMYWJlbEVsZW1lbnQgfCBudWxsID0gbnVsbDtcblxuICBwcml2YXRlIF9nZXRUYWJMYWJlbCgpOiBTYmJUYWJMYWJlbEVsZW1lbnQgfCBudWxsIHtcbiAgICBsZXQgcHJldmlvdXNTaWJsaW5nID0gdGhpcy5wcmV2aW91c0VsZW1lbnRTaWJsaW5nO1xuICAgIHdoaWxlIChwcmV2aW91c1NpYmxpbmcgJiYgcHJldmlvdXNTaWJsaW5nLmxvY2FsTmFtZSAhPT0gJ3NiYi10YWItbGFiZWwnKSB7XG4gICAgICBwcmV2aW91c1NpYmxpbmcgPSBwcmV2aW91c1NpYmxpbmcucHJldmlvdXNFbGVtZW50U2libGluZztcbiAgICB9XG4gICAgcmV0dXJuIHByZXZpb3VzU2libGluZyBhcyBTYmJUYWJMYWJlbEVsZW1lbnQ7XG4gIH1cblxuICAvKiogQGludGVybmFsICovXG4gIHB1YmxpYyBjb25maWd1cmUoKTogdm9pZCB7XG4gICAgdGhpcy5fbGFiZWwgPSB0aGlzLl9nZXRUYWJMYWJlbCgpO1xuICB9XG5cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIHJlbmRlcigpOiBUZW1wbGF0ZVJlc3VsdCB7XG4gICAgcmV0dXJuIGh0bWxgXG4gICAgICA8ZGl2IGNsYXNzPVwic2JiLXRhYlwiPlxuICAgICAgICA8c2xvdD48L3Nsb3Q+XG4gICAgICA8L2Rpdj5cbiAgICBgO1xuICB9XG59XG5cbmRlY2xhcmUgZ2xvYmFsIHtcbiAgaW50ZXJmYWNlIEhUTUxFbGVtZW50VGFnTmFtZU1hcCB7XG4gICAgLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uYW1pbmctY29udmVudGlvblxuICAgICdzYmItdGFiJzogU2JiVGFiRWxlbWVudDtcbiAgfVxufVxuIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztJQWdCTSxpQkFBYSxNQUFBOzswQkFEbEIsY0FBYyxTQUFTLENBQUM7Ozs7b0JBQ0cseUJBQXlCLFVBQVU7QUFBM0MsRUFBQSxtQkFBUSxZQUFvQztBQUFBOztBQVF0RCxXQUFBLFNBQW9DO0FBQUEsSUFzQjlDO0FBQUE7QUFBQSxJQXpCRSxJQUFXLFFBQUs7QUFDZCxhQUFPLEtBQUs7QUFBQSxJQUNkO0FBQUEsSUFHUSxlQUFZO0FBQ2xCLFVBQUksa0JBQWtCLEtBQUs7QUFDM0IsYUFBTyxtQkFBbUIsZ0JBQWdCLGNBQWMsaUJBQWlCO0FBQ3ZFLDBCQUFrQixnQkFBZ0I7QUFBQSxNQUNwQztBQUNBLGFBQU87QUFBQSxJQUNUO0FBQUE7QUFBQSxJQUdPLFlBQVM7QUFDZCxXQUFLLFNBQVMsS0FBSyxhQUFBO0FBQUEsSUFDckI7QUFBQSxJQUVtQixTQUFNO0FBQ3ZCLGFBQU87QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLElBS1Q7QUFBQTs7QUE3QkYsaUJBQUEsTUFBQSxtQkFBQSxFQUFBLE9BQUEsV0FBQSxHQUFBLGtCQUFBLEVBQUEsTUFBQSxTQUFBLE1BQUEsV0FBQSxNQUFBLFVBQUEsVUFBQSxHQUFBLE1BQUEsdUJBQUE7OztRQUN5QixHQUFBLE9BQU8sWUFDUCxHQUFBLFNBQXlCLE9BRjVDLGtCQUFBLFlBQUEsdUJBQUEsR0FBYzs7OyJ9
66
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLmNvbXBvbmVudC5qcyIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL2VsZW1lbnRzL3RhYnMvdGFiL3RhYi5jb21wb25lbnQudHMiXSwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBDU1NSZXN1bHRHcm91cCwgVGVtcGxhdGVSZXN1bHQgfSBmcm9tICdsaXQnO1xuaW1wb3J0IHsgaHRtbCwgTGl0RWxlbWVudCB9IGZyb20gJ2xpdCc7XG5pbXBvcnQgeyBjdXN0b21FbGVtZW50IH0gZnJvbSAnbGl0L2RlY29yYXRvcnMuanMnO1xuXG5pbXBvcnQgeyBTYmJFbGVtZW50SW50ZXJuYWxzTWl4aW4gfSBmcm9tICcuLi8uLi9jb3JlL21peGlucy5qcyc7XG5pbXBvcnQgdHlwZSB7IFNiYlRhYkxhYmVsRWxlbWVudCB9IGZyb20gJy4uL3RhYi1sYWJlbC5qcyc7XG5cbmltcG9ydCBzdHlsZSBmcm9tICcuL3RhYi5zY3NzP2xpdCZpbmxpbmUnO1xuXG5sZXQgbmV4dElkID0gMDtcblxuLyoqXG4gKiBDb21iaW5lZCB3aXRoIGEgYHNiYi10YWItZ3JvdXBgIGFuZCBgc2JiLXRhYi1sYWJlbGAsIGl0IGRpc3BsYXlzIGEgdGFiJ3MgY29udGVudC5cbiAqXG4gKiBAc2xvdCAtIFVzZSB0aGUgdW5uYW1lZCBzbG90IHRvIHByb3ZpZGUgY29udGVudC5cbiAqIEBldmVudCB7RXZlbnR9IGFjdGl2ZSAtIFRoZSBgYWN0aXZlYCBldmVudCBmaXJlcyB3aGVuIHRoZSBzYmItdGFiIGhhcyBiZWVuIGFjdGl2YXRlZCB2aWEgdXNlciBzZWxlY3Rpb24gb24gdGhlIHNiYi10YWItbGFiZWwuXG4gKi9cbmV4cG9ydFxuQGN1c3RvbUVsZW1lbnQoJ3NiYi10YWInKVxuY2xhc3MgU2JiVGFiRWxlbWVudCBleHRlbmRzIFNiYkVsZW1lbnRJbnRlcm5hbHNNaXhpbihMaXRFbGVtZW50KSB7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgcm9sZSA9ICd0YWJwYW5lbCc7XG4gIHB1YmxpYyBzdGF0aWMgb3ZlcnJpZGUgc3R5bGVzOiBDU1NSZXN1bHRHcm91cCA9IHN0eWxlO1xuICBwdWJsaWMgc3RhdGljIHJlYWRvbmx5IGV2ZW50cyA9IHtcbiAgICBhY3RpdmU6ICdhY3RpdmUnLFxuICB9IGFzIGNvbnN0O1xuXG4gIC8qKiBUaGUgYHNiYi10YWItbGFiZWxgIGFzc29jaWF0ZWQgd2l0aCB0aGUgdGFiLiAqL1xuICBwdWJsaWMgZ2V0IGxhYmVsKCk6IFNiYlRhYkxhYmVsRWxlbWVudCB8IG51bGwge1xuICAgIHJldHVybiB0aGlzLnByZXZpb3VzRWxlbWVudFNpYmxpbmc/LmxvY2FsTmFtZSA9PT0gJ3NiYi10YWItbGFiZWwnXG4gICAgICA/ICh0aGlzLnByZXZpb3VzRWxlbWVudFNpYmxpbmcgYXMgU2JiVGFiTGFiZWxFbGVtZW50KVxuICAgICAgOiBudWxsO1xuICB9XG5cbiAgLyoqXG4gICAqIEBpbnRlcm5hbFxuICAgKiBAZGVwcmVjYXRlZFxuICAgKi9cbiAgcHVibGljIGNvbmZpZ3VyZSgpOiB2b2lkIHt9XG5cbiAgcHVibGljIG92ZXJyaWRlIGNvbm5lY3RlZENhbGxiYWNrKCk6IHZvaWQge1xuICAgIHN1cGVyLmNvbm5lY3RlZENhbGxiYWNrKCk7XG5cbiAgICB0aGlzLmlkIHx8PSBgc2JiLXRhYi0ke25leHRJZCsrfWA7XG4gICAgdGhpcy50YWJJbmRleCA9IDA7XG4gIH1cblxuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgcmVuZGVyKCk6IFRlbXBsYXRlUmVzdWx0IHtcbiAgICByZXR1cm4gaHRtbGBcbiAgICAgIDxkaXYgY2xhc3M9XCJzYmItdGFiXCI+XG4gICAgICAgIDxzbG90Pjwvc2xvdD5cbiAgICAgIDwvZGl2PlxuICAgIGA7XG4gIH1cbn1cblxuZGVjbGFyZSBnbG9iYWwge1xuICBpbnRlcmZhY2UgSFRNTEVsZW1lbnRUYWdOYW1lTWFwIHtcbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25hbWluZy1jb252ZW50aW9uXG4gICAgJ3NiYi10YWInOiBTYmJUYWJFbGVtZW50O1xuICB9XG59XG4iXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBU0EsSUFBSSxTQUFTO0lBVVAsaUJBQWEsTUFBQTs7MEJBRGxCLGNBQWMsU0FBUyxDQUFDOzs7O29CQUNHLHlCQUF5QixVQUFVO0FBQTNDLEVBQUEsbUJBQVEsWUFBb0M7QUFBQTtBQUFBLElBUTlELElBQVcsUUFBSztBQUNkLGFBQU8sS0FBSyx3QkFBd0IsY0FBYyxrQkFDN0MsS0FBSyx5QkFDTjtBQUFBLElBQ047QUFBQTtBQUFBO0FBQUE7QUFBQTtBQUFBLElBTU87SUFBbUI7QUFBQSxJQUVWLG9CQUFpQjtBQUMvQixZQUFNLGtCQUFBO0FBRU4sV0FBSyxPQUFPLFdBQVcsUUFBUTtBQUMvQixXQUFLLFdBQVc7QUFBQSxJQUNsQjtBQUFBLElBRW1CLFNBQU07QUFDdkIsYUFBTztBQUFBO0FBQUE7QUFBQTtBQUFBO0FBQUEsSUFLVDtBQUFBOztBQWpDRixpQkFBQSxNQUFBLG1CQUFBLEVBQUEsT0FBQSxXQUFBLEdBQUEsa0JBQUEsRUFBQSxNQUFBLFNBQUEsTUFBQSxXQUFBLE1BQUEsVUFBQSxVQUFBLEdBQUEsTUFBQSx1QkFBQTs7O1FBQ3lCLEdBQUEsT0FBTyxZQUNQLEdBQUEsU0FBeUIsT0FDekIsR0FBQSxTQUFTO0FBQUEsSUFDOUIsUUFBUTtBQUFBLEVBQUEsR0FKTixrQkFBQSxZQUFBLHVCQUFBLEdBQWM7OzsifQ==
@@ -9,6 +9,9 @@ export type SbbTabChangedEventDetails = {
9
9
  previousTabLabel: SbbTabLabelElement | undefined;
10
10
  previousTab: SbbTabElement | undefined;
11
11
  };
12
+ /**
13
+ * @deprecated
14
+ */
12
15
  export interface InterfaceSbbTabGroupActions {
13
16
  activate(): void;
14
17
  deactivate(): void;
@@ -16,45 +19,47 @@ export interface InterfaceSbbTabGroupActions {
16
19
  disable(): void;
17
20
  select(): void;
18
21
  }
22
+ /**
23
+ * @deprecated
24
+ */
19
25
  export interface InterfaceSbbTabGroupTab extends SbbTabLabelElement {
20
26
  active: boolean;
21
27
  disabled: boolean;
22
- tab?: SbbTabElement;
28
+ tab: SbbTabElement | null;
23
29
  index?: number;
24
30
  tabGroupActions?: InterfaceSbbTabGroupActions;
25
31
  size: 's' | 'l' | 'xl';
26
32
  }
27
33
  declare const SbbTabGroupElement_base: import('../../core/mixins.js').AbstractConstructor<import('../../core/mixins.js').SbbHydrationMixinType> & typeof LitElement;
28
34
  /**
29
- * It displays one or more tabs, each one with a label and a content.
35
+ * It displays one or more tabs, each one with a label and some content.
30
36
  *
31
- * @slot - Use the unnamed slot to add content to the `sbb-tab-group` via
32
- * `sbb-tab-label` and `sbb-tab` instances.
37
+ * @slot - Use the unnamed slot to add content to the `sbb-tab-group` via `sbb-tab-label` and `sbb-tab` instances.
38
+ * @event {CustomEvent<SbbTabChangedEventDetails>} tabchange - The tabchange event is dispatched when a tab is selected.
33
39
  */
34
40
  export declare class SbbTabGroupElement extends SbbTabGroupElement_base {
35
41
  static styles: CSSResultGroup;
36
42
  static readonly events: {
37
43
  readonly tabchange: "tabchange";
38
44
  };
39
- private _tabs;
40
- private _selectedTab?;
41
45
  private _tabGroupElement;
42
46
  private _tabContentElement;
43
- private _tabAttributeObserver;
44
47
  private _tabGroupResizeObserver;
45
48
  private _tabContentResizeObserver;
46
49
  /**
47
50
  * Size variant, either s, l or xl.
48
51
  * @default 'l' / 's' (lean)
49
52
  */
50
- set size(value: InterfaceSbbTabGroupTab['size']);
51
- get size(): InterfaceSbbTabGroupTab['size'];
53
+ set size(value: 's' | 'l' | 'xl');
54
+ get size(): 's' | 'l' | 'xl';
52
55
  private _size;
53
56
  /**
54
57
  * Sets the initial tab. If it matches a disabled tab or exceeds the length of
55
58
  * the tab group, the first enabled tab will be selected.
56
59
  */
57
60
  accessor initialSelectedIndex: number;
61
+ /** Gets the slotted `sbb-tab-label`s. */
62
+ get labels(): SbbTabLabelElement[];
58
63
  constructor();
59
64
  protected firstUpdated(changedProperties: PropertyValues<this>): void;
60
65
  /**
@@ -72,17 +77,13 @@ export declare class SbbTabGroupElement extends SbbTabGroupElement_base {
72
77
  * @param tabIndex The index of the tab you want to activate.
73
78
  */
74
79
  activateTab(tabIndex: number): void;
75
- private _getTabs;
76
80
  private _enabledTabs;
77
81
  private _updateSize;
78
82
  private _onContentSlotChange;
79
- private _onTabsSlotChange;
80
- private _assignId;
83
+ private _onLabelSlotChange;
81
84
  private _initSelection;
82
- private _onTabAttributesChange;
83
85
  private _onTabGroupElementResize;
84
86
  private _onTabContentElementResize;
85
- private _configure;
86
87
  private _handleKeyDown;
87
88
  protected render(): TemplateResult;
88
89
  }
@@ -1 +1 @@
1
- {"version":3,"file":"tab-group.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/tabs/tab-group/tab-group.component.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AASvC,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAC1D,OAAO,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAI1C,MAAM,MAAM,yBAAyB,GAAG;IACtC,WAAW,EAAE,MAAM,CAAC;IACpB,cAAc,EAAE,kBAAkB,CAAC;IACnC,SAAS,EAAE,aAAa,CAAC;IACzB,aAAa,EAAE,MAAM,CAAC;IACtB,gBAAgB,EAAE,kBAAkB,GAAG,SAAS,CAAC;IACjD,WAAW,EAAE,aAAa,GAAG,SAAS,CAAC;CACxC,CAAC;AAEF,MAAM,WAAW,2BAA2B;IAC1C,QAAQ,IAAI,IAAI,CAAC;IACjB,UAAU,IAAI,IAAI,CAAC;IACnB,MAAM,IAAI,IAAI,CAAC;IACf,OAAO,IAAI,IAAI,CAAC;IAChB,MAAM,IAAI,IAAI,CAAC;CAChB;AAED,MAAM,WAAW,uBAAwB,SAAQ,kBAAkB;IACjE,MAAM,EAAE,OAAO,CAAC;IAChB,QAAQ,EAAE,OAAO,CAAC;IAClB,GAAG,CAAC,EAAE,aAAa,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,eAAe,CAAC,EAAE,2BAA2B,CAAC;IAC9C,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC;CACxB;;AAQD;;;;;GAKG;AACH,qBAEM,kBAAmB,SAAQ,uBAA6B;IAC5D,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;MAElB;IAEX,OAAO,CAAC,KAAK,CAAiC;IAC9C,OAAO,CAAC,YAAY,CAAC,CAA0B;IAC/C,OAAO,CAAC,gBAAgB,CAAe;IACvC,OAAO,CAAC,kBAAkB,CAAe;IACzC,OAAO,CAAC,qBAAqB,CAI1B;IACH,OAAO,CAAC,uBAAuB,CAI5B;IACH,OAAO,CAAC,yBAAyB,CAI9B;IAEH;;;OAGG;IACH,IACW,IAAI,CAAC,KAAK,EAAE,uBAAuB,CAAC,MAAM,CAAC,EAGrD;IACD,IAAW,IAAI,IAAI,uBAAuB,CAAC,MAAM,CAAC,CAEjD;IACD,OAAO,CAAC,KAAK,CAAyD;IAEtE;;;OAGG;IACH,SAEgB,oBAAoB,EAAE,MAAM,CAAK;;cAO9B,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAS9E;;;OAGG;IACI,UAAU,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAIzC;;;OAGG;IACI,SAAS,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAIxC;;;OAGG;IACI,WAAW,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAI1C,OAAO,CAAC,QAAQ;IAMhB,OAAO,CAAC,YAAY;IAIpB,OAAO,CAAC,WAAW;IAMnB,OAAO,CAAC,oBAAoB,CAY1B;IAEF,OAAO,CAAC,iBAAiB,CAavB;IAEF,OAAO,CAAC,SAAS;IAIjB,OAAO,CAAC,cAAc;IAYtB,OAAO,CAAC,sBAAsB;IAwB9B,OAAO,CAAC,wBAAwB;IAgBhC,OAAO,CAAC,0BAA0B;IAWlC,OAAO,CAAC,UAAU;IA4GlB,OAAO,CAAC,cAAc;cAoBH,MAAM,IAAI,cAAc;CAe5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,eAAe,EAAE,kBAAkB,CAAC;KACrC;CACF"}
1
+ {"version":3,"file":"tab-group.component.d.ts","sourceRoot":"","sources":["../../../../../src/elements/tabs/tab-group/tab-group.component.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AASvC,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAC1D,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,WAAW,CAAC;AAI/C,MAAM,MAAM,yBAAyB,GAAG;IACtC,WAAW,EAAE,MAAM,CAAC;IACpB,cAAc,EAAE,kBAAkB,CAAC;IACnC,SAAS,EAAE,aAAa,CAAC;IACzB,aAAa,EAAE,MAAM,CAAC;IACtB,gBAAgB,EAAE,kBAAkB,GAAG,SAAS,CAAC;IACjD,WAAW,EAAE,aAAa,GAAG,SAAS,CAAC;CACxC,CAAC;AAEF;;GAEG;AACH,MAAM,WAAW,2BAA2B;IAC1C,QAAQ,IAAI,IAAI,CAAC;IACjB,UAAU,IAAI,IAAI,CAAC;IACnB,MAAM,IAAI,IAAI,CAAC;IACf,OAAO,IAAI,IAAI,CAAC;IAChB,MAAM,IAAI,IAAI,CAAC;CAChB;AAED;;GAEG;AACH,MAAM,WAAW,uBAAwB,SAAQ,kBAAkB;IACjE,MAAM,EAAE,OAAO,CAAC;IAChB,QAAQ,EAAE,OAAO,CAAC;IAClB,GAAG,EAAE,aAAa,GAAG,IAAI,CAAC;IAC1B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,eAAe,CAAC,EAAE,2BAA2B,CAAC;IAC9C,IAAI,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC;CACxB;;AAED;;;;;GAKG;AACH,qBAEM,kBAAmB,SAAQ,uBAA6B;IAC5D,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;MAElB;IAEX,OAAO,CAAC,gBAAgB,CAAe;IACvC,OAAO,CAAC,kBAAkB,CAAe;IACzC,OAAO,CAAC,uBAAuB,CAI5B;IACH,OAAO,CAAC,yBAAyB,CAI9B;IAEH;;;OAGG;IACH,IACW,IAAI,CAAC,KAAK,EAAE,GAAG,GAAG,GAAG,GAAG,IAAI,EAGtC;IACD,IAAW,IAAI,IAAI,GAAG,GAAG,GAAG,GAAG,IAAI,CAElC;IACD,OAAO,CAAC,KAAK,CAA0C;IAEvD;;;OAGG;IACH,SAEgB,oBAAoB,EAAE,MAAM,CAAK;IAEjD,yCAAyC;IACzC,IAAW,MAAM,IAAI,kBAAkB,EAAE,CAQxC;;cAOkB,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAS9E;;;OAGG;IACI,UAAU,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAMzC;;;OAGG;IACI,SAAS,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAMxC;;;OAGG;IACI,WAAW,CAAC,QAAQ,EAAE,MAAM,GAAG,IAAI;IAI1C,OAAO,CAAC,YAAY;IAOpB,OAAO,CAAC,WAAW;IAMnB,OAAO,CAAC,oBAAoB,CAG1B;IAEF,OAAO,CAAC,kBAAkB,CAGxB;IAEF,OAAO,CAAC,cAAc;IAgBtB,OAAO,CAAC,wBAAwB;IAgBhC,OAAO,CAAC,0BAA0B;IAWlC,OAAO,CAAC,cAAc;cAoBH,MAAM,IAAI,cAAc;CAiB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,eAAe,EAAE,kBAAkB,CAAC;KACrC;CACF"}