@shipfox/react-ui 0.2.0 → 0.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.storybook/preview.tsx +1 -1
- package/.turbo/turbo-build.log +2 -2
- package/.turbo/turbo-check.log +3 -3
- package/.turbo/turbo-type.log +1 -1
- package/CHANGELOG.md +17 -0
- package/dist/components/alert/alert.d.ts +18 -0
- package/dist/components/alert/alert.d.ts.map +1 -0
- package/dist/components/alert/alert.js +123 -0
- package/dist/components/alert/alert.js.map +1 -0
- package/dist/components/alert/alert.stories.js +112 -0
- package/dist/components/alert/alert.stories.js.map +1 -0
- package/dist/components/alert/index.d.ts +2 -0
- package/dist/components/alert/index.d.ts.map +1 -0
- package/dist/components/alert/index.js +3 -0
- package/dist/components/alert/index.js.map +1 -0
- package/dist/components/avatar/avatar-group.d.ts +18 -0
- package/dist/components/avatar/avatar-group.d.ts.map +1 -0
- package/dist/components/avatar/avatar-group.js +132 -0
- package/dist/components/avatar/avatar-group.js.map +1 -0
- package/dist/components/avatar/avatar.d.ts +24 -0
- package/dist/components/avatar/avatar.d.ts.map +1 -0
- package/dist/components/avatar/avatar.js +165 -0
- package/dist/components/avatar/avatar.js.map +1 -0
- package/dist/components/avatar/avatar.stories.js +267 -0
- package/dist/components/avatar/avatar.stories.js.map +1 -0
- package/dist/components/avatar/index.d.ts +3 -0
- package/dist/components/avatar/index.d.ts.map +1 -0
- package/dist/components/avatar/index.js +4 -0
- package/dist/components/avatar/index.js.map +1 -0
- package/dist/components/badge/badge.d.ts +48 -0
- package/dist/components/badge/badge.d.ts.map +1 -0
- package/dist/components/badge/badge.js +72 -0
- package/dist/components/badge/badge.js.map +1 -0
- package/dist/components/badge/badge.stories.js +802 -0
- package/dist/components/badge/badge.stories.js.map +1 -0
- package/dist/components/badge/icon-badge.d.ts +9 -0
- package/dist/components/badge/icon-badge.d.ts.map +1 -0
- package/dist/components/badge/icon-badge.js +32 -0
- package/dist/components/badge/icon-badge.js.map +1 -0
- package/dist/components/badge/index.d.ts +5 -0
- package/dist/components/badge/index.d.ts.map +1 -0
- package/dist/components/badge/index.js +6 -0
- package/dist/components/badge/index.js.map +1 -0
- package/dist/components/badge/status-badge.d.ts +9 -0
- package/dist/components/badge/status-badge.d.ts.map +1 -0
- package/dist/components/badge/status-badge.js +29 -0
- package/dist/components/badge/status-badge.js.map +1 -0
- package/dist/components/badge/user-badge.d.ts +8 -0
- package/dist/components/badge/user-badge.d.ts.map +1 -0
- package/dist/components/badge/user-badge.js +24 -0
- package/dist/components/badge/user-badge.js.map +1 -0
- package/dist/components/{button.d.ts → button/button.d.ts} +1 -1
- package/dist/components/button/button.d.ts.map +1 -0
- package/dist/components/{button.js → button/button.js} +2 -2
- package/dist/components/button/button.js.map +1 -0
- package/dist/components/{button.stories.js → button/button.stories.js} +1 -1
- package/dist/components/button/button.stories.js.map +1 -0
- package/dist/components/button/index.d.ts +2 -0
- package/dist/components/button/index.d.ts.map +1 -0
- package/dist/components/button/index.js +3 -0
- package/dist/components/button/index.js.map +1 -0
- package/dist/components/checkbox/checkbox-label.d.ts +14 -0
- package/dist/components/checkbox/checkbox-label.d.ts.map +1 -0
- package/dist/components/checkbox/checkbox-label.js +82 -0
- package/dist/components/checkbox/checkbox-label.js.map +1 -0
- package/dist/components/checkbox/checkbox-links.d.ts +18 -0
- package/dist/components/checkbox/checkbox-links.d.ts.map +1 -0
- package/dist/components/checkbox/checkbox-links.js +58 -0
- package/dist/components/checkbox/checkbox-links.js.map +1 -0
- package/dist/components/checkbox/checkbox.d.ts +9 -0
- package/dist/components/checkbox/checkbox.d.ts.map +1 -0
- package/dist/components/checkbox/checkbox.js +49 -0
- package/dist/components/checkbox/checkbox.js.map +1 -0
- package/dist/components/checkbox/checkbox.stories.js +566 -0
- package/dist/components/checkbox/checkbox.stories.js.map +1 -0
- package/dist/components/checkbox/index.d.ts +4 -0
- package/dist/components/checkbox/index.d.ts.map +1 -0
- package/dist/components/checkbox/index.js +5 -0
- package/dist/components/checkbox/index.js.map +1 -0
- package/dist/components/code-block/code-block-footer.d.ts +26 -0
- package/dist/components/code-block/code-block-footer.d.ts.map +1 -0
- package/dist/components/code-block/code-block-footer.js +86 -0
- package/dist/components/code-block/code-block-footer.js.map +1 -0
- package/dist/components/code-block/code-block.d.ts +50 -0
- package/dist/components/code-block/code-block.d.ts.map +1 -0
- package/dist/components/code-block/code-block.js +142 -0
- package/dist/components/code-block/code-block.js.map +1 -0
- package/dist/components/code-block/code-block.stories.js +341 -0
- package/dist/components/code-block/code-block.stories.js.map +1 -0
- package/dist/components/code-block/code-content.d.ts +11 -0
- package/dist/components/code-block/code-content.d.ts.map +1 -0
- package/dist/components/code-block/code-content.js +29 -0
- package/dist/components/code-block/code-content.js.map +1 -0
- package/dist/components/code-block/code-copy-button.d.ts +11 -0
- package/dist/components/code-block/code-copy-button.d.ts.map +1 -0
- package/dist/components/code-block/code-copy-button.js +49 -0
- package/dist/components/code-block/code-copy-button.js.map +1 -0
- package/dist/components/code-block/code-tabs.d.ts +16 -0
- package/dist/components/code-block/code-tabs.d.ts.map +1 -0
- package/dist/components/code-block/code-tabs.js +98 -0
- package/dist/components/code-block/code-tabs.js.map +1 -0
- package/dist/components/code-block/index.d.ts +4 -0
- package/dist/components/code-block/index.d.ts.map +1 -0
- package/dist/components/code-block/index.js +5 -0
- package/dist/components/code-block/index.js.map +1 -0
- package/dist/components/dynamic-item/dynamic-item.d.ts +13 -0
- package/dist/components/dynamic-item/dynamic-item.d.ts.map +1 -0
- package/dist/components/dynamic-item/dynamic-item.js +43 -0
- package/dist/components/dynamic-item/dynamic-item.js.map +1 -0
- package/dist/components/dynamic-item/dynamic-item.stories.js +375 -0
- package/dist/components/dynamic-item/dynamic-item.stories.js.map +1 -0
- package/dist/components/dynamic-item/index.d.ts +2 -0
- package/dist/components/dynamic-item/index.d.ts.map +1 -0
- package/dist/components/dynamic-item/index.js +3 -0
- package/dist/components/dynamic-item/index.js.map +1 -0
- package/dist/components/icon/custom/index.d.ts +3 -0
- package/dist/components/icon/custom/index.d.ts.map +1 -1
- package/dist/components/icon/custom/index.js +3 -0
- package/dist/components/icon/custom/index.js.map +1 -1
- package/dist/components/icon/custom/shipfox-logo.d.ts +8 -0
- package/dist/components/icon/custom/shipfox-logo.d.ts.map +1 -0
- package/dist/components/icon/custom/shipfox-logo.js +22 -0
- package/dist/components/icon/custom/shipfox-logo.js.map +1 -0
- package/dist/components/icon/custom/slack-logo.d.ts +6 -0
- package/dist/components/icon/custom/slack-logo.d.ts.map +1 -0
- package/dist/components/icon/custom/slack-logo.js +34 -0
- package/dist/components/icon/custom/slack-logo.js.map +1 -0
- package/dist/components/icon/custom/stripe-logo.d.ts +8 -0
- package/dist/components/icon/custom/stripe-logo.d.ts.map +1 -0
- package/dist/components/icon/custom/stripe-logo.js +24 -0
- package/dist/components/icon/custom/stripe-logo.js.map +1 -0
- package/dist/components/icon/icon.d.ts +13 -1
- package/dist/components/icon/icon.d.ts.map +1 -1
- package/dist/components/icon/icon.js +15 -3
- package/dist/components/icon/icon.js.map +1 -1
- package/dist/components/icon/icon.stories.js +6 -3
- package/dist/components/icon/icon.stories.js.map +1 -1
- package/dist/components/index.d.ts +12 -1
- package/dist/components/index.d.ts.map +1 -1
- package/dist/components/index.js +13 -2
- package/dist/components/index.js.map +1 -1
- package/dist/components/inline-tips/index.d.ts +2 -0
- package/dist/components/inline-tips/index.d.ts.map +1 -0
- package/dist/components/inline-tips/index.js +3 -0
- package/dist/components/inline-tips/index.js.map +1 -0
- package/dist/components/inline-tips/inline-tips.d.ts +19 -0
- package/dist/components/inline-tips/inline-tips.d.ts.map +1 -0
- package/dist/components/inline-tips/inline-tips.js +98 -0
- package/dist/components/inline-tips/inline-tips.js.map +1 -0
- package/dist/components/inline-tips/inline-tips.stories.js +214 -0
- package/dist/components/inline-tips/inline-tips.stories.js.map +1 -0
- package/dist/components/input/index.d.ts +2 -0
- package/dist/components/input/index.d.ts.map +1 -0
- package/dist/components/input/index.js +3 -0
- package/dist/components/input/index.js.map +1 -0
- package/dist/components/input/input.d.ts.map +1 -0
- package/dist/components/{input.js → input/input.js} +2 -2
- package/dist/components/input/input.js.map +1 -0
- package/dist/components/{input.stories.js → input/input.stories.js} +1 -1
- package/dist/components/input/input.stories.js.map +1 -0
- package/dist/components/item/index.d.ts +2 -0
- package/dist/components/item/index.d.ts.map +1 -0
- package/dist/components/item/index.js +3 -0
- package/dist/components/item/index.js.map +1 -0
- package/dist/components/item/item.d.ts +32 -0
- package/dist/components/item/item.d.ts.map +1 -0
- package/dist/components/item/item.js +120 -0
- package/dist/components/item/item.js.map +1 -0
- package/dist/components/item/item.stories.js +232 -0
- package/dist/components/item/item.stories.js.map +1 -0
- package/dist/components/label/index.d.ts +2 -0
- package/dist/components/label/index.d.ts.map +1 -0
- package/dist/components/label/index.js +3 -0
- package/dist/components/label/index.js.map +1 -0
- package/dist/components/label/label.d.ts +7 -0
- package/dist/components/label/label.d.ts.map +1 -0
- package/dist/components/label/label.js +13 -0
- package/dist/components/label/label.js.map +1 -0
- package/dist/components/label/label.stories.js +105 -0
- package/dist/components/label/label.stories.js.map +1 -0
- package/dist/components/moving-border/moving-border.d.ts +9 -0
- package/dist/components/moving-border/moving-border.d.ts.map +1 -0
- package/dist/components/moving-border/moving-border.js +54 -0
- package/dist/components/moving-border/moving-border.js.map +1 -0
- package/dist/components/textarea/textarea.js +1 -1
- package/dist/components/textarea/textarea.js.map +1 -1
- package/dist/components/theme/index.d.ts +2 -0
- package/dist/components/theme/index.d.ts.map +1 -0
- package/dist/components/theme/index.js +3 -0
- package/dist/components/theme/index.js.map +1 -0
- package/dist/components/{theme-provider.d.ts → theme/theme-provider.d.ts} +1 -1
- package/dist/components/theme/theme-provider.d.ts.map +1 -0
- package/dist/components/{theme-provider.js → theme/theme-provider.js} +1 -1
- package/dist/components/theme/theme-provider.js.map +1 -0
- package/dist/components/toast/index.d.ts +3 -0
- package/dist/components/toast/index.d.ts.map +1 -0
- package/dist/components/toast/index.js +4 -0
- package/dist/components/toast/index.js.map +1 -0
- package/dist/components/toast/toast-custom.d.ts +19 -0
- package/dist/components/toast/toast-custom.d.ts.map +1 -0
- package/dist/components/toast/toast-custom.js +134 -0
- package/dist/components/toast/toast-custom.js.map +1 -0
- package/dist/components/toast/toast.d.ts +5 -0
- package/dist/components/toast/toast.d.ts.map +1 -0
- package/dist/components/toast/toast.js +40 -0
- package/dist/components/toast/toast.js.map +1 -0
- package/dist/components/toast/toast.stories.js +326 -0
- package/dist/components/toast/toast.stories.js.map +1 -0
- package/dist/components/tooltip/index.d.ts +2 -0
- package/dist/components/tooltip/index.d.ts.map +1 -0
- package/dist/components/tooltip/index.js +3 -0
- package/dist/components/tooltip/index.js.map +1 -0
- package/dist/components/tooltip/tooltip.d.ts +20 -0
- package/dist/components/tooltip/tooltip.d.ts.map +1 -0
- package/dist/components/tooltip/tooltip.js +98 -0
- package/dist/components/tooltip/tooltip.js.map +1 -0
- package/dist/components/tooltip/tooltip.stories.js +560 -0
- package/dist/components/tooltip/tooltip.stories.js.map +1 -0
- package/dist/hooks/index.d.ts +3 -0
- package/dist/hooks/index.d.ts.map +1 -1
- package/dist/hooks/index.js +3 -0
- package/dist/hooks/index.js.map +1 -1
- package/dist/hooks/useResolvedTheme.d.ts +2 -0
- package/dist/hooks/useResolvedTheme.d.ts.map +1 -0
- package/dist/hooks/useResolvedTheme.js +24 -0
- package/dist/hooks/useResolvedTheme.js.map +1 -0
- package/dist/hooks/useShikiHighlight.d.ts +28 -0
- package/dist/hooks/useShikiHighlight.d.ts.map +1 -0
- package/dist/hooks/useShikiHighlight.js +106 -0
- package/dist/hooks/useShikiHighlight.js.map +1 -0
- package/dist/hooks/useShikiStyleInjection.d.ts +2 -0
- package/dist/hooks/useShikiStyleInjection.d.ts.map +1 -0
- package/dist/hooks/useShikiStyleInjection.js +34 -0
- package/dist/hooks/useShikiStyleInjection.js.map +1 -0
- package/dist/utils/avatar.d.ts +3 -0
- package/dist/utils/avatar.d.ts.map +1 -0
- package/dist/utils/avatar.js +32 -0
- package/dist/utils/avatar.js.map +1 -0
- package/dist/utils/index.d.ts +1 -0
- package/dist/utils/index.d.ts.map +1 -1
- package/dist/utils/index.js +1 -0
- package/dist/utils/index.js.map +1 -1
- package/index.css +130 -7
- package/package.json +7 -4
- package/src/assets/illustration-1.svg +92 -0
- package/src/assets/illustration-2.svg +14 -0
- package/src/assets/illustration-gradient.svg +7049 -0
- package/src/components/alert/alert.stories.tsx +77 -0
- package/src/components/alert/alert.tsx +144 -0
- package/src/components/alert/index.ts +1 -0
- package/src/components/avatar/avatar-group.tsx +186 -0
- package/src/components/avatar/avatar.stories.tsx +179 -0
- package/src/components/avatar/avatar.tsx +219 -0
- package/src/components/avatar/index.ts +2 -0
- package/src/components/badge/badge.stories.tsx +468 -0
- package/src/components/badge/badge.tsx +147 -0
- package/src/components/badge/icon-badge.tsx +43 -0
- package/src/components/badge/index.ts +4 -0
- package/src/components/badge/status-badge.tsx +43 -0
- package/src/components/badge/user-badge.tsx +34 -0
- package/src/components/{button.tsx → button/button.tsx} +1 -1
- package/src/components/button/index.ts +1 -0
- package/src/components/checkbox/checkbox-label.tsx +125 -0
- package/src/components/checkbox/checkbox-links.tsx +90 -0
- package/src/components/checkbox/checkbox.stories.tsx +375 -0
- package/src/components/checkbox/checkbox.tsx +71 -0
- package/src/components/checkbox/index.ts +3 -0
- package/src/components/code-block/code-block-footer.tsx +173 -0
- package/src/components/code-block/code-block.stories.tsx +323 -0
- package/src/components/code-block/code-block.tsx +283 -0
- package/src/components/code-block/code-content.tsx +60 -0
- package/src/components/code-block/code-copy-button.tsx +73 -0
- package/src/components/code-block/code-tabs.tsx +170 -0
- package/src/components/code-block/index.ts +3 -0
- package/src/components/dynamic-item/dynamic-item.stories.tsx +261 -0
- package/src/components/dynamic-item/dynamic-item.tsx +68 -0
- package/src/components/dynamic-item/index.ts +1 -0
- package/src/components/icon/custom/index.ts +3 -0
- package/src/components/icon/custom/shipfox-logo.tsx +20 -0
- package/src/components/icon/custom/slack-logo.tsx +35 -0
- package/src/components/icon/custom/stripe-logo.tsx +27 -0
- package/src/components/icon/icon.stories.tsx +3 -1
- package/src/components/icon/icon.tsx +29 -1
- package/src/components/index.ts +12 -1
- package/src/components/inline-tips/index.ts +1 -0
- package/src/components/inline-tips/inline-tips.stories.tsx +126 -0
- package/src/components/inline-tips/inline-tips.tsx +132 -0
- package/src/components/input/index.ts +1 -0
- package/src/components/{input.tsx → input/input.tsx} +1 -1
- package/src/components/item/index.ts +1 -0
- package/src/components/item/item.stories.tsx +150 -0
- package/src/components/item/item.tsx +182 -0
- package/src/components/label/index.ts +1 -0
- package/src/components/label/label.stories.tsx +67 -0
- package/src/components/label/label.tsx +15 -0
- package/src/components/moving-border/moving-border.tsx +67 -0
- package/src/components/textarea/textarea.tsx +1 -1
- package/src/components/theme/index.ts +1 -0
- package/src/components/toast/index.ts +2 -0
- package/src/components/toast/toast-custom.tsx +154 -0
- package/src/components/toast/toast.stories.tsx +369 -0
- package/src/components/toast/toast.tsx +41 -0
- package/src/components/tooltip/index.ts +1 -0
- package/src/components/tooltip/tooltip.stories.tsx +284 -0
- package/src/components/tooltip/tooltip.tsx +121 -0
- package/src/hooks/index.ts +3 -0
- package/src/hooks/useResolvedTheme.ts +34 -0
- package/src/hooks/useShikiHighlight.ts +140 -0
- package/src/hooks/useShikiStyleInjection.ts +34 -0
- package/src/utils/avatar.ts +27 -0
- package/src/utils/index.ts +1 -0
- package/dist/components/button.d.ts.map +0 -1
- package/dist/components/button.js.map +0 -1
- package/dist/components/button.stories.js.map +0 -1
- package/dist/components/input.d.ts.map +0 -1
- package/dist/components/input.js.map +0 -1
- package/dist/components/input.stories.js.map +0 -1
- package/dist/components/theme-provider.d.ts.map +0 -1
- package/dist/components/theme-provider.js.map +0 -1
- /package/dist/components/{input.d.ts → input/input.d.ts} +0 -0
- /package/src/components/{button.stories.tsx → button/button.stories.tsx} +0 -0
- /package/src/components/{input.stories.tsx → input/input.stories.tsx} +0 -0
- /package/src/components/{theme-provider.tsx → theme/theme-provider.tsx} +0 -0
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { Checkbox } from '../../components/checkbox/index.js';
|
|
3
|
+
import { Input } from '../../components/input/input.js';
|
|
4
|
+
import { Textarea } from '../../components/textarea/index.js';
|
|
5
|
+
import { Label } from './label.js';
|
|
6
|
+
const meta = {
|
|
7
|
+
title: 'Components/Label',
|
|
8
|
+
component: Label,
|
|
9
|
+
tags: [
|
|
10
|
+
'autodocs'
|
|
11
|
+
],
|
|
12
|
+
argTypes: {
|
|
13
|
+
htmlFor: {
|
|
14
|
+
control: 'text'
|
|
15
|
+
}
|
|
16
|
+
}
|
|
17
|
+
};
|
|
18
|
+
export default meta;
|
|
19
|
+
export const Default = {
|
|
20
|
+
render: ()=>/*#__PURE__*/ _jsxs("div", {
|
|
21
|
+
className: "flex flex-col gap-8",
|
|
22
|
+
children: [
|
|
23
|
+
/*#__PURE__*/ _jsx(Label, {
|
|
24
|
+
htmlFor: "email",
|
|
25
|
+
children: "Email"
|
|
26
|
+
}),
|
|
27
|
+
/*#__PURE__*/ _jsx(Input, {
|
|
28
|
+
id: "email",
|
|
29
|
+
type: "email",
|
|
30
|
+
placeholder: "Enter your email"
|
|
31
|
+
})
|
|
32
|
+
]
|
|
33
|
+
})
|
|
34
|
+
};
|
|
35
|
+
export const WithCheckbox = {
|
|
36
|
+
render: ()=>/*#__PURE__*/ _jsxs("div", {
|
|
37
|
+
className: "flex items-center gap-8",
|
|
38
|
+
children: [
|
|
39
|
+
/*#__PURE__*/ _jsx(Checkbox, {
|
|
40
|
+
id: "terms"
|
|
41
|
+
}),
|
|
42
|
+
/*#__PURE__*/ _jsx(Label, {
|
|
43
|
+
htmlFor: "terms",
|
|
44
|
+
children: "Accept terms and conditions"
|
|
45
|
+
})
|
|
46
|
+
]
|
|
47
|
+
})
|
|
48
|
+
};
|
|
49
|
+
export const WithTextarea = {
|
|
50
|
+
render: ()=>/*#__PURE__*/ _jsxs("div", {
|
|
51
|
+
className: "flex flex-col gap-8",
|
|
52
|
+
children: [
|
|
53
|
+
/*#__PURE__*/ _jsx(Label, {
|
|
54
|
+
htmlFor: "message",
|
|
55
|
+
children: "Message"
|
|
56
|
+
}),
|
|
57
|
+
/*#__PURE__*/ _jsx(Textarea, {
|
|
58
|
+
id: "message",
|
|
59
|
+
placeholder: "Enter your message"
|
|
60
|
+
})
|
|
61
|
+
]
|
|
62
|
+
})
|
|
63
|
+
};
|
|
64
|
+
export const Required = {
|
|
65
|
+
render: ()=>/*#__PURE__*/ _jsxs("div", {
|
|
66
|
+
className: "flex flex-col gap-8",
|
|
67
|
+
children: [
|
|
68
|
+
/*#__PURE__*/ _jsxs(Label, {
|
|
69
|
+
htmlFor: "required-field",
|
|
70
|
+
children: [
|
|
71
|
+
"Required Field ",
|
|
72
|
+
/*#__PURE__*/ _jsx("span", {
|
|
73
|
+
className: "text-foreground-highlight-error",
|
|
74
|
+
children: "*"
|
|
75
|
+
})
|
|
76
|
+
]
|
|
77
|
+
}),
|
|
78
|
+
/*#__PURE__*/ _jsx(Input, {
|
|
79
|
+
id: "required-field",
|
|
80
|
+
type: "text",
|
|
81
|
+
placeholder: "This field is required"
|
|
82
|
+
})
|
|
83
|
+
]
|
|
84
|
+
})
|
|
85
|
+
};
|
|
86
|
+
export const Disabled = {
|
|
87
|
+
render: ()=>/*#__PURE__*/ _jsxs("div", {
|
|
88
|
+
className: "flex flex-col gap-8",
|
|
89
|
+
children: [
|
|
90
|
+
/*#__PURE__*/ _jsx(Label, {
|
|
91
|
+
htmlFor: "disabled-field",
|
|
92
|
+
className: "opacity-50",
|
|
93
|
+
children: "Disabled Field"
|
|
94
|
+
}),
|
|
95
|
+
/*#__PURE__*/ _jsx(Input, {
|
|
96
|
+
id: "disabled-field",
|
|
97
|
+
type: "text",
|
|
98
|
+
placeholder: "Disabled input",
|
|
99
|
+
disabled: true
|
|
100
|
+
})
|
|
101
|
+
]
|
|
102
|
+
})
|
|
103
|
+
};
|
|
104
|
+
|
|
105
|
+
//# sourceMappingURL=label.stories.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/components/label/label.stories.tsx"],"sourcesContent":["import type {Meta, StoryObj} from '@storybook/react';\nimport {Checkbox} from 'components/checkbox';\nimport {Input} from 'components/input/input';\nimport {Textarea} from 'components/textarea';\nimport {Label} from './label';\n\nconst meta = {\n title: 'Components/Label',\n component: Label,\n tags: ['autodocs'],\n argTypes: {\n htmlFor: {control: 'text'},\n },\n} satisfies Meta<typeof Label>;\n\nexport default meta;\n\ntype Story = StoryObj<typeof meta>;\n\nexport const Default: Story = {\n render: () => (\n <div className=\"flex flex-col gap-8\">\n <Label htmlFor=\"email\">Email</Label>\n <Input id=\"email\" type=\"email\" placeholder=\"Enter your email\" />\n </div>\n ),\n};\n\nexport const WithCheckbox: Story = {\n render: () => (\n <div className=\"flex items-center gap-8\">\n <Checkbox id=\"terms\" />\n <Label htmlFor=\"terms\">Accept terms and conditions</Label>\n </div>\n ),\n};\n\nexport const WithTextarea: Story = {\n render: () => (\n <div className=\"flex flex-col gap-8\">\n <Label htmlFor=\"message\">Message</Label>\n <Textarea id=\"message\" placeholder=\"Enter your message\" />\n </div>\n ),\n};\n\nexport const Required: Story = {\n render: () => (\n <div className=\"flex flex-col gap-8\">\n <Label htmlFor=\"required-field\">\n Required Field <span className=\"text-foreground-highlight-error\">*</span>\n </Label>\n <Input id=\"required-field\" type=\"text\" placeholder=\"This field is required\" />\n </div>\n ),\n};\n\nexport const Disabled: Story = {\n render: () => (\n <div className=\"flex flex-col gap-8\">\n <Label htmlFor=\"disabled-field\" className=\"opacity-50\">\n Disabled Field\n </Label>\n <Input id=\"disabled-field\" type=\"text\" placeholder=\"Disabled input\" disabled />\n </div>\n ),\n};\n"],"names":["Checkbox","Input","Textarea","Label","meta","title","component","tags","argTypes","htmlFor","control","Default","render","div","className","id","type","placeholder","WithCheckbox","WithTextarea","Required","span","Disabled","disabled"],"mappings":";AACA,SAAQA,QAAQ,QAAO,sBAAsB;AAC7C,SAAQC,KAAK,QAAO,yBAAyB;AAC7C,SAAQC,QAAQ,QAAO,sBAAsB;AAC7C,SAAQC,KAAK,QAAO,UAAU;AAE9B,MAAMC,OAAO;IACXC,OAAO;IACPC,WAAWH;IACXI,MAAM;QAAC;KAAW;IAClBC,UAAU;QACRC,SAAS;YAACC,SAAS;QAAM;IAC3B;AACF;AAEA,eAAeN,KAAK;AAIpB,OAAO,MAAMO,UAAiB;IAC5BC,QAAQ,kBACN,MAACC;YAAIC,WAAU;;8BACb,KAACX;oBAAMM,SAAQ;8BAAQ;;8BACvB,KAACR;oBAAMc,IAAG;oBAAQC,MAAK;oBAAQC,aAAY;;;;AAGjD,EAAE;AAEF,OAAO,MAAMC,eAAsB;IACjCN,QAAQ,kBACN,MAACC;YAAIC,WAAU;;8BACb,KAACd;oBAASe,IAAG;;8BACb,KAACZ;oBAAMM,SAAQ;8BAAQ;;;;AAG7B,EAAE;AAEF,OAAO,MAAMU,eAAsB;IACjCP,QAAQ,kBACN,MAACC;YAAIC,WAAU;;8BACb,KAACX;oBAAMM,SAAQ;8BAAU;;8BACzB,KAACP;oBAASa,IAAG;oBAAUE,aAAY;;;;AAGzC,EAAE;AAEF,OAAO,MAAMG,WAAkB;IAC7BR,QAAQ,kBACN,MAACC;YAAIC,WAAU;;8BACb,MAACX;oBAAMM,SAAQ;;wBAAiB;sCACf,KAACY;4BAAKP,WAAU;sCAAkC;;;;8BAEnE,KAACb;oBAAMc,IAAG;oBAAiBC,MAAK;oBAAOC,aAAY;;;;AAGzD,EAAE;AAEF,OAAO,MAAMK,WAAkB;IAC7BV,QAAQ,kBACN,MAACC;YAAIC,WAAU;;8BACb,KAACX;oBAAMM,SAAQ;oBAAiBK,WAAU;8BAAa;;8BAGvD,KAACb;oBAAMc,IAAG;oBAAiBC,MAAK;oBAAOC,aAAY;oBAAiBM,QAAQ;;;;AAGlF,EAAE"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { ComponentProps } from 'react';
|
|
2
|
+
export type MovingBorderProps = {
|
|
3
|
+
children: React.ReactNode;
|
|
4
|
+
duration?: number;
|
|
5
|
+
rx?: string;
|
|
6
|
+
ry?: string;
|
|
7
|
+
} & ComponentProps<'svg'>;
|
|
8
|
+
export declare function MovingBorder({ children, duration, rx, ry, ...otherProps }: MovingBorderProps): import("react/jsx-runtime").JSX.Element;
|
|
9
|
+
//# sourceMappingURL=moving-border.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"moving-border.d.ts","sourceRoot":"","sources":["../../../src/components/moving-border/moving-border.tsx"],"names":[],"mappings":"AAOA,OAAO,KAAK,EAAC,cAAc,EAAC,MAAM,OAAO,CAAC;AAG1C,MAAM,MAAM,iBAAiB,GAAG;IAC9B,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,EAAE,CAAC,EAAE,MAAM,CAAC;CACb,GAAG,cAAc,CAAC,KAAK,CAAC,CAAC;AAE1B,wBAAgB,YAAY,CAAC,EAC3B,QAAQ,EACR,QAAe,EACf,EAAE,EACF,EAAE,EACF,GAAG,UAAU,EACd,EAAE,iBAAiB,2CA2CnB"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { motion, useAnimationFrame, useMotionTemplate, useMotionValue, useTransform } from 'framer-motion';
|
|
3
|
+
import { useRef } from 'react';
|
|
4
|
+
export function MovingBorder({ children, duration = 3000, rx, ry, ...otherProps }) {
|
|
5
|
+
const pathRef = useRef(null);
|
|
6
|
+
const progress = useMotionValue(0);
|
|
7
|
+
useAnimationFrame((time)=>{
|
|
8
|
+
const length = pathRef.current?.getTotalLength();
|
|
9
|
+
if (length) {
|
|
10
|
+
const pxPerMillisecond = length / duration;
|
|
11
|
+
progress.set(time * pxPerMillisecond % length);
|
|
12
|
+
}
|
|
13
|
+
});
|
|
14
|
+
const x = useTransform(progress, (val)=>pathRef.current?.getPointAtLength(val)?.x ?? 0);
|
|
15
|
+
const y = useTransform(progress, (val)=>pathRef.current?.getPointAtLength(val)?.y ?? 0);
|
|
16
|
+
const transform = useMotionTemplate`translateX(${x}px) translateY(${y}px) translateX(-50%) translateY(-50%)`;
|
|
17
|
+
return /*#__PURE__*/ _jsxs(_Fragment, {
|
|
18
|
+
children: [
|
|
19
|
+
/*#__PURE__*/ _jsxs("svg", {
|
|
20
|
+
xmlns: "http://www.w3.org/2000/svg",
|
|
21
|
+
preserveAspectRatio: "none",
|
|
22
|
+
className: "absolute h-full w-full",
|
|
23
|
+
width: "100%",
|
|
24
|
+
height: "100%",
|
|
25
|
+
...otherProps,
|
|
26
|
+
children: [
|
|
27
|
+
/*#__PURE__*/ _jsx("title", {
|
|
28
|
+
children: "Moving Border"
|
|
29
|
+
}),
|
|
30
|
+
/*#__PURE__*/ _jsx("rect", {
|
|
31
|
+
fill: "none",
|
|
32
|
+
width: "100%",
|
|
33
|
+
height: "100%",
|
|
34
|
+
rx: rx,
|
|
35
|
+
ry: ry,
|
|
36
|
+
ref: pathRef
|
|
37
|
+
})
|
|
38
|
+
]
|
|
39
|
+
}),
|
|
40
|
+
/*#__PURE__*/ _jsx(motion.div, {
|
|
41
|
+
style: {
|
|
42
|
+
position: 'absolute',
|
|
43
|
+
top: 0,
|
|
44
|
+
left: 0,
|
|
45
|
+
display: 'inline-block',
|
|
46
|
+
transform
|
|
47
|
+
},
|
|
48
|
+
children: children
|
|
49
|
+
})
|
|
50
|
+
]
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
//# sourceMappingURL=moving-border.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/components/moving-border/moving-border.tsx"],"sourcesContent":["import {\n motion,\n useAnimationFrame,\n useMotionTemplate,\n useMotionValue,\n useTransform,\n} from 'framer-motion';\nimport type {ComponentProps} from 'react';\nimport {useRef} from 'react';\n\nexport type MovingBorderProps = {\n children: React.ReactNode;\n duration?: number;\n rx?: string;\n ry?: string;\n} & ComponentProps<'svg'>;\n\nexport function MovingBorder({\n children,\n duration = 3000,\n rx,\n ry,\n ...otherProps\n}: MovingBorderProps) {\n const pathRef = useRef<SVGRectElement | null>(null);\n const progress = useMotionValue<number>(0);\n\n useAnimationFrame((time: number) => {\n const length = pathRef.current?.getTotalLength();\n if (length) {\n const pxPerMillisecond = length / duration;\n progress.set((time * pxPerMillisecond) % length);\n }\n });\n\n const x = useTransform(progress, (val: number) => pathRef.current?.getPointAtLength(val)?.x ?? 0);\n const y = useTransform(progress, (val: number) => pathRef.current?.getPointAtLength(val)?.y ?? 0);\n\n const transform = useMotionTemplate`translateX(${x}px) translateY(${y}px) translateX(-50%) translateY(-50%)`;\n\n return (\n <>\n <svg\n xmlns=\"http://www.w3.org/2000/svg\"\n preserveAspectRatio=\"none\"\n className=\"absolute h-full w-full\"\n width=\"100%\"\n height=\"100%\"\n {...otherProps}\n >\n <title>Moving Border</title>\n <rect fill=\"none\" width=\"100%\" height=\"100%\" rx={rx} ry={ry} ref={pathRef} />\n </svg>\n <motion.div\n style={{\n position: 'absolute',\n top: 0,\n left: 0,\n display: 'inline-block',\n transform,\n }}\n >\n {children}\n </motion.div>\n </>\n );\n}\n"],"names":["motion","useAnimationFrame","useMotionTemplate","useMotionValue","useTransform","useRef","MovingBorder","children","duration","rx","ry","otherProps","pathRef","progress","time","length","current","getTotalLength","pxPerMillisecond","set","x","val","getPointAtLength","y","transform","svg","xmlns","preserveAspectRatio","className","width","height","title","rect","fill","ref","div","style","position","top","left","display"],"mappings":";AAAA,SACEA,MAAM,EACNC,iBAAiB,EACjBC,iBAAiB,EACjBC,cAAc,EACdC,YAAY,QACP,gBAAgB;AAEvB,SAAQC,MAAM,QAAO,QAAQ;AAS7B,OAAO,SAASC,aAAa,EAC3BC,QAAQ,EACRC,WAAW,IAAI,EACfC,EAAE,EACFC,EAAE,EACF,GAAGC,YACe;IAClB,MAAMC,UAAUP,OAA8B;IAC9C,MAAMQ,WAAWV,eAAuB;IAExCF,kBAAkB,CAACa;QACjB,MAAMC,SAASH,QAAQI,OAAO,EAAEC;QAChC,IAAIF,QAAQ;YACV,MAAMG,mBAAmBH,SAASP;YAClCK,SAASM,GAAG,CAAC,AAACL,OAAOI,mBAAoBH;QAC3C;IACF;IAEA,MAAMK,IAAIhB,aAAaS,UAAU,CAACQ,MAAgBT,QAAQI,OAAO,EAAEM,iBAAiBD,MAAMD,KAAK;IAC/F,MAAMG,IAAInB,aAAaS,UAAU,CAACQ,MAAgBT,QAAQI,OAAO,EAAEM,iBAAiBD,MAAME,KAAK;IAE/F,MAAMC,YAAYtB,iBAAiB,CAAC,WAAW,EAAEkB,EAAE,eAAe,EAAEG,EAAE,qCAAqC,CAAC;IAE5G,qBACE;;0BACE,MAACE;gBACCC,OAAM;gBACNC,qBAAoB;gBACpBC,WAAU;gBACVC,OAAM;gBACNC,QAAO;gBACN,GAAGnB,UAAU;;kCAEd,KAACoB;kCAAM;;kCACP,KAACC;wBAAKC,MAAK;wBAAOJ,OAAM;wBAAOC,QAAO;wBAAOrB,IAAIA;wBAAIC,IAAIA;wBAAIwB,KAAKtB;;;;0BAEpE,KAACZ,OAAOmC,GAAG;gBACTC,OAAO;oBACLC,UAAU;oBACVC,KAAK;oBACLC,MAAM;oBACNC,SAAS;oBACThB;gBACF;0BAECjB;;;;AAIT"}
|
|
@@ -20,7 +20,7 @@ export const textareaVariants = cva('', {
|
|
|
20
20
|
export function Textarea({ className, variant, size, ...props }) {
|
|
21
21
|
return /*#__PURE__*/ _jsx("textarea", {
|
|
22
22
|
"data-slot": "textarea",
|
|
23
|
-
className: cn('textarea-resize-custom placeholder:text-foreground-neutral-muted w-full min-w-0 rounded-6 px-8 pr-24 text-sm leading-20 text-foreground-neutral-base shadow-
|
|
23
|
+
className: cn('textarea-resize-custom placeholder:text-foreground-neutral-muted w-full min-w-0 rounded-6 px-8 pr-24 text-sm leading-20 text-foreground-neutral-base shadow-button-neutral transition-[color,box-shadow] outline-none', 'hover:bg-background-field-hover', 'selection:bg-background-accent-neutral-soft selection:text-foreground-neutral-on-inverted', 'disabled:pointer-events-none disabled:cursor-not-allowed disabled:bg-background-neutral-disabled disabled:shadow-none disabled:text-foreground-neutral-disabled', 'focus-visible:shadow-border-interactive-with-active', 'aria-invalid:shadow-border-error', textareaVariants({
|
|
24
24
|
variant,
|
|
25
25
|
size
|
|
26
26
|
}), className),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/components/textarea/textarea.tsx"],"sourcesContent":["import {cva, type VariantProps} from 'class-variance-authority';\nimport type {ComponentProps} from 'react';\nimport {cn} from 'utils/cn';\n\nexport const textareaVariants = cva('', {\n variants: {\n variant: {\n base: 'bg-background-field-base',\n component: 'bg-background-field-component',\n },\n size: {\n base: 'py-6',\n small: 'py-4',\n },\n },\n defaultVariants: {\n variant: 'base',\n size: 'base',\n },\n});\n\ntype TextareaProps = Omit<ComponentProps<'textarea'>, 'size'> &\n VariantProps<typeof textareaVariants>;\n\nexport function Textarea({className, variant, size, ...props}: TextareaProps) {\n return (\n <textarea\n data-slot=\"textarea\"\n className={cn(\n 'textarea-resize-custom placeholder:text-foreground-neutral-muted w-full min-w-0 rounded-6 px-8 pr-24 text-sm leading-20 text-foreground-neutral-base shadow-
|
|
1
|
+
{"version":3,"sources":["../../../src/components/textarea/textarea.tsx"],"sourcesContent":["import {cva, type VariantProps} from 'class-variance-authority';\nimport type {ComponentProps} from 'react';\nimport {cn} from 'utils/cn';\n\nexport const textareaVariants = cva('', {\n variants: {\n variant: {\n base: 'bg-background-field-base',\n component: 'bg-background-field-component',\n },\n size: {\n base: 'py-6',\n small: 'py-4',\n },\n },\n defaultVariants: {\n variant: 'base',\n size: 'base',\n },\n});\n\ntype TextareaProps = Omit<ComponentProps<'textarea'>, 'size'> &\n VariantProps<typeof textareaVariants>;\n\nexport function Textarea({className, variant, size, ...props}: TextareaProps) {\n return (\n <textarea\n data-slot=\"textarea\"\n className={cn(\n 'textarea-resize-custom placeholder:text-foreground-neutral-muted w-full min-w-0 rounded-6 px-8 pr-24 text-sm leading-20 text-foreground-neutral-base shadow-button-neutral transition-[color,box-shadow] outline-none',\n 'hover:bg-background-field-hover',\n 'selection:bg-background-accent-neutral-soft selection:text-foreground-neutral-on-inverted',\n 'disabled:pointer-events-none disabled:cursor-not-allowed disabled:bg-background-neutral-disabled disabled:shadow-none disabled:text-foreground-neutral-disabled',\n 'focus-visible:shadow-border-interactive-with-active',\n 'aria-invalid:shadow-border-error',\n textareaVariants({variant, size}),\n className,\n )}\n {...props}\n />\n );\n}\n"],"names":["cva","cn","textareaVariants","variants","variant","base","component","size","small","defaultVariants","Textarea","className","props","textarea","data-slot"],"mappings":";AAAA,SAAQA,GAAG,QAA0B,2BAA2B;AAEhE,SAAQC,EAAE,QAAO,WAAW;AAE5B,OAAO,MAAMC,mBAAmBF,IAAI,IAAI;IACtCG,UAAU;QACRC,SAAS;YACPC,MAAM;YACNC,WAAW;QACb;QACAC,MAAM;YACJF,MAAM;YACNG,OAAO;QACT;IACF;IACAC,iBAAiB;QACfL,SAAS;QACTG,MAAM;IACR;AACF,GAAG;AAKH,OAAO,SAASG,SAAS,EAACC,SAAS,EAAEP,OAAO,EAAEG,IAAI,EAAE,GAAGK,OAAqB;IAC1E,qBACE,KAACC;QACCC,aAAU;QACVH,WAAWV,GACT,yNACA,mCACA,6FACA,mKACA,uDACA,oCACAC,iBAAiB;YAACE;YAASG;QAAI,IAC/BI;QAED,GAAGC,KAAK;;AAGf"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/theme/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/components/theme/index.ts"],"sourcesContent":["export * from './theme-provider';\n"],"names":[],"mappings":"AAAA,cAAc,mBAAmB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"theme-provider.d.ts","sourceRoot":"","sources":["../../../src/components/theme/theme-provider.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAC,KAAK,SAAS,EAAsB,MAAM,OAAO,CAAC;AAC1D,OAAO,EAAC,KAAK,KAAK,EAAuB,MAAM,aAAa,CAAC;AAE7D,KAAK,kBAAkB,GAAG;IACxB,QAAQ,EAAE,SAAS,CAAC;IACpB,YAAY,CAAC,EAAE,KAAK,CAAC;IACrB,UAAU,CAAC,EAAE,MAAM,CAAC;CACrB,CAAC;AAEF,wBAAgB,aAAa,CAAC,EAC5B,QAAQ,EACR,YAAuB,EACvB,UAA4B,EAC5B,GAAG,KAAK,EACT,EAAE,kBAAkB,2CAmCpB"}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
2
|
import { useEffect, useState } from 'react';
|
|
3
|
-
import { ThemeProviderContext } from '
|
|
3
|
+
import { ThemeProviderContext } from '../../state/theme.js';
|
|
4
4
|
export function ThemeProvider({ children, defaultTheme = 'system', storageKey = 'shipfox-theme', ...props }) {
|
|
5
5
|
const [theme, setTheme] = useState(()=>localStorage.getItem(storageKey) || defaultTheme);
|
|
6
6
|
useEffect(()=>{
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/components/theme/theme-provider.tsx"],"sourcesContent":["import {type ReactNode, useEffect, useState} from 'react';\nimport {type Theme, ThemeProviderContext} from 'state/theme';\n\ntype ThemeProviderProps = {\n children: ReactNode;\n defaultTheme?: Theme;\n storageKey?: string;\n};\n\nexport function ThemeProvider({\n children,\n defaultTheme = 'system',\n storageKey = 'shipfox-theme',\n ...props\n}: ThemeProviderProps) {\n const [theme, setTheme] = useState<Theme>(\n () => (localStorage.getItem(storageKey) as Theme) || defaultTheme,\n );\n\n useEffect(() => {\n const root = window.document.documentElement;\n\n root.classList.remove('light', 'dark');\n\n if (theme === 'system') {\n const systemTheme = window.matchMedia('(prefers-color-scheme: dark)').matches\n ? 'dark'\n : 'light';\n\n root.classList.add(systemTheme);\n return;\n }\n\n root.classList.add(theme);\n }, [theme]);\n\n const value = {\n theme,\n setTheme: (theme: Theme) => {\n localStorage.setItem(storageKey, theme);\n setTheme(theme);\n },\n };\n\n return (\n <ThemeProviderContext.Provider {...props} value={value}>\n {children}\n </ThemeProviderContext.Provider>\n );\n}\n"],"names":["useEffect","useState","ThemeProviderContext","ThemeProvider","children","defaultTheme","storageKey","props","theme","setTheme","localStorage","getItem","root","window","document","documentElement","classList","remove","systemTheme","matchMedia","matches","add","value","setItem","Provider"],"mappings":";AAAA,SAAwBA,SAAS,EAAEC,QAAQ,QAAO,QAAQ;AAC1D,SAAoBC,oBAAoB,QAAO,cAAc;AAQ7D,OAAO,SAASC,cAAc,EAC5BC,QAAQ,EACRC,eAAe,QAAQ,EACvBC,aAAa,eAAe,EAC5B,GAAGC,OACgB;IACnB,MAAM,CAACC,OAAOC,SAAS,GAAGR,SACxB,IAAM,AAACS,aAAaC,OAAO,CAACL,eAAyBD;IAGvDL,UAAU;QACR,MAAMY,OAAOC,OAAOC,QAAQ,CAACC,eAAe;QAE5CH,KAAKI,SAAS,CAACC,MAAM,CAAC,SAAS;QAE/B,IAAIT,UAAU,UAAU;YACtB,MAAMU,cAAcL,OAAOM,UAAU,CAAC,gCAAgCC,OAAO,GACzE,SACA;YAEJR,KAAKI,SAAS,CAACK,GAAG,CAACH;YACnB;QACF;QAEAN,KAAKI,SAAS,CAACK,GAAG,CAACb;IACrB,GAAG;QAACA;KAAM;IAEV,MAAMc,QAAQ;QACZd;QACAC,UAAU,CAACD;YACTE,aAAaa,OAAO,CAACjB,YAAYE;YACjCC,SAASD;QACX;IACF;IAEA,qBACE,KAACN,qBAAqBsB,QAAQ;QAAE,GAAGjB,KAAK;QAAEe,OAAOA;kBAC9ClB;;AAGP"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/toast/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,OAAO,EAAE,KAAK,YAAY,EAAE,KAAK,EAAC,MAAM,SAAS,CAAC;AAC1D,OAAO,EAAC,WAAW,EAAE,KAAK,gBAAgB,EAAC,MAAM,gBAAgB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/components/toast/index.ts"],"sourcesContent":["export {Toaster, type ToasterProps, toast} from './toast';\nexport {ToastCustom, type ToastCustomProps} from './toast-custom';\n"],"names":["Toaster","toast","ToastCustom"],"mappings":"AAAA,SAAQA,OAAO,EAAqBC,KAAK,QAAO,UAAU;AAC1D,SAAQC,WAAW,QAA8B,iBAAiB"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { type VariantProps } from 'class-variance-authority';
|
|
2
|
+
declare const toastCustomVariants: (props?: ({
|
|
3
|
+
variant?: "info" | "default" | "success" | "warning" | "error" | null | undefined;
|
|
4
|
+
} & import("class-variance-authority/types").ClassProp) | undefined) => string;
|
|
5
|
+
export type ToastAction = {
|
|
6
|
+
label: string;
|
|
7
|
+
onClick: () => void;
|
|
8
|
+
};
|
|
9
|
+
export type ToastCustomProps = VariantProps<typeof toastCustomVariants> & {
|
|
10
|
+
title?: string;
|
|
11
|
+
description?: string;
|
|
12
|
+
content?: string;
|
|
13
|
+
actions?: ToastAction[];
|
|
14
|
+
onClose?: () => void;
|
|
15
|
+
className?: string;
|
|
16
|
+
};
|
|
17
|
+
export declare function ToastCustom({ variant, title, description, content, actions, onClose, className, }: ToastCustomProps): import("react/jsx-runtime").JSX.Element;
|
|
18
|
+
export {};
|
|
19
|
+
//# sourceMappingURL=toast-custom.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toast-custom.d.ts","sourceRoot":"","sources":["../../../src/components/toast/toast-custom.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAM,KAAK,YAAY,EAAC,MAAM,0BAA0B,CAAC;AAKhE,QAAA,MAAM,mBAAmB;;8EAavB,CAAC;AAEH,MAAM,MAAM,WAAW,GAAG;IACxB,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,IAAI,CAAC;CACrB,CAAC;AAEF,MAAM,MAAM,gBAAgB,GAAG,YAAY,CAAC,OAAO,mBAAmB,CAAC,GAAG;IACxE,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,OAAO,CAAC,EAAE,MAAM,CAAC;IACjB,OAAO,CAAC,EAAE,WAAW,EAAE,CAAC;IACxB,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC;AAiBF,wBAAgB,WAAW,CAAC,EAC1B,OAAmB,EACnB,KAAK,EACL,WAAW,EACX,OAAO,EACP,OAAO,EACP,OAAO,EACP,SAAS,GACV,EAAE,gBAAgB,2CAgGlB"}
|
|
@@ -0,0 +1,134 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
2
|
+
import { cva } from 'class-variance-authority';
|
|
3
|
+
import { Icon } from '../../components/icon/icon.js';
|
|
4
|
+
import { cn } from '../../utils/cn.js';
|
|
5
|
+
const toastCustomVariants = cva('group relative flex items-start gap-8', {
|
|
6
|
+
variants: {
|
|
7
|
+
variant: {
|
|
8
|
+
default: 'text-tag-neutral-icon',
|
|
9
|
+
info: 'text-tag-neutral-icon',
|
|
10
|
+
success: 'text-tag-success-icon',
|
|
11
|
+
warning: 'text-tag-warning-icon',
|
|
12
|
+
error: 'text-tag-error-icon'
|
|
13
|
+
}
|
|
14
|
+
},
|
|
15
|
+
defaultVariants: {
|
|
16
|
+
variant: 'default'
|
|
17
|
+
}
|
|
18
|
+
});
|
|
19
|
+
function getDefaultIcon(variant = 'default') {
|
|
20
|
+
switch(variant){
|
|
21
|
+
case 'info':
|
|
22
|
+
return /*#__PURE__*/ _jsx(Icon, {
|
|
23
|
+
name: "info",
|
|
24
|
+
size: 20
|
|
25
|
+
});
|
|
26
|
+
case 'success':
|
|
27
|
+
return /*#__PURE__*/ _jsx(Icon, {
|
|
28
|
+
name: "checkCircleSolid",
|
|
29
|
+
size: 20
|
|
30
|
+
});
|
|
31
|
+
case 'warning':
|
|
32
|
+
return /*#__PURE__*/ _jsx(Icon, {
|
|
33
|
+
name: "info",
|
|
34
|
+
size: 20
|
|
35
|
+
});
|
|
36
|
+
case 'error':
|
|
37
|
+
return /*#__PURE__*/ _jsx(Icon, {
|
|
38
|
+
name: "xCircleSolid",
|
|
39
|
+
size: 20
|
|
40
|
+
});
|
|
41
|
+
default:
|
|
42
|
+
return /*#__PURE__*/ _jsx(Icon, {
|
|
43
|
+
name: "info",
|
|
44
|
+
size: 20
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
export function ToastCustom({ variant = 'default', title, description, content, actions, onClose, className }) {
|
|
49
|
+
const hasTitle = Boolean(title);
|
|
50
|
+
const hasDescription = Boolean(description);
|
|
51
|
+
const hasContent = Boolean(content);
|
|
52
|
+
const hasActions = Boolean(actions && actions.length > 0);
|
|
53
|
+
const isSimple = hasContent && !hasTitle && !hasDescription;
|
|
54
|
+
return /*#__PURE__*/ _jsxs("div", {
|
|
55
|
+
"data-slot": "toast-custom",
|
|
56
|
+
className: cn(toastCustomVariants({
|
|
57
|
+
variant
|
|
58
|
+
}), className),
|
|
59
|
+
children: [
|
|
60
|
+
/*#__PURE__*/ _jsx("div", {
|
|
61
|
+
className: "w-20 h-20 rounded-full flex items-start justify-center shrink-0 pt-1",
|
|
62
|
+
children: getDefaultIcon(variant)
|
|
63
|
+
}),
|
|
64
|
+
/*#__PURE__*/ _jsxs("div", {
|
|
65
|
+
className: "flex-1 min-w-0",
|
|
66
|
+
children: [
|
|
67
|
+
hasTitle && /*#__PURE__*/ _jsx("div", {
|
|
68
|
+
"data-slot": "toast-custom-title",
|
|
69
|
+
className: "font-medium text-sm leading-20 text-foreground-neutral-base mb-4",
|
|
70
|
+
children: title
|
|
71
|
+
}),
|
|
72
|
+
hasDescription && /*#__PURE__*/ _jsx("div", {
|
|
73
|
+
"data-slot": "toast-custom-description",
|
|
74
|
+
className: "text-xs leading-20 text-foreground-neutral-muted mb-8",
|
|
75
|
+
children: description
|
|
76
|
+
}),
|
|
77
|
+
isSimple ? /*#__PURE__*/ _jsxs("div", {
|
|
78
|
+
className: "flex items-center justify-between gap-16 min-w-400 mr-30",
|
|
79
|
+
children: [
|
|
80
|
+
/*#__PURE__*/ _jsx("div", {
|
|
81
|
+
"data-slot": "toast-custom-content",
|
|
82
|
+
className: "text-sm leading-20 text-foreground-neutral-base",
|
|
83
|
+
children: content
|
|
84
|
+
}),
|
|
85
|
+
hasActions && /*#__PURE__*/ _jsx("div", {
|
|
86
|
+
"data-slot": "toast-custom-actions",
|
|
87
|
+
className: "flex items-center gap-16",
|
|
88
|
+
children: actions?.map((action)=>/*#__PURE__*/ _jsx("button", {
|
|
89
|
+
"data-slot": "toast-custom-action",
|
|
90
|
+
type: "button",
|
|
91
|
+
onClick: action.onClick,
|
|
92
|
+
className: "bg-transparent border-none p-0 cursor-pointer text-xs font-medium leading-20 text-foreground-neutral-base hover:text-foreground-neutral-subtle transition-colors duration-150 outline-none focus-visible:ring-2 focus-visible:ring-background-accent-blue-base focus-visible:ring-offset-2",
|
|
93
|
+
children: action.label
|
|
94
|
+
}, action.label))
|
|
95
|
+
})
|
|
96
|
+
]
|
|
97
|
+
}) : /*#__PURE__*/ _jsxs(_Fragment, {
|
|
98
|
+
children: [
|
|
99
|
+
hasContent && !hasTitle && /*#__PURE__*/ _jsx("div", {
|
|
100
|
+
"data-slot": "toast-custom-content",
|
|
101
|
+
className: "text-sm leading-20 text-foreground-neutral-base mb-8",
|
|
102
|
+
children: content
|
|
103
|
+
}),
|
|
104
|
+
hasActions && /*#__PURE__*/ _jsx("div", {
|
|
105
|
+
"data-slot": "toast-custom-actions",
|
|
106
|
+
className: "flex items-center gap-16 mt-8",
|
|
107
|
+
children: actions?.map((action)=>/*#__PURE__*/ _jsx("button", {
|
|
108
|
+
"data-slot": "toast-custom-action",
|
|
109
|
+
type: "button",
|
|
110
|
+
onClick: action.onClick,
|
|
111
|
+
className: "bg-transparent border-none p-0 cursor-pointer text-xs font-medium leading-20 text-foreground-neutral-base hover:text-foreground-neutral-subtle transition-colors duration-150 outline-none focus-visible:ring-2 focus-visible:ring-background-accent-blue-base focus-visible:ring-offset-2",
|
|
112
|
+
children: action.label
|
|
113
|
+
}, action.label))
|
|
114
|
+
})
|
|
115
|
+
]
|
|
116
|
+
})
|
|
117
|
+
]
|
|
118
|
+
}),
|
|
119
|
+
onClose && /*#__PURE__*/ _jsx("button", {
|
|
120
|
+
"data-slot": "toast-custom-close",
|
|
121
|
+
type: "button",
|
|
122
|
+
onClick: onClose,
|
|
123
|
+
className: "absolute cursor-pointer -top-2 -right-2 rounded-4 p-4 bg-transparent border-none text-foreground-neutral-muted hover:text-foreground-neutral-base hover:bg-background-components-hover transition-colors duration-150 outline-none focus-visible:ring-2 focus-visible:ring-background-accent-blue-base focus-visible:ring-offset-2 shrink-0",
|
|
124
|
+
"aria-label": "Close",
|
|
125
|
+
children: /*#__PURE__*/ _jsx(Icon, {
|
|
126
|
+
name: "close",
|
|
127
|
+
className: "w-16 h-16"
|
|
128
|
+
})
|
|
129
|
+
})
|
|
130
|
+
]
|
|
131
|
+
});
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
//# sourceMappingURL=toast-custom.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/components/toast/toast-custom.tsx"],"sourcesContent":["import {cva, type VariantProps} from 'class-variance-authority';\nimport {Icon} from 'components/icon/icon';\nimport type {ReactNode} from 'react';\nimport {cn} from 'utils/cn';\n\nconst toastCustomVariants = cva('group relative flex items-start gap-8', {\n variants: {\n variant: {\n default: 'text-tag-neutral-icon',\n info: 'text-tag-neutral-icon',\n success: 'text-tag-success-icon',\n warning: 'text-tag-warning-icon',\n error: 'text-tag-error-icon',\n },\n },\n defaultVariants: {\n variant: 'default',\n },\n});\n\nexport type ToastAction = {\n label: string;\n onClick: () => void;\n};\n\nexport type ToastCustomProps = VariantProps<typeof toastCustomVariants> & {\n title?: string;\n description?: string;\n content?: string;\n actions?: ToastAction[];\n onClose?: () => void;\n className?: string;\n};\n\nfunction getDefaultIcon(variant: ToastCustomProps['variant'] = 'default'): ReactNode {\n switch (variant) {\n case 'info':\n return <Icon name=\"info\" size={20} />;\n case 'success':\n return <Icon name=\"checkCircleSolid\" size={20} />;\n case 'warning':\n return <Icon name=\"info\" size={20} />;\n case 'error':\n return <Icon name=\"xCircleSolid\" size={20} />;\n default:\n return <Icon name=\"info\" size={20} />;\n }\n}\n\nexport function ToastCustom({\n variant = 'default',\n title,\n description,\n content,\n actions,\n onClose,\n className,\n}: ToastCustomProps) {\n const hasTitle = Boolean(title);\n const hasDescription = Boolean(description);\n const hasContent = Boolean(content);\n const hasActions = Boolean(actions && actions.length > 0);\n const isSimple = hasContent && !hasTitle && !hasDescription;\n\n return (\n <div data-slot=\"toast-custom\" className={cn(toastCustomVariants({variant}), className)}>\n <div className=\"w-20 h-20 rounded-full flex items-start justify-center shrink-0 pt-1\">\n {getDefaultIcon(variant)}\n </div>\n\n <div className=\"flex-1 min-w-0\">\n {hasTitle && (\n <div\n data-slot=\"toast-custom-title\"\n className=\"font-medium text-sm leading-20 text-foreground-neutral-base mb-4\"\n >\n {title}\n </div>\n )}\n {hasDescription && (\n <div\n data-slot=\"toast-custom-description\"\n className=\"text-xs leading-20 text-foreground-neutral-muted mb-8\"\n >\n {description}\n </div>\n )}\n {isSimple ? (\n <div className=\"flex items-center justify-between gap-16 min-w-400 mr-30\">\n <div\n data-slot=\"toast-custom-content\"\n className=\"text-sm leading-20 text-foreground-neutral-base\"\n >\n {content}\n </div>\n {hasActions && (\n <div data-slot=\"toast-custom-actions\" className=\"flex items-center gap-16\">\n {actions?.map((action) => (\n <button\n key={action.label}\n data-slot=\"toast-custom-action\"\n type=\"button\"\n onClick={action.onClick}\n className=\"bg-transparent border-none p-0 cursor-pointer text-xs font-medium leading-20 text-foreground-neutral-base hover:text-foreground-neutral-subtle transition-colors duration-150 outline-none focus-visible:ring-2 focus-visible:ring-background-accent-blue-base focus-visible:ring-offset-2\"\n >\n {action.label}\n </button>\n ))}\n </div>\n )}\n </div>\n ) : (\n <>\n {hasContent && !hasTitle && (\n <div\n data-slot=\"toast-custom-content\"\n className=\"text-sm leading-20 text-foreground-neutral-base mb-8\"\n >\n {content}\n </div>\n )}\n {hasActions && (\n <div data-slot=\"toast-custom-actions\" className=\"flex items-center gap-16 mt-8\">\n {actions?.map((action) => (\n <button\n key={action.label}\n data-slot=\"toast-custom-action\"\n type=\"button\"\n onClick={action.onClick}\n className=\"bg-transparent border-none p-0 cursor-pointer text-xs font-medium leading-20 text-foreground-neutral-base hover:text-foreground-neutral-subtle transition-colors duration-150 outline-none focus-visible:ring-2 focus-visible:ring-background-accent-blue-base focus-visible:ring-offset-2\"\n >\n {action.label}\n </button>\n ))}\n </div>\n )}\n </>\n )}\n </div>\n\n {onClose && (\n <button\n data-slot=\"toast-custom-close\"\n type=\"button\"\n onClick={onClose}\n className=\"absolute cursor-pointer -top-2 -right-2 rounded-4 p-4 bg-transparent border-none text-foreground-neutral-muted hover:text-foreground-neutral-base hover:bg-background-components-hover transition-colors duration-150 outline-none focus-visible:ring-2 focus-visible:ring-background-accent-blue-base focus-visible:ring-offset-2 shrink-0\"\n aria-label=\"Close\"\n >\n <Icon name=\"close\" className=\"w-16 h-16\" />\n </button>\n )}\n </div>\n );\n}\n"],"names":["cva","Icon","cn","toastCustomVariants","variants","variant","default","info","success","warning","error","defaultVariants","getDefaultIcon","name","size","ToastCustom","title","description","content","actions","onClose","className","hasTitle","Boolean","hasDescription","hasContent","hasActions","length","isSimple","div","data-slot","map","action","button","type","onClick","label","aria-label"],"mappings":";AAAA,SAAQA,GAAG,QAA0B,2BAA2B;AAChE,SAAQC,IAAI,QAAO,uBAAuB;AAE1C,SAAQC,EAAE,QAAO,WAAW;AAE5B,MAAMC,sBAAsBH,IAAI,yCAAyC;IACvEI,UAAU;QACRC,SAAS;YACPC,SAAS;YACTC,MAAM;YACNC,SAAS;YACTC,SAAS;YACTC,OAAO;QACT;IACF;IACAC,iBAAiB;QACfN,SAAS;IACX;AACF;AAgBA,SAASO,eAAeP,UAAuC,SAAS;IACtE,OAAQA;QACN,KAAK;YACH,qBAAO,KAACJ;gBAAKY,MAAK;gBAAOC,MAAM;;QACjC,KAAK;YACH,qBAAO,KAACb;gBAAKY,MAAK;gBAAmBC,MAAM;;QAC7C,KAAK;YACH,qBAAO,KAACb;gBAAKY,MAAK;gBAAOC,MAAM;;QACjC,KAAK;YACH,qBAAO,KAACb;gBAAKY,MAAK;gBAAeC,MAAM;;QACzC;YACE,qBAAO,KAACb;gBAAKY,MAAK;gBAAOC,MAAM;;IACnC;AACF;AAEA,OAAO,SAASC,YAAY,EAC1BV,UAAU,SAAS,EACnBW,KAAK,EACLC,WAAW,EACXC,OAAO,EACPC,OAAO,EACPC,OAAO,EACPC,SAAS,EACQ;IACjB,MAAMC,WAAWC,QAAQP;IACzB,MAAMQ,iBAAiBD,QAAQN;IAC/B,MAAMQ,aAAaF,QAAQL;IAC3B,MAAMQ,aAAaH,QAAQJ,WAAWA,QAAQQ,MAAM,GAAG;IACvD,MAAMC,WAAWH,cAAc,CAACH,YAAY,CAACE;IAE7C,qBACE,MAACK;QAAIC,aAAU;QAAeT,WAAWnB,GAAGC,oBAAoB;YAACE;QAAO,IAAIgB;;0BAC1E,KAACQ;gBAAIR,WAAU;0BACZT,eAAeP;;0BAGlB,MAACwB;gBAAIR,WAAU;;oBACZC,0BACC,KAACO;wBACCC,aAAU;wBACVT,WAAU;kCAETL;;oBAGJQ,gCACC,KAACK;wBACCC,aAAU;wBACVT,WAAU;kCAETJ;;oBAGJW,yBACC,MAACC;wBAAIR,WAAU;;0CACb,KAACQ;gCACCC,aAAU;gCACVT,WAAU;0CAETH;;4BAEFQ,4BACC,KAACG;gCAAIC,aAAU;gCAAuBT,WAAU;0CAC7CF,SAASY,IAAI,CAACC,uBACb,KAACC;wCAECH,aAAU;wCACVI,MAAK;wCACLC,SAASH,OAAOG,OAAO;wCACvBd,WAAU;kDAETW,OAAOI,KAAK;uCANRJ,OAAOI,KAAK;;;uCAa3B;;4BACGX,cAAc,CAACH,0BACd,KAACO;gCACCC,aAAU;gCACVT,WAAU;0CAETH;;4BAGJQ,4BACC,KAACG;gCAAIC,aAAU;gCAAuBT,WAAU;0CAC7CF,SAASY,IAAI,CAACC,uBACb,KAACC;wCAECH,aAAU;wCACVI,MAAK;wCACLC,SAASH,OAAOG,OAAO;wCACvBd,WAAU;kDAETW,OAAOI,KAAK;uCANRJ,OAAOI,KAAK;;;;;;YAe9BhB,yBACC,KAACa;gBACCH,aAAU;gBACVI,MAAK;gBACLC,SAASf;gBACTC,WAAU;gBACVgB,cAAW;0BAEX,cAAA,KAACpC;oBAAKY,MAAK;oBAAQQ,WAAU;;;;;AAKvC"}
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
import { type ToasterProps as SonnerToasterProps, toast as sonnerToast } from 'sonner';
|
|
2
|
+
type ToasterProps = Omit<SonnerToasterProps, 'theme'>;
|
|
3
|
+
declare function Toaster({ ...props }: ToasterProps): import("react/jsx-runtime").JSX.Element;
|
|
4
|
+
export { Toaster, sonnerToast as toast, type ToasterProps };
|
|
5
|
+
//# sourceMappingURL=toast.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"toast.d.ts","sourceRoot":"","sources":["../../../src/components/toast/toast.tsx"],"names":[],"mappings":"AAEA,OAAO,EAEL,KAAK,YAAY,IAAI,kBAAkB,EACvC,KAAK,IAAI,WAAW,EACrB,MAAM,QAAQ,CAAC;AAEhB,KAAK,YAAY,GAAG,IAAI,CAAC,kBAAkB,EAAE,OAAO,CAAC,CAAC;AAEtD,iBAAS,OAAO,CAAC,EAAC,GAAG,KAAK,EAAC,EAAE,YAAY,2CA4BxC;AAED,OAAO,EAAC,OAAO,EAAE,WAAW,IAAI,KAAK,EAAE,KAAK,YAAY,EAAC,CAAC"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { useTheme } from '../../hooks/useTheme.js';
|
|
3
|
+
import { AlertTriangle, CheckCircle2, Info, Loader2, XCircle } from 'lucide-react';
|
|
4
|
+
import { Toaster as SonnerToaster, toast as sonnerToast } from 'sonner';
|
|
5
|
+
function Toaster({ ...props }) {
|
|
6
|
+
const { theme } = useTheme();
|
|
7
|
+
return /*#__PURE__*/ _jsx(SonnerToaster, {
|
|
8
|
+
theme: theme,
|
|
9
|
+
className: "toaster group",
|
|
10
|
+
toastOptions: {
|
|
11
|
+
classNames: {
|
|
12
|
+
toast: 'group toast group-[.toaster]:bg-background-components-base group-[.toaster]:text-foreground-neutral-base group-[.toaster]:border group-[.toaster]:border-border-neutral-base group-[.toaster]:shadow-tooltip rounded-8 p-8',
|
|
13
|
+
description: 'group-[.toast]:text-foreground-neutral-muted text-xs leading-20 mt-4',
|
|
14
|
+
actionButton: 'group-[.toast]:bg-background-button-neutral-default group-[.toast]:text-foreground-neutral-base group-[.toast]:hover:bg-background-button-neutral-hover rounded-6 px-8 py-4 text-xs font-medium',
|
|
15
|
+
cancelButton: 'group-[.toast]:bg-background-button-transparent-default group-[.toast]:text-foreground-neutral-base group-[.toast]:hover:bg-background-button-transparent-hover rounded-6 px-8 py-4 text-xs font-medium'
|
|
16
|
+
}
|
|
17
|
+
},
|
|
18
|
+
icons: {
|
|
19
|
+
success: /*#__PURE__*/ _jsx(CheckCircle2, {
|
|
20
|
+
className: "size-20 text-tag-success-icon"
|
|
21
|
+
}),
|
|
22
|
+
info: /*#__PURE__*/ _jsx(Info, {
|
|
23
|
+
className: "size-20 text-tag-blue-icon"
|
|
24
|
+
}),
|
|
25
|
+
warning: /*#__PURE__*/ _jsx(AlertTriangle, {
|
|
26
|
+
className: "size-20 text-tag-warning-icon"
|
|
27
|
+
}),
|
|
28
|
+
error: /*#__PURE__*/ _jsx(XCircle, {
|
|
29
|
+
className: "size-20 text-tag-error-icon"
|
|
30
|
+
}),
|
|
31
|
+
loading: /*#__PURE__*/ _jsx(Loader2, {
|
|
32
|
+
className: "size-20 text-tag-neutral-icon animate-spin"
|
|
33
|
+
})
|
|
34
|
+
},
|
|
35
|
+
...props
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
export { Toaster, sonnerToast as toast };
|
|
39
|
+
|
|
40
|
+
//# sourceMappingURL=toast.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"sources":["../../../src/components/toast/toast.tsx"],"sourcesContent":["import {useTheme} from 'hooks/useTheme';\nimport {AlertTriangle, CheckCircle2, Info, Loader2, XCircle} from 'lucide-react';\nimport {\n Toaster as SonnerToaster,\n type ToasterProps as SonnerToasterProps,\n toast as sonnerToast,\n} from 'sonner';\n\ntype ToasterProps = Omit<SonnerToasterProps, 'theme'>;\n\nfunction Toaster({...props}: ToasterProps) {\n const {theme} = useTheme();\n\n return (\n <SonnerToaster\n theme={theme as SonnerToasterProps['theme']}\n className=\"toaster group\"\n toastOptions={{\n classNames: {\n toast:\n 'group toast group-[.toaster]:bg-background-components-base group-[.toaster]:text-foreground-neutral-base group-[.toaster]:border group-[.toaster]:border-border-neutral-base group-[.toaster]:shadow-tooltip rounded-8 p-8',\n description: 'group-[.toast]:text-foreground-neutral-muted text-xs leading-20 mt-4',\n actionButton:\n 'group-[.toast]:bg-background-button-neutral-default group-[.toast]:text-foreground-neutral-base group-[.toast]:hover:bg-background-button-neutral-hover rounded-6 px-8 py-4 text-xs font-medium',\n cancelButton:\n 'group-[.toast]:bg-background-button-transparent-default group-[.toast]:text-foreground-neutral-base group-[.toast]:hover:bg-background-button-transparent-hover rounded-6 px-8 py-4 text-xs font-medium',\n },\n }}\n icons={{\n success: <CheckCircle2 className=\"size-20 text-tag-success-icon\" />,\n info: <Info className=\"size-20 text-tag-blue-icon\" />,\n warning: <AlertTriangle className=\"size-20 text-tag-warning-icon\" />,\n error: <XCircle className=\"size-20 text-tag-error-icon\" />,\n loading: <Loader2 className=\"size-20 text-tag-neutral-icon animate-spin\" />,\n }}\n {...props}\n />\n );\n}\n\nexport {Toaster, sonnerToast as toast, type ToasterProps};\n"],"names":["useTheme","AlertTriangle","CheckCircle2","Info","Loader2","XCircle","Toaster","SonnerToaster","toast","sonnerToast","props","theme","className","toastOptions","classNames","description","actionButton","cancelButton","icons","success","info","warning","error","loading"],"mappings":";AAAA,SAAQA,QAAQ,QAAO,iBAAiB;AACxC,SAAQC,aAAa,EAAEC,YAAY,EAAEC,IAAI,EAAEC,OAAO,EAAEC,OAAO,QAAO,eAAe;AACjF,SACEC,WAAWC,aAAa,EAExBC,SAASC,WAAW,QACf,SAAS;AAIhB,SAASH,QAAQ,EAAC,GAAGI,OAAoB;IACvC,MAAM,EAACC,KAAK,EAAC,GAAGX;IAEhB,qBACE,KAACO;QACCI,OAAOA;QACPC,WAAU;QACVC,cAAc;YACZC,YAAY;gBACVN,OACE;gBACFO,aAAa;gBACbC,cACE;gBACFC,cACE;YACJ;QACF;QACAC,OAAO;YACLC,uBAAS,KAACjB;gBAAaU,WAAU;;YACjCQ,oBAAM,KAACjB;gBAAKS,WAAU;;YACtBS,uBAAS,KAACpB;gBAAcW,WAAU;;YAClCU,qBAAO,KAACjB;gBAAQO,WAAU;;YAC1BW,uBAAS,KAACnB;gBAAQQ,WAAU;;QAC9B;QACC,GAAGF,KAAK;;AAGf;AAEA,SAAQJ,OAAO,EAAEG,eAAeD,KAAK,GAAqB"}
|