@vonage/vivid 5.16.0 → 5.18.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 (564) hide show
  1. package/accordion/definition.cjs +6 -6
  2. package/accordion/definition.js +1 -1
  3. package/accordion/index.cjs +1 -1
  4. package/accordion/index.js +2 -2
  5. package/accordion-item/definition.cjs +5 -5
  6. package/accordion-item/definition.js +1 -1
  7. package/accordion-item/index.cjs +1 -1
  8. package/accordion-item/index.js +2 -2
  9. package/action-group/index.cjs +3 -3
  10. package/action-group/index.js +5 -5
  11. package/alert/definition.cjs +5 -5
  12. package/alert/definition.js +1 -1
  13. package/alert/index.cjs +3 -3
  14. package/alert/index.js +15 -14
  15. package/audio-player/definition.cjs +5 -5
  16. package/audio-player/definition.js +1 -1
  17. package/audio-player/index.cjs +16 -16
  18. package/audio-player/index.js +29 -28
  19. package/avatar/definition.cjs +5 -5
  20. package/avatar/definition.js +1 -1
  21. package/avatar/index.cjs +4 -4
  22. package/avatar/index.js +12 -11
  23. package/badge/definition.cjs +5 -5
  24. package/badge/definition.js +1 -1
  25. package/badge/index.cjs +1 -4
  26. package/badge/index.js +4 -20
  27. package/banner/definition.cjs +5 -5
  28. package/banner/definition.js +1 -1
  29. package/banner/index.cjs +3 -3
  30. package/banner/index.js +14 -13
  31. package/breadcrumb-item/definition.cjs +4 -4
  32. package/breadcrumb-item/definition.js +1 -1
  33. package/breadcrumb-item/index.cjs +1 -1
  34. package/breadcrumb-item/index.js +1 -0
  35. package/bundled/affix.cjs +1 -1
  36. package/bundled/affix.js +5 -5
  37. package/bundled/base-color-picker.cjs +2 -2
  38. package/bundled/base-color-picker.js +5 -5
  39. package/bundled/button.cjs +1 -1
  40. package/bundled/button.js +2 -2
  41. package/bundled/calendar-picker.template.cjs +2 -2
  42. package/bundled/calendar-picker.template.js +498 -498
  43. package/bundled/definition10.cjs +18 -30
  44. package/bundled/definition10.js +53 -155
  45. package/bundled/definition11.cjs +10 -19
  46. package/bundled/definition11.js +25 -74
  47. package/bundled/definition12.cjs +72 -18
  48. package/bundled/definition12.js +171 -107
  49. package/bundled/definition13.cjs +18 -17
  50. package/bundled/definition13.js +46 -66
  51. package/bundled/definition14.cjs +5 -10
  52. package/bundled/definition14.js +9 -27
  53. package/bundled/definition15.cjs +17 -71
  54. package/bundled/definition15.js +64 -181
  55. package/bundled/definition16.cjs +12 -4
  56. package/bundled/definition16.js +79 -14
  57. package/bundled/definition17.cjs +19 -13
  58. package/bundled/definition17.js +118 -69
  59. package/bundled/definition18.cjs +87 -12
  60. package/bundled/definition18.js +409 -52
  61. package/bundled/definition19.cjs +5 -87
  62. package/bundled/definition19.js +14 -422
  63. package/bundled/definition2.cjs +3 -14
  64. package/bundled/definition2.js +16 -49
  65. package/bundled/definition20.cjs +30 -5
  66. package/bundled/definition20.js +159 -9
  67. package/bundled/definition21.cjs +28 -19
  68. package/bundled/definition21.js +164 -47
  69. package/bundled/definition22.cjs +4 -24
  70. package/bundled/definition22.js +18 -88
  71. package/bundled/definition23.cjs +12 -0
  72. package/bundled/definition23.js +37 -0
  73. package/bundled/definition24.cjs +39 -0
  74. package/bundled/definition24.js +72 -0
  75. package/bundled/definition3.cjs +1 -1
  76. package/bundled/definition3.js +24 -21
  77. package/bundled/definition4.cjs +23 -38
  78. package/bundled/definition4.js +81 -63
  79. package/bundled/definition5.cjs +2 -2
  80. package/bundled/definition5.js +5 -5
  81. package/bundled/definition6.cjs +11 -11
  82. package/bundled/definition6.js +57 -41
  83. package/bundled/definition9.cjs +12 -30
  84. package/bundled/definition9.js +55 -148
  85. package/bundled/divider.cjs +1 -1
  86. package/bundled/divider.js +5 -5
  87. package/bundled/listbox.cjs +1 -1
  88. package/bundled/listbox.js +1 -1
  89. package/bundled/localized.cjs +1 -1
  90. package/bundled/localized.js +1 -0
  91. package/bundled/mixins.cjs +5 -5
  92. package/bundled/mixins.js +49 -49
  93. package/bundled/numberConverter.cjs +12 -0
  94. package/bundled/numberConverter.js +38 -0
  95. package/bundled/picker-field.template.cjs +8 -7
  96. package/bundled/picker-field.template.js +16 -15
  97. package/bundled/slider.template.cjs +7 -7
  98. package/bundled/slider.template.js +12 -12
  99. package/bundled/slottable-request.cjs +1 -1
  100. package/bundled/slottable-request.js +8 -38
  101. package/bundled/time-selection-picker.template.cjs +4 -4
  102. package/bundled/time-selection-picker.template.js +35 -35
  103. package/bundled/utils.cjs +1 -0
  104. package/bundled/utils.js +1420 -0
  105. package/bundled/vivid-element.cjs +1 -1
  106. package/bundled/vivid-element.js +1 -1
  107. package/button/definition.cjs +5 -5
  108. package/button/definition.js +1 -1
  109. package/button/index.cjs +1 -1
  110. package/button/index.js +1 -1
  111. package/calendar/index.cjs +11 -11
  112. package/calendar/index.js +30 -237
  113. package/calendar-event/index.cjs +3 -3
  114. package/calendar-event/index.js +4 -4
  115. package/card/definition.cjs +5 -5
  116. package/card/definition.js +1 -1
  117. package/card/index.cjs +15 -12
  118. package/card/index.js +17 -13
  119. package/checkbox/definition.cjs +5 -5
  120. package/checkbox/definition.js +1 -1
  121. package/checkbox/index.cjs +1 -1
  122. package/checkbox/index.js +2 -2
  123. package/color-picker/definition.cjs +5 -5
  124. package/color-picker/definition.js +2 -2
  125. package/color-picker/index.cjs +10 -10
  126. package/color-picker/index.js +58 -57
  127. package/combobox/definition.cjs +5 -5
  128. package/combobox/definition.js +2 -2
  129. package/combobox/index.cjs +9 -8
  130. package/combobox/index.js +40 -35
  131. package/contextual-help/definition.cjs +5 -5
  132. package/contextual-help/definition.js +2 -2
  133. package/contextual-help/index.cjs +1 -1
  134. package/contextual-help/index.js +2 -2
  135. package/country/definition.cjs +5 -5
  136. package/country/definition.js +1 -1
  137. package/country/index.cjs +1 -12
  138. package/country/index.js +4 -1216
  139. package/country-group/definition.cjs +6 -0
  140. package/country-group/definition.js +3 -0
  141. package/country-group/index.cjs +43 -0
  142. package/country-group/index.js +166 -0
  143. package/custom-elements.json +1274 -200
  144. package/data-grid/definition.cjs +9 -9
  145. package/data-grid/definition.js +2 -2
  146. package/data-grid/index.cjs +18 -18
  147. package/data-grid/index.js +260 -262
  148. package/date-picker/definition.cjs +5 -5
  149. package/date-picker/definition.js +2 -2
  150. package/date-picker/index.cjs +1 -1
  151. package/date-picker/index.js +13 -13
  152. package/date-range-picker/definition.cjs +5 -5
  153. package/date-range-picker/definition.js +2 -2
  154. package/date-range-picker/index.cjs +1 -1
  155. package/date-range-picker/index.js +8 -8
  156. package/date-time-picker/definition.cjs +5 -5
  157. package/date-time-picker/definition.js +2 -2
  158. package/date-time-picker/index.cjs +4 -4
  159. package/date-time-picker/index.js +25 -25
  160. package/dial-pad/definition.cjs +5 -5
  161. package/dial-pad/definition.js +2 -2
  162. package/dial-pad/index.cjs +6 -5
  163. package/dial-pad/index.js +14 -12
  164. package/dialog/definition.cjs +5 -5
  165. package/dialog/definition.js +2 -2
  166. package/dialog/index.cjs +6 -6
  167. package/dialog/index.js +17 -16
  168. package/divider/definition.cjs +1 -1
  169. package/divider/definition.js +1 -1
  170. package/divider/index.cjs +1 -1
  171. package/divider/index.js +1 -1
  172. package/empty-state/definition.cjs +5 -5
  173. package/empty-state/definition.js +2 -2
  174. package/empty-state/index.cjs +2 -2
  175. package/empty-state/index.js +6 -5
  176. package/fab/definition.cjs +5 -5
  177. package/fab/definition.js +2 -2
  178. package/fab/index.cjs +4 -4
  179. package/fab/index.js +13 -12
  180. package/file-picker/definition.cjs +5 -5
  181. package/file-picker/definition.js +2 -2
  182. package/file-picker/index.cjs +20 -17
  183. package/file-picker/index.js +40 -36
  184. package/flag/definition.cjs +6 -0
  185. package/flag/definition.js +3 -0
  186. package/flag/index.cjs +10 -0
  187. package/flag/index.js +61 -0
  188. package/header/definition.cjs +1 -1
  189. package/header/definition.js +1 -1
  190. package/header/index.cjs +4 -4
  191. package/header/index.js +5 -5
  192. package/icon/definition.cjs +1 -0
  193. package/icon/definition.js +1 -0
  194. package/icon/index.cjs +1 -1
  195. package/icon/index.js +1 -0
  196. package/index.cjs +204 -192
  197. package/index.js +55 -52
  198. package/layout/definition.cjs +1 -1
  199. package/layout/definition.js +1 -1
  200. package/lib/button/button.d.ts +1 -0
  201. package/lib/combobox/combobox.d.ts +0 -3
  202. package/lib/components.d.ts +2 -0
  203. package/lib/country/countries-data.d.ts +1 -0
  204. package/lib/country/{country-code-to-flag-icon.d.ts → utils.d.ts} +0 -3
  205. package/lib/country-group/country-group.d.ts +829 -0
  206. package/lib/country-group/country-group.template.d.ts +3 -0
  207. package/lib/country-group/definition.d.ts +3 -0
  208. package/lib/country-group/index.d.ts +1 -0
  209. package/lib/country-group/locale.d.ts +3 -0
  210. package/lib/date-picker/date-picker.d.ts +4 -0
  211. package/lib/date-range-picker/date-range-picker.d.ts +2 -0
  212. package/lib/date-time-picker/date-time-picker.d.ts +4 -4
  213. package/lib/dial-pad/dial-pad.d.ts +6 -2
  214. package/lib/dialog/dialog.d.ts +0 -1
  215. package/lib/flag/definition.d.ts +3 -0
  216. package/lib/flag/flag.d.ts +8 -0
  217. package/lib/flag/flag.template.d.ts +3 -0
  218. package/lib/flag/index.d.ts +1 -0
  219. package/lib/icon/icon.d.ts +1 -2
  220. package/lib/menu/menu.d.ts +0 -1
  221. package/lib/option/option.d.ts +0 -1
  222. package/lib/rich-text-editor/rte/exports.d.ts +1 -0
  223. package/lib/rich-text-editor/rte/features/alignment.d.ts +1 -1
  224. package/lib/rich-text-editor/rte/features/character-count.d.ts +21 -0
  225. package/lib/rich-text-editor/rte/features/font-size-picker.d.ts +1 -1
  226. package/lib/rich-text-editor/rte/features/internal/basic-text-blocks.d.ts +1 -1
  227. package/lib/rich-text-editor/rte/features/keyboard-shortcuts.d.ts +1 -1
  228. package/lib/rich-text-editor/rte/features/text-color-picker.d.ts +1 -1
  229. package/lib/rich-text-editor/rte/public-interface.d.ts +6 -0
  230. package/lib/searchable-select/option-tag.d.ts +3 -2
  231. package/lib/searchable-select/searchable-select.d.ts +3 -1
  232. package/lib/table/definition.d.ts +2 -1
  233. package/lib/table/table-header-cell.d.ts +3 -0
  234. package/lib/table/table-sorting-button.d.ts +415 -0
  235. package/lib/table/table-sorting-button.template.d.ts +3 -0
  236. package/lib/tag-name-map.d.ts +2 -1
  237. package/lib/time-picker/time-picker.d.ts +2 -0
  238. package/locales/de-DE.cjs +5 -178
  239. package/locales/de-DE.js +3 -179
  240. package/locales/en-GB.cjs +5 -9
  241. package/locales/en-GB.js +3 -10
  242. package/locales/en-US.cjs +269 -2
  243. package/locales/en-US.js +266 -1
  244. package/locales/ja-JP.cjs +5 -171
  245. package/locales/ja-JP.js +3 -172
  246. package/locales/zh-CN.cjs +5 -172
  247. package/locales/zh-CN.js +3 -173
  248. package/menu/definition.cjs +5 -5
  249. package/menu/definition.js +1 -1
  250. package/menu/index.cjs +1 -1
  251. package/menu/index.js +2 -2
  252. package/menu-item/definition.cjs +6 -6
  253. package/menu-item/definition.js +1 -1
  254. package/menu-item/index.cjs +1 -1
  255. package/menu-item/index.js +2 -2
  256. package/nav/definition.cjs +1 -1
  257. package/nav/definition.js +1 -1
  258. package/nav-disclosure/definition.cjs +5 -5
  259. package/nav-disclosure/definition.js +2 -2
  260. package/nav-disclosure/index.cjs +4 -4
  261. package/nav-disclosure/index.js +13 -12
  262. package/nav-item/definition.cjs +5 -5
  263. package/nav-item/definition.js +2 -2
  264. package/nav-item/index.cjs +2 -2
  265. package/nav-item/index.js +12 -11
  266. package/note/definition.cjs +5 -5
  267. package/note/definition.js +2 -2
  268. package/note/index.cjs +3 -3
  269. package/note/index.js +11 -10
  270. package/number-field/definition.cjs +5 -5
  271. package/number-field/definition.js +2 -2
  272. package/number-field/index.cjs +4 -4
  273. package/number-field/index.js +29 -28
  274. package/option/definition.cjs +5 -5
  275. package/option/definition.js +2 -2
  276. package/option/index.cjs +1 -1
  277. package/option/index.js +2 -2
  278. package/package.json +9 -10
  279. package/pagination/definition.cjs +5 -5
  280. package/pagination/definition.js +2 -2
  281. package/pagination/index.cjs +3 -3
  282. package/pagination/index.js +16 -16
  283. package/popover/definition.cjs +5 -5
  284. package/popover/definition.js +2 -2
  285. package/popover/index.cjs +7 -7
  286. package/popover/index.js +12 -11
  287. package/popup/definition.cjs +4 -4
  288. package/popup/definition.js +1 -1
  289. package/popup/index.cjs +1 -1
  290. package/popup/index.js +1 -1
  291. package/progress/definition.cjs +1 -1
  292. package/progress/definition.js +1 -1
  293. package/progress/index.cjs +2 -2
  294. package/progress/index.js +5 -5
  295. package/radio/definition.cjs +1 -1
  296. package/radio/definition.js +1 -1
  297. package/radio/index.cjs +1 -1
  298. package/radio/index.js +1 -1
  299. package/radio-group/definition.cjs +5 -5
  300. package/radio-group/definition.js +2 -2
  301. package/radio-group/index.cjs +4 -4
  302. package/radio-group/index.js +11 -11
  303. package/range-slider/definition.cjs +5 -5
  304. package/range-slider/definition.js +2 -2
  305. package/range-slider/index.cjs +4 -4
  306. package/range-slider/index.js +39 -36
  307. package/rich-text-editor/definition.cjs +32 -31
  308. package/rich-text-editor/definition.js +3 -3
  309. package/rich-text-editor/index.cjs +13 -13
  310. package/rich-text-editor/index.js +1887 -1830
  311. package/rich-text-view/definition.cjs +1 -1
  312. package/rich-text-view/definition.js +1 -1
  313. package/rich-text-view/index.cjs +1 -1
  314. package/rich-text-view/index.js +8 -8
  315. package/searchable-select/definition.cjs +4 -4
  316. package/searchable-select/definition.js +2 -2
  317. package/searchable-select/index.cjs +15 -13
  318. package/searchable-select/index.js +75 -72
  319. package/select/definition.cjs +5 -5
  320. package/select/definition.js +2 -2
  321. package/select/index.cjs +1 -1
  322. package/select/index.js +2 -2
  323. package/selectable-box/definition.cjs +5 -5
  324. package/selectable-box/definition.js +2 -2
  325. package/selectable-box/index.cjs +7 -7
  326. package/selectable-box/index.js +12 -12
  327. package/shared/foundation/test-utilities/fixture.d.ts +1 -1
  328. package/shared/icon/utils.d.ts +1 -0
  329. package/shared/localization/Locale.d.ts +2 -0
  330. package/shared/patterns/linkable.d.ts +1 -1
  331. package/shared/picker-field/mixins/calendar-picker.d.ts +1 -0
  332. package/shared/picker-field/mixins/calendar-picker.template.d.ts +1 -0
  333. package/shared/picker-field/mixins/min-max-calendar-picker.d.ts +1 -0
  334. package/shared/picker-field/mixins/single-date-picker.d.ts +1 -0
  335. package/shared/picker-field/mixins/single-value-picker.d.ts +1 -0
  336. package/shared/picker-field/mixins/time-selection-picker.d.ts +1 -0
  337. package/shared/picker-field/mixins/time-selection-picker.template.d.ts +2 -0
  338. package/shared/picker-field/picker-field.d.ts +2 -0
  339. package/side-drawer/definition.cjs +1 -1
  340. package/side-drawer/definition.js +1 -1
  341. package/simple-color-picker/definition.cjs +5 -5
  342. package/simple-color-picker/definition.js +2 -2
  343. package/simple-color-picker/index.cjs +3 -3
  344. package/simple-color-picker/index.js +15 -14
  345. package/slider/definition.cjs +5 -5
  346. package/slider/definition.js +1 -1
  347. package/slider/index.cjs +1 -1
  348. package/slider/index.js +1 -1
  349. package/split-button/definition.cjs +5 -5
  350. package/split-button/definition.js +2 -2
  351. package/split-button/index.cjs +6 -6
  352. package/split-button/index.js +17 -16
  353. package/status/definition.cjs +5 -5
  354. package/status/definition.js +2 -2
  355. package/status/index.cjs +2 -2
  356. package/status/index.js +11 -10
  357. package/switch/definition.cjs +5 -5
  358. package/switch/definition.js +2 -2
  359. package/switch/index.cjs +4 -4
  360. package/switch/index.js +11 -10
  361. package/tab/definition.cjs +5 -5
  362. package/tab/definition.js +2 -2
  363. package/tab/index.cjs +1 -1
  364. package/tab/index.js +2 -2
  365. package/tab-panel/definition.cjs +1 -1
  366. package/tab-panel/definition.js +1 -1
  367. package/tab-panel/index.cjs +1 -1
  368. package/tab-panel/index.js +1 -1
  369. package/table/definition.cjs +4 -1
  370. package/table/definition.js +3 -2
  371. package/table/index.cjs +19 -10
  372. package/table/index.js +70 -21
  373. package/tabs/definition.cjs +6 -6
  374. package/tabs/definition.js +2 -2
  375. package/tabs/index.cjs +2 -2
  376. package/tabs/index.js +5 -5
  377. package/tag/definition.cjs +5 -5
  378. package/tag/definition.js +2 -2
  379. package/tag/index.cjs +8 -8
  380. package/tag/index.js +14 -13
  381. package/tag-group/definition.cjs +1 -1
  382. package/tag-group/definition.js +1 -1
  383. package/tag-group/index.cjs +3 -3
  384. package/tag-group/index.js +5 -5
  385. package/text-area/definition.cjs +5 -5
  386. package/text-area/definition.js +2 -2
  387. package/text-area/index.cjs +2 -2
  388. package/text-area/index.js +13 -13
  389. package/text-field/definition.cjs +5 -5
  390. package/text-field/definition.js +2 -2
  391. package/text-field/index.cjs +1 -1
  392. package/text-field/index.js +2 -2
  393. package/time-picker/definition.cjs +4 -4
  394. package/time-picker/definition.js +2 -2
  395. package/time-picker/index.cjs +1 -1
  396. package/time-picker/index.js +2 -2
  397. package/toggletip/definition.cjs +5 -5
  398. package/toggletip/definition.js +2 -2
  399. package/toggletip/index.cjs +1 -1
  400. package/toggletip/index.js +2 -2
  401. package/tooltip/definition.cjs +5 -5
  402. package/tooltip/definition.js +2 -2
  403. package/tooltip/index.cjs +1 -1
  404. package/tooltip/index.js +2 -2
  405. package/tree-item/definition.cjs +5 -5
  406. package/tree-item/definition.js +2 -2
  407. package/tree-item/index.cjs +1 -1
  408. package/tree-item/index.js +2 -2
  409. package/tree-view/definition.cjs +5 -5
  410. package/tree-view/definition.js +2 -2
  411. package/tree-view/index.cjs +3 -3
  412. package/tree-view/index.js +18 -18
  413. package/unbundled/button.cjs +2 -2
  414. package/unbundled/button.js +2 -2
  415. package/unbundled/calendar-picker.template.cjs +4347 -9
  416. package/unbundled/calendar-picker.template.js +4345 -7
  417. package/unbundled/chunk.cjs +0 -22
  418. package/unbundled/definition11.cjs +6 -0
  419. package/unbundled/definition11.js +6 -0
  420. package/unbundled/definition13.cjs +1 -8
  421. package/unbundled/definition13.js +1 -8
  422. package/unbundled/definition14.cjs +3 -2
  423. package/unbundled/definition14.js +3 -2
  424. package/unbundled/definition2.cjs +5 -75
  425. package/unbundled/definition2.js +1 -71
  426. package/unbundled/definition21.cjs +1 -2
  427. package/unbundled/definition21.js +1 -2
  428. package/unbundled/definition22.cjs +7 -2
  429. package/unbundled/definition22.js +7 -2
  430. package/unbundled/definition24.cjs +98 -979
  431. package/unbundled/definition24.js +93 -974
  432. package/unbundled/definition25.cjs +37 -322
  433. package/unbundled/definition25.js +33 -318
  434. package/unbundled/definition26.cjs +317 -91
  435. package/unbundled/definition26.js +313 -87
  436. package/unbundled/definition27.cjs +94 -192
  437. package/unbundled/definition27.js +91 -183
  438. package/unbundled/definition28.cjs +388 -395
  439. package/unbundled/definition28.js +388 -395
  440. package/unbundled/definition29.cjs +189 -110
  441. package/unbundled/definition29.js +180 -107
  442. package/unbundled/definition30.cjs +520 -36
  443. package/unbundled/definition30.js +519 -35
  444. package/unbundled/definition31.cjs +2 -1189
  445. package/unbundled/definition31.js +1 -1188
  446. package/unbundled/definition32.cjs +207 -1835
  447. package/unbundled/definition32.js +203 -1807
  448. package/unbundled/definition33.cjs +85 -228
  449. package/unbundled/definition33.js +82 -165
  450. package/unbundled/definition34.cjs +1887 -25
  451. package/unbundled/definition34.js +1857 -24
  452. package/unbundled/definition35.cjs +315 -121
  453. package/unbundled/definition35.js +236 -114
  454. package/unbundled/definition36.cjs +25 -405
  455. package/unbundled/definition36.js +22 -397
  456. package/unbundled/definition37.cjs +49 -140
  457. package/unbundled/definition37.js +46 -137
  458. package/unbundled/definition38.cjs +346 -329
  459. package/unbundled/definition38.js +343 -326
  460. package/unbundled/definition39.cjs +183 -234
  461. package/unbundled/definition39.js +181 -232
  462. package/unbundled/definition40.cjs +377 -47
  463. package/unbundled/definition40.js +372 -42
  464. package/unbundled/definition41.cjs +256 -57
  465. package/unbundled/definition41.js +255 -56
  466. package/unbundled/definition42.cjs +45 -421
  467. package/unbundled/definition42.js +41 -417
  468. package/unbundled/definition43.cjs +63 -49
  469. package/unbundled/definition43.js +61 -47
  470. package/unbundled/definition44.cjs +438 -30
  471. package/unbundled/definition44.js +434 -25
  472. package/unbundled/definition45.cjs +46 -84
  473. package/unbundled/definition45.js +43 -81
  474. package/unbundled/definition46.cjs +29 -54
  475. package/unbundled/definition46.js +24 -50
  476. package/unbundled/definition47.cjs +93 -21
  477. package/unbundled/definition47.js +91 -16
  478. package/unbundled/definition48.cjs +49 -33
  479. package/unbundled/definition48.js +46 -30
  480. package/unbundled/definition49.cjs +22 -347
  481. package/unbundled/definition49.js +16 -344
  482. package/unbundled/definition50.cjs +34 -211
  483. package/unbundled/definition50.js +30 -207
  484. package/unbundled/definition51.cjs +282 -242
  485. package/unbundled/definition51.js +275 -235
  486. package/unbundled/definition52.cjs +211 -51
  487. package/unbundled/definition52.js +209 -48
  488. package/unbundled/definition53.cjs +275 -131
  489. package/unbundled/definition53.js +272 -127
  490. package/unbundled/definition54.cjs +50 -261
  491. package/unbundled/definition54.js +48 -260
  492. package/unbundled/definition55.cjs +126 -443
  493. package/unbundled/definition55.js +123 -441
  494. package/unbundled/definition56.cjs +238 -12669
  495. package/unbundled/definition56.js +232 -12506
  496. package/unbundled/definition57.cjs +408 -729
  497. package/unbundled/definition57.js +406 -727
  498. package/unbundled/definition58.cjs +3619 -106
  499. package/unbundled/definition58.js +3449 -99
  500. package/unbundled/definition59.cjs +625 -868
  501. package/unbundled/definition59.js +620 -863
  502. package/unbundled/definition60.cjs +106 -108
  503. package/unbundled/definition60.js +102 -104
  504. package/unbundled/definition61.cjs +1040 -71
  505. package/unbundled/definition61.js +1035 -65
  506. package/unbundled/definition62.cjs +105 -169
  507. package/unbundled/definition62.js +101 -165
  508. package/unbundled/definition63.cjs +70 -113
  509. package/unbundled/definition63.js +65 -109
  510. package/unbundled/definition64.cjs +181 -53
  511. package/unbundled/definition64.js +178 -50
  512. package/unbundled/definition65.cjs +109 -76
  513. package/unbundled/definition65.js +109 -75
  514. package/unbundled/definition66.cjs +58 -21
  515. package/unbundled/definition66.js +55 -15
  516. package/unbundled/definition67.cjs +81 -74
  517. package/unbundled/definition67.js +79 -73
  518. package/unbundled/definition68.cjs +19 -344
  519. package/unbundled/definition68.js +14 -335
  520. package/unbundled/definition69.cjs +88 -26
  521. package/unbundled/definition69.js +85 -22
  522. package/unbundled/definition7.cjs +18 -3
  523. package/unbundled/definition7.js +18 -3
  524. package/unbundled/definition70.cjs +330 -111
  525. package/unbundled/definition70.js +320 -108
  526. package/unbundled/definition71.cjs +26 -271
  527. package/unbundled/definition71.js +21 -267
  528. package/unbundled/definition72.cjs +134 -28
  529. package/unbundled/definition72.js +125 -26
  530. package/unbundled/definition73.cjs +245 -113
  531. package/unbundled/definition73.js +242 -104
  532. package/unbundled/definition74.cjs +28 -212
  533. package/unbundled/definition74.js +26 -202
  534. package/unbundled/definition75.cjs +120 -52190
  535. package/unbundled/definition75.js +112 -52188
  536. package/unbundled/definition76.cjs +232 -0
  537. package/unbundled/definition76.js +213 -0
  538. package/unbundled/definition77.cjs +533 -0
  539. package/unbundled/definition77.js +513 -0
  540. package/unbundled/listbox.cjs +1 -1
  541. package/unbundled/listbox.js +1 -1
  542. package/unbundled/localized.cjs +2 -2
  543. package/unbundled/localized.js +1 -1
  544. package/unbundled/numberConverter.cjs +91 -0
  545. package/unbundled/numberConverter.js +74 -0
  546. package/unbundled/picker-field.template.cjs +3 -1
  547. package/unbundled/picker-field.template.js +3 -1
  548. package/unbundled/slottable-request.cjs +2 -3168
  549. package/unbundled/slottable-request.js +3 -3097
  550. package/unbundled/time-selection-picker.template.cjs +1 -1
  551. package/unbundled/time-selection-picker.template.js +1 -1
  552. package/unbundled/utils.cjs +1439 -0
  553. package/unbundled/utils.js +1428 -0
  554. package/unbundled/vivid-element.cjs +1 -1
  555. package/unbundled/vivid-element.js +1 -1
  556. package/video-player/definition.cjs +1 -1
  557. package/video-player/definition.js +1 -1
  558. package/video-player/index.cjs +3 -3
  559. package/video-player/index.js +9 -9
  560. package/vivid.api.json +860 -409
  561. package/unbundled/chunk.js +0 -33
  562. package/unbundled/en-US.cjs +0 -447
  563. package/unbundled/en-US.js +0 -443
  564. /package/{lib/icon/icon.placeholder.d.ts → shared/icon/icon-placeholder.d.ts} +0 -0
@@ -1,819 +1,498 @@
1
- import { o as defineVividComponent, s as createRegisterFunction } from "./vivid-element.js";
2
- import { t as iconDefinition } from "./definition2.js";
1
+ import { o as defineVividComponent, s as createRegisterFunction, t as VividElement } from "./vivid-element.js";
3
2
  import { t as __decorate } from "./decorate.js";
4
- import { a as affixIconTemplateFactory, i as IconWrapper, n as AffixIconWithTrailing } from "./affix.js";
5
3
  import { n as FormAssociated } from "./form-associated.js";
6
4
  import { t as FormElement } from "./form-element.js";
7
- import { t as WithSuccessText } from "./with-success-text.js";
8
- import { t as WithErrorText } from "./with-error-text.js";
9
- import { t as WithContextualHelp } from "./with-contextual-help.js";
10
5
  import { t as Localized } from "./localized.js";
11
- import { i as Button, r as chevronTemplateFactory, t as buttonDefinition } from "./definition7.js";
12
- import { t as handleEscapeKeyAndStopPropogation } from "./dialog.js";
13
- import { i as Popup, t as popupDefinition } from "./definition10.js";
14
- import { n as applyHostSemantics, t as HostSemantics } from "./host-semantics.js";
15
- import { a as feedbackMessageDefinition, n as WithLightDOMFeedback } from "./mixins.js";
16
- import { r as ListboxOption, t as listboxOptionDefinition } from "./definition27.js";
17
- import { t as Listbox } from "./listbox.js";
18
- import { Observable, Updates, attr, html, observable, ref, slotted, volatile, when } from "@microsoft/fast-element";
19
- import { classNames, inRange, keyArrowDown, keyArrowUp, keyEnd, keyEnter, keyEscape, keyHome, keySpace, keyTab, uniqueId } from "@microsoft/fast-web-utilities";
20
- //#region src/lib/select/select.ts
6
+ import { i as Popup, r as PlacementStrategy, t as popupDefinition } from "./definition10.js";
7
+ import { n as keyArrowRight$1, t as keyArrowLeft$1 } from "./key-codes.js";
8
+ import { a as defaultToOneConverter, i as lerp, n as getMarkersTemplate, o as roundToStepValue, r as inverseLerp } from "./slider.template.js";
9
+ import { attr, html, nullableNumberConverter, observable, ref, when } from "@microsoft/fast-element";
10
+ import { Orientation, classNames, keyArrowDown, keyArrowUp, keyEnd, keyHome, limit } from "@microsoft/fast-web-utilities";
11
+ //#region src/lib/range-slider/range-slider.scss?inline
12
+ var range_slider_default = ":host{display:inline-block}:host(:not([orientation=vertical])){inline-size:100%}:host([orientation=vertical]){block-size:100%;min-block-size:calc(var(--_thumb-interaction-indicator-size) * 5)}:host([disabled]){cursor:not-allowed}.control.connotation-cta{--_connotation-color-primary:var(--vvd-slider-cta-primary,var(--vvd-color-cta-500))}.control:not(.connotation-cta){--_connotation-color-primary:var(--vvd-slider-accent-primary,var(--vvd-color-canvas-text))}.control{--_appearance-color-text:var(--_connotation-color-primary-text);--_appearance-color-fill:var(--_connotation-color-primary);--_appearance-color-outline:transparent;--_thumb-size:12px;--_thumb-interaction-indicator-size:36px;--_track-start-inset-inline-start:0;--_track-start-inset-block-start:0;cursor:pointer;user-select:none;outline:none}.control .positioning-region{position:relative}.control .track{background:var(--_track-background-color);border-radius:4px;position:absolute}.control .track-start{border-radius:inherit;background:var(--_track-start-background-color);block-size:100%;position:absolute;inset-inline-start:var(--_track-start-inset-inline-start)}.control.horizontal{block-size:var(--_thumb-interaction-indicator-size);inline-size:calc(100% - var(--_thumb-size));min-inline-size:var(--_thumb-size);margin-inline-start:calc(var(--_thumb-size) / 2)}.control.horizontal .track{top:calc((var(--_thumb-interaction-indicator-size) - 2px) / 2);block-size:2px;left:0;right:0}:host([markers]) .control.horizontal .track-start{--_track-start-inset-inline-start:1px;border-top-left-radius:0;border-bottom-left-radius:0}.control.horizontal .track .mark{block-size:6px;inline-size:100%;position:absolute;inset-block-start:-2px;inset-inline-start:0}.control.vertical{margin-top:calc(var(--_thumb-interaction-indicator-size) / 2);block-size:calc(100% - var(--_thumb-interaction-indicator-size));inline-size:var(--_thumb-interaction-indicator-size);min-block-size:var(--_thumb-interaction-indicator-size)}.control.vertical .positioning-region{block-size:100%}.control.vertical .track{left:calc((var(--_thumb-interaction-indicator-size) - 2px) / 2);block-size:100%;inline-size:2px}.control.vertical .track .mark{block-size:100%;inline-size:6px;position:absolute;inset-block-start:0;inset-inline-start:-2px}.control.vertical .track-start{block-size:auto;inline-size:100%;inset-block-start:var(--_track-start-inset-block-start)}:host([markers]) .control.vertical .track-start{--_track-start-inset-block-start:1px;border-radius:0}.control.disabled{--_track-background-color:var(--vvd-color-neutral-100);--_track-start-background-color:var(--vvd-color-neutral-300);pointer-events:none}.control:not(.disabled){--_track-background-color:var(--vvd-color-neutral-300);--_track-start-background-color:var(--_appearance-color-fill)}.control:not(.disabled) .mark{color:var(--vvd-color-neutral-950)}.control.disabled .mark{color:var(--_track-start-background-color)}.thumb-container{block-size:var(--_thumb-interaction-indicator-size);cursor:inherit;inline-size:var(--_thumb-interaction-indicator-size);touch-action:none;border-radius:50%;outline:none;position:absolute}.thumb-container.focus-visible{box-shadow:0 0 0 4px color-mix(in srgb, var(--focus-stroke-color,var(--vvd-color-cta-500)), transparent 85%), inset 0 0 0 3px var(--focus-stroke-gap-color,currentColor);outline:1px solid var(--focus-stroke-color,var(--vvd-color-cta-500));outline-offset:calc(-1px - var(--focus-inset,0px));--focus-stroke-gap-color:transparent;--_thumb-interaction-indicator-alpha:.05;border-radius:50%}.control.horizontal .thumb-container{transform:translateX(calc(var(--_thumb-interaction-indicator-size) / 2))}.control.vertical .thumb-container{transform:translateY(calc(var(--_thumb-interaction-indicator-size) / 2))}@media (hover:hover){.control:not(.disabled) .thumb-container:hover{--_thumb-interaction-indicator-alpha:.12}}.control:not(.disabled) .thumb-container:active{--_thumb-interaction-indicator-alpha:.25}.thumb-container:before{border-radius:inherit;background-color:var(--_track-start-background-color);block-size:var(--_thumb-interaction-indicator-size);content:\"\";inline-size:var(--_thumb-interaction-indicator-size);opacity:var(--_thumb-interaction-indicator-alpha,0);transition:opacity .2s ease-out;display:block;position:absolute}.thumb-container:after{border-radius:inherit;background-color:var(--_track-start-background-color);block-size:var(--_thumb-size);content:\"\";inline-size:var(--_thumb-size);inset:calc((var(--_thumb-interaction-indicator-size) - var(--_thumb-size)) / 2);display:block;position:absolute}.popup{pointer-events:none}.tooltip{width:auto;color:var(--vvd-color-canvas-text);font:var(--vvd-typography-base-bold);padding:8px 12px}:host([internal-part]) .thumb-container{opacity:0;transition:opacity .2s}:host([internal-part]) .control.horizontal .track{block-size:4px;top:16px;overflow:hidden}:host([internal-part]) .control:focus .thumb-container{opacity:1}@media (hover:hover){:host([internal-part]) .control:hover .thumb-container{opacity:1}}.control,:host([markers]) .control.horizontal .track-start,:host([markers]) .control.vertical .track-start{--_track-start-inset-inline-start:auto;--_track-start-inset-block-start:auto}";
13
+ //#endregion
14
+ //#region src/lib/range-slider/range-slider.ts
15
+ var Direction$1 = {
16
+ Increment: 1,
17
+ Decrement: -1
18
+ };
21
19
  /**
20
+ * Base class for range-slider
21
+ *
22
+ * @component range-slider
22
23
  * @public
23
- * @component select
24
- * @slot - Default slot.
25
- * @slot icon - The preferred way to add an icon to the select control.
26
- * @slot meta - Slot to add meta content to the select control.
27
- * @slot helper-text - Describes how to use the select. Alternative to the `helper-text` attribute.
28
- * @event {CustomEvent<undefined>} input - Fires a custom 'input' event when the value updates
29
- * @event {CustomEvent<HTMLElement>} change - Fires a custom 'change' event when the value updates
30
- * @vueModel modelValue value input `event.currentTarget.value`
31
- * @testAction selectOptionByValue selectOptionByValue
32
- * @testAction selectOptionByText selectOptionByText
24
+ * @event {CustomEvent<undefined>} input:start - Event emitted when the start value changes
25
+ * @event {CustomEvent<undefined>} input:end - Event emitted when the end value changes
26
+ * @event {CustomEvent<undefined>} input - Event emitted when either the start or end value changes.
27
+ * @event {CustomEvent<undefined>} change - Event emitted when either the start or end value changes.
28
+ * @vueModel start start input:start `event.currentTarget.start`
29
+ * @vueModel end end input:end `event.currentTarget.end`
30
+ * @vueModel startAsNumber startAsNumber input:start `event.currentTarget.startAsNumber`
31
+ * @vueModel endAsNumber endAsNumber input:end `event.currentTarget.endAsNumber`
32
+ * @testSelector byLabel byLabel
33
+ * @testAction slideStartTo slideTo #track #startThumb
34
+ * @testAction slideEndTo slideTo #track #endThumb
35
+ * @testQuery range rangeAsNumber
36
+ * @testRef track shadow .control
37
+ * @testRef startThumb shadow #start-thumb
38
+ * @testRef endThumb shadow #end-thumb
33
39
  */
34
- var Select = class extends WithLightDOMFeedback(WithContextualHelp(WithErrorText(WithSuccessText(Localized(FormElement(HostSemantics(AffixIconWithTrailing(FormAssociated(Listbox))))))))) {
40
+ var RangeSlider = class extends Localized(FormElement(FormAssociated(VividElement))) {
35
41
  constructor(..._args) {
36
42
  super(..._args);
37
- this.proxy = document.createElement("select");
38
- this.activeIndex = -1;
39
- this.rangeStartIndex = -1;
40
- this.open = false;
41
- this.listboxId = uniqueId("listbox-");
42
- this.maxHeight = 0;
43
- this.fixedDropdown = false;
44
- this._feedbackWrapper = null;
45
- this._isResetting = false;
46
- this.clearable = false;
47
- this._isClearButtonFocused = false;
48
- }
49
- /**
50
- * Returns the last checked option.
51
- *
52
- * @internal
53
- */
54
- get activeOption() {
55
- return this.options[this.activeIndex];
56
- }
57
- /**
58
- * Returns the list of checked options.
59
- *
60
- * @internal
61
- */
62
- get checkedOptions() {
63
- return this.options.filter((o) => o.checked);
64
- }
65
- /**
66
- * Returns the index of the first selected option.
67
- *
68
- * @internal
69
- */
70
- get firstSelectedOptionIndex() {
71
- return this.options.indexOf(this.firstSelectedOption);
72
- }
73
- /**
74
- * Updates the `ariaActiveDescendant` property when the active index changes.
75
- *
76
- * @internal
77
- */
78
- activeIndexChanged(_, next) {
79
- this._activeDescendant = this.options[next]?.id ?? "";
80
- this.focusAndScrollOptionIntoView();
81
- }
82
- /**
83
- * Toggles the checked state for the currently active option.
84
- *
85
- * @remarks
86
- * Multiple-selection mode only.
87
- *
88
- * @internal
89
- */
90
- checkActiveIndex() {
91
- const activeItem = this.activeOption;
92
- /* v8 ignore else -- @preserve */
93
- if (activeItem) activeItem.checked = true;
94
- }
95
- /**
96
- * Sets the active index to the first option and marks it as checked.
97
- *
98
- * @remarks
99
- * Multi-selection mode only.
100
- *
101
- * @param preserveChecked - mark all options unchecked before changing the active index
102
- *
103
- * @internal
104
- */
105
- checkFirstOption(preserveChecked) {
106
- const firstSelectableIndex = this.getNextSelectableIndex(0);
107
- if (firstSelectableIndex === -1) return;
108
- if (preserveChecked) {
109
- if (this.rangeStartIndex === -1) this.rangeStartIndex = this.activeIndex;
110
- this.options.forEach((o, i) => {
111
- o.checked = inRange(i, firstSelectableIndex, this.rangeStartIndex + 1) && !o.disabled;
112
- });
113
- } else this.uncheckAllOptions();
114
- this.activeIndex = firstSelectableIndex;
115
- this.checkActiveIndex();
116
- }
117
- /**
118
- * Decrements the active index and sets the matching option as checked.
119
- *
120
- * @remarks
121
- * Multi-selection mode only.
122
- *
123
- * @param preserveChecked - mark all options unchecked before changing the active index
124
- *
125
- * @internal
126
- */
127
- checkLastOption(preserveChecked) {
128
- const lastSelectableIndex = this.getPreviousSelectableIndex(this.length - 1);
129
- if (lastSelectableIndex === -1) return;
130
- if (preserveChecked) {
131
- if (this.rangeStartIndex === -1) this.rangeStartIndex = this.activeIndex;
132
- this.options.forEach((o, i) => {
133
- o.checked = inRange(i, this.rangeStartIndex, lastSelectableIndex + 1) && !o.disabled;
134
- });
135
- } else this.uncheckAllOptions();
136
- this.activeIndex = lastSelectableIndex;
137
- this.checkActiveIndex();
138
- }
139
- /**
140
- * Increments the active index and marks the matching option as checked.
141
- *
142
- * @remarks
143
- * Multiple-selection mode only.
144
- *
145
- * @param preserveChecked - mark all options unchecked before changing the active index
146
- *
147
- * @internal
148
- */
149
- checkNextOption(preserveChecked) {
150
- const nextIndex = this.getNextSelectableIndex(this.activeIndex + 1);
151
- if (nextIndex === -1) return;
152
- if (preserveChecked) {
153
- if (this.rangeStartIndex === -1) this.rangeStartIndex = this.activeIndex;
154
- this.options.forEach((o, i) => {
155
- o.checked = inRange(i, this.rangeStartIndex, nextIndex + 1) && !o.disabled;
156
- });
157
- } else this.uncheckAllOptions();
158
- this.activeIndex = nextIndex;
159
- this.checkActiveIndex();
160
- }
161
- /**
162
- * Decrements the active index and marks the matching option as checked.
163
- *
164
- * @remarks
165
- * Multiple-selection mode only.
166
- *
167
- * @param preserveChecked - mark all options unchecked before changing the active index
168
- *
169
- * @internal
170
- */
171
- checkPreviousOption(preserveChecked) {
172
- const previousIndex = this.getPreviousSelectableIndex(this.activeIndex - 1);
173
- if (previousIndex === -1) return;
174
- if (preserveChecked) {
175
- if (this.rangeStartIndex === -1) this.rangeStartIndex = this.activeIndex;
176
- if (this.checkedOptions.length === 1) this.rangeStartIndex += 1;
177
- this.options.forEach((o, i) => {
178
- o.checked = inRange(i, previousIndex, this.rangeStartIndex + 1) && !o.disabled;
179
- });
180
- } else this.uncheckAllOptions();
181
- this.activeIndex = previousIndex;
182
- this.checkActiveIndex();
43
+ this.start = "";
44
+ this.end = "";
45
+ this.min = 0;
46
+ this.max = 10;
47
+ this.step = 1;
48
+ this.orientation = Orientation.horizontal;
49
+ this.ariaStartLabel = null;
50
+ this.ariaEndLabel = null;
51
+ this.markers = false;
52
+ this.pin = false;
53
+ this.valueTextFormatter = (value) => parseFloat(value).toLocaleString(this.locale.lang);
54
+ this.proxy = document.createElement("input");
55
+ this._trackEl = null;
56
+ this._startThumbEl = null;
57
+ this._endThumbEl = null;
58
+ this._draggingThumb = false;
59
+ this._visiblyFocusedThumb = null;
60
+ this._hoveredThumb = null;
61
+ this._startThumbCss = "";
62
+ this._endThumbCss = "";
63
+ this._selectedRangeCss = "";
64
+ }
65
+ #isInternalValueUpdate = false;
66
+ /**
67
+ * @internal
68
+ */
69
+ startChanged() {
70
+ this.currentStart = this.start;
71
+ if (!this.#isInternalValueUpdate) {
72
+ this.dirtyValue = true;
73
+ this.#updateFormValue();
74
+ }
75
+ if (this.$fastController.isConnected) this.#updateThumbPositions();
183
76
  }
184
77
  /**
185
78
  * @internal
186
79
  */
187
- focusAndScrollOptionIntoView() {
188
- super.focusAndScrollOptionIntoView(this.activeOption);
80
+ initialStartChanged(_, newValue) {
81
+ if (newValue && !this.dirtyValue) {
82
+ this.start = newValue;
83
+ this.dirtyValue = false;
84
+ }
189
85
  }
190
86
  /**
191
- * In multiple-selection mode:
192
- * If any options are selected, the first selected option is checked when
193
- * the listbox receives focus. If no options are selected, the first
194
- * selectable option is checked.
195
- *
196
87
  * @internal
197
88
  */
198
- focusinHandler(e) {
199
- if (!this.multiple) return super.focusinHandler(e);
200
- /* v8 ignore else -- @preserve */
201
- if (!this.shouldSkipFocus && e.target === e.currentTarget) {
202
- this.uncheckAllOptions();
203
- if (this.activeIndex === -1) this.activeIndex = this.firstSelectedOptionIndex !== -1 ? this.firstSelectedOptionIndex : 0;
204
- this.checkActiveIndex();
205
- this.setSelectedOptions();
206
- this.focusAndScrollOptionIntoView();
207
- }
208
- this.shouldSkipFocus = false;
89
+ currentStartChanged() {
90
+ this.start = this.currentStart;
209
91
  }
210
92
  /**
211
- * Sets an option as selected and gives it focus.
93
+ * The start property, typed as a number.
212
94
  *
213
95
  * @public
214
96
  */
215
- setSelectedOptions() {
216
- if (!this.multiple) {
217
- super.setSelectedOptions();
218
- return;
219
- }
220
- /* v8 ignore else -- @preserve */
221
- if (this.$fastController.isConnected && this.options) {
222
- this.selectedOptions = this.options.filter((o) => o.selected);
223
- this.focusAndScrollOptionIntoView();
224
- }
97
+ get startAsNumber() {
98
+ return parseFloat(this.start);
225
99
  }
226
- /**
227
- * Toggles the selected state of the provided options. If any provided items
228
- * are in an unselected state, all items are set to selected. If every
229
- * provided item is selected, they are all unselected.
230
- *
231
- * @internal
232
- */
233
- toggleSelectedForAllCheckedOptions() {
234
- const enabledCheckedOptions = this.checkedOptions.filter((o) => !o.disabled);
235
- const force = !enabledCheckedOptions.every((o) => o.selected);
236
- enabledCheckedOptions.forEach((o) => o.selected = force);
237
- this.selectedIndex = this.options.indexOf(enabledCheckedOptions[enabledCheckedOptions.length - 1]);
238
- this.setSelectedOptions();
239
- this.updateValue(true);
100
+ set startAsNumber(next) {
101
+ this.start = next.toString();
240
102
  }
241
103
  /**
242
104
  * @internal
243
105
  */
244
- typeaheadBufferChanged(prev, next) {
245
- if (!this.multiple) {
246
- super.typeaheadBufferChanged(prev, next);
247
- return;
248
- }
249
- /* v8 ignore if -- @preserve */
250
- if (this.$fastController.isConnected) {
251
- const typeaheadMatches = this.getTypeaheadMatches();
252
- const activeIndex = this.options.indexOf(typeaheadMatches[0]);
253
- if (activeIndex > -1) {
254
- this.activeIndex = activeIndex;
255
- this.uncheckAllOptions();
256
- this.checkActiveIndex();
257
- }
258
- this.typeaheadExpired = false;
106
+ endChanged() {
107
+ this.currentEnd = this.end;
108
+ if (!this.#isInternalValueUpdate) {
109
+ this.dirtyValue = true;
110
+ this.#updateFormValue();
259
111
  }
112
+ if (this.$fastController.isConnected) this.#updateThumbPositions();
260
113
  }
261
114
  /**
262
- * Unchecks all options.
263
- *
264
- * @remarks
265
- * Multiple-selection mode only.
266
- *
267
- * @param preserveChecked - reset the rangeStartIndex
268
- *
269
115
  * @internal
270
116
  */
271
- uncheckAllOptions(preserveChecked = false) {
272
- this.options.forEach((o) => o.checked = false);
273
- /* v8 ignore else -- @preserve */
274
- if (!preserveChecked) this.rangeStartIndex = -1;
275
- }
276
- /**
277
- * Sets focus when the open property changes.
278
- *
279
- * @internal
280
- */
281
- openChanged(prev, next) {
282
- if (!this.collapsible) return;
283
- if (this.open) {
284
- this.focusAndScrollOptionIntoView();
285
- this.indexWhenOpened = this.selectedIndex;
286
- Updates.enqueue(() => this.focus());
287
- return;
117
+ initialEndChanged(_, newValue) {
118
+ if (newValue && !this.dirtyValue) {
119
+ this.end = newValue;
120
+ this.dirtyValue = false;
288
121
  }
289
- const didClose = prev === true && next === false;
290
- const selectionChangedWhileOpen = this.indexWhenOpened !== this.selectedIndex;
291
- if (didClose && selectionChangedWhileOpen) this.updateValue(true);
292
- }
293
- /**
294
- * The component is collapsible when in single-selection mode.
295
- *
296
- * @internal
297
- */
298
- get collapsible() {
299
- return !this.multiple;
300
122
  }
301
123
  /**
302
124
  * @internal
303
125
  */
304
- valueChanged(prev, next) {
305
- const nextSelectedIndex = this.options.findIndex((el) => el.value === next);
306
- const validNextSelectedIndex = this._validSelectedIndex(nextSelectedIndex);
307
- const nextValue = this.options[validNextSelectedIndex]?.value ?? "";
308
- if (this.selectedIndex !== validNextSelectedIndex) this.selectedIndex = validNextSelectedIndex;
309
- if (next !== nextValue) return;
310
- super.valueChanged(prev, next);
311
- this.updateDisplayValue();
126
+ currentEndChanged() {
127
+ this.end = this.currentEnd;
312
128
  }
313
129
  /**
314
- * Sets the value and display value to match the first selected option.
315
- *
316
- * @param shouldEmit - if true, the input and change events will be emitted
130
+ * The end property, typed as a number.
317
131
  *
318
- * @internal
132
+ * @public
319
133
  */
320
- updateValue(shouldEmit) {
321
- if (this.$fastController.isConnected) this.value = this.firstSelectedOption?.value ?? "";
322
- if (shouldEmit) {
134
+ get endAsNumber() {
135
+ return parseFloat(this.end);
136
+ }
137
+ set endAsNumber(next) {
138
+ this.end = next.toString();
139
+ }
140
+ #updateValues({ start, end }, emitEvents = true) {
141
+ if (start === this.start) start = void 0;
142
+ if (end === this.end) end = void 0;
143
+ if (start === void 0 && end === void 0) return;
144
+ this.#isInternalValueUpdate = true;
145
+ if (start !== void 0) this.start = start;
146
+ if (end !== void 0) this.end = end;
147
+ this.#isInternalValueUpdate = false;
148
+ if (emitEvents) {
149
+ if (start !== void 0) this.$emit("input:start");
150
+ if (end !== void 0) this.$emit("input:end");
323
151
  this.$emit("input");
324
- this.$emit("change", this, {
325
- bubbles: true,
326
- composed: void 0
327
- });
152
+ this.$emit("change");
153
+ this.dirtyValue = true;
328
154
  }
155
+ this.#updateFormValue();
329
156
  }
330
- /**
331
- * Updates the proxy value when the selected index changes.
332
- *
333
- * @param prev - the previous selected index
334
- * @param next - the next selected index
335
- *
336
- * @internal
337
- */
338
- selectedIndexChanged(prev, next) {
339
- super.selectedIndexChanged(prev, next);
340
- this.updateValue();
157
+ #applyStep(thumb, direction) {
158
+ this.#updateValues({ [thumb]: this.#roundToNearestStep(thumb, Number(this[thumb]) + direction * this.step).toString() });
341
159
  }
342
160
  /**
343
- * Handle opening and closing the listbox when the select is clicked.
344
- *
345
- * @param e - the mouse event
346
161
  * @internal
347
162
  */
348
- clickHandler(e) {
349
- if (this.disabled || this._isFromContextualHelp(e)) return;
350
- const clickedOption = e.target.closest(`option,[role=option],[data-vvd-component=option]`);
351
- if (clickedOption && clickedOption.disabled) return;
352
- if (this.multiple) {
353
- this.uncheckAllOptions();
354
- this.activeIndex = this.options.indexOf(clickedOption);
355
- this.checkActiveIndex();
356
- this.toggleSelectedForAllCheckedOptions();
357
- } else super.clickHandler(e);
358
- if (this.collapsible) this.open = !this.open;
359
- return true;
163
+ orientationChanged() {
164
+ if (this.$fastController.isConnected) this.#updateThumbPositions();
360
165
  }
361
166
  /**
362
- * Handles focus state when the element or its children lose focus.
363
- *
364
- * @param e - The focus event
365
167
  * @internal
366
168
  */
367
- focusoutHandler(e) {
368
- if (this.multiple) this.uncheckAllOptions();
369
- if (!this.open) return true;
370
- const focusTarget = e.relatedTarget;
371
- if (this.isSameNode(focusTarget)) {
372
- this.focus();
373
- return;
374
- }
375
- /* v8 ignore else -- @preserve */
376
- if (!this.options.includes(focusTarget)) {
377
- this.open = false;
378
- if (this.indexWhenOpened !== this.selectedIndex) this.updateValue(true);
169
+ nameChanged(previous, next) {
170
+ super.nameChanged(previous, next);
171
+ this.#updateFormValue();
172
+ }
173
+ #updateFormValue() {
174
+ if (!this.name) this.setFormValue(null);
175
+ else {
176
+ const formData = new FormData();
177
+ formData.append(this.name, this.start);
178
+ formData.append(this.name, this.end);
179
+ this.setFormValue(formData);
379
180
  }
380
181
  }
381
- /**
382
- * Updates the value when an option's value changes.
383
- *
384
- * @param source - the source object
385
- * @param propertyName - the property to evaluate
386
- *
387
- * @internal
388
- */
389
- handleChange(source, propertyName) {
390
- super.handleChange(source, propertyName);
391
- if (propertyName === "value") this.updateValue();
182
+ formResetCallback() {
183
+ this.#updateValues({
184
+ start: this.initialStart ?? this.min.toString(),
185
+ end: this.initialEnd ?? this.max.toString()
186
+ });
187
+ super.formResetCallback();
188
+ }
189
+ get #thumbs() {
190
+ return {
191
+ start: this._startThumbEl,
192
+ end: this._endThumbEl
193
+ };
194
+ }
195
+ get #thumbConstraints() {
196
+ return {
197
+ start: {
198
+ min: this.min,
199
+ max: this.endAsNumber
200
+ },
201
+ end: {
202
+ min: this.startAsNumber,
203
+ max: this.max
204
+ }
205
+ };
392
206
  }
393
- /**
394
- * Prevents focus when a scrollbar is clicked.
395
- *
396
- * @param e - the mouse event object
397
- *
398
- * @internal
399
- */
400
- mousedownHandler(e) {
401
- if (e.offsetX >= 0 && e.offsetX <= this.listbox.scrollWidth) return super.mousedownHandler(e);
402
- return this.collapsible;
207
+ #getThumbId(thumb) {
208
+ return thumb === this._startThumbEl ? "start" : "end";
403
209
  }
404
- /**
405
- * @internal
406
- */
407
- multipleChanged(_, next) {
408
- this.options.forEach((o) => {
409
- o.checked = next ? false : void 0;
410
- });
411
- this.setSelectedOptions();
412
- /* v8 ignore if -- @preserve */
413
- if (this.proxy) this.proxy.multiple = next;
210
+ #getThumbIdFromEvent(e) {
211
+ return this.#getThumbId(e.target);
414
212
  }
415
- /**
416
- * Updates the selectedness of each option when the list of selected options changes.
417
- *
418
- * @param prev - the previous list of selected options
419
- * @param next - the current list of selected options
420
- *
421
- * @internal
422
- */
423
- selectedOptionsChanged(prev, next) {
424
- super.selectedOptionsChanged(prev, next);
425
- this.options.forEach((o, i) => {
426
- const proxyOption = this.proxy.options.item(i);
427
- if (proxyOption) proxyOption.selected = o.selected;
428
- });
213
+ #updateThumbPositions() {
214
+ const startOffsetPct = this.#thumbTrackEndOffset(this.startAsNumber);
215
+ const endOffsetPct = this.#thumbTrackEndOffset(this.endAsNumber);
216
+ const [dirProp, dimProp] = this.orientation === Orientation.horizontal ? ["right", "width"] : ["bottom", "height"];
217
+ const transition = `transition: ${this._draggingThumb ? "none" : "all 0.2s ease"};`;
218
+ this._startThumbCss = `${dirProp}: ${startOffsetPct}%; ${transition}`;
219
+ this._endThumbCss = `${dirProp}: ${endOffsetPct}%; ${transition}`;
220
+ this._selectedRangeCss = `${dirProp}: ${endOffsetPct}%; ${dimProp}: ${startOffsetPct - endOffsetPct}%; ${transition}`;
429
221
  }
430
- /**
431
- * Resets and fills the proxy to match the component's options.
432
- *
433
- * @internal
434
- */
435
- setProxyOptions() {
436
- /* v8 ignore else -- @preserve */
437
- if (this.proxy instanceof HTMLSelectElement && this.options) {
438
- this.proxy.length = 0;
439
- this.options.forEach((option) => {
440
- const proxyOption = option.proxy || (option instanceof HTMLOptionElement ? option.cloneNode() : null);
441
- if (proxyOption) this.proxy.options.add(proxyOption);
442
- });
443
- }
222
+ #thumbTrackEndOffset(value) {
223
+ return (1 - inverseLerp(this.min, this.max, value)) * 100;
444
224
  }
445
- /**
446
- * Handles keydown actions when the select is in multiple selection mode.
447
- *
448
- * @internal
449
- */
450
- multipleKeydownHandler(e) {
451
- if (this.disabled) return;
452
- const { key, shiftKey } = e;
453
- this.shouldSkipFocus = false;
454
- switch (key) {
455
- case keyHome:
456
- this.checkFirstOption(shiftKey);
457
- return;
458
- case keyArrowDown:
459
- this.checkNextOption(shiftKey);
460
- return;
461
- case keyArrowUp:
462
- this.checkPreviousOption(shiftKey);
463
- return;
464
- case keyEnd:
465
- this.checkLastOption(shiftKey);
466
- return;
467
- case keyTab:
468
- this.focusAndScrollOptionIntoView();
469
- return;
470
- case keyEscape:
471
- this.uncheckAllOptions();
472
- this.checkActiveIndex();
473
- return;
474
- case keySpace:
475
- e.preventDefault();
476
- /* v8 ignore else -- @preserve */
477
- if (this.typeaheadExpired) {
478
- this.toggleSelectedForAllCheckedOptions();
479
- return;
480
- }
481
- default:
482
- /* v8 ignore else -- @preserve */
483
- if (key.length === 1) this.handleTypeAhead(`${key}`);
484
- return;
485
- }
225
+ #calculateValueFromMouseEvent(e) {
226
+ const trackClientRect = this._trackEl.getBoundingClientRect();
227
+ const [minPos, maxPos, valuePos] = this.orientation === Orientation.horizontal ? [
228
+ this._trackEl.clientLeft,
229
+ this._trackEl.clientWidth,
230
+ e.pageX - document.documentElement.scrollLeft - this.getBoundingClientRect().left
231
+ ] : [
232
+ trackClientRect.top,
233
+ trackClientRect.bottom,
234
+ e.pageY - document.documentElement.scrollTop
235
+ ];
236
+ return lerp(this.min, this.max, inverseLerp(minPos, maxPos, valuePos));
237
+ }
238
+ #roundToNearestStep(thumb, value) {
239
+ return limit(this.#thumbConstraints[thumb].min, this.#thumbConstraints[thumb].max, roundToStepValue(value - this.min, this.step) + this.min);
240
+ }
241
+ #isNonVisibleFocus = false;
242
+ #focusThumbNonVisibly(thumb) {
243
+ this.#isNonVisibleFocus = true;
244
+ thumb.focus();
245
+ this.#isNonVisibleFocus = false;
486
246
  }
487
247
  /**
488
- * Handle keyboard interaction for the select.
489
- *
490
- * @param e - the keyboard event
491
248
  * @internal
492
249
  */
493
- keydownHandler(e) {
494
- const selectedIndexBefore = this.selectedIndex;
495
- if (this.multiple) this.multipleKeydownHandler(e);
496
- else super.keydownHandler(e);
497
- switch (e.key) {
498
- case keySpace:
499
- e.preventDefault();
500
- if (this.collapsible && this.typeaheadExpired) this.open = !this.open;
501
- break;
502
- case keyHome:
503
- case keyEnd:
504
- e.preventDefault();
505
- break;
506
- case keyEnter:
507
- e.preventDefault();
508
- this.open = !this.open;
509
- break;
510
- case keyEscape:
511
- if (this.collapsible && this.open) {
512
- e.preventDefault();
513
- this.open = false;
514
- }
515
- break;
516
- case keyTab:
517
- if (this.collapsible && this.open) {
518
- e.preventDefault();
519
- this.open = false;
520
- }
521
- return true;
522
- }
523
- if (this.collapsible && !this.open && this.selectedIndex !== selectedIndexBefore) this.updateValue(true);
524
- return !(e.key === keyArrowDown || e.key === keyArrowUp);
250
+ _isThumbPopupOpen(thumb) {
251
+ return this._visiblyFocusedThumb === thumb || this._hoveredThumb === thumb || this._draggingThumb === thumb;
525
252
  }
526
253
  connectedCallback() {
527
254
  super.connectedCallback();
528
- this.addEventListener("focusout", this.focusoutHandler);
529
- this.addEventListener("contentchange", this.updateDisplayValue);
255
+ this.#updateValues({
256
+ start: this.start || this.initialStart || this.min.toString(),
257
+ end: this.end || this.initialEnd || this.max.toString()
258
+ }, false);
259
+ this.#registerThumbListeners();
260
+ this.#updateThumbPositions();
261
+ document.addEventListener("visibilitychange", this.#onVisibilityChange);
530
262
  }
531
263
  disconnectedCallback() {
532
- this.removeEventListener("focusout", this.focusoutHandler);
533
- this.removeEventListener("contentchange", this.updateDisplayValue);
534
264
  super.disconnectedCallback();
535
- }
536
- /**
537
- *
538
- * @internal
539
- */
540
- updateDisplayValue() {
541
- if (this.collapsible) Observable.notify(this, "displayValue");
542
- }
543
- get displayValue() {
544
- Observable.track(this, "displayValue");
545
- return this.firstSelectedOption?.getAttribute("label") ?? this.firstSelectedOption?.text ?? this.placeholder ?? "";
546
- }
547
- _newDefaultSelectedIndex(prev, next, currentSelectIndex) {
548
- const defaultSelectedIndex = super._newDefaultSelectedIndex(prev, next, currentSelectIndex);
549
- if (defaultSelectedIndex === null && currentSelectIndex === -1 && !this.placeholder) {
550
- const firstSelectableIndex = this.getNextSelectableIndex(0);
551
- if (firstSelectableIndex !== -1) return firstSelectableIndex;
265
+ this.#unregisterThumbListeners();
266
+ this.#unregisterDragListeners();
267
+ document.removeEventListener("visibilitychange", this.#onVisibilityChange);
268
+ }
269
+ #registerThumbListeners() {
270
+ for (const thumb of ["start", "end"]) {
271
+ this.#thumbs[thumb].addEventListener("keydown", this.#onThumbKeydown);
272
+ this.#thumbs[thumb].addEventListener("mousedown", this.#onThumbMousedown, { passive: true });
273
+ this.#thumbs[thumb].addEventListener("touchstart", this.#onThumbMousedown, { passive: true });
274
+ this.#thumbs[thumb].addEventListener("mouseover", this.#onMouseOver, { passive: true });
275
+ this.#thumbs[thumb].addEventListener("mouseout", this.#onMouseOut, { passive: true });
276
+ this.#thumbs[thumb].addEventListener("focus", this.#onThumbFocus);
277
+ this.#thumbs[thumb].addEventListener("blur", this.#onThumbBlur);
552
278
  }
553
- return defaultSelectedIndex;
554
- }
555
- _isDefaultSelected(option) {
556
- return super._isDefaultSelected(option) || option.value === this.initialValue || !this._isResetting && option.value === this.value;
557
- }
558
- slottedOptionsChanged(prev, next) {
559
- this.options.forEach((o) => {
560
- Observable.getNotifier(o).unsubscribe(this, "value");
561
- });
562
- super.slottedOptionsChanged(prev, next);
563
- this.options.forEach((o) => {
564
- Observable.getNotifier(o).subscribe(this, "value");
565
- });
566
- this.setProxyOptions();
567
- this.updateValue();
568
- const scale = this.getAttribute("scale") || this.scale;
569
- next.forEach((element) => {
570
- if (scale) {
571
- element.setAttribute("scale", scale);
572
- element.scale = scale;
573
- }
574
- });
575
- this.proxy.value = this.value;
576
- this.validate();
577
- }
578
- formResetCallback() {
579
- this.setProxyOptions();
580
- this._isResetting = true;
581
- this.selectedIndex = this._newDefaultSelectedIndex([], this.options, -1) ?? -1;
582
- this._isResetting = false;
583
- }
584
- /**
585
- * @internal
586
- */
587
- get _shouldShowClearButton() {
588
- if (!this.clearable) return false;
589
- if (this.multiple) return this.selectedOptions?.length > 0;
590
- return this.value !== "";
591
- }
592
- /**
593
- * @internal
594
- */
595
- _onClearButtonFocus() {
596
- this._isClearButtonFocused = true;
597
- this.activeIndex = -1;
598
- this.uncheckAllOptions();
599
279
  }
600
- /**
601
- * @internal
602
- */
603
- _onClearButtonBlur() {
604
- this._isClearButtonFocused = false;
605
- }
606
- /**
607
- * @internal
608
- */
609
- get _shouldShowLabelWrapper() {
610
- return Boolean(this.label || this._hasContextualHelp || this.multiple && this._shouldShowClearButton);
280
+ #unregisterThumbListeners() {
281
+ for (const thumb of ["start", "end"]) {
282
+ this.#thumbs[thumb].removeEventListener("keydown", this.#onThumbKeydown);
283
+ this.#thumbs[thumb].removeEventListener("mousedown", this.#onThumbMousedown);
284
+ this.#thumbs[thumb].removeEventListener("touchstart", this.#onThumbMousedown);
285
+ this.#thumbs[thumb].removeEventListener("mouseover", this.#onMouseOver);
286
+ this.#thumbs[thumb].removeEventListener("mouseout", this.#onMouseOut);
287
+ this.#thumbs[thumb].removeEventListener("focus", this.#onThumbFocus);
288
+ this.#thumbs[thumb].removeEventListener("blur", this.#onThumbBlur);
289
+ }
611
290
  }
612
291
  /**
613
292
  * @internal
614
293
  */
615
- _onClearButtonClick() {
616
- if (this.multiple) this.selectedOptions?.forEach((o) => {
617
- /* v8 ignore else -- @preserve */
618
- if (!o.disabled) o.selected = false;
619
- });
620
- else this.selectedIndex = -1;
621
- this.updateValue(true);
294
+ _onMouseDown(e) {
295
+ if (this.disabled || this._draggingThumb) return;
296
+ const value = this.#calculateValueFromMouseEvent(e);
297
+ const startDistance = Math.abs(value - Number(this.start));
298
+ const endDistance = Math.abs(value - Number(this.end));
299
+ const thumb = startDistance < endDistance || startDistance === endDistance && value < Number(this.start) ? "start" : "end";
300
+ this.#updateValues({ [thumb]: `${this.#roundToNearestStep(thumb, value)}` });
301
+ this._draggingThumb = thumb;
302
+ this.#focusThumbNonVisibly(this.#thumbs[thumb]);
303
+ this.#registerDragHandlers();
622
304
  }
305
+ #onThumbFocus = (e) => {
306
+ if (!this.#isNonVisibleFocus) this._visiblyFocusedThumb = this.#getThumbIdFromEvent(e);
307
+ this.#isNonVisibleFocus = false;
308
+ };
309
+ #onThumbBlur = () => {
310
+ this._visiblyFocusedThumb = null;
311
+ };
312
+ #onVisibilityChange = () => {
313
+ if (document.hidden && (this.shadowRoot.activeElement === this._startThumbEl || this.shadowRoot.activeElement === this._endThumbEl)) this.#isNonVisibleFocus = true;
314
+ };
315
+ #onMouseOver = (e) => {
316
+ this._hoveredThumb = this.#getThumbIdFromEvent(e);
317
+ };
318
+ #onMouseOut = () => {
319
+ this._hoveredThumb = null;
320
+ };
321
+ #onThumbMousedown = (event) => {
322
+ if (this.disabled || event.defaultPrevented) return;
323
+ let target = event.target;
324
+ if (target === this._endThumbEl && this.startAsNumber === this.max && this.endAsNumber === this.max) target = this._startThumbEl;
325
+ this.#focusThumbNonVisibly(target);
326
+ this._draggingThumb = this.#getThumbId(target);
327
+ this.#registerDragHandlers();
328
+ };
329
+ #onThumbKeydown = (e) => {
330
+ const thumb = this.#getThumbIdFromEvent(e);
331
+ this._visiblyFocusedThumb = thumb;
332
+ if (e.key === keyHome) {
333
+ e.preventDefault();
334
+ this.#updateValues({ [thumb]: `${this.#thumbConstraints[thumb].min}` });
335
+ } else if (e.key === keyEnd) {
336
+ e.preventDefault();
337
+ this.#updateValues({ [thumb]: `${this.#thumbConstraints[thumb].max}` });
338
+ } else {
339
+ if (e.shiftKey) return;
340
+ switch (e.key) {
341
+ case keyArrowRight$1:
342
+ case keyArrowDown:
343
+ e.preventDefault();
344
+ this.#applyStep(thumb, Direction$1.Increment);
345
+ break;
346
+ case keyArrowLeft$1:
347
+ case keyArrowUp:
348
+ e.preventDefault();
349
+ this.#applyStep(thumb, Direction$1.Decrement);
350
+ break;
351
+ }
352
+ }
353
+ };
354
+ #registerDragHandlers() {
355
+ window.addEventListener("mousemove", this.#onDragMove, { passive: true });
356
+ window.addEventListener("touchmove", this.#onDragMove, { passive: true });
357
+ window.addEventListener("mouseup", this.#onDragEnd);
358
+ window.addEventListener("touchend", this.#onDragEnd);
359
+ window.document.addEventListener("mouseleave", this.#onDragEnd);
360
+ }
361
+ #unregisterDragListeners() {
362
+ window.removeEventListener("mouseup", this.#onDragEnd);
363
+ window.document.removeEventListener("mouseleave", this.#onDragEnd);
364
+ window.removeEventListener("mousemove", this.#onDragMove);
365
+ window.removeEventListener("touchmove", this.#onDragMove);
366
+ window.removeEventListener("touchend", this.#onDragEnd);
367
+ }
368
+ #onDragMove = (e) => {
369
+ if (this.disabled || e.defaultPrevented || !this._draggingThumb) return;
370
+ const sourceEvent = "TouchEvent" in window && e instanceof TouchEvent ? e.touches[0] : e;
371
+ const value = this.#calculateValueFromMouseEvent(sourceEvent);
372
+ this.#updateValues({ [this._draggingThumb]: `${this.#roundToNearestStep(this._draggingThumb, value)}` });
373
+ };
374
+ #onDragEnd = () => {
375
+ this._draggingThumb = false;
376
+ this.#unregisterDragListeners();
377
+ };
623
378
  };
624
- __decorate([observable], Select.prototype, "activeIndex", void 0);
625
- __decorate([attr({ mode: "boolean" })], Select.prototype, "multiple", void 0);
379
+ __decorate([observable], RangeSlider.prototype, "start", void 0);
626
380
  __decorate([attr({
627
- attribute: "open",
628
- mode: "boolean"
629
- })], Select.prototype, "open", void 0);
630
- __decorate([volatile], Select.prototype, "collapsible", null);
631
- __decorate([observable], Select.prototype, "control", void 0);
632
- __decorate([observable], Select.prototype, "maxHeight", void 0);
633
- __decorate([observable], Select.prototype, "_anchor", void 0);
634
- __decorate([attr()], Select.prototype, "scale", void 0);
635
- __decorate([attr], Select.prototype, "appearance", void 0);
636
- __decorate([attr], Select.prototype, "shape", void 0);
381
+ mode: "fromView",
382
+ attribute: "start"
383
+ })], RangeSlider.prototype, "initialStart", void 0);
384
+ __decorate([attr({ attribute: "current-start" })], RangeSlider.prototype, "currentStart", void 0);
385
+ __decorate([observable], RangeSlider.prototype, "end", void 0);
637
386
  __decorate([attr({
638
- mode: "boolean",
639
- attribute: "fixed-dropdown"
640
- })], Select.prototype, "fixedDropdown", void 0);
641
- __decorate([attr], Select.prototype, "placeholder", void 0);
642
- __decorate([observable], Select.prototype, "_feedbackWrapper", void 0);
643
- __decorate([observable], Select.prototype, "metaSlottedContent", void 0);
644
- __decorate([attr({ mode: "boolean" })], Select.prototype, "clearable", void 0);
645
- __decorate([observable], Select.prototype, "_isClearButtonFocused", void 0);
646
- //#endregion
647
- //#region src/lib/select/select.scss?inline
648
- var select_default = ".label-wrapper{align-items:center;gap:var(--label-wrapper-gap,4px);flex-direction:row;display:flex}.label-wrapper[hidden]{display:none}.label:not(slot),.label::slotted(label){flex:0 auto}.chevron{font:var(--vvd-typography-base-extended);flex-shrink:0;transition:transform .2s;display:flex;transform:rotate(0)}:host([data-expanded=true]) .chevron,:host([open]) .chevron{transform:rotate(180deg)}:host(:focus-visible){outline:none}:host{--_low-ink-color:var(--vvd-color-neutral-600);--focus-stroke-gap-color:transparent;flex-direction:column;gap:4px;display:inline-flex}:host([disabled]){--_low-ink-color:var(--vvd-color-neutral-400);cursor:not-allowed}.label{color:var(--vvd-color-canvas-text);font:var(--vvd-typography-base)}.control{--_appearance-color-text:var(--vvd-color-canvas-text);--_appearance-color-fill:var(--vvd-color-canvas);--_appearance-color-outline:var(--vvd-color-neutral-500)}.control.appearance-ghost{--_appearance-color-text:var(--_connotation-color-firm);--_appearance-color-fill:transparent;--_appearance-color-outline:transparent}@media (hover:hover){.control:hover:where(:not(.disabled,:disabled,.readonly)){--_appearance-color-text:var(--vvd-color-canvas-text);--_appearance-color-fill:var(--vvd-color-canvas);--_appearance-color-outline:var(--vvd-color-neutral-700)}.control:hover:where(:not(.disabled,:disabled,.readonly)).appearance-ghost{--_appearance-color-text:var(--_connotation-color-firm);--_appearance-color-fill:var(--_connotation-color-faint);--_appearance-color-outline:transparent}}.control.hover:where(:not(.disabled,:disabled,.readonly)){--_appearance-color-text:var(--vvd-color-canvas-text);--_appearance-color-fill:var(--vvd-color-canvas);--_appearance-color-outline:var(--vvd-color-neutral-700)}.control.hover:where(:not(.disabled,:disabled,.readonly)).appearance-ghost{--_appearance-color-text:var(--_connotation-color-firm);--_appearance-color-fill:var(--_connotation-color-faint);--_appearance-color-outline:transparent}.control:disabled{--_appearance-color-text:var(--vvd-color-neutral-300);--_appearance-color-fill:var(--vvd-color-neutral-100);--_appearance-color-outline:var(--vvd-color-neutral-300)}.control:disabled.appearance-ghost{--_appearance-color-text:var(--vvd-color-neutral-300);--_appearance-color-fill:transparent;--_appearance-color-outline:transparent}.control.disabled{--_appearance-color-text:var(--vvd-color-neutral-300);--_appearance-color-fill:var(--vvd-color-neutral-100);--_appearance-color-outline:var(--vvd-color-neutral-300)}.control.disabled.appearance-ghost{--_appearance-color-text:var(--vvd-color-neutral-300);--_appearance-color-fill:transparent;--_appearance-color-outline:transparent}.control.readonly:where(:not(.disabled,:disabled)){--_appearance-color-text:var(--vvd-color-canvas-text);--_appearance-color-fill:var(--vvd-color-neutral-200);--_appearance-color-outline:var(--vvd-color-neutral-400)}.control.readonly:where(:not(.disabled,:disabled)).appearance-ghost{--_appearance-color-text:var(--vvd-color-neutral-600);--_appearance-color-fill:transparent;--_appearance-color-outline:transparent}.control.error:where(:not(.disabled,:disabled)){--_appearance-color-text:notSet;--_appearance-color-fill:var(--vvd-color-alert-50);--_appearance-color-outline:var(--vvd-color-alert-500)}.control.error:where(:not(.disabled,:disabled)).appearance-ghost{--_appearance-color-text:notSet;--_appearance-color-fill:var(--vvd-color-alert-50);--_appearance-color-outline:transparent}.control.success:where(:not(.disabled,:disabled)){--_appearance-color-text:notSet;--_appearance-color-fill:var(--vvd-color-success-50);--_appearance-color-outline:var(--vvd-color-success-500)}.control.success:where(:not(.disabled,:disabled)).appearance-ghost{--_appearance-color-text:notSet;--_appearance-color-fill:var(--vvd-color-success-50);--_appearance-color-outline:transparent}.control{--_connotation-color-primary:var(--vvd-select-accent-primary,var(--vvd-color-canvas-text));--_connotation-color-primary-text:var(--vvd-select-accent-primary-text,var(--vvd-color-canvas));--_connotation-color-primary-increment:var(--vvd-select-accent-primary-increment,var(--vvd-color-neutral-800));--_connotation-color-intermediate:var(--vvd-select-accent-intermediate,var(--vvd-color-neutral-500));--_connotation-color-faint:var(--vvd-select-accent-faint,var(--vvd-color-neutral-50));--_connotation-color-soft:var(--vvd-select-accent-soft,var(--vvd-color-neutral-100));--_connotation-color-firm:var(--vvd-select-accent-firm,var(--vvd-color-canvas-text));--_connotation-color-fierce:var(--vvd-select-accent-fierce,var(--vvd-color-neutral-700));border-radius:var(--_select-control-border-radius);block-size:var(--_select-block-size);padding-inline:var(--_select-padding-inline);--_select-icon-size:calc(calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2))) / 2);--_select-block-size:calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2)));--_select-padding-inline:calc(calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2))) / 2.5);background-color:var(--_appearance-color-fill);box-shadow:inset 0 0 0 1px var(--_appearance-color-outline);color:var(--_appearance-color-text);font:var(--vvd-typography-base);justify-content:space-between;align-items:center;gap:8px;transition:box-shadow .2s,background-color .2s;display:flex}.control.size-condensed{--_select-icon-size:calc(calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2))) / 2.5);--_select-block-size:calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2) - 8));--_select-padding-inline:calc(calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2) - 16)) / 2)}.control.size-condensed:not(.shape-pill){--_select-control-border-radius:4px}.control-wrapper{position:relative}.control:not(.disabled){cursor:pointer}.control.disabled{pointer-events:none}.control:not(.shape-pill){--_select-control-border-radius:8px}.control.shape-pill{--_select-control-border-radius:24px}.listbox{max-height:var(--select-height,408px);flex-direction:column;gap:2px;padding:4px;display:flex;overflow-y:auto}:host([multiple]:focus-visible) .listbox{box-shadow:0 0 0 4px color-mix(in srgb, var(--focus-stroke-color,var(--vvd-color-cta-500)), transparent 85%), inset 0 0 0 3px var(--focus-stroke-gap-color,currentColor);outline:1px solid var(--focus-stroke-color,var(--vvd-color-cta-500));outline-offset:calc(-1px - var(--focus-inset,0px));border-radius:8px}.selected-value{white-space:nowrap;flex-grow:1;align-items:center;column-gap:12px;display:flex;overflow:hidden}.selected-value .text{text-overflow:ellipsis;max-inline-size:100%;overflow:hidden}.control.shows-placeholder .selected-value .text{color:var(--vvd-color-neutral-600)}.selected-value slot[name=icon]{flex:0 0 var(--_select-icon-size);font-size:var(--_select-icon-size);line-height:1}.control.has-meta .selected-value{padding-inline-end:8px}.feedback-wrapper{display:contents}::part(popup-base){inline-size:max-content;min-inline-size:var(--_select-fixed-width,100%)}:host([multiple]) ::part(popup-base){position:static}@supports selector(:has(*)){:host(:focus-within) .control:not(.has-activedescendant,:has(.clear-button:focus)){--focus-stroke-gap-color:transparent;box-shadow:0 0 0 4px color-mix(in srgb, var(--focus-stroke-color,var(--vvd-color-cta-500)), transparent 85%), inset 0 0 0 3px var(--focus-stroke-gap-color,currentColor);outline:1px solid var(--focus-stroke-color,var(--vvd-color-cta-500));outline-offset:calc(-1px - var(--focus-inset,0px))}}@supports not selector(:has(*)){:host(:focus-within) .control:not(.has-activedescendant){--focus-stroke-gap-color:transparent;box-shadow:0 0 0 4px color-mix(in srgb, var(--focus-stroke-color,var(--vvd-color-cta-500)), transparent 85%), inset 0 0 0 3px var(--focus-stroke-gap-color,currentColor);outline:1px solid var(--focus-stroke-color,var(--vvd-color-cta-500));outline-offset:calc(-1px - var(--focus-inset,0px))}}:host(:not([multiple])) ::slotted([data-vvd-component=option][current-selected]){box-shadow:0 0 0 4px color-mix(in srgb, var(--focus-stroke-color,var(--vvd-color-cta-500)), transparent 85%), inset 0 0 0 3px var(--focus-stroke-gap-color,currentColor);outline:1px solid var(--focus-stroke-color,var(--vvd-color-cta-500));outline-offset:calc(-1px - var(--focus-inset,0px));--focus-stroke-gap-color:transparent;border-radius:8px}:host([multiple]) .clear-button{margin-inline-start:auto}:host([multiple][clearable]) .label-wrapper{min-block-size:calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2) - 16))}";
387
+ mode: "fromView",
388
+ attribute: "end"
389
+ })], RangeSlider.prototype, "initialEnd", void 0);
390
+ __decorate([attr({ attribute: "current-end" })], RangeSlider.prototype, "currentEnd", void 0);
391
+ __decorate([attr({ converter: nullableNumberConverter })], RangeSlider.prototype, "min", void 0);
392
+ __decorate([attr({ converter: nullableNumberConverter })], RangeSlider.prototype, "max", void 0);
393
+ __decorate([attr({ converter: defaultToOneConverter })], RangeSlider.prototype, "step", void 0);
394
+ __decorate([attr], RangeSlider.prototype, "orientation", void 0);
395
+ __decorate([attr({ attribute: "aria-start-label" })], RangeSlider.prototype, "ariaStartLabel", void 0);
396
+ __decorate([attr({ attribute: "aria-end-label" })], RangeSlider.prototype, "ariaEndLabel", void 0);
397
+ __decorate([attr({ mode: "boolean" })], RangeSlider.prototype, "markers", void 0);
398
+ __decorate([attr], RangeSlider.prototype, "connotation", void 0);
399
+ __decorate([attr({ mode: "boolean" })], RangeSlider.prototype, "pin", void 0);
400
+ __decorate([observable], RangeSlider.prototype, "valueTextFormatter", void 0);
401
+ __decorate([observable], RangeSlider.prototype, "_draggingThumb", void 0);
402
+ __decorate([observable], RangeSlider.prototype, "_visiblyFocusedThumb", void 0);
403
+ __decorate([observable], RangeSlider.prototype, "_hoveredThumb", void 0);
404
+ __decorate([observable], RangeSlider.prototype, "_startThumbCss", void 0);
405
+ __decorate([observable], RangeSlider.prototype, "_endThumbCss", void 0);
406
+ __decorate([observable], RangeSlider.prototype, "_selectedRangeCss", void 0);
649
407
  //#endregion
650
- //#region src/lib/select/select.template.ts
651
- var getStateClasses = ({ shape, disabled, appearance, metaSlottedContent, errorValidationMessage, successText, placeholder, value, scale, _activeDescendant, open }) => classNames(["has-activedescendant", Boolean(_activeDescendant) && open], ["disabled", disabled], [`appearance-${appearance}`, Boolean(appearance)], [`shape-${shape}`, Boolean(shape)], ["has-meta", Boolean(metaSlottedContent?.length)], ["error", Boolean(errorValidationMessage)], ["success", !!successText], ["shows-placeholder", Boolean(placeholder) && !value], [`size-${scale}`, Boolean(scale)]);
652
- function renderLabel() {
653
- return html` <label
654
- for="${(x) => x.multiple ? null : "control"}"
655
- class="label"
656
- id="label"
657
- >
658
- ${(x) => x.label}
659
- </label>`;
660
- }
661
- function renderPlaceholder(context) {
662
- const optionTag = context.tagFor(ListboxOption);
663
- return html`
664
- <${optionTag} text="${(x) => x.placeholder}" hidden disabled>
665
- </${optionTag}>`;
666
- }
667
- function renderClearButton(context) {
668
- const buttonTag = context.tagFor(Button);
669
- return html`
670
- <${buttonTag}
671
- aria-label="${(x) => x.locale.select.clearButtonLabel}"
672
- aria-hidden="${(x) => x._isClearButtonFocused ? "false" : "true"}"
673
- @click="${(x, c) => {
674
- x._onClearButtonClick();
675
- c.event.stopPropagation();
676
- }}"
677
- @mousedown="${() => false}"
678
- @keydown="${(x, c) => {
679
- /* v8 ignore next -- @preserve */
680
- if (c.event.key === "Tab") x._onClearButtonBlur();
681
- c.event.stopPropagation();
682
- return true;
683
- }}"
684
- @focusin="${(x, c) => {
685
- c.event.stopPropagation();
686
- x._onClearButtonFocus();
687
- }}"
688
- @focusout="${(x) => x._onClearButtonBlur()}"
689
- ?disabled="${(x) => x.disabled}"
690
- :shape="${(x) => x.shape}"
691
- size="super-condensed"
692
- icon="close-line"
693
- appearance="ghost-light"
694
- class="clear-button"
695
- tabindex="0"
696
- ></${buttonTag}>
697
- `;
698
- }
699
- function selectValue(context) {
700
- const affixIconTemplate = affixIconTemplateFactory(context);
701
- const chevronTemplate = chevronTemplateFactory(context);
702
- return html` <div
703
- class="control ${getStateClasses}"
704
- ${ref("_anchor")}
705
- id="control"
706
- ?disabled="${(x) => x.disabled}"
707
- >
708
- <div class="selected-value">
709
- ${(x) => affixIconTemplate(x.icon, IconWrapper.Slot)}
710
- <span class="text">${(x) => x.displayValue}</span>
711
- <slot name="meta" ${slotted("metaSlottedContent")}></slot>
712
- </div>
713
- ${when((x) => x._shouldShowClearButton, renderClearButton(context))}
714
- ${chevronTemplate}
715
- </div>`;
716
- }
717
- function setFixedDropdownVarWidth(x) {
718
- return x.open && x.fixedDropdown ? `--_select-fixed-width: ${Math.round(x.getBoundingClientRect().width)}px` : null;
719
- }
720
- /**
721
- * @param context - element definition context
722
- */
723
- function renderControl(context) {
408
+ //#region src/lib/range-slider/range-slider.template.ts
409
+ var getClasses = ({ disabled, connotation }) => classNames("control", ["disabled", Boolean(disabled)], [`connotation-${connotation}`, Boolean(connotation)]);
410
+ var getThumbClassesFor = (thumb) => ({ _visiblyFocusedThumb }) => classNames("thumb-container", ["focus-visible", _visiblyFocusedThumb === thumb]);
411
+ var RangeSliderTemplate = (context) => {
724
412
  const popupTag = context.tagFor(Popup);
725
- return html`
726
- <div class="label-wrapper" ?hidden=${(x) => !x._shouldShowLabelWrapper}>
727
- ${when((x) => x.label, renderLabel())}
728
- ${when((x) => x.multiple && x._shouldShowClearButton, renderClearButton(context))}
729
- <slot name="contextual-help" ${slotted("_contextualHelpSlottedContent")}></slot>
730
- </div>
731
- <div class="control-wrapper">
732
- ${when((x) => !x.multiple, selectValue(context))}
733
- <${popupTag} class="popup"
734
- style="${setFixedDropdownVarWidth}"
735
- ?open="${(x) => x.collapsible ? x.open : true}"
736
- :anchor="${(x) => x._anchor}"
737
- placement="bottom-start"
738
- strategy="${(x) => x.fixedDropdown ? null : "absolute"}">
739
- <div class="listbox"
740
- id="${(x) => x.listboxId}"
741
- role="listbox"
742
- aria-multiselectable="${(x) => x.multiple}"
743
- aria-label="${(x) => x.multiple && !x.label && x.ariaLabel ? x.ariaLabel : null}"
744
- aria-labelledby="${(x) => x.multiple && x.label ? "label" : null}"
745
- ?disabled="${(x) => x.disabled}"
746
- ?hidden="${(x) => x.collapsible ? !x.open : false}"
747
- ${ref("listbox")}>
748
- ${when((x) => x.placeholder, renderPlaceholder(context))}
749
- <slot
750
- ${slotted({
751
- filter: Listbox.slottedOptionFilter,
752
- flatten: true,
753
- property: "slottedOptions"
754
- })}>
755
- </slot>
756
- </div>
757
- </${popupTag}>
758
- </div>
759
- `;
760
- }
761
- /**
762
- * Ignore events that originate from feedback, e.g. a click on link
763
- */
764
- function ifNotFromFeedback(handler) {
765
- return (x, c) => {
766
- if (!c.event.composedPath().includes(x._feedbackWrapper)) return handler(x, c.event);
767
- return true;
768
- };
769
- }
770
- var SelectTemplate = (context) => {
771
- return html`
772
- <template
773
- ${applyHostSemantics({
774
- role: "combobox",
775
- ariaLabel: (x) => x.ariaLabel ?? x.label,
776
- ariaHasPopup: (x) => x.collapsible ? "listbox" : "false",
777
- ariaExpanded: (x) => x.open,
778
- ariaDisabled: (x) => x.disabled
779
- })}
780
- aria-controls="${(x) => x.listboxId}"
781
- aria-activedescendant="${(x) => x.open ? x._activeDescendant : null}"
782
- aria-describedby="${(x) => x._feedbackDescribedBy}"
783
- tabindex="${(x) => !x.disabled ? "0" : null}"
784
- @click="${ifNotFromFeedback((x, e) => x.clickHandler(e))}"
785
- @focusin="${ifNotFromFeedback((x, e) => x.focusinHandler(e))}"
786
- @focusout="${ifNotFromFeedback((x, e) => x.focusoutHandler(e))}"
787
- @keydown="${ifNotFromFeedback((x, e) => {
788
- x.open && handleEscapeKeyAndStopPropogation(e);
789
- return x.keydownHandler(e);
790
- })}"
791
- @mousedown="${ifNotFromFeedback((x, e) => x.mousedownHandler(e))}"
792
- >
793
- ${renderControl(context)}
794
- <div class="feedback-wrapper" ${ref("_feedbackWrapper")}>
795
- ${(x) => x._getFeedbackTemplate(context)}
413
+ return html` <template
414
+ @mousedown="${(x, c) => x._onMouseDown(c.event)}"
415
+ >
416
+ <div class="${getClasses} ${(x) => x.orientation}">
417
+ <div class="positioning-region">
418
+ <div ${ref("_trackEl")} class="track">
419
+ <div class="track-start" style="${(x) => x._selectedRangeCss}"></div>
420
+ ${when((x) => x.markers, html`${(x) => getMarkersTemplate(x.orientation === Orientation.horizontal, Math.floor((x.max - x.min) / x.step))}`)}
421
+ </div>
422
+ <div
423
+ id="start-thumb"
424
+ ${ref("_startThumbEl")}
425
+ class="${getThumbClassesFor("start")}"
426
+ style="${(x) => x._startThumbCss}"
427
+ role="slider"
428
+ tabindex="${(x) => x.disabled ? null : 0}"
429
+ aria-label="${(x) => x.ariaStartLabel || x.locale.rangeSlider.startThumbLabel}"
430
+ aria-valuetext="${(x) => x.valueTextFormatter(x.start)}"
431
+ aria-valuenow="${(x) => x.start}"
432
+ aria-valuemin="${(x) => x.min}"
433
+ aria-valuemax="${(x) => x.end}"
434
+ aria-disabled="${(x) => x.disabled}"
435
+ aria-orientation="${(x) => x.orientation}"
436
+ ></div>
437
+ ${when((x) => x.pin, html`<${popupTag}
438
+ class="popup"
439
+ arrow
440
+ alternate
441
+ :anchor="${(x) => x._startThumbEl}"
442
+ :open=${(x) => x._isThumbPopupOpen("start")}
443
+ :placementStrategy=${(x) => x.orientation === Orientation.horizontal ? PlacementStrategy.AutoPlacementHorizontal : PlacementStrategy.AutoPlacementVertical}
444
+ animation-frame
445
+ exportparts="vvd-theme-alternate"
446
+ aria-hidden="true"
447
+ >
448
+ <div class="tooltip">${(x) => x.valueTextFormatter(x.start)}</div>
449
+ </${popupTag}>`)}
450
+ <div
451
+ id="end-thumb"
452
+ ${ref("_endThumbEl")}
453
+ class="${getThumbClassesFor("end")}"
454
+ style="${(x) => x._endThumbCss}"
455
+ role="slider"
456
+ tabindex="${(x) => x.disabled ? null : 0}"
457
+ aria-label="${(x) => x.ariaEndLabel || x.locale.rangeSlider.endThumbLabel}"
458
+ aria-valuetext="${(x) => x.valueTextFormatter(x.end)}"
459
+ aria-valuenow="${(x) => x.end}"
460
+ aria-valuemin="${(x) => x.start}"
461
+ aria-valuemax="${(x) => x.max}"
462
+ aria-disabled="${(x) => x.disabled}"
463
+ aria-orientation="${(x) => x.orientation}"
464
+ ></div>
465
+ ${when((x) => x.pin, html`<${popupTag}
466
+ class="popup"
467
+ arrow
468
+ alternate
469
+ :anchor="${(x) => x._endThumbEl}"
470
+ :open=${(x) => x._isThumbPopupOpen("end")}
471
+ :placementStrategy=${(x) => x.orientation === Orientation.horizontal ? PlacementStrategy.AutoPlacementHorizontal : PlacementStrategy.AutoPlacementVertical}
472
+ animation-frame
473
+ exportparts="vvd-theme-alternate"
474
+ aria-hidden="true"
475
+ >
476
+ <div class="tooltip">${(x) => x.valueTextFormatter(x.end)}</div>
477
+ </${popupTag}>`)}
796
478
  </div>
797
- </template>
798
- `;
479
+ </div>
480
+ </template>`;
799
481
  };
800
482
  //#endregion
801
- //#region src/lib/select/definition.ts
483
+ //#region src/lib/range-slider/definition.ts
802
484
  /**
803
485
  * @internal
804
486
  */
805
- var selectDefinition = defineVividComponent("select", Select, SelectTemplate, [
806
- popupDefinition,
807
- iconDefinition,
808
- listboxOptionDefinition,
809
- buttonDefinition,
810
- feedbackMessageDefinition
811
- ], { styles: select_default });
487
+ var rangeSliderDefinition = defineVividComponent("range-slider", RangeSlider, RangeSliderTemplate, [popupDefinition], {
488
+ styles: range_slider_default,
489
+ shadowOptions: { delegatesFocus: true }
490
+ });
812
491
  /**
813
- * Registers the select elements with the design system.
492
+ * Registers the range-slider element with the design system.
814
493
  *
815
494
  * @param prefix - the prefix to use for the component name
816
495
  */
817
- var registerSelect = createRegisterFunction(selectDefinition);
496
+ var registerRangeSlider = createRegisterFunction(rangeSliderDefinition);
818
497
  //#endregion
819
- export { selectDefinition as n, Select as r, registerSelect as t };
498
+ export { registerRangeSlider as n, RangeSlider as r, rangeSliderDefinition as t };