@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
@@ -2,74 +2,558 @@ require("./chunk.cjs");
2
2
  const require_vivid_element = require("./vivid-element.cjs");
3
3
  const require_definition = require("./definition2.cjs");
4
4
  const require_decorate = require("./decorate.cjs");
5
- const require_definition$1 = require("./definition29.cjs");
5
+ const require_affix = require("./affix.cjs");
6
+ const require_form_associated = require("./form-associated.cjs");
7
+ const require_form_element = require("./form-element.cjs");
8
+ const require_with_success_text = require("./with-success-text.cjs");
9
+ const require_with_error_text = require("./with-error-text.cjs");
10
+ const require_with_contextual_help = require("./with-contextual-help.cjs");
11
+ const require_definition$1 = require("./definition7.cjs");
12
+ const require_dialog = require("./dialog.cjs");
13
+ const require_definition$2 = require("./definition10.cjs");
14
+ const require_mixins = require("./mixins.cjs");
15
+ const require_text_field = require("./text-field.cjs");
16
+ const require_definition$3 = require("./definition29.cjs");
17
+ const require_listbox = require("./listbox.cjs");
6
18
  let _microsoft_fast_element = require("@microsoft/fast-element");
7
19
  let _microsoft_fast_web_utilities = require("@microsoft/fast-web-utilities");
8
- //#region src/lib/contextual-help/contextual-help.ts
20
+ //#region src/lib/combobox/combobox.scss?inline
21
+ var combobox_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)}:not(.disabled) .chevron{cursor:pointer}.disabled .chevron{color:var(--_low-ink-color);cursor:not-allowed}:host{--_low-ink-color:var(--vvd-color-neutral-600);flex-direction:column;gap:4px;display:inline-flex;position:relative}:host([disabled]){--_low-ink-color:var(--vvd-color-neutral-400);cursor:not-allowed}.base{--_text-field-gutter-end:8px;--_appearance-color-text:var(--vvd-color-canvas-text);--_appearance-color-fill:var(--vvd-color-canvas);--_appearance-color-outline:var(--vvd-color-neutral-500)}.base.appearance-ghost{--_appearance-color-text:var(--_connotation-color-firm);--_appearance-color-fill:transparent;--_appearance-color-outline:transparent}@media (hover:hover){.base: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)}.base: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}}.base.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)}.base.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}.base: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)}.base:disabled.appearance-ghost{--_appearance-color-text:var(--vvd-color-neutral-300);--_appearance-color-fill:transparent;--_appearance-color-outline:transparent}.base.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)}.base.disabled.appearance-ghost{--_appearance-color-text:var(--vvd-color-neutral-300);--_appearance-color-fill:transparent;--_appearance-color-outline:transparent}.base.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)}.base.readonly:where(:not(.disabled,:disabled)).appearance-ghost{--_appearance-color-text:var(--vvd-color-neutral-600);--_appearance-color-fill:transparent;--_appearance-color-outline:transparent}.base.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)}.base.error:where(:not(.disabled,:disabled)).appearance-ghost{--_appearance-color-text:notSet;--_appearance-color-fill:var(--vvd-color-alert-50);--_appearance-color-outline:transparent}.base.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)}.base.success:where(:not(.disabled,:disabled)).appearance-ghost{--_appearance-color-text:notSet;--_appearance-color-fill:var(--vvd-color-success-50);--_appearance-color-outline:transparent}.base:not(.shape-pill) .base{border-radius:var(--_text-field-border-radius)}.base.shape-pill .base{border-radius:var(--_text-field-pill-border-radius)}.base slot[name=icon]{z-index:1;color:var(--_low-ink-color);font-size:var(--_text-field-icon-size);pointer-events:none;line-height:1;display:inline-block;position:absolute;inset-block-start:50%;inset-inline-start:var(--_text-field-gutter-start);transform:translateY(-50%)}.base.has-meta{padding-inline-end:16px}.control{text-overflow:ellipsis;white-space:nowrap}.fieldset .leading-items-wrapper{flex-shrink:0;align-items:center;gap:8px;padding-inline-end:16px;display:flex;position:relative}.listbox{max-height:var(--combobox-height,408px);contain:paint;border-radius:8px;flex-direction:column;gap:2px;padding:4px;display:flex;overflow-y:auto}::part(popup-base){inline-size:max-content;min-inline-size:var(--_combobox-fixed-width,100%)}@supports selector(:has(*)){.base:not(.has-activedescendant) .fieldset:has(.control:focus-within):after{--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(*)){.base:not(.has-activedescendant) .fieldset:focus-within:after{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;z-index:1;border-radius:inherit;content:\"\";pointer-events:none;display:block;position:absolute;inset:0}}::slotted([data-vvd-component=option][current-selected]){border-radius:8px}:host(.has-activedescendant) ::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}";
22
+ //#endregion
23
+ //#region src/lib/combobox/combobox.options.ts
24
+ /**
25
+ * Autocomplete values for combobox.
26
+ * @public
27
+ */
28
+ var ComboboxAutocomplete = {
29
+ inline: "inline",
30
+ list: "list",
31
+ both: "both",
32
+ none: "none"
33
+ };
34
+ //#endregion
35
+ //#region src/lib/combobox/combobox.ts
9
36
  /**
10
37
  * @public
11
- * @component contextual-help
38
+ * @component combobox
12
39
  * @slot - Default slot.
13
- * @slot icon - Custom icon slot (optional).
40
+ * @slot icon - The preferred way to add an icon to the combobox control.
41
+ * @slot meta - Slot to add meta content to the combobox control.
42
+ * @slot helper-text - Describes how to use the combobox. Alternative to the `helper-text` attribute.
43
+ * @event {CustomEvent<undefined>} change - Fires a custom 'change' event when the value updates
44
+ * @vueModel modelValue value change `event.currentTarget.value`
45
+ * @testAction fill comboboxFill
46
+ * @testAction clear comboboxClear
47
+ * @testAction selectOptionByText selectOptionByText
48
+ * @testAction selectOptionByValue selectOptionByValue
49
+ * @testRef control shadow input.control
14
50
  */
15
- var ContextualHelp = class extends require_vivid_element.VividElement {
51
+ var Combobox = class extends require_with_contextual_help.WithContextualHelp(require_mixins.WithFeedback(require_with_error_text.WithErrorText(require_with_success_text.WithSuccessText(require_form_element.FormElement(require_affix.AffixIcon(require_form_associated.FormAssociated(require_listbox.Listbox))))))) {
16
52
  constructor(..._args) {
17
53
  super(..._args);
18
- this.placement = "right";
54
+ this.filteredOptions = [];
55
+ this.filter = "";
56
+ this._isNavigatingWithKeyboard = false;
57
+ this.fixedDropdown = false;
58
+ this.listboxId = (0, _microsoft_fast_web_utilities.uniqueId)("listbox-");
59
+ this.maxHeight = 0;
60
+ this.open = false;
61
+ this.proxy = document.createElement("input");
62
+ }
63
+ /**
64
+ * @internal
65
+ */
66
+ formResetCallback() {
67
+ super.formResetCallback();
68
+ this.selectedIndex = this._newDefaultSelectedIndex([], this.options, -1) ?? -1;
69
+ this.value = this.firstSelectedOption?.text || "";
70
+ }
71
+ /** {@inheritDoc (FormAssociated:interface).validate} */
72
+ validate() {
73
+ super.validate(this.control);
74
+ }
75
+ get isAutocompleteInline() {
76
+ return this.autocomplete === ComboboxAutocomplete.inline || this.isAutocompleteBoth;
77
+ }
78
+ get isAutocompleteList() {
79
+ return this.autocomplete === ComboboxAutocomplete.list || this.isAutocompleteBoth;
80
+ }
81
+ get isAutocompleteBoth() {
82
+ return this.autocomplete === ComboboxAutocomplete.both;
83
+ }
84
+ /**
85
+ * @internal
86
+ */
87
+ openChanged() {
88
+ if (this.open) this.enqueueScrollSelectedOptionIntoViewIfNeeded();
89
+ }
90
+ /**
91
+ * A read-only list of options.
92
+ *
93
+ * @public
94
+ * @remarks
95
+ * Overrides `Listbox.options`.
96
+ */
97
+ get options() {
98
+ _microsoft_fast_element.Observable.track(this, "options");
99
+ return this.filteredOptions.length ? this.filteredOptions : this._options;
100
+ }
101
+ set options(value) {
102
+ super.options = value;
103
+ }
104
+ /**
105
+ * Updates the placeholder on the proxy element.
106
+ * @internal
107
+ */
108
+ placeholderChanged() {
109
+ /* v8 ignore if -- @preserve */
110
+ if (this.proxy instanceof HTMLInputElement) this.proxy.placeholder = this.placeholder;
111
+ }
112
+ /**
113
+ * @internal
114
+ */
115
+ valueChanged(prev, next) {
116
+ if (this.$fastController.isConnected && this.options) {
117
+ const selectedIndex = this.options.findIndex((el) => el.text.toLowerCase() === next.toLowerCase());
118
+ this.selectedIndex = this.options[this.selectedIndex]?.text !== this.options[selectedIndex]?.text ? selectedIndex : this.selectedIndex;
119
+ }
120
+ super.valueChanged(prev, next);
121
+ }
122
+ /**
123
+ * Handle opening and closing the listbox when the combobox is clicked.
124
+ *
125
+ * @param e - the mouse event
126
+ * @internal
127
+ */
128
+ clickHandler(e) {
129
+ if (this.disabled || this._isFromContextualHelp(e)) return;
130
+ if (this.open) {
131
+ const capturedOption = e.target.closest(`option,[role=option],[data-vvd-component=option]`);
132
+ if (!capturedOption || capturedOption.disabled) return;
133
+ this.selectedOptions = [capturedOption];
134
+ this.control.value = capturedOption.text;
135
+ this.clearSelectionRange();
136
+ this.updateValue(true);
137
+ }
138
+ this.open = !this.open;
139
+ if (this.open) this.control.focus();
140
+ return true;
141
+ }
142
+ /**
143
+ * Handle closing the listbox when the combobox is open and the chevron icon is clicked.
144
+ *
145
+ * @param e - the mouse event
146
+ * @internal
147
+ */
148
+ _chevronIconClickHandler(e) {
149
+ if (!this.open) return;
150
+ e.stopPropagation();
151
+ this.open = false;
152
+ }
153
+ connectedCallback() {
154
+ super.connectedCallback();
155
+ if (this.value) this.initialValue = this.value;
156
+ this._popup.anchor = this._anchor;
157
+ }
158
+ /**
159
+ * Filter available options by text value.
160
+ *
161
+ * @public
162
+ */
163
+ filterOptions() {
164
+ if (!this.autocomplete || this.autocomplete === ComboboxAutocomplete.none) this.filter = "";
165
+ this.filteredOptions = this._options.filter((o) => o.text.toLowerCase().startsWith(this.filter.toLowerCase()));
166
+ if (this.isAutocompleteList) this._options.forEach((o) => {
167
+ o.hidden = !this.filteredOptions.includes(o);
168
+ });
169
+ }
170
+ /**
171
+ * Focus the control and scroll the first selected option into view.
172
+ *
173
+ * @internal
174
+ * @remarks
175
+ * Overrides: `Listbox.focusAndScrollOptionIntoView`
176
+ */
177
+ focusAndScrollOptionIntoView() {
178
+ if (this.contains(document.activeElement)) {
179
+ this.control.focus();
180
+ this.enqueueScrollSelectedOptionIntoViewIfNeeded();
181
+ }
182
+ }
183
+ /**
184
+ * @internal
185
+ */
186
+ enqueueScrollSelectedOptionIntoViewIfNeeded() {
187
+ const firstSelectedOption = this.firstSelectedOption;
188
+ /* v8 ignore else -- @preserve */
189
+ if (firstSelectedOption) requestAnimationFrame(() => {
190
+ firstSelectedOption.scrollIntoView({ block: "nearest" });
191
+ });
192
+ }
193
+ /**
194
+ * Handle focus state when the element or its children lose focus.
195
+ *
196
+ * @param e - The focus event
197
+ * @internal
198
+ */
199
+ focusoutHandler(e) {
200
+ this.syncValue();
201
+ if (!this.open) return true;
202
+ const focusTarget = e.relatedTarget;
203
+ if (this.isSameNode(focusTarget)) {
204
+ this.focus();
205
+ return;
206
+ }
207
+ this.open = false;
208
+ }
209
+ /**
210
+ * Handle content changes on the control input.
211
+ *
212
+ * @param e - the input event
213
+ * @internal
214
+ */
215
+ inputHandler(e) {
216
+ this.filter = this.control.value;
217
+ this.filterOptions();
218
+ if (!this.isAutocompleteInline) this.selectedIndex = this.options.map((option) => option.text).indexOf(this.control.value);
219
+ if (e.inputType.includes("deleteContent") || !this.filter.length) return true;
220
+ if (this.isAutocompleteList && !this.open) this.open = true;
221
+ if (this.isAutocompleteInline) if (this.filteredOptions.length) {
222
+ this.selectedOptions = [this.filteredOptions[0]];
223
+ this.selectedIndex = this.options.indexOf(this.firstSelectedOption);
224
+ this.setInlineSelection();
225
+ } else this.selectedIndex = -1;
226
+ }
227
+ /**
228
+ * Handle keydown actions for listbox navigation.
229
+ *
230
+ * @param e - the keyboard event
231
+ * @internal
232
+ */
233
+ keydownHandler(e) {
234
+ const key = e.key;
235
+ if (e.ctrlKey || e.shiftKey) return true;
236
+ switch (key) {
237
+ case "Enter":
238
+ this.syncValue();
239
+ /* v8 ignore else -- @preserve */
240
+ if (this.isAutocompleteInline) this.filter = this.value;
241
+ this.open = false;
242
+ this.clearSelectionRange();
243
+ break;
244
+ case "Escape":
245
+ /* v8 ignore else -- @preserve */
246
+ if (!this.isAutocompleteInline) this.selectedIndex = -1;
247
+ if (this.open) {
248
+ this.open = false;
249
+ break;
250
+ }
251
+ this.value = "";
252
+ this.control.value = "";
253
+ this.filter = "";
254
+ this.filterOptions();
255
+ break;
256
+ case "Tab":
257
+ this.setInputToSelection();
258
+ if (!this.open) return true;
259
+ e.preventDefault();
260
+ this.open = false;
261
+ break;
262
+ case "ArrowUp":
263
+ case "ArrowDown":
264
+ this.filterOptions();
265
+ if (!this.open) {
266
+ this.open = true;
267
+ break;
268
+ }
269
+ /* v8 ignore else -- @preserve */
270
+ if (this.filteredOptions.length > 0) {
271
+ this._isNavigatingWithKeyboard = true;
272
+ super.keydownHandler(e);
273
+ this._isNavigatingWithKeyboard = false;
274
+ }
275
+ if (this.isAutocompleteInline) this.setInlineSelection();
276
+ break;
277
+ default: return true;
278
+ }
279
+ }
280
+ /**
281
+ * @internal
282
+ */
283
+ setSelectedOptions() {
284
+ super.setSelectedOptions();
285
+ if (!this._isNavigatingWithKeyboard) this._activeDescendant = "";
286
+ }
287
+ /**
288
+ * Ensure that the selectedIndex is within the current allowable filtered range.
289
+ *
290
+ * @param prev - the previous selected index value
291
+ * @param next - the current selected index value
292
+ *
293
+ * @internal
294
+ */
295
+ selectedIndexChanged(prev, next) {
296
+ if (this.$fastController.isConnected) {
297
+ next = (0, _microsoft_fast_web_utilities.limit)(-1, this.options.length - 1, next);
298
+ if (next !== this.selectedIndex) {
299
+ this.selectedIndex = next;
300
+ return;
301
+ }
302
+ super.selectedIndexChanged(prev, next);
303
+ }
304
+ }
305
+ /**
306
+ * Move focus to the previous selectable option.
307
+ *
308
+ * @internal
309
+ * @remarks
310
+ * Overrides `Listbox.selectPreviousOption`
311
+ */
312
+ selectPreviousOption() {
313
+ if (!this.disabled && this.selectedIndex >= 0) this.selectedIndex = this.selectedIndex - 1;
314
+ }
315
+ _isDefaultSelected(option) {
316
+ return super._isDefaultSelected(option) || option.text !== "" && option.text === this.initialValue;
317
+ }
318
+ /**
319
+ * Focus and set the content of the control based on the first selected option.
320
+ *
321
+ * @internal
322
+ */
323
+ setInputToSelection() {
324
+ if (this.firstSelectedOption) {
325
+ this.control.value = this.firstSelectedOption.text;
326
+ this.control.focus();
327
+ }
328
+ }
329
+ /**
330
+ * Focus, set and select the content of the control based on the first selected option.
331
+ *
332
+ * @internal
333
+ */
334
+ setInlineSelection() {
335
+ /* v8 ignore else -- @preserve */
336
+ if (this.firstSelectedOption) {
337
+ this.setInputToSelection();
338
+ this.control.setSelectionRange(this.filter.length, this.control.value.length, "backward");
339
+ }
340
+ }
341
+ /**
342
+ * Determines if a value update should involve emitting a change event, then updates the value.
343
+ *
344
+ * @internal
345
+ */
346
+ syncValue() {
347
+ const newValue = this.firstSelectedOption?.text ?? this.control.value;
348
+ this.updateValue(this.value !== newValue);
349
+ }
350
+ /**
351
+ * Ensure that the entire list of options is used when setting the selected property.
352
+ *
353
+ * @param prev - the previous list of selected options
354
+ * @param next - the current list of selected options
355
+ *
356
+ * @internal
357
+ * @remarks
358
+ * Overrides: `Listbox.selectedOptionsChanged`
359
+ */
360
+ selectedOptionsChanged(_prev, next) {
361
+ if (this.$fastController.isConnected) this._options.forEach((o) => {
362
+ o.selected = next.includes(o);
363
+ });
364
+ }
365
+ /**
366
+ * Synchronize the form-associated proxy and update the value property of the element.
367
+ *
368
+ * @param prev - the previous collection of slotted option elements
369
+ * @param next - the next collection of slotted option elements
370
+ *
371
+ * @internal
372
+ */
373
+ slottedOptionsChanged(prev, next) {
374
+ super.slottedOptionsChanged(prev, next);
375
+ this.updateValue();
376
+ const scale = this.getAttribute("scale") || this.scale;
377
+ next.forEach((element) => {
378
+ if (scale) {
379
+ element.setAttribute("scale", scale);
380
+ element.scale = scale;
381
+ }
382
+ });
383
+ }
384
+ /**
385
+ * Sets the value and to match the first selected option.
386
+ *
387
+ * @param shouldEmit - if true, the change event will be emitted
388
+ *
389
+ * @internal
390
+ */
391
+ updateValue(shouldEmit) {
392
+ if (this.$fastController.isConnected) this.value = this.firstSelectedOption?.text || this.control.value;
393
+ if (shouldEmit) this.$emit("change");
394
+ }
395
+ /**
396
+ * @internal
397
+ */
398
+ clearSelectionRange() {
399
+ const controlValueLength = this.control.value.length;
400
+ this.control.setSelectionRange(controlValueLength, controlValueLength);
19
401
  }
20
402
  };
21
- require_decorate.__decorate([(0, _microsoft_fast_element.attr)({ mode: "fromView" })], ContextualHelp.prototype, "placement", void 0);
403
+ require_decorate.__decorate([(0, _microsoft_fast_element.attr)({
404
+ attribute: "autocomplete",
405
+ mode: "fromView"
406
+ })], Combobox.prototype, "autocomplete", void 0);
407
+ require_decorate.__decorate([_microsoft_fast_element.attr], Combobox.prototype, "appearance", void 0);
408
+ require_decorate.__decorate([_microsoft_fast_element.attr], Combobox.prototype, "shape", void 0);
409
+ require_decorate.__decorate([(0, _microsoft_fast_element.attr)()], Combobox.prototype, "scale", void 0);
410
+ require_decorate.__decorate([_microsoft_fast_element.attr], Combobox.prototype, "placement", void 0);
411
+ require_decorate.__decorate([(0, _microsoft_fast_element.attr)({
412
+ mode: "boolean",
413
+ attribute: "fixed-dropdown"
414
+ })], Combobox.prototype, "fixedDropdown", void 0);
415
+ require_decorate.__decorate([_microsoft_fast_element.observable], Combobox.prototype, "metaSlottedContent", void 0);
416
+ require_decorate.__decorate([_microsoft_fast_element.observable], Combobox.prototype, "maxHeight", void 0);
417
+ require_decorate.__decorate([(0, _microsoft_fast_element.attr)({
418
+ attribute: "open",
419
+ mode: "boolean"
420
+ })], Combobox.prototype, "open", void 0);
421
+ require_decorate.__decorate([_microsoft_fast_element.attr], Combobox.prototype, "placeholder", void 0);
22
422
  //#endregion
23
- //#region src/lib/contextual-help/contextual-help.template.ts
24
- var getClasses = (_) => (0, _microsoft_fast_web_utilities.classNames)("control");
25
- /**
26
- * The template for the ContextualHelp component.
27
- *
28
- * @param context - element definition context
29
- * @public
30
- */
31
- var ContextualHelpTemplate = (context) => {
32
- const toggletipTag = context.tagFor(require_definition$1.Toggletip);
33
- const iconTag = context.tagFor(require_definition.Icon);
423
+ //#region src/lib/combobox/combobox.template.ts
424
+ var getStateClasses = ({ icon, iconSlottedContent, metaSlottedContent, errorValidationMessage, successText, shape, scale, disabled, placeholder, label, appearance, open, _activeDescendant }) => (0, _microsoft_fast_web_utilities.classNames)("base", ["disabled", disabled], [`shape-${shape}`, Boolean(shape)], [`size-${scale}`, Boolean(scale)], ["placeholder", Boolean(placeholder)], [`appearance-${appearance}`, Boolean(appearance)], ["no-label", !label], ["has-icon", !!icon || Boolean(iconSlottedContent?.length)], ["has-meta", Boolean(metaSlottedContent?.length)], ["has-activedescendant", Boolean(_activeDescendant) && open], ["error", Boolean(errorValidationMessage)], ["success", !!successText]);
425
+ function renderLabel() {
426
+ return _microsoft_fast_element.html` <label for="control" class="label">
427
+ ${(x) => x.label}
428
+ </label>`;
429
+ }
430
+ function setFixedDropdownVarWidth(x) {
431
+ return x.open && x.fixedDropdown ? `--_combobox-fixed-width: ${Math.round(x.getBoundingClientRect().width)}px` : null;
432
+ }
433
+ function renderInput(context) {
434
+ const affixIconTemplate = require_affix.affixIconTemplateFactory(context);
435
+ const chevronTemplate = require_definition$1.chevronTemplateFactory(context);
436
+ return _microsoft_fast_element.html` <div class="${getStateClasses}" ${(0, _microsoft_fast_element.ref)("_anchor")}>
437
+ <div
438
+ class="label-wrapper"
439
+ ?hidden=${(x) => !x.label && !x._hasContextualHelp}
440
+ >
441
+ ${(0, _microsoft_fast_element.when)((x) => x.label, renderLabel())}
442
+ <slot
443
+ name="contextual-help"
444
+ ${(0, _microsoft_fast_element.slotted)("_contextualHelpSlottedContent")}
445
+ ></slot>
446
+ </div>
447
+ <div class="fieldset">
448
+ ${(x) => affixIconTemplate(x.icon, require_affix.IconWrapper.Slot)}
449
+ <div class="wrapper">
450
+ <input
451
+ id="control"
452
+ autocomplete="off"
453
+ class="control"
454
+ aria-activedescendant="${(x) => x.open ? x._activeDescendant : null}"
455
+ aria-autocomplete="${(x) => x.autocomplete}"
456
+ aria-controls="${(x) => x.listboxId}"
457
+ aria-expanded="${(x) => x.open}"
458
+ aria-haspopup="listbox"
459
+ aria-describedby="${(x) => x._feedbackDescribedBy}"
460
+ placeholder="${(x) => x.placeholder}"
461
+ role="combobox"
462
+ type="text"
463
+ ?disabled="${(x) => x.disabled}"
464
+ :value="${(x) => x.value}"
465
+ @input="${(x, c) => x.inputHandler(c.event)}"
466
+ ${(0, _microsoft_fast_element.ref)("control")}
467
+ />
468
+ </div>
469
+ <div class="leading-items-wrapper">
470
+ <slot name="meta" ${(0, _microsoft_fast_element.slotted)("metaSlottedContent")}></slot>
471
+ <div
472
+ @click="${(x, c) => x._chevronIconClickHandler(c.event)}"
473
+ >
474
+ ${chevronTemplate}
475
+ </div>
476
+ </div>
477
+ </div>
478
+ </div>`;
479
+ }
480
+ var comboboxTemplate = (context) => {
481
+ const popupTag = context.tagFor(require_definition$2.Popup);
34
482
  return _microsoft_fast_element.html`
35
- <${toggletipTag} class="base" exportparts="vvd-theme-alternate">
36
- <button class="${getClasses}" slot="anchor">
37
- <slot name="icon" slot="icon">
38
- <${iconTag} name="help-solid"></${iconTag}>
39
- </slot>
40
- </button>
41
- <slot></slot>
42
- </${toggletipTag}>
483
+ <template
484
+ tabindex="${(x) => !x.disabled ? "0" : null}"
485
+ class="${(x) => (0, _microsoft_fast_web_utilities.classNames)(["has-activedescendant", Boolean(x._activeDescendant) && x.open])}"
486
+ @click="${(x, c) => x.clickHandler(c.event)}"
487
+ @focusout="${(x, c) => x.focusoutHandler(c.event)}"
488
+ @keydown="${(x, { event }) => {
489
+ x.open && require_dialog.handleEscapeKeyAndStopPropogation(event);
490
+ return x.keydownHandler(event);
491
+ }}"
492
+ >
493
+ <div class="control-wrapper">
494
+ ${() => renderInput(context)}
495
+ <${popupTag} class="popup"
496
+ style="${setFixedDropdownVarWidth}"
497
+ ?open="${(x) => x.open}"
498
+ placement="${(x) => x.placement ?? "bottom-start"}"
499
+ strategy="${(x) => x.fixedDropdown ? "fixed" : "absolute"}"
500
+ ${(0, _microsoft_fast_element.ref)("_popup")}>
501
+ <div id="${(x) => x.listboxId}"
502
+ class="listbox"
503
+ role="listbox"
504
+ ?disabled="${(x) => x.disabled}"
505
+ ${(0, _microsoft_fast_element.ref)("listbox")}>
506
+ <slot ${(0, _microsoft_fast_element.slotted)({
507
+ filter: require_listbox.Listbox.slottedOptionFilter,
508
+ flatten: true,
509
+ property: "slottedOptions"
510
+ })}>
511
+ </slot>
512
+ </div>
513
+ </${popupTag}>
514
+ </div>
515
+ <div class="feedback-wrapper" @click="${(_, c) => c.event.stopPropagation()}">
516
+ ${(x) => x._getFeedbackTemplate(context)}
517
+ </div>
518
+ </template>
43
519
  `;
44
520
  };
45
521
  //#endregion
46
- //#region src/lib/contextual-help/definition.ts
522
+ //#region src/lib/combobox/definition.ts
47
523
  /**
48
524
  * @internal
49
525
  */
50
- var contextualHelpDefinition = require_vivid_element.defineVividComponent("contextual-help", ContextualHelp, ContextualHelpTemplate, [require_definition.iconDefinition, require_definition$1.toggletipDefinition], { styles: ".control{--_connotation-color-primary:var(--vvd-button-accent-primary,var(--vvd-color-canvas-text));--_connotation-color-primary-text:var(--vvd-button-accent-primary-text,var(--vvd-color-canvas));--_connotation-color-primary-increment:var(--vvd-button-accent-primary-increment,var(--vvd-color-neutral-800));--_connotation-color-contrast:var(--vvd-button-accent-contrast,var(--vvd-color-neutral-800));--_connotation-color-fierce:var(--vvd-button-accent-fierce,var(--vvd-color-neutral-700));--_connotation-color-firm:var(--vvd-button-accent-firm,var(--vvd-color-canvas-text));--_connotation-color-soft:var(--vvd-button-accent-soft,var(--vvd-color-neutral-100));--_connotation-color-faint:var(--vvd-button-accent-faint,var(--vvd-color-neutral-50));--_connotation-color-fierce-primary:var(--vvd-button-accent-fierce-primary,var(--vvd-color-canvas-text));--_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(--_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(--_connotation-color-firm);--_appearance-color-fill:var(--_connotation-color-faint);--_appearance-color-outline:transparent}.control:disabled,.control.disabled{--_appearance-color-text:var(--vvd-color-neutral-300);--_appearance-color-fill:transparent;--_appearance-color-outline:transparent}.control:active:where(:not(.disabled,:disabled)),.control.active:where(:not(.disabled,:disabled)){--_appearance-color-text:var(--_connotation-color-firm);--_appearance-color-fill:var(--_connotation-color-soft);--_appearance-color-outline:transparent}.control{--focus-stroke-gap-color:transparent;box-sizing:border-box;background-color:var(--_appearance-color-fill);block-size:var(--_button-block-size,24px);box-shadow:inset 0 0 0 1px var(--_appearance-color-outline);color:var(--_appearance-color-text);cursor:pointer;padding-inline:calc(var(--_button-block-size,24px) / 6);vertical-align:middle;border:0;border-radius:50%;justify-content:center;align-items:center;margin:0;display:inline-flex}@supports (aspect-ratio:auto){.control{aspect-ratio:1;padding:0}}.control: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))}slot[name=icon]{font-size:var(--_button-icon-size,16px);line-height:1}" });
526
+ var comboboxDefinition = require_vivid_element.defineVividComponent("combobox", Combobox, comboboxTemplate, [
527
+ require_definition.iconDefinition,
528
+ require_definition$2.popupDefinition,
529
+ require_definition$3.listboxOptionDefinition,
530
+ require_mixins.feedbackMessageDefinition
531
+ ], {
532
+ styles: [require_text_field.text_field_default, combobox_default],
533
+ shadowOptions: { delegatesFocus: true }
534
+ });
51
535
  /**
52
- * Registers the contextual-help element with the design system.
536
+ * Registers the combobox elements with the design system.
53
537
  *
54
538
  * @param prefix - the prefix to use for the component name
55
539
  */
56
- var registerContextualHelp = require_vivid_element.createRegisterFunction(contextualHelpDefinition);
540
+ var registerCombobox = require_vivid_element.createRegisterFunction(comboboxDefinition);
57
541
  //#endregion
58
- Object.defineProperty(exports, "ContextualHelp", {
542
+ Object.defineProperty(exports, "Combobox", {
59
543
  enumerable: true,
60
544
  get: function() {
61
- return ContextualHelp;
545
+ return Combobox;
62
546
  }
63
547
  });
64
- Object.defineProperty(exports, "contextualHelpDefinition", {
548
+ Object.defineProperty(exports, "comboboxDefinition", {
65
549
  enumerable: true,
66
550
  get: function() {
67
- return contextualHelpDefinition;
551
+ return comboboxDefinition;
68
552
  }
69
553
  });
70
- Object.defineProperty(exports, "registerContextualHelp", {
554
+ Object.defineProperty(exports, "registerCombobox", {
71
555
  enumerable: true,
72
556
  get: function() {
73
- return registerContextualHelp;
557
+ return registerCombobox;
74
558
  }
75
559
  });