@sbb-esta/lyne-elements 1.7.0 → 1.8.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 (88) hide show
  1. package/calendar/calendar.d.ts +5 -2
  2. package/calendar/calendar.d.ts.map +1 -1
  3. package/calendar.js +73 -66
  4. package/container/container.js +5 -5
  5. package/core/base-elements/open-close-base-element.d.ts +10 -0
  6. package/core/base-elements/open-close-base-element.d.ts.map +1 -1
  7. package/core/base-elements.js +4 -0
  8. package/core/controllers/inert-controller.d.ts +18 -0
  9. package/core/controllers/inert-controller.d.ts.map +1 -0
  10. package/core/controllers.d.ts +1 -0
  11. package/core/controllers.d.ts.map +1 -1
  12. package/core/controllers.js +67 -23
  13. package/core/overlay/overlay.d.ts +0 -13
  14. package/core/overlay/overlay.d.ts.map +1 -1
  15. package/core/overlay.js +36 -86
  16. package/custom-elements.json +369 -65
  17. package/datepicker/datepicker-toggle/datepicker-toggle.d.ts +4 -0
  18. package/datepicker/datepicker-toggle/datepicker-toggle.d.ts.map +1 -1
  19. package/datepicker/datepicker-toggle.js +51 -41
  20. package/development/calendar/calendar.d.ts +5 -2
  21. package/development/calendar/calendar.d.ts.map +1 -1
  22. package/development/calendar.js +35 -19
  23. package/development/container/container.js +8 -4
  24. package/development/core/base-elements/open-close-base-element.d.ts +10 -0
  25. package/development/core/base-elements/open-close-base-element.d.ts.map +1 -1
  26. package/development/core/base-elements.js +5 -1
  27. package/development/core/controllers/inert-controller.d.ts +18 -0
  28. package/development/core/controllers/inert-controller.d.ts.map +1 -0
  29. package/development/core/controllers.d.ts +1 -0
  30. package/development/core/controllers.d.ts.map +1 -1
  31. package/development/core/controllers.js +90 -1
  32. package/development/core/overlay/overlay.d.ts +0 -13
  33. package/development/core/overlay/overlay.d.ts.map +1 -1
  34. package/development/core/overlay.js +1 -87
  35. package/development/datepicker/datepicker-toggle/datepicker-toggle.d.ts +4 -0
  36. package/development/datepicker/datepicker-toggle/datepicker-toggle.d.ts.map +1 -1
  37. package/development/datepicker/datepicker-toggle.js +17 -2
  38. package/development/dialog/dialog/dialog.d.ts.map +1 -1
  39. package/development/dialog/dialog.js +3 -4
  40. package/development/flip-card/flip-card/flip-card.d.ts.map +1 -1
  41. package/development/flip-card/flip-card-details/flip-card-details.d.ts.map +1 -1
  42. package/development/flip-card/flip-card-details.js +28 -9
  43. package/development/flip-card/flip-card-summary.js +6 -1
  44. package/development/flip-card/flip-card.js +43 -12
  45. package/development/form-field/form-field.js +4 -2
  46. package/development/lead-container.js +5 -1
  47. package/development/menu/menu/menu.d.ts +1 -0
  48. package/development/menu/menu/menu.d.ts.map +1 -1
  49. package/development/menu/menu.js +6 -9
  50. package/development/navigation/navigation/navigation.d.ts +1 -0
  51. package/development/navigation/navigation/navigation.d.ts.map +1 -1
  52. package/development/navigation/navigation.js +6 -9
  53. package/development/overlay/overlay-base-element.d.ts +2 -1
  54. package/development/overlay/overlay-base-element.d.ts.map +1 -1
  55. package/development/overlay/overlay.d.ts.map +1 -1
  56. package/development/overlay.js +5 -9
  57. package/development/popover/popover.js +2 -2
  58. package/development/toggle/toggle/toggle.d.ts +2 -1
  59. package/development/toggle/toggle/toggle.d.ts.map +1 -1
  60. package/development/toggle/toggle-option/toggle-option.d.ts.map +1 -1
  61. package/development/toggle/toggle-option.js +3 -2
  62. package/development/toggle/toggle.js +7 -7
  63. package/dialog/dialog/dialog.d.ts.map +1 -1
  64. package/dialog/dialog.js +11 -12
  65. package/flip-card/flip-card/flip-card.d.ts.map +1 -1
  66. package/flip-card/flip-card-details/flip-card-details.d.ts.map +1 -1
  67. package/flip-card/flip-card-details.js +19 -17
  68. package/flip-card/flip-card-summary.js +13 -13
  69. package/flip-card/flip-card.js +26 -24
  70. package/form-field/form-field.js +1 -1
  71. package/lead-container.js +1 -1
  72. package/menu/menu/menu.d.ts +1 -0
  73. package/menu/menu/menu.d.ts.map +1 -1
  74. package/menu/menu.js +30 -30
  75. package/navigation/navigation/navigation.d.ts +1 -0
  76. package/navigation/navigation/navigation.d.ts.map +1 -1
  77. package/navigation/navigation.js +37 -37
  78. package/overlay/overlay-base-element.d.ts +2 -1
  79. package/overlay/overlay-base-element.d.ts.map +1 -1
  80. package/overlay/overlay.d.ts.map +1 -1
  81. package/overlay.js +44 -45
  82. package/package.json +1 -1
  83. package/popover/popover.js +1 -1
  84. package/toggle/toggle/toggle.d.ts +2 -1
  85. package/toggle/toggle/toggle.d.ts.map +1 -1
  86. package/toggle/toggle-option/toggle-option.d.ts.map +1 -1
  87. package/toggle/toggle-option.js +8 -8
  88. package/toggle/toggle.js +20 -21
@@ -1,5 +1,4 @@
1
1
  import { html } from "lit";
2
- const IS_OPEN_OVERLAY_QUERY = `:is(sbb-dialog, sbb-navigation, sbb-menu, sbb-overlay)[data-state='opened']`;
3
2
  function overlayGapFixCorners() {
4
3
  return html`
5
4
  <div class="sbb-gap-fix-wrapper">
@@ -10,89 +9,6 @@ function overlayGapFixCorners() {
10
9
  </div>
11
10
  `;
12
11
  }
13
- const getAncestors = (overlay, root) => {
14
- let el = overlay.parentElement;
15
- const ancestors = [];
16
- while (el) {
17
- ancestors.push(el);
18
- if (el !== root) {
19
- el = el.parentElement;
20
- } else {
21
- break;
22
- }
23
- }
24
- return ancestors;
25
- };
26
- const setDataSbbInert = (el) => {
27
- el.setAttribute(
28
- "data-sbb-inert",
29
- `${+(el.getAttribute("data-sbb-inert") ?? void 0) + 1 || 0}`
30
- );
31
- };
32
- const setSbbInert = (el) => {
33
- if (!el.inert) {
34
- el.inert = true;
35
- if (el.matches(IS_OPEN_OVERLAY_QUERY)) {
36
- setDataSbbInert(el);
37
- } else {
38
- el.toggleAttribute("data-sbb-inert", true);
39
- }
40
- }
41
- if (!el.hasAttribute("aria-hidden")) {
42
- el.setAttribute("aria-hidden", "true");
43
- el.toggleAttribute("data-sbb-aria-hidden", true);
44
- }
45
- };
46
- const removeSbbInert = (el) => {
47
- if (el.hasAttribute("data-sbb-inert")) {
48
- el.inert = false;
49
- el.removeAttribute("data-sbb-inert");
50
- }
51
- if (el.hasAttribute("data-sbb-aria-hidden")) {
52
- el.removeAttribute("aria-hidden");
53
- el.removeAttribute("data-sbb-aria-hidden");
54
- }
55
- };
56
- function applyInertMechanism(overlay) {
57
- removeSbbInert(overlay);
58
- const overlayRoot = overlay.closest("body > *");
59
- const documentChildren = Array.from(document.querySelectorAll("body > *")).filter(
60
- (el) => el !== overlayRoot
61
- );
62
- documentChildren.forEach((el) => setSbbInert(el));
63
- let children = [];
64
- const ancestors = getAncestors(overlay, overlayRoot);
65
- for (const el of ancestors) {
66
- children = children.concat(
67
- Array.from(el.children).filter(
68
- (el2) => el2 !== overlay && !ancestors.includes(el2)
69
- )
70
- );
71
- if (el.matches(IS_OPEN_OVERLAY_QUERY)) {
72
- setDataSbbInert(el);
73
- }
74
- }
75
- children.forEach((el) => setSbbInert(el));
76
- }
77
- function removeInertMechanism() {
78
- const openOverlays = Array.from(
79
- document.documentElement.querySelectorAll(IS_OPEN_OVERLAY_QUERY)
80
- );
81
- if (openOverlays.length) {
82
- openOverlays.forEach((el) => {
83
- const newValue = +el.getAttribute("data-sbb-inert") - 1;
84
- el.setAttribute("data-sbb-inert", `${newValue}`);
85
- if (newValue && newValue < 0) {
86
- removeSbbInert(el);
87
- Array.from(el.children).forEach((el2) => removeSbbInert(el2));
88
- }
89
- });
90
- return;
91
- }
92
- Array.from(document.documentElement.querySelectorAll("[data-sbb-inert]")).forEach(
93
- (el) => removeSbbInert(el)
94
- );
95
- }
96
12
  function getElementRectangle(el) {
97
13
  const elementStyle = window.getComputedStyle(el), elementDisplay = elementStyle.display, elementMaxHeight = parseInt(elementStyle.maxHeight, 10).toString();
98
14
  if (elementDisplay !== "none" && elementMaxHeight !== "0") {
@@ -225,16 +141,14 @@ function removeAriaComboBoxAttributes(trigger) {
225
141
  trigger.removeAttribute("aria-expanded");
226
142
  }
227
143
  export {
228
- applyInertMechanism,
229
144
  getElementPosition,
230
145
  getElementRectangle,
231
146
  isEventOnElement,
232
147
  overlayGapFixCorners,
233
148
  removeAriaComboBoxAttributes,
234
149
  removeAriaOverlayTriggerAttributes,
235
- removeInertMechanism,
236
150
  setAriaComboBoxAttributes,
237
151
  setAriaOverlayTriggerAttributes,
238
152
  setOverlayPosition
239
153
  };
240
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"overlay.js","sources":["../../../../src/elements/core/overlay/overlay.ts","../../../../src/elements/core/overlay/position.ts","../../../../src/elements/core/overlay/overlay-option-panel.ts","../../../../src/elements/core/overlay/overlay-trigger-attributes.ts"],"sourcesContent":["import type { TemplateResult } from 'lit';\nimport { html } from 'lit';\n\nconst IS_OPEN_OVERLAY_QUERY = `:is(sbb-dialog, sbb-navigation, sbb-menu, sbb-overlay)[data-state='opened']`;\n\n/**\n * Used to create the \"wrapping\" effect around the anchor for overlays (es. autocomplete)\n * Works in conjunction with the 'overlayGapFixCorners()' function in 'overlay.ts'\n */\nexport function overlayGapFixCorners(): TemplateResult {\n  return html`\n    <div class=\"sbb-gap-fix-wrapper\">\n      <div class=\"sbb-gap-fix-corner\" id=\"left\"></div>\n    </div>\n    <div class=\"sbb-gap-fix-wrapper\">\n      <div class=\"sbb-gap-fix-corner\" id=\"right\"></div>\n    </div>\n  `;\n}\n\n/**\n * Returns all the ancestors of the overlay.\n */\nconst getAncestors = (overlay: HTMLElement, root: HTMLElement): HTMLElement[] => {\n  let el = overlay.parentElement;\n  const ancestors: HTMLElement[] = [];\n  while (el) {\n    ancestors.push(el);\n    if (el !== root) {\n      el = el.parentElement;\n    } else {\n      break;\n    }\n  }\n  return ancestors;\n};\n\nconst setDataSbbInert = (el: HTMLElement): void => {\n  el.setAttribute(\n    'data-sbb-inert',\n    `${+(el.getAttribute('data-sbb-inert') ?? undefined)! + 1 || 0}`,\n  );\n};\n\n/**\n * Set the inert and the data-sbb-inert attributes.\n */\nconst setSbbInert = (el: HTMLElement): void => {\n  if (!el.inert) {\n    el.inert = true;\n    if (el.matches(IS_OPEN_OVERLAY_QUERY)) {\n      setDataSbbInert(el);\n    } else {\n      el.toggleAttribute('data-sbb-inert', true);\n    }\n  }\n\n  if (!el.hasAttribute('aria-hidden')) {\n    el.setAttribute('aria-hidden', 'true');\n    el.toggleAttribute('data-sbb-aria-hidden', true);\n  }\n};\n\n/**\n * Removes the inert and the data-sbb-inert attributes.\n */\nconst removeSbbInert = (el: HTMLElement): void => {\n  if (el.hasAttribute('data-sbb-inert')) {\n    el.inert = false;\n    el.removeAttribute('data-sbb-inert');\n  }\n\n  if (el.hasAttribute('data-sbb-aria-hidden')) {\n    el.removeAttribute('aria-hidden');\n    el.removeAttribute('data-sbb-aria-hidden');\n  }\n};\n\n/**\n * Applies inert to every other element on the page except the overlay.\n */\nexport function applyInertMechanism(overlay: HTMLElement): void {\n  removeSbbInert(overlay);\n\n  const overlayRoot = overlay.closest('body > *') as HTMLElement;\n  const documentChildren = Array.from(document.querySelectorAll('body > *')).filter(\n    (el) => el !== overlayRoot,\n  ) as HTMLElement[];\n\n  documentChildren.forEach((el) => setSbbInert(el));\n\n  let children: HTMLElement[] = [];\n  const ancestors = getAncestors(overlay, overlayRoot);\n\n  for (const el of ancestors) {\n    children = children.concat(\n      Array.from(el.children).filter(\n        (el: Element) => el !== overlay && !ancestors.includes(el as HTMLElement),\n      ) as HTMLElement[],\n    );\n    if (el.matches(IS_OPEN_OVERLAY_QUERY)) {\n      setDataSbbInert(el);\n    }\n  }\n\n  children.forEach((el) => setSbbInert(el));\n}\n\nexport function removeInertMechanism(): void {\n  const openOverlays = Array.from(\n    document.documentElement.querySelectorAll(IS_OPEN_OVERLAY_QUERY),\n  ) as HTMLElement[];\n\n  if (openOverlays.length) {\n    openOverlays.forEach((el) => {\n      const newValue = +el.getAttribute('data-sbb-inert')! - 1;\n      el.setAttribute('data-sbb-inert', `${newValue}`);\n\n      if (newValue && newValue < 0) {\n        removeSbbInert(el);\n        Array.from(el.children).forEach((el: Element) => removeSbbInert(el as HTMLElement));\n      }\n    });\n    return;\n  }\n\n  Array.from(document.documentElement.querySelectorAll('[data-sbb-inert]')).forEach((el: Element) =>\n    removeSbbInert(el as HTMLElement),\n  );\n}\ndeclare global {\n  interface GlobalEventHandlersEventMap {\n    willOpen: CustomEvent<void>;\n    willClose: CustomEvent<void>;\n    didOpen: CustomEvent<void>;\n    didClose: CustomEvent<void>;\n  }\n}\n","export type ElementRectangle = Pick<\n  HTMLElement,\n  'scrollHeight' | 'clientHeight' | 'offsetHeight' | 'scrollWidth' | 'clientWidth' | 'offsetWidth'\n>;\n\nexport interface SbbAlignment {\n  horizontal: 'start' | 'center' | 'end';\n  vertical: 'above' | 'below';\n}\n\nexport interface SbbElementPositionInfos {\n  top: number;\n  left: number;\n  maxHeight: string;\n  alignment: SbbAlignment;\n}\n\n/**\n * Gets height and width of an element even if it's hidden (`display: none`).\n */\nexport function getElementRectangle(el: HTMLElement): ElementRectangle {\n  const elementStyle = window.getComputedStyle(el),\n    elementDisplay = elementStyle.display,\n    elementMaxHeight = parseInt(elementStyle.maxHeight, 10).toString();\n\n  // If it is not hidden we just return normal height\n  if (elementDisplay !== 'none' && elementMaxHeight !== '0') {\n    return {\n      scrollHeight: el.scrollHeight,\n      clientHeight: el.clientHeight,\n      offsetHeight: el.offsetHeight,\n      scrollWidth: el.scrollWidth,\n      clientWidth: el.clientWidth,\n      offsetWidth: el.offsetWidth,\n    };\n  }\n\n  // The element is hidden so:\n  // make the el block in order to measure its height but still be hidden\n  el.style.position = 'absolute';\n  el.style.visibility = 'hidden';\n  el.style.display = 'block';\n\n  const scrollHeight = el.scrollHeight,\n    clientHeight = el.clientHeight,\n    offsetHeight = el.offsetHeight,\n    scrollWidth = el.scrollWidth,\n    clientWidth = el.clientWidth,\n    offsetWidth = el.offsetWidth;\n\n  // Reverting to the original values\n  el.style.display = '';\n  el.style.position = '';\n  el.style.visibility = '';\n\n  return { scrollHeight, clientHeight, offsetHeight, scrollWidth, clientWidth, offsetWidth };\n}\n\n/**\n * Determines whether an event is fired on a specific element.\n */\nexport function isEventOnElement(element: HTMLElement, event: MouseEvent | PointerEvent): boolean {\n  if (!element || !event) {\n    return false;\n  }\n\n  const rect = element.getBoundingClientRect();\n  return (\n    rect.top <= event.clientY &&\n    event.clientY <= rect.top + rect.height &&\n    rect.left <= event.clientX &&\n    event.clientX <= rect.left + rect.width\n  );\n}\n\n/**\n * Determines the position of an element relative to a trigger element by evaluating\n * the optimal position based on the available space.\n *\n * @param element The element of which to calculate the position.\n * @param trigger The element relative to which to calculate the position.\n * @param container The element which has the position:fixed applied.\n * @param properties Properties to take into account in calculations (optional).\n * @param properties.verticalOffset The distance to be added between the element and the trigger (optional).\n * @param properties.horizontalOffset The horizontal offset to be applied to the element (optional).\n * @param properties.centered Whether the element should be placed in the center by default (optional).\n * @param properties.responsiveHeight Whether the element calculates its height based on its content (optional).\n * @returns Returns an object containing the left position, the top position, the maximum height\n * of the element and the current alignment object.\n */\nexport function getElementPosition(\n  element: HTMLElement,\n  trigger: HTMLElement,\n  container: HTMLElement,\n  properties?: {\n    verticalOffset?: number;\n    horizontalOffset?: number;\n    centered?: boolean;\n    responsiveHeight?: boolean;\n  },\n): SbbElementPositionInfos {\n  const maxWidthOffset = 16;\n  const verticalOffset = properties?.verticalOffset || 0;\n  const horizontalOffset = properties?.horizontalOffset || 0;\n  const responsiveHeight = properties?.responsiveHeight || false;\n\n  const triggerRec = trigger.getBoundingClientRect();\n  const elementRec = getElementRectangle(element);\n\n  const triggerLeft = triggerRec.left;\n  const triggerTop = triggerRec.top;\n\n  const availableSpaceRight =\n    document.documentElement.clientWidth - (triggerLeft + triggerRec.width);\n  const availableSpaceAbove = triggerTop - verticalOffset;\n  const availableSpaceBelow =\n    document.documentElement.clientHeight - (triggerTop + triggerRec.height + verticalOffset);\n\n  // Default element alignment is \"start/below\"\n  let elementXPosition = triggerLeft;\n  let elementYPosition = triggerTop + triggerRec.height + verticalOffset;\n  let elementXOverflow = elementRec.offsetWidth - triggerRec.width;\n  const alignment: SbbAlignment = { horizontal: 'start', vertical: 'below' };\n\n  // Calculate element max-height\n  let elementMaxHeight = `${availableSpaceBelow - verticalOffset}px`;\n\n  // Check if horizontal alignment needs to be changed to \"center\"\n  if (\n    properties?.centered &&\n    triggerLeft - maxWidthOffset + triggerRec.width / 2 > elementRec.offsetWidth / 2 &&\n    availableSpaceRight - maxWidthOffset > elementXOverflow / 2\n  ) {\n    elementXPosition -= elementXOverflow /= 2;\n    alignment.horizontal = 'center';\n  }\n\n  // Check if horizontal alignment needs to be changed to \"end\"\n  if (availableSpaceRight < elementXOverflow && triggerLeft > elementXOverflow) {\n    elementXPosition = elementXPosition - elementXOverflow;\n    alignment.horizontal = 'end';\n  }\n\n  // Add horizontal offset\n  if (\n    horizontalOffset &&\n    alignment.horizontal !== 'center' &&\n    triggerRec.width / 2 < horizontalOffset\n  ) {\n    elementXPosition += horizontalOffset * (alignment.horizontal === 'start' ? -1 : 1);\n  }\n\n  // Check whether there is insufficient space on both sides\n  if (\n    (triggerLeft < elementXOverflow && availableSpaceRight < elementXOverflow) ||\n    document.documentElement.clientWidth < elementRec.offsetWidth\n  ) {\n    elementXPosition = document.documentElement.clientWidth / 2 - elementRec.offsetWidth / 2;\n  }\n\n  // Check if vertical alignment needs to be changed to \"above\":\n  if (\n    (availableSpaceBelow - verticalOffset < elementRec.scrollHeight &&\n      availableSpaceAbove - verticalOffset >\n        (responsiveHeight ? elementRec.clientHeight : elementRec.scrollHeight)) ||\n    (availableSpaceAbove > availableSpaceBelow &&\n      availableSpaceBelow - verticalOffset < elementRec.clientHeight &&\n      !responsiveHeight)\n  ) {\n    elementYPosition =\n      availableSpaceAbove < elementRec.scrollHeight\n        ? elementYPosition - triggerRec.height - availableSpaceAbove - verticalOffset\n        : triggerTop - elementRec.clientHeight - verticalOffset;\n\n    elementMaxHeight = `${availableSpaceAbove - verticalOffset}px`;\n    alignment.vertical = 'above';\n  }\n\n  const containerRect = container.getBoundingClientRect();\n\n  // When zooming in Safari the container rectangle contains negative values for the position\n  // and we need to re-add them to the calculated coordinates.\n  if (containerRect.left < 0) {\n    elementXPosition -= containerRect.left;\n  }\n\n  // Normally the containerRect's top value would be zero, however when the overlay is attached to an input\n  // (e.g. in an autocomplete), mobile browsers will shift everything in order to put the input in the middle\n  // of the screen and to make space for the virtual keyboard. We need to account for this offset,\n  // otherwise our positioning will be thrown off.\n  // Additionally, when zooming in Safari this fixes the vertical position.\n  if (containerRect.top < 0) {\n    elementYPosition -= containerRect.top;\n  }\n\n  return {\n    top: elementYPosition,\n    left: elementXPosition,\n    maxHeight: elementMaxHeight,\n    alignment: alignment,\n  };\n}\n","import { getElementPosition } from './position.js';\n\n/**\n * Places the overlay in the correct position.\n * @param dialog The reference to the dialog element.\n * @param originElement The reference to the element the dialog is attached to.\n * @param optionContainer The reference to the option panel.\n * @param container The element which has the position:fixed applied.\n * @param element The reference to the component.\n */\nexport function setOverlayPosition(\n  dialog: HTMLElement,\n  originElement: HTMLElement,\n  optionContainer: HTMLElement,\n  container: HTMLElement,\n  element: HTMLElement,\n): void {\n  if (!dialog || !originElement) {\n    return;\n  }\n\n  // Set the width to match the trigger element\n  element.style.setProperty('--sbb-options-panel-width', `${originElement.offsetWidth}px`);\n\n  // Set the origin height\n  element.style.setProperty('--sbb-options-panel-origin-height', `${originElement.offsetHeight}px`);\n\n  // Calculate and set the position\n  const panelPosition = getElementPosition(optionContainer, originElement, container);\n\n  element.style.setProperty('--sbb-options-panel-position-x', `${panelPosition.left}px`);\n  element.style.setProperty('--sbb-options-panel-position-y', `${panelPosition.top}px`);\n  element.style.setProperty('--sbb-options-panel-max-height', panelPosition.maxHeight);\n  element.setAttribute('data-options-panel-position', panelPosition.alignment.vertical);\n  originElement.setAttribute('data-options-panel-position', panelPosition.alignment.vertical);\n}\n","/**\n * Add meaningful aria attributes to trigger elements that are connected to\n * overlay elements such as menus and dialogs.\n */\nexport function setAriaOverlayTriggerAttributes(\n  trigger: HTMLElement,\n  popupType: 'menu' | 'dialog',\n  overlayId: string,\n  state: string,\n): void {\n  if (!trigger) {\n    return;\n  }\n\n  trigger.setAttribute('aria-haspopup', popupType);\n  trigger.setAttribute('aria-controls', overlayId);\n  trigger.setAttribute('aria-expanded', `${state === 'opening' || state === 'opened'}`);\n}\n\n/**\n * Remove aria attributes from trigger elements.\n */\nexport function removeAriaOverlayTriggerAttributes(trigger: HTMLElement | null | undefined): void {\n  if (!trigger) {\n    return;\n  }\n\n  trigger.removeAttribute('aria-haspopup');\n  trigger.removeAttribute('aria-controls');\n  trigger.removeAttribute('aria-expanded');\n}\n\n/**\n * Add meaningful aria attributes to trigger element of role='combobox'\n */\nexport function setAriaComboBoxAttributes(\n  trigger: HTMLElement,\n  overlayId: string,\n  expanded: boolean,\n  hasPopup: 'listbox' | 'grid' = 'listbox',\n): void {\n  if (!trigger) {\n    return;\n  }\n\n  trigger.setAttribute('autocomplete', 'off');\n  trigger.setAttribute('role', 'combobox');\n  trigger.setAttribute('aria-autocomplete', 'list');\n  trigger.setAttribute('aria-haspopup', hasPopup);\n  trigger.setAttribute('aria-controls', overlayId);\n  trigger.setAttribute('aria-owns', overlayId); // From Aria 1.2 this should not be necessary, but safari still needs it\n  trigger.setAttribute('aria-expanded', `${expanded}`);\n}\n\n/**\n * Remove aria attributes from trigger elements.\n */\nexport function removeAriaComboBoxAttributes(trigger?: HTMLElement): void {\n  if (!trigger) {\n    return;\n  }\n\n  trigger.removeAttribute('autocomplete');\n  trigger.removeAttribute('role');\n  trigger.removeAttribute('aria-autocomplete');\n  trigger.removeAttribute('aria-haspopup');\n  trigger.removeAttribute('aria-controls');\n  trigger.removeAttribute('aria-owns');\n  trigger.removeAttribute('aria-expanded');\n}\n"],"names":["el"],"mappings":"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"}
154
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"overlay.js","sources":["../../../../src/elements/core/overlay/overlay.ts","../../../../src/elements/core/overlay/position.ts","../../../../src/elements/core/overlay/overlay-option-panel.ts","../../../../src/elements/core/overlay/overlay-trigger-attributes.ts"],"sourcesContent":["import type { TemplateResult } from 'lit';\nimport { html } from 'lit';\n\n/**\n * Used to create the \"wrapping\" effect around the anchor for overlays (es. autocomplete)\n * Works in conjunction with the 'overlayGapFixCorners()' function in 'overlay.ts'\n */\nexport function overlayGapFixCorners(): TemplateResult {\n  return html`\n    <div class=\"sbb-gap-fix-wrapper\">\n      <div class=\"sbb-gap-fix-corner\" id=\"left\"></div>\n    </div>\n    <div class=\"sbb-gap-fix-wrapper\">\n      <div class=\"sbb-gap-fix-corner\" id=\"right\"></div>\n    </div>\n  `;\n}\n","export type ElementRectangle = Pick<\n  HTMLElement,\n  'scrollHeight' | 'clientHeight' | 'offsetHeight' | 'scrollWidth' | 'clientWidth' | 'offsetWidth'\n>;\n\nexport interface SbbAlignment {\n  horizontal: 'start' | 'center' | 'end';\n  vertical: 'above' | 'below';\n}\n\nexport interface SbbElementPositionInfos {\n  top: number;\n  left: number;\n  maxHeight: string;\n  alignment: SbbAlignment;\n}\n\n/**\n * Gets height and width of an element even if it's hidden (`display: none`).\n */\nexport function getElementRectangle(el: HTMLElement): ElementRectangle {\n  const elementStyle = window.getComputedStyle(el),\n    elementDisplay = elementStyle.display,\n    elementMaxHeight = parseInt(elementStyle.maxHeight, 10).toString();\n\n  // If it is not hidden we just return normal height\n  if (elementDisplay !== 'none' && elementMaxHeight !== '0') {\n    return {\n      scrollHeight: el.scrollHeight,\n      clientHeight: el.clientHeight,\n      offsetHeight: el.offsetHeight,\n      scrollWidth: el.scrollWidth,\n      clientWidth: el.clientWidth,\n      offsetWidth: el.offsetWidth,\n    };\n  }\n\n  // The element is hidden so:\n  // make the el block in order to measure its height but still be hidden\n  el.style.position = 'absolute';\n  el.style.visibility = 'hidden';\n  el.style.display = 'block';\n\n  const scrollHeight = el.scrollHeight,\n    clientHeight = el.clientHeight,\n    offsetHeight = el.offsetHeight,\n    scrollWidth = el.scrollWidth,\n    clientWidth = el.clientWidth,\n    offsetWidth = el.offsetWidth;\n\n  // Reverting to the original values\n  el.style.display = '';\n  el.style.position = '';\n  el.style.visibility = '';\n\n  return { scrollHeight, clientHeight, offsetHeight, scrollWidth, clientWidth, offsetWidth };\n}\n\n/**\n * Determines whether an event is fired on a specific element.\n */\nexport function isEventOnElement(element: HTMLElement, event: MouseEvent | PointerEvent): boolean {\n  if (!element || !event) {\n    return false;\n  }\n\n  const rect = element.getBoundingClientRect();\n  return (\n    rect.top <= event.clientY &&\n    event.clientY <= rect.top + rect.height &&\n    rect.left <= event.clientX &&\n    event.clientX <= rect.left + rect.width\n  );\n}\n\n/**\n * Determines the position of an element relative to a trigger element by evaluating\n * the optimal position based on the available space.\n *\n * @param element The element of which to calculate the position.\n * @param trigger The element relative to which to calculate the position.\n * @param container The element which has the position:fixed applied.\n * @param properties Properties to take into account in calculations (optional).\n * @param properties.verticalOffset The distance to be added between the element and the trigger (optional).\n * @param properties.horizontalOffset The horizontal offset to be applied to the element (optional).\n * @param properties.centered Whether the element should be placed in the center by default (optional).\n * @param properties.responsiveHeight Whether the element calculates its height based on its content (optional).\n * @returns Returns an object containing the left position, the top position, the maximum height\n * of the element and the current alignment object.\n */\nexport function getElementPosition(\n  element: HTMLElement,\n  trigger: HTMLElement,\n  container: HTMLElement,\n  properties?: {\n    verticalOffset?: number;\n    horizontalOffset?: number;\n    centered?: boolean;\n    responsiveHeight?: boolean;\n  },\n): SbbElementPositionInfos {\n  const maxWidthOffset = 16;\n  const verticalOffset = properties?.verticalOffset || 0;\n  const horizontalOffset = properties?.horizontalOffset || 0;\n  const responsiveHeight = properties?.responsiveHeight || false;\n\n  const triggerRec = trigger.getBoundingClientRect();\n  const elementRec = getElementRectangle(element);\n\n  const triggerLeft = triggerRec.left;\n  const triggerTop = triggerRec.top;\n\n  const availableSpaceRight =\n    document.documentElement.clientWidth - (triggerLeft + triggerRec.width);\n  const availableSpaceAbove = triggerTop - verticalOffset;\n  const availableSpaceBelow =\n    document.documentElement.clientHeight - (triggerTop + triggerRec.height + verticalOffset);\n\n  // Default element alignment is \"start/below\"\n  let elementXPosition = triggerLeft;\n  let elementYPosition = triggerTop + triggerRec.height + verticalOffset;\n  let elementXOverflow = elementRec.offsetWidth - triggerRec.width;\n  const alignment: SbbAlignment = { horizontal: 'start', vertical: 'below' };\n\n  // Calculate element max-height\n  let elementMaxHeight = `${availableSpaceBelow - verticalOffset}px`;\n\n  // Check if horizontal alignment needs to be changed to \"center\"\n  if (\n    properties?.centered &&\n    triggerLeft - maxWidthOffset + triggerRec.width / 2 > elementRec.offsetWidth / 2 &&\n    availableSpaceRight - maxWidthOffset > elementXOverflow / 2\n  ) {\n    elementXPosition -= elementXOverflow /= 2;\n    alignment.horizontal = 'center';\n  }\n\n  // Check if horizontal alignment needs to be changed to \"end\"\n  if (availableSpaceRight < elementXOverflow && triggerLeft > elementXOverflow) {\n    elementXPosition = elementXPosition - elementXOverflow;\n    alignment.horizontal = 'end';\n  }\n\n  // Add horizontal offset\n  if (\n    horizontalOffset &&\n    alignment.horizontal !== 'center' &&\n    triggerRec.width / 2 < horizontalOffset\n  ) {\n    elementXPosition += horizontalOffset * (alignment.horizontal === 'start' ? -1 : 1);\n  }\n\n  // Check whether there is insufficient space on both sides\n  if (\n    (triggerLeft < elementXOverflow && availableSpaceRight < elementXOverflow) ||\n    document.documentElement.clientWidth < elementRec.offsetWidth\n  ) {\n    elementXPosition = document.documentElement.clientWidth / 2 - elementRec.offsetWidth / 2;\n  }\n\n  // Check if vertical alignment needs to be changed to \"above\":\n  if (\n    (availableSpaceBelow - verticalOffset < elementRec.scrollHeight &&\n      availableSpaceAbove - verticalOffset >\n        (responsiveHeight ? elementRec.clientHeight : elementRec.scrollHeight)) ||\n    (availableSpaceAbove > availableSpaceBelow &&\n      availableSpaceBelow - verticalOffset < elementRec.clientHeight &&\n      !responsiveHeight)\n  ) {\n    elementYPosition =\n      availableSpaceAbove < elementRec.scrollHeight\n        ? elementYPosition - triggerRec.height - availableSpaceAbove - verticalOffset\n        : triggerTop - elementRec.clientHeight - verticalOffset;\n\n    elementMaxHeight = `${availableSpaceAbove - verticalOffset}px`;\n    alignment.vertical = 'above';\n  }\n\n  const containerRect = container.getBoundingClientRect();\n\n  // When zooming in Safari the container rectangle contains negative values for the position\n  // and we need to re-add them to the calculated coordinates.\n  if (containerRect.left < 0) {\n    elementXPosition -= containerRect.left;\n  }\n\n  // Normally the containerRect's top value would be zero, however when the overlay is attached to an input\n  // (e.g. in an autocomplete), mobile browsers will shift everything in order to put the input in the middle\n  // of the screen and to make space for the virtual keyboard. We need to account for this offset,\n  // otherwise our positioning will be thrown off.\n  // Additionally, when zooming in Safari this fixes the vertical position.\n  if (containerRect.top < 0) {\n    elementYPosition -= containerRect.top;\n  }\n\n  return {\n    top: elementYPosition,\n    left: elementXPosition,\n    maxHeight: elementMaxHeight,\n    alignment: alignment,\n  };\n}\n","import { getElementPosition } from './position.js';\n\n/**\n * Places the overlay in the correct position.\n * @param dialog The reference to the dialog element.\n * @param originElement The reference to the element the dialog is attached to.\n * @param optionContainer The reference to the option panel.\n * @param container The element which has the position:fixed applied.\n * @param element The reference to the component.\n */\nexport function setOverlayPosition(\n  dialog: HTMLElement,\n  originElement: HTMLElement,\n  optionContainer: HTMLElement,\n  container: HTMLElement,\n  element: HTMLElement,\n): void {\n  if (!dialog || !originElement) {\n    return;\n  }\n\n  // Set the width to match the trigger element\n  element.style.setProperty('--sbb-options-panel-width', `${originElement.offsetWidth}px`);\n\n  // Set the origin height\n  element.style.setProperty('--sbb-options-panel-origin-height', `${originElement.offsetHeight}px`);\n\n  // Calculate and set the position\n  const panelPosition = getElementPosition(optionContainer, originElement, container);\n\n  element.style.setProperty('--sbb-options-panel-position-x', `${panelPosition.left}px`);\n  element.style.setProperty('--sbb-options-panel-position-y', `${panelPosition.top}px`);\n  element.style.setProperty('--sbb-options-panel-max-height', panelPosition.maxHeight);\n  element.setAttribute('data-options-panel-position', panelPosition.alignment.vertical);\n  originElement.setAttribute('data-options-panel-position', panelPosition.alignment.vertical);\n}\n","/**\n * Add meaningful aria attributes to trigger elements that are connected to\n * overlay elements such as menus and dialogs.\n */\nexport function setAriaOverlayTriggerAttributes(\n  trigger: HTMLElement,\n  popupType: 'menu' | 'dialog',\n  overlayId: string,\n  state: string,\n): void {\n  if (!trigger) {\n    return;\n  }\n\n  trigger.setAttribute('aria-haspopup', popupType);\n  trigger.setAttribute('aria-controls', overlayId);\n  trigger.setAttribute('aria-expanded', `${state === 'opening' || state === 'opened'}`);\n}\n\n/**\n * Remove aria attributes from trigger elements.\n */\nexport function removeAriaOverlayTriggerAttributes(trigger: HTMLElement | null | undefined): void {\n  if (!trigger) {\n    return;\n  }\n\n  trigger.removeAttribute('aria-haspopup');\n  trigger.removeAttribute('aria-controls');\n  trigger.removeAttribute('aria-expanded');\n}\n\n/**\n * Add meaningful aria attributes to trigger element of role='combobox'\n */\nexport function setAriaComboBoxAttributes(\n  trigger: HTMLElement,\n  overlayId: string,\n  expanded: boolean,\n  hasPopup: 'listbox' | 'grid' = 'listbox',\n): void {\n  if (!trigger) {\n    return;\n  }\n\n  trigger.setAttribute('autocomplete', 'off');\n  trigger.setAttribute('role', 'combobox');\n  trigger.setAttribute('aria-autocomplete', 'list');\n  trigger.setAttribute('aria-haspopup', hasPopup);\n  trigger.setAttribute('aria-controls', overlayId);\n  trigger.setAttribute('aria-owns', overlayId); // From Aria 1.2 this should not be necessary, but safari still needs it\n  trigger.setAttribute('aria-expanded', `${expanded}`);\n}\n\n/**\n * Remove aria attributes from trigger elements.\n */\nexport function removeAriaComboBoxAttributes(trigger?: HTMLElement): void {\n  if (!trigger) {\n    return;\n  }\n\n  trigger.removeAttribute('autocomplete');\n  trigger.removeAttribute('role');\n  trigger.removeAttribute('aria-autocomplete');\n  trigger.removeAttribute('aria-haspopup');\n  trigger.removeAttribute('aria-controls');\n  trigger.removeAttribute('aria-owns');\n  trigger.removeAttribute('aria-expanded');\n}\n"],"names":[],"mappings":"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"}
@@ -1,4 +1,5 @@
1
1
  import { CSSResultGroup, PropertyValues, TemplateResult, LitElement } from 'lit';
2
+ import { CalendarView } from '../../calendar.js';
2
3
  import { SbbDatepickerElement } from '../datepicker.js';
3
4
  declare const SbbDatepickerToggleElement_base: import('../../core/mixins.js').AbstractConstructor<import('../../core/mixins.js').SbbNegativeMixinType> & import('../../core/mixins.js').AbstractConstructor<import('../../core/mixins.js').SbbHydrationMixinType> & typeof LitElement;
4
5
  /**
@@ -8,6 +9,8 @@ export declare class SbbDatepickerToggleElement<T = Date> extends SbbDatepickerT
8
9
  static styles: CSSResultGroup;
9
10
  /** Datepicker reference. */
10
11
  datePicker?: string | SbbDatepickerElement;
12
+ /** The initial view of calendar which should be displayed on opening. */
13
+ view: CalendarView;
11
14
  private _disabled;
12
15
  private _min;
13
16
  private _max;
@@ -18,6 +21,7 @@ export declare class SbbDatepickerToggleElement<T = Date> extends SbbDatepickerT
18
21
  private _popoverElement;
19
22
  private _datePickerController;
20
23
  private _language;
24
+ private _abort;
21
25
  constructor();
22
26
  /**
23
27
  * Opens the calendar.
@@ -1 +1 @@
1
- {"version":3,"file":"datepicker-toggle.d.ts","sourceRoot":"","sources":["../../../../../src/elements/datepicker/datepicker-toggle/datepicker-toggle.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAkB,UAAU,EAAW,MAAM,KAAK,CAAC;AAW1D,OAAO,KAAK,EAAE,oBAAoB,EAAuB,MAAM,kBAAkB,CAAC;AAKlF,OAAO,mBAAmB,CAAC;AAC3B,OAAO,kBAAkB,CAAC;;AAE1B;;GAEG;AACH,qBAIa,0BAA0B,CAAC,CAAC,GAAG,IAAI,CAAE,SAAQ,+BAEzD;IACC,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,4BAA4B;IACmB,UAAU,CAAC,EAAE,MAAM,GAAG,oBAAoB,CAAC;IAEjF,OAAO,CAAC,SAAS,CAAS;IAE1B,OAAO,CAAC,IAAI,CAA4C;IAExD,OAAO,CAAC,IAAI,CAA4C;IAExD,OAAO,CAAC,eAAe,CAAS;IAEzC,OAAO,CAAC,kBAAkB,CAA6C;IAEvE,OAAO,CAAC,gBAAgB,CAAyB;IAEjD,OAAO,CAAC,eAAe,CAA4B;IAEnD,OAAO,CAAC,eAAe,CAAqB;IAE5C,OAAO,CAAC,qBAAqB,CAAmB;IAEhD,OAAO,CAAC,SAAS,CAAmC;;IASpD;;OAEG;IACI,IAAI,IAAI,IAAI;IAOH,iBAAiB,IAAI,IAAI;IAYzB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAQzD,oBAAoB,IAAI,IAAI;IAK5C,OAAO,CAAC,KAAK;IAyCb,OAAO,CAAC,kBAAkB;IAY1B,OAAO,CAAC,kBAAkB;IAO1B,OAAO,CAAC,eAAe;cAgBJ,OAAO,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAMzE,OAAO,CAAC,eAAe;cAIJ,MAAM,IAAI,cAAc;CA0C5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,uBAAuB,EAAE,0BAA0B,CAAC;KACrD;CACF"}
1
+ {"version":3,"file":"datepicker-toggle.d.ts","sourceRoot":"","sources":["../../../../../src/elements/datepicker/datepicker-toggle/datepicker-toggle.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAkB,UAAU,EAAW,MAAM,KAAK,CAAC;AAI1D,OAAO,KAAK,EAAE,YAAY,EAAsB,MAAM,mBAAmB,CAAC;AAO1E,OAAO,KAAK,EAAE,oBAAoB,EAAuB,MAAM,kBAAkB,CAAC;AAKlF,OAAO,mBAAmB,CAAC;AAC3B,OAAO,kBAAkB,CAAC;;AAE1B;;GAEG;AACH,qBAIa,0BAA0B,CAAC,CAAC,GAAG,IAAI,CAAE,SAAQ,+BAEzD;IACC,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,4BAA4B;IACmB,UAAU,CAAC,EAAE,MAAM,GAAG,oBAAoB,CAAC;IAE1F,yEAAyE;IACtD,IAAI,EAAE,YAAY,CAAS;IAErC,OAAO,CAAC,SAAS,CAAS;IAE1B,OAAO,CAAC,IAAI,CAA4C;IAExD,OAAO,CAAC,IAAI,CAA4C;IAExD,OAAO,CAAC,eAAe,CAAS;IAEzC,OAAO,CAAC,kBAAkB,CAA6C;IACvE,OAAO,CAAC,gBAAgB,CAAyB;IACjD,OAAO,CAAC,eAAe,CAA4B;IACnD,OAAO,CAAC,eAAe,CAAqB;IAC5C,OAAO,CAAC,qBAAqB,CAAmB;IAChD,OAAO,CAAC,SAAS,CAAmC;IACpD,OAAO,CAAC,MAAM,CAAyC;;IASvD;;OAEG;IACI,IAAI,IAAI,IAAI;IAOH,iBAAiB,IAAI,IAAI;IAsBzB,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAQzD,oBAAoB,IAAI,IAAI;IAK5C,OAAO,CAAC,KAAK;IAyCb,OAAO,CAAC,kBAAkB;IAY1B,OAAO,CAAC,kBAAkB;IAO1B,OAAO,CAAC,eAAe;cAgBJ,OAAO,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAMzE,OAAO,CAAC,eAAe;cAIJ,MAAM,IAAI,cAAc;CA2C5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,uBAAuB,EAAE,0BAA0B,CAAC;KACrD;CACF"}
@@ -2,7 +2,7 @@ import { css, LitElement, isServer, html, nothing } from "lit";
2
2
  import { property, state, customElement } from "lit/decorators.js";
3
3
  import { ref } from "lit/directives/ref.js";
4
4
  import { sbbInputModalityDetector } from "../core/a11y.js";
5
- import { SbbLanguageController } from "../core/controllers.js";
5
+ import { SbbLanguageController, SbbConnectedAbortController } from "../core/controllers.js";
6
6
  import { hostAttributes } from "../core/decorators.js";
7
7
  import { i18nShowCalendar } from "../core/i18n.js";
8
8
  import { SbbNegativeMixin, SbbHydrationMixin } from "../core/mixins.js";
@@ -64,11 +64,13 @@ let SbbDatepickerToggleElement = class extends SbbNegativeMixin(
64
64
  ) {
65
65
  constructor() {
66
66
  super();
67
+ this.view = "day";
67
68
  this._disabled = false;
68
69
  this._min = null;
69
70
  this._max = null;
70
71
  this._renderCalendar = false;
71
72
  this._language = new SbbLanguageController(this);
73
+ this._abort = new SbbConnectedAbortController(this);
72
74
  if (!isServer) {
73
75
  this.hydrationComplete.then(() => this._renderCalendar = true);
74
76
  }
@@ -92,6 +94,15 @@ let SbbDatepickerToggleElement = class extends SbbNegativeMixin(
92
94
  if (formField) {
93
95
  this.negative = formField.hasAttribute("negative");
94
96
  }
97
+ this.addEventListener(
98
+ "click",
99
+ (event) => {
100
+ if (event.composedPath()[0] === this) {
101
+ this.open();
102
+ }
103
+ },
104
+ { signal: this._abort.signal }
105
+ );
95
106
  }
96
107
  willUpdate(changedProperties) {
97
108
  super.willUpdate(changedProperties);
@@ -199,6 +210,7 @@ let SbbDatepickerToggleElement = class extends SbbNegativeMixin(
199
210
  ${ref((el) => this._popoverElement = el)}
200
211
  >
201
212
  ${this._renderCalendar ? html`<sbb-calendar
213
+ .view=${this.view}
202
214
  .min=${this._min}
203
215
  .max=${this._max}
204
216
  .now=${this._nowOrUndefined()}
@@ -222,6 +234,9 @@ SbbDatepickerToggleElement.styles = style;
222
234
  __decorateClass([
223
235
  property({ attribute: "date-picker" })
224
236
  ], SbbDatepickerToggleElement.prototype, "datePicker", 2);
237
+ __decorateClass([
238
+ property()
239
+ ], SbbDatepickerToggleElement.prototype, "view", 2);
225
240
  __decorateClass([
226
241
  state()
227
242
  ], SbbDatepickerToggleElement.prototype, "_disabled", 2);
@@ -243,4 +258,4 @@ SbbDatepickerToggleElement = __decorateClass([
243
258
  export {
244
259
  SbbDatepickerToggleElement
245
260
  };
246
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"datepicker-toggle.js","sources":["../../../../src/elements/datepicker/datepicker-toggle/datepicker-toggle.ts"],"sourcesContent":["import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, isServer, LitElement, nothing } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\n\nimport type { SbbCalendarElement } from '../../calendar.js';\nimport { sbbInputModalityDetector } from '../../core/a11y.js';\nimport { SbbLanguageController } from '../../core/controllers.js';\nimport { hostAttributes } from '../../core/decorators.js';\nimport { i18nShowCalendar } from '../../core/i18n.js';\nimport { SbbHydrationMixin, SbbNegativeMixin } from '../../core/mixins.js';\nimport type { SbbPopoverElement, SbbPopoverTriggerElement } from '../../popover.js';\nimport type { SbbDatepickerElement, SbbInputUpdateEvent } from '../datepicker.js';\nimport { datepickerControlRegisteredEventFactory, getDatePicker } from '../datepicker.js';\n\nimport style from './datepicker-toggle.scss?lit&inline';\n\nimport '../../calendar.js';\nimport '../../popover.js';\n\n/**\n * Combined with a `sbb-datepicker`, it can be used to select a date from a `sbb-calendar`.\n */\n@customElement('sbb-datepicker-toggle')\n@hostAttributes({\n  slot: 'prefix',\n})\nexport class SbbDatepickerToggleElement<T = Date> extends SbbNegativeMixin(\n  SbbHydrationMixin(LitElement),\n) {\n  public static override styles: CSSResultGroup = style;\n\n  /** Datepicker reference. */\n  @property({ attribute: 'date-picker' }) public datePicker?: string | SbbDatepickerElement;\n\n  @state() private _disabled = false;\n\n  @state() private _min: string | number | null | undefined = null;\n\n  @state() private _max: string | number | null | undefined = null;\n\n  @state() private _renderCalendar = false;\n\n  private _datePickerElement: SbbDatepickerElement<T> | null | undefined;\n\n  private _calendarElement!: SbbCalendarElement<T>;\n\n  private _triggerElement!: SbbPopoverTriggerElement;\n\n  private _popoverElement!: SbbPopoverElement;\n\n  private _datePickerController!: AbortController;\n\n  private _language = new SbbLanguageController(this);\n\n  public constructor() {\n    super();\n    if (!isServer) {\n      this.hydrationComplete.then(() => (this._renderCalendar = true));\n    }\n  }\n\n  /**\n   * Opens the calendar.\n   */\n  public open(): void {\n    if (!this._triggerElement) {\n      this._triggerElement = this.shadowRoot!.querySelector('sbb-popover-trigger')!;\n    }\n    this._triggerElement.click();\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    if (!this.datePicker) {\n      this._init();\n    }\n\n    const formField = this.closest?.('sbb-form-field') ?? this.closest?.('[data-form-field]');\n    if (formField) {\n      this.negative = formField.hasAttribute('negative');\n    }\n  }\n\n  public override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('datePicker')) {\n      this._init(this.datePicker);\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._datePickerController?.abort();\n  }\n\n  private _init(datePicker?: string | SbbDatepickerElement): void {\n    this._datePickerController?.abort();\n    this._datePickerController = new AbortController();\n    this._datePickerElement = getDatePicker<T>(this, datePicker);\n    if (!this._datePickerElement) {\n      // If the component is attached to the DOM before the datepicker, it has to listen for the datepicker init,\n      // assuming that the two components share the same parent element.\n      this.parentElement?.addEventListener(\n        'inputUpdated',\n        (e: Event) => this._init(e.target as SbbDatepickerElement),\n        { once: true, signal: this._datePickerController.signal },\n      );\n      return;\n    }\n\n    this._datePickerElement?.addEventListener(\n      'inputUpdated',\n      (event: CustomEvent<SbbInputUpdateEvent>) => {\n        this._datePickerElement = event.target as SbbDatepickerElement<T>;\n        this._disabled = !!(event.detail.disabled || event.detail.readonly);\n        this._min = event.detail.min;\n        this._max = event.detail.max;\n      },\n      { signal: this._datePickerController.signal },\n    );\n    this._datePickerElement?.addEventListener(\n      'change',\n      (event: Event) => this._datePickerChanged(event),\n      {\n        signal: this._datePickerController.signal,\n      },\n    );\n    this._datePickerElement?.addEventListener(\n      'datePickerUpdated',\n      (event: Event) =>\n        this._configureCalendar(this._calendarElement, event.target as SbbDatepickerElement<T>),\n      { signal: this._datePickerController.signal },\n    );\n    this._datePickerElement.dispatchEvent(datepickerControlRegisteredEventFactory());\n  }\n\n  private _configureCalendar(\n    calendar: SbbCalendarElement<T>,\n    datepicker: SbbDatepickerElement<T>,\n  ): void {\n    if (!calendar || !datepicker) {\n      return;\n    }\n    calendar.wide = datepicker.wide;\n    calendar.now = this._nowOrUndefined();\n    calendar.dateFilter = datepicker.dateFilter;\n  }\n\n  private _datePickerChanged(event: Event): void {\n    this._datePickerElement = event.target as SbbDatepickerElement<T>;\n    if (this._calendarElement && this._datePickerElement.valueAsDate) {\n      this._calendarElement.selected = this._datePickerElement.valueAsDate;\n    }\n  }\n\n  private _assignCalendar(calendar: SbbCalendarElement<T>): void {\n    if (this._calendarElement && this._calendarElement === calendar) {\n      return;\n    }\n    this._calendarElement = calendar;\n    if (\n      !('valueAsDate' in (this._datePickerElement ?? {})) ||\n      !this._calendarElement?.resetPosition\n    ) {\n      return;\n    }\n    this._calendarElement.selected = this._datePickerElement!.valueAsDate ?? undefined;\n    this._configureCalendar(this._calendarElement, this._datePickerElement!);\n    this._calendarElement.resetPosition();\n  }\n\n  protected override updated(changedProperties: PropertyValues<this>): void {\n    super.updated(changedProperties);\n\n    this._popoverElement.trigger = this._triggerElement;\n  }\n\n  private _nowOrUndefined(): T | undefined {\n    return this._datePickerElement?.hasCustomNow() ? this._datePickerElement.now : undefined;\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <sbb-popover-trigger\n        icon-name=\"calendar-small\"\n        aria-label=${i18nShowCalendar[this._language.current]}\n        ?disabled=${!isServer && (!this._datePickerElement || this._disabled)}\n        ?negative=${this.negative}\n        data-icon-small\n        ${ref((el?: Element) => (this._triggerElement = el as SbbPopoverTriggerElement))}\n      ></sbb-popover-trigger>\n      <sbb-popover\n        @willOpen=${() => this._calendarElement.resetPosition()}\n        @didOpen=${() => {\n          if (sbbInputModalityDetector.mostRecentModality === 'keyboard') {\n            this._calendarElement.focus();\n          }\n        }}\n        .trigger=${this._triggerElement}\n        hide-close-button\n        ${ref((el?: Element) => (this._popoverElement = el as SbbPopoverElement))}\n      >\n        ${this._renderCalendar\n          ? html`<sbb-calendar\n              .min=${this._min}\n              .max=${this._max}\n              .now=${this._nowOrUndefined()}\n              ?wide=${this._datePickerElement?.wide}\n              .dateFilter=${this._datePickerElement?.dateFilter}\n              @dateSelected=${(d: CustomEvent<T>) => {\n                this._calendarElement.selected = d.detail;\n                if (this._datePickerElement) {\n                  this._datePickerElement.valueAsDate = d.detail;\n                }\n              }}\n              ${ref((calendar?: Element) =>\n                this._assignCalendar(calendar as SbbCalendarElement<T>),\n              )}\n            ></sbb-calendar>`\n          : nothing}\n      </sbb-popover>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-datepicker-toggle': SbbDatepickerToggleElement;\n  }\n}\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA2BO,IAAM,6BAAN,cAAmD;AAAA,EACxD,kBAAkB,UAAU;AAC9B,EAAE;AAAA,EA0BO,cAAc;AACb;AArBC,SAAQ,YAAY;AAEpB,SAAQ,OAA2C;AAEnD,SAAQ,OAA2C;AAEnD,SAAQ,kBAAkB;AAY3B,SAAA,YAAY,IAAI,sBAAsB,IAAI;AAIhD,QAAI,CAAC,UAAU;AACb,WAAK,kBAAkB,KAAK,MAAO,KAAK,kBAAkB,IAAK;AAAA,IACjE;AAAA,EACF;AAAA;AAAA;AAAA;AAAA,EAKO,OAAa;AACd,QAAA,CAAC,KAAK,iBAAiB;AACzB,WAAK,kBAAkB,KAAK,WAAY,cAAc,qBAAqB;AAAA,IAC7E;AACA,SAAK,gBAAgB;EACvB;AAAA,EAEgB,oBAA0B;;AACxC,UAAM,kBAAkB;AACpB,QAAA,CAAC,KAAK,YAAY;AACpB,WAAK,MAAM;AAAA,IACb;AAEA,UAAM,cAAY,UAAK,YAAL,8BAAe,wBAAqB,UAAK,YAAL,8BAAe;AACrE,QAAI,WAAW;AACR,WAAA,WAAW,UAAU,aAAa,UAAU;AAAA,IACnD;AAAA,EACF;AAAA,EAEgB,WAAW,mBAA+C;AACxE,UAAM,WAAW,iBAAiB;AAE9B,QAAA,kBAAkB,IAAI,YAAY,GAAG;AAClC,WAAA,MAAM,KAAK,UAAU;AAAA,IAC5B;AAAA,EACF;AAAA,EAEgB,uBAA6B;;AAC3C,UAAM,qBAAqB;AAC3B,eAAK,0BAAL,mBAA4B;AAAA,EAC9B;AAAA,EAEQ,MAAM,YAAkD;;AAC9D,eAAK,0BAAL,mBAA4B;AACvB,SAAA,wBAAwB,IAAI;AAC5B,SAAA,qBAAqB,cAAiB,MAAM,UAAU;AACvD,QAAA,CAAC,KAAK,oBAAoB;AAG5B,iBAAK,kBAAL,mBAAoB;AAAA,QAClB;AAAA,QACA,CAAC,MAAa,KAAK,MAAM,EAAE,MAA8B;AAAA,QACzD,EAAE,MAAM,MAAM,QAAQ,KAAK,sBAAsB,OAAO;AAAA;AAE1D;AAAA,IACF;AAEA,eAAK,uBAAL,mBAAyB;AAAA,MACvB;AAAA,MACA,CAAC,UAA4C;AAC3C,aAAK,qBAAqB,MAAM;AAChC,aAAK,YAAY,CAAC,EAAE,MAAM,OAAO,YAAY,MAAM,OAAO;AACrD,aAAA,OAAO,MAAM,OAAO;AACpB,aAAA,OAAO,MAAM,OAAO;AAAA,MAC3B;AAAA,MACA,EAAE,QAAQ,KAAK,sBAAsB,OAAO;AAAA;AAE9C,eAAK,uBAAL,mBAAyB;AAAA,MACvB;AAAA,MACA,CAAC,UAAiB,KAAK,mBAAmB,KAAK;AAAA,MAC/C;AAAA,QACE,QAAQ,KAAK,sBAAsB;AAAA,MACrC;AAAA;AAEF,eAAK,uBAAL,mBAAyB;AAAA,MACvB;AAAA,MACA,CAAC,UACC,KAAK,mBAAmB,KAAK,kBAAkB,MAAM,MAAiC;AAAA,MACxF,EAAE,QAAQ,KAAK,sBAAsB,OAAO;AAAA;AAEzC,SAAA,mBAAmB,cAAc,wCAAyC,CAAA;AAAA,EACjF;AAAA,EAEQ,mBACN,UACA,YACM;AACF,QAAA,CAAC,YAAY,CAAC,YAAY;AAC5B;AAAA,IACF;AACA,aAAS,OAAO,WAAW;AAClB,aAAA,MAAM,KAAK;AACpB,aAAS,aAAa,WAAW;AAAA,EACnC;AAAA,EAEQ,mBAAmB,OAAoB;AAC7C,SAAK,qBAAqB,MAAM;AAChC,QAAI,KAAK,oBAAoB,KAAK,mBAAmB,aAAa;AAC3D,WAAA,iBAAiB,WAAW,KAAK,mBAAmB;AAAA,IAC3D;AAAA,EACF;AAAA,EAEQ,gBAAgB,UAAuC;;AAC7D,QAAI,KAAK,oBAAoB,KAAK,qBAAqB,UAAU;AAC/D;AAAA,IACF;AACA,SAAK,mBAAmB;AAEtB,QAAA,EAAE,kBAAkB,KAAK,sBAAsB,CAAA,OAC/C,GAAC,UAAK,qBAAL,mBAAuB,gBACxB;AACA;AAAA,IACF;AACA,SAAK,iBAAiB,WAAW,KAAK,mBAAoB,eAAe;AACzE,SAAK,mBAAmB,KAAK,kBAAkB,KAAK,kBAAmB;AACvE,SAAK,iBAAiB;EACxB;AAAA,EAEmB,QAAQ,mBAA+C;AACxE,UAAM,QAAQ,iBAAiB;AAE1B,SAAA,gBAAgB,UAAU,KAAK;AAAA,EACtC;AAAA,EAEQ,kBAAiC;;AACvC,aAAO,UAAK,uBAAL,mBAAyB,kBAAiB,KAAK,mBAAmB,MAAM;AAAA,EACjF;AAAA,EAEmB,SAAyB;;AACnC,WAAA;AAAA;AAAA;AAAA,qBAGU,iBAAiB,KAAK,UAAU,OAAO,CAAC;AAAA,oBACzC,CAAC,aAAa,CAAC,KAAK,sBAAsB,KAAK,UAAU;AAAA,oBACzD,KAAK,QAAQ;AAAA;AAAA,UAEvB,IAAI,CAAC,OAAkB,KAAK,kBAAkB,EAA+B,CAAC;AAAA;AAAA;AAAA,oBAGpE,MAAM,KAAK,iBAAiB,eAAe;AAAA,mBAC5C,MAAM;AACX,UAAA,yBAAyB,uBAAuB,YAAY;AAC9D,aAAK,iBAAiB;MACxB;AAAA,IAAA,CACD;AAAA,mBACU,KAAK,eAAe;AAAA;AAAA,UAE7B,IAAI,CAAC,OAAkB,KAAK,kBAAkB,EAAwB,CAAC;AAAA;AAAA,UAEvE,KAAK,kBACH;AAAA,qBACS,KAAK,IAAI;AAAA,qBACT,KAAK,IAAI;AAAA,qBACT,KAAK,iBAAiB;AAAA,uBACrB,UAAK,uBAAL,mBAAyB,IAAI;AAAA,6BACvB,UAAK,uBAAL,mBAAyB,UAAU;AAAA,8BACjC,CAAC,MAAsB;AAChC,WAAA,iBAAiB,WAAW,EAAE;AACnC,UAAI,KAAK,oBAAoB;AACtB,aAAA,mBAAmB,cAAc,EAAE;AAAA,MAC1C;AAAA,IAAA,CACD;AAAA,gBACC;AAAA,MAAI,CAAC,aACL,KAAK,gBAAgB,QAAiC;AAAA,IAAA,CACvD;AAAA,gCAEH,OAAO;AAAA;AAAA;AAAA,EAGjB;AACF;AAtMa,2BAGY,SAAyB;AAGD,gBAAA;AAAA,EAA9C,SAAS,EAAE,WAAW,eAAe;AAAA,GAN3B,2BAMoC,WAAA,cAAA,CAAA;AAE9B,gBAAA;AAAA,EAAhB,MAAM;AAAA,GARI,2BAQM,WAAA,aAAA,CAAA;AAEA,gBAAA;AAAA,EAAhB,MAAM;AAAA,GAVI,2BAUM,WAAA,QAAA,CAAA;AAEA,gBAAA;AAAA,EAAhB,MAAM;AAAA,GAZI,2BAYM,WAAA,QAAA,CAAA;AAEA,gBAAA;AAAA,EAAhB,MAAM;AAAA,GAdI,2BAcM,WAAA,mBAAA,CAAA;AAdN,6BAAN,gBAAA;AAAA,EAJN,cAAc,uBAAuB;AAAA,EACrC,eAAe;AAAA,IACd,MAAM;AAAA,EAAA,CACP;AAAA,GACY,0BAAA;"}
261
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"datepicker-toggle.js","sources":["../../../../src/elements/datepicker/datepicker-toggle/datepicker-toggle.ts"],"sourcesContent":["import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { html, isServer, LitElement, nothing } from 'lit';\nimport { customElement, property, state } from 'lit/decorators.js';\nimport { ref } from 'lit/directives/ref.js';\n\nimport type { CalendarView, SbbCalendarElement } from '../../calendar.js';\nimport { sbbInputModalityDetector } from '../../core/a11y.js';\nimport { SbbConnectedAbortController, SbbLanguageController } from '../../core/controllers.js';\nimport { hostAttributes } from '../../core/decorators.js';\nimport { i18nShowCalendar } from '../../core/i18n.js';\nimport { SbbHydrationMixin, SbbNegativeMixin } from '../../core/mixins.js';\nimport type { SbbPopoverElement, SbbPopoverTriggerElement } from '../../popover.js';\nimport type { SbbDatepickerElement, SbbInputUpdateEvent } from '../datepicker.js';\nimport { datepickerControlRegisteredEventFactory, getDatePicker } from '../datepicker.js';\n\nimport style from './datepicker-toggle.scss?lit&inline';\n\nimport '../../calendar.js';\nimport '../../popover.js';\n\n/**\n * Combined with a `sbb-datepicker`, it can be used to select a date from a `sbb-calendar`.\n */\n@customElement('sbb-datepicker-toggle')\n@hostAttributes({\n  slot: 'prefix',\n})\nexport class SbbDatepickerToggleElement<T = Date> extends SbbNegativeMixin(\n  SbbHydrationMixin(LitElement),\n) {\n  public static override styles: CSSResultGroup = style;\n\n  /** Datepicker reference. */\n  @property({ attribute: 'date-picker' }) public datePicker?: string | SbbDatepickerElement;\n\n  /** The initial view of calendar which should be displayed on opening. */\n  @property() public view: CalendarView = 'day';\n\n  @state() private _disabled = false;\n\n  @state() private _min: string | number | null | undefined = null;\n\n  @state() private _max: string | number | null | undefined = null;\n\n  @state() private _renderCalendar = false;\n\n  private _datePickerElement: SbbDatepickerElement<T> | null | undefined;\n  private _calendarElement!: SbbCalendarElement<T>;\n  private _triggerElement!: SbbPopoverTriggerElement;\n  private _popoverElement!: SbbPopoverElement;\n  private _datePickerController!: AbortController;\n  private _language = new SbbLanguageController(this);\n  private _abort = new SbbConnectedAbortController(this);\n\n  public constructor() {\n    super();\n    if (!isServer) {\n      this.hydrationComplete.then(() => (this._renderCalendar = true));\n    }\n  }\n\n  /**\n   * Opens the calendar.\n   */\n  public open(): void {\n    if (!this._triggerElement) {\n      this._triggerElement = this.shadowRoot!.querySelector('sbb-popover-trigger')!;\n    }\n    this._triggerElement.click();\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n    if (!this.datePicker) {\n      this._init();\n    }\n\n    const formField = this.closest?.('sbb-form-field') ?? this.closest?.('[data-form-field]');\n    if (formField) {\n      this.negative = formField.hasAttribute('negative');\n    }\n\n    this.addEventListener(\n      'click',\n      (event) => {\n        if (event.composedPath()[0] === this) {\n          this.open();\n        }\n      },\n      { signal: this._abort.signal },\n    );\n  }\n\n  public override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('datePicker')) {\n      this._init(this.datePicker);\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._datePickerController?.abort();\n  }\n\n  private _init(datePicker?: string | SbbDatepickerElement): void {\n    this._datePickerController?.abort();\n    this._datePickerController = new AbortController();\n    this._datePickerElement = getDatePicker<T>(this, datePicker);\n    if (!this._datePickerElement) {\n      // If the component is attached to the DOM before the datepicker, it has to listen for the datepicker init,\n      // assuming that the two components share the same parent element.\n      this.parentElement?.addEventListener(\n        'inputUpdated',\n        (e: Event) => this._init(e.target as SbbDatepickerElement),\n        { once: true, signal: this._datePickerController.signal },\n      );\n      return;\n    }\n\n    this._datePickerElement?.addEventListener(\n      'inputUpdated',\n      (event: CustomEvent<SbbInputUpdateEvent>) => {\n        this._datePickerElement = event.target as SbbDatepickerElement<T>;\n        this._disabled = !!(event.detail.disabled || event.detail.readonly);\n        this._min = event.detail.min;\n        this._max = event.detail.max;\n      },\n      { signal: this._datePickerController.signal },\n    );\n    this._datePickerElement?.addEventListener(\n      'change',\n      (event: Event) => this._datePickerChanged(event),\n      {\n        signal: this._datePickerController.signal,\n      },\n    );\n    this._datePickerElement?.addEventListener(\n      'datePickerUpdated',\n      (event: Event) =>\n        this._configureCalendar(this._calendarElement, event.target as SbbDatepickerElement<T>),\n      { signal: this._datePickerController.signal },\n    );\n    this._datePickerElement.dispatchEvent(datepickerControlRegisteredEventFactory());\n  }\n\n  private _configureCalendar(\n    calendar: SbbCalendarElement<T>,\n    datepicker: SbbDatepickerElement<T>,\n  ): void {\n    if (!calendar || !datepicker) {\n      return;\n    }\n    calendar.wide = datepicker.wide;\n    calendar.now = this._nowOrUndefined();\n    calendar.dateFilter = datepicker.dateFilter;\n  }\n\n  private _datePickerChanged(event: Event): void {\n    this._datePickerElement = event.target as SbbDatepickerElement<T>;\n    if (this._calendarElement && this._datePickerElement.valueAsDate) {\n      this._calendarElement.selected = this._datePickerElement.valueAsDate;\n    }\n  }\n\n  private _assignCalendar(calendar: SbbCalendarElement<T>): void {\n    if (this._calendarElement && this._calendarElement === calendar) {\n      return;\n    }\n    this._calendarElement = calendar;\n    if (\n      !('valueAsDate' in (this._datePickerElement ?? {})) ||\n      !this._calendarElement?.resetPosition\n    ) {\n      return;\n    }\n    this._calendarElement.selected = this._datePickerElement!.valueAsDate ?? undefined;\n    this._configureCalendar(this._calendarElement, this._datePickerElement!);\n    this._calendarElement.resetPosition();\n  }\n\n  protected override updated(changedProperties: PropertyValues<this>): void {\n    super.updated(changedProperties);\n\n    this._popoverElement.trigger = this._triggerElement;\n  }\n\n  private _nowOrUndefined(): T | undefined {\n    return this._datePickerElement?.hasCustomNow() ? this._datePickerElement.now : undefined;\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <sbb-popover-trigger\n        icon-name=\"calendar-small\"\n        aria-label=${i18nShowCalendar[this._language.current]}\n        ?disabled=${!isServer && (!this._datePickerElement || this._disabled)}\n        ?negative=${this.negative}\n        data-icon-small\n        ${ref((el?: Element) => (this._triggerElement = el as SbbPopoverTriggerElement))}\n      ></sbb-popover-trigger>\n      <sbb-popover\n        @willOpen=${() => this._calendarElement.resetPosition()}\n        @didOpen=${() => {\n          if (sbbInputModalityDetector.mostRecentModality === 'keyboard') {\n            this._calendarElement.focus();\n          }\n        }}\n        .trigger=${this._triggerElement}\n        hide-close-button\n        ${ref((el?: Element) => (this._popoverElement = el as SbbPopoverElement))}\n      >\n        ${this._renderCalendar\n          ? html`<sbb-calendar\n              .view=${this.view}\n              .min=${this._min}\n              .max=${this._max}\n              .now=${this._nowOrUndefined()}\n              ?wide=${this._datePickerElement?.wide}\n              .dateFilter=${this._datePickerElement?.dateFilter}\n              @dateSelected=${(d: CustomEvent<T>) => {\n                this._calendarElement.selected = d.detail;\n                if (this._datePickerElement) {\n                  this._datePickerElement.valueAsDate = d.detail;\n                }\n              }}\n              ${ref((calendar?: Element) =>\n                this._assignCalendar(calendar as SbbCalendarElement<T>),\n              )}\n            ></sbb-calendar>`\n          : nothing}\n      </sbb-popover>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-datepicker-toggle': SbbDatepickerToggleElement;\n  }\n}\n"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"dialog.d.ts","sourceRoot":"","sources":["../../../../../src/elements/dialog/dialog/dialog.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAQ1E,OAAO,EAAe,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AAMtE,OAAO,6BAA6B,CAAC;AAIrC;;;;;;;;;;;GAWG;AACH,qBACa,gBAAiB,SAAQ,qBAAqB;IACzD,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,6BAA6B;IACsB,cAAc,EAAE,OAAO,GAAG,MAAM,CAAW;IAM9F,OAAO,CAAC,4BAA4B,CAElC;IAEF,OAAO,CAAC,mBAAmB,CAAsC;IACjE,OAAO,CAAC,kBAAkB,CAAC,CAAS;IACpC,OAAO,CAAC,qBAAqB,CAA4B;IACzD,OAAO,CAAC,qBAAqB,CAAwC;IACrE,OAAO,CAAC,2BAA2B,CAAkB;IACrD,OAAO,CAAC,UAAU,CAAkB;IACpC,OAAO,CAAC,WAAW,CAAK;IACxB,OAAO,CAAC,SAAS,CAA4B;IAC7C,SAAS,CAAC,cAAc,EAAE,MAAM,CAAsB;IAEtD,2BAA2B;IACpB,IAAI,IAAI,IAAI;IA2BH,iBAAiB,IAAI,IAAI;cAYtB,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAO3D,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAQ5D,oBAAoB,IAAI,IAAI;cAKzB,uBAAuB,IAAI,IAAI;IAgBlD,SAAS,CAAC,qBAAqB,CAAC,KAAK,EAAE,cAAc,GAAG,IAAI;IAsC5D,SAAS,CAAC,eAAe,IAAI,IAAI;IAQjC,OAAO,CAAC,aAAa;IAUrB,OAAO,CAAC,gBAAgB;IAqCxB,OAAO,CAAC,oBAAoB,CAS1B;IAGF,OAAO,CAAC,qBAAqB,CAc3B;IAEF,OAAO,CAAC,sBAAsB;IAK9B,OAAO,CAAC,gBAAgB;IASxB,OAAO,CAAC,2BAA2B;IAYnC,OAAO,CAAC,0BAA0B;cAMf,MAAM,IAAI,cAAc;CAmB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,YAAY,EAAE,gBAAgB,CAAC;KAChC;CACF"}
1
+ {"version":3,"file":"dialog.d.ts","sourceRoot":"","sources":["../../../../../src/elements/dialog/dialog/dialog.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAO1E,OAAO,EAAe,qBAAqB,EAAE,MAAM,kBAAkB,CAAC;AAMtE,OAAO,6BAA6B,CAAC;AAIrC;;;;;;;;;;;GAWG;AACH,qBACa,gBAAiB,SAAQ,qBAAqB;IACzD,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,6BAA6B;IACsB,cAAc,EAAE,OAAO,GAAG,MAAM,CAAW;IAM9F,OAAO,CAAC,4BAA4B,CAElC;IAEF,OAAO,CAAC,mBAAmB,CAAsC;IACjE,OAAO,CAAC,kBAAkB,CAAC,CAAS;IACpC,OAAO,CAAC,qBAAqB,CAA4B;IACzD,OAAO,CAAC,qBAAqB,CAAwC;IACrE,OAAO,CAAC,2BAA2B,CAAkB;IACrD,OAAO,CAAC,UAAU,CAAkB;IACpC,OAAO,CAAC,WAAW,CAAK;IACxB,OAAO,CAAC,SAAS,CAA4B;IAC7C,SAAS,CAAC,cAAc,EAAE,MAAM,CAAsB;IAEtD,2BAA2B;IACpB,IAAI,IAAI,IAAI;IA2BH,iBAAiB,IAAI,IAAI;cAYtB,YAAY,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;cAO3D,UAAU,CAAC,iBAAiB,EAAE,cAAc,CAAC,IAAI,CAAC,GAAG,IAAI;IAQ5D,oBAAoB,IAAI,IAAI;cAKzB,uBAAuB,IAAI,IAAI;IAgBlD,SAAS,CAAC,qBAAqB,CAAC,KAAK,EAAE,cAAc,GAAG,IAAI;IAsC5D,SAAS,CAAC,eAAe,IAAI,IAAI;IAQjC,OAAO,CAAC,aAAa;IAUrB,OAAO,CAAC,gBAAgB;IAqCxB,OAAO,CAAC,oBAAoB,CAS1B;IAGF,OAAO,CAAC,qBAAqB,CAc3B;IAEF,OAAO,CAAC,sBAAsB;IAK9B,OAAO,CAAC,gBAAgB;IASxB,OAAO,CAAC,2BAA2B;IAYnC,OAAO,CAAC,0BAA0B;cAMf,MAAM,IAAI,cAAc;CAmB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,YAAY,EAAE,gBAAgB,CAAC;KAChC;CACF"}
@@ -3,7 +3,6 @@ import { html } from "lit/static-html.js";
3
3
  import { setModalityOnNextFocus, getFirstFocusableElement } from "../core/a11y.js";
4
4
  import { isBreakpoint } from "../core/dom.js";
5
5
  import { AgnosticResizeObserver } from "../core/observers.js";
6
- import { applyInertMechanism, removeInertMechanism } from "../core/overlay.js";
7
6
  import { SbbOverlayBaseElement, overlayRefs } from "../overlay.js";
8
7
  import { css } from "lit";
9
8
  import "../screen-reader-only.js";
@@ -320,7 +319,7 @@ let SbbDialogElement = class extends SbbOverlayBaseElement {
320
319
  if (event.animationName === "open" && this.state === "opening") {
321
320
  this.state = "opened";
322
321
  this.didOpen.emit();
323
- applyInertMechanism(this);
322
+ this.inertController.activate();
324
323
  this.attachOpenOverlayEvents();
325
324
  this.setOverlayFocus();
326
325
  setTimeout(
@@ -336,7 +335,7 @@ let SbbDialogElement = class extends SbbOverlayBaseElement {
336
335
  this._setHideHeaderDataAttribute(false);
337
336
  (_a = this._dialogContentElement) == null ? void 0 : _a.scrollTo(0, 0);
338
337
  this.state = "closed";
339
- removeInertMechanism();
338
+ this.inertController.deactivate();
340
339
  setModalityOnNextFocus(this.lastFocusedElement);
341
340
  (_b = this.lastFocusedElement) == null ? void 0 : _b.focus();
342
341
  (_c = this.openOverlayController) == null ? void 0 : _c.abort();
@@ -443,4 +442,4 @@ SbbDialogElement = __decorateClass([
443
442
  export {
444
443
  SbbDialogElement
445
444
  };
446
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"dialog.js","sources":["../../../../src/elements/dialog/dialog/dialog.ts"],"sourcesContent":["import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { html } from 'lit/static-html.js';\n\nimport { getFirstFocusableElement, setModalityOnNextFocus } from '../../core/a11y.js';\nimport { isBreakpoint } from '../../core/dom.js';\nimport { AgnosticResizeObserver } from '../../core/observers.js';\nimport { applyInertMechanism, removeInertMechanism } from '../../core/overlay.js';\nimport { overlayRefs, SbbOverlayBaseElement } from '../../overlay.js';\nimport type { SbbDialogActionsElement } from '../dialog-actions.js';\nimport type { SbbDialogTitleElement } from '../dialog-title.js';\n\nimport style from './dialog.scss?lit&inline';\n\nimport '../../screen-reader-only.js';\n\nlet nextId = 0;\n\n/**\n * It displays an interactive overlay element.\n *\n * @slot - Use the unnamed slot to provide a `sbb-dialog-title`, `sbb-dialog-content` and an optional `sbb-dialog-actions`.\n * @event {CustomEvent<void>} willOpen - Emits whenever the `sbb-dialog` starts the opening transition. Can be canceled.\n * @event {CustomEvent<void>} didOpen - Emits whenever the `sbb-dialog` is opened.\n * @event {CustomEvent<void>} willClose - Emits whenever the `sbb-dialog` begins the closing transition. Can be canceled.\n * @event {CustomEvent<SbbOverlayCloseEventDetails>} didClose - Emits whenever the `sbb-dialog` is closed.\n * @cssprop [--sbb-dialog-z-index=var(--sbb-overlay-default-z-index)] - To specify a custom stack order,\n * the `z-index` can be overridden by defining this CSS variable. The default `z-index` of the\n * component is set to `var(--sbb-overlay-default-z-index)` with a value of `1000`.\n */\n@customElement('sbb-dialog')\nexport class SbbDialogElement extends SbbOverlayBaseElement {\n  public static override styles: CSSResultGroup = style;\n\n  /** Backdrop click action. */\n  @property({ attribute: 'backdrop-action' }) public backdropAction: 'close' | 'none' = 'close';\n\n  // We use a timeout as a workaround to the \"ResizeObserver loop completed with undelivered notifications\" error.\n  // For more details:\n  // - https://github.com/WICG/resize-observer/issues/38#issuecomment-422126006\n  // - https://github.com/juggle/resize-observer/issues/103#issuecomment-1711148285\n  private _dialogContentResizeObserver = new AgnosticResizeObserver(() =>\n    setTimeout(() => this._onContentResize()),\n  );\n\n  private _dialogTitleElement: SbbDialogTitleElement | null = null;\n  private _dialogTitleHeight?: number;\n  private _dialogContentElement: HTMLElement | null = null;\n  private _dialogActionsElement: SbbDialogActionsElement | null = null;\n  private _isPointerDownEventOnDialog: boolean = false;\n  private _overflows: boolean = false;\n  private _lastScroll = 0;\n  private _dialogId = `sbb-dialog-${nextId++}`;\n  protected closeAttribute: string = 'sbb-dialog-close';\n\n  /** Opens the component. */\n  public open(): void {\n    if (this.state !== 'closed') {\n      return;\n    }\n    this.lastFocusedElement = document.activeElement as HTMLElement;\n\n    // Initialize dialog elements\n    this._dialogTitleElement = this.querySelector('sbb-dialog-title');\n    this._dialogContentElement = this.querySelector('sbb-dialog-content')?.shadowRoot!\n      .firstElementChild as HTMLElement;\n    this._dialogActionsElement = this.querySelector('sbb-dialog-actions');\n\n    this._syncNegative();\n\n    if (!this.willOpen.emit()) {\n      return;\n    }\n    this.state = 'opening';\n\n    // Add this dialog to the global collection\n    overlayRefs.push(this as SbbDialogElement);\n    this._dialogContentResizeObserver.observe(this._dialogContentElement);\n\n    // Disable scrolling for content below the dialog\n    this.scrollHandler.disableScroll();\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n\n    // Close dialog on backdrop click\n    this.addEventListener('pointerdown', this._pointerDownListener, {\n      signal: this.overlayController.signal,\n    });\n    this.addEventListener('pointerup', this._closeOnBackdropClick, {\n      signal: this.overlayController.signal,\n    });\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    // Synchronize the negative state before the first opening to avoid a possible color flash if it is negative.\n    this._dialogTitleElement = this.querySelector('sbb-dialog-title')!;\n    this._syncNegative();\n    super.firstUpdated(changedProperties);\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('negative')) {\n      this._syncNegative();\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._dialogContentResizeObserver.disconnect();\n  }\n\n  protected override attachOpenOverlayEvents(): void {\n    super.attachOpenOverlayEvents();\n\n    // If the content overflows, show/hide the dialog header on scroll.\n    this._dialogContentElement?.addEventListener('scroll', () => this._onContentScroll(), {\n      passive: true,\n      signal: this.openOverlayController.signal,\n    });\n    window.addEventListener('resize', () => this._setHideHeaderDataAttribute(false), {\n      signal: this.openOverlayController.signal,\n    });\n  }\n\n  // Wait for dialog transition to complete.\n  // In rare cases, it can be that the animationEnd event is triggered twice.\n  // To avoid entering a corrupt state, exit when state is not expected.\n  protected onOverlayAnimationEnd(event: AnimationEvent): void {\n    if (event.animationName === 'open' && this.state === 'opening') {\n      this.state = 'opened';\n      this.didOpen.emit();\n      applyInertMechanism(this);\n      this.attachOpenOverlayEvents();\n      this.setOverlayFocus();\n      // Use timeout to read label after focused element\n      setTimeout(() =>\n        this.setAriaLiveRefContent(\n          this.accessibilityLabel || this._dialogTitleElement?.innerText.trim(),\n        ),\n      );\n      this.focusHandler.trap(this);\n    } else if (event.animationName === 'close' && this.state === 'closing') {\n      this._setHideHeaderDataAttribute(false);\n      this._dialogContentElement?.scrollTo(0, 0);\n      this.state = 'closed';\n      removeInertMechanism();\n      setModalityOnNextFocus(this.lastFocusedElement);\n      // Manually focus last focused element\n      this.lastFocusedElement?.focus();\n      this.openOverlayController?.abort();\n      this.focusHandler.disconnect();\n      this._dialogContentResizeObserver.disconnect();\n      this.removeInstanceFromGlobalCollection();\n      // Enable scrolling for content below the dialog if no dialog is open\n      if (!overlayRefs.length) {\n        this.scrollHandler.enableScroll();\n      }\n      this.didClose.emit({\n        returnValue: this.returnValue,\n        closeTarget: this.overlayCloseElement,\n      });\n    }\n  }\n\n  // Set focus on the first focusable element.\n  protected setOverlayFocus(): void {\n    const firstFocusable = getFirstFocusableElement(\n      Array.from(this.children).filter((e): e is HTMLElement => e instanceof window.HTMLElement),\n    );\n    setModalityOnNextFocus(firstFocusable);\n    firstFocusable?.focus();\n  }\n\n  private _syncNegative(): void {\n    if (this._dialogTitleElement) {\n      this._dialogTitleElement.negative = this.negative;\n    }\n\n    if (this._dialogActionsElement) {\n      this._dialogActionsElement.toggleAttribute('data-negative', this.negative);\n    }\n  }\n\n  private _onContentScroll(): void {\n    if (!this._dialogContentElement) {\n      return;\n    }\n\n    const hasVisibleHeader = this.dataset.hideHeader === undefined;\n\n    // Check whether hiding the header would make the scrollbar disappear\n    // and prevent the hiding animation if so.\n    if (\n      hasVisibleHeader &&\n      this._dialogContentElement.clientHeight + this._dialogTitleHeight! >=\n        this._dialogContentElement.scrollHeight\n    ) {\n      return;\n    }\n\n    const currentScroll = this._dialogContentElement.scrollTop;\n    if (\n      Math.round(currentScroll + this._dialogContentElement.clientHeight) >=\n      this._dialogContentElement.scrollHeight\n    ) {\n      return;\n    }\n    // Check whether is scrolling down or up.\n    if (currentScroll > 0 && this._lastScroll < currentScroll) {\n      // Scrolling down\n      this._setHideHeaderDataAttribute(true);\n    } else {\n      // Scrolling up\n      this._setHideHeaderDataAttribute(false);\n    }\n    // `currentScroll` can be negative, e.g. on mobile; this is not allowed.\n    this._lastScroll = currentScroll <= 0 ? 0 : currentScroll;\n  }\n\n  // Check if the pointerdown event target is triggered on the dialog.\n  private _pointerDownListener = (event: PointerEvent): void => {\n    if (this.backdropAction !== 'close') {\n      return;\n    }\n\n    this._isPointerDownEventOnDialog = event\n      .composedPath()\n      .filter((e): e is HTMLElement => e instanceof window.HTMLElement)\n      .some((target) => target.id === this._dialogId);\n  };\n\n  // Close dialog on backdrop click.\n  private _closeOnBackdropClick = (event: PointerEvent): void => {\n    if (this.backdropAction !== 'close') {\n      return;\n    }\n\n    if (\n      !this._isPointerDownEventOnDialog &&\n      !event\n        .composedPath()\n        .filter((e): e is HTMLElement => e instanceof window.HTMLElement)\n        .some((target) => target.id === this._dialogId)\n    ) {\n      this.close();\n    }\n  };\n\n  private _setDialogHeaderHeight(): void {\n    this._dialogTitleHeight = this._dialogTitleElement?.shadowRoot!.firstElementChild!.clientHeight;\n    this.style.setProperty('--sbb-dialog-header-height', `${this._dialogTitleHeight}px`);\n  }\n\n  private _onContentResize(): void {\n    this._setDialogHeaderHeight();\n    // Check whether the content overflows and set the `overflows` attribute.\n    this._overflows = this._dialogContentElement\n      ? this._dialogContentElement?.scrollHeight > this._dialogContentElement?.clientHeight\n      : false;\n    this._setOverflowsDataAttribute();\n  }\n\n  private _setHideHeaderDataAttribute(value: boolean): void {\n    const hideOnScroll = this._dialogTitleElement?.hideOnScroll ?? false;\n    const hideHeader =\n      typeof hideOnScroll === 'boolean'\n        ? hideOnScroll\n        : isBreakpoint('zero', hideOnScroll, { includeMaxBreakpoint: true });\n    this.toggleAttribute('data-hide-header', !hideHeader ? false : value);\n    if (this._dialogTitleElement) {\n      this._dialogTitleElement.toggleAttribute('data-hide-header', !hideHeader ? false : value);\n    }\n  }\n\n  private _setOverflowsDataAttribute(): void {\n    this.toggleAttribute('data-overflows', this._overflows);\n    this._dialogTitleElement?.toggleAttribute('data-overflows', this._overflows);\n    this._dialogActionsElement?.toggleAttribute('data-overflows', this._overflows);\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-dialog__container\">\n        <div\n          @animationend=${(event: AnimationEvent) => this.onOverlayAnimationEnd(event)}\n          class=\"sbb-dialog\"\n          id=${this._dialogId}\n        >\n          <div\n            @click=${(event: Event) => this.closeOnSbbOverlayCloseClick(event)}\n            class=\"sbb-dialog__wrapper\"\n          >\n            <slot></slot>\n          </div>\n        </div>\n      </div>\n      <sbb-screen-reader-only aria-live=\"polite\"></sbb-screen-reader-only>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-dialog': SbbDialogElement;\n  }\n}\n"],"names":["_a"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAgBA,IAAI,SAAS;AAeA,IAAA,mBAAN,cAA+B,sBAAsB;AAAA,EAArD,cAAA;AAAA,UAAA,GAAA,SAAA;AAIuC,SAAO,iBAAmC;AAMtF,SAAQ,+BAA+B,IAAI;AAAA,MAAuB,MAChE,WAAW,MAAM,KAAK,kBAAkB;AAAA,IAAA;AAG1C,SAAQ,sBAAoD;AAE5D,SAAQ,wBAA4C;AACpD,SAAQ,wBAAwD;AAChE,SAAQ,8BAAuC;AAC/C,SAAQ,aAAsB;AAC9B,SAAQ,cAAc;AACd,SAAA,YAAY,cAAc,QAAQ;AAC1C,SAAU,iBAAyB;AA2K3B,SAAA,uBAAuB,CAAC,UAA8B;AACxD,UAAA,KAAK,mBAAmB,SAAS;AACnC;AAAA,MACF;AAEA,WAAK,8BAA8B,MAChC,aACA,EAAA,OAAO,CAAC,MAAwB,aAAa,OAAO,WAAW,EAC/D,KAAK,CAAC,WAAW,OAAO,OAAO,KAAK,SAAS;AAAA,IAAA;AAI1C,SAAA,wBAAwB,CAAC,UAA8B;AACzD,UAAA,KAAK,mBAAmB,SAAS;AACnC;AAAA,MACF;AAGE,UAAA,CAAC,KAAK,+BACN,CAAC,MACE,eACA,OAAO,CAAC,MAAwB,aAAa,OAAO,WAAW,EAC/D,KAAK,CAAC,WAAW,OAAO,OAAO,KAAK,SAAS,GAChD;AACA,aAAK,MAAM;AAAA,MACb;AAAA,IAAA;AAAA,EACF;AAAA;AAAA,EAlMO,OAAa;;AACd,QAAA,KAAK,UAAU,UAAU;AAC3B;AAAA,IACF;AACA,SAAK,qBAAqB,SAAS;AAG9B,SAAA,sBAAsB,KAAK,cAAc,kBAAkB;AAChE,SAAK,yBAAwB,UAAK,cAAc,oBAAoB,MAAvC,mBAA0C,WACpE;AACE,SAAA,wBAAwB,KAAK,cAAc,oBAAoB;AAEpE,SAAK,cAAc;AAEnB,QAAI,CAAC,KAAK,SAAS,QAAQ;AACzB;AAAA,IACF;AACA,SAAK,QAAQ;AAGb,gBAAY,KAAK,IAAwB;AACpC,SAAA,6BAA6B,QAAQ,KAAK,qBAAqB;AAGpE,SAAK,cAAc;EACrB;AAAA,EAEgB,oBAA0B;AACxC,UAAM,kBAAkB;AAGnB,SAAA,iBAAiB,eAAe,KAAK,sBAAsB;AAAA,MAC9D,QAAQ,KAAK,kBAAkB;AAAA,IAAA,CAChC;AACI,SAAA,iBAAiB,aAAa,KAAK,uBAAuB;AAAA,MAC7D,QAAQ,KAAK,kBAAkB;AAAA,IAAA,CAChC;AAAA,EACH;AAAA,EAEmB,aAAa,mBAA+C;AAExE,SAAA,sBAAsB,KAAK,cAAc,kBAAkB;AAChE,SAAK,cAAc;AACnB,UAAM,aAAa,iBAAiB;AAAA,EACtC;AAAA,EAEmB,WAAW,mBAA+C;AAC3E,UAAM,WAAW,iBAAiB;AAE9B,QAAA,kBAAkB,IAAI,UAAU,GAAG;AACrC,WAAK,cAAc;AAAA,IACrB;AAAA,EACF;AAAA,EAEgB,uBAA6B;AAC3C,UAAM,qBAAqB;AAC3B,SAAK,6BAA6B;EACpC;AAAA,EAEmB,0BAAgC;;AACjD,UAAM,wBAAwB;AAG9B,eAAK,0BAAL,mBAA4B,iBAAiB,UAAU,MAAM,KAAK,oBAAoB;AAAA,MACpF,SAAS;AAAA,MACT,QAAQ,KAAK,sBAAsB;AAAA,IAAA;AAErC,WAAO,iBAAiB,UAAU,MAAM,KAAK,4BAA4B,KAAK,GAAG;AAAA,MAC/E,QAAQ,KAAK,sBAAsB;AAAA,IAAA,CACpC;AAAA,EACH;AAAA;AAAA;AAAA;AAAA,EAKU,sBAAsB,OAA6B;;AAC3D,QAAI,MAAM,kBAAkB,UAAU,KAAK,UAAU,WAAW;AAC9D,WAAK,QAAQ;AACb,WAAK,QAAQ;AACb,0BAAoB,IAAI;AACxB,WAAK,wBAAwB;AAC7B,WAAK,gBAAgB;AAErB;AAAA,QAAW,MAAA;;AACT,sBAAK;AAAA,YACH,KAAK,wBAAsBA,MAAA,KAAK,wBAAL,gBAAAA,IAA0B,UAAU;AAAA,UACjE;AAAA;AAAA,MAAA;AAEG,WAAA,aAAa,KAAK,IAAI;AAAA,IAAA,WAClB,MAAM,kBAAkB,WAAW,KAAK,UAAU,WAAW;AACtE,WAAK,4BAA4B,KAAK;AACjC,iBAAA,0BAAA,mBAAuB,SAAS,GAAG;AACxC,WAAK,QAAQ;AACQ;AACrB,6BAAuB,KAAK,kBAAkB;AAE9C,iBAAK,uBAAL,mBAAyB;AACzB,iBAAK,0BAAL,mBAA4B;AAC5B,WAAK,aAAa;AAClB,WAAK,6BAA6B;AAClC,WAAK,mCAAmC;AAEpC,UAAA,CAAC,YAAY,QAAQ;AACvB,aAAK,cAAc;MACrB;AACA,WAAK,SAAS,KAAK;AAAA,QACjB,aAAa,KAAK;AAAA,QAClB,aAAa,KAAK;AAAA,MAAA,CACnB;AAAA,IACH;AAAA,EACF;AAAA;AAAA,EAGU,kBAAwB;AAChC,UAAM,iBAAiB;AAAA,MACrB,MAAM,KAAK,KAAK,QAAQ,EAAE,OAAO,CAAC,MAAwB,aAAa,OAAO,WAAW;AAAA,IAAA;AAE3F,2BAAuB,cAAc;AACrC,qDAAgB;AAAA,EAClB;AAAA,EAEQ,gBAAsB;AAC5B,QAAI,KAAK,qBAAqB;AACvB,WAAA,oBAAoB,WAAW,KAAK;AAAA,IAC3C;AAEA,QAAI,KAAK,uBAAuB;AAC9B,WAAK,sBAAsB,gBAAgB,iBAAiB,KAAK,QAAQ;AAAA,IAC3E;AAAA,EACF;AAAA,EAEQ,mBAAyB;AAC3B,QAAA,CAAC,KAAK,uBAAuB;AAC/B;AAAA,IACF;AAEM,UAAA,mBAAmB,KAAK,QAAQ,eAAe;AAKnD,QAAA,oBACA,KAAK,sBAAsB,eAAe,KAAK,sBAC7C,KAAK,sBAAsB,cAC7B;AACA;AAAA,IACF;AAEM,UAAA,gBAAgB,KAAK,sBAAsB;AAE/C,QAAA,KAAK,MAAM,gBAAgB,KAAK,sBAAsB,YAAY,KAClE,KAAK,sBAAsB,cAC3B;AACA;AAAA,IACF;AAEA,QAAI,gBAAgB,KAAK,KAAK,cAAc,eAAe;AAEzD,WAAK,4BAA4B,IAAI;AAAA,IAAA,OAChC;AAEL,WAAK,4BAA4B,KAAK;AAAA,IACxC;AAEK,SAAA,cAAc,iBAAiB,IAAI,IAAI;AAAA,EAC9C;AAAA,EA+BQ,yBAA+B;;AACrC,SAAK,sBAAqB,UAAK,wBAAL,mBAA0B,WAAY,kBAAmB;AACnF,SAAK,MAAM,YAAY,8BAA8B,GAAG,KAAK,kBAAkB,IAAI;AAAA,EACrF;AAAA,EAEQ,mBAAyB;;AAC/B,SAAK,uBAAuB;AAEvB,SAAA,aAAa,KAAK,0BACnB,UAAK,0BAAL,mBAA4B,kBAAe,UAAK,0BAAL,mBAA4B,gBACvE;AACJ,SAAK,2BAA2B;AAAA,EAClC;AAAA,EAEQ,4BAA4B,OAAsB;;AAClD,UAAA,iBAAe,UAAK,wBAAL,mBAA0B,iBAAgB;AACzD,UAAA,aACJ,OAAO,iBAAiB,YACpB,eACA,aAAa,QAAQ,cAAc,EAAE,sBAAsB,KAAM,CAAA;AACvE,SAAK,gBAAgB,oBAAoB,CAAC,aAAa,QAAQ,KAAK;AACpE,QAAI,KAAK,qBAAqB;AAC5B,WAAK,oBAAoB,gBAAgB,oBAAoB,CAAC,aAAa,QAAQ,KAAK;AAAA,IAC1F;AAAA,EACF;AAAA,EAEQ,6BAAmC;;AACpC,SAAA,gBAAgB,kBAAkB,KAAK,UAAU;AACtD,eAAK,wBAAL,mBAA0B,gBAAgB,kBAAkB,KAAK;AACjE,eAAK,0BAAL,mBAA4B,gBAAgB,kBAAkB,KAAK;AAAA,EACrE;AAAA,EAEmB,SAAyB;AACnC,WAAA;AAAA;AAAA;AAAA,0BAGe,CAAC,UAA0B,KAAK,sBAAsB,KAAK,CAAC;AAAA;AAAA,eAEvE,KAAK,SAAS;AAAA;AAAA;AAAA,qBAGR,CAAC,UAAiB,KAAK,4BAA4B,KAAK,CAAC;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EAS5E;AACF;AAhRa,iBACY,SAAyB;AAGG,gBAAA;AAAA,EAAlD,SAAS,EAAE,WAAW,mBAAmB;AAAA,GAJ/B,iBAIwC,WAAA,kBAAA,CAAA;AAJxC,mBAAN,gBAAA;AAAA,EADN,cAAc,YAAY;AAAA,GACd,gBAAA;"}
445
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"dialog.js","sources":["../../../../src/elements/dialog/dialog/dialog.ts"],"sourcesContent":["import type { CSSResultGroup, PropertyValues, TemplateResult } from 'lit';\nimport { customElement, property } from 'lit/decorators.js';\nimport { html } from 'lit/static-html.js';\n\nimport { getFirstFocusableElement, setModalityOnNextFocus } from '../../core/a11y.js';\nimport { isBreakpoint } from '../../core/dom.js';\nimport { AgnosticResizeObserver } from '../../core/observers.js';\nimport { overlayRefs, SbbOverlayBaseElement } from '../../overlay.js';\nimport type { SbbDialogActionsElement } from '../dialog-actions.js';\nimport type { SbbDialogTitleElement } from '../dialog-title.js';\n\nimport style from './dialog.scss?lit&inline';\n\nimport '../../screen-reader-only.js';\n\nlet nextId = 0;\n\n/**\n * It displays an interactive overlay element.\n *\n * @slot - Use the unnamed slot to provide a `sbb-dialog-title`, `sbb-dialog-content` and an optional `sbb-dialog-actions`.\n * @event {CustomEvent<void>} willOpen - Emits whenever the `sbb-dialog` starts the opening transition. Can be canceled.\n * @event {CustomEvent<void>} didOpen - Emits whenever the `sbb-dialog` is opened.\n * @event {CustomEvent<void>} willClose - Emits whenever the `sbb-dialog` begins the closing transition. Can be canceled.\n * @event {CustomEvent<SbbOverlayCloseEventDetails>} didClose - Emits whenever the `sbb-dialog` is closed.\n * @cssprop [--sbb-dialog-z-index=var(--sbb-overlay-default-z-index)] - To specify a custom stack order,\n * the `z-index` can be overridden by defining this CSS variable. The default `z-index` of the\n * component is set to `var(--sbb-overlay-default-z-index)` with a value of `1000`.\n */\n@customElement('sbb-dialog')\nexport class SbbDialogElement extends SbbOverlayBaseElement {\n  public static override styles: CSSResultGroup = style;\n\n  /** Backdrop click action. */\n  @property({ attribute: 'backdrop-action' }) public backdropAction: 'close' | 'none' = 'close';\n\n  // We use a timeout as a workaround to the \"ResizeObserver loop completed with undelivered notifications\" error.\n  // For more details:\n  // - https://github.com/WICG/resize-observer/issues/38#issuecomment-422126006\n  // - https://github.com/juggle/resize-observer/issues/103#issuecomment-1711148285\n  private _dialogContentResizeObserver = new AgnosticResizeObserver(() =>\n    setTimeout(() => this._onContentResize()),\n  );\n\n  private _dialogTitleElement: SbbDialogTitleElement | null = null;\n  private _dialogTitleHeight?: number;\n  private _dialogContentElement: HTMLElement | null = null;\n  private _dialogActionsElement: SbbDialogActionsElement | null = null;\n  private _isPointerDownEventOnDialog: boolean = false;\n  private _overflows: boolean = false;\n  private _lastScroll = 0;\n  private _dialogId = `sbb-dialog-${nextId++}`;\n  protected closeAttribute: string = 'sbb-dialog-close';\n\n  /** Opens the component. */\n  public open(): void {\n    if (this.state !== 'closed') {\n      return;\n    }\n    this.lastFocusedElement = document.activeElement as HTMLElement;\n\n    // Initialize dialog elements\n    this._dialogTitleElement = this.querySelector('sbb-dialog-title');\n    this._dialogContentElement = this.querySelector('sbb-dialog-content')?.shadowRoot!\n      .firstElementChild as HTMLElement;\n    this._dialogActionsElement = this.querySelector('sbb-dialog-actions');\n\n    this._syncNegative();\n\n    if (!this.willOpen.emit()) {\n      return;\n    }\n    this.state = 'opening';\n\n    // Add this dialog to the global collection\n    overlayRefs.push(this as SbbDialogElement);\n    this._dialogContentResizeObserver.observe(this._dialogContentElement);\n\n    // Disable scrolling for content below the dialog\n    this.scrollHandler.disableScroll();\n  }\n\n  public override connectedCallback(): void {\n    super.connectedCallback();\n\n    // Close dialog on backdrop click\n    this.addEventListener('pointerdown', this._pointerDownListener, {\n      signal: this.overlayController.signal,\n    });\n    this.addEventListener('pointerup', this._closeOnBackdropClick, {\n      signal: this.overlayController.signal,\n    });\n  }\n\n  protected override firstUpdated(changedProperties: PropertyValues<this>): void {\n    // Synchronize the negative state before the first opening to avoid a possible color flash if it is negative.\n    this._dialogTitleElement = this.querySelector('sbb-dialog-title')!;\n    this._syncNegative();\n    super.firstUpdated(changedProperties);\n  }\n\n  protected override willUpdate(changedProperties: PropertyValues<this>): void {\n    super.willUpdate(changedProperties);\n\n    if (changedProperties.has('negative')) {\n      this._syncNegative();\n    }\n  }\n\n  public override disconnectedCallback(): void {\n    super.disconnectedCallback();\n    this._dialogContentResizeObserver.disconnect();\n  }\n\n  protected override attachOpenOverlayEvents(): void {\n    super.attachOpenOverlayEvents();\n\n    // If the content overflows, show/hide the dialog header on scroll.\n    this._dialogContentElement?.addEventListener('scroll', () => this._onContentScroll(), {\n      passive: true,\n      signal: this.openOverlayController.signal,\n    });\n    window.addEventListener('resize', () => this._setHideHeaderDataAttribute(false), {\n      signal: this.openOverlayController.signal,\n    });\n  }\n\n  // Wait for dialog transition to complete.\n  // In rare cases, it can be that the animationEnd event is triggered twice.\n  // To avoid entering a corrupt state, exit when state is not expected.\n  protected onOverlayAnimationEnd(event: AnimationEvent): void {\n    if (event.animationName === 'open' && this.state === 'opening') {\n      this.state = 'opened';\n      this.didOpen.emit();\n      this.inertController.activate();\n      this.attachOpenOverlayEvents();\n      this.setOverlayFocus();\n      // Use timeout to read label after focused element\n      setTimeout(() =>\n        this.setAriaLiveRefContent(\n          this.accessibilityLabel || this._dialogTitleElement?.innerText.trim(),\n        ),\n      );\n      this.focusHandler.trap(this);\n    } else if (event.animationName === 'close' && this.state === 'closing') {\n      this._setHideHeaderDataAttribute(false);\n      this._dialogContentElement?.scrollTo(0, 0);\n      this.state = 'closed';\n      this.inertController.deactivate();\n      setModalityOnNextFocus(this.lastFocusedElement);\n      // Manually focus last focused element\n      this.lastFocusedElement?.focus();\n      this.openOverlayController?.abort();\n      this.focusHandler.disconnect();\n      this._dialogContentResizeObserver.disconnect();\n      this.removeInstanceFromGlobalCollection();\n      // Enable scrolling for content below the dialog if no dialog is open\n      if (!overlayRefs.length) {\n        this.scrollHandler.enableScroll();\n      }\n      this.didClose.emit({\n        returnValue: this.returnValue,\n        closeTarget: this.overlayCloseElement,\n      });\n    }\n  }\n\n  // Set focus on the first focusable element.\n  protected setOverlayFocus(): void {\n    const firstFocusable = getFirstFocusableElement(\n      Array.from(this.children).filter((e): e is HTMLElement => e instanceof window.HTMLElement),\n    );\n    setModalityOnNextFocus(firstFocusable);\n    firstFocusable?.focus();\n  }\n\n  private _syncNegative(): void {\n    if (this._dialogTitleElement) {\n      this._dialogTitleElement.negative = this.negative;\n    }\n\n    if (this._dialogActionsElement) {\n      this._dialogActionsElement.toggleAttribute('data-negative', this.negative);\n    }\n  }\n\n  private _onContentScroll(): void {\n    if (!this._dialogContentElement) {\n      return;\n    }\n\n    const hasVisibleHeader = this.dataset.hideHeader === undefined;\n\n    // Check whether hiding the header would make the scrollbar disappear\n    // and prevent the hiding animation if so.\n    if (\n      hasVisibleHeader &&\n      this._dialogContentElement.clientHeight + this._dialogTitleHeight! >=\n        this._dialogContentElement.scrollHeight\n    ) {\n      return;\n    }\n\n    const currentScroll = this._dialogContentElement.scrollTop;\n    if (\n      Math.round(currentScroll + this._dialogContentElement.clientHeight) >=\n      this._dialogContentElement.scrollHeight\n    ) {\n      return;\n    }\n    // Check whether is scrolling down or up.\n    if (currentScroll > 0 && this._lastScroll < currentScroll) {\n      // Scrolling down\n      this._setHideHeaderDataAttribute(true);\n    } else {\n      // Scrolling up\n      this._setHideHeaderDataAttribute(false);\n    }\n    // `currentScroll` can be negative, e.g. on mobile; this is not allowed.\n    this._lastScroll = currentScroll <= 0 ? 0 : currentScroll;\n  }\n\n  // Check if the pointerdown event target is triggered on the dialog.\n  private _pointerDownListener = (event: PointerEvent): void => {\n    if (this.backdropAction !== 'close') {\n      return;\n    }\n\n    this._isPointerDownEventOnDialog = event\n      .composedPath()\n      .filter((e): e is HTMLElement => e instanceof window.HTMLElement)\n      .some((target) => target.id === this._dialogId);\n  };\n\n  // Close dialog on backdrop click.\n  private _closeOnBackdropClick = (event: PointerEvent): void => {\n    if (this.backdropAction !== 'close') {\n      return;\n    }\n\n    if (\n      !this._isPointerDownEventOnDialog &&\n      !event\n        .composedPath()\n        .filter((e): e is HTMLElement => e instanceof window.HTMLElement)\n        .some((target) => target.id === this._dialogId)\n    ) {\n      this.close();\n    }\n  };\n\n  private _setDialogHeaderHeight(): void {\n    this._dialogTitleHeight = this._dialogTitleElement?.shadowRoot!.firstElementChild!.clientHeight;\n    this.style.setProperty('--sbb-dialog-header-height', `${this._dialogTitleHeight}px`);\n  }\n\n  private _onContentResize(): void {\n    this._setDialogHeaderHeight();\n    // Check whether the content overflows and set the `overflows` attribute.\n    this._overflows = this._dialogContentElement\n      ? this._dialogContentElement?.scrollHeight > this._dialogContentElement?.clientHeight\n      : false;\n    this._setOverflowsDataAttribute();\n  }\n\n  private _setHideHeaderDataAttribute(value: boolean): void {\n    const hideOnScroll = this._dialogTitleElement?.hideOnScroll ?? false;\n    const hideHeader =\n      typeof hideOnScroll === 'boolean'\n        ? hideOnScroll\n        : isBreakpoint('zero', hideOnScroll, { includeMaxBreakpoint: true });\n    this.toggleAttribute('data-hide-header', !hideHeader ? false : value);\n    if (this._dialogTitleElement) {\n      this._dialogTitleElement.toggleAttribute('data-hide-header', !hideHeader ? false : value);\n    }\n  }\n\n  private _setOverflowsDataAttribute(): void {\n    this.toggleAttribute('data-overflows', this._overflows);\n    this._dialogTitleElement?.toggleAttribute('data-overflows', this._overflows);\n    this._dialogActionsElement?.toggleAttribute('data-overflows', this._overflows);\n  }\n\n  protected override render(): TemplateResult {\n    return html`\n      <div class=\"sbb-dialog__container\">\n        <div\n          @animationend=${(event: AnimationEvent) => this.onOverlayAnimationEnd(event)}\n          class=\"sbb-dialog\"\n          id=${this._dialogId}\n        >\n          <div\n            @click=${(event: Event) => this.closeOnSbbOverlayCloseClick(event)}\n            class=\"sbb-dialog__wrapper\"\n          >\n            <slot></slot>\n          </div>\n        </div>\n      </div>\n      <sbb-screen-reader-only aria-live=\"polite\"></sbb-screen-reader-only>\n    `;\n  }\n}\n\ndeclare global {\n  interface HTMLElementTagNameMap {\n    // eslint-disable-next-line @typescript-eslint/naming-convention\n    'sbb-dialog': SbbDialogElement;\n  }\n}\n"],"names":["_a"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"flip-card.d.ts","sourceRoot":"","sources":["../../../../../src/elements/flip-card/flip-card/flip-card.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAkB,UAAU,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAM3F,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAGtD,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,yBAAyB,CAAC;AACzE,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,yBAAyB,CAAC;AAIzE,OAAO,yCAAyC,CAAC;AACjD,OAAO,6BAA6B,CAAC;;AAErC;;;;;;GAMG;AACH,qBACa,kBAAmB,SAAQ,uBAA6B;IACnE,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;MAElB;IAEX;;;OAGG;IACoD,kBAAkB,EAAE,MAAM,GAAG,SAAS,CAAC;IAE9F,+CAA+C;IAC/C,SAAS,CAAC,IAAI,EAAE,YAAY,CAA0D;IAEtF,iDAAiD;IACjD,IAAW,OAAO,IAAI,yBAAyB,GAAG,IAAI,CAErD;IAED,iDAAiD;IACjD,IAAW,OAAO,IAAI,yBAAyB,GAAG,IAAI,CAErD;IAED,wCAAwC;IACxC,IAAW,SAAS,IAAI,OAAO,CAE9B;IAED,0CAA0C;IACjC,OAAO,CAAC,QAAQ,CAAS;IAElC,OAAO,CAAC,MAAM,CAAyC;IACvD,OAAO,CAAC,SAAS,CAAmC;IAEpC,iBAAiB,IAAI,IAAI;IAgBzC,8CAA8C;IACvC,MAAM,IAAI,IAAI;YAQP,mBAAmB;cAWd,MAAM,IAAI,cAAc;CAoB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,eAAe,EAAE,kBAAkB,CAAC;KACrC;CACF"}
1
+ {"version":3,"file":"flip-card.d.ts","sourceRoot":"","sources":["../../../../../src/elements/flip-card/flip-card/flip-card.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,cAAc,EAAkB,UAAU,EAAE,KAAK,cAAc,EAAE,MAAM,KAAK,CAAC;AAM3F,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAGtD,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,yBAAyB,CAAC;AACzE,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,yBAAyB,CAAC;AAIzE,OAAO,yCAAyC,CAAC;AACjD,OAAO,6BAA6B,CAAC;;AAErC;;;;;;GAMG;AACH,qBACa,kBAAmB,SAAQ,uBAA6B;IACnE,OAAuB,MAAM,EAAE,cAAc,CAAS;IACtD,gBAAuB,MAAM;;MAElB;IAEX;;;OAGG;IACoD,kBAAkB,EAAE,MAAM,GAAG,SAAS,CAAC;IAE9F,+CAA+C;IAC/C,SAAS,CAAC,IAAI,EAAE,YAAY,CAA0D;IAEtF,iDAAiD;IACjD,IAAW,OAAO,IAAI,yBAAyB,GAAG,IAAI,CAErD;IAED,iDAAiD;IACjD,IAAW,OAAO,IAAI,yBAAyB,GAAG,IAAI,CAErD;IAED,wCAAwC;IACxC,IAAW,SAAS,IAAI,OAAO,CAE9B;IAED,0CAA0C;IACjC,OAAO,CAAC,QAAQ,CAAS;IAElC,OAAO,CAAC,MAAM,CAAyC;IACvD,OAAO,CAAC,SAAS,CAAmC;IAEpC,iBAAiB,IAAI,IAAI;IAgBzC,8CAA8C;IACvC,MAAM,IAAI,IAAI;YASP,mBAAmB;cAWd,MAAM,IAAI,cAAc;CAsB5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,eAAe,EAAE,kBAAkB,CAAC;KACrC;CACF"}
@@ -1 +1 @@
1
- {"version":3,"file":"flip-card-details.d.ts","sourceRoot":"","sources":["../../../../../src/elements/flip-card/flip-card-details/flip-card-details.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AASvC;;;;GAIG;AACH,qBAIa,yBAA0B,SAAQ,UAAU;IACvD,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,OAAO,CAAC,yBAAyB,CAE/B;IAEF,OAAO,CAAC,uBAAuB;IAQf,iBAAiB,IAAI,IAAI;cAStB,YAAY,CAAC,iBAAiB,EAAE,cAAc,GAAG,IAAI;IAKxD,oBAAoB,IAAI,IAAI;cAKzB,MAAM,IAAI,cAAc;CAO5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,uBAAuB,EAAE,yBAAyB,CAAC;KACpD;CACF"}
1
+ {"version":3,"file":"flip-card-details.d.ts","sourceRoot":"","sources":["../../../../../src/elements/flip-card/flip-card-details/flip-card-details.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,cAAc,EAAE,cAAc,EAAE,cAAc,EAAE,MAAM,KAAK,CAAC;AAC1E,OAAO,EAAQ,UAAU,EAAE,MAAM,KAAK,CAAC;AASvC;;;;GAIG;AACH,qBAIa,yBAA0B,SAAQ,UAAU;IACvD,OAAuB,MAAM,EAAE,cAAc,CAAS;IAEtD,OAAO,CAAC,yBAAyB,CAE/B;IAEF,OAAO,CAAC,uBAAuB;IAQf,iBAAiB,IAAI,IAAI;cAStB,YAAY,CAAC,iBAAiB,EAAE,cAAc,GAAG,IAAI;IAKxD,oBAAoB,IAAI,IAAI;cAKzB,MAAM,IAAI,cAAc;CAS5C;AAED,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,qBAAqB;QAE7B,uBAAuB,EAAE,yBAAyB,CAAC;KACpD;CACF"}