@vonage/vivid 5.16.0 → 5.18.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (564) hide show
  1. package/accordion/definition.cjs +6 -6
  2. package/accordion/definition.js +1 -1
  3. package/accordion/index.cjs +1 -1
  4. package/accordion/index.js +2 -2
  5. package/accordion-item/definition.cjs +5 -5
  6. package/accordion-item/definition.js +1 -1
  7. package/accordion-item/index.cjs +1 -1
  8. package/accordion-item/index.js +2 -2
  9. package/action-group/index.cjs +3 -3
  10. package/action-group/index.js +5 -5
  11. package/alert/definition.cjs +5 -5
  12. package/alert/definition.js +1 -1
  13. package/alert/index.cjs +3 -3
  14. package/alert/index.js +15 -14
  15. package/audio-player/definition.cjs +5 -5
  16. package/audio-player/definition.js +1 -1
  17. package/audio-player/index.cjs +16 -16
  18. package/audio-player/index.js +29 -28
  19. package/avatar/definition.cjs +5 -5
  20. package/avatar/definition.js +1 -1
  21. package/avatar/index.cjs +4 -4
  22. package/avatar/index.js +12 -11
  23. package/badge/definition.cjs +5 -5
  24. package/badge/definition.js +1 -1
  25. package/badge/index.cjs +1 -4
  26. package/badge/index.js +4 -20
  27. package/banner/definition.cjs +5 -5
  28. package/banner/definition.js +1 -1
  29. package/banner/index.cjs +3 -3
  30. package/banner/index.js +14 -13
  31. package/breadcrumb-item/definition.cjs +4 -4
  32. package/breadcrumb-item/definition.js +1 -1
  33. package/breadcrumb-item/index.cjs +1 -1
  34. package/breadcrumb-item/index.js +1 -0
  35. package/bundled/affix.cjs +1 -1
  36. package/bundled/affix.js +5 -5
  37. package/bundled/base-color-picker.cjs +2 -2
  38. package/bundled/base-color-picker.js +5 -5
  39. package/bundled/button.cjs +1 -1
  40. package/bundled/button.js +2 -2
  41. package/bundled/calendar-picker.template.cjs +2 -2
  42. package/bundled/calendar-picker.template.js +498 -498
  43. package/bundled/definition10.cjs +18 -30
  44. package/bundled/definition10.js +53 -155
  45. package/bundled/definition11.cjs +10 -19
  46. package/bundled/definition11.js +25 -74
  47. package/bundled/definition12.cjs +72 -18
  48. package/bundled/definition12.js +171 -107
  49. package/bundled/definition13.cjs +18 -17
  50. package/bundled/definition13.js +46 -66
  51. package/bundled/definition14.cjs +5 -10
  52. package/bundled/definition14.js +9 -27
  53. package/bundled/definition15.cjs +17 -71
  54. package/bundled/definition15.js +64 -181
  55. package/bundled/definition16.cjs +12 -4
  56. package/bundled/definition16.js +79 -14
  57. package/bundled/definition17.cjs +19 -13
  58. package/bundled/definition17.js +118 -69
  59. package/bundled/definition18.cjs +87 -12
  60. package/bundled/definition18.js +409 -52
  61. package/bundled/definition19.cjs +5 -87
  62. package/bundled/definition19.js +14 -422
  63. package/bundled/definition2.cjs +3 -14
  64. package/bundled/definition2.js +16 -49
  65. package/bundled/definition20.cjs +30 -5
  66. package/bundled/definition20.js +159 -9
  67. package/bundled/definition21.cjs +28 -19
  68. package/bundled/definition21.js +164 -47
  69. package/bundled/definition22.cjs +4 -24
  70. package/bundled/definition22.js +18 -88
  71. package/bundled/definition23.cjs +12 -0
  72. package/bundled/definition23.js +37 -0
  73. package/bundled/definition24.cjs +39 -0
  74. package/bundled/definition24.js +72 -0
  75. package/bundled/definition3.cjs +1 -1
  76. package/bundled/definition3.js +24 -21
  77. package/bundled/definition4.cjs +23 -38
  78. package/bundled/definition4.js +81 -63
  79. package/bundled/definition5.cjs +2 -2
  80. package/bundled/definition5.js +5 -5
  81. package/bundled/definition6.cjs +11 -11
  82. package/bundled/definition6.js +57 -41
  83. package/bundled/definition9.cjs +12 -30
  84. package/bundled/definition9.js +55 -148
  85. package/bundled/divider.cjs +1 -1
  86. package/bundled/divider.js +5 -5
  87. package/bundled/listbox.cjs +1 -1
  88. package/bundled/listbox.js +1 -1
  89. package/bundled/localized.cjs +1 -1
  90. package/bundled/localized.js +1 -0
  91. package/bundled/mixins.cjs +5 -5
  92. package/bundled/mixins.js +49 -49
  93. package/bundled/numberConverter.cjs +12 -0
  94. package/bundled/numberConverter.js +38 -0
  95. package/bundled/picker-field.template.cjs +8 -7
  96. package/bundled/picker-field.template.js +16 -15
  97. package/bundled/slider.template.cjs +7 -7
  98. package/bundled/slider.template.js +12 -12
  99. package/bundled/slottable-request.cjs +1 -1
  100. package/bundled/slottable-request.js +8 -38
  101. package/bundled/time-selection-picker.template.cjs +4 -4
  102. package/bundled/time-selection-picker.template.js +35 -35
  103. package/bundled/utils.cjs +1 -0
  104. package/bundled/utils.js +1420 -0
  105. package/bundled/vivid-element.cjs +1 -1
  106. package/bundled/vivid-element.js +1 -1
  107. package/button/definition.cjs +5 -5
  108. package/button/definition.js +1 -1
  109. package/button/index.cjs +1 -1
  110. package/button/index.js +1 -1
  111. package/calendar/index.cjs +11 -11
  112. package/calendar/index.js +30 -237
  113. package/calendar-event/index.cjs +3 -3
  114. package/calendar-event/index.js +4 -4
  115. package/card/definition.cjs +5 -5
  116. package/card/definition.js +1 -1
  117. package/card/index.cjs +15 -12
  118. package/card/index.js +17 -13
  119. package/checkbox/definition.cjs +5 -5
  120. package/checkbox/definition.js +1 -1
  121. package/checkbox/index.cjs +1 -1
  122. package/checkbox/index.js +2 -2
  123. package/color-picker/definition.cjs +5 -5
  124. package/color-picker/definition.js +2 -2
  125. package/color-picker/index.cjs +10 -10
  126. package/color-picker/index.js +58 -57
  127. package/combobox/definition.cjs +5 -5
  128. package/combobox/definition.js +2 -2
  129. package/combobox/index.cjs +9 -8
  130. package/combobox/index.js +40 -35
  131. package/contextual-help/definition.cjs +5 -5
  132. package/contextual-help/definition.js +2 -2
  133. package/contextual-help/index.cjs +1 -1
  134. package/contextual-help/index.js +2 -2
  135. package/country/definition.cjs +5 -5
  136. package/country/definition.js +1 -1
  137. package/country/index.cjs +1 -12
  138. package/country/index.js +4 -1216
  139. package/country-group/definition.cjs +6 -0
  140. package/country-group/definition.js +3 -0
  141. package/country-group/index.cjs +43 -0
  142. package/country-group/index.js +166 -0
  143. package/custom-elements.json +1274 -200
  144. package/data-grid/definition.cjs +9 -9
  145. package/data-grid/definition.js +2 -2
  146. package/data-grid/index.cjs +18 -18
  147. package/data-grid/index.js +260 -262
  148. package/date-picker/definition.cjs +5 -5
  149. package/date-picker/definition.js +2 -2
  150. package/date-picker/index.cjs +1 -1
  151. package/date-picker/index.js +13 -13
  152. package/date-range-picker/definition.cjs +5 -5
  153. package/date-range-picker/definition.js +2 -2
  154. package/date-range-picker/index.cjs +1 -1
  155. package/date-range-picker/index.js +8 -8
  156. package/date-time-picker/definition.cjs +5 -5
  157. package/date-time-picker/definition.js +2 -2
  158. package/date-time-picker/index.cjs +4 -4
  159. package/date-time-picker/index.js +25 -25
  160. package/dial-pad/definition.cjs +5 -5
  161. package/dial-pad/definition.js +2 -2
  162. package/dial-pad/index.cjs +6 -5
  163. package/dial-pad/index.js +14 -12
  164. package/dialog/definition.cjs +5 -5
  165. package/dialog/definition.js +2 -2
  166. package/dialog/index.cjs +6 -6
  167. package/dialog/index.js +17 -16
  168. package/divider/definition.cjs +1 -1
  169. package/divider/definition.js +1 -1
  170. package/divider/index.cjs +1 -1
  171. package/divider/index.js +1 -1
  172. package/empty-state/definition.cjs +5 -5
  173. package/empty-state/definition.js +2 -2
  174. package/empty-state/index.cjs +2 -2
  175. package/empty-state/index.js +6 -5
  176. package/fab/definition.cjs +5 -5
  177. package/fab/definition.js +2 -2
  178. package/fab/index.cjs +4 -4
  179. package/fab/index.js +13 -12
  180. package/file-picker/definition.cjs +5 -5
  181. package/file-picker/definition.js +2 -2
  182. package/file-picker/index.cjs +20 -17
  183. package/file-picker/index.js +40 -36
  184. package/flag/definition.cjs +6 -0
  185. package/flag/definition.js +3 -0
  186. package/flag/index.cjs +10 -0
  187. package/flag/index.js +61 -0
  188. package/header/definition.cjs +1 -1
  189. package/header/definition.js +1 -1
  190. package/header/index.cjs +4 -4
  191. package/header/index.js +5 -5
  192. package/icon/definition.cjs +1 -0
  193. package/icon/definition.js +1 -0
  194. package/icon/index.cjs +1 -1
  195. package/icon/index.js +1 -0
  196. package/index.cjs +204 -192
  197. package/index.js +55 -52
  198. package/layout/definition.cjs +1 -1
  199. package/layout/definition.js +1 -1
  200. package/lib/button/button.d.ts +1 -0
  201. package/lib/combobox/combobox.d.ts +0 -3
  202. package/lib/components.d.ts +2 -0
  203. package/lib/country/countries-data.d.ts +1 -0
  204. package/lib/country/{country-code-to-flag-icon.d.ts → utils.d.ts} +0 -3
  205. package/lib/country-group/country-group.d.ts +829 -0
  206. package/lib/country-group/country-group.template.d.ts +3 -0
  207. package/lib/country-group/definition.d.ts +3 -0
  208. package/lib/country-group/index.d.ts +1 -0
  209. package/lib/country-group/locale.d.ts +3 -0
  210. package/lib/date-picker/date-picker.d.ts +4 -0
  211. package/lib/date-range-picker/date-range-picker.d.ts +2 -0
  212. package/lib/date-time-picker/date-time-picker.d.ts +4 -4
  213. package/lib/dial-pad/dial-pad.d.ts +6 -2
  214. package/lib/dialog/dialog.d.ts +0 -1
  215. package/lib/flag/definition.d.ts +3 -0
  216. package/lib/flag/flag.d.ts +8 -0
  217. package/lib/flag/flag.template.d.ts +3 -0
  218. package/lib/flag/index.d.ts +1 -0
  219. package/lib/icon/icon.d.ts +1 -2
  220. package/lib/menu/menu.d.ts +0 -1
  221. package/lib/option/option.d.ts +0 -1
  222. package/lib/rich-text-editor/rte/exports.d.ts +1 -0
  223. package/lib/rich-text-editor/rte/features/alignment.d.ts +1 -1
  224. package/lib/rich-text-editor/rte/features/character-count.d.ts +21 -0
  225. package/lib/rich-text-editor/rte/features/font-size-picker.d.ts +1 -1
  226. package/lib/rich-text-editor/rte/features/internal/basic-text-blocks.d.ts +1 -1
  227. package/lib/rich-text-editor/rte/features/keyboard-shortcuts.d.ts +1 -1
  228. package/lib/rich-text-editor/rte/features/text-color-picker.d.ts +1 -1
  229. package/lib/rich-text-editor/rte/public-interface.d.ts +6 -0
  230. package/lib/searchable-select/option-tag.d.ts +3 -2
  231. package/lib/searchable-select/searchable-select.d.ts +3 -1
  232. package/lib/table/definition.d.ts +2 -1
  233. package/lib/table/table-header-cell.d.ts +3 -0
  234. package/lib/table/table-sorting-button.d.ts +415 -0
  235. package/lib/table/table-sorting-button.template.d.ts +3 -0
  236. package/lib/tag-name-map.d.ts +2 -1
  237. package/lib/time-picker/time-picker.d.ts +2 -0
  238. package/locales/de-DE.cjs +5 -178
  239. package/locales/de-DE.js +3 -179
  240. package/locales/en-GB.cjs +5 -9
  241. package/locales/en-GB.js +3 -10
  242. package/locales/en-US.cjs +269 -2
  243. package/locales/en-US.js +266 -1
  244. package/locales/ja-JP.cjs +5 -171
  245. package/locales/ja-JP.js +3 -172
  246. package/locales/zh-CN.cjs +5 -172
  247. package/locales/zh-CN.js +3 -173
  248. package/menu/definition.cjs +5 -5
  249. package/menu/definition.js +1 -1
  250. package/menu/index.cjs +1 -1
  251. package/menu/index.js +2 -2
  252. package/menu-item/definition.cjs +6 -6
  253. package/menu-item/definition.js +1 -1
  254. package/menu-item/index.cjs +1 -1
  255. package/menu-item/index.js +2 -2
  256. package/nav/definition.cjs +1 -1
  257. package/nav/definition.js +1 -1
  258. package/nav-disclosure/definition.cjs +5 -5
  259. package/nav-disclosure/definition.js +2 -2
  260. package/nav-disclosure/index.cjs +4 -4
  261. package/nav-disclosure/index.js +13 -12
  262. package/nav-item/definition.cjs +5 -5
  263. package/nav-item/definition.js +2 -2
  264. package/nav-item/index.cjs +2 -2
  265. package/nav-item/index.js +12 -11
  266. package/note/definition.cjs +5 -5
  267. package/note/definition.js +2 -2
  268. package/note/index.cjs +3 -3
  269. package/note/index.js +11 -10
  270. package/number-field/definition.cjs +5 -5
  271. package/number-field/definition.js +2 -2
  272. package/number-field/index.cjs +4 -4
  273. package/number-field/index.js +29 -28
  274. package/option/definition.cjs +5 -5
  275. package/option/definition.js +2 -2
  276. package/option/index.cjs +1 -1
  277. package/option/index.js +2 -2
  278. package/package.json +9 -10
  279. package/pagination/definition.cjs +5 -5
  280. package/pagination/definition.js +2 -2
  281. package/pagination/index.cjs +3 -3
  282. package/pagination/index.js +16 -16
  283. package/popover/definition.cjs +5 -5
  284. package/popover/definition.js +2 -2
  285. package/popover/index.cjs +7 -7
  286. package/popover/index.js +12 -11
  287. package/popup/definition.cjs +4 -4
  288. package/popup/definition.js +1 -1
  289. package/popup/index.cjs +1 -1
  290. package/popup/index.js +1 -1
  291. package/progress/definition.cjs +1 -1
  292. package/progress/definition.js +1 -1
  293. package/progress/index.cjs +2 -2
  294. package/progress/index.js +5 -5
  295. package/radio/definition.cjs +1 -1
  296. package/radio/definition.js +1 -1
  297. package/radio/index.cjs +1 -1
  298. package/radio/index.js +1 -1
  299. package/radio-group/definition.cjs +5 -5
  300. package/radio-group/definition.js +2 -2
  301. package/radio-group/index.cjs +4 -4
  302. package/radio-group/index.js +11 -11
  303. package/range-slider/definition.cjs +5 -5
  304. package/range-slider/definition.js +2 -2
  305. package/range-slider/index.cjs +4 -4
  306. package/range-slider/index.js +39 -36
  307. package/rich-text-editor/definition.cjs +32 -31
  308. package/rich-text-editor/definition.js +3 -3
  309. package/rich-text-editor/index.cjs +13 -13
  310. package/rich-text-editor/index.js +1887 -1830
  311. package/rich-text-view/definition.cjs +1 -1
  312. package/rich-text-view/definition.js +1 -1
  313. package/rich-text-view/index.cjs +1 -1
  314. package/rich-text-view/index.js +8 -8
  315. package/searchable-select/definition.cjs +4 -4
  316. package/searchable-select/definition.js +2 -2
  317. package/searchable-select/index.cjs +15 -13
  318. package/searchable-select/index.js +75 -72
  319. package/select/definition.cjs +5 -5
  320. package/select/definition.js +2 -2
  321. package/select/index.cjs +1 -1
  322. package/select/index.js +2 -2
  323. package/selectable-box/definition.cjs +5 -5
  324. package/selectable-box/definition.js +2 -2
  325. package/selectable-box/index.cjs +7 -7
  326. package/selectable-box/index.js +12 -12
  327. package/shared/foundation/test-utilities/fixture.d.ts +1 -1
  328. package/shared/icon/utils.d.ts +1 -0
  329. package/shared/localization/Locale.d.ts +2 -0
  330. package/shared/patterns/linkable.d.ts +1 -1
  331. package/shared/picker-field/mixins/calendar-picker.d.ts +1 -0
  332. package/shared/picker-field/mixins/calendar-picker.template.d.ts +1 -0
  333. package/shared/picker-field/mixins/min-max-calendar-picker.d.ts +1 -0
  334. package/shared/picker-field/mixins/single-date-picker.d.ts +1 -0
  335. package/shared/picker-field/mixins/single-value-picker.d.ts +1 -0
  336. package/shared/picker-field/mixins/time-selection-picker.d.ts +1 -0
  337. package/shared/picker-field/mixins/time-selection-picker.template.d.ts +2 -0
  338. package/shared/picker-field/picker-field.d.ts +2 -0
  339. package/side-drawer/definition.cjs +1 -1
  340. package/side-drawer/definition.js +1 -1
  341. package/simple-color-picker/definition.cjs +5 -5
  342. package/simple-color-picker/definition.js +2 -2
  343. package/simple-color-picker/index.cjs +3 -3
  344. package/simple-color-picker/index.js +15 -14
  345. package/slider/definition.cjs +5 -5
  346. package/slider/definition.js +1 -1
  347. package/slider/index.cjs +1 -1
  348. package/slider/index.js +1 -1
  349. package/split-button/definition.cjs +5 -5
  350. package/split-button/definition.js +2 -2
  351. package/split-button/index.cjs +6 -6
  352. package/split-button/index.js +17 -16
  353. package/status/definition.cjs +5 -5
  354. package/status/definition.js +2 -2
  355. package/status/index.cjs +2 -2
  356. package/status/index.js +11 -10
  357. package/switch/definition.cjs +5 -5
  358. package/switch/definition.js +2 -2
  359. package/switch/index.cjs +4 -4
  360. package/switch/index.js +11 -10
  361. package/tab/definition.cjs +5 -5
  362. package/tab/definition.js +2 -2
  363. package/tab/index.cjs +1 -1
  364. package/tab/index.js +2 -2
  365. package/tab-panel/definition.cjs +1 -1
  366. package/tab-panel/definition.js +1 -1
  367. package/tab-panel/index.cjs +1 -1
  368. package/tab-panel/index.js +1 -1
  369. package/table/definition.cjs +4 -1
  370. package/table/definition.js +3 -2
  371. package/table/index.cjs +19 -10
  372. package/table/index.js +70 -21
  373. package/tabs/definition.cjs +6 -6
  374. package/tabs/definition.js +2 -2
  375. package/tabs/index.cjs +2 -2
  376. package/tabs/index.js +5 -5
  377. package/tag/definition.cjs +5 -5
  378. package/tag/definition.js +2 -2
  379. package/tag/index.cjs +8 -8
  380. package/tag/index.js +14 -13
  381. package/tag-group/definition.cjs +1 -1
  382. package/tag-group/definition.js +1 -1
  383. package/tag-group/index.cjs +3 -3
  384. package/tag-group/index.js +5 -5
  385. package/text-area/definition.cjs +5 -5
  386. package/text-area/definition.js +2 -2
  387. package/text-area/index.cjs +2 -2
  388. package/text-area/index.js +13 -13
  389. package/text-field/definition.cjs +5 -5
  390. package/text-field/definition.js +2 -2
  391. package/text-field/index.cjs +1 -1
  392. package/text-field/index.js +2 -2
  393. package/time-picker/definition.cjs +4 -4
  394. package/time-picker/definition.js +2 -2
  395. package/time-picker/index.cjs +1 -1
  396. package/time-picker/index.js +2 -2
  397. package/toggletip/definition.cjs +5 -5
  398. package/toggletip/definition.js +2 -2
  399. package/toggletip/index.cjs +1 -1
  400. package/toggletip/index.js +2 -2
  401. package/tooltip/definition.cjs +5 -5
  402. package/tooltip/definition.js +2 -2
  403. package/tooltip/index.cjs +1 -1
  404. package/tooltip/index.js +2 -2
  405. package/tree-item/definition.cjs +5 -5
  406. package/tree-item/definition.js +2 -2
  407. package/tree-item/index.cjs +1 -1
  408. package/tree-item/index.js +2 -2
  409. package/tree-view/definition.cjs +5 -5
  410. package/tree-view/definition.js +2 -2
  411. package/tree-view/index.cjs +3 -3
  412. package/tree-view/index.js +18 -18
  413. package/unbundled/button.cjs +2 -2
  414. package/unbundled/button.js +2 -2
  415. package/unbundled/calendar-picker.template.cjs +4347 -9
  416. package/unbundled/calendar-picker.template.js +4345 -7
  417. package/unbundled/chunk.cjs +0 -22
  418. package/unbundled/definition11.cjs +6 -0
  419. package/unbundled/definition11.js +6 -0
  420. package/unbundled/definition13.cjs +1 -8
  421. package/unbundled/definition13.js +1 -8
  422. package/unbundled/definition14.cjs +3 -2
  423. package/unbundled/definition14.js +3 -2
  424. package/unbundled/definition2.cjs +5 -75
  425. package/unbundled/definition2.js +1 -71
  426. package/unbundled/definition21.cjs +1 -2
  427. package/unbundled/definition21.js +1 -2
  428. package/unbundled/definition22.cjs +7 -2
  429. package/unbundled/definition22.js +7 -2
  430. package/unbundled/definition24.cjs +98 -979
  431. package/unbundled/definition24.js +93 -974
  432. package/unbundled/definition25.cjs +37 -322
  433. package/unbundled/definition25.js +33 -318
  434. package/unbundled/definition26.cjs +317 -91
  435. package/unbundled/definition26.js +313 -87
  436. package/unbundled/definition27.cjs +94 -192
  437. package/unbundled/definition27.js +91 -183
  438. package/unbundled/definition28.cjs +388 -395
  439. package/unbundled/definition28.js +388 -395
  440. package/unbundled/definition29.cjs +189 -110
  441. package/unbundled/definition29.js +180 -107
  442. package/unbundled/definition30.cjs +520 -36
  443. package/unbundled/definition30.js +519 -35
  444. package/unbundled/definition31.cjs +2 -1189
  445. package/unbundled/definition31.js +1 -1188
  446. package/unbundled/definition32.cjs +207 -1835
  447. package/unbundled/definition32.js +203 -1807
  448. package/unbundled/definition33.cjs +85 -228
  449. package/unbundled/definition33.js +82 -165
  450. package/unbundled/definition34.cjs +1887 -25
  451. package/unbundled/definition34.js +1857 -24
  452. package/unbundled/definition35.cjs +315 -121
  453. package/unbundled/definition35.js +236 -114
  454. package/unbundled/definition36.cjs +25 -405
  455. package/unbundled/definition36.js +22 -397
  456. package/unbundled/definition37.cjs +49 -140
  457. package/unbundled/definition37.js +46 -137
  458. package/unbundled/definition38.cjs +346 -329
  459. package/unbundled/definition38.js +343 -326
  460. package/unbundled/definition39.cjs +183 -234
  461. package/unbundled/definition39.js +181 -232
  462. package/unbundled/definition40.cjs +377 -47
  463. package/unbundled/definition40.js +372 -42
  464. package/unbundled/definition41.cjs +256 -57
  465. package/unbundled/definition41.js +255 -56
  466. package/unbundled/definition42.cjs +45 -421
  467. package/unbundled/definition42.js +41 -417
  468. package/unbundled/definition43.cjs +63 -49
  469. package/unbundled/definition43.js +61 -47
  470. package/unbundled/definition44.cjs +438 -30
  471. package/unbundled/definition44.js +434 -25
  472. package/unbundled/definition45.cjs +46 -84
  473. package/unbundled/definition45.js +43 -81
  474. package/unbundled/definition46.cjs +29 -54
  475. package/unbundled/definition46.js +24 -50
  476. package/unbundled/definition47.cjs +93 -21
  477. package/unbundled/definition47.js +91 -16
  478. package/unbundled/definition48.cjs +49 -33
  479. package/unbundled/definition48.js +46 -30
  480. package/unbundled/definition49.cjs +22 -347
  481. package/unbundled/definition49.js +16 -344
  482. package/unbundled/definition50.cjs +34 -211
  483. package/unbundled/definition50.js +30 -207
  484. package/unbundled/definition51.cjs +282 -242
  485. package/unbundled/definition51.js +275 -235
  486. package/unbundled/definition52.cjs +211 -51
  487. package/unbundled/definition52.js +209 -48
  488. package/unbundled/definition53.cjs +275 -131
  489. package/unbundled/definition53.js +272 -127
  490. package/unbundled/definition54.cjs +50 -261
  491. package/unbundled/definition54.js +48 -260
  492. package/unbundled/definition55.cjs +126 -443
  493. package/unbundled/definition55.js +123 -441
  494. package/unbundled/definition56.cjs +238 -12669
  495. package/unbundled/definition56.js +232 -12506
  496. package/unbundled/definition57.cjs +408 -729
  497. package/unbundled/definition57.js +406 -727
  498. package/unbundled/definition58.cjs +3619 -106
  499. package/unbundled/definition58.js +3449 -99
  500. package/unbundled/definition59.cjs +625 -868
  501. package/unbundled/definition59.js +620 -863
  502. package/unbundled/definition60.cjs +106 -108
  503. package/unbundled/definition60.js +102 -104
  504. package/unbundled/definition61.cjs +1040 -71
  505. package/unbundled/definition61.js +1035 -65
  506. package/unbundled/definition62.cjs +105 -169
  507. package/unbundled/definition62.js +101 -165
  508. package/unbundled/definition63.cjs +70 -113
  509. package/unbundled/definition63.js +65 -109
  510. package/unbundled/definition64.cjs +181 -53
  511. package/unbundled/definition64.js +178 -50
  512. package/unbundled/definition65.cjs +109 -76
  513. package/unbundled/definition65.js +109 -75
  514. package/unbundled/definition66.cjs +58 -21
  515. package/unbundled/definition66.js +55 -15
  516. package/unbundled/definition67.cjs +81 -74
  517. package/unbundled/definition67.js +79 -73
  518. package/unbundled/definition68.cjs +19 -344
  519. package/unbundled/definition68.js +14 -335
  520. package/unbundled/definition69.cjs +88 -26
  521. package/unbundled/definition69.js +85 -22
  522. package/unbundled/definition7.cjs +18 -3
  523. package/unbundled/definition7.js +18 -3
  524. package/unbundled/definition70.cjs +330 -111
  525. package/unbundled/definition70.js +320 -108
  526. package/unbundled/definition71.cjs +26 -271
  527. package/unbundled/definition71.js +21 -267
  528. package/unbundled/definition72.cjs +134 -28
  529. package/unbundled/definition72.js +125 -26
  530. package/unbundled/definition73.cjs +245 -113
  531. package/unbundled/definition73.js +242 -104
  532. package/unbundled/definition74.cjs +28 -212
  533. package/unbundled/definition74.js +26 -202
  534. package/unbundled/definition75.cjs +120 -52190
  535. package/unbundled/definition75.js +112 -52188
  536. package/unbundled/definition76.cjs +232 -0
  537. package/unbundled/definition76.js +213 -0
  538. package/unbundled/definition77.cjs +533 -0
  539. package/unbundled/definition77.js +513 -0
  540. package/unbundled/listbox.cjs +1 -1
  541. package/unbundled/listbox.js +1 -1
  542. package/unbundled/localized.cjs +2 -2
  543. package/unbundled/localized.js +1 -1
  544. package/unbundled/numberConverter.cjs +91 -0
  545. package/unbundled/numberConverter.js +74 -0
  546. package/unbundled/picker-field.template.cjs +3 -1
  547. package/unbundled/picker-field.template.js +3 -1
  548. package/unbundled/slottable-request.cjs +2 -3168
  549. package/unbundled/slottable-request.js +3 -3097
  550. package/unbundled/time-selection-picker.template.cjs +1 -1
  551. package/unbundled/time-selection-picker.template.js +1 -1
  552. package/unbundled/utils.cjs +1439 -0
  553. package/unbundled/utils.js +1428 -0
  554. package/unbundled/vivid-element.cjs +1 -1
  555. package/unbundled/vivid-element.js +1 -1
  556. package/video-player/definition.cjs +1 -1
  557. package/video-player/definition.js +1 -1
  558. package/video-player/index.cjs +3 -3
  559. package/video-player/index.js +9 -9
  560. package/vivid.api.json +860 -409
  561. package/unbundled/chunk.js +0 -33
  562. package/unbundled/en-US.cjs +0 -447
  563. package/unbundled/en-US.js +0 -443
  564. /package/{lib/icon/icon.placeholder.d.ts → shared/icon/icon-placeholder.d.ts} +0 -0
@@ -1,1038 +1,157 @@
1
1
  require("./chunk.cjs");
2
2
  const require_vivid_element = require("./vivid-element.cjs");
3
- const require_definition = require("./definition2.cjs");
4
3
  const require_decorate = require("./decorate.cjs");
5
- const require_delegates_aria = require("./delegates-aria.cjs");
6
- const require_with_success_text = require("./with-success-text.cjs");
7
- const require_with_error_text = require("./with-error-text.cjs");
8
- const require_with_contextual_help = require("./with-contextual-help.cjs");
9
- const require_trapped_focus = require("./trapped-focus.cjs");
10
- const require_definition$1 = require("./definition7.cjs");
4
+ const require_localized = require("./localized.cjs");
11
5
  const require_dialog = require("./dialog.cjs");
12
- const require_definition$2 = require("./definition10.cjs");
13
- const require_mixins = require("./mixins.cjs");
14
- const require_base_color_picker = require("./base-color-picker.cjs");
15
- const require_definition$3 = require("./definition25.cjs");
16
- const require_definition$4 = require("./definition26.cjs");
6
+ const require_definition = require("./definition10.cjs");
7
+ const require_anchored = require("./anchored.cjs");
17
8
  let _microsoft_fast_element = require("@microsoft/fast-element");
18
9
  let _microsoft_fast_web_utilities = require("@microsoft/fast-web-utilities");
19
- //#region src/lib/color-picker/color-picker.scss?inline
20
- var color_picker_default$1 = ".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}";
10
+ //#region src/lib/toggletip/toggletip.scss?inline
11
+ var toggletip_default = ":host :host{display:var(--_popup-display,inline)}:host :host([slotted-anchor]){--_popup-display:contents}.content-wrapper{width:var(--toggletip-inline-size,auto);max-inline-size:var(--toggletip-max-inline-size,30ch);padding:16px}.headline{font:var(--vvd-typography-base-bold);margin:0}.action-items{justify-content:flex-end;gap:10px;display:flex}::slotted([slot=action-items]){margin-block-start:16px}";
21
12
  //#endregion
22
- //#region ../../node_modules/.pnpm/vanilla-colorful@0.7.2/node_modules/vanilla-colorful/lib/utils/math.js
23
- var clamp = (number, min = 0, max = 1) => {
24
- return number > max ? max : number < min ? min : number;
25
- };
26
- var round = (number, digits = 0, base = Math.pow(10, digits)) => {
27
- return Math.round(base * number) / base;
28
- };
29
- 360 / (Math.PI * 2);
30
- var hexToHsva = (hex) => rgbaToHsva(hexToRgba(hex));
31
- var hexToRgba = (hex) => {
32
- if (hex[0] === "#") hex = hex.substring(1);
33
- if (hex.length < 6) return {
34
- r: parseInt(hex[0] + hex[0], 16),
35
- g: parseInt(hex[1] + hex[1], 16),
36
- b: parseInt(hex[2] + hex[2], 16),
37
- a: hex.length === 4 ? round(parseInt(hex[3] + hex[3], 16) / 255, 2) : 1
38
- };
39
- return {
40
- r: parseInt(hex.substring(0, 2), 16),
41
- g: parseInt(hex.substring(2, 4), 16),
42
- b: parseInt(hex.substring(4, 6), 16),
43
- a: hex.length === 8 ? round(parseInt(hex.substring(6, 8), 16) / 255, 2) : 1
44
- };
45
- };
46
- var hsvaToHex = (hsva) => rgbaToHex(hsvaToRgba(hsva));
47
- var hsvaToHsla = ({ h, s, v, a }) => {
48
- const hh = (200 - s) * v / 100;
49
- return {
50
- h: round(h),
51
- s: round(hh > 0 && hh < 200 ? s * v / 100 / (hh <= 100 ? hh : 200 - hh) * 100 : 0),
52
- l: round(hh / 2),
53
- a: round(a, 2)
54
- };
55
- };
56
- var hsvaToHslString = (hsva) => {
57
- const { h, s, l } = hsvaToHsla(hsva);
58
- return `hsl(${h}, ${s}%, ${l}%)`;
59
- };
60
- var hsvaToRgba = ({ h, s, v, a }) => {
61
- h = h / 360 * 6;
62
- s = s / 100;
63
- v = v / 100;
64
- const hh = Math.floor(h), b = v * (1 - s), c = v * (1 - (h - hh) * s), d = v * (1 - (1 - h + hh) * s), module = hh % 6;
65
- return {
66
- r: round([
67
- v,
68
- c,
69
- b,
70
- b,
71
- d,
72
- v
73
- ][module] * 255),
74
- g: round([
75
- d,
76
- v,
77
- v,
78
- c,
79
- b,
80
- b
81
- ][module] * 255),
82
- b: round([
83
- b,
84
- b,
85
- d,
86
- v,
87
- v,
88
- c
89
- ][module] * 255),
90
- a: round(a, 2)
91
- };
92
- };
93
- var format = (number) => {
94
- const hex = number.toString(16);
95
- return hex.length < 2 ? "0" + hex : hex;
96
- };
97
- var rgbaToHex = ({ r, g, b, a }) => {
98
- const alphaHex = a < 1 ? format(round(a * 255)) : "";
99
- return "#" + format(r) + format(g) + format(b) + alphaHex;
100
- };
101
- var rgbaToHsva = ({ r, g, b, a }) => {
102
- const max = Math.max(r, g, b);
103
- const delta = max - Math.min(r, g, b);
104
- const hh = delta ? max === r ? (g - b) / delta : max === g ? 2 + (b - r) / delta : 4 + (r - g) / delta : 0;
105
- return {
106
- h: round(60 * (hh < 0 ? hh + 6 : hh)),
107
- s: round(max ? delta / max * 100 : 0),
108
- v: round(max / 255 * 100),
109
- a
110
- };
111
- };
112
- //#endregion
113
- //#region ../../node_modules/.pnpm/vanilla-colorful@0.7.2/node_modules/vanilla-colorful/lib/utils/compare.js
114
- var equalColorObjects = (first, second) => {
115
- if (first === second) return true;
116
- for (const prop in first) if (first[prop] !== second[prop]) return false;
117
- return true;
118
- };
119
- var equalHex = (first, second) => {
120
- if (first.toLowerCase() === second.toLowerCase()) return true;
121
- return equalColorObjects(hexToRgba(first), hexToRgba(second));
122
- };
123
- //#endregion
124
- //#region ../../node_modules/.pnpm/vanilla-colorful@0.7.2/node_modules/vanilla-colorful/lib/utils/dom.js
125
- var cache = {};
126
- var tpl = (html) => {
127
- let template = cache[html];
128
- if (!template) {
129
- template = document.createElement("template");
130
- template.innerHTML = html;
131
- cache[html] = template;
132
- }
133
- return template;
134
- };
135
- var fire = (target, type, detail) => {
136
- target.dispatchEvent(new CustomEvent(type, {
137
- bubbles: true,
138
- detail
139
- }));
140
- };
141
- //#endregion
142
- //#region ../../node_modules/.pnpm/vanilla-colorful@0.7.2/node_modules/vanilla-colorful/lib/components/slider.js
143
- var hasTouched = false;
144
- var isTouch = (e) => "touches" in e;
145
- var isValid = (event) => {
146
- if (hasTouched && !isTouch(event)) return false;
147
- if (!hasTouched) hasTouched = isTouch(event);
148
- return true;
149
- };
150
- var pointerMove = (target, event) => {
151
- const pointer = isTouch(event) ? event.touches[0] : event;
152
- const rect = target.el.getBoundingClientRect();
153
- fire(target.el, "move", target.getMove({
154
- x: clamp((pointer.pageX - (rect.left + window.pageXOffset)) / rect.width),
155
- y: clamp((pointer.pageY - (rect.top + window.pageYOffset)) / rect.height)
156
- }));
157
- };
158
- var keyMove = (target, event) => {
159
- const keyCode = event.keyCode;
160
- if (keyCode > 40 || target.xy && keyCode < 37 || keyCode < 33) return;
161
- event.preventDefault();
162
- fire(target.el, "move", target.getMove({
163
- x: keyCode === 39 ? .01 : keyCode === 37 ? -.01 : keyCode === 34 ? .05 : keyCode === 33 ? -.05 : keyCode === 35 ? 1 : keyCode === 36 ? -1 : 0,
164
- y: keyCode === 40 ? .01 : keyCode === 38 ? -.01 : 0
165
- }, true));
166
- };
167
- var Slider = class {
168
- constructor(root, part, aria, xy) {
169
- const template = tpl(`<div role="slider" tabindex="0" part="${part}" ${aria}><div part="${part}-pointer"></div></div>`);
170
- root.appendChild(template.content.cloneNode(true));
171
- const el = root.querySelector(`[part=${part}]`);
172
- el.addEventListener("mousedown", this);
173
- el.addEventListener("touchstart", this);
174
- el.addEventListener("keydown", this);
175
- this.el = el;
176
- this.xy = xy;
177
- this.nodes = [el.firstChild, el];
178
- }
179
- set dragging(state) {
180
- const toggleEvent = state ? document.addEventListener : document.removeEventListener;
181
- toggleEvent(hasTouched ? "touchmove" : "mousemove", this);
182
- toggleEvent(hasTouched ? "touchend" : "mouseup", this);
183
- }
184
- handleEvent(event) {
185
- switch (event.type) {
186
- case "mousedown":
187
- case "touchstart":
188
- event.preventDefault();
189
- if (!isValid(event) || !hasTouched && event.button != 0) return;
190
- this.el.focus();
191
- pointerMove(this, event);
192
- this.dragging = true;
193
- break;
194
- case "mousemove":
195
- case "touchmove":
196
- event.preventDefault();
197
- pointerMove(this, event);
198
- break;
199
- case "mouseup":
200
- case "touchend":
201
- this.dragging = false;
202
- break;
203
- case "keydown":
204
- keyMove(this, event);
205
- break;
206
- }
207
- }
208
- style(styles) {
209
- styles.forEach((style, i) => {
210
- for (const p in style) this.nodes[i].style.setProperty(p, style[p]);
211
- });
212
- }
213
- };
214
- //#endregion
215
- //#region ../../node_modules/.pnpm/vanilla-colorful@0.7.2/node_modules/vanilla-colorful/lib/components/hue.js
216
- var Hue = class extends Slider {
217
- constructor(root) {
218
- super(root, "hue", "aria-label=\"Hue\" aria-valuemin=\"0\" aria-valuemax=\"360\"", false);
219
- }
220
- update({ h }) {
221
- this.h = h;
222
- this.style([{
223
- left: `${h / 360 * 100}%`,
224
- color: hsvaToHslString({
225
- h,
226
- s: 100,
227
- v: 100,
228
- a: 1
229
- })
230
- }]);
231
- this.el.setAttribute("aria-valuenow", `${round(h)}`);
232
- }
233
- getMove(offset, key) {
234
- return { h: key ? clamp(this.h + offset.x * 360, 0, 360) : 360 * offset.x };
235
- }
236
- };
237
- //#endregion
238
- //#region ../../node_modules/.pnpm/vanilla-colorful@0.7.2/node_modules/vanilla-colorful/lib/components/saturation.js
239
- var Saturation = class extends Slider {
240
- constructor(root) {
241
- super(root, "saturation", "aria-label=\"Color\"", true);
242
- }
243
- update(hsva) {
244
- this.hsva = hsva;
245
- this.style([{
246
- top: `${100 - hsva.v}%`,
247
- left: `${hsva.s}%`,
248
- color: hsvaToHslString(hsva)
249
- }, { "background-color": hsvaToHslString({
250
- h: hsva.h,
251
- s: 100,
252
- v: 100,
253
- a: 1
254
- }) }]);
255
- this.el.setAttribute("aria-valuetext", `Saturation ${round(hsva.s)}%, Brightness ${round(hsva.v)}%`);
256
- }
257
- getMove(offset, key) {
258
- return {
259
- s: key ? clamp(this.hsva.s + offset.x * 100, 0, 100) : offset.x * 100,
260
- v: key ? clamp(this.hsva.v - offset.y * 100, 0, 100) : Math.round(100 - offset.y * 100)
261
- };
262
- }
263
- };
264
- //#endregion
265
- //#region ../../node_modules/.pnpm/vanilla-colorful@0.7.2/node_modules/vanilla-colorful/lib/styles/color-picker.js
266
- var color_picker_default = `:host{display:flex;flex-direction:column;position:relative;width:200px;height:200px;user-select:none;-webkit-user-select:none;cursor:default}:host([hidden]){display:none!important}[role=slider]{position:relative;touch-action:none;user-select:none;-webkit-user-select:none;outline:0}[role=slider]:last-child{border-radius:0 0 8px 8px}[part$=pointer]{position:absolute;z-index:1;box-sizing:border-box;width:28px;height:28px;display:flex;place-content:center center;transform:translate(-50%,-50%);background-color:#fff;border:2px solid #fff;border-radius:50%;box-shadow:0 2px 4px rgba(0,0,0,.2)}[part$=pointer]::after{content:"";width:100%;height:100%;border-radius:inherit;background-color:currentColor}[role=slider]:focus [part$=pointer]{transform:translate(-50%,-50%) scale(1.1)}`;
267
- //#endregion
268
- //#region ../../node_modules/.pnpm/vanilla-colorful@0.7.2/node_modules/vanilla-colorful/lib/styles/hue.js
269
- var hue_default = `[part=hue]{flex:0 0 24px;background:linear-gradient(to right,red 0,#ff0 17%,#0f0 33%,#0ff 50%,#00f 67%,#f0f 83%,red 100%)}[part=hue-pointer]{top:50%;z-index:2}`;
270
- //#endregion
271
- //#region ../../node_modules/.pnpm/vanilla-colorful@0.7.2/node_modules/vanilla-colorful/lib/styles/saturation.js
272
- var saturation_default = `[part=saturation]{flex-grow:1;border-color:transparent;border-bottom:12px solid #000;border-radius:8px 8px 0 0;background-image:linear-gradient(to top,#000,transparent),linear-gradient(to right,#fff,rgba(255,255,255,0));box-shadow:inset 0 0 0 1px rgba(0,0,0,.05)}[part=saturation-pointer]{z-index:3}`;
273
- //#endregion
274
- //#region ../../node_modules/.pnpm/vanilla-colorful@0.7.2/node_modules/vanilla-colorful/lib/components/color-picker.js
275
- var $isSame = Symbol("same");
276
- var $color$1 = Symbol("color");
277
- var $hsva = Symbol("hsva");
278
- var $update$1 = Symbol("update");
279
- var $parts = Symbol("parts");
280
- var $css = Symbol("css");
281
- var $sliders = Symbol("sliders");
282
- var ColorPicker$1 = class extends HTMLElement {
283
- static get observedAttributes() {
284
- return ["color"];
285
- }
286
- get [$css]() {
287
- return [
288
- color_picker_default,
289
- hue_default,
290
- saturation_default
291
- ];
292
- }
293
- get [$sliders]() {
294
- return [Saturation, Hue];
295
- }
296
- get color() {
297
- return this[$color$1];
298
- }
299
- set color(newColor) {
300
- if (!this[$isSame](newColor)) {
301
- const newHsva = this.colorModel.toHsva(newColor);
302
- this[$update$1](newHsva);
303
- this[$color$1] = newColor;
304
- }
305
- }
306
- constructor() {
307
- super();
308
- const template = tpl(`<style>${this[$css].join("")}</style>`);
309
- const root = this.attachShadow({ mode: "open" });
310
- root.appendChild(template.content.cloneNode(true));
311
- root.addEventListener("move", this);
312
- this[$parts] = this[$sliders].map((slider) => new slider(root));
313
- }
314
- connectedCallback() {
315
- if (this.hasOwnProperty("color")) {
316
- const value = this.color;
317
- delete this["color"];
318
- this.color = value;
319
- } else if (!this.color) this.color = this.colorModel.defaultColor;
320
- }
321
- attributeChangedCallback(_attr, _oldVal, newVal) {
322
- const color = this.colorModel.fromAttr(newVal);
323
- if (!this[$isSame](color)) this.color = color;
324
- }
325
- handleEvent(event) {
326
- const oldHsva = this[$hsva];
327
- const newHsva = {
328
- ...oldHsva,
329
- ...event.detail
330
- };
331
- this[$update$1](newHsva);
332
- let newColor;
333
- if (!equalColorObjects(newHsva, oldHsva) && !this[$isSame](newColor = this.colorModel.fromHsva(newHsva))) {
334
- this[$color$1] = newColor;
335
- fire(this, "color-changed", { value: newColor });
336
- }
337
- }
338
- [$isSame](color) {
339
- return this.color && this.colorModel.equal(color, this.color);
340
- }
341
- [$update$1](hsva) {
342
- this[$hsva] = hsva;
343
- this[$parts].forEach((part) => part.update(hsva));
344
- }
345
- };
346
- //#endregion
347
- //#region ../../node_modules/.pnpm/vanilla-colorful@0.7.2/node_modules/vanilla-colorful/lib/entrypoints/hex.js
348
- var colorModel = {
349
- defaultColor: "#000",
350
- toHsva: hexToHsva,
351
- fromHsva: ({ h, s, v }) => hsvaToHex({
352
- h,
353
- s,
354
- v,
355
- a: 1
356
- }),
357
- equal: equalHex,
358
- fromAttr: (color) => color
359
- };
360
- var HexBase = class extends ColorPicker$1 {
361
- get colorModel() {
362
- return colorModel;
363
- }
364
- };
365
- //#endregion
366
- //#region ../../node_modules/.pnpm/vanilla-colorful@0.7.2/node_modules/vanilla-colorful/hex-color-picker.js
367
- /**
368
- * A color picker custom element that uses HEX format.
369
- *
370
- * @element hex-color-picker
371
- *
372
- * @prop {string} color - Selected color in HEX format.
373
- * @attr {string} color - Selected color in HEX format.
374
- *
375
- * @fires color-changed - Event fired when color property changes.
376
- *
377
- * @csspart hue - A hue selector container.
378
- * @csspart saturation - A saturation selector container
379
- * @csspart hue-pointer - A hue pointer element.
380
- * @csspart saturation-pointer - A saturation pointer element.
381
- */
382
- var HexColorPicker = class extends HexBase {};
383
- customElements.define("hex-color-picker", HexColorPicker);
384
- //#endregion
385
- //#region ../../node_modules/.pnpm/vanilla-colorful@0.7.2/node_modules/vanilla-colorful/lib/utils/validate.js
386
- var matcher = /^#?([0-9A-F]{3,8})$/i;
387
- var validHex = (value, alpha) => {
388
- const match = matcher.exec(value);
389
- const length = match ? match[1].length : 0;
390
- return length === 3 || length === 6 || !!alpha && length === 4 || !!alpha && length === 8;
391
- };
392
- //#endregion
393
- //#region ../../node_modules/.pnpm/vanilla-colorful@0.7.2/node_modules/vanilla-colorful/lib/entrypoints/hex-input.js
394
- var template = tpl("<slot><input part=\"input\" spellcheck=\"false\"></slot>");
395
- var escape = (hex, alpha) => hex.replace(/([^0-9A-F]+)/gi, "").substring(0, alpha ? 8 : 6);
396
- var $alpha = Symbol("alpha");
397
- var $color = Symbol("color");
398
- var $saved = Symbol("saved");
399
- var $input = Symbol("input");
400
- var $init = Symbol("init");
401
- var $prefix = Symbol("prefix");
402
- var $update = Symbol("update");
403
- var HexInputBase = class extends HTMLElement {
404
- static get observedAttributes() {
405
- return [
406
- "alpha",
407
- "color",
408
- "prefixed"
409
- ];
410
- }
411
- get color() {
412
- return this[$color];
413
- }
414
- set color(hex) {
415
- this[$color] = hex;
416
- this[$update](hex);
417
- }
418
- get alpha() {
419
- return this[$alpha];
420
- }
421
- set alpha(alpha) {
422
- this[$alpha] = alpha;
423
- this.toggleAttribute("alpha", alpha);
424
- const color = this.color;
425
- if (color && !validHex(color, alpha)) this.color = color.startsWith("#") ? color.substring(0, color.length === 5 ? 4 : 7) : color.substring(0, color.length === 4 ? 3 : 6);
426
- }
427
- get prefixed() {
428
- return this[$prefix];
429
- }
430
- set prefixed(prefixed) {
431
- this[$prefix] = prefixed;
432
- this.toggleAttribute("prefixed", prefixed);
433
- this[$update](this.color);
434
- }
435
- constructor() {
436
- super();
437
- const root = this.attachShadow({ mode: "open" });
438
- root.appendChild(template.content.cloneNode(true));
439
- root.firstElementChild.addEventListener("slotchange", () => this[$init](root));
440
- }
441
- connectedCallback() {
442
- this[$init](this.shadowRoot);
443
- if (this.hasOwnProperty("alpha")) {
444
- const value = this.alpha;
445
- delete this["alpha"];
446
- this.alpha = value;
447
- } else this.alpha = this.hasAttribute("alpha");
448
- if (this.hasOwnProperty("prefixed")) {
449
- const value = this.prefixed;
450
- delete this["prefixed"];
451
- this.prefixed = value;
452
- } else this.prefixed = this.hasAttribute("prefixed");
453
- if (this.hasOwnProperty("color")) {
454
- const value = this.color;
455
- delete this["color"];
456
- this.color = value;
457
- } else if (this.color == null) this.color = this.getAttribute("color") || "";
458
- else if (this[$color]) this[$update](this[$color]);
459
- }
460
- handleEvent(event) {
461
- const { value } = event.target;
462
- switch (event.type) {
463
- case "input":
464
- const hex = escape(value, this.alpha);
465
- this[$saved] = this.color;
466
- if (validHex(hex, this.alpha) || value === "") {
467
- this.color = hex;
468
- this.dispatchEvent(new CustomEvent("color-changed", {
469
- bubbles: true,
470
- detail: { value: hex ? "#" + hex : "" }
471
- }));
472
- }
473
- break;
474
- case "blur": if (value && !validHex(value, this.alpha)) this.color = this[$saved];
475
- }
476
- }
477
- attributeChangedCallback(attr, _oldVal, newVal) {
478
- if (attr === "color" && this.color !== newVal) this.color = newVal;
479
- const hasBooleanAttr = newVal != null;
480
- if (attr === "alpha") {
481
- if (this.alpha !== hasBooleanAttr) this.alpha = hasBooleanAttr;
482
- }
483
- if (attr === "prefixed") {
484
- if (this.prefixed !== hasBooleanAttr) this.prefixed = hasBooleanAttr;
485
- }
486
- }
487
- [$init](root) {
488
- let input = this.querySelector("input");
489
- if (!input) {
490
- let c;
491
- while (c = this.firstChild) c.remove();
492
- input = root.querySelector("input");
493
- }
494
- input.addEventListener("input", this);
495
- input.addEventListener("blur", this);
496
- this[$input] = input;
497
- this[$update](this.color);
498
- }
499
- [$update](hex) {
500
- if (this[$input]) this[$input].value = hex == null || hex == "" ? "" : (this.prefixed ? "#" : "") + escape(hex, this.alpha);
501
- }
502
- };
503
- //#endregion
504
- //#region ../../node_modules/.pnpm/vanilla-colorful@0.7.2/node_modules/vanilla-colorful/hex-input.js
505
- /**
506
- * A custom element for entering color in HEX format.
507
- *
508
- * @element hex-input
509
- *
510
- * @prop {string} color - Color in HEX format.
511
- * @attr {string} color - Selected color in HEX format.
512
- * @prop {boolean} alpha - When true, `#rgba` and `#rrggbbaa` color formats are allowed.
513
- * @attr {boolean} alpha - Allows `#rgba` and `#rrggbbaa` color formats.
514
- * @prop {boolean} prefixed - When true, `#` prefix is displayed in the input.
515
- * @attr {boolean} prefixed - Enables `#` prefix displaying.
516
- *
517
- * @fires color-changed - Event fired when color is changed.
518
- *
519
- * @csspart input - A native input element.
520
- */
521
- var HexInput = class extends HexInputBase {};
522
- customElements.define("hex-input", HexInput);
523
- //#endregion
524
- //#region src/lib/color-picker/color-picker.ts
525
- var VC_HEX_PICKER_TAG = "vvd-hex-picker";
526
- var VC_HEX_INPUT_TAG = "vvd-hex-input";
527
- var VvdHexPicker = class extends HexColorPicker {
528
- static {
529
- this.displayName = "VvdHexPicker";
530
- }
531
- };
532
- var VvdHexInput = class extends HexInput {
533
- static {
534
- this.displayName = "VvdHexInput";
535
- }
536
- };
537
- /* v8 ignore if -- @preserve */
538
- if (!customElements.get(VC_HEX_PICKER_TAG)) customElements.define(VC_HEX_PICKER_TAG, VvdHexPicker);
539
- /* v8 ignore if -- @preserve */
540
- if (!customElements.get(VC_HEX_INPUT_TAG)) customElements.define(VC_HEX_INPUT_TAG, VvdHexInput);
541
- var vcPickerTag = VC_HEX_PICKER_TAG;
542
- var vcInputTag = VC_HEX_INPUT_TAG;
13
+ //#region src/lib/toggletip/toggletip.ts
543
14
  /**
544
15
  * @public
545
- * @component color-picker
546
- * @slot helper-text - Describes how to use the text-field. Alternative to the `helper-text` attribute.
547
- * @slot popup-text - Overrides the default "Color Picker" title of the Popup window.
548
- * @slot swatches-text - Overrides the default "Saved colors:" text above color swatches.
549
- * @event {CustomEvent<undefined>} change - Fires when the value changes
550
- * @vueModel modelValue value input `event.currentTarget.value`
16
+ * @component toggletip
17
+ * @slot - The content to display in the toggletip.
18
+ * @slot anchor - Used to set the anchor element for the toggletip.
19
+ * @slot action-items - The content to display in the toggletip action items.
20
+ * @testSelector byHeadline byHeadline
21
+ * @testQuery open open true
22
+ * @testQuery closed open false
551
23
  */
552
- 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))))))) {
24
+ var Toggletip = class extends require_localized.Localized(require_anchored.Anchored(require_vivid_element.VividElement)) {
553
25
  constructor(..._args) {
554
26
  super(..._args);
555
- this.disableSavedColors = false;
556
- this.savedColors = [];
557
- this.maxSwatches = 6;
558
- this.copyIconName = "copy-2-line";
559
- this._copyValueToClipboard = async (value) => {
560
- try {
561
- await navigator.clipboard.writeText(value);
562
- this._setTemporaryCopyIcon("check-circle-line");
563
- this._ariaLiveDescription = this.locale.colorPicker.copySuccessMessage(value);
564
- } catch {
565
- alert(this.locale.colorPicker.copyErrorText);
566
- this._setTemporaryCopyIcon("error-line");
567
- this._ariaLiveDescription = this.locale.colorPicker.copyErrorText;
568
- }
569
- };
570
- this._ariaLiveDescription = "";
571
- }
572
- static {
573
- this.HEX_COLOR_PATTERN = /^#(([0-9a-fA-F]{2}){3}|([0-9a-fA-F]){3})$/;
574
- }
575
- /**
576
- * @internal
577
- */
578
- placeholderChanged() {
579
- /* v8 ignore if -- @preserve */
580
- if (this.proxy instanceof HTMLInputElement) this.proxy.placeholder = this.placeholder;
581
- }
582
- /**
583
- * Change event handler for inner control.
584
- * @remarks
585
- * @internal
586
- */
587
- handleChange() {
588
- this.$emit("change");
589
- }
590
- /**
591
- * @internal
592
- */
593
- openChanged(_oldValue, newValue) {
594
- if (newValue && this.isConnected) requestAnimationFrame(() => {
595
- this._refreshCanvasColor();
596
- });
597
- }
598
- /**
599
- * @internal
600
- */
601
- savedColorsKeyChanged() {
602
- this.savedColors = this._loadSavedColors();
603
- }
604
- /**
605
- * @internal
606
- */
607
- get _savedColorsStorageKey() {
608
- if (this.savedColorsKey) return this.savedColorsKey;
609
- return `vvd-saved-colors:${this.tagName.toLowerCase()}`;
610
- }
611
- /**
612
- * @internal
613
- */
614
- _handleColorSaving() {
615
- this._saveCurrentColor();
616
- }
617
- /**
618
- * @internal
619
- */
620
- _saveCurrentColor() {
621
- const value = this.value;
622
- if (typeof value !== "string" || !require_base_color_picker.isValidHexColor(value)) return;
623
- const swatches = Array.isArray(this.savedColors) ? [...this.savedColors] : [];
624
- const idx = swatches.findIndex((s) => s?.value === value);
625
- if (idx !== -1) swatches.splice(idx, 1);
626
- swatches.unshift({ value });
627
- this.savedColors = swatches.slice(0, this._maxSwatchesNormalized);
628
- this._setSavedColors(this.savedColors);
629
- }
630
- /**
631
- * @internal
632
- */
633
- _loadSavedColors() {
634
- try {
635
- const savedColors = localStorage.getItem(this._savedColorsStorageKey);
636
- if (!savedColors) return [];
637
- const parsed = JSON.parse(savedColors);
638
- if (!Array.isArray(parsed)) return [];
639
- return parsed.filter((x) => x && typeof x.value === "string" && require_base_color_picker.isValidHexColor(x.value)).map((x) => ({
640
- value: x.value,
641
- label: typeof x.label === "string" ? x.label : void 0
642
- }));
643
- } catch {
644
- return [];
645
- }
646
- }
647
- /**
648
- * @internal
649
- */
650
- _setSavedColors(swatches) {
651
- try {
652
- localStorage.setItem(this._savedColorsStorageKey, JSON.stringify(swatches));
653
- } catch {}
654
- }
655
- /**
656
- * Get all color swatches combined, both from swatches property and saved colors
657
- * @internal
658
- */
659
- get allSwatches() {
660
- const predefinedColors = Array.isArray(this.swatches) ? this.swatches : [];
661
- const savedColors = Array.isArray(this.savedColors) ? this.savedColors : [];
662
- const seen = /* @__PURE__ */ new Set();
663
- const merged = [];
664
- const appendIfUniqueAndValid = (swatch) => {
665
- if (!swatch || typeof swatch.value !== "string") return;
666
- if (!require_base_color_picker.isValidHexColor(swatch.value) || seen.has(swatch.value)) return;
667
- seen.add(swatch.value);
668
- merged.push(swatch);
669
- };
670
- if (!this.disableSavedColors) savedColors.forEach(appendIfUniqueAndValid);
671
- predefinedColors.forEach(appendIfUniqueAndValid);
672
- return merged.slice(0, this._maxSwatchesNormalized);
673
- }
674
- /**
675
- * @internal
676
- */
677
- get _maxSwatchesNormalized() {
678
- return Number.isFinite(this.maxSwatches) ? Math.max(0, Math.floor(this.maxSwatches)) : 0;
679
- }
680
- /**
681
- * @internal
682
- */
683
- maxSwatchesChanged() {
684
- const maxCount = this._maxSwatchesNormalized;
685
- if (this.savedColors?.length > maxCount) {
686
- this.savedColors = this.savedColors.slice(0, maxCount);
687
- this._setSavedColors(this.savedColors);
688
- }
689
- }
690
- /**
691
- * @internal
692
- */
693
- _onPickerColorChanged(e) {
694
- if (typeof e.detail?.value === "string") this.value = e.detail?.value;
695
- }
696
- /**
697
- * @internal
698
- */
699
- valueChanged(_oldVal, newVal) {
700
- if (this._vcHexPickerEl && typeof newVal === "string") this._vcHexPickerEl.color = newVal;
701
- if (this._vcHexInputEl && typeof newVal === "string") this._vcHexInputEl.color = newVal;
702
- }
703
- /**
704
- * @internal
705
- */
706
- _onTextFieldInput(event) {
707
- this.value = event.currentTarget.value;
708
- }
709
- /**
710
- * @internal
711
- */
712
- get _buttonColor() {
713
- /* v8 ignore else -- @preserve */
714
- if (!this._canvasColor) this._refreshCanvasColor();
715
- if (this.value && require_base_color_picker.isValidHexColor(this.value)) return this.value;
716
- return "var(--vvd-color-canvas-text)";
717
- }
718
- /**
719
- * @internal
720
- */
721
- _onButtonClick() {
722
- this.open = !this.open;
723
- }
724
- /**
725
- * @internal
726
- */
727
- _handleCloseRequest() {
27
+ this.alternate = false;
28
+ this.placement = "right";
728
29
  this.open = false;
729
30
  }
31
+ #originalAriaLabel = null;
730
32
  /**
731
33
  * @internal
732
34
  */
733
- _isInPath(e, el) {
734
- if (!el) return false;
735
- const path = e.composedPath?.();
736
- return !!(path && path.includes(el));
35
+ openChanged(oldValue, newValue) {
36
+ if (oldValue === void 0) return;
37
+ if (newValue) this.setAttribute("role", "status");
38
+ else this.removeAttribute("role");
39
+ this.#updateListeners();
40
+ if (this._anchorEl) this.#updateAnchor(this._anchorEl);
737
41
  }
738
- /**
739
- * @internal
740
- */
741
- #closeOnPointerOutside = (e) => {
742
- if (this._isInPath(e, this._buttonEl) || this._isInPath(e, this._popupEl)) return;
743
- this.open = false;
744
- };
745
42
  connectedCallback() {
746
43
  super.connectedCallback();
747
- this.savedColors = this._loadSavedColors();
748
- document.addEventListener("mousedown", this.#closeOnPointerOutside, true);
44
+ this.#updateListeners();
749
45
  }
750
46
  disconnectedCallback() {
751
47
  super.disconnectedCallback();
752
- document.removeEventListener("mousedown", this.#closeOnPointerOutside, true);
48
+ this.#updateListeners();
753
49
  }
754
- #iconResetTimer = null;
755
50
  /**
756
51
  * @internal
757
52
  */
758
- _setTemporaryCopyIcon(name, ms = 2e3) {
759
- this.copyIconName = name;
760
- if (this.#iconResetTimer) clearTimeout(this.#iconResetTimer);
761
- this.#iconResetTimer = setTimeout(() => {
762
- this.copyIconName = "copy-2-line";
763
- this.#iconResetTimer = null;
764
- }, ms);
53
+ _anchorElChanged(oldValue, newValue) {
54
+ if (oldValue) this.#cleanupAnchor(oldValue);
55
+ if (newValue) this.#setupAnchor(newValue);
765
56
  }
766
- /**
767
- * @internal
768
- */
769
- _onBaseKeydown(event) {
770
- if (this.open && require_dialog.handleEscapeKeyAndStopPropogation(event)) {
771
- this.open = false;
772
- return false;
773
- }
774
- if (this._trappedFocus(event, () => this._focusableElsWithinDialog())) return false;
775
- return true;
57
+ #setupAnchor(a) {
58
+ a.addEventListener("click", this.#openIfClosed, true);
59
+ this.#originalAriaLabel = a.ariaLabel;
60
+ a.ariaLabel = `${this.locale.toggletip.anchorLabel(a.ariaLabel || "")}`;
61
+ this.#updateAnchor(a);
776
62
  }
777
- /**
778
- * @internal
779
- */
780
- _focusableElsWithinDialog() {
781
- return this._popupEl.querySelectorAll("button:not([role=\"gridcell\"]), [data-vvd-component=\"button\"], vwc-button:not([role=\"gridcell\"])");
63
+ #updateAnchor(a) {
64
+ a.setAttribute("aria-expanded", this.open.toString());
65
+ a.setAttribute("data-expanded", this.open.toString());
782
66
  }
783
- /**
784
- * @internal
785
- */
786
- _handleCellKeydown(event, value, index, isSaveCell) {
787
- if (event.key === "Tab") {
788
- event.preventDefault();
789
- const focusableEls = this._focusableElsWithinDialog();
790
- const idx = Array.prototype.indexOf.call(focusableEls, event.currentTarget);
791
- focusableEls[event.shiftKey ? (idx - 1 + focusableEls.length) % focusableEls.length : (idx + 1) % focusableEls.length]?.focus();
792
- return false;
67
+ #cleanupAnchor(a) {
68
+ a.removeEventListener("click", this.#openIfClosed, true);
69
+ a.removeAttribute("aria-expanded");
70
+ a.removeAttribute("data-expanded");
71
+ /* v8 ignore else -- @preserve */
72
+ if (a.ariaLabel) a.ariaLabel = this.#originalAriaLabel;
73
+ }
74
+ #openIfClosed = () => {
75
+ if (!this.open) _microsoft_fast_element.Updates.enqueue(() => this.open = true);
76
+ };
77
+ #updateListeners() {
78
+ document.removeEventListener("click", this.#closeOnClickOutside);
79
+ document.removeEventListener("keydown", this.#closeOnEscape);
80
+ if (this.open && this.isConnected) {
81
+ document.addEventListener("click", this.#closeOnClickOutside);
82
+ document.addEventListener("keydown", this.#closeOnEscape);
793
83
  }
794
- return super._handleCellKeydown(event, value, index, isSaveCell);
795
84
  }
796
- /**
797
- * @internal
798
- */
799
- _handleSwatchSelection(value) {
85
+ #closeOnClickOutside = (e) => {
86
+ const clickedOutside = !this.contains(e.target);
87
+ const clickedOnAnchor = this._anchorEl?.contains(e.target);
88
+ if (clickedOutside || clickedOnAnchor) this.open = false;
89
+ };
90
+ #closeOnEscape = (e) => {
800
91
  /* v8 ignore else -- @preserve */
801
- if (this.value !== value) this._ariaLiveDescription = this.locale.colorPicker.selectionSuccessMessage(value);
802
- super._handleSwatchSelection(value);
803
- }
92
+ if (e.key === "Escape") this.open = false;
93
+ };
804
94
  };
805
- require_decorate.__decorate([_microsoft_fast_element.attr], ColorPicker.prototype, "placeholder", void 0);
806
- require_decorate.__decorate([(0, _microsoft_fast_element.attr)({ attribute: "saved-colors-key" })], ColorPicker.prototype, "savedColorsKey", void 0);
807
- require_decorate.__decorate([(0, _microsoft_fast_element.attr)({
808
- mode: "boolean",
809
- attribute: "disable-saved-colors"
810
- })], ColorPicker.prototype, "disableSavedColors", void 0);
811
- require_decorate.__decorate([_microsoft_fast_element.observable], ColorPicker.prototype, "savedColors", void 0);
812
- require_decorate.__decorate([(0, _microsoft_fast_element.attr)({
813
- attribute: "max-swatches",
814
- mode: "fromView",
815
- converter: _microsoft_fast_element.nullableNumberConverter
816
- })], ColorPicker.prototype, "maxSwatches", void 0);
817
- require_decorate.__decorate([_microsoft_fast_element.observable], ColorPicker.prototype, "copyIconName", void 0);
818
- require_decorate.__decorate([_microsoft_fast_element.observable], ColorPicker.prototype, "_ariaLiveDescription", void 0);
95
+ require_decorate.__decorate([_microsoft_fast_element.attr], Toggletip.prototype, "headline", void 0);
96
+ require_decorate.__decorate([(0, _microsoft_fast_element.attr)({ mode: "boolean" })], Toggletip.prototype, "alternate", void 0);
97
+ require_decorate.__decorate([(0, _microsoft_fast_element.attr)({ mode: "fromView" })], Toggletip.prototype, "placement", void 0);
98
+ require_decorate.__decorate([(0, _microsoft_fast_element.attr)({ mode: "boolean" })], Toggletip.prototype, "open", void 0);
819
99
  //#endregion
820
- //#region src/lib/color-picker/color-picker.template.ts
821
- function renderTextField(textFieldTag, iconTag) {
822
- const getClasses = (_) => (0, _microsoft_fast_web_utilities.classNames)("control");
100
+ //#region src/lib/toggletip/toggletip.template.ts
101
+ var getClasses = (_) => (0, _microsoft_fast_web_utilities.classNames)("control");
102
+ var ToggletipTemplate = (context) => {
103
+ const popup = context.tagFor(require_definition.Popup);
823
104
  return _microsoft_fast_element.html`
824
- <${textFieldTag}
825
- id="text-field"
826
- class="${getClasses}"
827
- pattern="${ColorPicker.HEX_COLOR_PATTERN.source}"
828
- maxlength="7"
829
- label="${(x) => x.label}"
830
- :value="${(x) => x.value}"
831
- placeholder="${(x) => x.placeholder}"
832
- helper-text="${(x) => x.helperText}"
833
- error-text="${(x) => x.errorValidationMessage}"
834
- success-text="${(x) => x.successText}"
835
- ?disabled="${(x) => x.disabled}"
836
- ?required="${(x) => x.required}"
837
- @input='${(x, c) => x._onTextFieldInput(c.event)}'
838
- @change="${(x) => x.handleChange()}"
839
- @blur="${(x) => {
840
- x.$emit("blur", void 0, { bubbles: false });
841
- }}"
842
- @focus="${(x) => {
843
- x.$emit("focus", void 0, { bubbles: false });
105
+ ${require_anchored.anchorSlotTemplateFactory()}
106
+ <${popup}
107
+ @keydown="${(x, { event }) => {
108
+ if (x.open && require_dialog.handleEscapeKeyAndStopPropogation(event)) return false;
109
+ return true;
844
110
  }}"
845
- ${require_delegates_aria.delegateAria()}
846
- ${(0, _microsoft_fast_element.ref)("_textFieldEl")}
111
+ class="${getClasses}"
112
+ arrow
113
+ :anchor="${(x) => x._anchorEl}"
114
+ :open="${(x) => x.open}"
115
+ ?alternate="${(x) => !x.alternate}"
116
+ placement="${(x) => x.placement}"
117
+ exportparts="vvd-theme-alternate"
847
118
  >
848
- <button
849
- aria-label="${(x) => x.locale.colorPicker.pickerButtonLabel}"
850
- aria-expanded="${(x) => x.open}"
851
- aria-haspopup="dialog"
852
- class="button ${(x) => (0, _microsoft_fast_web_utilities.classNames)(x._applyContrastClass(x._buttonColor) ? "contrast" : "", x.disabled ? "disabled" : "")}"
853
- style="--button-color: ${(x) => x._buttonColor};"
854
- ?disabled="${(x) => x.disabled}"
855
- @click="${(x) => x._onButtonClick()}"
856
- slot="action-items"
857
- ${(0, _microsoft_fast_element.ref)("_buttonEl")}>
858
- <${iconTag} name="edit-line"></${iconTag}>
859
- </button>
860
- <slot
861
- slot="${(x) => x._helperTextSlottedContent?.length ? "helper-text" : void 0}"
862
- name="helper-text"
863
- ${(0, _microsoft_fast_element.slotted)("_helperTextSlottedContent")}
864
- ></slot>
865
- <slot
866
- slot='${(x) => x._contextualHelpSlottedContent?.length ? "contextual-help" : void 0}'
867
- name='contextual-help'
868
- ${(0, _microsoft_fast_element.slotted)("_contextualHelpSlottedContent")}
869
- ></slot>
870
- </${textFieldTag}>
871
- `;
872
- }
873
- function renderPopupHeader(buttonTag, iconTag) {
874
- return _microsoft_fast_element.html`
875
- <div class="header">
876
- <h2 class="header-title" id="color-picker-title">
877
- <slot name="popup-text">${(x) => x.locale.colorPicker.popupLabel}</slot>
878
- </h2>
879
- <${buttonTag} size="condensed"
880
- aria-label="${(x) => x.locale.colorPicker.closeButtonLabel}"
881
- @click="${(x) => x._handleCloseRequest()}">
882
- <${iconTag} slot="icon" name="close-line"></${iconTag}>
883
- </${buttonTag}>
884
- </div>
885
- `;
886
- }
887
- function renderPopupBody(buttonTag, iconTag, tooltipTag) {
888
- return _microsoft_fast_element.html`
889
- <div class="body">
890
- <${_microsoft_fast_element.html.partial(vcPickerTag)}
891
- part="hex-picker"
892
- color="${(x) => x.value}"
893
- @color-changed="${(x, c) => x._onPickerColorChanged(c.event)}"
894
- ${(0, _microsoft_fast_element.ref)("_vcHexPickerEl")}
895
- ></${_microsoft_fast_element.html.partial(vcPickerTag)}>
896
- <div class="hex-input-wrapper">
897
- <${_microsoft_fast_element.html.partial(vcInputTag)}
898
- part="hex-input"
899
- prefixed
900
- color="${(x) => x.value}"
901
- @color-changed="${(x, c) => x._onPickerColorChanged(c.event)}"
902
- ${(0, _microsoft_fast_element.ref)("_vcHexInputEl")}
903
- >
904
- <input name="hex-code-input" aria-label="${(x) => x.locale.colorPicker.hexInputLabel}"
905
- placeholder="${(x) => x.placeholder}"
906
- @blur="${(x, c) => c.event.stopImmediatePropagation()}"
907
- part="input">
908
- </${_microsoft_fast_element.html.partial(vcInputTag)}>
909
- <${tooltipTag} placement="top"
910
- text="${(x) => x.locale.colorPicker.copyButtonLabel}"
911
- exportparts="vvd-theme-alternate">
912
- <${buttonTag}
913
- slot="anchor" size="normal"
914
- aria-label="${(x) => x.locale.colorPicker.copyButtonLabel}"
915
- @click="${(x) => x._copyValueToClipboard(x.value)}">
916
- <${iconTag} slot="icon" name="${(x) => x.copyIconName}"></${iconTag}>
917
- </${buttonTag}>
918
- </${tooltipTag}>
919
- </div>
920
- </div>
921
- `;
922
- }
923
- function renderPopupFooter(buttonTag, iconTag, tooltipTag) {
924
- return _microsoft_fast_element.html`
925
- <div class="footer">
926
- <div class="footer-header">
927
- <span class="footer-title" id="color-picker-footer-title"
928
- ><slot name="swatches-text"
929
- >${(x) => x.locale.colorPicker.swatchesLabel}</slot
930
- ></span
931
- >
932
- ${(0, _microsoft_fast_element.when)((x) => !x.disableSavedColors, renderSwatchesCount())}
933
- </div>
934
- <div
935
- class="palette"
936
- role="grid"
937
- aria-rowcount="${(x) => Math.ceil(x.allSwatches.length / x._getRowLength())}"
938
- aria-colcount="${(x) => x._getRowLength()}"
939
- style="--swatches-per-row: ${(x) => x._getRowLength()};"
940
- aria-labelledby="color-picker-footer-title"
941
- >
942
- ${(0, _microsoft_fast_element.repeat)((x) => x.allSwatches, (x) => x._renderColorSwatch(iconTag, tooltipTag), { positioning: true })}
943
- ${(0, _microsoft_fast_element.when)((x) => !x.disableSavedColors, _microsoft_fast_element.html`
944
- <${tooltipTag} placement="top"
945
- text="${(x) => x.locale.colorPicker.saveButtonLabel}"
946
- exportparts="vvd-theme-alternate">
947
- <${buttonTag}
948
- slot="anchor"
949
- appearance="outlined"
950
- size="super-condensed"
951
- role="gridcell"
952
- tabindex="${(x) => x.allSwatches.length ? "-1" : "0"}"
953
- aria-label="${(x) => x.locale.colorPicker.saveButtonLabel}"
954
- @click="${(x) => x._saveCurrentColor()}"
955
- @keydown="${(x, c) => x._handleCellKeydown(c.event, x.value, x.allSwatches.length, true)}">
956
- <${iconTag} slot="icon" name="plus-line"></${iconTag}>
957
- </${buttonTag}>
958
- </${tooltipTag}>
959
- `)}
119
+ <div class="content-wrapper">
120
+ ${(0, _microsoft_fast_element.when)((x) => x.headline, _microsoft_fast_element.html`<h2 class="headline">${(x) => x.headline}</h2>`)}
121
+ <slot></slot>
122
+ <div class="action-items"><slot name="action-items"></slot></div>
960
123
  </div>
961
- </div>
962
- `;
963
- }
964
- function renderSwatchesCount() {
965
- return _microsoft_fast_element.html`
966
- <span
967
- id="swatches-count"
968
- class="swatches-count"
969
- aria-label="${(x) => x.locale.colorPicker.maxSwatchesMessage(x.allSwatches.length, x.maxSwatches)}"
970
- >${(x) => `${x.allSwatches.length}/${x.maxSwatches}`}</span
971
- >
972
- `;
973
- }
974
- var ColorPickerTemplate = (context) => {
975
- const textFieldTag = context.tagFor(require_definition$3.TextField);
976
- const iconTag = context.tagFor(require_definition.Icon);
977
- const popupTag = context.tagFor(require_definition$2.Popup);
978
- const buttonTag = context.tagFor(require_definition$1.Button);
979
- const tooltipTag = context.tagFor(require_definition$4.Tooltip);
980
- return _microsoft_fast_element.html`
981
- <div class="base" @keydown="${(x, { event }) => x._onBaseKeydown(event)}">
982
- <span aria-live="assertive" aria-relevant="text" class="visually-hidden">
983
- ${(x) => x._ariaLiveDescription}
984
- </span>
985
- ${renderTextField(textFieldTag, iconTag)}
986
- <${popupTag}
987
- :open="${(x) => x.open}"
988
- :anchor="${(x) => x._buttonEl}"
989
- placement="top"
990
- offset="10"
991
- ${(0, _microsoft_fast_element.ref)("_popupEl")}>
992
- <div class="dialog"
993
- role="dialog"
994
- aria-modal="true"
995
- aria-labelledby="color-picker-title">
996
- ${renderPopupHeader(buttonTag, iconTag)}
997
- ${renderPopupBody(buttonTag, iconTag, tooltipTag)}
998
- ${(0, _microsoft_fast_element.when)((x) => !x.disableSavedColors || x.allSwatches.length > 0, renderPopupFooter(buttonTag, iconTag, tooltipTag))}
999
- </div>
1000
- </${popupTag}>
1001
- </div>
124
+ </${popup}>
1002
125
  `;
1003
126
  };
1004
127
  //#endregion
1005
- //#region src/lib/color-picker/definition.ts
1006
- var colorPickerDefinition = require_vivid_element.defineVividComponent("color-picker", ColorPicker, ColorPickerTemplate, [
1007
- require_definition$2.popupDefinition,
1008
- require_definition.iconDefinition,
1009
- require_definition$3.textFieldDefinition,
1010
- require_definition$1.buttonDefinition,
1011
- require_definition$4.tooltipDefinition,
1012
- require_mixins.feedbackMessageDefinition
1013
- ], { styles: color_picker_default$1 });
128
+ //#region src/lib/toggletip/definition.ts
129
+ /**
130
+ * @internal
131
+ */
132
+ var toggletipDefinition = require_vivid_element.defineVividComponent("toggletip", Toggletip, ToggletipTemplate, [require_definition.popupDefinition], { styles: toggletip_default });
1014
133
  /**
1015
- * Registers the color-picker element with the design system.
134
+ * Registers the toggletip element with the design system.
1016
135
  *
1017
136
  * @param prefix - the prefix to use for the component name
1018
137
  */
1019
- var registerColorPicker = require_vivid_element.createRegisterFunction(colorPickerDefinition);
138
+ var registerToggletip = require_vivid_element.createRegisterFunction(toggletipDefinition);
1020
139
  //#endregion
1021
- Object.defineProperty(exports, "ColorPicker", {
140
+ Object.defineProperty(exports, "Toggletip", {
1022
141
  enumerable: true,
1023
142
  get: function() {
1024
- return ColorPicker;
143
+ return Toggletip;
1025
144
  }
1026
145
  });
1027
- Object.defineProperty(exports, "colorPickerDefinition", {
146
+ Object.defineProperty(exports, "registerToggletip", {
1028
147
  enumerable: true,
1029
148
  get: function() {
1030
- return colorPickerDefinition;
149
+ return registerToggletip;
1031
150
  }
1032
151
  });
1033
- Object.defineProperty(exports, "registerColorPicker", {
152
+ Object.defineProperty(exports, "toggletipDefinition", {
1034
153
  enumerable: true,
1035
154
  get: function() {
1036
- return registerColorPicker;
155
+ return toggletipDefinition;
1037
156
  }
1038
157
  });