@sentropic/design-system-vue 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/dist/Accordion.d.ts +26 -4
- package/dist/Accordion.d.ts.map +1 -1
- package/dist/Accordion.js +7 -4
- package/dist/Accordion.js.map +1 -1
- package/dist/AreaChart.d.ts +38 -21
- package/dist/AreaChart.d.ts.map +1 -1
- package/dist/AreaChart.js +154 -40
- package/dist/AreaChart.js.map +1 -1
- package/dist/BackToTop.d.ts +79 -0
- package/dist/BackToTop.d.ts.map +1 -0
- package/dist/BackToTop.js +72 -0
- package/dist/BackToTop.js.map +1 -0
- package/dist/BarChart.d.ts +23 -16
- package/dist/BarChart.d.ts.map +1 -1
- package/dist/BarChart.js +137 -30
- package/dist/BarChart.js.map +1 -1
- package/dist/Combobox.d.ts +1 -1
- package/dist/ContentSwitcher.d.ts +10 -0
- package/dist/ContentSwitcher.d.ts.map +1 -1
- package/dist/ContentSwitcher.js +5 -1
- package/dist/ContentSwitcher.js.map +1 -1
- package/dist/CopyButton.d.ts +1 -1
- package/dist/DataTable.d.ts +208 -18
- package/dist/DataTable.d.ts.map +1 -1
- package/dist/DataTable.js +267 -26
- package/dist/DataTable.js.map +1 -1
- package/dist/DisplaySettings.d.ts +90 -0
- package/dist/DisplaySettings.d.ts.map +1 -0
- package/dist/DisplaySettings.js +91 -0
- package/dist/DisplaySettings.js.map +1 -0
- package/dist/DonutChart.d.ts +33 -26
- package/dist/DonutChart.d.ts.map +1 -1
- package/dist/DonutChart.js +104 -26
- package/dist/DonutChart.js.map +1 -1
- package/dist/Drawer.d.ts +1 -1
- package/dist/Dropdown.d.ts +11 -1
- package/dist/Dropdown.d.ts.map +1 -1
- package/dist/Dropdown.js +1 -0
- package/dist/Dropdown.js.map +1 -1
- package/dist/FileUploader.d.ts +10 -1
- package/dist/FileUploader.d.ts.map +1 -1
- package/dist/FileUploader.js +33 -9
- package/dist/FileUploader.js.map +1 -1
- package/dist/ForceGraph.d.ts +1 -1
- package/dist/LanguageSelector.d.ts +1 -1
- package/dist/LineChart.d.ts +42 -16
- package/dist/LineChart.d.ts.map +1 -1
- package/dist/LineChart.js +146 -35
- package/dist/LineChart.js.map +1 -1
- package/dist/MediaContent.d.ts +130 -0
- package/dist/MediaContent.d.ts.map +1 -0
- package/dist/MediaContent.js +53 -0
- package/dist/MediaContent.js.map +1 -0
- package/dist/Menu.d.ts +7 -3
- package/dist/Menu.d.ts.map +1 -1
- package/dist/Menu.js +17 -7
- package/dist/Menu.js.map +1 -1
- package/dist/MenuPopover.d.ts +1 -1
- package/dist/MenuTriggerButton.d.ts +13 -3
- package/dist/MenuTriggerButton.d.ts.map +1 -1
- package/dist/MenuTriggerButton.js +4 -2
- package/dist/MenuTriggerButton.js.map +1 -1
- package/dist/MessageActions.d.ts +7 -1
- package/dist/MessageActions.d.ts.map +1 -1
- package/dist/MessageActions.js +4 -1
- package/dist/MessageActions.js.map +1 -1
- package/dist/Modal.d.ts +1 -1
- package/dist/MultiSelect.d.ts +1 -1
- package/dist/Notification.d.ts +71 -0
- package/dist/Notification.d.ts.map +1 -0
- package/dist/Notification.js +43 -0
- package/dist/Notification.js.map +1 -0
- package/dist/NumberInput.d.ts +13 -2
- package/dist/NumberInput.d.ts.map +1 -1
- package/dist/NumberInput.js +2 -1
- package/dist/NumberInput.js.map +1 -1
- package/dist/OverflowMenu.d.ts +1 -1
- package/dist/PaginationNav.d.ts +12 -2
- package/dist/PaginationNav.d.ts.map +1 -1
- package/dist/PaginationNav.js +3 -2
- package/dist/PaginationNav.js.map +1 -1
- package/dist/Popover.d.ts +1 -1
- package/dist/ProgressBar.d.ts +1 -1
- package/dist/ScatterPlot.d.ts +43 -14
- package/dist/ScatterPlot.d.ts.map +1 -1
- package/dist/ScatterPlot.js +113 -25
- package/dist/ScatterPlot.js.map +1 -1
- package/dist/Search.d.ts +11 -0
- package/dist/Search.d.ts.map +1 -1
- package/dist/Search.js +2 -1
- package/dist/Search.js.map +1 -1
- package/dist/Slider.d.ts +2 -2
- package/dist/Sparkline.d.ts +47 -7
- package/dist/Sparkline.d.ts.map +1 -1
- package/dist/Sparkline.js +57 -21
- package/dist/Sparkline.js.map +1 -1
- package/dist/StackedBarChart.d.ts +25 -16
- package/dist/StackedBarChart.d.ts.map +1 -1
- package/dist/StackedBarChart.js +131 -39
- package/dist/StackedBarChart.js.map +1 -1
- package/dist/TableOfContents.d.ts +53 -0
- package/dist/TableOfContents.d.ts.map +1 -0
- package/dist/TableOfContents.js +39 -0
- package/dist/TableOfContents.js.map +1 -0
- package/dist/Tabs.d.ts +10 -0
- package/dist/Tabs.d.ts.map +1 -1
- package/dist/Tabs.js +2 -0
- package/dist/Tabs.js.map +1 -1
- package/dist/Toggletip.d.ts +1 -1
- package/dist/Transcription.d.ts +75 -0
- package/dist/Transcription.d.ts.map +1 -0
- package/dist/Transcription.js +59 -0
- package/dist/Transcription.js.map +1 -0
- package/dist/chartScale.d.ts +22 -0
- package/dist/chartScale.d.ts.map +1 -0
- package/dist/chartScale.js +70 -0
- package/dist/chartScale.js.map +1 -0
- package/dist/index.d.ts +13 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +6 -0
- package/dist/index.js.map +1 -1
- package/dist/styles.css +260 -0
- package/package.json +1 -1
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
export type DisplayFontScale = "normal" | "large" | "extra-large";
|
|
2
|
+
export type DisplayContrast = "default" | "high";
|
|
3
|
+
export type DisplayLineSpacing = "normal" | "comfortable";
|
|
4
|
+
export interface DisplaySettingsState {
|
|
5
|
+
fontScale: DisplayFontScale;
|
|
6
|
+
contrast: DisplayContrast;
|
|
7
|
+
lineSpacing: DisplayLineSpacing;
|
|
8
|
+
reducedMotion: boolean;
|
|
9
|
+
}
|
|
10
|
+
export type DisplaySettingsProps = {
|
|
11
|
+
title?: string;
|
|
12
|
+
values?: Partial<DisplaySettingsState>;
|
|
13
|
+
showFontScale?: boolean;
|
|
14
|
+
showContrast?: boolean;
|
|
15
|
+
showLineSpacing?: boolean;
|
|
16
|
+
showReducedMotion?: boolean;
|
|
17
|
+
class?: string;
|
|
18
|
+
};
|
|
19
|
+
export declare const DisplaySettings: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
|
|
20
|
+
title: {
|
|
21
|
+
type: StringConstructor;
|
|
22
|
+
default: string;
|
|
23
|
+
};
|
|
24
|
+
values: {
|
|
25
|
+
type: () => Partial<DisplaySettingsState>;
|
|
26
|
+
default: undefined;
|
|
27
|
+
};
|
|
28
|
+
showFontScale: {
|
|
29
|
+
type: BooleanConstructor;
|
|
30
|
+
default: boolean;
|
|
31
|
+
};
|
|
32
|
+
showContrast: {
|
|
33
|
+
type: BooleanConstructor;
|
|
34
|
+
default: boolean;
|
|
35
|
+
};
|
|
36
|
+
showLineSpacing: {
|
|
37
|
+
type: BooleanConstructor;
|
|
38
|
+
default: boolean;
|
|
39
|
+
};
|
|
40
|
+
showReducedMotion: {
|
|
41
|
+
type: BooleanConstructor;
|
|
42
|
+
default: boolean;
|
|
43
|
+
};
|
|
44
|
+
class: {
|
|
45
|
+
type: StringConstructor;
|
|
46
|
+
default: undefined;
|
|
47
|
+
};
|
|
48
|
+
}>, () => import("vue").VNode<import("vue").RendererNode, import("vue").RendererElement, {
|
|
49
|
+
[key: string]: any;
|
|
50
|
+
}>, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, "change"[], "change", import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
|
|
51
|
+
title: {
|
|
52
|
+
type: StringConstructor;
|
|
53
|
+
default: string;
|
|
54
|
+
};
|
|
55
|
+
values: {
|
|
56
|
+
type: () => Partial<DisplaySettingsState>;
|
|
57
|
+
default: undefined;
|
|
58
|
+
};
|
|
59
|
+
showFontScale: {
|
|
60
|
+
type: BooleanConstructor;
|
|
61
|
+
default: boolean;
|
|
62
|
+
};
|
|
63
|
+
showContrast: {
|
|
64
|
+
type: BooleanConstructor;
|
|
65
|
+
default: boolean;
|
|
66
|
+
};
|
|
67
|
+
showLineSpacing: {
|
|
68
|
+
type: BooleanConstructor;
|
|
69
|
+
default: boolean;
|
|
70
|
+
};
|
|
71
|
+
showReducedMotion: {
|
|
72
|
+
type: BooleanConstructor;
|
|
73
|
+
default: boolean;
|
|
74
|
+
};
|
|
75
|
+
class: {
|
|
76
|
+
type: StringConstructor;
|
|
77
|
+
default: undefined;
|
|
78
|
+
};
|
|
79
|
+
}>> & Readonly<{
|
|
80
|
+
onChange?: ((...args: any[]) => any) | undefined;
|
|
81
|
+
}>, {
|
|
82
|
+
class: string;
|
|
83
|
+
values: Partial<DisplaySettingsState>;
|
|
84
|
+
title: string;
|
|
85
|
+
showFontScale: boolean;
|
|
86
|
+
showContrast: boolean;
|
|
87
|
+
showLineSpacing: boolean;
|
|
88
|
+
showReducedMotion: boolean;
|
|
89
|
+
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
|
|
90
|
+
//# sourceMappingURL=DisplaySettings.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DisplaySettings.d.ts","sourceRoot":"","sources":["../src/DisplaySettings.ts"],"names":[],"mappings":"AAGA,MAAM,MAAM,gBAAgB,GAAG,QAAQ,GAAG,OAAO,GAAG,aAAa,CAAC;AAClE,MAAM,MAAM,eAAe,GAAG,SAAS,GAAG,MAAM,CAAC;AACjD,MAAM,MAAM,kBAAkB,GAAG,QAAQ,GAAG,aAAa,CAAC;AAE1D,MAAM,WAAW,oBAAoB;IACnC,SAAS,EAAE,gBAAgB,CAAC;IAC5B,QAAQ,EAAE,eAAe,CAAC;IAC1B,WAAW,EAAE,kBAAkB,CAAC;IAChC,aAAa,EAAE,OAAO,CAAC;CACxB;AAED,MAAM,MAAM,oBAAoB,GAAG;IACjC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,OAAO,CAAC,oBAAoB,CAAC,CAAC;IACvC,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAC5B,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AASF,eAAO,MAAM,eAAe;;;;;;cAIE,MAAM,OAAO,CAAC,oBAAoB,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;cAAnC,MAAM,OAAO,CAAC,oBAAoB,CAAC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;4EAsG/D,CAAC"}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
import { defineComponent, h, ref, watch } from "vue";
|
|
2
|
+
import { classNames } from "./classNames.js";
|
|
3
|
+
const DEFAULT_SETTINGS = {
|
|
4
|
+
fontScale: "normal",
|
|
5
|
+
contrast: "default",
|
|
6
|
+
lineSpacing: "normal",
|
|
7
|
+
reducedMotion: false,
|
|
8
|
+
};
|
|
9
|
+
export const DisplaySettings = defineComponent({
|
|
10
|
+
name: "DisplaySettings",
|
|
11
|
+
props: {
|
|
12
|
+
title: { type: String, default: "Paramètres d’affichage" },
|
|
13
|
+
values: { type: Object, default: undefined },
|
|
14
|
+
showFontScale: { type: Boolean, default: true },
|
|
15
|
+
showContrast: { type: Boolean, default: true },
|
|
16
|
+
showLineSpacing: { type: Boolean, default: true },
|
|
17
|
+
showReducedMotion: { type: Boolean, default: true },
|
|
18
|
+
class: { type: String, default: undefined },
|
|
19
|
+
},
|
|
20
|
+
emits: ["change"],
|
|
21
|
+
setup(props, { emit, attrs }) {
|
|
22
|
+
const resolve = () => ({
|
|
23
|
+
fontScale: props.values?.fontScale ?? DEFAULT_SETTINGS.fontScale,
|
|
24
|
+
contrast: props.values?.contrast ?? DEFAULT_SETTINGS.contrast,
|
|
25
|
+
lineSpacing: props.values?.lineSpacing ?? DEFAULT_SETTINGS.lineSpacing,
|
|
26
|
+
reducedMotion: props.values?.reducedMotion ?? DEFAULT_SETTINGS.reducedMotion,
|
|
27
|
+
});
|
|
28
|
+
const state = ref(resolve());
|
|
29
|
+
watch(() => props.values, () => {
|
|
30
|
+
state.value = { ...state.value, ...resolve() };
|
|
31
|
+
}, { deep: true });
|
|
32
|
+
const update = (next) => {
|
|
33
|
+
state.value = { ...state.value, ...next };
|
|
34
|
+
emit("change", { ...state.value });
|
|
35
|
+
};
|
|
36
|
+
return () => h("div", { ...attrs, class: classNames("st-displaySettings", props.class) }, [
|
|
37
|
+
h("p", { class: "st-displaySettings__title" }, props.title),
|
|
38
|
+
h("div", { class: "st-displaySettings__grid" }, [
|
|
39
|
+
props.showFontScale
|
|
40
|
+
? h("label", { class: "st-displaySettings__field" }, [
|
|
41
|
+
h("span", { class: "st-displaySettings__label" }, "Taille de texte"),
|
|
42
|
+
h("select", {
|
|
43
|
+
value: state.value.fontScale,
|
|
44
|
+
onChange: (event) => update({ fontScale: event.target.value }),
|
|
45
|
+
}, [
|
|
46
|
+
h("option", { value: "normal" }, "Normale"),
|
|
47
|
+
h("option", { value: "large" }, "Grande"),
|
|
48
|
+
h("option", { value: "extra-large" }, "Très grande"),
|
|
49
|
+
]),
|
|
50
|
+
])
|
|
51
|
+
: null,
|
|
52
|
+
props.showContrast
|
|
53
|
+
? h("label", { class: "st-displaySettings__field" }, [
|
|
54
|
+
h("span", { class: "st-displaySettings__label" }, "Contraste"),
|
|
55
|
+
h("select", {
|
|
56
|
+
value: state.value.contrast,
|
|
57
|
+
onChange: (event) => update({ contrast: event.target.value }),
|
|
58
|
+
}, [
|
|
59
|
+
h("option", { value: "default" }, "Standard"),
|
|
60
|
+
h("option", { value: "high" }, "Élevé"),
|
|
61
|
+
]),
|
|
62
|
+
])
|
|
63
|
+
: null,
|
|
64
|
+
props.showLineSpacing
|
|
65
|
+
? h("label", { class: "st-displaySettings__field" }, [
|
|
66
|
+
h("span", { class: "st-displaySettings__label" }, "Interligne"),
|
|
67
|
+
h("select", {
|
|
68
|
+
value: state.value.lineSpacing,
|
|
69
|
+
onChange: (event) => update({ lineSpacing: event.target.value }),
|
|
70
|
+
}, [
|
|
71
|
+
h("option", { value: "normal" }, "Normal"),
|
|
72
|
+
h("option", { value: "comfortable" }, "Confortable"),
|
|
73
|
+
]),
|
|
74
|
+
])
|
|
75
|
+
: null,
|
|
76
|
+
props.showReducedMotion
|
|
77
|
+
? h("label", { class: "st-displaySettings__field st-displaySettings__field--switch" }, [
|
|
78
|
+
h("span", { class: "st-displaySettings__label" }, "Animations (réduction)"),
|
|
79
|
+
h("input", {
|
|
80
|
+
type: "checkbox",
|
|
81
|
+
role: "switch",
|
|
82
|
+
checked: state.value.reducedMotion,
|
|
83
|
+
onChange: (event) => update({ reducedMotion: event.target.checked }),
|
|
84
|
+
}),
|
|
85
|
+
])
|
|
86
|
+
: null,
|
|
87
|
+
]),
|
|
88
|
+
]);
|
|
89
|
+
},
|
|
90
|
+
});
|
|
91
|
+
//# sourceMappingURL=DisplaySettings.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"DisplaySettings.js","sourceRoot":"","sources":["../src/DisplaySettings.ts"],"names":[],"mappings":"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"}
|
package/dist/DonutChart.d.ts
CHANGED
|
@@ -1,16 +1,15 @@
|
|
|
1
|
+
export type DonutChartTone = "category1" | "category2" | "category3" | "category4" | "category5" | "category6" | "category7" | "category8";
|
|
1
2
|
export type DonutChartDatum = {
|
|
2
|
-
label
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
value?: number;
|
|
6
|
-
tone?: string;
|
|
3
|
+
label: string;
|
|
4
|
+
value: number;
|
|
5
|
+
tone?: DonutChartTone;
|
|
7
6
|
};
|
|
8
|
-
export type DonutChartTone = string;
|
|
9
7
|
export type DonutChartProps = {
|
|
10
8
|
data: DonutChartDatum[];
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
9
|
+
size?: number;
|
|
10
|
+
thickness?: number;
|
|
11
|
+
centerLabel?: string | null;
|
|
12
|
+
label: string;
|
|
14
13
|
class?: string;
|
|
15
14
|
};
|
|
16
15
|
export declare const DonutChart: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
|
|
@@ -18,18 +17,22 @@ export declare const DonutChart: import("vue").DefineComponent<import("vue").Ext
|
|
|
18
17
|
type: () => DonutChartDatum[];
|
|
19
18
|
required: true;
|
|
20
19
|
};
|
|
21
|
-
|
|
22
|
-
type: StringConstructor;
|
|
23
|
-
default: string;
|
|
24
|
-
};
|
|
25
|
-
width: {
|
|
20
|
+
size: {
|
|
26
21
|
type: NumberConstructor;
|
|
27
|
-
default:
|
|
22
|
+
default: number;
|
|
28
23
|
};
|
|
29
|
-
|
|
24
|
+
thickness: {
|
|
30
25
|
type: NumberConstructor;
|
|
26
|
+
default: number;
|
|
27
|
+
};
|
|
28
|
+
centerLabel: {
|
|
29
|
+
type: () => string | null;
|
|
31
30
|
default: undefined;
|
|
32
31
|
};
|
|
32
|
+
label: {
|
|
33
|
+
type: StringConstructor;
|
|
34
|
+
required: true;
|
|
35
|
+
};
|
|
33
36
|
class: {
|
|
34
37
|
type: StringConstructor;
|
|
35
38
|
default: undefined;
|
|
@@ -41,26 +44,30 @@ export declare const DonutChart: import("vue").DefineComponent<import("vue").Ext
|
|
|
41
44
|
type: () => DonutChartDatum[];
|
|
42
45
|
required: true;
|
|
43
46
|
};
|
|
44
|
-
|
|
45
|
-
type: StringConstructor;
|
|
46
|
-
default: string;
|
|
47
|
-
};
|
|
48
|
-
width: {
|
|
47
|
+
size: {
|
|
49
48
|
type: NumberConstructor;
|
|
50
|
-
default:
|
|
49
|
+
default: number;
|
|
51
50
|
};
|
|
52
|
-
|
|
51
|
+
thickness: {
|
|
53
52
|
type: NumberConstructor;
|
|
53
|
+
default: number;
|
|
54
|
+
};
|
|
55
|
+
centerLabel: {
|
|
56
|
+
type: () => string | null;
|
|
54
57
|
default: undefined;
|
|
55
58
|
};
|
|
59
|
+
label: {
|
|
60
|
+
type: StringConstructor;
|
|
61
|
+
required: true;
|
|
62
|
+
};
|
|
56
63
|
class: {
|
|
57
64
|
type: StringConstructor;
|
|
58
65
|
default: undefined;
|
|
59
66
|
};
|
|
60
67
|
}>> & Readonly<{}>, {
|
|
61
68
|
class: string;
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
69
|
+
size: number;
|
|
70
|
+
thickness: number;
|
|
71
|
+
centerLabel: string | null;
|
|
65
72
|
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
|
|
66
73
|
//# sourceMappingURL=DonutChart.d.ts.map
|
package/dist/DonutChart.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DonutChart.d.ts","sourceRoot":"","sources":["../src/DonutChart.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"DonutChart.d.ts","sourceRoot":"","sources":["../src/DonutChart.ts"],"names":[],"mappings":"AAIA,MAAM,MAAM,cAAc,GACtB,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,CAAC;AAEhB,MAAM,MAAM,eAAe,GAAG;IAC5B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,cAAc,CAAC;CACvB,CAAC;AAEF,MAAM,MAAM,eAAe,GAAG;IAC5B,IAAI,EAAE,eAAe,EAAE,CAAC;IACxB,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAiBF,eAAO,MAAM,UAAU;;cAGI,MAAM,eAAe,EAAE;;;;;;;;;;;;cAGI,MAAM,MAAM,GAAG,IAAI;;;;;;;;;;;;;;;cAH9C,MAAM,eAAe,EAAE;;;;;;;;;;;;cAGI,MAAM,MAAM,GAAG,IAAI;;;;;;;;;;;;;;;;4EA6HvE,CAAC"}
|
package/dist/DonutChart.js
CHANGED
|
@@ -1,40 +1,118 @@
|
|
|
1
|
-
import { defineComponent, h } from "vue";
|
|
1
|
+
import { defineComponent, h, ref } from "vue";
|
|
2
2
|
import { classNames } from "./classNames.js";
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
"
|
|
3
|
+
import { chartDataList } from "./chartScale.js";
|
|
4
|
+
const TONES = [
|
|
5
|
+
"category1",
|
|
6
|
+
"category2",
|
|
7
|
+
"category3",
|
|
8
|
+
"category4",
|
|
9
|
+
"category5",
|
|
10
|
+
"category6",
|
|
11
|
+
"category7",
|
|
12
|
+
"category8",
|
|
6
13
|
];
|
|
14
|
+
const fmtPct = (p) => `${p.toFixed(p < 10 ? 1 : 0)}%`;
|
|
7
15
|
export const DonutChart = defineComponent({
|
|
8
16
|
name: "DonutChart",
|
|
9
17
|
props: {
|
|
10
18
|
data: { type: Array, required: true },
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
19
|
+
size: { type: Number, default: 220 },
|
|
20
|
+
thickness: { type: Number, default: 34 },
|
|
21
|
+
centerLabel: { type: [String, null], default: undefined },
|
|
22
|
+
label: { type: String, required: true },
|
|
14
23
|
class: { type: String, default: undefined },
|
|
15
24
|
},
|
|
16
25
|
setup(props, { attrs }) {
|
|
26
|
+
const hoveredIndex = ref(null);
|
|
27
|
+
function handleLeave() {
|
|
28
|
+
hoveredIndex.value = null;
|
|
29
|
+
}
|
|
30
|
+
function handleVisualPointerMove(event) {
|
|
31
|
+
const target = event.target;
|
|
32
|
+
if (!(target instanceof Element)) {
|
|
33
|
+
hoveredIndex.value = null;
|
|
34
|
+
return;
|
|
35
|
+
}
|
|
36
|
+
const index = Number(target.getAttribute("data-chart-index"));
|
|
37
|
+
hoveredIndex.value = Number.isInteger(index) ? index : null;
|
|
38
|
+
}
|
|
17
39
|
return () => {
|
|
18
|
-
const
|
|
19
|
-
const
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
40
|
+
const size = props.size ?? 220;
|
|
41
|
+
const thickness = props.thickness ?? 34;
|
|
42
|
+
const centerLabel = props.centerLabel;
|
|
43
|
+
const label = props.label;
|
|
44
|
+
const data = props.data;
|
|
45
|
+
const total = data.reduce((sum, d) => sum + Math.max(d.value, 0), 0);
|
|
46
|
+
let items = [];
|
|
47
|
+
if (total > 0) {
|
|
48
|
+
const cx = size / 2;
|
|
49
|
+
const cy = size / 2;
|
|
50
|
+
const rOuter = size / 2 - 2;
|
|
51
|
+
const rInner = Math.max(rOuter - thickness, 1);
|
|
52
|
+
const TWO_PI = Math.PI * 2;
|
|
53
|
+
let angle = -Math.PI / 2;
|
|
54
|
+
const polar = (r, a) => [cx + r * Math.cos(a), cy + r * Math.sin(a)];
|
|
55
|
+
items = data.map((d, i) => {
|
|
56
|
+
const frac = Math.max(d.value, 0) / total;
|
|
57
|
+
const span = Math.min(frac * TWO_PI, TWO_PI - 0.0001);
|
|
58
|
+
const a0 = angle;
|
|
59
|
+
const a1 = angle + span;
|
|
60
|
+
angle = a1;
|
|
61
|
+
const large = span > Math.PI ? 1 : 0;
|
|
62
|
+
const [x0o, y0o] = polar(rOuter, a0);
|
|
63
|
+
const [x1o, y1o] = polar(rOuter, a1);
|
|
64
|
+
const [x1i, y1i] = polar(rInner, a1);
|
|
65
|
+
const [x0i, y0i] = polar(rInner, a0);
|
|
66
|
+
const path = `M ${x0o} ${y0o} A ${rOuter} ${rOuter} 0 ${large} 1 ${x1o} ${y1o} L ${x1i} ${y1i} A ${rInner} ${rInner} 0 ${large} 0 ${x0i} ${y0i} Z`;
|
|
67
|
+
return { d, path, tone: d.tone ?? TONES[i % TONES.length], pct: frac * 100 };
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
const dataValueItems = items.map((slice) => `${slice.d.label}: ${slice.d.value} (${fmtPct(slice.pct)})`);
|
|
71
|
+
const svgChildren = [];
|
|
72
|
+
if (total > 0) {
|
|
73
|
+
for (let i = 0; i < items.length; i++) {
|
|
74
|
+
const slice = items[i];
|
|
75
|
+
svgChildren.push(h("path", {
|
|
76
|
+
key: slice.d.label,
|
|
77
|
+
class: classNames("st-donutChart__slice", `st-donutChart__slice--${slice.tone}`, hoveredIndex.value !== null && hoveredIndex.value !== i && "st-donutChart__slice--dim"),
|
|
78
|
+
d: slice.path,
|
|
79
|
+
"data-chart-index": i,
|
|
80
|
+
}));
|
|
81
|
+
}
|
|
82
|
+
if (centerLabel !== null) {
|
|
83
|
+
svgChildren.push(h("text", {
|
|
84
|
+
class: "st-donutChart__center",
|
|
85
|
+
x: size / 2,
|
|
86
|
+
y: size / 2,
|
|
87
|
+
"text-anchor": "middle",
|
|
88
|
+
"dominant-baseline": "central",
|
|
89
|
+
}, String(centerLabel ?? total)));
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
const hovered = hoveredIndex.value !== null ? items[hoveredIndex.value] : undefined;
|
|
93
|
+
return h("div", { ...attrs, class: classNames("st-donutChart", props.class) }, [
|
|
94
|
+
h("div", {
|
|
95
|
+
class: "st-donutChart__visual",
|
|
96
|
+
role: "img",
|
|
97
|
+
"aria-label": label,
|
|
98
|
+
onPointermove: handleVisualPointerMove,
|
|
99
|
+
onPointerleave: handleLeave,
|
|
100
|
+
}, [
|
|
101
|
+
h("svg", {
|
|
102
|
+
viewBox: `0 0 ${size} ${size}`,
|
|
103
|
+
width: "100%",
|
|
104
|
+
height: "100%",
|
|
105
|
+
focusable: "false",
|
|
106
|
+
"aria-hidden": "true",
|
|
107
|
+
}, svgChildren),
|
|
37
108
|
]),
|
|
109
|
+
chartDataList(label, dataValueItems),
|
|
110
|
+
hovered
|
|
111
|
+
? h("div", { class: "st-donutChart__tooltip", role: "presentation" }, [
|
|
112
|
+
h("span", { class: "st-donutChart__tooltipLabel" }, hovered.d.label),
|
|
113
|
+
h("span", { class: "st-donutChart__tooltipValue" }, `${hovered.d.value} · ${fmtPct(hovered.pct)}`),
|
|
114
|
+
])
|
|
115
|
+
: null,
|
|
38
116
|
]);
|
|
39
117
|
};
|
|
40
118
|
},
|
package/dist/DonutChart.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DonutChart.js","sourceRoot":"","sources":["../src/DonutChart.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;
|
|
1
|
+
{"version":3,"file":"DonutChart.js","sourceRoot":"","sources":["../src/DonutChart.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,CAAC,EAAE,GAAG,EAAE,MAAM,KAAK,CAAC;AAC9C,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AA2BhD,MAAM,KAAK,GAAqB;IAC9B,WAAW;IACX,WAAW;IACX,WAAW;IACX,WAAW;IACX,WAAW;IACX,WAAW;IACX,WAAW;IACX,WAAW;CACZ,CAAC;AAEF,MAAM,MAAM,GAAG,CAAC,CAAS,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,GAAG,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC;AAI9D,MAAM,CAAC,MAAM,UAAU,GAAG,eAAe,CAAC;IACxC,IAAI,EAAE,YAAY;IAClB,KAAK,EAAE;QACL,IAAI,EAAE,EAAE,IAAI,EAAE,KAAgC,EAAE,QAAQ,EAAE,IAAI,EAAE;QAChE,IAAI,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,EAAE;QACpC,SAAS,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,EAAE,EAAE;QACxC,WAAW,EAAE,EAAE,IAAI,EAAE,CAAC,MAAM,EAAE,IAAI,CAAmC,EAAE,OAAO,EAAE,SAAS,EAAE;QAC3F,KAAK,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,IAAI,EAAE;QACvC,KAAK,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE;KAC5C;IACD,KAAK,CAAC,KAAK,EAAE,EAAE,KAAK,EAAE;QACpB,MAAM,YAAY,GAAG,GAAG,CAAgB,IAAI,CAAC,CAAC;QAE9C,SAAS,WAAW;YAClB,YAAY,CAAC,KAAK,GAAG,IAAI,CAAC;QAC5B,CAAC;QACD,SAAS,uBAAuB,CAAC,KAAmB;YAClD,MAAM,MAAM,GAAG,KAAK,CAAC,MAAM,CAAC;YAC5B,IAAI,CAAC,CAAC,MAAM,YAAY,OAAO,CAAC,EAAE,CAAC;gBACjC,YAAY,CAAC,KAAK,GAAG,IAAI,CAAC;gBAC1B,OAAO;YACT,CAAC;YACD,MAAM,KAAK,GAAG,MAAM,CAAC,MAAM,CAAC,YAAY,CAAC,kBAAkB,CAAC,CAAC,CAAC;YAC9D,YAAY,CAAC,KAAK,GAAG,MAAM,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC;QAC9D,CAAC;QAED,OAAO,GAAG,EAAE;YACV,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,IAAI,GAAG,CAAC;YAC/B,MAAM,SAAS,GAAG,KAAK,CAAC,SAAS,IAAI,EAAE,CAAC;YACxC,MAAM,WAAW,GAAG,KAAK,CAAC,WAAW,CAAC;YACtC,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC;YAC1B,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC;YAExB,MAAM,KAAK,GAAG,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,CAAC,EAAE,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YACrE,IAAI,KAAK,GAAY,EAAE,CAAC;YACxB,IAAI,KAAK,GAAG,CAAC,EAAE,CAAC;gBACd,MAAM,EAAE,GAAG,IAAI,GAAG,CAAC,CAAC;gBACpB,MAAM,EAAE,GAAG,IAAI,GAAG,CAAC,CAAC;gBACpB,MAAM,MAAM,GAAG,IAAI,GAAG,CAAC,GAAG,CAAC,CAAC;gBAC5B,MAAM,MAAM,GAAG,IAAI,CAAC,GAAG,CAAC,MAAM,GAAG,SAAS,EAAE,CAAC,CAAC,CAAC;gBAC/C,MAAM,MAAM,GAAG,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC;gBAC3B,IAAI,KAAK,GAAG,CAAC,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC;gBACzB,MAAM,KAAK,GAAG,CAAC,CAAS,EAAE,CAAS,EAAoB,EAAE,CAAC,CAAC,EAAE,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,GAAG,CAAC,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;gBACvG,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;oBACxB,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,GAAG,KAAK,CAAC;oBAC1C,MAAM,IAAI,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,GAAG,MAAM,EAAE,MAAM,GAAG,MAAM,CAAC,CAAC;oBACtD,MAAM,EAAE,GAAG,KAAK,CAAC;oBACjB,MAAM,EAAE,GAAG,KAAK,GAAG,IAAI,CAAC;oBACxB,KAAK,GAAG,EAAE,CAAC;oBACX,MAAM,KAAK,GAAG,IAAI,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;oBACrC,MAAM,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;oBACrC,MAAM,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;oBACrC,MAAM,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;oBACrC,MAAM,CAAC,GAAG,EAAE,GAAG,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;oBACrC,MAAM,IAAI,GAAG,KAAK,GAAG,IAAI,GAAG,MAAM,MAAM,IAAI,MAAM,MAAM,KAAK,MAAM,GAAG,IAAI,GAAG,MAAM,GAAG,IAAI,GAAG,MAAM,MAAM,IAAI,MAAM,MAAM,KAAK,MAAM,GAAG,IAAI,GAAG,IAAI,CAAC;oBACnJ,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,IAAI,KAAK,CAAC,CAAC,GAAG,KAAK,CAAC,MAAM,CAAC,EAAE,GAAG,EAAE,IAAI,GAAG,GAAG,EAAE,CAAC;gBAC/E,CAAC,CAAC,CAAC;YACL,CAAC;YAED,MAAM,cAAc,GAAG,KAAK,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,EAAE,CAAC,GAAG,KAAK,CAAC,CAAC,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC,CAAC,KAAK,KAAK,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,GAAG,CAAC,CAAC;YAEzG,MAAM,WAAW,GAA2B,EAAE,CAAC;YAC/C,IAAI,KAAK,GAAG,CAAC,EAAE,CAAC;gBACd,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,KAAK,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;oBACtC,MAAM,KAAK,GAAG,KAAK,CAAC,CAAC,CAAC,CAAC;oBACvB,WAAW,CAAC,IAAI,CACd,CAAC,CAAC,MAAM,EAAE;wBACR,GAAG,EAAE,KAAK,CAAC,CAAC,CAAC,KAAK;wBAClB,KAAK,EAAE,UAAU,CACf,sBAAsB,EACtB,yBAAyB,KAAK,CAAC,IAAI,EAAE,EACrC,YAAY,CAAC,KAAK,KAAK,IAAI,IAAI,YAAY,CAAC,KAAK,KAAK,CAAC,IAAI,2BAA2B,CACvF;wBACD,CAAC,EAAE,KAAK,CAAC,IAAI;wBACb,kBAAkB,EAAE,CAAC;qBACtB,CAAC,CACH,CAAC;gBACJ,CAAC;gBACD,IAAI,WAAW,KAAK,IAAI,EAAE,CAAC;oBACzB,WAAW,CAAC,IAAI,CACd,CAAC,CACC,MAAM,EACN;wBACE,KAAK,EAAE,uBAAuB;wBAC9B,CAAC,EAAE,IAAI,GAAG,CAAC;wBACX,CAAC,EAAE,IAAI,GAAG,CAAC;wBACX,aAAa,EAAE,QAAQ;wBACvB,mBAAmB,EAAE,SAAS;qBAC/B,EACD,MAAM,CAAC,WAAW,IAAI,KAAK,CAAC,CAC7B,CACF,CAAC;gBACJ,CAAC;YACH,CAAC;YAED,MAAM,OAAO,GAAG,YAAY,CAAC,KAAK,KAAK,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;YAEpF,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE,GAAG,KAAK,EAAE,KAAK,EAAE,UAAU,CAAC,eAAe,EAAE,KAAK,CAAC,KAAK,CAAC,EAAE,EAAE;gBAC7E,CAAC,CACC,KAAK,EACL;oBACE,KAAK,EAAE,uBAAuB;oBAC9B,IAAI,EAAE,KAAK;oBACX,YAAY,EAAE,KAAK;oBACnB,aAAa,EAAE,uBAAuB;oBACtC,cAAc,EAAE,WAAW;iBAC5B,EACD;oBACE,CAAC,CACC,KAAK,EACL;wBACE,OAAO,EAAE,OAAO,IAAI,IAAI,IAAI,EAAE;wBAC9B,KAAK,EAAE,MAAM;wBACb,MAAM,EAAE,MAAM;wBACd,SAAS,EAAE,OAAO;wBAClB,aAAa,EAAE,MAAM;qBACtB,EACD,WAAW,CACZ;iBACF,CACF;gBACD,aAAa,CAAC,KAAK,EAAE,cAAc,CAAC;gBACpC,OAAO;oBACL,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,EAAE,KAAK,EAAE,wBAAwB,EAAE,IAAI,EAAE,cAAc,EAAE,EAAE;wBAClE,CAAC,CAAC,MAAM,EAAE,EAAE,KAAK,EAAE,6BAA6B,EAAE,EAAE,OAAO,CAAC,CAAC,CAAC,KAAK,CAAC;wBACpE,CAAC,CAAC,MAAM,EAAE,EAAE,KAAK,EAAE,6BAA6B,EAAE,EAAE,GAAG,OAAO,CAAC,CAAC,CAAC,KAAK,MAAM,MAAM,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CAAC;qBACnG,CAAC;oBACJ,CAAC,CAAC,IAAI;aACT,CAAC,CAAC;QACL,CAAC,CAAC;IACJ,CAAC;CACF,CAAC,CAAC"}
|
package/dist/Drawer.d.ts
CHANGED
|
@@ -53,9 +53,9 @@ export declare const Drawer: import("vue").DefineComponent<import("vue").Extract
|
|
|
53
53
|
}>> & Readonly<{
|
|
54
54
|
onClose?: ((...args: any[]) => any) | undefined;
|
|
55
55
|
}>, {
|
|
56
|
+
open: boolean;
|
|
56
57
|
class: string;
|
|
57
58
|
title: string;
|
|
58
|
-
open: boolean;
|
|
59
59
|
description: string;
|
|
60
60
|
placement: DrawerPlacement;
|
|
61
61
|
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
|
package/dist/Dropdown.d.ts
CHANGED
|
@@ -9,6 +9,7 @@ export type DropdownProps = {
|
|
|
9
9
|
value?: string;
|
|
10
10
|
open?: boolean;
|
|
11
11
|
placeholder?: string;
|
|
12
|
+
onSelect?: (value: string) => void;
|
|
12
13
|
class?: string;
|
|
13
14
|
};
|
|
14
15
|
export declare const Dropdown: import("vue").DefineComponent<import("vue").ExtractPropTypes<{
|
|
@@ -32,6 +33,10 @@ export declare const Dropdown: import("vue").DefineComponent<import("vue").Extra
|
|
|
32
33
|
type: StringConstructor;
|
|
33
34
|
default: string;
|
|
34
35
|
};
|
|
36
|
+
onSelect: {
|
|
37
|
+
type: () => (value: string) => void;
|
|
38
|
+
default: undefined;
|
|
39
|
+
};
|
|
35
40
|
class: {
|
|
36
41
|
type: StringConstructor;
|
|
37
42
|
default: undefined;
|
|
@@ -59,6 +64,10 @@ export declare const Dropdown: import("vue").DefineComponent<import("vue").Extra
|
|
|
59
64
|
type: StringConstructor;
|
|
60
65
|
default: string;
|
|
61
66
|
};
|
|
67
|
+
onSelect: {
|
|
68
|
+
type: () => (value: string) => void;
|
|
69
|
+
default: undefined;
|
|
70
|
+
};
|
|
62
71
|
class: {
|
|
63
72
|
type: StringConstructor;
|
|
64
73
|
default: undefined;
|
|
@@ -67,10 +76,11 @@ export declare const Dropdown: import("vue").DefineComponent<import("vue").Extra
|
|
|
67
76
|
onSelect?: ((...args: any[]) => any) | undefined;
|
|
68
77
|
"onUpdate:open"?: ((...args: any[]) => any) | undefined;
|
|
69
78
|
}>, {
|
|
79
|
+
open: boolean;
|
|
70
80
|
class: string;
|
|
71
81
|
label: string;
|
|
82
|
+
onSelect: (value: string) => void;
|
|
72
83
|
value: string;
|
|
73
84
|
placeholder: string;
|
|
74
|
-
open: boolean;
|
|
75
85
|
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, true, {}, any>;
|
|
76
86
|
//# sourceMappingURL=Dropdown.d.ts.map
|
package/dist/Dropdown.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Dropdown.d.ts","sourceRoot":"","sources":["../src/Dropdown.ts"],"names":[],"mappings":"AAGA,MAAM,MAAM,cAAc,GAAG;IAC3B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,OAAO,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB,CAAC;
|
|
1
|
+
{"version":3,"file":"Dropdown.d.ts","sourceRoot":"","sources":["../src/Dropdown.ts"],"names":[],"mappings":"AAGA,MAAM,MAAM,cAAc,GAAG;IAC3B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,OAAO,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB,CAAC;AAIF,MAAM,MAAM,aAAa,GAAG;IAC1B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,OAAO,EAAE,cAAc,EAAE,CAAC;IAC1B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,eAAO,MAAM,QAAQ;;;;;;cAIS,MAAM,cAAc,EAAE;;;;;;;;;;;;;;;;cAIP,MAAM,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI;;;;;;;;;;;;;;;cAJ5C,MAAM,cAAc,EAAE;;;;;;;;;;;;;;;;cAIP,MAAM,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI;;;;;;;;;;;;;;sBAAf,MAAM,KAAK,IAAI;;;4EA8FxE,CAAC"}
|
package/dist/Dropdown.js
CHANGED
|
@@ -8,6 +8,7 @@ export const Dropdown = defineComponent({
|
|
|
8
8
|
value: { type: String, default: undefined },
|
|
9
9
|
open: { type: Boolean, default: undefined },
|
|
10
10
|
placeholder: { type: String, default: "Select" },
|
|
11
|
+
onSelect: { type: Function, default: undefined },
|
|
11
12
|
class: { type: String, default: undefined },
|
|
12
13
|
},
|
|
13
14
|
emits: ["select", "update:open"],
|
package/dist/Dropdown.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Dropdown.js","sourceRoot":"","sources":["../src/Dropdown.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,CAAC,EAAE,GAAG,EAAE,KAAK,EAAE,WAAW,EAAE,MAAM,KAAK,CAAC;AAClE,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;
|
|
1
|
+
{"version":3,"file":"Dropdown.js","sourceRoot":"","sources":["../src/Dropdown.ts"],"names":[],"mappings":"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"}
|
package/dist/FileUploader.d.ts
CHANGED
|
@@ -1,8 +1,17 @@
|
|
|
1
1
|
export type FileUploadStatus = "idle" | "uploading" | "complete" | "error";
|
|
2
|
+
/**
|
|
3
|
+
* Accepts both the flat React/Vue shape (`{ name, size }`) and the Svelte
|
|
4
|
+
* canonical shape (`{ file: { name, size } }`). When `file` is present it takes
|
|
5
|
+
* precedence so a consumer can pass the exact same item array used in Svelte.
|
|
6
|
+
*/
|
|
2
7
|
export type FileUploadItem = {
|
|
3
8
|
id?: string;
|
|
4
|
-
name
|
|
9
|
+
name?: string;
|
|
5
10
|
size?: number;
|
|
11
|
+
file?: {
|
|
12
|
+
name: string;
|
|
13
|
+
size?: number;
|
|
14
|
+
};
|
|
6
15
|
status?: FileUploadStatus;
|
|
7
16
|
error?: string;
|
|
8
17
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"FileUploader.d.ts","sourceRoot":"","sources":["../src/FileUploader.ts"],"names":[],"mappings":"AAGA,MAAM,MAAM,gBAAgB,GAAG,MAAM,GAAG,WAAW,GAAG,UAAU,GAAG,OAAO,CAAC;AAE3E,MAAM,MAAM,cAAc,GAAG;IAC3B,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,IAAI,EAAE,MAAM,CAAC;
|
|
1
|
+
{"version":3,"file":"FileUploader.d.ts","sourceRoot":"","sources":["../src/FileUploader.ts"],"names":[],"mappings":"AAGA,MAAM,MAAM,gBAAgB,GAAG,MAAM,GAAG,WAAW,GAAG,UAAU,GAAG,OAAO,CAAC;AAE3E;;;;GAIG;AACH,MAAM,MAAM,cAAc,GAAG;IAC3B,EAAE,CAAC,EAAE,MAAM,CAAC;IACZ,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE;QAAE,IAAI,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,CAAA;KAAE,CAAC;IACvC,MAAM,CAAC,EAAE,gBAAgB,CAAC;IAC1B,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAoBF,MAAM,MAAM,iBAAiB,GAAG;IAC9B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,cAAc,EAAE,CAAC;IACzB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,eAAO,MAAM,YAAY;;;;;;cAIG,MAAM,cAAc,EAAE;;;;;;;;;;;;;;;;;;;cAAtB,MAAM,cAAc,EAAE;;;;;;;;;;;;;;;;4EAyEhD,CAAC"}
|
package/dist/FileUploader.js
CHANGED
|
@@ -1,5 +1,22 @@
|
|
|
1
1
|
import { defineComponent, h } from "vue";
|
|
2
2
|
import { classNames } from "./classNames.js";
|
|
3
|
+
function formatFileSize(bytes) {
|
|
4
|
+
if (typeof bytes !== "number" || !Number.isFinite(bytes) || bytes < 0)
|
|
5
|
+
return "";
|
|
6
|
+
if (bytes === 0)
|
|
7
|
+
return "0 B";
|
|
8
|
+
const units = ["B", "KB", "MB", "GB", "TB"];
|
|
9
|
+
const i = Math.min(Math.floor(Math.log(bytes) / Math.log(1024)), units.length - 1);
|
|
10
|
+
const value = bytes / Math.pow(1024, i);
|
|
11
|
+
const formatted = value >= 10 || i === 0 ? value.toFixed(0) : value.toFixed(1);
|
|
12
|
+
return `${formatted} ${units[i]}`;
|
|
13
|
+
}
|
|
14
|
+
function fileItemName(item) {
|
|
15
|
+
return item.file?.name ?? item.name;
|
|
16
|
+
}
|
|
17
|
+
function fileItemSize(item) {
|
|
18
|
+
return item.file?.size ?? item.size;
|
|
19
|
+
}
|
|
3
20
|
export const FileUploader = defineComponent({
|
|
4
21
|
name: "FileUploader",
|
|
5
22
|
props: {
|
|
@@ -24,15 +41,22 @@ export const FileUploader = defineComponent({
|
|
|
24
41
|
"aria-label": props.label,
|
|
25
42
|
}),
|
|
26
43
|
]),
|
|
27
|
-
h("ul", { class: "st-fileUploader__list" }, props.items.map((item, index) =>
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
:
|
|
35
|
-
|
|
44
|
+
h("ul", { class: "st-fileUploader__list" }, props.items.map((item, index) => {
|
|
45
|
+
const name = fileItemName(item);
|
|
46
|
+
const sizeLabel = formatFileSize(fileItemSize(item));
|
|
47
|
+
return h("li", {
|
|
48
|
+
key: item.id ?? name ?? index,
|
|
49
|
+
class: classNames("st-fileUploader__item", item.status && `st-fileUploader__item--${item.status}`),
|
|
50
|
+
}, [
|
|
51
|
+
h("span", { class: "st-fileUploader__itemName st-fileUploader__name" }, name),
|
|
52
|
+
sizeLabel
|
|
53
|
+
? h("span", { class: "st-fileUploader__itemSize" }, sizeLabel)
|
|
54
|
+
: null,
|
|
55
|
+
item.error
|
|
56
|
+
? h("span", { class: "st-fileUploader__itemError" }, item.error)
|
|
57
|
+
: null,
|
|
58
|
+
]);
|
|
59
|
+
})),
|
|
36
60
|
]);
|
|
37
61
|
},
|
|
38
62
|
});
|