@refinitiv-ui/elements 5.12.0-alpha.0 → 5.12.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 (513) hide show
  1. package/CHANGELOG.md +24 -0
  2. package/README.md +4 -4
  3. package/lib/accordion/index.d.ts +76 -0
  4. package/lib/accordion/index.js +136 -0
  5. package/lib/accordion/themes/halo/dark/index.js +3 -0
  6. package/lib/accordion/themes/halo/light/index.js +3 -0
  7. package/lib/accordion/themes/solar/charcoal/index.js +3 -0
  8. package/lib/accordion/themes/solar/pearl/index.js +3 -0
  9. package/lib/appstate-bar/index.d.ts +65 -0
  10. package/lib/appstate-bar/index.js +100 -0
  11. package/lib/appstate-bar/themes/halo/dark/index.js +3 -0
  12. package/lib/appstate-bar/themes/halo/light/index.js +3 -0
  13. package/lib/appstate-bar/themes/solar/charcoal/index.js +3 -0
  14. package/lib/appstate-bar/themes/solar/pearl/index.js +3 -0
  15. package/lib/autosuggest/helpers/types.d.ts +54 -0
  16. package/lib/autosuggest/helpers/types.js +1 -0
  17. package/lib/autosuggest/helpers/utils.d.ts +39 -0
  18. package/lib/autosuggest/helpers/utils.js +75 -0
  19. package/lib/autosuggest/index.d.ts +538 -0
  20. package/lib/autosuggest/index.js +1255 -0
  21. package/lib/autosuggest/themes/halo/dark/index.js +5 -0
  22. package/lib/autosuggest/themes/halo/light/index.js +5 -0
  23. package/lib/autosuggest/themes/solar/charcoal/index.js +5 -0
  24. package/lib/autosuggest/themes/solar/pearl/index.js +5 -0
  25. package/lib/button/index.d.ts +138 -0
  26. package/lib/button/index.js +241 -0
  27. package/lib/button/themes/halo/dark/index.js +3 -0
  28. package/lib/button/themes/halo/light/index.js +3 -0
  29. package/lib/button/themes/solar/charcoal/index.js +3 -0
  30. package/lib/button/themes/solar/pearl/index.js +3 -0
  31. package/lib/button-bar/index.d.ts +125 -0
  32. package/lib/button-bar/index.js +295 -0
  33. package/lib/button-bar/themes/halo/dark/index.js +3 -0
  34. package/lib/button-bar/themes/halo/light/index.js +3 -0
  35. package/lib/button-bar/themes/solar/charcoal/index.js +3 -0
  36. package/lib/button-bar/themes/solar/pearl/index.js +3 -0
  37. package/lib/calendar/constants.d.ts +26 -0
  38. package/lib/calendar/constants.js +28 -0
  39. package/lib/calendar/index.d.ts +412 -0
  40. package/lib/calendar/index.js +1274 -0
  41. package/lib/calendar/locales.d.ts +1 -0
  42. package/lib/calendar/locales.js +41 -0
  43. package/lib/calendar/themes/halo/dark/index.js +3 -0
  44. package/lib/calendar/themes/halo/light/index.js +3 -0
  45. package/lib/calendar/themes/solar/charcoal/index.js +3 -0
  46. package/lib/calendar/themes/solar/pearl/index.js +3 -0
  47. package/lib/calendar/types.d.ts +32 -0
  48. package/lib/calendar/types.js +1 -0
  49. package/lib/calendar/utils.d.ts +42 -0
  50. package/lib/calendar/utils.js +120 -0
  51. package/lib/canvas/index.d.ts +101 -0
  52. package/lib/canvas/index.js +173 -0
  53. package/lib/canvas/themes/halo/dark/index.js +2 -0
  54. package/lib/canvas/themes/halo/light/index.js +2 -0
  55. package/lib/canvas/themes/solar/charcoal/index.js +2 -0
  56. package/lib/canvas/themes/solar/pearl/index.js +2 -0
  57. package/lib/card/helpers/types.d.ts +12 -0
  58. package/lib/card/helpers/types.js +1 -0
  59. package/lib/card/index.d.ts +142 -0
  60. package/lib/card/index.js +248 -0
  61. package/lib/card/themes/halo/dark/index.js +5 -0
  62. package/lib/card/themes/halo/light/index.js +5 -0
  63. package/lib/card/themes/solar/charcoal/index.js +5 -0
  64. package/lib/card/themes/solar/pearl/index.js +5 -0
  65. package/lib/chart/helpers/index.d.ts +2 -0
  66. package/lib/chart/helpers/index.js +2 -0
  67. package/lib/chart/helpers/legend.d.ts +5 -0
  68. package/lib/chart/helpers/legend.js +78 -0
  69. package/lib/chart/helpers/merge.d.ts +15 -0
  70. package/lib/chart/helpers/merge.js +28 -0
  71. package/lib/chart/helpers/types.d.ts +69 -0
  72. package/lib/chart/helpers/types.js +1 -0
  73. package/lib/chart/index.d.ts +187 -0
  74. package/lib/chart/index.js +491 -0
  75. package/lib/chart/plugins/doughnut-center-label.d.ts +3 -0
  76. package/lib/chart/plugins/doughnut-center-label.js +196 -0
  77. package/lib/chart/themes/halo/dark/index.js +4 -0
  78. package/lib/chart/themes/halo/light/index.js +4 -0
  79. package/lib/chart/themes/solar/charcoal/index.js +4 -0
  80. package/lib/chart/themes/solar/pearl/index.js +4 -0
  81. package/lib/checkbox/index.d.ts +97 -0
  82. package/lib/checkbox/index.js +194 -0
  83. package/lib/checkbox/themes/halo/dark/index.js +4 -0
  84. package/lib/checkbox/themes/halo/light/index.js +4 -0
  85. package/lib/checkbox/themes/solar/charcoal/index.js +4 -0
  86. package/lib/checkbox/themes/solar/pearl/index.js +4 -0
  87. package/lib/clock/index.d.ts +321 -0
  88. package/lib/clock/index.js +583 -0
  89. package/lib/clock/themes/halo/dark/index.js +2 -0
  90. package/lib/clock/themes/halo/light/index.js +2 -0
  91. package/lib/clock/themes/solar/charcoal/index.js +2 -0
  92. package/lib/clock/themes/solar/pearl/index.js +2 -0
  93. package/lib/clock/utils/TickManager.d.ts +14 -0
  94. package/lib/clock/utils/TickManager.js +66 -0
  95. package/lib/clock/utils/timestamps.d.ts +6 -0
  96. package/lib/clock/utils/timestamps.js +6 -0
  97. package/lib/collapse/custom-elements.json +4 -2
  98. package/lib/collapse/custom-elements.md +1 -1
  99. package/lib/collapse/index.d.ts +123 -0
  100. package/lib/collapse/index.js +227 -0
  101. package/lib/collapse/themes/halo/dark/index.js +5 -0
  102. package/lib/collapse/themes/halo/light/index.js +5 -0
  103. package/lib/collapse/themes/solar/charcoal/index.js +5 -0
  104. package/lib/collapse/themes/solar/pearl/index.js +5 -0
  105. package/lib/color-dialog/elements/color-palettes.d.ts +52 -0
  106. package/lib/color-dialog/elements/color-palettes.js +101 -0
  107. package/lib/color-dialog/elements/grayscale-palettes.d.ts +67 -0
  108. package/lib/color-dialog/elements/grayscale-palettes.js +161 -0
  109. package/lib/color-dialog/elements/palettes.d.ts +65 -0
  110. package/lib/color-dialog/elements/palettes.js +132 -0
  111. package/lib/color-dialog/helpers/color-helpers.d.ts +16 -0
  112. package/lib/color-dialog/helpers/color-helpers.js +161 -0
  113. package/lib/color-dialog/helpers/value-model.d.ts +75 -0
  114. package/lib/color-dialog/helpers/value-model.js +141 -0
  115. package/lib/color-dialog/index.d.ts +232 -0
  116. package/lib/color-dialog/index.js +459 -0
  117. package/lib/color-dialog/themes/halo/dark/index.js +7 -0
  118. package/lib/color-dialog/themes/halo/light/index.js +7 -0
  119. package/lib/color-dialog/themes/solar/charcoal/index.js +7 -0
  120. package/lib/color-dialog/themes/solar/pearl/index.js +7 -0
  121. package/lib/combo-box/helpers/filter.d.ts +10 -0
  122. package/lib/combo-box/helpers/filter.js +29 -0
  123. package/lib/combo-box/helpers/keyboard-event.d.ts +17 -0
  124. package/lib/combo-box/helpers/keyboard-event.js +19 -0
  125. package/lib/combo-box/helpers/renderer.d.ts +8 -0
  126. package/lib/combo-box/helpers/renderer.js +24 -0
  127. package/lib/combo-box/helpers/types.d.ts +11 -0
  128. package/lib/combo-box/helpers/types.js +1 -0
  129. package/lib/combo-box/index.d.ts +551 -0
  130. package/lib/combo-box/index.js +1183 -0
  131. package/lib/combo-box/themes/halo/dark/index.js +7 -0
  132. package/lib/combo-box/themes/halo/light/index.js +7 -0
  133. package/lib/combo-box/themes/solar/charcoal/index.js +7 -0
  134. package/lib/combo-box/themes/solar/pearl/index.js +7 -0
  135. package/lib/counter/index.d.ts +91 -0
  136. package/lib/counter/index.js +154 -0
  137. package/lib/counter/themes/halo/dark/index.js +3 -0
  138. package/lib/counter/themes/halo/light/index.js +3 -0
  139. package/lib/counter/themes/solar/charcoal/index.js +3 -0
  140. package/lib/counter/themes/solar/pearl/index.js +3 -0
  141. package/lib/counter/utils.d.ts +13 -0
  142. package/lib/counter/utils.js +52 -0
  143. package/lib/datetime-picker/index.d.ts +509 -0
  144. package/lib/datetime-picker/index.js +1175 -0
  145. package/lib/datetime-picker/locales.d.ts +8 -0
  146. package/lib/datetime-picker/locales.js +57 -0
  147. package/lib/datetime-picker/themes/halo/dark/index.js +7 -0
  148. package/lib/datetime-picker/themes/halo/light/index.js +7 -0
  149. package/lib/datetime-picker/themes/solar/charcoal/index.js +7 -0
  150. package/lib/datetime-picker/themes/solar/pearl/index.js +7 -0
  151. package/lib/datetime-picker/types.d.ts +3 -0
  152. package/lib/datetime-picker/types.js +1 -0
  153. package/lib/datetime-picker/utils.d.ts +55 -0
  154. package/lib/datetime-picker/utils.js +92 -0
  155. package/lib/dialog/custom-elements.json +11 -0
  156. package/lib/dialog/custom-elements.md +4 -3
  157. package/lib/dialog/draggable-element.d.ts +14 -0
  158. package/lib/dialog/draggable-element.js +221 -0
  159. package/lib/dialog/index.d.ts +213 -0
  160. package/lib/dialog/index.js +353 -0
  161. package/lib/dialog/themes/halo/dark/index.js +7 -0
  162. package/lib/dialog/themes/halo/light/index.js +7 -0
  163. package/lib/dialog/themes/solar/charcoal/index.js +7 -0
  164. package/lib/dialog/themes/solar/pearl/index.js +7 -0
  165. package/lib/email-field/index.d.ts +80 -0
  166. package/lib/email-field/index.js +86 -0
  167. package/lib/email-field/themes/halo/dark/index.js +3 -0
  168. package/lib/email-field/themes/halo/light/index.js +3 -0
  169. package/lib/email-field/themes/solar/charcoal/index.js +3 -0
  170. package/lib/email-field/themes/solar/pearl/index.js +3 -0
  171. package/lib/events.d.ts +121 -0
  172. package/lib/events.js +1 -0
  173. package/lib/flag/index.d.ts +96 -0
  174. package/lib/flag/index.js +168 -0
  175. package/lib/flag/themes/halo/dark/index.js +2 -0
  176. package/lib/flag/themes/halo/light/index.js +2 -0
  177. package/lib/flag/themes/solar/charcoal/index.js +2 -0
  178. package/lib/flag/themes/solar/pearl/index.js +2 -0
  179. package/lib/flag/utils/FlagLoader.d.ts +47 -0
  180. package/lib/flag/utils/FlagLoader.js +86 -0
  181. package/lib/header/index.d.ts +46 -0
  182. package/lib/header/index.js +73 -0
  183. package/lib/header/themes/halo/dark/index.js +2 -0
  184. package/lib/header/themes/halo/light/index.js +2 -0
  185. package/lib/header/themes/solar/charcoal/index.js +2 -0
  186. package/lib/header/themes/solar/pearl/index.js +2 -0
  187. package/lib/heatmap/helpers/color.d.ts +30 -0
  188. package/lib/heatmap/helpers/color.js +68 -0
  189. package/lib/heatmap/helpers/text.d.ts +26 -0
  190. package/lib/heatmap/helpers/text.js +91 -0
  191. package/lib/heatmap/helpers/track.d.ts +102 -0
  192. package/lib/heatmap/helpers/track.js +160 -0
  193. package/lib/heatmap/helpers/types.d.ts +40 -0
  194. package/lib/heatmap/helpers/types.js +1 -0
  195. package/lib/heatmap/index.d.ts +453 -0
  196. package/lib/heatmap/index.js +1103 -0
  197. package/lib/heatmap/themes/halo/dark/index.js +4 -0
  198. package/lib/heatmap/themes/halo/light/index.js +4 -0
  199. package/lib/heatmap/themes/solar/charcoal/index.js +4 -0
  200. package/lib/heatmap/themes/solar/pearl/index.js +4 -0
  201. package/lib/icon/index.d.ts +90 -0
  202. package/lib/icon/index.js +171 -0
  203. package/lib/icon/themes/halo/dark/index.js +2 -0
  204. package/lib/icon/themes/halo/light/index.js +2 -0
  205. package/lib/icon/themes/solar/charcoal/index.js +2 -0
  206. package/lib/icon/themes/solar/pearl/index.js +2 -0
  207. package/lib/icon/utils/IconLoader.d.ts +52 -0
  208. package/lib/icon/utils/IconLoader.js +93 -0
  209. package/lib/index.d.ts +3 -0
  210. package/lib/index.js +3 -0
  211. package/lib/interactive-chart/helpers/merge.d.ts +15 -0
  212. package/lib/interactive-chart/helpers/merge.js +28 -0
  213. package/lib/interactive-chart/helpers/types.d.ts +45 -0
  214. package/lib/interactive-chart/helpers/types.js +6 -0
  215. package/lib/interactive-chart/index.d.ts +383 -0
  216. package/lib/interactive-chart/index.js +1093 -0
  217. package/lib/interactive-chart/themes/halo/dark/index.js +3 -0
  218. package/lib/interactive-chart/themes/halo/light/index.js +3 -0
  219. package/lib/interactive-chart/themes/solar/charcoal/index.js +3 -0
  220. package/lib/interactive-chart/themes/solar/pearl/index.js +3 -0
  221. package/lib/item/helpers/types.d.ts +57 -0
  222. package/lib/item/helpers/types.js +1 -0
  223. package/lib/item/index.d.ts +159 -0
  224. package/lib/item/index.js +272 -0
  225. package/lib/item/themes/halo/dark/index.js +4 -0
  226. package/lib/item/themes/halo/light/index.js +4 -0
  227. package/lib/item/themes/solar/charcoal/index.js +4 -0
  228. package/lib/item/themes/solar/pearl/index.js +4 -0
  229. package/lib/label/index.d.ts +102 -0
  230. package/lib/label/index.js +245 -0
  231. package/lib/label/themes/halo/dark/index.js +3 -0
  232. package/lib/label/themes/halo/light/index.js +3 -0
  233. package/lib/label/themes/solar/charcoal/index.js +3 -0
  234. package/lib/label/themes/solar/pearl/index.js +3 -0
  235. package/lib/layout/index.d.ts +107 -0
  236. package/lib/layout/index.js +212 -0
  237. package/lib/layout/themes/halo/dark/index.js +2 -0
  238. package/lib/layout/themes/halo/light/index.js +2 -0
  239. package/lib/layout/themes/solar/charcoal/index.js +2 -0
  240. package/lib/layout/themes/solar/pearl/index.js +2 -0
  241. package/lib/led-gauge/index.d.ts +144 -0
  242. package/lib/led-gauge/index.js +438 -0
  243. package/lib/led-gauge/themes/halo/dark/index.js +3 -0
  244. package/lib/led-gauge/themes/halo/light/index.js +3 -0
  245. package/lib/led-gauge/themes/solar/charcoal/index.js +3 -0
  246. package/lib/led-gauge/themes/solar/pearl/index.js +3 -0
  247. package/lib/list/extensible-function.d.ts +8 -0
  248. package/lib/list/extensible-function.js +13 -0
  249. package/lib/list/helpers/list-renderer.d.ts +9 -0
  250. package/lib/list/helpers/list-renderer.js +37 -0
  251. package/lib/list/helpers/types.d.ts +3 -0
  252. package/lib/list/helpers/types.js +1 -0
  253. package/lib/list/index.d.ts +313 -0
  254. package/lib/list/index.js +640 -0
  255. package/lib/list/renderer.d.ts +36 -0
  256. package/lib/list/renderer.js +9 -0
  257. package/lib/list/themes/halo/dark/index.js +3 -0
  258. package/lib/list/themes/halo/light/index.js +3 -0
  259. package/lib/list/themes/solar/charcoal/index.js +3 -0
  260. package/lib/list/themes/solar/pearl/index.js +3 -0
  261. package/lib/loader/index.d.ts +41 -0
  262. package/lib/loader/index.js +61 -0
  263. package/lib/loader/themes/halo/dark/index.js +2 -0
  264. package/lib/loader/themes/halo/light/index.js +2 -0
  265. package/lib/loader/themes/solar/charcoal/index.js +2 -0
  266. package/lib/loader/themes/solar/pearl/index.js +2 -0
  267. package/lib/multi-input/helpers/types.d.ts +11 -0
  268. package/lib/multi-input/helpers/types.js +1 -0
  269. package/lib/multi-input/index.d.ts +301 -0
  270. package/lib/multi-input/index.js +594 -0
  271. package/lib/multi-input/themes/halo/dark/index.js +4 -0
  272. package/lib/multi-input/themes/halo/light/index.js +4 -0
  273. package/lib/multi-input/themes/solar/charcoal/index.js +4 -0
  274. package/lib/multi-input/themes/solar/pearl/index.js +4 -0
  275. package/lib/notification/elements/notification-tray.d.ts +97 -0
  276. package/lib/notification/elements/notification-tray.js +167 -0
  277. package/lib/notification/elements/notification.d.ts +90 -0
  278. package/lib/notification/elements/notification.js +154 -0
  279. package/lib/notification/helpers/status.d.ts +30 -0
  280. package/lib/notification/helpers/status.js +130 -0
  281. package/lib/notification/helpers/types.d.ts +10 -0
  282. package/lib/notification/helpers/types.js +1 -0
  283. package/lib/notification/index.d.ts +2 -0
  284. package/lib/notification/index.js +2 -0
  285. package/lib/notification/themes/halo/dark/index.js +5 -0
  286. package/lib/notification/themes/halo/light/index.js +5 -0
  287. package/lib/notification/themes/solar/charcoal/index.js +5 -0
  288. package/lib/notification/themes/solar/pearl/index.js +5 -0
  289. package/lib/number-field/index.d.ts +339 -0
  290. package/lib/number-field/index.js +741 -0
  291. package/lib/number-field/themes/halo/dark/index.js +3 -0
  292. package/lib/number-field/themes/halo/light/index.js +3 -0
  293. package/lib/number-field/themes/solar/charcoal/index.js +3 -0
  294. package/lib/number-field/themes/solar/pearl/index.js +3 -0
  295. package/lib/overlay/elements/overlay-backdrop.d.ts +46 -0
  296. package/lib/overlay/elements/overlay-backdrop.js +64 -0
  297. package/lib/overlay/elements/overlay-viewport.d.ts +40 -0
  298. package/lib/overlay/elements/overlay-viewport.js +52 -0
  299. package/lib/overlay/elements/overlay.d.ts +408 -0
  300. package/lib/overlay/elements/overlay.js +1426 -0
  301. package/lib/overlay/helpers/functions.d.ts +13 -0
  302. package/lib/overlay/helpers/functions.js +16 -0
  303. package/lib/overlay/helpers/types.d.ts +97 -0
  304. package/lib/overlay/helpers/types.js +16 -0
  305. package/lib/overlay/index.d.ts +2 -0
  306. package/lib/overlay/index.js +1 -0
  307. package/lib/overlay/managers/backdrop-manager.d.ts +45 -0
  308. package/lib/overlay/managers/backdrop-manager.js +96 -0
  309. package/lib/overlay/managers/close-manager.d.ts +54 -0
  310. package/lib/overlay/managers/close-manager.js +138 -0
  311. package/lib/overlay/managers/focus-manager.d.ts +71 -0
  312. package/lib/overlay/managers/focus-manager.js +228 -0
  313. package/lib/overlay/managers/interaction-lock-manager.d.ts +138 -0
  314. package/lib/overlay/managers/interaction-lock-manager.js +375 -0
  315. package/lib/overlay/managers/viewport-manager.d.ts +93 -0
  316. package/lib/overlay/managers/viewport-manager.js +211 -0
  317. package/lib/overlay/managers/zindex-manager.d.ts +80 -0
  318. package/lib/overlay/managers/zindex-manager.js +195 -0
  319. package/lib/overlay/themes/halo/dark/index.js +4 -0
  320. package/lib/overlay/themes/halo/light/index.js +4 -0
  321. package/lib/overlay/themes/solar/charcoal/index.js +4 -0
  322. package/lib/overlay/themes/solar/pearl/index.js +4 -0
  323. package/lib/overlay-menu/helpers/types.d.ts +8 -0
  324. package/lib/overlay-menu/helpers/types.js +1 -0
  325. package/lib/overlay-menu/index.d.ts +387 -0
  326. package/lib/overlay-menu/index.js +935 -0
  327. package/lib/overlay-menu/managers/menu-manager.d.ts +98 -0
  328. package/lib/overlay-menu/managers/menu-manager.js +240 -0
  329. package/lib/overlay-menu/themes/halo/dark/index.js +5 -0
  330. package/lib/overlay-menu/themes/halo/light/index.js +5 -0
  331. package/lib/overlay-menu/themes/solar/charcoal/index.js +5 -0
  332. package/lib/overlay-menu/themes/solar/pearl/index.js +5 -0
  333. package/lib/pagination/index.d.ts +275 -0
  334. package/lib/pagination/index.js +552 -0
  335. package/lib/pagination/themes/halo/dark/index.js +6 -0
  336. package/lib/pagination/themes/halo/light/index.js +6 -0
  337. package/lib/pagination/themes/solar/charcoal/index.js +6 -0
  338. package/lib/pagination/themes/solar/pearl/index.js +6 -0
  339. package/lib/panel/index.d.ts +48 -0
  340. package/lib/panel/index.js +74 -0
  341. package/lib/panel/themes/halo/dark/index.js +2 -0
  342. package/lib/panel/themes/halo/light/index.js +2 -0
  343. package/lib/panel/themes/solar/charcoal/index.js +2 -0
  344. package/lib/panel/themes/solar/pearl/index.js +2 -0
  345. package/lib/password-field/index.d.ts +89 -0
  346. package/lib/password-field/index.js +112 -0
  347. package/lib/password-field/themes/halo/dark/index.js +3 -0
  348. package/lib/password-field/themes/halo/light/index.js +3 -0
  349. package/lib/password-field/themes/solar/charcoal/index.js +3 -0
  350. package/lib/password-field/themes/solar/pearl/index.js +3 -0
  351. package/lib/pill/index.d.ts +97 -0
  352. package/lib/pill/index.js +160 -0
  353. package/lib/pill/themes/halo/dark/index.js +3 -0
  354. package/lib/pill/themes/halo/light/index.js +3 -0
  355. package/lib/pill/themes/solar/charcoal/index.js +3 -0
  356. package/lib/pill/themes/solar/pearl/index.js +3 -0
  357. package/lib/progress-bar/index.d.ts +82 -0
  358. package/lib/progress-bar/index.js +157 -0
  359. package/lib/progress-bar/themes/halo/dark/index.js +2 -0
  360. package/lib/progress-bar/themes/halo/light/index.js +2 -0
  361. package/lib/progress-bar/themes/solar/charcoal/index.js +2 -0
  362. package/lib/progress-bar/themes/solar/pearl/index.js +2 -0
  363. package/lib/radio-button/index.d.ts +123 -0
  364. package/lib/radio-button/index.js +261 -0
  365. package/lib/radio-button/radio-button-registry.d.ts +22 -0
  366. package/lib/radio-button/radio-button-registry.js +93 -0
  367. package/lib/radio-button/themes/halo/dark/index.js +3 -0
  368. package/lib/radio-button/themes/halo/light/index.js +3 -0
  369. package/lib/radio-button/themes/solar/charcoal/index.js +3 -0
  370. package/lib/radio-button/themes/solar/pearl/index.js +3 -0
  371. package/lib/rating/index.d.ts +91 -0
  372. package/lib/rating/index.js +157 -0
  373. package/lib/rating/themes/halo/dark/index.js +2 -0
  374. package/lib/rating/themes/halo/light/index.js +2 -0
  375. package/lib/rating/themes/solar/charcoal/index.js +2 -0
  376. package/lib/rating/themes/solar/pearl/index.js +2 -0
  377. package/lib/search-field/index.d.ts +77 -0
  378. package/lib/search-field/index.js +84 -0
  379. package/lib/search-field/themes/halo/dark/index.js +3 -0
  380. package/lib/search-field/themes/halo/light/index.js +3 -0
  381. package/lib/search-field/themes/solar/charcoal/index.js +3 -0
  382. package/lib/search-field/themes/solar/pearl/index.js +3 -0
  383. package/lib/select/helpers/types.d.ts +3 -0
  384. package/lib/select/helpers/types.js +1 -0
  385. package/lib/select/index.d.ts +396 -0
  386. package/lib/select/index.js +981 -0
  387. package/lib/select/themes/halo/dark/index.js +5 -0
  388. package/lib/select/themes/halo/light/index.js +5 -0
  389. package/lib/select/themes/solar/charcoal/index.js +5 -0
  390. package/lib/select/themes/solar/pearl/index.js +5 -0
  391. package/lib/sidebar-layout/index.d.ts +70 -0
  392. package/lib/sidebar-layout/index.js +134 -0
  393. package/lib/sidebar-layout/themes/halo/dark/index.js +3 -0
  394. package/lib/sidebar-layout/themes/halo/light/index.js +3 -0
  395. package/lib/sidebar-layout/themes/solar/charcoal/index.js +3 -0
  396. package/lib/sidebar-layout/themes/solar/pearl/index.js +3 -0
  397. package/lib/slider/index.d.ts +409 -0
  398. package/lib/slider/index.js +1197 -0
  399. package/lib/slider/themes/halo/dark/index.js +3 -0
  400. package/lib/slider/themes/halo/light/index.js +3 -0
  401. package/lib/slider/themes/solar/charcoal/index.js +3 -0
  402. package/lib/slider/themes/solar/pearl/index.js +3 -0
  403. package/lib/sparkline/index.d.ts +109 -0
  404. package/lib/sparkline/index.js +188 -0
  405. package/lib/sparkline/themes/halo/dark/index.js +2 -0
  406. package/lib/sparkline/themes/halo/light/index.js +2 -0
  407. package/lib/sparkline/themes/solar/charcoal/index.js +2 -0
  408. package/lib/sparkline/themes/solar/pearl/index.js +2 -0
  409. package/lib/swing-gauge/const.d.ts +22 -0
  410. package/lib/swing-gauge/const.js +26 -0
  411. package/lib/swing-gauge/helpers.d.ts +8 -0
  412. package/lib/swing-gauge/helpers.js +105 -0
  413. package/lib/swing-gauge/index.d.ts +296 -0
  414. package/lib/swing-gauge/index.js +764 -0
  415. package/lib/swing-gauge/themes/halo/dark/index.js +3 -0
  416. package/lib/swing-gauge/themes/halo/light/index.js +3 -0
  417. package/lib/swing-gauge/themes/solar/charcoal/index.js +3 -0
  418. package/lib/swing-gauge/themes/solar/pearl/index.js +3 -0
  419. package/lib/swing-gauge/types.d.ts +34 -0
  420. package/lib/swing-gauge/types.js +1 -0
  421. package/lib/tab/custom-elements.json +13 -0
  422. package/lib/tab/custom-elements.md +1 -0
  423. package/lib/tab/index.d.ts +136 -0
  424. package/lib/tab/index.js +236 -0
  425. package/lib/tab/themes/halo/dark/index.js +4 -0
  426. package/lib/tab/themes/halo/light/index.js +4 -0
  427. package/lib/tab/themes/solar/charcoal/index.js +4 -0
  428. package/lib/tab/themes/solar/pearl/index.js +4 -0
  429. package/lib/tab-bar/custom-elements.json +12 -0
  430. package/lib/tab-bar/custom-elements.md +7 -0
  431. package/lib/tab-bar/helpers/animate.d.ts +16 -0
  432. package/lib/tab-bar/helpers/animate.js +53 -0
  433. package/lib/tab-bar/index.d.ts +198 -0
  434. package/lib/tab-bar/index.js +428 -0
  435. package/lib/tab-bar/themes/halo/dark/index.js +4 -0
  436. package/lib/tab-bar/themes/halo/light/index.js +4 -0
  437. package/lib/tab-bar/themes/solar/charcoal/index.js +4 -0
  438. package/lib/tab-bar/themes/solar/pearl/index.js +4 -0
  439. package/lib/text-field/index.d.ts +151 -0
  440. package/lib/text-field/index.js +260 -0
  441. package/lib/text-field/themes/halo/dark/index.js +3 -0
  442. package/lib/text-field/themes/halo/light/index.js +3 -0
  443. package/lib/text-field/themes/solar/charcoal/index.js +3 -0
  444. package/lib/text-field/themes/solar/pearl/index.js +3 -0
  445. package/lib/time-picker/index.d.ts +412 -0
  446. package/lib/time-picker/index.js +898 -0
  447. package/lib/time-picker/themes/halo/dark/index.js +4 -0
  448. package/lib/time-picker/themes/halo/light/index.js +4 -0
  449. package/lib/time-picker/themes/solar/charcoal/index.js +4 -0
  450. package/lib/time-picker/themes/solar/pearl/index.js +4 -0
  451. package/lib/toggle/index.d.ts +87 -0
  452. package/lib/toggle/index.js +153 -0
  453. package/lib/toggle/themes/halo/dark/index.js +2 -0
  454. package/lib/toggle/themes/halo/light/index.js +2 -0
  455. package/lib/toggle/themes/solar/charcoal/index.js +2 -0
  456. package/lib/toggle/themes/solar/pearl/index.js +2 -0
  457. package/lib/tooltip/elements/title-tooltip.d.ts +1 -0
  458. package/lib/tooltip/elements/title-tooltip.js +18 -0
  459. package/lib/tooltip/elements/tooltip-element.d.ts +21 -0
  460. package/lib/tooltip/elements/tooltip-element.js +54 -0
  461. package/lib/tooltip/helpers/overflow-tooltip.d.ts +9 -0
  462. package/lib/tooltip/helpers/overflow-tooltip.js +19 -0
  463. package/lib/tooltip/helpers/renderer.d.ts +8 -0
  464. package/lib/tooltip/helpers/renderer.js +11 -0
  465. package/lib/tooltip/helpers/types.d.ts +23 -0
  466. package/lib/tooltip/helpers/types.js +1 -0
  467. package/lib/tooltip/index.d.ts +232 -0
  468. package/lib/tooltip/index.js +477 -0
  469. package/lib/tooltip/managers/tooltip-manager.d.ts +15 -0
  470. package/lib/tooltip/managers/tooltip-manager.js +140 -0
  471. package/lib/tooltip/themes/halo/dark/index.js +3 -0
  472. package/lib/tooltip/themes/halo/light/index.js +3 -0
  473. package/lib/tooltip/themes/solar/charcoal/index.js +3 -0
  474. package/lib/tooltip/themes/solar/pearl/index.js +3 -0
  475. package/lib/tornado-chart/elements/tornado-chart.d.ts +78 -0
  476. package/lib/tornado-chart/elements/tornado-chart.js +122 -0
  477. package/lib/tornado-chart/elements/tornado-item.d.ts +110 -0
  478. package/lib/tornado-chart/elements/tornado-item.js +207 -0
  479. package/lib/tornado-chart/index.d.ts +2 -0
  480. package/lib/tornado-chart/index.js +2 -0
  481. package/lib/tornado-chart/themes/halo/dark/index.js +6 -0
  482. package/lib/tornado-chart/themes/halo/light/index.js +6 -0
  483. package/lib/tornado-chart/themes/solar/charcoal/index.js +6 -0
  484. package/lib/tornado-chart/themes/solar/pearl/index.js +6 -0
  485. package/lib/tree/elements/tree-item.d.ts +129 -0
  486. package/lib/tree/elements/tree-item.js +238 -0
  487. package/lib/tree/elements/tree.d.ts +203 -0
  488. package/lib/tree/elements/tree.js +414 -0
  489. package/lib/tree/helpers/filter.d.ts +8 -0
  490. package/lib/tree/helpers/filter.js +33 -0
  491. package/lib/tree/helpers/renderer.d.ts +5 -0
  492. package/lib/tree/helpers/renderer.js +33 -0
  493. package/lib/tree/helpers/types.d.ts +25 -0
  494. package/lib/tree/helpers/types.js +1 -0
  495. package/lib/tree/index.d.ts +4 -0
  496. package/lib/tree/index.js +3 -0
  497. package/lib/tree/managers/tree-manager.d.ts +248 -0
  498. package/lib/tree/managers/tree-manager.js +395 -0
  499. package/lib/tree/themes/halo/dark/index.js +7 -0
  500. package/lib/tree/themes/halo/light/index.js +7 -0
  501. package/lib/tree/themes/solar/charcoal/index.js +7 -0
  502. package/lib/tree/themes/solar/pearl/index.js +7 -0
  503. package/lib/tree-select/helpers/types.d.ts +4 -0
  504. package/lib/tree-select/helpers/types.js +1 -0
  505. package/lib/tree-select/index.d.ts +404 -0
  506. package/lib/tree-select/index.js +891 -0
  507. package/lib/tree-select/themes/halo/dark/index.js +11 -0
  508. package/lib/tree-select/themes/halo/light/index.js +11 -0
  509. package/lib/tree-select/themes/solar/charcoal/index.js +11 -0
  510. package/lib/tree-select/themes/solar/pearl/index.js +11 -0
  511. package/lib/version.d.ts +1 -0
  512. package/lib/version.js +1 -0
  513. package/package.json +293 -24
@@ -0,0 +1,640 @@
1
+ import { __decorate } from "tslib";
2
+ import { ControlElement, css, html, WarningNotice } from '@refinitiv-ui/core';
3
+ import { customElement } from '@refinitiv-ui/core/lib/decorators/custom-element.js';
4
+ import { property } from '@refinitiv-ui/core/lib/decorators/property.js';
5
+ import { VERSION } from '../version.js';
6
+ import { CollectionComposer } from '@refinitiv-ui/utils/lib/collection.js';
7
+ import { ListRenderer } from './helpers/list-renderer.js';
8
+ import '../item/index.js';
9
+ export { ListRenderer };
10
+ /**
11
+ * Key direction
12
+ */
13
+ var Direction;
14
+ (function (Direction) {
15
+ Direction[Direction["UP"] = -1] = "UP";
16
+ Direction[Direction["DOWN"] = 1] = "DOWN";
17
+ })(Direction || (Direction = {}));
18
+ const valueFormatWarning = new WarningNotice('The specified \'values\' format does not conform to the required format.');
19
+ /**
20
+ * Provides listing and immutable selection
21
+ * @fires value-changed - Dispatched when value changes
22
+ */
23
+ let List = class List extends ControlElement {
24
+ constructor() {
25
+ super(...arguments);
26
+ this.defaultRole = 'listbox';
27
+ /**
28
+ * Used to timestamp renders.
29
+ * This enables diff checking against item updates,
30
+ * rendering only items which have updated since the last render cycle.
31
+ */
32
+ this.renderTimestamp = new Map();
33
+ /**
34
+ * Requests an update after a composer modification.
35
+ * @returns Update promise.
36
+ */
37
+ this.modificationUpdate = () => {
38
+ this.requestUpdate();
39
+ };
40
+ /**
41
+ * Item map; used to link element nodes to data items.
42
+ */
43
+ this.itemMap = new Map();
44
+ /**
45
+ * Element map; used to link data items to element nodes.
46
+ */
47
+ this.elementMap = new Map();
48
+ /**
49
+ * Composer used to query and modify item state.
50
+ */
51
+ this.composer = new CollectionComposer([]);
52
+ /**
53
+ * Use default `tabindex` so that items are priority focus targets
54
+ */
55
+ this.defaultTabIndex = null;
56
+ /**
57
+ * Element focus delegation.
58
+ * Set to `false` and relies on native focusing.
59
+ */
60
+ this.delegatesFocus = false;
61
+ /**
62
+ * Renderer used to render list item elements
63
+ * @type {ListRenderer}
64
+ */
65
+ this.renderer = new ListRenderer(this);
66
+ /**
67
+ * Disable selections
68
+ */
69
+ this.stateless = false;
70
+ /**
71
+ * Aria indicating that list supports multiple selection
72
+ */
73
+ this.ariaMultiselectable = 'false';
74
+ /**
75
+ * Allow multiple selections
76
+ */
77
+ this.multiple = false;
78
+ this._data = null;
79
+ }
80
+ /**
81
+ * Element version number
82
+ * @returns version number
83
+ */
84
+ static get version() {
85
+ return VERSION;
86
+ }
87
+ /**
88
+ * The data object, used to render the list.
89
+ * @type {ListData}
90
+ * @default null
91
+ */
92
+ get data() {
93
+ return this._data;
94
+ }
95
+ set data(value) {
96
+ const oldValue = this._data;
97
+ if (oldValue === value) {
98
+ return;
99
+ }
100
+ if (value instanceof CollectionComposer) {
101
+ this.composer = value;
102
+ }
103
+ else if (Array.isArray(value)) {
104
+ this.composer = new CollectionComposer(value);
105
+ }
106
+ else {
107
+ this.composer = new CollectionComposer([]);
108
+ }
109
+ this.composer.on('modification', // Listen for modifications
110
+ this.modificationUpdate // Update the template
111
+ );
112
+ this.clearMaps();
113
+ this._data = value;
114
+ this.requestUpdate('data', oldValue);
115
+ }
116
+ /**
117
+ * Returns the first selected item value.
118
+ * Use `values` when multiple selection mode is enabled.
119
+ * @default -
120
+ */
121
+ get value() {
122
+ return this.values[0] || '';
123
+ }
124
+ set value(value) {
125
+ const oldValue = this.value;
126
+ if (value !== oldValue || this.values.length > 1) {
127
+ this.clearSelection();
128
+ const item = this.queryItemsByPropertyValue('value', value)[0];
129
+ if (item) {
130
+ this.composer.setItemPropertyValue(item, 'selected', true);
131
+ }
132
+ this.requestUpdate('value', oldValue);
133
+ }
134
+ }
135
+ /**
136
+ * Returns a values collection of the currently
137
+ * selected item values
138
+ * @type {string[]}
139
+ * @default []
140
+ * @readonly
141
+ */
142
+ get values() {
143
+ return this.queryItemsByPropertyValue('selected', true)
144
+ .map((item) => this.composer.getItemPropertyValue(item, 'value'));
145
+ }
146
+ set values(values) {
147
+ if (!Array.isArray(values)) {
148
+ valueFormatWarning.show();
149
+ this.values = [];
150
+ }
151
+ else {
152
+ // Clone value arrays
153
+ const newValue = values.slice();
154
+ const oldValue = this.values.slice();
155
+ // Create comparison strings to check for differences
156
+ const newComparison = newValue.sort().toString();
157
+ const oldComparison = oldValue.sort().toString();
158
+ // Should we update the selection state?
159
+ if (newComparison !== oldComparison) {
160
+ this.clearSelection();
161
+ values.some((value) => {
162
+ const matches = this.queryItemsByPropertyValue('value', value);
163
+ matches.forEach((match) => this.composer.setItemPropertyValue(match, 'selected', true));
164
+ return !this.multiple; // Only set the fist value if multiple is not enabled
165
+ });
166
+ this.requestUpdate('values', oldValue);
167
+ }
168
+ }
169
+ }
170
+ /**
171
+ * Selects an item in the list
172
+ * @param item Data Item or Item Element
173
+ * @returns If a selection has been made or not
174
+ */
175
+ selectItem(item) {
176
+ if (!this.stateless) {
177
+ if (item instanceof HTMLElement) {
178
+ item = this.itemFromElement(item);
179
+ }
180
+ if (item && this.multiple) {
181
+ const value = this.composer.getItemPropertyValue(item, 'selected');
182
+ this.composer.setItemPropertyValue(item, 'selected', !value);
183
+ return true;
184
+ }
185
+ if (item && this.composer.getItemPropertyValue(item, 'selected') !== true) {
186
+ this.clearSelection();
187
+ this.composer.setItemPropertyValue(item, 'selected', true);
188
+ return true;
189
+ }
190
+ }
191
+ return false;
192
+ }
193
+ /**
194
+ * Navigate up through the list items
195
+ * @returns {void}
196
+ */
197
+ up() {
198
+ this.highlightItem(this.getNextHighlightItem(Direction.UP), true);
199
+ }
200
+ /**
201
+ * Navigate down through the list items
202
+ * @returns {void}
203
+ */
204
+ down() {
205
+ this.highlightItem(this.getNextHighlightItem(Direction.DOWN), true);
206
+ }
207
+ /**
208
+ * Navigate to first focusable item of the list
209
+ * @returns {void}
210
+ */
211
+ first() {
212
+ const firstItem = this.itemMap.get(this.tabbableElements[0]);
213
+ this.highlightItem(firstItem, true);
214
+ }
215
+ /**
216
+ * Navigate to first focusable item of the list
217
+ * @returns {void}
218
+ */
219
+ last() {
220
+ const lastItem = this.itemMap.get(this.tabbableElements[this.tabbableElements.length - 1]);
221
+ this.highlightItem(lastItem, true);
222
+ }
223
+ /**
224
+ * Proxy for querying the composer
225
+ * @param engine composer querying engine
226
+ * @returns Collection of queried items
227
+ */
228
+ queryItems(engine) {
229
+ return this.composer.queryItems(engine);
230
+ }
231
+ /**
232
+ * Proxy for querying the composer by property and value
233
+ * @param property Property name
234
+ * @param value Property value
235
+ * @returns Collection of queried items
236
+ */
237
+ queryItemsByPropertyValue(property, value) {
238
+ return this.composer.queryItemsByPropertyValue(property, value);
239
+ }
240
+ /**
241
+ * Gets the associated element for the data item provided,
242
+ * if there is one available.
243
+ * @param item Item to map element to
244
+ * @returns Associated element
245
+ */
246
+ elementFromItem(item) {
247
+ return this.elementMap.get(item);
248
+ }
249
+ /**
250
+ * Gets the associated data item for the provided element,
251
+ * if there is one available.
252
+ * @param element Element to map item to
253
+ * @returns Associated date item
254
+ */
255
+ itemFromElement(element) {
256
+ return this.itemMap.get(element);
257
+ }
258
+ /**
259
+ * Tries to find the next focusable element.
260
+ * @param direction Direction to search
261
+ * @param element Starting element
262
+ * @returns Next logical element to focus
263
+ */
264
+ getNextFocusableItem(direction, element = this.activeElement) {
265
+ if (!element) {
266
+ return;
267
+ }
268
+ const children = this.tabbableItems;
269
+ if (children.length > 1) {
270
+ let index = children.indexOf(element) + direction;
271
+ index = index < 0 ? children.length - 1 : index === children.length ? 0 : index;
272
+ return children[index];
273
+ }
274
+ }
275
+ /**
276
+ * Tries to find the next highlight item
277
+ * @param direction Direction to search
278
+ * @returns A data item, if found.
279
+ */
280
+ getNextHighlightItem(direction) {
281
+ const highlightItem = this.queryItemsByPropertyValue('highlighted', true)[0];
282
+ const nextElement = this.getNextFocusableItem(direction) || this.getNextFocusableItem(direction, this.elementFromItem(highlightItem));
283
+ const backupElement = this.tabbableItems[0];
284
+ return nextElement ? this.itemFromElement(nextElement) : backupElement ? this.itemFromElement(backupElement) : undefined;
285
+ }
286
+ /**
287
+ * Clears any highlighted item
288
+ * @returns {void}
289
+ */
290
+ clearHighlighted() {
291
+ this.queryItemsByPropertyValue('highlighted', true)
292
+ .forEach(item => this.composer.setItemPropertyValue(item, 'highlighted', false));
293
+ }
294
+ /**
295
+ * Highlights a single item.
296
+ * Used for navigation.
297
+ * @param item Item to highlight
298
+ * @param scrollToItem Scroll the item into view?
299
+ * @returns {void}
300
+ */
301
+ highlightItem(item, scrollToItem = false) {
302
+ if (item) {
303
+ const elementToFocus = this.elementFromItem(item);
304
+ const focus = this.activeElement && this.activeElement !== elementToFocus;
305
+ this.clearHighlighted();
306
+ this.composer.setItemPropertyValue(item, 'highlighted', true);
307
+ focus && (elementToFocus === null || elementToFocus === void 0 ? void 0 : elementToFocus.focus({ preventScroll: true }));
308
+ scrollToItem && this.scrollToItem(item);
309
+ }
310
+ }
311
+ /**
312
+ * Gets the available tabbable elements
313
+ */
314
+ get tabbableItems() {
315
+ return Array.from(this.children)
316
+ .filter((el) => el.tabIndex >= 0);
317
+ }
318
+ /**
319
+ * Returns the current focused element
320
+ */
321
+ get activeElement() {
322
+ const el = this.getRootNode().activeElement;
323
+ const itemEl = this.findItemElementFromTarget(el);
324
+ if (itemEl && this.tabbableItems.includes(itemEl)) {
325
+ return itemEl;
326
+ }
327
+ return null;
328
+ }
329
+ /**
330
+ * Returns the current focused element
331
+ */
332
+ get highlightElement() {
333
+ const item = this.queryItemsByPropertyValue('highlighted', true)[0];
334
+ return item ? this.elementFromItem(item) || null : null;
335
+ }
336
+ /**
337
+ * Tries to select the current highlighted element
338
+ * @returns {void}
339
+ */
340
+ triggerActiveItem() {
341
+ const el = this.activeElement || this.highlightElement;
342
+ const item = el && this.itemFromElement(el);
343
+ item && this.selectItem(item) && this.fireSelectionUpdate();
344
+ }
345
+ /**
346
+ * Scroll to list item element
347
+ * @param item Data item to scroll to
348
+ * @returns {void}
349
+ */
350
+ scrollToItem(item) {
351
+ const element = this.elementFromItem(item);
352
+ if (element) {
353
+ const min = this.scrollTop;
354
+ const max = this.scrollTop + this.clientHeight - element.offsetHeight;
355
+ const pos = element.offsetTop;
356
+ pos > max ? this.scrollTop = element.offsetTop - this.clientHeight + element.offsetHeight
357
+ : pos < min ? this.scrollTop = element.offsetTop : 0;
358
+ }
359
+ }
360
+ /**
361
+ * Handles key input
362
+ * @param event Key down event object
363
+ * @returns {void}
364
+ */
365
+ onKeyDown(event) {
366
+ switch (event.key) {
367
+ case ' ':
368
+ case 'Spacebar':
369
+ case 'Enter':
370
+ this.triggerActiveItem();
371
+ break;
372
+ case 'Up':
373
+ case 'ArrowUp':
374
+ this.up();
375
+ break;
376
+ case 'Down':
377
+ case 'ArrowDown':
378
+ this.down();
379
+ break;
380
+ case 'Home':
381
+ this.first();
382
+ break;
383
+ case 'End':
384
+ this.last();
385
+ break;
386
+ default:
387
+ return;
388
+ }
389
+ event.preventDefault();
390
+ }
391
+ /**
392
+ * Handle list on tap
393
+ * Typically it will select an item
394
+ * @param event Event to handle
395
+ * @returns {void}
396
+ */
397
+ onTap(event) {
398
+ const el = this.findItemElementFromTarget(event.target);
399
+ const item = el && this.itemFromElement(el);
400
+ if (item) {
401
+ this.clearHighlighted();
402
+ if (this.selectItem(item)) {
403
+ this.highlightItem(item);
404
+ this.fireSelectionUpdate();
405
+ }
406
+ }
407
+ }
408
+ /**
409
+ * Handles mouse move
410
+ * Typically it will highlight an item
411
+ * @param event Event to handle
412
+ * @returns {void}
413
+ */
414
+ onMouse(event) {
415
+ const el = this.findItemElementFromTarget(event.target);
416
+ const item = el ? this.itemFromElement(el) : null;
417
+ if (item && el !== this.highlightElement) {
418
+ if (this.activeElement) {
419
+ // prevent shifting focus to other items
420
+ // on mouse move and just fallback to host
421
+ this.activeElement.focus({ preventScroll: true });
422
+ }
423
+ this.highlightItem(item);
424
+ }
425
+ }
426
+ /**
427
+ * Handles item focus in
428
+ * Typically it will highlight the item
429
+ * @param event Event to handle
430
+ * @returns {void}
431
+ */
432
+ onFocus(event) {
433
+ const el = this.findItemElementFromTarget(event.target);
434
+ const item = el && this.itemFromElement(el);
435
+ if (item) {
436
+ this.highlightItem(item);
437
+ }
438
+ }
439
+ /**
440
+ * Handles item focus out
441
+ * Typically it will remove highlighting
442
+ * @returns {void}
443
+ */
444
+ onBlur() {
445
+ this.clearHighlighted();
446
+ }
447
+ /**
448
+ * Tries to find a known item element,
449
+ * from an event target
450
+ * @param target Event target
451
+ * @returns Found element, if available
452
+ */
453
+ findItemElementFromTarget(target) {
454
+ let el = target;
455
+ while (el) {
456
+ if (this.itemMap.has(el)) {
457
+ break; // known rendered item
458
+ }
459
+ el = el.parentElement;
460
+ }
461
+ return el;
462
+ }
463
+ /**
464
+ * Clears the current selected items
465
+ * @returns {void}
466
+ */
467
+ clearSelection() {
468
+ this.queryItemsByPropertyValue('selected', true)
469
+ .forEach((item) => this.composer.setItemPropertyValue(item, 'selected', false));
470
+ this.requestUpdate();
471
+ }
472
+ /**
473
+ * Queries and returns all renderable items.
474
+ * @returns Collection of renderable items
475
+ */
476
+ get renderItems() {
477
+ return this.queryItems((item, composer) => {
478
+ return composer.getItemPropertyValue(item, 'hidden') !== true;
479
+ });
480
+ }
481
+ /**
482
+ * Proxy for creating list item elements.
483
+ * Allows for a mapping to be created between
484
+ * Data Item and Item Element.
485
+ * @param item Data item context
486
+ * @param recyclableElements Child elements available for reuse
487
+ * @returns List item element
488
+ */
489
+ createListItem(item, recyclableElements) {
490
+ const cachedElement = this.elementFromItem(item);
491
+ const previousTimestamp = this.renderTimestamp.get(item) || NaN;
492
+ if (cachedElement && previousTimestamp > this.composer.getItemTimestamp(item)) {
493
+ return cachedElement; // don't re-render if the item hasn't changed
494
+ }
495
+ if (!cachedElement && recyclableElements.length) {
496
+ // Remove any old ties with the reusable element.
497
+ const recycledElement = recyclableElements.pop();
498
+ const previousItem = this.itemFromElement(recycledElement);
499
+ this.itemMap.delete(recycledElement);
500
+ previousItem && this.elementMap.delete(previousItem);
501
+ this.elementMap.set(item, recycledElement);
502
+ }
503
+ const freshElement = this.renderer(item, this.composer, this.elementFromItem(item));
504
+ if (cachedElement && cachedElement !== freshElement) {
505
+ // Renderer returned a new element, so remove the old link.
506
+ this.itemMap.delete(cachedElement);
507
+ }
508
+ this.itemMap.set(freshElement, item); // Link element to item
509
+ this.elementMap.set(item, freshElement); // Link item to element
510
+ this.renderTimestamp.set(item, performance.now());
511
+ return freshElement;
512
+ }
513
+ /**
514
+ * Clears all item-element and timestamp maps
515
+ * @returns {void}
516
+ */
517
+ clearMaps() {
518
+ this.itemMap.clear();
519
+ this.elementMap.clear();
520
+ this.renderTimestamp.clear();
521
+ }
522
+ /**
523
+ * Fire value changed event
524
+ * @returns {void}
525
+ */
526
+ fireSelectionUpdate() {
527
+ /**
528
+ * @event List#value-changed
529
+ */
530
+ this.notifyPropertyChange('value', this.value);
531
+ }
532
+ /**
533
+ * Calculates what elements can be recycled safely
534
+ * @param renderItems Current items to render
535
+ * @returns Collection of elements to be recycled
536
+ */
537
+ calculateRecyclableElements(renderItems) {
538
+ const result = [];
539
+ for (const element of this.children) {
540
+ const item = this.itemFromElement(element);
541
+ if (item && !renderItems.includes(item)) {
542
+ result.push(element);
543
+ }
544
+ }
545
+ return result;
546
+ }
547
+ /**
548
+ * Renders updates to light DOM
549
+ * @returns {void}
550
+ */
551
+ renderLightDOM() {
552
+ const renderItems = this.renderItems;
553
+ const currentChildren = Array.from(this.children);
554
+ const recyclableElements = this.calculateRecyclableElements(renderItems);
555
+ const renderChildren = renderItems.map((item) => this.createListItem(item, recyclableElements));
556
+ const deletions = currentChildren.filter(element => !renderChildren.includes(element));
557
+ deletions.forEach(element => this.removeChild(element));
558
+ renderChildren.forEach((element, index) => {
559
+ if (this.children.length === index) {
560
+ this.appendChild(element);
561
+ }
562
+ else if (element !== this.children[index]) {
563
+ this.insertBefore(element, this.children[index]);
564
+ }
565
+ });
566
+ }
567
+ firstUpdated(changeProperties) {
568
+ super.firstUpdated(changeProperties);
569
+ this.addEventListener('keydown', this.onKeyDown);
570
+ this.addEventListener('tap', this.onTap);
571
+ this.addEventListener('mousemove', this.onMouse);
572
+ this.addEventListener('mouseleave', this.clearHighlighted);
573
+ this.addEventListener('focusin', this.onFocus);
574
+ this.addEventListener('focusout', this.onBlur);
575
+ }
576
+ update(changeProperties) {
577
+ if (changeProperties.has('multiple')) {
578
+ this.renderTimestamp.clear(); // force render of all items
579
+ }
580
+ return super.update(changeProperties);
581
+ }
582
+ updated(changedProperties) {
583
+ super.updated(changedProperties);
584
+ if (changedProperties.has('multiple')) {
585
+ this.setAttribute('aria-multiselectable', this.multiple ? 'true' : 'false');
586
+ }
587
+ }
588
+ /**
589
+ * A `CSSResultGroup` that will be used
590
+ * to style the host, slotted children
591
+ * and the internal template of the element.
592
+ * @return CSS template
593
+ */
594
+ static get styles() {
595
+ return css `
596
+ :host {
597
+ display: block;
598
+ max-height: 600px;
599
+ overflow-y: auto;
600
+ position: relative; /* required for scrollToItem */
601
+ }
602
+ `;
603
+ }
604
+ /**
605
+ * A `TemplateResult` that will be used
606
+ * to render the updated internal template.
607
+ * @return Render template
608
+ */
609
+ render() {
610
+ this.renderLightDOM();
611
+ return html `<slot></slot>`;
612
+ }
613
+ };
614
+ __decorate([
615
+ property({ type: Function, attribute: false })
616
+ ], List.prototype, "renderer", void 0);
617
+ __decorate([
618
+ property({ type: Boolean })
619
+ ], List.prototype, "stateless", void 0);
620
+ __decorate([
621
+ property({ type: String, reflect: true, attribute: 'aria-multiselectable' })
622
+ ], List.prototype, "ariaMultiselectable", void 0);
623
+ __decorate([
624
+ property({ type: Boolean })
625
+ ], List.prototype, "multiple", void 0);
626
+ __decorate([
627
+ property({ attribute: false })
628
+ ], List.prototype, "data", null);
629
+ __decorate([
630
+ property({ type: String })
631
+ ], List.prototype, "value", null);
632
+ __decorate([
633
+ property({ type: Array, attribute: false })
634
+ ], List.prototype, "values", null);
635
+ List = __decorate([
636
+ customElement('ef-list', {
637
+ alias: 'coral-list'
638
+ })
639
+ ], List);
640
+ export { List };
@@ -0,0 +1,36 @@
1
+ import { ExtensibleFunction } from './extensible-function.js';
2
+ import type { DataItem, CollectionComposer } from '@refinitiv-ui/utils/lib/collection.js';
3
+ /**
4
+ * Render function interface
5
+ * TODO: Move this to @refinitiv-ui/utils
6
+ * ! Do not import this module !
7
+ */
8
+ export interface RenderFunction {
9
+ /**
10
+ * Renders data items into elements
11
+ * @param item Data item context
12
+ * @param composer Composer context
13
+ * @param element Reusable element. This element tries to be the same as was used before.
14
+ * @returns List item element
15
+ */
16
+ (item: DataItem, composer: CollectionComposer, element?: HTMLElement): HTMLElement;
17
+ }
18
+ /**
19
+ * Render constructor interface
20
+ * TODO: Move this to @refinitiv-ui/utils
21
+ * ! Do not import this module !
22
+ */
23
+ export interface RendererConstructor {
24
+ /**
25
+ * @param fn Render function to use as the instance
26
+ */
27
+ new (fn: RenderFunction): RenderFunction;
28
+ }
29
+ /**
30
+ * Renderer base class.
31
+ * Used for creating renderers to render data items.
32
+ * TODO: Move this to @refinitiv-ui/utils
33
+ * ! Do not import this module !
34
+ */
35
+ export declare abstract class Renderer extends ExtensibleFunction {
36
+ }
@@ -0,0 +1,9 @@
1
+ import { ExtensibleFunction } from './extensible-function.js';
2
+ /**
3
+ * Renderer base class.
4
+ * Used for creating renderers to render data items.
5
+ * TODO: Move this to @refinitiv-ui/utils
6
+ * ! Do not import this module !
7
+ */
8
+ export class Renderer extends ExtensibleFunction {
9
+ }