@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,545 +2,538 @@ 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_affix = require("./affix.cjs");
6
- const require_form_associated = require("./form-associated.cjs");
7
- const require_form_element = require("./form-element.cjs");
5
+ const require_delegates_aria = require("./delegates-aria.cjs");
8
6
  const require_with_success_text = require("./with-success-text.cjs");
9
7
  const require_with_error_text = require("./with-error-text.cjs");
10
8
  const require_with_contextual_help = require("./with-contextual-help.cjs");
9
+ const require_trapped_focus = require("./trapped-focus.cjs");
11
10
  const require_definition$1 = require("./definition7.cjs");
12
11
  const require_dialog = require("./dialog.cjs");
13
12
  const require_definition$2 = require("./definition10.cjs");
14
13
  const require_mixins = require("./mixins.cjs");
15
- const require_definition$3 = require("./definition27.cjs");
16
- const require_text_field = require("./text-field.cjs");
17
- const require_listbox = require("./listbox.cjs");
14
+ const require_definition$3 = require("./definition26.cjs");
15
+ const require_definition$4 = require("./definition27.cjs");
16
+ const require_base_color_picker = require("./base-color-picker.cjs");
18
17
  let _microsoft_fast_element = require("@microsoft/fast-element");
19
18
  let _microsoft_fast_web_utilities = require("@microsoft/fast-web-utilities");
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]){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}";
19
+ let vanilla_colorful_hex_color_picker_js = require("vanilla-colorful/hex-color-picker.js");
20
+ let vanilla_colorful_hex_input_js = require("vanilla-colorful/hex-input.js");
21
+ //#region src/lib/color-picker/color-picker.scss?inline
22
+ var color_picker_default = ".palette{grid-template-columns:repeat(var(--swatches-per-row,7), var(--_color-swatch-size,24px));display:grid}.swatch{background-color:var(--swatch-color);block-size:var(--_color-swatch-size,24px);color:var(--vvd-color-canvas);cursor:pointer;inline-size:var(--_color-swatch-size,24px);border-radius:4px;padding:0;position:relative}.swatch:not(.contrast){border:none}.swatch.contrast{border:1px solid var(--vvd-color-neutral-400);color:var(--vvd-color-canvas-text)}.swatch: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:none;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;--focus-inset:-3px}:host{--_low-ink-color:var(--vvd-color-neutral-600);display:inline-block}.base{min-inline-size:var(--_color-picker-min-inline-size,280px);display:inline-block}.control{inline-size:100%}.button{box-sizing:border-box;background-color:var(--button-color,var(--vvd-color-canvas-text));block-size:calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2) - 8));color:var(--vvd-color-canvas);inline-size:calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2) - 8));padding-inline:calc(calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2) - 8)) / 4);vertical-align:middle;border:0;border-radius:4px;align-items:center;margin:0;text-decoration:none;display:inline-flex}.button.contrast{color:var(--vvd-color-canvas-text)}.button:not(.disabled){cursor:pointer}.button.disabled{background-color:var(--vvd-color-neutral-300);color:var(--vvd-color-neutral-500);cursor:not-allowed}.button:focus-visible{--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))}.button [data-vvd-component=icon]{font-size:calc(calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2) - 8)) / 2);line-height:1}.dialog{min-inline-size:var(--_color-picker-popup-min-inline-size,264px);flex-direction:column;display:flex}.dialog .header{justify-content:space-between;align-items:center;padding-block:8px;padding-inline:16px;display:inline-flex}.dialog .header-title{font:var(--vvd-typography-base-extended-bold);margin-block:0}.dialog .body{flex-direction:column;gap:16px;margin-block-end:16px;padding-inline:16px;display:flex}.dialog .hex-input-wrapper{align-items:stretch;gap:8px;display:flex}.dialog .hex-input-wrapper [data-vvd-component=button]{flex:none}.dialog .footer{border-top:1px solid var(--vvd-color-neutral-200);padding:16px}.dialog .footer-header{margin-block-end:8px}.dialog .swatches-count{color:var(--_low-ink-color);font:var(--vvd-typography-base)}.dialog .palette{gap:var(--_color-swatches-gap,8px)}vvd-hex-input{flex:auto;min-width:0}vvd-hex-input::part(input),vvd-hex-input>input{box-sizing:border-box;background-color:var(--vvd-color-canvas);width:100%;height:100%;box-shadow:inset 0 0 0 1px var(--vvd-color-neutral-500);font:var(--vvd-typography-base);padding-inline:calc(calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2))) / 2.5);border:0;border-radius:8px;outline:#0000}vvd-hex-input::part(input):focus-visible,vvd-hex-input>input:focus-visible{box-shadow:0 0 0 4px color-mix(in srgb, var(--focus-stroke-color,var(--vvd-color-cta-500)), transparent 85%), inset 0 0 0 3px var(--focus-stroke-gap-color,currentColor);outline:1px solid var(--focus-stroke-color,var(--vvd-color-cta-500));outline-offset:calc(-1px - var(--focus-inset,0px));--focus-stroke-gap-color:transparent}vvd-hex-picker{width:auto;height:auto;gap:16px;inline-size:100%}vvd-hex-picker::part(saturation){border-radius:8px;block-size:120px}vvd-hex-picker::part(hue){border-radius:8px;flex:0 0 8px}vvd-hex-picker::part(hue-pointer){width:10px;height:10px}vvd-hex-picker::part(saturation-pointer){width:18px;height:18px}::part(popup-base){inline-size:max-content;min-block-size:var(--_color-picker-popup-min-inline-size,264px);min-inline-size:var(--_color-picker-popup-min-inline-size,264px)}.visually-hidden{clip:rect(0 0 0 0);border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}";
22
23
  //#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"
24
+ //#region src/lib/color-picker/color-picker.ts
25
+ var VC_HEX_PICKER_TAG = "vvd-hex-picker";
26
+ var VC_HEX_INPUT_TAG = "vvd-hex-input";
27
+ var VvdHexPicker = class extends vanilla_colorful_hex_color_picker_js.HexColorPicker {
28
+ static {
29
+ this.displayName = "VvdHexPicker";
30
+ }
33
31
  };
34
- //#endregion
35
- //#region src/lib/combobox/combobox.ts
32
+ var VvdHexInput = class extends vanilla_colorful_hex_input_js.HexInput {
33
+ static {
34
+ this.displayName = "VvdHexInput";
35
+ }
36
+ };
37
+ /* v8 ignore if -- @preserve */
38
+ if (!customElements.get(VC_HEX_PICKER_TAG)) customElements.define(VC_HEX_PICKER_TAG, VvdHexPicker);
39
+ /* v8 ignore if -- @preserve */
40
+ if (!customElements.get(VC_HEX_INPUT_TAG)) customElements.define(VC_HEX_INPUT_TAG, VvdHexInput);
41
+ var vcPickerTag = VC_HEX_PICKER_TAG;
42
+ var vcInputTag = VC_HEX_INPUT_TAG;
36
43
  /**
37
44
  * @public
38
- * @component combobox
39
- * @slot - Default slot.
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
45
+ * @component color-picker
46
+ * @slot helper-text - Describes how to use the text-field. Alternative to the `helper-text` attribute.
47
+ * @slot popup-text - Overrides the default "Color Picker" title of the Popup window.
48
+ * @slot swatches-text - Overrides the default "Saved colors:" text above color swatches.
49
+ * @event {CustomEvent<undefined>} change - Fires when the value changes
50
+ * @event {Event} input - Fires when the value of the element changes.
51
+ * @vueModel modelValue value input,@lazy:change `event.currentTarget.value`
50
52
  */
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))))))) {
53
+ var ColorPicker = class extends require_with_contextual_help.WithContextualHelp(require_mixins.WithFeedback(require_with_error_text.WithErrorText(require_with_success_text.WithSuccessText(require_delegates_aria.DelegatesAria(require_trapped_focus.TrappedFocus(require_base_color_picker.BaseColorPicker(require_vivid_element.VividElement))))))) {
52
54
  constructor(..._args) {
53
55
  super(..._args);
54
- this.filteredOptions = [];
55
- this.filter = "";
56
- this.fixedDropdown = false;
57
- this.listboxId = (0, _microsoft_fast_web_utilities.uniqueId)("listbox-");
58
- this.maxHeight = 0;
59
- this.open = false;
60
- this.proxy = document.createElement("input");
56
+ this.disableSavedColors = false;
57
+ this.savedColors = [];
58
+ this.maxSwatches = 6;
59
+ this.copyIconName = "copy-2-line";
60
+ this._copyValueToClipboard = async (value) => {
61
+ try {
62
+ await navigator.clipboard.writeText(value);
63
+ this._setTemporaryCopyIcon("check-circle-line");
64
+ this._ariaLiveDescription = this.locale.colorPicker.copySuccessMessage(value);
65
+ } catch {
66
+ alert(this.locale.colorPicker.copyErrorText);
67
+ this._setTemporaryCopyIcon("error-line");
68
+ this._ariaLiveDescription = this.locale.colorPicker.copyErrorText;
69
+ }
70
+ };
71
+ this._ariaLiveDescription = "";
72
+ }
73
+ static {
74
+ this.HEX_COLOR_PATTERN = /^#(([0-9a-fA-F]{2}){3}|([0-9a-fA-F]){3})$/;
61
75
  }
62
76
  /**
63
77
  * @internal
64
78
  */
65
- formResetCallback() {
66
- super.formResetCallback();
67
- this.selectedIndex = this._newDefaultSelectedIndex([], this.options, -1) ?? -1;
68
- this.value = this.firstSelectedOption?.text || "";
69
- }
70
- /** {@inheritDoc (FormAssociated:interface).validate} */
71
- validate() {
72
- super.validate(this.control);
73
- }
74
- get isAutocompleteInline() {
75
- return this.autocomplete === ComboboxAutocomplete.inline || this.isAutocompleteBoth;
76
- }
77
- get isAutocompleteList() {
78
- return this.autocomplete === ComboboxAutocomplete.list || this.isAutocompleteBoth;
79
+ placeholderChanged() {
80
+ /* v8 ignore if -- @preserve */
81
+ if (this.proxy instanceof HTMLInputElement) this.proxy.placeholder = this.placeholder;
79
82
  }
80
- get isAutocompleteBoth() {
81
- return this.autocomplete === ComboboxAutocomplete.both;
83
+ /**
84
+ * Change event handler for inner control.
85
+ * @remarks
86
+ * @internal
87
+ */
88
+ handleChange() {
89
+ this.$emit("change");
82
90
  }
83
91
  /**
84
92
  * @internal
85
93
  */
86
- openChanged() {
87
- if (this.open) this.enqueueScrollSelectedOptionIntoViewIfNeeded();
94
+ openChanged(_oldValue, newValue) {
95
+ if (newValue && this.isConnected) requestAnimationFrame(() => {
96
+ this._refreshCanvasColor();
97
+ });
88
98
  }
89
99
  /**
90
- * A read-only list of options.
91
- *
92
- * @public
93
- * @remarks
94
- * Overrides `Listbox.options`.
100
+ * @internal
95
101
  */
96
- get options() {
97
- _microsoft_fast_element.Observable.track(this, "options");
98
- return this.filteredOptions.length ? this.filteredOptions : this._options;
102
+ savedColorsKeyChanged() {
103
+ this.savedColors = this._loadSavedColors();
99
104
  }
100
- set options(value) {
101
- super.options = value;
105
+ /**
106
+ * @internal
107
+ */
108
+ get _savedColorsStorageKey() {
109
+ if (this.savedColorsKey) return this.savedColorsKey;
110
+ return `vvd-saved-colors:${this.tagName.toLowerCase()}`;
102
111
  }
103
112
  /**
104
- * Updates the placeholder on the proxy element.
105
113
  * @internal
106
114
  */
107
- placeholderChanged() {
108
- /* v8 ignore if -- @preserve */
109
- if (this.proxy instanceof HTMLInputElement) this.proxy.placeholder = this.placeholder;
115
+ _handleColorSaving() {
116
+ this._saveCurrentColor();
110
117
  }
111
118
  /**
112
119
  * @internal
113
120
  */
114
- valueChanged(prev, next) {
115
- if (this.$fastController.isConnected && this.options) {
116
- const selectedIndex = this.options.findIndex((el) => el.text.toLowerCase() === next.toLowerCase());
117
- this.selectedIndex = this.options[this.selectedIndex]?.text !== this.options[selectedIndex]?.text ? selectedIndex : this.selectedIndex;
118
- }
119
- super.valueChanged(prev, next);
121
+ _saveCurrentColor() {
122
+ const value = this.value;
123
+ if (typeof value !== "string" || !require_base_color_picker.isValidHexColor(value)) return;
124
+ const swatches = Array.isArray(this.savedColors) ? [...this.savedColors] : [];
125
+ const idx = swatches.findIndex((s) => s?.value === value);
126
+ if (idx !== -1) swatches.splice(idx, 1);
127
+ swatches.unshift({ value });
128
+ this.savedColors = swatches.slice(0, this._maxSwatchesNormalized);
129
+ this._setSavedColors(this.savedColors);
120
130
  }
121
131
  /**
122
- * Handle opening and closing the listbox when the combobox is clicked.
123
- *
124
- * @param e - the mouse event
125
132
  * @internal
126
133
  */
127
- clickHandler(e) {
128
- if (this.disabled || this._isFromContextualHelp(e)) return;
129
- if (this.open) {
130
- const capturedOption = e.target.closest(`option,[role=option],[data-vvd-component=option]`);
131
- if (!capturedOption || capturedOption.disabled) return;
132
- this.selectedOptions = [capturedOption];
133
- this.control.value = capturedOption.text;
134
- this.clearSelectionRange();
135
- this.updateValue(true);
134
+ _loadSavedColors() {
135
+ try {
136
+ const savedColors = localStorage.getItem(this._savedColorsStorageKey);
137
+ if (!savedColors) return [];
138
+ const parsed = JSON.parse(savedColors);
139
+ if (!Array.isArray(parsed)) return [];
140
+ return parsed.filter((x) => x && typeof x.value === "string" && require_base_color_picker.isValidHexColor(x.value)).map((x) => ({
141
+ value: x.value,
142
+ label: typeof x.label === "string" ? x.label : void 0
143
+ }));
144
+ } catch {
145
+ return [];
136
146
  }
137
- this.open = !this.open;
138
- if (this.open) this.control.focus();
139
- return true;
140
147
  }
141
148
  /**
142
- * Handle closing the listbox when the combobox is open and the chevron icon is clicked.
143
- *
144
- * @param e - the mouse event
145
149
  * @internal
146
150
  */
147
- _chevronIconClickHandler(e) {
148
- if (!this.open) return;
149
- e.stopPropagation();
150
- this.open = false;
151
+ _setSavedColors(swatches) {
152
+ try {
153
+ localStorage.setItem(this._savedColorsStorageKey, JSON.stringify(swatches));
154
+ } catch {}
151
155
  }
152
- connectedCallback() {
153
- super.connectedCallback();
154
- if (this.value) this.initialValue = this.value;
155
- this._popup.anchor = this._anchor;
156
+ /**
157
+ * Get all color swatches combined, both from swatches property and saved colors
158
+ * @internal
159
+ */
160
+ get allSwatches() {
161
+ const predefinedColors = Array.isArray(this.swatches) ? this.swatches : [];
162
+ const savedColors = Array.isArray(this.savedColors) ? this.savedColors : [];
163
+ const seen = /* @__PURE__ */ new Set();
164
+ const merged = [];
165
+ const appendIfUniqueAndValid = (swatch) => {
166
+ if (!swatch || typeof swatch.value !== "string") return;
167
+ if (!require_base_color_picker.isValidHexColor(swatch.value) || seen.has(swatch.value)) return;
168
+ seen.add(swatch.value);
169
+ merged.push(swatch);
170
+ };
171
+ if (!this.disableSavedColors) savedColors.forEach(appendIfUniqueAndValid);
172
+ predefinedColors.forEach(appendIfUniqueAndValid);
173
+ return merged.slice(0, this._maxSwatchesNormalized);
156
174
  }
157
175
  /**
158
- * Filter available options by text value.
159
- *
160
- * @public
176
+ * @internal
161
177
  */
162
- filterOptions() {
163
- if (!this.autocomplete || this.autocomplete === ComboboxAutocomplete.none) this.filter = "";
164
- this.filteredOptions = this._options.filter((o) => o.text.toLowerCase().startsWith(this.filter.toLowerCase()));
165
- if (this.isAutocompleteList) this._options.forEach((o) => {
166
- o.hidden = !this.filteredOptions.includes(o);
167
- });
178
+ get _maxSwatchesNormalized() {
179
+ return Number.isFinite(this.maxSwatches) ? Math.max(0, Math.floor(this.maxSwatches)) : 0;
168
180
  }
169
181
  /**
170
- * Focus the control and scroll the first selected option into view.
171
- *
172
182
  * @internal
173
- * @remarks
174
- * Overrides: `Listbox.focusAndScrollOptionIntoView`
175
183
  */
176
- focusAndScrollOptionIntoView() {
177
- if (this.contains(document.activeElement)) {
178
- this.control.focus();
179
- this.enqueueScrollSelectedOptionIntoViewIfNeeded();
184
+ maxSwatchesChanged() {
185
+ const maxCount = this._maxSwatchesNormalized;
186
+ if (this.savedColors?.length > maxCount) {
187
+ this.savedColors = this.savedColors.slice(0, maxCount);
188
+ this._setSavedColors(this.savedColors);
180
189
  }
181
190
  }
182
191
  /**
183
192
  * @internal
184
193
  */
185
- enqueueScrollSelectedOptionIntoViewIfNeeded() {
186
- const firstSelectedOption = this.firstSelectedOption;
187
- /* v8 ignore else -- @preserve */
188
- if (firstSelectedOption) requestAnimationFrame(() => {
189
- firstSelectedOption.scrollIntoView({ block: "nearest" });
190
- });
194
+ _onPickerColorChanged(e) {
195
+ if (typeof e.detail?.value === "string") this.value = e.detail?.value;
191
196
  }
192
197
  /**
193
- * Handle focus state when the element or its children lose focus.
194
- *
195
- * @param e - The focus event
196
198
  * @internal
197
199
  */
198
- focusoutHandler(e) {
199
- this.syncValue();
200
- if (!this.open) return true;
201
- const focusTarget = e.relatedTarget;
202
- if (this.isSameNode(focusTarget)) {
203
- this.focus();
204
- return;
205
- }
206
- this.open = false;
200
+ valueChanged(_oldVal, newVal) {
201
+ if (this._vcHexPickerEl && typeof newVal === "string") this._vcHexPickerEl.color = newVal;
202
+ if (this._vcHexInputEl && typeof newVal === "string") this._vcHexInputEl.color = newVal;
207
203
  }
208
204
  /**
209
- * Handle content changes on the control input.
210
- *
211
- * @param e - the input event
212
205
  * @internal
213
206
  */
214
- inputHandler(e) {
215
- this.filter = this.control.value;
216
- this.filterOptions();
217
- if (!this.isAutocompleteInline) this.selectedIndex = this.options.map((option) => option.text).indexOf(this.control.value);
218
- if (e.inputType.includes("deleteContent") || !this.filter.length) return true;
219
- if (this.isAutocompleteList && !this.open) this.open = true;
220
- if (this.isAutocompleteInline) if (this.filteredOptions.length) {
221
- this.selectedOptions = [this.filteredOptions[0]];
222
- this.selectedIndex = this.options.indexOf(this.firstSelectedOption);
223
- this.setInlineSelection();
224
- } else this.selectedIndex = -1;
207
+ _onTextFieldInput(event) {
208
+ this.value = event.currentTarget.value;
225
209
  }
226
210
  /**
227
- * Handle keydown actions for listbox navigation.
228
- *
229
- * @param e - the keyboard event
230
211
  * @internal
231
212
  */
232
- keydownHandler(e) {
233
- const key = e.key;
234
- if (e.ctrlKey || e.shiftKey) return true;
235
- switch (key) {
236
- case "Enter":
237
- this.syncValue();
238
- /* v8 ignore else -- @preserve */
239
- if (this.isAutocompleteInline) this.filter = this.value;
240
- this.open = false;
241
- this.clearSelectionRange();
242
- break;
243
- case "Escape":
244
- /* v8 ignore else -- @preserve */
245
- if (!this.isAutocompleteInline) this.selectedIndex = -1;
246
- if (this.open) {
247
- this.open = false;
248
- break;
249
- }
250
- this.value = "";
251
- this.control.value = "";
252
- this.filter = "";
253
- this.filterOptions();
254
- break;
255
- case "Tab":
256
- this.setInputToSelection();
257
- if (!this.open) return true;
258
- e.preventDefault();
259
- this.open = false;
260
- break;
261
- case "ArrowUp":
262
- case "ArrowDown":
263
- this.filterOptions();
264
- if (!this.open) {
265
- this.open = true;
266
- break;
267
- }
268
- /* v8 ignore else -- @preserve */
269
- if (this.filteredOptions.length > 0) super.keydownHandler(e);
270
- if (this.isAutocompleteInline) this.setInlineSelection();
271
- break;
272
- default: return true;
273
- }
213
+ get _buttonColor() {
214
+ /* v8 ignore else -- @preserve */
215
+ if (!this._canvasColor) this._refreshCanvasColor();
216
+ if (this.value && require_base_color_picker.isValidHexColor(this.value)) return this.value;
217
+ return "var(--vvd-color-canvas-text)";
274
218
  }
275
219
  /**
276
- * Ensure that the selectedIndex is within the current allowable filtered range.
277
- *
278
- * @param prev - the previous selected index value
279
- * @param next - the current selected index value
280
- *
281
220
  * @internal
282
221
  */
283
- selectedIndexChanged(prev, next) {
284
- if (this.$fastController.isConnected) {
285
- next = (0, _microsoft_fast_web_utilities.limit)(-1, this.options.length - 1, next);
286
- if (next !== this.selectedIndex) {
287
- this.selectedIndex = next;
288
- return;
289
- }
290
- super.selectedIndexChanged(prev, next);
291
- }
222
+ _onButtonClick() {
223
+ this.open = !this.open;
292
224
  }
293
225
  /**
294
- * Move focus to the previous selectable option.
295
- *
296
226
  * @internal
297
- * @remarks
298
- * Overrides `Listbox.selectPreviousOption`
299
227
  */
300
- selectPreviousOption() {
301
- if (!this.disabled && this.selectedIndex >= 0) this.selectedIndex = this.selectedIndex - 1;
302
- }
303
- _isDefaultSelected(option) {
304
- return super._isDefaultSelected(option) || option.text !== "" && option.text === this.initialValue;
228
+ _handleCloseRequest() {
229
+ this.open = false;
305
230
  }
306
231
  /**
307
- * Focus and set the content of the control based on the first selected option.
308
- *
309
232
  * @internal
310
233
  */
311
- setInputToSelection() {
312
- if (this.firstSelectedOption) {
313
- this.control.value = this.firstSelectedOption.text;
314
- this.control.focus();
315
- }
234
+ _isInPath(e, el) {
235
+ if (!el) return false;
236
+ const path = e.composedPath?.();
237
+ return !!(path && path.includes(el));
316
238
  }
317
239
  /**
318
- * Focus, set and select the content of the control based on the first selected option.
319
- *
320
240
  * @internal
321
241
  */
322
- setInlineSelection() {
323
- /* v8 ignore else -- @preserve */
324
- if (this.firstSelectedOption) {
325
- this.setInputToSelection();
326
- this.control.setSelectionRange(this.filter.length, this.control.value.length, "backward");
327
- }
242
+ #closeOnPointerOutside = (e) => {
243
+ if (this._isInPath(e, this._buttonEl) || this._isInPath(e, this._popupEl)) return;
244
+ this.open = false;
245
+ };
246
+ connectedCallback() {
247
+ super.connectedCallback();
248
+ this.savedColors = this._loadSavedColors();
249
+ document.addEventListener("mousedown", this.#closeOnPointerOutside, true);
250
+ }
251
+ disconnectedCallback() {
252
+ super.disconnectedCallback();
253
+ document.removeEventListener("mousedown", this.#closeOnPointerOutside, true);
328
254
  }
255
+ #iconResetTimer = null;
329
256
  /**
330
- * Determines if a value update should involve emitting a change event, then updates the value.
331
- *
332
257
  * @internal
333
258
  */
334
- syncValue() {
335
- const newValue = this.firstSelectedOption?.text ?? this.control.value;
336
- this.updateValue(this.value !== newValue);
259
+ _setTemporaryCopyIcon(name, ms = 2e3) {
260
+ this.copyIconName = name;
261
+ if (this.#iconResetTimer) clearTimeout(this.#iconResetTimer);
262
+ this.#iconResetTimer = setTimeout(() => {
263
+ this.copyIconName = "copy-2-line";
264
+ this.#iconResetTimer = null;
265
+ }, ms);
337
266
  }
338
267
  /**
339
- * Ensure that the entire list of options is used when setting the selected property.
340
- *
341
- * @param prev - the previous list of selected options
342
- * @param next - the current list of selected options
343
- *
344
268
  * @internal
345
- * @remarks
346
- * Overrides: `Listbox.selectedOptionsChanged`
347
269
  */
348
- selectedOptionsChanged(_prev, next) {
349
- if (this.$fastController.isConnected) this._options.forEach((o) => {
350
- o.selected = next.includes(o);
351
- });
270
+ _onBaseKeydown(event) {
271
+ if (this.open && require_dialog.handleEscapeKeyAndStopPropogation(event)) {
272
+ this.open = false;
273
+ return false;
274
+ }
275
+ if (this._trappedFocus(event, () => this._focusableElsWithinDialog())) return false;
276
+ return true;
352
277
  }
353
278
  /**
354
- * Synchronize the form-associated proxy and update the value property of the element.
355
- *
356
- * @param prev - the previous collection of slotted option elements
357
- * @param next - the next collection of slotted option elements
358
- *
359
279
  * @internal
360
280
  */
361
- slottedOptionsChanged(prev, next) {
362
- super.slottedOptionsChanged(prev, next);
363
- this.updateValue();
364
- const scale = this.getAttribute("scale") || this.scale;
365
- next.forEach((element) => {
366
- if (scale) {
367
- element.setAttribute("scale", scale);
368
- element.scale = scale;
369
- }
370
- });
281
+ _focusableElsWithinDialog() {
282
+ return this._popupEl.querySelectorAll("button:not([role=\"gridcell\"]), [data-vvd-component=\"button\"], vwc-button:not([role=\"gridcell\"])");
371
283
  }
372
284
  /**
373
- * Sets the value and to match the first selected option.
374
- *
375
- * @param shouldEmit - if true, the change event will be emitted
376
- *
377
285
  * @internal
378
286
  */
379
- updateValue(shouldEmit) {
380
- if (this.$fastController.isConnected) this.value = this.firstSelectedOption?.text || this.control.value;
381
- if (shouldEmit) this.$emit("change");
287
+ _handleCellKeydown(event, value, index, isSaveCell) {
288
+ if (event.key === "Tab") {
289
+ event.preventDefault();
290
+ const focusableEls = this._focusableElsWithinDialog();
291
+ const idx = Array.prototype.indexOf.call(focusableEls, event.currentTarget);
292
+ focusableEls[event.shiftKey ? (idx - 1 + focusableEls.length) % focusableEls.length : (idx + 1) % focusableEls.length]?.focus();
293
+ return false;
294
+ }
295
+ return super._handleCellKeydown(event, value, index, isSaveCell);
382
296
  }
383
297
  /**
384
298
  * @internal
385
299
  */
386
- clearSelectionRange() {
387
- const controlValueLength = this.control.value.length;
388
- this.control.setSelectionRange(controlValueLength, controlValueLength);
300
+ _handleSwatchSelection(value) {
301
+ /* v8 ignore else -- @preserve */
302
+ if (this.value !== value) this._ariaLiveDescription = this.locale.colorPicker.selectionSuccessMessage(value);
303
+ super._handleSwatchSelection(value);
389
304
  }
390
305
  };
391
- require_decorate.__decorate([(0, _microsoft_fast_element.attr)({
392
- attribute: "autocomplete",
393
- mode: "fromView"
394
- })], Combobox.prototype, "autocomplete", void 0);
395
- require_decorate.__decorate([_microsoft_fast_element.attr], Combobox.prototype, "appearance", void 0);
396
- require_decorate.__decorate([_microsoft_fast_element.attr], Combobox.prototype, "shape", void 0);
397
- require_decorate.__decorate([(0, _microsoft_fast_element.attr)()], Combobox.prototype, "scale", void 0);
398
- require_decorate.__decorate([_microsoft_fast_element.attr], Combobox.prototype, "placement", void 0);
306
+ require_decorate.__decorate([_microsoft_fast_element.attr], ColorPicker.prototype, "placeholder", void 0);
307
+ require_decorate.__decorate([(0, _microsoft_fast_element.attr)({ attribute: "saved-colors-key" })], ColorPicker.prototype, "savedColorsKey", void 0);
399
308
  require_decorate.__decorate([(0, _microsoft_fast_element.attr)({
400
309
  mode: "boolean",
401
- attribute: "fixed-dropdown"
402
- })], Combobox.prototype, "fixedDropdown", void 0);
403
- require_decorate.__decorate([_microsoft_fast_element.observable], Combobox.prototype, "metaSlottedContent", void 0);
404
- require_decorate.__decorate([_microsoft_fast_element.observable], Combobox.prototype, "maxHeight", void 0);
310
+ attribute: "disable-saved-colors"
311
+ })], ColorPicker.prototype, "disableSavedColors", void 0);
312
+ require_decorate.__decorate([_microsoft_fast_element.observable], ColorPicker.prototype, "savedColors", void 0);
405
313
  require_decorate.__decorate([(0, _microsoft_fast_element.attr)({
406
- attribute: "open",
407
- mode: "boolean"
408
- })], Combobox.prototype, "open", void 0);
409
- require_decorate.__decorate([_microsoft_fast_element.attr], Combobox.prototype, "placeholder", void 0);
314
+ attribute: "max-swatches",
315
+ mode: "fromView",
316
+ converter: _microsoft_fast_element.nullableNumberConverter
317
+ })], ColorPicker.prototype, "maxSwatches", void 0);
318
+ require_decorate.__decorate([_microsoft_fast_element.observable], ColorPicker.prototype, "copyIconName", void 0);
319
+ require_decorate.__decorate([_microsoft_fast_element.observable], ColorPicker.prototype, "_ariaLiveDescription", void 0);
410
320
  //#endregion
411
- //#region src/lib/combobox/combobox.template.ts
412
- 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]);
413
- function renderLabel() {
414
- return _microsoft_fast_element.html` <label for="control" class="label">
415
- ${(x) => x.label}
416
- </label>`;
417
- }
418
- function setFixedDropdownVarWidth(x) {
419
- return x.open && x.fixedDropdown ? `--_combobox-fixed-width: ${Math.round(x.getBoundingClientRect().width)}px` : null;
420
- }
421
- function renderInput(context) {
422
- const affixIconTemplate = require_affix.affixIconTemplateFactory(context);
423
- const chevronTemplate = require_definition$1.chevronTemplateFactory(context);
424
- return _microsoft_fast_element.html` <div class="${getStateClasses}" ${(0, _microsoft_fast_element.ref)("_anchor")}>
425
- <div
426
- class="label-wrapper"
427
- ?hidden=${(x) => !x.label && !x._hasContextualHelp}
321
+ //#region src/lib/color-picker/color-picker.template.ts
322
+ function renderTextField(textFieldTag, iconTag) {
323
+ const getClasses = (_) => (0, _microsoft_fast_web_utilities.classNames)("control");
324
+ return _microsoft_fast_element.html`
325
+ <${textFieldTag}
326
+ id="text-field"
327
+ class="${getClasses}"
328
+ pattern="${ColorPicker.HEX_COLOR_PATTERN.source}"
329
+ maxlength="7"
330
+ label="${(x) => x.label}"
331
+ :value="${(x) => x.value}"
332
+ placeholder="${(x) => x.placeholder}"
333
+ helper-text="${(x) => x.helperText}"
334
+ error-text="${(x) => x.errorValidationMessage}"
335
+ success-text="${(x) => x.successText}"
336
+ ?disabled="${(x) => x.disabled}"
337
+ ?required="${(x) => x.required}"
338
+ @input='${(x, c) => x._onTextFieldInput(c.event)}'
339
+ @change="${(x) => x.handleChange()}"
340
+ @blur="${(x) => {
341
+ x.$emit("blur", void 0, { bubbles: false });
342
+ }}"
343
+ @focus="${(x) => {
344
+ x.$emit("focus", void 0, { bubbles: false });
345
+ }}"
346
+ ${require_delegates_aria.delegateAria()}
347
+ ${(0, _microsoft_fast_element.ref)("_textFieldEl")}
428
348
  >
429
- ${(0, _microsoft_fast_element.when)((x) => x.label, renderLabel())}
349
+ <button
350
+ aria-label="${(x) => x.locale.colorPicker.pickerButtonLabel}"
351
+ aria-expanded="${(x) => x.open}"
352
+ aria-haspopup="dialog"
353
+ class="button ${(x) => (0, _microsoft_fast_web_utilities.classNames)(x._applyContrastClass(x._buttonColor) ? "contrast" : "", x.disabled ? "disabled" : "")}"
354
+ style="--button-color: ${(x) => x._buttonColor};"
355
+ ?disabled="${(x) => x.disabled}"
356
+ @click="${(x) => x._onButtonClick()}"
357
+ slot="action-items"
358
+ ${(0, _microsoft_fast_element.ref)("_buttonEl")}>
359
+ <${iconTag} name="edit-line"></${iconTag}>
360
+ </button>
361
+ <slot
362
+ slot="${(x) => x._helperTextSlottedContent?.length ? "helper-text" : void 0}"
363
+ name="helper-text"
364
+ ${(0, _microsoft_fast_element.slotted)("_helperTextSlottedContent")}
365
+ ></slot>
430
366
  <slot
431
- name="contextual-help"
367
+ slot='${(x) => x._contextualHelpSlottedContent?.length ? "contextual-help" : void 0}'
368
+ name='contextual-help'
432
369
  ${(0, _microsoft_fast_element.slotted)("_contextualHelpSlottedContent")}
433
370
  ></slot>
371
+ </${textFieldTag}>
372
+ `;
373
+ }
374
+ function renderPopupHeader(buttonTag, iconTag) {
375
+ return _microsoft_fast_element.html`
376
+ <div class="header">
377
+ <h2 class="header-title" id="color-picker-title">
378
+ <slot name="popup-text">${(x) => x.locale.colorPicker.popupLabel}</slot>
379
+ </h2>
380
+ <${buttonTag} size="condensed"
381
+ aria-label="${(x) => x.locale.colorPicker.closeButtonLabel}"
382
+ @click="${(x) => x._handleCloseRequest()}">
383
+ <${iconTag} slot="icon" name="close-line"></${iconTag}>
384
+ </${buttonTag}>
434
385
  </div>
435
- <div class="fieldset">
436
- ${(x) => affixIconTemplate(x.icon, require_affix.IconWrapper.Slot)}
437
- <div class="wrapper">
438
- <input
439
- id="control"
440
- autocomplete="off"
441
- class="control"
442
- aria-activedescendant="${(x) => x.open ? x._activeDescendant : null}"
443
- aria-autocomplete="${(x) => x.autocomplete}"
444
- aria-controls="${(x) => x.listboxId}"
445
- aria-expanded="${(x) => x.open}"
446
- aria-haspopup="listbox"
447
- aria-describedby="${(x) => x._feedbackDescribedBy}"
448
- placeholder="${(x) => x.placeholder}"
449
- role="combobox"
450
- type="text"
451
- ?disabled="${(x) => x.disabled}"
452
- :value="${(x) => x.value}"
453
- @input="${(x, c) => x.inputHandler(c.event)}"
454
- ${(0, _microsoft_fast_element.ref)("control")}
455
- />
456
- </div>
457
- <div class="leading-items-wrapper">
458
- <slot name="meta" ${(0, _microsoft_fast_element.slotted)("metaSlottedContent")}></slot>
459
- <div
460
- @click="${(x, c) => x._chevronIconClickHandler(c.event)}"
386
+ `;
387
+ }
388
+ function renderPopupBody(buttonTag, iconTag, tooltipTag) {
389
+ return _microsoft_fast_element.html`
390
+ <div class="body">
391
+ <${_microsoft_fast_element.html.partial(vcPickerTag)}
392
+ part="hex-picker"
393
+ color="${(x) => x.value}"
394
+ @color-changed="${(x, c) => x._onPickerColorChanged(c.event)}"
395
+ ${(0, _microsoft_fast_element.ref)("_vcHexPickerEl")}
396
+ ></${_microsoft_fast_element.html.partial(vcPickerTag)}>
397
+ <div class="hex-input-wrapper">
398
+ <${_microsoft_fast_element.html.partial(vcInputTag)}
399
+ part="hex-input"
400
+ prefixed
401
+ color="${(x) => x.value}"
402
+ @color-changed="${(x, c) => x._onPickerColorChanged(c.event)}"
403
+ ${(0, _microsoft_fast_element.ref)("_vcHexInputEl")}
461
404
  >
462
- ${chevronTemplate}
463
- </div>
405
+ <input name="hex-code-input" aria-label="${(x) => x.locale.colorPicker.hexInputLabel}"
406
+ placeholder="${(x) => x.placeholder}"
407
+ @blur="${(x, c) => c.event.stopImmediatePropagation()}"
408
+ part="input">
409
+ </${_microsoft_fast_element.html.partial(vcInputTag)}>
410
+ <${tooltipTag} placement="top"
411
+ text="${(x) => x.locale.colorPicker.copyButtonLabel}"
412
+ exportparts="vvd-theme-alternate">
413
+ <${buttonTag}
414
+ slot="anchor" size="normal"
415
+ aria-label="${(x) => x.locale.colorPicker.copyButtonLabel}"
416
+ @click="${(x) => x._copyValueToClipboard(x.value)}">
417
+ <${iconTag} slot="icon" name="${(x) => x.copyIconName}"></${iconTag}>
418
+ </${buttonTag}>
419
+ </${tooltipTag}>
464
420
  </div>
465
421
  </div>
466
- </div>`;
422
+ `;
467
423
  }
468
- var comboboxTemplate = (context) => {
469
- const popupTag = context.tagFor(require_definition$2.Popup);
424
+ function renderPopupFooter(buttonTag, iconTag, tooltipTag) {
470
425
  return _microsoft_fast_element.html`
471
- <template
472
- tabindex="${(x) => !x.disabled ? "0" : null}"
473
- @click="${(x, c) => x.clickHandler(c.event)}"
474
- @focusout="${(x, c) => x.focusoutHandler(c.event)}"
475
- @keydown="${(x, { event }) => {
476
- x.open && require_dialog.handleEscapeKeyAndStopPropogation(event);
477
- return x.keydownHandler(event);
478
- }}"
479
- >
480
- <div class="control-wrapper">
481
- ${() => renderInput(context)}
482
- <${popupTag} class="popup"
483
- style="${setFixedDropdownVarWidth}"
484
- ?open="${(x) => x.open}"
485
- placement="${(x) => x.placement ?? "bottom-start"}"
486
- strategy="${(x) => x.fixedDropdown ? "fixed" : "absolute"}"
487
- ${(0, _microsoft_fast_element.ref)("_popup")}>
488
- <div id="${(x) => x.listboxId}"
489
- class="listbox"
490
- role="listbox"
491
- ?disabled="${(x) => x.disabled}"
492
- ${(0, _microsoft_fast_element.ref)("listbox")}>
493
- <slot ${(0, _microsoft_fast_element.slotted)({
494
- filter: require_listbox.Listbox.slottedOptionFilter,
495
- flatten: true,
496
- property: "slottedOptions"
497
- })}>
498
- </slot>
499
- </div>
500
- </${popupTag}>
426
+ <div class="footer">
427
+ <div class="footer-header">
428
+ <span class="footer-title" id="color-picker-footer-title"
429
+ ><slot name="swatches-text"
430
+ >${(x) => x.locale.colorPicker.swatchesLabel}</slot
431
+ ></span
432
+ >
433
+ ${(0, _microsoft_fast_element.when)((x) => !x.disableSavedColors, renderSwatchesCount())}
501
434
  </div>
502
- <div class="feedback-wrapper" @click="${(_, c) => c.event.stopPropagation()}">
503
- ${(x) => x._getFeedbackTemplate(context)}
435
+ <div
436
+ class="palette"
437
+ role="grid"
438
+ aria-rowcount="${(x) => Math.ceil(x.allSwatches.length / x._getRowLength())}"
439
+ aria-colcount="${(x) => x._getRowLength()}"
440
+ style="--swatches-per-row: ${(x) => x._getRowLength()};"
441
+ aria-labelledby="color-picker-footer-title"
442
+ >
443
+ ${(0, _microsoft_fast_element.repeat)((x) => x.allSwatches, (x) => x._renderColorSwatch(iconTag, tooltipTag), { positioning: true })}
444
+ ${(0, _microsoft_fast_element.when)((x) => !x.disableSavedColors, _microsoft_fast_element.html`
445
+ <${tooltipTag} placement="top"
446
+ text="${(x) => x.locale.colorPicker.saveButtonLabel}"
447
+ exportparts="vvd-theme-alternate">
448
+ <${buttonTag}
449
+ slot="anchor"
450
+ appearance="outlined"
451
+ size="super-condensed"
452
+ role="gridcell"
453
+ tabindex="${(x) => x.allSwatches.length ? "-1" : "0"}"
454
+ aria-label="${(x) => x.locale.colorPicker.saveButtonLabel}"
455
+ @click="${(x) => x._saveCurrentColor()}"
456
+ @keydown="${(x, c) => x._handleCellKeydown(c.event, x.value, x.allSwatches.length, true)}">
457
+ <${iconTag} slot="icon" name="plus-line"></${iconTag}>
458
+ </${buttonTag}>
459
+ </${tooltipTag}>
460
+ `)}
504
461
  </div>
505
- </template>
462
+ </div>
463
+ `;
464
+ }
465
+ function renderSwatchesCount() {
466
+ return _microsoft_fast_element.html`
467
+ <span
468
+ id="swatches-count"
469
+ class="swatches-count"
470
+ aria-label="${(x) => x.locale.colorPicker.maxSwatchesMessage(x.allSwatches.length, x.maxSwatches)}"
471
+ >${(x) => `${x.allSwatches.length}/${x.maxSwatches}`}</span
472
+ >
473
+ `;
474
+ }
475
+ var ColorPickerTemplate = (context) => {
476
+ const textFieldTag = context.tagFor(require_definition$3.TextField);
477
+ const iconTag = context.tagFor(require_definition.Icon);
478
+ const popupTag = context.tagFor(require_definition$2.Popup);
479
+ const buttonTag = context.tagFor(require_definition$1.Button);
480
+ const tooltipTag = context.tagFor(require_definition$4.Tooltip);
481
+ return _microsoft_fast_element.html`
482
+ <div class="base" @keydown="${(x, { event }) => x._onBaseKeydown(event)}">
483
+ <span aria-live="assertive" aria-relevant="text" class="visually-hidden">
484
+ ${(x) => x._ariaLiveDescription}
485
+ </span>
486
+ ${renderTextField(textFieldTag, iconTag)}
487
+ <${popupTag}
488
+ :open="${(x) => x.open}"
489
+ :anchor="${(x) => x._buttonEl}"
490
+ placement="top"
491
+ offset="10"
492
+ ${(0, _microsoft_fast_element.ref)("_popupEl")}>
493
+ <div class="dialog"
494
+ role="dialog"
495
+ aria-modal="true"
496
+ aria-labelledby="color-picker-title">
497
+ ${renderPopupHeader(buttonTag, iconTag)}
498
+ ${renderPopupBody(buttonTag, iconTag, tooltipTag)}
499
+ ${(0, _microsoft_fast_element.when)((x) => !x.disableSavedColors || x.allSwatches.length > 0, renderPopupFooter(buttonTag, iconTag, tooltipTag))}
500
+ </div>
501
+ </${popupTag}>
502
+ </div>
506
503
  `;
507
504
  };
508
505
  //#endregion
509
- //#region src/lib/combobox/definition.ts
510
- /**
511
- * @internal
512
- */
513
- var comboboxDefinition = require_vivid_element.defineVividComponent("combobox", Combobox, comboboxTemplate, [
514
- require_definition.iconDefinition,
506
+ //#region src/lib/color-picker/definition.ts
507
+ var colorPickerDefinition = require_vivid_element.defineVividComponent("color-picker", ColorPicker, ColorPickerTemplate, [
515
508
  require_definition$2.popupDefinition,
516
- require_definition$3.listboxOptionDefinition,
509
+ require_definition.iconDefinition,
510
+ require_definition$3.textFieldDefinition,
511
+ require_definition$1.buttonDefinition,
512
+ require_definition$4.tooltipDefinition,
517
513
  require_mixins.feedbackMessageDefinition
518
- ], {
519
- styles: [require_text_field.text_field_default, combobox_default],
520
- shadowOptions: { delegatesFocus: true }
521
- });
514
+ ], { styles: color_picker_default });
522
515
  /**
523
- * Registers the combobox elements with the design system.
516
+ * Registers the color-picker element with the design system.
524
517
  *
525
518
  * @param prefix - the prefix to use for the component name
526
519
  */
527
- var registerCombobox = require_vivid_element.createRegisterFunction(comboboxDefinition);
520
+ var registerColorPicker = require_vivid_element.createRegisterFunction(colorPickerDefinition);
528
521
  //#endregion
529
- Object.defineProperty(exports, "Combobox", {
522
+ Object.defineProperty(exports, "ColorPicker", {
530
523
  enumerable: true,
531
524
  get: function() {
532
- return Combobox;
525
+ return ColorPicker;
533
526
  }
534
527
  });
535
- Object.defineProperty(exports, "comboboxDefinition", {
528
+ Object.defineProperty(exports, "colorPickerDefinition", {
536
529
  enumerable: true,
537
530
  get: function() {
538
- return comboboxDefinition;
531
+ return colorPickerDefinition;
539
532
  }
540
533
  });
541
- Object.defineProperty(exports, "registerCombobox", {
534
+ Object.defineProperty(exports, "registerColorPicker", {
542
535
  enumerable: true,
543
536
  get: function() {
544
- return registerCombobox;
537
+ return registerColorPicker;
545
538
  }
546
539
  });