@reshape-biotech/design-system 0.0.23 → 0.0.25
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/README.md +30 -38
- package/dist/app.css +4 -4
- package/dist/components/avatar/index.d.ts +1 -0
- package/dist/components/avatar/index.js +1 -0
- package/dist/components/banner/Banner.stories.svelte +129 -0
- package/dist/components/banner/Banner.svelte +59 -0
- package/dist/components/banner/Banner.svelte.d.ts +11 -0
- package/dist/components/banner/index.d.ts +1 -0
- package/dist/components/banner/index.js +1 -0
- package/dist/components/button/Button.stories.svelte +37 -0
- package/dist/components/button/Button.svelte +85 -0
- package/dist/components/button/Button.svelte.d.ts +17 -0
- package/dist/components/button/index.d.ts +1 -0
- package/dist/components/button/index.js +1 -0
- package/dist/components/datepicker/DatePicker.svelte +283 -0
- package/dist/components/datepicker/DatePicker.svelte.d.ts +8 -0
- package/dist/components/datepicker/index.d.ts +1 -0
- package/dist/components/datepicker/index.js +1 -0
- package/dist/components/divider/Divider.stories.svelte +14 -0
- package/dist/components/divider/Divider.svelte +9 -0
- package/dist/components/divider/Divider.svelte.d.ts +6 -0
- package/dist/components/divider/index.d.ts +1 -0
- package/dist/components/divider/index.js +1 -0
- package/dist/components/drawer/Drawer.stories.svelte +99 -0
- package/dist/components/drawer/Drawer.svelte +45 -0
- package/dist/components/drawer/Drawer.svelte.d.ts +12 -0
- package/dist/components/drawer/DrawerLabel.svelte +13 -0
- package/dist/components/drawer/DrawerLabel.svelte.d.ts +9 -0
- package/dist/components/drawer/index.d.ts +1 -0
- package/dist/components/drawer/index.js +1 -0
- package/dist/components/dropdown/Dropdown.stories.svelte +214 -0
- package/dist/components/dropdown/Dropdown.svelte +69 -0
- package/dist/components/dropdown/Dropdown.svelte.d.ts +14 -0
- package/dist/components/dropdown/components/DropdownContent.svelte +29 -0
- package/dist/components/dropdown/components/DropdownContent.svelte.d.ts +10 -0
- package/dist/components/dropdown/components/DropdownMenu.svelte +23 -0
- package/dist/components/dropdown/components/DropdownMenu.svelte.d.ts +8 -0
- package/dist/components/dropdown/components/DropdownTrigger.svelte +44 -0
- package/dist/components/dropdown/components/DropdownTrigger.svelte.d.ts +12 -0
- package/dist/components/dropdown/index.d.ts +1 -0
- package/dist/components/dropdown/index.js +1 -0
- package/dist/components/icon-button/IconButton.stories.svelte +52 -0
- package/dist/components/icon-button/IconButton.svelte +72 -0
- package/dist/components/icon-button/IconButton.svelte.d.ts +14 -0
- package/dist/components/icon-button/index.d.ts +1 -0
- package/dist/components/icon-button/index.js +1 -0
- package/dist/components/image/Image.svelte +56 -0
- package/dist/components/image/Image.svelte.d.ts +7 -0
- package/dist/components/image/index.d.ts +1 -0
- package/dist/components/image/index.js +1 -0
- package/dist/components/input/Input.stories.svelte +81 -0
- package/dist/components/input/Input.svelte +131 -0
- package/dist/components/input/Input.svelte.d.ts +20 -0
- package/dist/components/input/index.d.ts +1 -0
- package/dist/components/input/index.js +1 -0
- package/dist/components/list/List.stories.svelte +97 -0
- package/dist/components/list/List.svelte +75 -0
- package/dist/components/list/List.svelte.d.ts +24 -0
- package/dist/components/list/index.d.ts +1 -0
- package/dist/components/list/index.js +1 -0
- package/dist/components/markdown/Markdown.stories.svelte +41 -0
- package/dist/components/markdown/Markdown.svelte +12 -0
- package/dist/components/markdown/Markdown.svelte.d.ts +6 -0
- package/dist/components/markdown/index.d.ts +1 -0
- package/dist/components/markdown/index.js +1 -0
- package/dist/components/modal/Modal.stories.svelte +41 -0
- package/dist/components/modal/Modal.svelte +56 -0
- package/dist/components/modal/Modal.svelte.d.ts +16 -0
- package/dist/components/modal/index.d.ts +1 -0
- package/dist/components/modal/index.js +1 -0
- package/dist/components/notification-popup/NotificationPopup.stories.svelte +27 -0
- package/dist/components/notification-popup/NotificationPopup.svelte +31 -0
- package/dist/components/notification-popup/NotificationPopup.svelte.d.ts +11 -0
- package/dist/components/notification-popup/index.d.ts +1 -0
- package/dist/components/notification-popup/index.js +1 -0
- package/dist/components/pill/Pill.svelte +39 -0
- package/dist/components/pill/Pill.svelte.d.ts +10 -0
- package/dist/components/pill/index.d.ts +1 -0
- package/dist/components/pill/index.js +1 -0
- package/dist/components/progress-circle/ProgressCircle.svelte +79 -0
- package/dist/components/progress-circle/ProgressCircle.svelte.d.ts +7 -0
- package/dist/components/progress-circle/index.d.ts +1 -0
- package/dist/components/progress-circle/index.js +1 -0
- package/dist/components/segmented-control-buttons/ControlButton.svelte +59 -0
- package/dist/components/segmented-control-buttons/ControlButton.svelte.d.ts +14 -0
- package/dist/components/segmented-control-buttons/SegmentedControlButtons.stories.svelte +45 -0
- package/dist/components/segmented-control-buttons/SegmentedControlButtons.svelte +21 -0
- package/dist/components/segmented-control-buttons/SegmentedControlButtons.svelte.d.ts +10 -0
- package/dist/components/segmented-control-buttons/index.d.ts +2 -0
- package/dist/components/segmented-control-buttons/index.js +2 -0
- package/dist/components/select/Select.stories.svelte +113 -0
- package/dist/components/select/Select.svelte +137 -0
- package/dist/components/select/Select.svelte.d.ts +60 -0
- package/dist/components/select/index.d.ts +7 -0
- package/dist/components/select/index.js +1 -0
- package/dist/components/skeleton-loader/SkeletonLoader.stories.svelte +71 -0
- package/dist/components/skeleton-loader/SkeletonLoader.svelte +17 -0
- package/dist/components/skeleton-loader/SkeletonLoader.svelte.d.ts +9 -0
- package/dist/components/skeleton-loader/StatcardSkeleton.svelte +17 -0
- package/dist/components/skeleton-loader/StatcardSkeleton.svelte.d.ts +18 -0
- package/dist/components/skeleton-loader/components/Skeleton.svelte +14 -0
- package/dist/components/skeleton-loader/components/Skeleton.svelte.d.ts +8 -0
- package/dist/components/skeleton-loader/components/SkeletonImage.svelte +14 -0
- package/dist/components/{tooltip/Tooltip.stories.svelte.d.ts → skeleton-loader/components/SkeletonImage.svelte.d.ts} +3 -4
- package/dist/components/skeleton-loader/index.d.ts +3 -0
- package/dist/components/skeleton-loader/index.js +3 -0
- package/dist/components/slider/Slider.stories.svelte +37 -0
- package/dist/components/slider/Slider.svelte +117 -0
- package/dist/components/slider/Slider.svelte.d.ts +29 -0
- package/dist/components/slider/index.d.ts +1 -0
- package/dist/components/slider/index.js +1 -0
- package/dist/components/spinner/Spinner.svelte +27 -0
- package/dist/components/spinner/Spinner.svelte.d.ts +6 -0
- package/dist/components/spinner/index.d.ts +1 -0
- package/dist/components/spinner/index.js +1 -0
- package/dist/components/stat-card/StatCard.stories.svelte +32 -0
- package/dist/components/stat-card/StatCard.svelte +52 -0
- package/dist/components/stat-card/StatCard.svelte.d.ts +10 -0
- package/dist/components/stat-card/index.d.ts +1 -0
- package/dist/components/stat-card/index.js +1 -0
- package/dist/components/status-badge/StatusBadge.stories.svelte +401 -0
- package/dist/components/status-badge/StatusBadge.svelte +147 -0
- package/dist/components/status-badge/StatusBadge.svelte.d.ts +12 -0
- package/dist/components/status-badge/index.d.ts +1 -0
- package/dist/components/status-badge/index.js +1 -0
- package/dist/components/table/Table.stories.svelte +86 -0
- package/dist/components/table/Table.svelte +33 -0
- package/dist/components/table/Table.svelte.d.ts +8 -0
- package/dist/components/table/components/Td.svelte +14 -0
- package/dist/components/table/components/Td.svelte.d.ts +8 -0
- package/dist/components/table/components/Th.svelte +15 -0
- package/dist/components/table/components/Th.svelte.d.ts +9 -0
- package/dist/components/table/components/Tr.svelte +31 -0
- package/dist/components/table/components/Tr.svelte.d.ts +8 -0
- package/dist/components/table/index.d.ts +1 -0
- package/dist/components/table/index.js +1 -0
- package/dist/components/tabs/Tabs.stories.svelte +30 -0
- package/dist/components/tabs/Tabs.svelte +15 -0
- package/dist/components/tabs/Tabs.svelte.d.ts +8 -0
- package/dist/components/tabs/components/Content.svelte +15 -0
- package/dist/components/tabs/components/Content.svelte.d.ts +9 -0
- package/dist/components/tabs/components/Tab.svelte +21 -0
- package/dist/components/tabs/components/Tab.svelte.d.ts +10 -0
- package/dist/components/tabs/components/Tabs.svelte +14 -0
- package/dist/components/tabs/components/Tabs.svelte.d.ts +8 -0
- package/dist/components/tabs/index.d.ts +1 -0
- package/dist/components/tabs/index.js +1 -0
- package/dist/components/tag/Tag.stories.svelte +50 -0
- package/dist/components/tag/Tag.svelte +104 -0
- package/dist/components/tag/Tag.svelte.d.ts +11 -0
- package/dist/components/tag/index.d.ts +1 -0
- package/dist/components/tag/index.js +1 -0
- package/dist/components/toast/Toast.svelte +66 -0
- package/dist/components/toast/Toast.svelte.d.ts +5 -0
- package/dist/components/toast/index.d.ts +1 -0
- package/dist/components/toast/index.js +1 -0
- package/dist/components/tooltip/index.d.ts +1 -0
- package/dist/components/tooltip/index.js +1 -0
- package/dist/fonts/MDSystem-Medium.woff +0 -0
- package/dist/fonts/MDSystem-Medium.woff2 +0 -0
- package/dist/fonts/MDSystem-Regular.woff +0 -0
- package/dist/fonts/MDSystem-Regular.woff2 +0 -0
- package/dist/fonts/MDSystem-Semibold.woff +0 -0
- package/dist/fonts/MDSystem-Semibold.woff2 +0 -0
- package/dist/fonts/MDSystemMono-Regular.woff +0 -0
- package/dist/fonts/MDSystemMono-Regular.woff2 +0 -0
- package/dist/fonts/index.d.ts +6 -0
- package/dist/fonts/index.js +10 -0
- package/dist/index.d.ts +29 -3
- package/dist/index.js +31 -4
- package/dist/tailwind.preset.d.ts +1 -0
- package/dist/tokens.d.ts +314 -36
- package/dist/tokens.js +235 -248
- package/dist/types/fonts.d.ts +4 -0
- package/package.json +9 -15
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import type { Snippet } from 'svelte';
|
|
3
|
+
|
|
4
|
+
interface Props {
|
|
5
|
+
dataTestId?: string;
|
|
6
|
+
children?: Snippet;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
let { dataTestId = '', children }: Props = $props();
|
|
10
|
+
</script>
|
|
11
|
+
|
|
12
|
+
<td data-testid={dataTestId} class={`text-left text-sm font-normal`}>
|
|
13
|
+
{@render children?.()}
|
|
14
|
+
</td>
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import type { Width } from '../../../tailwind';
|
|
3
|
+
import type { Snippet } from 'svelte';
|
|
4
|
+
|
|
5
|
+
interface Props {
|
|
6
|
+
class?: Width | '';
|
|
7
|
+
children?: Snippet;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
let { class: className = '', children }: Props = $props();
|
|
11
|
+
</script>
|
|
12
|
+
|
|
13
|
+
<th class={`text-left text-xs font-normal text-secondary ${className}`}>
|
|
14
|
+
{@render children?.()}
|
|
15
|
+
</th>
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { Width } from '../../../tailwind';
|
|
2
|
+
import type { Snippet } from 'svelte';
|
|
3
|
+
interface Props {
|
|
4
|
+
class?: Width | '';
|
|
5
|
+
children?: Snippet;
|
|
6
|
+
}
|
|
7
|
+
declare const Th: import("svelte").Component<Props, {}, "">;
|
|
8
|
+
type Th = ReturnType<typeof Th>;
|
|
9
|
+
export default Th;
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import type { Snippet } from 'svelte';
|
|
3
|
+
|
|
4
|
+
interface Props {
|
|
5
|
+
disabled?: boolean;
|
|
6
|
+
children?: Snippet;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
let { disabled = false, children }: Props = $props();
|
|
10
|
+
</script>
|
|
11
|
+
|
|
12
|
+
<tr class="my-2 border-static [&.disabled]:text-tertiary" class:disabled>
|
|
13
|
+
{@render children?.()}
|
|
14
|
+
</tr>
|
|
15
|
+
|
|
16
|
+
<style>
|
|
17
|
+
:global(td) {
|
|
18
|
+
padding-top: 1rem;
|
|
19
|
+
padding-bottom: 1rem
|
|
20
|
+
}
|
|
21
|
+
:global(td):first-child {
|
|
22
|
+
padding-left: 0.5rem
|
|
23
|
+
}
|
|
24
|
+
:global(th) {
|
|
25
|
+
padding-top: 1rem;
|
|
26
|
+
padding-bottom: 1rem
|
|
27
|
+
}
|
|
28
|
+
:global(th):first-child {
|
|
29
|
+
padding-left: 0.5rem
|
|
30
|
+
}
|
|
31
|
+
</style>
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default as Table } from './Table.svelte';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default as Table } from './Table.svelte';
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
<script module>
|
|
2
|
+
import Tabs from './Tabs.svelte';
|
|
3
|
+
|
|
4
|
+
import { defineMeta } from '@storybook/addon-svelte-csf';
|
|
5
|
+
const { Story } = defineMeta({
|
|
6
|
+
component: Tabs,
|
|
7
|
+
title: 'Design System/Tabs',
|
|
8
|
+
tags: ['autodocs']
|
|
9
|
+
});
|
|
10
|
+
|
|
11
|
+
let activeTab = 'tab-1';
|
|
12
|
+
</script>
|
|
13
|
+
|
|
14
|
+
<Story name="Primary">
|
|
15
|
+
<Tabs>
|
|
16
|
+
{#snippet children({ C })}
|
|
17
|
+
<C.Tabs>
|
|
18
|
+
<C.Tab active={activeTab === 'tab-1'} onClick={() => (activeTab = 'tab-1')}>Tab 1</C.Tab>
|
|
19
|
+
<C.Tab active={activeTab === 'tab-2'} onClick={() => (activeTab = 'tab-2')}>Tab 2</C.Tab>
|
|
20
|
+
<C.Tab active={activeTab === 'tab-3'} onClick={() => (activeTab = 'tab-3')}>Tab 3</C.Tab>
|
|
21
|
+
</C.Tabs>
|
|
22
|
+
|
|
23
|
+
<C.Content show={activeTab === 'tab-1'}>Showing tab 1 content</C.Content>
|
|
24
|
+
|
|
25
|
+
<C.Content show={activeTab === 'tab-2'}>Showing tab 2 content</C.Content>
|
|
26
|
+
|
|
27
|
+
<C.Content show={activeTab === 'tab-3'}>Showing tab 3 content</C.Content>
|
|
28
|
+
{/snippet}
|
|
29
|
+
</Tabs>
|
|
30
|
+
</Story>
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import type { Snippet } from 'svelte';
|
|
3
|
+
import Content from './components/Content.svelte';
|
|
4
|
+
import Tab from './components/Tab.svelte';
|
|
5
|
+
import Tabs from './components/Tabs.svelte';
|
|
6
|
+
interface Props {
|
|
7
|
+
children?: Snippet<[any]>;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
let { children }: Props = $props();
|
|
11
|
+
|
|
12
|
+
const C = { Tabs, Tab, Content };
|
|
13
|
+
</script>
|
|
14
|
+
|
|
15
|
+
{@render children?.({ C })}
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import type { Snippet } from 'svelte';
|
|
3
|
+
|
|
4
|
+
interface Props {
|
|
5
|
+
class?: string;
|
|
6
|
+
show?: boolean;
|
|
7
|
+
children?: Snippet;
|
|
8
|
+
}
|
|
9
|
+
|
|
10
|
+
let { class: className = '', show = false, children }: Props = $props();
|
|
11
|
+
</script>
|
|
12
|
+
|
|
13
|
+
<div class:hidden={!show} class={className}>
|
|
14
|
+
{@render children?.()}
|
|
15
|
+
</div>
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import Button from '../../button/';
|
|
3
|
+
import type { Snippet } from 'svelte';
|
|
4
|
+
interface Props {
|
|
5
|
+
active?: boolean;
|
|
6
|
+
onClick: () => void;
|
|
7
|
+
class?: string;
|
|
8
|
+
children?: Snippet;
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
let { active = false, onClick, class: className = '', children }: Props = $props();
|
|
12
|
+
</script>
|
|
13
|
+
|
|
14
|
+
<Button
|
|
15
|
+
{onClick}
|
|
16
|
+
variant="transparent"
|
|
17
|
+
size="md"
|
|
18
|
+
class={`tab flex !h-10 gap-2 !rounded-md !px-0 !py-0 ${active ? 'tab-active' : ''} ${className}`}
|
|
19
|
+
>
|
|
20
|
+
{@render children?.()}
|
|
21
|
+
</Button>
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import type { Snippet } from 'svelte';
|
|
2
|
+
interface Props {
|
|
3
|
+
active?: boolean;
|
|
4
|
+
onClick: () => void;
|
|
5
|
+
class?: string;
|
|
6
|
+
children?: Snippet;
|
|
7
|
+
}
|
|
8
|
+
declare const Tab: import("svelte").Component<Props, {}, "">;
|
|
9
|
+
type Tab = ReturnType<typeof Tab>;
|
|
10
|
+
export default Tab;
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import type { Snippet } from 'svelte';
|
|
3
|
+
|
|
4
|
+
interface Props {
|
|
5
|
+
class?: string;
|
|
6
|
+
children?: Snippet;
|
|
7
|
+
}
|
|
8
|
+
|
|
9
|
+
let { class: className = '', children }: Props = $props();
|
|
10
|
+
</script>
|
|
11
|
+
|
|
12
|
+
<div role="tablist" class={`tabs-boxed tabs h-[48px] gap-1 rounded-lg ${className}`}>
|
|
13
|
+
{@render children?.()}
|
|
14
|
+
</div>
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default } from './Tabs.svelte';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default } from './Tabs.svelte';
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
<script module lang="ts">
|
|
2
|
+
import { Folder } from 'phosphor-svelte';
|
|
3
|
+
import Tag from './Tag.svelte';
|
|
4
|
+
import { defineMeta } from '@storybook/addon-svelte-csf';
|
|
5
|
+
const { Story } = defineMeta({
|
|
6
|
+
component: Tag,
|
|
7
|
+
title: 'Design System/Tag',
|
|
8
|
+
tags: ['autodocs']
|
|
9
|
+
});
|
|
10
|
+
</script>
|
|
11
|
+
|
|
12
|
+
<Story name="Default">
|
|
13
|
+
<div class="w-fit">
|
|
14
|
+
<Tag>Default</Tag>
|
|
15
|
+
</div>
|
|
16
|
+
</Story>
|
|
17
|
+
<Story name="Default small">
|
|
18
|
+
<div class="w-fit">
|
|
19
|
+
<Tag variant="default" size="sm">Default</Tag>
|
|
20
|
+
</div>
|
|
21
|
+
</Story>
|
|
22
|
+
<Story name="Default onclick">
|
|
23
|
+
<div class="w-fit">
|
|
24
|
+
<Tag onclick={() => {}}>Default</Tag>
|
|
25
|
+
</div>
|
|
26
|
+
</Story>
|
|
27
|
+
<Story name="Default icon onclick">
|
|
28
|
+
<div class="w-fit">
|
|
29
|
+
<Tag onclick={() => {}}>
|
|
30
|
+
<Folder />
|
|
31
|
+
Default
|
|
32
|
+
</Tag>
|
|
33
|
+
</div>
|
|
34
|
+
</Story>
|
|
35
|
+
|
|
36
|
+
<Story name="Transparent">
|
|
37
|
+
<div class="w-fit">
|
|
38
|
+
<Tag variant="transparent">Transparent</Tag>
|
|
39
|
+
</div>
|
|
40
|
+
</Story>
|
|
41
|
+
<Story name="Transparent small">
|
|
42
|
+
<div class="w-fit">
|
|
43
|
+
<Tag variant="transparent" size="sm">Transparent</Tag>
|
|
44
|
+
</div>
|
|
45
|
+
</Story>
|
|
46
|
+
<Story name="Transparent onclick">
|
|
47
|
+
<div class="w-fit">
|
|
48
|
+
<Tag variant="transparent" onclick={() => {}}>Transparent</Tag>
|
|
49
|
+
</div>
|
|
50
|
+
</Story>
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import type { Snippet } from 'svelte';
|
|
3
|
+
import Tooltip from '../tooltip/';
|
|
4
|
+
|
|
5
|
+
interface Props {
|
|
6
|
+
children: Snippet;
|
|
7
|
+
variant?: 'default' | 'outline' | 'transparent';
|
|
8
|
+
size?: 'sm' | 'md';
|
|
9
|
+
tooltip?: string;
|
|
10
|
+
onclick?: (event: MouseEvent) => void;
|
|
11
|
+
class?: string;
|
|
12
|
+
}
|
|
13
|
+
|
|
14
|
+
let {
|
|
15
|
+
children,
|
|
16
|
+
variant = 'default',
|
|
17
|
+
size = 'md',
|
|
18
|
+
tooltip,
|
|
19
|
+
onclick,
|
|
20
|
+
class: className
|
|
21
|
+
}: Props = $props();
|
|
22
|
+
|
|
23
|
+
const sizes = {
|
|
24
|
+
sm: 'h-6 text-xs',
|
|
25
|
+
md: 'h-6 text-sm'
|
|
26
|
+
};
|
|
27
|
+
let sizeClassName = $derived(sizes[size]);
|
|
28
|
+
|
|
29
|
+
const variants = {
|
|
30
|
+
default: 'bg-neutral text-primary',
|
|
31
|
+
outline: 'bg-transparent text-secondary border',
|
|
32
|
+
transparent: 'bg-transparent text-secondary'
|
|
33
|
+
};
|
|
34
|
+
|
|
35
|
+
const buttonClassVariants = {
|
|
36
|
+
default: 'hover:bg-neutral-hover',
|
|
37
|
+
outline: 'hover:bg-neutral hover:text-primary',
|
|
38
|
+
transparent: 'hover:bg-neutral hover:text-primary'
|
|
39
|
+
};
|
|
40
|
+
|
|
41
|
+
let variantClassName = $derived(variants[variant]);
|
|
42
|
+
let buttonClassVariant = $derived(buttonClassVariants[variant]);
|
|
43
|
+
</script>
|
|
44
|
+
|
|
45
|
+
{#snippet renderTag()}
|
|
46
|
+
{#if onclick}
|
|
47
|
+
<button
|
|
48
|
+
class="outer {variantClassName} {sizeClassName} {buttonClassVariant} hover:cursor-pointer {className} "
|
|
49
|
+
title={tooltip}
|
|
50
|
+
{onclick}
|
|
51
|
+
>
|
|
52
|
+
{@render children()}
|
|
53
|
+
</button>
|
|
54
|
+
{:else}
|
|
55
|
+
<div class="outer {variantClassName} {sizeClassName} no-underline {className}" title={tooltip}>
|
|
56
|
+
{@render children()}
|
|
57
|
+
</div>
|
|
58
|
+
{/if}
|
|
59
|
+
{/snippet}
|
|
60
|
+
|
|
61
|
+
{#if tooltip}
|
|
62
|
+
<Tooltip>
|
|
63
|
+
{#snippet trigger()}
|
|
64
|
+
{@render renderTag()}
|
|
65
|
+
{/snippet}
|
|
66
|
+
{#snippet content()}
|
|
67
|
+
{tooltip}
|
|
68
|
+
{/snippet}
|
|
69
|
+
</Tooltip>
|
|
70
|
+
{:else}
|
|
71
|
+
{@render renderTag()}
|
|
72
|
+
{/if}
|
|
73
|
+
|
|
74
|
+
<style>
|
|
75
|
+
.outer {
|
|
76
|
+
|
|
77
|
+
display: flex;
|
|
78
|
+
|
|
79
|
+
align-items: center;
|
|
80
|
+
|
|
81
|
+
gap: 0.5rem;
|
|
82
|
+
|
|
83
|
+
overflow: hidden;
|
|
84
|
+
|
|
85
|
+
text-overflow: ellipsis;
|
|
86
|
+
|
|
87
|
+
white-space: nowrap;
|
|
88
|
+
|
|
89
|
+
border-radius: 0.25rem;
|
|
90
|
+
|
|
91
|
+
padding: 0.25rem
|
|
92
|
+
}
|
|
93
|
+
|
|
94
|
+
svg {
|
|
95
|
+
|
|
96
|
+
height: 1rem;
|
|
97
|
+
|
|
98
|
+
width: 1rem;
|
|
99
|
+
|
|
100
|
+
--tw-text-opacity: 1;
|
|
101
|
+
|
|
102
|
+
color: rgb(136 140 148 / var(--tw-text-opacity, 1))
|
|
103
|
+
}
|
|
104
|
+
</style>
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
import type { Snippet } from 'svelte';
|
|
2
|
+
declare const Tag: import("svelte").Component<{
|
|
3
|
+
children: Snippet;
|
|
4
|
+
variant?: "default" | "outline" | "transparent";
|
|
5
|
+
size?: "sm" | "md";
|
|
6
|
+
tooltip?: string;
|
|
7
|
+
onclick?: (event: MouseEvent) => void;
|
|
8
|
+
class?: string;
|
|
9
|
+
}, {}, "">;
|
|
10
|
+
type Tag = ReturnType<typeof Tag>;
|
|
11
|
+
export default Tag;
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default as Tag } from './Tag.svelte';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default as Tag } from './Tag.svelte';
|
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
<script lang="ts">
|
|
2
|
+
import { flip } from 'svelte/animate';
|
|
3
|
+
import { fly } from 'svelte/transition';
|
|
4
|
+
import { notifications } from '../../notifications';
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* @typedef {Object} Props
|
|
8
|
+
* @property {any} [themes]
|
|
9
|
+
*/
|
|
10
|
+
|
|
11
|
+
/** @type {Props} */
|
|
12
|
+
let {
|
|
13
|
+
themes = {
|
|
14
|
+
danger: '#E26D69',
|
|
15
|
+
success: '#84C991',
|
|
16
|
+
warning: '#f0ad4e',
|
|
17
|
+
info: '#5bc0de',
|
|
18
|
+
default: '#aaaaaa'
|
|
19
|
+
}
|
|
20
|
+
} = $props();
|
|
21
|
+
</script>
|
|
22
|
+
|
|
23
|
+
<div class="notifications">
|
|
24
|
+
{#each $notifications as notification (notification.id)}
|
|
25
|
+
<div
|
|
26
|
+
animate:flip
|
|
27
|
+
class="toast-custom"
|
|
28
|
+
style="background: {themes[notification.type]};"
|
|
29
|
+
transition:fly={{ y: 30 }}
|
|
30
|
+
>
|
|
31
|
+
<div class="content">{notification.message}</div>
|
|
32
|
+
{#if notification.icon}<i class={notification.icon}></i>{/if}
|
|
33
|
+
</div>
|
|
34
|
+
{/each}
|
|
35
|
+
</div>
|
|
36
|
+
|
|
37
|
+
<style>
|
|
38
|
+
.notifications {
|
|
39
|
+
position: fixed;
|
|
40
|
+
top: 10px;
|
|
41
|
+
left: 0;
|
|
42
|
+
right: 0;
|
|
43
|
+
margin: 0 auto;
|
|
44
|
+
padding: 0;
|
|
45
|
+
z-index: 9999;
|
|
46
|
+
display: flex;
|
|
47
|
+
flex-direction: column;
|
|
48
|
+
justify-content: flex-start;
|
|
49
|
+
align-items: center;
|
|
50
|
+
pointer-events: none;
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
.toast-custom {
|
|
54
|
+
flex: 0 0 auto;
|
|
55
|
+
padding: 0 16px;
|
|
56
|
+
margin-bottom: 10px;
|
|
57
|
+
border-radius: 100px;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
.content {
|
|
61
|
+
padding: 10px;
|
|
62
|
+
display: block;
|
|
63
|
+
color: white;
|
|
64
|
+
font-weight: 500;
|
|
65
|
+
}
|
|
66
|
+
</style>
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default as Toast } from './Toast.svelte';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default as Toast } from './Toast.svelte';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default } from './Tooltip.svelte';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export { default } from './Tooltip.svelte';
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
Binary file
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import MDSystemMonoRegular from './MDSystemMono-Regular.woff2';
|
|
2
|
+
import MDSystemRegular from './MDSystem-Regular.woff2';
|
|
3
|
+
import MDSystemMedium from './MDSystem-Medium.woff2';
|
|
4
|
+
import MDSystemSemibold from './MDSystem-Semibold.woff2';
|
|
5
|
+
export const fonts = {
|
|
6
|
+
MDSystemMonoRegular,
|
|
7
|
+
MDSystemRegular,
|
|
8
|
+
MDSystemMedium,
|
|
9
|
+
MDSystemSemibold
|
|
10
|
+
};
|
package/dist/index.d.ts
CHANGED
|
@@ -1,4 +1,30 @@
|
|
|
1
|
-
export
|
|
2
|
-
export
|
|
3
|
-
export
|
|
1
|
+
export * from './components/avatar/';
|
|
2
|
+
export * from './components/banner/';
|
|
3
|
+
export * from './components/button/';
|
|
4
|
+
export * from './components/datepicker/';
|
|
5
|
+
export * from './components/divider/';
|
|
6
|
+
export * from './components/drawer/';
|
|
7
|
+
export * from './components/drawer/';
|
|
8
|
+
export * from './components/dropdown/';
|
|
9
|
+
export * from './components/icon-button/';
|
|
10
|
+
export * from './components/image';
|
|
11
|
+
export * from './components/input/';
|
|
12
|
+
export * from './components/list/';
|
|
13
|
+
export * from './components/markdown/';
|
|
14
|
+
export * from './components/modal/';
|
|
15
|
+
export * from './components/notification-popup/';
|
|
16
|
+
export * from './components/pill/';
|
|
17
|
+
export * from './components/progress-circle/';
|
|
18
|
+
export * from './components/segmented-control-buttons/';
|
|
19
|
+
export * from './components/select/';
|
|
20
|
+
export * from './components/skeleton-loader/';
|
|
21
|
+
export * from './components/slider/';
|
|
22
|
+
export * from './components/spinner/';
|
|
23
|
+
export * from './components/stat-card/';
|
|
24
|
+
export * from './components/status-badge/';
|
|
25
|
+
export * from './components/table/';
|
|
26
|
+
export * from './components/tabs/';
|
|
27
|
+
export * from './components/tag/';
|
|
28
|
+
export * from './components/tooltip/';
|
|
29
|
+
export { tokens } from './tokens';
|
|
4
30
|
import './app.css';
|
package/dist/index.js
CHANGED
|
@@ -1,5 +1,32 @@
|
|
|
1
|
-
//
|
|
2
|
-
export
|
|
3
|
-
export
|
|
4
|
-
export
|
|
1
|
+
// Components
|
|
2
|
+
export * from './components/avatar/';
|
|
3
|
+
export * from './components/banner/';
|
|
4
|
+
export * from './components/button/';
|
|
5
|
+
export * from './components/datepicker/';
|
|
6
|
+
export * from './components/divider/';
|
|
7
|
+
export * from './components/drawer/';
|
|
8
|
+
export * from './components/drawer/';
|
|
9
|
+
export * from './components/dropdown/';
|
|
10
|
+
export * from './components/icon-button/';
|
|
11
|
+
export * from './components/image';
|
|
12
|
+
export * from './components/input/';
|
|
13
|
+
export * from './components/list/';
|
|
14
|
+
export * from './components/markdown/';
|
|
15
|
+
export * from './components/modal/';
|
|
16
|
+
export * from './components/notification-popup/';
|
|
17
|
+
export * from './components/pill/';
|
|
18
|
+
export * from './components/progress-circle/';
|
|
19
|
+
export * from './components/segmented-control-buttons/';
|
|
20
|
+
export * from './components/select/';
|
|
21
|
+
export * from './components/skeleton-loader/';
|
|
22
|
+
export * from './components/slider/';
|
|
23
|
+
export * from './components/spinner/';
|
|
24
|
+
export * from './components/stat-card/';
|
|
25
|
+
export * from './components/status-badge/';
|
|
26
|
+
export * from './components/table/';
|
|
27
|
+
export * from './components/tabs/';
|
|
28
|
+
export * from './components/tag/';
|
|
29
|
+
export * from './components/tooltip/';
|
|
30
|
+
// Styles and Tokens
|
|
31
|
+
export { tokens } from './tokens';
|
|
5
32
|
import './app.css';
|