cisse-vue-ui 0.7.2 → 0.7.3

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 (327) hide show
  1. package/dist/{PageHero.vue_vue_type_script_setup_true_lang-C-YXGDTY.js → PageHero.vue_vue_type_script_setup_true_lang-BYx595-2.js} +87 -47
  2. package/dist/{PageHero.vue_vue_type_script_setup_true_lang-C-YXGDTY.js.map → PageHero.vue_vue_type_script_setup_true_lang-BYx595-2.js.map} +1 -1
  3. package/dist/{TagsInput-D0O6z6le.js → TagsInput-DtoJKN3L.js} +17 -5
  4. package/dist/TagsInput-DtoJKN3L.js.map +1 -0
  5. package/dist/components/form/index.js +1 -1
  6. package/dist/components/index.js +2 -2
  7. package/dist/components/layout/index.js +1 -1
  8. package/dist/{index-D9_zMCpN.js → index-F9yanU6_.js} +3 -3
  9. package/dist/index-F9yanU6_.js.map +1 -0
  10. package/dist/index.js +3 -3
  11. package/package.json +1 -1
  12. package/dist/BadgeType.vue_vue_type_script_setup_true_lang-zs0NXN4g.cjs +0 -145
  13. package/dist/BadgeType.vue_vue_type_script_setup_true_lang-zs0NXN4g.cjs.map +0 -1
  14. package/dist/Button.vue_vue_type_script_setup_true_lang-CXRj7LEP.cjs +0 -98
  15. package/dist/Button.vue_vue_type_script_setup_true_lang-CXRj7LEP.cjs.map +0 -1
  16. package/dist/ConfirmDialog.vue_vue_type_script_setup_true_lang-Bine-xfp.cjs +0 -928
  17. package/dist/ConfirmDialog.vue_vue_type_script_setup_true_lang-Bine-xfp.cjs.map +0 -1
  18. package/dist/Dropdown.vue_vue_type_script_setup_true_lang-BNOHbbm5.cjs +0 -228
  19. package/dist/Dropdown.vue_vue_type_script_setup_true_lang-BNOHbbm5.cjs.map +0 -1
  20. package/dist/FilterTabs.vue_vue_type_script_setup_true_lang-HwjuvIJX.cjs +0 -2242
  21. package/dist/FilterTabs.vue_vue_type_script_setup_true_lang-HwjuvIJX.cjs.map +0 -1
  22. package/dist/ListSkeleton.vue_vue_type_script_setup_true_lang-DtwwmfWr.cjs +0 -149
  23. package/dist/ListSkeleton.vue_vue_type_script_setup_true_lang-DtwwmfWr.cjs.map +0 -1
  24. package/dist/PageHero.vue_vue_type_script_setup_true_lang-CKCmOxOa.cjs +0 -724
  25. package/dist/PageHero.vue_vue_type_script_setup_true_lang-CKCmOxOa.cjs.map +0 -1
  26. package/dist/TagsInput-BF3zRMcU.cjs +0 -3682
  27. package/dist/TagsInput-BF3zRMcU.cjs.map +0 -1
  28. package/dist/TagsInput-D0O6z6le.js.map +0 -1
  29. package/dist/_plugin-vue_export-helper-DM9IkUGy.cjs +0 -10
  30. package/dist/_plugin-vue_export-helper-DM9IkUGy.cjs.map +0 -1
  31. package/dist/components/core/Accordion.stories.d.ts +0 -11
  32. package/dist/components/core/Accordion.test.d.ts +0 -1
  33. package/dist/components/core/Accordion.vue.d.ts +0 -27
  34. package/dist/components/core/AccordionItem.stories.d.ts +0 -10
  35. package/dist/components/core/AccordionItem.vue.d.ts +0 -29
  36. package/dist/components/core/AutocompleteComponent.stories.d.ts +0 -14
  37. package/dist/components/core/AutocompleteComponent.test.d.ts +0 -1
  38. package/dist/components/core/AutocompleteComponent.vue.d.ts +0 -25
  39. package/dist/components/core/Avatar.stories.d.ts +0 -12
  40. package/dist/components/core/Avatar.test.d.ts +0 -1
  41. package/dist/components/core/Avatar.vue.d.ts +0 -20
  42. package/dist/components/core/Breadcrumb.stories.d.ts +0 -11
  43. package/dist/components/core/Breadcrumb.test.d.ts +0 -1
  44. package/dist/components/core/Breadcrumb.vue.d.ts +0 -26
  45. package/dist/components/core/Button.stories.d.ts +0 -18
  46. package/dist/components/core/Button.test.d.ts +0 -1
  47. package/dist/components/core/Button.vue.d.ts +0 -49
  48. package/dist/components/core/CardComponent.stories.d.ts +0 -13
  49. package/dist/components/core/CardComponent.test.d.ts +0 -1
  50. package/dist/components/core/CardComponent.vue.d.ts +0 -40
  51. package/dist/components/core/CollapsibleCard.stories.d.ts +0 -10
  52. package/dist/components/core/CollapsibleCard.test.d.ts +0 -1
  53. package/dist/components/core/CollapsibleCard.vue.d.ts +0 -38
  54. package/dist/components/core/DarkModeToggle.stories.d.ts +0 -15
  55. package/dist/components/core/DarkModeToggle.test.d.ts +0 -1
  56. package/dist/components/core/DarkModeToggle.vue.d.ts +0 -21
  57. package/dist/components/core/Drawer.stories.d.ts +0 -12
  58. package/dist/components/core/Drawer.test.d.ts +0 -1
  59. package/dist/components/core/Drawer.vue.d.ts +0 -50
  60. package/dist/components/core/Dropdown.stories.d.ts +0 -11
  61. package/dist/components/core/Dropdown.test.d.ts +0 -1
  62. package/dist/components/core/Dropdown.vue.d.ts +0 -56
  63. package/dist/components/core/FilterTabs.stories.d.ts +0 -14
  64. package/dist/components/core/FilterTabs.test.d.ts +0 -1
  65. package/dist/components/core/FilterTabs.vue.d.ts +0 -29
  66. package/dist/components/core/MenuItem.stories.d.ts +0 -13
  67. package/dist/components/core/MenuItem.test.d.ts +0 -1
  68. package/dist/components/core/MenuItem.vue.d.ts +0 -16
  69. package/dist/components/core/MobileList.stories.d.ts +0 -13
  70. package/dist/components/core/MobileList.test.d.ts +0 -1
  71. package/dist/components/core/MobileList.vue.d.ts +0 -86
  72. package/dist/components/core/Popover.stories.d.ts +0 -10
  73. package/dist/components/core/Popover.test.d.ts +0 -1
  74. package/dist/components/core/Popover.vue.d.ts +0 -44
  75. package/dist/components/core/ResponsiveList.stories.d.ts +0 -15
  76. package/dist/components/core/ResponsiveList.test.d.ts +0 -1
  77. package/dist/components/core/ResponsiveList.vue.d.ts +0 -128
  78. package/dist/components/core/StatsCard.stories.d.ts +0 -15
  79. package/dist/components/core/StatsCard.test.d.ts +0 -1
  80. package/dist/components/core/StatsCard.vue.d.ts +0 -44
  81. package/dist/components/core/StatsGrid.stories.d.ts +0 -12
  82. package/dist/components/core/StatsGrid.test.d.ts +0 -1
  83. package/dist/components/core/StatsGrid.vue.d.ts +0 -16
  84. package/dist/components/core/StatusBadge.stories.d.ts +0 -13
  85. package/dist/components/core/StatusBadge.test.d.ts +0 -1
  86. package/dist/components/core/StatusBadge.vue.d.ts +0 -21
  87. package/dist/components/core/Stepper.stories.d.ts +0 -12
  88. package/dist/components/core/Stepper.test.d.ts +0 -1
  89. package/dist/components/core/Stepper.vue.d.ts +0 -22
  90. package/dist/components/core/TabPanel.stories.d.ts +0 -8
  91. package/dist/components/core/TabPanel.test.d.ts +0 -1
  92. package/dist/components/core/TabPanel.vue.d.ts +0 -21
  93. package/dist/components/core/TableAction.stories.d.ts +0 -14
  94. package/dist/components/core/TableAction.test.d.ts +0 -1
  95. package/dist/components/core/TableAction.vue.d.ts +0 -8
  96. package/dist/components/core/TableComponent.stories.d.ts +0 -16
  97. package/dist/components/core/TableComponent.test.d.ts +0 -1
  98. package/dist/components/core/TableComponent.vue.d.ts +0 -67
  99. package/dist/components/core/Tabs.stories.d.ts +0 -10
  100. package/dist/components/core/Tabs.test.d.ts +0 -1
  101. package/dist/components/core/Tabs.vue.d.ts +0 -39
  102. package/dist/components/core/Timeline.stories.d.ts +0 -11
  103. package/dist/components/core/Timeline.test.d.ts +0 -1
  104. package/dist/components/core/Timeline.vue.d.ts +0 -34
  105. package/dist/components/core/Tooltip.stories.d.ts +0 -10
  106. package/dist/components/core/Tooltip.test.d.ts +0 -1
  107. package/dist/components/core/Tooltip.vue.d.ts +0 -34
  108. package/dist/components/core/index.cjs +0 -33
  109. package/dist/components/core/index.cjs.map +0 -1
  110. package/dist/components/core/index.test.d.ts +0 -1
  111. package/dist/components/feedback/Alert.stories.d.ts +0 -13
  112. package/dist/components/feedback/Alert.test.d.ts +0 -1
  113. package/dist/components/feedback/Alert.vue.d.ts +0 -34
  114. package/dist/components/feedback/CardSkeleton.stories.d.ts +0 -11
  115. package/dist/components/feedback/CardSkeleton.test.d.ts +0 -1
  116. package/dist/components/feedback/CardSkeleton.vue.d.ts +0 -14
  117. package/dist/components/feedback/ConfirmDialog.stories.d.ts +0 -12
  118. package/dist/components/feedback/ConfirmDialog.test.d.ts +0 -1
  119. package/dist/components/feedback/ConfirmDialog.vue.d.ts +0 -53
  120. package/dist/components/feedback/EmptyState.stories.d.ts +0 -13
  121. package/dist/components/feedback/EmptyState.test.d.ts +0 -1
  122. package/dist/components/feedback/EmptyState.vue.d.ts +0 -29
  123. package/dist/components/feedback/ListSkeleton.stories.d.ts +0 -12
  124. package/dist/components/feedback/ListSkeleton.test.d.ts +0 -1
  125. package/dist/components/feedback/ListSkeleton.vue.d.ts +0 -17
  126. package/dist/components/feedback/LoadingSpinner.stories.d.ts +0 -11
  127. package/dist/components/feedback/LoadingSpinner.test.d.ts +0 -1
  128. package/dist/components/feedback/LoadingSpinner.vue.d.ts +0 -12
  129. package/dist/components/feedback/Modal.stories.d.ts +0 -11
  130. package/dist/components/feedback/Modal.test.d.ts +0 -1
  131. package/dist/components/feedback/Modal.vue.d.ts +0 -47
  132. package/dist/components/feedback/NotificationComponent.stories.d.ts +0 -14
  133. package/dist/components/feedback/NotificationComponent.test.d.ts +0 -1
  134. package/dist/components/feedback/NotificationComponent.vue.d.ts +0 -12
  135. package/dist/components/feedback/NotificationList.stories.d.ts +0 -11
  136. package/dist/components/feedback/NotificationList.test.d.ts +0 -1
  137. package/dist/components/feedback/NotificationList.vue.d.ts +0 -18
  138. package/dist/components/feedback/PaginationControls.stories.d.ts +0 -12
  139. package/dist/components/feedback/PaginationControls.test.d.ts +0 -1
  140. package/dist/components/feedback/PaginationControls.vue.d.ts +0 -21
  141. package/dist/components/feedback/Progress.stories.d.ts +0 -14
  142. package/dist/components/feedback/Progress.test.d.ts +0 -1
  143. package/dist/components/feedback/Progress.vue.d.ts +0 -30
  144. package/dist/components/feedback/Skeleton.stories.d.ts +0 -15
  145. package/dist/components/feedback/Skeleton.test.d.ts +0 -1
  146. package/dist/components/feedback/Skeleton.vue.d.ts +0 -19
  147. package/dist/components/feedback/TableSkeleton.stories.d.ts +0 -12
  148. package/dist/components/feedback/TableSkeleton.test.d.ts +0 -1
  149. package/dist/components/feedback/TableSkeleton.vue.d.ts +0 -14
  150. package/dist/components/feedback/Toast.stories.d.ts +0 -12
  151. package/dist/components/feedback/Toast.test.d.ts +0 -1
  152. package/dist/components/feedback/Toast.vue.d.ts +0 -23
  153. package/dist/components/feedback/ToastContainer.stories.d.ts +0 -15
  154. package/dist/components/feedback/ToastContainer.test.d.ts +0 -1
  155. package/dist/components/feedback/ToastContainer.vue.d.ts +0 -24
  156. package/dist/components/feedback/index.cjs +0 -20
  157. package/dist/components/feedback/index.cjs.map +0 -1
  158. package/dist/components/feedback/index.test.d.ts +0 -1
  159. package/dist/components/form/Checkbox.stories.d.ts +0 -13
  160. package/dist/components/form/Checkbox.test.d.ts +0 -1
  161. package/dist/components/form/Checkbox.vue.d.ts +0 -22
  162. package/dist/components/form/ColorPicker.stories.d.ts +0 -12
  163. package/dist/components/form/ColorPicker.test.d.ts +0 -1
  164. package/dist/components/form/ColorPicker.vue.d.ts +0 -26
  165. package/dist/components/form/Combobox.stories.d.ts +0 -15
  166. package/dist/components/form/Combobox.test.d.ts +0 -1
  167. package/dist/components/form/Combobox.vue.d.ts +0 -46
  168. package/dist/components/form/DatePicker.stories.d.ts +0 -15
  169. package/dist/components/form/DatePicker.test.d.ts +0 -1
  170. package/dist/components/form/DatePicker.vue.d.ts +0 -36
  171. package/dist/components/form/EmailInput.stories.d.ts +0 -13
  172. package/dist/components/form/EmailInput.test.d.ts +0 -1
  173. package/dist/components/form/EmailInput.vue.d.ts +0 -32
  174. package/dist/components/form/FileUpload.stories.d.ts +0 -12
  175. package/dist/components/form/FileUpload.test.d.ts +0 -1
  176. package/dist/components/form/FileUpload.vue.d.ts +0 -40
  177. package/dist/components/form/FormActions.stories.d.ts +0 -18
  178. package/dist/components/form/FormActions.test.d.ts +0 -1
  179. package/dist/components/form/FormActions.vue.d.ts +0 -56
  180. package/dist/components/form/FormGroup.stories.d.ts +0 -10
  181. package/dist/components/form/FormGroup.test.d.ts +0 -1
  182. package/dist/components/form/FormGroup.vue.d.ts +0 -30
  183. package/dist/components/form/FormHelp.stories.d.ts +0 -11
  184. package/dist/components/form/FormHelp.test.d.ts +0 -1
  185. package/dist/components/form/FormHelp.vue.d.ts +0 -23
  186. package/dist/components/form/FormInput.stories.d.ts +0 -12
  187. package/dist/components/form/FormInput.test.d.ts +0 -1
  188. package/dist/components/form/FormInput.vue.d.ts +0 -13
  189. package/dist/components/form/FormLabel.stories.d.ts +0 -12
  190. package/dist/components/form/FormLabel.test.d.ts +0 -1
  191. package/dist/components/form/FormLabel.vue.d.ts +0 -21
  192. package/dist/components/form/FormSection.stories.d.ts +0 -13
  193. package/dist/components/form/FormSection.test.d.ts +0 -1
  194. package/dist/components/form/FormSection.vue.d.ts +0 -49
  195. package/dist/components/form/FormSelect.stories.d.ts +0 -13
  196. package/dist/components/form/FormSelect.test.d.ts +0 -1
  197. package/dist/components/form/FormSelect.vue.d.ts +0 -55
  198. package/dist/components/form/IconPicker.vue.d.ts +0 -33
  199. package/dist/components/form/InputWrapper.stories.d.ts +0 -16
  200. package/dist/components/form/InputWrapper.test.d.ts +0 -1
  201. package/dist/components/form/InputWrapper.vue.d.ts +0 -40
  202. package/dist/components/form/MoneyInput.stories.d.ts +0 -16
  203. package/dist/components/form/MoneyInput.test.d.ts +0 -1
  204. package/dist/components/form/MoneyInput.vue.d.ts +0 -40
  205. package/dist/components/form/NumberInput.stories.d.ts +0 -14
  206. package/dist/components/form/NumberInput.test.d.ts +0 -1
  207. package/dist/components/form/NumberInput.vue.d.ts +0 -39
  208. package/dist/components/form/OTPInput.stories.d.ts +0 -13
  209. package/dist/components/form/OTPInput.test.d.ts +0 -1
  210. package/dist/components/form/OTPInput.vue.d.ts +0 -33
  211. package/dist/components/form/PasswordInput.stories.d.ts +0 -15
  212. package/dist/components/form/PasswordInput.test.d.ts +0 -1
  213. package/dist/components/form/PasswordInput.vue.d.ts +0 -36
  214. package/dist/components/form/PercentInput.stories.d.ts +0 -12
  215. package/dist/components/form/PercentInput.test.d.ts +0 -1
  216. package/dist/components/form/PercentInput.vue.d.ts +0 -38
  217. package/dist/components/form/PhoneInput.stories.d.ts +0 -13
  218. package/dist/components/form/PhoneInput.test.d.ts +0 -1
  219. package/dist/components/form/PhoneInput.vue.d.ts +0 -89
  220. package/dist/components/form/QuantityInput.stories.d.ts +0 -12
  221. package/dist/components/form/QuantityInput.test.d.ts +0 -1
  222. package/dist/components/form/QuantityInput.vue.d.ts +0 -32
  223. package/dist/components/form/RangeSlider.stories.d.ts +0 -13
  224. package/dist/components/form/RangeSlider.test.d.ts +0 -1
  225. package/dist/components/form/RangeSlider.vue.d.ts +0 -35
  226. package/dist/components/form/Rating.stories.d.ts +0 -16
  227. package/dist/components/form/Rating.test.d.ts +0 -1
  228. package/dist/components/form/Rating.vue.d.ts +0 -43
  229. package/dist/components/form/SearchInput.stories.d.ts +0 -13
  230. package/dist/components/form/SearchInput.test.d.ts +0 -1
  231. package/dist/components/form/SearchInput.vue.d.ts +0 -26
  232. package/dist/components/form/Slider.stories.d.ts +0 -13
  233. package/dist/components/form/Slider.test.d.ts +0 -1
  234. package/dist/components/form/Slider.vue.d.ts +0 -29
  235. package/dist/components/form/Switch.stories.d.ts +0 -11
  236. package/dist/components/form/Switch.test.d.ts +0 -1
  237. package/dist/components/form/Switch.vue.d.ts +0 -23
  238. package/dist/components/form/TagsInput.stories.d.ts +0 -13
  239. package/dist/components/form/TagsInput.test.d.ts +0 -1
  240. package/dist/components/form/TagsInput.vue.d.ts +0 -37
  241. package/dist/components/form/URLInput.stories.d.ts +0 -11
  242. package/dist/components/form/URLInput.test.d.ts +0 -1
  243. package/dist/components/form/URLInput.vue.d.ts +0 -32
  244. package/dist/components/form/index.cjs +0 -34
  245. package/dist/components/form/index.cjs.map +0 -1
  246. package/dist/components/form/index.test.d.ts +0 -1
  247. package/dist/components/index.cjs +0 -91
  248. package/dist/components/index.cjs.map +0 -1
  249. package/dist/components/index.d.ts +0 -5
  250. package/dist/components/index.test.d.ts +0 -1
  251. package/dist/components/layout/AuthLayout.stories.d.ts +0 -10
  252. package/dist/components/layout/AuthLayout.test.d.ts +0 -1
  253. package/dist/components/layout/AuthLayout.vue.d.ts +0 -88
  254. package/dist/components/layout/BaseLayout.stories.d.ts +0 -11
  255. package/dist/components/layout/BaseLayout.test.d.ts +0 -1
  256. package/dist/components/layout/BaseLayout.vue.d.ts +0 -77
  257. package/dist/components/layout/PageHero.stories.d.ts +0 -11
  258. package/dist/components/layout/PageHero.test.d.ts +0 -1
  259. package/dist/components/layout/PageHero.vue.d.ts +0 -51
  260. package/dist/components/layout/PageLayout.stories.d.ts +0 -10
  261. package/dist/components/layout/PageLayout.test.d.ts +0 -1
  262. package/dist/components/layout/PageLayout.vue.d.ts +0 -37
  263. package/dist/components/layout/index.cjs +0 -8
  264. package/dist/components/layout/index.cjs.map +0 -1
  265. package/dist/components/layout/index.test.d.ts +0 -1
  266. package/dist/components/type/BadgeType.stories.d.ts +0 -13
  267. package/dist/components/type/BadgeType.test.d.ts +0 -1
  268. package/dist/components/type/BooleanType.stories.d.ts +0 -12
  269. package/dist/components/type/BooleanType.test.d.ts +0 -1
  270. package/dist/components/type/DateType.stories.d.ts +0 -12
  271. package/dist/components/type/DateType.test.d.ts +0 -1
  272. package/dist/components/type/NumberType.stories.d.ts +0 -11
  273. package/dist/components/type/NumberType.test.d.ts +0 -1
  274. package/dist/components/type/TextType.stories.d.ts +0 -10
  275. package/dist/components/type/TextType.test.d.ts +0 -1
  276. package/dist/components/type/index.cjs +0 -9
  277. package/dist/components/type/index.cjs.map +0 -1
  278. package/dist/components/type/index.test.d.ts +0 -1
  279. package/dist/composables/index.cjs +0 -19
  280. package/dist/composables/index.cjs.map +0 -1
  281. package/dist/composables/index.d.ts +0 -8
  282. package/dist/composables/index.test.d.ts +0 -1
  283. package/dist/composables/useDarkMode.d.ts +0 -14
  284. package/dist/composables/useDarkMode.test.d.ts +0 -1
  285. package/dist/composables/useDropdown.d.ts +0 -51
  286. package/dist/composables/useDropdown.test.d.ts +0 -1
  287. package/dist/composables/useExportCSV.d.ts +0 -10
  288. package/dist/composables/useExportCSV.test.d.ts +0 -1
  289. package/dist/composables/useFocusTrap.d.ts +0 -41
  290. package/dist/composables/useFocusTrap.test.d.ts +0 -1
  291. package/dist/composables/useId.d.ts +0 -42
  292. package/dist/composables/useId.test.d.ts +0 -1
  293. package/dist/composables/useModal.d.ts +0 -60
  294. package/dist/composables/useModal.test.d.ts +0 -1
  295. package/dist/composables/useNotifications.d.ts +0 -27
  296. package/dist/composables/useNotifications.test.d.ts +0 -1
  297. package/dist/composables/useToast.d.ts +0 -30
  298. package/dist/composables/useToast.test.d.ts +0 -1
  299. package/dist/index-D1x3TH9k.cjs +0 -401
  300. package/dist/index-D1x3TH9k.cjs.map +0 -1
  301. package/dist/index-D9_zMCpN.js.map +0 -1
  302. package/dist/index-PehFvNFG.cjs +0 -94
  303. package/dist/index-PehFvNFG.cjs.map +0 -1
  304. package/dist/index.cjs +0 -123
  305. package/dist/index.cjs.map +0 -1
  306. package/dist/index.d.ts +0 -5
  307. package/dist/index.test.d.ts +0 -1
  308. package/dist/plugin.d.ts +0 -24
  309. package/dist/style.css +0 -2
  310. package/dist/types/components.d.ts +0 -27
  311. package/dist/types/form.d.ts +0 -37
  312. package/dist/types/index.cjs +0 -2
  313. package/dist/types/index.cjs.map +0 -1
  314. package/dist/types/index.d.ts +0 -4
  315. package/dist/types/index.test.d.ts +0 -1
  316. package/dist/types/notification.d.ts +0 -12
  317. package/dist/types/property.d.ts +0 -34
  318. package/dist/useDarkMode-DLZcJEUQ.cjs +0 -52
  319. package/dist/useDarkMode-DLZcJEUQ.cjs.map +0 -1
  320. package/dist/useDropdown-DHFnd259.cjs +0 -130
  321. package/dist/useDropdown-DHFnd259.cjs.map +0 -1
  322. package/dist/useFocusTrap-kcxO8AeU.cjs +0 -119
  323. package/dist/useFocusTrap-kcxO8AeU.cjs.map +0 -1
  324. package/dist/useId-nxrBaIC9.cjs +0 -25
  325. package/dist/useId-nxrBaIC9.cjs.map +0 -1
  326. package/dist/useToast-Bk60GArg.cjs +0 -176
  327. package/dist/useToast-Bk60GArg.cjs.map +0 -1
@@ -1,724 +0,0 @@
1
- "use strict";
2
- const vue = require("vue");
3
- const vue$1 = require("@iconify/vue");
4
- const Dropdown_vue_vue_type_script_setup_true_lang = require("./Dropdown.vue_vue_type_script_setup_true_lang-BNOHbbm5.cjs");
5
- const _hoisted_1$3 = { class: "flex min-h-screen" };
6
- const _hoisted_2$3 = {
7
- key: 0,
8
- class: "absolute inset-0 overflow-hidden pointer-events-none"
9
- };
10
- const _hoisted_3$3 = {
11
- key: 1,
12
- class: "absolute inset-0 opacity-20 pointer-events-none",
13
- style: { "background-image": "radial-gradient(circle, rgba(255,255,255,0.4) 1px, transparent 1px)", "background-size": "24px 24px" }
14
- };
15
- const _hoisted_4$3 = { class: "relative z-10 flex flex-col justify-center px-16 py-12 text-white w-full" };
16
- const _hoisted_5$3 = { class: "flex items-center gap-3 mb-12" };
17
- const _hoisted_6$3 = { class: "size-14 bg-white/20 backdrop-blur-sm rounded-2xl flex items-center justify-center" };
18
- const _hoisted_7$3 = {
19
- key: 0,
20
- class: "text-3xl font-bold"
21
- };
22
- const _hoisted_8$3 = {
23
- key: 0,
24
- class: "text-4xl xl:text-5xl font-bold leading-tight mb-6"
25
- };
26
- const _hoisted_9$3 = {
27
- key: 1,
28
- class: "relative inline-block"
29
- };
30
- const _hoisted_10$3 = { class: "relative z-10" };
31
- const _hoisted_11$2 = {
32
- class: "absolute -bottom-2 left-0 w-full",
33
- viewBox: "0 0 280 12",
34
- fill: "none",
35
- preserveAspectRatio: "none"
36
- };
37
- const _hoisted_12$2 = ["stroke"];
38
- const _hoisted_13$2 = {
39
- key: 0,
40
- class: "text-lg text-white/80 max-w-md mb-10"
41
- };
42
- const _hoisted_14$2 = {
43
- key: 0,
44
- class: "space-y-4"
45
- };
46
- const _hoisted_15$1 = { class: "size-10 rounded-xl bg-white/10 backdrop-blur-sm flex items-center justify-center shrink-0" };
47
- const _hoisted_16 = { class: "flex-1 flex items-center justify-center p-6 sm:p-12 bg-gradient-to-br from-gray-50 to-gray-100 dark:from-slate-900 dark:to-slate-800" };
48
- const _hoisted_17 = { class: "lg:hidden text-center mb-8" };
49
- const _hoisted_18 = { class: "size-12 bg-primary-600 rounded-xl flex items-center justify-center shadow-lg shadow-primary-200 dark:shadow-primary-900/30" };
50
- const _hoisted_19 = {
51
- key: 0,
52
- class: "text-2xl font-bold text-gray-900 dark:text-white"
53
- };
54
- const _hoisted_20 = {
55
- key: 0,
56
- class: "text-center lg:text-left mb-8"
57
- };
58
- const _hoisted_21 = {
59
- key: 0,
60
- class: "text-2xl sm:text-3xl font-bold text-gray-900 dark:text-white mb-2"
61
- };
62
- const _hoisted_22 = {
63
- key: 1,
64
- class: "text-gray-600 dark:text-gray-400"
65
- };
66
- const _hoisted_23 = { class: "bg-white dark:bg-slate-800/80 rounded-3xl shadow-xl shadow-gray-200/50 dark:shadow-none p-8" };
67
- const _sfc_main$3 = /* @__PURE__ */ vue.defineComponent({
68
- __name: "AuthLayout",
69
- props: {
70
- appName: { default: "" },
71
- appIcon: { default: "lucide:box" },
72
- headline: { default: "" },
73
- subHeadline: { default: "" },
74
- description: { default: "" },
75
- features: { default: () => [] },
76
- gradientFrom: { default: "from-primary-700" },
77
- gradientVia: { default: "" },
78
- gradientTo: { default: "to-primary-800" },
79
- showDecorations: { type: Boolean, default: true },
80
- showPattern: { type: Boolean, default: true },
81
- underlineColor: { default: "rgba(165, 180, 252, 0.5)" },
82
- formTitle: { default: "" },
83
- formSubtitle: { default: "" },
84
- homeLink: { default: "/" },
85
- brandingAnimation: { default: "" },
86
- formAnimation: { default: "" }
87
- },
88
- setup(__props) {
89
- const props = __props;
90
- const slots = vue.useSlots();
91
- const hasBrandingContent = vue.computed(() => {
92
- return props.headline || props.subHeadline || props.description || props.features.length > 0 || slots["branding-logo"] || slots["branding-headline"] || slots["branding-content"] || props.appName;
93
- });
94
- const routerLinkComponent = vue.computed(() => {
95
- try {
96
- const RouterLink = vue.resolveComponent("RouterLink");
97
- if (typeof RouterLink !== "string") {
98
- return RouterLink;
99
- }
100
- } catch {
101
- }
102
- return "a";
103
- });
104
- const getLinkProps = (link) => {
105
- if (routerLinkComponent.value === "a") {
106
- return { href: link };
107
- }
108
- return { to: link };
109
- };
110
- const gradientClasses = vue.computed(() => {
111
- const classes = [props.gradientFrom, props.gradientTo];
112
- if (props.gradientVia) {
113
- classes.splice(1, 0, props.gradientVia);
114
- }
115
- return classes.filter(Boolean);
116
- });
117
- return (_ctx, _cache) => {
118
- return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$3, [
119
- hasBrandingContent.value || _ctx.$slots["branding-panel"] ? (vue.openBlock(), vue.createElementBlock("div", {
120
- key: 0,
121
- class: vue.normalizeClass([
122
- "hidden lg:flex lg:w-1/2 relative overflow-hidden bg-gradient-to-br",
123
- ...gradientClasses.value
124
- ])
125
- }, [
126
- vue.renderSlot(_ctx.$slots, "branding-panel", {}, () => [
127
- __props.showDecorations ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_2$3, [..._cache[0] || (_cache[0] = [
128
- vue.createElementVNode("div", { class: "absolute -top-20 -left-20 size-80 bg-white/5 rounded-full blur-3xl" }, null, -1),
129
- vue.createElementVNode("div", { class: "absolute top-1/3 right-10 size-60 bg-white/5 rounded-full blur-3xl" }, null, -1),
130
- vue.createElementVNode("div", { class: "absolute bottom-20 left-1/4 size-72 bg-white/5 rounded-full blur-3xl" }, null, -1)
131
- ])])) : vue.createCommentVNode("", true),
132
- __props.showPattern ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_3$3)) : vue.createCommentVNode("", true),
133
- __props.showDecorations ? (vue.openBlock(), vue.createElementBlock(vue.Fragment, { key: 2 }, [
134
- _cache[1] || (_cache[1] = vue.createElementVNode("div", { class: "absolute top-20 right-20 size-16 border-2 border-white/20 rounded-2xl rotate-12 pointer-events-none" }, null, -1)),
135
- _cache[2] || (_cache[2] = vue.createElementVNode("div", { class: "absolute bottom-32 left-16 size-12 border-2 border-white/20 rounded-full pointer-events-none" }, null, -1)),
136
- _cache[3] || (_cache[3] = vue.createElementVNode("div", { class: "absolute top-1/2 left-10 size-8 bg-white/10 rounded-lg rotate-45 pointer-events-none" }, null, -1))
137
- ], 64)) : vue.createCommentVNode("", true),
138
- vue.createElementVNode("div", _hoisted_4$3, [
139
- vue.createElementVNode("div", {
140
- class: vue.normalizeClass(__props.brandingAnimation)
141
- }, [
142
- vue.createElementVNode("div", _hoisted_5$3, [
143
- vue.renderSlot(_ctx.$slots, "branding-logo", {}, () => [
144
- __props.appName || __props.appIcon ? (vue.openBlock(), vue.createElementBlock(vue.Fragment, { key: 0 }, [
145
- vue.createElementVNode("div", _hoisted_6$3, [
146
- vue.createVNode(vue.unref(vue$1.Icon), {
147
- icon: __props.appIcon,
148
- class: "size-8 text-white"
149
- }, null, 8, ["icon"])
150
- ]),
151
- __props.appName ? (vue.openBlock(), vue.createElementBlock("span", _hoisted_7$3, vue.toDisplayString(__props.appName), 1)) : vue.createCommentVNode("", true)
152
- ], 64)) : vue.createCommentVNode("", true)
153
- ])
154
- ]),
155
- vue.renderSlot(_ctx.$slots, "branding-headline", {}, () => [
156
- __props.headline || __props.subHeadline ? (vue.openBlock(), vue.createElementBlock("h1", _hoisted_8$3, [
157
- __props.headline ? (vue.openBlock(), vue.createElementBlock(vue.Fragment, { key: 0 }, [
158
- vue.createTextVNode(vue.toDisplayString(__props.headline), 1),
159
- _cache[4] || (_cache[4] = vue.createElementVNode("br", null, null, -1))
160
- ], 64)) : vue.createCommentVNode("", true),
161
- __props.subHeadline ? (vue.openBlock(), vue.createElementBlock("span", _hoisted_9$3, [
162
- vue.createElementVNode("span", _hoisted_10$3, vue.toDisplayString(__props.subHeadline), 1),
163
- (vue.openBlock(), vue.createElementBlock("svg", _hoisted_11$2, [
164
- vue.createElementVNode("path", {
165
- d: "M2 10C45 4 90 2 140 6C190 10 235 4 278 8",
166
- stroke: __props.underlineColor,
167
- "stroke-width": "4",
168
- "stroke-linecap": "round"
169
- }, null, 8, _hoisted_12$2)
170
- ]))
171
- ])) : vue.createCommentVNode("", true)
172
- ])) : vue.createCommentVNode("", true)
173
- ]),
174
- __props.description ? (vue.openBlock(), vue.createElementBlock("p", _hoisted_13$2, vue.toDisplayString(__props.description), 1)) : vue.createCommentVNode("", true),
175
- vue.renderSlot(_ctx.$slots, "branding-features", {}, () => [
176
- __props.features.length > 0 ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_14$2, [
177
- (vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(__props.features, (feature, index) => {
178
- return vue.openBlock(), vue.createElementBlock("div", {
179
- key: index,
180
- class: "flex items-center gap-3 text-white/90"
181
- }, [
182
- vue.createElementVNode("div", _hoisted_15$1, [
183
- vue.createVNode(vue.unref(vue$1.Icon), {
184
- icon: feature.icon,
185
- class: "size-5"
186
- }, null, 8, ["icon"])
187
- ]),
188
- vue.createElementVNode("span", null, vue.toDisplayString(feature.text), 1)
189
- ]);
190
- }), 128))
191
- ])) : vue.createCommentVNode("", true)
192
- ]),
193
- vue.renderSlot(_ctx.$slots, "branding-content")
194
- ], 2)
195
- ])
196
- ])
197
- ], 2)) : vue.createCommentVNode("", true),
198
- vue.createElementVNode("div", _hoisted_16, [
199
- vue.createElementVNode("div", {
200
- class: vue.normalizeClass(["w-full max-w-md", __props.formAnimation])
201
- }, [
202
- vue.createElementVNode("div", _hoisted_17, [
203
- (vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(routerLinkComponent.value), vue.mergeProps(getLinkProps(__props.homeLink), { class: "inline-flex items-center gap-3" }), {
204
- default: vue.withCtx(() => [
205
- vue.renderSlot(_ctx.$slots, "mobile-logo", {}, () => [
206
- __props.appName || __props.appIcon ? (vue.openBlock(), vue.createElementBlock(vue.Fragment, { key: 0 }, [
207
- vue.createElementVNode("div", _hoisted_18, [
208
- vue.createVNode(vue.unref(vue$1.Icon), {
209
- icon: __props.appIcon,
210
- class: "size-6 text-white"
211
- }, null, 8, ["icon"])
212
- ]),
213
- __props.appName ? (vue.openBlock(), vue.createElementBlock("span", _hoisted_19, vue.toDisplayString(__props.appName), 1)) : vue.createCommentVNode("", true)
214
- ], 64)) : vue.createCommentVNode("", true)
215
- ])
216
- ]),
217
- _: 3
218
- }, 16))
219
- ]),
220
- vue.renderSlot(_ctx.$slots, "form-header", {}, () => [
221
- __props.formTitle || __props.formSubtitle ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_20, [
222
- __props.formTitle ? (vue.openBlock(), vue.createElementBlock("h2", _hoisted_21, vue.toDisplayString(__props.formTitle), 1)) : vue.createCommentVNode("", true),
223
- __props.formSubtitle ? (vue.openBlock(), vue.createElementBlock("p", _hoisted_22, vue.toDisplayString(__props.formSubtitle), 1)) : vue.createCommentVNode("", true)
224
- ])) : vue.createCommentVNode("", true)
225
- ]),
226
- vue.createElementVNode("div", _hoisted_23, [
227
- vue.renderSlot(_ctx.$slots, "default")
228
- ]),
229
- vue.renderSlot(_ctx.$slots, "form-footer")
230
- ], 2)
231
- ])
232
- ]);
233
- };
234
- }
235
- });
236
- const _hoisted_1$2 = { class: "font-inter relative flex h-dvh overflow-hidden bg-gray-100 dark:bg-slate-900" };
237
- const _hoisted_2$2 = { class: "flex h-16 items-center px-3" };
238
- const _hoisted_3$2 = { class: "flex flex-1 items-center justify-center gap-3" };
239
- const _hoisted_4$2 = { class: "bg-primary text-primary-foreground flex size-8 items-center justify-center rounded-lg bg-white/20" };
240
- const _hoisted_5$2 = { class: "flex flex-col gap-3 px-3 pb-3" };
241
- const _hoisted_6$2 = { class: "flex flex-1 flex-col min-w-0" };
242
- const _hoisted_7$2 = { class: "flex h-16 items-center justify-between border-b border-slate-200 bg-white px-4 dark:border-slate-800 dark:bg-slate-950" };
243
- const _hoisted_8$2 = { class: "flex-1" };
244
- const _hoisted_9$2 = { class: "flex items-center gap-3" };
245
- const _hoisted_10$2 = { class: "flex items-center gap-2 rounded-lg p-1.5 transition hover:bg-gray-100 dark:hover:bg-gray-800" };
246
- const _hoisted_11$1 = { class: "flex size-8 items-center justify-center rounded-full bg-primary text-sm font-medium text-white" };
247
- const _hoisted_12$1 = { class: "hidden text-sm font-medium text-gray-700 dark:text-gray-300 md:block" };
248
- const _hoisted_13$1 = { class: "min-w-48 py-1" };
249
- const _hoisted_14$1 = { class: "flex flex-1 flex-col overflow-y-auto overflow-x-hidden" };
250
- const _hoisted_15 = { class: "container mx-auto flex flex-1 flex-col gap-5 p-5 max-w-full" };
251
- const _sfc_main$2 = /* @__PURE__ */ vue.defineComponent({
252
- __name: "BaseLayout",
253
- props: {
254
- menuItems: { default: () => [] },
255
- appName: { default: "App" },
256
- appIcon: { default: "lucide:box" },
257
- sidebarOpen: { type: Boolean, default: true },
258
- dark: { type: Boolean, default: false },
259
- showDarkToggle: { type: Boolean, default: true },
260
- sidebarClass: { default: "bg-[#172b4c] dark:bg-slate-950" },
261
- currentPath: { default: void 0 },
262
- userName: { default: void 0 },
263
- userAvatar: { default: void 0 },
264
- userMenuItems: { default: () => [] },
265
- menuPosition: { default: "top" }
266
- },
267
- emits: ["update:sidebarOpen", "update:dark"],
268
- setup(__props, { emit: __emit }) {
269
- const props = __props;
270
- const menuPositionClass = vue.computed(() => {
271
- switch (props.menuPosition) {
272
- case "center":
273
- return "lg:justify-center";
274
- case "bottom":
275
- return "lg:justify-end";
276
- case "top":
277
- default:
278
- return "lg:justify-start";
279
- }
280
- });
281
- const emit = __emit;
282
- const internalSidebarOpen = vue.ref(props.sidebarOpen);
283
- const internalDark = vue.ref(props.dark);
284
- const sidebarOpenModel = vue.computed({
285
- get: () => props.sidebarOpen ?? internalSidebarOpen.value,
286
- set: (value) => {
287
- internalSidebarOpen.value = value;
288
- emit("update:sidebarOpen", value);
289
- }
290
- });
291
- const darkModel = vue.computed({
292
- get: () => props.dark ?? internalDark.value,
293
- set: (value) => {
294
- internalDark.value = value;
295
- emit("update:dark", value);
296
- }
297
- });
298
- const toggleSidebar = () => {
299
- sidebarOpenModel.value = !sidebarOpenModel.value;
300
- };
301
- const toggleDark = () => {
302
- darkModel.value = !darkModel.value;
303
- };
304
- const routerViewComponent = vue.computed(() => {
305
- try {
306
- const RouterView = vue.resolveComponent("RouterView");
307
- if (typeof RouterView !== "string") {
308
- return RouterView;
309
- }
310
- } catch {
311
- }
312
- return null;
313
- });
314
- const routerLinkComponent = vue.computed(() => {
315
- try {
316
- const RouterLink = vue.resolveComponent("RouterLink");
317
- if (typeof RouterLink !== "string") {
318
- return RouterLink;
319
- }
320
- } catch {
321
- }
322
- return "a";
323
- });
324
- const getLinkProps = (link) => {
325
- if (routerLinkComponent.value === "a") {
326
- return { href: link };
327
- }
328
- return { to: link };
329
- };
330
- const handleUserMenuClick = (item) => {
331
- if (item.action) {
332
- item.action();
333
- }
334
- };
335
- return (_ctx, _cache) => {
336
- return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$2, [
337
- sidebarOpenModel.value ? (vue.openBlock(), vue.createElementBlock("div", {
338
- key: 0,
339
- class: "absolute z-40 h-full w-full bg-slate-950/20 lg:hidden dark:bg-white/20",
340
- onClick: _cache[0] || (_cache[0] = ($event) => sidebarOpenModel.value = false)
341
- })) : vue.createCommentVNode("", true),
342
- vue.createElementVNode("aside", {
343
- class: vue.normalizeClass([[
344
- sidebarOpenModel.value ? "lg:w-60" : "max-lg:-translate-x-76 lg:w-16",
345
- __props.sidebarClass
346
- ], "@container max-lg:absolute max-lg:z-50 flex h-full w-76 flex-col justify-between gap-10 transition-all duration-1000 ease-in-out"])
347
- }, [
348
- vue.createElementVNode("div", _hoisted_2$2, [
349
- vue.createElementVNode("div", _hoisted_3$2, [
350
- vue.renderSlot(_ctx.$slots, "logo", {}, () => [
351
- vue.createElementVNode("div", _hoisted_4$2, [
352
- vue.createVNode(vue.unref(vue$1.Icon), {
353
- class: "size-5 text-white",
354
- icon: __props.appIcon
355
- }, null, 8, ["icon"])
356
- ]),
357
- vue.createElementVNode("span", {
358
- class: vue.normalizeClass([sidebarOpenModel.value ? "block" : "hidden", "font-outfit flex-1 text-lg font-semibold text-white"])
359
- }, vue.toDisplayString(__props.appName), 3)
360
- ])
361
- ]),
362
- vue.createElementVNode("button", {
363
- class: "rounded-lg bg-white/10 p-1 transition hover:bg-white/20 lg:hidden",
364
- onClick: toggleSidebar
365
- }, [
366
- vue.createVNode(vue.unref(vue$1.Icon), {
367
- class: "size-6 text-white",
368
- icon: "lucide:menu"
369
- })
370
- ])
371
- ]),
372
- vue.createElementVNode("div", {
373
- class: vue.normalizeClass([[sidebarOpenModel.value ? "items-start" : "items-center", menuPositionClass.value], "flex min-h-0 flex-1 flex-col gap-8 overflow-y-auto overflow-x-hidden px-2"])
374
- }, [
375
- vue.renderSlot(_ctx.$slots, "menu", { currentPath: __props.currentPath }, () => [
376
- (vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(__props.menuItems, (item, index) => {
377
- return vue.openBlock(), vue.createBlock(Dropdown_vue_vue_type_script_setup_true_lang._sfc_main, {
378
- key: index,
379
- "menu-item": item,
380
- expanded: sidebarOpenModel.value,
381
- "current-path": __props.currentPath
382
- }, null, 8, ["menu-item", "expanded", "current-path"]);
383
- }), 128))
384
- ])
385
- ], 2),
386
- vue.createElementVNode("div", _hoisted_5$2, [
387
- vue.renderSlot(_ctx.$slots, "sidebar-footer")
388
- ])
389
- ], 2),
390
- vue.createElementVNode("div", _hoisted_6$2, [
391
- vue.createElementVNode("header", _hoisted_7$2, [
392
- vue.createElementVNode("div", null, [
393
- vue.createElementVNode("button", {
394
- class: "rounded-lg bg-gray-100 p-1 transition hover:bg-gray-200 dark:bg-gray-900 dark:hover:bg-gray-800",
395
- onClick: toggleSidebar
396
- }, [
397
- vue.createVNode(vue.unref(vue$1.Icon), {
398
- class: "size-6 text-gray-900 hover:text-gray-800 dark:text-gray-100",
399
- icon: "lucide:menu"
400
- })
401
- ])
402
- ]),
403
- vue.createElementVNode("div", _hoisted_8$2, [
404
- vue.renderSlot(_ctx.$slots, "header-center")
405
- ]),
406
- vue.createElementVNode("div", _hoisted_9$2, [
407
- vue.renderSlot(_ctx.$slots, "header-actions"),
408
- __props.showDarkToggle ? (vue.openBlock(), vue.createElementBlock("button", {
409
- key: 0,
410
- class: "flex items-center justify-center rounded-lg bg-gray-100 p-2 transition hover:bg-gray-200 dark:bg-gray-900 dark:hover:bg-gray-800",
411
- onClick: toggleDark
412
- }, [
413
- vue.createVNode(vue.unref(vue$1.Icon), {
414
- icon: darkModel.value ? "lucide:sun" : "lucide:moon",
415
- class: "size-5 text-gray-900 dark:text-gray-100"
416
- }, null, 8, ["icon"])
417
- ])) : vue.createCommentVNode("", true),
418
- __props.userName || __props.userAvatar ? (vue.openBlock(), vue.createBlock(Dropdown_vue_vue_type_script_setup_true_lang._sfc_main$1, {
419
- key: 1,
420
- align: "right"
421
- }, {
422
- trigger: vue.withCtx(() => [
423
- vue.createElementVNode("button", _hoisted_10$2, [
424
- vue.createElementVNode("div", _hoisted_11$1, vue.toDisplayString(__props.userAvatar || "?"), 1),
425
- vue.createElementVNode("span", _hoisted_12$1, vue.toDisplayString(__props.userName), 1),
426
- vue.createVNode(vue.unref(vue$1.Icon), {
427
- icon: "lucide:chevron-down",
428
- class: "size-4 text-gray-500"
429
- })
430
- ])
431
- ]),
432
- default: vue.withCtx(({ close }) => [
433
- vue.createElementVNode("div", _hoisted_13$1, [
434
- (vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(__props.userMenuItems, (item) => {
435
- return vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(item.link ? routerLinkComponent.value : "button"), vue.mergeProps({
436
- key: item.label
437
- }, { ref_for: true }, item.link ? getLinkProps(item.link) : {}, {
438
- class: "flex w-full items-center gap-2 px-4 py-2 text-left text-sm text-gray-700 hover:bg-gray-100 dark:text-gray-300 dark:hover:bg-gray-800",
439
- onClick: ($event) => {
440
- handleUserMenuClick(item);
441
- close();
442
- }
443
- }), {
444
- default: vue.withCtx(() => [
445
- item.icon ? (vue.openBlock(), vue.createBlock(vue.unref(vue$1.Icon), {
446
- key: 0,
447
- icon: item.icon,
448
- class: "size-4"
449
- }, null, 8, ["icon"])) : vue.createCommentVNode("", true),
450
- vue.createTextVNode(" " + vue.toDisplayString(item.label), 1)
451
- ]),
452
- _: 2
453
- }, 1040, ["onClick"]);
454
- }), 128))
455
- ])
456
- ]),
457
- _: 1
458
- })) : vue.createCommentVNode("", true)
459
- ])
460
- ]),
461
- vue.createElementVNode("div", _hoisted_14$1, [
462
- vue.createElementVNode("main", _hoisted_15, [
463
- vue.renderSlot(_ctx.$slots, "default", {}, () => [
464
- routerViewComponent.value ? (vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(routerViewComponent.value), { key: 0 })) : vue.createCommentVNode("", true)
465
- ])
466
- ])
467
- ])
468
- ])
469
- ]);
470
- };
471
- }
472
- });
473
- const _hoisted_1$1 = { class: "flex flex-col gap-4" };
474
- const _hoisted_2$1 = {
475
- key: 0,
476
- "aria-label": "Breadcrumb"
477
- };
478
- const _hoisted_3$1 = { class: "flex items-center" };
479
- const _hoisted_4$1 = {
480
- key: 0,
481
- class: "mx-3 text-sm font-semibold text-gray-400 dark:text-gray-600"
482
- };
483
- const _hoisted_5$1 = { class: "flex flex-col gap-4 md:flex-row md:items-start md:justify-between" };
484
- const _hoisted_6$1 = { class: "flex flex-col gap-1 min-w-0 flex-1" };
485
- const _hoisted_7$1 = {
486
- key: 0,
487
- class: "text-2xl font-bold text-gray-900 dark:text-gray-100 truncate"
488
- };
489
- const _hoisted_8$1 = {
490
- key: 1,
491
- class: "text-sm text-gray-600 dark:text-gray-400"
492
- };
493
- const _hoisted_9$1 = { class: "flex items-center gap-2 flex-wrap shrink-0" };
494
- const _hoisted_10$1 = { class: "flex-1" };
495
- const _sfc_main$1 = /* @__PURE__ */ vue.defineComponent({
496
- __name: "PageLayout",
497
- props: {
498
- title: {},
499
- description: {},
500
- breadcrumbs: {}
501
- },
502
- setup(__props) {
503
- const linkComponent = vue.computed(() => {
504
- try {
505
- const RouterLink = vue.resolveComponent("RouterLink");
506
- if (typeof RouterLink !== "string") {
507
- return RouterLink;
508
- }
509
- } catch {
510
- }
511
- return "a";
512
- });
513
- const getLinkProps = (link) => {
514
- if (linkComponent.value === "a") {
515
- return { href: link };
516
- }
517
- return { to: link };
518
- };
519
- return (_ctx, _cache) => {
520
- return vue.openBlock(), vue.createElementBlock("div", _hoisted_1$1, [
521
- __props.breadcrumbs && __props.breadcrumbs.length > 0 ? (vue.openBlock(), vue.createElementBlock("nav", _hoisted_2$1, [
522
- vue.createElementVNode("ol", _hoisted_3$1, [
523
- (vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(__props.breadcrumbs, (breadcrumb, index) => {
524
- return vue.openBlock(), vue.createElementBlock("li", {
525
- key: index,
526
- class: "flex items-center"
527
- }, [
528
- index > 0 ? (vue.openBlock(), vue.createElementBlock("span", _hoisted_4$1, " / ")) : vue.createCommentVNode("", true),
529
- vue.renderSlot(_ctx.$slots, "breadcrumb", {
530
- breadcrumb,
531
- index,
532
- isLast: index === __props.breadcrumbs.length - 1
533
- }, () => [
534
- (vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(linkComponent.value), vue.mergeProps({ ref_for: true }, getLinkProps(breadcrumb.link), {
535
- class: [
536
- "text-sm transition-colors",
537
- index < __props.breadcrumbs.length - 1 ? "font-semibold text-gray-900 hover:text-primary/90 hover:underline dark:text-gray-100" : "text-gray-400 dark:text-gray-600"
538
- ]
539
- }), {
540
- default: vue.withCtx(() => [
541
- vue.createTextVNode(vue.toDisplayString(breadcrumb.label), 1)
542
- ]),
543
- _: 2
544
- }, 1040, ["class"]))
545
- ])
546
- ]);
547
- }), 128))
548
- ])
549
- ])) : vue.createCommentVNode("", true),
550
- vue.createElementVNode("div", _hoisted_5$1, [
551
- vue.createElementVNode("div", _hoisted_6$1, [
552
- __props.title ? (vue.openBlock(), vue.createElementBlock("h1", _hoisted_7$1, [
553
- vue.renderSlot(_ctx.$slots, "title", {}, () => [
554
- vue.createTextVNode(vue.toDisplayString(__props.title), 1)
555
- ])
556
- ])) : vue.createCommentVNode("", true),
557
- __props.description ? (vue.openBlock(), vue.createElementBlock("p", _hoisted_8$1, [
558
- vue.renderSlot(_ctx.$slots, "description", {}, () => [
559
- vue.createTextVNode(vue.toDisplayString(__props.description), 1)
560
- ])
561
- ])) : vue.createCommentVNode("", true)
562
- ]),
563
- vue.createElementVNode("div", _hoisted_9$1, [
564
- vue.renderSlot(_ctx.$slots, "actions")
565
- ])
566
- ]),
567
- vue.createElementVNode("div", _hoisted_10$1, [
568
- vue.renderSlot(_ctx.$slots, "default")
569
- ])
570
- ]);
571
- };
572
- }
573
- });
574
- const _hoisted_1 = { class: "relative overflow-hidden bg-linear-to-br from-primary-600 via-primary-500 to-primary-400" };
575
- const _hoisted_2 = {
576
- key: 0,
577
- class: "absolute inset-0 overflow-hidden pointer-events-none"
578
- };
579
- const _hoisted_3 = {
580
- key: 1,
581
- class: "absolute inset-0 overflow-hidden pointer-events-none"
582
- };
583
- const _hoisted_4 = { class: "relative px-4 pt-8 pb-10 sm:px-6 lg:px-8 max-w-5xl mx-auto" };
584
- const _hoisted_5 = { class: "text-center mb-8 animate-fade-in-up" };
585
- const _hoisted_6 = {
586
- key: 0,
587
- class: "inline-flex items-center gap-2 px-4 py-2 rounded-full bg-white/15 backdrop-blur-sm border border-white/20 mb-4"
588
- };
589
- const _hoisted_7 = {
590
- key: 1,
591
- class: "text-sm font-medium text-white"
592
- };
593
- const _hoisted_8 = { class: "text-2xl sm:text-3xl font-bold text-white mb-2" };
594
- const _hoisted_9 = {
595
- key: 1,
596
- class: "text-primary-100 text-sm sm:text-base"
597
- };
598
- const _hoisted_10 = {
599
- key: 0,
600
- class: "animate-fade-in-up [animation-delay:0.1s]"
601
- };
602
- const _hoisted_11 = {
603
- key: 0,
604
- class: "w-10 h-10 mx-auto mb-2 rounded-xl bg-white/20 flex items-center justify-center"
605
- };
606
- const _hoisted_12 = { class: "text-2xl sm:text-3xl font-bold text-white" };
607
- const _hoisted_13 = { class: "text-xs sm:text-sm text-primary-100" };
608
- const _hoisted_14 = {
609
- key: 2,
610
- class: "absolute bottom-0 left-0 right-0"
611
- };
612
- const _sfc_main = /* @__PURE__ */ vue.defineComponent({
613
- __name: "PageHero",
614
- props: {
615
- title: {},
616
- subtitle: {},
617
- badge: {},
618
- badgeIcon: {},
619
- showBlobs: { type: Boolean, default: true },
620
- showWave: { type: Boolean, default: true },
621
- stats: {},
622
- gradientDirection: { default: "br" },
623
- decorativeIcons: {}
624
- },
625
- setup(__props) {
626
- return (_ctx, _cache) => {
627
- var _a, _b;
628
- return vue.openBlock(), vue.createElementBlock("div", _hoisted_1, [
629
- __props.showBlobs ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_2, [..._cache[0] || (_cache[0] = [
630
- vue.createElementVNode("div", { class: "absolute -top-20 -right-20 w-72 h-72 bg-white/10 rounded-full blur-3xl animate-float" }, null, -1),
631
- vue.createElementVNode("div", { class: "absolute -bottom-32 -left-32 w-96 h-96 bg-white/5 rounded-full blur-3xl animate-float [animation-delay:1s]" }, null, -1)
632
- ])])) : vue.createCommentVNode("", true),
633
- ((_a = __props.decorativeIcons) == null ? void 0 : _a.length) ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_3, [
634
- __props.decorativeIcons[0] ? (vue.openBlock(), vue.createBlock(vue.unref(vue$1.Icon), {
635
- key: 0,
636
- icon: __props.decorativeIcons[0],
637
- class: "absolute top-12 right-8 w-24 h-24 text-white/5 rotate-12"
638
- }, null, 8, ["icon"])) : vue.createCommentVNode("", true),
639
- __props.decorativeIcons[1] ? (vue.openBlock(), vue.createBlock(vue.unref(vue$1.Icon), {
640
- key: 1,
641
- icon: __props.decorativeIcons[1],
642
- class: "absolute bottom-8 left-12 w-20 h-20 text-white/5 -rotate-12"
643
- }, null, 8, ["icon"])) : vue.createCommentVNode("", true)
644
- ])) : vue.createCommentVNode("", true),
645
- vue.renderSlot(_ctx.$slots, "background"),
646
- vue.createElementVNode("div", _hoisted_4, [
647
- vue.createElementVNode("div", _hoisted_5, [
648
- __props.badge || __props.badgeIcon || _ctx.$slots.badge ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_6, [
649
- vue.renderSlot(_ctx.$slots, "badge", {}, () => [
650
- __props.badgeIcon ? (vue.openBlock(), vue.createBlock(vue.unref(vue$1.Icon), {
651
- key: 0,
652
- icon: __props.badgeIcon,
653
- class: "w-5 h-5 text-white"
654
- }, null, 8, ["icon"])) : vue.createCommentVNode("", true),
655
- __props.badge ? (vue.openBlock(), vue.createElementBlock("span", _hoisted_7, vue.toDisplayString(__props.badge), 1)) : vue.createCommentVNode("", true)
656
- ])
657
- ])) : vue.createCommentVNode("", true),
658
- vue.createElementVNode("h1", _hoisted_8, [
659
- vue.renderSlot(_ctx.$slots, "title", {}, () => [
660
- vue.createTextVNode(vue.toDisplayString(__props.title), 1)
661
- ])
662
- ]),
663
- __props.subtitle || _ctx.$slots.subtitle ? (vue.openBlock(), vue.createElementBlock("p", _hoisted_9, [
664
- vue.renderSlot(_ctx.$slots, "subtitle", {}, () => [
665
- vue.createTextVNode(vue.toDisplayString(__props.subtitle), 1)
666
- ])
667
- ])) : vue.createCommentVNode("", true)
668
- ]),
669
- ((_b = __props.stats) == null ? void 0 : _b.length) || _ctx.$slots.stats ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_10, [
670
- vue.renderSlot(_ctx.$slots, "stats", {}, () => {
671
- var _a2, _b2, _c;
672
- return [
673
- vue.createElementVNode("div", {
674
- class: vue.normalizeClass(["grid gap-3 sm:gap-4", [
675
- ((_a2 = __props.stats) == null ? void 0 : _a2.length) === 2 ? "grid-cols-2" : "",
676
- ((_b2 = __props.stats) == null ? void 0 : _b2.length) === 3 ? "grid-cols-3" : "",
677
- ((_c = __props.stats) == null ? void 0 : _c.length) === 4 ? "grid-cols-2 sm:grid-cols-4" : "",
678
- __props.stats && __props.stats.length > 4 ? "grid-cols-2 sm:grid-cols-3 lg:grid-cols-4" : ""
679
- ]])
680
- }, [
681
- (vue.openBlock(true), vue.createElementBlock(vue.Fragment, null, vue.renderList(__props.stats, (stat, index) => {
682
- return vue.openBlock(), vue.createElementBlock("div", {
683
- key: index,
684
- class: "bg-white/15 backdrop-blur-sm rounded-2xl p-4 border border-white/20 text-center"
685
- }, [
686
- stat.icon ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_11, [
687
- vue.createVNode(vue.unref(vue$1.Icon), {
688
- icon: stat.icon,
689
- class: "w-5 h-5 text-white"
690
- }, null, 8, ["icon"])
691
- ])) : vue.createCommentVNode("", true),
692
- vue.createElementVNode("div", _hoisted_12, vue.toDisplayString(stat.value), 1),
693
- vue.createElementVNode("div", _hoisted_13, vue.toDisplayString(stat.label), 1)
694
- ]);
695
- }), 128))
696
- ], 2)
697
- ];
698
- })
699
- ])) : vue.createCommentVNode("", true),
700
- vue.renderSlot(_ctx.$slots, "content")
701
- ]),
702
- __props.showWave ? (vue.openBlock(), vue.createElementBlock("div", _hoisted_14, [..._cache[1] || (_cache[1] = [
703
- vue.createElementVNode("svg", {
704
- viewBox: "0 0 1440 80",
705
- fill: "none",
706
- xmlns: "http://www.w3.org/2000/svg",
707
- class: "w-full h-auto",
708
- preserveAspectRatio: "none"
709
- }, [
710
- vue.createElementVNode("path", {
711
- d: "M0 80L60 74.7C120 69 240 59 360 53.3C480 48 600 48 720 53.3C840 59 960 69 1080 69.3C1200 69 1320 59 1380 53.3L1440 48V80H1380C1320 80 1200 80 1080 80C960 80 840 80 720 80C600 80 480 80 360 80C240 80 120 80 60 80H0Z",
712
- class: "fill-gray-50 dark:fill-slate-900"
713
- })
714
- ], -1)
715
- ])])) : vue.createCommentVNode("", true)
716
- ]);
717
- };
718
- }
719
- });
720
- exports._sfc_main = _sfc_main$3;
721
- exports._sfc_main$1 = _sfc_main$2;
722
- exports._sfc_main$2 = _sfc_main$1;
723
- exports._sfc_main$3 = _sfc_main;
724
- //# sourceMappingURL=PageHero.vue_vue_type_script_setup_true_lang-CKCmOxOa.cjs.map