@vonage/vivid 5.17.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 (459) 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/alert/definition.cjs +5 -5
  10. package/alert/definition.js +1 -1
  11. package/alert/index.cjs +2 -2
  12. package/alert/index.js +6 -5
  13. package/audio-player/definition.cjs +5 -5
  14. package/audio-player/definition.js +1 -1
  15. package/audio-player/index.cjs +1 -1
  16. package/audio-player/index.js +2 -1
  17. package/avatar/definition.cjs +5 -5
  18. package/avatar/definition.js +1 -1
  19. package/avatar/index.cjs +3 -3
  20. package/avatar/index.js +6 -5
  21. package/badge/definition.cjs +5 -5
  22. package/badge/definition.js +1 -1
  23. package/badge/index.cjs +1 -4
  24. package/badge/index.js +4 -20
  25. package/banner/definition.cjs +5 -5
  26. package/banner/definition.js +1 -1
  27. package/banner/index.cjs +2 -2
  28. package/banner/index.js +5 -4
  29. package/breadcrumb-item/definition.cjs +4 -4
  30. package/breadcrumb-item/definition.js +1 -1
  31. package/breadcrumb-item/index.cjs +1 -1
  32. package/breadcrumb-item/index.js +1 -0
  33. package/bundled/affix.cjs +1 -1
  34. package/bundled/affix.js +5 -5
  35. package/bundled/definition11.cjs +2 -2
  36. package/bundled/definition11.js +5 -5
  37. package/bundled/definition12.cjs +3 -3
  38. package/bundled/definition12.js +5 -5
  39. package/bundled/definition13.cjs +2 -2
  40. package/bundled/definition13.js +4 -4
  41. package/bundled/definition15.cjs +3 -3
  42. package/bundled/definition15.js +7 -7
  43. package/bundled/definition17.cjs +3 -3
  44. package/bundled/definition17.js +8 -8
  45. package/bundled/definition18.cjs +2 -2
  46. package/bundled/definition18.js +6 -6
  47. package/bundled/definition2.cjs +3 -14
  48. package/bundled/definition2.js +15 -48
  49. package/bundled/definition20.cjs +5 -5
  50. package/bundled/definition20.js +8 -8
  51. package/bundled/definition22.cjs +4 -39
  52. package/bundled/definition22.js +18 -70
  53. package/bundled/definition23.cjs +12 -0
  54. package/bundled/definition23.js +37 -0
  55. package/bundled/definition24.cjs +39 -0
  56. package/bundled/definition24.js +72 -0
  57. package/bundled/definition3.cjs +1 -1
  58. package/bundled/definition3.js +9 -6
  59. package/bundled/definition4.cjs +2 -2
  60. package/bundled/definition4.js +5 -5
  61. package/bundled/definition6.cjs +11 -11
  62. package/bundled/definition6.js +45 -29
  63. package/bundled/localized.cjs +1 -1
  64. package/bundled/localized.js +1 -0
  65. package/bundled/mixins.cjs +4 -4
  66. package/bundled/mixins.js +7 -7
  67. package/bundled/numberConverter.cjs +12 -0
  68. package/bundled/numberConverter.js +38 -0
  69. package/bundled/picker-field.template.cjs +2 -1
  70. package/bundled/picker-field.template.js +2 -1
  71. package/bundled/utils.cjs +1 -0
  72. package/bundled/utils.js +1420 -0
  73. package/bundled/vivid-element.cjs +1 -1
  74. package/bundled/vivid-element.js +1 -1
  75. package/button/definition.cjs +5 -5
  76. package/button/definition.js +1 -1
  77. package/button/index.cjs +1 -1
  78. package/button/index.js +1 -1
  79. package/card/definition.cjs +5 -5
  80. package/card/definition.js +1 -1
  81. package/card/index.cjs +4 -4
  82. package/card/index.js +7 -6
  83. package/checkbox/definition.cjs +5 -5
  84. package/checkbox/definition.js +1 -1
  85. package/checkbox/index.cjs +1 -1
  86. package/checkbox/index.js +1 -1
  87. package/color-picker/definition.cjs +5 -5
  88. package/color-picker/definition.js +1 -1
  89. package/color-picker/index.cjs +7 -7
  90. package/color-picker/index.js +55 -54
  91. package/combobox/definition.cjs +5 -5
  92. package/combobox/definition.js +1 -1
  93. package/combobox/index.cjs +2 -2
  94. package/combobox/index.js +8 -7
  95. package/contextual-help/definition.cjs +5 -5
  96. package/contextual-help/definition.js +1 -1
  97. package/contextual-help/index.cjs +1 -1
  98. package/contextual-help/index.js +1 -1
  99. package/country/definition.cjs +5 -5
  100. package/country/definition.js +1 -1
  101. package/country/index.cjs +1 -12
  102. package/country/index.js +4 -1216
  103. package/country-group/definition.cjs +6 -0
  104. package/country-group/definition.js +3 -0
  105. package/country-group/index.cjs +43 -0
  106. package/country-group/index.js +166 -0
  107. package/custom-elements.json +1112 -450
  108. package/data-grid/definition.cjs +9 -9
  109. package/data-grid/definition.js +2 -2
  110. package/data-grid/index.cjs +4 -4
  111. package/data-grid/index.js +47 -46
  112. package/date-picker/definition.cjs +5 -5
  113. package/date-picker/definition.js +2 -2
  114. package/date-picker/index.cjs +1 -1
  115. package/date-picker/index.js +1 -1
  116. package/date-range-picker/definition.cjs +5 -5
  117. package/date-range-picker/definition.js +2 -2
  118. package/date-range-picker/index.cjs +1 -1
  119. package/date-range-picker/index.js +1 -1
  120. package/date-time-picker/definition.cjs +5 -5
  121. package/date-time-picker/definition.js +2 -2
  122. package/date-time-picker/index.cjs +1 -1
  123. package/date-time-picker/index.js +1 -1
  124. package/dial-pad/definition.cjs +5 -5
  125. package/dial-pad/definition.js +2 -2
  126. package/dial-pad/index.cjs +4 -4
  127. package/dial-pad/index.js +9 -8
  128. package/dialog/definition.cjs +5 -5
  129. package/dialog/definition.js +2 -2
  130. package/dialog/index.cjs +4 -4
  131. package/dialog/index.js +12 -11
  132. package/divider/definition.cjs +1 -1
  133. package/divider/definition.js +1 -1
  134. package/empty-state/definition.cjs +5 -5
  135. package/empty-state/definition.js +2 -2
  136. package/empty-state/index.cjs +2 -2
  137. package/empty-state/index.js +6 -5
  138. package/fab/definition.cjs +5 -5
  139. package/fab/definition.js +2 -2
  140. package/fab/index.cjs +2 -2
  141. package/fab/index.js +5 -4
  142. package/file-picker/definition.cjs +5 -5
  143. package/file-picker/definition.js +2 -2
  144. package/file-picker/index.cjs +6 -6
  145. package/file-picker/index.js +9 -8
  146. package/flag/definition.cjs +6 -0
  147. package/flag/definition.js +3 -0
  148. package/flag/index.cjs +10 -0
  149. package/flag/index.js +61 -0
  150. package/header/definition.cjs +1 -1
  151. package/header/definition.js +1 -1
  152. package/icon/definition.cjs +1 -0
  153. package/icon/definition.js +1 -0
  154. package/icon/index.cjs +1 -1
  155. package/icon/index.js +1 -0
  156. package/index.cjs +183 -174
  157. package/index.js +48 -45
  158. package/layout/definition.cjs +1 -1
  159. package/layout/definition.js +1 -1
  160. package/lib/button/button.d.ts +1 -0
  161. package/lib/components.d.ts +2 -0
  162. package/lib/country/countries-data.d.ts +1 -0
  163. package/lib/country/{country-code-to-flag-icon.d.ts → utils.d.ts} +0 -3
  164. package/lib/country-group/country-group.d.ts +829 -0
  165. package/lib/country-group/country-group.template.d.ts +3 -0
  166. package/lib/country-group/definition.d.ts +3 -0
  167. package/lib/country-group/index.d.ts +1 -0
  168. package/lib/country-group/locale.d.ts +3 -0
  169. package/lib/date-picker/date-picker.d.ts +4 -0
  170. package/lib/date-range-picker/date-range-picker.d.ts +2 -0
  171. package/lib/date-time-picker/date-time-picker.d.ts +4 -0
  172. package/lib/flag/definition.d.ts +3 -0
  173. package/lib/flag/flag.d.ts +8 -0
  174. package/lib/flag/flag.template.d.ts +3 -0
  175. package/lib/flag/index.d.ts +1 -0
  176. package/lib/icon/icon.d.ts +1 -2
  177. package/lib/searchable-select/option-tag.d.ts +3 -1
  178. package/lib/searchable-select/searchable-select.d.ts +3 -1
  179. package/lib/tag-name-map.d.ts +2 -1
  180. package/lib/time-picker/time-picker.d.ts +2 -0
  181. package/locales/de-DE.cjs +1 -0
  182. package/locales/de-DE.js +1 -0
  183. package/locales/en-GB.cjs +1 -0
  184. package/locales/en-GB.js +1 -0
  185. package/locales/en-US.cjs +1 -0
  186. package/locales/en-US.js +1 -0
  187. package/locales/ja-JP.cjs +1 -0
  188. package/locales/ja-JP.js +1 -0
  189. package/locales/zh-CN.cjs +1 -0
  190. package/locales/zh-CN.js +1 -0
  191. package/menu/definition.cjs +5 -5
  192. package/menu/definition.js +1 -1
  193. package/menu/index.cjs +1 -1
  194. package/menu/index.js +1 -1
  195. package/menu-item/definition.cjs +6 -6
  196. package/menu-item/definition.js +1 -1
  197. package/menu-item/index.cjs +1 -1
  198. package/menu-item/index.js +1 -1
  199. package/nav/definition.cjs +1 -1
  200. package/nav/definition.js +1 -1
  201. package/nav-disclosure/definition.cjs +5 -5
  202. package/nav-disclosure/definition.js +2 -2
  203. package/nav-disclosure/index.cjs +2 -2
  204. package/nav-disclosure/index.js +6 -5
  205. package/nav-item/definition.cjs +5 -5
  206. package/nav-item/definition.js +2 -2
  207. package/nav-item/index.cjs +2 -2
  208. package/nav-item/index.js +5 -4
  209. package/note/definition.cjs +5 -5
  210. package/note/definition.js +2 -2
  211. package/note/index.cjs +2 -2
  212. package/note/index.js +5 -4
  213. package/number-field/definition.cjs +5 -5
  214. package/number-field/definition.js +2 -2
  215. package/number-field/index.cjs +2 -2
  216. package/number-field/index.js +6 -5
  217. package/option/definition.cjs +5 -5
  218. package/option/definition.js +1 -1
  219. package/option/index.cjs +1 -1
  220. package/option/index.js +1 -1
  221. package/package.json +4 -4
  222. package/pagination/definition.cjs +5 -5
  223. package/pagination/definition.js +2 -2
  224. package/pagination/index.cjs +1 -1
  225. package/pagination/index.js +1 -1
  226. package/popover/definition.cjs +5 -5
  227. package/popover/definition.js +2 -2
  228. package/popover/index.cjs +4 -4
  229. package/popover/index.js +7 -6
  230. package/popup/definition.cjs +4 -4
  231. package/popup/definition.js +1 -1
  232. package/popup/index.cjs +1 -1
  233. package/popup/index.js +1 -1
  234. package/progress/definition.cjs +1 -1
  235. package/progress/definition.js +1 -1
  236. package/radio/definition.cjs +1 -1
  237. package/radio/definition.js +1 -1
  238. package/radio-group/definition.cjs +5 -5
  239. package/radio-group/definition.js +2 -2
  240. package/radio-group/index.cjs +1 -1
  241. package/radio-group/index.js +1 -1
  242. package/range-slider/definition.cjs +5 -5
  243. package/range-slider/definition.js +2 -2
  244. package/range-slider/index.cjs +1 -1
  245. package/range-slider/index.js +22 -19
  246. package/rich-text-editor/definition.cjs +32 -32
  247. package/rich-text-editor/definition.js +2 -2
  248. package/rich-text-editor/index.cjs +1 -1
  249. package/rich-text-editor/index.js +2 -2
  250. package/rich-text-view/definition.cjs +1 -1
  251. package/rich-text-view/definition.js +1 -1
  252. package/searchable-select/definition.cjs +4 -4
  253. package/searchable-select/definition.js +2 -2
  254. package/searchable-select/index.cjs +6 -4
  255. package/searchable-select/index.js +76 -73
  256. package/select/definition.cjs +5 -5
  257. package/select/definition.js +2 -2
  258. package/select/index.cjs +1 -1
  259. package/select/index.js +1 -1
  260. package/selectable-box/definition.cjs +5 -5
  261. package/selectable-box/definition.js +2 -2
  262. package/selectable-box/index.cjs +1 -1
  263. package/selectable-box/index.js +1 -1
  264. package/shared/icon/utils.d.ts +1 -0
  265. package/shared/localization/Locale.d.ts +2 -0
  266. package/shared/picker-field/mixins/calendar-picker.d.ts +1 -0
  267. package/shared/picker-field/mixins/calendar-picker.template.d.ts +1 -0
  268. package/shared/picker-field/mixins/min-max-calendar-picker.d.ts +1 -0
  269. package/shared/picker-field/mixins/single-date-picker.d.ts +1 -0
  270. package/shared/picker-field/mixins/single-value-picker.d.ts +1 -0
  271. package/shared/picker-field/mixins/time-selection-picker.d.ts +1 -0
  272. package/shared/picker-field/mixins/time-selection-picker.template.d.ts +2 -0
  273. package/shared/picker-field/picker-field.d.ts +2 -0
  274. package/side-drawer/definition.cjs +1 -1
  275. package/side-drawer/definition.js +1 -1
  276. package/simple-color-picker/definition.cjs +5 -5
  277. package/simple-color-picker/definition.js +2 -2
  278. package/simple-color-picker/index.cjs +2 -2
  279. package/simple-color-picker/index.js +6 -5
  280. package/slider/definition.cjs +5 -5
  281. package/slider/definition.js +1 -1
  282. package/slider/index.cjs +1 -1
  283. package/slider/index.js +1 -1
  284. package/split-button/definition.cjs +5 -5
  285. package/split-button/definition.js +2 -2
  286. package/split-button/index.cjs +2 -2
  287. package/split-button/index.js +7 -6
  288. package/status/definition.cjs +5 -5
  289. package/status/definition.js +2 -2
  290. package/status/index.cjs +2 -2
  291. package/status/index.js +5 -4
  292. package/switch/definition.cjs +5 -5
  293. package/switch/definition.js +2 -2
  294. package/switch/index.cjs +2 -2
  295. package/switch/index.js +6 -5
  296. package/tab/definition.cjs +5 -5
  297. package/tab/definition.js +2 -2
  298. package/tab/index.cjs +1 -1
  299. package/tab/index.js +1 -1
  300. package/tab-panel/definition.cjs +1 -1
  301. package/tab-panel/definition.js +1 -1
  302. package/table/definition.cjs +17 -17
  303. package/table/definition.js +2 -2
  304. package/table/index.cjs +3 -3
  305. package/table/index.js +6 -5
  306. package/tabs/definition.cjs +6 -6
  307. package/tabs/definition.js +2 -2
  308. package/tabs/index.cjs +1 -1
  309. package/tabs/index.js +1 -1
  310. package/tag/definition.cjs +5 -5
  311. package/tag/definition.js +2 -2
  312. package/tag/index.cjs +4 -4
  313. package/tag/index.js +6 -5
  314. package/tag-group/definition.cjs +1 -1
  315. package/tag-group/definition.js +1 -1
  316. package/text-area/definition.cjs +5 -5
  317. package/text-area/definition.js +2 -2
  318. package/text-area/index.cjs +1 -1
  319. package/text-area/index.js +1 -1
  320. package/text-field/definition.cjs +5 -5
  321. package/text-field/definition.js +1 -1
  322. package/text-field/index.cjs +1 -1
  323. package/text-field/index.js +1 -1
  324. package/time-picker/definition.cjs +4 -4
  325. package/time-picker/definition.js +2 -2
  326. package/time-picker/index.cjs +1 -1
  327. package/time-picker/index.js +1 -1
  328. package/toggletip/definition.cjs +5 -5
  329. package/toggletip/definition.js +1 -1
  330. package/toggletip/index.cjs +1 -1
  331. package/toggletip/index.js +1 -1
  332. package/tooltip/definition.cjs +5 -5
  333. package/tooltip/definition.js +1 -1
  334. package/tooltip/index.cjs +1 -1
  335. package/tooltip/index.js +1 -1
  336. package/tree-item/definition.cjs +5 -5
  337. package/tree-item/definition.js +2 -2
  338. package/tree-item/index.cjs +1 -1
  339. package/tree-item/index.js +1 -1
  340. package/tree-view/definition.cjs +5 -5
  341. package/tree-view/definition.js +2 -2
  342. package/tree-view/index.cjs +1 -1
  343. package/tree-view/index.js +1 -1
  344. package/unbundled/definition11.cjs +6 -0
  345. package/unbundled/definition11.js +6 -0
  346. package/unbundled/definition14.cjs +1 -0
  347. package/unbundled/definition14.js +1 -0
  348. package/unbundled/definition2.cjs +5 -75
  349. package/unbundled/definition2.js +1 -71
  350. package/unbundled/definition28.cjs +1 -0
  351. package/unbundled/definition28.js +1 -0
  352. package/unbundled/definition31.cjs +2 -1189
  353. package/unbundled/definition31.js +1 -1188
  354. package/unbundled/definition32.cjs +207 -1835
  355. package/unbundled/definition32.js +203 -1807
  356. package/unbundled/definition33.cjs +83 -311
  357. package/unbundled/definition33.js +79 -235
  358. package/unbundled/definition34.cjs +1887 -25
  359. package/unbundled/definition34.js +1857 -24
  360. package/unbundled/definition35.cjs +315 -121
  361. package/unbundled/definition35.js +236 -114
  362. package/unbundled/definition36.cjs +25 -405
  363. package/unbundled/definition36.js +22 -397
  364. package/unbundled/definition37.cjs +47 -142
  365. package/unbundled/definition37.js +44 -139
  366. package/unbundled/definition38.cjs +345 -330
  367. package/unbundled/definition38.js +343 -328
  368. package/unbundled/definition39.cjs +183 -235
  369. package/unbundled/definition39.js +181 -233
  370. package/unbundled/definition40.cjs +377 -47
  371. package/unbundled/definition40.js +372 -42
  372. package/unbundled/definition41.cjs +256 -57
  373. package/unbundled/definition41.js +255 -56
  374. package/unbundled/definition42.cjs +45 -432
  375. package/unbundled/definition42.js +41 -428
  376. package/unbundled/definition43.cjs +63 -49
  377. package/unbundled/definition43.js +61 -47
  378. package/unbundled/definition44.cjs +438 -30
  379. package/unbundled/definition44.js +434 -25
  380. package/unbundled/definition45.cjs +46 -84
  381. package/unbundled/definition45.js +43 -81
  382. package/unbundled/definition46.cjs +29 -54
  383. package/unbundled/definition46.js +24 -50
  384. package/unbundled/definition47.cjs +93 -21
  385. package/unbundled/definition47.js +91 -16
  386. package/unbundled/definition48.cjs +49 -33
  387. package/unbundled/definition48.js +46 -30
  388. package/unbundled/definition49.cjs +22 -347
  389. package/unbundled/definition49.js +16 -344
  390. package/unbundled/definition50.cjs +34 -211
  391. package/unbundled/definition50.js +30 -207
  392. package/unbundled/definition51.cjs +282 -242
  393. package/unbundled/definition51.js +275 -235
  394. package/unbundled/definition52.cjs +211 -51
  395. package/unbundled/definition52.js +209 -48
  396. package/unbundled/definition53.cjs +275 -131
  397. package/unbundled/definition53.js +272 -127
  398. package/unbundled/definition54.cjs +50 -261
  399. package/unbundled/definition54.js +48 -260
  400. package/unbundled/definition55.cjs +126 -443
  401. package/unbundled/definition55.js +123 -441
  402. package/unbundled/definition56.cjs +234 -3596
  403. package/unbundled/definition56.js +229 -3428
  404. package/unbundled/definition57.cjs +407 -728
  405. package/unbundled/definition57.js +405 -726
  406. package/unbundled/definition58.cjs +3618 -106
  407. package/unbundled/definition58.js +3449 -100
  408. package/unbundled/definition59.cjs +624 -868
  409. package/unbundled/definition59.js +619 -863
  410. package/unbundled/definition60.cjs +106 -108
  411. package/unbundled/definition60.js +102 -104
  412. package/unbundled/definition61.cjs +1040 -71
  413. package/unbundled/definition61.js +1035 -65
  414. package/unbundled/definition62.cjs +105 -169
  415. package/unbundled/definition62.js +101 -165
  416. package/unbundled/definition63.cjs +70 -113
  417. package/unbundled/definition63.js +65 -109
  418. package/unbundled/definition64.cjs +181 -53
  419. package/unbundled/definition64.js +178 -50
  420. package/unbundled/definition65.cjs +109 -76
  421. package/unbundled/definition65.js +109 -75
  422. package/unbundled/definition66.cjs +58 -21
  423. package/unbundled/definition66.js +55 -15
  424. package/unbundled/definition67.cjs +81 -74
  425. package/unbundled/definition67.js +79 -73
  426. package/unbundled/definition68.cjs +19 -344
  427. package/unbundled/definition68.js +14 -335
  428. package/unbundled/definition69.cjs +88 -26
  429. package/unbundled/definition69.js +85 -22
  430. package/unbundled/definition7.cjs +18 -3
  431. package/unbundled/definition7.js +18 -3
  432. package/unbundled/definition70.cjs +330 -111
  433. package/unbundled/definition70.js +320 -108
  434. package/unbundled/definition71.cjs +26 -271
  435. package/unbundled/definition71.js +21 -267
  436. package/unbundled/definition72.cjs +134 -27
  437. package/unbundled/definition72.js +125 -25
  438. package/unbundled/definition73.cjs +245 -113
  439. package/unbundled/definition73.js +242 -104
  440. package/unbundled/definition74.cjs +28 -212
  441. package/unbundled/definition74.js +26 -202
  442. package/unbundled/definition75.cjs +117 -479
  443. package/unbundled/definition75.js +109 -475
  444. package/unbundled/definition76.cjs +232 -0
  445. package/unbundled/definition76.js +213 -0
  446. package/unbundled/definition77.cjs +533 -0
  447. package/unbundled/definition77.js +513 -0
  448. package/unbundled/numberConverter.cjs +91 -0
  449. package/unbundled/numberConverter.js +74 -0
  450. package/unbundled/picker-field.template.cjs +2 -0
  451. package/unbundled/picker-field.template.js +2 -0
  452. package/unbundled/utils.cjs +1439 -0
  453. package/unbundled/utils.js +1428 -0
  454. package/unbundled/vivid-element.cjs +1 -1
  455. package/unbundled/vivid-element.js +1 -1
  456. package/video-player/definition.cjs +1 -1
  457. package/video-player/definition.js +1 -1
  458. package/vivid.api.json +513 -0
  459. /package/{lib/icon/icon.placeholder.d.ts → shared/icon/icon-placeholder.d.ts} +0 -0
@@ -1,86 +1,246 @@
1
1
  require("./chunk.cjs");
2
2
  const require_vivid_element = require("./vivid-element.cjs");
3
3
  const require_decorate = require("./decorate.cjs");
4
- const require_delegates_aria = require("./delegates-aria.cjs");
5
- const require_base_progress = require("./base-progress.cjs");
4
+ const require_localized = require("./localized.cjs");
5
+ const require_definition = require("./definition7.cjs");
6
+ const require_enums = require("./enums.cjs");
6
7
  let _microsoft_fast_element = require("@microsoft/fast-element");
7
8
  let _microsoft_fast_web_utilities = require("@microsoft/fast-web-utilities");
8
- //#region src/lib/progress/progress.scss?inline
9
- var progress_default = ".base{outline:none;align-items:center;height:6px;margin:0}.base:not(.connotation-pacific).connotation-cta{--_connotation-color-primary:var(--vvd-progress-cta-primary,var(--vvd-color-cta-500));--_connotation-color-soft:var(--vvd-progress-cta-soft,var(--vvd-color-cta-100))}.base:not(.connotation-pacific).connotation-alert{--_connotation-color-primary:var(--vvd-progress-alert-primary,var(--vvd-color-alert-500));--_connotation-color-soft:var(--vvd-progress-alert-soft,var(--vvd-color-alert-100))}.base:not(.connotation-pacific).connotation-success{--_connotation-color-primary:var(--vvd-progress-success-primary,var(--vvd-color-success-500));--_connotation-color-soft:var(--vvd-progress-success-soft,var(--vvd-color-success-100))}.base:not(.connotation-pacific):not(.connotation-cta,.connotation-alert,.connotation-success){--_connotation-color-primary:var(--vvd-progress-accent-primary,var(--vvd-color-canvas-text));--_connotation-color-soft:var(--vvd-progress-accent-soft,var(--vvd-color-neutral-100))}.base:not(.connotation-pacific){--_appearance-color-text:var(--_connotation-color-contrast);--_appearance-color-fill:var(--_connotation-color-soft);--_appearance-color-outline:transparent}.base.connotation-pacific{--_connotation-color-primary:linear-gradient(to right, var(--vvd-color-information-200), var(--vvd-color-cta-600))}.progress{align-items:center;block-size:100%;inline-size:100%;display:flex;position:relative;overflow:hidden}.base:not(.connotation-pacific) .progress{background-color:var(--_appearance-color-fill)}.base.connotation-pacific .progress{background-color:var(--vvd-color-neutral-100)}.base:not(.shape-sharp) .progress{border-radius:4px}.indeterminate{border-radius:inherit;background-color:var(--_connotation-color-primary);block-size:100%;inline-size:100%;display:flex}.determinate{border-radius:inherit;background-color:var(--_connotation-color-primary);block-size:100%;transition:all .2s ease-in-out}.connotation-pacific .determinate{background-image:var(--_connotation-color-primary)}.reverse .determinate{position:absolute;right:0}.paused .determinate{background:var(--vvd-color-neutral-300)}.indicator-1{inline-size:30%;animation:2s infinite indeterminate-1}.indicator-2{inline-size:60%;animation:2s infinite indeterminate-2}.indicator-1,.indicator-2{background-color:var(--vvd-color-neutral-100);opacity:0;block-size:100%;animation-timing-function:cubic-bezier(.4,0,.6,1);position:absolute}.connotation-pacific .indicator-1,.connotation-pacific .indicator-2{background-image:var(--_connotation-color-primary)}.paused .indicator-1,.paused .indicator-2{background-color:var(--_connotation-color-primary);animation-play-state:paused}.reverse .indicator-1,.reverse .indicator-2{animation-direction:reverse}@keyframes indeterminate-1{0%{opacity:1;transform:translate(-100%)}70%{opacity:1;transform:translate(300%)}70.01%{opacity:0}to{opacity:0;transform:translate(300%)}}@keyframes indeterminate-2{0%{opacity:0;transform:translate(-150%)}29.99%{opacity:0}30%{opacity:1;transform:translate(-150%)}to{opacity:1;transform:translate(166.66%)}}";
9
+ //#region src/lib/pagination/pagination.scss?inline
10
+ var pagination_default = ".control{justify-content:space-between;display:inline-flex}.control:not(.shape-pill){border-radius:4px}.control.shape-pill{border-radius:16px}.buttons-wrapper{column-gap:4px;display:flex}.vwc-pagination-button[size=super-condensed]{--base-size:calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2) - 16))}.vwc-pagination-button[size=condensed]{--base-size:calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2) - 8))}.vwc-pagination-button[size=normal]{--base-size:calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2)))}.vwc-pagination-button::part(button){padding-inline:0}.dots{text-align:center;align-self:center}.dots:not(.size-super-condensed){font:var(--vvd-typography-base-bold)}.dots.size-super-condensed{font:var(--vvd-typography-base-condensed-bold);inline-size:calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2) - 16))}.dots.size-condensed{inline-size:calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2) - 8))}.dots.size-normal{inline-size:calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2)))}";
10
11
  //#endregion
11
- //#region src/lib/progress/progress.ts
12
+ //#region src/lib/pagination/pagination.ts
13
+ var MAX_DIGITS_AND_PLACEHOLDERS = 7;
14
+ var totalConverter = {
15
+ fromView: (value) => parseInt(value, 10),
16
+ toView: (value) => value.toString()
17
+ };
12
18
  /**
13
19
  * @public
14
- * @component progress
20
+ * @component pagination
21
+ * @event {CustomEvent<{selectedIndex: number, total: number, oldIndex: number}>} pagination-change - Fires when the page changes.
22
+ * @vueModel modelValue selectedIndex pagination-change `event.currentTarget.selectedIndex`
23
+ * @testAction clickNext click #nextButton
24
+ * @testAction clickPrev click #prevButton
25
+ * @testAction clickPageIndex clickPaginationPage
26
+ * @testQuery total total
27
+ * @testQuery selectedPage paginationSelectedPage
28
+ * @testRef nextButton shadow .next-button
29
+ * @testRef prevButton shadow .prev-button
15
30
  */
16
- var Progress = class extends require_delegates_aria.DelegatesAria(require_base_progress.BaseProgress) {
17
- constructor(..._args) {
18
- super(..._args);
19
- this.reverse = false;
31
+ var Pagination = class extends require_localized.Localized(require_vivid_element.VividElement) {
32
+ get pagesList() {
33
+ return new Array(this.total < MAX_DIGITS_AND_PLACEHOLDERS ? this.total : MAX_DIGITS_AND_PLACEHOLDERS).fill(0).map((_, i, arr) => {
34
+ if (i === 0) return 1;
35
+ if (i === arr.length - 1) return this.total;
36
+ if (this.selectedIndex !== void 0 && this.total > MAX_DIGITS_AND_PLACEHOLDERS) {
37
+ if (this.selectedIndex < 4) {
38
+ if (i === MAX_DIGITS_AND_PLACEHOLDERS - 2) return "...";
39
+ }
40
+ if (this.selectedIndex >= 4 && this.selectedIndex <= this.total - 5) {
41
+ if (i > 1 && i < MAX_DIGITS_AND_PLACEHOLDERS - 2) return this.selectedIndex + (i - 2);
42
+ /* v8 ignore else -- @preserve */
43
+ if (i === 1 || i === MAX_DIGITS_AND_PLACEHOLDERS - 2) return "...";
44
+ }
45
+ if (this.selectedIndex > this.total - 5) {
46
+ if (i > 1) return this.total - (6 - i);
47
+ /* v8 ignore else -- @preserve */
48
+ if (i === 1) return "...";
49
+ }
50
+ }
51
+ return i + 1;
52
+ });
53
+ }
54
+ constructor() {
55
+ super();
56
+ this.navIcons = false;
57
+ this.total = 0;
58
+ this.selectedIndex = 0;
59
+ this.addEventListener("tabpressed", (e) => {
60
+ const { value: currentLabel, shiftKey } = e.detail;
61
+ const index = this.paginationButtons.findIndex((button) => Number(button.label) === currentLabel);
62
+ const focusDirection = shiftKey ? -1 : 1;
63
+ const newIndex = index + focusDirection;
64
+ if (newIndex < 0) return this.prevButton.focus();
65
+ if (newIndex > this.paginationButtons.length - 1) return this.nextButton.focus();
66
+ this.paginationButtons && this.paginationButtons[index + focusDirection].focus();
67
+ });
68
+ }
69
+ /**
70
+ * @internal
71
+ */
72
+ totalChanged(_, newValue) {
73
+ if (newValue < 0) {
74
+ this.total = 0;
75
+ return;
76
+ }
77
+ this.#constrainSelectedIndex();
78
+ }
79
+ /**
80
+ * @internal
81
+ */
82
+ selectedIndexChanged(oldValue, newValue) {
83
+ if (oldValue === void 0) return;
84
+ this.$emit("pagination-change", {
85
+ selectedIndex: newValue,
86
+ total: this.total,
87
+ oldIndex: oldValue
88
+ });
89
+ this.#constrainSelectedIndex();
90
+ }
91
+ /**
92
+ * @internal
93
+ */
94
+ paginationButtonsChanged(_, newValue) {
95
+ newValue.forEach((button) => {
96
+ button.shadowRoot.querySelector("button").setAttribute("part", "button");
97
+ });
98
+ }
99
+ get #constrainedSelectedIndex() {
100
+ return Math.max(0, Math.min(this.selectedIndex ?? 0, this.total - 1));
101
+ }
102
+ #constrainSelectedIndex() {
103
+ if (this.selectedIndex !== this.#constrainedSelectedIndex) window.queueMicrotask(() => {
104
+ if (this.selectedIndex !== this.#constrainedSelectedIndex) this.selectedIndex = this.#constrainedSelectedIndex;
105
+ });
20
106
  }
21
107
  };
22
- require_decorate.__decorate([(0, _microsoft_fast_element.attr)()], Progress.prototype, "shape", void 0);
23
- require_decorate.__decorate([(0, _microsoft_fast_element.attr)()], Progress.prototype, "connotation", void 0);
24
- require_decorate.__decorate([(0, _microsoft_fast_element.attr)({ mode: "boolean" })], Progress.prototype, "reverse", void 0);
108
+ require_decorate.__decorate([_microsoft_fast_element.attr], Pagination.prototype, "size", void 0);
109
+ require_decorate.__decorate([_microsoft_fast_element.attr], Pagination.prototype, "shape", void 0);
110
+ require_decorate.__decorate([_microsoft_fast_element.observable], Pagination.prototype, "paginationButtons", void 0);
111
+ require_decorate.__decorate([_microsoft_fast_element.observable], Pagination.prototype, "prevButton", void 0);
112
+ require_decorate.__decorate([_microsoft_fast_element.observable], Pagination.prototype, "nextButton", void 0);
113
+ require_decorate.__decorate([(0, _microsoft_fast_element.attr)({
114
+ attribute: "nav-icons",
115
+ mode: "boolean"
116
+ })], Pagination.prototype, "navIcons", void 0);
117
+ require_decorate.__decorate([_microsoft_fast_element.volatile], Pagination.prototype, "pagesList", null);
118
+ require_decorate.__decorate([(0, _microsoft_fast_element.attr)({
119
+ mode: "reflect",
120
+ converter: totalConverter
121
+ })], Pagination.prototype, "total", void 0);
122
+ require_decorate.__decorate([(0, _microsoft_fast_element.attr)({
123
+ mode: "reflect",
124
+ converter: totalConverter,
125
+ attribute: "selected-index"
126
+ })], Pagination.prototype, "selectedIndex", void 0);
25
127
  //#endregion
26
- //#region src/lib/progress/progress.template.ts
27
- var getClasses = ({ connotation, shape, reverse, paused }) => (0, _microsoft_fast_web_utilities.classNames)("base", [`connotation-${connotation}`, Boolean(connotation)], [`shape-${shape}`, Boolean(shape)], ["reverse", Boolean(reverse)], ["paused", Boolean(paused)]);
28
- function determinate() {
29
- return _microsoft_fast_element.html` <span
30
- class="determinate"
31
- style="width: ${(x) => x.percentComplete}%"
32
- ></span>`;
33
- }
34
- function indeterminate() {
35
- return _microsoft_fast_element.html` <span class="indeterminate" name="indeterminate">
36
- <span class="indicator-1"></span>
37
- <span class="indicator-2"></span>
38
- </span>`;
128
+ //#region src/lib/pagination/pagination.template.ts
129
+ var ALLOWED_SIZES = [
130
+ require_enums.Size.SuperCondensed,
131
+ require_enums.Size.Condensed,
132
+ require_enums.Size.Normal
133
+ ];
134
+ var ALLOWED_SHAPES = [require_enums.Shape.Rounded, require_enums.Shape.Pill];
135
+ var handleSelection = (value, { parent: x }) => {
136
+ return x.selectedIndex = Number(value) - 1;
137
+ };
138
+ var handleKeyDown = (value, { event, parent }) => {
139
+ if (event.key === " " || event.key === "Enter") handleSelection(value, { parent });
140
+ if (event.key === "Tab") event.target.dispatchEvent(new CustomEvent("tabpressed", {
141
+ detail: {
142
+ value,
143
+ shiftKey: event.shiftKey
144
+ },
145
+ bubbles: true,
146
+ composed: true
147
+ }));
148
+ };
149
+ var getClasses = (_) => (0, _microsoft_fast_web_utilities.classNames)("control");
150
+ function getButtonAppearance(value, { parent }) {
151
+ return parent.selectedIndex === Number(value) - 1 ? "filled" : "ghost";
39
152
  }
40
- var ProgressTemplate = _microsoft_fast_element.html`<template>
41
- <div
42
- class="${getClasses}"
43
- ${require_delegates_aria.delegateAria({
44
- role: "progressbar",
45
- ariaValueNow: (x) => x.value,
46
- ariaValueMin: (x) => x.min,
47
- ariaValueMax: (x) => x.max
48
- })}
49
- >
50
- <div class="progress">
51
- ${(0, _microsoft_fast_element.when)((x) => typeof x.value === "number", determinate())}
52
- ${(0, _microsoft_fast_element.when)((x) => typeof x.value !== "number", indeterminate())}
153
+ var paginationButtonRenderer = (buttonTag) => _microsoft_fast_element.html` ${(0, _microsoft_fast_element.when)((value) => value !== "...", _microsoft_fast_element.html`
154
+ <${buttonTag} class="vwc-pagination-button"
155
+ label="${(value) => value}"
156
+ appearance="${getButtonAppearance}"
157
+ size="${(_, { parent: x }) => getPaginationSize(x)}"
158
+ shape="${(_, { parent: x }) => getPaginationShape(x)}"
159
+ style="inline-size: ${(value) => getPaginationButtonWidth(value)};"
160
+ tabindex="0"
161
+ aria-label="${(value, { parent: x }) => x.locale.pagination.goToPageLabel(value)}"
162
+ aria-current="${(value, { parent }) => parent.selectedIndex === Number(value) - 1}"
163
+ @click="${handleSelection}"
164
+ @keydown="${handleKeyDown}">
165
+ </${buttonTag}>
166
+ `)}
167
+ ${(0, _microsoft_fast_element.when)((value) => value === "...", _microsoft_fast_element.html` <div
168
+ class="dots size-${(_, { parent: x }) => getPaginationSize(x)}"
169
+ aria-hidden="true"
170
+ >
171
+ ...
172
+ </div>`)}`;
173
+ var getPaginationSize = (x) => {
174
+ if (!x.size || !ALLOWED_SIZES.includes(x.size)) return require_enums.Size.SuperCondensed;
175
+ return x.size;
176
+ };
177
+ var getPaginationShape = (x) => {
178
+ if (!x.shape || !ALLOWED_SHAPES.includes(x.shape)) return require_enums.Shape.Rounded;
179
+ return x.shape;
180
+ };
181
+ var getPaginationButtonWidth = (value) => {
182
+ return `calc(var(--base-size) + ${String(value).length - 1}ch)`;
183
+ };
184
+ var PaginationTemplate = (context) => {
185
+ const buttonTag = context.tagFor(require_definition.Button);
186
+ const buttonTagName = context.tagFor(require_definition.Button, true);
187
+ const paginationButtonTemplate = paginationButtonRenderer(buttonTag);
188
+ return _microsoft_fast_element.html`
189
+ <div class="${getClasses}">
190
+ <${buttonTag} class="prev-button" ${(0, _microsoft_fast_element.ref)("prevButton")}
191
+ label="${(x) => !x.navIcons ? "Previous" : null}"
192
+ icon="${(x) => x.navIcons ? "chevron-left-line" : null}"
193
+ size="${getPaginationSize}"
194
+ shape="${getPaginationShape}"
195
+ ?disabled="${(x) => x.total === 0 || x.selectedIndex === 0}"
196
+ @click="${(x) => x.selectedIndex !== void 0 && x.selectedIndex--}"
197
+ aria-label="${(x) => x.locale.pagination.previousPageLabel}"
198
+ ></${buttonTag}>
199
+ <div id="buttons-wrapper" class="buttons-wrapper" ${(0, _microsoft_fast_element.children)({
200
+ property: "paginationButtons",
201
+ filter: (0, _microsoft_fast_element.elements)(buttonTagName)
202
+ })}>
203
+ ${(0, _microsoft_fast_element.repeat)((x) => x.pagesList, paginationButtonTemplate, { positioning: true })}
53
204
  </div>
54
- </div>
55
- </template>`;
205
+ <${buttonTag} class="next-button" ${(0, _microsoft_fast_element.ref)("nextButton")}
206
+ label="${(x) => !x.navIcons ? "Next" : null}"
207
+ icon="${(x) => x.navIcons ? "chevron-right-line" : null}"
208
+ size="${getPaginationSize}"
209
+ shape="${getPaginationShape}"
210
+ ?disabled="${(x) => x.total === 0 || x.selectedIndex === x.total - 1}"
211
+ @click="${(x) => x.selectedIndex !== void 0 && x.selectedIndex++}"
212
+ aria-label="${(x) => x.locale.pagination.nextPageLabel}"
213
+ ></${buttonTag}>
214
+ </div>`;
215
+ };
56
216
  //#endregion
57
- //#region src/lib/progress/definition.ts
217
+ //#region src/lib/pagination/definition.ts
58
218
  /**
59
219
  * @internal
60
220
  */
61
- var progressDefinition = require_vivid_element.defineVividComponent("progress", Progress, ProgressTemplate, [], { styles: progress_default });
221
+ var paginationDefinition = require_vivid_element.defineVividComponent("pagination", Pagination, PaginationTemplate, [require_definition.buttonDefinition], { styles: pagination_default });
62
222
  /**
63
- * Registers the progress elements with the design system.
223
+ * Registers the pagination element with the design system.
64
224
  *
65
225
  * @param prefix - the prefix to use for the component name
66
226
  */
67
- var registerProgress = require_vivid_element.createRegisterFunction(progressDefinition);
227
+ var registerPagination = require_vivid_element.createRegisterFunction(paginationDefinition);
68
228
  //#endregion
69
- Object.defineProperty(exports, "Progress", {
229
+ Object.defineProperty(exports, "Pagination", {
70
230
  enumerable: true,
71
231
  get: function() {
72
- return Progress;
232
+ return Pagination;
73
233
  }
74
234
  });
75
- Object.defineProperty(exports, "progressDefinition", {
235
+ Object.defineProperty(exports, "paginationDefinition", {
76
236
  enumerable: true,
77
237
  get: function() {
78
- return progressDefinition;
238
+ return paginationDefinition;
79
239
  }
80
240
  });
81
- Object.defineProperty(exports, "registerProgress", {
241
+ Object.defineProperty(exports, "registerPagination", {
82
242
  enumerable: true,
83
243
  get: function() {
84
- return registerProgress;
244
+ return registerPagination;
85
245
  }
86
246
  });
@@ -1,67 +1,228 @@
1
- import { o as defineVividComponent, s as createRegisterFunction } from "./vivid-element.js";
1
+ import { o as defineVividComponent, s as createRegisterFunction, t as VividElement } from "./vivid-element.js";
2
2
  import { t as __decorate } from "./decorate.js";
3
- import { n as delegateAria, t as DelegatesAria } from "./delegates-aria.js";
4
- import { t as BaseProgress } from "./base-progress.js";
5
- import { attr, html, when } from "@microsoft/fast-element";
3
+ import { t as Localized } from "./localized.js";
4
+ import { i as Button, t as buttonDefinition } from "./definition7.js";
5
+ import { d as Size, u as Shape } from "./enums.js";
6
+ import { attr, children, elements, html, observable, ref, repeat, volatile, when } from "@microsoft/fast-element";
6
7
  import { classNames } from "@microsoft/fast-web-utilities";
7
- //#region src/lib/progress/progress.scss?inline
8
- var progress_default = ".base{outline:none;align-items:center;height:6px;margin:0}.base:not(.connotation-pacific).connotation-cta{--_connotation-color-primary:var(--vvd-progress-cta-primary,var(--vvd-color-cta-500));--_connotation-color-soft:var(--vvd-progress-cta-soft,var(--vvd-color-cta-100))}.base:not(.connotation-pacific).connotation-alert{--_connotation-color-primary:var(--vvd-progress-alert-primary,var(--vvd-color-alert-500));--_connotation-color-soft:var(--vvd-progress-alert-soft,var(--vvd-color-alert-100))}.base:not(.connotation-pacific).connotation-success{--_connotation-color-primary:var(--vvd-progress-success-primary,var(--vvd-color-success-500));--_connotation-color-soft:var(--vvd-progress-success-soft,var(--vvd-color-success-100))}.base:not(.connotation-pacific):not(.connotation-cta,.connotation-alert,.connotation-success){--_connotation-color-primary:var(--vvd-progress-accent-primary,var(--vvd-color-canvas-text));--_connotation-color-soft:var(--vvd-progress-accent-soft,var(--vvd-color-neutral-100))}.base:not(.connotation-pacific){--_appearance-color-text:var(--_connotation-color-contrast);--_appearance-color-fill:var(--_connotation-color-soft);--_appearance-color-outline:transparent}.base.connotation-pacific{--_connotation-color-primary:linear-gradient(to right, var(--vvd-color-information-200), var(--vvd-color-cta-600))}.progress{align-items:center;block-size:100%;inline-size:100%;display:flex;position:relative;overflow:hidden}.base:not(.connotation-pacific) .progress{background-color:var(--_appearance-color-fill)}.base.connotation-pacific .progress{background-color:var(--vvd-color-neutral-100)}.base:not(.shape-sharp) .progress{border-radius:4px}.indeterminate{border-radius:inherit;background-color:var(--_connotation-color-primary);block-size:100%;inline-size:100%;display:flex}.determinate{border-radius:inherit;background-color:var(--_connotation-color-primary);block-size:100%;transition:all .2s ease-in-out}.connotation-pacific .determinate{background-image:var(--_connotation-color-primary)}.reverse .determinate{position:absolute;right:0}.paused .determinate{background:var(--vvd-color-neutral-300)}.indicator-1{inline-size:30%;animation:2s infinite indeterminate-1}.indicator-2{inline-size:60%;animation:2s infinite indeterminate-2}.indicator-1,.indicator-2{background-color:var(--vvd-color-neutral-100);opacity:0;block-size:100%;animation-timing-function:cubic-bezier(.4,0,.6,1);position:absolute}.connotation-pacific .indicator-1,.connotation-pacific .indicator-2{background-image:var(--_connotation-color-primary)}.paused .indicator-1,.paused .indicator-2{background-color:var(--_connotation-color-primary);animation-play-state:paused}.reverse .indicator-1,.reverse .indicator-2{animation-direction:reverse}@keyframes indeterminate-1{0%{opacity:1;transform:translate(-100%)}70%{opacity:1;transform:translate(300%)}70.01%{opacity:0}to{opacity:0;transform:translate(300%)}}@keyframes indeterminate-2{0%{opacity:0;transform:translate(-150%)}29.99%{opacity:0}30%{opacity:1;transform:translate(-150%)}to{opacity:1;transform:translate(166.66%)}}";
8
+ //#region src/lib/pagination/pagination.scss?inline
9
+ var pagination_default = ".control{justify-content:space-between;display:inline-flex}.control:not(.shape-pill){border-radius:4px}.control.shape-pill{border-radius:16px}.buttons-wrapper{column-gap:4px;display:flex}.vwc-pagination-button[size=super-condensed]{--base-size:calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2) - 16))}.vwc-pagination-button[size=condensed]{--base-size:calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2) - 8))}.vwc-pagination-button[size=normal]{--base-size:calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2)))}.vwc-pagination-button::part(button){padding-inline:0}.dots{text-align:center;align-self:center}.dots:not(.size-super-condensed){font:var(--vvd-typography-base-bold)}.dots.size-super-condensed{font:var(--vvd-typography-base-condensed-bold);inline-size:calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2) - 16))}.dots.size-condensed{inline-size:calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2) - 8))}.dots.size-normal{inline-size:calc(1px * (40 + 4 * clamp(-1, var(--vvd-size-density,0), 2)))}";
9
10
  //#endregion
10
- //#region src/lib/progress/progress.ts
11
+ //#region src/lib/pagination/pagination.ts
12
+ var MAX_DIGITS_AND_PLACEHOLDERS = 7;
13
+ var totalConverter = {
14
+ fromView: (value) => parseInt(value, 10),
15
+ toView: (value) => value.toString()
16
+ };
11
17
  /**
12
18
  * @public
13
- * @component progress
19
+ * @component pagination
20
+ * @event {CustomEvent<{selectedIndex: number, total: number, oldIndex: number}>} pagination-change - Fires when the page changes.
21
+ * @vueModel modelValue selectedIndex pagination-change `event.currentTarget.selectedIndex`
22
+ * @testAction clickNext click #nextButton
23
+ * @testAction clickPrev click #prevButton
24
+ * @testAction clickPageIndex clickPaginationPage
25
+ * @testQuery total total
26
+ * @testQuery selectedPage paginationSelectedPage
27
+ * @testRef nextButton shadow .next-button
28
+ * @testRef prevButton shadow .prev-button
14
29
  */
15
- var Progress = class extends DelegatesAria(BaseProgress) {
16
- constructor(..._args) {
17
- super(..._args);
18
- this.reverse = false;
30
+ var Pagination = class extends Localized(VividElement) {
31
+ get pagesList() {
32
+ return new Array(this.total < MAX_DIGITS_AND_PLACEHOLDERS ? this.total : MAX_DIGITS_AND_PLACEHOLDERS).fill(0).map((_, i, arr) => {
33
+ if (i === 0) return 1;
34
+ if (i === arr.length - 1) return this.total;
35
+ if (this.selectedIndex !== void 0 && this.total > MAX_DIGITS_AND_PLACEHOLDERS) {
36
+ if (this.selectedIndex < 4) {
37
+ if (i === MAX_DIGITS_AND_PLACEHOLDERS - 2) return "...";
38
+ }
39
+ if (this.selectedIndex >= 4 && this.selectedIndex <= this.total - 5) {
40
+ if (i > 1 && i < MAX_DIGITS_AND_PLACEHOLDERS - 2) return this.selectedIndex + (i - 2);
41
+ /* v8 ignore else -- @preserve */
42
+ if (i === 1 || i === MAX_DIGITS_AND_PLACEHOLDERS - 2) return "...";
43
+ }
44
+ if (this.selectedIndex > this.total - 5) {
45
+ if (i > 1) return this.total - (6 - i);
46
+ /* v8 ignore else -- @preserve */
47
+ if (i === 1) return "...";
48
+ }
49
+ }
50
+ return i + 1;
51
+ });
52
+ }
53
+ constructor() {
54
+ super();
55
+ this.navIcons = false;
56
+ this.total = 0;
57
+ this.selectedIndex = 0;
58
+ this.addEventListener("tabpressed", (e) => {
59
+ const { value: currentLabel, shiftKey } = e.detail;
60
+ const index = this.paginationButtons.findIndex((button) => Number(button.label) === currentLabel);
61
+ const focusDirection = shiftKey ? -1 : 1;
62
+ const newIndex = index + focusDirection;
63
+ if (newIndex < 0) return this.prevButton.focus();
64
+ if (newIndex > this.paginationButtons.length - 1) return this.nextButton.focus();
65
+ this.paginationButtons && this.paginationButtons[index + focusDirection].focus();
66
+ });
67
+ }
68
+ /**
69
+ * @internal
70
+ */
71
+ totalChanged(_, newValue) {
72
+ if (newValue < 0) {
73
+ this.total = 0;
74
+ return;
75
+ }
76
+ this.#constrainSelectedIndex();
77
+ }
78
+ /**
79
+ * @internal
80
+ */
81
+ selectedIndexChanged(oldValue, newValue) {
82
+ if (oldValue === void 0) return;
83
+ this.$emit("pagination-change", {
84
+ selectedIndex: newValue,
85
+ total: this.total,
86
+ oldIndex: oldValue
87
+ });
88
+ this.#constrainSelectedIndex();
89
+ }
90
+ /**
91
+ * @internal
92
+ */
93
+ paginationButtonsChanged(_, newValue) {
94
+ newValue.forEach((button) => {
95
+ button.shadowRoot.querySelector("button").setAttribute("part", "button");
96
+ });
97
+ }
98
+ get #constrainedSelectedIndex() {
99
+ return Math.max(0, Math.min(this.selectedIndex ?? 0, this.total - 1));
100
+ }
101
+ #constrainSelectedIndex() {
102
+ if (this.selectedIndex !== this.#constrainedSelectedIndex) window.queueMicrotask(() => {
103
+ if (this.selectedIndex !== this.#constrainedSelectedIndex) this.selectedIndex = this.#constrainedSelectedIndex;
104
+ });
19
105
  }
20
106
  };
21
- __decorate([attr()], Progress.prototype, "shape", void 0);
22
- __decorate([attr()], Progress.prototype, "connotation", void 0);
23
- __decorate([attr({ mode: "boolean" })], Progress.prototype, "reverse", void 0);
107
+ __decorate([attr], Pagination.prototype, "size", void 0);
108
+ __decorate([attr], Pagination.prototype, "shape", void 0);
109
+ __decorate([observable], Pagination.prototype, "paginationButtons", void 0);
110
+ __decorate([observable], Pagination.prototype, "prevButton", void 0);
111
+ __decorate([observable], Pagination.prototype, "nextButton", void 0);
112
+ __decorate([attr({
113
+ attribute: "nav-icons",
114
+ mode: "boolean"
115
+ })], Pagination.prototype, "navIcons", void 0);
116
+ __decorate([volatile], Pagination.prototype, "pagesList", null);
117
+ __decorate([attr({
118
+ mode: "reflect",
119
+ converter: totalConverter
120
+ })], Pagination.prototype, "total", void 0);
121
+ __decorate([attr({
122
+ mode: "reflect",
123
+ converter: totalConverter,
124
+ attribute: "selected-index"
125
+ })], Pagination.prototype, "selectedIndex", void 0);
24
126
  //#endregion
25
- //#region src/lib/progress/progress.template.ts
26
- var getClasses = ({ connotation, shape, reverse, paused }) => classNames("base", [`connotation-${connotation}`, Boolean(connotation)], [`shape-${shape}`, Boolean(shape)], ["reverse", Boolean(reverse)], ["paused", Boolean(paused)]);
27
- function determinate() {
28
- return html` <span
29
- class="determinate"
30
- style="width: ${(x) => x.percentComplete}%"
31
- ></span>`;
32
- }
33
- function indeterminate() {
34
- return html` <span class="indeterminate" name="indeterminate">
35
- <span class="indicator-1"></span>
36
- <span class="indicator-2"></span>
37
- </span>`;
127
+ //#region src/lib/pagination/pagination.template.ts
128
+ var ALLOWED_SIZES = [
129
+ Size.SuperCondensed,
130
+ Size.Condensed,
131
+ Size.Normal
132
+ ];
133
+ var ALLOWED_SHAPES = [Shape.Rounded, Shape.Pill];
134
+ var handleSelection = (value, { parent: x }) => {
135
+ return x.selectedIndex = Number(value) - 1;
136
+ };
137
+ var handleKeyDown = (value, { event, parent }) => {
138
+ if (event.key === " " || event.key === "Enter") handleSelection(value, { parent });
139
+ if (event.key === "Tab") event.target.dispatchEvent(new CustomEvent("tabpressed", {
140
+ detail: {
141
+ value,
142
+ shiftKey: event.shiftKey
143
+ },
144
+ bubbles: true,
145
+ composed: true
146
+ }));
147
+ };
148
+ var getClasses = (_) => classNames("control");
149
+ function getButtonAppearance(value, { parent }) {
150
+ return parent.selectedIndex === Number(value) - 1 ? "filled" : "ghost";
38
151
  }
152
+ var paginationButtonRenderer = (buttonTag) => html` ${when((value) => value !== "...", html`
153
+ <${buttonTag} class="vwc-pagination-button"
154
+ label="${(value) => value}"
155
+ appearance="${getButtonAppearance}"
156
+ size="${(_, { parent: x }) => getPaginationSize(x)}"
157
+ shape="${(_, { parent: x }) => getPaginationShape(x)}"
158
+ style="inline-size: ${(value) => getPaginationButtonWidth(value)};"
159
+ tabindex="0"
160
+ aria-label="${(value, { parent: x }) => x.locale.pagination.goToPageLabel(value)}"
161
+ aria-current="${(value, { parent }) => parent.selectedIndex === Number(value) - 1}"
162
+ @click="${handleSelection}"
163
+ @keydown="${handleKeyDown}">
164
+ </${buttonTag}>
165
+ `)}
166
+ ${when((value) => value === "...", html` <div
167
+ class="dots size-${(_, { parent: x }) => getPaginationSize(x)}"
168
+ aria-hidden="true"
169
+ >
170
+ ...
171
+ </div>`)}`;
172
+ var getPaginationSize = (x) => {
173
+ if (!x.size || !ALLOWED_SIZES.includes(x.size)) return Size.SuperCondensed;
174
+ return x.size;
175
+ };
176
+ var getPaginationShape = (x) => {
177
+ if (!x.shape || !ALLOWED_SHAPES.includes(x.shape)) return Shape.Rounded;
178
+ return x.shape;
179
+ };
180
+ var getPaginationButtonWidth = (value) => {
181
+ return `calc(var(--base-size) + ${String(value).length - 1}ch)`;
182
+ };
183
+ var PaginationTemplate = (context) => {
184
+ const buttonTag = context.tagFor(Button);
185
+ const buttonTagName = context.tagFor(Button, true);
186
+ const paginationButtonTemplate = paginationButtonRenderer(buttonTag);
187
+ return html`
188
+ <div class="${getClasses}">
189
+ <${buttonTag} class="prev-button" ${ref("prevButton")}
190
+ label="${(x) => !x.navIcons ? "Previous" : null}"
191
+ icon="${(x) => x.navIcons ? "chevron-left-line" : null}"
192
+ size="${getPaginationSize}"
193
+ shape="${getPaginationShape}"
194
+ ?disabled="${(x) => x.total === 0 || x.selectedIndex === 0}"
195
+ @click="${(x) => x.selectedIndex !== void 0 && x.selectedIndex--}"
196
+ aria-label="${(x) => x.locale.pagination.previousPageLabel}"
197
+ ></${buttonTag}>
198
+ <div id="buttons-wrapper" class="buttons-wrapper" ${children({
199
+ property: "paginationButtons",
200
+ filter: elements(buttonTagName)
201
+ })}>
202
+ ${repeat((x) => x.pagesList, paginationButtonTemplate, { positioning: true })}
203
+ </div>
204
+ <${buttonTag} class="next-button" ${ref("nextButton")}
205
+ label="${(x) => !x.navIcons ? "Next" : null}"
206
+ icon="${(x) => x.navIcons ? "chevron-right-line" : null}"
207
+ size="${getPaginationSize}"
208
+ shape="${getPaginationShape}"
209
+ ?disabled="${(x) => x.total === 0 || x.selectedIndex === x.total - 1}"
210
+ @click="${(x) => x.selectedIndex !== void 0 && x.selectedIndex++}"
211
+ aria-label="${(x) => x.locale.pagination.nextPageLabel}"
212
+ ></${buttonTag}>
213
+ </div>`;
214
+ };
39
215
  //#endregion
40
- //#region src/lib/progress/definition.ts
216
+ //#region src/lib/pagination/definition.ts
41
217
  /**
42
218
  * @internal
43
219
  */
44
- var progressDefinition = defineVividComponent("progress", Progress, html`<template>
45
- <div
46
- class="${getClasses}"
47
- ${delegateAria({
48
- role: "progressbar",
49
- ariaValueNow: (x) => x.value,
50
- ariaValueMin: (x) => x.min,
51
- ariaValueMax: (x) => x.max
52
- })}
53
- >
54
- <div class="progress">
55
- ${when((x) => typeof x.value === "number", determinate())}
56
- ${when((x) => typeof x.value !== "number", indeterminate())}
57
- </div>
58
- </div>
59
- </template>`, [], { styles: progress_default });
220
+ var paginationDefinition = defineVividComponent("pagination", Pagination, PaginationTemplate, [buttonDefinition], { styles: pagination_default });
60
221
  /**
61
- * Registers the progress elements with the design system.
222
+ * Registers the pagination element with the design system.
62
223
  *
63
224
  * @param prefix - the prefix to use for the component name
64
225
  */
65
- var registerProgress = createRegisterFunction(progressDefinition);
226
+ var registerPagination = createRegisterFunction(paginationDefinition);
66
227
  //#endregion
67
- export { registerProgress as n, Progress as r, progressDefinition as t };
228
+ export { registerPagination as n, Pagination as r, paginationDefinition as t };