@limetech/lime-elements 36.4.0 → 37.0.0-dev.1

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 (942) hide show
  1. package/dist/cjs/_arrayIncludesWith-29083f83.js +2 -0
  2. package/dist/cjs/_arrayIncludesWith-29083f83.js.map +1 -0
  3. package/dist/cjs/_assignValue-7c18d8d6.js +2 -0
  4. package/dist/cjs/_assignValue-7c18d8d6.js.map +1 -0
  5. package/dist/cjs/_commonjsHelpers-0c557e26.js +2 -0
  6. package/dist/cjs/_commonjsHelpers-0c557e26.js.map +1 -0
  7. package/dist/cjs/_defineProperty-8f56146d.js +2 -0
  8. package/dist/cjs/_defineProperty-8f56146d.js.map +1 -0
  9. package/dist/cjs/_getNative-60328036.js +2 -0
  10. package/dist/cjs/_getNative-60328036.js.map +1 -0
  11. package/dist/cjs/animationframe-e4c1798e.js +2 -0
  12. package/dist/cjs/animationframe-e4c1798e.js.map +1 -0
  13. package/dist/cjs/{checkbox.template-60ed3ee2.js → checkbox.template-234f4813.js} +3 -1
  14. package/dist/cjs/checkbox.template-234f4813.js.map +1 -0
  15. package/dist/cjs/component-66df95e7.js +2 -0
  16. package/dist/cjs/component-66df95e7.js.map +1 -0
  17. package/dist/cjs/component-67144c1c.js +2 -0
  18. package/dist/cjs/component-67144c1c.js.map +1 -0
  19. package/dist/cjs/component-ae3bfacf.js +2 -0
  20. package/dist/cjs/component-ae3bfacf.js.map +1 -0
  21. package/dist/cjs/component-cf490570.js +2 -0
  22. package/dist/cjs/component-cf490570.js.map +1 -0
  23. package/dist/cjs/component-dd795ff0.js +2 -0
  24. package/dist/cjs/component-dd795ff0.js.map +1 -0
  25. package/dist/cjs/config-c6520559.js +2 -0
  26. package/dist/cjs/config-c6520559.js.map +1 -0
  27. package/dist/cjs/device-c5841113.js +2 -0
  28. package/dist/cjs/device-c5841113.js.map +1 -0
  29. package/dist/cjs/dispatch-resize-event-4462d78f.js +2 -0
  30. package/dist/cjs/dispatch-resize-event-4462d78f.js.map +1 -0
  31. package/dist/cjs/dom-eb080f70.js +2 -0
  32. package/dist/cjs/dom-eb080f70.js.map +1 -0
  33. package/dist/cjs/eq-9a943b00.js +2 -0
  34. package/dist/cjs/eq-9a943b00.js.map +1 -0
  35. package/dist/cjs/format-5b928cf3.js +2 -0
  36. package/dist/cjs/format-5b928cf3.js.map +1 -0
  37. package/dist/cjs/identity-6dc34885.js +2 -0
  38. package/dist/cjs/identity-6dc34885.js.map +1 -0
  39. package/dist/cjs/{index-287e25e0.js → index-aafa56ee.js} +209 -23
  40. package/dist/cjs/index-aafa56ee.js.map +1 -0
  41. package/dist/cjs/index.cjs.js +2 -0
  42. package/dist/cjs/index.cjs.js.map +1 -0
  43. package/dist/cjs/isArray-d188a04f.js +2 -0
  44. package/dist/cjs/isArray-d188a04f.js.map +1 -0
  45. package/dist/cjs/isArrayLike-ac53bdac.js +2 -0
  46. package/dist/cjs/isArrayLike-ac53bdac.js.map +1 -0
  47. package/dist/cjs/isEqual-d2a13a24.js +2 -0
  48. package/dist/cjs/isEqual-d2a13a24.js.map +1 -0
  49. package/dist/cjs/isObject-e28b7997.js +2 -0
  50. package/dist/cjs/isObject-e28b7997.js.map +1 -0
  51. package/dist/cjs/isObjectLike-3e3f0cba.js +2 -0
  52. package/dist/cjs/isObjectLike-3e3f0cba.js.map +1 -0
  53. package/dist/cjs/isSymbol-d22b2798.js +2 -0
  54. package/dist/cjs/isSymbol-d22b2798.js.map +1 -0
  55. package/dist/cjs/keyboard-9477d3a8.js +2 -0
  56. package/dist/cjs/keyboard-9477d3a8.js.map +1 -0
  57. package/dist/cjs/keycodes-3949f425.js +2 -0
  58. package/dist/cjs/keycodes-3949f425.js.map +1 -0
  59. package/dist/cjs/lime-elements.cjs.js +12 -3
  60. package/dist/cjs/lime-elements.cjs.js.map +1 -0
  61. package/dist/cjs/limel-action-bar-item_2.cjs.entry.js +3 -1
  62. package/dist/cjs/limel-action-bar-item_2.cjs.entry.js.map +1 -0
  63. package/dist/cjs/limel-action-bar.cjs.entry.js +3 -1
  64. package/dist/cjs/limel-action-bar.cjs.entry.js.map +1 -0
  65. package/dist/cjs/limel-badge.cjs.entry.js +3 -1
  66. package/dist/cjs/limel-badge.cjs.entry.js.map +1 -0
  67. package/dist/cjs/limel-banner.cjs.entry.js +3 -1
  68. package/dist/cjs/limel-banner.cjs.entry.js.map +1 -0
  69. package/dist/cjs/limel-button-group.cjs.entry.js +3 -1
  70. package/dist/cjs/limel-button-group.cjs.entry.js.map +1 -0
  71. package/dist/cjs/limel-button.cjs.entry.js +3 -1
  72. package/dist/cjs/limel-button.cjs.entry.js.map +1 -0
  73. package/dist/cjs/limel-callout.cjs.entry.js +3 -1
  74. package/dist/cjs/limel-callout.cjs.entry.js.map +1 -0
  75. package/dist/cjs/limel-checkbox.cjs.entry.js +4 -2
  76. package/dist/cjs/limel-checkbox.cjs.entry.js.map +1 -0
  77. package/dist/cjs/limel-chip-set.cjs.entry.js +3 -1
  78. package/dist/cjs/limel-chip-set.cjs.entry.js.map +1 -0
  79. package/dist/cjs/limel-circular-progress_2.cjs.entry.js +3 -1
  80. package/dist/cjs/limel-circular-progress_2.cjs.entry.js.map +1 -0
  81. package/dist/cjs/limel-code-editor.cjs.entry.js +3 -1
  82. package/dist/cjs/limel-code-editor.cjs.entry.js.map +1 -0
  83. package/dist/cjs/limel-collapsible-section.cjs.entry.js +3 -1
  84. package/dist/cjs/limel-collapsible-section.cjs.entry.js.map +1 -0
  85. package/dist/cjs/limel-color-picker-palette.cjs.entry.js +3 -1
  86. package/dist/cjs/limel-color-picker-palette.cjs.entry.js.map +1 -0
  87. package/dist/cjs/limel-color-picker.cjs.entry.js +3 -1
  88. package/dist/cjs/limel-color-picker.cjs.entry.js.map +1 -0
  89. package/dist/cjs/limel-config.cjs.entry.js +3 -1
  90. package/dist/cjs/limel-config.cjs.entry.js.map +1 -0
  91. package/dist/cjs/limel-date-picker.cjs.entry.js +3 -1
  92. package/dist/cjs/limel-date-picker.cjs.entry.js.map +1 -0
  93. package/dist/cjs/limel-dialog.cjs.entry.js +3 -1
  94. package/dist/cjs/limel-dialog.cjs.entry.js.map +1 -0
  95. package/dist/cjs/limel-dock-button.cjs.entry.js +3 -1
  96. package/dist/cjs/limel-dock-button.cjs.entry.js.map +1 -0
  97. package/dist/cjs/limel-dock.cjs.entry.js +3 -1
  98. package/dist/cjs/limel-dock.cjs.entry.js.map +1 -0
  99. package/dist/cjs/limel-file.cjs.entry.js +3 -1
  100. package/dist/cjs/limel-file.cjs.entry.js.map +1 -0
  101. package/dist/cjs/limel-flatpickr-adapter.cjs.entry.js +3 -1
  102. package/dist/cjs/limel-flatpickr-adapter.cjs.entry.js.map +1 -0
  103. package/dist/cjs/limel-flex-container.cjs.entry.js +3 -1
  104. package/dist/cjs/limel-flex-container.cjs.entry.js.map +1 -0
  105. package/dist/cjs/limel-form.cjs.entry.js +3 -1
  106. package/dist/cjs/limel-form.cjs.entry.js.map +1 -0
  107. package/dist/cjs/limel-grid.cjs.entry.js +3 -1
  108. package/dist/cjs/limel-grid.cjs.entry.js.map +1 -0
  109. package/dist/cjs/limel-header.cjs.entry.js +3 -1
  110. package/dist/cjs/limel-header.cjs.entry.js.map +1 -0
  111. package/dist/cjs/limel-helper-line.cjs.entry.js +3 -1
  112. package/dist/cjs/limel-helper-line.cjs.entry.js.map +1 -0
  113. package/dist/cjs/limel-icon-button.cjs.entry.js +3 -1
  114. package/dist/cjs/limel-icon-button.cjs.entry.js.map +1 -0
  115. package/dist/cjs/limel-icon.cjs.entry.js +3 -1
  116. package/dist/cjs/limel-icon.cjs.entry.js.map +1 -0
  117. package/dist/cjs/limel-info-tile.cjs.entry.js +3 -1
  118. package/dist/cjs/limel-info-tile.cjs.entry.js.map +1 -0
  119. package/dist/cjs/limel-input-field.cjs.entry.js +3 -1
  120. package/dist/cjs/limel-input-field.cjs.entry.js.map +1 -0
  121. package/dist/cjs/limel-list_2.cjs.entry.js +4 -2
  122. package/dist/cjs/limel-list_2.cjs.entry.js.map +1 -0
  123. package/dist/cjs/limel-menu_2.cjs.entry.js +3 -1
  124. package/dist/cjs/limel-menu_2.cjs.entry.js.map +1 -0
  125. package/dist/cjs/limel-picker.cjs.entry.js +3 -1
  126. package/dist/cjs/limel-picker.cjs.entry.js.map +1 -0
  127. package/dist/cjs/limel-popover_2.cjs.entry.js +3 -1
  128. package/dist/cjs/limel-popover_2.cjs.entry.js.map +1 -0
  129. package/dist/cjs/limel-portal.cjs.entry.js +15 -13
  130. package/dist/cjs/limel-portal.cjs.entry.js.map +1 -0
  131. package/dist/cjs/limel-progress-flow-item.cjs.entry.js +3 -1
  132. package/dist/cjs/limel-progress-flow-item.cjs.entry.js.map +1 -0
  133. package/dist/cjs/limel-progress-flow.cjs.entry.js +3 -1
  134. package/dist/cjs/limel-progress-flow.cjs.entry.js.map +1 -0
  135. package/dist/cjs/limel-select.cjs.entry.js +3 -1
  136. package/dist/cjs/limel-select.cjs.entry.js.map +1 -0
  137. package/dist/cjs/limel-shortcut.cjs.entry.js +3 -1
  138. package/dist/cjs/limel-shortcut.cjs.entry.js.map +1 -0
  139. package/dist/cjs/limel-slider.cjs.entry.js +3 -1
  140. package/dist/cjs/limel-slider.cjs.entry.js.map +1 -0
  141. package/dist/cjs/limel-snackbar.cjs.entry.js +3 -1
  142. package/dist/cjs/limel-snackbar.cjs.entry.js.map +1 -0
  143. package/dist/cjs/limel-spinner.cjs.entry.js +3 -1
  144. package/dist/cjs/limel-spinner.cjs.entry.js.map +1 -0
  145. package/dist/cjs/limel-split-button.cjs.entry.js +3 -1
  146. package/dist/cjs/limel-split-button.cjs.entry.js.map +1 -0
  147. package/dist/cjs/limel-switch.cjs.entry.js +3 -1
  148. package/dist/cjs/limel-switch.cjs.entry.js.map +1 -0
  149. package/dist/cjs/limel-tab-bar.cjs.entry.js +3 -1
  150. package/dist/cjs/limel-tab-bar.cjs.entry.js.map +1 -0
  151. package/dist/cjs/limel-tab-panel.cjs.entry.js +3 -1
  152. package/dist/cjs/limel-tab-panel.cjs.entry.js.map +1 -0
  153. package/dist/cjs/limel-table.cjs.entry.js +3 -1
  154. package/dist/cjs/limel-table.cjs.entry.js.map +1 -0
  155. package/dist/cjs/limel-tooltip_2.cjs.entry.js +3 -1
  156. package/dist/cjs/limel-tooltip_2.cjs.entry.js.map +1 -0
  157. package/dist/cjs/link-helper-4f75d41d.js +2 -0
  158. package/dist/cjs/link-helper-4f75d41d.js.map +1 -0
  159. package/dist/cjs/loader.cjs.js +6 -3
  160. package/dist/cjs/loader.cjs.js.map +1 -0
  161. package/dist/cjs/moment-d1e35cdc.js +2 -0
  162. package/dist/cjs/moment-d1e35cdc.js.map +1 -0
  163. package/dist/cjs/multiple-2af83b6d.js +2 -0
  164. package/dist/cjs/multiple-2af83b6d.js.map +1 -0
  165. package/dist/cjs/pickBy-3ef47bf2.js +2 -0
  166. package/dist/cjs/pickBy-3ef47bf2.js.map +1 -0
  167. package/dist/cjs/ponyfill-98ca4766.js +2 -0
  168. package/dist/cjs/ponyfill-98ca4766.js.map +1 -0
  169. package/dist/cjs/random-string-4c3b7f1c.js +2 -0
  170. package/dist/cjs/random-string-4c3b7f1c.js.map +1 -0
  171. package/dist/cjs/sv-dffe48b5.js +2 -0
  172. package/dist/cjs/sv-dffe48b5.js.map +1 -0
  173. package/dist/cjs/toNumber-062ea29c.js +2 -0
  174. package/dist/cjs/toNumber-062ea29c.js.map +1 -0
  175. package/dist/cjs/translations-f8080c48.js +2 -0
  176. package/dist/cjs/translations-f8080c48.js.map +1 -0
  177. package/dist/cjs/util-b0f5741e.js +2 -0
  178. package/dist/cjs/util-b0f5741e.js.map +1 -0
  179. package/dist/cjs/zipObject-93a471fa.js +2 -0
  180. package/dist/cjs/zipObject-93a471fa.js.map +1 -0
  181. package/dist/collection/collection-manifest.json +2 -2
  182. package/dist/collection/components/action-bar/action-bar-item/action-bar-item.js +1 -0
  183. package/dist/collection/components/action-bar/action-bar-item/action-bar-item.js.map +1 -0
  184. package/dist/collection/components/action-bar/action-bar-item/action-bar-overflow-menu.js +2 -1
  185. package/dist/collection/components/action-bar/action-bar-item/action-bar-overflow-menu.js.map +1 -0
  186. package/dist/collection/components/action-bar/action-bar.js +1 -0
  187. package/dist/collection/components/action-bar/action-bar.js.map +1 -0
  188. package/dist/collection/components/action-bar/action-bar.types.js +1 -0
  189. package/dist/collection/components/action-bar/action-bar.types.js.map +1 -0
  190. package/dist/collection/components/action-bar/isItem.js +1 -0
  191. package/dist/collection/components/action-bar/isItem.js.map +1 -0
  192. package/dist/collection/components/badge/badge.js +1 -0
  193. package/dist/collection/components/badge/badge.js.map +1 -0
  194. package/dist/collection/components/badge/format.js +1 -0
  195. package/dist/collection/components/badge/format.js.map +1 -0
  196. package/dist/collection/components/banner/banner.js +1 -0
  197. package/dist/collection/components/banner/banner.js.map +1 -0
  198. package/dist/collection/components/button/button.js +1 -0
  199. package/dist/collection/components/button/button.js.map +1 -0
  200. package/dist/collection/components/button/button.types.js +1 -0
  201. package/dist/collection/components/button/button.types.js.map +1 -0
  202. package/dist/collection/components/button-group/button-group.js +1 -0
  203. package/dist/collection/components/button-group/button-group.js.map +1 -0
  204. package/dist/collection/components/callout/callout.helpers.js +1 -0
  205. package/dist/collection/components/callout/callout.helpers.js.map +1 -0
  206. package/dist/collection/components/callout/callout.js +3 -2
  207. package/dist/collection/components/callout/callout.js.map +1 -0
  208. package/dist/collection/components/callout/callout.types.js +1 -0
  209. package/dist/collection/components/callout/callout.types.js.map +1 -0
  210. package/dist/collection/components/checkbox/checkbox.js +1 -0
  211. package/dist/collection/components/checkbox/checkbox.js.map +1 -0
  212. package/dist/collection/components/checkbox/checkbox.template.js +1 -0
  213. package/dist/collection/components/checkbox/checkbox.template.js.map +1 -0
  214. package/dist/collection/components/chip-set/chip-set-input-helpers.js +1 -0
  215. package/dist/collection/components/chip-set/chip-set-input-helpers.js.map +1 -0
  216. package/dist/collection/components/chip-set/chip-set.js +6 -5
  217. package/dist/collection/components/chip-set/chip-set.js.map +1 -0
  218. package/dist/collection/components/chip-set/chip.types.js +1 -0
  219. package/dist/collection/components/chip-set/chip.types.js.map +1 -0
  220. package/dist/collection/components/circular-progress/circular-progress.js +1 -0
  221. package/dist/collection/components/circular-progress/circular-progress.js.map +1 -0
  222. package/dist/collection/components/circular-progress/circular-progress.types.js +1 -0
  223. package/dist/collection/components/circular-progress/circular-progress.types.js.map +1 -0
  224. package/dist/collection/components/code-editor/code-editor.js +1 -0
  225. package/dist/collection/components/code-editor/code-editor.js.map +1 -0
  226. package/dist/collection/components/code-editor/code-editor.types.js +1 -0
  227. package/dist/collection/components/code-editor/code-editor.types.js.map +1 -0
  228. package/dist/collection/components/collapsible-section/action.js +1 -0
  229. package/dist/collection/components/collapsible-section/action.js.map +1 -0
  230. package/dist/collection/components/collapsible-section/collapsible-section.js +1 -0
  231. package/dist/collection/components/collapsible-section/collapsible-section.js.map +1 -0
  232. package/dist/collection/components/color-picker/color-picker-palette.js +1 -0
  233. package/dist/collection/components/color-picker/color-picker-palette.js.map +1 -0
  234. package/dist/collection/components/color-picker/color-picker.js +1 -0
  235. package/dist/collection/components/color-picker/color-picker.js.map +1 -0
  236. package/dist/collection/components/color-picker/swatches.js +1 -0
  237. package/dist/collection/components/color-picker/swatches.js.map +1 -0
  238. package/dist/collection/components/config/config.js +1 -0
  239. package/dist/collection/components/config/config.js.map +1 -0
  240. package/dist/collection/components/date-picker/date-picker.js +5 -4
  241. package/dist/collection/components/date-picker/date-picker.js.map +1 -0
  242. package/dist/collection/components/date-picker/date.types.js +1 -0
  243. package/dist/collection/components/date-picker/date.types.js.map +1 -0
  244. package/dist/collection/components/date-picker/dateFormatter.js +1 -0
  245. package/dist/collection/components/date-picker/dateFormatter.js.map +1 -0
  246. package/dist/collection/components/date-picker/flatpickr-adapter/flatpickr-adapter.js +5 -4
  247. package/dist/collection/components/date-picker/flatpickr-adapter/flatpickr-adapter.js.map +1 -0
  248. package/dist/collection/components/date-picker/pickers/DatePicker.js +1 -0
  249. package/dist/collection/components/date-picker/pickers/DatePicker.js.map +1 -0
  250. package/dist/collection/components/date-picker/pickers/DatetimePicker.js +1 -0
  251. package/dist/collection/components/date-picker/pickers/DatetimePicker.js.map +1 -0
  252. package/dist/collection/components/date-picker/pickers/MonthPicker.js +1 -0
  253. package/dist/collection/components/date-picker/pickers/MonthPicker.js.map +1 -0
  254. package/dist/collection/components/date-picker/pickers/Picker.js +1 -0
  255. package/dist/collection/components/date-picker/pickers/Picker.js.map +1 -0
  256. package/dist/collection/components/date-picker/pickers/QuarterPicker.js +1 -0
  257. package/dist/collection/components/date-picker/pickers/QuarterPicker.js.map +1 -0
  258. package/dist/collection/components/date-picker/pickers/TimePicker.js +1 -0
  259. package/dist/collection/components/date-picker/pickers/TimePicker.js.map +1 -0
  260. package/dist/collection/components/date-picker/pickers/WeekPicker.js +1 -0
  261. package/dist/collection/components/date-picker/pickers/WeekPicker.js.map +1 -0
  262. package/dist/collection/components/date-picker/pickers/YearPicker.js +1 -0
  263. package/dist/collection/components/date-picker/pickers/YearPicker.js.map +1 -0
  264. package/dist/collection/components/dialog/dialog.js +6 -3
  265. package/dist/collection/components/dialog/dialog.js.map +1 -0
  266. package/dist/collection/components/dialog/dialog.types.js +1 -0
  267. package/dist/collection/components/dialog/dialog.types.js.map +1 -0
  268. package/dist/collection/components/dock/dock-button/dock-button.js +1 -0
  269. package/dist/collection/components/dock/dock-button/dock-button.js.map +1 -0
  270. package/dist/collection/components/dock/dock.js +1 -0
  271. package/dist/collection/components/dock/dock.js.map +1 -0
  272. package/dist/collection/components/dock/dock.types.js +1 -0
  273. package/dist/collection/components/dock/dock.types.js.map +1 -0
  274. package/dist/collection/components/file/file-metadata.js +1 -0
  275. package/dist/collection/components/file/file-metadata.js.map +1 -0
  276. package/dist/collection/components/file/file.js +7 -4
  277. package/dist/collection/components/file/file.js.map +1 -0
  278. package/dist/collection/components/file/file.types.js +1 -0
  279. package/dist/collection/components/file/file.types.js.map +1 -0
  280. package/dist/collection/components/file/icon-background-colors.js +1 -0
  281. package/dist/collection/components/file/icon-background-colors.js.map +1 -0
  282. package/dist/collection/components/file/icon-fill-colors.js +1 -0
  283. package/dist/collection/components/file/icon-fill-colors.js.map +1 -0
  284. package/dist/collection/components/file/icons.js +1 -0
  285. package/dist/collection/components/file/icons.js.map +1 -0
  286. package/dist/collection/components/flex-container/flex-container.js +7 -6
  287. package/dist/collection/components/flex-container/flex-container.js.map +1 -0
  288. package/dist/collection/components/flex-container/flex-container.types.js +1 -0
  289. package/dist/collection/components/flex-container/flex-container.types.js.map +1 -0
  290. package/dist/collection/components/form/adapters/base-adapter.js +3 -1
  291. package/dist/collection/components/form/adapters/base-adapter.js.map +1 -0
  292. package/dist/collection/components/form/adapters/index.js +1 -0
  293. package/dist/collection/components/form/adapters/index.js.map +1 -0
  294. package/dist/collection/components/form/adapters/widget-adapter.js +1 -0
  295. package/dist/collection/components/form/adapters/widget-adapter.js.map +1 -0
  296. package/dist/collection/components/form/fields/array-field.js +1 -0
  297. package/dist/collection/components/form/fields/array-field.js.map +1 -0
  298. package/dist/collection/components/form/fields/field-helpers.js +1 -0
  299. package/dist/collection/components/form/fields/field-helpers.js.map +1 -0
  300. package/dist/collection/components/form/fields/object-field.js +1 -0
  301. package/dist/collection/components/form/fields/object-field.js.map +1 -0
  302. package/dist/collection/components/form/fields/schema-field.js +1 -0
  303. package/dist/collection/components/form/fields/schema-field.js.map +1 -0
  304. package/dist/collection/components/form/fields/types.js +1 -0
  305. package/dist/collection/components/form/fields/types.js.map +1 -0
  306. package/dist/collection/components/form/form.js +1 -0
  307. package/dist/collection/components/form/form.js.map +1 -0
  308. package/dist/collection/components/form/form.types.js +1 -0
  309. package/dist/collection/components/form/form.types.js.map +1 -0
  310. package/dist/collection/components/form/internal.types.js +1 -0
  311. package/dist/collection/components/form/internal.types.js.map +1 -0
  312. package/dist/collection/components/form/row/row.js +1 -0
  313. package/dist/collection/components/form/row/row.js.map +1 -0
  314. package/dist/collection/components/form/schema.js +1 -0
  315. package/dist/collection/components/form/schema.js.map +1 -0
  316. package/dist/collection/components/form/templates/array-field-collapsible-item.js +1 -0
  317. package/dist/collection/components/form/templates/array-field-collapsible-item.js.map +1 -0
  318. package/dist/collection/components/form/templates/array-field-simple-item.js +1 -0
  319. package/dist/collection/components/form/templates/array-field-simple-item.js.map +1 -0
  320. package/dist/collection/components/form/templates/array-field.js +1 -0
  321. package/dist/collection/components/form/templates/array-field.js.map +1 -0
  322. package/dist/collection/components/form/templates/common.js +1 -0
  323. package/dist/collection/components/form/templates/common.js.map +1 -0
  324. package/dist/collection/components/form/templates/field.js +1 -0
  325. package/dist/collection/components/form/templates/field.js.map +1 -0
  326. package/dist/collection/components/form/templates/grid-layout.js +1 -0
  327. package/dist/collection/components/form/templates/grid-layout.js.map +1 -0
  328. package/dist/collection/components/form/templates/index.js +1 -0
  329. package/dist/collection/components/form/templates/index.js.map +1 -0
  330. package/dist/collection/components/form/templates/object-field.js +1 -0
  331. package/dist/collection/components/form/templates/object-field.js.map +1 -0
  332. package/dist/collection/components/form/templates/row-layout.js +1 -0
  333. package/dist/collection/components/form/templates/row-layout.js.map +1 -0
  334. package/dist/collection/components/form/templates/types.js +1 -0
  335. package/dist/collection/components/form/templates/types.js.map +1 -0
  336. package/dist/collection/components/form/validators/format.js +1 -0
  337. package/dist/collection/components/form/validators/format.js.map +1 -0
  338. package/dist/collection/components/form/validators/index.js +1 -0
  339. package/dist/collection/components/form/validators/index.js.map +1 -0
  340. package/dist/collection/components/form/widgets/checkbox.js +1 -0
  341. package/dist/collection/components/form/widgets/checkbox.js.map +1 -0
  342. package/dist/collection/components/form/widgets/code-editor.js +1 -0
  343. package/dist/collection/components/form/widgets/code-editor.js.map +1 -0
  344. package/dist/collection/components/form/widgets/date-picker.js +1 -0
  345. package/dist/collection/components/form/widgets/date-picker.js.map +1 -0
  346. package/dist/collection/components/form/widgets/index.js +1 -0
  347. package/dist/collection/components/form/widgets/index.js.map +1 -0
  348. package/dist/collection/components/form/widgets/input-field.js +1 -0
  349. package/dist/collection/components/form/widgets/input-field.js.map +1 -0
  350. package/dist/collection/components/form/widgets/select.js +1 -0
  351. package/dist/collection/components/form/widgets/select.js.map +1 -0
  352. package/dist/collection/components/form/widgets/slider.js +1 -0
  353. package/dist/collection/components/form/widgets/slider.js.map +1 -0
  354. package/dist/collection/components/form/widgets/types.js +1 -0
  355. package/dist/collection/components/form/widgets/types.js.map +1 -0
  356. package/dist/collection/components/grid/grid.js +1 -0
  357. package/dist/collection/components/grid/grid.js.map +1 -0
  358. package/dist/collection/components/header/header.js +1 -0
  359. package/dist/collection/components/header/header.js.map +1 -0
  360. package/dist/collection/components/helper-line/helper-line.js +1 -0
  361. package/dist/collection/components/helper-line/helper-line.js.map +1 -0
  362. package/dist/collection/components/icon/icon.js +1 -0
  363. package/dist/collection/components/icon/icon.js.map +1 -0
  364. package/dist/collection/components/icon/icon.types.js +1 -0
  365. package/dist/collection/components/icon/icon.types.js.map +1 -0
  366. package/dist/collection/components/icon-button/icon-button.js +1 -0
  367. package/dist/collection/components/icon-button/icon-button.js.map +1 -0
  368. package/dist/collection/components/info-tile/info-tile.js +5 -2
  369. package/dist/collection/components/info-tile/info-tile.js.map +1 -0
  370. package/dist/collection/components/info-tile/info-tile.types.js +1 -0
  371. package/dist/collection/components/info-tile/info-tile.types.js.map +1 -0
  372. package/dist/collection/components/input-field/input-field.js +1 -0
  373. package/dist/collection/components/input-field/input-field.js.map +1 -0
  374. package/dist/collection/components/input-field/input-field.types.js +1 -0
  375. package/dist/collection/components/input-field/input-field.types.js.map +1 -0
  376. package/dist/collection/components/linear-progress/linear-progress.js +1 -0
  377. package/dist/collection/components/linear-progress/linear-progress.js.map +1 -0
  378. package/dist/collection/components/list/list-item.types.js +1 -0
  379. package/dist/collection/components/list/list-item.types.js.map +1 -0
  380. package/dist/collection/components/list/list-renderer-config.js +1 -0
  381. package/dist/collection/components/list/list-renderer-config.js.map +1 -0
  382. package/dist/collection/components/list/list-renderer.js +1 -0
  383. package/dist/collection/components/list/list-renderer.js.map +1 -0
  384. package/dist/collection/components/list/list.js +6 -5
  385. package/dist/collection/components/list/list.js.map +1 -0
  386. package/dist/collection/components/list/list.types.js +1 -0
  387. package/dist/collection/components/list/list.types.js.map +1 -0
  388. package/dist/collection/components/list/radio-button/radio-button.template.js +1 -0
  389. package/dist/collection/components/list/radio-button/radio-button.template.js.map +1 -0
  390. package/dist/collection/components/menu/menu.js +3 -2
  391. package/dist/collection/components/menu/menu.js.map +1 -0
  392. package/dist/collection/components/menu/menu.types.js +1 -0
  393. package/dist/collection/components/menu/menu.types.js.map +1 -0
  394. package/dist/collection/components/menu-list/menu-list-renderer-config.js +1 -0
  395. package/dist/collection/components/menu-list/menu-list-renderer-config.js.map +1 -0
  396. package/dist/collection/components/menu-list/menu-list-renderer.js +1 -0
  397. package/dist/collection/components/menu-list/menu-list-renderer.js.map +1 -0
  398. package/dist/collection/components/menu-list/menu-list.js +5 -4
  399. package/dist/collection/components/menu-list/menu-list.js.map +1 -0
  400. package/dist/collection/components/menu-list/menu-list.types.js +1 -0
  401. package/dist/collection/components/menu-list/menu-list.types.js.map +1 -0
  402. package/dist/collection/components/menu-surface/menu-surface.js +1 -0
  403. package/dist/collection/components/menu-surface/menu-surface.js.map +1 -0
  404. package/dist/collection/components/picker/actions.types.js +1 -0
  405. package/dist/collection/components/picker/actions.types.js.map +1 -0
  406. package/dist/collection/components/picker/picker.js +12 -7
  407. package/dist/collection/components/picker/picker.js.map +1 -0
  408. package/dist/collection/components/picker/searcher.types.js +1 -0
  409. package/dist/collection/components/picker/searcher.types.js.map +1 -0
  410. package/dist/collection/components/popover/popover.js +1 -0
  411. package/dist/collection/components/popover/popover.js.map +1 -0
  412. package/dist/collection/components/popover-surface/popover-surface.js +1 -0
  413. package/dist/collection/components/popover-surface/popover-surface.js.map +1 -0
  414. package/dist/collection/components/portal/contains.js +1 -0
  415. package/dist/collection/components/portal/contains.js.map +1 -0
  416. package/dist/collection/components/portal/portal.js +12 -11
  417. package/dist/collection/components/portal/portal.js.map +1 -0
  418. package/dist/collection/components/progress-flow/progress-flow-item/progress-flow-item.js +1 -0
  419. package/dist/collection/components/progress-flow/progress-flow-item/progress-flow-item.js.map +1 -0
  420. package/dist/collection/components/progress-flow/progress-flow.js +1 -0
  421. package/dist/collection/components/progress-flow/progress-flow.js.map +1 -0
  422. package/dist/collection/components/progress-flow/progress-flow.types.js +1 -0
  423. package/dist/collection/components/progress-flow/progress-flow.types.js.map +1 -0
  424. package/dist/collection/components/select/option.types.js +1 -0
  425. package/dist/collection/components/select/option.types.js.map +1 -0
  426. package/dist/collection/components/select/select.js +8 -5
  427. package/dist/collection/components/select/select.js.map +1 -0
  428. package/dist/collection/components/select/select.template.js +1 -0
  429. package/dist/collection/components/select/select.template.js.map +1 -0
  430. package/dist/collection/components/shortcut/shortcut.js +5 -2
  431. package/dist/collection/components/shortcut/shortcut.js.map +1 -0
  432. package/dist/collection/components/slider/getPercentageClass.js +1 -0
  433. package/dist/collection/components/slider/getPercentageClass.js.map +1 -0
  434. package/dist/collection/components/slider/slider.js +1 -0
  435. package/dist/collection/components/slider/slider.js.map +1 -0
  436. package/dist/collection/components/snackbar/snackbar.js +3 -2
  437. package/dist/collection/components/snackbar/snackbar.js.map +1 -0
  438. package/dist/collection/components/spinner/spinner.js +3 -2
  439. package/dist/collection/components/spinner/spinner.js.map +1 -0
  440. package/dist/collection/components/spinner/spinner.types.js +1 -0
  441. package/dist/collection/components/spinner/spinner.types.js.map +1 -0
  442. package/dist/collection/components/split-button/split-button.js +3 -2
  443. package/dist/collection/components/split-button/split-button.js.map +1 -0
  444. package/dist/collection/components/switch/switch.js +1 -0
  445. package/dist/collection/components/switch/switch.js.map +1 -0
  446. package/dist/collection/components/tab-bar/tab-bar.js +1 -0
  447. package/dist/collection/components/tab-bar/tab-bar.js.map +1 -0
  448. package/dist/collection/components/tab-bar/tab.types.js +1 -0
  449. package/dist/collection/components/tab-bar/tab.types.js.map +1 -0
  450. package/dist/collection/components/tab-bar/tabs.js +1 -0
  451. package/dist/collection/components/tab-bar/tabs.js.map +1 -0
  452. package/dist/collection/components/tab-panel/tab-panel.js +1 -0
  453. package/dist/collection/components/tab-panel/tab-panel.js.map +1 -0
  454. package/dist/collection/components/tab-panel/tab-panel.types.js +1 -0
  455. package/dist/collection/components/tab-panel/tab-panel.types.js.map +1 -0
  456. package/dist/collection/components/table/columns.js +1 -0
  457. package/dist/collection/components/table/columns.js.map +1 -0
  458. package/dist/collection/components/table/element-pool.js +1 -0
  459. package/dist/collection/components/table/element-pool.js.map +1 -0
  460. package/dist/collection/components/table/layout.js +1 -0
  461. package/dist/collection/components/table/layout.js.map +1 -0
  462. package/dist/collection/components/table/selection.js +1 -0
  463. package/dist/collection/components/table/selection.js.map +1 -0
  464. package/dist/collection/components/table/table-selection.js +1 -0
  465. package/dist/collection/components/table/table-selection.js.map +1 -0
  466. package/dist/collection/components/table/table.js +1 -0
  467. package/dist/collection/components/table/table.js.map +1 -0
  468. package/dist/collection/components/table/table.types.js +1 -0
  469. package/dist/collection/components/table/table.types.js.map +1 -0
  470. package/dist/collection/components/tooltip/tooltip-content.js +1 -0
  471. package/dist/collection/components/tooltip/tooltip-content.js.map +1 -0
  472. package/dist/collection/components/tooltip/tooltip.js +1 -0
  473. package/dist/collection/components/tooltip/tooltip.js.map +1 -0
  474. package/dist/collection/global/config.js +1 -0
  475. package/dist/collection/global/config.js.map +1 -0
  476. package/dist/collection/global/icon-cache.js +1 -0
  477. package/dist/collection/global/icon-cache.js.map +1 -0
  478. package/dist/collection/global/shared-types/link.types.js +1 -0
  479. package/dist/collection/global/shared-types/link.types.js.map +1 -0
  480. package/dist/collection/global/translations.js +1 -0
  481. package/dist/collection/global/translations.js.map +1 -0
  482. package/dist/collection/index.js +1 -0
  483. package/dist/collection/index.js.map +1 -0
  484. package/dist/collection/translations/da.js +1 -0
  485. package/dist/collection/translations/da.js.map +1 -0
  486. package/dist/collection/translations/en.js +1 -0
  487. package/dist/collection/translations/en.js.map +1 -0
  488. package/dist/collection/translations/fi.js +1 -0
  489. package/dist/collection/translations/fi.js.map +1 -0
  490. package/dist/collection/translations/nl.js +1 -0
  491. package/dist/collection/translations/nl.js.map +1 -0
  492. package/dist/collection/translations/no.js +1 -0
  493. package/dist/collection/translations/no.js.map +1 -0
  494. package/dist/collection/translations/sv.js +1 -0
  495. package/dist/collection/translations/sv.js.map +1 -0
  496. package/dist/collection/util/device.js +1 -0
  497. package/dist/collection/util/device.js.map +1 -0
  498. package/dist/collection/util/dispatch-resize-event.js +1 -0
  499. package/dist/collection/util/dispatch-resize-event.js.map +1 -0
  500. package/dist/collection/util/dom.js +1 -0
  501. package/dist/collection/util/dom.js.map +1 -0
  502. package/dist/collection/util/keycodes.js +1 -0
  503. package/dist/collection/util/keycodes.js.map +1 -0
  504. package/dist/collection/util/link-helper.js +1 -0
  505. package/dist/collection/util/link-helper.js.map +1 -0
  506. package/dist/collection/util/multiple.js +1 -0
  507. package/dist/collection/util/multiple.js.map +1 -0
  508. package/dist/collection/util/random-string.js +1 -0
  509. package/dist/collection/util/random-string.js.map +1 -0
  510. package/dist/esm/_arrayIncludesWith-969bccda.js +2 -0
  511. package/dist/esm/_arrayIncludesWith-969bccda.js.map +1 -0
  512. package/dist/esm/_assignValue-fb2bf80a.js +2 -0
  513. package/dist/esm/_assignValue-fb2bf80a.js.map +1 -0
  514. package/dist/esm/_commonjsHelpers-5ec8f9b7.js +2 -0
  515. package/dist/esm/_commonjsHelpers-5ec8f9b7.js.map +1 -0
  516. package/dist/esm/_defineProperty-2105cb48.js +2 -0
  517. package/dist/esm/_defineProperty-2105cb48.js.map +1 -0
  518. package/dist/esm/_getNative-93d6bfe9.js +2 -0
  519. package/dist/esm/_getNative-93d6bfe9.js.map +1 -0
  520. package/dist/esm/animationframe-b52af02d.js +2 -0
  521. package/dist/esm/animationframe-b52af02d.js.map +1 -0
  522. package/dist/esm/{checkbox.template-4ce8d92f.js → checkbox.template-c838ee7b.js} +3 -1
  523. package/dist/esm/checkbox.template-c838ee7b.js.map +1 -0
  524. package/dist/esm/component-19eb6e2b.js +2 -0
  525. package/dist/esm/component-19eb6e2b.js.map +1 -0
  526. package/dist/esm/component-288691f3.js +2 -0
  527. package/dist/esm/component-288691f3.js.map +1 -0
  528. package/dist/esm/component-410aad5a.js +2 -0
  529. package/dist/esm/component-410aad5a.js.map +1 -0
  530. package/dist/esm/component-5b4ac85a.js +2 -0
  531. package/dist/esm/component-5b4ac85a.js.map +1 -0
  532. package/dist/esm/component-fffa3419.js +2 -0
  533. package/dist/esm/component-fffa3419.js.map +1 -0
  534. package/dist/esm/config-f7362aeb.js +2 -0
  535. package/dist/esm/config-f7362aeb.js.map +1 -0
  536. package/dist/esm/device-39db3b5f.js +2 -0
  537. package/dist/esm/device-39db3b5f.js.map +1 -0
  538. package/dist/esm/dispatch-resize-event-cd1d230c.js +2 -0
  539. package/dist/esm/dispatch-resize-event-cd1d230c.js.map +1 -0
  540. package/dist/esm/dom-2fe617e7.js +2 -0
  541. package/dist/esm/dom-2fe617e7.js.map +1 -0
  542. package/dist/esm/eq-c1c7f528.js +2 -0
  543. package/dist/esm/eq-c1c7f528.js.map +1 -0
  544. package/dist/esm/format-c76733cb.js +2 -0
  545. package/dist/esm/format-c76733cb.js.map +1 -0
  546. package/dist/esm/identity-87aa3962.js +2 -0
  547. package/dist/esm/identity-87aa3962.js.map +1 -0
  548. package/dist/esm/{index-cdfd351d.js → index-9bd6d7c6.js} +209 -24
  549. package/dist/esm/index-9bd6d7c6.js.map +1 -0
  550. package/dist/esm/index.js +2 -0
  551. package/dist/esm/index.js.map +1 -0
  552. package/dist/esm/isArray-80298bc7.js +2 -0
  553. package/dist/esm/isArray-80298bc7.js.map +1 -0
  554. package/dist/esm/isArrayLike-385e0f31.js +2 -0
  555. package/dist/esm/isArrayLike-385e0f31.js.map +1 -0
  556. package/dist/esm/isEqual-c5a636a4.js +2 -0
  557. package/dist/esm/isEqual-c5a636a4.js.map +1 -0
  558. package/dist/esm/isObject-c74e273c.js +2 -0
  559. package/dist/esm/isObject-c74e273c.js.map +1 -0
  560. package/dist/esm/isObjectLike-38996507.js +2 -0
  561. package/dist/esm/isObjectLike-38996507.js.map +1 -0
  562. package/dist/esm/isSymbol-5bf20921.js +2 -0
  563. package/dist/esm/isSymbol-5bf20921.js.map +1 -0
  564. package/dist/esm/keyboard-4b9e12e3.js +2 -0
  565. package/dist/esm/keyboard-4b9e12e3.js.map +1 -0
  566. package/dist/esm/keycodes-44c01beb.js +2 -0
  567. package/dist/esm/keycodes-44c01beb.js.map +1 -0
  568. package/dist/esm/lime-elements.js +9 -3
  569. package/dist/esm/lime-elements.js.map +1 -0
  570. package/dist/esm/limel-action-bar-item_2.entry.js +3 -1
  571. package/dist/esm/limel-action-bar-item_2.entry.js.map +1 -0
  572. package/dist/esm/limel-action-bar.entry.js +3 -1
  573. package/dist/esm/limel-action-bar.entry.js.map +1 -0
  574. package/dist/esm/limel-badge.entry.js +3 -1
  575. package/dist/esm/limel-badge.entry.js.map +1 -0
  576. package/dist/esm/limel-banner.entry.js +3 -1
  577. package/dist/esm/limel-banner.entry.js.map +1 -0
  578. package/dist/esm/limel-button-group.entry.js +3 -1
  579. package/dist/esm/limel-button-group.entry.js.map +1 -0
  580. package/dist/esm/limel-button.entry.js +3 -1
  581. package/dist/esm/limel-button.entry.js.map +1 -0
  582. package/dist/esm/limel-callout.entry.js +3 -1
  583. package/dist/esm/limel-callout.entry.js.map +1 -0
  584. package/dist/esm/limel-checkbox.entry.js +4 -2
  585. package/dist/esm/limel-checkbox.entry.js.map +1 -0
  586. package/dist/esm/limel-chip-set.entry.js +3 -1
  587. package/dist/esm/limel-chip-set.entry.js.map +1 -0
  588. package/dist/esm/limel-circular-progress_2.entry.js +3 -1
  589. package/dist/esm/limel-circular-progress_2.entry.js.map +1 -0
  590. package/dist/esm/limel-code-editor.entry.js +3 -1
  591. package/dist/esm/limel-code-editor.entry.js.map +1 -0
  592. package/dist/esm/limel-collapsible-section.entry.js +3 -1
  593. package/dist/esm/limel-collapsible-section.entry.js.map +1 -0
  594. package/dist/esm/limel-color-picker-palette.entry.js +3 -1
  595. package/dist/esm/limel-color-picker-palette.entry.js.map +1 -0
  596. package/dist/esm/limel-color-picker.entry.js +3 -1
  597. package/dist/esm/limel-color-picker.entry.js.map +1 -0
  598. package/dist/esm/limel-config.entry.js +3 -1
  599. package/dist/esm/limel-config.entry.js.map +1 -0
  600. package/dist/esm/limel-date-picker.entry.js +3 -1
  601. package/dist/esm/limel-date-picker.entry.js.map +1 -0
  602. package/dist/esm/limel-dialog.entry.js +3 -1
  603. package/dist/esm/limel-dialog.entry.js.map +1 -0
  604. package/dist/esm/limel-dock-button.entry.js +3 -1
  605. package/dist/esm/limel-dock-button.entry.js.map +1 -0
  606. package/dist/esm/limel-dock.entry.js +3 -1
  607. package/dist/esm/limel-dock.entry.js.map +1 -0
  608. package/dist/esm/limel-file.entry.js +3 -1
  609. package/dist/esm/limel-file.entry.js.map +1 -0
  610. package/dist/esm/limel-flatpickr-adapter.entry.js +3 -1
  611. package/dist/esm/limel-flatpickr-adapter.entry.js.map +1 -0
  612. package/dist/esm/limel-flex-container.entry.js +3 -1
  613. package/dist/esm/limel-flex-container.entry.js.map +1 -0
  614. package/dist/esm/limel-form.entry.js +3 -1
  615. package/dist/esm/limel-form.entry.js.map +1 -0
  616. package/dist/esm/limel-grid.entry.js +3 -1
  617. package/dist/esm/limel-grid.entry.js.map +1 -0
  618. package/dist/esm/limel-header.entry.js +3 -1
  619. package/dist/esm/limel-header.entry.js.map +1 -0
  620. package/dist/esm/limel-helper-line.entry.js +3 -1
  621. package/dist/esm/limel-helper-line.entry.js.map +1 -0
  622. package/dist/esm/limel-icon-button.entry.js +3 -1
  623. package/dist/esm/limel-icon-button.entry.js.map +1 -0
  624. package/dist/esm/limel-icon.entry.js +3 -1
  625. package/dist/esm/limel-icon.entry.js.map +1 -0
  626. package/dist/esm/limel-info-tile.entry.js +3 -1
  627. package/dist/esm/limel-info-tile.entry.js.map +1 -0
  628. package/dist/esm/limel-input-field.entry.js +3 -1
  629. package/dist/esm/limel-input-field.entry.js.map +1 -0
  630. package/dist/esm/limel-list_2.entry.js +4 -2
  631. package/dist/esm/limel-list_2.entry.js.map +1 -0
  632. package/dist/esm/limel-menu_2.entry.js +3 -1
  633. package/dist/esm/limel-menu_2.entry.js.map +1 -0
  634. package/dist/esm/limel-picker.entry.js +3 -1
  635. package/dist/esm/limel-picker.entry.js.map +1 -0
  636. package/dist/esm/limel-popover_2.entry.js +3 -1
  637. package/dist/esm/limel-popover_2.entry.js.map +1 -0
  638. package/dist/esm/limel-portal.entry.js +15 -13
  639. package/dist/esm/limel-portal.entry.js.map +1 -0
  640. package/dist/esm/limel-progress-flow-item.entry.js +3 -1
  641. package/dist/esm/limel-progress-flow-item.entry.js.map +1 -0
  642. package/dist/esm/limel-progress-flow.entry.js +3 -1
  643. package/dist/esm/limel-progress-flow.entry.js.map +1 -0
  644. package/dist/esm/limel-select.entry.js +3 -1
  645. package/dist/esm/limel-select.entry.js.map +1 -0
  646. package/dist/esm/limel-shortcut.entry.js +3 -1
  647. package/dist/esm/limel-shortcut.entry.js.map +1 -0
  648. package/dist/esm/limel-slider.entry.js +3 -1
  649. package/dist/esm/limel-slider.entry.js.map +1 -0
  650. package/dist/esm/limel-snackbar.entry.js +3 -1
  651. package/dist/esm/limel-snackbar.entry.js.map +1 -0
  652. package/dist/esm/limel-spinner.entry.js +3 -1
  653. package/dist/esm/limel-spinner.entry.js.map +1 -0
  654. package/dist/esm/limel-split-button.entry.js +3 -1
  655. package/dist/esm/limel-split-button.entry.js.map +1 -0
  656. package/dist/esm/limel-switch.entry.js +3 -1
  657. package/dist/esm/limel-switch.entry.js.map +1 -0
  658. package/dist/esm/limel-tab-bar.entry.js +3 -1
  659. package/dist/esm/limel-tab-bar.entry.js.map +1 -0
  660. package/dist/esm/limel-tab-panel.entry.js +3 -1
  661. package/dist/esm/limel-tab-panel.entry.js.map +1 -0
  662. package/dist/esm/limel-table.entry.js +3 -1
  663. package/dist/esm/limel-table.entry.js.map +1 -0
  664. package/dist/esm/limel-tooltip_2.entry.js +3 -1
  665. package/dist/esm/limel-tooltip_2.entry.js.map +1 -0
  666. package/dist/esm/link-helper-b08fe56c.js +2 -0
  667. package/dist/esm/link-helper-b08fe56c.js.map +1 -0
  668. package/dist/esm/loader.js +6 -3
  669. package/dist/esm/loader.js.map +1 -0
  670. package/dist/esm/moment-faa8a4a8.js +2 -0
  671. package/dist/esm/moment-faa8a4a8.js.map +1 -0
  672. package/dist/esm/multiple-0bd62427.js +2 -0
  673. package/dist/esm/multiple-0bd62427.js.map +1 -0
  674. package/dist/esm/pickBy-d359eb12.js +2 -0
  675. package/dist/esm/pickBy-d359eb12.js.map +1 -0
  676. package/dist/esm/polyfills/css-shim.js +1 -1
  677. package/dist/esm/ponyfill-30263d5e.js +2 -0
  678. package/dist/esm/ponyfill-30263d5e.js.map +1 -0
  679. package/dist/esm/random-string-2246b81e.js +2 -0
  680. package/dist/esm/random-string-2246b81e.js.map +1 -0
  681. package/dist/esm/sv-336c4576.js +2 -0
  682. package/dist/esm/sv-336c4576.js.map +1 -0
  683. package/dist/esm/toNumber-a6ed64f0.js +2 -0
  684. package/dist/esm/toNumber-a6ed64f0.js.map +1 -0
  685. package/dist/esm/translations-f88bb584.js +2 -0
  686. package/dist/esm/translations-f88bb584.js.map +1 -0
  687. package/dist/esm/util-f1bde91c.js +2 -0
  688. package/dist/esm/util-f1bde91c.js.map +1 -0
  689. package/dist/esm/zipObject-2bb1968e.js +2 -0
  690. package/dist/esm/zipObject-2bb1968e.js.map +1 -0
  691. package/dist/lime-elements/index.esm.js +2 -0
  692. package/dist/lime-elements/index.esm.js.map +1 -0
  693. package/dist/lime-elements/lime-elements.esm.js +2 -1
  694. package/dist/lime-elements/lime-elements.esm.js.map +1 -0
  695. package/dist/lime-elements/p-0137d2fb.entry.js +2 -0
  696. package/dist/lime-elements/p-0137d2fb.entry.js.map +1 -0
  697. package/dist/lime-elements/p-0b1af919.js +2 -1
  698. package/dist/lime-elements/p-0b1af919.js.map +1 -0
  699. package/dist/lime-elements/p-0eabb204.js +2 -1
  700. package/dist/lime-elements/p-0eabb204.js.map +1 -0
  701. package/dist/lime-elements/p-13ed01eb.entry.js +236 -0
  702. package/dist/lime-elements/p-13ed01eb.entry.js.map +1 -0
  703. package/dist/lime-elements/p-17ac8cca.entry.js +2 -0
  704. package/dist/lime-elements/p-17ac8cca.entry.js.map +1 -0
  705. package/dist/lime-elements/p-1a80da5e.entry.js +104 -0
  706. package/dist/lime-elements/p-1a80da5e.entry.js.map +1 -0
  707. package/dist/lime-elements/p-1c284626.js +372 -5
  708. package/dist/lime-elements/p-1c284626.js.map +1 -0
  709. package/dist/lime-elements/p-1dc042e5.entry.js +2 -0
  710. package/dist/lime-elements/p-1dc042e5.entry.js.map +1 -0
  711. package/dist/lime-elements/p-2118b9ae.entry.js +2 -0
  712. package/dist/lime-elements/p-2118b9ae.entry.js.map +1 -0
  713. package/dist/lime-elements/p-2359d139.entry.js +82 -0
  714. package/dist/lime-elements/p-2359d139.entry.js.map +1 -0
  715. package/dist/lime-elements/p-240fda3b.js +2 -1
  716. package/dist/lime-elements/p-240fda3b.js.map +1 -0
  717. package/dist/lime-elements/p-2565927b.entry.js +21 -0
  718. package/dist/lime-elements/p-2565927b.entry.js.map +1 -0
  719. package/dist/lime-elements/p-28da3c47.entry.js +2 -0
  720. package/dist/lime-elements/p-28da3c47.entry.js.map +1 -0
  721. package/dist/lime-elements/p-2b0c6ccd.entry.js +17 -0
  722. package/dist/lime-elements/p-2b0c6ccd.entry.js.map +1 -0
  723. package/dist/lime-elements/p-2f71d4d4.js +2 -1
  724. package/dist/lime-elements/p-2f71d4d4.js.map +1 -0
  725. package/dist/lime-elements/p-30df2bb6.entry.js +2 -0
  726. package/dist/lime-elements/p-30df2bb6.entry.js.map +1 -0
  727. package/dist/lime-elements/p-365098fe.js +2 -1
  728. package/dist/lime-elements/p-365098fe.js.map +1 -0
  729. package/dist/lime-elements/p-3670f018.entry.js +2 -0
  730. package/dist/lime-elements/p-3670f018.entry.js.map +1 -0
  731. package/dist/lime-elements/p-40b7d717.entry.js +2 -0
  732. package/dist/lime-elements/p-40b7d717.entry.js.map +1 -0
  733. package/dist/lime-elements/p-4114c214.entry.js +82 -0
  734. package/dist/lime-elements/p-4114c214.entry.js.map +1 -0
  735. package/dist/lime-elements/p-42a24572.entry.js +2 -0
  736. package/dist/lime-elements/p-42a24572.entry.js.map +1 -0
  737. package/dist/lime-elements/p-48105d44.js +2 -1
  738. package/dist/lime-elements/p-48105d44.js.map +1 -0
  739. package/dist/lime-elements/p-48d4ef20.js +4 -3
  740. package/dist/lime-elements/p-48d4ef20.js.map +1 -0
  741. package/dist/lime-elements/p-4c3358cb.js +2 -1
  742. package/dist/lime-elements/p-4c3358cb.js.map +1 -0
  743. package/dist/lime-elements/p-4dd9a5a5.js +12 -5
  744. package/dist/lime-elements/p-4dd9a5a5.js.map +1 -0
  745. package/dist/lime-elements/p-4ed75a11.entry.js +162 -0
  746. package/dist/lime-elements/p-4ed75a11.entry.js.map +1 -0
  747. package/dist/lime-elements/p-4ef9aa7d.entry.js +104 -0
  748. package/dist/lime-elements/p-4ef9aa7d.entry.js.map +1 -0
  749. package/dist/lime-elements/p-55a09930.entry.js +126 -0
  750. package/dist/lime-elements/p-55a09930.entry.js.map +1 -0
  751. package/dist/lime-elements/p-5b374246.entry.js +476 -0
  752. package/dist/lime-elements/p-5b374246.entry.js.map +1 -0
  753. package/dist/lime-elements/p-5b6d2d55.js +2 -0
  754. package/dist/lime-elements/p-5b6d2d55.js.map +1 -0
  755. package/dist/lime-elements/p-5f020b3c.js +2 -1
  756. package/dist/lime-elements/p-5f020b3c.js.map +1 -0
  757. package/dist/lime-elements/p-5fdb83c9.js +2 -1
  758. package/dist/lime-elements/p-5fdb83c9.js.map +1 -0
  759. package/dist/lime-elements/p-623d09d9.entry.js +2 -0
  760. package/dist/lime-elements/p-623d09d9.entry.js.map +1 -0
  761. package/dist/lime-elements/p-63111b62.entry.js +2 -0
  762. package/dist/lime-elements/p-63111b62.entry.js.map +1 -0
  763. package/dist/lime-elements/p-648d9057.entry.js +2 -0
  764. package/dist/lime-elements/p-648d9057.entry.js.map +1 -0
  765. package/dist/lime-elements/p-669626e5.js +2 -1
  766. package/dist/lime-elements/p-669626e5.js.map +1 -0
  767. package/dist/lime-elements/p-6b952164.entry.js +2 -0
  768. package/dist/lime-elements/p-6b952164.entry.js.map +1 -0
  769. package/dist/lime-elements/p-6c094f3f.js +2 -1
  770. package/dist/lime-elements/p-6c094f3f.js.map +1 -0
  771. package/dist/lime-elements/p-6e219bb4.js +2 -1
  772. package/dist/lime-elements/p-6e219bb4.js.map +1 -0
  773. package/dist/lime-elements/p-715d3252.entry.js +2 -0
  774. package/dist/lime-elements/p-715d3252.entry.js.map +1 -0
  775. package/dist/lime-elements/p-753f500b.entry.js +82 -0
  776. package/dist/lime-elements/p-753f500b.entry.js.map +1 -0
  777. package/dist/lime-elements/p-795079c9.entry.js +2 -0
  778. package/dist/lime-elements/p-795079c9.entry.js.map +1 -0
  779. package/dist/lime-elements/p-7a3f58cd.entry.js +2 -0
  780. package/dist/lime-elements/p-7a3f58cd.entry.js.map +1 -0
  781. package/dist/lime-elements/p-7cda574b.js +2 -1
  782. package/dist/lime-elements/p-7cda574b.js.map +1 -0
  783. package/dist/lime-elements/p-848437f8.entry.js +2 -0
  784. package/dist/lime-elements/p-848437f8.entry.js.map +1 -0
  785. package/dist/lime-elements/p-858c6b82.js +2 -1
  786. package/dist/lime-elements/p-858c6b82.js.map +1 -0
  787. package/dist/lime-elements/p-896043d6.entry.js +2 -0
  788. package/dist/lime-elements/p-896043d6.entry.js.map +1 -0
  789. package/dist/lime-elements/p-8b339748.entry.js +2 -0
  790. package/dist/lime-elements/p-8b339748.entry.js.map +1 -0
  791. package/dist/lime-elements/p-945afca2.js +3 -2
  792. package/dist/lime-elements/p-945afca2.js.map +1 -0
  793. package/dist/lime-elements/p-9aab2892.entry.js +2 -0
  794. package/dist/lime-elements/p-9aab2892.entry.js.map +1 -0
  795. package/dist/lime-elements/p-9acf7b5d.js +2 -1
  796. package/dist/lime-elements/p-9acf7b5d.js.map +1 -0
  797. package/dist/lime-elements/p-9e78a21c.entry.js +16 -0
  798. package/dist/lime-elements/p-9e78a21c.entry.js.map +1 -0
  799. package/dist/lime-elements/p-9faad6eb.js +2 -1
  800. package/dist/lime-elements/p-9faad6eb.js.map +1 -0
  801. package/dist/lime-elements/p-9fe3bc64.entry.js +2 -0
  802. package/dist/lime-elements/p-9fe3bc64.entry.js.map +1 -0
  803. package/dist/lime-elements/p-a11a971e.entry.js +2 -0
  804. package/dist/lime-elements/p-a11a971e.entry.js.map +1 -0
  805. package/dist/lime-elements/p-a3bea367.entry.js +2 -0
  806. package/dist/lime-elements/p-a3bea367.entry.js.map +1 -0
  807. package/dist/lime-elements/p-a40e05c3.entry.js +2 -0
  808. package/dist/lime-elements/p-a40e05c3.entry.js.map +1 -0
  809. package/dist/lime-elements/p-a8714655.entry.js +2 -0
  810. package/dist/lime-elements/p-a8714655.entry.js.map +1 -0
  811. package/dist/lime-elements/p-acf307d9.js +2 -1
  812. package/dist/lime-elements/p-acf307d9.js.map +1 -0
  813. package/dist/lime-elements/p-ad8cb388.js +2 -1
  814. package/dist/lime-elements/p-ad8cb388.js.map +1 -0
  815. package/dist/lime-elements/p-ade76f1d.js +2 -1
  816. package/dist/lime-elements/p-ade76f1d.js.map +1 -0
  817. package/dist/lime-elements/p-b28128d2.js +2 -1
  818. package/dist/lime-elements/p-b28128d2.js.map +1 -0
  819. package/dist/lime-elements/p-b59e4287.js +2 -1
  820. package/dist/lime-elements/p-b59e4287.js.map +1 -0
  821. package/dist/lime-elements/p-b8ed25b3.entry.js +2 -0
  822. package/dist/lime-elements/p-b8ed25b3.entry.js.map +1 -0
  823. package/dist/lime-elements/p-c647b197.entry.js +2 -0
  824. package/dist/lime-elements/p-c647b197.entry.js.map +1 -0
  825. package/dist/lime-elements/p-c70b1ea3.js +2 -1
  826. package/dist/lime-elements/p-c70b1ea3.js.map +1 -0
  827. package/dist/lime-elements/p-c8818b66.js +3 -0
  828. package/dist/lime-elements/p-c8818b66.js.map +1 -0
  829. package/dist/lime-elements/p-c93050d6.js +2 -1
  830. package/dist/lime-elements/p-c93050d6.js.map +1 -0
  831. package/dist/lime-elements/p-ca9b383b.entry.js +2 -0
  832. package/dist/lime-elements/p-ca9b383b.entry.js.map +1 -0
  833. package/dist/lime-elements/p-cbc43682.js +27 -4
  834. package/dist/lime-elements/p-cbc43682.js.map +1 -0
  835. package/dist/lime-elements/p-cc9ebbef.js +2 -1
  836. package/dist/lime-elements/p-cc9ebbef.js.map +1 -0
  837. package/dist/lime-elements/p-d07f1a1f.entry.js +2 -0
  838. package/dist/lime-elements/p-d07f1a1f.entry.js.map +1 -0
  839. package/dist/lime-elements/p-d0a7de87.js +48 -3
  840. package/dist/lime-elements/p-d0a7de87.js.map +1 -0
  841. package/dist/lime-elements/p-d228fd62.entry.js +2 -0
  842. package/dist/lime-elements/p-d228fd62.entry.js.map +1 -0
  843. package/dist/lime-elements/p-d529bb7d.js +2 -1
  844. package/dist/lime-elements/p-d529bb7d.js.map +1 -0
  845. package/dist/lime-elements/p-d7801e00.js +2 -1
  846. package/dist/lime-elements/p-d7801e00.js.map +1 -0
  847. package/dist/lime-elements/p-d7c39d02.entry.js +126 -0
  848. package/dist/lime-elements/p-d7c39d02.entry.js.map +1 -0
  849. package/dist/lime-elements/p-da25e94d.entry.js +2 -0
  850. package/dist/lime-elements/p-da25e94d.entry.js.map +1 -0
  851. package/dist/lime-elements/p-dcc97cc2.js +2 -1
  852. package/dist/lime-elements/p-dcc97cc2.js.map +1 -0
  853. package/dist/lime-elements/p-dfba92de.js +88 -8
  854. package/dist/lime-elements/p-dfba92de.js.map +1 -0
  855. package/dist/lime-elements/p-e0fa49ca.entry.js +2 -0
  856. package/dist/lime-elements/p-e0fa49ca.entry.js.map +1 -0
  857. package/dist/lime-elements/p-e59e0040.entry.js +2 -0
  858. package/dist/lime-elements/p-e59e0040.entry.js.map +1 -0
  859. package/dist/lime-elements/p-eab67c09.js +2 -1
  860. package/dist/lime-elements/p-eab67c09.js.map +1 -0
  861. package/dist/lime-elements/p-eda23c05.js +2 -1
  862. package/dist/lime-elements/p-eda23c05.js.map +1 -0
  863. package/dist/lime-elements/p-f1d9723a.entry.js +2 -0
  864. package/dist/lime-elements/p-f1d9723a.entry.js.map +1 -0
  865. package/dist/lime-elements/p-fa607ed3.js +2 -1
  866. package/dist/lime-elements/p-fa607ed3.js.map +1 -0
  867. package/dist/lime-elements/p-fb799569.entry.js +2 -0
  868. package/dist/lime-elements/p-fb799569.entry.js.map +1 -0
  869. package/dist/loader/index.d.ts +9 -0
  870. package/dist/types/components/callout/callout.types.d.ts +1 -1
  871. package/dist/types/components/circular-progress/circular-progress.types.d.ts +1 -1
  872. package/dist/types/components/code-editor/code-editor.types.d.ts +2 -2
  873. package/dist/types/components/date-picker/date.types.d.ts +2 -2
  874. package/dist/types/components/file/file-metadata.d.ts +5 -5
  875. package/dist/types/components/flex-container/flex-container.types.d.ts +3 -3
  876. package/dist/types/components/form/form.types.d.ts +1 -1
  877. package/dist/types/components/form/templates/types.d.ts +3 -3
  878. package/dist/types/components/form/widgets/index.d.ts +1 -1
  879. package/dist/types/components/icon/icon.types.d.ts +1 -1
  880. package/dist/types/components/input-field/input-field.types.d.ts +1 -1
  881. package/dist/types/components/list/list.types.d.ts +1 -1
  882. package/dist/types/components/menu/menu.types.d.ts +1 -1
  883. package/dist/types/components/menu-list/menu-list.types.d.ts +1 -1
  884. package/dist/types/components/picker/actions.types.d.ts +2 -2
  885. package/dist/types/components/picker/searcher.types.d.ts +1 -1
  886. package/dist/types/components/spinner/spinner.types.d.ts +1 -1
  887. package/dist/types/components/table/layout.d.ts +1 -1
  888. package/dist/types/components/table/table.types.d.ts +2 -2
  889. package/dist/types/components.d.ts +2848 -0
  890. package/dist/types/interface.d.ts +5 -14
  891. package/dist/types/stencil-public-runtime.d.ts +74 -15
  892. package/package.json +2 -2
  893. package/dist/lime-elements/p-076de623.entry.js +0 -1
  894. package/dist/lime-elements/p-07dd6729.entry.js +0 -1
  895. package/dist/lime-elements/p-094dd76a.entry.js +0 -126
  896. package/dist/lime-elements/p-10e259de.entry.js +0 -1
  897. package/dist/lime-elements/p-123f5fbb.entry.js +0 -1
  898. package/dist/lime-elements/p-29350441.entry.js +0 -37
  899. package/dist/lime-elements/p-30f5cc4d.entry.js +0 -1
  900. package/dist/lime-elements/p-35a6ab13.entry.js +0 -1
  901. package/dist/lime-elements/p-3618f8be.entry.js +0 -1
  902. package/dist/lime-elements/p-3be2dfc7.entry.js +0 -1
  903. package/dist/lime-elements/p-3cdc210b.entry.js +0 -1
  904. package/dist/lime-elements/p-3fda3473.entry.js +0 -1
  905. package/dist/lime-elements/p-46a76d55.entry.js +0 -1
  906. package/dist/lime-elements/p-4a62273c.entry.js +0 -1
  907. package/dist/lime-elements/p-4eeabc1f.entry.js +0 -1
  908. package/dist/lime-elements/p-5338663b.entry.js +0 -1
  909. package/dist/lime-elements/p-55900379.entry.js +0 -59
  910. package/dist/lime-elements/p-55c8cb64.entry.js +0 -131
  911. package/dist/lime-elements/p-6b8142ba.entry.js +0 -73
  912. package/dist/lime-elements/p-6c38b505.entry.js +0 -1
  913. package/dist/lime-elements/p-727fd4ea.entry.js +0 -38
  914. package/dist/lime-elements/p-7719a91d.entry.js +0 -1
  915. package/dist/lime-elements/p-79049482.entry.js +0 -1
  916. package/dist/lime-elements/p-7d7d19de.entry.js +0 -1
  917. package/dist/lime-elements/p-803cc4b7.entry.js +0 -1
  918. package/dist/lime-elements/p-82cd7bb6.entry.js +0 -1
  919. package/dist/lime-elements/p-8a2d1761.entry.js +0 -11
  920. package/dist/lime-elements/p-8acabe02.entry.js +0 -59
  921. package/dist/lime-elements/p-9336fd7f.entry.js +0 -1
  922. package/dist/lime-elements/p-95cefb5f.entry.js +0 -1
  923. package/dist/lime-elements/p-a3acc38f.entry.js +0 -83
  924. package/dist/lime-elements/p-a5d5efc4.entry.js +0 -1
  925. package/dist/lime-elements/p-b0bfec52.entry.js +0 -1
  926. package/dist/lime-elements/p-b40f37d7.entry.js +0 -1
  927. package/dist/lime-elements/p-b526ebd4.entry.js +0 -1
  928. package/dist/lime-elements/p-b80de0ea.entry.js +0 -1
  929. package/dist/lime-elements/p-bf3d6097.entry.js +0 -1
  930. package/dist/lime-elements/p-c6e913a4.entry.js +0 -82
  931. package/dist/lime-elements/p-cb2c9562.entry.js +0 -16
  932. package/dist/lime-elements/p-cc3529bb.entry.js +0 -82
  933. package/dist/lime-elements/p-cfaa685f.entry.js +0 -1
  934. package/dist/lime-elements/p-d2a3d50b.js +0 -1
  935. package/dist/lime-elements/p-d4e788e1.js +0 -2
  936. package/dist/lime-elements/p-d55d88a5.entry.js +0 -1
  937. package/dist/lime-elements/p-da4d1bc1.entry.js +0 -16
  938. package/dist/lime-elements/p-eda87f8c.entry.js +0 -1
  939. package/dist/lime-elements/p-edbd8d62.entry.js +0 -1
  940. package/dist/lime-elements/p-ef93fd3e.entry.js +0 -1
  941. package/dist/lime-elements/p-f11e7ce1.entry.js +0 -1
  942. package/dist/lime-elements/p-f979c0f2.entry.js +0 -1
@@ -0,0 +1 @@
1
+ {"version":3,"file":"radio-button.template.js","sourceRoot":"","sources":["../../../../src/components/list/radio-button/radio-button.template.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAuB,CAAC,EAAE,MAAM,eAAe,CAAC;AAUvD,MAAM,CAAC,MAAM,mBAAmB,GAE5B,CAAC,KAAK,EAAE,EAAE;EACV,OAAO,CACH,WAAK,KAAK,EAAC,gBAAgB;IACvB,WACI,KAAK,EAAE;;0BAEG,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,EAAE;qBAChD;MAEL,aACI,KAAK,EAAC,2BAA2B,EACjC,IAAI,EAAC,OAAO,EACZ,EAAE,EAAE,KAAK,CAAC,EAAE,EACZ,OAAO,EAAE,KAAK,CAAC,OAAO,EACtB,QAAQ,EAAE,KAAK,CAAC,QAAQ,EACxB,QAAQ,EAAE,KAAK,CAAC,QAAQ,GAC1B;MACF,WAAK,KAAK,EAAC,uBAAuB;QAC9B,WAAK,KAAK,EAAC,yBAAyB,GAAG;QACvC,WAAK,KAAK,EAAC,yBAAyB,GAAG,CACrC,CACJ;IACN,aACI,KAAK,EAAE,GAAG,KAAK,CAAC,QAAQ,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,EAAE,EAC5C,OAAO,EAAE,KAAK,CAAC,EAAE,IAEhB,KAAK,CAAC,KAAK,CACR,CACN,CACT,CAAC;AACN,CAAC,CAAC","sourcesContent":["import { FunctionalComponent, h } from '@stencil/core';\n\ninterface RadioButtonTemplateProps {\n disabled?: boolean;\n id: string;\n checked?: boolean;\n onChange?: (event: Event) => void;\n label?: string;\n}\n\nexport const RadioButtonTemplate: FunctionalComponent<\n RadioButtonTemplateProps\n> = (props) => {\n return (\n <div class=\"mdc-form-field\">\n <div\n class={`\n mdc-radio\n ${props.disabled ? 'mdc-radio--disabled' : ''}\n `}\n >\n <input\n class=\"mdc-radio__native-control\"\n type=\"radio\"\n id={props.id}\n checked={props.checked}\n disabled={props.disabled}\n onChange={props.onChange}\n />\n <div class=\"mdc-radio__background\">\n <div class=\"mdc-radio__outer-circle\" />\n <div class=\"mdc-radio__inner-circle\" />\n </div>\n </div>\n <label\n class={`${props.disabled ? 'disabled' : ''}`}\n htmlFor={props.id}\n >\n {props.label}\n </label>\n </div>\n );\n};\n"]}
@@ -134,7 +134,7 @@ export class Menu {
134
134
  "mutable": false,
135
135
  "complexType": {
136
136
  "original": "Array<MenuItem | ListSeparator>",
137
- "resolved": "(MenuItem<any> | ListSeparator)[]",
137
+ "resolved": "any[]",
138
138
  "references": {
139
139
  "Array": {
140
140
  "location": "global"
@@ -282,7 +282,7 @@ export class Menu {
282
282
  },
283
283
  "complexType": {
284
284
  "original": "MenuItem | MenuItem[]",
285
- "resolved": "MenuItem<any> | MenuItem<any>[]",
285
+ "resolved": "any",
286
286
  "references": {
287
287
  "MenuItem": {
288
288
  "location": "import",
@@ -300,3 +300,4 @@ export class Menu {
300
300
  }];
301
301
  }
302
302
  }
303
+ //# sourceMappingURL=menu.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"menu.js","sourceRoot":"","sources":["../../../src/components/menu/menu.tsx"],"names":[],"mappings":"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","sourcesContent":["import {\n Component,\n Event,\n EventEmitter,\n h,\n Prop,\n Element,\n Watch,\n} from '@stencil/core';\nimport { createRandomString } from '../../util/random-string';\nimport { zipObject } from 'lodash-es';\nimport {\n ListSeparator,\n MenuItem,\n OpenDirection,\n} from '@limetech/lime-elements';\n\n/**\n * @slot trigger - Element to use as a trigger for the menu.\n * @exampleComponent limel-example-menu-basic\n * @exampleComponent limel-example-menu-disabled\n * @exampleComponent limel-example-menu-open-direction\n * @exampleComponent limel-example-menu-icons\n * @exampleComponent limel-example-menu-badge-icons\n * @exampleComponent limel-example-menu-grid\n * @exampleComponent limel-example-menu-hotkeys\n * @exampleComponent limel-example-menu-secondary-text\n * @exampleComponent limel-example-menu-notification\n * @exampleComponent limel-example-menu-composite\n */\n@Component({\n tag: 'limel-menu',\n shadow: true,\n styleUrl: 'menu.scss',\n})\nexport class Menu {\n /**\n * A list of items and separators to show in the menu.\n */\n @Prop()\n public items: Array<MenuItem | ListSeparator> = [];\n\n /**\n * Sets the disabled state of the menu.\n */\n @Prop({ reflect: true })\n public disabled = false;\n\n /**\n * Decides the menu's location in relation to its trigger\n */\n @Prop({ reflect: true })\n public openDirection: OpenDirection = 'bottom-start';\n\n /**\n * Sets the open state of the menu.\n */\n @Prop({ mutable: true, reflect: true })\n public open = false;\n\n /**\n * Defines whether the menu should show badges.\n */\n @Prop({ reflect: true })\n public badgeIcons = false;\n\n /**\n * Renders list items in a grid layout, rather than a vertical list\n */\n @Prop({ reflect: true })\n public gridLayout = false;\n\n /**\n * Is emitted when the menu is cancelled.\n */\n @Event()\n private cancel: EventEmitter<void>;\n\n /**\n * Is emitted when a menu item is selected.\n */\n @Event()\n private select: EventEmitter<MenuItem | MenuItem[]>;\n\n @Element()\n private host: HTMLLimelMenuElement;\n\n private list: HTMLLimelMenuListElement;\n\n private portalId: string;\n\n constructor() {\n this.portalId = createRandomString();\n }\n\n @Watch('open')\n protected openWatcher() {\n if (!this.open) {\n return;\n }\n\n const observer = new IntersectionObserver(() => {\n observer.unobserve(this.list);\n this.focusMenuItem();\n });\n observer.observe(this.list);\n }\n\n public render() {\n const cssProperties = this.getCssProperties();\n const dropdownZIndex = getComputedStyle(this.host).getPropertyValue(\n '--dropdown-z-index'\n );\n\n return (\n <div class=\"mdc-menu-surface--anchor\" onClick={this.onTriggerClick}>\n <slot name=\"trigger\" />\n {this.renderNotificationBadge()}\n <limel-portal\n visible={this.open}\n containerId={this.portalId}\n openDirection={this.openDirection}\n position=\"absolute\"\n containerStyle={{ 'z-index': dropdownZIndex }}\n >\n <limel-menu-surface\n open={this.open}\n onDismiss={this.onClose}\n style={cssProperties}\n class={{\n 'has-grid-layout': this.gridLayout,\n }}\n >\n <limel-menu-list\n class={{\n 'has-grid-layout has-interactive-items':\n this.gridLayout,\n }}\n items={this.items}\n type=\"menu\"\n badgeIcons={this.badgeIcons}\n onSelect={this.handleSelect}\n ref={this.setListElement}\n />\n </limel-menu-surface>\n </limel-portal>\n </div>\n );\n }\n\n public componentDidRender() {\n const slotElement = this.host.shadowRoot.querySelector('slot');\n slotElement.assignedElements().forEach(this.setTriggerAttributes);\n }\n\n private setTriggerAttributes = (element: HTMLElement) => {\n const attributes = {\n 'aria-haspopup': true,\n 'aria-expanded': this.open,\n disabled: this.disabled,\n role: 'button',\n };\n\n for (const [key, value] of Object.entries(attributes)) {\n if (!value) {\n element.removeAttribute(key);\n } else {\n element.setAttribute(key, String(value));\n }\n }\n };\n\n private onClose = () => {\n this.cancel.emit();\n this.open = false;\n };\n\n private onTriggerClick = (event: MouseEvent) => {\n event.stopPropagation();\n if (this.disabled) {\n return;\n }\n\n this.open = !this.open;\n };\n\n private handleSelect = (event: CustomEvent<MenuItem>) => {\n event.stopPropagation();\n this.select.emit(event.detail);\n this.open = false;\n };\n\n private getCssProperties() {\n const propertyNames = [\n '--menu-surface-width',\n '--list-grid-item-max-width',\n '--list-grid-item-min-width',\n '--list-grid-gap',\n '--notification-badge-background-color',\n '--notification-badge-text-color',\n ];\n const style = getComputedStyle(this.host);\n const values = propertyNames.map((property) => {\n return style.getPropertyValue(property);\n });\n\n return zipObject(propertyNames, values);\n }\n\n private setListElement = (element: HTMLLimelMenuListElement) => {\n this.list = element;\n };\n\n private focusMenuItem = () => {\n const activeElement = this.list.shadowRoot.activeElement as HTMLElement;\n activeElement?.blur();\n\n const MenuItems = this.items.filter(this.isMenuItem);\n const selectedIndex = Math.max(\n MenuItems.findIndex((item) => item.selected),\n 0\n );\n const menuElements: HTMLElement[] = Array.from(\n this.list.shadowRoot.querySelectorAll('[role=\"menuitem\"]')\n );\n menuElements[selectedIndex]?.focus();\n };\n\n private isMenuItem(item: MenuItem | ListSeparator): item is MenuItem {\n return !('separator' in item);\n }\n\n private renderNotificationBadge = () => {\n if (this.items.some(this.hasNotificationBadge)) {\n return <limel-badge />;\n }\n };\n\n private hasNotificationBadge = (item: MenuItem | ListSeparator) =>\n this.isMenuItem(item) && item.badge !== undefined;\n}\n"]}
@@ -1 +1,2 @@
1
1
  export {};
2
+ //# sourceMappingURL=menu.types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"menu.types.js","sourceRoot":"","sources":["../../../src/components/menu/menu.types.ts"],"names":[],"mappings":"","sourcesContent":["export type OpenDirection =\n | 'left-start'\n | 'left'\n | 'left-end'\n | 'right-start'\n | 'right'\n | 'right-end'\n | 'top-start'\n | 'top'\n | 'top-end'\n | 'bottom-start'\n | 'bottom'\n | 'bottom-end';\n\nexport interface MenuItem<T = any> {\n /**\n * The additional supporting text is used for shortcut commands and displayed in the menu item.\n */\n commandText?: string;\n\n /**\n * Text to display in the menu item.\n */\n text: string;\n\n /**\n * Additional supporting text to display in the menu item.\n */\n secondaryText?: string;\n\n /**\n * True if the menu item should be disabled.\n */\n disabled?: boolean;\n\n /**\n * Name of the icon to use.\n */\n icon?: string;\n\n /**\n * Background color of the icon. Overrides `--icon-background-color`.\n */\n iconColor?: string;\n\n /**\n * True if the menu item should be selected.\n */\n selected?: boolean;\n\n /**\n * If specified, will display a notification badge on the buttons in the dock.\n */\n badge?: number | string;\n\n /**\n * Value of the menu item.\n */\n value?: T;\n}\n"]}
@@ -1 +1,2 @@
1
1
  export {};
2
+ //# sourceMappingURL=menu-list-renderer-config.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"menu-list-renderer-config.js","sourceRoot":"","sources":["../../../src/components/menu-list/menu-list-renderer-config.ts"],"names":[],"mappings":"","sourcesContent":["import { IconSize, MenuListType } from '@limetech/lime-elements';\n\nexport interface MenuListRendererConfig {\n isOpen?: boolean;\n badgeIcons?: boolean;\n type?: MenuListType;\n iconSize?: IconSize;\n}\n"]}
@@ -139,3 +139,4 @@ export class MenuListRenderer {
139
139
  return (h("ul", { class: classNames, "aria-hidden": true, role: "menu", "aria-orientation": "vertical", style: { '--maxLinesSecondaryText': '2' } }, items.map(this.renderMenuItem)));
140
140
  }
141
141
  }
142
+ //# sourceMappingURL=menu-list-renderer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"menu-list-renderer.js","sourceRoot":"","sources":["../../../src/components/menu-list/menu-list-renderer.tsx"],"names":[],"mappings":"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","sourcesContent":["import { ListSeparator, MenuItem } from '@limetech/lime-elements';\nimport { h } from '@stencil/core';\nimport { MenuListRendererConfig } from './menu-list-renderer-config';\n\nexport class MenuListRenderer {\n private defaultConfig: MenuListRendererConfig = {\n isOpen: true,\n badgeIcons: false,\n };\n\n private config: MenuListRendererConfig;\n\n private hasIcons: boolean;\n private twoLines: boolean;\n private avatarList: boolean;\n private commandKey: boolean;\n\n private applyTabIndexToItemAtIndex: number;\n\n public render(\n items: Array<MenuItem | ListSeparator>,\n config: MenuListRendererConfig = {}\n ) {\n items = items || [];\n this.config = { ...this.defaultConfig, ...config };\n\n this.twoLines = items.some((item) => {\n return 'secondaryText' in item && !!item.secondaryText;\n });\n\n this.commandKey = items.some((item) => {\n return 'commandText' in item && !!item.commandText;\n });\n\n this.hasIcons = items.some((item) => {\n return 'icon' in item && !!item.icon;\n });\n\n this.avatarList = this.config.badgeIcons && this.hasIcons;\n\n this.applyTabIndexToItemAtIndex =\n this.getIndexForWhichToApplyTabIndex(items);\n\n const classNames = {\n 'mdc-deprecated-list': true,\n 'mdc-deprecated-list--two-line': this.twoLines,\n selectable: true,\n 'mdc-deprecated-list--avatar-list': this.avatarList,\n 'list--compact':\n this.twoLines &&\n this.commandKey &&\n ['small', 'x-small'].includes(this.config.iconSize),\n };\n\n return (\n <ul\n class={classNames}\n aria-hidden={true}\n role=\"menu\"\n aria-orientation=\"vertical\"\n style={{ '--maxLinesSecondaryText': '2' }}\n >\n {items.map(this.renderMenuItem)}\n </ul>\n );\n }\n\n /**\n * Determine which MenuItem should have the `tab-index` attribute set,\n * and return the index at which that MenuItem is located in `items`.\n * Returns `undefined` if no item should have the attribute set.\n * See https://github.com/material-components/material-components-web/tree/e66a43a75fef4f9179e24856649518e15e279a04/packages/mdc-list#accessibility\n * @param {Array<MenuItem | ListSeparator>} items the items of the list, including any `ListSeparator`:s\n * @returns {number} the index as per the description\n */\n private getIndexForWhichToApplyTabIndex = (\n items: Array<MenuItem | ListSeparator>\n ) => {\n let result;\n for (let i = 0, max = items.length; i < max; i += 1) {\n if ('separator' in items[i]) {\n // Ignore ListSeparator\n } else {\n const item = items[i] as MenuItem<any>;\n if (item.selected) {\n result = i;\n break;\n }\n\n if (result === undefined && !item.disabled) {\n result = i;\n // Do NOT break, as any later item with\n // `selected=true` should get the tab-index instead!\n }\n }\n }\n\n return result;\n };\n\n /**\n * Render a single list item\n * @param {MenuItem | ListSeparator} item the item to render\n * @param {number} index the index the item had in the `items` array\n * @returns {HTMLElement} the list item\n */\n private renderMenuItem = (\n item: MenuItem | ListSeparator,\n index: number\n ) => {\n if ('separator' in item) {\n return <li class=\"mdc-deprecated-list-divider\" role=\"separator\" />;\n }\n\n const classNames = {\n 'mdc-deprecated-list-item': true,\n 'mdc-deprecated-list-item--disabled': item.disabled,\n 'mdc-deprecated-list-item--selected': item.selected,\n };\n\n const attributes: { tabindex?: string } = {};\n if (index === this.applyTabIndexToItemAtIndex) {\n attributes.tabindex = '0';\n }\n\n return (\n <li\n class={classNames}\n role=\"menuitem\"\n aria-disabled={item.disabled ? 'true' : 'false'}\n aria-selected={item.selected ? 'true' : 'false'}\n data-index={index}\n {...attributes}\n >\n {item.icon ? this.renderIcon(this.config, item) : null}\n {this.renderText(item)}\n {this.renderNotification(item)}\n {this.twoLines && this.avatarList ? this.renderDivider() : null}\n </li>\n );\n };\n\n /**\n * Render the text of the list item\n * @param {MenuItem} item the list item\n * @returns {HTMLElement | string} the text for the list item\n */\n private renderText = (item: MenuItem) => {\n if (this.isSimpleItem(item)) {\n return (\n <span class=\"mdc-deprecated-list-item__text\">{item.text}</span>\n );\n }\n\n return (\n <div class=\"mdc-deprecated-list-item__text\">\n <div class=\"mdc-deprecated-list-item__primary-command-text\">\n <div class=\"mdc-deprecated-list-item__primary-text\">\n {item.text}\n </div>\n {this.renderCommandText(item)}\n </div>\n <div class=\"mdc-deprecated-list-item__secondary-text\">\n {item.secondaryText}\n </div>\n </div>\n );\n };\n\n private renderCommandText = (item: MenuItem) => {\n if (!('commandText' in item)) {\n return;\n }\n\n return (\n <div class=\"mdc-deprecated-list-item__command-text\">\n {item.commandText}\n </div>\n );\n };\n\n private isSimpleItem = (item: MenuItem): boolean => {\n if ('commandText' in item) {\n return false;\n }\n\n return !('secondaryText' in item);\n };\n\n /**\n * Render an icon for a list item\n * @param {MenuListRendererConfig} config the config object, passed on from the `renderMenuItem` function\n * @param {MenuItem} item the list item\n * @returns {HTMLElement} the icon element\n */\n private renderIcon = (config: MenuListRendererConfig, item: MenuItem) => {\n const style: any = {};\n if (item.iconColor) {\n if (config.badgeIcons) {\n style['--icon-background-color'] = item.iconColor;\n } else {\n style.color = item.iconColor;\n }\n }\n\n return (\n <limel-icon\n badge={config.badgeIcons}\n class=\"mdc-deprecated-list-item__graphic\"\n name={item.icon}\n style={style}\n size={config.iconSize}\n />\n );\n };\n\n private renderNotification = (item: MenuItem) => {\n if (item.badge !== undefined) {\n return <limel-badge label={item.badge} />;\n }\n };\n\n private renderDivider = () => {\n const classes = {\n 'mdc-deprecated-list-divider': true,\n 'mdc-deprecated-list-divider--inset': true,\n };\n if (this.config.iconSize) {\n classes[this.config.iconSize] = true;\n }\n\n return <hr class={classes} />;\n };\n}\n"]}
@@ -117,7 +117,7 @@ export class MenuList {
117
117
  "mutable": false,
118
118
  "complexType": {
119
119
  "original": "Array<MenuItem | ListSeparator>",
120
- "resolved": "(MenuItem<any> | ListSeparator)[]",
120
+ "resolved": "any[]",
121
121
  "references": {
122
122
  "Array": {
123
123
  "location": "global"
@@ -180,11 +180,11 @@ export class MenuList {
180
180
  "defaultValue": "'small'"
181
181
  },
182
182
  "type": {
183
- "type": "string",
183
+ "type": "any",
184
184
  "mutable": false,
185
185
  "complexType": {
186
186
  "original": "MenuListType",
187
- "resolved": "\"menu\"",
187
+ "resolved": "MenuListType",
188
188
  "references": {
189
189
  "MenuListType": {
190
190
  "location": "import",
@@ -234,7 +234,7 @@ export class MenuList {
234
234
  },
235
235
  "complexType": {
236
236
  "original": "MenuItem",
237
- "resolved": "MenuItem<any>",
237
+ "resolved": "MenuItem",
238
238
  "references": {
239
239
  "MenuItem": {
240
240
  "location": "import",
@@ -255,3 +255,4 @@ export class MenuList {
255
255
  }];
256
256
  }
257
257
  }
258
+ //# sourceMappingURL=menu-list.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"menu-list.js","sourceRoot":"","sources":["../../../src/components/menu-list/menu-list.tsx"],"names":[],"mappings":"AAOA,OAAO,EAAE,OAAO,EAAoB,MAAM,gBAAgB,CAAC;AAC3D,OAAO,EAAE,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC7C,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAClE,OAAO,EAAE,OAAO,IAAI,WAAW,EAAE,MAAM,0BAA0B,CAAC;AAClE,OAAO,EACH,SAAS,EACT,OAAO,EACP,KAAK,EAEL,CAAC,EACD,IAAI,EACJ,KAAK,GACR,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,gBAAgB,EAAE,MAAM,sBAAsB,CAAC;AAGxD,MAAM,EAAE,YAAY,EAAE,GAAG,WAAW,CAAC;AACrC,MAAM,EAAE,cAAc,EAAE,GAAG,WAAW,CAAC;AAEvC;;GAEG;AAMH,MAAM,OAAO,QAAQ;;IAwCT,qBAAgB,GAAG,IAAI,gBAAgB,EAAE,CAAC;IAoD1C,UAAK,GAAG,GAAG,EAAE;MACjB,IAAI,CAAC,SAAS,EAAE,CAAC;MACjB,IAAI,CAAC,cAAc,EAAE,CAAC;IAC1B,CAAC,CAAC;IAEM,cAAS,GAAG,GAAG,EAAE;MACrB,MAAM,OAAO,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,aAAa,CAAC,WAAW,CAAC,CAAC;MACnE,IAAI,CAAC,OAAO,EAAE;QACV,OAAO;OACV;MAED,IAAI,CAAC,OAAO,GAAG,IAAI,OAAO,CAAC,OAAO,CAAC,CAAC;MACpC,IAAI,CAAC,OAAO,CAAC,YAAY,GAAG,IAAI,CAAC;MACjC,IAAI,CAAC,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC;MAC9B,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,SAAS,CAAC,IAAI,CAAC,CAAC,CAAC;IAC9D,CAAC,CAAC;IAEM,mBAAc,GAAG,GAAG,EAAE;MAC1B,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;QACf,OAAO;OACV;MAED,IAAI,CAAC,OAAO,CAAC,QAAQ,CAAC,cAAc,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;MAC7D,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,cAAc,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;IAC/D,CAAC,CAAC;IAEM,aAAQ,GAAG,GAAG,EAAE;;MACpB,MAAA,IAAI,CAAC,OAAO,0CAAE,QAAQ,CAAC,YAAY,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;MACxD,MAAA,IAAI,CAAC,OAAO,0CAAE,OAAO,EAAE,CAAC;MAExB,MAAA,IAAI,CAAC,OAAO,0CAAE,QAAQ,CAAC,cAAc,EAAE,IAAI,CAAC,gBAAgB,CAAC,CAAC;MAC9D,MAAA,IAAI,CAAC,OAAO,0CAAE,OAAO,EAAE,CAAC;IAC5B,CAAC,CAAC;IAEM,iBAAY,GAAG,CAAC,KAAyB,EAAE,EAAE;MACjD,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAChD,CAAC,CAAC;IAEM,qBAAgB,GAAG,CAAC,KAAuB,EAAE,EAAE;MACnD,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;IAChD,CAAC,CAAC;IAEM,uBAAkB,GAAG,CAAC,KAAa,EAAE,EAAE;MAC3C,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAe,CAAC;MACnE,IAAI,SAAS,CAAC,KAAK,CAAC,CAAC,QAAQ,EAAE;QAC3B,OAAO;OACV;MAED,MAAM,YAAY,GAAa,SAAS,CAAC,IAAI,CAAC,CAAC,IAAc,EAAE,EAAE;QAC7D,OAAO,CAAC,CAAC,IAAI,CAAC,QAAQ,CAAC;MAC3B,CAAC,CAAC,CAAC;MAEH,IAAI,YAAY,EAAE;QACd,IAAI,CAAC,MAAM,CAAC,IAAI,iCAAM,YAAY,KAAE,QAAQ,EAAE,KAAK,IAAG,CAAC;OAC1D;MAED,IAAI,SAAS,CAAC,KAAK,CAAC,KAAK,YAAY,EAAE;QACnC,IAAI,CAAC,MAAM,CAAC,IAAI,iCAAM,SAAS,CAAC,KAAK,CAAC,KAAE,QAAQ,EAAE,KAAK,IAAG,CAAC;OAC9D;IACL,CAAC,CAAC;IAEM,eAAU,GAAG,CAAC,IAAc,EAAW,EAAE;MAC7C,OAAO,CAAC,CAAC,WAAW,IAAI,IAAI,CAAC,CAAC;IAClC,CAAC,CAAC;;;oBA1I0B,OAAO;;iCAiBK,CAAC;;EAgBlC,iBAAiB;IACpB,IAAI,CAAC,KAAK,EAAE,CAAC;EACjB,CAAC;EAEM,oBAAoB;IACvB,IAAI,CAAC,QAAQ,EAAE,CAAC;EACpB,CAAC;EAEM,gBAAgB;IACnB,IAAI,CAAC,KAAK,EAAE,CAAC;EACjB,CAAC;EAEM,MAAM;IACT,IAAI,CAAC,MAAM,GAAG;MACV,UAAU,EAAE,IAAI,CAAC,UAAU;MAC3B,IAAI,EAAE,IAAI,CAAC,IAAI;MACf,QAAQ,EAAE,IAAI,CAAC,QAAQ;KAC1B,CAAC;IAEF,MAAM,IAAI,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,CAAC;IAEnE,OAAO,WAAK,KAAK,EAAC,2BAA2B,IAAE,IAAI,CAAO,CAAC;EAC/D,CAAC;EAGS,UAAU;IAChB,IAAI,CAAC,cAAc,EAAE,CAAC;EAC1B,CAAC;EAGS,YAAY;IAClB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;MACf,OAAO;KACV;IAED,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;IAErD,IAAI,CAAC,OAAO,CAAC,aAAa,GAAG,SAAS,CAAC,SAAS,CAC5C,CAAC,IAAc,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CACpC,CAAC;EACN,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CAkEJ","sourcesContent":["import {\n IconSize,\n MenuItem,\n ListSeparator,\n MenuListType,\n} from '@limetech/lime-elements';\nimport { MDCList, MDCListActionEvent } from '@material/list';\nimport { MDCMenu, MDCMenuItemEvent } from '@material/menu';\nimport { MDCRipple } from '@material/ripple';\nimport { strings as listStrings } from '@material/list/constants';\nimport { strings as menuStrings } from '@material/menu/constants';\nimport {\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Prop,\n Watch,\n} from '@stencil/core';\nimport { MenuListRenderer } from './menu-list-renderer';\nimport { MenuListRendererConfig } from './menu-list-renderer-config';\n\nconst { ACTION_EVENT } = listStrings;\nconst { SELECTED_EVENT } = menuStrings;\n\n/**\n * @private\n */\n@Component({\n tag: 'limel-menu-list',\n shadow: true,\n styleUrl: 'menu-list.scss',\n})\nexport class MenuList {\n /**\n * List of items to display\n */\n @Prop()\n public items: Array<MenuItem | ListSeparator>;\n\n /**\n * Set to `true` if the list should display larger icons with a background\n */\n @Prop()\n public badgeIcons: boolean;\n\n /**\n * Size of the icons in the list\n */\n @Prop()\n public iconSize: IconSize = 'small';\n\n /**\n * The type of the menu, omit to get a regular vertical menu.\n * Available types are:\n * `menu`: regular vertical menu.\n */\n @Prop()\n public type: MenuListType;\n\n /**\n * By default, lists will display 3 lines of text, and then truncate the rest.\n * Consumers can increase or decrease this number by specifying\n * `maxLinesSecondaryText`. If consumer enters zero or negative\n * numbers we default to 1; and if they type decimals we round up.\n */\n // eslint-disable-next-line no-magic-numbers\n @Prop() maxLinesSecondaryText: number = 3;\n\n @Element()\n private element: HTMLLimelMenuListElement;\n\n private config: MenuListRendererConfig;\n private MenuListRenderer = new MenuListRenderer();\n private mdcList: MDCList;\n private mdcMenu: MDCMenu;\n\n /**\n * Fired when a new value has been selected from the list.\n */\n @Event()\n private select: EventEmitter<MenuItem>;\n\n public connectedCallback() {\n this.setup();\n }\n\n public disconnectedCallback() {\n this.teardown();\n }\n\n public componentDidLoad() {\n this.setup();\n }\n\n public render() {\n this.config = {\n badgeIcons: this.badgeIcons,\n type: this.type,\n iconSize: this.iconSize,\n };\n\n const html = this.MenuListRenderer.render(this.items, this.config);\n\n return <div class=\"mdc-menu mdc-menu-surface\">{html}</div>;\n }\n\n @Watch('type')\n protected handleType() {\n this.setupListeners();\n }\n\n @Watch('items')\n protected itemsChanged() {\n if (!this.mdcList) {\n return;\n }\n\n const MenuItems = this.items.filter(this.isMenuItem);\n\n this.mdcList.selectedIndex = MenuItems.findIndex(\n (item: MenuItem) => item.selected\n );\n }\n\n private setup = () => {\n this.setupMenu();\n this.setupListeners();\n };\n\n private setupMenu = () => {\n const element = this.element.shadowRoot.querySelector('.mdc-menu');\n if (!element) {\n return;\n }\n\n this.mdcMenu = new MDCMenu(element);\n this.mdcMenu.hasTypeahead = true;\n this.mdcMenu.wrapFocus = true;\n this.mdcMenu.items.forEach((item) => new MDCRipple(item));\n };\n\n private setupListeners = () => {\n if (!this.mdcMenu) {\n return;\n }\n\n this.mdcMenu.unlisten(SELECTED_EVENT, this.handleMenuSelect);\n this.mdcMenu.listen(SELECTED_EVENT, this.handleMenuSelect);\n };\n\n private teardown = () => {\n this.mdcList?.unlisten(ACTION_EVENT, this.handleAction);\n this.mdcList?.destroy();\n\n this.mdcMenu?.unlisten(SELECTED_EVENT, this.handleMenuSelect);\n this.mdcMenu?.destroy();\n };\n\n private handleAction = (event: MDCListActionEvent) => {\n this.handleSingleSelect(event.detail.index);\n };\n\n private handleMenuSelect = (event: MDCMenuItemEvent) => {\n this.handleSingleSelect(event.detail.index);\n };\n\n private handleSingleSelect = (index: number) => {\n const MenuItems = this.items.filter(this.isMenuItem) as MenuItem[];\n if (MenuItems[index].disabled) {\n return;\n }\n\n const selectedItem: MenuItem = MenuItems.find((item: MenuItem) => {\n return !!item.selected;\n });\n\n if (selectedItem) {\n this.select.emit({ ...selectedItem, selected: false });\n }\n\n if (MenuItems[index] !== selectedItem) {\n this.select.emit({ ...MenuItems[index], selected: false });\n }\n };\n\n private isMenuItem = (item: MenuItem): boolean => {\n return !('separator' in item);\n };\n}\n"]}
@@ -1 +1,2 @@
1
1
  export {};
2
+ //# sourceMappingURL=menu-list.types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"menu-list.types.js","sourceRoot":"","sources":["../../../src/components/menu-list/menu-list.types.ts"],"names":[],"mappings":"","sourcesContent":["/**\n * The type of the menu, omit to get a regular vertical menu.\n * Available types are:\n * `menu`: regular vertical menu.\n */\nexport type MenuListType = 'menu';\n"]}
@@ -187,3 +187,4 @@ export class MenuSurface {
187
187
  }
188
188
  static get elementRef() { return "host"; }
189
189
  }
190
+ //# sourceMappingURL=menu-surface.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"menu-surface.js","sourceRoot":"","sources":["../../../src/components/menu-surface/menu-surface.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,MAAM,wBAAwB,CAAC;AAChE,OAAO,EACH,SAAS,EACT,OAAO,EACP,KAAK,EAEL,CAAC,EACD,IAAI,GACP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,EACH,MAAM,EACN,eAAe,EACf,GAAG,EACH,YAAY,GACf,MAAM,qBAAqB,CAAC;AAE7B;;;GAGG;AAMH,MAAM,OAAO,WAAW;;IAoDZ,UAAK,GAAG,GAAG,EAAE;MACjB,MAAM,WAAW,GACb,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,mBAAmB,CAAC,CAAC;MAC5D,IAAI,CAAC,WAAW,EAAE;QACd,OAAO;OACV;MAED,IAAI,CAAC,WAAW,GAAG,IAAI,cAAc,CAAC,WAAW,CAAC,CAAC;MACnD,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,MAAM,CAAC,SAAS,CAAC,CAAC;MAEnD,QAAQ,CAAC,gBAAgB,CAAC,WAAW,EAAE,IAAI,CAAC,mBAAmB,EAAE;QAC7D,OAAO,EAAE,IAAI;OAChB,CAAC,CAAC;MACH,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;MAC1D,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,YAAY,EAAE;QACjD,OAAO,EAAE,IAAI;OAChB,CAAC,CAAC;IACP,CAAC,CAAC;IAEM,aAAQ,GAAG,GAAG,EAAE;;MACpB,MAAA,IAAI,CAAC,WAAW,0CAAE,OAAO,EAAE,CAAC;MAC5B,QAAQ,CAAC,mBAAmB,CAAC,WAAW,EAAE,IAAI,CAAC,mBAAmB,EAAE;QAChE,OAAO,EAAE,IAAI;OAChB,CAAC,CAAC;MACH,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;MAC7D,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAAE,IAAI,CAAC,YAAY,CAAC,CAAC;IAC5D,CAAC,CAAC;IAEM,wBAAmB,GAAG,CAAC,KAAK,EAAE,EAAE;MACpC,MAAM,WAAW,GAAG,KAAK,CAAC,IAAI,IAAI,EAAE,CAAC;MAErC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE;QACZ,OAAO;OACV;MAED,IAAI,YAAY,CAAC,KAAK,CAAC,MAAM,EAAE,IAAI,CAAC,IAAI,CAAC,EAAE;QACvC,OAAO;OACV;MAED,IAAI,IAAI,CAAC,kBAAkB,EAAE;QACzB,MAAM,uBAAuB,GAAG,WAAW,CAAC,QAAQ,CAChD,IAAI,CAAC,kBAAkB,CAC1B,CAAC;QAEF,IAAI,uBAAuB,EAAE;UACzB,OAAO;SACV;OACJ;MAED,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;MACpB,IAAI,CAAC,4BAA4B,EAAE,CAAC;IACxC,CAAC,CAAC;IAEM,iBAAY,GAAG,GAAG,EAAE;MACxB,IAAI,IAAI,CAAC,IAAI,EAAE;QACX,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;OACvB;IACL,CAAC,CAAC;IAEM,iCAA4B,GAAG,GAAG,EAAE;MACxC,oFAAoF;MACpF,qFAAqF;MACrF,6FAA6F;MAC7F,0FAA0F;MAC1F,gDAAgD;MAChD,QAAQ,CAAC,gBAAgB,CAAC,OAAO,EAAE,IAAI,CAAC,SAAS,EAAE;QAC/C,OAAO,EAAE,IAAI;QACb,IAAI,EAAE,IAAI;OACb,CAAC,CAAC;MACH,uDAAuD;MACvD,QAAQ,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,SAAS,EAAE;QACjD,OAAO,EAAE,IAAI;QACb,IAAI,EAAE,IAAI;OACb,CAAC,CAAC;MACH,kFAAkF;MAClF,uEAAuE;MACvE,mFAAmF;MACnF,QAAQ,CAAC,gBAAgB,CACrB,SAAS,EACT,GAAG,EAAE;QACD,QAAQ,CAAC,mBAAmB,CAAC,OAAO,EAAE,IAAI,CAAC,SAAS,EAAE;UAClD,OAAO,EAAE,IAAI;SAChB,CAAC,CAAC;MACP,CAAC,EACD;QACI,IAAI,EAAE,IAAI;OACb,CACJ,CAAC;IACN,CAAC,CAAC;IAEM,cAAS,GAAG,CAAC,KAAK,EAAE,EAAE;MAC1B,KAAK,CAAC,eAAe,EAAE,CAAC;MACxB,KAAK,CAAC,cAAc,EAAE,CAAC;IAC3B,CAAC,CAAC;IAEM,kBAAa,GAAG,CAAC,KAAoB,EAAE,EAAE;MAC7C,MAAM,QAAQ,GACV,KAAK,CAAC,GAAG,KAAK,MAAM,IAAI,KAAK,CAAC,OAAO,KAAK,eAAe,CAAC;MAC9D,MAAM,KAAK,GAAG,KAAK,CAAC,GAAG,KAAK,GAAG,IAAI,KAAK,CAAC,OAAO,KAAK,YAAY,CAAC;MAElE,IAAI,IAAI,CAAC,IAAI,IAAI,CAAC,QAAQ,IAAI,KAAK,CAAC,EAAE;QAClC,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;OACvB;IACL,CAAC,CAAC;gBAvJY,KAAK;;;EAmBZ,iBAAiB;IACpB,IAAI,CAAC,KAAK,EAAE,CAAC;EACjB,CAAC;EAEM,oBAAoB;IACvB,IAAI,CAAC,QAAQ,EAAE,CAAC;EACpB,CAAC;EAEM,gBAAgB;IACnB,IAAI,CAAC,KAAK,EAAE,CAAC;EACjB,CAAC;EAEM,MAAM;IACT,MAAM,SAAS,GAAG;MACd,UAAU,EAAE,IAAI;MAChB,kBAAkB,EAAE,IAAI;MACxB,wBAAwB,EAAE,IAAI,CAAC,IAAI;MACnC,0BAA0B,EAAE,IAAI;MAChC,mBAAmB,EAAE,IAAI;KAC5B,CAAC;IAEF,OAAO,CACH,WAAK,KAAK,EAAE,SAAS,EAAE,QAAQ,EAAC,IAAI;MAChC,eAAQ,CACN,CACT,CAAC;EACN,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CA2GJ","sourcesContent":["import { Corner, MDCMenuSurface } from '@material/menu-surface';\nimport {\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Prop,\n} from '@stencil/core';\nimport { isDescendant } from '../../util/dom';\nimport {\n ESCAPE,\n ESCAPE_KEY_CODE,\n TAB,\n TAB_KEY_CODE,\n} from '../../util/keycodes';\n\n/**\n * @slot - Content to put inside the surface\n * @private\n */\n@Component({\n tag: 'limel-menu-surface',\n shadow: true,\n styleUrl: 'menu-surface.scss',\n})\nexport class MenuSurface {\n /**\n * True if the menu surface is open, false otherwise\n */\n @Prop()\n public open = false;\n\n /**\n * Clicks in this element should not be prevented when the menu surface is open\n */\n @Prop()\n public allowClicksElement: HTMLElement;\n\n /**\n * Emitted when the menu surface is dismissed and should be closed\n */\n @Event()\n public dismiss: EventEmitter<void>;\n\n @Element()\n private host: HTMLLimelMenuSurfaceElement;\n\n private menuSurface: MDCMenuSurface;\n\n public connectedCallback() {\n this.setup();\n }\n\n public disconnectedCallback() {\n this.teardown();\n }\n\n public componentDidLoad() {\n this.setup();\n }\n\n public render() {\n const classList = {\n 'mdc-menu': true,\n 'mdc-menu-surface': true,\n 'mdc-menu-surface--open': this.open,\n 'mdc-elevation-transition': true,\n 'mdc-elevation--z4': true,\n };\n\n return (\n <div class={classList} tabindex=\"-1\">\n <slot />\n </div>\n );\n }\n\n private setup = () => {\n const menuElement: HTMLElement =\n this.host.shadowRoot.querySelector('.mdc-menu-surface');\n if (!menuElement) {\n return;\n }\n\n this.menuSurface = new MDCMenuSurface(menuElement);\n this.menuSurface.setAnchorCorner(Corner.TOP_START);\n\n document.addEventListener('mousedown', this.handleDocumentClick, {\n capture: true,\n });\n this.host.addEventListener('keydown', this.handleKeyDown);\n window.addEventListener('resize', this.handleResize, {\n passive: true,\n });\n };\n\n private teardown = () => {\n this.menuSurface?.destroy();\n document.removeEventListener('mousedown', this.handleDocumentClick, {\n capture: true,\n });\n this.host.removeEventListener('keydown', this.handleKeyDown);\n window.removeEventListener('resize', this.handleResize);\n };\n\n private handleDocumentClick = (event) => {\n const elementPath = event.path || [];\n\n if (!this.open) {\n return;\n }\n\n if (isDescendant(event.target, this.host)) {\n return;\n }\n\n if (this.allowClicksElement) {\n const clickedInAllowedElement = elementPath.includes(\n this.allowClicksElement\n );\n\n if (clickedInAllowedElement) {\n return;\n }\n }\n\n this.dismiss.emit();\n this.preventClickEventPropagation();\n };\n\n private handleResize = () => {\n if (this.open) {\n this.dismiss.emit();\n }\n };\n\n private preventClickEventPropagation = () => {\n // When the menu surface is open, we want to stop the `click` event from propagating\n // when clicking outside the surface itself. This is to prevent any dialog that might\n // be open from closing, etc. However, when dragging a scrollbar no `click` event is emitted,\n // only mousedown and mouseup. So we listen for `mousedown` and attach a one-time listener\n // for `click`, so we can capture and \"kill\" it.\n document.addEventListener('click', this.stopEvent, {\n capture: true,\n once: true,\n });\n // We also capture and \"kill\" the next `mouseup` event.\n document.addEventListener('mouseup', this.stopEvent, {\n capture: true,\n once: true,\n });\n // If the user dragged the scrollbar, no `click` event happens. So when we get the\n // `mouseup` event, remove the handler for `click` if it's still there.\n // Otherwise, we would catch the next click even though the menu is no longer open.\n document.addEventListener(\n 'mouseup',\n () => {\n document.removeEventListener('click', this.stopEvent, {\n capture: true,\n });\n },\n {\n once: true,\n }\n );\n };\n\n private stopEvent = (event) => {\n event.stopPropagation();\n event.preventDefault();\n };\n\n private handleKeyDown = (event: KeyboardEvent) => {\n const isEscape =\n event.key === ESCAPE || event.keyCode === ESCAPE_KEY_CODE;\n const isTab = event.key === TAB || event.keyCode === TAB_KEY_CODE;\n\n if (this.open && (isEscape || isTab)) {\n event.stopPropagation();\n this.dismiss.emit();\n }\n };\n}\n"]}
@@ -1 +1,2 @@
1
1
  export {};
2
+ //# sourceMappingURL=actions.types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"actions.types.js","sourceRoot":"","sources":["../../../src/components/picker/actions.types.ts"],"names":[],"mappings":"","sourcesContent":["export type ActionPosition = 'top' | 'bottom';\nexport type ActionScrollBehavior = 'sticky' | 'scroll';\n"]}
@@ -540,11 +540,11 @@ export class Picker {
540
540
  "defaultValue": "false"
541
541
  },
542
542
  "value": {
543
- "type": "unknown",
543
+ "type": "any",
544
544
  "mutable": false,
545
545
  "complexType": {
546
546
  "original": "ListItem<number | string> | Array<ListItem<number | string>>",
547
- "resolved": "ListItem<string | number> | ListItem<string | number>[]",
547
+ "resolved": "any",
548
548
  "references": {
549
549
  "ListItem": {
550
550
  "location": "import",
@@ -560,14 +560,16 @@ export class Picker {
560
560
  "docs": {
561
561
  "tags": [],
562
562
  "text": "Currently selected value or values"
563
- }
563
+ },
564
+ "attribute": "value",
565
+ "reflect": false
564
566
  },
565
567
  "searcher": {
566
- "type": "unknown",
568
+ "type": "any",
567
569
  "mutable": false,
568
570
  "complexType": {
569
571
  "original": "Searcher",
570
- "resolved": "(query: string) => Promise<ListItem<any>[]>",
572
+ "resolved": "Searcher",
571
573
  "references": {
572
574
  "Searcher": {
573
575
  "location": "import",
@@ -580,7 +582,9 @@ export class Picker {
580
582
  "docs": {
581
583
  "tags": [],
582
584
  "text": "A search function that takes a search-string as an argument,\nand returns a promise that will eventually be resolved with\nan array of `ListItem`:s.\n\nSee the docs for the type `Searcher` for type information on\nthe searcher function itself."
583
- }
585
+ },
586
+ "attribute": "searcher",
587
+ "reflect": false
584
588
  },
585
589
  "multiple": {
586
590
  "type": "boolean",
@@ -733,7 +737,7 @@ export class Picker {
733
737
  },
734
738
  "complexType": {
735
739
  "original": "ListItem<number | string> | Array<ListItem<number | string>>",
736
- "resolved": "ListItem<string | number> | ListItem<string | number>[]",
740
+ "resolved": "any",
737
741
  "references": {
738
742
  "ListItem": {
739
743
  "location": "import",
@@ -797,3 +801,4 @@ export class Picker {
797
801
  }];
798
802
  }
799
803
  }
804
+ //# sourceMappingURL=picker.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"picker.js","sourceRoot":"","sources":["../../../src/components/picker/picker.tsx"],"names":[],"mappings":"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","sourcesContent":["import {\n Action,\n Chip,\n LimelChipSetCustomEvent,\n LimelListCustomEvent,\n ListItem,\n Searcher,\n} from '@limetech/lime-elements';\nimport {\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Prop,\n State,\n Watch,\n} from '@stencil/core';\nimport AwesomeDebouncePromise from 'awesome-debounce-promise';\nimport { isDescendant } from '../../util/dom';\nimport {\n ARROW_DOWN,\n ARROW_DOWN_KEY_CODE,\n ARROW_UP,\n ARROW_UP_KEY_CODE,\n ENTER,\n ENTER_KEY_CODE,\n ESCAPE,\n ESCAPE_KEY_CODE,\n TAB,\n TAB_KEY_CODE,\n} from '../../util/keycodes';\nimport { createRandomString } from '../../util/random-string';\nimport { ActionScrollBehavior, ActionPosition } from './actions.types';\n\nconst SEARCH_DEBOUNCE = 500;\nconst CHIP_SET_TAG_NAME = 'limel-chip-set';\n\n/**\n * @exampleComponent limel-example-picker-single\n * @exampleComponent limel-example-picker-multiple\n * @exampleComponent limel-example-picker-icons\n * @exampleComponent limel-example-picker-empty-suggestions\n * @exampleComponent limel-example-picker-leading-icon\n * @exampleComponent limel-example-picker-static-actions\n * @exampleComponent limel-example-picker-composite\n */\n@Component({\n tag: 'limel-picker',\n shadow: true,\n styleUrl: 'picker.scss',\n})\nexport class Picker {\n /**\n * True if the picker should be disabled\n */\n @Prop()\n public disabled: boolean = false;\n\n /**\n * Set to `true` to disable adding and removing items,\n * but allow interaction with existing items.\n */\n @Prop({ reflect: true })\n public readonly: boolean = false;\n\n /**\n * Text to display for the input field of the picker\n */\n @Prop()\n public label: string;\n\n /**\n * Search label to display in the input field when searching\n */\n @Prop()\n public searchLabel: string;\n\n /**\n * Optional helper text to display below the input field when it has focus\n */\n @Prop({ reflect: true })\n public helperText: string;\n\n /**\n * Leading icon to show to the far left in the text field\n */\n @Prop()\n public leadingIcon: string;\n\n /**\n * A message to display when the search returned an empty result\n */\n @Prop()\n public emptyResultMessage: string;\n\n /**\n * True if the control requires a value\n */\n @Prop()\n public required: boolean = false;\n\n /**\n * Currently selected value or values\n */\n @Prop()\n public value: ListItem<number | string> | Array<ListItem<number | string>>;\n\n /**\n * A search function that takes a search-string as an argument,\n * and returns a promise that will eventually be resolved with\n * an array of `ListItem`:s.\n *\n * See the docs for the type `Searcher` for type information on\n * the searcher function itself.\n */\n @Prop()\n public searcher: Searcher;\n\n /**\n * True if multiple values are allowed\n */\n @Prop()\n public multiple: boolean = false;\n\n /**\n * Sets delimiters between chips. Works only when `multiple` is `true`.\n */\n @Prop({ reflect: true })\n public delimiter: string = null;\n\n /**\n * Static actions that can be clicked by the user.\n */\n @Prop()\n public actions: Array<ListItem<Action>> = [];\n\n /**\n * Position of the custom static actions in the picker's results dropdown.\n * Can be set to `'top'` or `'bottom'`.\n */\n @Prop()\n public actionPosition: ActionPosition = 'bottom';\n\n /**\n * Scroll behavior of the custom static actions, when user scrolls\n * in the picker's results dropdown. Can be set to `'scroll'` which means\n * the action items will scroll together with the list, or `'sticky'` which\n * retains their position at the top or bottom of the drop down while\n * scrolling.\n */\n @Prop()\n public actionScrollBehavior: ActionScrollBehavior = 'sticky';\n\n /**\n * Whether badge icons should be used in the result list or not\n */\n @Prop({ reflect: true })\n public badgeIcons: boolean = true;\n\n /**\n * Fired when a new value has been selected from the picker\n */\n @Event()\n private change: EventEmitter<\n ListItem<number | string> | Array<ListItem<number | string>>\n >;\n\n /**\n * Fired when clicking on a selected value\n */\n @Event()\n private interact: EventEmitter<ListItem<number | string>>;\n\n /**\n * Emitted when the user selects an action.\n */\n @Event()\n private action: EventEmitter<Action>;\n\n @State()\n private items: Array<ListItem<number | string>>;\n\n @State()\n private textValue: string = '';\n\n @State()\n private loading: boolean = false;\n\n @State()\n private chips: Chip[] = [];\n\n @Element()\n private host: HTMLLimelPickerElement;\n\n // Should NOT be decorated with State(), since this\n // should not trigger a re-render by itself.\n private chipSetEditMode = false;\n\n private debouncedSearch: Searcher;\n private chipSet: HTMLLimelChipSetElement;\n private portalId: string;\n\n constructor() {\n this.handleTextInput = this.handleTextInput.bind(this);\n this.handleInputKeyDown = this.handleInputKeyDown.bind(this);\n this.handleDropdownKeyDown = this.handleDropdownKeyDown.bind(this);\n this.handleInputFieldFocus = this.handleInputFieldFocus.bind(this);\n this.handleChange = this.handleChange.bind(this);\n this.handleInteract = this.handleInteract.bind(this);\n this.handleListChange = this.handleListChange.bind(this);\n this.handleActionListChange = this.handleActionListChange.bind(this);\n this.handleStopEditAndBlur = this.handleStopEditAndBlur.bind(this);\n this.createDebouncedSearcher = this.createDebouncedSearcher.bind(this);\n this.handleCloseMenu = this.handleCloseMenu.bind(this);\n this.onListKeyDown = this.onListKeyDown.bind(this);\n\n this.portalId = createRandomString();\n }\n\n public componentWillLoad() {\n this.chips = this.createChips(this.value);\n }\n\n public componentDidLoad() {\n this.createDebouncedSearcher(this.searcher);\n this.chipSet = this.host.shadowRoot.querySelector(CHIP_SET_TAG_NAME);\n }\n\n public async componentWillUpdate() {\n this.chipSetEditMode = false;\n if (this.chipSet) {\n this.chipSetEditMode = await this.chipSet.getEditMode();\n }\n }\n\n public render() {\n this.chips.forEach((chip: Chip) => {\n if ('iconBackgroundColor' in chip && !!chip.iconBackgroundColor) {\n chip.iconFillColor = 'rgb(var(--color-white))';\n }\n });\n\n const props: {\n maxItems?: number;\n } = {};\n\n if (!this.multiple) {\n props.maxItems = 1;\n }\n\n return [\n <limel-chip-set\n type=\"input\"\n inputType=\"search\"\n label={this.label}\n helperText={this.helperText}\n leadingIcon={this.leadingIcon}\n value={this.chips}\n disabled={this.disabled}\n delimiter={this.renderDelimiter()}\n readonly={this.readonly}\n required={this.required}\n searchLabel={this.searchLabel}\n onInput={this.handleTextInput}\n onKeyDown={this.handleInputKeyDown}\n onChange={this.handleChange}\n onInteract={this.handleInteract}\n onStartEdit={this.handleInputFieldFocus}\n onStopEdit={this.handleStopEditAndBlur}\n emptyInputOnBlur={false}\n clearAllButton={this.multiple}\n {...props}\n />,\n this.renderDropdown(),\n ];\n }\n\n @Watch('value')\n protected onChangeValue() {\n this.chips = this.createChips(this.value);\n }\n\n @Watch('searcher')\n protected createDebouncedSearcher(newValue: Searcher) {\n if (typeof newValue !== 'function') {\n return;\n }\n\n this.debouncedSearch = AwesomeDebouncePromise(\n newValue,\n SEARCH_DEBOUNCE\n );\n }\n\n private renderDelimiter() {\n if (this.multiple) {\n return this.delimiter;\n }\n\n return null;\n }\n\n private createChips(value: ListItem | ListItem[]): Chip[] {\n if (!value) {\n return [];\n }\n\n if (this.multiple) {\n const listItems: ListItem[] = value as ListItem[];\n\n return listItems.map(this.createChip);\n }\n\n const listItem: ListItem = value as ListItem;\n\n return [this.createChip(listItem)];\n }\n\n private createChip(listItem: ListItem): Chip {\n return {\n id: `${listItem.value}`,\n text: listItem.text,\n removable: true,\n icon: listItem.icon,\n iconBackgroundColor: listItem.iconColor,\n value: listItem,\n };\n }\n\n /**\n * Renders the dropdown with the items to pick from, or a spinner if the picker\n * is waiting for items to be received\n * @returns {HTMLElement} picker dropdown\n */\n private renderDropdown() {\n const dropDownContent = this.getDropdownContent();\n\n const content = [];\n\n if (this.shouldShowDropDownContent()) {\n const actionContent = this.getActionContent();\n if (this.actionPosition === 'top') {\n content.push(actionContent);\n }\n\n if (dropDownContent) {\n content.push(dropDownContent);\n }\n\n if (this.actionPosition === 'bottom') {\n content.push(actionContent);\n }\n }\n\n return this.renderPortal(content);\n }\n\n private getActionContent() {\n const actionCount = this.actions?.length ?? 0;\n if (actionCount === 0) {\n return null;\n }\n\n return [\n <limel-list\n class={{\n 'static-actions-list': true,\n 'is-on-top': this.actionPosition === 'top',\n 'is-at-bottom': this.actionPosition === 'bottom',\n 'has-position-sticky':\n this.actionScrollBehavior === 'sticky',\n }}\n badgeIcons={true}\n type={'selectable'}\n onChange={this.handleActionListChange}\n items={this.actions.map(this.removeUnusedPropertiesOnAction)}\n />,\n ];\n }\n\n private removeUnusedPropertiesOnAction(\n action: ListItem<Action>\n ): ListItem<Action> {\n return {\n ...action,\n actions: [],\n };\n }\n\n private shouldShowDropDownContent() {\n if (this.isFull()) {\n return false;\n }\n\n return !!this.chipSetEditMode;\n }\n\n private getDropdownContent() {\n if (!this.shouldShowDropDownContent()) {\n return;\n }\n\n if (this.loading) {\n return this.renderSpinner();\n }\n\n if (!this.items || !this.items.length) {\n return this.renderEmptyMessage();\n }\n\n return this.renderListResult();\n }\n\n /**\n * Returns true if the picker is \"full\"\n * The picker is considered to be full if it has a value and only one is allowed\n * @returns {boolean} true if the picker is full\n */\n private isFull(): boolean {\n return !this.multiple && !!this.value;\n }\n\n private renderSpinner() {\n return (\n <div\n style={{\n width: '100%',\n display: 'flex',\n 'align-items': 'center',\n 'justify-content': 'center',\n padding: '1rem 0',\n }}\n >\n <limel-spinner limeBranded={false} />\n </div>\n );\n }\n\n private renderEmptyMessage() {\n if (!this.emptyResultMessage) {\n return;\n }\n\n const style = {\n color: 'rgb(var(--contrast-1100))',\n 'text-align': 'center',\n margin: '0.5rem 1rem',\n };\n\n return <p style={style}>{this.emptyResultMessage}</p>;\n }\n\n private renderListResult() {\n const hasIcons = this.items.some((item) => {\n return 'icon' in item && !!item.icon;\n });\n\n return (\n <limel-list\n badgeIcons={hasIcons && this.badgeIcons}\n onChange={this.handleListChange}\n onKeyDown={this.onListKeyDown}\n type=\"selectable\"\n items={this.items}\n />\n );\n }\n\n private onListKeyDown(event: KeyboardEvent) {\n const keyFound = [TAB, ESCAPE, ENTER].includes(event.key);\n const keyCodeFound = [\n TAB_KEY_CODE,\n ESCAPE_KEY_CODE,\n ENTER_KEY_CODE,\n ].includes(event.keyCode);\n if (keyFound || keyCodeFound) {\n this.chipSet.setFocus();\n }\n }\n\n private renderPortal(content: any[] = []) {\n const dropdownZIndex = getComputedStyle(this.host).getPropertyValue(\n '--dropdown-z-index'\n );\n\n return (\n <limel-portal\n visible={content.length > 0}\n containerId={this.portalId}\n inheritParentWidth={true}\n containerStyle={{ 'z-index': dropdownZIndex }}\n >\n <limel-menu-surface\n open={content.length > 0}\n allowClicksElement={this.host}\n style={{\n '--mdc-menu-min-width': '100%',\n 'max-height': 'inherit',\n display: 'flex',\n }}\n onDismiss={this.handleCloseMenu}\n >\n {content}\n </limel-menu-surface>\n </limel-portal>\n );\n }\n\n /**\n * Check if a descendant still has focus. If not, reset text value and search result.\n * @returns {void}\n */\n private handleStopEditAndBlur() {\n // In browsers where shadow DOM is not supported activeElement on shadowRoot will return null\n // However, document.activeElement will return the actual focused element instead of the outermost shadow host\n const element =\n this.host.shadowRoot.activeElement || document.activeElement;\n const portalElement = document.querySelector(`#${this.portalId}`);\n if (\n isDescendant(element as HTMLElement, this.host) ||\n isDescendant(element as HTMLElement, portalElement as HTMLElement)\n ) {\n return;\n }\n\n this.clearInputField();\n }\n\n /**\n * Input handler for the input field\n * @param {InputEvent} event event\n * @returns {void}\n */\n private async handleTextInput(event) {\n event.stopPropagation();\n\n const query = event.detail;\n this.textValue = query;\n this.loading = true;\n\n // If the search-query is an empty string, bypass debouncing.\n const searchFn = query === '' ? this.searcher : this.debouncedSearch;\n const result = await searchFn(query);\n this.handleSearchResult(query, result);\n }\n\n /**\n * Change handler for the list\n * @param {LimelListCustomEvent<ListItem>} event event\n * @returns {void}\n */\n private handleListChange(event: LimelListCustomEvent<ListItem>) {\n event.stopPropagation();\n if (!this.value || this.value !== event.detail) {\n let newValue: ListItem | ListItem[] = event.detail;\n if (this.multiple) {\n newValue = [...(this.value as ListItem[]), event.detail];\n }\n\n this.change.emit(newValue);\n this.items = [];\n }\n\n if (this.multiple) {\n this.chipSet?.setFocus(true);\n }\n }\n\n /**\n * Change handler for the list\n * @param {LimelChipSetCustomEvent} event event\n * @returns {void}\n */\n private handleActionListChange(\n event: LimelListCustomEvent<ListItem<Action>>\n ) {\n event.stopPropagation();\n if (!event.detail) {\n return;\n }\n\n this.action.emit(event.detail.value);\n this.items = [];\n }\n\n /**\n * Focus handler for the chip set\n * Prevent focus if the picker has a value and does not support multiple values\n * @returns {void}\n */\n private async handleInputFieldFocus() {\n this.loading = true;\n const query = this.textValue;\n const result = await this.searcher(query);\n this.handleSearchResult(query, result);\n }\n\n private handleChange(event: LimelChipSetCustomEvent<Chip | Chip[]>) {\n event.stopPropagation();\n\n let newValue = null;\n if (this.multiple) {\n const chips = event.detail as Chip[];\n newValue = chips.map((chip) => {\n return (this.value as ListItem[]).find((item) => {\n return `${item.value}` === chip.id;\n });\n });\n }\n\n this.change.emit(newValue);\n }\n\n private handleInteract(event: LimelChipSetCustomEvent<Chip>) {\n event.stopPropagation();\n this.interact.emit(event.detail ? event.detail.value : event.detail);\n }\n\n /**\n * Key handler for the input field\n * Will change focus to the first/last item in the dropdown list to enable selection with the keyboard\n * @param {KeyboardEvent} event event\n * @returns {void}\n */\n private handleInputKeyDown(event: KeyboardEvent) {\n const isForwardTab =\n (event.key === TAB || event.keyCode === TAB_KEY_CODE) &&\n !event.altKey &&\n !event.metaKey &&\n !event.shiftKey;\n const isUp =\n event.key === ARROW_UP || event.keyCode === ARROW_UP_KEY_CODE;\n const isDown =\n event.key === ARROW_DOWN || event.keyCode === ARROW_DOWN_KEY_CODE;\n\n if (!isForwardTab && !isUp && !isDown) {\n return;\n }\n\n const list = document.querySelector(` #${this.portalId} limel-list`);\n if (!list) {\n return;\n }\n\n event.preventDefault();\n\n if (isForwardTab || isDown) {\n const listElement: HTMLElement = list.shadowRoot.querySelector(\n '.mdc-deprecated-list-item:first-child'\n );\n listElement.focus();\n\n return;\n }\n\n if (isUp) {\n const listElement: HTMLElement = list.shadowRoot.querySelector(\n '.mdc-deprecated-list-item:last-child'\n );\n listElement.focus();\n }\n }\n\n /**\n * Key handler for the dropdown\n * @param {KeyboardEvent} event event\n * @returns {void}\n */\n private handleDropdownKeyDown(event: KeyboardEvent) {\n const isEscape =\n event.key === ESCAPE || event.keyCode === ESCAPE_KEY_CODE;\n\n if (isEscape) {\n event.preventDefault();\n this.textValue = '';\n this.chipSet.setFocus(true);\n }\n }\n\n private handleSearchResult(query: string, result: ListItem[]) {\n if (query === this.textValue) {\n this.items = result;\n if (this.multiple) {\n const values = this.value as ListItem[];\n this.items = result.filter((item) => {\n return !values.includes(item);\n });\n }\n\n this.loading = false;\n }\n }\n\n private handleCloseMenu() {\n if (this.items.length > 0) {\n return;\n }\n\n this.clearInputField();\n }\n\n private clearInputField() {\n this.chipSet.emptyInput();\n this.textValue = '';\n this.handleSearchResult('', []);\n }\n}\n"]}
@@ -1 +1,2 @@
1
1
  export {};
2
+ //# sourceMappingURL=searcher.types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"searcher.types.js","sourceRoot":"","sources":["../../../src/components/picker/searcher.types.ts"],"names":[],"mappings":"","sourcesContent":["import { ListItem } from '../list/list-item.types';\n\n/**\n * A search function that takes a search-string as an argument, and returns\n * a promise that will eventually be resolved with an array of `ListItem`:s.\n * @param {string} query A search query. Typically what the user has written\n * in the input field of a limel-picker.\n * @returns {Promise<ListItem[]>} The search result.\n */\nexport type Searcher = (query: string) => Promise<ListItem[]>;\n"]}
@@ -193,3 +193,4 @@ export class Popover {
193
193
  }];
194
194
  }
195
195
  }
196
+ //# sourceMappingURL=popover.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"popover.js","sourceRoot":"","sources":["../../../src/components/popover/popover.tsx"],"names":[],"mappings":"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","sourcesContent":["import {\n Component,\n h,\n Prop,\n Element,\n Event,\n EventEmitter,\n Watch,\n} from '@stencil/core';\nimport { createRandomString } from '../../util/random-string';\nimport { zipObject } from 'lodash-es';\nimport { portalContains } from '../portal/contains';\nimport { ESCAPE } from '../../util/keycodes';\nimport { OpenDirection } from '../menu/menu.types';\n\n/**\n * A popover is an impermanent layer that is displayed on top of other content\n * when user taps an element that triggers the popover. This element can be\n * practically anything, a button, piece of text, and icon, etc.\n *\n * Popovers are nonmodal, thus they don't have a semi-transparent backdrop layer\n * that darkens the content below them. Also for the same reason, they can be\n * dismissed by tapping or clicking another part of the screen, but not by a\n * clicking a button or link on the popover itself.\n *\n * :::warning\n * The component is emitting a close event when you click outside its container\n * or press the <kbd>Esc</kbd> key. However, it’s up to you as consumer to react\n * properly on this event and hide the component (preferably by setting the\n * property `open` to `false`).\n * :::\n *\n * ## Usage\n * Use a popover to show **options** or **information** related to the trigger\n * onscreen. A typical use case for popovers is a tooltip, in which you show\n * help text or contextual information to users.\n *\n * Popovers are most appropriate on larger screens but can be used on smaller\n * screens too, as long as their content is responsive and takes into account\n * the context they are displayed on.\n *\n * When a popover is displayed, interactions with other controls are blocked,\n * until user dismisses the popover.\n *\n *\n * ## Layout\n * Popovers has only one slot in which you can import a custom web-component.\n *\n * :::note\n * You must make sure that web-components that you import into the slot has\n * a `width: 100%;` style so that it can horizontally stretch across the popover.\n *\n * However, `width` of the popover can be controlled by specifying a CSS variable\n * of `--popover-surface-width`. If you don't specify any width, the popover\n * will grow as wide as its content.\n * :::\n *\n * :::important\n * Do not make a popover too big. They should never take over the entire screen.\n * If your content is that big, you should probably be using a Modal instead.\n * :::\n * @slot - Content to put inside the surface\n * @exampleComponent limel-example-popover\n */\n@Component({\n tag: 'limel-popover',\n shadow: true,\n styleUrl: 'popover.scss',\n})\nexport class Popover {\n /**\n * True if the content within the popover should be visible\n */\n @Prop()\n public open = false;\n\n /**\n * Decides the popover's location in relation to its trigger\n */\n @Prop({ reflect: true })\n public openDirection: OpenDirection;\n\n /**\n * Emits an event when the component is closing\n */\n @Event()\n private close: EventEmitter<void>;\n\n @Element()\n private host: HTMLLimelPopoverElement;\n\n private portalId: string;\n\n constructor() {\n this.portalId = createRandomString();\n this.globalClickListener = this.globalClickListener.bind(this);\n }\n\n @Watch('open')\n protected watchOpen() {\n this.setupGlobalHandlers();\n }\n\n public componentWillLoad() {\n this.setupGlobalHandlers();\n }\n\n private setupGlobalHandlers() {\n if (this.open) {\n document.addEventListener('click', this.globalClickListener, {\n capture: true,\n });\n document.addEventListener('keyup', this.handleGlobalKeyPress);\n } else {\n document.removeEventListener('click', this.globalClickListener);\n document.removeEventListener('keyup', this.handleGlobalKeyPress);\n }\n }\n\n public render() {\n const cssProperties = this.getCssProperties();\n const popoverZIndex = getComputedStyle(this.host).getPropertyValue(\n '--popover-z-index'\n );\n\n return (\n <div class=\"trigger-anchor\">\n <slot name=\"trigger\"></slot>\n <limel-portal\n visible={this.open}\n containerId={this.portalId}\n containerStyle={{ 'z-index': popoverZIndex }}\n openDirection={this.openDirection}\n >\n <limel-popover-surface\n contentCollection={this.host.children}\n style={cssProperties}\n />\n </limel-portal>\n </div>\n );\n }\n\n private globalClickListener(event: MouseEvent) {\n const element: HTMLElement = event.target as HTMLElement;\n const clickedInside = portalContains(this.host, element);\n if (this.open && !clickedInside) {\n event.stopPropagation();\n event.preventDefault();\n this.close.emit();\n }\n }\n\n private getCssProperties() {\n const propertyNames = [\n '--popover-surface-width',\n '--popover-body-background-color',\n '--popover-border-radius',\n ];\n const style = getComputedStyle(this.host);\n const values = propertyNames.map((property) => {\n return style.getPropertyValue(property);\n });\n\n return zipObject(propertyNames, values);\n }\n\n private handleGlobalKeyPress = (event: KeyboardEvent) => {\n if (event.key !== ESCAPE) {\n return;\n }\n\n event.stopPropagation();\n event.preventDefault();\n this.close.emit();\n };\n}\n"]}
@@ -59,3 +59,4 @@ export class PopoverSurface {
59
59
  }
60
60
  static get elementRef() { return "host"; }
61
61
  }
62
+ //# sourceMappingURL=popover-surface.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"popover-surface.js","sourceRoot":"","sources":["../../../src/components/popover-surface/popover-surface.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,eAAe,CAAC;AAE5D;;;GAGG;AAOH,MAAM,OAAO,cAAc;;;;EAUhB,gBAAgB;IACnB,IAAI,CAAC,aAAa,EAAE,CAAC;EACzB,CAAC;EAEM,MAAM;IACT,OAAO,WAAK,KAAK,EAAC,uBAAuB,EAAC,QAAQ,EAAC,GAAG,GAAG,CAAC;EAC9D,CAAC;EAEO,aAAa;IACjB,MAAM,eAAe,GAAG,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,aAAa,CACtD,wBAAwB,CAC3B,CAAC;IAEF,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;MACjD,IAAI,KAAK,CAAC,IAAI,KAAK,SAAS,EAAE;QAC1B,OAAO;OACV;MAED,eAAe,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;IACvC,CAAC,CAAC,CAAC;EACP,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACJ","sourcesContent":["import { Component, h, Prop, Element } from '@stencil/core';\n\n/**\n * @slot - Content to put inside the surface\n * @private\n */\n\n@Component({\n tag: 'limel-popover-surface',\n shadow: true,\n styleUrl: 'popover-surface.scss',\n})\nexport class PopoverSurface {\n /**\n * Content to render\n */\n @Prop()\n public contentCollection: HTMLCollection;\n\n @Element()\n private host: HTMLLimelPopoverSurfaceElement;\n\n public componentDidLoad() {\n this.appendElement();\n }\n\n public render() {\n return <div class=\"limel-popover-surface\" tabindex=\"0\" />;\n }\n\n private appendElement() {\n const portalContainer = this.host.shadowRoot.querySelector(\n '.limel-popover-surface'\n );\n\n Array.from(this.contentCollection).forEach((child) => {\n if (child.slot === 'trigger') {\n return;\n }\n\n portalContainer.appendChild(child);\n });\n }\n}\n"]}
@@ -27,3 +27,4 @@ function findParent(element) {
27
27
  const rootNode = element.getRootNode();
28
28
  return rootNode.host;
29
29
  }
30
+ //# sourceMappingURL=contains.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"contains.js","sourceRoot":"","sources":["../../../src/components/portal/contains.ts"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AACH,MAAM,UAAU,cAAc,CAC1B,OAAoB,EACpB,KAAkB;;EAElB,IAAI,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAI,MAAA,OAAO,CAAC,UAAU,0CAAE,QAAQ,CAAC,KAAK,CAAC,CAAA,EAAE;IAChE,OAAO,IAAI,CAAC;GACf;EAED,MAAM,MAAM,GAAG,UAAU,CAAC,KAAK,CAAC,CAAC;EACjC,IAAI,CAAC,MAAM,EAAE;IACT,OAAO,KAAK,CAAC;GAChB;EAED,OAAO,cAAc,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;AAC3C,CAAC;AAED,SAAS,UAAU,CAAC,OAAoB;EACpC,MAAM,MAAM,GAAQ,OAAO,CAAC,OAAO,CAAC,0BAA0B,CAAC,CAAC;EAChE,IAAI,MAAM,EAAE;IACR,OAAO,MAAM,CAAC,YAAY,CAAC;GAC9B;EAED,MAAM,QAAQ,GAAG,OAAO,CAAC,WAAW,EAAgB,CAAC;EAErD,OAAO,QAAQ,CAAC,IAAI,CAAC;AACzB,CAAC","sourcesContent":["/**\n * Check if an element is a descendant of another\n *\n * If the child element is a descendant of a limel-portal, this function will\n * go back through the portal and check the original tree recursively\n * @param {HTMLElement} element the parent element\n * @param {HTMLElement} child the child element to check\n * @returns {boolean} `true` if child is a descendant of element, taking\n * portals into account\n */\nexport function portalContains(\n element: HTMLElement,\n child: HTMLElement\n): boolean {\n if (element.contains(child) || element.shadowRoot?.contains(child)) {\n return true;\n }\n\n const parent = findParent(child);\n if (!parent) {\n return false;\n }\n\n return portalContains(element, parent);\n}\n\nfunction findParent(element: HTMLElement) {\n const portal: any = element.closest('.limel-portal--container');\n if (portal) {\n return portal.portalSource;\n }\n\n const rootNode = element.getRootNode() as ShadowRoot;\n\n return rootNode.host;\n}\n"]}
@@ -27,17 +27,6 @@ import { createPopper, } from '@popperjs/core';
27
27
  */
28
28
  /* eslint-enable jsdoc/check-indentation */
29
29
  export class Portal {
30
- constructor() {
31
- this.loaded = false;
32
- this.openDirection = 'bottom';
33
- this.position = 'absolute';
34
- this.containerId = undefined;
35
- this.containerStyle = {};
36
- this.parent = document.body;
37
- this.inheritParentWidth = false;
38
- this.visible = false;
39
- this.parents = new WeakMap();
40
- }
41
30
  onVisible() {
42
31
  if (!this.visible) {
43
32
  this.hideContainer();
@@ -51,6 +40,17 @@ export class Portal {
51
40
  this.showContainer();
52
41
  });
53
42
  }
43
+ constructor() {
44
+ this.loaded = false;
45
+ this.openDirection = 'bottom';
46
+ this.position = 'absolute';
47
+ this.containerId = undefined;
48
+ this.containerStyle = {};
49
+ this.parent = document.body;
50
+ this.inheritParentWidth = false;
51
+ this.visible = false;
52
+ this.parents = new WeakMap();
53
+ }
54
54
  disconnectedCallback() {
55
55
  this.removeContainer();
56
56
  this.destroyPopper();
@@ -379,3 +379,4 @@ export class Portal {
379
379
  }];
380
380
  }
381
381
  }
382
+ //# sourceMappingURL=portal.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"portal.js","sourceRoot":"","sources":["../../../src/components/portal/portal.tsx"],"names":[],"mappings":"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","sourcesContent":["import { Component, Element, h, Prop, Watch } from '@stencil/core';\nimport { OpenDirection } from '../menu/menu.types';\nimport {\n createPopper,\n Instance,\n OptionsGeneric,\n Placement,\n} from '@popperjs/core';\nimport { FlipModifier } from '@popperjs/core/lib/modifiers/flip';\n\n/* eslint-disable jsdoc/check-indentation */\n/**\n * The portal component provides a way to render children into a DOM node that\n * exist outside the DOM hierarchy of the parent component.\n *\n * There are some caveats when using this component\n *\n * Events might not bubble up as expected since the content is moved out to\n * another DOM node.\n * Any styling that is applied to content from the parent will be lost, if the\n * content is just another web compoent it will work without any issues.\n * Alternatively, use the\n * `style=\"\"` html attribute.\n * Any component that is placed inside the container must have a style of\n * `max-height: inherit`. This ensures that its placement is calculated\n * correctly in relation to the trigger, and that it never covers its own\n * trigger.\n * When the node is moved in the DOM, `disconnectedCallback` and\n * `connectedCallback` will be invoked, so if `disconnectedCallback` is used\n * to do any tear-down, the appropriate setup will have to be done again on\n * `connectedCallback`.\n * @slot - Content to put inside the portal\n * @private\n * @exampleComponent limel-example-portal\n */\n/* eslint-enable jsdoc/check-indentation */\n@Component({\n tag: 'limel-portal',\n shadow: true,\n styleUrl: 'portal.scss',\n})\nexport class Portal {\n /**\n * Decides which direction the portal content should open.\n */\n @Prop()\n public openDirection: OpenDirection = 'bottom';\n\n /**\n * Position of the content.\n */\n @Prop()\n public position: 'fixed' | 'absolute' = 'absolute';\n\n /**\n * A unique ID.\n */\n @Prop()\n public containerId: string;\n\n /**\n * Dynamic styling that can be applied to the container holding the content.\n */\n @Prop()\n public containerStyle: object = {};\n\n /**\n * Parent element to move the content to.\n */\n @Prop()\n public parent: HTMLElement = document.body;\n\n /**\n * Used to make a dropdown have the same width as the trigger, for example\n * in `limel-picker`.\n */\n @Prop()\n public inheritParentWidth = false;\n\n /**\n * True if the content within the portal should be visible.\n *\n * If the content is from within a dialog for instance, this can be set to\n * true from false when the dialog opens to position the content properly.\n */\n @Prop()\n public visible = false;\n\n private parents: WeakMap<HTMLElement, HTMLElement>;\n\n @Watch('visible')\n protected onVisible() {\n if (!this.visible) {\n this.hideContainer();\n this.styleContainer();\n this.destroyPopper();\n\n return;\n }\n\n this.styleContainer();\n this.createPopper();\n requestAnimationFrame(() => {\n this.showContainer();\n });\n }\n\n @Element()\n private host: HTMLLimelPortalElement;\n\n private container: HTMLElement;\n\n private popperInstance: Instance;\n\n private loaded = false;\n\n private observer: ResizeObserver;\n\n constructor() {\n this.parents = new WeakMap();\n }\n\n public disconnectedCallback() {\n this.removeContainer();\n this.destroyPopper();\n if (this.observer) {\n this.observer.unobserve(this.container);\n }\n }\n\n public connectedCallback() {\n if (!this.loaded) {\n return;\n }\n\n this.createContainer();\n this.hideContainer();\n this.attachContainer();\n this.styleContainer();\n\n if (this.visible) {\n this.createPopper();\n this.showContainer();\n }\n\n if ('ResizeObserver' in window) {\n const observer = new ResizeObserver(() => {\n if (this.popperInstance) {\n this.styleContainer();\n this.popperInstance.update();\n }\n });\n observer.observe(this.container);\n }\n }\n\n public componentDidLoad() {\n this.loaded = true;\n this.connectedCallback();\n }\n\n public render() {\n return <slot />;\n }\n\n private createContainer() {\n const slot: HTMLSlotElement =\n this.host.shadowRoot.querySelector('slot');\n const content =\n (slot.assignedElements && slot.assignedElements()) || [];\n\n this.container = document.createElement('div');\n this.container.setAttribute('id', this.containerId);\n this.container.setAttribute('class', 'limel-portal--container');\n Object.assign(this.container, {\n portalSource: this.host,\n });\n\n content.forEach((element: HTMLElement) => {\n this.parents.set(element, element.parentElement);\n this.container.appendChild(element);\n });\n }\n\n private attachContainer() {\n this.parent.appendChild(this.container);\n }\n\n private removeContainer() {\n if (!this.container) {\n return;\n }\n\n Array.from(this.container.children).forEach((element: HTMLElement) => {\n const parent = this.parents.get(element);\n if (!parent) {\n return;\n }\n\n parent.appendChild(element);\n });\n\n this.hideContainer();\n this.container.parentElement.removeChild(this.container);\n }\n\n private hideContainer() {\n this.container.style.opacity = '0';\n }\n\n private showContainer() {\n this.container.style.opacity = '1';\n }\n\n private styleContainer() {\n const hostWidth = this.host.getBoundingClientRect().width;\n\n if (this.visible) {\n this.container.style.display = 'block';\n } else {\n this.container.style.display = 'none';\n }\n\n if (this.inheritParentWidth) {\n const containerWidth = this.getContentWidth(this.container);\n let width = containerWidth;\n if (hostWidth > 0) {\n width = hostWidth;\n }\n\n this.container.style.width = `${width}px`;\n }\n\n this.ensureContainerFitsInViewPort();\n\n Object.keys(this.containerStyle).forEach((property) => {\n this.container.style[property] = this.containerStyle[property];\n });\n }\n\n private getContentWidth(element: HTMLElement | Element) {\n if (!element) {\n return null;\n }\n\n const width = element.getBoundingClientRect().width;\n if (width !== 0) {\n return width;\n }\n\n const elementContent = element.querySelector('*');\n\n return this.getContentWidth(elementContent);\n }\n\n private createPopper() {\n const config = this.createPopperConfig();\n\n this.popperInstance = createPopper(this.host, this.container, config);\n }\n\n private destroyPopper() {\n this.popperInstance?.destroy();\n this.popperInstance = null;\n }\n\n private createPopperConfig(): Partial<\n OptionsGeneric<Partial<FlipModifier>>\n > {\n const placement = this.getPlacement(this.openDirection);\n const flipPlacement = this.getFlipPlacement(this.openDirection);\n\n return {\n strategy: this.position,\n placement: placement,\n modifiers: [\n {\n name: 'flip',\n options: {\n fallbackPlacements: [flipPlacement],\n },\n },\n ],\n };\n }\n\n private getPlacement(direction: OpenDirection): Placement {\n const placements: Record<OpenDirection, Placement> = {\n 'left-start': 'left-start',\n left: 'left',\n 'left-end': 'left-end',\n 'right-start': 'right-start',\n right: 'right',\n 'right-end': 'right-end',\n 'top-start': 'top-start',\n top: 'top',\n 'top-end': 'top-end',\n 'bottom-start': 'bottom-start',\n bottom: 'bottom',\n 'bottom-end': 'bottom-end',\n };\n\n return placements[direction];\n }\n\n private getFlipPlacement(direction: OpenDirection): Placement {\n const flipPlacements: Record<OpenDirection, Placement> = {\n 'left-start': 'right-start',\n left: 'right',\n 'left-end': 'right-end',\n 'right-start': 'left-start',\n right: 'left',\n 'right-end': 'left-end',\n 'top-start': 'bottom-start',\n top: 'bottom',\n 'top-end': 'bottom-end',\n 'bottom-start': 'top-start',\n bottom: 'top',\n 'bottom-end': 'top-end',\n };\n\n return flipPlacements[direction];\n }\n\n private ensureContainerFitsInViewPort() {\n const viewHeight = Math.max(\n document.documentElement.clientHeight || 0,\n window.innerHeight || 0\n );\n\n const { top, bottom } = this.host.getBoundingClientRect();\n const spaceAboveTopOfSurface = Math.max(top, 0);\n const spaceBelowTopOfSurface = Math.max(viewHeight - bottom, 0);\n const extraCosmeticSpace = 16;\n const maxHeight =\n Math.max(spaceAboveTopOfSurface, spaceBelowTopOfSurface) -\n extraCosmeticSpace;\n\n this.container.style.maxHeight = `${maxHeight}px`;\n }\n}\n"]}
@@ -147,3 +147,4 @@ export class ProgressFlowItem {
147
147
  }
148
148
  static get elementRef() { return "element"; }
149
149
  }
150
+ //# sourceMappingURL=progress-flow-item.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"progress-flow-item.js","sourceRoot":"","sources":["../../../../src/components/progress-flow/progress-flow-item/progress-flow-item.tsx"],"names":[],"mappings":"AAAA,OAAO,EACH,SAAS,EACT,OAAO,EACP,KAAK,EAEL,CAAC,EACD,IAAI,GACP,MAAM,eAAe,CAAC;AAGvB;;GAEG;AAMH,MAAM,OAAO,gBAAgB;;IAmEjB,gBAAW,GAAG,GAAG,EAAE;MACvB,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;IACzB,CAAC,CAAC;gBA7DsB,IAAI;oBAMV,KAAK;oBAML,KAAK;;EAQhB,MAAM;;IACT,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE;MACZ,OAAO;KACV;IAED,OAAO;MACH,cACI,QAAQ,EAAC,GAAG,EACZ,KAAK,EAAE,IAAI,CAAC,cAAc,EAAE,EAC5B,IAAI,EAAC,QAAQ,EACb,KAAK,EAAE;UACH,IAAI,EAAE,IAAI;UACV,QAAQ,EAAE,MAAA,IAAI,CAAC,IAAI,0CAAE,QAAQ;UAC7B,QAAQ,EAAE,IAAI,CAAC,UAAU,EAAE;UAC3B,QAAQ,EAAE,IAAI,CAAC,QAAQ;SAC1B,EACD,OAAO,EAAE,IAAI,CAAC,WAAW,EACzB,QAAQ,EAAE,IAAI,CAAC,UAAU,EAAE;QAE1B,IAAI,CAAC,UAAU,EAAE;QAClB,YAAM,KAAK,EAAC,MAAM,IAAE,IAAI,CAAC,IAAI,CAAC,IAAI,CAAQ;QACzC,IAAI,CAAC,aAAa,EAAE,CAChB;MACT,IAAI,CAAC,mBAAmB,EAAE;KAC7B,CAAC;EACN,CAAC;EAEO,UAAU;;IACd,OAAO,CAAA,MAAA,IAAI,CAAC,IAAI,0CAAE,QAAQ,KAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC;EACjE,CAAC;EAEO,cAAc;IAClB,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;MAC1B,OAAO,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC;KACzB;IAED,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;EACjE,CAAC;EAMO,mBAAmB;;IACvB,IAAI,CAAC,CAAA,MAAA,IAAI,CAAC,IAAI,0CAAE,aAAa,CAAA,EAAE;MAC3B,OAAO;KACV;IAED,OAAO,WAAK,KAAK,EAAC,gBAAgB,IAAE,IAAI,CAAC,IAAI,CAAC,aAAa,CAAO,CAAC;EACvE,CAAC;EAEO,UAAU;IACd,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE;MACjB,OAAO;KACV;IAED,OAAO,kBAAY,IAAI,EAAE,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,EAAC,OAAO,EAAC,KAAK,EAAC,MAAM,GAAG,CAAC;EAC1E,CAAC;EAEO,aAAa;IACjB,IAAI,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE;MACzB,OAAO;KACV;IAED,OAAO,WAAK,KAAK,EAAC,SAAS,GAAG,CAAC;EACnC,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;CACJ","sourcesContent":["import {\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Prop,\n} from '@stencil/core';\nimport { FlowItem } from '../progress-flow.types';\n\n/**\n * @private\n */\n@Component({\n tag: 'limel-progress-flow-item',\n shadow: false,\n styleUrl: 'progress-flow-item.scss',\n})\nexport class ProgressFlowItem {\n @Element()\n public element: HTMLLimelProgressFlowItemElement;\n\n /**\n * The flow item that should be rendered\n */\n @Prop()\n public item: FlowItem = null;\n\n /**\n * True if the flow item should be disabled\n */\n @Prop()\n public disabled = false;\n\n /**\n * True if the flow item should be readonly\n */\n @Prop()\n public readonly = false;\n\n /**\n * Fired when clicking on the flow item\n */\n @Event()\n public interact: EventEmitter<void>;\n\n public render() {\n if (!this.item) {\n return;\n }\n\n return [\n <button\n tabindex=\"0\"\n title={this.getToolTipText()}\n type=\"button\"\n class={{\n step: true,\n selected: this.item?.selected,\n disabled: this.isDisabled(),\n readonly: this.readonly,\n }}\n onClick={this.handleClick}\n disabled={this.isDisabled()}\n >\n {this.renderIcon()}\n <span class=\"text\">{this.item.text}</span>\n {this.renderDivider()}\n </button>,\n this.renderSecondaryText(),\n ];\n }\n\n private isDisabled() {\n return this.item?.disabled || this.readonly || this.disabled;\n }\n\n private getToolTipText() {\n if (!this.item.secondaryText) {\n return this.item.text;\n }\n\n return [this.item.text, this.item.secondaryText].join(' · ');\n }\n\n private handleClick = () => {\n this.interact.emit();\n };\n\n private renderSecondaryText() {\n if (!this.item?.secondaryText) {\n return;\n }\n\n return <div class=\"secondary-text\">{this.item.secondaryText}</div>;\n }\n\n private renderIcon() {\n if (!this.item.icon) {\n return;\n }\n\n return <limel-icon name={this.item.icon} size=\"small\" class=\"icon\" />;\n }\n\n private renderDivider() {\n if (this.item.isOffProgress) {\n return;\n }\n\n return <div class=\"divider\" />;\n }\n}\n"]}
@@ -187,3 +187,4 @@ export class ProgressFlow {
187
187
  }
188
188
  static get elementRef() { return "element"; }
189
189
  }
190
+ //# sourceMappingURL=progress-flow.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"progress-flow.js","sourceRoot":"","sources":["../../../src/components/progress-flow/progress-flow.tsx"],"names":[],"mappings":"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","sourcesContent":["import {\n Component,\n Element,\n Event,\n EventEmitter,\n h,\n Prop,\n} from '@stencil/core';\nimport { FlowItem } from './progress-flow.types';\n\n/**\n * @exampleComponent limel-example-progress-flow-basic\n * @exampleComponent limel-example-progress-flow-secondary-text\n * @exampleComponent limel-example-progress-flow-disabled-step\n * @exampleComponent limel-example-progress-flow-colors\n * @exampleComponent limel-example-progress-flow-colors-css\n * @exampleComponent limel-example-progress-flow-off-progress-steps\n * @exampleComponent limel-example-progress-flow-narrow\n */\n@Component({\n tag: 'limel-progress-flow',\n shadow: true,\n styleUrl: 'progress-flow.scss',\n})\nexport class ProgressFlow {\n @Element()\n public element: HTMLLimelProgressFlowElement;\n\n /**\n * What flow items to render\n */\n @Prop()\n public flowItems: FlowItem[] = [];\n\n /**\n * Set to `true` to disable the progress flow.\n * Use `disabled` to indicate that the component can normally be interacted\n * with, but is currently disabled. This tells the user that if certain\n * requirements are met, the field may become enabled again.\n */\n @Prop()\n public disabled = false;\n\n /**\n * Disables the progress flow when `true`.\n * This does not visualize the component that much differently.\n * But since the component does not provide any feedback that users can\n * interact with the component, it makes it perfect for illustrative and\n * informative porpuses.\n */\n @Prop()\n public readonly = false;\n\n /**\n * Fired when a new value has been selected from the progress flow\n */\n @Event()\n public change: EventEmitter<FlowItem>;\n\n private selectedItemIndex: number;\n\n public componentDidRender() {\n this.scrollToSelectedItem();\n }\n\n public render() {\n const regularFlowItems = this.flowItems.filter((item) => {\n return !item.isOffProgress;\n });\n const endPhaseItems = this.flowItems.filter((item) => {\n return item.isOffProgress;\n });\n this.selectedItemIndex = regularFlowItems.findIndex((item) => {\n return item.selected;\n });\n\n return [\n regularFlowItems.map(this.renderRegularFlowItem),\n endPhaseItems.map(this.renderEndPhaseItem),\n ];\n }\n\n private renderRegularFlowItem = (\n item: FlowItem,\n index: number,\n array: FlowItem[]\n ) => {\n return (\n <limel-progress-flow-item\n class={{\n 'flow-item': true,\n first: index === 0,\n last: index === array.length - 1,\n passed: index < this.selectedItemIndex,\n selected: item.selected,\n }}\n style={this.getItemStyle(item)}\n disabled={this.disabled || this.readonly}\n readonly={this.readonly}\n item={item}\n onInteract={this.handleFlowItemClick(item)}\n data-tracking-value={item.value}\n />\n );\n };\n\n private renderEndPhaseItem = (\n item: FlowItem,\n index: number,\n array: FlowItem[]\n ) => {\n return (\n <limel-progress-flow-item\n class={{\n 'flow-item': true,\n 'off-progress-item': true,\n selected: item.selected,\n 'first-off-progress-item': index === 0,\n 'last-off-progress-item': index === array.length - 1,\n }}\n style={this.getItemStyle(item)}\n disabled={this.disabled || this.readonly}\n readonly={this.readonly}\n item={item}\n onInteract={this.handleFlowItemClick(item)}\n data-tracking-value={item.value}\n />\n );\n };\n\n private handleFlowItemClick = (flowItem: FlowItem) => () => {\n if (!flowItem.selected && !flowItem.disabled && !this.disabled) {\n this.change.emit(flowItem);\n }\n };\n\n private getItemStyle(flowItem: FlowItem) {\n const style: any = {};\n if (flowItem?.selectedColor) {\n style['--progress-flow-step-background-color--selected'] =\n flowItem.selectedColor;\n }\n\n if (flowItem?.passedColor) {\n style['--progress-flow-step-background-color--passed'] =\n flowItem.passedColor;\n }\n\n if (flowItem?.iconColor) {\n style['--progress-flow-icon-color--inactive'] = flowItem.iconColor;\n }\n\n return style;\n }\n\n private scrollToSelectedItem() {\n const selectedElement = this.getElementForSelectedItem();\n if (selectedElement) {\n const selectedItemLeftPosition =\n selectedElement.offsetLeft - this.element.offsetLeft;\n const selectedElementLeftPositionCentered =\n // eslint-disable-next-line no-magic-numbers\n selectedItemLeftPosition - this.element.offsetWidth / 2;\n const selectedElementCentered =\n selectedElementLeftPositionCentered +\n // eslint-disable-next-line no-magic-numbers\n selectedElement.offsetWidth / 2;\n this.element.scrollTo({\n behavior: 'smooth',\n left: selectedElementCentered,\n });\n }\n }\n\n private getElementForSelectedItem(): HTMLLimelProgressFlowItemElement {\n return this.element.shadowRoot.querySelector('.flow-item.selected');\n }\n}\n"]}
@@ -1 +1,2 @@
1
1
  export {};
2
+ //# sourceMappingURL=progress-flow.types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"progress-flow.types.js","sourceRoot":"","sources":["../../../src/components/progress-flow/progress-flow.types.ts"],"names":[],"mappings":"","sourcesContent":["import { ListItem } from '../list/list-item.types';\n\nexport interface FlowItem extends ListItem {\n /**\n * Determines whether a step should be a part of the flow,\n * or should be an independent step visually located on the side.\n */\n isOffProgress?: boolean;\n\n /**\n * Background color of selected step.\n */\n selectedColor?: string;\n\n /**\n * Background color of the step, when it is passed.\n */\n passedColor?: string;\n\n /**\n * Fill color of the icon on the step,\n * when it is neither selected nor passed.\n */\n iconColor?: string;\n}\n"]}
@@ -1 +1,2 @@
1
1
  export {};
2
+ //# sourceMappingURL=option.types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"option.types.js","sourceRoot":"","sources":["../../../src/components/select/option.types.ts"],"names":[],"mappings":"","sourcesContent":["/**\n * Describes an option for limel-select.\n */\nexport interface Option<T extends string = string> {\n /**\n * The name of the option as shown to the user.\n */\n text: string;\n\n /**\n * The unique value of the option. Should always be the same for any given\n * option, regardless of localization. The type `T` defaults to `string`,\n * but can be set to any type that extends `string` (using `Option<type>`),\n * for example an enum of specific strings.\n *\n * Note the value of this property *must* be a string!\n * If the value you wish to use is, for example, numeric, convert it to a\n * string before sending it to limel-select. Using numeric values does work\n * in many desktop browsers, but breaks the select completely on some\n * iOS devices.\n */\n value: T;\n\n /**\n * Set to `true` to make this option disabled and not possible to select.\n */\n disabled?: boolean;\n\n /**\n * Displays an icon beside the name of the option.\n */\n icon?: string;\n\n /**\n * Adds a color to the icon.\n */\n iconColor?: string;\n}\n"]}