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.
- 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
- 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
- package/dist/{TagsInput-D0O6z6le.js → TagsInput-DtoJKN3L.js} +17 -5
- package/dist/TagsInput-DtoJKN3L.js.map +1 -0
- package/dist/components/form/index.js +1 -1
- package/dist/components/index.js +2 -2
- package/dist/components/layout/index.js +1 -1
- package/dist/{index-D9_zMCpN.js → index-F9yanU6_.js} +3 -3
- package/dist/index-F9yanU6_.js.map +1 -0
- package/dist/index.js +3 -3
- package/package.json +1 -1
- package/dist/BadgeType.vue_vue_type_script_setup_true_lang-zs0NXN4g.cjs +0 -145
- package/dist/BadgeType.vue_vue_type_script_setup_true_lang-zs0NXN4g.cjs.map +0 -1
- package/dist/Button.vue_vue_type_script_setup_true_lang-CXRj7LEP.cjs +0 -98
- package/dist/Button.vue_vue_type_script_setup_true_lang-CXRj7LEP.cjs.map +0 -1
- package/dist/ConfirmDialog.vue_vue_type_script_setup_true_lang-Bine-xfp.cjs +0 -928
- package/dist/ConfirmDialog.vue_vue_type_script_setup_true_lang-Bine-xfp.cjs.map +0 -1
- package/dist/Dropdown.vue_vue_type_script_setup_true_lang-BNOHbbm5.cjs +0 -228
- package/dist/Dropdown.vue_vue_type_script_setup_true_lang-BNOHbbm5.cjs.map +0 -1
- package/dist/FilterTabs.vue_vue_type_script_setup_true_lang-HwjuvIJX.cjs +0 -2242
- package/dist/FilterTabs.vue_vue_type_script_setup_true_lang-HwjuvIJX.cjs.map +0 -1
- package/dist/ListSkeleton.vue_vue_type_script_setup_true_lang-DtwwmfWr.cjs +0 -149
- package/dist/ListSkeleton.vue_vue_type_script_setup_true_lang-DtwwmfWr.cjs.map +0 -1
- package/dist/PageHero.vue_vue_type_script_setup_true_lang-CKCmOxOa.cjs +0 -724
- package/dist/PageHero.vue_vue_type_script_setup_true_lang-CKCmOxOa.cjs.map +0 -1
- package/dist/TagsInput-BF3zRMcU.cjs +0 -3682
- package/dist/TagsInput-BF3zRMcU.cjs.map +0 -1
- package/dist/TagsInput-D0O6z6le.js.map +0 -1
- package/dist/_plugin-vue_export-helper-DM9IkUGy.cjs +0 -10
- package/dist/_plugin-vue_export-helper-DM9IkUGy.cjs.map +0 -1
- package/dist/components/core/Accordion.stories.d.ts +0 -11
- package/dist/components/core/Accordion.test.d.ts +0 -1
- package/dist/components/core/Accordion.vue.d.ts +0 -27
- package/dist/components/core/AccordionItem.stories.d.ts +0 -10
- package/dist/components/core/AccordionItem.vue.d.ts +0 -29
- package/dist/components/core/AutocompleteComponent.stories.d.ts +0 -14
- package/dist/components/core/AutocompleteComponent.test.d.ts +0 -1
- package/dist/components/core/AutocompleteComponent.vue.d.ts +0 -25
- package/dist/components/core/Avatar.stories.d.ts +0 -12
- package/dist/components/core/Avatar.test.d.ts +0 -1
- package/dist/components/core/Avatar.vue.d.ts +0 -20
- package/dist/components/core/Breadcrumb.stories.d.ts +0 -11
- package/dist/components/core/Breadcrumb.test.d.ts +0 -1
- package/dist/components/core/Breadcrumb.vue.d.ts +0 -26
- package/dist/components/core/Button.stories.d.ts +0 -18
- package/dist/components/core/Button.test.d.ts +0 -1
- package/dist/components/core/Button.vue.d.ts +0 -49
- package/dist/components/core/CardComponent.stories.d.ts +0 -13
- package/dist/components/core/CardComponent.test.d.ts +0 -1
- package/dist/components/core/CardComponent.vue.d.ts +0 -40
- package/dist/components/core/CollapsibleCard.stories.d.ts +0 -10
- package/dist/components/core/CollapsibleCard.test.d.ts +0 -1
- package/dist/components/core/CollapsibleCard.vue.d.ts +0 -38
- package/dist/components/core/DarkModeToggle.stories.d.ts +0 -15
- package/dist/components/core/DarkModeToggle.test.d.ts +0 -1
- package/dist/components/core/DarkModeToggle.vue.d.ts +0 -21
- package/dist/components/core/Drawer.stories.d.ts +0 -12
- package/dist/components/core/Drawer.test.d.ts +0 -1
- package/dist/components/core/Drawer.vue.d.ts +0 -50
- package/dist/components/core/Dropdown.stories.d.ts +0 -11
- package/dist/components/core/Dropdown.test.d.ts +0 -1
- package/dist/components/core/Dropdown.vue.d.ts +0 -56
- package/dist/components/core/FilterTabs.stories.d.ts +0 -14
- package/dist/components/core/FilterTabs.test.d.ts +0 -1
- package/dist/components/core/FilterTabs.vue.d.ts +0 -29
- package/dist/components/core/MenuItem.stories.d.ts +0 -13
- package/dist/components/core/MenuItem.test.d.ts +0 -1
- package/dist/components/core/MenuItem.vue.d.ts +0 -16
- package/dist/components/core/MobileList.stories.d.ts +0 -13
- package/dist/components/core/MobileList.test.d.ts +0 -1
- package/dist/components/core/MobileList.vue.d.ts +0 -86
- package/dist/components/core/Popover.stories.d.ts +0 -10
- package/dist/components/core/Popover.test.d.ts +0 -1
- package/dist/components/core/Popover.vue.d.ts +0 -44
- package/dist/components/core/ResponsiveList.stories.d.ts +0 -15
- package/dist/components/core/ResponsiveList.test.d.ts +0 -1
- package/dist/components/core/ResponsiveList.vue.d.ts +0 -128
- package/dist/components/core/StatsCard.stories.d.ts +0 -15
- package/dist/components/core/StatsCard.test.d.ts +0 -1
- package/dist/components/core/StatsCard.vue.d.ts +0 -44
- package/dist/components/core/StatsGrid.stories.d.ts +0 -12
- package/dist/components/core/StatsGrid.test.d.ts +0 -1
- package/dist/components/core/StatsGrid.vue.d.ts +0 -16
- package/dist/components/core/StatusBadge.stories.d.ts +0 -13
- package/dist/components/core/StatusBadge.test.d.ts +0 -1
- package/dist/components/core/StatusBadge.vue.d.ts +0 -21
- package/dist/components/core/Stepper.stories.d.ts +0 -12
- package/dist/components/core/Stepper.test.d.ts +0 -1
- package/dist/components/core/Stepper.vue.d.ts +0 -22
- package/dist/components/core/TabPanel.stories.d.ts +0 -8
- package/dist/components/core/TabPanel.test.d.ts +0 -1
- package/dist/components/core/TabPanel.vue.d.ts +0 -21
- package/dist/components/core/TableAction.stories.d.ts +0 -14
- package/dist/components/core/TableAction.test.d.ts +0 -1
- package/dist/components/core/TableAction.vue.d.ts +0 -8
- package/dist/components/core/TableComponent.stories.d.ts +0 -16
- package/dist/components/core/TableComponent.test.d.ts +0 -1
- package/dist/components/core/TableComponent.vue.d.ts +0 -67
- package/dist/components/core/Tabs.stories.d.ts +0 -10
- package/dist/components/core/Tabs.test.d.ts +0 -1
- package/dist/components/core/Tabs.vue.d.ts +0 -39
- package/dist/components/core/Timeline.stories.d.ts +0 -11
- package/dist/components/core/Timeline.test.d.ts +0 -1
- package/dist/components/core/Timeline.vue.d.ts +0 -34
- package/dist/components/core/Tooltip.stories.d.ts +0 -10
- package/dist/components/core/Tooltip.test.d.ts +0 -1
- package/dist/components/core/Tooltip.vue.d.ts +0 -34
- package/dist/components/core/index.cjs +0 -33
- package/dist/components/core/index.cjs.map +0 -1
- package/dist/components/core/index.test.d.ts +0 -1
- package/dist/components/feedback/Alert.stories.d.ts +0 -13
- package/dist/components/feedback/Alert.test.d.ts +0 -1
- package/dist/components/feedback/Alert.vue.d.ts +0 -34
- package/dist/components/feedback/CardSkeleton.stories.d.ts +0 -11
- package/dist/components/feedback/CardSkeleton.test.d.ts +0 -1
- package/dist/components/feedback/CardSkeleton.vue.d.ts +0 -14
- package/dist/components/feedback/ConfirmDialog.stories.d.ts +0 -12
- package/dist/components/feedback/ConfirmDialog.test.d.ts +0 -1
- package/dist/components/feedback/ConfirmDialog.vue.d.ts +0 -53
- package/dist/components/feedback/EmptyState.stories.d.ts +0 -13
- package/dist/components/feedback/EmptyState.test.d.ts +0 -1
- package/dist/components/feedback/EmptyState.vue.d.ts +0 -29
- package/dist/components/feedback/ListSkeleton.stories.d.ts +0 -12
- package/dist/components/feedback/ListSkeleton.test.d.ts +0 -1
- package/dist/components/feedback/ListSkeleton.vue.d.ts +0 -17
- package/dist/components/feedback/LoadingSpinner.stories.d.ts +0 -11
- package/dist/components/feedback/LoadingSpinner.test.d.ts +0 -1
- package/dist/components/feedback/LoadingSpinner.vue.d.ts +0 -12
- package/dist/components/feedback/Modal.stories.d.ts +0 -11
- package/dist/components/feedback/Modal.test.d.ts +0 -1
- package/dist/components/feedback/Modal.vue.d.ts +0 -47
- package/dist/components/feedback/NotificationComponent.stories.d.ts +0 -14
- package/dist/components/feedback/NotificationComponent.test.d.ts +0 -1
- package/dist/components/feedback/NotificationComponent.vue.d.ts +0 -12
- package/dist/components/feedback/NotificationList.stories.d.ts +0 -11
- package/dist/components/feedback/NotificationList.test.d.ts +0 -1
- package/dist/components/feedback/NotificationList.vue.d.ts +0 -18
- package/dist/components/feedback/PaginationControls.stories.d.ts +0 -12
- package/dist/components/feedback/PaginationControls.test.d.ts +0 -1
- package/dist/components/feedback/PaginationControls.vue.d.ts +0 -21
- package/dist/components/feedback/Progress.stories.d.ts +0 -14
- package/dist/components/feedback/Progress.test.d.ts +0 -1
- package/dist/components/feedback/Progress.vue.d.ts +0 -30
- package/dist/components/feedback/Skeleton.stories.d.ts +0 -15
- package/dist/components/feedback/Skeleton.test.d.ts +0 -1
- package/dist/components/feedback/Skeleton.vue.d.ts +0 -19
- package/dist/components/feedback/TableSkeleton.stories.d.ts +0 -12
- package/dist/components/feedback/TableSkeleton.test.d.ts +0 -1
- package/dist/components/feedback/TableSkeleton.vue.d.ts +0 -14
- package/dist/components/feedback/Toast.stories.d.ts +0 -12
- package/dist/components/feedback/Toast.test.d.ts +0 -1
- package/dist/components/feedback/Toast.vue.d.ts +0 -23
- package/dist/components/feedback/ToastContainer.stories.d.ts +0 -15
- package/dist/components/feedback/ToastContainer.test.d.ts +0 -1
- package/dist/components/feedback/ToastContainer.vue.d.ts +0 -24
- package/dist/components/feedback/index.cjs +0 -20
- package/dist/components/feedback/index.cjs.map +0 -1
- package/dist/components/feedback/index.test.d.ts +0 -1
- package/dist/components/form/Checkbox.stories.d.ts +0 -13
- package/dist/components/form/Checkbox.test.d.ts +0 -1
- package/dist/components/form/Checkbox.vue.d.ts +0 -22
- package/dist/components/form/ColorPicker.stories.d.ts +0 -12
- package/dist/components/form/ColorPicker.test.d.ts +0 -1
- package/dist/components/form/ColorPicker.vue.d.ts +0 -26
- package/dist/components/form/Combobox.stories.d.ts +0 -15
- package/dist/components/form/Combobox.test.d.ts +0 -1
- package/dist/components/form/Combobox.vue.d.ts +0 -46
- package/dist/components/form/DatePicker.stories.d.ts +0 -15
- package/dist/components/form/DatePicker.test.d.ts +0 -1
- package/dist/components/form/DatePicker.vue.d.ts +0 -36
- package/dist/components/form/EmailInput.stories.d.ts +0 -13
- package/dist/components/form/EmailInput.test.d.ts +0 -1
- package/dist/components/form/EmailInput.vue.d.ts +0 -32
- package/dist/components/form/FileUpload.stories.d.ts +0 -12
- package/dist/components/form/FileUpload.test.d.ts +0 -1
- package/dist/components/form/FileUpload.vue.d.ts +0 -40
- package/dist/components/form/FormActions.stories.d.ts +0 -18
- package/dist/components/form/FormActions.test.d.ts +0 -1
- package/dist/components/form/FormActions.vue.d.ts +0 -56
- package/dist/components/form/FormGroup.stories.d.ts +0 -10
- package/dist/components/form/FormGroup.test.d.ts +0 -1
- package/dist/components/form/FormGroup.vue.d.ts +0 -30
- package/dist/components/form/FormHelp.stories.d.ts +0 -11
- package/dist/components/form/FormHelp.test.d.ts +0 -1
- package/dist/components/form/FormHelp.vue.d.ts +0 -23
- package/dist/components/form/FormInput.stories.d.ts +0 -12
- package/dist/components/form/FormInput.test.d.ts +0 -1
- package/dist/components/form/FormInput.vue.d.ts +0 -13
- package/dist/components/form/FormLabel.stories.d.ts +0 -12
- package/dist/components/form/FormLabel.test.d.ts +0 -1
- package/dist/components/form/FormLabel.vue.d.ts +0 -21
- package/dist/components/form/FormSection.stories.d.ts +0 -13
- package/dist/components/form/FormSection.test.d.ts +0 -1
- package/dist/components/form/FormSection.vue.d.ts +0 -49
- package/dist/components/form/FormSelect.stories.d.ts +0 -13
- package/dist/components/form/FormSelect.test.d.ts +0 -1
- package/dist/components/form/FormSelect.vue.d.ts +0 -55
- package/dist/components/form/IconPicker.vue.d.ts +0 -33
- package/dist/components/form/InputWrapper.stories.d.ts +0 -16
- package/dist/components/form/InputWrapper.test.d.ts +0 -1
- package/dist/components/form/InputWrapper.vue.d.ts +0 -40
- package/dist/components/form/MoneyInput.stories.d.ts +0 -16
- package/dist/components/form/MoneyInput.test.d.ts +0 -1
- package/dist/components/form/MoneyInput.vue.d.ts +0 -40
- package/dist/components/form/NumberInput.stories.d.ts +0 -14
- package/dist/components/form/NumberInput.test.d.ts +0 -1
- package/dist/components/form/NumberInput.vue.d.ts +0 -39
- package/dist/components/form/OTPInput.stories.d.ts +0 -13
- package/dist/components/form/OTPInput.test.d.ts +0 -1
- package/dist/components/form/OTPInput.vue.d.ts +0 -33
- package/dist/components/form/PasswordInput.stories.d.ts +0 -15
- package/dist/components/form/PasswordInput.test.d.ts +0 -1
- package/dist/components/form/PasswordInput.vue.d.ts +0 -36
- package/dist/components/form/PercentInput.stories.d.ts +0 -12
- package/dist/components/form/PercentInput.test.d.ts +0 -1
- package/dist/components/form/PercentInput.vue.d.ts +0 -38
- package/dist/components/form/PhoneInput.stories.d.ts +0 -13
- package/dist/components/form/PhoneInput.test.d.ts +0 -1
- package/dist/components/form/PhoneInput.vue.d.ts +0 -89
- package/dist/components/form/QuantityInput.stories.d.ts +0 -12
- package/dist/components/form/QuantityInput.test.d.ts +0 -1
- package/dist/components/form/QuantityInput.vue.d.ts +0 -32
- package/dist/components/form/RangeSlider.stories.d.ts +0 -13
- package/dist/components/form/RangeSlider.test.d.ts +0 -1
- package/dist/components/form/RangeSlider.vue.d.ts +0 -35
- package/dist/components/form/Rating.stories.d.ts +0 -16
- package/dist/components/form/Rating.test.d.ts +0 -1
- package/dist/components/form/Rating.vue.d.ts +0 -43
- package/dist/components/form/SearchInput.stories.d.ts +0 -13
- package/dist/components/form/SearchInput.test.d.ts +0 -1
- package/dist/components/form/SearchInput.vue.d.ts +0 -26
- package/dist/components/form/Slider.stories.d.ts +0 -13
- package/dist/components/form/Slider.test.d.ts +0 -1
- package/dist/components/form/Slider.vue.d.ts +0 -29
- package/dist/components/form/Switch.stories.d.ts +0 -11
- package/dist/components/form/Switch.test.d.ts +0 -1
- package/dist/components/form/Switch.vue.d.ts +0 -23
- package/dist/components/form/TagsInput.stories.d.ts +0 -13
- package/dist/components/form/TagsInput.test.d.ts +0 -1
- package/dist/components/form/TagsInput.vue.d.ts +0 -37
- package/dist/components/form/URLInput.stories.d.ts +0 -11
- package/dist/components/form/URLInput.test.d.ts +0 -1
- package/dist/components/form/URLInput.vue.d.ts +0 -32
- package/dist/components/form/index.cjs +0 -34
- package/dist/components/form/index.cjs.map +0 -1
- package/dist/components/form/index.test.d.ts +0 -1
- package/dist/components/index.cjs +0 -91
- package/dist/components/index.cjs.map +0 -1
- package/dist/components/index.d.ts +0 -5
- package/dist/components/index.test.d.ts +0 -1
- package/dist/components/layout/AuthLayout.stories.d.ts +0 -10
- package/dist/components/layout/AuthLayout.test.d.ts +0 -1
- package/dist/components/layout/AuthLayout.vue.d.ts +0 -88
- package/dist/components/layout/BaseLayout.stories.d.ts +0 -11
- package/dist/components/layout/BaseLayout.test.d.ts +0 -1
- package/dist/components/layout/BaseLayout.vue.d.ts +0 -77
- package/dist/components/layout/PageHero.stories.d.ts +0 -11
- package/dist/components/layout/PageHero.test.d.ts +0 -1
- package/dist/components/layout/PageHero.vue.d.ts +0 -51
- package/dist/components/layout/PageLayout.stories.d.ts +0 -10
- package/dist/components/layout/PageLayout.test.d.ts +0 -1
- package/dist/components/layout/PageLayout.vue.d.ts +0 -37
- package/dist/components/layout/index.cjs +0 -8
- package/dist/components/layout/index.cjs.map +0 -1
- package/dist/components/layout/index.test.d.ts +0 -1
- package/dist/components/type/BadgeType.stories.d.ts +0 -13
- package/dist/components/type/BadgeType.test.d.ts +0 -1
- package/dist/components/type/BooleanType.stories.d.ts +0 -12
- package/dist/components/type/BooleanType.test.d.ts +0 -1
- package/dist/components/type/DateType.stories.d.ts +0 -12
- package/dist/components/type/DateType.test.d.ts +0 -1
- package/dist/components/type/NumberType.stories.d.ts +0 -11
- package/dist/components/type/NumberType.test.d.ts +0 -1
- package/dist/components/type/TextType.stories.d.ts +0 -10
- package/dist/components/type/TextType.test.d.ts +0 -1
- package/dist/components/type/index.cjs +0 -9
- package/dist/components/type/index.cjs.map +0 -1
- package/dist/components/type/index.test.d.ts +0 -1
- package/dist/composables/index.cjs +0 -19
- package/dist/composables/index.cjs.map +0 -1
- package/dist/composables/index.d.ts +0 -8
- package/dist/composables/index.test.d.ts +0 -1
- package/dist/composables/useDarkMode.d.ts +0 -14
- package/dist/composables/useDarkMode.test.d.ts +0 -1
- package/dist/composables/useDropdown.d.ts +0 -51
- package/dist/composables/useDropdown.test.d.ts +0 -1
- package/dist/composables/useExportCSV.d.ts +0 -10
- package/dist/composables/useExportCSV.test.d.ts +0 -1
- package/dist/composables/useFocusTrap.d.ts +0 -41
- package/dist/composables/useFocusTrap.test.d.ts +0 -1
- package/dist/composables/useId.d.ts +0 -42
- package/dist/composables/useId.test.d.ts +0 -1
- package/dist/composables/useModal.d.ts +0 -60
- package/dist/composables/useModal.test.d.ts +0 -1
- package/dist/composables/useNotifications.d.ts +0 -27
- package/dist/composables/useNotifications.test.d.ts +0 -1
- package/dist/composables/useToast.d.ts +0 -30
- package/dist/composables/useToast.test.d.ts +0 -1
- package/dist/index-D1x3TH9k.cjs +0 -401
- package/dist/index-D1x3TH9k.cjs.map +0 -1
- package/dist/index-D9_zMCpN.js.map +0 -1
- package/dist/index-PehFvNFG.cjs +0 -94
- package/dist/index-PehFvNFG.cjs.map +0 -1
- package/dist/index.cjs +0 -123
- package/dist/index.cjs.map +0 -1
- package/dist/index.d.ts +0 -5
- package/dist/index.test.d.ts +0 -1
- package/dist/plugin.d.ts +0 -24
- package/dist/style.css +0 -2
- package/dist/types/components.d.ts +0 -27
- package/dist/types/form.d.ts +0 -37
- package/dist/types/index.cjs +0 -2
- package/dist/types/index.cjs.map +0 -1
- package/dist/types/index.d.ts +0 -4
- package/dist/types/index.test.d.ts +0 -1
- package/dist/types/notification.d.ts +0 -12
- package/dist/types/property.d.ts +0 -34
- package/dist/useDarkMode-DLZcJEUQ.cjs +0 -52
- package/dist/useDarkMode-DLZcJEUQ.cjs.map +0 -1
- package/dist/useDropdown-DHFnd259.cjs +0 -130
- package/dist/useDropdown-DHFnd259.cjs.map +0 -1
- package/dist/useFocusTrap-kcxO8AeU.cjs +0 -119
- package/dist/useFocusTrap-kcxO8AeU.cjs.map +0 -1
- package/dist/useId-nxrBaIC9.cjs +0 -25
- package/dist/useId-nxrBaIC9.cjs.map +0 -1
- package/dist/useToast-Bk60GArg.cjs +0 -176
- package/dist/useToast-Bk60GArg.cjs.map +0 -1
|
@@ -1,145 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
const vue = require("vue");
|
|
3
|
-
const vue$1 = require("@iconify/vue");
|
|
4
|
-
const _sfc_main$5 = /* @__PURE__ */ vue.defineComponent({
|
|
5
|
-
__name: "TextType",
|
|
6
|
-
props: {
|
|
7
|
-
value: {}
|
|
8
|
-
},
|
|
9
|
-
setup(__props) {
|
|
10
|
-
return (_ctx, _cache) => {
|
|
11
|
-
return vue.openBlock(), vue.createElementBlock("span", null, vue.toDisplayString(__props.value ?? ""), 1);
|
|
12
|
-
};
|
|
13
|
-
}
|
|
14
|
-
});
|
|
15
|
-
const _sfc_main$4 = /* @__PURE__ */ vue.defineComponent({
|
|
16
|
-
__name: "NumberType",
|
|
17
|
-
props: {
|
|
18
|
-
value: {},
|
|
19
|
-
locale: { default: "en-US" }
|
|
20
|
-
},
|
|
21
|
-
setup(__props) {
|
|
22
|
-
const formattedValue = () => {
|
|
23
|
-
if (__props.value === null || __props.value === void 0) return "";
|
|
24
|
-
const num = Number(__props.value);
|
|
25
|
-
return isNaN(num) ? String(__props.value) : num.toLocaleString(__props.locale);
|
|
26
|
-
};
|
|
27
|
-
return (_ctx, _cache) => {
|
|
28
|
-
return vue.openBlock(), vue.createElementBlock("span", null, vue.toDisplayString(formattedValue()), 1);
|
|
29
|
-
};
|
|
30
|
-
}
|
|
31
|
-
});
|
|
32
|
-
const _sfc_main$3 = /* @__PURE__ */ vue.defineComponent({
|
|
33
|
-
__name: "DateType",
|
|
34
|
-
props: {
|
|
35
|
-
value: {},
|
|
36
|
-
format: { default: "date" },
|
|
37
|
-
locale: { default: "en-US" }
|
|
38
|
-
},
|
|
39
|
-
setup(__props) {
|
|
40
|
-
const formattedValue = () => {
|
|
41
|
-
if (!__props.value) return "";
|
|
42
|
-
try {
|
|
43
|
-
const date = new Date(String(__props.value));
|
|
44
|
-
if (isNaN(date.getTime())) return String(__props.value);
|
|
45
|
-
switch (__props.format) {
|
|
46
|
-
case "datetime":
|
|
47
|
-
return date.toLocaleString(__props.locale);
|
|
48
|
-
case "time":
|
|
49
|
-
return date.toLocaleTimeString(__props.locale);
|
|
50
|
-
default:
|
|
51
|
-
return date.toLocaleDateString(__props.locale);
|
|
52
|
-
}
|
|
53
|
-
} catch {
|
|
54
|
-
return "";
|
|
55
|
-
}
|
|
56
|
-
};
|
|
57
|
-
return (_ctx, _cache) => {
|
|
58
|
-
return vue.openBlock(), vue.createElementBlock("span", null, vue.toDisplayString(formattedValue()), 1);
|
|
59
|
-
};
|
|
60
|
-
}
|
|
61
|
-
});
|
|
62
|
-
const _hoisted_1 = { key: 1 };
|
|
63
|
-
const _sfc_main$2 = /* @__PURE__ */ vue.defineComponent({
|
|
64
|
-
__name: "BooleanType",
|
|
65
|
-
props: {
|
|
66
|
-
value: {},
|
|
67
|
-
display: { default: "text" },
|
|
68
|
-
trueLabel: { default: "Yes" },
|
|
69
|
-
falseLabel: { default: "No" }
|
|
70
|
-
},
|
|
71
|
-
setup(__props) {
|
|
72
|
-
const boolValue = Boolean(__props.value);
|
|
73
|
-
const label = boolValue ? __props.trueLabel : __props.falseLabel;
|
|
74
|
-
const icon = boolValue ? "lucide:check-circle" : "lucide:x-circle";
|
|
75
|
-
const colorClass = boolValue ? "text-green-600 dark:text-green-400" : "text-red-600 dark:text-red-400";
|
|
76
|
-
return (_ctx, _cache) => {
|
|
77
|
-
return vue.openBlock(), vue.createElementBlock("span", {
|
|
78
|
-
class: vue.normalizeClass([vue.unref(colorClass), "inline-flex items-center gap-1"])
|
|
79
|
-
}, [
|
|
80
|
-
__props.display === "icon" || __props.display === "both" ? (vue.openBlock(), vue.createBlock(vue.unref(vue$1.Icon), {
|
|
81
|
-
key: 0,
|
|
82
|
-
icon: vue.unref(icon),
|
|
83
|
-
class: "size-4"
|
|
84
|
-
}, null, 8, ["icon"])) : vue.createCommentVNode("", true),
|
|
85
|
-
__props.display === "text" || __props.display === "both" ? (vue.openBlock(), vue.createElementBlock("span", _hoisted_1, vue.toDisplayString(vue.unref(label)), 1)) : vue.createCommentVNode("", true)
|
|
86
|
-
], 2);
|
|
87
|
-
};
|
|
88
|
-
}
|
|
89
|
-
});
|
|
90
|
-
const _sfc_main$1 = /* @__PURE__ */ vue.defineComponent({
|
|
91
|
-
__name: "StatusBadge",
|
|
92
|
-
props: {
|
|
93
|
-
variant: { default: "default" }
|
|
94
|
-
},
|
|
95
|
-
setup(__props) {
|
|
96
|
-
const variantClasses = {
|
|
97
|
-
default: "bg-gray-100 text-gray-800 dark:bg-gray-700 dark:text-gray-200",
|
|
98
|
-
success: "bg-green-100 text-green-800 dark:bg-green-900/30 dark:text-green-400",
|
|
99
|
-
error: "bg-red-100 text-red-800 dark:bg-red-900/30 dark:text-red-400",
|
|
100
|
-
warning: "bg-yellow-100 text-yellow-800 dark:bg-yellow-900/30 dark:text-yellow-400",
|
|
101
|
-
info: "bg-blue-100 text-blue-800 dark:bg-blue-900/30 dark:text-blue-400",
|
|
102
|
-
blue: "bg-blue-100 text-blue-800 dark:bg-blue-900/30 dark:text-blue-400",
|
|
103
|
-
orange: "bg-orange-100 text-orange-800 dark:bg-orange-900/30 dark:text-orange-400",
|
|
104
|
-
green: "bg-green-100 text-green-800 dark:bg-green-900/30 dark:text-green-400",
|
|
105
|
-
red: "bg-red-100 text-red-800 dark:bg-red-900/30 dark:text-red-400",
|
|
106
|
-
yellow: "bg-yellow-100 text-yellow-800 dark:bg-yellow-900/30 dark:text-yellow-400",
|
|
107
|
-
purple: "bg-purple-100 text-purple-800 dark:bg-purple-900/30 dark:text-purple-400",
|
|
108
|
-
pink: "bg-pink-100 text-pink-800 dark:bg-pink-900/30 dark:text-pink-400",
|
|
109
|
-
gray: "bg-gray-100 text-gray-800 dark:bg-gray-700 dark:text-gray-200"
|
|
110
|
-
};
|
|
111
|
-
return (_ctx, _cache) => {
|
|
112
|
-
return vue.openBlock(), vue.createElementBlock("span", {
|
|
113
|
-
class: vue.normalizeClass([variantClasses[__props.variant], "inline-flex rounded-full px-2 py-1 text-xs font-semibold"])
|
|
114
|
-
}, [
|
|
115
|
-
vue.renderSlot(_ctx.$slots, "default")
|
|
116
|
-
], 2);
|
|
117
|
-
};
|
|
118
|
-
}
|
|
119
|
-
});
|
|
120
|
-
const _sfc_main = /* @__PURE__ */ vue.defineComponent({
|
|
121
|
-
__name: "BadgeType",
|
|
122
|
-
props: {
|
|
123
|
-
value: {},
|
|
124
|
-
variant: { default: "default" },
|
|
125
|
-
formatter: { type: Function }
|
|
126
|
-
},
|
|
127
|
-
setup(__props) {
|
|
128
|
-
const displayValue = __props.formatter ? __props.formatter(__props.value) : String(__props.value ?? "");
|
|
129
|
-
return (_ctx, _cache) => {
|
|
130
|
-
return vue.openBlock(), vue.createBlock(_sfc_main$1, { variant: __props.variant }, {
|
|
131
|
-
default: vue.withCtx(() => [
|
|
132
|
-
vue.createTextVNode(vue.toDisplayString(vue.unref(displayValue)), 1)
|
|
133
|
-
]),
|
|
134
|
-
_: 1
|
|
135
|
-
}, 8, ["variant"]);
|
|
136
|
-
};
|
|
137
|
-
}
|
|
138
|
-
});
|
|
139
|
-
exports._sfc_main = _sfc_main$1;
|
|
140
|
-
exports._sfc_main$1 = _sfc_main$5;
|
|
141
|
-
exports._sfc_main$2 = _sfc_main$4;
|
|
142
|
-
exports._sfc_main$3 = _sfc_main$3;
|
|
143
|
-
exports._sfc_main$4 = _sfc_main$2;
|
|
144
|
-
exports._sfc_main$5 = _sfc_main;
|
|
145
|
-
//# sourceMappingURL=BadgeType.vue_vue_type_script_setup_true_lang-zs0NXN4g.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"BadgeType.vue_vue_type_script_setup_true_lang-zs0NXN4g.cjs","sources":["../src/components/type/TextType.vue","../src/components/type/NumberType.vue","../src/components/type/DateType.vue","../src/components/type/BooleanType.vue","../src/components/core/StatusBadge.vue","../src/components/type/BadgeType.vue"],"sourcesContent":["<script lang=\"ts\" setup>\n/**\n * Text type component - default text rendering\n */\ndefineProps<{\n value: unknown\n}>()\n</script>\n\n<template>\n <span>{{ value ?? '' }}</span>\n</template>\n","<script lang=\"ts\" setup>\n/**\n * Number type component - formatted number display\n */\nconst { value, locale = 'en-US' } = defineProps<{\n value: unknown\n locale?: string\n}>()\n\nconst formattedValue = () => {\n if (value === null || value === undefined) return ''\n const num = Number(value)\n return isNaN(num) ? String(value) : num.toLocaleString(locale)\n}\n</script>\n\n<template>\n <span>{{ formattedValue() }}</span>\n</template>\n","<script lang=\"ts\" setup>\n/**\n * Date type component - formatted date display\n */\nconst { value, format = 'date', locale = 'en-US' } = defineProps<{\n value: unknown\n format?: 'date' | 'datetime' | 'time'\n locale?: string\n}>()\n\nconst formattedValue = () => {\n if (!value) return ''\n\n try {\n const date = new Date(String(value))\n if (isNaN(date.getTime())) return String(value)\n\n switch (format) {\n case 'datetime':\n return date.toLocaleString(locale)\n case 'time':\n return date.toLocaleTimeString(locale)\n default:\n return date.toLocaleDateString(locale)\n }\n } catch {\n return ''\n }\n}\n</script>\n\n<template>\n <span>{{ formattedValue() }}</span>\n</template>\n","<script lang=\"ts\" setup>\nimport { Icon } from '@iconify/vue'\n\n/**\n * Boolean type component - displays boolean as Yes/No with icons\n */\nconst {\n value,\n display = 'text',\n trueLabel = 'Yes',\n falseLabel = 'No',\n} = defineProps<{\n value: unknown\n display?: 'text' | 'icon' | 'both'\n trueLabel?: string\n falseLabel?: string\n}>()\n\nconst boolValue = Boolean(value)\nconst label = boolValue ? trueLabel : falseLabel\nconst icon = boolValue ? 'lucide:check-circle' : 'lucide:x-circle'\nconst colorClass = boolValue\n ? 'text-green-600 dark:text-green-400'\n : 'text-red-600 dark:text-red-400'\n</script>\n\n<template>\n <span\n :class=\"colorClass\"\n class=\"inline-flex items-center gap-1\"\n >\n <Icon\n v-if=\"display === 'icon' || display === 'both'\"\n :icon=\"icon\"\n class=\"size-4\"\n />\n <span v-if=\"display === 'text' || display === 'both'\">{{ label }}</span>\n </span>\n</template>\n","<script lang=\"ts\" setup>\nimport type { StatusBadgeVariant } from '@/types'\n\nconst { variant = 'default' } = defineProps<{\n variant?: StatusBadgeVariant\n}>()\n\nconst variantClasses: Record<StatusBadgeVariant, string> = {\n default: 'bg-gray-100 text-gray-800 dark:bg-gray-700 dark:text-gray-200',\n success: 'bg-green-100 text-green-800 dark:bg-green-900/30 dark:text-green-400',\n error: 'bg-red-100 text-red-800 dark:bg-red-900/30 dark:text-red-400',\n warning: 'bg-yellow-100 text-yellow-800 dark:bg-yellow-900/30 dark:text-yellow-400',\n info: 'bg-blue-100 text-blue-800 dark:bg-blue-900/30 dark:text-blue-400',\n blue: 'bg-blue-100 text-blue-800 dark:bg-blue-900/30 dark:text-blue-400',\n orange: 'bg-orange-100 text-orange-800 dark:bg-orange-900/30 dark:text-orange-400',\n green: 'bg-green-100 text-green-800 dark:bg-green-900/30 dark:text-green-400',\n red: 'bg-red-100 text-red-800 dark:bg-red-900/30 dark:text-red-400',\n yellow: 'bg-yellow-100 text-yellow-800 dark:bg-yellow-900/30 dark:text-yellow-400',\n purple: 'bg-purple-100 text-purple-800 dark:bg-purple-900/30 dark:text-purple-400',\n pink: 'bg-pink-100 text-pink-800 dark:bg-pink-900/30 dark:text-pink-400',\n gray: 'bg-gray-100 text-gray-800 dark:bg-gray-700 dark:text-gray-200',\n}\n</script>\n\n<template>\n <span\n :class=\"variantClasses[variant]\"\n class=\"inline-flex rounded-full px-2 py-1 text-xs font-semibold\"\n >\n <slot />\n </span>\n</template>\n","<script lang=\"ts\" setup>\nimport StatusBadge from '@/components/core/StatusBadge.vue'\nimport type { StatusBadgeVariant } from '@/types'\n\n/**\n * Badge type component - displays value as a badge\n */\nconst { value, variant = 'default', formatter } = defineProps<{\n value: unknown\n variant?: StatusBadgeVariant\n formatter?: (value: unknown) => string\n}>()\n\nconst displayValue = formatter ? formatter(value) : String(value ?? '')\n</script>\n\n<template>\n <StatusBadge :variant=\"variant\">\n {{ displayValue }}\n </StatusBadge>\n</template>\n"],"names":["_openBlock","_createElementBlock","_normalizeClass","_unref","_createBlock","Icon","_renderSlot","StatusBadge"],"mappings":";;;;;;;;;;AAUE,aAAAA,cAAA,GAAAC,uBAA8B,kCAArB,QAAA,SAAK,EAAA,GAAA,CAAA;AAAA;;;;;;;;;;ACDhB,UAAM,iBAAiB,MAAM;AAC3B,UAAI,QAAA,UAAU,QAAQ,QAAA,UAAU,OAAW,QAAO;AAClD,YAAM,MAAM,OAAO,QAAA,KAAK;AACxB,aAAO,MAAM,GAAG,IAAI,OAAO,QAAA,KAAK,IAAI,IAAI,eAAe,QAAA,MAAM;AAAA,IAC/D;;AAIE,aAAAD,IAAAA,UAAA,GAAAC,IAAAA,mBAAmC,kCAA1B,gBAAc,GAAA,CAAA;AAAA;;;;;;;;;;;ACPzB,UAAM,iBAAiB,MAAM;AAC3B,UAAI,CAAC,QAAA,MAAO,QAAO;AAEnB,UAAI;AACF,cAAM,OAAO,IAAI,KAAK,OAAO,aAAK,CAAC;AACnC,YAAI,MAAM,KAAK,QAAA,CAAS,EAAG,QAAO,OAAO,QAAA,KAAK;AAE9C,gBAAQ,QAAA,QAAA;AAAA,UACN,KAAK;AACH,mBAAO,KAAK,eAAe,QAAA,MAAM;AAAA,UACnC,KAAK;AACH,mBAAO,KAAK,mBAAmB,QAAA,MAAM;AAAA,UACvC;AACE,mBAAO,KAAK,mBAAmB,QAAA,MAAM;AAAA,QAAA;AAAA,MAE3C,QAAQ;AACN,eAAO;AAAA,MACT;AAAA,IACF;;AAIE,aAAAD,IAAAA,UAAA,GAAAC,IAAAA,mBAAmC,kCAA1B,gBAAc,GAAA,CAAA;AAAA;;;;;;;;;;;;;ACdzB,UAAM,YAAY,QAAQ,QAAA,KAAK;AAC/B,UAAM,QAAQ,YAAY,QAAA,YAAY,QAAA;AACtC,UAAM,OAAO,YAAY,wBAAwB;AACjD,UAAM,aAAa,YACf,uCACA;;8BAIFA,IAAAA,mBAUO,QAAA;AAAA,QATJ,OAAKC,IAAAA,eAAA,CAAEC,IAAAA,MAAA,UAAA,GACF,gCAAgC,CAAA;AAAA,MAAA;QAG9B,QAAA,sBAAsB,QAAA,YAAO,2BADrCC,IAAAA,YAIED,IAAAA,MAAAE,MAAAA,IAAA,GAAA;AAAA;UAFC,MAAMF,IAAAA,MAAA,IAAA;AAAA,UACP,OAAM;AAAA,QAAA;QAEI,QAAA,sBAAsB,QAAA,YAAO,UAAzCH,IAAAA,UAAA,GAAAC,uBAAwE,wCAAfE,IAAAA,MAAA,KAAA,CAAK,GAAA,CAAA;;;;;;;;;;;AC7BlE,UAAM,iBAAqD;AAAA,MACzD,SAAS;AAAA,MACT,SAAS;AAAA,MACT,OAAO;AAAA,MACP,SAAS;AAAA,MACT,MAAM;AAAA,MACN,MAAM;AAAA,MACN,QAAQ;AAAA,MACR,OAAO;AAAA,MACP,KAAK;AAAA,MACL,QAAQ;AAAA,MACR,QAAQ;AAAA,MACR,MAAM;AAAA,MACN,MAAM;AAAA,IAAA;;8BAKNF,IAAAA,mBAKO,QAAA;AAAA,QAJJ,OAAKC,IAAAA,eAAA,CAAE,eAAe,QAAA,OAAO,GACxB,0DAA0D,CAAA;AAAA,MAAA;QAEhEI,eAAQ,KAAA,QAAA,SAAA;AAAA,MAAA;;;;;;;;;;;;AChBZ,UAAM,eAAe,QAAA,YAAY,QAAA,UAAU,QAAA,KAAK,IAAI,OAAO,QAAA,SAAS,EAAE;;8BAIpEF,gBAEcG,aAAA,EAFA,SAAS,QAAA,WAAO;AAAA,6BAC5B,MAAkB;AAAA,kDAAfJ,IAAAA,MAAA,YAAA,CAAY,GAAA,CAAA;AAAA,QAAA;;;;;;;;;;;;"}
|
|
@@ -1,98 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
const vue = require("vue");
|
|
3
|
-
const vue$1 = require("@iconify/vue");
|
|
4
|
-
const _sfc_main = /* @__PURE__ */ vue.defineComponent({
|
|
5
|
-
__name: "Button",
|
|
6
|
-
props: {
|
|
7
|
-
variant: { default: "primary" },
|
|
8
|
-
size: { default: "md" },
|
|
9
|
-
icon: {},
|
|
10
|
-
iconRight: {},
|
|
11
|
-
loading: { type: Boolean },
|
|
12
|
-
disabled: { type: Boolean },
|
|
13
|
-
block: { type: Boolean },
|
|
14
|
-
href: {},
|
|
15
|
-
to: {},
|
|
16
|
-
type: { default: "button" }
|
|
17
|
-
},
|
|
18
|
-
emits: ["click"],
|
|
19
|
-
setup(__props, { emit: __emit }) {
|
|
20
|
-
const props = __props;
|
|
21
|
-
const emit = __emit;
|
|
22
|
-
const variantClasses = {
|
|
23
|
-
primary: "bg-primary text-primary-foreground hover:bg-primary/90 focus:ring-primary",
|
|
24
|
-
secondary: "bg-secondary text-secondary-foreground hover:bg-secondary/90 focus:ring-secondary",
|
|
25
|
-
outline: "border border-gray-300 bg-transparent text-gray-700 hover:bg-gray-50 focus:ring-primary dark:border-gray-600 dark:text-gray-300 dark:hover:bg-gray-800",
|
|
26
|
-
ghost: "bg-transparent text-gray-700 hover:bg-gray-100 focus:ring-primary dark:text-gray-300 dark:hover:bg-gray-800",
|
|
27
|
-
danger: "bg-red-500 text-white hover:bg-red-600 focus:ring-red-500",
|
|
28
|
-
success: "bg-green-500 text-white hover:bg-green-600 focus:ring-green-500"
|
|
29
|
-
};
|
|
30
|
-
const sizeClasses = {
|
|
31
|
-
xs: "px-2 py-1 text-xs gap-1",
|
|
32
|
-
sm: "px-3 py-1.5 text-sm gap-1.5",
|
|
33
|
-
md: "px-4 py-2 text-sm gap-2",
|
|
34
|
-
lg: "px-5 py-2.5 text-base gap-2",
|
|
35
|
-
xl: "px-6 py-3 text-lg gap-2.5"
|
|
36
|
-
};
|
|
37
|
-
const iconSizeClasses = {
|
|
38
|
-
xs: "size-3",
|
|
39
|
-
sm: "size-4",
|
|
40
|
-
md: "size-4",
|
|
41
|
-
lg: "size-5",
|
|
42
|
-
xl: "size-6"
|
|
43
|
-
};
|
|
44
|
-
const classes = vue.computed(() => [
|
|
45
|
-
"inline-flex items-center justify-center font-medium rounded-lg transition-colors focus:outline-hidden focus:ring-2 focus:ring-offset-2 disabled:opacity-50 disabled:cursor-not-allowed",
|
|
46
|
-
variantClasses[props.variant],
|
|
47
|
-
sizeClasses[props.size],
|
|
48
|
-
props.block && "w-full"
|
|
49
|
-
]);
|
|
50
|
-
const component = vue.computed(() => {
|
|
51
|
-
if (props.to) {
|
|
52
|
-
try {
|
|
53
|
-
const RouterLink = vue.resolveComponent("RouterLink");
|
|
54
|
-
if (typeof RouterLink !== "string") return RouterLink;
|
|
55
|
-
} catch {
|
|
56
|
-
}
|
|
57
|
-
}
|
|
58
|
-
if (props.href) return "a";
|
|
59
|
-
return "button";
|
|
60
|
-
});
|
|
61
|
-
const componentProps = vue.computed(() => {
|
|
62
|
-
if (props.to) return { to: props.to };
|
|
63
|
-
if (props.href) return { href: props.href };
|
|
64
|
-
return { type: props.type, disabled: props.disabled || props.loading };
|
|
65
|
-
});
|
|
66
|
-
const handleClick = (event) => {
|
|
67
|
-
if (props.disabled || props.loading) return;
|
|
68
|
-
emit("click", event);
|
|
69
|
-
};
|
|
70
|
-
return (_ctx, _cache) => {
|
|
71
|
-
return vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(component.value), vue.mergeProps(componentProps.value, {
|
|
72
|
-
class: classes.value,
|
|
73
|
-
onClick: handleClick
|
|
74
|
-
}), {
|
|
75
|
-
default: vue.withCtx(() => [
|
|
76
|
-
__props.loading ? (vue.openBlock(), vue.createBlock(vue.unref(vue$1.Icon), {
|
|
77
|
-
key: 0,
|
|
78
|
-
icon: "lucide:loader-2",
|
|
79
|
-
class: vue.normalizeClass([iconSizeClasses[__props.size], "animate-spin"])
|
|
80
|
-
}, null, 8, ["class"])) : __props.icon ? (vue.openBlock(), vue.createBlock(vue.unref(vue$1.Icon), {
|
|
81
|
-
key: 1,
|
|
82
|
-
icon: __props.icon,
|
|
83
|
-
class: vue.normalizeClass(iconSizeClasses[__props.size])
|
|
84
|
-
}, null, 8, ["icon", "class"])) : vue.createCommentVNode("", true),
|
|
85
|
-
vue.renderSlot(_ctx.$slots, "default"),
|
|
86
|
-
__props.iconRight && !__props.loading ? (vue.openBlock(), vue.createBlock(vue.unref(vue$1.Icon), {
|
|
87
|
-
key: 2,
|
|
88
|
-
icon: __props.iconRight,
|
|
89
|
-
class: vue.normalizeClass(iconSizeClasses[__props.size])
|
|
90
|
-
}, null, 8, ["icon", "class"])) : vue.createCommentVNode("", true)
|
|
91
|
-
]),
|
|
92
|
-
_: 3
|
|
93
|
-
}, 16, ["class"]);
|
|
94
|
-
};
|
|
95
|
-
}
|
|
96
|
-
});
|
|
97
|
-
exports._sfc_main = _sfc_main;
|
|
98
|
-
//# sourceMappingURL=Button.vue_vue_type_script_setup_true_lang-CXRj7LEP.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Button.vue_vue_type_script_setup_true_lang-CXRj7LEP.cjs","sources":["../src/components/core/Button.vue"],"sourcesContent":["<script lang=\"ts\" setup>\nimport { computed, resolveComponent } from 'vue'\nimport { Icon } from '@iconify/vue'\n\nexport type ButtonVariant = 'primary' | 'secondary' | 'outline' | 'ghost' | 'danger' | 'success'\nexport type ButtonSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl'\n\nconst props = withDefaults(\n defineProps<{\n /** Button variant */\n variant?: ButtonVariant\n /** Button size */\n size?: ButtonSize\n /** Icon to show (left side) */\n icon?: string\n /** Icon on right side */\n iconRight?: string\n /** Loading state */\n loading?: boolean\n /** Disabled state */\n disabled?: boolean\n /** Full width */\n block?: boolean\n /** Link href (renders as <a>) */\n href?: string\n /** Router link (renders as RouterLink) */\n to?: string\n /** Button type */\n type?: 'button' | 'submit' | 'reset'\n }>(),\n {\n variant: 'primary',\n size: 'md',\n type: 'button',\n },\n)\n\nconst emit = defineEmits<{\n click: [event: MouseEvent]\n}>()\n\nconst variantClasses: Record<ButtonVariant, string> = {\n primary: 'bg-primary text-primary-foreground hover:bg-primary/90 focus:ring-primary',\n secondary: 'bg-secondary text-secondary-foreground hover:bg-secondary/90 focus:ring-secondary',\n outline: 'border border-gray-300 bg-transparent text-gray-700 hover:bg-gray-50 focus:ring-primary dark:border-gray-600 dark:text-gray-300 dark:hover:bg-gray-800',\n ghost: 'bg-transparent text-gray-700 hover:bg-gray-100 focus:ring-primary dark:text-gray-300 dark:hover:bg-gray-800',\n danger: 'bg-red-500 text-white hover:bg-red-600 focus:ring-red-500',\n success: 'bg-green-500 text-white hover:bg-green-600 focus:ring-green-500',\n}\n\nconst sizeClasses: Record<ButtonSize, string> = {\n xs: 'px-2 py-1 text-xs gap-1',\n sm: 'px-3 py-1.5 text-sm gap-1.5',\n md: 'px-4 py-2 text-sm gap-2',\n lg: 'px-5 py-2.5 text-base gap-2',\n xl: 'px-6 py-3 text-lg gap-2.5',\n}\n\nconst iconSizeClasses: Record<ButtonSize, string> = {\n xs: 'size-3',\n sm: 'size-4',\n md: 'size-4',\n lg: 'size-5',\n xl: 'size-6',\n}\n\nconst classes = computed(() => [\n 'inline-flex items-center justify-center font-medium rounded-lg transition-colors focus:outline-hidden focus:ring-2 focus:ring-offset-2 disabled:opacity-50 disabled:cursor-not-allowed',\n variantClasses[props.variant],\n sizeClasses[props.size],\n props.block && 'w-full',\n])\n\nconst component = computed(() => {\n if (props.to) {\n try {\n const RouterLink = resolveComponent('RouterLink')\n if (typeof RouterLink !== 'string') return RouterLink\n } catch {\n // RouterLink not available\n }\n }\n if (props.href) return 'a'\n return 'button'\n})\n\nconst componentProps = computed(() => {\n if (props.to) return { to: props.to }\n if (props.href) return { href: props.href }\n return { type: props.type, disabled: props.disabled || props.loading }\n})\n\nconst handleClick = (event: MouseEvent) => {\n if (props.disabled || props.loading) return\n emit('click', event)\n}\n</script>\n\n<template>\n <component\n :is=\"component\"\n v-bind=\"componentProps\"\n :class=\"classes\"\n @click=\"handleClick\"\n >\n <Icon\n v-if=\"loading\"\n icon=\"lucide:loader-2\"\n :class=\"[iconSizeClasses[size], 'animate-spin']\"\n />\n <Icon\n v-else-if=\"icon\"\n :icon=\"icon\"\n :class=\"iconSizeClasses[size]\"\n />\n <slot />\n <Icon\n v-if=\"iconRight && !loading\"\n :icon=\"iconRight\"\n :class=\"iconSizeClasses[size]\"\n />\n </component>\n</template>\n"],"names":["computed","resolveComponent","_openBlock","_createBlock","_resolveDynamicComponent","_mergeProps","_unref","Icon","_normalizeClass","_renderSlot"],"mappings":";;;;;;;;;;;;;;;;;;;AAOA,UAAM,QAAQ;AA8Bd,UAAM,OAAO;AAIb,UAAM,iBAAgD;AAAA,MACpD,SAAS;AAAA,MACT,WAAW;AAAA,MACX,SAAS;AAAA,MACT,OAAO;AAAA,MACP,QAAQ;AAAA,MACR,SAAS;AAAA,IAAA;AAGX,UAAM,cAA0C;AAAA,MAC9C,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,IAAA;AAGN,UAAM,kBAA8C;AAAA,MAClD,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,MACJ,IAAI;AAAA,IAAA;AAGN,UAAM,UAAUA,IAAAA,SAAS,MAAM;AAAA,MAC7B;AAAA,MACA,eAAe,MAAM,OAAO;AAAA,MAC5B,YAAY,MAAM,IAAI;AAAA,MACtB,MAAM,SAAS;AAAA,IAAA,CAChB;AAED,UAAM,YAAYA,IAAAA,SAAS,MAAM;AAC/B,UAAI,MAAM,IAAI;AACZ,YAAI;AACF,gBAAM,aAAaC,IAAAA,iBAAiB,YAAY;AAChD,cAAI,OAAO,eAAe,SAAU,QAAO;AAAA,QAC7C,QAAQ;AAAA,QAER;AAAA,MACF;AACA,UAAI,MAAM,KAAM,QAAO;AACvB,aAAO;AAAA,IACT,CAAC;AAED,UAAM,iBAAiBD,IAAAA,SAAS,MAAM;AACpC,UAAI,MAAM,GAAI,QAAO,EAAE,IAAI,MAAM,GAAA;AACjC,UAAI,MAAM,KAAM,QAAO,EAAE,MAAM,MAAM,KAAA;AACrC,aAAO,EAAE,MAAM,MAAM,MAAM,UAAU,MAAM,YAAY,MAAM,QAAA;AAAA,IAC/D,CAAC;AAED,UAAM,cAAc,CAAC,UAAsB;AACzC,UAAI,MAAM,YAAY,MAAM,QAAS;AACrC,WAAK,SAAS,KAAK;AAAA,IACrB;;AAIE,aAAAE,IAAAA,UAAA,GAAAC,IAAAA,YAsBYC,4BArBL,UAAA,KAAS,GADhBC,IAAAA,WAEU,eAoBE,OApBY;AAAA,QACrB,OAAO,QAAA;AAAA,QACP,SAAO;AAAA,MAAA;6BAER,MAIE;AAAA,UAHM,QAAA,4BADRF,IAAAA,YAIEG,IAAAA,MAAAC,MAAAA,IAAA,GAAA;AAAA;YAFA,MAAK;AAAA,YACJ,OAAKC,IAAAA,eAAA,CAAG,gBAAgB,QAAA,IAAI,GAAA,cAAA,CAAA;AAAA,UAAA,0BAGlB,QAAA,yBADbL,IAAAA,YAIEG,IAAAA,MAAAC,MAAAA,IAAA,GAAA;AAAA;YAFC,MAAM,QAAA;AAAA,YACN,OAAKC,IAAAA,eAAE,gBAAgB,QAAA,IAAI,CAAA;AAAA,UAAA;UAE9BC,eAAQ,KAAA,QAAA,SAAA;AAAA,UAEA,QAAA,cAAc,QAAA,4BADtBN,IAAAA,YAIEG,UAAAC,MAAAA,IAAA,GAAA;AAAA;YAFC,MAAM,QAAA;AAAA,YACN,OAAKC,IAAAA,eAAE,gBAAgB,QAAA,IAAI,CAAA;AAAA,UAAA;;;;;;;;"}
|