@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,349 +1,28 @@
1
1
  import { o as defineVividComponent, s as createRegisterFunction, t as VividElement } from "./vivid-element.js";
2
- import { t as __decorate } from "./decorate.js";
3
- import { n as keyArrowRight$1, t as keyArrowLeft$1 } from "./key-codes.js";
4
- import { n as tabPanelDefinition } from "./definition66.js";
5
- import { n as tabDefinition, r as Tab } from "./definition67.js";
6
- import { Updates, attr, html, observable, ref, slotted } from "@microsoft/fast-element";
7
- import { classNames, keyArrowDown, keyArrowUp, keyEnd, keyHome, limit, uniqueId } from "@microsoft/fast-web-utilities";
8
- //#region src/lib/tabs/tabs.scss?inline
9
- var tabs_default = ":host{display:block}.base{--_appearance-color-text:var(--_connotation-color-firm);--_appearance-color-fill:transparent;--_appearance-color-outline:transparent}.base.connotation-cta{--_connotation-color-firm:var(--vvd-tabs-cta-firm,var(--vvd-color-cta-600))}.base:not(.connotation-cta){--_connotation-color-firm:var(--vvd-tabs-accent-firm,var(--vvd-color-canvas-text))}.base{--_tabs-tablist-gutter:8px;--_tabs-active-indicator-stroke-width:2px;box-sizing:border-box;display:grid}.base.orientation-vertical{block-size:inherit;grid-template-rows:1fr;grid-template-columns:auto 1fr;overflow:hidden}.base:not(.orientation-vertical){block-size:var(--tabs-block-size,auto);grid-template-rows:auto 1fr;grid-template-columns:1fr;max-block-size:100%}.base.layout-stretch .scroll-shadow{flex:1}.base:not(.orientation-vertical) .scroll-shadow{isolation:isolate;position:relative;overflow:hidden}.base:not(.orientation-vertical) .scroll-shadow.start-scroll:before,.base:not(.orientation-vertical) .scroll-shadow.start-scroll:after,.base:not(.orientation-vertical) .scroll-shadow.end-scroll:before,.base:not(.orientation-vertical) .scroll-shadow.end-scroll:after{content:\"\";opacity:0;inline-size:10px;transition:opacity .1s;position:absolute;inset-block:0}.base:not(.orientation-vertical) .scroll-shadow.start-scroll:before{z-index:1;box-shadow:inset 7px 1px 5px -3px var(--vvd-color-neutral-950);opacity:.2;inset-inline-start:0}.base:not(.orientation-vertical) .scroll-shadow.end-scroll:after{box-shadow:inset -7px 1px 5px -3px var(--vvd-color-neutral-950);opacity:.2;inset-inline-end:0}.tabs{display:flex;overflow:hidden}.base.orientation-vertical .tabs{box-shadow:1px 0 0 0 var(--vvd-color-neutral-300);flex-direction:column}.base.orientation-horizontal .tabs{border-bottom:1px solid var(--vvd-color-neutral-300);flex-direction:row}.tablist{box-sizing:border-box;color:var(--_appearance-color-text);display:grid;position:relative;overflow:hidden}.base.layout-stretch .tablist{--_tab-justify-content:center;--_tabs-tablist-column:1fr}.tablist .base:not(.layout-stretch){--_tabs-tablist-column:auto}.base.orientation-vertical .tablist{padding:var(--_tabs-tablist-gutter);place-self:flex-start end;row-gap:var(--_tabs-tablist-gutter);grid-row:1/2;grid-template-rows:auto;grid-template-columns:auto 1fr;block-size:fit-content;min-block-size:100%;inline-size:100%}.base:not(.orientation-vertical) .tablist{justify-content:flex-start;column-gap:var(--_tabs-tablist-gutter);grid-auto-columns:var(--_tabs-tablist-column);inline-size:fit-content;min-inline-size:100%;padding-inline:var(--_tabs-tablist-gutter);grid-template-rows:auto auto;grid-auto-flow:column}.base.has-action-items.orientation-vertical .tablist{padding-block-end:0}.base.has-action-items:not(.orientation-vertical) .tablist{padding-inline-end:0}.tablist-wrapper{--scrollbar-track-color:transparent;--scrollbar-thumb-color:color-mix(in srgb, var(--vvd-color-neutral-950), transparent 70%);scrollbar-color:var(--scrollbar-thumb-color) var(--scrollbar-track-color);scrollbar-width:thin}.tablist-wrapper ::-webkit-scrollbar{width:4px}.tablist-wrapper ::-webkit-scrollbar-track{background:var(--scrollbar-track-color)}.tablist-wrapper ::-webkit-scrollbar-thumb{background-color:var(--scrollbar-fallback-track-color,var(--scrollbar-thumb-color));border:0;border-radius:4px}.base:not(.orientation-vertical) .tablist-wrapper{align-self:end;inline-size:100%;overflow:auto hidden}.base.orientation-vertical .tablist-wrapper{block-size:100%;overflow:hidden auto}.tablist-wrapper::-webkit-scrollbar{display:none}slot[name=action-items]{display:flex}.base.has-action-items.orientation-horizontal slot[name=action-items]{margin-inline:var(--_tabs-tablist-gutter);align-items:center}.base.has-action-items.orientation-vertical slot[name=action-items]{margin-block:var(--_tabs-tablist-gutter)}.tabpanel{box-sizing:border-box;block-size:100%;min-block-size:0;min-inline-size:0}.base.scroll .tabpanel{--scrollbar-track-color:transparent;--scrollbar-thumb-color:color-mix(in srgb, var(--vvd-color-neutral-950), transparent 70%);scrollbar-color:var(--scrollbar-thumb-color) var(--scrollbar-track-color);scrollbar-width:thin;overflow-y:auto}.base.scroll .tabpanel ::-webkit-scrollbar{width:4px}.base.scroll .tabpanel ::-webkit-scrollbar-track{background:var(--scrollbar-track-color)}.base.scroll .tabpanel ::-webkit-scrollbar-thumb{background-color:var(--scrollbar-fallback-track-color,var(--scrollbar-thumb-color));border:0;border-radius:4px}.base.gutters-small .tabpanel{padding:calc(calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2))) - calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2) - 16)))}.active-indicator{background:currentColor;margin-inline-start:calc(var(--_tabs-tablist-gutter) * -1)}.base.orientation-vertical .active-indicator{block-size:80%;inline-size:var(--_tabs-active-indicator-stroke-width);border-radius:2px;grid-area:1/1;align-self:center}.base:not(.orientation-vertical) .active-indicator{z-index:1;block-size:var(--_tabs-active-indicator-stroke-width);inline-size:calc(var(--_tabs-active-tab-inline-size));border-radius:2px;grid-area:2/1;position:absolute;inset-block-end:0;inset-inline-start:8px}.activeIndicatorTransition{transition:transform .2s ease-out,inline-size .2s ease-out}";
10
- //#endregion
11
- //#region src/lib/tabs/tabs.ts
12
- var ACTIVE_TAB_WIDTH = "--_tabs-active-tab-inline-size";
13
- var TabsGutters = {
14
- None: "none",
15
- Small: "small"
16
- };
17
- var TabsOrientation = {
18
- vertical: "vertical",
19
- horizontal: "horizontal"
20
- };
21
- var oppositeOrientation = (orientation) => orientation === TabsOrientation.horizontal ? TabsOrientation.vertical : TabsOrientation.horizontal;
22
- var gridProperty = (orientation) => orientation === TabsOrientation.horizontal ? "gridColumn" : "gridRow";
23
- var translateProperty = (orientation) => orientation === TabsOrientation.horizontal ? "translateX" : "translateY";
24
- var offsetProperty = (orientation) => orientation === TabsOrientation.horizontal ? "offsetLeft" : "offsetTop";
25
- var isFocusableElement = (el) => el.getAttribute("aria-disabled") !== "true" && !el.disabled && !el.hasAttribute("hidden");
26
- var arrayShallowEquals = (a, b) => a.length === b.length && a.every((v, i) => v === b[i]);
2
+ import { n as applyHostSemantics, t as HostSemantics } from "./host-semantics.js";
3
+ import { html } from "@microsoft/fast-element";
4
+ //#region src/lib/tab-panel/tab-panel.ts
27
5
  /**
28
6
  * @public
29
- * @component tabs
30
- * @slot - Default slot for tab and tab-panel elements.
31
- * @slot action-items - Slot for action items such as buttons or controls.
32
- * @event {CustomEvent<HTMLElement>} change - Fires a custom 'change' event when a tab is clicked or during keyboard navigation
7
+ * @component tab-panel
8
+ * @slot - Default slot.
33
9
  */
34
- var Tabs = class extends VividElement {
35
- constructor(..._args) {
36
- super(..._args);
37
- this.orientation = TabsOrientation.horizontal;
38
- this.tabs = [];
39
- this.tabpanels = [];
40
- this.scrollablePanel = false;
41
- this._actionItemsSlottedContent = [];
42
- this.activeindicator = true;
43
- }
44
- /**
45
- * @internal
46
- */
47
- orientationChanged() {
48
- this._registerTabsChange();
49
- if (this.$fastController.isConnected) Updates.enqueue(() => this.#moveActiveIndicator(false));
50
- }
51
- /**
52
- * @internal
53
- */
54
- tabsChanged() {
55
- for (const tab of this.tabs) {
56
- if (!tab.id) tab.id = `tab-${uniqueId()}`;
57
- tab.addEventListener("click", this.#onTabClick);
58
- tab.addEventListener("keydown", this.#onTabKeyDown);
59
- }
60
- this._registerTabsChange();
61
- }
62
- /**
63
- * @internal
64
- */
65
- tabpanelsChanged() {
66
- for (const panel of this.tabpanels) if (!panel.id) panel.id = `panel-${uniqueId()}`;
67
- this._registerTabsChange();
68
- }
69
- #areSlotsSynced() {
70
- return arrayShallowEquals(this.tabs, this._tabsSlot.assignedNodes()) && arrayShallowEquals(this.tabpanels, this._tabPanelsSlot.assignedNodes());
71
- }
72
- /**
73
- * Tabs that are paired with a tabpanel. Ignore any excess tabs or panels.
74
- */
75
- get _pairedTabs() {
76
- return this.tabs.slice(0, Math.min(this.tabs.length, this.tabpanels.length));
77
- }
78
- /**
79
- * Tabs that are eligible to become active.
80
- */
81
- get _validTabs() {
82
- return this._pairedTabs.filter(isFocusableElement);
83
- }
84
- /**
85
- * @internal
86
- */
87
- activeidChanged() {
88
- this._registerTabsChange();
89
- }
90
- /**
91
- * A reference to the active tab
92
- * @public
93
- */
94
- get activetab() {
95
- return this._validTabs.find((tab) => tab.id === this.activeid) ?? null;
96
- }
97
- #setActiveTabDueToUserInteraction(tab) {
98
- this.activeid = tab.id;
99
- tab.focus();
100
- this.$emit("change", tab);
101
- }
102
- #isTabsChangeQueued = false;
103
- /**
104
- * Defer actual processing of changes into a microtask to wait for all DOM changes to complete. E.g. when tabs and
105
- * active id are updated at the same time.
106
- */
107
- _registerTabsChange() {
108
- if (this.#isTabsChangeQueued) return;
109
- this.#isTabsChangeQueued = true;
110
- window.queueMicrotask(() => {
111
- if (this.$fastController.isConnected && this.#areSlotsSynced()) this.#handleTabsChange();
112
- this.#isTabsChangeQueued = false;
113
- });
114
- }
115
- #lastActiveId = void 0;
116
- #handleTabsChange() {
117
- const validTabs = this._validTabs;
118
- let newActiveId = this.activeid;
119
- if (!validTabs.length || newActiveId && !validTabs.find((t) => t.id === newActiveId)) newActiveId = void 0;
120
- if (!newActiveId && validTabs.length) newActiveId = validTabs[0].id;
121
- if (this.activeid !== newActiveId) {
122
- this.activeid = newActiveId;
123
- this.$emit("change", this.activetab);
124
- }
125
- this.#updateSlottedChildren();
126
- if (this.activeid !== this.#lastActiveId) {
127
- if (this.activetab) {
128
- const shouldAnimate = this.#lastActiveId !== void 0;
129
- this.#scrollToTab(this.activetab, shouldAnimate);
130
- this.#moveActiveIndicator(shouldAnimate);
131
- }
132
- this.#lastActiveId = this.activeid;
133
- } else this.#moveActiveIndicator(this.#isTransitioningTransform);
134
- }
135
- /**
136
- * Updates the tabs and their panels according to the current state of the component.
137
- */
138
- #updateSlottedChildren() {
139
- for (const [index, tab] of this._pairedTabs.entries()) {
140
- const panel = this.tabpanels[index];
141
- const isActiveTab = tab.id === this.activeid;
142
- /* v8 ignore else -- @preserve */
143
- if (tab instanceof Tab) tab.active = isActiveTab;
144
- tab.setAttribute("aria-controls", panel.id);
145
- tab.setAttribute("tabindex", isActiveTab ? "0" : "-1");
146
- if (isActiveTab && this.connotation) tab.setAttribute("connotation", this.connotation);
147
- else tab.removeAttribute("connotation");
148
- tab.classList.toggle("vertical", this.orientation === TabsOrientation.vertical);
149
- tab.style[gridProperty(oppositeOrientation(this.orientation))] = "";
150
- tab.style[gridProperty(this.orientation)] = `${index + 1}`;
151
- panel.setAttribute("aria-labelledby", tab.id);
152
- panel.hidden = !isActiveTab;
153
- }
154
- }
155
- #onTabClick = (event) => {
156
- const selectedTab = event.currentTarget;
157
- if (this._validTabs.includes(selectedTab)) this.#setActiveTabDueToUserInteraction(selectedTab);
158
- };
159
- #onTabKeyDown = (event) => {
160
- const tabs = this._validTabs;
161
- const activeTab = this.activetab;
162
- if (!activeTab) return;
163
- const [arrowKeyPrev, arrowKeyNext] = this.orientation === TabsOrientation.horizontal ? [keyArrowLeft$1, keyArrowRight$1] : [keyArrowUp, keyArrowDown];
164
- const keyToNextTab = {
165
- [arrowKeyPrev]: () => tabs[(tabs.indexOf(activeTab) - 1 + tabs.length) % tabs.length],
166
- [arrowKeyNext]: () => tabs[(tabs.indexOf(activeTab) + 1) % tabs.length],
167
- [keyHome]: () => tabs[0],
168
- [keyEnd]: () => tabs[tabs.length - 1]
169
- };
170
- if (keyToNextTab[event.key]) {
171
- event.preventDefault();
172
- this.#setActiveTabDueToUserInteraction(keyToNextTab[event.key]());
173
- }
174
- };
175
- /**
176
- * Adjusts the active index by numerical increments.
177
- * Only enabled tabs are considered.
178
- * @public
179
- * @remarks
180
- */
181
- adjust(adjustment) {
182
- const focusableTabs = this._validTabs;
183
- const currentActiveTabIndex = focusableTabs.findIndex((t) => t.id === this.activeid);
184
- if (currentActiveTabIndex === -1) return;
185
- const nextTabIndex = limit(0, focusableTabs.length - 1, currentActiveTabIndex + adjustment);
186
- this.#setActiveTabDueToUserInteraction(focusableTabs[nextTabIndex]);
187
- }
188
- #isTransitioningTransform = false;
189
- /**
190
- * @internal
191
- */
192
- _onActiveIndicatorTransitionend(event) {
193
- /* v8 ignore else -- @preserve */
194
- if (event.propertyName === "transform") this.#isTransitioningTransform = false;
195
- }
196
- #cancelAnimationIfNeeded() {
197
- this.#isTransitioningTransform = false;
198
- this.activeIndicatorRef.classList.remove("activeIndicatorTransition");
199
- }
200
- #moveActiveIndicator(shouldAnimate) {
201
- const activeTabIndex = this._pairedTabs.findIndex((tab) => tab.id === this.activeid);
202
- if (activeTabIndex === -1) return;
203
- const indicatorEl = this.activeIndicatorRef;
204
- const currentOffset = indicatorEl[offsetProperty(this.orientation)];
205
- indicatorEl.style[gridProperty(this.orientation)] = `${activeTabIndex + 1}`;
206
- const targetOffset = indicatorEl[offsetProperty(this.orientation)];
207
- indicatorEl.style[gridProperty(this.orientation)] = "";
208
- const relativeOffset = targetOffset - currentOffset;
209
- const currentTransform = indicatorEl.style.transform;
210
- const targetTransform = `${translateProperty(this.orientation)}(${relativeOffset}px)`;
211
- if (shouldAnimate) {
212
- indicatorEl.classList.add("activeIndicatorTransition");
213
- if (currentTransform !== targetTransform) this.#isTransitioningTransform = true;
214
- } else this.#cancelAnimationIfNeeded();
215
- indicatorEl.style.transform = targetTransform;
216
- indicatorEl.style.setProperty(ACTIVE_TAB_WIDTH, this.tabs[activeTabIndex].getBoundingClientRect().width + "px");
217
- }
218
- /**
219
- * @internal
220
- */
221
- connotationChanged() {
222
- this._registerTabsChange();
223
- }
224
- #updateScrollStatus() {
225
- this.#tabListScrollWrapper.dispatchEvent(new Event("scroll"));
226
- }
227
- #resizeObserver;
228
- connectedCallback() {
229
- super.connectedCallback();
230
- this._registerTabsChange();
231
- requestAnimationFrame(() => this.#updateScrollStatus());
232
- this.#resizeObserver = new ResizeObserver(() => {
233
- this.#moveActiveIndicator(this.#isTransitioningTransform);
234
- this.#updateScrollStatus();
235
- });
236
- this.#resizeObserver.observe(this.#tabListScrollWrapper);
237
- this.#resizeObserver.observe(this.tablist);
238
- }
239
- disconnectedCallback() {
240
- super.disconnectedCallback();
241
- this.#resizeObserver.disconnect();
242
- }
243
- get #tabListWrapper() {
244
- return this.shadowRoot.querySelector(".tablist-wrapper");
245
- }
246
- get #tabListScrollWrapper() {
247
- return this.tablist.parentElement;
248
- }
249
- #scrollToTab(tab, shouldAnimate = true) {
250
- const index = this.tabs.findIndex((t) => t === tab);
251
- let left = 0;
252
- let top = 0;
253
- if (this.orientation === TabsOrientation.vertical) {
254
- if (index === this.tabs.length - 1) top = this.#tabListWrapper.scrollHeight;
255
- if (index > 0 && index < this.tabs.length - 1) top = tab.offsetTop - this.#tabListWrapper.offsetHeight / 2 + tab.offsetHeight / 2;
256
- } else {
257
- if (index === this.tabs.length - 1) left = this.#tabListWrapper.scrollWidth;
258
- if (index > 0 && index < this.tabs.length - 1) left = tab.offsetLeft - this.#tabListWrapper.offsetWidth / 2 + tab.offsetWidth / 2;
259
- }
260
- this.#tabListWrapper.scrollTo({
261
- top,
262
- left,
263
- behavior: shouldAnimate ? "smooth" : "instant"
264
- });
265
- }
266
- };
267
- __decorate([attr], Tabs.prototype, "orientation", void 0);
268
- __decorate([observable], Tabs.prototype, "tabs", void 0);
269
- __decorate([observable], Tabs.prototype, "tabpanels", void 0);
270
- __decorate([attr], Tabs.prototype, "activeid", void 0);
271
- __decorate([observable], Tabs.prototype, "activeIndicatorRef", void 0);
272
- __decorate([observable], Tabs.prototype, "tablist", void 0);
273
- __decorate([attr], Tabs.prototype, "connotation", void 0);
274
- __decorate([attr], Tabs.prototype, "gutters", void 0);
275
- __decorate([attr({
276
- mode: "boolean",
277
- attribute: "scrollable-panel"
278
- })], Tabs.prototype, "scrollablePanel", void 0);
279
- __decorate([attr({ attribute: "tabs-layout" })], Tabs.prototype, "tabsLayout", void 0);
280
- __decorate([observable], Tabs.prototype, "_actionItemsSlottedContent", void 0);
281
- __decorate([attr({ mode: "boolean" })], Tabs.prototype, "activeindicator", void 0);
282
- //#endregion
283
- //#region src/lib/tabs/tabs.template.ts
284
- var getClasses = ({ connotation, orientation, gutters, scrollablePanel, tabsLayout, _actionItemsSlottedContent }) => classNames("base", `layout-${tabsLayout ?? "align-start"}`, [`connotation-${connotation}`, Boolean(connotation)], [`orientation-${orientation}`, Boolean(orientation)], `gutters-${gutters ?? "small"}`, ["scroll", Boolean(scrollablePanel)], ["has-action-items", Boolean(_actionItemsSlottedContent.length)]);
285
- function setNoScrollState(scrollShadow, scrollWrapper) {
286
- if (scrollWrapper.scrollWidth <= scrollWrapper.clientWidth) {
287
- scrollShadow.classList.toggle("start-scroll", false);
288
- scrollShadow.classList.toggle("end-scroll", false);
289
- return true;
290
- }
291
- return false;
292
- }
293
- function addStartShadow(scrollShadow, scrollWrapper) {
294
- scrollShadow.classList.toggle("start-scroll", scrollWrapper.scrollLeft > 0);
295
- }
296
- function addEndShadow(scrollShadow, scrollWrapper) {
297
- scrollShadow.classList.toggle("end-scroll", scrollWrapper.scrollLeft + 1 < scrollWrapper.scrollWidth - scrollWrapper.clientWidth);
298
- }
299
- function setShadowWhenScrollTabs(_, { event }) {
300
- const scrollWrapper = event.currentTarget;
301
- const scrollShadow = scrollWrapper.parentElement;
302
- if (setNoScrollState(scrollShadow, scrollWrapper)) return;
303
- addStartShadow(scrollShadow, scrollWrapper);
304
- addEndShadow(scrollShadow, scrollWrapper);
305
- }
10
+ var TabPanel = class extends HostSemantics(VividElement) {};
306
11
  //#endregion
307
- //#region src/lib/tabs/definition.ts
12
+ //#region src/lib/tab-panel/definition.ts
308
13
  /**
309
14
  * @internal
310
15
  */
311
- var tabsDefinition = defineVividComponent("tabs", Tabs, html`
312
- <template>
313
- <div class="${getClasses}">
314
- <div class="tabs">
315
- <div class="scroll-shadow">
316
- <div class="tablist-wrapper" @scroll="${setShadowWhenScrollTabs}">
317
- <div class="tablist" role="tablist" ${ref("tablist")}>
318
- <slot name="tab" ${ref("_tabsSlot")} ${slotted("tabs")}></slot>
319
- <div
320
- ${ref("activeIndicatorRef")}
321
- class="active-indicator"
322
- @transitionend="${(x, c) => x._onActiveIndicatorTransitionend(c.event)}"
323
- ></div>
324
- </div>
325
- </div>
326
- </div>
327
- <slot
328
- name="action-items"
329
- ${slotted("_actionItemsSlottedContent")}
330
- ></slot>
331
- </div>
332
- <div class="tabpanel" part="tab-panel">
333
- <slot
334
- name="tabpanel"
335
- ${ref("_tabPanelsSlot")}
336
- ${slotted("tabpanels")}
337
- ></slot>
338
- </div>
339
- </div>
16
+ var tabPanelDefinition = defineVividComponent("tab-panel", TabPanel, html`
17
+ <template slot="tabpanel" ${applyHostSemantics({ role: "tabpanel" })}>
18
+ <slot></slot>
340
19
  </template>
341
- `, [tabDefinition, tabPanelDefinition], { styles: tabs_default });
20
+ `, [], {});
342
21
  /**
343
- * Registers the tabs elements with the design system.
22
+ * Registers the tab-panel elements with the design system.
344
23
  *
345
24
  * @param prefix - the prefix to use for the component name
346
25
  */
347
- var registerTabs = createRegisterFunction(tabsDefinition);
26
+ var registerTabPanel = createRegisterFunction(tabPanelDefinition);
348
27
  //#endregion
349
- export { TabsGutters as i, tabsDefinition as n, Tabs as r, registerTabs as t };
28
+ export { tabPanelDefinition as n, TabPanel as r, registerTabPanel as t };
@@ -1,57 +1,119 @@
1
1
  require("./chunk.cjs");
2
2
  const require_vivid_element = require("./vivid-element.cjs");
3
- const require_delegates_aria = require("./delegates-aria.cjs");
3
+ const require_definition = require("./definition2.cjs");
4
+ const require_decorate = require("./decorate.cjs");
5
+ const require_affix = require("./affix.cjs");
6
+ const require_localized = require("./localized.cjs");
7
+ const require_host_semantics = require("./host-semantics.cjs");
4
8
  let _microsoft_fast_element = require("@microsoft/fast-element");
5
9
  let _microsoft_fast_web_utilities = require("@microsoft/fast-web-utilities");
6
- //#region src/lib/tag-group/tag-group.scss?inline
7
- var tag_group_default = ".base{flex-wrap:wrap;gap:8px;display:flex}";
10
+ //#region src/lib/tab/tab.scss?inline
11
+ var tab_default = ":host{--_vvd-tab-accent-firm-wrapper:var(--vvd-tab-accent-firm);--_vvd-tab-cta-firm-wrapper:var(--vvd-tab-cta-firm)}.base{--vvd-tab-accent-firm:var(--_vvd-tab-accent-firm-wrapper,var(--vvd-tab-accent-primary));--vvd-tab-cta-firm:var(--_vvd-tab-cta-firm-wrapper,var(--vvd-tab-cta-primary))}:host(.vertical){grid-column:1;justify-content:end}:host([disabled]){cursor:not-allowed}:host([removable]){position:relative}:host(:focus-visible){outline:none}.base{--_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(--_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(--_connotation-color-firm);--_appearance-color-fill:var(--_connotation-color-faint);--_appearance-color-outline:transparent}.base:disabled,.base.disabled{--_appearance-color-text:var(--vvd-color-neutral-300);--_appearance-color-fill:transparent;--_appearance-color-outline:transparent}.base:active:where(:not(.disabled,:disabled)),.base.active:where(:not(.disabled,:disabled)){--_appearance-color-text:var(--_connotation-color-firm);--_appearance-color-fill:var(--_connotation-color-soft);--_appearance-color-outline:transparent}.base.connotation-cta{--_connotation-color-primary-text:var(--vvd-tab-cta-primary-text,var(--vvd-color-canvas));--_connotation-color-firm:var(--vvd-tab-cta-firm,var(--vvd-color-cta-600));--_connotation-color-faint:var(--vvd-tab-cta-faint,var(--vvd-color-cta-50));--_connotation-color-fierce:var(--vvd-tab-cta-fierce,var(--vvd-color-cta-700));--_connotation-color-pale:var(--vvd-tab-cta-pale,var(--vvd-color-cta-300));--_connotation-color-soft:var(--vvd-tab-cta-soft,var(--vvd-color-cta-100))}.base:not(.connotation-cta){--_connotation-color-primary-text:var(--vvd-tab-accent-primary-text,var(--vvd-color-canvas));--_connotation-color-firm:var(--vvd-tab-accent-firm,var(--vvd-color-canvas-text));--_connotation-color-faint:var(--vvd-tab-accent-faint,var(--vvd-color-neutral-50));--_connotation-color-fierce:var(--vvd-tab-accent-fierce,var(--vvd-color-neutral-700));--_connotation-color-pale:var(--vvd-tab-accent-pale,var(--vvd-color-neutral-300));--_connotation-color-soft:var(--vvd-tab-accent-soft,var(--vvd-color-neutral-100))}.base{box-sizing:border-box;align-items:center;justify-content:var(--_tab-justify-content);padding:var(--_tabs-tablist-gutter);background-color:var(--_appearance-color-fill);box-shadow:inset 0 0 0 1px var(--_appearance-color-outline);color:var(--_appearance-color-text);font:var(--vvd-typography-base-bold);gap:var(--_tabs-tablist-gutter);vertical-align:middle;white-space:nowrap;min-block-size:40px;display:flex;position:relative}@supports (user-select:none){.base{user-select:none}}.base:not(.shape-sharp){border-radius:8px}.base:not(.disabled){cursor:pointer}.base.disabled{pointer-events:none}.base.removable{padding-inline-end:40px}:host(:focus-visible) .base{--focus-stroke-gap-color:transparent;box-shadow:0 0 0 4px color-mix(in srgb, var(--focus-stroke-color,var(--vvd-color-cta-500)), transparent 85%), inset 0 0 0 3px var(--focus-stroke-gap-color,currentColor);outline:1px solid var(--focus-stroke-color,var(--vvd-color-cta-500));outline-offset:calc(-1px - var(--focus-inset,0px))}:host(.vertical) .base{margin-inline-start:var(--_tabs-active-indicator-stroke-width)}slot[name=icon]{font-size:20px;line-height:1}.icon-trailing slot[name=icon]{order:1;margin-inline-start:auto;display:inline-block}.close{background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;block-size:24px;inline-size:24px;display:flex;position:absolute;inset-block-start:50%;inset-inline-end:4px;transform:translateY(-50%)}.close: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))}.close vwc-icon{font-size:12px}.close .icon{justify-content:center;align-items:center;display:flex}";
8
12
  //#endregion
9
- //#region src/lib/tag-group/tag-group.ts
13
+ //#region src/lib/tab/tab.ts
10
14
  /**
11
15
  * @public
12
- * @component tag-group
13
- * @slot - The content of the tag-group.
16
+ * @component tab
17
+ * @slot icon - The preferred way to add an icon to the component.
18
+ * @testSelector byLabel byLabel
19
+ * @testAction select click #base
20
+ * @testQuery active active true
21
+ * @testQuery inactive active false
22
+ * @testRef base shadow .base
14
23
  */
15
- var TagGroup = class extends require_delegates_aria.DelegatesAria(require_vivid_element.VividElement) {};
24
+ var Tab = class extends require_host_semantics.HostSemantics(require_affix.AffixIconWithTrailing(require_localized.Localized(require_vivid_element.VividElement))) {
25
+ constructor(..._args) {
26
+ super(..._args);
27
+ this.removable = false;
28
+ this.tabIndex = "-1";
29
+ this.active = false;
30
+ }
31
+ /**
32
+ * @internal
33
+ */
34
+ _handleCloseClick(e) {
35
+ e.stopImmediatePropagation();
36
+ this.$emit("close");
37
+ }
38
+ /**
39
+ * @internal
40
+ */
41
+ _onKeyDown(e) {
42
+ if (!this.removable || e.key !== "Delete") return true;
43
+ e.stopImmediatePropagation();
44
+ this.$emit("close");
45
+ return false;
46
+ }
47
+ };
48
+ require_decorate.__decorate([(0, _microsoft_fast_element.attr)({ mode: "boolean" })], Tab.prototype, "disabled", void 0);
49
+ require_decorate.__decorate([_microsoft_fast_element.attr], Tab.prototype, "connotation", void 0);
50
+ require_decorate.__decorate([_microsoft_fast_element.attr], Tab.prototype, "shape", void 0);
51
+ require_decorate.__decorate([_microsoft_fast_element.attr], Tab.prototype, "label", void 0);
52
+ require_decorate.__decorate([(0, _microsoft_fast_element.attr)({ mode: "boolean" })], Tab.prototype, "removable", void 0);
53
+ require_decorate.__decorate([(0, _microsoft_fast_element.attr)({ mode: "fromView" })], Tab.prototype, "tabIndex", void 0);
54
+ require_decorate.__decorate([_microsoft_fast_element.observable], Tab.prototype, "active", void 0);
16
55
  //#endregion
17
- //#region src/lib/tag-group/tag-group.template.ts
18
- var getClasses = (_) => (0, _microsoft_fast_web_utilities.classNames)("base");
19
- var TagGroupTemplate = _microsoft_fast_element.html`
20
- <div
21
- class="${getClasses}"
22
- ${require_delegates_aria.delegateAria({ role: "group" })}
56
+ //#region src/lib/tab/tab.template.ts
57
+ var getClasses = ({ connotation, disabled, active, iconTrailing, shape, removable }) => (0, _microsoft_fast_web_utilities.classNames)("base", [`connotation-${connotation}`, Boolean(connotation) && Boolean(active)], [`shape-${shape}`, Boolean(shape)], ["disabled", Boolean(disabled)], ["selected", Boolean(active)], ["icon-trailing", iconTrailing], ["removable", removable]);
58
+ function renderDismissButton(context) {
59
+ const affixIconTemplate = require_affix.affixIconTemplateFactory(context);
60
+ return _microsoft_fast_element.html`<button
61
+ aria-label="${(x) => x.locale.tab.dismissButtonLabel}"
62
+ class="close"
63
+ id="close-btn"
64
+ @click="${(x, c) => x._handleCloseClick(c.event)}"
23
65
  >
24
- <slot></slot>
25
- </div>
26
- `;
66
+ ${() => affixIconTemplate("close-line", require_affix.IconWrapper.Span)}
67
+ </button>`;
68
+ }
69
+ var TabTemplate = (context) => {
70
+ const affixIconTemplate = require_affix.affixIconTemplateFactory(context);
71
+ return _microsoft_fast_element.html`
72
+ <template
73
+ slot="tab"
74
+ ?active="${(x) => x.active}"
75
+ ${require_host_semantics.applyHostSemantics({
76
+ role: "tab",
77
+ ariaDisabled: (x) => x.disabled,
78
+ ariaSelected: (x) => x.active
79
+ })}
80
+ @keydown="${(x, c) => x._onKeyDown(c.event)}"
81
+ >
82
+ <div class="${getClasses}">
83
+ ${(x) => affixIconTemplate(x.icon, require_affix.IconWrapper.Slot)} ${(x) => x.label}
84
+ ${(x) => x.removable ? renderDismissButton(context) : null}
85
+ </div>
86
+ </template>
87
+ `;
88
+ };
27
89
  //#endregion
28
- //#region src/lib/tag-group/definition.ts
90
+ //#region src/lib/tab/definition.ts
29
91
  /**
30
92
  * @internal
31
93
  */
32
- var tagGroupDefinition = require_vivid_element.defineVividComponent("tag-group", TagGroup, TagGroupTemplate, [], { styles: tag_group_default });
94
+ var tabDefinition = require_vivid_element.defineVividComponent("tab", Tab, TabTemplate, [require_definition.iconDefinition], { styles: tab_default });
33
95
  /**
34
- * Registers the tag-group element with the design system.
96
+ * Registers the tab elements with the design system.
35
97
  *
36
98
  * @param prefix - the prefix to use for the component name
37
99
  */
38
- var registerTagGroup = require_vivid_element.createRegisterFunction(tagGroupDefinition);
100
+ var registerTab = require_vivid_element.createRegisterFunction(tabDefinition);
39
101
  //#endregion
40
- Object.defineProperty(exports, "TagGroup", {
102
+ Object.defineProperty(exports, "Tab", {
41
103
  enumerable: true,
42
104
  get: function() {
43
- return TagGroup;
105
+ return Tab;
44
106
  }
45
107
  });
46
- Object.defineProperty(exports, "registerTagGroup", {
108
+ Object.defineProperty(exports, "registerTab", {
47
109
  enumerable: true,
48
110
  get: function() {
49
- return registerTagGroup;
111
+ return registerTab;
50
112
  }
51
113
  });
52
- Object.defineProperty(exports, "tagGroupDefinition", {
114
+ Object.defineProperty(exports, "tabDefinition", {
53
115
  enumerable: true,
54
116
  get: function() {
55
- return tagGroupDefinition;
117
+ return tabDefinition;
56
118
  }
57
119
  });
@@ -1,38 +1,101 @@
1
1
  import { o as defineVividComponent, s as createRegisterFunction, t as VividElement } from "./vivid-element.js";
2
- import { n as delegateAria, t as DelegatesAria } from "./delegates-aria.js";
3
- import { html } from "@microsoft/fast-element";
2
+ import { t as iconDefinition } from "./definition2.js";
3
+ import { t as __decorate } from "./decorate.js";
4
+ import { a as affixIconTemplateFactory, i as IconWrapper, n as AffixIconWithTrailing } from "./affix.js";
5
+ import { t as Localized } from "./localized.js";
6
+ import { n as applyHostSemantics, t as HostSemantics } from "./host-semantics.js";
7
+ import { attr, html, observable } from "@microsoft/fast-element";
4
8
  import { classNames } from "@microsoft/fast-web-utilities";
5
- //#region src/lib/tag-group/tag-group.scss?inline
6
- var tag_group_default = ".base{flex-wrap:wrap;gap:8px;display:flex}";
9
+ //#region src/lib/tab/tab.scss?inline
10
+ var tab_default = ":host{--_vvd-tab-accent-firm-wrapper:var(--vvd-tab-accent-firm);--_vvd-tab-cta-firm-wrapper:var(--vvd-tab-cta-firm)}.base{--vvd-tab-accent-firm:var(--_vvd-tab-accent-firm-wrapper,var(--vvd-tab-accent-primary));--vvd-tab-cta-firm:var(--_vvd-tab-cta-firm-wrapper,var(--vvd-tab-cta-primary))}:host(.vertical){grid-column:1;justify-content:end}:host([disabled]){cursor:not-allowed}:host([removable]){position:relative}:host(:focus-visible){outline:none}.base{--_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(--_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(--_connotation-color-firm);--_appearance-color-fill:var(--_connotation-color-faint);--_appearance-color-outline:transparent}.base:disabled,.base.disabled{--_appearance-color-text:var(--vvd-color-neutral-300);--_appearance-color-fill:transparent;--_appearance-color-outline:transparent}.base:active:where(:not(.disabled,:disabled)),.base.active:where(:not(.disabled,:disabled)){--_appearance-color-text:var(--_connotation-color-firm);--_appearance-color-fill:var(--_connotation-color-soft);--_appearance-color-outline:transparent}.base.connotation-cta{--_connotation-color-primary-text:var(--vvd-tab-cta-primary-text,var(--vvd-color-canvas));--_connotation-color-firm:var(--vvd-tab-cta-firm,var(--vvd-color-cta-600));--_connotation-color-faint:var(--vvd-tab-cta-faint,var(--vvd-color-cta-50));--_connotation-color-fierce:var(--vvd-tab-cta-fierce,var(--vvd-color-cta-700));--_connotation-color-pale:var(--vvd-tab-cta-pale,var(--vvd-color-cta-300));--_connotation-color-soft:var(--vvd-tab-cta-soft,var(--vvd-color-cta-100))}.base:not(.connotation-cta){--_connotation-color-primary-text:var(--vvd-tab-accent-primary-text,var(--vvd-color-canvas));--_connotation-color-firm:var(--vvd-tab-accent-firm,var(--vvd-color-canvas-text));--_connotation-color-faint:var(--vvd-tab-accent-faint,var(--vvd-color-neutral-50));--_connotation-color-fierce:var(--vvd-tab-accent-fierce,var(--vvd-color-neutral-700));--_connotation-color-pale:var(--vvd-tab-accent-pale,var(--vvd-color-neutral-300));--_connotation-color-soft:var(--vvd-tab-accent-soft,var(--vvd-color-neutral-100))}.base{box-sizing:border-box;align-items:center;justify-content:var(--_tab-justify-content);padding:var(--_tabs-tablist-gutter);background-color:var(--_appearance-color-fill);box-shadow:inset 0 0 0 1px var(--_appearance-color-outline);color:var(--_appearance-color-text);font:var(--vvd-typography-base-bold);gap:var(--_tabs-tablist-gutter);vertical-align:middle;white-space:nowrap;min-block-size:40px;display:flex;position:relative}@supports (user-select:none){.base{user-select:none}}.base:not(.shape-sharp){border-radius:8px}.base:not(.disabled){cursor:pointer}.base.disabled{pointer-events:none}.base.removable{padding-inline-end:40px}:host(:focus-visible) .base{--focus-stroke-gap-color:transparent;box-shadow:0 0 0 4px color-mix(in srgb, var(--focus-stroke-color,var(--vvd-color-cta-500)), transparent 85%), inset 0 0 0 3px var(--focus-stroke-gap-color,currentColor);outline:1px solid var(--focus-stroke-color,var(--vvd-color-cta-500));outline-offset:calc(-1px - var(--focus-inset,0px))}:host(.vertical) .base{margin-inline-start:var(--_tabs-active-indicator-stroke-width)}slot[name=icon]{font-size:20px;line-height:1}.icon-trailing slot[name=icon]{order:1;margin-inline-start:auto;display:inline-block}.close{background:0 0;border:none;border-radius:4px;justify-content:center;align-items:center;block-size:24px;inline-size:24px;display:flex;position:absolute;inset-block-start:50%;inset-inline-end:4px;transform:translateY(-50%)}.close: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))}.close vwc-icon{font-size:12px}.close .icon{justify-content:center;align-items:center;display:flex}";
7
11
  //#endregion
8
- //#region src/lib/tag-group/tag-group.ts
12
+ //#region src/lib/tab/tab.ts
9
13
  /**
10
14
  * @public
11
- * @component tag-group
12
- * @slot - The content of the tag-group.
15
+ * @component tab
16
+ * @slot icon - The preferred way to add an icon to the component.
17
+ * @testSelector byLabel byLabel
18
+ * @testAction select click #base
19
+ * @testQuery active active true
20
+ * @testQuery inactive active false
21
+ * @testRef base shadow .base
13
22
  */
14
- var TagGroup = class extends DelegatesAria(VividElement) {};
23
+ var Tab = class extends HostSemantics(AffixIconWithTrailing(Localized(VividElement))) {
24
+ constructor(..._args) {
25
+ super(..._args);
26
+ this.removable = false;
27
+ this.tabIndex = "-1";
28
+ this.active = false;
29
+ }
30
+ /**
31
+ * @internal
32
+ */
33
+ _handleCloseClick(e) {
34
+ e.stopImmediatePropagation();
35
+ this.$emit("close");
36
+ }
37
+ /**
38
+ * @internal
39
+ */
40
+ _onKeyDown(e) {
41
+ if (!this.removable || e.key !== "Delete") return true;
42
+ e.stopImmediatePropagation();
43
+ this.$emit("close");
44
+ return false;
45
+ }
46
+ };
47
+ __decorate([attr({ mode: "boolean" })], Tab.prototype, "disabled", void 0);
48
+ __decorate([attr], Tab.prototype, "connotation", void 0);
49
+ __decorate([attr], Tab.prototype, "shape", void 0);
50
+ __decorate([attr], Tab.prototype, "label", void 0);
51
+ __decorate([attr({ mode: "boolean" })], Tab.prototype, "removable", void 0);
52
+ __decorate([attr({ mode: "fromView" })], Tab.prototype, "tabIndex", void 0);
53
+ __decorate([observable], Tab.prototype, "active", void 0);
15
54
  //#endregion
16
- //#region src/lib/tag-group/tag-group.template.ts
17
- var getClasses = (_) => classNames("base");
55
+ //#region src/lib/tab/tab.template.ts
56
+ var getClasses = ({ connotation, disabled, active, iconTrailing, shape, removable }) => classNames("base", [`connotation-${connotation}`, Boolean(connotation) && Boolean(active)], [`shape-${shape}`, Boolean(shape)], ["disabled", Boolean(disabled)], ["selected", Boolean(active)], ["icon-trailing", iconTrailing], ["removable", removable]);
57
+ function renderDismissButton(context) {
58
+ const affixIconTemplate = affixIconTemplateFactory(context);
59
+ return html`<button
60
+ aria-label="${(x) => x.locale.tab.dismissButtonLabel}"
61
+ class="close"
62
+ id="close-btn"
63
+ @click="${(x, c) => x._handleCloseClick(c.event)}"
64
+ >
65
+ ${() => affixIconTemplate("close-line", IconWrapper.Span)}
66
+ </button>`;
67
+ }
68
+ var TabTemplate = (context) => {
69
+ const affixIconTemplate = affixIconTemplateFactory(context);
70
+ return html`
71
+ <template
72
+ slot="tab"
73
+ ?active="${(x) => x.active}"
74
+ ${applyHostSemantics({
75
+ role: "tab",
76
+ ariaDisabled: (x) => x.disabled,
77
+ ariaSelected: (x) => x.active
78
+ })}
79
+ @keydown="${(x, c) => x._onKeyDown(c.event)}"
80
+ >
81
+ <div class="${getClasses}">
82
+ ${(x) => affixIconTemplate(x.icon, IconWrapper.Slot)} ${(x) => x.label}
83
+ ${(x) => x.removable ? renderDismissButton(context) : null}
84
+ </div>
85
+ </template>
86
+ `;
87
+ };
18
88
  //#endregion
19
- //#region src/lib/tag-group/definition.ts
89
+ //#region src/lib/tab/definition.ts
20
90
  /**
21
91
  * @internal
22
92
  */
23
- var tagGroupDefinition = defineVividComponent("tag-group", TagGroup, html`
24
- <div
25
- class="${getClasses}"
26
- ${delegateAria({ role: "group" })}
27
- >
28
- <slot></slot>
29
- </div>
30
- `, [], { styles: tag_group_default });
93
+ var tabDefinition = defineVividComponent("tab", Tab, TabTemplate, [iconDefinition], { styles: tab_default });
31
94
  /**
32
- * Registers the tag-group element with the design system.
95
+ * Registers the tab elements with the design system.
33
96
  *
34
97
  * @param prefix - the prefix to use for the component name
35
98
  */
36
- var registerTagGroup = createRegisterFunction(tagGroupDefinition);
99
+ var registerTab = createRegisterFunction(tabDefinition);
37
100
  //#endregion
38
- export { tagGroupDefinition as n, TagGroup as r, registerTagGroup as t };
101
+ export { tabDefinition as n, Tab as r, registerTab as t };