@solid-design-system/components 3.5.0 → 3.7.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 (163) hide show
  1. package/dist/components/es/dialog.js +1 -1
  2. package/dist/components/es/interactive.js +1 -1
  3. package/dist/components/es/option.js +1 -1
  4. package/dist/components/es/solid-components2.js +1 -1
  5. package/dist/components/es/step.js +1 -1
  6. package/dist/components/umd/solid-components.js +18 -18
  7. package/dist/custom-elements.json +1 -1
  8. package/dist/package/components/accordion/accordion.d.ts +2 -1
  9. package/dist/package/components/carousel/carousel.d.ts +2 -1
  10. package/dist/package/components/dialog/dialog.d.ts +2 -1
  11. package/dist/package/components/drawer/drawer.d.ts +2 -1
  12. package/dist/package/components/dropdown/dropdown.d.ts +2 -1
  13. package/dist/package/components/input/input.d.ts +2 -1
  14. package/dist/package/components/notification/notification.d.ts +2 -1
  15. package/dist/package/components/option/option.d.ts +0 -1
  16. package/dist/package/components/option/option.js +0 -2
  17. package/dist/package/components/select/select.d.ts +2 -1
  18. package/dist/package/components/spinner/spinner.d.ts +2 -1
  19. package/dist/package/components/tab-group/tab-group.d.ts +2 -1
  20. package/dist/package/components/tooltip/tooltip.d.ts +2 -1
  21. package/dist/package/styles/headline/headline.css.js +1 -1
  22. package/dist/package/styles/interactive/interactive.css.js +1 -1
  23. package/dist/package/styles/paragraph/paragraph.css.js +1 -1
  24. package/dist/package/utilities/localize.d.ts +10 -0
  25. package/dist/package/utilities/localize.js +45 -0
  26. package/dist/styles/solid-styles.css +1 -1
  27. package/dist/versioned-components/es/accordion-group.js +1 -1
  28. package/dist/versioned-components/es/accordion.js +1 -1
  29. package/dist/versioned-components/es/badge.js +1 -1
  30. package/dist/versioned-components/es/brandshape.js +1 -1
  31. package/dist/versioned-components/es/button.js +1 -1
  32. package/dist/versioned-components/es/carousel-item.js +1 -1
  33. package/dist/versioned-components/es/carousel.js +3 -3
  34. package/dist/versioned-components/es/checkbox-group.js +1 -1
  35. package/dist/versioned-components/es/checkbox.js +1 -1
  36. package/dist/versioned-components/es/dialog.js +1 -1
  37. package/dist/versioned-components/es/divider.js +1 -1
  38. package/dist/versioned-components/es/drawer.js +1 -1
  39. package/dist/versioned-components/es/dropdown.js +1 -1
  40. package/dist/versioned-components/es/form.js +1 -1
  41. package/dist/versioned-components/es/header.js +1 -1
  42. package/dist/versioned-components/es/icon.js +1 -1
  43. package/dist/versioned-components/es/include.js +1 -1
  44. package/dist/versioned-components/es/input.js +1 -1
  45. package/dist/versioned-components/es/interactive.js +1 -1
  46. package/dist/versioned-components/es/link.js +1 -1
  47. package/dist/versioned-components/es/map-marker.js +1 -1
  48. package/dist/versioned-components/es/navigation-item.js +1 -1
  49. package/dist/versioned-components/es/notification.js +1 -1
  50. package/dist/versioned-components/es/option.js +1 -1
  51. package/dist/versioned-components/es/popup.js +1 -1
  52. package/dist/versioned-components/es/radio-button.js +1 -1
  53. package/dist/versioned-components/es/radio-group.js +1 -1
  54. package/dist/versioned-components/es/radio.js +1 -1
  55. package/dist/versioned-components/es/scrollable.js +1 -1
  56. package/dist/versioned-components/es/select.js +3 -3
  57. package/dist/versioned-components/es/solid-components2.js +1 -1
  58. package/dist/versioned-components/es/spinner.js +1 -1
  59. package/dist/versioned-components/es/step-group.js +1 -1
  60. package/dist/versioned-components/es/step.js +1 -1
  61. package/dist/versioned-components/es/switch.js +1 -1
  62. package/dist/versioned-components/es/tab-group.js +1 -1
  63. package/dist/versioned-components/es/tab-panel.js +1 -1
  64. package/dist/versioned-components/es/tab.js +1 -1
  65. package/dist/versioned-components/es/tag.js +1 -1
  66. package/dist/versioned-components/es/teaser-media.js +1 -1
  67. package/dist/versioned-components/es/teaser.js +1 -1
  68. package/dist/versioned-components/es/textarea.js +1 -1
  69. package/dist/versioned-components/es/tooltip.js +2 -2
  70. package/dist/versioned-components/es/video.js +1 -1
  71. package/dist/versioned-package/_components/button-group/button-group.d.ts +1 -1
  72. package/dist/versioned-package/_components/button-group/button-group.js +11 -11
  73. package/dist/versioned-package/components/accordion/accordion.d.ts +3 -2
  74. package/dist/versioned-package/components/accordion/accordion.js +2 -2
  75. package/dist/versioned-package/components/accordion-group/accordion-group.d.ts +1 -1
  76. package/dist/versioned-package/components/accordion-group/accordion-group.js +3 -3
  77. package/dist/versioned-package/components/badge/badge.d.ts +1 -1
  78. package/dist/versioned-package/components/badge/badge.js +1 -1
  79. package/dist/versioned-package/components/brandshape/brandshape.d.ts +1 -1
  80. package/dist/versioned-package/components/brandshape/brandshape.js +1 -1
  81. package/dist/versioned-package/components/button/button.d.ts +1 -1
  82. package/dist/versioned-package/components/button/button.js +4 -4
  83. package/dist/versioned-package/components/carousel/carousel.d.ts +3 -2
  84. package/dist/versioned-package/components/carousel/carousel.js +6 -6
  85. package/dist/versioned-package/components/carousel-item/carousel-item.d.ts +1 -1
  86. package/dist/versioned-package/components/carousel-item/carousel-item.js +1 -1
  87. package/dist/versioned-package/components/checkbox/checkbox.d.ts +1 -1
  88. package/dist/versioned-package/components/checkbox/checkbox.js +3 -3
  89. package/dist/versioned-package/components/checkbox-group/checkbox-group.d.ts +1 -1
  90. package/dist/versioned-package/components/checkbox-group/checkbox-group.js +5 -5
  91. package/dist/versioned-package/components/dialog/dialog.d.ts +3 -2
  92. package/dist/versioned-package/components/dialog/dialog.js +2 -2
  93. package/dist/versioned-package/components/divider/divider.d.ts +1 -1
  94. package/dist/versioned-package/components/divider/divider.js +2 -2
  95. package/dist/versioned-package/components/drawer/drawer.d.ts +3 -2
  96. package/dist/versioned-package/components/drawer/drawer.js +2 -2
  97. package/dist/versioned-package/components/dropdown/dropdown.d.ts +3 -2
  98. package/dist/versioned-package/components/dropdown/dropdown.js +8 -8
  99. package/dist/versioned-package/components/header/header.d.ts +1 -1
  100. package/dist/versioned-package/components/header/header.js +4 -4
  101. package/dist/versioned-package/components/icon/icon.d.ts +1 -1
  102. package/dist/versioned-package/components/icon/icon.js +1 -1
  103. package/dist/versioned-package/components/include/include.d.ts +1 -1
  104. package/dist/versioned-package/components/include/include.js +1 -1
  105. package/dist/versioned-package/components/input/input.d.ts +3 -2
  106. package/dist/versioned-package/components/input/input.js +2 -2
  107. package/dist/versioned-package/components/link/link.d.ts +1 -1
  108. package/dist/versioned-package/components/link/link.js +2 -2
  109. package/dist/versioned-package/components/map-marker/map-marker.d.ts +1 -1
  110. package/dist/versioned-package/components/map-marker/map-marker.js +1 -1
  111. package/dist/versioned-package/components/navigation-item/navigation-item.d.ts +1 -1
  112. package/dist/versioned-package/components/navigation-item/navigation-item.js +3 -3
  113. package/dist/versioned-package/components/notification/notification.d.ts +3 -2
  114. package/dist/versioned-package/components/notification/notification.js +5 -5
  115. package/dist/versioned-package/components/option/option.d.ts +1 -2
  116. package/dist/versioned-package/components/option/option.js +2 -4
  117. package/dist/versioned-package/components/popup/popup.d.ts +1 -1
  118. package/dist/versioned-package/components/popup/popup.js +1 -1
  119. package/dist/versioned-package/components/radio/radio.d.ts +1 -1
  120. package/dist/versioned-package/components/radio/radio.js +2 -2
  121. package/dist/versioned-package/components/radio-button/radio-button.d.ts +1 -1
  122. package/dist/versioned-package/components/radio-button/radio-button.js +2 -2
  123. package/dist/versioned-package/components/radio-group/radio-group.d.ts +2 -2
  124. package/dist/versioned-package/components/radio-group/radio-group.js +13 -13
  125. package/dist/versioned-package/components/scrollable/scrollable.d.ts +1 -1
  126. package/dist/versioned-package/components/scrollable/scrollable.js +3 -3
  127. package/dist/versioned-package/components/select/select.d.ts +6 -5
  128. package/dist/versioned-package/components/select/select.js +25 -25
  129. package/dist/versioned-package/components/spinner/spinner.d.ts +3 -2
  130. package/dist/versioned-package/components/spinner/spinner.js +1 -1
  131. package/dist/versioned-package/components/step/step.d.ts +1 -1
  132. package/dist/versioned-package/components/step/step.js +5 -5
  133. package/dist/versioned-package/components/step-group/step-group.d.ts +1 -1
  134. package/dist/versioned-package/components/step-group/step-group.js +2 -2
  135. package/dist/versioned-package/components/switch/switch.d.ts +1 -1
  136. package/dist/versioned-package/components/switch/switch.js +1 -1
  137. package/dist/versioned-package/components/tab/tab.d.ts +1 -1
  138. package/dist/versioned-package/components/tab/tab.js +2 -2
  139. package/dist/versioned-package/components/tab-group/tab-group.d.ts +3 -2
  140. package/dist/versioned-package/components/tab-group/tab-group.js +13 -13
  141. package/dist/versioned-package/components/tab-panel/tab-panel.d.ts +1 -1
  142. package/dist/versioned-package/components/tab-panel/tab-panel.js +2 -2
  143. package/dist/versioned-package/components/tag/tag.d.ts +1 -1
  144. package/dist/versioned-package/components/tag/tag.js +2 -2
  145. package/dist/versioned-package/components/teaser/teaser.js +1 -1
  146. package/dist/versioned-package/components/teaser-media/teaser-media.js +1 -1
  147. package/dist/versioned-package/components/textarea/textarea.d.ts +1 -1
  148. package/dist/versioned-package/components/textarea/textarea.js +2 -2
  149. package/dist/versioned-package/components/tooltip/tooltip.d.ts +3 -2
  150. package/dist/versioned-package/components/tooltip/tooltip.js +5 -5
  151. package/dist/versioned-package/components/video/video.d.ts +1 -1
  152. package/dist/versioned-package/components/video/video.js +2 -2
  153. package/dist/versioned-package/internal/form.js +3 -3
  154. package/dist/versioned-package/styles/headline/headline.css.js +1 -1
  155. package/dist/versioned-package/styles/interactive/interactive.css.js +1 -1
  156. package/dist/versioned-package/styles/paragraph/paragraph.css.js +1 -1
  157. package/dist/versioned-package/utilities/autocomplete-config.js +4 -4
  158. package/dist/versioned-package/utilities/localize.d.ts +10 -0
  159. package/dist/versioned-package/utilities/localize.js +45 -0
  160. package/dist/versioned-styles/solid-styles.css +1 -1
  161. package/dist/vscode.html-custom-data.json +41 -41
  162. package/dist/web-types.json +42 -50
  163. package/package.json +3 -3
@@ -129,7 +129,7 @@ let SdNotification = class extends SolidElement {
129
129
  () => {
130
130
  toastStack.removeChild(this);
131
131
  resolve();
132
- if (toastStack.querySelector("sd-3-5-0-notification") === null) {
132
+ if (toastStack.querySelector("sd-3-7-0-notification") === null) {
133
133
  toastStack.remove();
134
134
  }
135
135
  },
@@ -146,15 +146,15 @@ let SdNotification = class extends SolidElement {
146
146
  warning: "bg-warning",
147
147
  error: "bg-error"
148
148
  }[this.variant]
149
- )}"><sd-3-5-0-icon name="${{
149
+ )}"><sd-3-7-0-icon name="${{
150
150
  info: "info-circle",
151
151
  success: "confirm-circle",
152
152
  warning: "exclamation-circle",
153
153
  error: "warning"
154
- }[this.variant] || ""}" library="system" class="h-6 w-6 text-white"></sd-3-5-0-icon></slot><div part="content" class="${cx(
154
+ }[this.variant] || ""}" library="system" class="h-6 w-6 text-white"></sd-3-7-0-icon></slot><div part="content" class="${cx(
155
155
  "h-full w-full p-1 gap-2 flex items-center justify-stretch bg-white",
156
156
  "border-solid border-[1px] border-l-0 border-neutral-400"
157
- )}"><slot part="message" class="block w-full pl-3 py-2" aria-live="polite"></slot>${this.closable ? html`<sd-3-5-0-button size="md" variant="tertiary" part="close-button" class="ml-auto flex flex-[0_0_auto] items-stretch" label="${this.localize.term("close")}" @click="${this.handleCloseClick}"><sd-3-5-0-icon name="close" library="system" color="currentColor"></sd-3-5-0-icon></sd-3-5-0-button>` : ""}</div>${this.durationIndicator ? html`<div part="duration-indicator__elapsed" id="duration-indicator__elapsed" style="${`animation-duration: ${this.duration}ms`}" class="${cx(`absolute w-0 h-[2px] bottom-0 bg-primary z-10 animate-grow`)}"></div><div part="duration-indicator__total" class="w-full h-[2px] bottom-0 absolute bg-neutral-400"></div>` : ""}</div>`;
157
+ )}"><slot part="message" class="block w-full pl-3 py-2" aria-live="polite"></slot>${this.closable ? html`<sd-3-7-0-button size="md" variant="tertiary" part="close-button" class="ml-auto flex flex-[0_0_auto] items-stretch" label="${this.localize.term("close")}" @click="${this.handleCloseClick}"><sd-3-7-0-icon name="close" library="system" color="currentColor"></sd-3-7-0-icon></sd-3-7-0-button>` : ""}</div>${this.durationIndicator ? html`<div part="duration-indicator__elapsed" id="duration-indicator__elapsed" style="${`animation-duration: ${this.duration}ms`}" class="${cx(`absolute w-0 h-[2px] bottom-0 bg-primary z-10 animate-grow`)}"></div><div part="duration-indicator__total" class="w-full h-[2px] bottom-0 absolute bg-neutral-400"></div>` : ""}</div>`;
158
158
  }
159
159
  };
160
160
  SdNotification.styles = [
@@ -190,7 +190,7 @@ __decorateClass([
190
190
  watch("duration")
191
191
  ], SdNotification.prototype, "handleDurationChange", 1);
192
192
  SdNotification = __decorateClass([
193
- customElement("sd-3-5-0-notification")
193
+ customElement("sd-3-7-0-notification")
194
194
  ], SdNotification);
195
195
  setDefaultAnimation("notification.show", {
196
196
  keyframes: [
@@ -3,7 +3,6 @@ import SolidElement from '../../internal/solid-element';
3
3
  export default class SdOption extends SolidElement {
4
4
  private readonly hasSlotController;
5
5
  private cachedTextLabel;
6
- private readonly localize;
7
6
  defaultSlot: HTMLSlotElement;
8
7
  current: boolean;
9
8
  selected: boolean;
@@ -25,6 +24,6 @@ export default class SdOption extends SolidElement {
25
24
  }
26
25
  declare global {
27
26
  interface HTMLElementTagNameMap {
28
- 'sd-3-5-0-option': SdOption;
27
+ 'sd-3-7-0-option': SdOption;
29
28
  }
30
29
  }
@@ -2,7 +2,6 @@ import "../icon/icon.js";
2
2
  import { css, html } from "lit";
3
3
  import { customElement } from "../../internal/register-custom-element.js";
4
4
  import { HasSlotController } from "../../internal/slot.js";
5
- import { LocalizeController } from "../../utilities/localize.js";
6
5
  import { query, state, property } from "lit/decorators.js";
7
6
  import { watch } from "../../internal/watch.js";
8
7
  import componentStyles from "../../styles/component.styles.js";
@@ -23,7 +22,6 @@ let SdOption = class extends SolidElement {
23
22
  constructor() {
24
23
  super(...arguments);
25
24
  this.hasSlotController = new HasSlotController(this, "default", "left", "right");
26
- this.localize = new LocalizeController(this);
27
25
  this.current = false;
28
26
  this.selected = false;
29
27
  this.hasHover = false;
@@ -94,7 +92,7 @@ let SdOption = class extends SolidElement {
94
92
  )}"></span> ${this.checkbox ? html`<span id="control" part="control ${this.selected ? " control--checked" : "control--unchecked"}" class="${cx(
95
93
  "relative flex flex-initial items-center justify-center border rounded-sm h-4 w-4 mr-2",
96
94
  this.disabled ? "border-neutral-500" : this.selected ? "bg-accent border-accent" : "border-neutral-800"
97
- )}">${this.selected ? html`<sd-3-5-0-icon part="checked-icon" class="text-white w-3 h-3" library="system" name="status-check"></sd-3-5-0-icon>` : ""}</span>` : ""} ${slots["left"] ? html`<slot name="left" part="left" class="inline-flex mr-2"></slot>` : ""}<slot part="label" class="inline-block flex-grow" @slotchange="${this.handleDefaultSlotChange}"></slot>${slots["right"] ? html`<slot name="right" part="right" class="inline-flex ml-2"></slot>` : ""}</div>`;
95
+ )}">${this.selected ? html`<sd-3-7-0-icon part="checked-icon" class="text-white w-3 h-3" library="system" name="status-check"></sd-3-7-0-icon>` : ""}</span>` : ""} ${slots["left"] ? html`<slot name="left" part="left" class="inline-flex mr-2"></slot>` : ""}<slot part="label" class="inline-block flex-grow" @slotchange="${this.handleDefaultSlotChange}"></slot>${slots["right"] ? html`<slot name="right" part="right" class="inline-flex ml-2"></slot>` : ""}</div>`;
98
96
  }
99
97
  };
100
98
  SdOption.styles = [
@@ -136,7 +134,7 @@ __decorateClass([
136
134
  watch("value")
137
135
  ], SdOption.prototype, "handleValueChange", 1);
138
136
  SdOption = __decorateClass([
139
- customElement("sd-3-5-0-option")
137
+ customElement("sd-3-7-0-option")
140
138
  ], SdOption);
141
139
  export {
142
140
  SdOption as default
@@ -40,6 +40,6 @@ export default class SdPopup extends SolidElement {
40
40
  }
41
41
  declare global {
42
42
  interface HTMLElementTagNameMap {
43
- 'sd-3-5-0-popup': SdPopup;
43
+ 'sd-3-7-0-popup': SdPopup;
44
44
  }
45
45
  }
@@ -329,7 +329,7 @@ __decorateClass([
329
329
  property({ attribute: "auto-size-padding", type: Number })
330
330
  ], SdPopup.prototype, "autoSizePadding", 2);
331
331
  SdPopup = __decorateClass([
332
- customElement("sd-3-5-0-popup")
332
+ customElement("sd-3-7-0-popup")
333
333
  ], SdPopup);
334
334
  export {
335
335
  SdPopup as default
@@ -22,6 +22,6 @@ export default class SdRadio extends SolidElement {
22
22
  }
23
23
  declare global {
24
24
  interface HTMLElementTagNameMap {
25
- 'sd-3-5-0-radio': SdRadio;
25
+ 'sd-3-7-0-radio': SdRadio;
26
26
  }
27
27
  }
@@ -73,7 +73,7 @@ let SdRadio = class extends SolidElement {
73
73
  }
74
74
  render() {
75
75
  return html`<span part="base" class="${cx(
76
- "sd-3-5-0-radio group inline-flex items-start items-center text-base leading-normal text-black cursor-pointer align-middle",
76
+ "sd-3-7-0-radio group inline-flex items-start items-center text-base leading-normal text-black cursor-pointer align-middle",
77
77
  this.disabled && "hover:cursor-not-allowed",
78
78
  {
79
79
  /* sizes, fonts */
@@ -121,7 +121,7 @@ __decorateClass([
121
121
  watch("disabled", { waitUntilFirstUpdate: true })
122
122
  ], SdRadio.prototype, "handleDisabledChange", 1);
123
123
  SdRadio = __decorateClass([
124
- customElement("sd-3-5-0-radio")
124
+ customElement("sd-3-7-0-radio")
125
125
  ], SdRadio);
126
126
  export {
127
127
  SdRadio as default
@@ -20,6 +20,6 @@ export default class SdRadioButton extends SolidElement {
20
20
  }
21
21
  declare global {
22
22
  interface HTMLElementTagNameMap {
23
- 'sd-3-5-0-radio-button': SdRadioButton;
23
+ 'sd-3-7-0-radio-button': SdRadioButton;
24
24
  }
25
25
  }
@@ -84,7 +84,7 @@ let SdRadioButton = class extends SolidElement {
84
84
  SdRadioButton.styles = [
85
85
  SolidElement.styles,
86
86
  componentStyles,
87
- css`:host{display:block;width:-moz-min-content;width:min-content}.hidden-input{all:unset;position:absolute;inset:var(--sd-spacing-0,0);z-index:-10;opacity:var(--sd-opacity-0,0);outline-style:dotted;outline-width:1px;outline-color:rgb(var(--sd-color-error,204 25 55) / 1)}.lg-label{height:var(--sd-spacing-12,3rem)}.lg-no-label{height:var(--sd-spacing-12,3rem);width:var(--sd-spacing-12,3rem)}.md-label{height:var(--sd-spacing-10,2.5rem)}.md-no-label{height:var(--sd-spacing-10,2.5rem);width:var(--sd-spacing-10,2.5rem)}.sm-label{height:var(--sd-spacing-8,2rem)}.sm-no-label{height:var(--sd-spacing-8,2rem);width:var(--sd-spacing-8,2rem)}:host(.sd-3-5-0-button-group__button--first:not(.sd-3-5-0-button-group__button--last)) button{border-top-right-radius:var(--sd-border-radius-none,0);border-bottom-right-radius:var(--sd-border-radius-none,0)}:host(.sd-3-5-0-button-group__button--inner) button{border-radius:var(--sd-border-radius-none,0)}:host(.sd-3-5-0-button-group__button--last:not(.sd-3-5-0-button-group__button--first)) button{border-top-left-radius:var(--sd-border-radius-none,0);border-bottom-left-radius:var(--sd-border-radius-none,0)}:host(.sd-3-5-0-button-group__button:not(.sd-3-5-0-button-group__button--first)){margin-inline-start:-1px}:host(.sd-3-5-0-button-group__button--hover){z-index:10}:host(.sd-3-5-0-button-group__button--focus),:host(.sd-3-5-0-button-group__button[checked]){z-index:20}`
87
+ css`:host{display:block;width:-moz-min-content;width:min-content}.hidden-input{all:unset;position:absolute;inset:var(--sd-spacing-0,0);z-index:-10;opacity:var(--sd-opacity-0,0);outline-style:dotted;outline-width:1px;outline-color:rgb(var(--sd-color-error,204 25 55) / 1)}.lg-label{height:var(--sd-spacing-12,3rem)}.lg-no-label{height:var(--sd-spacing-12,3rem);width:var(--sd-spacing-12,3rem)}.md-label{height:var(--sd-spacing-10,2.5rem)}.md-no-label{height:var(--sd-spacing-10,2.5rem);width:var(--sd-spacing-10,2.5rem)}.sm-label{height:var(--sd-spacing-8,2rem)}.sm-no-label{height:var(--sd-spacing-8,2rem);width:var(--sd-spacing-8,2rem)}:host(.sd-3-7-0-button-group__button--first:not(.sd-3-7-0-button-group__button--last)) button{border-top-right-radius:var(--sd-border-radius-none,0);border-bottom-right-radius:var(--sd-border-radius-none,0)}:host(.sd-3-7-0-button-group__button--inner) button{border-radius:var(--sd-border-radius-none,0)}:host(.sd-3-7-0-button-group__button--last:not(.sd-3-7-0-button-group__button--first)) button{border-top-left-radius:var(--sd-border-radius-none,0);border-bottom-left-radius:var(--sd-border-radius-none,0)}:host(.sd-3-7-0-button-group__button:not(.sd-3-7-0-button-group__button--first)){margin-inline-start:-1px}:host(.sd-3-7-0-button-group__button--hover){z-index:10}:host(.sd-3-7-0-button-group__button--focus),:host(.sd-3-7-0-button-group__button[checked]){z-index:20}`
88
88
  ];
89
89
  __decorateClass([
90
90
  query(".button")
@@ -111,7 +111,7 @@ __decorateClass([
111
111
  watch("disabled", { waitUntilFirstUpdate: true })
112
112
  ], SdRadioButton.prototype, "handleDisabledChange", 1);
113
113
  SdRadioButton = __decorateClass([
114
- customElement("sd-3-5-0-radio-button")
114
+ customElement("sd-3-7-0-radio-button")
115
115
  ], SdRadioButton);
116
116
  export {
117
117
  SdRadioButton as default
@@ -4,7 +4,7 @@ import SolidElement from '../../internal/solid-element';
4
4
  import type { SolidFormControl } from '../../internal/solid-element';
5
5
  export default class SdRadioGroup extends SolidElement implements SolidFormControl {
6
6
  static dependencies: {
7
- 'sd-3-5-0-button-group': typeof SdButtonGroup;
7
+ 'sd-3-7-0-button-group': typeof SdButtonGroup;
8
8
  };
9
9
  protected readonly formControlController: FormControlController;
10
10
  private readonly hasSlotController;
@@ -48,6 +48,6 @@ export default class SdRadioGroup extends SolidElement implements SolidFormContr
48
48
  }
49
49
  declare global {
50
50
  interface HTMLElementTagNameMap {
51
- 'sd-3-5-0-radio-group': SdRadioGroup;
51
+ 'sd-3-7-0-radio-group': SdRadioGroup;
52
52
  }
53
53
  }
@@ -68,10 +68,10 @@ let SdRadioGroup = class extends SolidElement {
68
68
  this.formControlController.updateValidity();
69
69
  }
70
70
  getAllRadios() {
71
- return [...this.querySelectorAll("sd-3-5-0-radio, sd-3-5-0-radio-button")];
71
+ return [...this.querySelectorAll("sd-3-7-0-radio, sd-3-7-0-radio-button")];
72
72
  }
73
73
  handleRadioClick(event) {
74
- const target = event.target.closest("sd-3-5-0-radio, sd-3-5-0-radio-button");
74
+ const target = event.target.closest("sd-3-7-0-radio, sd-3-7-0-radio-button");
75
75
  const radios = this.getAllRadios();
76
76
  const oldValue = this.value;
77
77
  if (target.disabled) {
@@ -147,7 +147,7 @@ let SdRadioGroup = class extends SolidElement {
147
147
  }
148
148
  })
149
149
  );
150
- this.hasButtonGroup = radios.some((radio) => radio.tagName.toLowerCase() === "sd-3-5-0-radio-button");
150
+ this.hasButtonGroup = radios.some((radio) => radio.tagName.toLowerCase() === "sd-3-7-0-radio-button");
151
151
  if (!radios.some((radio) => radio.checked)) {
152
152
  if (this.hasButtonGroup) {
153
153
  const buttonRadio = (_a = radios[0].shadowRoot) == null ? void 0 : _a.querySelector("button");
@@ -159,26 +159,26 @@ let SdRadioGroup = class extends SolidElement {
159
159
  }
160
160
  }
161
161
  if (this.hasButtonGroup) {
162
- const buttonGroup = (_b = this.shadowRoot) == null ? void 0 : _b.querySelector("sd-3-5-0-button-group");
162
+ const buttonGroup = (_b = this.shadowRoot) == null ? void 0 : _b.querySelector("sd-3-7-0-button-group");
163
163
  if (buttonGroup) {
164
164
  buttonGroup.disableRole = true;
165
165
  }
166
166
  }
167
167
  }
168
168
  syncRadios() {
169
- if (customElements.get("sd-3-5-0-radio") && customElements.get("sd-3-5-0-radio-button")) {
169
+ if (customElements.get("sd-3-7-0-radio") && customElements.get("sd-3-7-0-radio-button")) {
170
170
  this.syncRadioElements();
171
171
  return;
172
172
  }
173
- if (customElements.get("sd-3-5-0-radio")) {
173
+ if (customElements.get("sd-3-7-0-radio")) {
174
174
  this.syncRadioElements();
175
175
  } else {
176
- customElements.whenDefined("sd-3-5-0-radio").then(() => this.syncRadios());
176
+ customElements.whenDefined("sd-3-7-0-radio").then(() => this.syncRadios());
177
177
  }
178
- if (customElements.get("sd-3-5-0-radio-button")) {
178
+ if (customElements.get("sd-3-7-0-radio-button")) {
179
179
  this.syncRadioElements();
180
180
  } else {
181
- customElements.whenDefined("sd-3-5-0-radio-button").then(() => this.syncRadios());
181
+ customElements.whenDefined("sd-3-7-0-radio-button").then(() => this.syncRadios());
182
182
  }
183
183
  }
184
184
  updateCheckedRadio() {
@@ -253,14 +253,14 @@ let SdRadioGroup = class extends SolidElement {
253
253
  vertical: "flex-col",
254
254
  horizontal: "flex-row"
255
255
  }[this.orientation]
256
- )}"><div class="sr-only"><label><input id="validation-input" type="text" ?required="${this.required}" tabindex="-1" hidden @invalid="${this.handleInvalid}"></label></div>${this.hasButtonGroup ? html`<sd-3-5-0-button-group part="button-group" exportparts="base:button-group__base" role="presentation">${defaultSlot}</sd-3-5-0-button-group>` : defaultSlot}</div></fieldset>${this.formControlController.renderInvalidMessage()}`;
256
+ )}"><div class="sr-only"><label><input id="validation-input" type="text" ?required="${this.required}" tabindex="-1" hidden @invalid="${this.handleInvalid}"></label></div>${this.hasButtonGroup ? html`<sd-3-7-0-button-group part="button-group" exportparts="base:button-group__base" role="presentation">${defaultSlot}</sd-3-7-0-button-group>` : defaultSlot}</div></fieldset>${this.formControlController.renderInvalidMessage()}`;
257
257
  }
258
258
  };
259
- SdRadioGroup.dependencies = { "sd-3-5-0-button-group": SdButtonGroup };
259
+ SdRadioGroup.dependencies = { "sd-3-7-0-button-group": SdButtonGroup };
260
260
  SdRadioGroup.styles = [
261
261
  componentStyles,
262
262
  SolidElement.styles,
263
- css`:host{display:block}:host([orientation=vertical]) ::slotted(sd-3-5-0-radio){margin-bottom:var(--sd-spacing-2,.5rem);display:flex}:host([orientation=vertical]) ::slotted(sd-3-5-0-radio:last-of-type){margin-bottom:var(--sd-spacing-0,0)}:host([orientation=horizontal]) ::slotted(sd-3-5-0-radio){margin-right:var(--sd-spacing-6,1.5rem)}:host([orientation=horizontal]) ::slotted(sd-3-5-0-radio:last-of-type){margin-right:var(--sd-spacing-0,0)}:host([orientation=horizontal]):host([size=sm]) ::slotted(sd-3-5-0-radio){margin-right:var(--sd-spacing-4,1rem)}:host([orientation=horizontal]):host([size=sm]) ::slotted(sd-3-5-0-radio:last-of-type){margin-right:var(--sd-spacing-0,0)}:host([required]) #label::after{content:' *'}`
263
+ css`:host{display:block}:host([orientation=vertical]) ::slotted(sd-3-7-0-radio){margin-bottom:var(--sd-spacing-2,.5rem);display:flex}:host([orientation=vertical]) ::slotted(sd-3-7-0-radio:last-of-type){margin-bottom:var(--sd-spacing-0,0)}:host([orientation=horizontal]) ::slotted(sd-3-7-0-radio){margin-right:var(--sd-spacing-6,1.5rem)}:host([orientation=horizontal]) ::slotted(sd-3-7-0-radio:last-of-type){margin-right:var(--sd-spacing-0,0)}:host([orientation=horizontal]):host([size=sm]) ::slotted(sd-3-7-0-radio){margin-right:var(--sd-spacing-4,1rem)}:host([orientation=horizontal]):host([size=sm]) ::slotted(sd-3-7-0-radio:last-of-type){margin-right:var(--sd-spacing-0,0)}:host([required]) #label::after{content:' *'}`
264
264
  ];
265
265
  __decorateClass([
266
266
  query("slot:not([name])")
@@ -314,7 +314,7 @@ __decorateClass([
314
314
  watch("value")
315
315
  ], SdRadioGroup.prototype, "handleValueChange", 1);
316
316
  SdRadioGroup = __decorateClass([
317
- customElement("sd-3-5-0-radio-group")
317
+ customElement("sd-3-7-0-radio-group")
318
318
  ], SdRadioGroup);
319
319
  export {
320
320
  SdRadioGroup as default
@@ -23,6 +23,6 @@ export default class SdScrollable extends SolidElement {
23
23
  }
24
24
  declare global {
25
25
  interface HTMLElementTagNameMap {
26
- 'sd-3-5-0-scrollable': SdScrollable;
26
+ 'sd-3-7-0-scrollable': SdScrollable;
27
27
  }
28
28
  }
@@ -112,14 +112,14 @@ let SdScrollable = class extends SolidElement {
112
112
  this.orientation === "auto" && "scroll-auto overflow-auto",
113
113
  this.scrollbars ? "show-scrollbars" : "hide-scrollbars",
114
114
  this.inset ? "p-4" : ""
115
- )}" @scroll="${this.updateScrollIndicatorVisibility}"><div part="scroll-content" class="flex-1"><slot></slot></div></div>${this.buttons ? html`${this.isScrollHorizontalEnabled ? html`${this.canScroll.left ? html`<div part="button-left" class="absolute z-10 flex items-center justify-center top-0 left-0 h-full w-8"><button part="button-start" class="${cx(scrollButtonClasses)}" @click="${() => this.handleScroll("left")}"><slot name="icon-start"><sd-3-5-0-icon library="system" name="chevron-up" class="rotate-[-90deg]"></sd-3-5-0-icon></slot></button></div>` : null} ${this.canScroll.right ? html`<div part="button-right" class="absolute z-10 flex items-center justify-center top-0 right-0 h-full w-8"><button part="button-end" class="${cx(scrollButtonClasses)}" @click="${() => this.handleScroll("right")}"><slot name="icon-end"><sd-3-5-0-icon library="system" name="chevron-down" class="rotate-[-90deg]"></sd-3-5-0-icon></slot></button></div>` : null}` : null} ${this.isScrollVerticalEnabled ? html`${this.canScroll.up ? html`<div part="button-top" class="absolute z-10 flex items-center justify-center top-0 left-0 w-full h-8"><button part="button-start" class="${cx(scrollButtonClasses)}" @click="${() => this.handleScroll("up")}"><slot name="icon-start"><sd-3-5-0-icon library="system" name="chevron-up"></sd-3-5-0-icon></slot></button></div>` : null} ${this.canScroll.down ? html`<div part="button-bottom" class="absolute z-10 flex items-center justify-center bottom-0 left-0 w-full h-8"><button part="button-end" class="${cx(scrollButtonClasses)}" @click="${() => this.handleScroll("down")}"><slot name="icon-end"><sd-3-5-0-icon library="system" name="chevron-down"></sd-3-5-0-icon></slot></button></div>` : null}` : null}` : null} ${this.shadows ? html`${this.isScrollHorizontalEnabled ? html`${this.canScroll.left ? html`<div part="shadow-left" class="${scrollShadowClasses} left top-0 left-0 w-[6px] h-full"></div>` : null} ${this.canScroll.right ? html`<div part="shadow-right" class="${scrollShadowClasses} right top-0 right-0 w-[6px] h-full"></div>` : null}` : null} ${this.isScrollVerticalEnabled ? html`${this.canScroll.up ? html`<div part="shadow-top" class="${scrollShadowClasses} top top-0 left-0 w-full h-[6px]"></div>` : null} ${this.canScroll.down ? html`<div part="shadow-bottom" class="${scrollShadowClasses} bottom bottom-0 left-0 w-full h-[6px]"></div>` : null}` : null}` : null}`;
115
+ )}" @scroll="${this.updateScrollIndicatorVisibility}"><div part="scroll-content" class="flex-1"><slot></slot></div></div>${this.buttons ? html`${this.isScrollHorizontalEnabled ? html`${this.canScroll.left ? html`<div part="button-left" class="absolute z-10 flex items-center justify-center top-0 left-0 h-full w-8"><button part="button-start" class="${cx(scrollButtonClasses)}" @click="${() => this.handleScroll("left")}"><slot name="icon-start"><sd-3-7-0-icon library="system" name="chevron-up" class="rotate-[-90deg]"></sd-3-7-0-icon></slot></button></div>` : null} ${this.canScroll.right ? html`<div part="button-right" class="absolute z-10 flex items-center justify-center top-0 right-0 h-full w-8"><button part="button-end" class="${cx(scrollButtonClasses)}" @click="${() => this.handleScroll("right")}"><slot name="icon-end"><sd-3-7-0-icon library="system" name="chevron-down" class="rotate-[-90deg]"></sd-3-7-0-icon></slot></button></div>` : null}` : null} ${this.isScrollVerticalEnabled ? html`${this.canScroll.up ? html`<div part="button-top" class="absolute z-10 flex items-center justify-center top-0 left-0 w-full h-8"><button part="button-start" class="${cx(scrollButtonClasses)}" @click="${() => this.handleScroll("up")}"><slot name="icon-start"><sd-3-7-0-icon library="system" name="chevron-up"></sd-3-7-0-icon></slot></button></div>` : null} ${this.canScroll.down ? html`<div part="button-bottom" class="absolute z-10 flex items-center justify-center bottom-0 left-0 w-full h-8"><button part="button-end" class="${cx(scrollButtonClasses)}" @click="${() => this.handleScroll("down")}"><slot name="icon-end"><sd-3-7-0-icon library="system" name="chevron-down"></sd-3-7-0-icon></slot></button></div>` : null}` : null}` : null} ${this.shadows ? html`${this.isScrollHorizontalEnabled ? html`${this.canScroll.left ? html`<div part="shadow-left" class="${scrollShadowClasses} left top-0 left-0 w-[6px] h-full"></div>` : null} ${this.canScroll.right ? html`<div part="shadow-right" class="${scrollShadowClasses} right top-0 right-0 w-[6px] h-full"></div>` : null}` : null} ${this.isScrollVerticalEnabled ? html`${this.canScroll.up ? html`<div part="shadow-top" class="${scrollShadowClasses} top top-0 left-0 w-full h-[6px]"></div>` : null} ${this.canScroll.down ? html`<div part="shadow-bottom" class="${scrollShadowClasses} bottom bottom-0 left-0 w-full h-[6px]"></div>` : null}` : null}` : null}`;
116
116
  }
117
117
  };
118
118
  SdScrollable.styles = [
119
119
  SolidElement.styles,
120
120
  unsafeCSS(InteractiveStyles),
121
121
  componentStyles,
122
- css`:host{--gradient-color:rgba(255, 255, 255, 0);--gradient:var(--gradient-color) 0%,#fff 80%,#fff 100%;position:relative;display:flex;overflow:hidden}.hide-scrollbars{scrollbar-width:none;-ms-overflow-style:none}.hide-scrollbars::-webkit-scrollbar{display:none}.scroll-container::-webkit-scrollbar-thumb{background-color:transparent}.scroll-container:hover::-webkit-scrollbar-thumb{background:var(--background-neutral-400,#c3c3c3);border-radius:var(--sd-border-radius-sm,.125rem)}.scroll-container::-webkit-scrollbar{height:var(--sd-spacing-1,.25rem);width:var(--sd-spacing-1,.25rem)}.scroll-auto{overflow:auto}[part=button-left]{background:linear-gradient(270deg,var(--gradient))}[part=button-right]{background:linear-gradient(90deg,var(--gradient))}[part=button-top]{background:linear-gradient(0deg,var(--gradient))}[part=button-bottom]{background:linear-gradient(180deg,var(--gradient))}[part=shadow-left]{background:linear-gradient(270deg,rgba(24,24,24,0) 50%,rgba(24,24,24,.4) 100%)}[part=shadow-right]{background:linear-gradient(90deg,rgba(24,24,24,0) 50%,rgba(24,24,24,.4) 100%)}[part=shadow-top]{background:linear-gradient(0deg,rgba(24,24,24,0) 50%,rgba(24,24,24,.4) 100%)}[part=shadow-bottom]{background:linear-gradient(180deg,rgba(24,24,24,0) 50%,rgba(24,24,24,.4) 100%)}.sd-3-5-0-icon--top{align-self:flex-start}.sd-3-5-0-icon--down{align-self:flex-end}`
122
+ css`:host{--gradient-color:rgba(255, 255, 255, 0);--gradient:var(--gradient-color) 0%,#fff 80%,#fff 100%;position:relative;display:flex;overflow:hidden}.hide-scrollbars{scrollbar-width:none;-ms-overflow-style:none}.hide-scrollbars::-webkit-scrollbar{display:none}.scroll-container::-webkit-scrollbar-thumb{background-color:transparent}.scroll-container:hover::-webkit-scrollbar-thumb{background:var(--background-neutral-400,#c3c3c3);border-radius:var(--sd-border-radius-sm,.125rem)}.scroll-container::-webkit-scrollbar{height:var(--sd-spacing-1,.25rem);width:var(--sd-spacing-1,.25rem)}.scroll-auto{overflow:auto}[part=button-left]{background:linear-gradient(270deg,var(--gradient))}[part=button-right]{background:linear-gradient(90deg,var(--gradient))}[part=button-top]{background:linear-gradient(0deg,var(--gradient))}[part=button-bottom]{background:linear-gradient(180deg,var(--gradient))}[part=shadow-left]{background:linear-gradient(270deg,rgba(24,24,24,0) 50%,rgba(24,24,24,.4) 100%)}[part=shadow-right]{background:linear-gradient(90deg,rgba(24,24,24,0) 50%,rgba(24,24,24,.4) 100%)}[part=shadow-top]{background:linear-gradient(0deg,rgba(24,24,24,0) 50%,rgba(24,24,24,.4) 100%)}[part=shadow-bottom]{background:linear-gradient(180deg,rgba(24,24,24,0) 50%,rgba(24,24,24,.4) 100%)}.sd-3-7-0-icon--top{align-self:flex-start}.sd-3-7-0-icon--down{align-self:flex-end}`
123
123
  ];
124
124
  __decorateClass([
125
125
  property({ type: String, reflect: true })
@@ -149,7 +149,7 @@ __decorateClass([
149
149
  state()
150
150
  ], SdScrollable.prototype, "isScrollVerticalEnabled", 2);
151
151
  SdScrollable = __decorateClass([
152
- customElement("sd-3-5-0-scrollable")
152
+ customElement("sd-3-7-0-scrollable")
153
153
  ], SdScrollable);
154
154
  export {
155
155
  SdScrollable as default
@@ -1,3 +1,4 @@
1
+ import { LocalizeController } from '../../utilities/localize.js';
1
2
  import SdIcon from '../icon/icon';
2
3
  import SdPopup from '../popup/popup';
3
4
  import SdTag from '../tag/tag';
@@ -7,13 +8,13 @@ import type { TemplateResult } from 'lit';
7
8
  import type SdOption from '../option/option';
8
9
  export default class SdSelect extends SolidElement implements SolidFormControl {
9
10
  static dependencies: {
10
- 'sd-3-5-0-icon': typeof SdIcon;
11
- 'sd-3-5-0-popup': typeof SdPopup;
12
- 'sd-3-5-0-tag': typeof SdTag;
11
+ 'sd-3-7-0-icon': typeof SdIcon;
12
+ 'sd-3-7-0-popup': typeof SdPopup;
13
+ 'sd-3-7-0-tag': typeof SdTag;
13
14
  };
14
15
  private readonly formControlController;
15
16
  private readonly hasSlotController;
16
- private readonly localize;
17
+ localize: LocalizeController;
17
18
  private typeToSelectString;
18
19
  private typeToSelectTimeout;
19
20
  _optionsInDefaultSlot: SdOption[];
@@ -97,6 +98,6 @@ export default class SdSelect extends SolidElement implements SolidFormControl {
97
98
  }
98
99
  declare global {
99
100
  interface HTMLElementTagNameMap {
100
- 'sd-3-5-0-select': SdSelect;
101
+ 'sd-3-7-0-select': SdSelect;
101
102
  }
102
103
  }
@@ -32,7 +32,7 @@ let SdSelect = class extends SolidElement {
32
32
  constructor() {
33
33
  super(...arguments);
34
34
  this.formControlController = new FormControlController(this, {
35
- assumeInteractionOn: ["sd-blur", "sd-3-5-0-input"]
35
+ assumeInteractionOn: ["sd-blur", "sd-3-7-0-input"]
36
36
  });
37
37
  this.hasSlotController = new HasSlotController(this, "help-text", "label");
38
38
  this.localize = new LocalizeController(this);
@@ -63,11 +63,11 @@ let SdSelect = class extends SolidElement {
63
63
  this.styleOnValid = false;
64
64
  this.hoist = false;
65
65
  this.getTag = (option) => {
66
- return html`<sd-3-5-0-tag ?disabled="${this.disabled}" part="tag" exportparts="
66
+ return html`<sd-3-7-0-tag ?disabled="${this.disabled}" part="tag" exportparts="
67
67
  base:tag__base,
68
68
  content:tag__content,
69
69
  removable-indicator:tag__removable-indicator,
70
- " size="${this.size === "sm" ? "sm" : "lg"}" removable @sd-remove="${(event) => this.handleTagRemove(event, option)}">${option.getTextLabel()}</sd-3-5-0-tag>`;
70
+ " size="${this.size === "sm" ? "sm" : "lg"}" removable @sd-remove="${(event) => this.handleTagRemove(event, option)}">${option.getTextLabel()}</sd-3-7-0-tag>`;
71
71
  };
72
72
  this.handleDocumentFocusIn = (event) => {
73
73
  const path = event.composedPath();
@@ -78,7 +78,7 @@ let SdSelect = class extends SolidElement {
78
78
  this.handleDocumentKeyDown = (event) => {
79
79
  const target = event.target;
80
80
  const isClearButton = target.closest(".select__clear") !== null;
81
- const isIconButton = target.closest("sd-3-5-0-icon-button") !== null;
81
+ const isIconButton = target.closest("sd-3-7-0-icon-button") !== null;
82
82
  if (isClearButton || isIconButton) {
83
83
  return;
84
84
  }
@@ -241,7 +241,7 @@ let SdSelect = class extends SolidElement {
241
241
  }
242
242
  handleOptionClick(event) {
243
243
  const target = event.target;
244
- const option = target.closest("sd-3-5-0-option");
244
+ const option = target.closest("sd-3-7-0-option");
245
245
  const oldValue = this.value;
246
246
  if (option && !option.disabled) {
247
247
  if (this.multiple) {
@@ -266,7 +266,7 @@ let SdSelect = class extends SolidElement {
266
266
  const allOptions = this.getAllOptions();
267
267
  const value = Array.isArray(this.value) ? this.value : [this.value];
268
268
  const values = [];
269
- if (customElements.get("sd-3-5-0-option")) {
269
+ if (customElements.get("sd-3-7-0-option")) {
270
270
  allOptions.forEach((option) => {
271
271
  if (this.multiple) {
272
272
  option.checkbox = true;
@@ -275,7 +275,7 @@ let SdSelect = class extends SolidElement {
275
275
  });
276
276
  this.setSelectedOptions(allOptions.filter((el) => value.includes(el.value)));
277
277
  } else {
278
- customElements.whenDefined("sd-3-5-0-option").then(() => this.handleDefaultSlotChange());
278
+ customElements.whenDefined("sd-3-7-0-option").then(() => this.handleDefaultSlotChange());
279
279
  }
280
280
  }
281
281
  handleTagRemove(event, option) {
@@ -288,13 +288,13 @@ let SdSelect = class extends SolidElement {
288
288
  });
289
289
  }
290
290
  }
291
- // Gets an array of all <sd-3-5-0-option> elements
291
+ // Gets an array of all <sd-3-7-0-option> elements
292
292
  getAllOptions() {
293
- return [...this.querySelectorAll("sd-3-5-0-option")];
293
+ return [...this.querySelectorAll("sd-3-7-0-option")];
294
294
  }
295
- // Gets the first <sd-3-5-0-option> element
295
+ // Gets the first <sd-3-7-0-option> element
296
296
  getFirstOption() {
297
- return this.querySelector("sd-3-5-0-option");
297
+ return this.querySelector("sd-3-7-0-option");
298
298
  }
299
299
  // Sets the current option, which is the option the user is currently interacting with (e.g. via keyboard). Only one
300
300
  // option may be "current" at a time.
@@ -356,7 +356,7 @@ let SdSelect = class extends SolidElement {
356
356
  const tag = this.getTag(option, index);
357
357
  return html`<div @sd-remove="${(e) => this.handleTagRemove(e, option)}">${typeof tag === "string" ? unsafeHTML(tag) : tag}</div>`;
358
358
  } else if (index === this.maxOptionsVisible) {
359
- return html`<sd-3-5-0-tag size="${this.size === "sm" ? "sm" : "lg"}" ?disabled="${this.disabled}">+${this.selectedOptions.length - index}</sd-3-5-0-tag>`;
359
+ return html`<sd-3-7-0-tag size="${this.size === "sm" ? "sm" : "lg"}" ?disabled="${this.disabled}">+${this.selectedOptions.length - index}</sd-3-7-0-tag>`;
360
360
  }
361
361
  return html``;
362
362
  });
@@ -372,7 +372,7 @@ let SdSelect = class extends SolidElement {
372
372
  handleMouseLeave() {
373
373
  this.hasHover = false;
374
374
  }
375
- /** Receives incoming event detail from sd-3-5-0-popup and updates local state for conditional styling. */
375
+ /** Receives incoming event detail from sd-3-7-0-popup and updates local state for conditional styling. */
376
376
  handleCurrentPlacement(e) {
377
377
  const incomingPlacement = e.detail;
378
378
  if (incomingPlacement) {
@@ -381,7 +381,7 @@ let SdSelect = class extends SolidElement {
381
381
  }
382
382
  handleUseTagsChange() {
383
383
  const allOptions = this.getAllOptions();
384
- if (customElements.get("sd-3-5-0-option")) {
384
+ if (customElements.get("sd-3-7-0-option")) {
385
385
  allOptions.forEach((option) => {
386
386
  option.checkbox = this.multiple;
387
387
  });
@@ -526,7 +526,7 @@ let SdSelect = class extends SolidElement {
526
526
  default: "border-neutral-800"
527
527
  }[selectState],
528
528
  this.open && (this.currentPlacement === "bottom" ? "rounded-bl-none rounded-br-none" : "rounded-tl-none rounded-tr-none")
529
- )}"></div><sd-3-5-0-popup @sd-current-placement="${this.handleCurrentPlacement}" class="${cx(
529
+ )}"></div><sd-3-7-0-popup @sd-current-placement="${this.handleCurrentPlacement}" class="${cx(
530
530
  "inline-flex relative w-full",
531
531
  this.currentPlacement === "bottom" ? "origin-top" : "origin-bottom"
532
532
  )}" placement="${this.placement}" strategy="${this.hoist ? "fixed" : "absolute"}" flip shift sync="width" auto-size="vertical" auto-size-padding="10" exportparts="
@@ -543,33 +543,33 @@ let SdSelect = class extends SolidElement {
543
543
  "appearance-none outline-none flex-grow bg-transparent w-full",
544
544
  cursorStyles,
545
545
  this.multiple && this.useTags && this.value.length > 0 ? "hidden" : ""
546
- )}" type="text" placeholder="${this.placeholder}" .disabled="${this.disabled}" .value="${this.displayLabel}" autocomplete="off" spellcheck="false" autocapitalize="off" readonly="readonly" aria-controls="listbox" aria-expanded="${this.open ? "true" : "false"}" aria-haspopup="listbox" aria-labelledby="label" aria-disabled="${this.disabled ? "true" : "false"}" aria-describedby="help-text" role="combobox" tabindex="0" @focus="${this.handleFocus}" @blur="${this.handleBlur}"> ${this.multiple && this.useTags ? html`<div part="tags" class="flex-grow flex flex-wrap items-center gap-1">${this.tags}</div>` : ""} <input class="${cx("value-input absolute top-0 left-0 w-full h-full opacity-0 -z-10", cursorStyles)}" type="text" ?disabled="${this.disabled}" ?required="${this.required}" .value="${Array.isArray(this.value) ? this.value.join(", ") : this.value}" tabindex="-1" aria-hidden="true" @focus="${() => this.focus()}" @invalid="${this.handleInvalid}"> ${hasClearIcon ? html`<button part="clear-button" class="${cx("select__clear flex justify-center", iconMarginLeft)}" type="button" aria-label="${this.localize.term("clearEntry")}" @mousedown="${this.handleClearMouseDown}" @click="${this.handleClearClick}" tabindex="-1"><slot name="clear-icon"><sd-3-5-0-icon class="${cx("text-neutral-500", iconSize)}" library="system" name="closing-round"></sd-3-5-0-icon></slot></button>` : ""} ${this.showInvalidStyle ? html`<sd-3-5-0-icon part="invalid-icon" class="${cx(iconMarginLeft, iconSize)}" library="system" name="risk"></sd-3-5-0-icon>` : ""} ${this.styleOnValid && this.showValidStyle ? html`<sd-3-5-0-icon part="valid-icon" class="${cx("flex-shrink-0", iconMarginLeft, iconSize)}" library="system" name="status-check"></sd-3-5-0-icon>` : ""}<slot name="expand-icon" part="expand-icon" class="${cx(
546
+ )}" type="text" placeholder="${this.placeholder}" .disabled="${this.disabled}" .value="${this.displayLabel}" autocomplete="off" spellcheck="false" autocapitalize="off" readonly="readonly" aria-controls="listbox" aria-expanded="${this.open ? "true" : "false"}" aria-haspopup="listbox" aria-labelledby="label" aria-disabled="${this.disabled ? "true" : "false"}" aria-describedby="help-text" role="combobox" tabindex="0" @focus="${this.handleFocus}" @blur="${this.handleBlur}"> ${this.multiple && this.useTags ? html`<div part="tags" class="flex-grow flex flex-wrap items-center gap-1">${this.tags}</div>` : ""} <input class="${cx("value-input absolute top-0 left-0 w-full h-full opacity-0 -z-10", cursorStyles)}" type="text" ?disabled="${this.disabled}" ?required="${this.required}" .value="${Array.isArray(this.value) ? this.value.join(", ") : this.value}" tabindex="-1" aria-hidden="true" @focus="${() => this.focus()}" @invalid="${this.handleInvalid}"> ${hasClearIcon ? html`<button part="clear-button" class="${cx("select__clear flex justify-center", iconMarginLeft)}" type="button" aria-label="${this.localize.term("clearEntry")}" @mousedown="${this.handleClearMouseDown}" @click="${this.handleClearClick}" tabindex="-1"><slot name="clear-icon"><sd-3-7-0-icon class="${cx("text-neutral-500", iconSize)}" library="system" name="closing-round"></sd-3-7-0-icon></slot></button>` : ""} ${this.showInvalidStyle ? html`<sd-3-7-0-icon part="invalid-icon" class="${cx(iconMarginLeft, iconSize)}" library="system" name="risk"></sd-3-7-0-icon>` : ""} ${this.styleOnValid && this.showValidStyle ? html`<sd-3-7-0-icon part="valid-icon" class="${cx("flex-shrink-0", iconMarginLeft, iconSize)}" library="system" name="status-check"></sd-3-7-0-icon>` : ""}<slot name="expand-icon" part="expand-icon" class="${cx(
547
547
  "inline-flex ml-2 transition-all",
548
548
  this.open ? "rotate-180" : "rotate-0",
549
549
  this.disabled ? "text-neutral-500" : "text-primary",
550
550
  iconSize
551
- )}"><sd-3-5-0-icon name="chevron-down" part="chevron" library="system" color="currentColor"></sd-3-5-0-icon></slot></div><div id="listbox" role="listbox" aria-expanded="${this.open ? "true" : "false"}" aria-multiselectable="${this.multiple ? "true" : "false"}" aria-labelledby="label" part="listbox" class="${cx(
551
+ )}"><sd-3-7-0-icon name="chevron-down" part="chevron" library="system" color="currentColor"></sd-3-7-0-icon></slot></div><div id="listbox" role="listbox" aria-expanded="${this.open ? "true" : "false"}" aria-multiselectable="${this.multiple ? "true" : "false"}" aria-labelledby="label" part="listbox" class="${cx(
552
552
  "bg-white px-2 py-3 relative border-primary",
553
553
  this.open && "shadow",
554
554
  this.currentPlacement === "bottom" ? "border-r-2 border-b-2 border-l-2 rounded-br-default rounded-bl-default" : "border-r-2 border-t-2 border-l-2 rounded-tr-default rounded-tl-default"
555
- )}" tabindex="-1" @mouseup="${this.handleOptionClick}" @slotchange="${this.handleDefaultSlotChange}"><slot></slot></div></sd-3-5-0-popup></div><div class="text-sm text-neutral-700" part="form-control-help-text" id="help-text" aria-hidden="${hasHelpText ? "false" : "true"}"><slot name="help-text">${this.helpText}</slot></div></div>${this.formControlController.renderInvalidMessage()}`;
555
+ )}" tabindex="-1" @mouseup="${this.handleOptionClick}" @slotchange="${this.handleDefaultSlotChange}"><slot></slot></div></sd-3-7-0-popup></div><div class="text-sm text-neutral-700" part="form-control-help-text" id="help-text" aria-hidden="${hasHelpText ? "false" : "true"}"><slot name="help-text">${this.helpText}</slot></div></div>${this.formControlController.renderInvalidMessage()}`;
556
556
  }
557
557
  };
558
558
  SdSelect.dependencies = {
559
- "sd-3-5-0-icon": SdIcon,
560
- "sd-3-5-0-popup": SdPopup,
561
- "sd-3-5-0-tag": SdTag
559
+ "sd-3-7-0-icon": SdIcon,
560
+ "sd-3-7-0-popup": SdPopup,
561
+ "sd-3-7-0-tag": SdTag
562
562
  };
563
563
  SdSelect.styles = [
564
564
  componentStyles,
565
565
  SolidElement.styles,
566
- css`:host{position:relative;display:block;width:100%}:host([required]) #label::after{content:' *'}sd-3-5-0-popup::part(popup){z-index:var(--sd-z-index-dropdown,900);overflow-y:scroll}sd-3-5-0-tag::part(base){border-radius:var(--sd-border-radius-default,.25rem);padding-left:var(--sd-spacing-1,.25rem);padding-right:var(--sd-spacing-1,.25rem)}sd-3-5-0-tag[size=lg]::part(base){padding-left:var(--sd-spacing-2,.5rem);padding-right:var(--sd-spacing-2,.5rem)}sd-3-5-0-tag[disabled=false]::part(base):hover{--tw-bg-opacity:1;background-color:rgb(var(--sd-color-primary-100,236 240 249) / var(--tw-bg-opacity))}`
566
+ css`:host{position:relative;display:block;width:100%}:host([required]) #label::after{content:' *'}sd-3-7-0-popup::part(popup){z-index:var(--sd-z-index-dropdown,900);overflow-y:scroll}sd-3-7-0-tag::part(base){border-radius:var(--sd-border-radius-default,.25rem);padding-left:var(--sd-spacing-1,.25rem);padding-right:var(--sd-spacing-1,.25rem)}sd-3-7-0-tag[size=lg]::part(base){padding-left:var(--sd-spacing-2,.5rem);padding-right:var(--sd-spacing-2,.5rem)}sd-3-7-0-tag[disabled=false]::part(base):hover{--tw-bg-opacity:1;background-color:rgb(var(--sd-color-primary-100,236 240 249) / var(--tw-bg-opacity))}`
567
567
  ];
568
568
  __decorateClass([
569
- queryAssignedElements({ selector: "sd-3-5-0-option" })
569
+ queryAssignedElements({ selector: "sd-3-7-0-option" })
570
570
  ], SdSelect.prototype, "_optionsInDefaultSlot", 2);
571
571
  __decorateClass([
572
- query("sd-3-5-0-popup")
572
+ query("sd-3-7-0-popup")
573
573
  ], SdSelect.prototype, "popup", 2);
574
574
  __decorateClass([
575
575
  query('[part="combobox"]')
@@ -688,7 +688,7 @@ __decorateClass([
688
688
  watch("value", { waitUntilFirstUpdate: true })
689
689
  ], SdSelect.prototype, "handleValueChange", 1);
690
690
  SdSelect = __decorateClass([
691
- customElement("sd-3-5-0-select")
691
+ customElement("sd-3-7-0-select")
692
692
  ], SdSelect);
693
693
  setDefaultAnimation("select.show", {
694
694
  keyframes: [
@@ -1,12 +1,13 @@
1
+ import { LocalizeController } from '../../utilities/localize';
1
2
  import SolidElement from '../../internal/solid-element';
2
3
  export default class SdSpinner extends SolidElement {
3
4
  color: 'primary' | 'white' | 'currentColor';
4
- private readonly localize;
5
+ localize: LocalizeController;
5
6
  render(): import("lit-html").TemplateResult<1>;
6
7
  static styles: import("lit").CSSResultGroup[];
7
8
  }
8
9
  declare global {
9
10
  interface HTMLElementTagNameMap {
10
- 'sd-3-5-0-spinner': SdSpinner;
11
+ 'sd-3-7-0-spinner': SdSpinner;
11
12
  }
12
13
  }
@@ -40,7 +40,7 @@ __decorateClass([
40
40
  property({ reflect: true })
41
41
  ], SdSpinner.prototype, "color", 2);
42
42
  SdSpinner = __decorateClass([
43
- customElement("sd-3-5-0-spinner")
43
+ customElement("sd-3-7-0-spinner")
44
44
  ], SdSpinner);
45
45
  export {
46
46
  SdSpinner as default
@@ -22,6 +22,6 @@ export default class SdStep extends SolidElement {
22
22
  }
23
23
  declare global {
24
24
  interface HTMLElementTagNameMap {
25
- 'sd-3-5-0-step': SdStep;
25
+ 'sd-3-7-0-step': SdStep;
26
26
  }
27
27
  }
@@ -85,20 +85,20 @@ let SdStep = class extends SolidElement {
85
85
  !this.disabled && !this.current && !this.notInteractive && "text-primary group-hover:text-primary-500 group-hover:fill-primary-500",
86
86
  this.notInteractive && "text-primary",
87
87
  this.size === "lg" ? "text-lg" : "text-sm"
88
- )}">${!this.disabled && !this.current && !this.notInteractive ? html`<sd-3-5-0-icon name="status-check" library="system"></sd-3-5-0-icon>` : html`${this.index}`}</slot></${tag}>${this.noTail ? "" : this.orientation === "horizontal" ? html`<sd-3-5-0-divider part="tail" orientation="horizontal" class="${cx(
88
+ )}">${!this.disabled && !this.current && !this.notInteractive ? html`<sd-3-7-0-icon name="status-check" library="system"></sd-3-7-0-icon>` : html`${this.index}`}</slot></${tag}>${this.noTail ? "" : this.orientation === "horizontal" ? html`<sd-3-7-0-divider part="tail" orientation="horizontal" class="${cx(
89
89
  "w-full my-auto mr-2",
90
90
  !this.disabled && !this.current && !this.notInteractive && "tail-to-primary"
91
- )}"></sd-3-5-0-divider>` : html`<sd-3-5-0-divider part="tail" orientation="vertical" class="${cx(
91
+ )}"></sd-3-7-0-divider>` : html`<sd-3-7-0-divider part="tail" orientation="vertical" class="${cx(
92
92
  "flex-grow flex-shrink-0 basis-auto h-full w-[1px] mx-auto",
93
93
  !this.disabled && !this.current && !this.notInteractive && "tail-to-primary"
94
- )}"></sd-3-5-0-divider>`}</div><div part="text-container" class="${cx("mt-4 mr-4 break-words flex flex-col gap-2", this.orientation === "horizontal" ? "text-center w-40" : "w-max text-left", this.disabled && "!text-neutral-500")}"><div part="label" class="${cx("!font-bold sd-paragraph", this.disabled && "!text-neutral-500", !this.disabled && !this.current && !this.notInteractive ? "!text-primary group-hover:!text-primary-500 group-hover:cursor-pointer" : "text-black")}"><slot name="label">${this.label}</slot></div><div part="description" class="${cx("sd-paragraph sd-paragraph--size-sm", this.disabled && "!text-neutral-500")}">${this.description || html`<slot></slot>`}</div></div></div>`;
94
+ )}"></sd-3-7-0-divider>`}</div><div part="text-container" class="${cx("mt-4 mr-4 break-words flex flex-col gap-2", this.orientation === "horizontal" ? "text-center w-40" : "w-max text-left", this.disabled && "!text-neutral-500")}"><div part="label" class="${cx("!font-bold sd-paragraph", this.disabled && "!text-neutral-500", !this.disabled && !this.current && !this.notInteractive ? "!text-primary group-hover:!text-primary-500 group-hover:cursor-pointer" : "text-black")}"><slot name="label">${this.label}</slot></div><div part="description" class="${cx("sd-paragraph sd-paragraph--size-sm", this.disabled && "!text-neutral-500")}">${this.description || html`<slot></slot>`}</div></div></div>`;
95
95
  }
96
96
  };
97
97
  SdStep.styles = [
98
98
  SolidElement.styles,
99
99
  componentStyles,
100
100
  unsafeCSS(ParagraphStyles),
101
- css`:host{flex:1 1 0%}[part=base]:not(:has(sd-3-5-0-divider)){height:-moz-max-content;height:max-content}:host([no-tail]){flex-grow:0}.translateLg{transform:translateX(55px)}.translateSm{transform:translateX(64px)}.tail-to-primary::part(main){--tw-border-opacity:1!important;border-color:rgb(var(--sd-color-primary,0 53 142) / var(--tw-border-opacity))!important}.group:hover .tail-to-primary::part(main){--tw-border-opacity:1!important;border-color:rgb(var(--sd-color-primary-500,70 109 175) / var(--tw-border-opacity))!important}sd-3-5-0-divider::part(main){--tw-border-opacity:1!important;border-color:rgb(var(--sd-color-neutral-400,195 195 195) / var(--tw-border-opacity))!important}`
101
+ css`:host{flex:1 1 0%}[part=base]:not(:has(sd-3-7-0-divider)){height:-moz-max-content;height:max-content}:host([no-tail]){flex-grow:0}.translateLg{transform:translateX(55px)}.translateSm{transform:translateX(64px)}.tail-to-primary::part(main){--tw-border-opacity:1!important;border-color:rgb(var(--sd-color-primary,0 53 142) / var(--tw-border-opacity))!important}.group:hover .tail-to-primary::part(main){--tw-border-opacity:1!important;border-color:rgb(var(--sd-color-primary-500,70 109 175) / var(--tw-border-opacity))!important}sd-3-7-0-divider::part(main){--tw-border-opacity:1!important;border-color:rgb(var(--sd-color-neutral-400,195 195 195) / var(--tw-border-opacity))!important}`
102
102
  ];
103
103
  __decorateClass([
104
104
  property({ reflect: true })
@@ -140,7 +140,7 @@ __decorateClass([
140
140
  watch("notInteractive")
141
141
  ], SdStep.prototype, "handleInteractivityChange", 1);
142
142
  SdStep = __decorateClass([
143
- customElement("sd-3-5-0-step")
143
+ customElement("sd-3-7-0-step")
144
144
  ], SdStep);
145
145
  export {
146
146
  SdStep as default
@@ -17,6 +17,6 @@ export default class SdStepGroup extends SolidElement {
17
17
  }
18
18
  declare global {
19
19
  interface HTMLElementTagNameMap {
20
- 'sd-3-5-0-step-group': SdStepGroup;
20
+ 'sd-3-7-0-step-group': SdStepGroup;
21
21
  }
22
22
  }