@sbb-esta/lyne-elements-dev 5.0.0-next-dev.1776332654 → 5.0.0-next-dev.1776353458

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.
@@ -9,7 +9,7 @@ var o = "data-ssr-child-count", s = "li", c = (c) => (() => {
9
9
  constructor() {
10
10
  super(...arguments), this.#e = t(this, d, []), this._handleSlotchange = (t(this, f), () => {
11
11
  let e = Array.from(this.children ?? []).filter((e) => this.listChildLocalNames.includes(e.localName));
12
- e.length === this.listChildren.length && this.listChildren.every((t, n) => e[n] === t) || (this.listChildren.filter((t) => !e.includes(t)).forEach((e) => e.removeAttribute("slot")), this.listChildren = e, this.listChildren.forEach((e, t) => e.setAttribute("slot", `${s}-${t}`)), this.removeAttribute(o));
12
+ e.length === this.listChildren.length && this.listChildren.every((t, n) => e[n] === t) || (this.listChildren.filter((t) => !e.includes(t)).forEach((e) => e.removeAttribute("slot")), this.listChildren = e, this.removeAttribute(o));
13
13
  });
14
14
  }
15
15
  static {
@@ -50,6 +50,9 @@ var o = "data-ssr-child-count", s = "li", c = (c) => (() => {
50
50
  disconnectedCallback() {
51
51
  super.disconnectedCallback(), this.shadowRoot?.removeEventListener("slotchange", this._handleSlotchange);
52
52
  }
53
+ updated(e) {
54
+ super.updated(e), e.has("listChildren") && this.listChildren.forEach((e, t) => e.setAttribute("slot", `${s}-${t}`));
55
+ }
53
56
  renderList(e = {}, t = {}) {
54
57
  let i = this.listSlotEntries(t);
55
58
  return i.length >= 2 ? n`
@@ -1 +1 @@
1
- {"version":3,"file":"named-slot-list-mixin.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/mixins/named-slot-list-mixin.ts"],"names":[],"mappings":"AAAA,OAAO,EAAiB,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAGzD,OAAO,KAAK,EACV,UAAU,EACV,qBAAqB,EAEtB,MAAM,6BAA6B,CAAC;AAGrC,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAK5D,MAAM,WAAW,sBAAsB;IACrC,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,OAAO,CAAC;CACrB;AAED;;;;;;;;;;GAUG;AACH,MAAM,MAAM,gBAAgB,CAC1B,CAAC,SAAS,yBAAyB,CAAC,CAAC,CAAC,EACtC,CAAC,SAAS,WAAW,GAAG,WAAW,IACjC,CAAC,GAAG;IAAE,YAAY,EAAE,CAAC,EAAE,CAAA;CAAE,CAAC;AAE9B,MAAM,CAAC,OAAO,CAAC,QAAQ,OAAO,yBAAyB,CAAC,CAAC,SAAS,WAAW,CAAE,SAAQ,UAAU;IAC/F,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,mBAAmB,EAAE,MAAM,EAAE,CAAC;IAC1D,SAAS,CAAC,QAAQ,CAAC,YAAY,EAAE,CAAC,EAAE,CAAC;IACrC,SAAS,CAAC,UAAU,CAClB,UAAU,CAAC,EAAE;QACX,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,cAAc,CAAC,EAAE,MAAM,CAAC;KACzB,EACD,kBAAkB,CAAC,EAAE;QACnB,mBAAmB,CAAC,EAAE,MAAM,EAAE,CAAC;KAChC,GACA,cAAc;IACjB,SAAS,CAAC,eAAe,IAAI,sBAAsB,EAAE;IACrD,SAAS,CAAC,gBAAgB,IAAI,cAAc;CAC7C;AAGD,eAAO,MAAM,qBAAqB,GAChC,CAAC,SAAS,WAAW,EACrB,CAAC,SAAS,mBAAmB,CAAC,UAAU,CAAC,GAAG,qBAAqB,EAEjE,YAAY,CAAC,KACZ,mBAAmB,CAAC,yBAAyB,CAAC,CAAC,CAAC,CAAC,GAAG,CAuItD,CAAC"}
1
+ {"version":3,"file":"named-slot-list-mixin.d.ts","sourceRoot":"","sources":["../../../../../src/elements/core/mixins/named-slot-list-mixin.ts"],"names":[],"mappings":"AAAA,OAAO,EAAsC,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAG9E,OAAO,KAAK,EACV,UAAU,EACV,qBAAqB,EAEtB,MAAM,6BAA6B,CAAC;AAGrC,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAK5D,MAAM,WAAW,sBAAsB;IACrC,IAAI,EAAE,MAAM,CAAC;IACb,UAAU,EAAE,OAAO,CAAC;CACrB;AAED;;;;;;;;;;GAUG;AACH,MAAM,MAAM,gBAAgB,CAC1B,CAAC,SAAS,yBAAyB,CAAC,CAAC,CAAC,EACtC,CAAC,SAAS,WAAW,GAAG,WAAW,IACjC,CAAC,GAAG;IAAE,YAAY,EAAE,CAAC,EAAE,CAAA;CAAE,CAAC;AAE9B,MAAM,CAAC,OAAO,CAAC,QAAQ,OAAO,yBAAyB,CAAC,CAAC,SAAS,WAAW,CAAE,SAAQ,UAAU;IAC/F,SAAS,CAAC,QAAQ,CAAC,QAAQ,CAAC,mBAAmB,EAAE,MAAM,EAAE,CAAC;IAC1D,SAAS,CAAC,QAAQ,CAAC,YAAY,EAAE,CAAC,EAAE,CAAC;IACrC,SAAS,CAAC,UAAU,CAClB,UAAU,CAAC,EAAE;QACX,KAAK,CAAC,EAAE,MAAM,CAAC;QACf,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,cAAc,CAAC,EAAE,MAAM,CAAC;KACzB,EACD,kBAAkB,CAAC,EAAE;QACnB,mBAAmB,CAAC,EAAE,MAAM,EAAE,CAAC;KAChC,GACA,cAAc;IACjB,SAAS,CAAC,eAAe,IAAI,sBAAsB,EAAE;IACrD,SAAS,CAAC,gBAAgB,IAAI,cAAc;CAC7C;AAGD,eAAO,MAAM,qBAAqB,GAChC,CAAC,SAAS,WAAW,EACrB,CAAC,SAAS,mBAAmB,CAAC,UAAU,CAAC,GAAG,qBAAqB,EAEjE,YAAY,CAAC,KACZ,mBAAmB,CAAC,yBAAyB,CAAC,CAAC,CAAC,CAAC,GAAG,CAkJtD,CAAC"}
@@ -20,7 +20,6 @@ var SbbNamedSlotListMixin = (superClass) => {
20
20
  if (listChildren.length === this.listChildren.length && this.listChildren.every((e, i) => listChildren[i] === e)) return;
21
21
  this.listChildren.filter((c) => !listChildren.includes(c)).forEach((c) => c.removeAttribute("slot"));
22
22
  this.listChildren = listChildren;
23
- this.listChildren.forEach((c, index) => c.setAttribute("slot", `${SLOTNAME_PREFIX}-${index}`));
24
23
  this.removeAttribute(SSR_CHILD_COUNT_ATTRIBUTE);
25
24
  });
26
25
  }
@@ -71,6 +70,10 @@ var SbbNamedSlotListMixin = (superClass) => {
71
70
  super.disconnectedCallback();
72
71
  this.shadowRoot?.removeEventListener("slotchange", this._handleSlotchange);
73
72
  }
73
+ updated(changedProperties) {
74
+ super.updated(changedProperties);
75
+ if (changedProperties.has("listChildren")) this.listChildren.forEach((c, index) => c.setAttribute("slot", `${SLOTNAME_PREFIX}-${index}`));
76
+ }
74
77
  /**
75
78
  * Renders list and list slots for slotted children or a number of list slots
76
79
  * corresponding to the `data-ssr-child-count` attribute value.
@@ -134,4 +137,4 @@ var SbbNamedSlotListMixin = (superClass) => {
134
137
  //#endregion
135
138
  export { SbbNamedSlotListMixin };
136
139
 
137
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"named-slot-list-mixin.js","names":[],"sources":["../../../../../src/elements/core/mixins/named-slot-list-mixin.ts"],"sourcesContent":["import { html, nothing, type TemplateResult } from 'lit';\nimport { state } from 'lit/decorators.js';\n\nimport type {\n  SbbElement,\n  SbbElementConstructor,\n  SbbElementType,\n} from '../base-elements/element.ts';\nimport { SbbScreenReaderOnlyElement } from '../screen-reader-only/screen-reader-only.component.ts';\n\nimport type { AbstractConstructor } from './constructor.ts';\n\nconst SSR_CHILD_COUNT_ATTRIBUTE = 'data-ssr-child-count';\nconst SLOTNAME_PREFIX = 'li';\n\nexport interface SbbNamedSlotProperties {\n  name: string;\n  ariaHidden: boolean;\n}\n\n/**\n * Helper type for willUpdate or similar checks.\n * Allows the usage of the string literal 'listChildren'.\n *\n * @example\n * protected override willUpdate(changedProperties: PropertyValues<WithListChildren<this>>): void {\n *   if (changedProperties.has('listChildren')) {\n *     ...\n *   }\n * }\n */\nexport type WithListChildren<\n  T extends SbbNamedSlotListMixinType<C>,\n  C extends HTMLElement = HTMLElement,\n> = T & { listChildren: C[] };\n\nexport declare abstract class SbbNamedSlotListMixinType<C extends HTMLElement> extends SbbElement {\n  protected abstract readonly listChildLocalNames: string[];\n  protected accessor listChildren: C[];\n  protected renderList(\n    attributes?: {\n      class?: string;\n      ariaLabel?: string;\n      ariaLabelledby?: string;\n    },\n    listItemAttributes?: {\n      localNameVisualOnly?: string[];\n    },\n  ): TemplateResult;\n  protected listSlotEntries(): SbbNamedSlotProperties[];\n  protected renderHiddenSlot(): TemplateResult;\n}\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbNamedSlotListMixin = <\n  C extends HTMLElement,\n  T extends AbstractConstructor<SbbElement> & SbbElementConstructor,\n>(\n  superClass: T,\n): AbstractConstructor<SbbNamedSlotListMixinType<C>> & T => {\n  /**\n   * This base class provides named slot list observer functionality.\n   * This allows using the pattern of rendering a named slot for each child, which allows\n   * wrapping children in an ul/li list.\n   */\n  abstract class NamedSlotListElement\n    extends superClass\n    implements Partial<SbbNamedSlotListMixinType<C>>\n  {\n    public static override elementDependencies: SbbElementType[] = [SbbScreenReaderOnlyElement];\n    /** A list of lower-cased tag names to match against. (e.g. `sbb-link`) */\n    protected abstract readonly listChildLocalNames: string[];\n\n    /**\n     * A list of children with the defined tag names.\n     * This array is only updated if there is an actual change\n     * to the child elements.\n     */\n    @state() protected accessor listChildren: C[] = [];\n\n    public override connectedCallback(): void {\n      super.connectedCallback();\n      this.shadowRoot?.addEventListener('slotchange', this._handleSlotchange, { passive: true });\n    }\n\n    public override disconnectedCallback(): void {\n      super.disconnectedCallback();\n      this.shadowRoot?.removeEventListener('slotchange', this._handleSlotchange);\n    }\n\n    private _handleSlotchange = (): void => {\n      const listChildren = Array.from(this.children ?? []).filter((e): e is C =>\n        this.listChildLocalNames.includes(e.localName),\n      );\n      // If the slotted child instances have not changed, we can skip syncing and updating\n      // the link reference list.\n      if (\n        listChildren.length === this.listChildren.length &&\n        this.listChildren.every((e, i) => listChildren[i] === e)\n      ) {\n        return;\n      }\n\n      this.listChildren\n        .filter((c) => !listChildren.includes(c))\n        .forEach((c) => c.removeAttribute('slot'));\n      this.listChildren = listChildren;\n      this.listChildren.forEach((c, index) =>\n        c.setAttribute('slot', `${SLOTNAME_PREFIX}-${index}`),\n      );\n\n      // Remove the ssr attribute, once we have actually initialized the children elements.\n      this.removeAttribute(SSR_CHILD_COUNT_ATTRIBUTE);\n    };\n\n    /**\n     * Renders list and list slots for slotted children or a number of list slots\n     * corresponding to the `data-ssr-child-count` attribute value.\n     *\n     * This is a possible optimization for SSR, as in an SSR Lit environment\n     * other elements are not available, but might be available in the meta\n     * framework wrapper (like e.g. React). This allows to provide the number of\n     * children to be passed via the `data-ssr-child-count` attribute value.\n     */\n    protected renderList(\n      attributes: { class?: string; ariaLabel?: string; ariaLabelledby?: string } = {},\n      listItemAttributes: { localNameVisualOnly?: string[] } = {},\n    ): TemplateResult {\n      const listSlotNames: SbbNamedSlotProperties[] = this.listSlotEntries(listItemAttributes);\n\n      if (listSlotNames.length >= 2) {\n        return html`\n          <ul\n            class=${attributes.class || this.localName}\n            aria-label=${attributes.ariaLabel || nothing}\n            aria-labelledby=${attributes.ariaLabelledby || nothing}\n          >\n            ${listSlotNames.map(\n              (slot) => html`\n                <li aria-hidden=${slot.ariaHidden || nothing}>\n                  <slot name=${slot.name}></slot>\n                </li>\n              `,\n            )}\n          </ul>\n          ${this.renderHiddenSlot()}\n        `;\n      } else if (listSlotNames.length === 1) {\n        return html`<sbb-screen-reader-only>${attributes.ariaLabel}</sbb-screen-reader-only>\n          <span class=${attributes.class || this.localName}>\n            <span><slot name=${listSlotNames[0].name}></slot></span>\n          </span>\n          ${this.renderHiddenSlot()} `;\n      } else {\n        return this.renderHiddenSlot();\n      }\n    }\n\n    /**\n     * Returns an array of SbbNamedSlotProperties, which holds the list slot names and the hidden property;\n     * its length corresponds to the number of matched children or the `data-ssr-child-count` attribute value.\n     *\n     * This is a possible optimization for SSR, as in an SSR Lit environment\n     * other elements are not available, but might be available in the meta\n     * framework wrapper (like e.g. React). This allows to provide the number of\n     * children to be passed via the `data-ssr-child-count` attribute value.\n     */\n    protected listSlotEntries(listItemAttributes: {\n      localNameVisualOnly?: string[];\n    }): SbbNamedSlotProperties[] {\n      const listChildren = this.listChildren.length\n        ? this.listChildren\n        : Array.from({ length: +(this.getAttribute(SSR_CHILD_COUNT_ATTRIBUTE) ?? 0) });\n      return listChildren.map((e, i) => {\n        return {\n          name: `${SLOTNAME_PREFIX}-${i}`,\n          ariaHidden:\n            listItemAttributes?.localNameVisualOnly?.includes((e as HTMLElement).localName) ??\n            false,\n        };\n      });\n    }\n\n    /**\n     * Returns a hidden slot, which is intended as the children change detection.\n     * When an element without a slot attribute is slotted to the element, it triggers\n     * the slotchange event, which can be used to assign it to the appropriate named slot.\n     */\n    protected renderHiddenSlot(): TemplateResult {\n      return html`<span hidden><slot></slot></span>`;\n    }\n  }\n\n  return NamedSlotListElement as unknown as AbstractConstructor<SbbNamedSlotListMixinType<C>> & T;\n};\n"],"mappings":";;;;;AAYA,IAAM,4BAA4B;AAClC,IAAM,kBAAkB;AAyCxB,IAAa,yBAIX,eACyD;AAsIzD,eAhImC;oBACzB;;;;eADK,6BACL,YAAU;;;AAYU,UAAA,gCAAA,kBAAA,MAAA,4BAAoB,EAAE,CAAA;AAY1C,SAAA,qBAAiB,kBAAA,MAAA,gCAAA,QAAc;KACrC,MAAM,eAAe,MAAM,KAAK,KAAK,YAAY,EAAE,CAAC,CAAC,QAAQ,MAC3D,KAAK,oBAAoB,SAAS,EAAE,UAAU,CAC/C;AAGD,SACE,aAAa,WAAW,KAAK,aAAa,UAC1C,KAAK,aAAa,OAAO,GAAG,MAAM,aAAa,OAAO,EAAE,CAExD;AAGF,UAAK,aACF,QAAQ,MAAM,CAAC,aAAa,SAAS,EAAE,CAAC,CACxC,SAAS,MAAM,EAAE,gBAAgB,OAAO,CAAC;AAC5C,UAAK,eAAe;AACpB,UAAK,aAAa,SAAS,GAAG,UAC5B,EAAE,aAAa,QAAQ,GAAG,gBAAe,GAAI,QAAQ,CACtD;AAGD,UAAK,gBAAgB,0BAA0B;;;;;gCAlChD,OAAO,CAAA;AAAC,iBAAA,MAAA,MAAA,0BAAA;KAAA,MAAA;KAAA,MAAA;KAAA,QAAA;KAAA,SAAA;KAAA,QAAA;MAAA,MAAA,QAAA,kBAAA;MAAA,MAAA,QAAA,IAAmB;MAAY,MAAA,KAAA,UAAA;AAAA,WAAZ,eAAY;;MAAA;KAAA,UAAA;KAAA,EAAA,4BAAA,gCAAA;;;;;;;;;AATjB,SAAA,sBAAwC,CAAC,2BAA2B;;GASlF;;;;;;GAAA,IAAmB,eAAY;AAAA,WAAA,MAAA;;GAA/B,IAAmB,aAAY,OAAA;AAAA,UAAA,gCAAA;;GAExB,oBAAiB;AAC/B,UAAM,mBAAmB;AACzB,SAAK,YAAY,iBAAiB,cAAc,KAAK,mBAAmB,EAAE,SAAS,MAAM,CAAC;;GAG5E,uBAAoB;AAClC,UAAM,sBAAsB;AAC5B,SAAK,YAAY,oBAAoB,cAAc,KAAK,kBAAkB;;;;;;;;;;;GAqClE,WACR,aAA8E,EAAE,EAChF,qBAAyD,EAAE,EAAA;IAE3D,MAAM,gBAA0C,KAAK,gBAAgB,mBAAmB;AAExF,QAAI,cAAc,UAAU,EAC1B,QAAO,IAAI;;oBAEC,WAAW,SAAS,KAAK,UAAA;yBACpB,WAAW,aAAa,QAAA;8BACnB,WAAW,kBAAkB,QAAA;;cAE7C,cAAc,KACb,SAAS,IAAI;kCACM,KAAK,cAAc,QAAO;+BAC7B,KAAK,KAAI;;gBAG3B,CAAA;;YAED,KAAK,kBAAkB,CAAA;;aAElB,cAAc,WAAW,EAClC,QAAO,IAAI,2BAA2B,WAAW,UAAS;wBAC1C,WAAW,SAAS,KAAK,UAAS;+BAC3B,cAAc,GAAG,KAAI;;YAExC,KAAK,kBAAkB,CAAA;QAE3B,QAAO,KAAK,kBAAkB;;;;;;;;;;;GAaxB,gBAAgB,oBAEzB;AAIC,YAHqB,KAAK,aAAa,SACnC,KAAK,eACL,MAAM,KAAK,EAAE,QAAQ,EAAE,KAAK,aAAa,0BAA0B,IAAI,IAAI,CAAC,EAC5D,KAAK,GAAG,MAAK;AAC/B,YAAO;MACL,MAAM,GAAG,gBAAe,GAAI;MAC5B,YACE,oBAAoB,qBAAqB,SAAU,EAAkB,UAAU,IAC/E;MACH;MACD;;;;;;;GAQM,mBAAgB;AACxB,WAAO,IAAI"}
140
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"named-slot-list-mixin.js","names":[],"sources":["../../../../../src/elements/core/mixins/named-slot-list-mixin.ts"],"sourcesContent":["import { html, nothing, type PropertyValues, type TemplateResult } from 'lit';\nimport { state } from 'lit/decorators.js';\n\nimport type {\n  SbbElement,\n  SbbElementConstructor,\n  SbbElementType,\n} from '../base-elements/element.ts';\nimport { SbbScreenReaderOnlyElement } from '../screen-reader-only/screen-reader-only.component.ts';\n\nimport type { AbstractConstructor } from './constructor.ts';\n\nconst SSR_CHILD_COUNT_ATTRIBUTE = 'data-ssr-child-count';\nconst SLOTNAME_PREFIX = 'li';\n\nexport interface SbbNamedSlotProperties {\n  name: string;\n  ariaHidden: boolean;\n}\n\n/**\n * Helper type for willUpdate or similar checks.\n * Allows the usage of the string literal 'listChildren'.\n *\n * @example\n * protected override willUpdate(changedProperties: PropertyValues<WithListChildren<this>>): void {\n *   if (changedProperties.has('listChildren')) {\n *     ...\n *   }\n * }\n */\nexport type WithListChildren<\n  T extends SbbNamedSlotListMixinType<C>,\n  C extends HTMLElement = HTMLElement,\n> = T & { listChildren: C[] };\n\nexport declare abstract class SbbNamedSlotListMixinType<C extends HTMLElement> extends SbbElement {\n  protected abstract readonly listChildLocalNames: string[];\n  protected accessor listChildren: C[];\n  protected renderList(\n    attributes?: {\n      class?: string;\n      ariaLabel?: string;\n      ariaLabelledby?: string;\n    },\n    listItemAttributes?: {\n      localNameVisualOnly?: string[];\n    },\n  ): TemplateResult;\n  protected listSlotEntries(): SbbNamedSlotProperties[];\n  protected renderHiddenSlot(): TemplateResult;\n}\n\n// eslint-disable-next-line @typescript-eslint/naming-convention\nexport const SbbNamedSlotListMixin = <\n  C extends HTMLElement,\n  T extends AbstractConstructor<SbbElement> & SbbElementConstructor,\n>(\n  superClass: T,\n): AbstractConstructor<SbbNamedSlotListMixinType<C>> & T => {\n  /**\n   * This base class provides named slot list observer functionality.\n   * This allows using the pattern of rendering a named slot for each child, which allows\n   * wrapping children in an ul/li list.\n   */\n  abstract class NamedSlotListElement\n    extends superClass\n    implements Partial<SbbNamedSlotListMixinType<C>>\n  {\n    public static override elementDependencies: SbbElementType[] = [SbbScreenReaderOnlyElement];\n    /** A list of lower-cased tag names to match against. (e.g. `sbb-link`) */\n    protected abstract readonly listChildLocalNames: string[];\n\n    /**\n     * A list of children with the defined tag names.\n     * This array is only updated if there is an actual change\n     * to the child elements.\n     */\n    @state() protected accessor listChildren: C[] = [];\n\n    public override connectedCallback(): void {\n      super.connectedCallback();\n      this.shadowRoot?.addEventListener('slotchange', this._handleSlotchange, { passive: true });\n    }\n\n    public override disconnectedCallback(): void {\n      super.disconnectedCallback();\n      this.shadowRoot?.removeEventListener('slotchange', this._handleSlotchange);\n    }\n\n    private _handleSlotchange = (): void => {\n      const listChildren = Array.from(this.children ?? []).filter((e): e is C =>\n        this.listChildLocalNames.includes(e.localName),\n      );\n      // If the slotted child instances have not changed, we can skip syncing and updating\n      // the link reference list.\n      if (\n        listChildren.length === this.listChildren.length &&\n        this.listChildren.every((e, i) => listChildren[i] === e)\n      ) {\n        return;\n      }\n\n      this.listChildren\n        .filter((c) => !listChildren.includes(c))\n        .forEach((c) => c.removeAttribute('slot'));\n      this.listChildren = listChildren;\n\n      // Remove the ssr attribute, once we have actually initialized the children elements.\n      this.removeAttribute(SSR_CHILD_COUNT_ATTRIBUTE);\n    };\n\n    protected override updated(\n      changedProperties: PropertyValues<this & { listChildren: C[] }>,\n    ): void {\n      super.updated(changedProperties);\n\n      if (changedProperties.has('listChildren')) {\n        // If you assign a slot attribute without a corresponding slot element,\n        // it is not fully part of the DOM and e.g. media queries will fail.\n        this.listChildren.forEach((c, index) =>\n          c.setAttribute('slot', `${SLOTNAME_PREFIX}-${index}`),\n        );\n      }\n    }\n\n    /**\n     * Renders list and list slots for slotted children or a number of list slots\n     * corresponding to the `data-ssr-child-count` attribute value.\n     *\n     * This is a possible optimization for SSR, as in an SSR Lit environment\n     * other elements are not available, but might be available in the meta\n     * framework wrapper (like e.g. React). This allows to provide the number of\n     * children to be passed via the `data-ssr-child-count` attribute value.\n     */\n    protected renderList(\n      attributes: { class?: string; ariaLabel?: string; ariaLabelledby?: string } = {},\n      listItemAttributes: { localNameVisualOnly?: string[] } = {},\n    ): TemplateResult {\n      const listSlotNames: SbbNamedSlotProperties[] = this.listSlotEntries(listItemAttributes);\n\n      if (listSlotNames.length >= 2) {\n        return html`\n          <ul\n            class=${attributes.class || this.localName}\n            aria-label=${attributes.ariaLabel || nothing}\n            aria-labelledby=${attributes.ariaLabelledby || nothing}\n          >\n            ${listSlotNames.map(\n              (slot) => html`\n                <li aria-hidden=${slot.ariaHidden || nothing}>\n                  <slot name=${slot.name}></slot>\n                </li>\n              `,\n            )}\n          </ul>\n          ${this.renderHiddenSlot()}\n        `;\n      } else if (listSlotNames.length === 1) {\n        return html`<sbb-screen-reader-only>${attributes.ariaLabel}</sbb-screen-reader-only>\n          <span class=${attributes.class || this.localName}>\n            <span><slot name=${listSlotNames[0].name}></slot></span>\n          </span>\n          ${this.renderHiddenSlot()} `;\n      } else {\n        return this.renderHiddenSlot();\n      }\n    }\n\n    /**\n     * Returns an array of SbbNamedSlotProperties, which holds the list slot names and the hidden property;\n     * its length corresponds to the number of matched children or the `data-ssr-child-count` attribute value.\n     *\n     * This is a possible optimization for SSR, as in an SSR Lit environment\n     * other elements are not available, but might be available in the meta\n     * framework wrapper (like e.g. React). This allows to provide the number of\n     * children to be passed via the `data-ssr-child-count` attribute value.\n     */\n    protected listSlotEntries(listItemAttributes: {\n      localNameVisualOnly?: string[];\n    }): SbbNamedSlotProperties[] {\n      const listChildren = this.listChildren.length\n        ? this.listChildren\n        : Array.from({ length: +(this.getAttribute(SSR_CHILD_COUNT_ATTRIBUTE) ?? 0) });\n      return listChildren.map((e, i) => {\n        return {\n          name: `${SLOTNAME_PREFIX}-${i}`,\n          ariaHidden:\n            listItemAttributes?.localNameVisualOnly?.includes((e as HTMLElement).localName) ??\n            false,\n        };\n      });\n    }\n\n    /**\n     * Returns a hidden slot, which is intended as the children change detection.\n     * When an element without a slot attribute is slotted to the element, it triggers\n     * the slotchange event, which can be used to assign it to the appropriate named slot.\n     */\n    protected renderHiddenSlot(): TemplateResult {\n      return html`<span hidden><slot></slot></span>`;\n    }\n  }\n\n  return NamedSlotListElement as unknown as AbstractConstructor<SbbNamedSlotListMixinType<C>> & T;\n};\n"],"mappings":";;;;;AAYA,IAAM,4BAA4B;AAClC,IAAM,kBAAkB;AAyCxB,IAAa,yBAIX,eACyD;AAiJzD,eA3ImC;oBACzB;;;;eADK,6BACL,YAAU;;;AAYU,UAAA,gCAAA,kBAAA,MAAA,4BAAoB,EAAE,CAAA;AAY1C,SAAA,qBAAiB,kBAAA,MAAA,gCAAA,QAAc;KACrC,MAAM,eAAe,MAAM,KAAK,KAAK,YAAY,EAAE,CAAC,CAAC,QAAQ,MAC3D,KAAK,oBAAoB,SAAS,EAAE,UAAU,CAC/C;AAGD,SACE,aAAa,WAAW,KAAK,aAAa,UAC1C,KAAK,aAAa,OAAO,GAAG,MAAM,aAAa,OAAO,EAAE,CAExD;AAGF,UAAK,aACF,QAAQ,MAAM,CAAC,aAAa,SAAS,EAAE,CAAC,CACxC,SAAS,MAAM,EAAE,gBAAgB,OAAO,CAAC;AAC5C,UAAK,eAAe;AAGpB,UAAK,gBAAgB,0BAA0B;;;;;gCA/BhD,OAAO,CAAA;AAAC,iBAAA,MAAA,MAAA,0BAAA;KAAA,MAAA;KAAA,MAAA;KAAA,QAAA;KAAA,SAAA;KAAA,QAAA;MAAA,MAAA,QAAA,kBAAA;MAAA,MAAA,QAAA,IAAmB;MAAY,MAAA,KAAA,UAAA;AAAA,WAAZ,eAAY;;MAAA;KAAA,UAAA;KAAA,EAAA,4BAAA,gCAAA;;;;;;;;;AATjB,SAAA,sBAAwC,CAAC,2BAA2B;;GASlF;;;;;;GAAA,IAAmB,eAAY;AAAA,WAAA,MAAA;;GAA/B,IAAmB,aAAY,OAAA;AAAA,UAAA,gCAAA;;GAExB,oBAAiB;AAC/B,UAAM,mBAAmB;AACzB,SAAK,YAAY,iBAAiB,cAAc,KAAK,mBAAmB,EAAE,SAAS,MAAM,CAAC;;GAG5E,uBAAoB;AAClC,UAAM,sBAAsB;AAC5B,SAAK,YAAY,oBAAoB,cAAc,KAAK,kBAAkB;;GAyBzD,QACjB,mBAA+D;AAE/D,UAAM,QAAQ,kBAAkB;AAEhC,QAAI,kBAAkB,IAAI,eAAe,CAGvC,MAAK,aAAa,SAAS,GAAG,UAC5B,EAAE,aAAa,QAAQ,GAAG,gBAAe,GAAI,QAAQ,CACtD;;;;;;;;;;;GAaK,WACR,aAA8E,EAAE,EAChF,qBAAyD,EAAE,EAAA;IAE3D,MAAM,gBAA0C,KAAK,gBAAgB,mBAAmB;AAExF,QAAI,cAAc,UAAU,EAC1B,QAAO,IAAI;;oBAEC,WAAW,SAAS,KAAK,UAAA;yBACpB,WAAW,aAAa,QAAA;8BACnB,WAAW,kBAAkB,QAAA;;cAE7C,cAAc,KACb,SAAS,IAAI;kCACM,KAAK,cAAc,QAAO;+BAC7B,KAAK,KAAI;;gBAG3B,CAAA;;YAED,KAAK,kBAAkB,CAAA;;aAElB,cAAc,WAAW,EAClC,QAAO,IAAI,2BAA2B,WAAW,UAAS;wBAC1C,WAAW,SAAS,KAAK,UAAS;+BAC3B,cAAc,GAAG,KAAI;;YAExC,KAAK,kBAAkB,CAAA;QAE3B,QAAO,KAAK,kBAAkB;;;;;;;;;;;GAaxB,gBAAgB,oBAEzB;AAIC,YAHqB,KAAK,aAAa,SACnC,KAAK,eACL,MAAM,KAAK,EAAE,QAAQ,EAAE,KAAK,aAAa,0BAA0B,IAAI,IAAI,CAAC,EAC5D,KAAK,GAAG,MAAK;AAC/B,YAAO;MACL,MAAM,GAAG,gBAAe,GAAI;MAC5B,YACE,oBAAoB,qBAAqB,SAAU,EAAkB,UAAU,IAC/E;MACH;MACD;;;;;;;GAQM,mBAAgB;AACxB,WAAO,IAAI"}
package/package.json CHANGED
@@ -1,12 +1,12 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-elements-dev",
3
- "version": "5.0.0-next-dev.1776332654",
3
+ "version": "5.0.0-next-dev.1776353458",
4
4
  "description": "Lyne Design System",
5
5
  "keywords": [
6
6
  "design system",
7
7
  "web components",
8
8
  "lit",
9
- "https://github.com/sbb-design-systems/lyne-components/commit/8196ec523084c0e6674449e1fcea701e85a9f3cf"
9
+ "https://github.com/sbb-design-systems/lyne-components/commit/74ff19ab002cd406add06e532794be098e1db300"
10
10
  ],
11
11
  "type": "module",
12
12
  "exports": {