@finsweet/webflow-apps-utils 1.0.42 → 1.0.44
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/ui/components/Loader.stories.js +163 -0
- package/dist/ui/components/LoadingScreen.stories.js +242 -0
- package/dist/ui/components/checkbox/Checkbox.svelte +10 -10
- package/dist/ui/components/copy-text/CopyText.svelte +1 -1
- package/dist/ui/components/modal/Modal.svelte +2 -2
- package/dist/ui/components/select/Select.svelte +4 -0
- package/dist/ui/components/shared/ImageUpload.svelte +2 -2
- package/dist/ui/icons/AccordionDownArrow.svelte +2 -2
- package/dist/ui/icons/AccordionUpArrow.svelte +2 -2
- package/dist/ui/icons/AccountIcon.svelte +3 -3
- package/dist/ui/icons/AiIcon.svelte +8 -0
- package/dist/ui/icons/{CloseIcon.svelte.d.ts → AiIcon.svelte.d.ts} +3 -3
- package/dist/ui/icons/AnalyticsIcon.svelte +24 -0
- package/dist/ui/icons/{DeleteOutlinedIcon.svelte.d.ts → AnalyticsIcon.svelte.d.ts} +3 -3
- package/dist/ui/icons/ArrowIcon.svelte +7 -1
- package/dist/ui/icons/BackIcon.svelte +7 -1
- package/dist/ui/icons/BodyIcon.svelte +1 -1
- package/dist/ui/icons/BookmarkIcon.svelte +1 -1
- package/dist/ui/icons/BoxAddIcon.svelte +2 -2
- package/dist/ui/icons/BrushIcon.svelte +1 -1
- package/dist/ui/icons/BuilderEditIcon.svelte +1 -1
- package/dist/ui/icons/BuilderIcon.svelte +1 -1
- package/dist/ui/icons/CMSIcon.svelte +1 -1
- package/dist/ui/icons/CalendarIcon.svelte +8 -0
- package/dist/ui/icons/CalendarIcon.svelte.d.ts +26 -0
- package/dist/ui/icons/CheckCircleIcon.svelte +1 -1
- package/dist/ui/icons/CheckCircleOutlinedIcon.svelte +1 -1
- package/dist/ui/icons/CheckIcon.svelte +1 -1
- package/dist/ui/icons/CheckboxCheckedIcon.svelte +2 -2
- package/dist/ui/icons/ChevronIcon.svelte +7 -1
- package/dist/ui/icons/ChevronRightIcon.svelte +7 -1
- package/dist/ui/icons/CircleIcon.svelte +1 -1
- package/dist/ui/icons/CircleTimesIcon.svelte +19 -0
- package/dist/ui/icons/CircleTimesIcon.svelte.d.ts +26 -0
- package/dist/ui/icons/CloseCircleIcon.svelte +2 -2
- package/dist/ui/icons/CodeIcon.svelte +1 -1
- package/dist/ui/icons/ComponentsIcon.svelte +1 -1
- package/dist/ui/icons/CookieBannerIcon.svelte +12 -0
- package/dist/ui/icons/CookieBannerIcon.svelte.d.ts +26 -0
- package/dist/ui/icons/CookieIcon.svelte +1 -1
- package/dist/ui/icons/CopyIcon.svelte +1 -11
- package/dist/ui/icons/CopyIcon.svelte.d.ts +15 -9
- package/dist/ui/icons/CrossIcon.svelte +3 -3
- package/dist/ui/icons/DOMElement.svelte +2 -7
- package/dist/ui/icons/DOMElement.svelte.d.ts +3 -5
- package/dist/ui/icons/DeleteIcon.svelte +7 -1
- package/dist/ui/icons/Desktop.svelte +1 -12
- package/dist/ui/icons/Desktop.svelte.d.ts +15 -10
- package/dist/ui/icons/DesktopWithStar.svelte +1 -12
- package/dist/ui/icons/DesktopWithStar.svelte.d.ts +15 -10
- package/dist/ui/icons/DivBlock.svelte +2 -7
- package/dist/ui/icons/DivBlock.svelte.d.ts +3 -5
- package/dist/ui/icons/EditIcon.svelte +2 -2
- package/dist/ui/icons/EssentialIcon.svelte +8 -0
- package/dist/ui/icons/EssentialIcon.svelte.d.ts +26 -0
- package/dist/ui/icons/ExpertIcon.svelte +1 -1
- package/dist/ui/icons/EyeCancelIcon.svelte +1 -1
- package/dist/ui/icons/EyeIcon.svelte +1 -1
- package/dist/ui/icons/FavouriteIcon.svelte +1 -1
- package/dist/ui/icons/FileUploadIcon.svelte +3 -3
- package/dist/ui/icons/FilterIcon.svelte +1 -1
- package/dist/ui/icons/FinsweetLibraryIcon.svelte +1 -1
- package/dist/ui/icons/FinsweetLogoIcon.svelte +1 -1
- package/dist/ui/icons/FinsweetLogoOutlineIcon.svelte +1 -1
- package/dist/ui/icons/FolderIcon.svelte +1 -1
- package/dist/ui/icons/FolderOutlinedIcon.svelte +1 -1
- package/dist/ui/icons/FolderPlusIcon.svelte +1 -1
- package/dist/ui/icons/FreeComponentIcon.svelte +1 -1
- package/dist/ui/icons/GlobeCheckedIcon.svelte +14 -0
- package/dist/ui/icons/GlobeCheckedIcon.svelte.d.ts +26 -0
- package/dist/ui/icons/GlobeIcon.svelte +1 -1
- package/dist/ui/icons/GlobeWarningIcon.svelte +12 -0
- package/dist/ui/icons/GlobeWarningIcon.svelte.d.ts +26 -0
- package/dist/ui/icons/HandPointUpIcon.svelte +2 -2
- package/dist/ui/icons/HeartIcon.svelte +1 -1
- package/dist/ui/icons/HeartIconOutlined.svelte +1 -1
- package/dist/ui/icons/HelpAltIcon.svelte +2 -2
- package/dist/ui/icons/HelpIcon.svelte +13 -4
- package/dist/ui/icons/HomeIcon.svelte +1 -1
- package/dist/ui/icons/Icons.stories.js +55 -0
- package/dist/ui/icons/IconsShowcase.svelte +142 -0
- package/dist/ui/icons/IconsShowcase.svelte.d.ts +21 -0
- package/dist/ui/icons/InfoIcon.svelte +1 -1
- package/dist/ui/icons/LineChartIcon.svelte +1 -1
- package/dist/ui/icons/ListIcon.svelte +1 -1
- package/dist/ui/icons/LockIcon.svelte +3 -3
- package/dist/ui/icons/LogoutIcon.svelte +10 -0
- package/dist/ui/icons/LogoutIcon.svelte.d.ts +26 -0
- package/dist/ui/icons/MessageIcon.svelte +7 -1
- package/dist/ui/icons/MobileLandscape.svelte +1 -12
- package/dist/ui/icons/MobileLandscape.svelte.d.ts +15 -10
- package/dist/ui/icons/MobilePortrait.svelte +1 -12
- package/dist/ui/icons/MobilePortrait.svelte.d.ts +15 -10
- package/dist/ui/icons/NavigatorIcon.svelte +1 -1
- package/dist/ui/icons/OpenBookIcon.svelte +1 -1
- package/dist/ui/icons/PageDraftIcon.svelte +2 -2
- package/dist/ui/icons/PageIcon.svelte +1 -1
- package/dist/ui/icons/PageLockedIcon.svelte +2 -2
- package/dist/ui/icons/PageOutlinedIcon.svelte +1 -1
- package/dist/ui/icons/PageSectionIcon.svelte +1 -1
- package/dist/ui/icons/Pencil.svelte +1 -5
- package/dist/ui/icons/Pencil.svelte.d.ts +15 -9
- package/dist/ui/icons/PencilOutlinedIcon.svelte +7 -1
- package/dist/ui/icons/PinIcon.svelte +7 -1
- package/dist/ui/icons/PlayIcon.svelte +1 -1
- package/dist/ui/icons/PlusIcon.svelte +8 -2
- package/dist/ui/icons/PolicyIcon.svelte +7 -0
- package/dist/ui/icons/PolicyIcon.svelte.d.ts +26 -0
- package/dist/ui/icons/PreviewEyeIcon.svelte +3 -3
- package/dist/ui/icons/ProfileIcon.svelte +1 -1
- package/dist/ui/icons/PublishCancelIcon.svelte +1 -1
- package/dist/ui/icons/PublishIcon.svelte +1 -1
- package/dist/ui/icons/ReceiptIcon.svelte +1 -1
- package/dist/ui/icons/RefreshIcon.svelte +1 -1
- package/dist/ui/icons/RepairIcon.svelte +1 -1
- package/dist/ui/icons/SaveIcon.svelte +2 -2
- package/dist/ui/icons/SearchCancelIcon.svelte +12 -0
- package/dist/ui/icons/SearchCancelIcon.svelte.d.ts +26 -0
- package/dist/ui/icons/SearchIcon.svelte +1 -1
- package/dist/ui/icons/SelectIcon.svelte +1 -1
- package/dist/ui/icons/SettingsIcon.svelte +1 -1
- package/dist/ui/icons/ShopIcon.svelte +12 -0
- package/dist/ui/icons/ShopIcon.svelte.d.ts +26 -0
- package/dist/ui/icons/SidebarToggleIcon.svelte +4 -4
- package/dist/ui/icons/SliderAppIcon.svelte +1 -1
- package/dist/ui/icons/SquareCheckIcon.svelte +1 -1
- package/dist/ui/icons/StarIcon.svelte +1 -1
- package/dist/ui/icons/StarOutlinedIcon.svelte +9 -2
- package/dist/ui/icons/StaticContentIcon.svelte +1 -1
- package/dist/ui/icons/TabNewIcon.svelte +7 -1
- package/dist/ui/icons/TableAppIcon.svelte +1 -1
- package/dist/ui/icons/Tablet.svelte +2 -13
- package/dist/ui/icons/Tablet.svelte.d.ts +15 -10
- package/dist/ui/icons/TabletPreview.svelte +1 -12
- package/dist/ui/icons/TabletPreview.svelte.d.ts +15 -10
- package/dist/ui/icons/TabsIcon.svelte +1 -1
- package/dist/ui/icons/ThreeDotsIcon.svelte +1 -1
- package/dist/ui/icons/TimesIcon.svelte +3 -3
- package/dist/ui/icons/ToolTipInfoCircleIcon.svelte +4 -4
- package/dist/ui/icons/TooltipInfoCircleFilled.svelte +2 -2
- package/dist/ui/icons/TooltipInfoSquaredIcon.svelte +13 -4
- package/dist/ui/icons/TriangleDownIcon.svelte +2 -2
- package/dist/ui/icons/TriangleDownIconToggle.svelte +3 -3
- package/dist/ui/icons/UncategorizedIcon.svelte +16 -0
- package/dist/ui/icons/UncategorizedIcon.svelte.d.ts +26 -0
- package/dist/ui/icons/UndoIcon.svelte +1 -1
- package/dist/ui/icons/UpgradeIcon.svelte +26 -0
- package/dist/ui/icons/UpgradeIcon.svelte.d.ts +26 -0
- package/dist/ui/icons/UploadFileIcon.svelte +3 -3
- package/dist/ui/icons/WarningCircleIcon.svelte +1 -1
- package/dist/ui/icons/WarningCircleOutlineIcon.svelte +7 -1
- package/dist/ui/icons/WarningTriangleIcon.svelte +1 -1
- package/dist/ui/icons/WarningTriangleOutlineIcon.svelte +2 -2
- package/dist/ui/icons/WebflowComponentIcon.svelte +1 -1
- package/dist/ui/icons/WebflowComponentOutlinedIcon.svelte +1 -1
- package/dist/ui/icons/WebflowInsightsIcon.svelte +1 -1
- package/dist/ui/icons/WizedLogoIcon.svelte +1 -1
- package/dist/ui/icons/WorkspaceIcon.svelte +1 -1
- package/dist/ui/icons/XL.svelte +1 -12
- package/dist/ui/icons/XL.svelte.d.ts +15 -10
- package/dist/ui/icons/XXL.svelte +1 -12
- package/dist/ui/icons/XXL.svelte.d.ts +15 -10
- package/dist/ui/icons/XXXL.svelte +1 -12
- package/dist/ui/icons/XXXL.svelte.d.ts +15 -10
- package/dist/ui/icons/index.d.ts +15 -4
- package/dist/ui/icons/index.js +15 -4
- package/dist/ui/index.css +6 -0
- package/package.json +1 -1
- package/dist/ui/icons/CloseIcon.svelte +0 -8
- package/dist/ui/icons/DeleteOutlinedIcon.svelte +0 -8
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
import Loader from './Loader.svelte';
|
|
2
|
+
const meta = {
|
|
3
|
+
title: 'Ui/Loader',
|
|
4
|
+
component: Loader,
|
|
5
|
+
parameters: {
|
|
6
|
+
layout: 'centered',
|
|
7
|
+
docs: {
|
|
8
|
+
description: {
|
|
9
|
+
component: 'A customizable loading spinner component with proportional sizing, configurable colors, and adjustable animation speed.'
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
},
|
|
13
|
+
tags: ['autodocs'],
|
|
14
|
+
argTypes: {
|
|
15
|
+
size: {
|
|
16
|
+
control: { type: 'range', min: 16, max: 200, step: 4 },
|
|
17
|
+
description: 'The size of the loader in pixels'
|
|
18
|
+
},
|
|
19
|
+
color: {
|
|
20
|
+
control: 'color',
|
|
21
|
+
description: 'The color of the spinning arc'
|
|
22
|
+
},
|
|
23
|
+
speed: {
|
|
24
|
+
control: { type: 'range', min: 0.5, max: 3, step: 0.1 },
|
|
25
|
+
description: 'Animation speed in seconds (lower is faster)'
|
|
26
|
+
},
|
|
27
|
+
margin: {
|
|
28
|
+
control: 'text',
|
|
29
|
+
description: 'CSS margin value for the loader wrapper'
|
|
30
|
+
},
|
|
31
|
+
trackColor: {
|
|
32
|
+
control: 'color',
|
|
33
|
+
description: 'The color of the background track circle'
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
};
|
|
37
|
+
export default meta;
|
|
38
|
+
// Basic stories
|
|
39
|
+
export const Default = {
|
|
40
|
+
args: {}
|
|
41
|
+
};
|
|
42
|
+
export const Small = {
|
|
43
|
+
args: {
|
|
44
|
+
size: 24
|
|
45
|
+
}
|
|
46
|
+
};
|
|
47
|
+
export const Medium = {
|
|
48
|
+
args: {
|
|
49
|
+
size: 48
|
|
50
|
+
}
|
|
51
|
+
};
|
|
52
|
+
export const Large = {
|
|
53
|
+
args: {
|
|
54
|
+
size: 96
|
|
55
|
+
}
|
|
56
|
+
};
|
|
57
|
+
export const ExtraLarge = {
|
|
58
|
+
args: {
|
|
59
|
+
size: 150
|
|
60
|
+
}
|
|
61
|
+
};
|
|
62
|
+
// Color variants
|
|
63
|
+
export const Primary = {
|
|
64
|
+
args: {
|
|
65
|
+
color: '#3b82f6',
|
|
66
|
+
size: 64
|
|
67
|
+
}
|
|
68
|
+
};
|
|
69
|
+
export const Success = {
|
|
70
|
+
args: {
|
|
71
|
+
color: '#22c55e',
|
|
72
|
+
size: 64
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
export const Warning = {
|
|
76
|
+
args: {
|
|
77
|
+
color: '#f59e0b',
|
|
78
|
+
size: 64
|
|
79
|
+
}
|
|
80
|
+
};
|
|
81
|
+
export const Error = {
|
|
82
|
+
args: {
|
|
83
|
+
color: '#ef4444',
|
|
84
|
+
size: 64
|
|
85
|
+
}
|
|
86
|
+
};
|
|
87
|
+
export const CustomColors = {
|
|
88
|
+
args: {
|
|
89
|
+
color: '#8b5cf6',
|
|
90
|
+
trackColor: '#c084fc',
|
|
91
|
+
size: 64
|
|
92
|
+
}
|
|
93
|
+
};
|
|
94
|
+
// Speed variants
|
|
95
|
+
export const Slow = {
|
|
96
|
+
args: {
|
|
97
|
+
speed: 2,
|
|
98
|
+
size: 64
|
|
99
|
+
},
|
|
100
|
+
parameters: {
|
|
101
|
+
docs: {
|
|
102
|
+
description: {
|
|
103
|
+
story: 'Slower animation speed (2 seconds per rotation)'
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
};
|
|
108
|
+
export const Fast = {
|
|
109
|
+
args: {
|
|
110
|
+
speed: 0.5,
|
|
111
|
+
size: 64
|
|
112
|
+
},
|
|
113
|
+
parameters: {
|
|
114
|
+
docs: {
|
|
115
|
+
description: {
|
|
116
|
+
story: 'Faster animation speed (0.5 seconds per rotation)'
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
};
|
|
121
|
+
// With margin
|
|
122
|
+
export const WithMargin = {
|
|
123
|
+
args: {
|
|
124
|
+
margin: '20px',
|
|
125
|
+
size: 64
|
|
126
|
+
}
|
|
127
|
+
};
|
|
128
|
+
// Dark background showcase
|
|
129
|
+
export const OnDarkBackground = {
|
|
130
|
+
args: {
|
|
131
|
+
color: 'white',
|
|
132
|
+
trackColor: 'rgba(255, 255, 255, 0.2)',
|
|
133
|
+
size: 64
|
|
134
|
+
},
|
|
135
|
+
parameters: {
|
|
136
|
+
backgrounds: { default: 'dark' }
|
|
137
|
+
}
|
|
138
|
+
};
|
|
139
|
+
// Light background showcase
|
|
140
|
+
export const OnLightBackground = {
|
|
141
|
+
args: {
|
|
142
|
+
color: '#1e293b',
|
|
143
|
+
trackColor: 'rgba(30, 41, 59, 0.2)',
|
|
144
|
+
size: 64
|
|
145
|
+
},
|
|
146
|
+
parameters: {
|
|
147
|
+
backgrounds: { default: 'light' }
|
|
148
|
+
}
|
|
149
|
+
};
|
|
150
|
+
// Multiple sizes comparison
|
|
151
|
+
export const SizeComparison = {
|
|
152
|
+
render: () => ({
|
|
153
|
+
Component: Loader,
|
|
154
|
+
props: {}
|
|
155
|
+
}),
|
|
156
|
+
parameters: {
|
|
157
|
+
docs: {
|
|
158
|
+
description: {
|
|
159
|
+
story: 'Visual comparison of different loader sizes'
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
};
|
|
@@ -0,0 +1,242 @@
|
|
|
1
|
+
import LoadingScreen from './LoadingScreen.svelte';
|
|
2
|
+
const meta = {
|
|
3
|
+
title: 'Ui/LoadingScreen',
|
|
4
|
+
component: LoadingScreen,
|
|
5
|
+
parameters: {
|
|
6
|
+
layout: 'fullscreen',
|
|
7
|
+
docs: {
|
|
8
|
+
description: {
|
|
9
|
+
component: 'A full-screen loading overlay component with customizable messaging, error states, and support for both fixed and absolute positioning.'
|
|
10
|
+
}
|
|
11
|
+
}
|
|
12
|
+
},
|
|
13
|
+
tags: ['autodocs'],
|
|
14
|
+
argTypes: {
|
|
15
|
+
message: {
|
|
16
|
+
control: 'text',
|
|
17
|
+
description: 'The message to display below the loader or error icon'
|
|
18
|
+
},
|
|
19
|
+
position: {
|
|
20
|
+
control: { type: 'select' },
|
|
21
|
+
options: ['fixed', 'absolute'],
|
|
22
|
+
description: 'CSS position property for the loading screen'
|
|
23
|
+
},
|
|
24
|
+
active: {
|
|
25
|
+
control: 'boolean',
|
|
26
|
+
description: 'Controls visibility of the loading screen'
|
|
27
|
+
},
|
|
28
|
+
error: {
|
|
29
|
+
control: 'boolean',
|
|
30
|
+
description: 'If true, displays error state with warning icon'
|
|
31
|
+
},
|
|
32
|
+
raw: {
|
|
33
|
+
control: 'boolean',
|
|
34
|
+
description: 'If true, renders HTML in the message (use with caution)'
|
|
35
|
+
},
|
|
36
|
+
backgroundColor: {
|
|
37
|
+
control: 'color',
|
|
38
|
+
description: 'Background color of the overlay'
|
|
39
|
+
},
|
|
40
|
+
spinnerSize: {
|
|
41
|
+
control: { type: 'range', min: 24, max: 120, step: 4 },
|
|
42
|
+
description: 'Size of the spinner in pixels'
|
|
43
|
+
},
|
|
44
|
+
className: {
|
|
45
|
+
control: 'text',
|
|
46
|
+
description: 'Additional CSS class for the main loader container'
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
};
|
|
50
|
+
export default meta;
|
|
51
|
+
// Basic stories
|
|
52
|
+
export const Default = {
|
|
53
|
+
args: {
|
|
54
|
+
active: true,
|
|
55
|
+
message: 'Loading...'
|
|
56
|
+
}
|
|
57
|
+
};
|
|
58
|
+
export const WithCustomMessage = {
|
|
59
|
+
args: {
|
|
60
|
+
active: true,
|
|
61
|
+
message: 'Please wait while we fetch your data'
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
export const LongMessage = {
|
|
65
|
+
args: {
|
|
66
|
+
active: true,
|
|
67
|
+
message: 'This might take a few moments. Please do not close this window or navigate away.'
|
|
68
|
+
}
|
|
69
|
+
};
|
|
70
|
+
export const NoMessage = {
|
|
71
|
+
args: {
|
|
72
|
+
active: true,
|
|
73
|
+
message: ''
|
|
74
|
+
}
|
|
75
|
+
};
|
|
76
|
+
// Spinner sizes
|
|
77
|
+
export const SmallSpinner = {
|
|
78
|
+
args: {
|
|
79
|
+
active: true,
|
|
80
|
+
message: 'Loading...',
|
|
81
|
+
spinnerSize: 30
|
|
82
|
+
}
|
|
83
|
+
};
|
|
84
|
+
export const LargeSpinner = {
|
|
85
|
+
args: {
|
|
86
|
+
active: true,
|
|
87
|
+
message: 'Loading...',
|
|
88
|
+
spinnerSize: 80
|
|
89
|
+
}
|
|
90
|
+
};
|
|
91
|
+
// Position variants
|
|
92
|
+
export const FixedPosition = {
|
|
93
|
+
args: {
|
|
94
|
+
active: true,
|
|
95
|
+
message: 'Fixed position loading screen',
|
|
96
|
+
position: 'fixed'
|
|
97
|
+
},
|
|
98
|
+
parameters: {
|
|
99
|
+
docs: {
|
|
100
|
+
description: {
|
|
101
|
+
story: 'Fixed positioning covers the entire viewport regardless of scroll position'
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
};
|
|
106
|
+
export const AbsolutePosition = {
|
|
107
|
+
args: {
|
|
108
|
+
active: true,
|
|
109
|
+
message: 'Absolute position loading screen',
|
|
110
|
+
position: 'absolute'
|
|
111
|
+
},
|
|
112
|
+
parameters: {
|
|
113
|
+
docs: {
|
|
114
|
+
description: {
|
|
115
|
+
story: 'Absolute positioning is relative to the nearest positioned ancestor'
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
};
|
|
120
|
+
// Error states
|
|
121
|
+
export const ErrorState = {
|
|
122
|
+
args: {
|
|
123
|
+
active: true,
|
|
124
|
+
error: true,
|
|
125
|
+
message: 'Something went wrong while loading your data.'
|
|
126
|
+
}
|
|
127
|
+
};
|
|
128
|
+
export const ErrorWithDetails = {
|
|
129
|
+
args: {
|
|
130
|
+
active: true,
|
|
131
|
+
error: true,
|
|
132
|
+
message: 'Failed to connect to the server. Please check your internet connection and try again.'
|
|
133
|
+
}
|
|
134
|
+
};
|
|
135
|
+
export const ErrorMinimal = {
|
|
136
|
+
args: {
|
|
137
|
+
active: true,
|
|
138
|
+
error: true,
|
|
139
|
+
message: 'An error occurred.'
|
|
140
|
+
}
|
|
141
|
+
};
|
|
142
|
+
// Background colors
|
|
143
|
+
export const LightBackground = {
|
|
144
|
+
args: {
|
|
145
|
+
active: true,
|
|
146
|
+
message: 'Loading with light background',
|
|
147
|
+
backgroundColor: 'rgba(255, 255, 255, 0.95)'
|
|
148
|
+
}
|
|
149
|
+
};
|
|
150
|
+
export const DarkBackground = {
|
|
151
|
+
args: {
|
|
152
|
+
active: true,
|
|
153
|
+
message: 'Loading with dark background',
|
|
154
|
+
backgroundColor: 'rgba(0, 0, 0, 0.9)'
|
|
155
|
+
}
|
|
156
|
+
};
|
|
157
|
+
export const SemiTransparent = {
|
|
158
|
+
args: {
|
|
159
|
+
active: true,
|
|
160
|
+
message: 'Semi-transparent overlay',
|
|
161
|
+
backgroundColor: 'rgba(30, 30, 30, 0.7)'
|
|
162
|
+
}
|
|
163
|
+
};
|
|
164
|
+
export const ColoredBackground = {
|
|
165
|
+
args: {
|
|
166
|
+
active: true,
|
|
167
|
+
message: 'Custom colored background',
|
|
168
|
+
backgroundColor: 'rgba(59, 130, 246, 0.9)'
|
|
169
|
+
}
|
|
170
|
+
};
|
|
171
|
+
// HTML message with raw prop
|
|
172
|
+
export const RawHTMLMessage = {
|
|
173
|
+
args: {
|
|
174
|
+
active: true,
|
|
175
|
+
raw: true,
|
|
176
|
+
message: 'Loading <strong>important</strong> data<br/>Please wait...'
|
|
177
|
+
},
|
|
178
|
+
parameters: {
|
|
179
|
+
docs: {
|
|
180
|
+
description: {
|
|
181
|
+
story: 'Using raw=true to render HTML in the message. Use with caution and only with trusted content.'
|
|
182
|
+
}
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
};
|
|
186
|
+
// Inactive (hidden)
|
|
187
|
+
export const Inactive = {
|
|
188
|
+
args: {
|
|
189
|
+
active: false,
|
|
190
|
+
message: 'This should not be visible'
|
|
191
|
+
},
|
|
192
|
+
parameters: {
|
|
193
|
+
docs: {
|
|
194
|
+
description: {
|
|
195
|
+
story: 'When active is false, the loading screen is hidden'
|
|
196
|
+
}
|
|
197
|
+
}
|
|
198
|
+
}
|
|
199
|
+
};
|
|
200
|
+
// Use cases
|
|
201
|
+
export const InitialPageLoad = {
|
|
202
|
+
args: {
|
|
203
|
+
active: true,
|
|
204
|
+
message: 'Initializing application...',
|
|
205
|
+
spinnerSize: 60
|
|
206
|
+
}
|
|
207
|
+
};
|
|
208
|
+
export const DataFetch = {
|
|
209
|
+
args: {
|
|
210
|
+
active: true,
|
|
211
|
+
message: 'Fetching data from server...',
|
|
212
|
+
spinnerSize: 50
|
|
213
|
+
}
|
|
214
|
+
};
|
|
215
|
+
export const FileUpload = {
|
|
216
|
+
args: {
|
|
217
|
+
active: true,
|
|
218
|
+
message: 'Uploading files... This may take a moment.',
|
|
219
|
+
spinnerSize: 50
|
|
220
|
+
}
|
|
221
|
+
};
|
|
222
|
+
export const Processing = {
|
|
223
|
+
args: {
|
|
224
|
+
active: true,
|
|
225
|
+
message: 'Processing your request...',
|
|
226
|
+
spinnerSize: 50
|
|
227
|
+
}
|
|
228
|
+
};
|
|
229
|
+
export const NetworkError = {
|
|
230
|
+
args: {
|
|
231
|
+
active: true,
|
|
232
|
+
error: true,
|
|
233
|
+
message: 'Unable to connect to the server. Please check your network connection.'
|
|
234
|
+
}
|
|
235
|
+
};
|
|
236
|
+
export const ServerError = {
|
|
237
|
+
args: {
|
|
238
|
+
active: true,
|
|
239
|
+
error: true,
|
|
240
|
+
message: 'The server encountered an error. Our team has been notified.'
|
|
241
|
+
}
|
|
242
|
+
};
|
|
@@ -88,13 +88,12 @@
|
|
|
88
88
|
.checkbox {
|
|
89
89
|
width: 16px;
|
|
90
90
|
height: 16px;
|
|
91
|
-
border-radius:
|
|
92
|
-
border: 2px solid
|
|
91
|
+
border-radius: 1px;
|
|
92
|
+
border: 2px solid var(--actionSecondaryBorder);
|
|
93
93
|
display: flex;
|
|
94
94
|
justify-content: center;
|
|
95
95
|
align-items: center;
|
|
96
96
|
cursor: pointer;
|
|
97
|
-
transition: all 0.2s ease-in-out;
|
|
98
97
|
}
|
|
99
98
|
|
|
100
99
|
.checkbox--radio {
|
|
@@ -107,14 +106,15 @@
|
|
|
107
106
|
}
|
|
108
107
|
|
|
109
108
|
.checkbox--checked {
|
|
110
|
-
color:
|
|
109
|
+
color: var(--text1);
|
|
111
110
|
border: none;
|
|
112
111
|
}
|
|
113
112
|
|
|
114
113
|
.checkbox--checked :global(svg) {
|
|
115
|
-
color:
|
|
116
|
-
background:
|
|
117
|
-
border-radius:
|
|
114
|
+
color: var(--text1);
|
|
115
|
+
background: var(--actionPrimaryBackground);
|
|
116
|
+
border-radius: 1px;
|
|
117
|
+
padding: 2px;
|
|
118
118
|
}
|
|
119
119
|
|
|
120
120
|
.checkbox--checked.checkbox--radio :global(svg) {
|
|
@@ -127,15 +127,15 @@
|
|
|
127
127
|
}
|
|
128
128
|
|
|
129
129
|
.checkbox:focus-visible {
|
|
130
|
-
outline: 2px solid var(--
|
|
130
|
+
outline: 2px solid var(--actionPrimaryBackground);
|
|
131
131
|
outline-offset: 2px;
|
|
132
132
|
}
|
|
133
133
|
|
|
134
134
|
.checkbox:hover:not(.checkbox--disabled) {
|
|
135
|
-
border-color:
|
|
135
|
+
border-color: var(--actionSecondaryBorder);
|
|
136
136
|
}
|
|
137
137
|
|
|
138
138
|
.checkbox--checked:hover:not(.checkbox--disabled) :global(svg) {
|
|
139
|
-
background:
|
|
139
|
+
background: var(--actionPrimaryBackground);
|
|
140
140
|
}
|
|
141
141
|
</style>
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
import type { Component, Snippet } from 'svelte';
|
|
3
3
|
import { onMount, tick } from 'svelte';
|
|
4
4
|
|
|
5
|
-
import {
|
|
5
|
+
import { TimesIcon } from '../../icons';
|
|
6
6
|
import { Button, LoadingScreen, Text } from '../';
|
|
7
7
|
|
|
8
8
|
interface Props {
|
|
@@ -158,7 +158,7 @@
|
|
|
158
158
|
header,
|
|
159
159
|
children,
|
|
160
160
|
footer,
|
|
161
|
-
closeIcon =
|
|
161
|
+
closeIcon = TimesIcon,
|
|
162
162
|
onOpenChange,
|
|
163
163
|
onOverlayClick,
|
|
164
164
|
onEscapeKeyDown,
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
import { createEventDispatcher } from 'svelte';
|
|
3
3
|
import { onDestroy } from 'svelte';
|
|
4
4
|
|
|
5
|
-
import {
|
|
5
|
+
import { DeleteIcon, FileUploadIcon, RefreshIcon } from '../../icons';
|
|
6
6
|
import { Button } from '../button';
|
|
7
7
|
import { Text } from '../text';
|
|
8
8
|
|
|
@@ -134,7 +134,7 @@
|
|
|
134
134
|
{#if previewUrl}
|
|
135
135
|
<div class="action-buttons">
|
|
136
136
|
<Button text="Replace" variant="secondary" onclick={triggerFileInput} icon={RefreshIcon} />
|
|
137
|
-
<Button text="Delete" variant="secondary" onclick={reset} icon={
|
|
137
|
+
<Button text="Delete" variant="secondary" onclick={reset} icon={DeleteIcon} />
|
|
138
138
|
</div>
|
|
139
139
|
{/if}
|
|
140
140
|
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
<svg width="
|
|
1
|
+
<svg width="100%" height="100%" viewBox="0 0 10 6" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
2
2
|
<path
|
|
3
3
|
fill-rule="evenodd"
|
|
4
4
|
clip-rule="evenodd"
|
|
5
5
|
d="M4.99996 4.29293L8.64641 0.646484L9.35352 1.35359L4.99996 5.70714L0.646408 1.35359L1.35352 0.646484L4.99996 4.29293Z"
|
|
6
|
-
fill="
|
|
6
|
+
fill="currentColor"
|
|
7
7
|
/>
|
|
8
8
|
</svg>
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
<svg width="
|
|
1
|
+
<svg width="100%" height="100%" viewBox="0 0 10 6" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
2
2
|
<path
|
|
3
3
|
fill-rule="evenodd"
|
|
4
4
|
clip-rule="evenodd"
|
|
5
5
|
d="M5.00004 1.70707L1.35359 5.35352L0.646484 4.64641L5.00004 0.292855L9.35359 4.64641L8.64648 5.35351L5.00004 1.70707Z"
|
|
6
|
-
fill="
|
|
6
|
+
fill="currentColor"
|
|
7
7
|
/>
|
|
8
8
|
</svg>
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
<svg width="
|
|
1
|
+
<svg width="100%" height="100%" viewBox="0 0 16 16" fill="none" xmlns="http://www.w3.org/2000/svg">
|
|
2
2
|
<g id="Account">
|
|
3
3
|
<g id="icon">
|
|
4
4
|
<path
|
|
5
5
|
d="M11 5.5C11 7.15685 9.65685 8.5 8 8.5C6.34315 8.5 5 7.15685 5 5.5C5 3.84315 6.34315 2.5 8 2.5C9.65685 2.5 11 3.84315 11 5.5Z"
|
|
6
|
-
fill="
|
|
6
|
+
fill="currentColor"
|
|
7
7
|
/>
|
|
8
8
|
<path
|
|
9
9
|
d="M6.54545 10H9.45455C9.95455 10 10.6909 10.243 11.0909 10.54L13.2727 12.16C13.6727 12.457 14 13.105 14 13.6V14.5H2V13.6C2 13.105 2.32727 12.457 2.72727 12.16L4.90909 10.54C5.30909 10.243 6.04546 10 6.54545 10Z"
|
|
10
|
-
fill="
|
|
10
|
+
fill="currentColor"
|
|
11
11
|
/>
|
|
12
12
|
</g>
|
|
13
13
|
</g>
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
<svg xmlns="http://www.w3.org/2000/svg" width="100%" height="100%" viewBox="0 0 10 10" fill="none">
|
|
2
|
+
<path
|
|
3
|
+
fill-rule="evenodd"
|
|
4
|
+
clip-rule="evenodd"
|
|
5
|
+
d="M0 5.08696V4.30435C2.37723 4.30435 4.30435 2.37723 4.30435 0H5.08696C5.08696 2.37723 7.01405 4.30435 9.3913 4.30435V5.08696C7.01405 5.08696 5.08696 7.01405 5.08696 9.3913H4.30435C4.30435 7.01405 2.37723 5.08696 0 5.08696ZM4.69565 7.43134C5.21102 6.19807 6.19807 5.21102 7.43134 4.69565C6.19807 4.18029 5.21102 3.19323 4.69565 1.95996C4.18029 3.19323 3.19323 4.18029 1.95996 4.69565C3.19323 5.21102 4.18029 6.19807 4.69565 7.43134Z"
|
|
6
|
+
fill="currentColor"
|
|
7
|
+
/>
|
|
8
|
+
</svg>
|
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
export default
|
|
2
|
-
type
|
|
1
|
+
export default AiIcon;
|
|
2
|
+
type AiIcon = SvelteComponent<{
|
|
3
3
|
[x: string]: never;
|
|
4
4
|
}, {
|
|
5
5
|
[evt: string]: CustomEvent<any>;
|
|
6
6
|
}, {}> & {
|
|
7
7
|
$$bindings?: string | undefined;
|
|
8
8
|
};
|
|
9
|
-
declare const
|
|
9
|
+
declare const AiIcon: $$__sveltets_2_IsomorphicComponent<{
|
|
10
10
|
[x: string]: never;
|
|
11
11
|
}, {
|
|
12
12
|
[evt: string]: CustomEvent<any>;
|
|
@@ -0,0 +1,24 @@
|
|
|
1
|
+
<svg xmlns="http://www.w3.org/2000/svg" width="100%" height="100%" viewBox="0 0 16 16" fill="none">
|
|
2
|
+
<g opacity="0.4">
|
|
3
|
+
<path
|
|
4
|
+
d="M8.00033 4.5C8.00033 4.22386 8.22418 4 8.50033 4H9.50033C9.77647 4 10.0003 4.22386 10.0003 4.5V7L8.00033 9V4.5Z"
|
|
5
|
+
fill="currentColor"
|
|
6
|
+
/>
|
|
7
|
+
<path
|
|
8
|
+
d="M4.66699 11.5C4.66699 11.7761 4.89085 12 5.16699 12H6.66699V11.6667L4.66699 9.66667V11.5Z"
|
|
9
|
+
fill="currentColor"
|
|
10
|
+
/>
|
|
11
|
+
<path
|
|
12
|
+
d="M10.0003 11.5C10.0003 11.7761 9.77647 12 9.50033 12H8.33366L10.0003 10.3333V11.5Z"
|
|
13
|
+
fill="currentColor"
|
|
14
|
+
/>
|
|
15
|
+
<path
|
|
16
|
+
d="M6.66699 7.16667C6.66699 6.89052 6.44313 6.66667 6.16699 6.66667H5.00033L6.66699 8.33333V7.16667Z"
|
|
17
|
+
fill="currentColor"
|
|
18
|
+
/>
|
|
19
|
+
</g>
|
|
20
|
+
<path
|
|
21
|
+
d="M3.33366 8.19559V2.66699H2.66699V12.3337C2.66699 12.8859 3.11471 13.3337 3.66699 13.3337H13.3337V12.667H3.66699C3.4829 12.667 3.33366 12.5178 3.33366 12.3337V9.1384L4.33366 8.1384L7.43129 11.236C7.56146 11.3662 7.77252 11.3662 7.90269 11.236L13.3337 5.80506V8.00033H14.0003V4.66699H10.667V5.33366H12.8623L7.66699 10.5289L4.56936 7.43129C4.43919 7.30112 4.22813 7.30112 4.09796 7.43129L3.33366 8.19559Z"
|
|
22
|
+
fill="currentColor"
|
|
23
|
+
/>
|
|
24
|
+
</svg>
|
|
@@ -1,12 +1,12 @@
|
|
|
1
|
-
export default
|
|
2
|
-
type
|
|
1
|
+
export default AnalyticsIcon;
|
|
2
|
+
type AnalyticsIcon = SvelteComponent<{
|
|
3
3
|
[x: string]: never;
|
|
4
4
|
}, {
|
|
5
5
|
[evt: string]: CustomEvent<any>;
|
|
6
6
|
}, {}> & {
|
|
7
7
|
$$bindings?: string | undefined;
|
|
8
8
|
};
|
|
9
|
-
declare const
|
|
9
|
+
declare const AnalyticsIcon: $$__sveltets_2_IsomorphicComponent<{
|
|
10
10
|
[x: string]: never;
|
|
11
11
|
}, {
|
|
12
12
|
[evt: string]: CustomEvent<any>;
|
|
@@ -1,4 +1,10 @@
|
|
|
1
|
-
<svg
|
|
1
|
+
<svg
|
|
2
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
3
|
+
width="100%"
|
|
4
|
+
height="100%"
|
|
5
|
+
viewBox="4.5 4.5 8 7.5"
|
|
6
|
+
fill="none"
|
|
7
|
+
>
|
|
2
8
|
<path
|
|
3
9
|
d="M10.2929 5.5L5.99998 5.5V4.5L12 4.5L12 10.5L11 10.5V6.20711L5.35353 11.8536L4.64642 11.1464L10.2929 5.5Z"
|
|
4
10
|
fill="currentColor"
|
|
@@ -1,4 +1,10 @@
|
|
|
1
|
-
<svg
|
|
1
|
+
<svg
|
|
2
|
+
xmlns="http://www.w3.org/2000/svg"
|
|
3
|
+
width="100%"
|
|
4
|
+
height="100%"
|
|
5
|
+
viewBox="2.4 1.7 4.2 7.6"
|
|
6
|
+
fill="none"
|
|
7
|
+
>
|
|
2
8
|
<path
|
|
3
9
|
fill-rule="evenodd"
|
|
4
10
|
clip-rule="evenodd"
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
<svg xmlns="http://www.w3.org/2000/svg" width="
|
|
1
|
+
<svg xmlns="http://www.w3.org/2000/svg" width="100%" height="100%" viewBox="0 0 16 16" fill="none">
|
|
2
2
|
<g clip-path="url(#clip0_4033_5074)">
|
|
3
3
|
<path
|
|
4
4
|
d="M12.6666 2H3.33325V14L7.99992 12L12.6666 14V2ZM11.3333 12L7.99992 10.5467L4.66659 12V3.33333H11.3333V12Z"
|
|
@@ -1,8 +1,8 @@
|
|
|
1
|
-
<svg xmlns="http://www.w3.org/2000/svg" width="
|
|
1
|
+
<svg xmlns="http://www.w3.org/2000/svg" width="100%" height="100%" viewBox="0 0 16 16" fill="none">
|
|
2
2
|
<path
|
|
3
3
|
fill-rule="evenodd"
|
|
4
4
|
clip-rule="evenodd"
|
|
5
5
|
d="M3 2C2.44772 2 2 2.44772 2 3V13C2 13.5523 2.44772 14 3 14H13C13.5523 14 14 13.5523 14 13V3C14 2.44772 13.5523 2 13 2H3ZM7 4H9V7H12V9H9V12H7V9H4V7H7V4Z"
|
|
6
|
-
fill="
|
|
6
|
+
fill="currentColor"
|
|
7
7
|
/>
|
|
8
8
|
</svg>
|