@sbb-esta/lyne-elements-dev 4.11.0-dev.1776332009 → 4.11.0-dev.1776360524

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.
@@ -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,EAAQ,KAAK,UAAU,EAAW,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAG1E,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAC5D,OAAO,EAAqB,KAAK,qBAAqB,EAAE,MAAM,sBAAsB,CAAC;AAErF,OAAO,6BAA6B,CAAC;AAKrC,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,CACrD,CAAC,SAAS,WAAW,CACrB,SAAQ,qBAAqB;IAC7B,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,EAEzC,YAAY,CAAC,KACZ,mBAAmB,CAAC,yBAAyB,CAAC,CAAC,CAAC,CAAC,GAAG,CA2ItD,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,EAAQ,KAAK,UAAU,EAAgC,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAG/F,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,kBAAkB,CAAC;AAC5D,OAAO,EAAqB,KAAK,qBAAqB,EAAE,MAAM,sBAAsB,CAAC;AAErF,OAAO,6BAA6B,CAAC;AAKrC,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,CACrD,CAAC,SAAS,WAAW,CACrB,SAAQ,qBAAqB;IAC7B,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,EAEzC,YAAY,CAAC,KACZ,mBAAmB,CAAC,yBAAyB,CAAC,CAAC,CAAC,CAAC,GAAG,CAsJtD,CAAC"}
@@ -22,7 +22,6 @@ var SbbNamedSlotListMixin = (superClass) => {
22
22
  if (listChildren.length === this.listChildren.length && this.listChildren.every((e, i) => listChildren[i] === e)) return;
23
23
  this.listChildren.filter((c) => !listChildren.includes(c)).forEach((c) => c.removeAttribute("slot"));
24
24
  this.listChildren = listChildren;
25
- this.listChildren.forEach((c, index) => c.setAttribute("slot", `${SLOTNAME_PREFIX}-${index}`));
26
25
  this.removeAttribute(SSR_CHILD_COUNT_ATTRIBUTE);
27
26
  });
28
27
  }
@@ -70,6 +69,10 @@ var SbbNamedSlotListMixin = (superClass) => {
70
69
  super.disconnectedCallback();
71
70
  this.shadowRoot?.removeEventListener("slotchange", this._handleSlotchange);
72
71
  }
72
+ updated(changedProperties) {
73
+ super.updated(changedProperties);
74
+ if (changedProperties.has("listChildren")) this.listChildren.forEach((c, index) => c.setAttribute("slot", `${SLOTNAME_PREFIX}-${index}`));
75
+ }
73
76
  /**
74
77
  * Renders list and list slots for slotted children or a number of list slots
75
78
  * corresponding to the `data-ssr-child-count` attribute value.
@@ -133,4 +136,4 @@ var SbbNamedSlotListMixin = (superClass) => {
133
136
  //#endregion
134
137
  export { SbbNamedSlotListMixin };
135
138
 
136
- //# 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, type LitElement, nothing, type TemplateResult } from 'lit';\nimport { state } from 'lit/decorators.js';\n\nimport type { AbstractConstructor } from './constructor.ts';\nimport { SbbHydrationMixin, type SbbHydrationMixinType } from './hydration-mixin.ts';\n\nimport '../../screen-reader-only.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<\n  C extends HTMLElement,\n> extends SbbHydrationMixinType {\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<LitElement>,\n>(\n  superClass: T,\n): AbstractConstructor<SbbNamedSlotListMixinType<C>> & T => {\n  // TODO(breaking-change): Remove SbbElementInternalsMixin and depend on SbbElement as base class instead of LitElement\n  const conditionalSuperClass = (superClass as unknown as Record<string, unknown>)['_$sbbElement$']\n    ? (superClass as unknown as AbstractConstructor<SbbHydrationMixinType> & T)\n    : SbbHydrationMixin(superClass);\n\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<C extends HTMLElement = HTMLElement>\n    extends conditionalSuperClass\n    implements Partial<SbbNamedSlotListMixinType<C>>\n  {\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":";;;;;;AAQA,IAAM,4BAA4B;AAClC,IAAM,kBAAkB;AA2CxB,IAAa,yBAIX,eACyD;CAEzD,MAAM,wBAAyB,WAAkD,mBAC5E,aACD,kBAAkB,WAAW;AAsIjC,eA/HmC;oBACzB;;;;eADK,6BACL,YAAqB;;;AAWD,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;;;;;;;;GAA/B;;;;;;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"}
139
+ //# 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, type LitElement, nothing, type PropertyValues, type TemplateResult } from 'lit';\nimport { state } from 'lit/decorators.js';\n\nimport type { AbstractConstructor } from './constructor.ts';\nimport { SbbHydrationMixin, type SbbHydrationMixinType } from './hydration-mixin.ts';\n\nimport '../../screen-reader-only.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<\n  C extends HTMLElement,\n> extends SbbHydrationMixinType {\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<LitElement>,\n>(\n  superClass: T,\n): AbstractConstructor<SbbNamedSlotListMixinType<C>> & T => {\n  // TODO(breaking-change): Remove SbbElementInternalsMixin and depend on SbbElement as base class instead of LitElement\n  const conditionalSuperClass = (superClass as unknown as Record<string, unknown>)['_$sbbElement$']\n    ? (superClass as unknown as AbstractConstructor<SbbHydrationMixinType> & T)\n    : SbbHydrationMixin(superClass);\n\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<C extends HTMLElement = HTMLElement>\n    extends conditionalSuperClass\n    implements Partial<SbbNamedSlotListMixinType<C>>\n  {\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":";;;;;;AAQA,IAAM,4BAA4B;AAClC,IAAM,kBAAkB;AA2CxB,IAAa,yBAIX,eACyD;CAEzD,MAAM,wBAAyB,WAAkD,mBAC5E,aACD,kBAAkB,WAAW;AAiJjC,eA1ImC;oBACzB;;;;eADK,6BACL,YAAqB;;;AAWD,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;;;;;;;;GAA/B;;;;;;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": "4.11.0-dev.1776332009",
3
+ "version": "4.11.0-dev.1776360524",
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/b573cbffa3cab6ddee5eb6555ce548ba81e0d94b"
9
+ "https://github.com/sbb-design-systems/lyne-components/commit/f2d35bdd343d2b92616974fb032af6af027f6df3"
10
10
  ],
11
11
  "type": "module",
12
12
  "exports": {