@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.
Files changed (123) hide show
  1. package/dist/Accordion.d.ts +26 -4
  2. package/dist/Accordion.d.ts.map +1 -1
  3. package/dist/Accordion.js +7 -4
  4. package/dist/Accordion.js.map +1 -1
  5. package/dist/AreaChart.d.ts +38 -21
  6. package/dist/AreaChart.d.ts.map +1 -1
  7. package/dist/AreaChart.js +154 -40
  8. package/dist/AreaChart.js.map +1 -1
  9. package/dist/BackToTop.d.ts +79 -0
  10. package/dist/BackToTop.d.ts.map +1 -0
  11. package/dist/BackToTop.js +72 -0
  12. package/dist/BackToTop.js.map +1 -0
  13. package/dist/BarChart.d.ts +23 -16
  14. package/dist/BarChart.d.ts.map +1 -1
  15. package/dist/BarChart.js +137 -30
  16. package/dist/BarChart.js.map +1 -1
  17. package/dist/Combobox.d.ts +1 -1
  18. package/dist/ContentSwitcher.d.ts +10 -0
  19. package/dist/ContentSwitcher.d.ts.map +1 -1
  20. package/dist/ContentSwitcher.js +5 -1
  21. package/dist/ContentSwitcher.js.map +1 -1
  22. package/dist/CopyButton.d.ts +1 -1
  23. package/dist/DataTable.d.ts +208 -18
  24. package/dist/DataTable.d.ts.map +1 -1
  25. package/dist/DataTable.js +267 -26
  26. package/dist/DataTable.js.map +1 -1
  27. package/dist/DisplaySettings.d.ts +90 -0
  28. package/dist/DisplaySettings.d.ts.map +1 -0
  29. package/dist/DisplaySettings.js +91 -0
  30. package/dist/DisplaySettings.js.map +1 -0
  31. package/dist/DonutChart.d.ts +33 -26
  32. package/dist/DonutChart.d.ts.map +1 -1
  33. package/dist/DonutChart.js +104 -26
  34. package/dist/DonutChart.js.map +1 -1
  35. package/dist/Drawer.d.ts +1 -1
  36. package/dist/Dropdown.d.ts +11 -1
  37. package/dist/Dropdown.d.ts.map +1 -1
  38. package/dist/Dropdown.js +1 -0
  39. package/dist/Dropdown.js.map +1 -1
  40. package/dist/FileUploader.d.ts +10 -1
  41. package/dist/FileUploader.d.ts.map +1 -1
  42. package/dist/FileUploader.js +33 -9
  43. package/dist/FileUploader.js.map +1 -1
  44. package/dist/ForceGraph.d.ts +1 -1
  45. package/dist/LanguageSelector.d.ts +1 -1
  46. package/dist/LineChart.d.ts +42 -16
  47. package/dist/LineChart.d.ts.map +1 -1
  48. package/dist/LineChart.js +146 -35
  49. package/dist/LineChart.js.map +1 -1
  50. package/dist/MediaContent.d.ts +130 -0
  51. package/dist/MediaContent.d.ts.map +1 -0
  52. package/dist/MediaContent.js +53 -0
  53. package/dist/MediaContent.js.map +1 -0
  54. package/dist/Menu.d.ts +7 -3
  55. package/dist/Menu.d.ts.map +1 -1
  56. package/dist/Menu.js +17 -7
  57. package/dist/Menu.js.map +1 -1
  58. package/dist/MenuPopover.d.ts +1 -1
  59. package/dist/MenuTriggerButton.d.ts +13 -3
  60. package/dist/MenuTriggerButton.d.ts.map +1 -1
  61. package/dist/MenuTriggerButton.js +4 -2
  62. package/dist/MenuTriggerButton.js.map +1 -1
  63. package/dist/MessageActions.d.ts +7 -1
  64. package/dist/MessageActions.d.ts.map +1 -1
  65. package/dist/MessageActions.js +4 -1
  66. package/dist/MessageActions.js.map +1 -1
  67. package/dist/Modal.d.ts +1 -1
  68. package/dist/MultiSelect.d.ts +1 -1
  69. package/dist/Notification.d.ts +71 -0
  70. package/dist/Notification.d.ts.map +1 -0
  71. package/dist/Notification.js +43 -0
  72. package/dist/Notification.js.map +1 -0
  73. package/dist/NumberInput.d.ts +13 -2
  74. package/dist/NumberInput.d.ts.map +1 -1
  75. package/dist/NumberInput.js +2 -1
  76. package/dist/NumberInput.js.map +1 -1
  77. package/dist/OverflowMenu.d.ts +1 -1
  78. package/dist/PaginationNav.d.ts +12 -2
  79. package/dist/PaginationNav.d.ts.map +1 -1
  80. package/dist/PaginationNav.js +3 -2
  81. package/dist/PaginationNav.js.map +1 -1
  82. package/dist/Popover.d.ts +1 -1
  83. package/dist/ProgressBar.d.ts +1 -1
  84. package/dist/ScatterPlot.d.ts +43 -14
  85. package/dist/ScatterPlot.d.ts.map +1 -1
  86. package/dist/ScatterPlot.js +113 -25
  87. package/dist/ScatterPlot.js.map +1 -1
  88. package/dist/Search.d.ts +11 -0
  89. package/dist/Search.d.ts.map +1 -1
  90. package/dist/Search.js +2 -1
  91. package/dist/Search.js.map +1 -1
  92. package/dist/Slider.d.ts +2 -2
  93. package/dist/Sparkline.d.ts +47 -7
  94. package/dist/Sparkline.d.ts.map +1 -1
  95. package/dist/Sparkline.js +57 -21
  96. package/dist/Sparkline.js.map +1 -1
  97. package/dist/StackedBarChart.d.ts +25 -16
  98. package/dist/StackedBarChart.d.ts.map +1 -1
  99. package/dist/StackedBarChart.js +131 -39
  100. package/dist/StackedBarChart.js.map +1 -1
  101. package/dist/TableOfContents.d.ts +53 -0
  102. package/dist/TableOfContents.d.ts.map +1 -0
  103. package/dist/TableOfContents.js +39 -0
  104. package/dist/TableOfContents.js.map +1 -0
  105. package/dist/Tabs.d.ts +10 -0
  106. package/dist/Tabs.d.ts.map +1 -1
  107. package/dist/Tabs.js +2 -0
  108. package/dist/Tabs.js.map +1 -1
  109. package/dist/Toggletip.d.ts +1 -1
  110. package/dist/Transcription.d.ts +75 -0
  111. package/dist/Transcription.d.ts.map +1 -0
  112. package/dist/Transcription.js +59 -0
  113. package/dist/Transcription.js.map +1 -0
  114. package/dist/chartScale.d.ts +22 -0
  115. package/dist/chartScale.d.ts.map +1 -0
  116. package/dist/chartScale.js +70 -0
  117. package/dist/chartScale.js.map +1 -0
  118. package/dist/index.d.ts +13 -1
  119. package/dist/index.d.ts.map +1 -1
  120. package/dist/index.js +6 -0
  121. package/dist/index.js.map +1 -1
  122. package/dist/styles.css +260 -0
  123. 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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"}
@@ -1,16 +1,15 @@
1
+ export type DonutChartTone = "category1" | "category2" | "category3" | "category4" | "category5" | "category6" | "category7" | "category8";
1
2
  export type DonutChartDatum = {
2
- label?: string;
3
- x?: string | number;
4
- y?: number;
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
- label?: string;
12
- width?: number;
13
- height?: number;
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
- label: {
22
- type: StringConstructor;
23
- default: string;
24
- };
25
- width: {
20
+ size: {
26
21
  type: NumberConstructor;
27
- default: undefined;
22
+ default: number;
28
23
  };
29
- height: {
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
- label: {
45
- type: StringConstructor;
46
- default: string;
47
- };
48
- width: {
47
+ size: {
49
48
  type: NumberConstructor;
50
- default: undefined;
49
+ default: number;
51
50
  };
52
- height: {
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
- label: string;
63
- width: number;
64
- height: number;
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
@@ -1 +1 @@
1
- {"version":3,"file":"DonutChart.d.ts","sourceRoot":"","sources":["../src/DonutChart.ts"],"names":[],"mappings":"AAGA,MAAM,MAAM,eAAe,GAAG;IAAE,KAAK,CAAC,EAAE,MAAM,CAAC;IAAC,CAAC,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IAAC,CAAC,CAAC,EAAE,MAAM,CAAC;IAAC,KAAK,CAAC,EAAE,MAAM,CAAC;IAAC,IAAI,CAAC,EAAE,MAAM,CAAA;CAAE,CAAC;AACjH,MAAM,MAAM,cAAc,GAAG,MAAM,CAAC;AAEpC,MAAM,MAAM,eAAe,GAAG;IAC5B,IAAI,EAAE,eAAe,EAAE,CAAC;IACxB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAOF,eAAO,MAAM,UAAU;;cAGI,MAAM,eAAe,EAAE;;;;;;;;;;;;;;;;;;;;;;;cAAvB,MAAM,eAAe,EAAE;;;;;;;;;;;;;;;;;;;;;;;;4EAwChD,CAAC"}
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"}
@@ -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
- const DATA_TONES = [
4
- "category1", "category2", "category3", "category4",
5
- "category5", "category6", "category7", "category8",
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
- label: { type: String, default: "Donut chart" },
12
- width: { type: Number, default: undefined },
13
- height: { type: Number, default: undefined },
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 label = props.label ?? "Donut chart";
19
- const total = props.data.reduce((sum, datum) => sum + (datum.value ?? datum.y ?? 0), 0);
20
- return h("figure", {
21
- ...attrs,
22
- class: classNames("st-donutChart", props.class),
23
- "aria-label": label,
24
- }, [
25
- h("span", { class: "st-visually-hidden" }, label),
26
- h("svg", { viewBox: "0 0 120 120", "aria-hidden": "true" }, [
27
- ...props.data.map((datum, index) => h("circle", {
28
- key: index,
29
- class: classNames("st-donutChart__slice", `st-donutChart__slice--${datum.tone ?? DATA_TONES[index % DATA_TONES.length]}`),
30
- cx: "60",
31
- cy: "60",
32
- r: 36 - index * 3,
33
- fill: "none",
34
- "stroke-width": "8",
35
- })),
36
- h("text", { class: "st-donutChart__center", x: "60", y: "64", "text-anchor": "middle" }, String(total)),
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
  },
@@ -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;AACzC,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAa7C,MAAM,UAAU,GAAG;IACjB,WAAW,EAAE,WAAW,EAAE,WAAW,EAAE,WAAW;IAClD,WAAW,EAAE,WAAW,EAAE,WAAW,EAAE,WAAW;CACnD,CAAC;AAEF,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,KAAK,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,aAAa,EAAE;QAC/C,KAAK,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE;QAC3C,MAAM,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE;QAC5C,KAAK,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,SAAS,EAAE;KAC5C;IACD,KAAK,CAAC,KAAK,EAAE,EAAE,KAAK,EAAE;QACpB,OAAO,GAAG,EAAE;YACV,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,IAAI,aAAa,CAAC;YAC3C,MAAM,KAAK,GAAG,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,KAAK,EAAE,EAAE,CAAC,GAAG,GAAG,CAAC,KAAK,CAAC,KAAK,IAAI,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;YACxF,OAAO,CAAC,CACN,QAAQ,EACR;gBACE,GAAG,KAAK;gBACR,KAAK,EAAE,UAAU,CAAC,eAAe,EAAE,KAAK,CAAC,KAAK,CAAC;gBAC/C,YAAY,EAAE,KAAK;aACpB,EACD;gBACE,CAAC,CAAC,MAAM,EAAE,EAAE,KAAK,EAAE,oBAAoB,EAAE,EAAE,KAAK,CAAC;gBACjD,CAAC,CAAC,KAAK,EAAE,EAAE,OAAO,EAAE,aAAa,EAAE,aAAa,EAAE,MAAM,EAAE,EAAE;oBAC1D,GAAG,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,EAAE,CACjC,CAAC,CAAC,QAAQ,EAAE;wBACV,GAAG,EAAE,KAAK;wBACV,KAAK,EAAE,UAAU,CACf,sBAAsB,EACtB,yBAAyB,KAAK,CAAC,IAAI,IAAI,UAAU,CAAC,KAAK,GAAG,UAAU,CAAC,MAAM,CAAC,EAAE,CAC/E;wBACD,EAAE,EAAE,IAAI;wBACR,EAAE,EAAE,IAAI;wBACR,CAAC,EAAE,EAAE,GAAG,KAAK,GAAG,CAAC;wBACjB,IAAI,EAAE,MAAM;wBACZ,cAAc,EAAE,GAAG;qBACpB,CAAC,CACH;oBACD,CAAC,CAAC,MAAM,EAAE,EAAE,KAAK,EAAE,uBAAuB,EAAE,CAAC,EAAE,IAAI,EAAE,CAAC,EAAE,IAAI,EAAE,aAAa,EAAE,QAAQ,EAAE,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC;iBACxG,CAAC;aACH,CACF,CAAC;QACJ,CAAC,CAAC;IACJ,CAAC;CACF,CAAC,CAAC"}
1
+ {"version":3,"file":"DonutChart.js","sourceRoot":"","sources":["../src/DonutChart.ts"],"names":[],"mappings":"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"}
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>;
@@ -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
@@ -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;AAEF,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,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,eAAO,MAAM,QAAQ;;;;;;cAIS,MAAM,cAAc,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;cAAtB,MAAM,cAAc,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;4EAiGlD,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"],
@@ -1 +1 @@
1
- {"version":3,"file":"Dropdown.js","sourceRoot":"","sources":["../src/Dropdown.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"Dropdown.js","sourceRoot":"","sources":["../src/Dropdown.ts"],"names":[],"mappings":"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"}
@@ -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: string;
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;IACb,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,MAAM,CAAC,EAAE,gBAAgB,CAAC;IAC1B,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAEF,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;;;;;;;;;;;;;;;;4EAgEhD,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"}
@@ -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) => h("li", {
28
- key: item.id ?? item.name ?? index,
29
- class: classNames("st-fileUploader__item", item.status && `st-fileUploader__item--${item.status}`),
30
- }, [
31
- h("span", { class: "st-fileUploader__itemName st-fileUploader__name" }, item.name),
32
- item.error
33
- ? h("span", { class: "st-fileUploader__itemError" }, item.error)
34
- : null,
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
  });