@mittwald/flow-react-components 0.2.0-alpha.273 → 0.2.0-alpha.275

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 (46) hide show
  1. package/CHANGELOG.md +12 -0
  2. package/dist/assets/doc-properties.json +1152 -447
  3. package/dist/css/all.css +1 -1
  4. package/dist/js/components/src/components/DonutChart/DonutChart.mjs +73 -0
  5. package/dist/js/components/src/components/DonutChart/DonutChart.mjs.map +1 -0
  6. package/dist/js/components/src/components/DonutChart/DonutChart.module.scss.mjs +38 -0
  7. package/dist/js/components/src/components/DonutChart/DonutChart.module.scss.mjs.map +1 -0
  8. package/dist/js/components/src/components/DonutChart/components/Donut.mjs +68 -0
  9. package/dist/js/components/src/components/DonutChart/components/Donut.mjs.map +1 -0
  10. package/dist/js/components/src/components/DonutChart/components/DonutChartFill.mjs +46 -0
  11. package/dist/js/components/src/components/DonutChart/components/DonutChartFill.mjs.map +1 -0
  12. package/dist/js/components/src/components/DonutChart/components/DonutChartLegend.mjs +30 -0
  13. package/dist/js/components/src/components/DonutChart/components/DonutChartLegend.mjs.map +1 -0
  14. package/dist/js/components/src/components/DonutChart/components/DonutChartValue.mjs +19 -0
  15. package/dist/js/components/src/components/DonutChart/components/DonutChartValue.mjs.map +1 -0
  16. package/dist/js/components/src/components/List/model/sorting/Sorting.mjs +6 -2
  17. package/dist/js/components/src/components/List/model/sorting/Sorting.mjs.map +1 -1
  18. package/dist/js/components/src/components/ProgressBar/ProgressBar.mjs +3 -3
  19. package/dist/js/components/src/components/ProgressBar/ProgressBar.mjs.map +1 -1
  20. package/dist/js/default.mjs +1 -0
  21. package/dist/js/default.mjs.map +1 -1
  22. package/dist/types/components/DonutChart/DonutChart.d.ts +27 -0
  23. package/dist/types/components/DonutChart/DonutChart.d.ts.map +1 -0
  24. package/dist/types/components/DonutChart/components/Donut.d.ts +8 -0
  25. package/dist/types/components/DonutChart/components/Donut.d.ts.map +1 -0
  26. package/dist/types/components/DonutChart/components/DonutChartFill.d.ts +11 -0
  27. package/dist/types/components/DonutChart/components/DonutChartFill.d.ts.map +1 -0
  28. package/dist/types/components/DonutChart/components/DonutChartLegend.d.ts +6 -0
  29. package/dist/types/components/DonutChart/components/DonutChartLegend.d.ts.map +1 -0
  30. package/dist/types/components/DonutChart/components/DonutChartValue.d.ts +8 -0
  31. package/dist/types/components/DonutChart/components/DonutChartValue.d.ts.map +1 -0
  32. package/dist/types/components/DonutChart/index.d.ts +3 -0
  33. package/dist/types/components/DonutChart/index.d.ts.map +1 -0
  34. package/dist/types/components/DonutChart/stories/Default.stories.d.ts +11 -0
  35. package/dist/types/components/DonutChart/stories/Default.stories.d.ts.map +1 -0
  36. package/dist/types/components/DonutChart/stories/EdgeCases.stories.d.ts +8 -0
  37. package/dist/types/components/DonutChart/stories/EdgeCases.stories.d.ts.map +1 -0
  38. package/dist/types/components/DonutChart/view.d.ts +8 -0
  39. package/dist/types/components/DonutChart/view.d.ts.map +1 -0
  40. package/dist/types/components/List/model/sorting/Sorting.d.ts.map +1 -1
  41. package/dist/types/components/ProgressBar/ProgressBar.d.ts.map +1 -1
  42. package/dist/types/components/public.d.ts +1 -0
  43. package/dist/types/components/public.d.ts.map +1 -1
  44. package/dist/types/views/DonutChartView.d.ts +5 -0
  45. package/dist/types/views/DonutChartView.d.ts.map +1 -0
  46. package/package.json +4 -4
@@ -0,0 +1,73 @@
1
+ "use client"
2
+ /* */
3
+ import { jsx, jsxs } from 'react/jsx-runtime';
4
+ import * as Aria from 'react-aria-components';
5
+ import clsx from 'clsx';
6
+ import styles from './DonutChart.module.scss.mjs';
7
+ import { DonutChartValue } from './components/DonutChartValue.mjs';
8
+ import { Donut } from './components/Donut.mjs';
9
+ import { Wrap } from '../Wrap/Wrap.mjs';
10
+ import { DonutChartLegend } from './components/DonutChartLegend.mjs';
11
+
12
+ const DonutChart = (props) => {
13
+ const {
14
+ size = "m",
15
+ status = "info",
16
+ className,
17
+ value,
18
+ segments,
19
+ maxValue,
20
+ formatOptions,
21
+ showLegend = true,
22
+ legendPosition = "right",
23
+ children,
24
+ ...rest
25
+ } = props;
26
+ const rootClassName = clsx(
27
+ styles.donutChart,
28
+ size === "l" && styles["size-l"],
29
+ styles[status],
30
+ className
31
+ );
32
+ const segmentsTotalValue = segments ? segments.map((s) => s.value).reduce((a, b) => a + b, 0) : void 0;
33
+ return /* @__PURE__ */ jsx(Wrap, { if: showLegend && segments, children: /* @__PURE__ */ jsxs("div", { className: clsx(styles.donutChartContainer, styles[legendPosition]), children: [
34
+ /* @__PURE__ */ jsxs(
35
+ Aria.ProgressBar,
36
+ {
37
+ className: rootClassName,
38
+ value: segmentsTotalValue ?? value,
39
+ ...rest,
40
+ children: [
41
+ /* @__PURE__ */ jsx(
42
+ Donut,
43
+ {
44
+ value: segmentsTotalValue ?? value,
45
+ segments,
46
+ size,
47
+ maxValue
48
+ }
49
+ ),
50
+ /* @__PURE__ */ jsx(
51
+ DonutChartValue,
52
+ {
53
+ value: segmentsTotalValue ?? value,
54
+ formatOptions,
55
+ children
56
+ }
57
+ )
58
+ ]
59
+ }
60
+ ),
61
+ showLegend && segments && /* @__PURE__ */ jsx(
62
+ DonutChartLegend,
63
+ {
64
+ showLegend,
65
+ segments,
66
+ formatOptions
67
+ }
68
+ )
69
+ ] }) });
70
+ };
71
+
72
+ export { DonutChart, DonutChart as default };
73
+ //# sourceMappingURL=DonutChart.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DonutChart.mjs","sources":["../../../../../../src/components/DonutChart/DonutChart.tsx"],"sourcesContent":["import type { FC, PropsWithChildren } from \"react\";\nimport * as Aria from \"react-aria-components\";\nimport clsx from \"clsx\";\nimport styles from \"./DonutChart.module.scss\";\nimport type { PropsWithStatus } from \"@/lib/types/props\";\nimport type { CategoricalColors } from \"@/lib/tokens/CategoricalColors\";\nimport { DonutChartValue } from \"@/components/DonutChart/components/DonutChartValue\";\nimport { Donut } from \"@/components/DonutChart/components/Donut\";\nimport { Wrap } from \"@/components/Wrap\";\nimport { DonutChartLegend } from \"@/components/DonutChart/components/DonutChartLegend\";\n\nexport interface DonutChartSegment {\n value: number;\n title: string;\n color?: CategoricalColors;\n valueText?: string;\n}\n\nexport interface DonutChartProps\n extends Omit<Aria.ProgressBarProps, \"children\" | \"valueLabel\">,\n PropsWithStatus,\n PropsWithChildren {\n /** The size variant of the donut chart. @default \"m\" */\n size?: \"m\" | \"l\";\n /** Divides the fill of the donut chart into segments */\n segments?: DonutChartSegment[];\n /**\n * Whether the legend component is shown when segments are used. @default:\n * true\n */\n showLegend?: boolean;\n /** The position of the legend. @default \"right\" */\n legendPosition?: \"top\" | \"left\" | \"bottom\" | \"right\";\n}\n\n/** @flr-generate all */\nexport const DonutChart: FC<DonutChartProps> = (props) => {\n const {\n size = \"m\",\n status = \"info\",\n className,\n value,\n segments,\n maxValue,\n formatOptions,\n showLegend = true,\n legendPosition = \"right\",\n children,\n ...rest\n } = props;\n\n const rootClassName = clsx(\n styles.donutChart,\n size === \"l\" && styles[\"size-l\"],\n styles[status],\n className,\n );\n\n const segmentsTotalValue = segments\n ? segments.map((s) => s.value).reduce((a, b) => a + b, 0)\n : undefined;\n\n return (\n <Wrap if={showLegend && segments}>\n <div className={clsx(styles.donutChartContainer, styles[legendPosition])}>\n <Aria.ProgressBar\n className={rootClassName}\n value={segmentsTotalValue ?? value}\n {...rest}\n >\n <Donut\n value={segmentsTotalValue ?? value}\n segments={segments}\n size={size}\n maxValue={maxValue}\n />\n <DonutChartValue\n value={segmentsTotalValue ?? value}\n formatOptions={formatOptions}\n >\n {children}\n </DonutChartValue>\n </Aria.ProgressBar>\n\n {showLegend && segments && (\n <DonutChartLegend\n showLegend={showLegend}\n segments={segments}\n formatOptions={formatOptions}\n />\n )}\n </div>\n </Wrap>\n );\n};\n\nexport default DonutChart;\n"],"names":[],"mappings":";;;;;;;;;AAoCa,MAAA,UAAA,GAAkC,CAAC,KAAU,KAAA;AACxD,EAAM,MAAA;AAAA,IACJ,IAAO,GAAA,GAAA;AAAA,IACP,MAAS,GAAA,MAAA;AAAA,IACT,SAAA;AAAA,IACA,KAAA;AAAA,IACA,QAAA;AAAA,IACA,QAAA;AAAA,IACA,aAAA;AAAA,IACA,UAAa,GAAA,IAAA;AAAA,IACb,cAAiB,GAAA,OAAA;AAAA,IACjB,QAAA;AAAA,IACA,GAAG;AAAA,GACD,GAAA,KAAA;AAEJ,EAAA,MAAM,aAAgB,GAAA,IAAA;AAAA,IACpB,MAAO,CAAA,UAAA;AAAA,IACP,IAAA,KAAS,GAAO,IAAA,MAAA,CAAO,QAAQ,CAAA;AAAA,IAC/B,OAAO,MAAM,CAAA;AAAA,IACb;AAAA,GACF;AAEA,EAAA,MAAM,qBAAqB,QACvB,GAAA,QAAA,CAAS,GAAI,CAAA,CAAC,MAAM,CAAE,CAAA,KAAK,CAAE,CAAA,MAAA,CAAO,CAAC,CAAG,EAAA,CAAA,KAAM,CAAI,GAAA,CAAA,EAAG,CAAC,CACtD,GAAA,MAAA;AAEJ,EAAA,uBACG,GAAA,CAAA,IAAA,EAAA,EAAK,EAAI,EAAA,UAAA,IAAc,UACtB,QAAC,kBAAA,IAAA,CAAA,KAAA,EAAA,EAAI,SAAW,EAAA,IAAA,CAAK,MAAO,CAAA,mBAAA,EAAqB,MAAO,CAAA,cAAc,CAAC,CACrE,EAAA,QAAA,EAAA;AAAA,oBAAA,IAAA;AAAA,MAAC,IAAK,CAAA,WAAA;AAAA,MAAL;AAAA,QACC,SAAW,EAAA,aAAA;AAAA,QACX,OAAO,kBAAsB,IAAA,KAAA;AAAA,QAC5B,GAAG,IAAA;AAAA,QAEJ,QAAA,EAAA;AAAA,0BAAA,GAAA;AAAA,YAAC,KAAA;AAAA,YAAA;AAAA,cACC,OAAO,kBAAsB,IAAA,KAAA;AAAA,cAC7B,QAAA;AAAA,cACA,IAAA;AAAA,cACA;AAAA;AAAA,WACF;AAAA,0BACA,GAAA;AAAA,YAAC,eAAA;AAAA,YAAA;AAAA,cACC,OAAO,kBAAsB,IAAA,KAAA;AAAA,cAC7B,aAAA;AAAA,cAEC;AAAA;AAAA;AACH;AAAA;AAAA,KACF;AAAA,IAEC,cAAc,QACb,oBAAA,GAAA;AAAA,MAAC,gBAAA;AAAA,MAAA;AAAA,QACC,UAAA;AAAA,QACA,QAAA;AAAA,QACA;AAAA;AAAA;AACF,GAAA,EAEJ,CACF,EAAA,CAAA;AAEJ;;;;"}
@@ -0,0 +1,38 @@
1
+ "use client"
2
+ /* */
3
+ const donutChart = "flow--donut-chart";
4
+ const border = "flow--donut-chart--border";
5
+ const background = "flow--donut-chart--background";
6
+ const value = "flow--donut-chart--value";
7
+ const info = "flow--donut-chart--info";
8
+ const fill = "flow--donut-chart--fill";
9
+ const success = "flow--donut-chart--success";
10
+ const danger = "flow--donut-chart--danger";
11
+ const warning = "flow--donut-chart--warning";
12
+ const donutChartContainer = "flow--donut-chart--donut-chart-container";
13
+ const bottom = "flow--donut-chart--bottom";
14
+ const top = "flow--donut-chart--top";
15
+ const right = "flow--donut-chart--right";
16
+ const legend = "flow--donut-chart--legend";
17
+ const left = "flow--donut-chart--left";
18
+ const styles = {
19
+ donutChart: donutChart,
20
+ border: border,
21
+ background: background,
22
+ value: value,
23
+ "size-l": "flow--donut-chart--size-l",
24
+ info: info,
25
+ fill: fill,
26
+ success: success,
27
+ danger: danger,
28
+ warning: warning,
29
+ donutChartContainer: donutChartContainer,
30
+ bottom: bottom,
31
+ top: top,
32
+ right: right,
33
+ legend: legend,
34
+ left: left
35
+ };
36
+
37
+ export { background, border, bottom, danger, styles as default, donutChart, donutChartContainer, fill, info, left, legend, right, success, top, value, warning };
38
+ //# sourceMappingURL=DonutChart.module.scss.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DonutChart.module.scss.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,68 @@
1
+ "use client"
2
+ /* */
3
+ import { jsx, Fragment, jsxs } from 'react/jsx-runtime';
4
+ import styles from '../DonutChart.module.scss.mjs';
5
+ import { DonutChartFill } from './DonutChartFill.mjs';
6
+
7
+ const Donut = (props) => {
8
+ const { value = 0, segments, size, maxValue } = props;
9
+ const strokeWidth = 0.5;
10
+ const fillWidth = size === "m" ? 8 : 12;
11
+ const center = fillWidth * 4;
12
+ const radius = center - fillWidth / 2;
13
+ return /* @__PURE__ */ jsx(Fragment, { children: /* @__PURE__ */ jsxs(
14
+ "svg",
15
+ {
16
+ width: center * 4,
17
+ height: center * 4,
18
+ viewBox: `0 0 ${center * 2} ${center * 2}`,
19
+ fill: "none",
20
+ strokeWidth: fillWidth,
21
+ children: [
22
+ /* @__PURE__ */ jsx(
23
+ "circle",
24
+ {
25
+ className: styles.background,
26
+ cx: center,
27
+ cy: center,
28
+ r: radius,
29
+ strokeWidth: fillWidth
30
+ }
31
+ ),
32
+ /* @__PURE__ */ jsx(
33
+ "circle",
34
+ {
35
+ className: styles.border,
36
+ cx: center,
37
+ cy: center,
38
+ r: center - strokeWidth / 2,
39
+ strokeWidth
40
+ }
41
+ ),
42
+ /* @__PURE__ */ jsx(
43
+ "circle",
44
+ {
45
+ className: styles.border,
46
+ cx: center,
47
+ cy: center,
48
+ r: center - fillWidth + strokeWidth / 2,
49
+ strokeWidth
50
+ }
51
+ ),
52
+ /* @__PURE__ */ jsx(
53
+ DonutChartFill,
54
+ {
55
+ radius,
56
+ center,
57
+ value,
58
+ segments,
59
+ maxValue: maxValue ?? 100
60
+ }
61
+ )
62
+ ]
63
+ }
64
+ ) });
65
+ };
66
+
67
+ export { Donut };
68
+ //# sourceMappingURL=Donut.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Donut.mjs","sources":["../../../../../../../src/components/DonutChart/components/Donut.tsx"],"sourcesContent":["import type { FC } from \"react\";\nimport styles from \"@/components/DonutChart/DonutChart.module.scss\";\nimport { DonutChartFill } from \"@/components/DonutChart/components/DonutChartFill\";\nimport type { DonutChartProps } from \"@/components/DonutChart\";\n\ninterface Props\n extends Pick<DonutChartProps, \"segments\" | \"size\" | \"maxValue\"> {\n value?: number;\n}\n\nexport const Donut: FC<Props> = (props) => {\n const { value = 0, segments, size, maxValue } = props;\n\n const strokeWidth = 0.5;\n const fillWidth = size === \"m\" ? 8 : 12;\n const center = fillWidth * 4;\n const radius = center - fillWidth / 2;\n\n return (\n <>\n <svg\n width={center * 4}\n height={center * 4}\n viewBox={`0 0 ${center * 2} ${center * 2}`}\n fill=\"none\"\n strokeWidth={fillWidth}\n >\n <circle\n className={styles.background}\n cx={center}\n cy={center}\n r={radius}\n strokeWidth={fillWidth}\n />\n <circle\n className={styles.border}\n cx={center}\n cy={center}\n r={center - strokeWidth / 2}\n strokeWidth={strokeWidth}\n />\n <circle\n className={styles.border}\n cx={center}\n cy={center}\n r={center - fillWidth + strokeWidth / 2}\n strokeWidth={strokeWidth}\n />\n\n <DonutChartFill\n radius={radius}\n center={center}\n value={value}\n segments={segments}\n maxValue={maxValue ?? 100}\n />\n </svg>\n </>\n );\n};\n"],"names":[],"mappings":";;;;AAUa,MAAA,KAAA,GAAmB,CAAC,KAAU,KAAA;AACzC,EAAA,MAAM,EAAE,KAAQ,GAAA,CAAA,EAAG,QAAU,EAAA,IAAA,EAAM,UAAa,GAAA,KAAA;AAEhD,EAAA,MAAM,WAAc,GAAA,GAAA;AACpB,EAAM,MAAA,SAAA,GAAY,IAAS,KAAA,GAAA,GAAM,CAAI,GAAA,EAAA;AACrC,EAAA,MAAM,SAAS,SAAY,GAAA,CAAA;AAC3B,EAAM,MAAA,MAAA,GAAS,SAAS,SAAY,GAAA,CAAA;AAEpC,EAAA,uBAEI,GAAA,CAAA,QAAA,EAAA,EAAA,QAAA,kBAAA,IAAA;AAAA,IAAC,KAAA;AAAA,IAAA;AAAA,MACC,OAAO,MAAS,GAAA,CAAA;AAAA,MAChB,QAAQ,MAAS,GAAA,CAAA;AAAA,MACjB,SAAS,CAAO,IAAA,EAAA,MAAA,GAAS,CAAC,CAAA,CAAA,EAAI,SAAS,CAAC,CAAA,CAAA;AAAA,MACxC,IAAK,EAAA,MAAA;AAAA,MACL,WAAa,EAAA,SAAA;AAAA,MAEb,QAAA,EAAA;AAAA,wBAAA,GAAA;AAAA,UAAC,QAAA;AAAA,UAAA;AAAA,YACC,WAAW,MAAO,CAAA,UAAA;AAAA,YAClB,EAAI,EAAA,MAAA;AAAA,YACJ,EAAI,EAAA,MAAA;AAAA,YACJ,CAAG,EAAA,MAAA;AAAA,YACH,WAAa,EAAA;AAAA;AAAA,SACf;AAAA,wBACA,GAAA;AAAA,UAAC,QAAA;AAAA,UAAA;AAAA,YACC,WAAW,MAAO,CAAA,MAAA;AAAA,YAClB,EAAI,EAAA,MAAA;AAAA,YACJ,EAAI,EAAA,MAAA;AAAA,YACJ,CAAA,EAAG,SAAS,WAAc,GAAA,CAAA;AAAA,YAC1B;AAAA;AAAA,SACF;AAAA,wBACA,GAAA;AAAA,UAAC,QAAA;AAAA,UAAA;AAAA,YACC,WAAW,MAAO,CAAA,MAAA;AAAA,YAClB,EAAI,EAAA,MAAA;AAAA,YACJ,EAAI,EAAA,MAAA;AAAA,YACJ,CAAA,EAAG,MAAS,GAAA,SAAA,GAAY,WAAc,GAAA,CAAA;AAAA,YACtC;AAAA;AAAA,SACF;AAAA,wBAEA,GAAA;AAAA,UAAC,cAAA;AAAA,UAAA;AAAA,YACC,MAAA;AAAA,YACA,MAAA;AAAA,YACA,KAAA;AAAA,YACA,QAAA;AAAA,YACA,UAAU,QAAY,IAAA;AAAA;AAAA;AACxB;AAAA;AAAA,GAEJ,EAAA,CAAA;AAEJ;;;;"}
@@ -0,0 +1,46 @@
1
+ "use client"
2
+ /* */
3
+ import { jsx } from 'react/jsx-runtime';
4
+ import styles from '../DonutChart.module.scss.mjs';
5
+ import { getCategoricalColorByIndex } from '../../../lib/tokens/getCategoricalColorByIndex.mjs';
6
+
7
+ const DonutChartFill = (props) => {
8
+ const { center, value = 0, radius, segments, maxValue } = props;
9
+ const circumference = 2 * radius * Math.PI;
10
+ const percent = 100 / maxValue * value;
11
+ if (!segments) {
12
+ return /* @__PURE__ */ jsx(
13
+ "circle",
14
+ {
15
+ className: styles.fill,
16
+ cx: center,
17
+ cy: center,
18
+ r: radius,
19
+ strokeDasharray: `${circumference} ${circumference}`,
20
+ strokeDashoffset: circumference - percent / 100 * circumference,
21
+ transform: `rotate(-90 ${center} ${center})`
22
+ }
23
+ );
24
+ }
25
+ let rotationOffset = 0;
26
+ return segments.map((s, i) => {
27
+ const segmentPercent = 100 / maxValue * s.value;
28
+ const currentRotationOffset = rotationOffset;
29
+ rotationOffset = rotationOffset + 360 / 100 * segmentPercent;
30
+ return /* @__PURE__ */ jsx(
31
+ "circle",
32
+ {
33
+ cx: center,
34
+ cy: center,
35
+ r: radius,
36
+ strokeDasharray: `${circumference} ${circumference}`,
37
+ strokeDashoffset: circumference - segmentPercent / 100 * circumference,
38
+ stroke: `var(--color--categorical--${s.color ?? getCategoricalColorByIndex(i)})`,
39
+ transform: `rotate(${ -90 + currentRotationOffset} ${center} ${center})`
40
+ }
41
+ );
42
+ });
43
+ };
44
+
45
+ export { DonutChartFill };
46
+ //# sourceMappingURL=DonutChartFill.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DonutChartFill.mjs","sources":["../../../../../../../src/components/DonutChart/components/DonutChartFill.tsx"],"sourcesContent":["import type { FC } from \"react\";\nimport styles from \"@/components/DonutChart/DonutChart.module.scss\";\nimport type { DonutChartProps } from \"@/components/DonutChart\";\nimport { getCategoricalColorByIndex } from \"@/lib/tokens/getCategoricalColorByIndex\";\n\ninterface Props extends Pick<DonutChartProps, \"segments\"> {\n center: number;\n value?: number;\n radius: number;\n maxValue: number;\n}\n\nexport const DonutChartFill: FC<Props> = (props) => {\n const { center, value = 0, radius, segments, maxValue } = props;\n\n const circumference = 2 * radius * Math.PI;\n\n const percent = (100 / maxValue) * value;\n\n if (!segments) {\n return (\n <circle\n className={styles.fill}\n cx={center}\n cy={center}\n r={radius}\n strokeDasharray={`${circumference} ${circumference}`}\n strokeDashoffset={circumference - (percent / 100) * circumference}\n transform={`rotate(-90 ${center} ${center})`}\n />\n );\n }\n\n let rotationOffset = 0;\n\n return segments.map((s, i) => {\n const segmentPercent = (100 / maxValue) * s.value;\n\n const currentRotationOffset = rotationOffset;\n\n rotationOffset = rotationOffset + (360 / 100) * segmentPercent;\n\n return (\n <circle\n cx={center}\n cy={center}\n r={radius}\n strokeDasharray={`${circumference} ${circumference}`}\n strokeDashoffset={\n circumference - (segmentPercent / 100) * circumference\n }\n stroke={`var(--color--categorical--${s.color ?? getCategoricalColorByIndex(i)})`}\n transform={`rotate(${-90 + currentRotationOffset} ${center} ${center})`}\n />\n );\n });\n};\n"],"names":[],"mappings":";;;;AAYa,MAAA,cAAA,GAA4B,CAAC,KAAU,KAAA;AAClD,EAAA,MAAM,EAAE,MAAQ,EAAA,KAAA,GAAQ,GAAG,MAAQ,EAAA,QAAA,EAAU,UAAa,GAAA,KAAA;AAE1D,EAAM,MAAA,aAAA,GAAgB,CAAI,GAAA,MAAA,GAAS,IAAK,CAAA,EAAA;AAExC,EAAM,MAAA,OAAA,GAAW,MAAM,QAAY,GAAA,KAAA;AAEnC,EAAA,IAAI,CAAC,QAAU,EAAA;AACb,IACE,uBAAA,GAAA;AAAA,MAAC,QAAA;AAAA,MAAA;AAAA,QACC,WAAW,MAAO,CAAA,IAAA;AAAA,QAClB,EAAI,EAAA,MAAA;AAAA,QACJ,EAAI,EAAA,MAAA;AAAA,QACJ,CAAG,EAAA,MAAA;AAAA,QACH,eAAiB,EAAA,CAAA,EAAG,aAAa,CAAA,CAAA,EAAI,aAAa,CAAA,CAAA;AAAA,QAClD,gBAAA,EAAkB,aAAiB,GAAA,OAAA,GAAU,GAAO,GAAA,aAAA;AAAA,QACpD,SAAW,EAAA,CAAA,WAAA,EAAc,MAAM,CAAA,CAAA,EAAI,MAAM,CAAA,CAAA;AAAA;AAAA,KAC3C;AAAA;AAIJ,EAAA,IAAI,cAAiB,GAAA,CAAA;AAErB,EAAA,OAAO,QAAS,CAAA,GAAA,CAAI,CAAC,CAAA,EAAG,CAAM,KAAA;AAC5B,IAAM,MAAA,cAAA,GAAkB,GAAM,GAAA,QAAA,GAAY,CAAE,CAAA,KAAA;AAE5C,IAAA,MAAM,qBAAwB,GAAA,cAAA;AAE9B,IAAiB,cAAA,GAAA,cAAA,GAAkB,MAAM,GAAO,GAAA,cAAA;AAEhD,IACE,uBAAA,GAAA;AAAA,MAAC,QAAA;AAAA,MAAA;AAAA,QACC,EAAI,EAAA,MAAA;AAAA,QACJ,EAAI,EAAA,MAAA;AAAA,QACJ,CAAG,EAAA,MAAA;AAAA,QACH,eAAiB,EAAA,CAAA,EAAG,aAAa,CAAA,CAAA,EAAI,aAAa,CAAA,CAAA;AAAA,QAClD,gBAAA,EACE,aAAiB,GAAA,cAAA,GAAiB,GAAO,GAAA,aAAA;AAAA,QAE3C,QAAQ,CAA6B,0BAAA,EAAA,CAAA,CAAE,KAAS,IAAA,0BAAA,CAA2B,CAAC,CAAC,CAAA,CAAA,CAAA;AAAA,QAC7E,WAAW,CAAU,OAAA,EAAA,IAAA,GAAM,qBAAqB,CAAI,CAAA,EAAA,MAAM,IAAI,MAAM,CAAA,CAAA;AAAA;AAAA,KACtE;AAAA,GAEH,CAAA;AACH;;;;"}
@@ -0,0 +1,30 @@
1
+ "use client"
2
+ /* */
3
+ import { jsx } from 'react/jsx-runtime';
4
+ import styles from '../DonutChart.module.scss.mjs';
5
+ import 'react';
6
+ import { useNumberFormatter } from 'react-aria';
7
+ import { Legend } from '../../Legend/Legend.mjs';
8
+ import { LegendItem } from '../../Legend/components/LegendItem/LegendItem.mjs';
9
+ import { getCategoricalColorByIndex } from '../../../lib/tokens/getCategoricalColorByIndex.mjs';
10
+
11
+ const DonutChartLegend = (props) => {
12
+ const { segments, showLegend, formatOptions } = props;
13
+ const formatter = useNumberFormatter(formatOptions);
14
+ if (!segments || !showLegend) {
15
+ return null;
16
+ }
17
+ return /* @__PURE__ */ jsx(Legend, { className: styles.legend, children: segments.map((s, i) => {
18
+ const formattedValue = formatOptions ? formatter.format(s.value) : `${s.value} %`;
19
+ return /* @__PURE__ */ jsx(
20
+ LegendItem,
21
+ {
22
+ color: s.color ?? getCategoricalColorByIndex(i),
23
+ children: `${s.title} (${s.valueText ?? formattedValue})`
24
+ }
25
+ );
26
+ }) });
27
+ };
28
+
29
+ export { DonutChartLegend };
30
+ //# sourceMappingURL=DonutChartLegend.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DonutChartLegend.mjs","sources":["../../../../../../../src/components/DonutChart/components/DonutChartLegend.tsx"],"sourcesContent":["import styles from \"../DonutChart.module.scss\";\nimport React, { type FC } from \"react\";\nimport { useNumberFormatter } from \"react-aria\";\nimport { Legend, LegendItem } from \"@/components/Legend\";\nimport { getCategoricalColorByIndex } from \"@/lib/tokens/getCategoricalColorByIndex\";\nimport type { DonutChartProps } from \"@/components/DonutChart\";\n\ntype Props = Pick<DonutChartProps, \"segments\" | \"showLegend\" | \"formatOptions\">;\n\nexport const DonutChartLegend: FC<Props> = (props) => {\n const { segments, showLegend, formatOptions } = props;\n\n const formatter = useNumberFormatter(formatOptions);\n\n if (!segments || !showLegend) {\n return null;\n }\n\n return (\n <Legend className={styles.legend}>\n {segments.map((s, i) => {\n const formattedValue = formatOptions\n ? formatter.format(s.value)\n : `${s.value} %`;\n\n return (\n <LegendItem\n color={s.color ?? getCategoricalColorByIndex(i)}\n >{`${s.title} (${s.valueText ?? formattedValue})`}</LegendItem>\n );\n })}\n </Legend>\n );\n};\n"],"names":[],"mappings":";;;;;;;;AASa,MAAA,gBAAA,GAA8B,CAAC,KAAU,KAAA;AACpD,EAAA,MAAM,EAAE,QAAA,EAAU,UAAY,EAAA,aAAA,EAAkB,GAAA,KAAA;AAEhD,EAAM,MAAA,SAAA,GAAY,mBAAmB,aAAa,CAAA;AAElD,EAAI,IAAA,CAAC,QAAY,IAAA,CAAC,UAAY,EAAA;AAC5B,IAAO,OAAA,IAAA;AAAA;AAGT,EACE,uBAAA,GAAA,CAAC,UAAO,SAAW,EAAA,MAAA,CAAO,QACvB,QAAS,EAAA,QAAA,CAAA,GAAA,CAAI,CAAC,CAAA,EAAG,CAAM,KAAA;AACtB,IAAM,MAAA,cAAA,GAAiB,gBACnB,SAAU,CAAA,MAAA,CAAO,EAAE,KAAK,CAAA,GACxB,CAAG,EAAA,CAAA,CAAE,KAAK,CAAA,EAAA,CAAA;AAEd,IACE,uBAAA,GAAA;AAAA,MAAC,UAAA;AAAA,MAAA;AAAA,QACC,KAAO,EAAA,CAAA,CAAE,KAAS,IAAA,0BAAA,CAA2B,CAAC,CAAA;AAAA,QAC9C,aAAG,CAAE,CAAA,KAAK,CAAK,EAAA,EAAA,CAAA,CAAE,aAAa,cAAc,CAAA,CAAA;AAAA;AAAA,KAAI;AAAA,GAErD,CACH,EAAA,CAAA;AAEJ;;;;"}
@@ -0,0 +1,19 @@
1
+ "use client"
2
+ /* */
3
+ import { jsx } from 'react/jsx-runtime';
4
+ import styles from '../DonutChart.module.scss.mjs';
5
+ import 'react';
6
+ import { useNumberFormatter } from 'react-aria';
7
+
8
+ const DonutChartValue = (props) => {
9
+ const { value = 0, formatOptions, children } = props;
10
+ const formatter = useNumberFormatter(formatOptions);
11
+ if (children) {
12
+ return /* @__PURE__ */ jsx("span", { className: styles.value, children });
13
+ }
14
+ const formattedValue = formatOptions ? formatter.format(value) : `${value} %`;
15
+ return /* @__PURE__ */ jsx("span", { className: styles.value, children: /* @__PURE__ */ jsx("b", { children: formattedValue }) });
16
+ };
17
+
18
+ export { DonutChartValue };
19
+ //# sourceMappingURL=DonutChartValue.mjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DonutChartValue.mjs","sources":["../../../../../../../src/components/DonutChart/components/DonutChartValue.tsx"],"sourcesContent":["import styles from \"../DonutChart.module.scss\";\nimport React, { type FC } from \"react\";\nimport { useNumberFormatter } from \"react-aria\";\nimport type { DonutChartProps } from \"@/components/DonutChart\";\n\ninterface Props extends Pick<DonutChartProps, \"formatOptions\" | \"children\"> {\n value?: number;\n}\n\nexport const DonutChartValue: FC<Props> = (props) => {\n const { value = 0, formatOptions, children } = props;\n\n const formatter = useNumberFormatter(formatOptions);\n\n if (children) {\n return <span className={styles.value}>{children}</span>;\n }\n\n const formattedValue = formatOptions ? formatter.format(value) : `${value} %`;\n\n return (\n <span className={styles.value}>\n <b>{formattedValue}</b>\n </span>\n );\n};\n"],"names":[],"mappings":";;;;;AASa,MAAA,eAAA,GAA6B,CAAC,KAAU,KAAA;AACnD,EAAA,MAAM,EAAE,KAAA,GAAQ,CAAG,EAAA,aAAA,EAAe,UAAa,GAAA,KAAA;AAE/C,EAAM,MAAA,SAAA,GAAY,mBAAmB,aAAa,CAAA;AAElD,EAAA,IAAI,QAAU,EAAA;AACZ,IAAA,uBAAQ,GAAA,CAAA,MAAA,EAAA,EAAK,SAAW,EAAA,MAAA,CAAO,OAAQ,QAAS,EAAA,CAAA;AAAA;AAGlD,EAAA,MAAM,iBAAiB,aAAgB,GAAA,SAAA,CAAU,OAAO,KAAK,CAAA,GAAI,GAAG,KAAK,CAAA,EAAA,CAAA;AAEzE,EACE,uBAAA,GAAA,CAAC,UAAK,SAAW,EAAA,MAAA,CAAO,OACtB,QAAC,kBAAA,GAAA,CAAA,GAAA,EAAA,EAAG,0BAAe,CACrB,EAAA,CAAA;AAEJ;;;;"}
@@ -18,12 +18,16 @@ class Sorting {
18
18
  this.property = shape.property;
19
19
  this.name = shape.name;
20
20
  this.direction = shape.direction ?? "asc";
21
- this.defaultEnabled = this.getStoredDefaultEnabled() ?? shape.defaultEnabled ?? false;
21
+ const storedDefaultEnabled = this.getStoredDefaultEnabled();
22
+ this.defaultEnabled = shape.defaultEnabled === "hidden" ? "hidden" : storedDefaultEnabled ?? shape.defaultEnabled ?? false;
22
23
  this.customSortingFn = shape.customSortingFn;
23
24
  }
24
25
  getStoredDefaultEnabled() {
25
26
  const storedSorting = this.list.getStoredSortingDefaultSetting();
26
- return storedSorting?.property === this.property && storedSorting.direction === this.direction;
27
+ if (!storedSorting) {
28
+ return void 0;
29
+ }
30
+ return storedSorting.property === this.property && storedSorting.direction === this.direction;
27
31
  }
28
32
  updateTableColumnDef(def) {
29
33
  def.enableSorting = true;
@@ -1 +1 @@
1
- {"version":3,"file":"Sorting.mjs","sources":["../../../../../../../../src/components/List/model/sorting/Sorting.ts"],"sourcesContent":["import type List from \"@/components/List/model/List\";\nimport type {\n SortingDefaultMode,\n SortingShape,\n} from \"@/components/List/model/sorting/types\";\nimport type { PropertyName } from \"@/components/List/model/types\";\nimport type {\n Column,\n ColumnDef,\n ColumnSort,\n SortDirection,\n SortingFn,\n} from \"@tanstack/react-table\";\nimport z from \"zod\";\n\nexport class Sorting<T> {\n public static readonly storageSchema = z\n .object({\n direction: z.enum([\"asc\", \"desc\"]),\n property: z.string().or(z.number()),\n })\n .optional();\n public readonly list: List<T>;\n public readonly property: PropertyName<T>;\n public readonly name?: string;\n public readonly direction: SortDirection;\n public readonly defaultEnabled: SortingDefaultMode;\n public readonly customSortingFn?: SortingFn<T>;\n\n public constructor(list: List<T>, shape: SortingShape<T>) {\n this.list = list;\n this.property = shape.property;\n this.name = shape.name;\n this.direction = shape.direction ?? \"asc\";\n this.defaultEnabled =\n this.getStoredDefaultEnabled() ?? shape.defaultEnabled ?? false;\n this.customSortingFn = shape.customSortingFn;\n }\n\n private getStoredDefaultEnabled() {\n const storedSorting = this.list.getStoredSortingDefaultSetting();\n return (\n storedSorting?.property === this.property &&\n storedSorting.direction === this.direction\n );\n }\n\n public updateTableColumnDef(def: ColumnDef<T>): void {\n def.enableSorting = true;\n if (this.customSortingFn) {\n def.sortingFn = this.customSortingFn;\n }\n }\n\n public getReactTableColumnSort(): ColumnSort {\n return {\n id: this.property as string,\n desc: this.direction === \"desc\",\n };\n }\n\n public isSorted(): boolean {\n const col = this.getTableColumn();\n return col.getIsSorted() == this.direction;\n }\n\n public getTableColumn(): Column<T> {\n return this.list.reactTable.getTableColumn(this.property);\n }\n\n public enable(): void {\n this.list.reactTable\n .getTableColumn(this.property)\n .toggleSorting(this.direction === \"desc\", false);\n this.list.storeSortingSettings(this);\n }\n\n public clear(): void {\n this.list.reactTable.getTableColumn(this.property).clearSorting();\n }\n\n public get id(): string {\n return `${this.getTableColumn().id}:${this.direction}`;\n }\n}\n"],"names":[],"mappings":";;AAeO,MAAM,OAAW,CAAA;AAAA,EACtB,OAAuB,aAAgB,GAAA,CAAA,CACpC,MAAO,CAAA;AAAA,IACN,WAAW,CAAE,CAAA,IAAA,CAAK,CAAC,KAAA,EAAO,MAAM,CAAC,CAAA;AAAA,IACjC,UAAU,CAAE,CAAA,MAAA,GAAS,EAAG,CAAA,CAAA,CAAE,QAAQ;AAAA,GACnC,EACA,QAAS,EAAA;AAAA,EACI,IAAA;AAAA,EACA,QAAA;AAAA,EACA,IAAA;AAAA,EACA,SAAA;AAAA,EACA,cAAA;AAAA,EACA,eAAA;AAAA,EAET,WAAA,CAAY,MAAe,KAAwB,EAAA;AACxD,IAAA,IAAA,CAAK,IAAO,GAAA,IAAA;AACZ,IAAA,IAAA,CAAK,WAAW,KAAM,CAAA,QAAA;AACtB,IAAA,IAAA,CAAK,OAAO,KAAM,CAAA,IAAA;AAClB,IAAK,IAAA,CAAA,SAAA,GAAY,MAAM,SAAa,IAAA,KAAA;AACpC,IAAA,IAAA,CAAK,cACH,GAAA,IAAA,CAAK,uBAAwB,EAAA,IAAK,MAAM,cAAkB,IAAA,KAAA;AAC5D,IAAA,IAAA,CAAK,kBAAkB,KAAM,CAAA,eAAA;AAAA;AAC/B,EAEQ,uBAA0B,GAAA;AAChC,IAAM,MAAA,aAAA,GAAgB,IAAK,CAAA,IAAA,CAAK,8BAA+B,EAAA;AAC/D,IAAA,OACE,eAAe,QAAa,KAAA,IAAA,CAAK,QACjC,IAAA,aAAA,CAAc,cAAc,IAAK,CAAA,SAAA;AAAA;AAErC,EAEO,qBAAqB,GAAyB,EAAA;AACnD,IAAA,GAAA,CAAI,aAAgB,GAAA,IAAA;AACpB,IAAA,IAAI,KAAK,eAAiB,EAAA;AACxB,MAAA,GAAA,CAAI,YAAY,IAAK,CAAA,eAAA;AAAA;AACvB;AACF,EAEO,uBAAsC,GAAA;AAC3C,IAAO,OAAA;AAAA,MACL,IAAI,IAAK,CAAA,QAAA;AAAA,MACT,IAAA,EAAM,KAAK,SAAc,KAAA;AAAA,KAC3B;AAAA;AACF,EAEO,QAAoB,GAAA;AACzB,IAAM,MAAA,GAAA,GAAM,KAAK,cAAe,EAAA;AAChC,IAAO,OAAA,GAAA,CAAI,WAAY,EAAA,IAAK,IAAK,CAAA,SAAA;AAAA;AACnC,EAEO,cAA4B,GAAA;AACjC,IAAA,OAAO,IAAK,CAAA,IAAA,CAAK,UAAW,CAAA,cAAA,CAAe,KAAK,QAAQ,CAAA;AAAA;AAC1D,EAEO,MAAe,GAAA;AACpB,IAAK,IAAA,CAAA,IAAA,CAAK,UACP,CAAA,cAAA,CAAe,IAAK,CAAA,QAAQ,EAC5B,aAAc,CAAA,IAAA,CAAK,SAAc,KAAA,MAAA,EAAQ,KAAK,CAAA;AACjD,IAAK,IAAA,CAAA,IAAA,CAAK,qBAAqB,IAAI,CAAA;AAAA;AACrC,EAEO,KAAc,GAAA;AACnB,IAAA,IAAA,CAAK,KAAK,UAAW,CAAA,cAAA,CAAe,IAAK,CAAA,QAAQ,EAAE,YAAa,EAAA;AAAA;AAClE,EAEA,IAAW,EAAa,GAAA;AACtB,IAAA,OAAO,GAAG,IAAK,CAAA,cAAA,GAAiB,EAAE,CAAA,CAAA,EAAI,KAAK,SAAS,CAAA,CAAA;AAAA;AAExD;;;;"}
1
+ {"version":3,"file":"Sorting.mjs","sources":["../../../../../../../../src/components/List/model/sorting/Sorting.ts"],"sourcesContent":["import type List from \"@/components/List/model/List\";\nimport type {\n SortingDefaultMode,\n SortingShape,\n} from \"@/components/List/model/sorting/types\";\nimport type { PropertyName } from \"@/components/List/model/types\";\nimport type {\n Column,\n ColumnDef,\n ColumnSort,\n SortDirection,\n SortingFn,\n} from \"@tanstack/react-table\";\nimport z from \"zod\";\n\nexport class Sorting<T> {\n public static readonly storageSchema = z\n .object({\n direction: z.enum([\"asc\", \"desc\"]),\n property: z.string().or(z.number()),\n })\n .optional();\n public readonly list: List<T>;\n public readonly property: PropertyName<T>;\n public readonly name?: string;\n public readonly direction: SortDirection;\n public readonly defaultEnabled: SortingDefaultMode;\n public readonly customSortingFn?: SortingFn<T>;\n\n public constructor(list: List<T>, shape: SortingShape<T>) {\n this.list = list;\n this.property = shape.property;\n this.name = shape.name;\n this.direction = shape.direction ?? \"asc\";\n const storedDefaultEnabled = this.getStoredDefaultEnabled();\n this.defaultEnabled =\n shape.defaultEnabled === \"hidden\"\n ? \"hidden\"\n : (storedDefaultEnabled ?? shape.defaultEnabled ?? false);\n this.customSortingFn = shape.customSortingFn;\n }\n\n private getStoredDefaultEnabled() {\n const storedSorting = this.list.getStoredSortingDefaultSetting();\n if (!storedSorting) {\n return undefined;\n }\n return (\n storedSorting.property === this.property &&\n storedSorting.direction === this.direction\n );\n }\n\n public updateTableColumnDef(def: ColumnDef<T>): void {\n def.enableSorting = true;\n if (this.customSortingFn) {\n def.sortingFn = this.customSortingFn;\n }\n }\n\n public getReactTableColumnSort(): ColumnSort {\n return {\n id: this.property as string,\n desc: this.direction === \"desc\",\n };\n }\n\n public isSorted(): boolean {\n const col = this.getTableColumn();\n return col.getIsSorted() == this.direction;\n }\n\n public getTableColumn(): Column<T> {\n return this.list.reactTable.getTableColumn(this.property);\n }\n\n public enable(): void {\n this.list.reactTable\n .getTableColumn(this.property)\n .toggleSorting(this.direction === \"desc\", false);\n this.list.storeSortingSettings(this);\n }\n\n public clear(): void {\n this.list.reactTable.getTableColumn(this.property).clearSorting();\n }\n\n public get id(): string {\n return `${this.getTableColumn().id}:${this.direction}`;\n }\n}\n"],"names":[],"mappings":";;AAeO,MAAM,OAAW,CAAA;AAAA,EACtB,OAAuB,aAAgB,GAAA,CAAA,CACpC,MAAO,CAAA;AAAA,IACN,WAAW,CAAE,CAAA,IAAA,CAAK,CAAC,KAAA,EAAO,MAAM,CAAC,CAAA;AAAA,IACjC,UAAU,CAAE,CAAA,MAAA,GAAS,EAAG,CAAA,CAAA,CAAE,QAAQ;AAAA,GACnC,EACA,QAAS,EAAA;AAAA,EACI,IAAA;AAAA,EACA,QAAA;AAAA,EACA,IAAA;AAAA,EACA,SAAA;AAAA,EACA,cAAA;AAAA,EACA,eAAA;AAAA,EAET,WAAA,CAAY,MAAe,KAAwB,EAAA;AACxD,IAAA,IAAA,CAAK,IAAO,GAAA,IAAA;AACZ,IAAA,IAAA,CAAK,WAAW,KAAM,CAAA,QAAA;AACtB,IAAA,IAAA,CAAK,OAAO,KAAM,CAAA,IAAA;AAClB,IAAK,IAAA,CAAA,SAAA,GAAY,MAAM,SAAa,IAAA,KAAA;AACpC,IAAM,MAAA,oBAAA,GAAuB,KAAK,uBAAwB,EAAA;AAC1D,IAAA,IAAA,CAAK,iBACH,KAAM,CAAA,cAAA,KAAmB,WACrB,QACC,GAAA,oBAAA,IAAwB,MAAM,cAAkB,IAAA,KAAA;AACvD,IAAA,IAAA,CAAK,kBAAkB,KAAM,CAAA,eAAA;AAAA;AAC/B,EAEQ,uBAA0B,GAAA;AAChC,IAAM,MAAA,aAAA,GAAgB,IAAK,CAAA,IAAA,CAAK,8BAA+B,EAAA;AAC/D,IAAA,IAAI,CAAC,aAAe,EAAA;AAClB,MAAO,OAAA,MAAA;AAAA;AAET,IAAA,OACE,cAAc,QAAa,KAAA,IAAA,CAAK,QAChC,IAAA,aAAA,CAAc,cAAc,IAAK,CAAA,SAAA;AAAA;AAErC,EAEO,qBAAqB,GAAyB,EAAA;AACnD,IAAA,GAAA,CAAI,aAAgB,GAAA,IAAA;AACpB,IAAA,IAAI,KAAK,eAAiB,EAAA;AACxB,MAAA,GAAA,CAAI,YAAY,IAAK,CAAA,eAAA;AAAA;AACvB;AACF,EAEO,uBAAsC,GAAA;AAC3C,IAAO,OAAA;AAAA,MACL,IAAI,IAAK,CAAA,QAAA;AAAA,MACT,IAAA,EAAM,KAAK,SAAc,KAAA;AAAA,KAC3B;AAAA;AACF,EAEO,QAAoB,GAAA;AACzB,IAAM,MAAA,GAAA,GAAM,KAAK,cAAe,EAAA;AAChC,IAAO,OAAA,GAAA,CAAI,WAAY,EAAA,IAAK,IAAK,CAAA,SAAA;AAAA;AACnC,EAEO,cAA4B,GAAA;AACjC,IAAA,OAAO,IAAK,CAAA,IAAA,CAAK,UAAW,CAAA,cAAA,CAAe,KAAK,QAAQ,CAAA;AAAA;AAC1D,EAEO,MAAe,GAAA;AACpB,IAAK,IAAA,CAAA,IAAA,CAAK,UACP,CAAA,cAAA,CAAe,IAAK,CAAA,QAAQ,EAC5B,aAAc,CAAA,IAAA,CAAK,SAAc,KAAA,MAAA,EAAQ,KAAK,CAAA;AACjD,IAAK,IAAA,CAAA,IAAA,CAAK,qBAAqB,IAAI,CAAA;AAAA;AACrC,EAEO,KAAc,GAAA;AACnB,IAAA,IAAA,CAAK,KAAK,UAAW,CAAA,cAAA,CAAe,IAAK,CAAA,QAAQ,EAAE,YAAa,EAAA;AAAA;AAClE,EAEA,IAAW,EAAa,GAAA;AACtB,IAAA,OAAO,GAAG,IAAK,CAAA,cAAA,GAAiB,EAAE,CAAA,CAAA,EAAI,KAAK,SAAS,CAAA,CAAA;AAAA;AAExD;;;;"}
@@ -1,6 +1,6 @@
1
1
  "use client"
2
2
  /* */
3
- import { jsx, Fragment, jsxs } from 'react/jsx-runtime';
3
+ import { jsx, jsxs } from 'react/jsx-runtime';
4
4
  import * as Aria from 'react-aria-components';
5
5
  import 'react';
6
6
  import styles from './ProgressBar.module.scss.mjs';
@@ -41,7 +41,7 @@ const ProgressBar = flowComponent("ProgressBar", (props) => {
41
41
  }
42
42
  };
43
43
  const segmentsTotalValue = segments ? segments.map((s) => s.value).reduce((a, b) => a + b, 0) : void 0;
44
- return /* @__PURE__ */ jsx(Fragment, { children: /* @__PURE__ */ jsx(
44
+ return /* @__PURE__ */ jsx(
45
45
  Aria.ProgressBar,
46
46
  {
47
47
  className: rootClassName,
@@ -79,7 +79,7 @@ const ProgressBar = flowComponent("ProgressBar", (props) => {
79
79
  )
80
80
  ] })
81
81
  }
82
- ) });
82
+ );
83
83
  });
84
84
 
85
85
  export { ProgressBar, ProgressBar as default };
@@ -1 +1 @@
1
- {"version":3,"file":"ProgressBar.mjs","sources":["../../../../../../src/components/ProgressBar/ProgressBar.tsx"],"sourcesContent":["import * as Aria from \"react-aria-components\";\nimport type { PropsWithChildren } from \"react\";\nimport React from \"react\";\nimport styles from \"./ProgressBar.module.scss\";\nimport clsx from \"clsx\";\nimport type { PropsWithStatus } from \"@/lib/types/props\";\nimport type { PropsContext } from \"@/lib/propsContext\";\nimport { PropsContextProvider } from \"@/lib/propsContext\";\nimport { ProgressBarValue } from \"@/components/ProgressBar/components/ProgressBarValue\";\nimport { ProgressBarBar } from \"@/components/ProgressBar/components/ProgressBarBar\";\nimport { ProgressBarLegend } from \"@/components/ProgressBar/components/ProgressBarLegend\";\nimport type { CategoricalColors } from \"@/lib/tokens/CategoricalColors\";\nimport {\n flowComponent,\n type FlowComponentProps,\n} from \"@/lib/componentFactory/flowComponent\";\n\nexport interface ProgressBarProps\n extends PropsWithChildren<Omit<Aria.ProgressBarProps, \"children\">>,\n PropsWithStatus,\n FlowComponentProps {\n /** Whether the max value should be displayed. */\n showMaxValue?: boolean;\n /** The size variant of the progress bar. @default \"m\" */\n size?: \"s\" | \"m\" | \"l\";\n /** Divides the fill of the progress bar into segments */\n segments?: {\n value: number;\n title: string;\n color?: CategoricalColors;\n valueText?: string;\n }[];\n /**\n * Whether the legend component is shown when segments are used. @default:\n * true\n */\n showLegend?: boolean;\n}\n\n/**\n * @flr-generate all\n * @flr-clear-props-context\n */\nexport const ProgressBar = flowComponent(\"ProgressBar\", (props) => {\n const {\n children,\n className,\n status = \"info\",\n showMaxValue,\n size = \"m\",\n segments,\n value,\n formatOptions,\n showLegend = true,\n maxValue,\n valueLabel,\n ...rest\n } = props;\n\n const rootClassName = clsx(\n className,\n styles.progressBar,\n styles[`size-${size}`],\n styles[status],\n );\n\n const propsContext: PropsContext = {\n Label: {\n className: styles.label,\n unstyled: true,\n },\n };\n\n const segmentsTotalValue = segments\n ? segments.map((s) => s.value).reduce((a, b) => a + b, 0)\n : undefined;\n\n return (\n <>\n <Aria.ProgressBar\n className={rootClassName}\n value={segmentsTotalValue ?? value}\n formatOptions={formatOptions}\n maxValue={maxValue}\n {...rest}\n >\n {({ percentage }) => (\n <PropsContextProvider props={propsContext}>\n {children}\n\n <ProgressBarValue\n showMaxValue={showMaxValue}\n maxValue={maxValue}\n formatOptions={formatOptions}\n value={segmentsTotalValue ?? value}\n valueLabel={valueLabel}\n />\n\n <ProgressBarBar\n percentage={percentage}\n segmentsTotalValue={segmentsTotalValue}\n segments={segments}\n />\n\n <ProgressBarLegend\n showLegend={showLegend}\n segments={segments}\n formatOptions={formatOptions}\n />\n </PropsContextProvider>\n )}\n </Aria.ProgressBar>\n </>\n );\n});\n\nexport default ProgressBar;\n"],"names":[],"mappings":";;;;;;;;;;;;;AA2CO,MAAM,WAAc,GAAA,aAAA,CAAc,aAAe,EAAA,CAAC,KAAU,KAAA;AACjE,EAAM,MAAA;AAAA,IACJ,QAAA;AAAA,IACA,SAAA;AAAA,IACA,MAAS,GAAA,MAAA;AAAA,IACT,YAAA;AAAA,IACA,IAAO,GAAA,GAAA;AAAA,IACP,QAAA;AAAA,IACA,KAAA;AAAA,IACA,aAAA;AAAA,IACA,UAAa,GAAA,IAAA;AAAA,IACb,QAAA;AAAA,IACA,UAAA;AAAA,IACA,GAAG;AAAA,GACD,GAAA,KAAA;AAEJ,EAAA,MAAM,aAAgB,GAAA,IAAA;AAAA,IACpB,SAAA;AAAA,IACA,MAAO,CAAA,WAAA;AAAA,IACP,MAAA,CAAO,CAAQ,KAAA,EAAA,IAAI,CAAE,CAAA,CAAA;AAAA,IACrB,OAAO,MAAM;AAAA,GACf;AAEA,EAAA,MAAM,YAA6B,GAAA;AAAA,IACjC,KAAO,EAAA;AAAA,MACL,WAAW,MAAO,CAAA,KAAA;AAAA,MAClB,QAAU,EAAA;AAAA;AACZ,GACF;AAEA,EAAA,MAAM,qBAAqB,QACvB,GAAA,QAAA,CAAS,GAAI,CAAA,CAAC,MAAM,CAAE,CAAA,KAAK,CAAE,CAAA,MAAA,CAAO,CAAC,CAAG,EAAA,CAAA,KAAM,CAAI,GAAA,CAAA,EAAG,CAAC,CACtD,GAAA,MAAA;AAEJ,EAAA,uBAEI,GAAA,CAAA,QAAA,EAAA,EAAA,QAAA,kBAAA,GAAA;AAAA,IAAC,IAAK,CAAA,WAAA;AAAA,IAAL;AAAA,MACC,SAAW,EAAA,aAAA;AAAA,MACX,OAAO,kBAAsB,IAAA,KAAA;AAAA,MAC7B,aAAA;AAAA,MACA,QAAA;AAAA,MACC,GAAG,IAAA;AAAA,MAEH,WAAC,EAAE,UAAA,uBACD,IAAA,CAAA,oBAAA,EAAA,EAAqB,OAAO,YAC1B,EAAA,QAAA,EAAA;AAAA,QAAA,QAAA;AAAA,wBAED,GAAA;AAAA,UAAC,gBAAA;AAAA,UAAA;AAAA,YACC,YAAA;AAAA,YACA,QAAA;AAAA,YACA,aAAA;AAAA,YACA,OAAO,kBAAsB,IAAA,KAAA;AAAA,YAC7B;AAAA;AAAA,SACF;AAAA,wBAEA,GAAA;AAAA,UAAC,cAAA;AAAA,UAAA;AAAA,YACC,UAAA;AAAA,YACA,kBAAA;AAAA,YACA;AAAA;AAAA,SACF;AAAA,wBAEA,GAAA;AAAA,UAAC,iBAAA;AAAA,UAAA;AAAA,YACC,UAAA;AAAA,YACA,QAAA;AAAA,YACA;AAAA;AAAA;AACF,OACF,EAAA;AAAA;AAAA,GAGN,EAAA,CAAA;AAEJ,CAAC;;;;"}
1
+ {"version":3,"file":"ProgressBar.mjs","sources":["../../../../../../src/components/ProgressBar/ProgressBar.tsx"],"sourcesContent":["import * as Aria from \"react-aria-components\";\nimport type { PropsWithChildren } from \"react\";\nimport React from \"react\";\nimport styles from \"./ProgressBar.module.scss\";\nimport clsx from \"clsx\";\nimport type { PropsWithStatus } from \"@/lib/types/props\";\nimport type { PropsContext } from \"@/lib/propsContext\";\nimport { PropsContextProvider } from \"@/lib/propsContext\";\nimport { ProgressBarValue } from \"@/components/ProgressBar/components/ProgressBarValue\";\nimport { ProgressBarBar } from \"@/components/ProgressBar/components/ProgressBarBar\";\nimport { ProgressBarLegend } from \"@/components/ProgressBar/components/ProgressBarLegend\";\nimport type { CategoricalColors } from \"@/lib/tokens/CategoricalColors\";\nimport {\n flowComponent,\n type FlowComponentProps,\n} from \"@/lib/componentFactory/flowComponent\";\n\nexport interface ProgressBarProps\n extends PropsWithChildren<Omit<Aria.ProgressBarProps, \"children\">>,\n PropsWithStatus,\n FlowComponentProps {\n /** Whether the max value should be displayed. */\n showMaxValue?: boolean;\n /** The size variant of the progress bar. @default \"m\" */\n size?: \"s\" | \"m\" | \"l\";\n /** Divides the fill of the progress bar into segments */\n segments?: {\n value: number;\n title: string;\n color?: CategoricalColors;\n valueText?: string;\n }[];\n /**\n * Whether the legend component is shown when segments are used. @default:\n * true\n */\n showLegend?: boolean;\n}\n\n/**\n * @flr-generate all\n * @flr-clear-props-context\n */\nexport const ProgressBar = flowComponent(\"ProgressBar\", (props) => {\n const {\n children,\n className,\n status = \"info\",\n showMaxValue,\n size = \"m\",\n segments,\n value,\n formatOptions,\n showLegend = true,\n maxValue,\n valueLabel,\n ...rest\n } = props;\n\n const rootClassName = clsx(\n className,\n styles.progressBar,\n styles[`size-${size}`],\n styles[status],\n );\n\n const propsContext: PropsContext = {\n Label: {\n className: styles.label,\n unstyled: true,\n },\n };\n\n const segmentsTotalValue = segments\n ? segments.map((s) => s.value).reduce((a, b) => a + b, 0)\n : undefined;\n\n return (\n <Aria.ProgressBar\n className={rootClassName}\n value={segmentsTotalValue ?? value}\n formatOptions={formatOptions}\n maxValue={maxValue}\n {...rest}\n >\n {({ percentage }) => (\n <PropsContextProvider props={propsContext}>\n {children}\n\n <ProgressBarValue\n showMaxValue={showMaxValue}\n maxValue={maxValue}\n formatOptions={formatOptions}\n value={segmentsTotalValue ?? value}\n valueLabel={valueLabel}\n />\n\n <ProgressBarBar\n percentage={percentage}\n segmentsTotalValue={segmentsTotalValue}\n segments={segments}\n />\n\n <ProgressBarLegend\n showLegend={showLegend}\n segments={segments}\n formatOptions={formatOptions}\n />\n </PropsContextProvider>\n )}\n </Aria.ProgressBar>\n );\n});\n\nexport default ProgressBar;\n"],"names":[],"mappings":";;;;;;;;;;;;;AA2CO,MAAM,WAAc,GAAA,aAAA,CAAc,aAAe,EAAA,CAAC,KAAU,KAAA;AACjE,EAAM,MAAA;AAAA,IACJ,QAAA;AAAA,IACA,SAAA;AAAA,IACA,MAAS,GAAA,MAAA;AAAA,IACT,YAAA;AAAA,IACA,IAAO,GAAA,GAAA;AAAA,IACP,QAAA;AAAA,IACA,KAAA;AAAA,IACA,aAAA;AAAA,IACA,UAAa,GAAA,IAAA;AAAA,IACb,QAAA;AAAA,IACA,UAAA;AAAA,IACA,GAAG;AAAA,GACD,GAAA,KAAA;AAEJ,EAAA,MAAM,aAAgB,GAAA,IAAA;AAAA,IACpB,SAAA;AAAA,IACA,MAAO,CAAA,WAAA;AAAA,IACP,MAAA,CAAO,CAAQ,KAAA,EAAA,IAAI,CAAE,CAAA,CAAA;AAAA,IACrB,OAAO,MAAM;AAAA,GACf;AAEA,EAAA,MAAM,YAA6B,GAAA;AAAA,IACjC,KAAO,EAAA;AAAA,MACL,WAAW,MAAO,CAAA,KAAA;AAAA,MAClB,QAAU,EAAA;AAAA;AACZ,GACF;AAEA,EAAA,MAAM,qBAAqB,QACvB,GAAA,QAAA,CAAS,GAAI,CAAA,CAAC,MAAM,CAAE,CAAA,KAAK,CAAE,CAAA,MAAA,CAAO,CAAC,CAAG,EAAA,CAAA,KAAM,CAAI,GAAA,CAAA,EAAG,CAAC,CACtD,GAAA,MAAA;AAEJ,EACE,uBAAA,GAAA;AAAA,IAAC,IAAK,CAAA,WAAA;AAAA,IAAL;AAAA,MACC,SAAW,EAAA,aAAA;AAAA,MACX,OAAO,kBAAsB,IAAA,KAAA;AAAA,MAC7B,aAAA;AAAA,MACA,QAAA;AAAA,MACC,GAAG,IAAA;AAAA,MAEH,WAAC,EAAE,UAAA,uBACD,IAAA,CAAA,oBAAA,EAAA,EAAqB,OAAO,YAC1B,EAAA,QAAA,EAAA;AAAA,QAAA,QAAA;AAAA,wBAED,GAAA;AAAA,UAAC,gBAAA;AAAA,UAAA;AAAA,YACC,YAAA;AAAA,YACA,QAAA;AAAA,YACA,aAAA;AAAA,YACA,OAAO,kBAAsB,IAAA,KAAA;AAAA,YAC7B;AAAA;AAAA,SACF;AAAA,wBAEA,GAAA;AAAA,UAAC,cAAA;AAAA,UAAA;AAAA,YACC,UAAA;AAAA,YACA,kBAAA;AAAA,YACA;AAAA;AAAA,SACF;AAAA,wBAEA,GAAA;AAAA,UAAC,iBAAA;AAAA,UAAA;AAAA,YACC,UAAA;AAAA,YACA,QAAA;AAAA,YACA;AAAA;AAAA;AACF,OACF,EAAA;AAAA;AAAA,GAEJ;AAEJ,CAAC;;;;"}
@@ -42,6 +42,7 @@ export { CounterBadge } from './components/src/components/CounterBadge/CounterBa
42
42
  export { DatePicker } from './components/src/components/DatePicker/DatePicker.mjs';
43
43
  export { DateRangePicker } from './components/src/components/DateRangePicker/DateRangePicker.mjs';
44
44
  export { Div } from './components/src/components/Div/Div.mjs';
45
+ export { DonutChart } from './components/src/components/DonutChart/DonutChart.mjs';
45
46
  export { FieldDescription } from './components/src/components/FieldDescription/FieldDescription.mjs';
46
47
  export { FieldError } from './components/src/components/FieldError/FieldError.mjs';
47
48
  export { FileCard } from './components/src/components/FileCard/FileCard.mjs';
@@ -1 +1 @@
1
- {"version":3,"file":"default.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"default.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -0,0 +1,27 @@
1
+ import { FC, PropsWithChildren } from 'react';
2
+ import { PropsWithStatus } from '../../lib/types/props';
3
+ import { CategoricalColors } from '../../lib/tokens/CategoricalColors';
4
+ import * as Aria from "react-aria-components";
5
+ export interface DonutChartSegment {
6
+ value: number;
7
+ title: string;
8
+ color?: CategoricalColors;
9
+ valueText?: string;
10
+ }
11
+ export interface DonutChartProps extends Omit<Aria.ProgressBarProps, "children" | "valueLabel">, PropsWithStatus, PropsWithChildren {
12
+ /** The size variant of the donut chart. @default "m" */
13
+ size?: "m" | "l";
14
+ /** Divides the fill of the donut chart into segments */
15
+ segments?: DonutChartSegment[];
16
+ /**
17
+ * Whether the legend component is shown when segments are used. @default:
18
+ * true
19
+ */
20
+ showLegend?: boolean;
21
+ /** The position of the legend. @default "right" */
22
+ legendPosition?: "top" | "left" | "bottom" | "right";
23
+ }
24
+ /** @flr-generate all */
25
+ export declare const DonutChart: FC<DonutChartProps>;
26
+ export default DonutChart;
27
+ //# sourceMappingURL=DonutChart.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DonutChart.d.ts","sourceRoot":"","sources":["../../../../src/components/DonutChart/DonutChart.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,iBAAiB,EAAE,MAAM,OAAO,CAAC;AACnD,OAAO,KAAK,IAAI,MAAM,uBAAuB,CAAC;AAG9C,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AACzD,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AAMxE,MAAM,WAAW,iBAAiB;IAChC,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,iBAAiB,CAAC;IAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,MAAM,WAAW,eACf,SAAQ,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,UAAU,GAAG,YAAY,CAAC,EAC5D,eAAe,EACf,iBAAiB;IACnB,wDAAwD;IACxD,IAAI,CAAC,EAAE,GAAG,GAAG,GAAG,CAAC;IACjB,wDAAwD;IACxD,QAAQ,CAAC,EAAE,iBAAiB,EAAE,CAAC;IAC/B;;;OAGG;IACH,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,mDAAmD;IACnD,cAAc,CAAC,EAAE,KAAK,GAAG,MAAM,GAAG,QAAQ,GAAG,OAAO,CAAC;CACtD;AAED,wBAAwB;AACxB,eAAO,MAAM,UAAU,EAAE,EAAE,CAAC,eAAe,CA0D1C,CAAC;AAEF,eAAe,UAAU,CAAC"}
@@ -0,0 +1,8 @@
1
+ import { FC } from 'react';
2
+ import { DonutChartProps } from '..';
3
+ interface Props extends Pick<DonutChartProps, "segments" | "size" | "maxValue"> {
4
+ value?: number;
5
+ }
6
+ export declare const Donut: FC<Props>;
7
+ export {};
8
+ //# sourceMappingURL=Donut.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Donut.d.ts","sourceRoot":"","sources":["../../../../../src/components/DonutChart/components/Donut.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,OAAO,CAAC;AAGhC,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAE/D,UAAU,KACR,SAAQ,IAAI,CAAC,eAAe,EAAE,UAAU,GAAG,MAAM,GAAG,UAAU,CAAC;IAC/D,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,eAAO,MAAM,KAAK,EAAE,EAAE,CAAC,KAAK,CAiD3B,CAAC"}
@@ -0,0 +1,11 @@
1
+ import { FC } from 'react';
2
+ import { DonutChartProps } from '..';
3
+ interface Props extends Pick<DonutChartProps, "segments"> {
4
+ center: number;
5
+ value?: number;
6
+ radius: number;
7
+ maxValue: number;
8
+ }
9
+ export declare const DonutChartFill: FC<Props>;
10
+ export {};
11
+ //# sourceMappingURL=DonutChartFill.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DonutChartFill.d.ts","sourceRoot":"","sources":["../../../../../src/components/DonutChart/components/DonutChartFill.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,EAAE,MAAM,OAAO,CAAC;AAEhC,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAG/D,UAAU,KAAM,SAAQ,IAAI,CAAC,eAAe,EAAE,UAAU,CAAC;IACvD,MAAM,EAAE,MAAM,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,EAAE,MAAM,CAAC;CAClB;AAED,eAAO,MAAM,cAAc,EAAE,EAAE,CAAC,KAAK,CA4CpC,CAAC"}
@@ -0,0 +1,6 @@
1
+ import { FC } from 'react';
2
+ import { DonutChartProps } from '..';
3
+ type Props = Pick<DonutChartProps, "segments" | "showLegend" | "formatOptions">;
4
+ export declare const DonutChartLegend: FC<Props>;
5
+ export {};
6
+ //# sourceMappingURL=DonutChartLegend.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DonutChartLegend.d.ts","sourceRoot":"","sources":["../../../../../src/components/DonutChart/components/DonutChartLegend.tsx"],"names":[],"mappings":"AACA,OAAc,EAAE,KAAK,EAAE,EAAE,MAAM,OAAO,CAAC;AAIvC,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAE/D,KAAK,KAAK,GAAG,IAAI,CAAC,eAAe,EAAE,UAAU,GAAG,YAAY,GAAG,eAAe,CAAC,CAAC;AAEhF,eAAO,MAAM,gBAAgB,EAAE,EAAE,CAAC,KAAK,CAwBtC,CAAC"}
@@ -0,0 +1,8 @@
1
+ import { FC } from 'react';
2
+ import { DonutChartProps } from '..';
3
+ interface Props extends Pick<DonutChartProps, "formatOptions" | "children"> {
4
+ value?: number;
5
+ }
6
+ export declare const DonutChartValue: FC<Props>;
7
+ export {};
8
+ //# sourceMappingURL=DonutChartValue.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DonutChartValue.d.ts","sourceRoot":"","sources":["../../../../../src/components/DonutChart/components/DonutChartValue.tsx"],"names":[],"mappings":"AACA,OAAc,EAAE,KAAK,EAAE,EAAE,MAAM,OAAO,CAAC;AAEvC,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,yBAAyB,CAAC;AAE/D,UAAU,KAAM,SAAQ,IAAI,CAAC,eAAe,EAAE,eAAe,GAAG,UAAU,CAAC;IACzE,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,eAAO,MAAM,eAAe,EAAE,EAAE,CAAC,KAAK,CAgBrC,CAAC"}
@@ -0,0 +1,3 @@
1
+ export { default } from './DonutChart';
2
+ export { type DonutChartProps, type DonutChartSegment, DonutChart, } from './DonutChart';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/DonutChart/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,cAAc,CAAC;AAEvC,OAAO,EACL,KAAK,eAAe,EACpB,KAAK,iBAAiB,EACtB,UAAU,GACX,MAAM,cAAc,CAAC"}
@@ -0,0 +1,11 @@
1
+ import { Meta, StoryObj } from '@storybook/react';
2
+ import { DonutChart } from '../index';
3
+ declare const meta: Meta<typeof DonutChart>;
4
+ export default meta;
5
+ type Story = StoryObj<typeof DonutChart>;
6
+ export declare const Default: Story;
7
+ export declare const WithUnit: Story;
8
+ export declare const WithSegments: Story;
9
+ export declare const WithLegend: Story;
10
+ export declare const WithTextValue: Story;
11
+ //# sourceMappingURL=Default.stories.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Default.stories.d.ts","sourceRoot":"","sources":["../../../../../src/components/DonutChart/stories/Default.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AACvD,OAAO,EAAE,UAAU,EAAE,MAAM,UAAU,CAAC;AAGtC,QAAA,MAAM,IAAI,EAAE,IAAI,CAAC,OAAO,UAAU,CAsBjC,CAAC;AAEF,eAAe,IAAI,CAAC;AAEpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,UAAU,CAAC,CAAC;AAEzC,eAAO,MAAM,OAAO,EAAE,KAAU,CAAC;AAEjC,eAAO,MAAM,QAAQ,EAAE,KAMtB,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,KAU1B,CAAC;AAEF,eAAO,MAAM,UAAU,EAAE,KAexB,CAAC;AAEF,eAAO,MAAM,aAAa,EAAE,KAc3B,CAAC"}
@@ -0,0 +1,8 @@
1
+ import { Meta, StoryObj } from '@storybook/react';
2
+ import { DonutChart } from '..';
3
+ declare const meta: Meta<typeof DonutChart>;
4
+ export default meta;
5
+ type Story = StoryObj<typeof DonutChart>;
6
+ export declare const LongValue: Story;
7
+ export declare const LongChildrenContent: Story;
8
+ //# sourceMappingURL=EdgeCases.stories.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"EdgeCases.stories.d.ts","sourceRoot":"","sources":["../../../../../src/components/DonutChart/stories/EdgeCases.stories.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,IAAI,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AAGvD,OAAO,EAAE,UAAU,EAAE,MAAM,yBAAyB,CAAC;AAGrD,QAAA,MAAM,IAAI,EAAE,IAAI,CAAC,OAAO,UAAU,CAGjC,CAAC;AACF,eAAe,IAAI,CAAC;AAEpB,KAAK,KAAK,GAAG,QAAQ,CAAC,OAAO,UAAU,CAAC,CAAC;AAEzC,eAAO,MAAM,SAAS,EAAE,KAEvB,CAAC;AAEF,eAAO,MAAM,mBAAmB,EAAE,KAMjC,CAAC"}
@@ -0,0 +1,8 @@
1
+ import { DonutChart } from './DonutChart';
2
+ import { ViewComponent } from '../../lib/viewComponentContext';
3
+ declare global {
4
+ interface FlowViewComponents {
5
+ DonutChart: ViewComponent<typeof DonutChart>;
6
+ }
7
+ }
8
+ //# sourceMappingURL=view.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"view.d.ts","sourceRoot":"","sources":["../../../../src/components/DonutChart/view.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAC/C,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,4BAA4B,CAAC;AAEhE,OAAO,CAAC,MAAM,CAAC;IACb,UAAU,kBAAkB;QAC1B,UAAU,EAAE,aAAa,CAAC,OAAO,UAAU,CAAC,CAAC;KAC9C;CACF"}
@@ -1 +1 @@
1
- {"version":3,"file":"Sorting.d.ts","sourceRoot":"","sources":["../../../../../../src/components/List/model/sorting/Sorting.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,IAAI,MAAM,8BAA8B,CAAC;AACrD,OAAO,KAAK,EACV,kBAAkB,EAClB,YAAY,EACb,MAAM,uCAAuC,CAAC;AAC/C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAClE,OAAO,KAAK,EACV,MAAM,EACN,SAAS,EACT,UAAU,EACV,aAAa,EACb,SAAS,EACV,MAAM,uBAAuB,CAAC;AAC/B,OAAO,CAAC,MAAM,KAAK,CAAC;AAEpB,qBAAa,OAAO,CAAC,CAAC;IACpB,gBAAuB,aAAa;;;;;;;;;QAKtB;IACd,SAAgB,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;IAC9B,SAAgB,QAAQ,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC;IAC1C,SAAgB,IAAI,CAAC,EAAE,MAAM,CAAC;IAC9B,SAAgB,SAAS,EAAE,aAAa,CAAC;IACzC,SAAgB,cAAc,EAAE,kBAAkB,CAAC;IACnD,SAAgB,eAAe,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC;gBAE5B,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,YAAY,CAAC,CAAC,CAAC;IAUxD,OAAO,CAAC,uBAAuB;IAQxB,oBAAoB,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI;IAO7C,uBAAuB,IAAI,UAAU;IAOrC,QAAQ,IAAI,OAAO;IAKnB,cAAc,IAAI,MAAM,CAAC,CAAC,CAAC;IAI3B,MAAM,IAAI,IAAI;IAOd,KAAK,IAAI,IAAI;IAIpB,IAAW,EAAE,IAAI,MAAM,CAEtB;CACF"}
1
+ {"version":3,"file":"Sorting.d.ts","sourceRoot":"","sources":["../../../../../../src/components/List/model/sorting/Sorting.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,IAAI,MAAM,8BAA8B,CAAC;AACrD,OAAO,KAAK,EACV,kBAAkB,EAClB,YAAY,EACb,MAAM,uCAAuC,CAAC;AAC/C,OAAO,KAAK,EAAE,YAAY,EAAE,MAAM,+BAA+B,CAAC;AAClE,OAAO,KAAK,EACV,MAAM,EACN,SAAS,EACT,UAAU,EACV,aAAa,EACb,SAAS,EACV,MAAM,uBAAuB,CAAC;AAC/B,OAAO,CAAC,MAAM,KAAK,CAAC;AAEpB,qBAAa,OAAO,CAAC,CAAC;IACpB,gBAAuB,aAAa;;;;;;;;;QAKtB;IACd,SAAgB,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC;IAC9B,SAAgB,QAAQ,EAAE,YAAY,CAAC,CAAC,CAAC,CAAC;IAC1C,SAAgB,IAAI,CAAC,EAAE,MAAM,CAAC;IAC9B,SAAgB,SAAS,EAAE,aAAa,CAAC;IACzC,SAAgB,cAAc,EAAE,kBAAkB,CAAC;IACnD,SAAgB,eAAe,CAAC,EAAE,SAAS,CAAC,CAAC,CAAC,CAAC;gBAE5B,IAAI,EAAE,IAAI,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,YAAY,CAAC,CAAC,CAAC;IAaxD,OAAO,CAAC,uBAAuB;IAWxB,oBAAoB,CAAC,GAAG,EAAE,SAAS,CAAC,CAAC,CAAC,GAAG,IAAI;IAO7C,uBAAuB,IAAI,UAAU;IAOrC,QAAQ,IAAI,OAAO;IAKnB,cAAc,IAAI,MAAM,CAAC,CAAC,CAAC;IAI3B,MAAM,IAAI,IAAI;IAOd,KAAK,IAAI,IAAI;IAIpB,IAAW,EAAE,IAAI,MAAM,CAEtB;CACF"}
@@ -1 +1 @@
1
- {"version":3,"file":"ProgressBar.d.ts","sourceRoot":"","sources":["../../../../src/components/ProgressBar/ProgressBar.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,IAAI,MAAM,uBAAuB,CAAC;AAC9C,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,OAAO,CAAC;AAC/C,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAMzD,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AACxE,OAAO,EAEL,KAAK,kBAAkB,EACxB,MAAM,sCAAsC,CAAC;AAE9C,MAAM,WAAW,gBACf,SAAQ,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,UAAU,CAAC,CAAC,EAChE,eAAe,EACf,kBAAkB;IACpB,iDAAiD;IACjD,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,yDAAyD;IACzD,IAAI,CAAC,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;IACvB,yDAAyD;IACzD,QAAQ,CAAC,EAAE;QACT,KAAK,EAAE,MAAM,CAAC;QACd,KAAK,EAAE,MAAM,CAAC;QACd,KAAK,CAAC,EAAE,iBAAiB,CAAC;QAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;KACpB,EAAE,CAAC;IACJ;;;OAGG;IACH,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB;AAED;;;GAGG;AACH,eAAO,MAAM,WAAW,iFAuEtB,CAAC;AAEH,eAAe,WAAW,CAAC"}
1
+ {"version":3,"file":"ProgressBar.d.ts","sourceRoot":"","sources":["../../../../src/components/ProgressBar/ProgressBar.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,IAAI,MAAM,uBAAuB,CAAC;AAC9C,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,OAAO,CAAC;AAC/C,OAAO,KAAK,MAAM,OAAO,CAAC;AAG1B,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAMzD,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AACxE,OAAO,EAEL,KAAK,kBAAkB,EACxB,MAAM,sCAAsC,CAAC;AAE9C,MAAM,WAAW,gBACf,SAAQ,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE,UAAU,CAAC,CAAC,EAChE,eAAe,EACf,kBAAkB;IACpB,iDAAiD;IACjD,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,yDAAyD;IACzD,IAAI,CAAC,EAAE,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;IACvB,yDAAyD;IACzD,QAAQ,CAAC,EAAE;QACT,KAAK,EAAE,MAAM,CAAC;QACd,KAAK,EAAE,MAAM,CAAC;QACd,KAAK,CAAC,EAAE,iBAAiB,CAAC;QAC1B,SAAS,CAAC,EAAE,MAAM,CAAC;KACpB,EAAE,CAAC;IACJ;;;OAGG;IACH,UAAU,CAAC,EAAE,OAAO,CAAC;CACtB;AAED;;;GAGG;AACH,eAAO,MAAM,WAAW,iFAqEtB,CAAC;AAEH,eAAe,WAAW,CAAC"}
@@ -34,6 +34,7 @@ export * from './CounterBadge';
34
34
  export * from './DatePicker';
35
35
  export * from './DateRangePicker';
36
36
  export * from './Div';
37
+ export * from './DonutChart';
37
38
  export * from './FieldDescription';
38
39
  export * from './FieldError';
39
40
  export * from './FileCard';