@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,68 +1,425 @@
1
- import { d as e, l as t, o as n, s as r, t as i } from "./vivid-element.js";
2
- import { t as a } from "./decorate.js";
3
- import { t as o } from "./class-names.js";
4
- import { t as s } from "./dialog.js";
5
- import { i as c, t as l } from "./definition8.js";
6
- import { n as u, t as d } from "./anchored.js";
7
- //#region src/lib/tooltip/tooltip.ts
8
- var f = class extends d(i) {
1
+ import { t as e } from "./localized.js";
2
+ import { E as t, O as n, T as r, d as i, l as a, o, s, w as c } from "./vivid-element.js";
3
+ import { t as l } from "./ref.js";
4
+ import { t as u } from "./when.js";
5
+ import { t as d } from "./slotted.js";
6
+ import { t as f } from "./decorate.js";
7
+ import { t as p } from "./definition2.js";
8
+ import { a as m, i as h, n as g } from "./affix.js";
9
+ import { t as _ } from "./form-element.js";
10
+ import { t as v } from "./with-success-text.js";
11
+ import { t as y } from "./with-error-text.js";
12
+ import { t as b } from "./with-contextual-help.js";
13
+ import { t as x } from "./listbox.js";
14
+ import { t as S } from "./class-names.js";
15
+ import { a as C, i as w, o as T, s as E, t as D } from "./key-codes.js";
16
+ import { t as O } from "./numbers.js";
17
+ import { t as k } from "./strings.js";
18
+ import { n as A, t as j } from "./host-semantics.js";
19
+ import { n as M } from "./form-associated.js";
20
+ import { i as N, r as P, t as F } from "./definition6.js";
21
+ import { i as I, t as L } from "./definition8.js";
22
+ import { t as ee } from "./dialog.js";
23
+ import { a as R, n as z } from "./mixins.js";
24
+ import { r as B, t as V } from "./definition17.js";
25
+ //#region src/lib/select/select.scss?inline
26
+ var H = ".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]):focus-visible) ::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))}", U = class extends z(b(y(v(e(_(j(g(M(x))))))))) {
9
27
  constructor(...e) {
10
- super(...e), this.open = !1;
28
+ super(...e), this.proxy = document.createElement("select"), this.activeIndex = -1, this.rangeStartIndex = -1, this.open = !1, this.listboxId = k("listbox-"), this.maxHeight = 0, this.fixedDropdown = !1, this._feedbackWrapper = null, this._isResetting = !1, this.clearable = !1, this._isClearButtonFocused = !1;
29
+ }
30
+ get activeOption() {
31
+ return this.options[this.activeIndex];
32
+ }
33
+ get checkedOptions() {
34
+ return this.options.filter((e) => e.checked);
35
+ }
36
+ get firstSelectedOptionIndex() {
37
+ return this.options.indexOf(this.firstSelectedOption);
38
+ }
39
+ activeIndexChanged(e, t) {
40
+ this._activeDescendant = this.options[t]?.id ?? "", this.focusAndScrollOptionIntoView();
41
+ }
42
+ checkActiveIndex() {
43
+ let e = this.activeOption;
44
+ /* v8 ignore else -- @preserve */
45
+ e && (e.checked = !0);
46
+ }
47
+ checkFirstOption(e) {
48
+ let t = this.getNextSelectableIndex(0);
49
+ t !== -1 && (e ? (this.rangeStartIndex === -1 && (this.rangeStartIndex = this.activeIndex), this.options.forEach((e, n) => {
50
+ e.checked = O(n, t, this.rangeStartIndex + 1) && !e.disabled;
51
+ })) : this.uncheckAllOptions(), this.activeIndex = t, this.checkActiveIndex());
52
+ }
53
+ checkLastOption(e) {
54
+ let t = this.getPreviousSelectableIndex(this.length - 1);
55
+ t !== -1 && (e ? (this.rangeStartIndex === -1 && (this.rangeStartIndex = this.activeIndex), this.options.forEach((e, n) => {
56
+ e.checked = O(n, this.rangeStartIndex, t + 1) && !e.disabled;
57
+ })) : this.uncheckAllOptions(), this.activeIndex = t, this.checkActiveIndex());
58
+ }
59
+ checkNextOption(e) {
60
+ let t = this.getNextSelectableIndex(this.activeIndex + 1);
61
+ t !== -1 && (e ? (this.rangeStartIndex === -1 && (this.rangeStartIndex = this.activeIndex), this.options.forEach((e, n) => {
62
+ e.checked = O(n, this.rangeStartIndex, t + 1) && !e.disabled;
63
+ })) : this.uncheckAllOptions(), this.activeIndex = t, this.checkActiveIndex());
64
+ }
65
+ checkPreviousOption(e) {
66
+ let t = this.getPreviousSelectableIndex(this.activeIndex - 1);
67
+ t !== -1 && (e ? (this.rangeStartIndex === -1 && (this.rangeStartIndex = this.activeIndex), this.checkedOptions.length === 1 && (this.rangeStartIndex += 1), this.options.forEach((e, n) => {
68
+ e.checked = O(n, t, this.rangeStartIndex + 1) && !e.disabled;
69
+ })) : this.uncheckAllOptions(), this.activeIndex = t, this.checkActiveIndex());
70
+ }
71
+ focusAndScrollOptionIntoView() {
72
+ super.focusAndScrollOptionIntoView(this.activeOption);
73
+ }
74
+ focusinHandler(e) {
75
+ if (!this.multiple) return super.focusinHandler(e);
76
+ !this.shouldSkipFocus && e.target === e.currentTarget && (this.uncheckAllOptions(), this.activeIndex === -1 && (this.activeIndex = this.firstSelectedOptionIndex === -1 ? 0 : this.firstSelectedOptionIndex), this.checkActiveIndex(), this.setSelectedOptions(), this.focusAndScrollOptionIntoView()), this.shouldSkipFocus = !1;
77
+ }
78
+ setSelectedOptions() {
79
+ if (!this.multiple) {
80
+ super.setSelectedOptions();
81
+ return;
82
+ }
83
+ /* v8 ignore else -- @preserve */
84
+ this.$fastController.isConnected && this.options && (this.selectedOptions = this.options.filter((e) => e.selected), this.focusAndScrollOptionIntoView());
85
+ }
86
+ toggleSelectedForAllCheckedOptions() {
87
+ let e = this.checkedOptions.filter((e) => !e.disabled), t = !e.every((e) => e.selected);
88
+ e.forEach((e) => e.selected = t), this.selectedIndex = this.options.indexOf(e[e.length - 1]), this.setSelectedOptions(), this.updateValue(!0);
89
+ }
90
+ typeaheadBufferChanged(e, t) {
91
+ if (!this.multiple) {
92
+ super.typeaheadBufferChanged(e, t);
93
+ return;
94
+ }
95
+ /* v8 ignore if -- @preserve */
96
+ if (this.$fastController.isConnected) {
97
+ let e = this.getTypeaheadMatches(), t = this.options.indexOf(e[0]);
98
+ t > -1 && (this.activeIndex = t, this.uncheckAllOptions(), this.checkActiveIndex()), this.typeaheadExpired = !1;
99
+ }
100
+ }
101
+ uncheckAllOptions(e = !1) {
102
+ /* v8 ignore else -- @preserve */
103
+ this.options.forEach((e) => e.checked = !1), e || (this.rangeStartIndex = -1);
104
+ }
105
+ openChanged(e, t) {
106
+ if (!this.collapsible) return;
107
+ if (this.open) {
108
+ this.focusAndScrollOptionIntoView(), this.indexWhenOpened = this.selectedIndex, n.enqueue(() => this.focus());
109
+ return;
110
+ }
111
+ let r = e === !0 && t === !1, i = this.indexWhenOpened !== this.selectedIndex;
112
+ r && i && this.updateValue(!0);
113
+ }
114
+ get collapsible() {
115
+ return !this.multiple;
116
+ }
117
+ valueChanged(e, t) {
118
+ let n = this.options.findIndex((e) => e.value === t), r = this._validSelectedIndex(n), i = this.options[r]?.value ?? "";
119
+ this.selectedIndex !== r && (this.selectedIndex = r), t === i && (super.valueChanged(e, t), this.updateDisplayValue());
120
+ }
121
+ updateValue(e) {
122
+ this.$fastController.isConnected && (this.value = this.firstSelectedOption?.value ?? ""), e && (this.$emit("input"), this.$emit("change", this, {
123
+ bubbles: !0,
124
+ composed: void 0
125
+ }));
126
+ }
127
+ selectedIndexChanged(e, t) {
128
+ super.selectedIndexChanged(e, t), this.updateValue();
129
+ }
130
+ clickHandler(e) {
131
+ if (this.disabled || this._isFromContextualHelp(e)) return;
132
+ let t = e.target.closest("option,[role=option],[data-vvd-component=option]");
133
+ if (!(t && t.disabled)) return this.multiple ? (this.uncheckAllOptions(), this.activeIndex = this.options.indexOf(t), this.checkActiveIndex(), this.toggleSelectedForAllCheckedOptions()) : super.clickHandler(e), this.collapsible && (this.open = !this.open), !0;
134
+ }
135
+ focusoutHandler(e) {
136
+ if (this.multiple && this.uncheckAllOptions(), !this.open) return !0;
137
+ let t = e.relatedTarget;
138
+ if (this.isSameNode(t)) {
139
+ this.focus();
140
+ return;
141
+ }
142
+ /* v8 ignore else -- @preserve */
143
+ this.options.includes(t) || (this.open = !1, this.indexWhenOpened !== this.selectedIndex && this.updateValue(!0));
144
+ }
145
+ handleChange(e, t) {
146
+ super.handleChange(e, t), t === "value" && this.updateValue();
147
+ }
148
+ mousedownHandler(e) {
149
+ return e.offsetX >= 0 && e.offsetX <= this.listbox.scrollWidth ? super.mousedownHandler(e) : this.collapsible;
150
+ }
151
+ multipleChanged(e, t) {
152
+ /* v8 ignore if -- @preserve */
153
+ this.options.forEach((e) => {
154
+ e.checked = t ? !1 : void 0;
155
+ }), this.setSelectedOptions(), this.proxy && (this.proxy.multiple = t);
156
+ }
157
+ selectedOptionsChanged(e, t) {
158
+ super.selectedOptionsChanged(e, t), this.options.forEach((e, t) => {
159
+ let n = this.proxy.options.item(t);
160
+ n && (n.selected = e.selected);
161
+ });
162
+ }
163
+ setProxyOptions() {
164
+ /* v8 ignore else -- @preserve */
165
+ this.proxy instanceof HTMLSelectElement && this.options && (this.proxy.length = 0, this.options.forEach((e) => {
166
+ let t = e.proxy || (e instanceof HTMLOptionElement ? e.cloneNode() : null);
167
+ t && this.proxy.options.add(t);
168
+ }));
169
+ }
170
+ multipleKeydownHandler(e) {
171
+ if (this.disabled) return;
172
+ let { key: t, shiftKey: n } = e;
173
+ switch (this.shouldSkipFocus = !1, t) {
174
+ case E:
175
+ this.checkFirstOption(n);
176
+ return;
177
+ case D:
178
+ this.checkNextOption(n);
179
+ return;
180
+ case w:
181
+ this.checkPreviousOption(n);
182
+ return;
183
+ case "End":
184
+ this.checkLastOption(n);
185
+ return;
186
+ case "Tab":
187
+ this.focusAndScrollOptionIntoView();
188
+ return;
189
+ case T:
190
+ this.uncheckAllOptions(), this.checkActiveIndex();
191
+ return;
192
+ case " ":
193
+ /* v8 ignore else -- @preserve */
194
+ if (e.preventDefault(), this.typeaheadExpired) {
195
+ this.toggleSelectedForAllCheckedOptions();
196
+ return;
197
+ }
198
+ default:
199
+ /* v8 ignore else -- @preserve */
200
+ t.length === 1 && this.handleTypeAhead(`${t}`);
201
+ return;
202
+ }
203
+ }
204
+ keydownHandler(e) {
205
+ let t = this.selectedIndex;
206
+ switch (this.multiple ? this.multipleKeydownHandler(e) : super.keydownHandler(e), e.key) {
207
+ case " ":
208
+ e.preventDefault(), this.collapsible && this.typeaheadExpired && (this.open = !this.open);
209
+ break;
210
+ case E:
211
+ case "End":
212
+ e.preventDefault();
213
+ break;
214
+ case C:
215
+ e.preventDefault(), this.open = !this.open;
216
+ break;
217
+ case T:
218
+ this.collapsible && this.open && (e.preventDefault(), this.open = !1);
219
+ break;
220
+ case "Tab": return this.collapsible && this.open && (e.preventDefault(), this.open = !1), !0;
221
+ }
222
+ return this.collapsible && !this.open && this.selectedIndex !== t && this.updateValue(!0), !(e.key === "ArrowDown" || e.key === "ArrowUp");
11
223
  }
12
224
  connectedCallback() {
13
- super.connectedCallback(), this.#a();
225
+ super.connectedCallback(), this.addEventListener("focusout", this.focusoutHandler), this.addEventListener("contentchange", this.updateDisplayValue);
14
226
  }
15
227
  disconnectedCallback() {
16
- super.disconnectedCallback(), this.#a();
228
+ this.removeEventListener("focusout", this.focusoutHandler), this.removeEventListener("contentchange", this.updateDisplayValue), super.disconnectedCallback();
17
229
  }
18
- _anchorElChanged(e, t) {
19
- e && this.#t(e), t && this.#e(t);
230
+ updateDisplayValue() {
231
+ this.collapsible && c.notify(this, "displayValue");
20
232
  }
21
- #e(e) {
22
- e.addEventListener("mouseover", this.#n), e.addEventListener("mouseout", this.#r), e.addEventListener("focusin", this.#n), e.addEventListener("focusout", this.#r), e.setAttribute("aria-haspopup", "true"), e.setAttribute("aria-expanded", String(this.open));
233
+ get displayValue() {
234
+ return c.track(this, "displayValue"), this.firstSelectedOption?.getAttribute("label") ?? this.firstSelectedOption?.text ?? this.placeholder ?? "";
23
235
  }
24
- #t(e) {
25
- e.removeEventListener("mouseover", this.#n), e.removeEventListener("mouseout", this.#r), e.removeEventListener("focusin", this.#n), e.removeEventListener("focusout", this.#r), e.removeAttribute("aria-haspopup"), e.removeAttribute("aria-expanded");
236
+ _newDefaultSelectedIndex(e, t, n) {
237
+ let r = super._newDefaultSelectedIndex(e, t, n);
238
+ if (r === null && n === -1 && !this.placeholder) {
239
+ let e = this.getNextSelectableIndex(0);
240
+ if (e !== -1) return e;
241
+ }
242
+ return r;
26
243
  }
27
- #n = () => {
28
- this.open = !0, this.#i();
29
- };
30
- #r = () => {
31
- this.open = !1, this.#i();
32
- };
33
- #i() {
34
- this._anchorEl && this._anchorEl.setAttribute("aria-expanded", String(this.open));
244
+ _isDefaultSelected(e) {
245
+ return super._isDefaultSelected(e) || e.value === this.initialValue || !this._isResetting && e.value === this.value;
35
246
  }
36
- #a() {
37
- document.removeEventListener("keydown", this.#o), this.open && this.isConnected && document.addEventListener("keydown", this.#o);
247
+ slottedOptionsChanged(e, t) {
248
+ this.options.forEach((e) => {
249
+ c.getNotifier(e).unsubscribe(this, "value");
250
+ }), super.slottedOptionsChanged(e, t), this.options.forEach((e) => {
251
+ c.getNotifier(e).subscribe(this, "value");
252
+ }), this.setProxyOptions(), this.updateValue();
253
+ let n = this.getAttribute("scale") || this.scale;
254
+ t.forEach((e) => {
255
+ n && (e.setAttribute("scale", n), e.scale = n);
256
+ }), this.proxy.value = this.value, this.validate();
38
257
  }
39
- #o = (e) => {
40
- /* v8 ignore else -- @preserve */
41
- e.key === "Escape" && this.#r();
42
- };
43
- openChanged(e) {
44
- e !== void 0 && this.#a();
258
+ formResetCallback() {
259
+ this.setProxyOptions(), this._isResetting = !0, this.selectedIndex = this._newDefaultSelectedIndex([], this.options, -1) ?? -1, this._isResetting = !1;
260
+ }
261
+ get _shouldShowClearButton() {
262
+ return this.clearable ? this.multiple ? this.selectedOptions?.length > 0 : this.value !== "" : !1;
263
+ }
264
+ _onClearButtonFocus() {
265
+ this._isClearButtonFocused = !0, this.activeIndex = -1, this.uncheckAllOptions();
266
+ }
267
+ _onClearButtonBlur() {
268
+ this._isClearButtonFocused = !1;
269
+ }
270
+ get _shouldShowLabelWrapper() {
271
+ return !!(this.label || this._hasContextualHelp || this.multiple && this._shouldShowClearButton);
272
+ }
273
+ _onClearButtonClick() {
274
+ this.multiple ? this.selectedOptions?.forEach((e) => {
275
+ /* v8 ignore else -- @preserve */
276
+ e.disabled || (e.selected = !1);
277
+ }) : this.selectedIndex = -1, this.updateValue(!0);
45
278
  }
46
279
  };
47
- a([t], f.prototype, "text", void 0), a([t({ mode: "fromView" })], f.prototype, "placement", void 0), a([t({ mode: "boolean" })], f.prototype, "open", void 0);
280
+ f([r], U.prototype, "activeIndex", void 0), f([a({ mode: "boolean" })], U.prototype, "multiple", void 0), f([a({
281
+ attribute: "open",
282
+ mode: "boolean"
283
+ })], U.prototype, "open", void 0), f([t], U.prototype, "collapsible", null), f([r], U.prototype, "control", void 0), f([r], U.prototype, "maxHeight", void 0), f([r], U.prototype, "_anchor", void 0), f([a()], U.prototype, "scale", void 0), f([a], U.prototype, "appearance", void 0), f([a], U.prototype, "shape", void 0), f([a({
284
+ mode: "boolean",
285
+ attribute: "fixed-dropdown"
286
+ })], U.prototype, "fixedDropdown", void 0), f([a], U.prototype, "placeholder", void 0), f([r], U.prototype, "_feedbackWrapper", void 0), f([r], U.prototype, "metaSlottedContent", void 0), f([a({ mode: "boolean" })], U.prototype, "clearable", void 0), f([r], U.prototype, "_isClearButtonFocused", void 0);
48
287
  //#endregion
49
- //#region src/lib/tooltip/tooltip.scss?inline
50
- var p = ":host :host{display:var(--_popup-display,inline)}:host :host([slotted-anchor]){--_popup-display:contents}.control{pointer-events:none}.tooltip{width:var(--tooltip-inline-size,auto);box-sizing:border-box;color:var(--vvd-color-canvas-text);font:var(--vvd-typography-base-bold);max-inline-size:var(--tooltip-max-inline-size,30ch);padding:8px 12px}", m = ({ open: e }) => o("control", ["open", !!e]), h = n("tooltip", f, (t) => {
51
- let n = t.tagFor(c);
52
- return e`
53
- ${u()}
54
- <${n} class="${m}" arrow alternate
55
- :placement=${(e) => e.placement}
56
- :anchor="${(e) => e._anchorEl}"
57
- :open="${(e) => e.open}"
58
- @keydown="${(e, t) => {
59
- e.open && s(t.event) && (e.open = !1);
288
+ //#region src/lib/select/select.template.ts
289
+ var W = ({ shape: e, disabled: t, appearance: n, metaSlottedContent: r, errorValidationMessage: i, successText: a, placeholder: o, value: s, scale: c, _activeDescendant: l, open: u }) => S(["has-activedescendant", !!l && u], ["disabled", t], [`appearance-${n}`, !!n], [`shape-${e}`, !!e], ["has-meta", !!r?.length], ["error", !!i], ["success", !!a], ["shows-placeholder", !!o && !s], [`size-${c}`, !!c]);
290
+ function G() {
291
+ return i` <label
292
+ for="${(e) => e.multiple ? null : "control"}"
293
+ class="label"
294
+ id="label"
295
+ >
296
+ ${(e) => e.label}
297
+ </label>`;
298
+ }
299
+ function K(e) {
300
+ let t = e.tagFor(B);
301
+ return i`
302
+ <${t} text="${(e) => e.placeholder}" hidden disabled>
303
+ </${t}>`;
304
+ }
305
+ function q(e) {
306
+ let t = e.tagFor(N);
307
+ return i`
308
+ <${t}
309
+ aria-label="${(e) => e.locale.select.clearButtonLabel}"
310
+ aria-hidden="${(e) => e._isClearButtonFocused ? "false" : "true"}"
311
+ @click="${(e, t) => {
312
+ e._onClearButtonClick(), t.event.stopPropagation();
60
313
  }}"
61
- exportparts="vvd-theme-alternate">
62
- <div part="vvd-theme-alternate" class="tooltip" role="tooltip">
63
- ${(e) => e.text}
64
- </div>
65
- </${n}>`;
66
- }, [l], { styles: p }), g = r(h);
314
+ @mousedown="${() => !1}"
315
+ @keydown="${(e, t) => (t.event.key === "Tab" && e._onClearButtonBlur(), t.event.stopPropagation(), !0)}"
316
+ @focusin="${(e, t) => {
317
+ t.event.stopPropagation(), e._onClearButtonFocus();
318
+ }}"
319
+ @focusout="${(e) => e._onClearButtonBlur()}"
320
+ ?disabled="${(e) => e.disabled}"
321
+ :shape="${(e) => e.shape}"
322
+ size="super-condensed"
323
+ icon="close-line"
324
+ appearance="ghost-light"
325
+ class="clear-button"
326
+ tabindex="0"
327
+ ></${t}>
328
+ `;
329
+ }
330
+ function J(e) {
331
+ let t = m(e), n = P(e);
332
+ return i` <div
333
+ class="control ${W}"
334
+ ${l("_anchor")}
335
+ id="control"
336
+ ?disabled="${(e) => e.disabled}"
337
+ >
338
+ <div class="selected-value">
339
+ ${(e) => t(e.icon, h.Slot)}
340
+ <span class="text">${(e) => e.displayValue}</span>
341
+ <slot name="meta" ${d("metaSlottedContent")}></slot>
342
+ </div>
343
+ ${u((e) => e._shouldShowClearButton, q(e))}
344
+ ${n}
345
+ </div>`;
346
+ }
347
+ function Y(e) {
348
+ return e.open && e.fixedDropdown ? `--_select-fixed-width: ${Math.round(e.getBoundingClientRect().width)}px` : null;
349
+ }
350
+ function X(e) {
351
+ let t = e.tagFor(I);
352
+ return i`
353
+ <div class="label-wrapper" ?hidden=${(e) => !e._shouldShowLabelWrapper}>
354
+ ${u((e) => e.label, G())}
355
+ ${u((e) => e.multiple && e._shouldShowClearButton, q(e))}
356
+ <slot name="contextual-help" ${d("_contextualHelpSlottedContent")}></slot>
357
+ </div>
358
+ <div class="control-wrapper">
359
+ ${u((e) => !e.multiple, J(e))}
360
+ <${t} class="popup"
361
+ style="${Y}"
362
+ ?open="${(e) => e.collapsible ? e.open : !0}"
363
+ :anchor="${(e) => e._anchor}"
364
+ placement="bottom-start"
365
+ strategy="${(e) => e.fixedDropdown ? null : "absolute"}">
366
+ <div class="listbox"
367
+ id="${(e) => e.listboxId}"
368
+ role="listbox"
369
+ aria-multiselectable="${(e) => e.multiple}"
370
+ aria-label="${(e) => e.multiple && !e.label && e.ariaLabel ? e.ariaLabel : null}"
371
+ aria-labelledby="${(e) => e.multiple && e.label ? "label" : null}"
372
+ ?disabled="${(e) => e.disabled}"
373
+ ?hidden="${(e) => e.collapsible ? !e.open : !1}"
374
+ ${l("listbox")}>
375
+ ${u((e) => e.placeholder, K(e))}
376
+ <slot
377
+ ${d({
378
+ filter: x.slottedOptionFilter,
379
+ flatten: !0,
380
+ property: "slottedOptions"
381
+ })}>
382
+ </slot>
383
+ </div>
384
+ </${t}>
385
+ </div>
386
+ `;
387
+ }
388
+ function Z(e) {
389
+ return (t, n) => n.event.composedPath().includes(t._feedbackWrapper) ? !0 : e(t, n.event);
390
+ }
391
+ //#endregion
392
+ //#region src/lib/select/definition.ts
393
+ var Q = o("select", U, (e) => i`
394
+ <template
395
+ ${A({
396
+ role: "combobox",
397
+ ariaLabel: (e) => e.ariaLabel ?? e.label,
398
+ ariaHasPopup: (e) => e.collapsible ? "listbox" : "false",
399
+ ariaExpanded: (e) => e.open,
400
+ ariaDisabled: (e) => e.disabled
401
+ })}
402
+ aria-controls="${(e) => e.listboxId}"
403
+ aria-activedescendant="${(e) => e.open ? e._activeDescendant : null}"
404
+ aria-describedby="${(e) => e._feedbackDescribedBy}"
405
+ tabindex="${(e) => e.disabled ? null : "0"}"
406
+ @click="${Z((e, t) => e.clickHandler(t))}"
407
+ @focusin="${Z((e, t) => e.focusinHandler(t))}"
408
+ @focusout="${Z((e, t) => e.focusoutHandler(t))}"
409
+ @keydown="${Z((e, t) => (e.open && ee(t), e.keydownHandler(t)))}"
410
+ @mousedown="${Z((e, t) => e.mousedownHandler(t))}"
411
+ >
412
+ ${X(e)}
413
+ <div class="feedback-wrapper" ${l("_feedbackWrapper")}>
414
+ ${(t) => t._getFeedbackTemplate(e)}
415
+ </div>
416
+ </template>
417
+ `, [
418
+ L,
419
+ p,
420
+ V,
421
+ F,
422
+ R
423
+ ], { styles: H }), $ = s(Q);
67
424
  //#endregion
68
- export { h as n, f as r, g as t };
425
+ export { Q as n, U as r, $ as t };
@@ -1,87 +1,5 @@
1
- const e=require(`./localized.cjs`),t=require(`./vivid-element.cjs`),n=require(`./ref.cjs`),r=require(`./when.cjs`),i=require(`./slotted.cjs`),a=require(`./definition2.cjs`),o=require(`./decorate.cjs`),s=require(`./listbox.cjs`),c=require(`./class-names.cjs`),l=require(`./key-codes.cjs`),u=require(`./numbers.cjs`),d=require(`./strings.cjs`),f=require(`./affix.cjs`),p=require(`./form-associated.cjs`),m=require(`./form-element.cjs`),h=require(`./with-success-text.cjs`),g=require(`./with-error-text.cjs`),_=require(`./with-contextual-help.cjs`),v=require(`./definition6.cjs`),y=require(`./dialog.cjs`),b=require(`./definition8.cjs`),x=require(`./host-semantics.cjs`),S=require(`./mixins.cjs`),C=require(`./definition12.cjs`);var w=class extends S.n(_.t(g.t(h.t(e.t(m.t(x.t(f.n(p.n(s.t))))))))){constructor(...e){super(...e),this.proxy=document.createElement(`select`),this.activeIndex=-1,this.rangeStartIndex=-1,this.open=!1,this.listboxId=d.t(`listbox-`),this.maxHeight=0,this.fixedDropdown=!1,this._feedbackWrapper=null,this._isResetting=!1,this.clearable=!1,this._isClearButtonFocused=!1}get activeOption(){return this.options[this.activeIndex]}get checkedOptions(){return this.options.filter(e=>e.checked)}get firstSelectedOptionIndex(){return this.options.indexOf(this.firstSelectedOption)}activeIndexChanged(e,t){this._activeDescendant=this.options[t]?.id??``,this.focusAndScrollOptionIntoView()}checkActiveIndex(){let e=this.activeOption;e&&(e.checked=!0)}checkFirstOption(e){let t=this.getNextSelectableIndex(0);t!==-1&&(e?(this.rangeStartIndex===-1&&(this.rangeStartIndex=this.activeIndex),this.options.forEach((e,n)=>{e.checked=u.t(n,t,this.rangeStartIndex+1)&&!e.disabled})):this.uncheckAllOptions(),this.activeIndex=t,this.checkActiveIndex())}checkLastOption(e){let t=this.getPreviousSelectableIndex(this.length-1);t!==-1&&(e?(this.rangeStartIndex===-1&&(this.rangeStartIndex=this.activeIndex),this.options.forEach((e,n)=>{e.checked=u.t(n,this.rangeStartIndex,t+1)&&!e.disabled})):this.uncheckAllOptions(),this.activeIndex=t,this.checkActiveIndex())}checkNextOption(e){let t=this.getNextSelectableIndex(this.activeIndex+1);t!==-1&&(e?(this.rangeStartIndex===-1&&(this.rangeStartIndex=this.activeIndex),this.options.forEach((e,n)=>{e.checked=u.t(n,this.rangeStartIndex,t+1)&&!e.disabled})):this.uncheckAllOptions(),this.activeIndex=t,this.checkActiveIndex())}checkPreviousOption(e){let t=this.getPreviousSelectableIndex(this.activeIndex-1);t!==-1&&(e?(this.rangeStartIndex===-1&&(this.rangeStartIndex=this.activeIndex),this.checkedOptions.length===1&&(this.rangeStartIndex+=1),this.options.forEach((e,n)=>{e.checked=u.t(n,t,this.rangeStartIndex+1)&&!e.disabled})):this.uncheckAllOptions(),this.activeIndex=t,this.checkActiveIndex())}focusAndScrollOptionIntoView(){super.focusAndScrollOptionIntoView(this.activeOption)}focusinHandler(e){if(!this.multiple)return super.focusinHandler(e);!this.shouldSkipFocus&&e.target===e.currentTarget&&(this.uncheckAllOptions(),this.activeIndex===-1&&(this.activeIndex=this.firstSelectedOptionIndex===-1?0:this.firstSelectedOptionIndex),this.checkActiveIndex(),this.setSelectedOptions(),this.focusAndScrollOptionIntoView()),this.shouldSkipFocus=!1}setSelectedOptions(){if(!this.multiple){super.setSelectedOptions();return}this.$fastController.isConnected&&this.options&&(this.selectedOptions=this.options.filter(e=>e.selected),this.focusAndScrollOptionIntoView())}toggleSelectedForAllCheckedOptions(){let e=this.checkedOptions.filter(e=>!e.disabled),t=!e.every(e=>e.selected);e.forEach(e=>e.selected=t),this.selectedIndex=this.options.indexOf(e[e.length-1]),this.setSelectedOptions(),this.updateValue(!0)}typeaheadBufferChanged(e,t){if(!this.multiple){super.typeaheadBufferChanged(e,t);return}if(this.$fastController.isConnected){let e=this.getTypeaheadMatches(),t=this.options.indexOf(e[0]);t>-1&&(this.activeIndex=t,this.uncheckAllOptions(),this.checkActiveIndex()),this.typeaheadExpired=!1}}uncheckAllOptions(e=!1){this.options.forEach(e=>e.checked=!1),e||(this.rangeStartIndex=-1)}openChanged(e,n){if(!this.collapsible)return;if(this.open){this.focusAndScrollOptionIntoView(),this.indexWhenOpened=this.selectedIndex,t.O.enqueue(()=>this.focus());return}let r=e===!0&&n===!1,i=this.indexWhenOpened!==this.selectedIndex;r&&i&&this.updateValue(!0)}get collapsible(){return!this.multiple}valueChanged(e,t){let n=this.options.findIndex(e=>e.value===t),r=this._validSelectedIndex(n),i=this.options[r]?.value??``;this.selectedIndex!==r&&(this.selectedIndex=r),t===i&&(super.valueChanged(e,t),this.updateDisplayValue())}updateValue(e){this.$fastController.isConnected&&(this.value=this.firstSelectedOption?.value??``),e&&(this.$emit(`input`),this.$emit(`change`,this,{bubbles:!0,composed:void 0}))}selectedIndexChanged(e,t){super.selectedIndexChanged(e,t),this.updateValue()}clickHandler(e){if(this.disabled||this._isFromContextualHelp(e))return;let t=e.target.closest(`option,[role=option],[data-vvd-component=option]`);if(!(t&&t.disabled))return this.multiple?(this.uncheckAllOptions(),this.activeIndex=this.options.indexOf(t),this.checkActiveIndex(),this.toggleSelectedForAllCheckedOptions()):super.clickHandler(e),this.collapsible&&(this.open=!this.open),!0}focusoutHandler(e){if(this.multiple&&this.uncheckAllOptions(),!this.open)return!0;let t=e.relatedTarget;if(this.isSameNode(t)){this.focus();return}this.options.includes(t)||(this.open=!1,this.indexWhenOpened!==this.selectedIndex&&this.updateValue(!0))}handleChange(e,t){super.handleChange(e,t),t===`value`&&this.updateValue()}mousedownHandler(e){return e.offsetX>=0&&e.offsetX<=this.listbox.scrollWidth?super.mousedownHandler(e):this.collapsible}multipleChanged(e,t){this.options.forEach(e=>{e.checked=t?!1:void 0}),this.setSelectedOptions(),this.proxy&&(this.proxy.multiple=t)}selectedOptionsChanged(e,t){super.selectedOptionsChanged(e,t),this.options.forEach((e,t)=>{let n=this.proxy.options.item(t);n&&(n.selected=e.selected)})}setProxyOptions(){this.proxy instanceof HTMLSelectElement&&this.options&&(this.proxy.length=0,this.options.forEach(e=>{let t=e.proxy||(e instanceof HTMLOptionElement?e.cloneNode():null);t&&this.proxy.options.add(t)}))}multipleKeydownHandler(e){if(this.disabled)return;let{key:t,shiftKey:n}=e;switch(this.shouldSkipFocus=!1,t){case l.s:this.checkFirstOption(n);return;case l.t:this.checkNextOption(n);return;case l.i:this.checkPreviousOption(n);return;case`End`:this.checkLastOption(n);return;case`Tab`:this.focusAndScrollOptionIntoView();return;case l.o:this.uncheckAllOptions(),this.checkActiveIndex();return;case` `:if(e.preventDefault(),this.typeaheadExpired){this.toggleSelectedForAllCheckedOptions();return}default:t.length===1&&this.handleTypeAhead(`${t}`);return}}keydownHandler(e){let t=this.selectedIndex;switch(this.multiple?this.multipleKeydownHandler(e):super.keydownHandler(e),e.key){case` `:e.preventDefault(),this.collapsible&&this.typeaheadExpired&&(this.open=!this.open);break;case l.s:case`End`:e.preventDefault();break;case l.a:e.preventDefault(),this.open=!this.open;break;case l.o:this.collapsible&&this.open&&(e.preventDefault(),this.open=!1);break;case`Tab`:return this.collapsible&&this.open&&(e.preventDefault(),this.open=!1),!0}return this.collapsible&&!this.open&&this.selectedIndex!==t&&this.updateValue(!0),!(e.key===`ArrowDown`||e.key===`ArrowUp`)}connectedCallback(){super.connectedCallback(),this.addEventListener(`focusout`,this.focusoutHandler),this.addEventListener(`contentchange`,this.updateDisplayValue)}disconnectedCallback(){this.removeEventListener(`focusout`,this.focusoutHandler),this.removeEventListener(`contentchange`,this.updateDisplayValue),super.disconnectedCallback()}updateDisplayValue(){this.collapsible&&t.w.notify(this,`displayValue`)}get displayValue(){return t.w.track(this,`displayValue`),this.firstSelectedOption?.getAttribute(`label`)??this.firstSelectedOption?.text??this.placeholder??``}_newDefaultSelectedIndex(e,t,n){let r=super._newDefaultSelectedIndex(e,t,n);if(r===null&&n===-1&&!this.placeholder){let e=this.getNextSelectableIndex(0);if(e!==-1)return e}return r}_isDefaultSelected(e){return super._isDefaultSelected(e)||e.value===this.initialValue||!this._isResetting&&e.value===this.value}slottedOptionsChanged(e,n){this.options.forEach(e=>{t.w.getNotifier(e).unsubscribe(this,`value`)}),super.slottedOptionsChanged(e,n),this.options.forEach(e=>{t.w.getNotifier(e).subscribe(this,`value`)}),this.setProxyOptions(),this.updateValue();let r=this.getAttribute(`scale`)||this.scale;n.forEach(e=>{r&&(e.setAttribute(`scale`,r),e.scale=r)}),this.proxy.value=this.value,this.validate()}formResetCallback(){this.setProxyOptions(),this._isResetting=!0,this.selectedIndex=this._newDefaultSelectedIndex([],this.options,-1)??-1,this._isResetting=!1}get _shouldShowClearButton(){return this.clearable?this.multiple?this.selectedOptions?.length>0:this.value!==``:!1}_onClearButtonFocus(){this._isClearButtonFocused=!0,this.activeIndex=-1,this.uncheckAllOptions()}_onClearButtonBlur(){this._isClearButtonFocused=!1}get _shouldShowLabelWrapper(){return!!(this.label||this._hasContextualHelp||this.multiple&&this._shouldShowClearButton)}_onClearButtonClick(){this.multiple?this.selectedOptions?.forEach(e=>{e.disabled||(e.selected=!1)}):this.selectedIndex=-1,this.updateValue(!0)}};o.t([t.T],w.prototype,`activeIndex`,void 0),o.t([t.l({mode:`boolean`})],w.prototype,`multiple`,void 0),o.t([t.l({attribute:`open`,mode:`boolean`})],w.prototype,`open`,void 0),o.t([t.E],w.prototype,`collapsible`,null),o.t([t.T],w.prototype,`control`,void 0),o.t([t.T],w.prototype,`maxHeight`,void 0),o.t([t.T],w.prototype,`_anchor`,void 0),o.t([t.l()],w.prototype,`scale`,void 0),o.t([t.l],w.prototype,`appearance`,void 0),o.t([t.l],w.prototype,`shape`,void 0),o.t([t.l({mode:`boolean`,attribute:`fixed-dropdown`})],w.prototype,`fixedDropdown`,void 0),o.t([t.l],w.prototype,`placeholder`,void 0),o.t([t.T],w.prototype,`_feedbackWrapper`,void 0),o.t([t.T],w.prototype,`metaSlottedContent`,void 0),o.t([t.l({mode:`boolean`})],w.prototype,`clearable`,void 0),o.t([t.T],w.prototype,`_isClearButtonFocused`,void 0);var T=`.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))}`,E=({shape:e,disabled:t,appearance:n,metaSlottedContent:r,errorValidationMessage:i,successText:a,placeholder:o,value:s,scale:l,_activeDescendant:u,open:d})=>c.t([`has-activedescendant`,!!u&&d],[`disabled`,t],[`appearance-${n}`,!!n],[`shape-${e}`,!!e],[`has-meta`,!!r?.length],[`error`,!!i],[`success`,!!a],[`shows-placeholder`,!!o&&!s],[`size-${l}`,!!l]);function D(){return t.d` <label
2
- for="${e=>e.multiple?null:`control`}"
3
- class="label"
4
- id="label"
5
- >
6
- ${e=>e.label}
7
- </label>`}function O(e){let n=e.tagFor(C.r);return t.d`
8
- <${n} text="${e=>e.placeholder}" hidden disabled>
9
- </${n}>`}function k(e){let n=e.tagFor(v.i);return t.d`
10
- <${n}
11
- aria-label="${e=>e.locale.select.clearButtonLabel}"
12
- aria-hidden="${e=>e._isClearButtonFocused?`false`:`true`}"
13
- @click="${(e,t)=>{e._onClearButtonClick(),t.event.stopPropagation()}}"
14
- @mousedown="${()=>!1}"
15
- @keydown="${(e,t)=>(t.event.key===`Tab`&&e._onClearButtonBlur(),t.event.stopPropagation(),!0)}"
16
- @focusin="${(e,t)=>{t.event.stopPropagation(),e._onClearButtonFocus()}}"
17
- @focusout="${e=>e._onClearButtonBlur()}"
18
- ?disabled="${e=>e.disabled}"
19
- :shape="${e=>e.shape}"
20
- size="super-condensed"
21
- icon="close-line"
22
- appearance="ghost-light"
23
- class="clear-button"
24
- tabindex="0"
25
- ></${n}>
26
- `}function A(e){let a=f.a(e),o=v.r(e);return t.d` <div
27
- class="control ${E}"
28
- ${n.t(`_anchor`)}
29
- id="control"
30
- ?disabled="${e=>e.disabled}"
31
- >
32
- <div class="selected-value">
33
- ${e=>a(e.icon,f.i.Slot)}
34
- <span class="text">${e=>e.displayValue}</span>
35
- <slot name="meta" ${i.t(`metaSlottedContent`)}></slot>
36
- </div>
37
- ${r.t(e=>e._shouldShowClearButton,k(e))}
38
- ${o}
39
- </div>`}function j(e){return e.open&&e.fixedDropdown?`--_select-fixed-width: ${Math.round(e.getBoundingClientRect().width)}px`:null}function M(e){let a=e.tagFor(b.i);return t.d`
40
- <div class="label-wrapper" ?hidden=${e=>!e._shouldShowLabelWrapper}>
41
- ${r.t(e=>e.label,D())}
42
- ${r.t(e=>e.multiple&&e._shouldShowClearButton,k(e))}
43
- <slot name="contextual-help" ${i.t(`_contextualHelpSlottedContent`)}></slot>
44
- </div>
45
- <div class="control-wrapper">
46
- ${r.t(e=>!e.multiple,A(e))}
47
- <${a} class="popup"
48
- style="${j}"
49
- ?open="${e=>e.collapsible?e.open:!0}"
50
- :anchor="${e=>e._anchor}"
51
- placement="bottom-start"
52
- strategy="${e=>e.fixedDropdown?null:`absolute`}">
53
- <div class="listbox"
54
- id="${e=>e.listboxId}"
55
- role="listbox"
56
- aria-multiselectable="${e=>e.multiple}"
57
- aria-label="${e=>e.multiple&&!e.label&&e.ariaLabel?e.ariaLabel:null}"
58
- aria-labelledby="${e=>e.multiple&&e.label?`label`:null}"
59
- ?disabled="${e=>e.disabled}"
60
- ?hidden="${e=>e.collapsible?!e.open:!1}"
61
- ${n.t(`listbox`)}>
62
- ${r.t(e=>e.placeholder,O(e))}
63
- <slot
64
- ${i.t({filter:s.t.slottedOptionFilter,flatten:!0,property:`slottedOptions`})}>
65
- </slot>
66
- </div>
67
- </${a}>
68
- </div>
69
- `}function N(e){return(t,n)=>n.event.composedPath().includes(t._feedbackWrapper)?!0:e(t,n.event)}var P=t.o(`select`,w,e=>t.d`
70
- <template
71
- ${x.n({role:`combobox`,ariaLabel:e=>e.ariaLabel??e.label,ariaHasPopup:e=>e.collapsible?`listbox`:`false`,ariaExpanded:e=>e.open,ariaDisabled:e=>e.disabled})}
72
- aria-controls="${e=>e.listboxId}"
73
- aria-activedescendant="${e=>e.open?e._activeDescendant:null}"
74
- aria-describedby="${e=>e._feedbackDescribedBy}"
75
- tabindex="${e=>e.disabled?null:`0`}"
76
- @click="${N((e,t)=>e.clickHandler(t))}"
77
- @focusin="${N((e,t)=>e.focusinHandler(t))}"
78
- @focusout="${N((e,t)=>e.focusoutHandler(t))}"
79
- @keydown="${N((e,t)=>(e.open&&y.t(t),e.keydownHandler(t)))}"
80
- @mousedown="${N((e,t)=>e.mousedownHandler(t))}"
81
- >
82
- ${M(e)}
83
- <div class="feedback-wrapper" ${n.t(`_feedbackWrapper`)}>
84
- ${t=>t._getFeedbackTemplate(e)}
85
- </div>
86
- </template>
87
- `,[b.t,a.t,C.t,v.t,S.a],{styles:T}),F=t.s(P);Object.defineProperty(exports,`n`,{enumerable:!0,get:function(){return P}}),Object.defineProperty(exports,`r`,{enumerable:!0,get:function(){return w}}),Object.defineProperty(exports,`t`,{enumerable:!0,get:function(){return F}});
1
+ const e=require(`./vivid-element.cjs`),t=require(`./class-names.cjs`),n=require(`./host-semantics.cjs`),r=require(`./divider.cjs`);var i=`:host{display:block}.base{--_connotation-color-soft:var(--vvd-divider-accent-soft,var(--vvd-color-neutral-100));--_connotation-color-dim:var(--vvd-divider-accent-dim,var(--vvd-color-neutral-200));display:block}.base:not(.vertical){block-size:1px;inline-size:100%}.base.vertical{block-size:100%;inline-size:1px}.base.appearance-ghost{background-color:var(--_connotation-color-dim)}.base.appearance-subtle{background-color:var(--_connotation-color-soft)}`,a=e.d`<template
2
+ ${n.n({role:e=>e.role||r.n.separator,ariaHidden:!0,ariaOrientation:({role:e,orientation:t})=>e===r.n.presentation?null:t})}
3
+ >
4
+ <span class="${({orientation:e,appearance:n})=>t.t(`base`,[`${e}`,!!e],[`appearance-${n}`,!!n])}"></span
5
+ ></template>`,o=e.o(`divider`,r.t,a,[],{styles:i}),s=e.s(o);Object.defineProperty(exports,`n`,{enumerable:!0,get:function(){return s}}),Object.defineProperty(exports,`t`,{enumerable:!0,get:function(){return o}});