@warp-ds/elements 2.3.0-next.3 → 2.3.0-next.30

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 (245) hide show
  1. package/dist/custom-elements.json +1139 -144
  2. package/dist/index.d.ts +413 -34
  3. package/dist/packages/affix/index.js.map +2 -2
  4. package/dist/packages/affix/react.d.ts +1 -1
  5. package/dist/packages/alert/index.js.map +2 -2
  6. package/dist/packages/alert/react.d.ts +1 -1
  7. package/dist/packages/attention/attention.stories.js +4 -1
  8. package/dist/packages/attention/index.js +58 -22
  9. package/dist/packages/attention/index.js.map +3 -3
  10. package/dist/packages/attention/react.d.ts +1 -1
  11. package/dist/packages/attention/styles.js +1 -1
  12. package/dist/packages/badge/index.js.map +2 -2
  13. package/dist/packages/badge/react.d.ts +1 -1
  14. package/dist/packages/box/index.js.map +2 -2
  15. package/dist/packages/box/react.d.ts +1 -1
  16. package/dist/packages/breadcrumbs/index.js.map +2 -2
  17. package/dist/packages/breadcrumbs/react.d.ts +1 -1
  18. package/dist/packages/button/button.react.stories.d.ts +1 -1
  19. package/dist/packages/button/button.stories.d.ts +4 -4
  20. package/dist/packages/button/button.stories.js +4 -4
  21. package/dist/packages/button/button.test.js +30 -1
  22. package/dist/packages/button/index.d.ts +2 -0
  23. package/dist/packages/button/index.js +52 -16
  24. package/dist/packages/button/index.js.map +3 -3
  25. package/dist/packages/button/react.d.ts +1 -1
  26. package/dist/packages/card/index.js.map +2 -2
  27. package/dist/packages/card/react.d.ts +1 -1
  28. package/dist/packages/checkbox/checkbox-group.d.ts +10 -0
  29. package/dist/packages/checkbox/checkbox-group.js +7 -0
  30. package/dist/packages/checkbox/checkbox-group.js.map +7 -0
  31. package/dist/packages/{rip-and-tear-checkbox → checkbox}/checkbox.d.ts +2 -2
  32. package/dist/packages/{rip-and-tear-checkbox → checkbox}/checkbox.js +3 -4
  33. package/dist/packages/checkbox/checkbox.js.map +7 -0
  34. package/dist/packages/{rip-and-tear-checkbox → checkbox}/checkbox.stories.d.ts +3 -0
  35. package/dist/packages/checkbox/checkbox.stories.js +25 -0
  36. package/dist/packages/checkbox/index.d.ts +2 -0
  37. package/dist/packages/checkbox/index.js +2 -0
  38. package/dist/packages/checkbox/react.d.ts +7 -0
  39. package/dist/packages/{rip-and-tear-checkbox → checkbox}/react.js +5 -0
  40. package/dist/packages/combobox/combobox.react.stories.d.ts +1 -1
  41. package/dist/packages/combobox/combobox.stories.d.ts +1 -0
  42. package/dist/packages/combobox/combobox.stories.js +29 -3
  43. package/dist/packages/combobox/index.d.ts +7 -1
  44. package/dist/packages/combobox/index.js +20 -19
  45. package/dist/packages/combobox/index.js.map +4 -4
  46. package/dist/packages/combobox/react.d.ts +1 -1
  47. package/dist/packages/combobox/styles.js +2 -1
  48. package/dist/packages/datepicker/datepicker.d.ts +1 -0
  49. package/dist/packages/datepicker/datepicker.js +35 -35
  50. package/dist/packages/datepicker/datepicker.js.map +3 -3
  51. package/dist/packages/datepicker/datepicker.react.stories.d.ts +1 -1
  52. package/dist/packages/datepicker/datepicker.test.js +27 -0
  53. package/dist/packages/datepicker/react.d.ts +1 -1
  54. package/dist/packages/{dead-toggle → deadtoggle}/index.js +2 -3
  55. package/dist/packages/deadtoggle/index.js.map +7 -0
  56. package/dist/packages/{dead-toggle → deadtoggle}/react.d.ts +1 -1
  57. package/dist/packages/expandable/index.js.map +2 -2
  58. package/dist/packages/expandable/react.d.ts +1 -1
  59. package/dist/packages/link/index.d.ts +2 -8
  60. package/dist/packages/link/index.js +46 -10
  61. package/dist/packages/link/index.js.map +4 -4
  62. package/dist/packages/link/link.react.stories.d.ts +6 -3
  63. package/dist/packages/link/link.react.stories.js +27 -10
  64. package/dist/packages/link/link.stories.d.ts +5 -2
  65. package/dist/packages/link/link.stories.js +27 -10
  66. package/dist/packages/link/react.d.ts +1 -1
  67. package/dist/packages/link/styles.js +39 -3
  68. package/dist/packages/modal/index.js.map +2 -2
  69. package/dist/packages/modal/modal-header.js.map +2 -2
  70. package/dist/packages/modal/modal.stories.d.ts +3 -3
  71. package/dist/packages/modal/modal.stories.js +32 -32
  72. package/dist/packages/modal/react.d.ts +1 -1
  73. package/dist/packages/pageindicator/react.d.ts +1 -1
  74. package/dist/packages/pagination/index.js.map +2 -2
  75. package/dist/packages/pagination/react.d.ts +1 -1
  76. package/dist/packages/pill/index.js.map +2 -2
  77. package/dist/packages/pill/react.d.ts +1 -1
  78. package/dist/packages/radio/index.d.ts +2 -0
  79. package/dist/packages/radio/index.js +2 -0
  80. package/dist/packages/{rip-and-tear-radio → radio}/radio-group-styles.js.map +1 -1
  81. package/dist/packages/{rip-and-tear-radio → radio}/radio-group.js +7 -8
  82. package/dist/packages/radio/radio-group.js.map +7 -0
  83. package/dist/packages/{rip-and-tear-radio → radio}/radio.js +3 -4
  84. package/dist/packages/radio/radio.js.map +7 -0
  85. package/dist/packages/radio/radio.stories.d.ts +15 -0
  86. package/dist/packages/radio/radio.stories.js +3702 -0
  87. package/dist/packages/radio/radio.stories.js.map +7 -0
  88. package/dist/packages/{rip-and-tear-radio → radio}/react.d.ts +2 -2
  89. package/dist/packages/select/index.d.ts +26 -5
  90. package/dist/packages/select/index.js +17 -16
  91. package/dist/packages/select/index.js.map +3 -3
  92. package/dist/packages/select/react.d.ts +1 -1
  93. package/dist/packages/select/select.react.stories.d.ts +1 -1
  94. package/dist/packages/select/select.stories.d.ts +1 -1
  95. package/dist/packages/select/select.stories.js +3 -4
  96. package/dist/packages/select/select.test.js +30 -0
  97. package/dist/packages/slider/locales/da/messages.mjs +1 -0
  98. package/dist/packages/slider/locales/en/messages.mjs +1 -0
  99. package/dist/packages/slider/locales/fi/messages.mjs +1 -0
  100. package/dist/packages/slider/locales/nb/messages.mjs +1 -0
  101. package/dist/packages/slider/locales/sv/messages.mjs +1 -0
  102. package/dist/packages/slider/react.d.ts +2 -2
  103. package/dist/packages/slider/slider-thumb.d.ts +13 -7
  104. package/dist/packages/slider/slider-thumb.js +92 -49
  105. package/dist/packages/slider/slider-thumb.js.map +4 -4
  106. package/dist/packages/slider/slider.d.ts +12 -3
  107. package/dist/packages/slider/slider.js +109 -31
  108. package/dist/packages/slider/slider.js.map +4 -4
  109. package/dist/packages/slider/slider.react.stories.d.ts +1 -0
  110. package/dist/packages/slider/slider.react.stories.js +22 -0
  111. package/dist/packages/slider/slider.stories.d.ts +3 -0
  112. package/dist/packages/slider/slider.stories.js +240 -33
  113. package/dist/packages/slider/slider.test.js +28 -0
  114. package/dist/packages/slider/styles/w-slider-thumb.styles.js +24 -16
  115. package/dist/packages/slider/styles/w-slider.styles.js +65 -18
  116. package/dist/packages/{steps → stepindicator}/index.d.ts +3 -2
  117. package/dist/packages/{steps → stepindicator}/index.js +8 -8
  118. package/dist/packages/stepindicator/index.js.map +7 -0
  119. package/dist/packages/stepindicator/locales/da/messages.d.mts +1 -0
  120. package/dist/packages/stepindicator/locales/en/messages.d.mts +1 -0
  121. package/dist/packages/stepindicator/locales/fi/messages.d.mts +1 -0
  122. package/dist/packages/stepindicator/locales/nb/messages.d.mts +1 -0
  123. package/dist/packages/stepindicator/locales/sv/messages.d.mts +1 -0
  124. package/dist/packages/stepindicator/react.d.ts +3 -0
  125. package/dist/packages/{steps → stepindicator}/react.js +2 -2
  126. package/dist/packages/{steps/steps.react.stories.d.ts → stepindicator/stepindicator.react.stories.d.ts} +4 -4
  127. package/dist/packages/{steps/steps.react.stories.js → stepindicator/stepindicator.react.stories.js} +11 -11
  128. package/dist/packages/{steps/steps.stories.js → stepindicator/stepindicator.stories.js} +16 -16
  129. package/dist/packages/switch/index.d.ts +10 -2
  130. package/dist/packages/switch/index.js +7 -6
  131. package/dist/packages/switch/index.js.map +4 -4
  132. package/dist/packages/switch/react.d.ts +1 -1
  133. package/dist/packages/switch/styles.js +1 -1
  134. package/dist/packages/switch/switch.react.stories.js +4 -4
  135. package/dist/packages/switch/switch.stories.js +6 -5
  136. package/dist/packages/switch/switch.test.d.ts +1 -0
  137. package/dist/packages/switch/switch.test.js +40 -0
  138. package/dist/packages/tabs/tab.js +4 -3
  139. package/dist/packages/tabs/tab.js.map +2 -2
  140. package/dist/packages/tabs/tabs.js +5 -5
  141. package/dist/packages/tabs/tabs.js.map +3 -3
  142. package/dist/packages/tabs/tabs.stories.d.ts +3 -0
  143. package/dist/packages/tabs/tabs.stories.js +16 -7
  144. package/dist/packages/textarea/index.d.ts +1 -0
  145. package/dist/packages/textarea/index.js +1 -0
  146. package/dist/packages/textarea/locales/da/messages.d.mts +1 -0
  147. package/dist/packages/textarea/locales/da/messages.mjs +1 -0
  148. package/dist/packages/textarea/locales/en/messages.d.mts +1 -0
  149. package/dist/packages/textarea/locales/en/messages.mjs +1 -0
  150. package/dist/packages/textarea/locales/fi/messages.d.mts +1 -0
  151. package/dist/packages/textarea/locales/fi/messages.mjs +1 -0
  152. package/dist/packages/textarea/locales/nb/messages.d.mts +1 -0
  153. package/dist/packages/textarea/locales/nb/messages.mjs +1 -0
  154. package/dist/packages/textarea/locales/sv/messages.d.mts +1 -0
  155. package/dist/packages/textarea/locales/sv/messages.mjs +1 -0
  156. package/dist/packages/textarea/react.d.ts +11 -0
  157. package/dist/packages/textarea/react.js +21 -0
  158. package/dist/packages/textarea/styles.d.ts +1 -0
  159. package/dist/packages/textarea/styles.js +2 -0
  160. package/dist/packages/textarea/textarea.d.ts +49 -0
  161. package/dist/packages/{rip-and-tear-radio/radio.stories.js → textarea/textarea.js} +35 -214
  162. package/dist/packages/textarea/textarea.js.map +7 -0
  163. package/dist/packages/textarea/textarea.react.stories.d.ts +33 -0
  164. package/dist/packages/textarea/textarea.react.stories.js +41 -0
  165. package/dist/packages/textarea/textarea.stories.d.ts +19 -0
  166. package/dist/packages/textarea/textarea.stories.js +85 -0
  167. package/dist/packages/textarea/textarea.test.d.ts +1 -0
  168. package/dist/packages/textarea/textarea.test.js +68 -0
  169. package/dist/packages/textfield/index.d.ts +6 -0
  170. package/dist/packages/textfield/index.js +21 -20
  171. package/dist/packages/textfield/index.js.map +3 -3
  172. package/dist/packages/textfield/react.d.ts +1 -1
  173. package/dist/packages/textfield/textfield.react.stories.d.ts +1 -1
  174. package/dist/packages/textfield/textfield.stories.d.ts +1 -0
  175. package/dist/packages/textfield/textfield.stories.js +17 -0
  176. package/dist/packages/toggle-styles.js +2 -3
  177. package/dist/web-types.json +473 -30
  178. package/package.json +37 -31
  179. package/dist/packages/dead-toggle/index.js.map +0 -7
  180. package/dist/packages/rip-and-tear-checkbox/checkbox.js.map +0 -7
  181. package/dist/packages/rip-and-tear-checkbox/checkbox.stories.js +0 -11
  182. package/dist/packages/rip-and-tear-checkbox/index.d.ts +0 -1
  183. package/dist/packages/rip-and-tear-checkbox/index.js +0 -4
  184. package/dist/packages/rip-and-tear-checkbox/react.d.ts +0 -5
  185. package/dist/packages/rip-and-tear-radio/index.d.ts +0 -1
  186. package/dist/packages/rip-and-tear-radio/index.js +0 -6
  187. package/dist/packages/rip-and-tear-radio/radio-group.js.map +0 -7
  188. package/dist/packages/rip-and-tear-radio/radio.js.map +0 -7
  189. package/dist/packages/rip-and-tear-radio/radio.stories.d.ts +0 -8
  190. package/dist/packages/rip-and-tear-radio/radio.stories.js.map +0 -7
  191. package/dist/packages/steps/index.js.map +0 -7
  192. package/dist/packages/steps/react.d.ts +0 -3
  193. /package/dist/packages/{rip-and-tear-checkbox/rip-and-tear-checkbox.react.stories.d.ts → checkbox/checkbox.react.stories.d.ts} +0 -0
  194. /package/dist/packages/{rip-and-tear-checkbox/rip-and-tear-checkbox.react.stories.js → checkbox/checkbox.react.stories.js} +0 -0
  195. /package/dist/packages/{rip-and-tear-checkbox → checkbox}/styles.d.ts +0 -0
  196. /package/dist/packages/{rip-and-tear-checkbox → checkbox}/styles.js +0 -0
  197. /package/dist/packages/{dead-toggle → deadtoggle}/dead-toggle.react.stories.d.ts +0 -0
  198. /package/dist/packages/{dead-toggle → deadtoggle}/dead-toggle.react.stories.js +0 -0
  199. /package/dist/packages/{dead-toggle → deadtoggle}/dead-toggle.stories.d.ts +0 -0
  200. /package/dist/packages/{dead-toggle → deadtoggle}/dead-toggle.stories.js +0 -0
  201. /package/dist/packages/{dead-toggle → deadtoggle}/dead-toggle.test.d.ts +0 -0
  202. /package/dist/packages/{dead-toggle → deadtoggle}/dead-toggle.test.js +0 -0
  203. /package/dist/packages/{dead-toggle → deadtoggle}/index.d.ts +0 -0
  204. /package/dist/packages/{dead-toggle → deadtoggle}/react.js +0 -0
  205. /package/dist/packages/{rip-and-tear-radio → radio}/base-element.d.ts +0 -0
  206. /package/dist/packages/{rip-and-tear-radio → radio}/base-element.js +0 -0
  207. /package/dist/packages/{rip-and-tear-radio → radio}/custom-error-validator.d.ts +0 -0
  208. /package/dist/packages/{rip-and-tear-radio → radio}/custom-error-validator.js +0 -0
  209. /package/dist/packages/{rip-and-tear-radio → radio}/form-associated-element.d.ts +0 -0
  210. /package/dist/packages/{rip-and-tear-radio → radio}/form-associated-element.js +0 -0
  211. /package/dist/packages/{rip-and-tear-radio → radio}/host-styles.d.ts +0 -0
  212. /package/dist/packages/{rip-and-tear-radio → radio}/host-styles.js +0 -0
  213. /package/dist/packages/{rip-and-tear-radio → radio}/invalid.d.ts +0 -0
  214. /package/dist/packages/{rip-and-tear-radio → radio}/invalid.js +0 -0
  215. /package/dist/packages/{rip-and-tear-radio → radio}/math.d.ts +0 -0
  216. /package/dist/packages/{rip-and-tear-radio → radio}/math.js +0 -0
  217. /package/dist/packages/{rip-and-tear-radio → radio}/radio-group-styles.d.ts +0 -0
  218. /package/dist/packages/{rip-and-tear-radio → radio}/radio-group-styles.js +0 -0
  219. /package/dist/packages/{rip-and-tear-radio → radio}/radio-group.d.ts +0 -0
  220. /package/dist/packages/{rip-and-tear-radio → radio}/radio-styles.d.ts +0 -0
  221. /package/dist/packages/{rip-and-tear-radio → radio}/radio-styles.js +0 -0
  222. /package/dist/packages/{rip-and-tear-radio → radio}/radio-styles.js.map +0 -0
  223. /package/dist/packages/{rip-and-tear-radio → radio}/radio.d.ts +0 -0
  224. /package/dist/packages/{rip-and-tear-radio/rip-and-tear-radio.react.stories.d.ts → radio/radio.react.stories.d.ts} +0 -0
  225. /package/dist/packages/{rip-and-tear-radio/rip-and-tear-radio.react.stories.js → radio/radio.react.stories.js} +0 -0
  226. /package/dist/packages/{rip-and-tear-radio → radio}/react.js +0 -0
  227. /package/dist/packages/{rip-and-tear-radio → radio}/required-validator.d.ts +0 -0
  228. /package/dist/packages/{rip-and-tear-radio → radio}/required-validator.js +0 -0
  229. /package/dist/packages/{rip-and-tear-radio → radio}/slot.d.ts +0 -0
  230. /package/dist/packages/{rip-and-tear-radio → radio}/slot.js +0 -0
  231. /package/dist/packages/{rip-and-tear-radio → radio}/watch.d.ts +0 -0
  232. /package/dist/packages/{rip-and-tear-radio → radio}/watch.js +0 -0
  233. /package/dist/packages/{steps → slider}/locales/da/messages.d.mts +0 -0
  234. /package/dist/packages/{steps → slider}/locales/en/messages.d.mts +0 -0
  235. /package/dist/packages/{steps → slider}/locales/fi/messages.d.mts +0 -0
  236. /package/dist/packages/{steps → slider}/locales/nb/messages.d.mts +0 -0
  237. /package/dist/packages/{steps → slider}/locales/sv/messages.d.mts +0 -0
  238. /package/dist/packages/{steps → stepindicator}/locales/da/messages.mjs +0 -0
  239. /package/dist/packages/{steps → stepindicator}/locales/en/messages.mjs +0 -0
  240. /package/dist/packages/{steps → stepindicator}/locales/fi/messages.mjs +0 -0
  241. /package/dist/packages/{steps → stepindicator}/locales/nb/messages.mjs +0 -0
  242. /package/dist/packages/{steps → stepindicator}/locales/sv/messages.mjs +0 -0
  243. /package/dist/packages/{steps/steps.stories.d.ts → stepindicator/stepindicator.stories.d.ts} +0 -0
  244. /package/dist/packages/{steps → stepindicator}/styles.d.ts +0 -0
  245. /package/dist/packages/{steps → stepindicator}/styles.js +0 -0
@@ -1,4 +1,4 @@
1
- import { WarpSelect } from '.';
1
+ import { WarpSelect } from './index.js';
2
2
  export declare const Select: import("@lit/react").ReactWebComponent<WarpSelect, {
3
3
  onChange: string;
4
4
  onchange: string;
@@ -3,7 +3,7 @@ import { StoryObj } from '@storybook/react';
3
3
  import { Select } from './react';
4
4
  declare const _default: {
5
5
  title: string;
6
- render(args: Omit<React.HTMLAttributes<import(".").WarpSelect>, "label" | "onchange" | "autoFocus" | "onChange" | "render" | "renderOptions" | "connectedCallback" | "disconnectedCallback" | "renderRoot" | "isUpdatePending" | "hasUpdated" | "addController" | "removeController" | "attributeChangedCallback" | "requestUpdate" | "updateComplete" | "form" | "disabled" | "name" | "value" | "validationTarget" | "internals" | "showError" | "validationMessage" | "validity" | "validationComplete" | "checkValidity" | "formResetCallback" | "resetFormControl" | "valueChangedCallback" | "validityCallback" | "validationMessageCallback" | "setValue" | "shouldFormValueUpdate" | "invalid" | "always" | "hint" | "optional" | "readOnly" | "_options" | "_setValue" | "handleKeyDown"> & {
6
+ render(args: Omit<React.HTMLAttributes<import(".").WarpSelect>, "label" | "onchange" | "autoFocus" | "onChange" | "render" | "renderOptions" | "connectedCallback" | "disconnectedCallback" | "renderRoot" | "isUpdatePending" | "hasUpdated" | "addController" | "removeController" | "attributeChangedCallback" | "requestUpdate" | "updateComplete" | "form" | "disabled" | "name" | "value" | "resetFormControl" | "validationTarget" | "internals" | "showError" | "validationMessage" | "validity" | "validationComplete" | "checkValidity" | "formResetCallback" | "valueChangedCallback" | "validityCallback" | "validationMessageCallback" | "setValue" | "shouldFormValueUpdate" | "invalid" | "helpText" | "always" | "hint" | "optional" | "readOnly" | "readonly" | "_options" | "_setValue" | "handleKeyDown"> & {
7
7
  onChange?: (e: Event) => void;
8
8
  onchange?: (e: Event) => void;
9
9
  } & Partial<Omit<import(".").WarpSelect, keyof HTMLElement>> & React.RefAttributes<import(".").WarpSelect>): React.JSX.Element;
@@ -8,7 +8,7 @@ declare const meta: Meta<typeof args>;
8
8
  export default meta;
9
9
  type Story = StoryObj<typeof args>;
10
10
  export declare const Default: Story;
11
- export declare const Hint: Story;
11
+ export declare const HelpText: Story;
12
12
  export declare const Invalid: Story;
13
13
  export declare const Disabled: Story;
14
14
  export declare const ReadOnly: Story;
@@ -29,18 +29,17 @@ export const Default = {
29
29
  label: 'Berries',
30
30
  },
31
31
  };
32
- export const Hint = {
32
+ export const HelpText = {
33
33
  args: {
34
34
  label: 'Berries',
35
- always: true,
36
- hint: 'We assume this is your jam preference'
35
+ 'help-text': 'We assume this is your jam preference',
37
36
  },
38
37
  };
39
38
  export const Invalid = {
40
39
  args: {
41
40
  label: 'Berries',
42
41
  invalid: true,
43
- hint: 'Wrong choice'
42
+ 'help-text': 'Wrong choice',
44
43
  },
45
44
  };
46
45
  export const Disabled = {
@@ -29,3 +29,33 @@ test('works in a form', async () => {
29
29
  berry: 'raspberries',
30
30
  });
31
31
  });
32
+ test('can reset select by resetting surrounding form', async () => {
33
+ const label = 'Test label';
34
+ render(html `
35
+ <form>
36
+ <w-select
37
+ label=${label}
38
+ name="test"
39
+ value="strawberries"
40
+ >
41
+ <option value="strawberries">Strawberries</option>
42
+ <option value="raspberries">Raspberries</option>
43
+ <option value="cloudberries">Cloudberries</option>
44
+ </w-select>
45
+ </form>
46
+ `);
47
+ const form = document.querySelector('form');
48
+ const wSelect = document.querySelector('w-select');
49
+ // sanity
50
+ expect(form).not.toBeNull();
51
+ expect(wSelect).not.toBeNull();
52
+ // Initial value is "strawberries"
53
+ expect(wSelect.value).toBe('strawberries');
54
+ // Change the value to "raspberries"
55
+ wSelect.value = 'raspberries';
56
+ expect(wSelect.value).toBe('raspberries');
57
+ // Reset the form
58
+ form.reset();
59
+ // Value should be reset back to "strawberries"
60
+ expect(wSelect.value).toBe('strawberries');
61
+ });
@@ -0,0 +1 @@
1
+ /*eslint-disable*/ export const messages = JSON.parse("{\"slider.error.overlap\":[\"Maksimumværdien må ikke være mindre end minimumværdien\"],\"slider.error.required\":[\"Dette felt er påkrævet\"],\"slider.error.out_of_bounds\":[\"Værdien skal være mellem \",[\"min\"],\" og \",[\"max\"]]}");
@@ -0,0 +1 @@
1
+ /*eslint-disable*/ export const messages = JSON.parse("{\"slider.error.overlap\":[\"The maximum value cannot be less than the minimum\"],\"slider.error.required\":[\"This field is required\"],\"slider.error.out_of_bounds\":[\"Value must be between \",[\"min\"],\" and \",[\"max\"]]}");
@@ -0,0 +1 @@
1
+ /*eslint-disable*/ export const messages = JSON.parse("{\"slider.error.overlap\":[\"Maksimiarvo ei voi olla pienempi kuin minimiarvo\"],\"slider.error.required\":[\"Tämä kenttä on pakollinen\"],\"slider.error.out_of_bounds\":[\"Arvon on oltava välillä \",[\"min\"],\" - \",[\"max\"]]}");
@@ -0,0 +1 @@
1
+ /*eslint-disable*/ export const messages = JSON.parse("{\"slider.error.overlap\":[\"Maksimumsverdien kan ikke være mindre enn minimumsverdien\"],\"slider.error.required\":[\"Dette feltet er påkrevd\"],\"slider.error.out_of_bounds\":[\"Verdien må være mellom \",[\"min\"],\" og \",[\"max\"]]}");
@@ -0,0 +1 @@
1
+ /*eslint-disable*/ export const messages = JSON.parse("{\"slider.error.overlap\":[\"Maxvärdet kan inte vara mindre än minimivärdet\"],\"slider.error.required\":[\"Detta fält är obligatoriskt\"],\"slider.error.out_of_bounds\":[\"Värdet måste vara mellan \",[\"min\"],\" och \",[\"max\"]]}");
@@ -1,6 +1,6 @@
1
1
  import { EventName } from '@lit/react';
2
- import { WarpSlider } from './slider';
3
- import { WarpSliderThumb } from './slider-thumb';
2
+ import { WarpSlider } from './slider.js';
3
+ import { WarpSliderThumb } from './slider-thumb.js';
4
4
  export declare const Slider: import("@lit/react").ReactWebComponent<WarpSlider, {}>;
5
5
  export declare const SliderThumb: import("@lit/react").ReactWebComponent<WarpSliderThumb, {
6
6
  onSliderValidity: EventName<CustomEvent>;
@@ -21,6 +21,9 @@ declare class WarpSliderThumb extends WarpSliderThumb_base {
21
21
  name: string;
22
22
  value: string;
23
23
  disabled: boolean;
24
+ invalid: boolean;
25
+ /** Set by `<w-slider>` */
26
+ allowValuesOutsideRange: boolean;
24
27
  /** Set by `<w-slider>` */
25
28
  markers: string;
26
29
  /** Set by `<w-slider>` */
@@ -33,24 +36,27 @@ declare class WarpSliderThumb extends WarpSliderThumb_base {
33
36
  max: string;
34
37
  /** Set by `<w-slider>` */
35
38
  suffix: string;
36
- /** @internal */
37
- forceDisabled: boolean;
38
- /** @internal */
39
- forceInvalid: boolean;
40
39
  /** JS hook to help you format the numeric value how you want. */
41
- formatter: (value: string) => string;
40
+ formatter: (value: string, type: 'from' | 'to') => string;
42
41
  range: HTMLInputElement;
43
42
  textfield: WarpTextField;
44
43
  /** @internal */
45
- _invalid: boolean;
46
- /** @internal */
47
44
  _showTooltip: boolean;
45
+ /** @internal */
46
+ _inputHasFocus: boolean;
47
+ resetFormControl(): void;
48
48
  /**
49
49
  * Reference to the anchor positioning style element used by the polyfill.
50
50
  * @internal
51
51
  */
52
52
  anchorPositioningStyleElement: HTMLStyleElement | null;
53
+ updateFieldAfterValidation(): Promise<void>;
53
54
  connectedCallback(): Promise<void>;
55
+ get boundaryValue(): string;
56
+ /** Value to display in the textfield (shows boundary when focused on empty value) */
57
+ get textFieldDisplayValue(): string;
58
+ /** Value to display in the tooltip */
59
+ get tooltipDisplayValue(): string | number;
54
60
  updated(changedProperties: PropertyValues<this>): void;
55
61
  render(): import("lit").TemplateResult<1>;
56
62
  }
@@ -1,4 +1,5 @@
1
- var ie=Object.defineProperty;var ne=Object.getOwnPropertyDescriptor;var H=s=>{throw TypeError(s)};var d=(s,e,o,n)=>{for(var t=n>1?void 0:n?ne(e,o):e,b=s.length-1,m;b>=0;b--)(m=s[b])&&(t=(n?m(e,o,t):m(t))||t);return n&&t&&ie(e,o,t),t};var se=(s,e,o)=>e.has(s)||H("Cannot "+o);var B=(s,e,o)=>e.has(s)?H("Cannot add the same private member more than once"):e instanceof WeakSet?e.add(s):e.set(s,o);var f=(s,e,o)=>(se(s,e,"access private method"),o);var i=function(s,e,o,n){if(o==="a"&&!n)throw new TypeError("Private accessor was defined without a getter");if(typeof e=="function"?s!==e||!n:!e.has(s))throw new TypeError("Cannot read private member from an object whose class did not declare it");return o==="m"?n:o==="a"?n.call(s):n?n.value:e.get(s)},h=function(s,e,o,n,t){if(n==="m")throw new TypeError("Private method is not writable");if(n==="a"&&!t)throw new TypeError("Private accessor was defined without a setter");if(typeof e=="function"?s!==e||!t:!e.has(s))throw new TypeError("Cannot write private member to an object whose class did not declare it");return n==="a"?t.call(s,o):t?t.value=o:e.set(s,o),o};function W(s){var e,o,n,t,b,m,x,E,k,_,z,L,j,$,I,y,S,T,Z;class ae extends s{constructor(...r){var a,c,p;super(...r),e.add(this),this.internals=this.attachInternals(),o.set(this,!1),n.set(this,!1),t.set(this,!1),b.set(this,void 0),m.set(this,void 0),x.set(this,!0),k.set(this,""),_.set(this,()=>{h(this,t,!0,"f"),h(this,o,!0,"f"),i(this,e,"m",y).call(this)}),z.set(this,()=>{h(this,o,!1,"f"),i(this,e,"m",S).call(this,this.shouldFormValueUpdate()?i(this,k,"f"):""),!this.validity.valid&&i(this,t,"f")&&h(this,n,!0,"f");let w=i(this,e,"m",y).call(this);this.validationMessageCallback&&this.validationMessageCallback(w?this.internals.validationMessage:"")}),L.set(this,()=>{var w;i(this,x,"f")&&this.validationTarget&&(this.internals.setValidity(this.validity,this.validationMessage,this.validationTarget),h(this,x,!1,"f")),h(this,t,!0,"f"),h(this,n,!0,"f"),i(this,e,"m",y).call(this),(w=this===null||this===void 0?void 0:this.validationMessageCallback)===null||w===void 0||w.call(this,this.showError?this.internals.validationMessage:"")}),j.set(this,void 0),$.set(this,!1),I.set(this,Promise.resolve()),(a=this.addEventListener)===null||a===void 0||a.call(this,"focus",i(this,_,"f")),(c=this.addEventListener)===null||c===void 0||c.call(this,"blur",i(this,z,"f")),(p=this.addEventListener)===null||p===void 0||p.call(this,"invalid",i(this,L,"f")),this.setValue(null)}static get formAssociated(){return!0}static get validators(){return this.formControlValidators||[]}static get observedAttributes(){let r=this.validators.map(p=>p.attribute).flat(),a=super.observedAttributes||[];return[...new Set([...a,...r])]}static getValidator(r){return this.validators.find(a=>a.attribute===r)||null}static getValidators(r){return this.validators.filter(a=>{var c;if(a.attribute===r||!((c=a.attribute)===null||c===void 0)&&c.includes(r))return!0})}get form(){return this.internals.form}get showError(){return i(this,e,"m",y).call(this)}checkValidity(){return this.internals.checkValidity()}get validity(){return this.internals.validity}get validationMessage(){return this.internals.validationMessage}attributeChangedCallback(r,a,c){var p;(p=super.attributeChangedCallback)===null||p===void 0||p.call(this,r,a,c);let M=this.constructor.getValidators(r);M!=null&&M.length&&this.validationTarget&&this.setValue(i(this,k,"f"))}setValue(r){var a;h(this,n,!1,"f"),(a=this.validationMessageCallback)===null||a===void 0||a.call(this,""),h(this,k,r,"f");let p=this.shouldFormValueUpdate()?r:null;this.internals.setFormValue(p),i(this,e,"m",S).call(this,p),this.valueChangedCallback&&this.valueChangedCallback(p),i(this,e,"m",y).call(this)}shouldFormValueUpdate(){return!0}get validationComplete(){return new Promise(r=>r(i(this,I,"f")))}formResetCallback(){var r,a;h(this,t,!1,"f"),h(this,n,!1,"f"),i(this,e,"m",y).call(this),(r=this.resetFormControl)===null||r===void 0||r.call(this),(a=this.validationMessageCallback)===null||a===void 0||a.call(this,i(this,e,"m",y).call(this)?this.validationMessage:"")}}return o=new WeakMap,n=new WeakMap,t=new WeakMap,b=new WeakMap,m=new WeakMap,x=new WeakMap,k=new WeakMap,_=new WeakMap,z=new WeakMap,L=new WeakMap,j=new WeakMap,$=new WeakMap,I=new WeakMap,e=new WeakSet,E=function(){let r=this.getRootNode(),a=`${this.localName}[name="${this.getAttribute("name")}"]`;return r.querySelectorAll(a)},y=function(){if(this.hasAttribute("disabled"))return!1;let r=i(this,n,"f")||i(this,t,"f")&&!this.validity.valid&&!i(this,o,"f");return r&&this.internals.states?this.internals.states.add("--show-error"):this.internals.states&&this.internals.states.delete("--show-error"),r},S=function(r){let a=this.constructor,c={},p=a.validators,w=[],M=p.some(u=>u.isValid instanceof Promise);i(this,$,"f")||(h(this,I,new Promise(u=>{h(this,j,u,"f")}),"f"),h(this,$,!0,"f")),i(this,b,"f")&&(i(this,b,"f").abort(),h(this,m,i(this,b,"f"),"f"));let Y=new AbortController;h(this,b,Y,"f");let P,G=!1;p.length&&(p.forEach(u=>{let D=u.key||"customError",C=u.isValid(this,r,Y.signal);C instanceof Promise?(w.push(C),C.then(R=>{R!=null&&(c[D]=!R,P=i(this,e,"m",Z).call(this,u,r),i(this,e,"m",T).call(this,c,P))})):(c[D]=!C,this.validity[D]!==!C&&(G=!0),!C&&!P&&(P=i(this,e,"m",Z).call(this,u,r)))}),Promise.allSettled(w).then(()=>{var u;Y!=null&&Y.signal.aborted||(h(this,$,!1,"f"),(u=i(this,j,"f"))===null||u===void 0||u.call(this))}),(G||!M)&&i(this,e,"m",T).call(this,c,P))},T=function(r,a){if(this.validationTarget)this.internals.setValidity(r,a,this.validationTarget),h(this,x,!1,"f");else{if(this.internals.setValidity(r,a),this.internals.validity.valid)return;h(this,x,!0,"f")}},Z=function(r,a){if(this.validityCallback){let c=this.validityCallback(r.key||"customError");if(c)return c}return r.message instanceof Function?r.message(this,a):r.message},ae}import{html as X,LitElement as re,nothing as U}from"lit";import{property as F,query as oe,state as v}from"lit/decorators.js";import{ifDefined as q}from"lit/directives/if-defined.js";import{css as J}from"lit";var K=J`
1
+ var Ue=Object.create;var ie=Object.defineProperty;var me=Object.getOwnPropertyDescriptor;var He=Object.getOwnPropertyNames;var Xe=Object.getPrototypeOf,qe=Object.prototype.hasOwnProperty;var ve=t=>{throw TypeError(t)};var fe=(t,e)=>()=>(e||t((e={exports:{}}).exports,e),e.exports);var Ze=(t,e,r,o)=>{if(e&&typeof e=="object"||typeof e=="function")for(let a of He(e))!qe.call(t,a)&&a!==r&&ie(t,a,{get:()=>e[a],enumerable:!(o=me(e,a))||o.enumerable});return t};var Be=(t,e,r)=>(r=t!=null?Ue(Xe(t)):{},Ze(e||!t||!t.__esModule?ie(r,"default",{value:t,enumerable:!0}):r,t));var m=(t,e,r,o)=>{for(var a=o>1?void 0:o?me(e,r):e,n=t.length-1,s;n>=0;n--)(s=t[n])&&(a=(o?s(e,r,a):s(a))||a);return o&&a&&ie(e,r,a),a};var se=(t,e,r)=>e.has(t)||ve("Cannot "+r);var we=(t,e,r)=>(se(t,e,"read from private field"),r?r.call(t):e.get(t)),ne=(t,e,r)=>e.has(t)?ve("Cannot add the same private member more than once"):e instanceof WeakSet?e.add(t):e.set(t,r),xe=(t,e,r,o)=>(se(t,e,"write to private field"),o?o.call(t,r):e.set(t,r),r),p=(t,e,r)=>(se(t,e,"access private method"),r);var Ee=fe(L=>{"use strict";Object.defineProperty(L,"__esModule",{value:!0});L.errorMessages=L.ErrorType=void 0;var A;(function(t){t.MalformedUnicode="MALFORMED_UNICODE",t.MalformedHexadecimal="MALFORMED_HEXADECIMAL",t.CodePointLimit="CODE_POINT_LIMIT",t.OctalDeprecation="OCTAL_DEPRECATION",t.EndOfString="END_OF_STRING"})(A=L.ErrorType||(L.ErrorType={}));L.errorMessages=new Map([[A.MalformedUnicode,"malformed Unicode character escape sequence"],[A.MalformedHexadecimal,"malformed hexadecimal character escape sequence"],[A.CodePointLimit,"Unicode codepoint must not be greater than 0x10FFFF in escape sequence"],[A.OctalDeprecation,'"0"-prefixed octal literals and octal escape sequences are deprecated; for octal literals use the "0o" prefix instead'],[A.EndOfString,"malformed escape sequence at end of string"]])});var Ve=fe($=>{"use strict";Object.defineProperty($,"__esModule",{value:!0});$.unraw=$.errorMessages=$.ErrorType=void 0;var _=Ee();Object.defineProperty($,"ErrorType",{enumerable:!0,get:function(){return _.ErrorType}});Object.defineProperty($,"errorMessages",{enumerable:!0,get:function(){return _.errorMessages}});function We(t){return!t.match(/[^a-f0-9]/i)?parseInt(t,16):NaN}function B(t,e,r){let o=We(t);if(Number.isNaN(o)||r!==void 0&&r!==t.length)throw new SyntaxError(_.errorMessages.get(e));return o}function Je(t){let e=B(t,_.ErrorType.MalformedHexadecimal,2);return String.fromCharCode(e)}function Me(t,e){let r=B(t,_.ErrorType.MalformedUnicode,4);if(e!==void 0){let o=B(e,_.ErrorType.MalformedUnicode,4);return String.fromCharCode(r,o)}return String.fromCharCode(r)}function Qe(t){return t.charAt(0)==="{"&&t.charAt(t.length-1)==="}"}function er(t){if(!Qe(t))throw new SyntaxError(_.errorMessages.get(_.ErrorType.MalformedUnicode));let e=t.slice(1,-1),r=B(e,_.ErrorType.MalformedUnicode);try{return String.fromCodePoint(r)}catch(o){throw o instanceof RangeError?new SyntaxError(_.errorMessages.get(_.ErrorType.CodePointLimit)):o}}function rr(t,e=!1){if(e)throw new SyntaxError(_.errorMessages.get(_.ErrorType.OctalDeprecation));let r=parseInt(t,8);return String.fromCharCode(r)}var tr=new Map([["b","\b"],["f","\f"],["n",`
2
+ `],["r","\r"],["t"," "],["v","\v"],["0","\0"]]);function or(t){return tr.get(t)||t}var ar=/\\(?:(\\)|x([\s\S]{0,2})|u(\{[^}]*\}?)|u([\s\S]{4})\\u([^{][\s\S]{0,3})|u([\s\S]{0,4})|([0-3]?[0-7]{1,2})|([\s\S])|$)/g;function Fe(t,e=!1){return t.replace(ar,function(r,o,a,n,s,i,d,g,k){if(o!==void 0)return"\\";if(a!==void 0)return Je(a);if(n!==void 0)return er(n);if(s!==void 0)return Me(s,i);if(d!==void 0)return Me(d);if(g==="0")return"\0";if(g!==void 0)return rr(g,!e);if(k!==void 0)return or(k);throw new SyntaxError(_.errorMessages.get(_.ErrorType.EndOfString))})}$.unraw=Fe;$.default=Fe});var u=function(t,e,r,o){if(r==="a"&&!o)throw new TypeError("Private accessor was defined without a getter");if(typeof e=="function"?t!==e||!o:!e.has(t))throw new TypeError("Cannot read private member from an object whose class did not declare it");return r==="m"?o:r==="a"?o.call(t):o?o.value:e.get(t)},w=function(t,e,r,o,a){if(o==="m")throw new TypeError("Private method is not writable");if(o==="a"&&!a)throw new TypeError("Private accessor was defined without a setter");if(typeof e=="function"?t!==e||!a:!e.has(t))throw new TypeError("Cannot write private member to an object whose class did not declare it");return o==="a"?a.call(t,r):a?a.value=r:e.set(t,r),r};function ke(t){var e,r,o,a,n,s,i,d,g,k,z,F,y,E,M,v,T,Y,te;class Ye extends t{constructor(...l){var h,f,x;super(...l),e.add(this),this.internals=this.attachInternals(),r.set(this,!1),o.set(this,!1),a.set(this,!1),n.set(this,void 0),s.set(this,void 0),i.set(this,!0),g.set(this,""),k.set(this,()=>{w(this,a,!0,"f"),w(this,r,!0,"f"),u(this,e,"m",v).call(this)}),z.set(this,()=>{w(this,r,!1,"f"),u(this,e,"m",T).call(this,this.shouldFormValueUpdate()?u(this,g,"f"):""),!this.validity.valid&&u(this,a,"f")&&w(this,o,!0,"f");let V=u(this,e,"m",v).call(this);this.validationMessageCallback&&this.validationMessageCallback(V?this.internals.validationMessage:"")}),F.set(this,()=>{var V;u(this,i,"f")&&this.validationTarget&&(this.internals.setValidity(this.validity,this.validationMessage,this.validationTarget),w(this,i,!1,"f")),w(this,a,!0,"f"),w(this,o,!0,"f"),u(this,e,"m",v).call(this),(V=this===null||this===void 0?void 0:this.validationMessageCallback)===null||V===void 0||V.call(this,this.showError?this.internals.validationMessage:"")}),y.set(this,void 0),E.set(this,!1),M.set(this,Promise.resolve()),(h=this.addEventListener)===null||h===void 0||h.call(this,"focus",u(this,k,"f")),(f=this.addEventListener)===null||f===void 0||f.call(this,"blur",u(this,z,"f")),(x=this.addEventListener)===null||x===void 0||x.call(this,"invalid",u(this,F,"f")),this.setValue(null)}static get formAssociated(){return!0}static get validators(){return this.formControlValidators||[]}static get observedAttributes(){let l=this.validators.map(x=>x.attribute).flat(),h=super.observedAttributes||[];return[...new Set([...h,...l])]}static getValidator(l){return this.validators.find(h=>h.attribute===l)||null}static getValidators(l){return this.validators.filter(h=>{var f;if(h.attribute===l||!((f=h.attribute)===null||f===void 0)&&f.includes(l))return!0})}get form(){return this.internals.form}get showError(){return u(this,e,"m",v).call(this)}checkValidity(){return this.internals.checkValidity()}get validity(){return this.internals.validity}get validationMessage(){return this.internals.validationMessage}attributeChangedCallback(l,h,f){var x;(x=super.attributeChangedCallback)===null||x===void 0||x.call(this,l,h,f);let H=this.constructor.getValidators(l);H!=null&&H.length&&this.validationTarget&&this.setValue(u(this,g,"f"))}setValue(l){var h;w(this,o,!1,"f"),(h=this.validationMessageCallback)===null||h===void 0||h.call(this,""),w(this,g,l,"f");let x=this.shouldFormValueUpdate()?l:null;this.internals.setFormValue(x),u(this,e,"m",T).call(this,x),this.valueChangedCallback&&this.valueChangedCallback(x),u(this,e,"m",v).call(this)}shouldFormValueUpdate(){return!0}get validationComplete(){return new Promise(l=>l(u(this,M,"f")))}formResetCallback(){var l,h;w(this,a,!1,"f"),w(this,o,!1,"f"),u(this,e,"m",v).call(this),(l=this.resetFormControl)===null||l===void 0||l.call(this),(h=this.validationMessageCallback)===null||h===void 0||h.call(this,u(this,e,"m",v).call(this)?this.validationMessage:"")}}return r=new WeakMap,o=new WeakMap,a=new WeakMap,n=new WeakMap,s=new WeakMap,i=new WeakMap,g=new WeakMap,k=new WeakMap,z=new WeakMap,F=new WeakMap,y=new WeakMap,E=new WeakMap,M=new WeakMap,e=new WeakSet,d=function(){let l=this.getRootNode(),h=`${this.localName}[name="${this.getAttribute("name")}"]`;return l.querySelectorAll(h)},v=function(){if(this.hasAttribute("disabled"))return!1;let l=u(this,o,"f")||u(this,a,"f")&&!this.validity.valid&&!u(this,r,"f");return l&&this.internals.states?this.internals.states.add("--show-error"):this.internals.states&&this.internals.states.delete("--show-error"),l},T=function(l){let h=this.constructor,f={},x=h.validators,V=[],H=x.some(C=>C.isValid instanceof Promise);u(this,E,"f")||(w(this,M,new Promise(C=>{w(this,y,C,"f")}),"f"),w(this,E,!0,"f")),u(this,n,"f")&&(u(this,n,"f").abort(),w(this,s,u(this,n,"f"),"f"));let X=new AbortController;w(this,n,X,"f");let q,ge=!1;x.length&&(x.forEach(C=>{let oe=C.key||"customError",R=C.isValid(this,l,X.signal);R instanceof Promise?(V.push(R),R.then(ae=>{ae!=null&&(f[oe]=!ae,q=u(this,e,"m",te).call(this,C,l),u(this,e,"m",Y).call(this,f,q))})):(f[oe]=!R,this.validity[oe]!==!R&&(ge=!0),!R&&!q&&(q=u(this,e,"m",te).call(this,C,l)))}),Promise.allSettled(V).then(()=>{var C;X!=null&&X.signal.aborted||(w(this,E,!1,"f"),(C=u(this,y,"f"))===null||C===void 0||C.call(this))}),(ge||!H)&&u(this,e,"m",Y).call(this,f,q))},Y=function(l,h){if(this.validationTarget)this.internals.setValidity(l,h,this.validationTarget),w(this,i,!1,"f");else{if(this.internals.setValidity(l,h),this.internals.validity.valid)return;w(this,i,!0,"f")}},te=function(l,h){if(this.validityCallback){let f=this.validityCallback(l.key||"customError");if(f)return f}return l.message instanceof Function?l.message(this,h):l.message},Ye}import{html as I,LitElement as Le,nothing as O}from"lit";import{property as P,query as De,state as S}from"lit/decorators.js";import{ifDefined as J}from"lit/directives/if-defined.js";import{css as ye}from"lit";var _e=ye`
2
3
  *,
3
4
  :before,
4
5
  :after {
@@ -271,7 +272,7 @@ var ie=Object.defineProperty;var ne=Object.getOwnPropertyDescriptor;var H=s=>{th
271
272
  svg {
272
273
  pointer-events: none;
273
274
  }
274
- `,ge=J`*, :before, :after {
275
+ `,xr=ye`*, :before, :after {
275
276
  --w-rotate: 0;
276
277
  --w-rotate-x: 0;
277
278
  --w-rotate-y: 0;
@@ -2437,15 +2438,15 @@ var ie=Object.defineProperty;var ne=Object.getOwnPropertyDescriptor;var H=s=>{th
2437
2438
  display: none
2438
2439
  }
2439
2440
  }
2440
- `;import{css as le}from"lit";var Q=le`
2441
+ `;import{css as Ge}from"lit";var Ce=Ge`
2441
2442
  .w-slider-thumb {
2442
2443
  position: relative;
2443
2444
  display: grid;
2444
2445
  pointer-events: none; /* For range inputs we position two of these on top of each other. Let clicks go through the top one. */
2445
2446
  grid-template-areas:
2446
- 'slider slider slider'
2447
- 'frommarker . tomarker'
2448
- 'fromtextfield . totextfield';
2447
+ "slider slider slider"
2448
+ "frommarker . tomarker"
2449
+ "fromtextfield . totextfield";
2449
2450
  grid-template-columns: 1fr 24px 1fr;
2450
2451
  }
2451
2452
 
@@ -2476,7 +2477,11 @@ var ie=Object.defineProperty;var ne=Object.getOwnPropertyDescriptor;var H=s=>{th
2476
2477
  background: var(--w-s-color-background-primary);
2477
2478
  border-radius: 50%;
2478
2479
  height: var(--w-slider-thumb-size);
2479
- margin-top: calc(-1 * calc(var(--w-slider-thumb-offset) - calc(var(--w-slider-track-height) / 2)));
2480
+ margin-top: calc(
2481
+ -1 * calc(var(--w-slider-thumb-offset) - calc(
2482
+ var(--w-slider-track-height) / 2
2483
+ ))
2484
+ );
2480
2485
  pointer-events: initial;
2481
2486
  width: var(--w-slider-thumb-size);
2482
2487
  z-index: 1;
@@ -2491,7 +2496,11 @@ var ie=Object.defineProperty;var ne=Object.getOwnPropertyDescriptor;var H=s=>{th
2491
2496
  border-radius: 50%;
2492
2497
  border-color: transparent;
2493
2498
  height: var(--w-slider-thumb-size);
2494
- margin-top: calc(-1 * calc(var(--w-slider-thumb-offset) - calc(var(--w-slider-track-height) / 2)));
2499
+ margin-top: calc(
2500
+ -1 * calc(var(--w-slider-thumb-offset) - calc(
2501
+ var(--w-slider-track-height) / 2
2502
+ ))
2503
+ );
2495
2504
  pointer-events: initial;
2496
2505
  width: var(--w-slider-thumb-size);
2497
2506
  z-index: 1;
@@ -2561,47 +2570,55 @@ var ie=Object.defineProperty;var ne=Object.getOwnPropertyDescriptor;var H=s=>{th
2561
2570
  }
2562
2571
 
2563
2572
  .w-slider-thumb__textfield {
2564
- margin-top: 10px;
2573
+ margin-top: 12px;
2565
2574
  pointer-events: auto;
2566
2575
  grid-row: 3 / 4;
2567
2576
  grid-column: 1 / 3; /* Single sliders should have the text field use the fromtextfield _and_ gap portion of the CSS grid. */
2568
2577
  }
2569
2578
 
2570
- :host([name='from']) .w-slider-thumb__textfield {
2579
+ :host([name="from"]) .w-slider-thumb__textfield {
2571
2580
  grid-column: 1 / 2; /* Range sliders should leave the gap empty. */
2572
2581
  }
2573
2582
 
2574
- :host([name='from']) .w-slider-thumb__range {
2583
+ :host([name="from"]) .w-slider-thumb__range {
2575
2584
  margin-left: var(--w-slider-thumb-size);
2576
2585
  }
2577
2586
 
2578
- :host([name='to']) .w-slider-thumb__range {
2587
+ :host([name="to"]) .w-slider-thumb__range {
2579
2588
  margin-right: var(--w-slider-thumb-size);
2580
2589
  }
2581
2590
 
2582
- :host([name='from']) .w-slider-thumb__range::-webkit-slider-thumb,
2583
- :host([name='from']) .w-slider-thumb__tooltip-target {
2591
+ :host([name="from"]) .w-slider-thumb__range::-webkit-slider-thumb,
2592
+ :host([name="from"]) .w-slider-thumb__tooltip-target {
2584
2593
  transform: translateX(calc(-1 * var(--w-slider-thumb-size) - 1px));
2585
2594
  }
2586
2595
 
2587
- :host([name='from']) .w-slider-thumb__range::-moz-range-thumb {
2596
+ :host([name="from"]) .w-slider-thumb__range::-moz-range-thumb {
2588
2597
  transform: translateX(calc(-1 * var(--w-slider-thumb-size) - 1px));
2589
2598
  }
2590
2599
 
2591
- :host([name='to']) .w-slider-thumb__textfield {
2600
+ :host([name="to"]) .w-slider-thumb__textfield {
2592
2601
  grid-row: 3 / 4;
2593
2602
  grid-column: 3 / 4;
2594
2603
  }
2595
2604
 
2596
- :host([name='to']) .w-slider-thumb__tooltip-target,
2597
- :host([name='to']) .w-slider-thumb__range::-webkit-slider-thumb {
2605
+ :host([name="to"]) .w-slider-thumb__tooltip-target,
2606
+ :host([name="to"]) .w-slider-thumb__range::-webkit-slider-thumb {
2598
2607
  transform: translateX(calc(var(--w-slider-thumb-size) - 1px));
2599
2608
  }
2600
2609
 
2601
- :host([name='to']) .w-slider-thumb__range::-moz-range-thumb {
2610
+ :host([name="to"]) .w-slider-thumb__range::-moz-range-thumb {
2602
2611
  transform: translateX(calc(var(--w-slider-thumb-size) - 1px));
2603
2612
  }
2604
- `;import{css as de}from"lit";var ee=de`*,:before,:after{--w-rotate:0;--w-rotate-x:0;--w-rotate-y:0;--w-rotate-z:0;--w-scale-x:1;--w-scale-y:1;--w-scale-z:1;--w-skew-x:0;--w-skew-y:0;--w-translate-x:0;--w-translate-y:0;--w-translate-z:0}.hidden{display:none}.absolute{position:absolute}.relative{position:relative}.static{position:static}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}`;var te={};var g,N,A,O,l=class extends W(re){constructor(){super(...arguments);B(this,g);this._invalid=!1;this._showTooltip=!1;this.anchorPositioningStyleElement=null}async connectedCallback(){var o;if(super.connectedCallback(),"anchorName"in document.documentElement.style)await this.updateComplete;else{let n=te.url.substring(0,te.url.lastIndexOf("/"));try{let[{default:t}]=await Promise.all([import(`${n}/oddbird-css-anchor-positioning.js`),this.updateComplete]);this.anchorPositioningStyleElement||(this.anchorPositioningStyleElement=document.createElement("style"),this.shadowRoot.prepend(this.anchorPositioningStyleElement)),this.anchorPositioningStyleElement.textContent=`
2613
+ `;import{css as Ke}from"lit";var ze=Ke`*,:before,:after{--w-rotate:0;--w-rotate-x:0;--w-rotate-y:0;--w-rotate-z:0;--w-scale-x:1;--w-scale-y:1;--w-scale-z:1;--w-skew-x:0;--w-skew-y:0;--w-translate-x:0;--w-translate-y:0;--w-translate-z:0}.hidden{display:none}.absolute{position:absolute}.relative{position:relative}.static{position:static}.sr-only{clip:rect(0,0,0,0);white-space:nowrap;border-width:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}`;var Se=Be(Ve(),1);var N=t=>typeof t=="string",ir=t=>typeof t=="function",$e=new Map,Ne="en";function he(t){return[...Array.isArray(t)?t:[t],Ne]}function ue(t,e,r){let o=he(t);r||(r="default");let a;if(typeof r=="string")switch(a={day:"numeric",month:"short",year:"numeric"},r){case"full":a.weekday="long";case"long":a.month="long";break;case"short":a.month="numeric";break}else a=r;return G(()=>K("date",o,r),()=>new Intl.DateTimeFormat(o,a)).format(N(e)?new Date(e):e)}function sr(t,e,r){let o;if(r||(r="default"),typeof r=="string")switch(o={second:"numeric",minute:"numeric",hour:"numeric"},r){case"full":case"long":o.timeZoneName="short";break;case"short":delete o.second}else o=r;return ue(t,e,o)}function le(t,e,r){let o=he(t);return G(()=>K("number",o,r),()=>new Intl.NumberFormat(o,r)).format(e)}function Oe(t,e,r,{offset:o=0,...a}){var i,d;let n=he(t),s=e?G(()=>K("plural-ordinal",n),()=>new Intl.PluralRules(n,{type:"ordinal"})):G(()=>K("plural-cardinal",n),()=>new Intl.PluralRules(n,{type:"cardinal"}));return(d=(i=a[r])!=null?i:a[s.select(r-o)])!=null?d:a.other}function G(t,e){let r=t(),o=$e.get(r);return o||(o=e(),$e.set(r,o)),o}function K(t,e,r){let o=e.join("-");return`${t}-${o}-${JSON.stringify(r)}`}var Pe=/\\u[a-fA-F0-9]{4}|\\x[a-fA-F0-9]{2}/,Te="%__lingui_octothorpe__%",nr=(t,e,r={})=>{let o=e||t,a=s=>typeof s=="object"?s:r[s],n=(s,i)=>{let d=Object.keys(r).length?a("number"):void 0,g=le(o,s,d);return i.replace(new RegExp(Te,"g"),g)};return{plural:(s,i)=>{let{offset:d=0}=i,g=Oe(o,!1,s,i);return n(s-d,g)},selectordinal:(s,i)=>{let{offset:d=0}=i,g=Oe(o,!0,s,i);return n(s-d,g)},select:lr,number:(s,i)=>le(o,s,a(i)||{style:i}),date:(s,i)=>ue(o,s,a(i)||i),time:(s,i)=>sr(o,s,a(i)||i)}},lr=(t,e)=>{var r;return(r=e[t])!=null?r:e.other};function dr(t,e,r){return(o={},a)=>{let n=nr(e,r,a),s=(d,g=!1)=>Array.isArray(d)?d.reduce((k,z)=>{if(z==="#"&&g)return k+Te;if(N(z))return k+z;let[F,y,E]=z,M={};y==="plural"||y==="selectordinal"||y==="select"?Object.entries(E).forEach(([T,Y])=>{M[T]=s(Y,y==="plural"||y==="selectordinal")}):M=E;let v;if(y){let T=n[y];v=T(o[F],M)}else v=o[F];return v==null?k:k+v},""):d,i=s(t);return N(i)&&Pe.test(i)?(0,Se.unraw)(i):N(i)?i:i?String(i):""}}var cr=Object.defineProperty,hr=(t,e,r)=>e in t?cr(t,e,{enumerable:!0,configurable:!0,writable:!0,value:r}):t[e]=r,ur=(t,e,r)=>(hr(t,typeof e!="symbol"?e+"":e,r),r),de=class{constructor(){ur(this,"_events",{})}on(e,r){var a;var o;return(a=(o=this._events)[e])!=null||(o[e]=[]),this._events[e].push(r),()=>this.removeListener(e,r)}removeListener(e,r){let o=this._getListeners(e);if(!o)return;let a=o.indexOf(r);~a&&o.splice(a,1)}emit(e,...r){let o=this._getListeners(e);o&&o.map(a=>a.apply(this,r))}_getListeners(e){let r=this._events[e];return Array.isArray(r)?r:!1}},br=Object.defineProperty,pr=(t,e,r)=>e in t?br(t,e,{enumerable:!0,configurable:!0,writable:!0,value:r}):t[e]=r,D=(t,e,r)=>(pr(t,typeof e!="symbol"?e+"":e,r),r),ce=class extends de{constructor(e){var r;super(),D(this,"_locale",""),D(this,"_locales"),D(this,"_localeData",{}),D(this,"_messages",{}),D(this,"_missing"),D(this,"_messageCompiler"),D(this,"t",this._.bind(this)),e.missing!=null&&(this._missing=e.missing),e.messages!=null&&this.load(e.messages),e.localeData!=null&&this.loadLocaleData(e.localeData),(typeof e.locale=="string"||e.locales)&&this.activate((r=e.locale)!=null?r:Ne,e.locales)}get locale(){return this._locale}get locales(){return this._locales}get messages(){var e;return(e=this._messages[this._locale])!=null?e:{}}get localeData(){var e;return(e=this._localeData[this._locale])!=null?e:{}}_loadLocaleData(e,r){let o=this._localeData[e];o?Object.assign(o,r):this._localeData[e]=r}setMessagesCompiler(e){return this._messageCompiler=e,this}loadLocaleData(e,r){typeof e=="string"?this._loadLocaleData(e,r):Object.keys(e).forEach(o=>this._loadLocaleData(o,e[o])),this.emit("change")}_load(e,r){let o=this._messages[e];o?Object.assign(o,r):this._messages[e]=r}load(e,r){typeof e=="string"&&typeof r=="object"?this._load(e,r):Object.entries(e).forEach(([o,a])=>this._load(o,a)),this.emit("change")}loadAndActivate({locale:e,locales:r,messages:o}){this._locale=e,this._locales=r||void 0,this._messages[this._locale]=o,this.emit("change")}activate(e,r){this._locale=e,this._locales=r,this.emit("change")}_(e,r,o){if(!this.locale)throw new Error("Lingui: Attempted to call a translation function without setting a locale.\nMake sure to call `i18n.activate(locale)` before using Lingui functions.\nThis issue may also occur due to a race condition in your initialization logic.");let a=o==null?void 0:o.message;e||(e=""),N(e)||(r=e.values||r,a=e.message,e=e.id);let n=this.messages[e],s=n===void 0,i=this._missing;if(i&&s)return ir(i)?i(this._locale,e):i;s&&this.emit("missing",{id:e,locale:this._locale});let d=n||a||e;return N(d)&&(this._messageCompiler?d=this._messageCompiler(d):console.warn(`Uncompiled message detected! Message:
2614
+
2615
+ > ${d}
2616
+
2617
+ That means you use raw catalog or your catalog doesn't have a translation for the message and fallback was used.
2618
+ ICU features such as interpolation and plurals will not work properly for that message.
2619
+
2620
+ Please compile your catalog first.
2621
+ `)),N(d)&&Pe.test(d)?JSON.parse(`"${d}"`):N(d)?d:dr(d,this._locale,this._locales)(r,o==null?void 0:o.formats)}date(e,r){return ue(this._locales||this._locale,e,r)}number(e,r){return le(this._locales||this._locale,e,r)}};function gr(t={}){return new ce(t)}var W=gr();var Re={};var Z,c,Q,ee,be,j,re,pe,Ae,Ie,je,b=class extends ke(Le){constructor(){super(...arguments);ne(this,c);this.invalid=!1;this.allowValuesOutsideRange=!1;this.suffix="";this._showTooltip=!1;this._inputHasFocus=!1;ne(this,Z,null);this.anchorPositioningStyleElement=null}resetFormControl(){this.value=we(this,Z)}async updateFieldAfterValidation(){let r=this.shadowRoot.querySelector("w-textfield");await p(this,c,re).call(this,r.value,!0)}async connectedCallback(){if(super.connectedCallback(),xe(this,Z,this.value),this.setValue(this.value),"anchorName"in document.documentElement.style)await this.updateComplete;else{let r=Re.url.substring(0,Re.url.lastIndexOf("/"));try{let[{default:o}]=await Promise.all([import(`${r}/oddbird-css-anchor-positioning.js`),this.updateComplete]);this.anchorPositioningStyleElement||(this.anchorPositioningStyleElement=document.createElement("style"),this.shadowRoot.prepend(this.anchorPositioningStyleElement)),this.anchorPositioningStyleElement.textContent=`
2605
2622
  /*
2606
2623
  * The polyfill can only anchor to ::before and ::after pseudo elements, not the pseudo element slider thumb.
2607
2624
  * We work around that by recreating a transparent version of the active range
@@ -2650,56 +2667,82 @@ var ie=Object.defineProperty;var ne=Object.getOwnPropertyDescriptor;var H=s=>{th
2650
2667
  left: anchor(--polyfilled-thumb left);
2651
2668
  margin-left: 38px;
2652
2669
  }
2653
- `,await t({roots:[this.shadowRoot],elements:[this.anchorPositioningStyleElement]})}catch(t){console.error(new Error("Error registering the CSS anchor positioning polyfill. The UI will look broken.",{cause:t}))}}this.range.value=(o=this.value)!=null?o:this.max}updated(o){o.has("value")&&this.setValue(this.value),o.has("_invalid")&&this.dispatchEvent(new CustomEvent("slidervalidity",{bubbles:!0,detail:{invalid:this._invalid}}))}render(){return X`
2670
+ `,await o({roots:[this.shadowRoot],elements:[this.anchorPositioningStyleElement]})}catch(o){console.error(new Error("Error registering the CSS anchor positioning polyfill. The UI will look broken.",{cause:o}))}}p(this,c,be).call(this)}get boundaryValue(){return this.slot==="from"?this.min:this.max}get textFieldDisplayValue(){var r;return this._inputHasFocus?this.value!==""?this.value:(r=this.range)!=null&&r.value?Math.min(Math.max(Number(this.range.value),Number(this.min)+1),Number(this.max)-1).toString():"":this.value}get tooltipDisplayValue(){var r,o;return this.formatter?this.formatter(this.value,this.slot):this.value===""?(o=(r=this.range)==null?void 0:r.value)!=null?o:this.boundaryValue:this.value||0}updated(r){r.has("value")&&(this.setValue(this.value),p(this,c,be).call(this))}render(){return I`
2654
2671
  <div class="w-slider-thumb">
2655
2672
  <label for="range">${this.label}</label>
2656
- ${"anchorName"in document.documentElement.style?U:X`<div class="polyfill-range"><div class="polyfill-active-range"></div></div>`}
2673
+ ${"anchorName"in document.documentElement.style?O:I`<div class="polyfill-range">
2674
+ <div class="polyfill-active-range"></div>
2675
+ </div>`}
2657
2676
  <input
2658
2677
  id="range"
2659
2678
  aria-label="${this.ariaLabel}"
2660
- aria-describedby="${q(this.ariaDescription?"aria-description":void 0)}"
2679
+ aria-describedby="${J(this.ariaDescription?"aria-description":void 0)}"
2661
2680
  class="w-slider-thumb__range"
2662
2681
  type="range"
2663
2682
  .value="${this.value}"
2683
+ aria-valuetext="${this.tooltipDisplayValue}"
2664
2684
  min="${this.min}"
2665
2685
  max="${this.max}"
2666
- name="${this.name}"
2667
- step="${q(this.step?this.step:void 0)}"
2668
- ?disabled="${this.disabled||this.forceDisabled}"
2669
- @mousedown="${f(this,g,N)}"
2670
- @mouseup="${f(this,g,A)}"
2671
- @touchstart="${f(this,g,N)}"
2672
- @touchend="${f(this,g,A)}"
2673
- @focus="${f(this,g,N)}"
2674
- @blur="${f(this,g,A)}"
2675
- @input="${f(this,g,O)}" />
2676
-
2677
- <span class="w-slider-thumb__from-marker">${this.formatter?this.formatter(this.min):this.min} ${this.suffix}</span>
2678
- <span class="w-slider-thumb__to-marker">${this.formatter?this.formatter(this.max):this.max} ${this.suffix}</span>
2686
+ step="${J(!this.allowValuesOutsideRange&&this.step?this.step:void 0)}"
2687
+ ?disabled="${this.disabled}"
2688
+ @mousedown="${p(this,c,Q)}"
2689
+ @mouseup="${p(this,c,ee)}"
2690
+ @touchstart="${p(this,c,Q)}"
2691
+ @touchend="${p(this,c,ee)}"
2692
+ @focus="${p(this,c,Q)}"
2693
+ @blur="${p(this,c,ee)}"
2694
+ @input="${p(this,c,pe)}"
2695
+ @keydown="${this.allowValuesOutsideRange?p(this,c,Ae):O}"
2696
+ />
2697
+
2698
+ ${this.slot==="from"?I`<span class="w-slider-thumb__from-marker"
2699
+ >${this.formatter?this.formatter(this.allowValuesOutsideRange?"":this.min,"from"):this.min}
2700
+ ${this.suffix}</span
2701
+ >`:O}
2702
+ ${this.slot==="to"?I`<span class="w-slider-thumb__to-marker"
2703
+ >${this.formatter?this.formatter(this.allowValuesOutsideRange?"":this.max,"to"):this.max}
2704
+ ${this.suffix}</span
2705
+ >`:O}
2679
2706
 
2680
2707
  <w-textfield
2681
2708
  aria-label="${this.ariaLabel}"
2682
- aria-description="${q(this.ariaDescription)}"
2709
+ aria-description="${J(this.ariaDescription)}"
2683
2710
  class="w-slider-thumb__textfield"
2684
2711
  type="number"
2685
- min="${this.min}"
2686
- max="${this.max}"
2687
- .formatter=${this.formatter}
2688
- .value="${this.value}"
2689
- ?invalid="${this.forceInvalid||this._invalid}"
2690
- @input="${f(this,g,O)}">
2691
- ${this.suffix?X`<w-affix slot="suffix" label="${this.suffix}"></w-affix>`:U}
2712
+ .formatter=${this.formatter?r=>this.formatter(r,this.slot):O}
2713
+ .value="${this.textFieldDisplayValue}"
2714
+ min="${this.allowValuesOutsideRange?O:this.min}"
2715
+ max="${this.allowValuesOutsideRange?O:this.max}"
2716
+ step="${J(this.step)}"
2717
+ ?invalid="${!!this.invalid}"
2718
+ @input="${p(this,c,pe)}"
2719
+ @focus="${p(this,c,Ie)}"
2720
+ @blur="${p(this,c,je)}"
2721
+ >
2722
+ ${this.suffix?I`<w-affix slot="suffix" label="${this.suffix}"></w-affix>`:O}
2692
2723
  </w-textfield>
2693
2724
 
2694
- <w-attention tooltip placement="top" flip distance="24" .show="${this._showTooltip}">
2695
- <output id="target" class="w-slider-thumb__tooltip-target" slot="target"></output>
2725
+ <w-attention
2726
+ tooltip
2727
+ placement="top"
2728
+ flip
2729
+ distance="24"
2730
+ .show="${this._showTooltip}"
2731
+ >
2732
+ <output
2733
+ id="target"
2734
+ class="w-slider-thumb__tooltip-target"
2735
+ slot="target"
2736
+ ></output>
2696
2737
  <span slot="message">
2697
- ${this.value?this.formatter?this.formatter(this.value):this.value:0}${this.suffix?X`&nbsp;${this.suffix}`:U}
2738
+ ${this.tooltipDisplayValue}${this.suffix?I`&nbsp;${this.suffix}`:O}
2698
2739
  </span>
2699
2740
  </w-attention>
2700
2741
 
2701
2742
  <!-- aria-description is still not recommended for general use, so make a visually hidden element and refer to it with aria-describedby -->
2702
- <span class="sr-only" id="aria-description">${this.ariaDescription}</span>
2743
+ <span class="sr-only" id="aria-description"
2744
+ >${this.ariaDescription}</span
2745
+ >
2703
2746
  </div>
2704
- `}};g=new WeakSet,N=function(){this._showTooltip=!0,this.shadowRoot.querySelector("w-attention").handleDone()},A=function(){this._showTooltip=!1},O=function(o){let n=o.currentTarget.tagName==="W-TEXTFIELD";if(o instanceof CustomEvent)return;let t=o.currentTarget.value;if(t==="")return this.required&&(this._invalid=!0),!1;this._invalid&&(this._invalid=!1);let b=Number.parseInt(t),m=Number.parseInt(this.max),x=Number.parseInt(this.min);(b>m||b<x)&&(this._invalid=!0);let E=!1;if(this.slot){let k=getComputedStyle(this),_=k.getPropertyValue("--to"),z=k.getPropertyValue("--from");if(n&&(b>Number.parseInt(_)||b<Number.parseInt(z)))return this._invalid=!0,!1;this.slot==="from"?b>Number.parseInt(_)&&(E=!0,this.value=_):b<Number.parseInt(z)&&(E=!0,this.value=z)}return E?(o.preventDefault(),this.range.value=this.value,!1):(this.value=t,this.shadowRoot.querySelector("w-attention").handleDone(),!0)},l.shadowRootOptions={...re.shadowRootOptions,delegatesFocus:!0},l.styles=[K,ee,Q],d([F({attribute:"aria-label",reflect:!0})],l.prototype,"ariaLabel",2),d([F({attribute:"aria-description",reflect:!0})],l.prototype,"ariaDescription",2),d([F({reflect:!0})],l.prototype,"label",2),d([F({reflect:!0})],l.prototype,"name",2),d([F({reflect:!0})],l.prototype,"value",2),d([F({type:Boolean,reflect:!0})],l.prototype,"disabled",2),d([v()],l.prototype,"markers",2),d([v()],l.prototype,"required",2),d([v()],l.prototype,"step",2),d([v()],l.prototype,"min",2),d([v()],l.prototype,"max",2),d([v()],l.prototype,"suffix",2),d([v()],l.prototype,"forceDisabled",2),d([v()],l.prototype,"forceInvalid",2),d([v()],l.prototype,"formatter",2),d([oe('input[type="range"]')],l.prototype,"range",2),d([oe("w-textfield")],l.prototype,"textfield",2),d([v()],l.prototype,"_invalid",2),d([v()],l.prototype,"_showTooltip",2);customElements.get("w-slider-thumb")||customElements.define("w-slider-thumb",l);export{l as WarpSliderThumb};
2747
+ `}};Z=new WeakMap,c=new WeakSet,Q=function(){this._showTooltip=!0,this.shadowRoot.querySelector("w-attention").handleDone()},ee=function(){this._showTooltip=!1},be=function(){this.range&&(this.value===""?this.range.value=this.boundaryValue:this.value&&(this.range.value=this.value))},j=function(r){this.dispatchEvent(new CustomEvent("slidervalidity",{bubbles:!0,detail:{invalid:r,slot:this.slot}}))},re=async function(r,o){let a=Number.parseInt(r);if(this.allowValuesOutsideRange&&!o&&this.step&&!(this.slot==="to"&&a>=Number(this.max)-1||this.slot==="from"&&a<=Number(this.min)+1)){let k=1/this.step;a=Math.round(a*k)/k,r=a.toString()}let n=Number.parseInt(this.max),s=Number.parseInt(this.min);if(!this.allowValuesOutsideRange&&(a>n||a<s))return p(this,c,j).call(this,W.t({id:"slider.error.out_of_bounds",message:"Value must be between {min} and {max}",values:{min:`${this.min} ${this.suffix}`.trim(),max:`${this.max} ${this.suffix}`.trim()}})),{shouldCancel:!0};if(r==="")return this.required&&p(this,c,j).call(this,W.t({id:"slider.error.required",message:"This field is required"})),{shouldCancel:!0};this.value=r;let i=r===this.max||r===this.min,d=!1;if(this.slot){let g=this.parentElement.querySelector('w-slider-thumb[slot="to"]'),k=this.parentElement.querySelector('w-slider-thumb[slot="from"]'),z=g.textfield.value||this.max,F=k.textfield.value||this.min,y=Number.parseInt(z),E=Number.parseInt(F),M=W.t({id:"slider.error.overlap",message:"The maximum value cannot be less than the minimum"});if(this.slot==="from"){let v=this.allowValuesOutsideRange&&y>n?y:Math.min(y,this.allowValuesOutsideRange?n-1:n);a>v&&(d=!0,this.allowValuesOutsideRange&&i?this.value=String(v):this.value=z,o&&(p(this,c,j).call(this,M),await this.updateComplete,this.textfield.value=r))}else{let v=this.allowValuesOutsideRange&&E<s?E:Math.max(Number.parseInt(F),this.allowValuesOutsideRange?s+1:s);a<v&&(d=!0,this.allowValuesOutsideRange&&i?this.value=String(v):this.value=F,o&&(p(this,c,j).call(this,M),await this.updateComplete,this.textfield.value=r))}}return d?{shouldCancel:!0}:(p(this,c,j).call(this,""),this.range.value=Math.min(Math.max(Number(r),Number(this.min)),Number(this.max)).toString(),this.value=this.allowValuesOutsideRange&&!o&&i?"":r,this.shadowRoot.querySelector("w-attention").handleDone(),{shouldCancel:!1})},pe=async function(r){let o=r.currentTarget.tagName==="W-TEXTFIELD";if(r instanceof CustomEvent)return;let a=r.currentTarget.value;return(await p(this,c,re).call(this,a,o)).shouldCancel?(r.preventDefault(),!1):!0},Ae=async function(r){if(r.key!=="ArrowLeft"&&r.key!=="ArrowRight")return;let o=Number(this.range.value),a=this.step||1,n;r.key==="ArrowLeft"?n=o-a:n=o+a,n=Math.min(Math.max(n,Number(this.min)),Number(this.max)),(await p(this,c,re).call(this,n.toString(),!1)).shouldCancel&&r.preventDefault()},Ie=function(r){r instanceof CustomEvent&&r.type==="focus"&&(this._inputHasFocus=!0)},je=function(r){r instanceof CustomEvent&&r.type==="blur"&&(this._inputHasFocus=!1)},b.shadowRootOptions={...Le.shadowRootOptions,delegatesFocus:!0},b.styles=[_e,ze,Ce],m([P({attribute:"aria-label",reflect:!0})],b.prototype,"ariaLabel",2),m([P({attribute:"aria-description",reflect:!0})],b.prototype,"ariaDescription",2),m([P({reflect:!0})],b.prototype,"label",2),m([P({reflect:!0})],b.prototype,"name",2),m([P({reflect:!0})],b.prototype,"value",2),m([P({type:Boolean,reflect:!0})],b.prototype,"disabled",2),m([P({type:Boolean,reflect:!0})],b.prototype,"invalid",2),m([P({attribute:!1,reflect:!1})],b.prototype,"allowValuesOutsideRange",2),m([S()],b.prototype,"markers",2),m([S()],b.prototype,"required",2),m([S()],b.prototype,"step",2),m([S()],b.prototype,"min",2),m([S()],b.prototype,"max",2),m([S()],b.prototype,"suffix",2),m([S()],b.prototype,"formatter",2),m([De('input[type="range"]')],b.prototype,"range",2),m([De("w-textfield")],b.prototype,"textfield",2),m([S()],b.prototype,"_showTooltip",2),m([S()],b.prototype,"_inputHasFocus",2);customElements.get("w-slider-thumb")||customElements.define("w-slider-thumb",b);export{b as WarpSliderThumb};
2705
2748
  //# sourceMappingURL=slider-thumb.js.map