@leaflink/stash 49.5.0 → 50.0.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 (418) hide show
  1. package/assets/icons/circle-empty.svg +1 -0
  2. package/assets/spritesheet.svg +1 -1
  3. package/dist/Accordion.js +25 -28
  4. package/dist/Accordion.js.map +1 -1
  5. package/dist/Accordion.vue.d.ts +16 -16
  6. package/dist/ActionsDropdown.js +14 -26
  7. package/dist/ActionsDropdown.js.map +1 -1
  8. package/dist/ActionsDropdown.vue.d.ts +12 -12
  9. package/dist/AddressSelect.js +22 -47
  10. package/dist/AddressSelect.js.map +1 -1
  11. package/dist/AddressSelect.vue.d.ts +45 -45
  12. package/dist/Alert.js +4 -6
  13. package/dist/Alert.js.map +1 -1
  14. package/dist/Alert.vue.d.ts +18 -18
  15. package/dist/AppNavigationItem.js +16 -19
  16. package/dist/AppNavigationItem.js.map +1 -1
  17. package/dist/AppNavigationItem.vue.d.ts +4 -4
  18. package/dist/AppSidebar.js +27 -28
  19. package/dist/AppSidebar.js.map +1 -1
  20. package/dist/AppSidebar.vue.d.ts +7 -7
  21. package/dist/AppTopbar.js +12 -17
  22. package/dist/AppTopbar.js.map +1 -1
  23. package/dist/AppTopbar.vue.d.ts +8 -8
  24. package/dist/Avatar.js +1 -1
  25. package/dist/Avatar.vue.d.ts +22 -22
  26. package/dist/Backdrop.js +1 -1
  27. package/dist/Backdrop.vue.d.ts +1 -1
  28. package/dist/Badge.js +1 -1
  29. package/dist/Badge.js.map +1 -1
  30. package/dist/Badge.vue.d.ts +36 -36
  31. package/dist/Box.js +2 -3
  32. package/dist/Box.js.map +1 -1
  33. package/dist/Box.vue.d.ts +12 -12
  34. package/dist/{Box.vue_vue_type_script_setup_true_lang-69e5176b.js → Box.vue_vue_type_script_setup_true_lang-DgJHq-09.js} +1 -1
  35. package/dist/{Box.vue_vue_type_script_setup_true_lang-69e5176b.js.map → Box.vue_vue_type_script_setup_true_lang-DgJHq-09.js.map} +1 -1
  36. package/dist/Button.js +40 -27
  37. package/dist/Button.js.map +1 -1
  38. package/dist/Button.vue.d.ts +34 -27
  39. package/dist/ButtonGroup.js +1 -1
  40. package/dist/ButtonGroup.vue.d.ts +14 -14
  41. package/dist/Card.vue.d.ts +3 -3
  42. package/dist/CardContent.js +1 -1
  43. package/dist/CardContent.vue.d.ts +1 -1
  44. package/dist/CardFooter.js +1 -1
  45. package/dist/CardFooter.vue.d.ts +1 -1
  46. package/dist/CardMedia.js +11 -14
  47. package/dist/CardMedia.js.map +1 -1
  48. package/dist/Carousel.js +179 -180
  49. package/dist/Carousel.js.map +1 -1
  50. package/dist/Carousel.vue.d.ts +33 -11
  51. package/dist/Checkbox.js +38 -35
  52. package/dist/Checkbox.js.map +1 -1
  53. package/dist/Checkbox.vue.d.ts +31 -31
  54. package/dist/ChevronToggle.js +2 -10
  55. package/dist/ChevronToggle.js.map +1 -1
  56. package/dist/ChevronToggle.vue.d.ts +5 -5
  57. package/dist/{ChevronToggle.vue_vue_type_script_setup_true_lang-fcdf0c19.js → ChevronToggle.vue_vue_type_script_setup_true_lang-DuvluoTi.js} +1 -1
  58. package/dist/{ChevronToggle.vue_vue_type_script_setup_true_lang-fcdf0c19.js.map → ChevronToggle.vue_vue_type_script_setup_true_lang-DuvluoTi.js.map} +1 -1
  59. package/dist/Chip.js +17 -20
  60. package/dist/Chip.js.map +1 -1
  61. package/dist/Chip.vue.d.ts +32 -32
  62. package/dist/ConfirmationCodeInput.js +1 -1
  63. package/dist/ConfirmationCodeInput.js.map +1 -1
  64. package/dist/ConfirmationCodeInput.vue.d.ts +29 -29
  65. package/dist/ContextSwitcher.js +8 -14
  66. package/dist/ContextSwitcher.js.map +1 -1
  67. package/dist/ContextSwitcher.vue.d.ts +32 -32
  68. package/dist/Copy.js +23 -34
  69. package/dist/Copy.js.map +1 -1
  70. package/dist/Copy.vue.d.ts +9 -9
  71. package/dist/CurrencyInput.js +117 -128
  72. package/dist/CurrencyInput.js.map +1 -1
  73. package/dist/CurrencyInput.vue.d.ts +26 -21
  74. package/dist/CustomRender.vue.d.ts +12 -1
  75. package/dist/DataView.js +70 -73
  76. package/dist/DataView.js.map +1 -1
  77. package/dist/{DataView.vue_used_vue_type_style_index_0_lang.module-5c180dba.js → DataView.keys-C7eaZg2G.js} +5 -8
  78. package/dist/DataView.keys-C7eaZg2G.js.map +1 -0
  79. package/dist/DataView.vue.d.ts +51 -51
  80. package/dist/DataViewFilters.js +76 -90
  81. package/dist/DataViewFilters.js.map +1 -1
  82. package/dist/{DataViewFilters.keys-c80ffabe.js → DataViewFilters.keys-BLu07FiP.js} +1 -1
  83. package/dist/{DataViewFilters.keys-c80ffabe.js.map → DataViewFilters.keys-BLu07FiP.js.map} +1 -1
  84. package/dist/DataViewFilters.vue.d.ts +39 -39
  85. package/dist/DataViewSortButton.js +30 -43
  86. package/dist/DataViewSortButton.js.map +1 -1
  87. package/dist/DataViewSortButton.vue.d.ts +3 -3
  88. package/dist/DataViewToolbar.js +27 -36
  89. package/dist/DataViewToolbar.js.map +1 -1
  90. package/dist/DataViewToolbar.vue.d.ts +17 -17
  91. package/dist/DatePicker.js +649 -662
  92. package/dist/DatePicker.js.map +1 -1
  93. package/dist/DatePicker.vue.d.ts +73 -73
  94. package/dist/DescriptionList.js +1 -1
  95. package/dist/{DescriptionList.keys-c906ce05.js → DescriptionList.keys-BHlHYV6b.js} +1 -1
  96. package/dist/{DescriptionList.keys-c906ce05.js.map → DescriptionList.keys-BHlHYV6b.js.map} +1 -1
  97. package/dist/DescriptionList.vue.d.ts +6 -6
  98. package/dist/DescriptionListDetail.js +1 -1
  99. package/dist/DescriptionListDetail.vue.d.ts +1 -1
  100. package/dist/DescriptionListGroup.js +1 -1
  101. package/dist/DescriptionListGroup.vue.d.ts +1 -1
  102. package/dist/DescriptionListTerm.js +1 -1
  103. package/dist/DescriptionListTerm.vue.d.ts +1 -1
  104. package/dist/Dialog.js +26 -30
  105. package/dist/Dialog.js.map +1 -1
  106. package/dist/Dialog.vue.d.ts +34 -34
  107. package/dist/Divider.js +1 -1
  108. package/dist/Divider.js.map +1 -1
  109. package/dist/Divider.vue.d.ts +1 -1
  110. package/dist/Dropdown.js +21 -28
  111. package/dist/Dropdown.js.map +1 -1
  112. package/dist/Dropdown.vue.d.ts +28 -28
  113. package/dist/EmptyState.js +32 -33
  114. package/dist/EmptyState.js.map +1 -1
  115. package/dist/EmptyState.vue.d.ts +36 -36
  116. package/dist/Expand.js +2 -3
  117. package/dist/Expand.js.map +1 -1
  118. package/dist/Expand.vue.d.ts +14 -14
  119. package/dist/{Expand.vue_vue_type_script_setup_true_lang-0f236267.js → Expand.vue_vue_type_script_setup_true_lang-D0fSAtHr.js} +1 -1
  120. package/dist/{Expand.vue_vue_type_script_setup_true_lang-0f236267.js.map → Expand.vue_vue_type_script_setup_true_lang-D0fSAtHr.js.map} +1 -1
  121. package/dist/Field.js +2 -7
  122. package/dist/Field.js.map +1 -1
  123. package/dist/Field.vue.d.ts +30 -30
  124. package/dist/{Field.vue_vue_type_script_setup_true_lang-fded4f75.js → Field.vue_vue_type_script_setup_true_lang-DjxUvSRF.js} +2 -2
  125. package/dist/{Field.vue_vue_type_script_setup_true_lang-fded4f75.js.map → Field.vue_vue_type_script_setup_true_lang-DjxUvSRF.js.map} +1 -1
  126. package/dist/FileUpload.js +58 -57
  127. package/dist/FileUpload.js.map +1 -1
  128. package/dist/FileUpload.vue.d.ts +28 -28
  129. package/dist/FilterChip.js +12 -17
  130. package/dist/FilterChip.js.map +1 -1
  131. package/dist/FilterChip.vue.d.ts +19 -19
  132. package/dist/FilterDrawerItem.js +24 -30
  133. package/dist/FilterDrawerItem.js.map +1 -1
  134. package/dist/FilterDrawerItem.vue.d.ts +2 -2
  135. package/dist/FilterDropdown.js +41 -57
  136. package/dist/FilterDropdown.js.map +1 -1
  137. package/dist/FilterDropdown.vue.d.ts +9 -9
  138. package/dist/FilterSelect.js +36 -45
  139. package/dist/FilterSelect.js.map +1 -1
  140. package/dist/FilterSelect.vue.d.ts +5 -5
  141. package/dist/Filters.js +60 -96
  142. package/dist/Filters.js.map +1 -1
  143. package/dist/Filters.vue.d.ts +2005 -2294
  144. package/dist/HttpError.js +16 -23
  145. package/dist/HttpError.js.map +1 -1
  146. package/dist/HttpError.vue.d.ts +18 -18
  147. package/dist/Icon.js +28 -22
  148. package/dist/Icon.js.map +1 -1
  149. package/dist/Icon.vue.d.ts +13 -13
  150. package/dist/IconLabel.js +9 -12
  151. package/dist/IconLabel.js.map +1 -1
  152. package/dist/IconLabel.vue.d.ts +17 -17
  153. package/dist/Illustration.js +8 -11
  154. package/dist/Illustration.js.map +1 -1
  155. package/dist/Illustration.vue.d.ts +21 -21
  156. package/dist/{Illustration.vue_vue_type_script_setup_true_lang-e26c3841.js → Illustration.vue_vue_type_script_setup_true_lang-C3qG3Ty6.js} +2 -2
  157. package/dist/{Illustration.vue_vue_type_script_setup_true_lang-e26c3841.js.map → Illustration.vue_vue_type_script_setup_true_lang-C3qG3Ty6.js.map} +1 -1
  158. package/dist/Image.js.map +1 -1
  159. package/dist/Image.vue.d.ts +18 -18
  160. package/dist/InlineEdit.js +19 -30
  161. package/dist/InlineEdit.js.map +1 -1
  162. package/dist/InlineEdit.vue.d.ts +26 -26
  163. package/dist/Input.js +58 -64
  164. package/dist/Input.js.map +1 -1
  165. package/dist/Input.vue.d.ts +44 -36
  166. package/dist/InputOptions.js +66 -93
  167. package/dist/InputOptions.js.map +1 -1
  168. package/dist/InputOptions.vue.d.ts +66 -58
  169. package/dist/IntegrationIcon.js +2 -2
  170. package/dist/IntegrationIcon.js.map +1 -1
  171. package/dist/IntegrationIcon.vue.d.ts +12 -12
  172. package/dist/Label.js +2 -5
  173. package/dist/Label.js.map +1 -1
  174. package/dist/Label.vue.d.ts +17 -17
  175. package/dist/{Label.vue_vue_type_script_setup_true_lang-b6ba2f02.js → Label.vue_vue_type_script_setup_true_lang-C4JKdqvC.js} +1 -1
  176. package/dist/{Label.vue_vue_type_script_setup_true_lang-b6ba2f02.js.map → Label.vue_vue_type_script_setup_true_lang-C4JKdqvC.js.map} +1 -1
  177. package/dist/LicenseChip.js +10 -16
  178. package/dist/LicenseChip.js.map +1 -1
  179. package/dist/LicenseChip.vue.d.ts +3 -3
  180. package/dist/ListItem.js +5 -8
  181. package/dist/ListItem.js.map +1 -1
  182. package/dist/ListItem.vue.d.ts +275 -225
  183. package/dist/ListItemCell.js +1 -1
  184. package/dist/ListItemCell.js.map +1 -1
  185. package/dist/ListItemCell.vue.d.ts +13 -2
  186. package/dist/ListView.js +57 -101
  187. package/dist/ListView.js.map +1 -1
  188. package/dist/ListView.vue.d.ts +5185 -5430
  189. package/dist/Loading.js +12 -10
  190. package/dist/Loading.js.map +1 -1
  191. package/dist/Loading.vue.d.ts +1 -1
  192. package/dist/Logo.js +2 -4
  193. package/dist/Logo.js.map +1 -1
  194. package/dist/Logo.vue.d.ts +17 -17
  195. package/dist/{Logo.vue_vue_type_script_setup_true_lang-2a2597cb.js → Logo.vue_vue_type_script_setup_true_lang-BfUU9J9O.js} +1 -1
  196. package/dist/{Logo.vue_vue_type_script_setup_true_lang-2a2597cb.js.map → Logo.vue_vue_type_script_setup_true_lang-BfUU9J9O.js.map} +1 -1
  197. package/dist/Menu.js +1 -1
  198. package/dist/Menu.vue.d.ts +1 -1
  199. package/dist/MenuItem.js +1 -1
  200. package/dist/MenuItem.vue.d.ts +1 -1
  201. package/dist/{MenusPlugin-9288029a.js → MenusPlugin-Bk6UW6o9.js} +1 -1
  202. package/dist/{MenusPlugin-9288029a.js.map → MenusPlugin-Bk6UW6o9.js.map} +1 -1
  203. package/dist/Metric.vue.d.ts +10 -10
  204. package/dist/Modal.js +27 -32
  205. package/dist/Modal.js.map +1 -1
  206. package/dist/Modal.vue.d.ts +42 -42
  207. package/dist/Modals.js +14 -16
  208. package/dist/Modals.js.map +1 -1
  209. package/dist/Modals.vue.d.ts +1 -1
  210. package/dist/ModalsPlugin.js +9 -12
  211. package/dist/ModalsPlugin.js.map +1 -1
  212. package/dist/Module.js +3 -3
  213. package/dist/{Module.keys-2cc7d830.js → Module.keys-CEsrW2f0.js} +1 -1
  214. package/dist/{Module.keys-2cc7d830.js.map → Module.keys-CEsrW2f0.js.map} +1 -1
  215. package/dist/{Module.types-3f78f2a0.js → Module.types-B1FfGGac.js} +1 -1
  216. package/dist/{Module.types-3f78f2a0.js.map → Module.types-B1FfGGac.js.map} +1 -1
  217. package/dist/Module.vue.d.ts +3 -3
  218. package/dist/ModuleContent.js +2 -2
  219. package/dist/ModuleContent.vue.d.ts +1 -1
  220. package/dist/ModuleFooter.js +2 -2
  221. package/dist/ModuleFooter.vue.d.ts +1 -1
  222. package/dist/ModuleHeader.js +3 -3
  223. package/dist/ModuleHeader.vue.d.ts +15 -15
  224. package/dist/ObfuscateText.js +8 -13
  225. package/dist/ObfuscateText.js.map +1 -1
  226. package/dist/ObfuscateText.vue.d.ts +18 -18
  227. package/dist/PageContent.js +1 -1
  228. package/dist/PageContent.vue.d.ts +1 -1
  229. package/dist/PageHeader.js +26 -23
  230. package/dist/PageHeader.js.map +1 -1
  231. package/dist/PageHeader.vue.d.ts +7 -4
  232. package/dist/PageNavigation.js +41 -64
  233. package/dist/PageNavigation.js.map +1 -1
  234. package/dist/PageNavigation.vue.d.ts +10 -10
  235. package/dist/Paginate.js +36 -34
  236. package/dist/Paginate.js.map +1 -1
  237. package/dist/Paginate.vue.d.ts +11 -11
  238. package/dist/PlaidLink.js +3 -5
  239. package/dist/PlaidLink.js.map +1 -1
  240. package/dist/PlaidLink.vue.d.ts +29 -29
  241. package/dist/QuickAction.js +12 -15
  242. package/dist/QuickAction.js.map +1 -1
  243. package/dist/QuickAction.vue.d.ts +1 -1
  244. package/dist/Radio.js +1 -1
  245. package/dist/Radio.js.map +1 -1
  246. package/dist/Radio.vue.d.ts +83 -12
  247. package/dist/RadioGroup.js +41 -45
  248. package/dist/RadioGroup.js.map +1 -1
  249. package/dist/{RadioGroup.keys-974818d6.js → RadioGroup.keys-CqfiKkNz.js} +1 -1
  250. package/dist/{RadioGroup.keys-974818d6.js.map → RadioGroup.keys-CqfiKkNz.js.map} +1 -1
  251. package/dist/RadioGroup.vue.d.ts +30 -30
  252. package/dist/RadioNew.js +2 -2
  253. package/dist/RadioNew.js.map +1 -1
  254. package/dist/RadioNew.vue.d.ts +26 -26
  255. package/dist/RangeInput.js +10 -14
  256. package/dist/RangeInput.js.map +1 -1
  257. package/dist/RangeInput.vue.d.ts +1 -1
  258. package/dist/SearchBar.js +31 -41
  259. package/dist/SearchBar.js.map +1 -1
  260. package/dist/SearchBar.vue.d.ts +22 -22
  261. package/dist/Select.js +66 -78
  262. package/dist/Select.js.map +1 -1
  263. package/dist/Select.vue.d.ts +123 -123
  264. package/dist/SelectStatus.js +47 -69
  265. package/dist/SelectStatus.js.map +1 -1
  266. package/dist/SelectStatus.vue.d.ts +33 -26
  267. package/dist/Skeleton.js +1 -1
  268. package/dist/Skeleton.js.map +1 -1
  269. package/dist/Skeleton.vue.d.ts +9 -9
  270. package/dist/Step.js +10 -14
  271. package/dist/Step.js.map +1 -1
  272. package/dist/Step.vue.d.ts +21 -21
  273. package/dist/Stepper.js +37 -40
  274. package/dist/Stepper.js.map +1 -1
  275. package/dist/Stepper.vue.d.ts +34 -29
  276. package/dist/Switch.js +1 -1
  277. package/dist/Switch.vue.d.ts +23 -23
  278. package/dist/Tab.js +21 -36
  279. package/dist/Tab.js.map +1 -1
  280. package/dist/Table.js +38 -55
  281. package/dist/Table.js.map +1 -1
  282. package/dist/Table.keys-LHQf6FEH.js +7 -0
  283. package/dist/{Table.keys-83e4f09b.js.map → Table.keys-LHQf6FEH.js.map} +1 -1
  284. package/dist/Table.vue.d.ts +36 -36
  285. package/dist/TableCell.js +26 -26
  286. package/dist/TableCell.js.map +1 -1
  287. package/dist/TableCell.vue.d.ts +6 -6
  288. package/dist/TableHeaderCell.js +6 -13
  289. package/dist/TableHeaderCell.js.map +1 -1
  290. package/dist/TableHeaderCell.vue.d.ts +3 -3
  291. package/dist/TableHeaderRow.js +22 -32
  292. package/dist/TableHeaderRow.js.map +1 -1
  293. package/dist/TableHeaderRow.vue.d.ts +8 -8
  294. package/dist/TableRow.js +59 -59
  295. package/dist/TableRow.js.map +1 -1
  296. package/dist/TableRow.vue.d.ts +26 -26
  297. package/dist/Tabs.js +10 -24
  298. package/dist/Tabs.js.map +1 -1
  299. package/dist/Tabs.vue.d.ts +5 -5
  300. package/dist/{Tabs.vue_used_vue_type_style_index_0_lang.module-d7530989.js → Tabs.vue_vue_type_script_setup_true_lang-l41hWkV4.js} +31 -34
  301. package/dist/Tabs.vue_vue_type_script_setup_true_lang-l41hWkV4.js.map +1 -0
  302. package/dist/TextEditor.js +1269 -1364
  303. package/dist/TextEditor.js.map +1 -1
  304. package/dist/TextEditor.vue.d.ts +46 -46
  305. package/dist/Textarea.js +30 -31
  306. package/dist/Textarea.js.map +1 -1
  307. package/dist/Textarea.vue.d.ts +34 -26
  308. package/dist/Timeline.js +9 -10
  309. package/dist/Timeline.js.map +1 -1
  310. package/dist/Timeline.vue.d.ts +6 -6
  311. package/dist/TimelineItem.js +1 -1
  312. package/dist/TimelineItem.vue.d.ts +1 -1
  313. package/dist/Toast.js +5 -9
  314. package/dist/Toast.js.map +1 -1
  315. package/dist/Toast.vue.d.ts +3 -3
  316. package/dist/Toasts.js +15 -25
  317. package/dist/Toasts.js.map +1 -1
  318. package/dist/Toasts.vue.d.ts +1 -1
  319. package/dist/ToastsPlugin.js +11 -23
  320. package/dist/ToastsPlugin.js.map +1 -1
  321. package/dist/Tooltip.js +1 -1
  322. package/dist/Tooltip.js.map +1 -1
  323. package/dist/Tooltip.vue.d.ts +15 -15
  324. package/dist/{_commonjsHelpers-10dfc225.js → _commonjsHelpers-DaMA6jEr.js} +1 -1
  325. package/dist/_commonjsHelpers-DaMA6jEr.js.map +1 -0
  326. package/dist/{_plugin-vue_export-helper-dad06003.js → _plugin-vue_export-helper-CHgC5LLL.js} +1 -1
  327. package/dist/_plugin-vue_export-helper-CHgC5LLL.js.map +1 -0
  328. package/dist/{colors-8d9b9429.js → colors-DDDVvqfQ.js} +1 -1
  329. package/dist/{colors-8d9b9429.js.map → colors-DDDVvqfQ.js.map} +1 -1
  330. package/dist/components.css +2 -2
  331. package/dist/directives/observe.js.map +1 -1
  332. package/dist/directives/sticky.js.map +1 -1
  333. package/dist/directives/tooltip.js +21 -27
  334. package/dist/directives/tooltip.js.map +1 -1
  335. package/dist/directives/viewable.js +1 -1
  336. package/dist/directives/viewable.js.map +1 -1
  337. package/dist/{floating-ui.vue-8d7f7932.js → floating-ui.vue-BmfQDqE-.js} +2 -3
  338. package/dist/{floating-ui.vue-8d7f7932.js.map → floating-ui.vue-BmfQDqE-.js.map} +1 -1
  339. package/dist/{formatDateTime-a5e70901.js → formatDateTime-C8CYECpd.js} +8 -12
  340. package/dist/{formatDateTime-a5e70901.js.map → formatDateTime-C8CYECpd.js.map} +1 -1
  341. package/dist/{index-9e1095ef.js → index-D6bxWkZ1.js} +2 -3
  342. package/dist/{index-9e1095ef.js.map → index-D6bxWkZ1.js.map} +1 -1
  343. package/dist/index.d.ts +1 -1
  344. package/dist/index.js +90 -112
  345. package/dist/index.js.map +1 -1
  346. package/dist/{isDefined-2ce6cde4.js → isDefined-DzVx0B6k.js} +1 -1
  347. package/dist/{isDefined-2ce6cde4.js.map → isDefined-DzVx0B6k.js.map} +1 -1
  348. package/dist/{isValid-4b2b7a54.js → isValid-DN-HkCoi.js} +1 -1
  349. package/dist/{isValid-4b2b7a54.js.map → isValid-DN-HkCoi.js.map} +1 -1
  350. package/dist/{keys-241d03b7.js → keys-BEdEsanp.js} +1 -1
  351. package/dist/{keys-241d03b7.js.map → keys-BEdEsanp.js.map} +1 -1
  352. package/dist/{keys-7ecef029.js → keys-C8Zfr_By.js} +1 -1
  353. package/dist/{keys-7ecef029.js.map → keys-C8Zfr_By.js.map} +1 -1
  354. package/dist/{misc-76697f61.js → misc-CHQs-G03.js} +1 -1
  355. package/dist/{misc-76697f61.js.map → misc-CHQs-G03.js.map} +1 -1
  356. package/dist/{parseISO-ed4094c1.js → parseISO-wlfIB_QJ.js} +12 -18
  357. package/dist/{parseISO-ed4094c1.js.map → parseISO-wlfIB_QJ.js.map} +1 -1
  358. package/dist/{searchFuzzy-9b74ec4e.js → searchFuzzy-DKooyZM8.js} +110 -149
  359. package/dist/{searchFuzzy-9b74ec4e.js.map → searchFuzzy-DKooyZM8.js.map} +1 -1
  360. package/dist/{statusLevels-a8b041f4.js → statusLevels-D8EgtE_L.js} +1 -1
  361. package/dist/{statusLevels-a8b041f4.js.map → statusLevels-D8EgtE_L.js.map} +1 -1
  362. package/dist/storage.js +8 -15
  363. package/dist/storage.js.map +1 -1
  364. package/dist/tailwind-base.js.map +1 -1
  365. package/dist/{toTimeZone-a2ed6470.js → toTimeZone-CVE1ZmsS.js} +1 -1
  366. package/dist/{toTimeZone-a2ed6470.js.map → toTimeZone-CVE1ZmsS.js.map} +1 -1
  367. package/dist/useDialog.js +7 -7
  368. package/dist/useGoogleMaps.js +18 -28
  369. package/dist/useGoogleMaps.js.map +1 -1
  370. package/dist/useModals.js +1 -2
  371. package/dist/useModals.js.map +1 -1
  372. package/dist/useScriptTag.js.map +1 -1
  373. package/dist/useSearch.js +14 -19
  374. package/dist/useSearch.js.map +1 -1
  375. package/dist/useStepper.js.map +1 -1
  376. package/dist/useValidation.js +1 -1
  377. package/dist/useValidation.js.map +1 -1
  378. package/dist/utils/calculateElementOverflow.js +9 -13
  379. package/dist/utils/calculateElementOverflow.js.map +1 -1
  380. package/dist/utils/colorScheme.js.map +1 -1
  381. package/dist/utils/createQueryString.js +4 -5
  382. package/dist/utils/createQueryString.js.map +1 -1
  383. package/dist/utils/createValidDate.js +2 -2
  384. package/dist/utils/formatDateTime.js +4 -5
  385. package/dist/utils/formatDateTime.js.map +1 -1
  386. package/dist/utils/getContrastingTextColor.js +1 -1
  387. package/dist/utils/getContrastingTextColor.js.map +1 -1
  388. package/dist/utils/helpers.js.map +1 -1
  389. package/dist/utils/i18n.js +25 -26
  390. package/dist/utils/i18n.js.map +1 -1
  391. package/dist/utils/normalizeDate.js +1 -1
  392. package/dist/utils/searchFuzzy.js +3 -10
  393. package/dist/utils/searchFuzzy.js.map +1 -1
  394. package/dist/utils/storage.js +6 -11
  395. package/dist/utils/storage.js.map +1 -1
  396. package/dist/utils/toTimeZone.js +2 -3
  397. package/dist/utils/toTimeZone.js.map +1 -1
  398. package/package.json +13 -14
  399. package/dist/Button.vue_used_vue_type_style_index_0_lang.module-4dabc2a9.js +0 -17
  400. package/dist/Button.vue_used_vue_type_style_index_0_lang.module-4dabc2a9.js.map +0 -1
  401. package/dist/Carousel.types.d.ts +0 -33
  402. package/dist/Carousel.types.js +0 -2
  403. package/dist/Carousel.types.js.map +0 -1
  404. package/dist/Checkbox.vue_used_vue_type_style_index_0_lang.module-fa8d9c06.js +0 -9
  405. package/dist/Checkbox.vue_used_vue_type_style_index_0_lang.module-fa8d9c06.js.map +0 -1
  406. package/dist/DataView.vue_used_vue_type_style_index_0_lang.module-5c180dba.js.map +0 -1
  407. package/dist/EmptyState.vue_used_vue_type_style_index_0_lang.module-f5d89366.js +0 -8
  408. package/dist/EmptyState.vue_used_vue_type_style_index_0_lang.module-f5d89366.js.map +0 -1
  409. package/dist/Icon.vue_used_vue_type_style_index_0_lang.module-eb359559.js +0 -11
  410. package/dist/Icon.vue_used_vue_type_style_index_0_lang.module-eb359559.js.map +0 -1
  411. package/dist/Loading.vue_used_vue_type_style_index_0_lang.module-ef5a3bc6.js +0 -8
  412. package/dist/Loading.vue_used_vue_type_style_index_0_lang.module-ef5a3bc6.js.map +0 -1
  413. package/dist/Paginate.vue_used_vue_type_style_index_0_lang.module-18343da7.js +0 -11
  414. package/dist/Paginate.vue_used_vue_type_style_index_0_lang.module-18343da7.js.map +0 -1
  415. package/dist/Table.keys-83e4f09b.js +0 -27
  416. package/dist/Tabs.vue_used_vue_type_style_index_0_lang.module-d7530989.js.map +0 -1
  417. package/dist/_commonjsHelpers-10dfc225.js.map +0 -1
  418. package/dist/_plugin-vue_export-helper-dad06003.js.map +0 -1
@@ -33,38 +33,38 @@ declare type __VLS_WithTemplateSlots<T, S> = T & {
33
33
  };
34
34
 
35
35
  declare const _default: __VLS_WithTemplateSlots<DefineComponent<ExtractPropTypes<__VLS_WithDefaults<__VLS_TypePropsToRuntimeProps<FieldProps>, {
36
- addBottomSpace: boolean;
37
- errorText: undefined;
38
- hintText: undefined;
39
- id: undefined;
40
- errorId: undefined;
41
- isRequired: boolean;
42
- label: undefined;
43
- showOptionalInLabel: boolean;
44
- fieldset: boolean;
45
- disabled: boolean;
36
+ addBottomSpace: boolean;
37
+ errorText: undefined;
38
+ hintText: undefined;
39
+ id: undefined;
40
+ errorId: undefined;
41
+ isRequired: boolean;
42
+ label: undefined;
43
+ showOptionalInLabel: boolean;
44
+ fieldset: boolean;
45
+ disabled: boolean;
46
46
  }>>, {}, {}, {}, {}, ComponentOptionsMixin, ComponentOptionsMixin, {}, string, PublicProps, Readonly<ExtractPropTypes<__VLS_WithDefaults<__VLS_TypePropsToRuntimeProps<FieldProps>, {
47
- addBottomSpace: boolean;
48
- errorText: undefined;
49
- hintText: undefined;
50
- id: undefined;
51
- errorId: undefined;
52
- isRequired: boolean;
53
- label: undefined;
54
- showOptionalInLabel: boolean;
55
- fieldset: boolean;
56
- disabled: boolean;
47
+ addBottomSpace: boolean;
48
+ errorText: undefined;
49
+ hintText: undefined;
50
+ id: undefined;
51
+ errorId: undefined;
52
+ isRequired: boolean;
53
+ label: undefined;
54
+ showOptionalInLabel: boolean;
55
+ fieldset: boolean;
56
+ disabled: boolean;
57
57
  }>>> & Readonly<{}>, {
58
- disabled: boolean;
59
- fieldset: boolean;
60
- label: string;
61
- id: string;
62
- isRequired: boolean;
63
- addBottomSpace: boolean;
64
- errorText: string;
65
- hintText: string;
66
- errorId: string;
67
- showOptionalInLabel: boolean;
58
+ disabled: boolean;
59
+ fieldset: boolean;
60
+ label: string;
61
+ id: string;
62
+ isRequired: boolean;
63
+ addBottomSpace: boolean;
64
+ errorText: string;
65
+ hintText: string;
66
+ errorId: string;
67
+ showOptionalInLabel: boolean;
68
68
  }, {}, {}, {}, string, ComponentProvideOptions, true, {}, any>, {
69
69
  default?(_: {
70
70
  fieldId: string;
@@ -1,6 +1,6 @@
1
1
  import { defineComponent as _, useAttrs as B, useSlots as T, computed as l, openBlock as a, createBlock as w, resolveDynamicComponent as k, mergeProps as O, unref as f, withCtx as b, createTextVNode as R, toDisplayString as h, createCommentVNode as m, createElementBlock as o, renderSlot as u } from "vue";
2
2
  import p from "lodash-es/uniqueId";
3
- import { _ as q } from "./Label.vue_vue_type_script_setup_true_lang-b6ba2f02.js";
3
+ import { _ as q } from "./Label.vue_vue_type_script_setup_true_lang-C4JKdqvC.js";
4
4
  const E = ["aria-labelledby"], L = ["id"], S = {
5
5
  key: 4,
6
6
  class: "stash-field-hint tw-mt-1 tw-block tw-whitespace-pre-line tw-text-xs",
@@ -92,4 +92,4 @@ const E = ["aria-labelledby"], L = ["id"], S = {
92
92
  export {
93
93
  D as _
94
94
  };
95
- //# sourceMappingURL=Field.vue_vue_type_script_setup_true_lang-fded4f75.js.map
95
+ //# sourceMappingURL=Field.vue_vue_type_script_setup_true_lang-DjxUvSRF.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Field.vue_vue_type_script_setup_true_lang-fded4f75.js","sources":["../src/components/Field/Field.vue"],"sourcesContent":["<script setup lang=\"ts\">\n import uniqueId from 'lodash-es/uniqueId';\n import { computed, useAttrs, useSlots } from 'vue';\n\n import Label from '../Label/Label.vue';\n\n defineOptions({\n inheritAttrs: false,\n });\n\n export interface FieldProps {\n /**\n * Adds spacing under the field that is consistent whether hint/error text is displayed.\n */\n addBottomSpace?: boolean;\n\n /**\n * Error text to display. Replaces `hintText` (if provided) & adds error styling.\n */\n errorText?: string;\n\n /**\n * Displays text below the input; hidden when the isReadOnly prop is truthy.\n */\n hintText?: string;\n\n /**\n * ID for the Label and Input; must be unique\n */\n id?: string;\n\n /**\n * ID for the error text element; useful for aria-errormessage\n */\n errorId?: string;\n\n /**\n * Whether it's a readonly field.\n */\n isReadOnly?: boolean;\n\n /**\n * Whether the field is required.\n */\n isRequired?: boolean;\n\n /**\n * Label to render above the input.\n */\n label?: string;\n\n /**\n * Show \"(optional)\" to the right of the label text\n */\n showOptionalInLabel?: boolean;\n\n /**\n * Indicates wheter the field is a fieldset or not\n */\n fieldset?: boolean;\n\n /**\n * Indicates whether the field is disabled.\n */\n disabled?: boolean;\n }\n\n const props = withDefaults(defineProps<FieldProps>(), {\n addBottomSpace: false,\n errorText: undefined,\n hintText: undefined,\n id: undefined,\n errorId: undefined,\n isRequired: false,\n label: undefined,\n showOptionalInLabel: false,\n fieldset: false,\n disabled: false,\n });\n const attrs = useAttrs();\n const slots = useSlots();\n const fieldId = computed(() => props.id || uniqueId('stash-field-'));\n const fieldErrorId = computed(() => props.errorId || uniqueId('stash-field-error-'));\n const labelId = computed(() => uniqueId('stash-field-label-'));\n const hasError = computed(() => !!props.errorText);\n const wrapperElement = computed(() => (props.fieldset ? 'fieldset' : 'div'));\n\n // Any attributes that are unique to form elements, you want to exclude from\n // being bound from the root element.\n const rootAttrs = computed(() => {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { placeholder, ...otherAttrs } = attrs;\n\n return otherAttrs;\n });\n</script>\n\n<template>\n <component\n :is=\"wrapperElement\"\n data-test=\"stash-field\"\n class=\"stash-field\"\n :class=\"[\n { 'tw-p-0': props.fieldset },\n { 'tw-mb-9': props.addBottomSpace && !props.errorText && !props.hintText && !slots.hint },\n { 'tw-mb-4': props.addBottomSpace && (props.errorText || props.hintText || slots.hint) },\n { 'stash-field--disabled': props.disabled },\n ]\"\n v-bind=\"rootAttrs\"\n >\n <Label\n v-if=\"props.label\"\n :id=\"labelId\"\n :for=\"fieldId\"\n :has-error=\"hasError\"\n :is-required=\"isRequired\"\n :show-optional=\"props.showOptionalInLabel\"\n :legend=\"props.fieldset\"\n :disabled=\"props.disabled\"\n >\n {{ props.label }}\n </Label>\n\n <!-- @slot for the form field; the Label can also be rendered here instead of using the label prop -->\n <template v-if=\"props.isReadOnly\">\n <div :aria-labelledby=\"labelId\">\n <slot\n :field-id=\"fieldId\"\n :field-error-id=\"fieldErrorId\"\n :has-error=\"hasError\"\n :is-required=\"isRequired\"\n :label-id=\"labelId\"\n :show-optional-in-label=\"props.showOptionalInLabel\"\n ></slot>\n </div>\n </template>\n <template v-else>\n <slot\n :field-id=\"fieldId\"\n :field-error-id=\"fieldErrorId\"\n :has-error=\"hasError\"\n :is-required=\"isRequired\"\n :label-id=\"labelId\"\n :show-optional-in-label=\"props.showOptionalInLabel\"\n ></slot>\n </template>\n\n <span\n v-if=\"props.errorText\"\n :id=\"fieldErrorId\"\n class=\"stash-field-error tw-mt-1 tw-block tw-whitespace-pre-line tw-text-xs tw-text-red-500\"\n data-test=\"stash-field-error\"\n >\n {{ props.errorText }}\n </span>\n\n <span\n v-else-if=\"props.hintText && !props.isReadOnly\"\n class=\"stash-field-hint tw-mt-1 tw-block tw-whitespace-pre-line tw-text-xs\"\n data-test=\"stash-field-hint\"\n >\n {{ props.hintText }}\n </span>\n\n <div\n v-else-if=\"slots.hint && !props.isReadOnly\"\n class=\"stash-field-hint tw-mt-1 tw-whitespace-pre-line tw-text-xs\"\n data-test=\"stash-field-hint\"\n >\n <!-- @slot for displaying hint text below the field -->\n <slot name=\"hint\"></slot>\n </div>\n </component>\n</template>\n"],"names":["props","__props","attrs","useAttrs","slots","useSlots","fieldId","computed","uniqueId","fieldErrorId","labelId","hasError","wrapperElement","rootAttrs","placeholder","otherAttrs"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAmEE,UAAMA,IAAQC,GAYRC,IAAQC,KACRC,IAAQC,KACRC,IAAUC,EAAS,MAAMP,EAAM,MAAMQ,EAAS,cAAc,CAAC,GAC7DC,IAAeF,EAAS,MAAMP,EAAM,WAAWQ,EAAS,oBAAoB,CAAC,GAC7EE,IAAUH,EAAS,MAAMC,EAAS,oBAAoB,CAAC,GACvDG,IAAWJ,EAAS,MAAM,CAAC,CAACP,EAAM,SAAS,GAC3CY,IAAiBL,EAAS,MAAOP,EAAM,WAAW,aAAa,KAAM,GAIrEa,IAAYN,EAAS,MAAM;AAE/B,YAAM,EAAE,aAAAO,GAAa,GAAGC,EAAA,IAAeb;AAEhC,aAAAa;AAAA,IAAA,CACR;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"Field.vue_vue_type_script_setup_true_lang-DjxUvSRF.js","sources":["../src/components/Field/Field.vue"],"sourcesContent":["<script setup lang=\"ts\">\n import uniqueId from 'lodash-es/uniqueId';\n import { computed, useAttrs, useSlots } from 'vue';\n\n import Label from '../Label/Label.vue';\n\n defineOptions({\n inheritAttrs: false,\n });\n\n export interface FieldProps {\n /**\n * Adds spacing under the field that is consistent whether hint/error text is displayed.\n */\n addBottomSpace?: boolean;\n\n /**\n * Error text to display. Replaces `hintText` (if provided) & adds error styling.\n */\n errorText?: string;\n\n /**\n * Displays text below the input; hidden when the isReadOnly prop is truthy.\n */\n hintText?: string;\n\n /**\n * ID for the Label and Input; must be unique\n */\n id?: string;\n\n /**\n * ID for the error text element; useful for aria-errormessage\n */\n errorId?: string;\n\n /**\n * Whether it's a readonly field.\n */\n isReadOnly?: boolean;\n\n /**\n * Whether the field is required.\n */\n isRequired?: boolean;\n\n /**\n * Label to render above the input.\n */\n label?: string;\n\n /**\n * Show \"(optional)\" to the right of the label text\n */\n showOptionalInLabel?: boolean;\n\n /**\n * Indicates wheter the field is a fieldset or not\n */\n fieldset?: boolean;\n\n /**\n * Indicates whether the field is disabled.\n */\n disabled?: boolean;\n }\n\n const props = withDefaults(defineProps<FieldProps>(), {\n addBottomSpace: false,\n errorText: undefined,\n hintText: undefined,\n id: undefined,\n errorId: undefined,\n isRequired: false,\n label: undefined,\n showOptionalInLabel: false,\n fieldset: false,\n disabled: false,\n });\n const attrs = useAttrs();\n const slots = useSlots();\n const fieldId = computed(() => props.id || uniqueId('stash-field-'));\n const fieldErrorId = computed(() => props.errorId || uniqueId('stash-field-error-'));\n const labelId = computed(() => uniqueId('stash-field-label-'));\n const hasError = computed(() => !!props.errorText);\n const wrapperElement = computed(() => (props.fieldset ? 'fieldset' : 'div'));\n\n // Any attributes that are unique to form elements, you want to exclude from\n // being bound from the root element.\n const rootAttrs = computed(() => {\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n const { placeholder, ...otherAttrs } = attrs;\n\n return otherAttrs;\n });\n</script>\n\n<template>\n <component\n :is=\"wrapperElement\"\n data-test=\"stash-field\"\n class=\"stash-field\"\n :class=\"[\n { 'tw-p-0': props.fieldset },\n { 'tw-mb-9': props.addBottomSpace && !props.errorText && !props.hintText && !slots.hint },\n { 'tw-mb-4': props.addBottomSpace && (props.errorText || props.hintText || slots.hint) },\n { 'stash-field--disabled': props.disabled },\n ]\"\n v-bind=\"rootAttrs\"\n >\n <Label\n v-if=\"props.label\"\n :id=\"labelId\"\n :for=\"fieldId\"\n :has-error=\"hasError\"\n :is-required=\"isRequired\"\n :show-optional=\"props.showOptionalInLabel\"\n :legend=\"props.fieldset\"\n :disabled=\"props.disabled\"\n >\n {{ props.label }}\n </Label>\n\n <!-- @slot for the form field; the Label can also be rendered here instead of using the label prop -->\n <template v-if=\"props.isReadOnly\">\n <div :aria-labelledby=\"labelId\">\n <slot\n :field-id=\"fieldId\"\n :field-error-id=\"fieldErrorId\"\n :has-error=\"hasError\"\n :is-required=\"isRequired\"\n :label-id=\"labelId\"\n :show-optional-in-label=\"props.showOptionalInLabel\"\n ></slot>\n </div>\n </template>\n <template v-else>\n <slot\n :field-id=\"fieldId\"\n :field-error-id=\"fieldErrorId\"\n :has-error=\"hasError\"\n :is-required=\"isRequired\"\n :label-id=\"labelId\"\n :show-optional-in-label=\"props.showOptionalInLabel\"\n ></slot>\n </template>\n\n <span\n v-if=\"props.errorText\"\n :id=\"fieldErrorId\"\n class=\"stash-field-error tw-mt-1 tw-block tw-whitespace-pre-line tw-text-xs tw-text-red-500\"\n data-test=\"stash-field-error\"\n >\n {{ props.errorText }}\n </span>\n\n <span\n v-else-if=\"props.hintText && !props.isReadOnly\"\n class=\"stash-field-hint tw-mt-1 tw-block tw-whitespace-pre-line tw-text-xs\"\n data-test=\"stash-field-hint\"\n >\n {{ props.hintText }}\n </span>\n\n <div\n v-else-if=\"slots.hint && !props.isReadOnly\"\n class=\"stash-field-hint tw-mt-1 tw-whitespace-pre-line tw-text-xs\"\n data-test=\"stash-field-hint\"\n >\n <!-- @slot for displaying hint text below the field -->\n <slot name=\"hint\"></slot>\n </div>\n </component>\n</template>\n"],"names":["props","__props","attrs","useAttrs","slots","useSlots","fieldId","computed","uniqueId","fieldErrorId","labelId","hasError","wrapperElement","rootAttrs","placeholder","otherAttrs"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;AAmEE,UAAMA,IAAQC,GAYRC,IAAQC,KACRC,IAAQC,KACRC,IAAUC,EAAS,MAAMP,EAAM,MAAMQ,EAAS,cAAc,CAAC,GAC7DC,IAAeF,EAAS,MAAMP,EAAM,WAAWQ,EAAS,oBAAoB,CAAC,GAC7EE,IAAUH,EAAS,MAAMC,EAAS,oBAAoB,CAAC,GACvDG,IAAWJ,EAAS,MAAM,CAAC,CAACP,EAAM,SAAS,GAC3CY,IAAiBL,EAAS,MAAOP,EAAM,WAAW,aAAa,KAAM,GAIrEa,IAAYN,EAAS,MAAM;AAE/B,YAAM,EAAE,aAAAO,GAAa,GAAGC,EAAA,IAAeb;AAEhC,aAAAa;AAAA,IAAA,CACR;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -1,14 +1,10 @@
1
- import { defineComponent as q, useCssModule as K, ref as U, inject as Q, useAttrs as W, computed as w, openBlock as n, createElementBlock as a, normalizeClass as d, unref as l, createVNode as g, withModifiers as c, withCtx as I, renderSlot as S, createTextVNode as N, toDisplayString as p, createElementVNode as v, Fragment as k, createBlock as Z, createCommentVNode as R, renderList as ee, withDirectives as te, mergeProps as le, vShow as se } from "vue";
1
+ import { defineComponent as q, useCssModule as K, ref as U, inject as Q, useAttrs as W, computed as w, openBlock as n, createElementBlock as r, normalizeClass as c, unref as l, createVNode as g, withModifiers as p, withCtx as I, renderSlot as S, createTextVNode as N, toDisplayString as u, createElementVNode as v, Fragment as k, createBlock as Z, createCommentVNode as R, renderList as ee, withDirectives as te, mergeProps as le, vShow as se } from "vue";
2
2
  import ne from "@leaflink/snitch";
3
- import { I as oe } from "./index-9e1095ef.js";
4
- import { t as u } from "./locale.js";
3
+ import { I as oe } from "./index-D6bxWkZ1.js";
4
+ import { t as f } from "./locale.js";
5
5
  import F from "./Button.js";
6
- import ie from "./Icon.js";
7
- import { _ as ae } from "./_plugin-vue_export-helper-dad06003.js";
8
- import "lodash-es/get";
9
- import "./Button.vue_used_vue_type_style_index_0_lang.module-4dabc2a9.js";
10
- import "lodash-es/uniqueId";
11
- import "./Icon.vue_used_vue_type_style_index_0_lang.module-eb359559.js";
6
+ import ae from "./Icon.js";
7
+ import { _ as ie } from "./_plugin-vue_export-helper-CHgC5LLL.js";
12
8
  const M = {
13
9
  CSV: {
14
10
  EXTENSION: ["csv"],
@@ -41,7 +37,7 @@ const M = {
41
37
  ILLUSTRATION: "csv"
42
38
  }
43
39
  };
44
- var h = /* @__PURE__ */ ((f) => (f.Dense = "dense", f.Standard = "standard", f))(h || {});
40
+ var h = /* @__PURE__ */ ((m) => (m.Dense = "dense", m.Standard = "standard", m))(h || {});
45
41
  const re = { key: 0 }, de = { class: "tw-text-ice-900" }, ce = {
46
42
  key: 0,
47
43
  class: "tw-mt-6 tw-text-center tw-text-xs tw-text-ice-700"
@@ -56,16 +52,16 @@ const re = { key: 0 }, de = { class: "tw-text-ice-900" }, ce = {
56
52
  size: { default: "standard" }
57
53
  },
58
54
  emits: ["file-select", "file-delete", "file-error"],
59
- setup(f, { emit: A }) {
60
- const m = f, r = K(), E = A, y = U(!1), T = U(), b = Q("stashOptions"), D = W(), X = w(() => {
61
- const e = { ...D };
55
+ setup(m, { emit: A }) {
56
+ const o = m, d = K(), E = A, y = U(!1), T = U(), _ = Q("stashOptions"), x = W(), X = w(() => {
57
+ const e = { ...x };
62
58
  return delete e["data-test"], delete e.class, delete e.type, delete e.accept, e;
63
59
  });
64
- function O(e, t) {
60
+ function D(e, t) {
65
61
  return e.concat(t);
66
62
  }
67
- const _ = w(() => m.fileTypes.map((e) => M[e].MIME_TYPES).reduce(O)), L = w(() => m.fileTypes.map((e) => M[e].EXTENSION).reduce(O)), Y = w(() => `${b == null ? void 0 : b.staticPath}/illustrations/FileUpload/${M[m.fileTypes[0]].ILLUSTRATION}.svg`);
68
- function x() {
63
+ const b = w(() => o.fileTypes.map((e) => M[e].MIME_TYPES).reduce(D)), O = w(() => o.fileTypes.map((e) => M[e].EXTENSION).reduce(D)), Y = w(() => `${_ == null ? void 0 : _.staticPath}/illustrations/FileUpload/${M[o.fileTypes[0]].ILLUSTRATION}.svg`);
64
+ function L() {
69
65
  T.value && (T.value.value = "", T.value.click());
70
66
  }
71
67
  function $() {
@@ -75,20 +71,19 @@ const re = { key: 0 }, de = { class: "tw-text-ice-900" }, ce = {
75
71
  y.value = !1;
76
72
  }
77
73
  function B(e) {
78
- const t = u("ll.fileUpload.errors.incorrectFileType", {
79
- fileTypes: L.value.join(", ")
74
+ const t = f("ll.fileUpload.errors.incorrectFileType", {
75
+ fileTypes: O.value.join(", ")
80
76
  });
81
77
  E("file-error", t), ne.log(e);
82
78
  }
83
79
  async function V(e) {
84
- if (!_.value.length)
85
- return !0;
80
+ if (!b.value.length) return !0;
86
81
  const t = await Promise.all(e.map((i) => H(i)));
87
- if (!(!!t.length && t.every((i) => _.value.includes(i))))
82
+ if (!(!!t.length && t.every((i) => b.value.includes(i))))
88
83
  throw new Error("One or more files contains an unacceptable mime type.");
89
84
  if (!e.every((i) => {
90
85
  const C = i.name.split(".").pop();
91
- return C && L.value.includes(C);
86
+ return C && O.value.includes(C);
92
87
  }))
93
88
  throw new Error("One or more files contains an unacceptable extension.");
94
89
  return !0;
@@ -107,7 +102,7 @@ const re = { key: 0 }, de = { class: "tw-text-ice-900" }, ce = {
107
102
  }
108
103
  function G(e) {
109
104
  var s;
110
- if (m.disabled)
105
+ if (o.disabled)
111
106
  return;
112
107
  const t = [...((s = e.dataTransfer) == null ? void 0 : s.files) || []];
113
108
  return y.value = !1, P(t);
@@ -120,58 +115,64 @@ const re = { key: 0 }, de = { class: "tw-text-ice-900" }, ce = {
120
115
  if (e.type)
121
116
  return t(e.type);
122
117
  if (window.FileReader) {
123
- const o = new FileReader();
124
- o.onload = () => {
125
- const i = o.result && o.result.match(/[^:]\w+\/[\w-+\d.]+(?=;|,)/) ? o.result.match(/[^:]\w+\/[\w-+\d.]+(?=;|,)/)[0] : "";
118
+ const a = new FileReader();
119
+ a.onload = () => {
120
+ const i = a.result && a.result.match(/[^:]\w+\/[\w-+\d.]+(?=;|,)/) ? a.result.match(/[^:]\w+\/[\w-+\d.]+(?=;|,)/)[0] : "";
126
121
  t(i);
127
- }, o.readAsDataURL(e);
122
+ }, a.readAsDataURL(e);
128
123
  } else
129
124
  s(new Error("Failed to read file."));
130
125
  });
131
126
  }
132
- return (e, t) => (n(), a("div", {
133
- class: d(["stash-file-upload", l(D).class]),
127
+ return (e, t) => (n(), r("div", {
128
+ class: c(["stash-file-upload", l(x).class]),
134
129
  "data-test": "stash-file-upload"
135
130
  }, [
136
- e.buttonOnly ? (n(), a("div", re, [
131
+ e.buttonOnly ? (n(), r("div", re, [
137
132
  g(F, {
138
133
  secondary: "",
139
134
  type: "button",
140
- disabled: e.disabled || null,
141
- onClick: c(x, ["stop", "prevent"])
135
+ disabled: o.disabled,
136
+ onClick: p(L, ["stop", "prevent"])
142
137
  }, {
143
138
  default: I(() => [
144
139
  S(e.$slots, "submitText", {}, () => [
145
- N(p(l(u)("ll.fileUpload.uploadFile")), 1)
140
+ N(u(l(f)("ll.fileUpload.uploadFile")), 1)
146
141
  ])
147
142
  ]),
148
143
  _: 3
149
144
  }, 8, ["disabled"])
150
- ])) : (n(), a("div", {
145
+ ])) : (n(), r("div", {
151
146
  key: 1,
152
- class: d(["tw-rounded tw-p-6", [l(r)["file-dropbox"], y.value && l(r)["is-dragging"], e.disabled && l(r)["is-disabled"]]]),
153
- onDragover: c($, ["prevent"]),
154
- onDrop: c(G, ["prevent"]),
155
- onDragleave: c(j, ["prevent"])
147
+ class: c(["tw-rounded tw-p-6", [
148
+ l(d)["file-dropbox"],
149
+ {
150
+ [l(d)["is-dragging"]]: y.value,
151
+ [l(d)["is-disabled"]]: o.disabled
152
+ }
153
+ ]]),
154
+ onDragover: p($, ["prevent"]),
155
+ onDrop: p(G, ["prevent"]),
156
+ onDragleave: p(j, ["prevent"])
156
157
  }, [
157
158
  v("div", {
158
- class: d(["tw-flex tw-flex-col tw-items-center tw-justify-center tw-text-center", [{ "tw-items-center md:tw-flex-row": e.size === l(h).Dense }]])
159
+ class: c(["tw-flex tw-flex-col tw-items-center tw-justify-center tw-text-center", [{ "tw-items-center md:tw-flex-row": e.size === l(h).Dense }]])
159
160
  }, [
160
- e.files.length ? (n(!0), a(k, { key: 1 }, ee(e.files, (s) => (n(), a("div", {
161
+ e.files.length ? (n(!0), r(k, { key: 1 }, ee(e.files, (s) => (n(), r("div", {
161
162
  key: s.name
162
163
  }, [
163
- g(ie, { name: "file" }),
164
- v("span", null, p(s.name), 1),
164
+ g(ae, { name: "file" }),
165
+ v("span", null, u(s.name), 1),
165
166
  g(F, {
166
- class: d([l(r)["remove-button"], l(r).button]),
167
- onClick: c((o) => J(s), ["stop", "prevent"])
167
+ class: c([l(d)["remove-button"], l(d).button]),
168
+ onClick: p((a) => J(s), ["stop", "prevent"])
168
169
  }, {
169
170
  default: I(() => [
170
- N(p(l(u)("ll.fileUpload.remove")), 1)
171
+ N(u(l(f)("ll.fileUpload.remove")), 1)
171
172
  ]),
172
173
  _: 2
173
174
  }, 1032, ["class", "onClick"])
174
- ]))), 128)) : (n(), a(k, { key: 0 }, [
175
+ ]))), 128)) : (n(), r(k, { key: 0 }, [
175
176
  e.size !== l(h).Dense ? (n(), Z(l(oe), {
176
177
  key: 0,
177
178
  src: Y.value,
@@ -179,29 +180,29 @@ const re = { key: 0 }, de = { class: "tw-text-ice-900" }, ce = {
179
180
  width: "84",
180
181
  height: "96"
181
182
  }, null, 8, ["src"])) : R("", !0),
182
- v("span", de, p(l(u)("ll.fileUpload.dragDropFileHere")), 1),
183
+ v("span", de, u(l(f)("ll.fileUpload.dragDropFileHere")), 1),
183
184
  v("span", {
184
- class: d(
185
+ class: c(
185
186
  e.size === l(h).Dense ? "md:tw-ml-1.5 md:tw-mr-3 md:tw-my-0 tw-my-1.5 tw-text-ice-900" : "tw-mt-1.5 tw-my-1.5"
186
187
  )
187
- }, p(l(u)("ll.fileUpload.or")), 3),
188
+ }, u(l(f)("ll.fileUpload.or")), 3),
188
189
  g(F, {
189
- class: d(["tw-mt-1.5", l(r)["file-select-button"]]),
190
+ class: c(["tw-mt-1.5", l(d)["file-select-button"]]),
190
191
  secondary: "",
191
192
  type: "button",
192
193
  disabled: e.disabled,
193
- onClick: c(x, ["stop", "prevent"])
194
+ onClick: p(L, ["stop", "prevent"])
194
195
  }, {
195
196
  default: I(() => [
196
197
  S(e.$slots, "submitText", {}, () => [
197
- N(p(l(u)("ll.fileUpload.uploadFile")), 1)
198
+ N(u(l(f)("ll.fileUpload.uploadFile")), 1)
198
199
  ])
199
200
  ]),
200
201
  _: 3
201
202
  }, 8, ["class", "disabled"])
202
203
  ], 64))
203
204
  ], 2),
204
- e.$slots.hint && !e.files.length ? (n(), a("div", ce, [
205
+ e.$slots.hint && !e.files.length ? (n(), r("div", ce, [
205
206
  S(e.$slots, "hint")
206
207
  ])) : R("", !0)
207
208
  ], 34)),
@@ -211,8 +212,8 @@ const re = { key: 0 }, de = { class: "tw-text-ice-900" }, ce = {
211
212
  "data-test": "stash-file-upload|input",
212
213
  type: "file",
213
214
  disabled: e.disabled,
214
- accept: _.value.join(","),
215
- multiple: m.multiple,
215
+ accept: b.value.join(","),
216
+ multiple: o.multiple,
216
217
  onChange: z
217
218
  }), null, 16, pe), [
218
219
  [se, !1]
@@ -228,10 +229,10 @@ const re = { key: 0 }, de = { class: "tw-text-ice-900" }, ce = {
228
229
  button: fe
229
230
  }, ve = {
230
231
  $style: me
231
- }, Fe = /* @__PURE__ */ ae(ue, [["__cssModules", ve]]);
232
+ }, be = /* @__PURE__ */ ie(ue, [["__cssModules", ve]]);
232
233
  export {
233
234
  M as FILE_TYPES,
234
235
  h as FileUploadSizes,
235
- Fe as default
236
+ be as default
236
237
  };
237
238
  //# sourceMappingURL=FileUpload.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"FileUpload.js","sources":["../src/components/FileUpload/FileUpload.constants.ts","../src/components/FileUpload/FileUpload.vue"],"sourcesContent":["export const FILE_TYPES = {\n CSV: {\n EXTENSION: ['csv'],\n MIME_TYPES: ['text/csv', 'application/octet-stream', 'application/vnd.ms-excel'],\n ILLUSTRATION: 'csv',\n },\n PDF: {\n EXTENSION: ['pdf'],\n MIME_TYPES: ['application/pdf'],\n ILLUSTRATION: 'pdf',\n },\n PNG: {\n EXTENSION: ['png'],\n MIME_TYPES: ['image/png'],\n ILLUSTRATION: 'image',\n },\n JPEG: {\n EXTENSION: ['jpg', 'jpeg'],\n MIME_TYPES: ['image/jpeg'],\n ILLUSTRATION: 'image',\n },\n DOC: {\n EXTENSION: ['doc', 'docx'],\n MIME_TYPES: ['application/msword', 'application/vnd.openxmlformats-officedocument.wordprocessingml.document'],\n ILLUSTRATION: 'document',\n },\n XLS: {\n EXTENSION: ['xls', 'xlsx'],\n MIME_TYPES: ['application/vnd.ms-excel', 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'],\n ILLUSTRATION: 'csv',\n },\n};\n\nexport enum FileUploadSizes {\n Dense = 'dense',\n Standard = 'standard',\n}\n\nexport type FileUploadSize = `${FileUploadSizes}`;\n","<script lang=\"ts\">\n export * from './FileUpload.constants';\n</script>\n\n<script setup lang=\"ts\">\n import logger from '@leaflink/snitch';\n import { computed, inject, ref, useAttrs, useCssModule } from 'vue';\n import InlineSvg from 'vue-inline-svg';\n\n import { StashProvideState } from '../../../types/misc';\n import { t } from '../../locale';\n import Button from '../Button/Button.vue';\n import Icon from '../Icon/Icon.vue';\n import { FILE_TYPES, FileUploadSize, FileUploadSizes } from './FileUpload.constants';\n\n export type FileType = 'CSV' | 'PDF' | 'PNG' | 'JPEG' | 'DOC' | 'XLS';\n\n export interface FileUploadProps {\n /**\n * Files to display in the component\n */\n files?: File[];\n\n /**\n * Accepted file types\n */\n fileTypes?: FileType[];\n\n /**\n * Should display only the button\n */\n buttonOnly?: boolean;\n\n /**\n * Allows upload of multiple files\n */\n multiple?: boolean;\n\n /**\n * Is the input disabled\n */\n disabled?: boolean;\n\n /**\n * Component size\n */\n size?: FileUploadSize;\n }\n\n const props = withDefaults(defineProps<FileUploadProps>(), {\n files: () => [],\n fileTypes: () => ['CSV', 'PDF', 'PNG', 'JPEG', 'DOC', 'XLS'],\n buttonOnly: false,\n disabled: false,\n multiple: false,\n size: 'standard',\n });\n\n const classes = useCssModule();\n\n const emit = defineEmits<{\n (e: 'file-select', { files }: { files: FileUploadProps['files'] }): void;\n (e: 'file-delete', file: File): void;\n (e: 'file-error', message: string): void;\n }>();\n\n const isDraggingOver = ref(false);\n const fileUploadRef = ref<HTMLInputElement>();\n\n const stashOptions = inject<StashProvideState>('stashOptions');\n const attributes = useAttrs();\n\n const inputAttrs = computed(() => {\n const attrs = { ...attributes };\n\n delete attrs['data-test'];\n delete attrs.class;\n delete attrs.type;\n delete attrs.accept;\n\n return attrs;\n });\n\n function concatArraysToFirst(a: string[], b: string[]) {\n return a.concat(b);\n }\n\n const acceptedMimeTypes = computed(() => {\n return props.fileTypes.map((fileType) => FILE_TYPES[fileType].MIME_TYPES).reduce(concatArraysToFirst);\n });\n\n const acceptedFileExtensions = computed(() => {\n return props.fileTypes.map((fileType) => FILE_TYPES[fileType].EXTENSION).reduce(concatArraysToFirst);\n });\n\n const illustrationPath = computed(() => {\n return `${stashOptions?.staticPath}/illustrations/FileUpload/${FILE_TYPES[props.fileTypes[0]].ILLUSTRATION}.svg`;\n });\n\n function openFileDialog() {\n if (fileUploadRef.value) {\n fileUploadRef.value.value = '';\n fileUploadRef.value.click();\n }\n }\n\n function handleDragEnter() {\n isDraggingOver.value = true;\n }\n\n function handleDragLeave() {\n isDraggingOver.value = false;\n }\n\n function handleFileError(error: Error) {\n const message = t('ll.fileUpload.errors.incorrectFileType', {\n fileTypes: acceptedFileExtensions.value.join(', '),\n });\n\n emit('file-error', message);\n\n logger.log(error);\n }\n\n async function areFileTypesAccepted(files: File[]) {\n if (!acceptedMimeTypes.value.length) return true;\n\n const mimeTypes = await Promise.all(files.map((file) => readMimeType(file)));\n\n const allCorrectMimeTypes =\n !!mimeTypes.length && mimeTypes.every((mimeType) => acceptedMimeTypes.value.includes(mimeType));\n\n if (!allCorrectMimeTypes) {\n throw new Error('One or more files contains an unacceptable mime type.');\n }\n\n const allCorrectFileExtensions = files.every((file) => {\n const extension = file.name.split('.').pop();\n\n return extension && acceptedFileExtensions.value.includes(extension);\n });\n\n if (!allCorrectFileExtensions) {\n throw new Error('One or more files contains an unacceptable extension.');\n }\n\n return true;\n }\n\n async function processFiles(files: File[]) {\n try {\n await areFileTypesAccepted(files);\n\n emit('file-select', { files });\n } catch (error) {\n handleFileError(error as Error);\n }\n }\n\n /**\n * Sets file(s) to selected file(s) from dialogue\n * @param {Object} event - file select event that contains file(s)\n * @returns {Array} An array of files\n */\n function handleFileInput(event: Event) {\n const files = [...((event.target as HTMLInputElement)?.files || [])];\n\n processFiles(files);\n }\n\n /**\n * Sets file to dropped file if it is proper file type\n * @param {Object} event - file select event that contains file\n */\n function handleDropFile(event: DragEvent) {\n if (props.disabled) {\n return;\n }\n\n const files = [...(event.dataTransfer?.files || [])];\n\n isDraggingOver.value = false;\n\n return processFiles(files);\n }\n\n function handleFileDelete(file: File) {\n emit('file-delete', file);\n }\n\n function readMimeType(file: File): Promise<string> {\n return new Promise((resolve, reject) => {\n if (file.type) {\n return resolve(file.type);\n } else if (window.FileReader) {\n const fileReader = new FileReader();\n\n fileReader.onload = () => {\n const mimeType =\n fileReader.result && (fileReader.result as string).match(/[^:]\\w+\\/[\\w-+\\d.]+(?=;|,)/)\n ? ((fileReader.result as string).match(/[^:]\\w+\\/[\\w-+\\d.]+(?=;|,)/) as string[])[0]\n : '';\n\n resolve(mimeType);\n };\n\n fileReader.readAsDataURL(file);\n } else {\n reject(new Error('Failed to read file.'));\n }\n });\n }\n</script>\n\n<template>\n <div class=\"stash-file-upload\" :class=\"attributes.class\" data-test=\"stash-file-upload\">\n <div v-if=\"buttonOnly\">\n <Button secondary type=\"button\" :disabled=\"disabled || null\" @click.stop.prevent=\"openFileDialog\">\n <slot name=\"submitText\">\n {{ t('ll.fileUpload.uploadFile') }}\n </slot>\n </Button>\n </div>\n <div\n v-else\n class=\"tw-rounded tw-p-6\"\n :class=\"[classes['file-dropbox'], isDraggingOver && classes['is-dragging'], disabled && classes['is-disabled']]\"\n @dragover.prevent=\"handleDragEnter\"\n @drop.prevent=\"handleDropFile\"\n @dragleave.prevent=\"handleDragLeave\"\n >\n <div\n class=\"tw-flex tw-flex-col tw-items-center tw-justify-center tw-text-center\"\n :class=\"[{ 'tw-items-center md:tw-flex-row': size === FileUploadSizes.Dense }]\"\n >\n <template v-if=\"!files.length\">\n <InlineSvg v-if=\"size !== FileUploadSizes.Dense\" :src=\"illustrationPath\" name=\"file\" width=\"84\" height=\"96\" />\n <span class=\"tw-text-ice-900\">\n {{ t('ll.fileUpload.dragDropFileHere') }}\n </span>\n <span\n :class=\"\n size === FileUploadSizes.Dense\n ? 'md:tw-ml-1.5 md:tw-mr-3 md:tw-my-0 tw-my-1.5 tw-text-ice-900'\n : 'tw-mt-1.5 tw-my-1.5'\n \"\n >\n {{ t('ll.fileUpload.or') }}\n </span>\n <Button\n class=\"tw-mt-1.5\"\n secondary\n type=\"button\"\n :class=\"classes['file-select-button']\"\n :disabled=\"disabled\"\n @click.stop.prevent=\"openFileDialog\"\n >\n <!-- @slot for custom submit text -->\n <slot name=\"submitText\">{{ t('ll.fileUpload.uploadFile') }}</slot>\n </Button>\n </template>\n <template v-else>\n <div v-for=\"file in files\" :key=\"file.name\">\n <Icon name=\"file\" />\n <span>{{ file.name }}</span>\n <Button :class=\"[classes['remove-button'], classes['button']]\" @click.stop.prevent=\"handleFileDelete(file)\">\n {{ t('ll.fileUpload.remove') }}\n </Button>\n </div>\n </template>\n </div>\n <div v-if=\"$slots.hint && !files.length\" class=\"tw-mt-6 tw-text-center tw-text-xs tw-text-ice-700\">\n <!-- @slot for displaying helpful text and/or links -->\n <slot name=\"hint\"></slot>\n </div>\n </div>\n <input\n v-show=\"false\"\n v-bind=\"inputAttrs\"\n ref=\"fileUploadRef\"\n data-test=\"stash-file-upload|input\"\n type=\"file\"\n :disabled=\"disabled\"\n :accept=\"acceptedMimeTypes.join(',')\"\n :multiple=\"props.multiple\"\n @change=\"handleFileInput\"\n />\n </div>\n</template>\n\n<style module>\n .file-dropbox {\n background: var(--color-ice-200);\n background-image: url(\"data:image/svg+xml,%3csvg width='100%25' height='100%25' xmlns='http://www.w3.org/2000/svg'%3e%3crect width='100%25' height='100%25' fill='none' rx='4' ry='4' stroke='%23C5C9D4FF' stroke-width='1' stroke-dasharray='5 %2c 5' stroke-dashoffset='0' stroke-linecap='square'/%3e%3c/svg%3e\");\n background-repeat: no-repeat;\n border: theme('borderWidth.DEFAULT') solid var(--color-ice-500);\n border-color: transparent;\n }\n\n .is-dragging {\n background-image: none;\n border-color: var(--color-ice-500);\n\n & > * {\n pointer-events: none;\n }\n }\n\n .is-disabled {\n cursor: no-drop;\n }\n\n /* Constrain the upload icon for drag/drop to the required size */\n .upload-icon {\n height: 98px;\n width: 84px;\n }\n\n .remove-button.button {\n background: transparent;\n border: none;\n color: var(--color-red-500);\n\n &:hover {\n background: transparent;\n border: none;\n }\n }\n</style>\n"],"names":["FILE_TYPES","FileUploadSizes","props","__props","classes","useCssModule","emit","__emit","isDraggingOver","ref","fileUploadRef","stashOptions","inject","attributes","useAttrs","inputAttrs","computed","attrs","concatArraysToFirst","a","b","acceptedMimeTypes","fileType","acceptedFileExtensions","illustrationPath","openFileDialog","handleDragEnter","handleDragLeave","handleFileError","error","message","t","logger","areFileTypesAccepted","files","mimeTypes","file","readMimeType","mimeType","extension","processFiles","handleFileInput","event","_a","handleDropFile","handleFileDelete","resolve","reject","fileReader"],"mappings":"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"}
1
+ {"version":3,"file":"FileUpload.js","sources":["../src/components/FileUpload/FileUpload.constants.ts","../src/components/FileUpload/FileUpload.vue"],"sourcesContent":["export const FILE_TYPES = {\n CSV: {\n EXTENSION: ['csv'],\n MIME_TYPES: ['text/csv', 'application/octet-stream', 'application/vnd.ms-excel'],\n ILLUSTRATION: 'csv',\n },\n PDF: {\n EXTENSION: ['pdf'],\n MIME_TYPES: ['application/pdf'],\n ILLUSTRATION: 'pdf',\n },\n PNG: {\n EXTENSION: ['png'],\n MIME_TYPES: ['image/png'],\n ILLUSTRATION: 'image',\n },\n JPEG: {\n EXTENSION: ['jpg', 'jpeg'],\n MIME_TYPES: ['image/jpeg'],\n ILLUSTRATION: 'image',\n },\n DOC: {\n EXTENSION: ['doc', 'docx'],\n MIME_TYPES: ['application/msword', 'application/vnd.openxmlformats-officedocument.wordprocessingml.document'],\n ILLUSTRATION: 'document',\n },\n XLS: {\n EXTENSION: ['xls', 'xlsx'],\n MIME_TYPES: ['application/vnd.ms-excel', 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'],\n ILLUSTRATION: 'csv',\n },\n};\n\nexport enum FileUploadSizes {\n Dense = 'dense',\n Standard = 'standard',\n}\n\nexport type FileUploadSize = `${FileUploadSizes}`;\n","<script lang=\"ts\">\n export * from './FileUpload.constants';\n</script>\n\n<script setup lang=\"ts\">\n import logger from '@leaflink/snitch';\n import { computed, inject, ref, useAttrs, useCssModule } from 'vue';\n import InlineSvg from 'vue-inline-svg';\n\n import { StashProvideState } from '../../../types/misc';\n import { t } from '../../locale';\n import Button from '../Button/Button.vue';\n import Icon from '../Icon/Icon.vue';\n import { FILE_TYPES, FileUploadSize, FileUploadSizes } from './FileUpload.constants';\n\n export type FileType = 'CSV' | 'PDF' | 'PNG' | 'JPEG' | 'DOC' | 'XLS';\n\n export interface FileUploadProps {\n /**\n * Files to display in the component\n */\n files?: File[];\n\n /**\n * Accepted file types\n */\n fileTypes?: FileType[];\n\n /**\n * Should display only the button\n */\n buttonOnly?: boolean;\n\n /**\n * Allows upload of multiple files\n */\n multiple?: boolean;\n\n /**\n * Is the input disabled\n */\n disabled?: boolean;\n\n /**\n * Component size\n */\n size?: FileUploadSize;\n }\n\n const props = withDefaults(defineProps<FileUploadProps>(), {\n files: () => [],\n fileTypes: () => ['CSV', 'PDF', 'PNG', 'JPEG', 'DOC', 'XLS'],\n buttonOnly: false,\n disabled: false,\n multiple: false,\n size: 'standard',\n });\n\n const classes = useCssModule();\n\n const emit = defineEmits<{\n (e: 'file-select', { files }: { files: FileUploadProps['files'] }): void;\n (e: 'file-delete', file: File): void;\n (e: 'file-error', message: string): void;\n }>();\n\n const isDraggingOver = ref(false);\n const fileUploadRef = ref<HTMLInputElement>();\n\n const stashOptions = inject<StashProvideState>('stashOptions');\n const attributes = useAttrs();\n\n const inputAttrs = computed(() => {\n const attrs = { ...attributes };\n\n delete attrs['data-test'];\n delete attrs.class;\n delete attrs.type;\n delete attrs.accept;\n\n return attrs;\n });\n\n function concatArraysToFirst(a: string[], b: string[]) {\n return a.concat(b);\n }\n\n const acceptedMimeTypes = computed(() => {\n return props.fileTypes.map((fileType) => FILE_TYPES[fileType].MIME_TYPES).reduce(concatArraysToFirst);\n });\n\n const acceptedFileExtensions = computed(() => {\n return props.fileTypes.map((fileType) => FILE_TYPES[fileType].EXTENSION).reduce(concatArraysToFirst);\n });\n\n const illustrationPath = computed(() => {\n return `${stashOptions?.staticPath}/illustrations/FileUpload/${FILE_TYPES[props.fileTypes[0]].ILLUSTRATION}.svg`;\n });\n\n function openFileDialog() {\n if (fileUploadRef.value) {\n fileUploadRef.value.value = '';\n fileUploadRef.value.click();\n }\n }\n\n function handleDragEnter() {\n isDraggingOver.value = true;\n }\n\n function handleDragLeave() {\n isDraggingOver.value = false;\n }\n\n function handleFileError(error: Error) {\n const message = t('ll.fileUpload.errors.incorrectFileType', {\n fileTypes: acceptedFileExtensions.value.join(', '),\n });\n\n emit('file-error', message);\n\n logger.log(error);\n }\n\n async function areFileTypesAccepted(files: File[]) {\n if (!acceptedMimeTypes.value.length) return true;\n\n const mimeTypes = await Promise.all(files.map((file) => readMimeType(file)));\n\n const allCorrectMimeTypes =\n !!mimeTypes.length && mimeTypes.every((mimeType) => acceptedMimeTypes.value.includes(mimeType));\n\n if (!allCorrectMimeTypes) {\n throw new Error('One or more files contains an unacceptable mime type.');\n }\n\n const allCorrectFileExtensions = files.every((file) => {\n const extension = file.name.split('.').pop();\n\n return extension && acceptedFileExtensions.value.includes(extension);\n });\n\n if (!allCorrectFileExtensions) {\n throw new Error('One or more files contains an unacceptable extension.');\n }\n\n return true;\n }\n\n async function processFiles(files: File[]) {\n try {\n await areFileTypesAccepted(files);\n\n emit('file-select', { files });\n } catch (error) {\n handleFileError(error as Error);\n }\n }\n\n /**\n * Sets file(s) to selected file(s) from dialogue\n * @param {Object} event - file select event that contains file(s)\n * @returns {Array} An array of files\n */\n function handleFileInput(event: Event) {\n const files = [...((event.target as HTMLInputElement)?.files || [])];\n\n processFiles(files);\n }\n\n /**\n * Sets file to dropped file if it is proper file type\n * @param {Object} event - file select event that contains file\n */\n function handleDropFile(event: DragEvent) {\n if (props.disabled) {\n return;\n }\n\n const files = [...(event.dataTransfer?.files || [])];\n\n isDraggingOver.value = false;\n\n return processFiles(files);\n }\n\n function handleFileDelete(file: File) {\n emit('file-delete', file);\n }\n\n function readMimeType(file: File): Promise<string> {\n return new Promise((resolve, reject) => {\n if (file.type) {\n return resolve(file.type);\n } else if (window.FileReader) {\n const fileReader = new FileReader();\n\n fileReader.onload = () => {\n const mimeType =\n fileReader.result && (fileReader.result as string).match(/[^:]\\w+\\/[\\w-+\\d.]+(?=;|,)/)\n ? ((fileReader.result as string).match(/[^:]\\w+\\/[\\w-+\\d.]+(?=;|,)/) as string[])[0]\n : '';\n\n resolve(mimeType);\n };\n\n fileReader.readAsDataURL(file);\n } else {\n reject(new Error('Failed to read file.'));\n }\n });\n }\n</script>\n\n<template>\n <div class=\"stash-file-upload\" :class=\"attributes.class\" data-test=\"stash-file-upload\">\n <div v-if=\"buttonOnly\">\n <Button secondary type=\"button\" :disabled=\"props.disabled\" @click.stop.prevent=\"openFileDialog\">\n <slot name=\"submitText\">\n {{ t('ll.fileUpload.uploadFile') }}\n </slot>\n </Button>\n </div>\n <div\n v-else\n class=\"tw-rounded tw-p-6\"\n :class=\"[\n classes['file-dropbox'],\n {\n [classes['is-dragging']]: isDraggingOver,\n [classes['is-disabled']]: props.disabled,\n },\n ]\"\n @dragover.prevent=\"handleDragEnter\"\n @drop.prevent=\"handleDropFile\"\n @dragleave.prevent=\"handleDragLeave\"\n >\n <div\n class=\"tw-flex tw-flex-col tw-items-center tw-justify-center tw-text-center\"\n :class=\"[{ 'tw-items-center md:tw-flex-row': size === FileUploadSizes.Dense }]\"\n >\n <template v-if=\"!files.length\">\n <InlineSvg v-if=\"size !== FileUploadSizes.Dense\" :src=\"illustrationPath\" name=\"file\" width=\"84\" height=\"96\" />\n <span class=\"tw-text-ice-900\">\n {{ t('ll.fileUpload.dragDropFileHere') }}\n </span>\n <span\n :class=\"\n size === FileUploadSizes.Dense\n ? 'md:tw-ml-1.5 md:tw-mr-3 md:tw-my-0 tw-my-1.5 tw-text-ice-900'\n : 'tw-mt-1.5 tw-my-1.5'\n \"\n >\n {{ t('ll.fileUpload.or') }}\n </span>\n <Button\n class=\"tw-mt-1.5\"\n secondary\n type=\"button\"\n :class=\"classes['file-select-button']\"\n :disabled=\"disabled\"\n @click.stop.prevent=\"openFileDialog\"\n >\n <!-- @slot for custom submit text -->\n <slot name=\"submitText\">{{ t('ll.fileUpload.uploadFile') }}</slot>\n </Button>\n </template>\n <template v-else>\n <div v-for=\"file in files\" :key=\"file.name\">\n <Icon name=\"file\" />\n <span>{{ file.name }}</span>\n <Button :class=\"[classes['remove-button'], classes['button']]\" @click.stop.prevent=\"handleFileDelete(file)\">\n {{ t('ll.fileUpload.remove') }}\n </Button>\n </div>\n </template>\n </div>\n <div v-if=\"$slots.hint && !files.length\" class=\"tw-mt-6 tw-text-center tw-text-xs tw-text-ice-700\">\n <!-- @slot for displaying helpful text and/or links -->\n <slot name=\"hint\"></slot>\n </div>\n </div>\n <input\n v-show=\"false\"\n v-bind=\"inputAttrs\"\n ref=\"fileUploadRef\"\n data-test=\"stash-file-upload|input\"\n type=\"file\"\n :disabled=\"disabled\"\n :accept=\"acceptedMimeTypes.join(',')\"\n :multiple=\"props.multiple\"\n @change=\"handleFileInput\"\n />\n </div>\n</template>\n\n<style module>\n .file-dropbox {\n background: var(--color-ice-200);\n background-image: url(\"data:image/svg+xml,%3csvg width='100%25' height='100%25' xmlns='http://www.w3.org/2000/svg'%3e%3crect width='100%25' height='100%25' fill='none' rx='4' ry='4' stroke='%23C5C9D4FF' stroke-width='1' stroke-dasharray='5 %2c 5' stroke-dashoffset='0' stroke-linecap='square'/%3e%3c/svg%3e\");\n background-repeat: no-repeat;\n border: theme('borderWidth.DEFAULT') solid var(--color-ice-500);\n border-color: transparent;\n }\n\n .is-dragging {\n background-image: none;\n border-color: var(--color-ice-500);\n\n & > * {\n pointer-events: none;\n }\n }\n\n .is-disabled {\n cursor: no-drop;\n }\n\n /* Constrain the upload icon for drag/drop to the required size */\n .upload-icon {\n height: 98px;\n width: 84px;\n }\n\n .remove-button.button {\n background: transparent;\n border: none;\n color: var(--color-red-500);\n\n &:hover {\n background: transparent;\n border: none;\n }\n }\n</style>\n"],"names":["FILE_TYPES","FileUploadSizes","props","__props","classes","useCssModule","emit","__emit","isDraggingOver","ref","fileUploadRef","stashOptions","inject","attributes","useAttrs","inputAttrs","computed","attrs","concatArraysToFirst","a","b","acceptedMimeTypes","fileType","acceptedFileExtensions","illustrationPath","openFileDialog","handleDragEnter","handleDragLeave","handleFileError","error","message","t","logger","areFileTypesAccepted","files","mimeTypes","file","readMimeType","mimeType","extension","processFiles","handleFileInput","event","_a","handleDropFile","handleFileDelete","resolve","reject","fileReader"],"mappings":"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"}
@@ -33,38 +33,38 @@ declare type __VLS_WithTemplateSlots<T, S> = T & {
33
33
  };
34
34
 
35
35
  declare const _default: __VLS_WithTemplateSlots<DefineComponent<ExtractPropTypes<__VLS_WithDefaults<__VLS_TypePropsToRuntimeProps<FileUploadProps>, {
36
- files: () => never[];
37
- fileTypes: () => string[];
38
- buttonOnly: boolean;
39
- disabled: boolean;
40
- multiple: boolean;
41
- size: string;
36
+ files: () => never[];
37
+ fileTypes: () => string[];
38
+ buttonOnly: boolean;
39
+ disabled: boolean;
40
+ multiple: boolean;
41
+ size: string;
42
42
  }>>, {}, {}, {}, {}, ComponentOptionsMixin, ComponentOptionsMixin, {
43
- "file-select": (args_0: {
44
- files: FileUploadProps['files'];
45
- }) => void;
46
- "file-delete": (file: File) => void;
47
- "file-error": (message: string) => void;
43
+ "file-select": (args_0: {
44
+ files: FileUploadProps['files'];
45
+ }) => void;
46
+ "file-delete": (file: File) => void;
47
+ "file-error": (message: string) => void;
48
48
  }, string, PublicProps, Readonly<ExtractPropTypes<__VLS_WithDefaults<__VLS_TypePropsToRuntimeProps<FileUploadProps>, {
49
- files: () => never[];
50
- fileTypes: () => string[];
51
- buttonOnly: boolean;
52
- disabled: boolean;
53
- multiple: boolean;
54
- size: string;
49
+ files: () => never[];
50
+ fileTypes: () => string[];
51
+ buttonOnly: boolean;
52
+ disabled: boolean;
53
+ multiple: boolean;
54
+ size: string;
55
55
  }>>> & Readonly<{
56
- "onFile-select"?: ((args_0: {
57
- files: FileUploadProps['files'];
58
- }) => any) | undefined;
59
- "onFile-delete"?: ((file: File) => any) | undefined;
60
- "onFile-error"?: ((message: string) => any) | undefined;
56
+ "onFile-select"?: ((args_0: {
57
+ files: FileUploadProps['files'];
58
+ }) => any) | undefined;
59
+ "onFile-delete"?: ((file: File) => any) | undefined;
60
+ "onFile-error"?: ((message: string) => any) | undefined;
61
61
  }>, {
62
- disabled: boolean;
63
- size: "standard" | "dense";
64
- multiple: boolean;
65
- files: File[];
66
- fileTypes: FileType[];
67
- buttonOnly: boolean;
62
+ disabled: boolean;
63
+ size: "standard" | "dense";
64
+ multiple: boolean;
65
+ files: File[];
66
+ fileTypes: FileType[];
67
+ buttonOnly: boolean;
68
68
  }, {}, {}, {}, string, ComponentProvideOptions, true, {}, any>, {
69
69
  submitText?(_: {}): any;
70
70
  hint?(_: {}): any;
@@ -1,13 +1,8 @@
1
- import { defineComponent as f, useCssModule as v, computed as h, openBlock as a, createBlock as w, normalizeClass as s, unref as t, withCtx as b, createElementVNode as C, renderSlot as k, createElementBlock as i, toDisplayString as y, createCommentVNode as n, createVNode as D } from "vue";
1
+ import { defineComponent as f, useCssModule as v, computed as h, openBlock as a, createBlock as w, normalizeClass as s, unref as t, withCtx as b, createElementVNode as C, renderSlot as k, createElementBlock as n, toDisplayString as y, createCommentVNode as i, createVNode as D } from "vue";
2
2
  import { t as c } from "./locale.js";
3
3
  import x from "./Chip.js";
4
4
  import B from "./Icon.js";
5
- import { _ as F } from "./_plugin-vue_export-helper-dad06003.js";
6
- import "lodash-es/get";
7
- import "./utils/colorScheme.js";
8
- import "lodash-es/uniqueId";
9
- import "./index-9e1095ef.js";
10
- import "./Icon.vue_used_vue_type_style_index_0_lang.module-eb359559.js";
5
+ import { _ as F } from "./_plugin-vue_export-helper-CHgC5LLL.js";
11
6
  const O = { class: "tw-flex tw-items-center" }, R = ["aria-label", "title"], S = { key: 1 }, N = /* @__PURE__ */ f({
12
7
  __name: "FilterChip",
13
8
  props: {
@@ -19,12 +14,12 @@ const O = { class: "tw-flex tw-items-center" }, R = ["aria-label", "title"], S =
19
14
  },
20
15
  emits: ["click", "remove"],
21
16
  setup(d, { emit: p }) {
22
- const e = d, r = p, o = v(), l = h(() => Number(e.filterCount) > 0);
17
+ const e = d, l = p, o = v(), r = h(() => Number(e.filterCount) > 0);
23
18
  function m() {
24
- r("click");
19
+ l("click");
25
20
  }
26
21
  function _() {
27
- r("remove");
22
+ l("remove");
28
23
  }
29
24
  return (u, E) => (a(), w(x, {
30
25
  "should-override-colors": "",
@@ -36,7 +31,7 @@ const O = { class: "tw-flex tw-items-center" }, R = ["aria-label", "title"], S =
36
31
  [t(o)["is-removable"]]: e.isRemovable,
37
32
  [t(o)["is-dropdown-open"]]: e.isDropdownOpen,
38
33
  [t(o)["has-dropdown"]]: e.hasDropdown,
39
- [t(o)["has-filter-count"]]: l.value
34
+ [t(o)["has-filter-count"]]: r.value
40
35
  }
41
36
  ]]),
42
37
  radius: "pill",
@@ -47,14 +42,14 @@ const O = { class: "tw-flex tw-items-center" }, R = ["aria-label", "title"], S =
47
42
  default: b(() => [
48
43
  C("div", O, [
49
44
  k(u.$slots, "default"),
50
- l.value ? (a(), i("span", {
45
+ r.value ? (a(), n("span", {
51
46
  key: 0,
52
47
  "data-test": "span|filter-count",
53
48
  class: s(t(o)["filter-count"]),
54
49
  "aria-label": t(c)("ll.numberOfActiveFilters"),
55
50
  title: t(c)("ll.numberOfActiveFilters")
56
- }, y(e.filterCount), 11, R)) : n("", !0),
57
- e.hasDropdown ? (a(), i("span", S, [
51
+ }, y(e.filterCount), 11, R)) : i("", !0),
52
+ e.hasDropdown ? (a(), n("span", S, [
58
53
  D(B, {
59
54
  "data-test": "icon|caret",
60
55
  name: "caret-down",
@@ -65,7 +60,7 @@ const O = { class: "tw-flex tw-items-center" }, R = ["aria-label", "title"], S =
65
60
  }
66
61
  ])
67
62
  }, null, 8, ["class"])
68
- ])) : n("", !0)
63
+ ])) : i("", !0)
69
64
  ])
70
65
  ]),
71
66
  _: 3
@@ -82,8 +77,8 @@ const O = { class: "tw-flex tw-items-center" }, R = ["aria-label", "title"], S =
82
77
  "caret-rotate": "_caret-rotate_1avat_105"
83
78
  }, A = {
84
79
  $style: g
85
- }, P = /* @__PURE__ */ F(N, [["__cssModules", A]]);
80
+ }, G = /* @__PURE__ */ F(N, [["__cssModules", A]]);
86
81
  export {
87
- P as default
82
+ G as default
88
83
  };
89
84
  //# sourceMappingURL=FilterChip.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"FilterChip.js","sources":["../src/components/FilterChip/FilterChip.vue"],"sourcesContent":["<script setup lang=\"ts\">\n import { computed, useCssModule } from 'vue';\n\n import { t } from '../../locale';\n import Chip from '../Chip/Chip.vue';\n import Icon from '../Icon/Icon.vue';\n\n export interface FilterChipProps {\n /**\n * Used for conditionally rendering filter count chip\n */\n filterCount?: number;\n\n /**\n * Use for conditionally rendering caret\n */\n hasDropdown?: boolean;\n\n /**\n * Used for styling when `hasDropdown` is true\n */\n isDropdownOpen?: boolean;\n\n /**\n * Used for conditionally rendering close icon and exposing remove event\n */\n isRemovable?: boolean;\n\n /**\n * Used for conditionally applying styles\n */\n isSelected?: boolean;\n }\n\n const props = withDefaults(defineProps<FilterChipProps>(), {\n filterCount: undefined,\n hasDropdown: false,\n isDropdownOpen: false,\n isRemovable: false,\n isSelected: false,\n });\n\n const emit = defineEmits<{\n (e: 'click'): void;\n (e: 'remove'): void;\n }>();\n\n const classes = useCssModule();\n const hasFilterCount = computed(() => Number(props.filterCount) > 0);\n\n function handleClick() {\n emit('click');\n }\n\n function handleRemove() {\n emit('remove');\n }\n</script>\n\n<template>\n <Chip\n should-override-colors\n tabindex=\"0\"\n class=\"stash-filter-chip tw-text-sm tw-font-normal tw-normal-case tw-leading-5 tw-text-ice-900\"\n radius=\"pill\"\n :class=\"[\n classes.root,\n {\n [classes['is-selected']]: props.isSelected,\n [classes['is-removable']]: props.isRemovable,\n [classes['is-dropdown-open']]: props.isDropdownOpen,\n [classes['has-dropdown']]: props.hasDropdown,\n [classes['has-filter-count']]: hasFilterCount,\n },\n ]\"\n :is-removable=\"props.isSelected && props.isRemovable && !props.hasDropdown\"\n @click=\"handleClick\"\n @remove=\"handleRemove\"\n >\n <div class=\"tw-flex tw-items-center\">\n <!-- @slot default -->\n <slot></slot>\n\n <span\n v-if=\"hasFilterCount\"\n data-test=\"span|filter-count\"\n :class=\"classes['filter-count']\"\n :aria-label=\"t('ll.numberOfActiveFilters')\"\n :title=\"t('ll.numberOfActiveFilters')\"\n >\n {{ props.filterCount }}\n </span>\n\n <span v-if=\"props.hasDropdown\">\n <Icon\n data-test=\"icon|caret\"\n name=\"caret-down\"\n :class=\"[\n classes.caret,\n {\n [classes['caret-rotate']]: props.isDropdownOpen,\n },\n ]\"\n />\n </span>\n </div>\n </Chip>\n</template>\n\n<style module>\n /**\n many styles declared here are overriding styles defined in Chip\n */\n .root {\n background-color: var(--color-white);\n border: 1px solid var(--color-ice-500);\n cursor: pointer;\n height: theme('spacing.9');\n padding-left: theme('spacing.3');\n padding-right: theme('spacing.3');\n }\n\n .root:focus {\n box-shadow: 0 0 0 4px rgb(0 123 255 / 15%);\n outline: none;\n }\n\n .root:hover {\n background-color: var(--color-blue-100);\n border: 1px solid var(--color-blue-500);\n }\n\n .root.is-selected {\n color: var(--color-white);\n background-color: var(--color-blue-500);\n border: 1px solid var(--color-blue-500);\n }\n\n .root.is-selected:hover {\n color: var(--color-white);\n background-color: var(--color-blue-700);\n border: 1px solid var(--color-blue-700);\n }\n\n .root.is-selected.is-removable {\n background-color: var(--color-blue-500);\n }\n\n .root.is-selected.is-removable :global(.stash-chip__remove-button) {\n margin-right: -1px;\n padding-right: theme('spacing.3');\n }\n\n .root.is-selected.is-removable :global(.stash-chip__remove-button):hover {\n background-color: var(--color-blue-700);\n }\n\n .root.is-selected.has-filter-count:hover {\n background-color: var(--color-blue-700);\n color: var(--color-white);\n }\n\n .root.has-dropdown {\n padding-right: theme('spacing[1.5]');\n }\n\n .root.has-filter-count:hover {\n background-color: var(--color-blue-100);\n color: var(--color-ice-900);\n }\n\n .root label {\n cursor: pointer;\n }\n\n .filter-count {\n display: inline-flex;\n align-items: center;\n border-radius: 5em;\n height: 16px;\n padding: 0 8px;\n margin-left: theme('spacing[1.5]');\n font-size: 10px;\n font-weight: bold;\n background-color: var(--color-blue-500);\n color: var(--color-white);\n }\n\n .is-selected .filter-count {\n background-color: var(--color-blue-700);\n }\n\n .is-selected:hover .filter-count {\n background-color: var(--color-white);\n color: var(--color-blue-700);\n }\n\n .is-selected.is-removable .filter-count {\n background-color: var(--color-blue-700);\n color: var(--color-white);\n }\n\n .caret {\n color: var(--color-ice-700);\n margin-left: theme('spacing[1.5]');\n transform: rotate(0);\n transition: all 0.5s;\n }\n\n .is-selected .caret {\n color: var(--color-white);\n }\n\n .caret-rotate {\n transform: rotate(-180deg);\n }\n</style>\n"],"names":["props","__props","emit","__emit","classes","useCssModule","hasFilterCount","computed","handleClick","handleRemove"],"mappings":";;;;;;;;;;;;;;;;;;;;;AAkCE,UAAMA,IAAQC,GAQRC,IAAOC,GAKPC,IAAUC,KACVC,IAAiBC,EAAS,MAAM,OAAOP,EAAM,WAAW,IAAI,CAAC;AAEnE,aAASQ,IAAc;AACrB,MAAAN,EAAK,OAAO;AAAA,IACd;AAEA,aAASO,IAAe;AACtB,MAAAP,EAAK,QAAQ;AAAA,IACf;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"FilterChip.js","sources":["../src/components/FilterChip/FilterChip.vue"],"sourcesContent":["<script setup lang=\"ts\">\n import { computed, useCssModule } from 'vue';\n\n import { t } from '../../locale';\n import Chip from '../Chip/Chip.vue';\n import Icon from '../Icon/Icon.vue';\n\n export interface FilterChipProps {\n /**\n * Used for conditionally rendering filter count chip\n */\n filterCount?: number;\n\n /**\n * Use for conditionally rendering caret\n */\n hasDropdown?: boolean;\n\n /**\n * Used for styling when `hasDropdown` is true\n */\n isDropdownOpen?: boolean;\n\n /**\n * Used for conditionally rendering close icon and exposing remove event\n */\n isRemovable?: boolean;\n\n /**\n * Used for conditionally applying styles\n */\n isSelected?: boolean;\n }\n\n const props = withDefaults(defineProps<FilterChipProps>(), {\n filterCount: undefined,\n hasDropdown: false,\n isDropdownOpen: false,\n isRemovable: false,\n isSelected: false,\n });\n\n const emit = defineEmits<{\n (e: 'click'): void;\n (e: 'remove'): void;\n }>();\n\n const classes = useCssModule();\n const hasFilterCount = computed(() => Number(props.filterCount) > 0);\n\n function handleClick() {\n emit('click');\n }\n\n function handleRemove() {\n emit('remove');\n }\n</script>\n\n<template>\n <Chip\n should-override-colors\n tabindex=\"0\"\n class=\"stash-filter-chip tw-text-sm tw-font-normal tw-normal-case tw-leading-5 tw-text-ice-900\"\n radius=\"pill\"\n :class=\"[\n classes.root,\n {\n [classes['is-selected']]: props.isSelected,\n [classes['is-removable']]: props.isRemovable,\n [classes['is-dropdown-open']]: props.isDropdownOpen,\n [classes['has-dropdown']]: props.hasDropdown,\n [classes['has-filter-count']]: hasFilterCount,\n },\n ]\"\n :is-removable=\"props.isSelected && props.isRemovable && !props.hasDropdown\"\n @click=\"handleClick\"\n @remove=\"handleRemove\"\n >\n <div class=\"tw-flex tw-items-center\">\n <!-- @slot default -->\n <slot></slot>\n\n <span\n v-if=\"hasFilterCount\"\n data-test=\"span|filter-count\"\n :class=\"classes['filter-count']\"\n :aria-label=\"t('ll.numberOfActiveFilters')\"\n :title=\"t('ll.numberOfActiveFilters')\"\n >\n {{ props.filterCount }}\n </span>\n\n <span v-if=\"props.hasDropdown\">\n <Icon\n data-test=\"icon|caret\"\n name=\"caret-down\"\n :class=\"[\n classes.caret,\n {\n [classes['caret-rotate']]: props.isDropdownOpen,\n },\n ]\"\n />\n </span>\n </div>\n </Chip>\n</template>\n\n<style module>\n /**\n many styles declared here are overriding styles defined in Chip\n */\n .root {\n background-color: var(--color-white);\n border: 1px solid var(--color-ice-500);\n cursor: pointer;\n height: theme('spacing.9');\n padding-left: theme('spacing.3');\n padding-right: theme('spacing.3');\n }\n\n .root:focus {\n box-shadow: 0 0 0 4px rgb(0 123 255 / 15%);\n outline: none;\n }\n\n .root:hover {\n background-color: var(--color-blue-100);\n border: 1px solid var(--color-blue-500);\n }\n\n .root.is-selected {\n color: var(--color-white);\n background-color: var(--color-blue-500);\n border: 1px solid var(--color-blue-500);\n }\n\n .root.is-selected:hover {\n color: var(--color-white);\n background-color: var(--color-blue-700);\n border: 1px solid var(--color-blue-700);\n }\n\n .root.is-selected.is-removable {\n background-color: var(--color-blue-500);\n }\n\n .root.is-selected.is-removable :global(.stash-chip__remove-button) {\n margin-right: -1px;\n padding-right: theme('spacing.3');\n }\n\n .root.is-selected.is-removable :global(.stash-chip__remove-button):hover {\n background-color: var(--color-blue-700);\n }\n\n .root.is-selected.has-filter-count:hover {\n background-color: var(--color-blue-700);\n color: var(--color-white);\n }\n\n .root.has-dropdown {\n padding-right: theme('spacing[1.5]');\n }\n\n .root.has-filter-count:hover {\n background-color: var(--color-blue-100);\n color: var(--color-ice-900);\n }\n\n .root label {\n cursor: pointer;\n }\n\n .filter-count {\n display: inline-flex;\n align-items: center;\n border-radius: 5em;\n height: 16px;\n padding: 0 8px;\n margin-left: theme('spacing[1.5]');\n font-size: 10px;\n font-weight: bold;\n background-color: var(--color-blue-500);\n color: var(--color-white);\n }\n\n .is-selected .filter-count {\n background-color: var(--color-blue-700);\n }\n\n .is-selected:hover .filter-count {\n background-color: var(--color-white);\n color: var(--color-blue-700);\n }\n\n .is-selected.is-removable .filter-count {\n background-color: var(--color-blue-700);\n color: var(--color-white);\n }\n\n .caret {\n color: var(--color-ice-700);\n margin-left: theme('spacing[1.5]');\n transform: rotate(0);\n transition: all 0.5s;\n }\n\n .is-selected .caret {\n color: var(--color-white);\n }\n\n .caret-rotate {\n transform: rotate(-180deg);\n }\n</style>\n"],"names":["props","__props","emit","__emit","classes","useCssModule","hasFilterCount","computed","handleClick","handleRemove"],"mappings":";;;;;;;;;;;;;;;;AAkCE,UAAMA,IAAQC,GAQRC,IAAOC,GAKPC,IAAUC,KACVC,IAAiBC,EAAS,MAAM,OAAOP,EAAM,WAAW,IAAI,CAAC;AAEnE,aAASQ,IAAc;AACrB,MAAAN,EAAK,OAAO;AAAA,IACd;AAEA,aAASO,IAAe;AACtB,MAAAP,EAAK,QAAQ;AAAA,IACf;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}