@sbb-esta/lyne-react-dev 5.0.0-next.2-dev.1778141171 → 5.0.0-next.2-dev.1778145574

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.
@@ -139,4 +139,4 @@ var createComponent = ({ react: React, tagName, elementClass, events, displayNam
139
139
  //#endregion
140
140
  export { createComponent };
141
141
 
142
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"create-component.js","names":[],"sources":["../../../../src/react/core/create-component.ts"],"sourcesContent":["/* eslint-disable\n  @typescript-eslint/explicit-function-return-type,\n  @typescript-eslint/naming-convention,\n  @typescript-eslint/naming-convention,\n  @typescript-eslint/no-empty-object-type,\n  import-x/no-named-as-default-member,\n*/\n/**\n * Copied from https://github.com/lit/lit/blob/main/packages/react/src/create-component.ts\n * TODO: Can be removed once https://github.com/lit/lit/issues/4023 or https://github.com/lit/lit/pull/4476 is solved.\n *\n * @license\n * Copyright 2018 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\n\nimport type { SbbElement } from '@sbb-esta/lyne-elements/core.js';\nimport {\n  type ComplexAttributeConverter,\n  isServer,\n  type PropertyDeclaration,\n  type ReactiveElement,\n} from 'lit';\nimport type React from 'react';\n\nconst NODE_MODE = isServer;\nconst DEV_MODE = import.meta.env.DEV;\n\ntype DistributiveOmit<T, K extends string | number | symbol> = T extends any\n  ? K extends keyof T\n    ? Omit<T, K>\n    : T\n  : T;\ntype PropsWithoutRef<T> = DistributiveOmit<T, 'ref'>;\n\n/**\n * Creates a type to be used for the props of a web component used directly in\n * React JSX.\n *\n * Example:\n *\n * ```ts\n * declare module \"react\" {\n *   namespace JSX {\n *     interface IntrinsicElements {\n *       'x-foo': WebComponentProps<XFoo>;\n *     }\n *   }\n * }\n * ```\n */\nexport type WebComponentProps<I extends HTMLElement> = React.DetailedHTMLProps<\n  React.HTMLAttributes<I>,\n  I\n> &\n  ElementProps<I>;\n\n/**\n * Type of the React component wrapping the web component. This is the return\n * type of `createComponent`.\n */\nexport type ReactWebComponent<\n  I extends HTMLElement,\n  E extends EventNames = {},\n> = React.ForwardRefExoticComponent<\n  // TODO(augustjk): Remove and use `React.PropsWithoutRef` when\n  // https://github.com/preactjs/preact/issues/4124 is fixed.\n  PropsWithoutRef<ComponentProps<I, E>> & React.RefAttributes<I>\n>;\n\n// Props derived from custom element class. Currently has limitations of making\n// all properties optional and also surfaces life cycle methods in autocomplete.\n// TODO(augustjk) Consider omitting keyof LitElement to remove \"internal\"\n// lifecycle methods or allow user to explicitly provide props.\ntype ElementProps<I> = Partial<Omit<I, keyof HTMLElement>>;\n\n// Acceptable props to the React component.\ntype ComponentProps<I, E extends EventNames = {}> = Omit<\n  React.HTMLAttributes<I>,\n  // Prefer type of provided event handler props or those on element over\n  // built-in HTMLAttributes\n  keyof E | keyof ElementProps<I>\n> &\n  EventListeners<E> &\n  ElementProps<I>;\n\n/**\n * Type used to cast an event name with an event type when providing the\n * `events` option to `createComponent` for better typing of the event handler\n * prop.\n *\n * Example:\n *\n * ```ts\n * const FooComponent = createComponent({\n *   ...\n *   events: {\n *     onfoo: 'foo' as EventName<FooEvent>,\n *   }\n * });\n * ```\n *\n * `onfoo` prop will have the type `(e: FooEvent) => void`.\n */\nexport type EventName<T extends Event = Event> = string & {\n  __eventType: T;\n};\n\n// A key value map matching React prop names to event names.\ntype EventNames = Record<string, EventName | string>;\n\n// A map of expected event listener types based on EventNames.\ntype EventListeners<R extends EventNames> = {\n  [K in keyof R]?: R[K] extends EventName ? (e: R[K]['__eventType']) => void : (e: Event) => void;\n};\n\nexport interface Options<I extends HTMLElement, E extends EventNames = {}> {\n  react: typeof React;\n  tagName: string;\n  elementClass: Constructor<I>;\n  events?: E;\n  displayName?: string;\n}\n\ninterface Constructor<T> {\n  new (): T;\n}\n\nconst reservedReactProperties = new Set([\n  'children',\n  'localName',\n  'ref',\n  'style',\n  'className',\n  'id',\n]);\n\nconst listenedEvents = new WeakMap<Element, Map<string, EventListenerObject>>();\n\n/**\n * Adds an event listener for the specified event to the given node. In the\n * React setup, there should only ever be one event listener. Thus, for\n * efficiency only one listener is added and the handler for that listener is\n * updated to point to the given listener function.\n */\nconst addOrUpdateEventListener = (\n  node: Element,\n  event: string,\n  listener: (event?: Event) => void,\n) => {\n  let events = listenedEvents.get(node);\n  if (events === undefined) {\n    listenedEvents.set(node, (events = new Map()));\n  }\n  let handler = events.get(event);\n  if (listener !== undefined) {\n    // If necessary, add listener and track handler\n    if (handler === undefined) {\n      events.set(event, (handler = { handleEvent: listener }));\n      node.addEventListener(event, handler);\n      // Otherwise just update the listener with new value\n    } else {\n      handler.handleEvent = listener;\n    }\n    // Remove listener if one exists and value is undefined\n  } else if (handler !== undefined) {\n    events.delete(event);\n    node.removeEventListener(event, handler);\n  }\n};\n\n/**\n * Sets properties and events on custom elements. These properties and events\n * have been pre-filtered so we know they should apply to the custom element.\n */\nconst setProperty = <E extends Element>(\n  node: E,\n  name: string,\n  value: unknown,\n  old: unknown,\n  events?: EventNames,\n) => {\n  const event = events?.[name];\n  // Dirty check event value.\n  if (event !== undefined) {\n    if (value !== old) {\n      addOrUpdateEventListener(node, event, value as (e?: Event) => void);\n    }\n    return;\n  }\n  // But don't dirty check properties; elements are assumed to do this.\n  node[name as keyof E] = value as E[keyof E];\n\n  // This block is to replicate React's behavior for attributes of native\n  // elements where `undefined` or `null` values result in attributes being\n  // removed.\n  // https://github.com/facebook/react/blob/899cb95f52cc83ab5ca1eb1e268c909d3f0961e7/packages/react-dom-bindings/src/client/DOMPropertyOperations.js#L107-L141\n  //\n  // It's only needed here for native HTMLElement properties that reflect\n  // attributes of the same name but don't have that behavior like \"id\" or\n  // \"draggable\".\n  if ((value === undefined || value === null) && name in HTMLElement.prototype) {\n    node.removeAttribute(name);\n  }\n};\n\n/**\n * Creates a React component for a custom element. Properties are distinguished\n * from attributes automatically, and events can be configured so they are added\n * to the custom element as event listeners.\n *\n * @param options An options bag containing the parameters needed to generate a\n * wrapped web component.\n *\n * @param options.react The React module, typically imported from the `react`\n * npm package.\n * @param options.tagName The custom element tag name registered via\n * `customElements.define`.\n * @param options.elementClass The custom element class registered via\n * `customElements.define`.\n * @param options.events An object listing events to which the component can\n * listen. The object keys are the event property names passed in via React\n * props and the object values are the names of the corresponding events\n * generated by the custom element. For example, given `{onactivate:\n * 'activate'}` an event function may be passed via the component's `onactivate`\n * prop and will be called when the custom element fires its `activate` event.\n * @param options.displayName A React component display name, used in debugging\n * messages. Default value is inferred from the name of custom element class\n * registered via `customElements.define`.\n */\nexport const createComponent = <I extends HTMLElement, E extends EventNames = {}>({\n  react: React,\n  tagName,\n  elementClass,\n  events,\n  displayName,\n}: Options<I, E>): ReactWebComponent<I, E> => {\n  // Next.js re-rendering somehow fails, because the finalization calculation\n  // is broken in SSR. We call `finalize()` here explicitly to avoid that.\n  (elementClass as unknown as typeof SbbElement)['finalize']?.();\n  (elementClass as unknown as typeof SbbElement).define?.();\n\n  const eventProps = new Set(Object.keys(events ?? {}));\n\n  if (DEV_MODE && !NODE_MODE) {\n    for (const p of reservedReactProperties) {\n      if (p in elementClass.prototype && !(p in HTMLElement.prototype)) {\n        // Note, this effectively warns only for `ref` since the other\n        // reserved props are on HTMLElement.prototype. To address this\n        // would require crawling down the prototype, which doesn't feel worth\n        // it since implementing these properties on an element is extremely\n        // rare.\n        console.warn(\n          `${tagName} contains property ${p} which is a React reserved ` +\n            `property. It will be used by React and not set on the element.`,\n        );\n      }\n    }\n  }\n\n  type Props = ComponentProps<I, E>;\n\n  const ReactComponent = React.forwardRef<I, Props>((props, ref) => {\n    const prevElemPropsRef = React.useRef(new Map());\n    const elementRef = React.useRef<I | null>(null);\n\n    // Props to be passed to React.createElement\n    const reactProps: Record<string, unknown> = {};\n    // Props to be set on element with setProperty\n    const elementProps: Record<string, unknown> = {};\n    // A map of element properties with meta information.\n    const elementProperties: Map<PropertyKey, PropertyDeclaration> | undefined = (\n      elementClass as unknown as typeof ReactiveElement\n    ).elementProperties;\n\n    for (const [k, v] of Object.entries(props)) {\n      if (reservedReactProperties.has(k)) {\n        // React does *not* handle `className` for custom elements so\n        // coerce it to `class` so it's handled correctly.\n        reactProps[k === 'className' ? 'class' : k] = v;\n        continue;\n      } else if (eventProps.has(k) || k in elementClass.prototype) {\n        const elementProperty = elementProperties?.get(k);\n        const toAttribute = (elementProperty?.converter as ComplexAttributeConverter)?.toAttribute;\n        if (\n          !elementProperty ||\n          elementProperty.attribute === false ||\n          (typeof v === 'object' && !toAttribute)\n        ) {\n          elementProps[k] = v;\n          continue;\n        }\n\n        const attributeName =\n          elementProperty.attribute === true ? k : elementProperty.attribute || k;\n        if (elementProperty.type !== Boolean) {\n          reactProps[attributeName] = toAttribute ? toAttribute(v) : v;\n        } else if (v) {\n          reactProps[attributeName] = '';\n          // Some boolean props like `checked` don't react to mutations after user interaction.\n          // To ensure expectation from React/JSX, we set also the corresponding property in this case.\n          elementProps[k] = v;\n        } else {\n          // We set false for falsy values as we know it is a boolean\n          elementProps[k] = false;\n        }\n        continue;\n      }\n\n      reactProps[k] = v;\n    }\n\n    // useLayoutEffect produces warnings during server rendering.\n    if (!NODE_MODE) {\n      // This one has no dependency array so it'll run on every re-render.\n      React.useLayoutEffect(() => {\n        if (elementRef.current === null) {\n          return;\n        }\n        const newElemProps = new Map();\n        for (const key in elementProps) {\n          setProperty(\n            elementRef.current,\n            key,\n            (props as Record<string, unknown>)[key],\n            prevElemPropsRef.current.get(key),\n            events,\n          );\n          prevElemPropsRef.current.delete(key);\n          newElemProps.set(key, (props as Record<string, unknown>)[key]);\n        }\n        // \"Unset\" any props from previous render that no longer exist.\n        // Setting to `undefined` seems like the correct thing to \"unset\"\n        // but currently React will set it as `null`.\n        // See https://github.com/facebook/react/issues/28203\n        for (const [key, value] of prevElemPropsRef.current) {\n          setProperty(elementRef.current, key, undefined, value, events);\n        }\n        prevElemPropsRef.current = newElemProps;\n      });\n\n      // Empty dependency array so this will only run once after first render.\n      React.useLayoutEffect(() => {\n        elementRef.current?.removeAttribute('defer-hydration');\n      }, []);\n    }\n\n    if (NODE_MODE) {\n      // If component is to be server rendered with `@lit/ssr-react`, pass\n      // element properties in a special bag to be set by the server-side\n      // element renderer.\n      if (\n        (React.createElement.name === 'litPatchedCreateElement' ||\n          (globalThis as unknown as { litSsrReactEnabled: boolean }).litSsrReactEnabled) &&\n        Object.keys(elementProps).length\n      ) {\n        // This property needs to remain unminified.\n        reactProps['_$litProps$'] = elementProps;\n      }\n    } else {\n      // Suppress hydration warning for server-rendered attributes.\n      // This property needs to remain unminified.\n      reactProps['suppressHydrationWarning'] = true;\n    }\n\n    return React.createElement(tagName, {\n      ...reactProps,\n      ref: React.useCallback(\n        (node: I) => {\n          elementRef.current = node;\n          if (typeof ref === 'function') {\n            ref(node);\n          } else if (ref !== null) {\n            ref.current = node;\n          }\n        },\n        [ref],\n      ),\n    });\n  });\n\n  ReactComponent.displayName = displayName ?? elementClass.name;\n\n  return ReactComponent;\n};\n"],"mappings":"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"}
142
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"create-component.js","names":[],"sources":["../../../../src/react/core/create-component.ts"],"sourcesContent":["/* eslint-disable\n  @typescript-eslint/explicit-function-return-type,\n  @typescript-eslint/naming-convention,\n  @typescript-eslint/naming-convention,\n  @typescript-eslint/no-empty-object-type,\n  import-x/no-named-as-default-member,\n*/\n/**\n * Copied from https://github.com/lit/lit/blob/main/packages/react/src/create-component.ts\n * TODO: Can be removed once https://github.com/lit/lit/issues/4023 or https://github.com/lit/lit/pull/4476 is solved.\n *\n * @license\n * Copyright 2018 Google LLC\n * SPDX-License-Identifier: BSD-3-Clause\n */\n\nimport type { SbbElement } from '@sbb-esta/lyne-elements/core.js';\nimport {\n  type ComplexAttributeConverter,\n  isServer,\n  type PropertyDeclaration,\n  type ReactiveElement,\n} from 'lit';\nimport type React from 'react';\n\nconst NODE_MODE = isServer;\nconst DEV_MODE = import.meta.env.DEV;\n\ntype DistributiveOmit<T, K extends string | number | symbol> = T extends any\n  ? K extends keyof T\n    ? Omit<T, K>\n    : T\n  : T;\ntype PropsWithoutRef<T> = DistributiveOmit<T, 'ref'>;\n\n/**\n * Creates a type to be used for the props of a web component used directly in\n * React JSX.\n *\n * Example:\n *\n * ```ts\n * declare module \"react\" {\n *   namespace JSX {\n *     interface IntrinsicElements {\n *       'x-foo': WebComponentProps<XFoo>;\n *     }\n *   }\n * }\n * ```\n */\nexport type WebComponentProps<I extends HTMLElement> = React.DetailedHTMLProps<\n  React.HTMLAttributes<I>,\n  I\n> &\n  ElementProps<I>;\n\n/**\n * Type of the React component wrapping the web component. This is the return\n * type of `createComponent`.\n */\nexport type ReactWebComponent<\n  I extends HTMLElement,\n  E extends EventNames = {},\n> = React.ForwardRefExoticComponent<\n  // TODO(augustjk): Remove and use `React.PropsWithoutRef` when\n  // https://github.com/preactjs/preact/issues/4124 is fixed.\n  PropsWithoutRef<ComponentProps<I, E>> & React.RefAttributes<I>\n>;\n\n// Props derived from custom element class. Currently has limitations of making\n// all properties optional and also surfaces life cycle methods in autocomplete.\n// TODO(augustjk) Consider omitting keyof LitElement to remove \"internal\"\n// lifecycle methods or allow user to explicitly provide props.\ntype ElementProps<I> = Partial<Omit<I, keyof HTMLElement>>;\n\n// Acceptable props to the React component.\ntype ComponentProps<I, E extends EventNames = {}> = Omit<\n  React.HTMLAttributes<I>,\n  // Prefer type of provided event handler props or those on element over\n  // built-in HTMLAttributes\n  keyof E | keyof ElementProps<I>\n> &\n  EventListeners<E> &\n  ElementProps<I>;\n\n/**\n * Type used to cast an event name with an event type when providing the\n * `events` option to `createComponent` for better typing of the event handler\n * prop.\n *\n * Example:\n *\n * ```ts\n * const FooComponent = createComponent({\n *   ...\n *   events: {\n *     onfoo: 'foo' as EventName<FooEvent>,\n *   }\n * });\n * ```\n *\n * `onfoo` prop will have the type `(e: FooEvent) => void`.\n */\nexport type EventName<T extends Event = Event> = string & {\n  __eventType: T;\n};\n\n// A key value map matching React prop names to event names.\ntype EventNames = Record<string, EventName | string>;\n\n// A map of expected event listener types based on EventNames.\ntype EventListeners<R extends EventNames> = {\n  [K in keyof R]?: R[K] extends EventName ? (e: R[K]['__eventType']) => void : (e: Event) => void;\n};\n\nexport interface Options<I extends HTMLElement, E extends EventNames = {}> {\n  react: typeof React;\n  tagName: string;\n  elementClass: Constructor<I>;\n  events?: E;\n  displayName?: string;\n}\n\ninterface Constructor<T> {\n  new (): T;\n}\n\nconst reservedReactProperties = new Set([\n  'children',\n  'localName',\n  'ref',\n  'style',\n  'className',\n  'id',\n]);\n\nconst listenedEvents = new WeakMap<Element, Map<string, EventListenerObject>>();\n\n/**\n * Adds an event listener for the specified event to the given node. In the\n * React setup, there should only ever be one event listener. Thus, for\n * efficiency only one listener is added and the handler for that listener is\n * updated to point to the given listener function.\n */\nconst addOrUpdateEventListener = (\n  node: Element,\n  event: string,\n  listener: (event?: Event) => void,\n) => {\n  let events = listenedEvents.get(node);\n  if (events === undefined) {\n    listenedEvents.set(node, (events = new Map()));\n  }\n  let handler = events.get(event);\n  if (listener !== undefined) {\n    // If necessary, add listener and track handler\n    if (handler === undefined) {\n      events.set(event, (handler = { handleEvent: listener }));\n      node.addEventListener(event, handler);\n      // Otherwise just update the listener with new value\n    } else {\n      handler.handleEvent = listener;\n    }\n    // Remove listener if one exists and value is undefined\n  } else if (handler !== undefined) {\n    events.delete(event);\n    node.removeEventListener(event, handler);\n  }\n};\n\n/**\n * Sets properties and events on custom elements. These properties and events\n * have been pre-filtered so we know they should apply to the custom element.\n */\nconst setProperty = <E extends Element>(\n  node: E,\n  name: string,\n  value: unknown,\n  old: unknown,\n  events?: EventNames,\n) => {\n  const event = events?.[name];\n  // Dirty check event value.\n  if (event !== undefined) {\n    if (value !== old) {\n      addOrUpdateEventListener(node, event, value as (e?: Event) => void);\n    }\n    return;\n  }\n  // But don't dirty check properties; elements are assumed to do this.\n  node[name as keyof E] = value as E[keyof E];\n\n  // This block is to replicate React's behavior for attributes of native\n  // elements where `undefined` or `null` values result in attributes being\n  // removed.\n  // https://github.com/facebook/react/blob/899cb95f52cc83ab5ca1eb1e268c909d3f0961e7/packages/react-dom-bindings/src/client/DOMPropertyOperations.js#L107-L141\n  //\n  // It's only needed here for native HTMLElement properties that reflect\n  // attributes of the same name but don't have that behavior like \"id\" or\n  // \"draggable\".\n  if ((value === undefined || value === null) && name in HTMLElement.prototype) {\n    node.removeAttribute(name);\n  }\n};\n\n/**\n * Creates a React component for a custom element. Properties are distinguished\n * from attributes automatically, and events can be configured so they are added\n * to the custom element as event listeners.\n *\n * @param options An options bag containing the parameters needed to generate a\n * wrapped web component.\n *\n * @param options.react The React module, typically imported from the `react`\n * npm package.\n * @param options.tagName The custom element tag name registered via\n * `customElements.define`.\n * @param options.elementClass The custom element class registered via\n * `customElements.define`.\n * @param options.events An object listing events to which the component can\n * listen. The object keys are the event property names passed in via React\n * props and the object values are the names of the corresponding events\n * generated by the custom element. For example, given `{onactivate:\n * 'activate'}` an event function may be passed via the component's `onactivate`\n * prop and will be called when the custom element fires its `activate` event.\n * @param options.displayName A React component display name, used in debugging\n * messages. Default value is inferred from the name of custom element class\n * registered via `customElements.define`.\n */\nexport const createComponent = <I extends HTMLElement, E extends EventNames = {}>({\n  react: React,\n  tagName,\n  elementClass,\n  events,\n  displayName,\n}: Options<I, E>): ReactWebComponent<I, E> => {\n  // Next.js re-rendering somehow fails, because the finalization calculation\n  // is broken in SSR. We call `finalize()` here explicitly to avoid that.\n  (elementClass as unknown as typeof SbbElement)['finalize']?.();\n  (elementClass as unknown as typeof SbbElement).define?.();\n\n  const eventProps = new Set(Object.keys(events ?? {}));\n\n  if (DEV_MODE && !NODE_MODE) {\n    for (const p of reservedReactProperties) {\n      if (p in elementClass.prototype && !(p in HTMLElement.prototype)) {\n        // Note, this effectively warns only for `ref` since the other\n        // reserved props are on HTMLElement.prototype. To address this\n        // would require crawling down the prototype, which doesn't feel worth\n        // it since implementing these properties on an element is extremely\n        // rare.\n        console.warn(\n          `${tagName} contains property ${p} which is a React reserved ` +\n            `property. It will be used by React and not set on the element.`,\n        );\n      }\n    }\n  }\n\n  type Props = ComponentProps<I, E>;\n\n  const ReactComponent = React.forwardRef<I, Props>((props, ref) => {\n    const prevElemPropsRef = React.useRef(new Map());\n    const elementRef = React.useRef<I | null>(null);\n\n    // Props to be passed to React.createElement\n    const reactProps: Record<string, unknown> = {};\n    // Props to be set on element with setProperty\n    const elementProps: Record<string, unknown> = {};\n    // A map of element properties with meta information.\n    const elementProperties: Map<PropertyKey, PropertyDeclaration> | undefined = (\n      elementClass as unknown as typeof ReactiveElement\n    ).elementProperties;\n\n    for (const [k, v] of Object.entries(props)) {\n      if (reservedReactProperties.has(k)) {\n        // React does *not* handle `className` for custom elements so\n        // coerce it to `class` so it's handled correctly.\n        reactProps[k === 'className' ? 'class' : k] = v;\n        continue;\n      } else if (eventProps.has(k) || k in elementClass.prototype) {\n        const elementProperty = elementProperties?.get(k);\n        const toAttribute = (elementProperty?.converter as ComplexAttributeConverter)?.toAttribute;\n        if (\n          !elementProperty ||\n          elementProperty.attribute === false ||\n          (typeof v === 'object' && !toAttribute)\n        ) {\n          elementProps[k] = v;\n          continue;\n        }\n\n        const attributeName =\n          elementProperty.attribute === true ? k : elementProperty.attribute || k;\n        if (elementProperty.type !== Boolean) {\n          reactProps[attributeName] = toAttribute ? toAttribute(v) : v;\n        } else if (v) {\n          reactProps[attributeName] = '';\n          // Some boolean props like `checked` don't react to mutations after user interaction.\n          // To ensure expectation from React/JSX, we set also the corresponding property in this case.\n          elementProps[k] = v;\n        } else {\n          // We set false for falsy values as we know it is a boolean\n          elementProps[k] = false;\n        }\n        continue;\n      }\n\n      reactProps[k] = v;\n    }\n\n    // useLayoutEffect produces warnings during server rendering.\n    if (!NODE_MODE) {\n      // This one has no dependency array so it'll run on every re-render.\n      React.useLayoutEffect(() => {\n        if (elementRef.current === null) {\n          return;\n        }\n        const newElemProps = new Map();\n        for (const key in elementProps) {\n          setProperty(\n            elementRef.current,\n            key,\n            (props as Record<string, unknown>)[key],\n            prevElemPropsRef.current.get(key),\n            events,\n          );\n          prevElemPropsRef.current.delete(key);\n          newElemProps.set(key, (props as Record<string, unknown>)[key]);\n        }\n        // \"Unset\" any props from previous render that no longer exist.\n        // Setting to `undefined` seems like the correct thing to \"unset\"\n        // but currently React will set it as `null`.\n        // See https://github.com/facebook/react/issues/28203\n        for (const [key, value] of prevElemPropsRef.current) {\n          setProperty(elementRef.current, key, undefined, value, events);\n        }\n        prevElemPropsRef.current = newElemProps;\n      });\n\n      // Empty dependency array so this will only run once after first render.\n      React.useLayoutEffect(() => {\n        elementRef.current?.removeAttribute('defer-hydration');\n      }, []);\n    }\n\n    if (NODE_MODE) {\n      // If component is to be server rendered with `@lit/ssr-react`, pass\n      // element properties in a special bag to be set by the server-side\n      // element renderer.\n      if (\n        (React.createElement.name === 'litPatchedCreateElement' ||\n          (globalThis as unknown as { litSsrReactEnabled: boolean }).litSsrReactEnabled) &&\n        Object.keys(elementProps).length\n      ) {\n        // This property needs to remain unminified.\n        reactProps['_$litProps$'] = elementProps;\n      }\n    } else {\n      // Suppress hydration warning for server-rendered attributes.\n      // This property needs to remain unminified.\n      reactProps['suppressHydrationWarning'] = true;\n    }\n\n    return React.createElement(tagName, {\n      ...reactProps,\n      ref: React.useCallback(\n        (node: I) => {\n          elementRef.current = node;\n          if (typeof ref === 'function') {\n            ref(node);\n          } else if (ref !== null) {\n            ref.current = node;\n          }\n        },\n        [ref],\n      ),\n    });\n  });\n\n  ReactComponent.displayName = displayName ?? elementClass.name;\n\n  return ReactComponent;\n};\n"],"mappings":"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"}
@@ -1,6 +1,6 @@
1
1
  import { SbbBlockLink } from "./link/block-link/block-link.component.js";
2
- import { SbbBlockLinkButton } from "./link/block-link-button/block-link-button.component.js";
3
2
  import { SbbBlockLinkStatic } from "./link/block-link-static/block-link-static.component.js";
3
+ import { SbbBlockLinkButton } from "./link/block-link-button/block-link-button.component.js";
4
4
  import { SbbLink } from "./link/link/link.component.js";
5
5
  import { SbbLinkButton } from "./link/link-button/link-button.component.js";
6
6
  import { SbbLinkStatic } from "./link/link-static/link-static.component.js";
@@ -1,6 +1,6 @@
1
1
  import { SbbSidebar } from "./sidebar/sidebar/sidebar.component.js";
2
- import { SbbSidebarCloseButton } from "./sidebar/sidebar-close-button/sidebar-close-button.component.js";
3
2
  import { SbbSidebarContainer } from "./sidebar/sidebar-container/sidebar-container.component.js";
3
+ import { SbbSidebarCloseButton } from "./sidebar/sidebar-close-button/sidebar-close-button.component.js";
4
4
  import { SbbSidebarContent } from "./sidebar/sidebar-content/sidebar-content.component.js";
5
5
  import { SbbSidebarTitle } from "./sidebar/sidebar-title/sidebar-title.component.js";
6
6
  export { SbbSidebar, SbbSidebarCloseButton, SbbSidebarContainer, SbbSidebarContent, SbbSidebarTitle };
@@ -1,6 +1,6 @@
1
1
  import { SbbTrain } from "./train/train/train.component.js";
2
- import { SbbTrainBlockedPassage } from "./train/train-blocked-passage/train-blocked-passage.component.js";
3
2
  import { SbbTrainFormation } from "./train/train-formation/train-formation.component.js";
3
+ import { SbbTrainBlockedPassage } from "./train/train-blocked-passage/train-blocked-passage.component.js";
4
4
  import { SbbTrainWagon } from "./train/train-wagon/train-wagon.component.js";
5
5
  import { SbbTrainWagonButton } from "./train/train-wagon-button/train-wagon-button.component.js";
6
6
  import { SbbTrainWagonLink } from "./train/train-wagon-link/train-wagon-link.component.js";
package/link.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import { SbbBlockLink as e } from "./link/block-link/block-link.component.js";
2
- import { SbbBlockLinkButton as t } from "./link/block-link-button/block-link-button.component.js";
3
- import { SbbBlockLinkStatic as n } from "./link/block-link-static/block-link-static.component.js";
2
+ import { SbbBlockLinkStatic as t } from "./link/block-link-static/block-link-static.component.js";
3
+ import { SbbBlockLinkButton as n } from "./link/block-link-button/block-link-button.component.js";
4
4
  import { SbbLink as r } from "./link/link/link.component.js";
5
5
  import { SbbLinkButton as i } from "./link/link-button/link-button.component.js";
6
6
  import { SbbLinkStatic as a } from "./link/link-static/link-static.component.js";
7
- export { e as SbbBlockLink, t as SbbBlockLinkButton, n as SbbBlockLinkStatic, r as SbbLink, i as SbbLinkButton, a as SbbLinkStatic };
7
+ export { e as SbbBlockLink, n as SbbBlockLinkButton, t as SbbBlockLinkStatic, r as SbbLink, i as SbbLinkButton, a as SbbLinkStatic };
package/package.json CHANGED
@@ -1,13 +1,13 @@
1
1
  {
2
2
  "name": "@sbb-esta/lyne-react-dev",
3
- "version": "5.0.0-next.2-dev.1778141171",
3
+ "version": "5.0.0-next.2-dev.1778145574",
4
4
  "description": "Lyne Design System React Library",
5
5
  "keywords": [
6
6
  "design system",
7
7
  "web components",
8
8
  "lit",
9
9
  "react",
10
- "https://github.com/sbb-design-systems/lyne-components/commit/35df8146d9f5dfd62323e0ae536bbec3ca1dfb89"
10
+ "https://github.com/sbb-design-systems/lyne-components/commit/03fcbe17224b607f1b023093c33786cf61db164f"
11
11
  ],
12
12
  "type": "module",
13
13
  "exports": {
package/sidebar.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import { SbbSidebar as e } from "./sidebar/sidebar/sidebar.component.js";
2
- import { SbbSidebarCloseButton as t } from "./sidebar/sidebar-close-button/sidebar-close-button.component.js";
3
- import { SbbSidebarContainer as n } from "./sidebar/sidebar-container/sidebar-container.component.js";
2
+ import { SbbSidebarContainer as t } from "./sidebar/sidebar-container/sidebar-container.component.js";
3
+ import { SbbSidebarCloseButton as n } from "./sidebar/sidebar-close-button/sidebar-close-button.component.js";
4
4
  import { SbbSidebarContent as r } from "./sidebar/sidebar-content/sidebar-content.component.js";
5
5
  import { SbbSidebarTitle as i } from "./sidebar/sidebar-title/sidebar-title.component.js";
6
- export { e as SbbSidebar, t as SbbSidebarCloseButton, n as SbbSidebarContainer, r as SbbSidebarContent, i as SbbSidebarTitle };
6
+ export { e as SbbSidebar, n as SbbSidebarCloseButton, t as SbbSidebarContainer, r as SbbSidebarContent, i as SbbSidebarTitle };
package/train.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import { SbbTrain as e } from "./train/train/train.component.js";
2
- import { SbbTrainBlockedPassage as t } from "./train/train-blocked-passage/train-blocked-passage.component.js";
3
- import { SbbTrainFormation as n } from "./train/train-formation/train-formation.component.js";
2
+ import { SbbTrainFormation as t } from "./train/train-formation/train-formation.component.js";
3
+ import { SbbTrainBlockedPassage as n } from "./train/train-blocked-passage/train-blocked-passage.component.js";
4
4
  import { SbbTrainWagon as r } from "./train/train-wagon/train-wagon.component.js";
5
5
  import { SbbTrainWagonButton as i } from "./train/train-wagon-button/train-wagon-button.component.js";
6
6
  import { SbbTrainWagonLink as a } from "./train/train-wagon-link/train-wagon-link.component.js";
7
- export { e as SbbTrain, t as SbbTrainBlockedPassage, n as SbbTrainFormation, r as SbbTrainWagon, i as SbbTrainWagonButton, a as SbbTrainWagonLink };
7
+ export { e as SbbTrain, n as SbbTrainBlockedPassage, t as SbbTrainFormation, r as SbbTrainWagon, i as SbbTrainWagonButton, a as SbbTrainWagonLink };