@mdigital_ui/ui 0.1.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 (205) hide show
  1. package/README.md +296 -0
  2. package/dist/accordion/index.js +5 -0
  3. package/dist/accordion/index.js.map +1 -0
  4. package/dist/badge/index.js +5 -0
  5. package/dist/badge/index.js.map +1 -0
  6. package/dist/button/index.js +6 -0
  7. package/dist/button/index.js.map +1 -0
  8. package/dist/card/index.js +4 -0
  9. package/dist/card/index.js.map +1 -0
  10. package/dist/carousel/index.js +3 -0
  11. package/dist/carousel/index.js.map +1 -0
  12. package/dist/cascader/index.js +4 -0
  13. package/dist/cascader/index.js.map +1 -0
  14. package/dist/chart/index.js +4 -0
  15. package/dist/chart/index.js.map +1 -0
  16. package/dist/checkbox/index.js +5 -0
  17. package/dist/checkbox/index.js.map +1 -0
  18. package/dist/checkbox-group/index.js +4 -0
  19. package/dist/checkbox-group/index.js.map +1 -0
  20. package/dist/chunk-2JGAYDZR.js +181 -0
  21. package/dist/chunk-2JGAYDZR.js.map +1 -0
  22. package/dist/chunk-3PFA3YG6.js +228 -0
  23. package/dist/chunk-3PFA3YG6.js.map +1 -0
  24. package/dist/chunk-4OMLQCUV.js +96 -0
  25. package/dist/chunk-4OMLQCUV.js.map +1 -0
  26. package/dist/chunk-4P5EMRFI.js +298 -0
  27. package/dist/chunk-4P5EMRFI.js.map +1 -0
  28. package/dist/chunk-5UEWVFF6.js +212 -0
  29. package/dist/chunk-5UEWVFF6.js.map +1 -0
  30. package/dist/chunk-5VCGW53O.js +332 -0
  31. package/dist/chunk-5VCGW53O.js.map +1 -0
  32. package/dist/chunk-75XESYGN.js +49 -0
  33. package/dist/chunk-75XESYGN.js.map +1 -0
  34. package/dist/chunk-7AEGBABZ.js +1102 -0
  35. package/dist/chunk-7AEGBABZ.js.map +1 -0
  36. package/dist/chunk-AOITJRSV.js +134 -0
  37. package/dist/chunk-AOITJRSV.js.map +1 -0
  38. package/dist/chunk-AWPKZYHT.js +152 -0
  39. package/dist/chunk-AWPKZYHT.js.map +1 -0
  40. package/dist/chunk-BNILRB4T.js +37 -0
  41. package/dist/chunk-BNILRB4T.js.map +1 -0
  42. package/dist/chunk-BP434VYV.js +448 -0
  43. package/dist/chunk-BP434VYV.js.map +1 -0
  44. package/dist/chunk-C7SXY3ZV.js +65 -0
  45. package/dist/chunk-C7SXY3ZV.js.map +1 -0
  46. package/dist/chunk-CLLQDCDR.js +560 -0
  47. package/dist/chunk-CLLQDCDR.js.map +1 -0
  48. package/dist/chunk-CWHFK7ZC.js +128 -0
  49. package/dist/chunk-CWHFK7ZC.js.map +1 -0
  50. package/dist/chunk-D3JWPGCA.js +123 -0
  51. package/dist/chunk-D3JWPGCA.js.map +1 -0
  52. package/dist/chunk-DOKTHDG3.js +55 -0
  53. package/dist/chunk-DOKTHDG3.js.map +1 -0
  54. package/dist/chunk-DPOSWW22.js +126 -0
  55. package/dist/chunk-DPOSWW22.js.map +1 -0
  56. package/dist/chunk-E2CYDDYC.js +39 -0
  57. package/dist/chunk-E2CYDDYC.js.map +1 -0
  58. package/dist/chunk-EYTOKUBM.js +401 -0
  59. package/dist/chunk-EYTOKUBM.js.map +1 -0
  60. package/dist/chunk-FGWSUPVW.js +356 -0
  61. package/dist/chunk-FGWSUPVW.js.map +1 -0
  62. package/dist/chunk-FPOXTCYV.js +166 -0
  63. package/dist/chunk-FPOXTCYV.js.map +1 -0
  64. package/dist/chunk-FTJOSVTY.js +104 -0
  65. package/dist/chunk-FTJOSVTY.js.map +1 -0
  66. package/dist/chunk-FYHQDFKE.js +164 -0
  67. package/dist/chunk-FYHQDFKE.js.map +1 -0
  68. package/dist/chunk-H2HIBD5Y.js +158 -0
  69. package/dist/chunk-H2HIBD5Y.js.map +1 -0
  70. package/dist/chunk-J3G5WWGR.js +53 -0
  71. package/dist/chunk-J3G5WWGR.js.map +1 -0
  72. package/dist/chunk-JZCHZ4B3.js +487 -0
  73. package/dist/chunk-JZCHZ4B3.js.map +1 -0
  74. package/dist/chunk-KBCBVH7B.js +51 -0
  75. package/dist/chunk-KBCBVH7B.js.map +1 -0
  76. package/dist/chunk-KNQ7UQ2W.js +143 -0
  77. package/dist/chunk-KNQ7UQ2W.js.map +1 -0
  78. package/dist/chunk-KTBPIEP2.js +102 -0
  79. package/dist/chunk-KTBPIEP2.js.map +1 -0
  80. package/dist/chunk-L3SP7GHC.js +1023 -0
  81. package/dist/chunk-L3SP7GHC.js.map +1 -0
  82. package/dist/chunk-LBJG2UWT.js +100 -0
  83. package/dist/chunk-LBJG2UWT.js.map +1 -0
  84. package/dist/chunk-MLDX3Z67.js +470 -0
  85. package/dist/chunk-MLDX3Z67.js.map +1 -0
  86. package/dist/chunk-NNSS366W.js +331 -0
  87. package/dist/chunk-NNSS366W.js.map +1 -0
  88. package/dist/chunk-OQANRZPV.js +197 -0
  89. package/dist/chunk-OQANRZPV.js.map +1 -0
  90. package/dist/chunk-OW5A5IIF.js +175 -0
  91. package/dist/chunk-OW5A5IIF.js.map +1 -0
  92. package/dist/chunk-R225A5II.js +187 -0
  93. package/dist/chunk-R225A5II.js.map +1 -0
  94. package/dist/chunk-ROR4E6IE.js +119 -0
  95. package/dist/chunk-ROR4E6IE.js.map +1 -0
  96. package/dist/chunk-RPAQAZTI.js +54 -0
  97. package/dist/chunk-RPAQAZTI.js.map +1 -0
  98. package/dist/chunk-RQBXZKTH.js +452 -0
  99. package/dist/chunk-RQBXZKTH.js.map +1 -0
  100. package/dist/chunk-S5XJXU52.js +178 -0
  101. package/dist/chunk-S5XJXU52.js.map +1 -0
  102. package/dist/chunk-SAVE5ACL.js +324 -0
  103. package/dist/chunk-SAVE5ACL.js.map +1 -0
  104. package/dist/chunk-SERJ3TZE.js +640 -0
  105. package/dist/chunk-SERJ3TZE.js.map +1 -0
  106. package/dist/chunk-SK5ECBBK.js +175 -0
  107. package/dist/chunk-SK5ECBBK.js.map +1 -0
  108. package/dist/chunk-SOV4PE3P.js +218 -0
  109. package/dist/chunk-SOV4PE3P.js.map +1 -0
  110. package/dist/chunk-W7BQYIXF.js +687 -0
  111. package/dist/chunk-W7BQYIXF.js.map +1 -0
  112. package/dist/chunk-XMAH5PDW.js +59 -0
  113. package/dist/chunk-XMAH5PDW.js.map +1 -0
  114. package/dist/chunk-XOBGEMQY.js +94 -0
  115. package/dist/chunk-XOBGEMQY.js.map +1 -0
  116. package/dist/chunk-YNNAOXU5.js +57 -0
  117. package/dist/chunk-YNNAOXU5.js.map +1 -0
  118. package/dist/chunk-YZVSDRJD.js +253 -0
  119. package/dist/chunk-YZVSDRJD.js.map +1 -0
  120. package/dist/collapse/index.js +4 -0
  121. package/dist/collapse/index.js.map +1 -0
  122. package/dist/command/index.js +5 -0
  123. package/dist/command/index.js.map +1 -0
  124. package/dist/date-picker/index.js +5 -0
  125. package/dist/date-picker/index.js.map +1 -0
  126. package/dist/descriptions/index.js +4 -0
  127. package/dist/descriptions/index.js.map +1 -0
  128. package/dist/drawer/index.js +4 -0
  129. package/dist/drawer/index.js.map +1 -0
  130. package/dist/dropdown/index.js +5 -0
  131. package/dist/dropdown/index.js.map +1 -0
  132. package/dist/empty/index.js +4 -0
  133. package/dist/empty/index.js.map +1 -0
  134. package/dist/fetching-overlay/index.js +5 -0
  135. package/dist/fetching-overlay/index.js.map +1 -0
  136. package/dist/image/index.js +4 -0
  137. package/dist/image/index.js.map +1 -0
  138. package/dist/index.d.ts +2672 -0
  139. package/dist/index.js +976 -0
  140. package/dist/index.js.map +1 -0
  141. package/dist/input/index.js +5 -0
  142. package/dist/input/index.js.map +1 -0
  143. package/dist/input-group/index.js +4 -0
  144. package/dist/input-group/index.js.map +1 -0
  145. package/dist/input-otp/index.js +4 -0
  146. package/dist/input-otp/index.js.map +1 -0
  147. package/dist/input-password/index.js +6 -0
  148. package/dist/input-password/index.js.map +1 -0
  149. package/dist/kbd/index.js +4 -0
  150. package/dist/kbd/index.js.map +1 -0
  151. package/dist/modal/index.js +4 -0
  152. package/dist/modal/index.js.map +1 -0
  153. package/dist/multi-select/index.js +5 -0
  154. package/dist/multi-select/index.js.map +1 -0
  155. package/dist/notification/index.js +4 -0
  156. package/dist/notification/index.js.map +1 -0
  157. package/dist/pagination/index.js +4 -0
  158. package/dist/pagination/index.js.map +1 -0
  159. package/dist/popover/index.js +4 -0
  160. package/dist/popover/index.js.map +1 -0
  161. package/dist/progress/index.js +4 -0
  162. package/dist/progress/index.js.map +1 -0
  163. package/dist/radio/index.js +4 -0
  164. package/dist/radio/index.js.map +1 -0
  165. package/dist/radio-group/index.js +4 -0
  166. package/dist/radio-group/index.js.map +1 -0
  167. package/dist/rating/index.js +4 -0
  168. package/dist/rating/index.js.map +1 -0
  169. package/dist/ribbon/index.js +4 -0
  170. package/dist/ribbon/index.js.map +1 -0
  171. package/dist/select/index.js +6 -0
  172. package/dist/select/index.js.map +1 -0
  173. package/dist/skeleton/index.js +4 -0
  174. package/dist/skeleton/index.js.map +1 -0
  175. package/dist/slider/index.js +4 -0
  176. package/dist/slider/index.js.map +1 -0
  177. package/dist/spinner/index.js +4 -0
  178. package/dist/spinner/index.js.map +1 -0
  179. package/dist/stepper/index.js +4 -0
  180. package/dist/stepper/index.js.map +1 -0
  181. package/dist/styles/base.css +161 -0
  182. package/dist/styles/global.css +633 -0
  183. package/dist/styles/themes/dark.css +84 -0
  184. package/dist/styles/themes/light.css +84 -0
  185. package/dist/switch/index.js +4 -0
  186. package/dist/switch/index.js.map +1 -0
  187. package/dist/table/index.js +12 -0
  188. package/dist/table/index.js.map +1 -0
  189. package/dist/tabs/index.js +5 -0
  190. package/dist/tabs/index.js.map +1 -0
  191. package/dist/textarea/index.js +4 -0
  192. package/dist/textarea/index.js.map +1 -0
  193. package/dist/toggle/index.js +4 -0
  194. package/dist/toggle/index.js.map +1 -0
  195. package/dist/toggle-group/index.js +4 -0
  196. package/dist/toggle-group/index.js.map +1 -0
  197. package/dist/tooltip/index.js +4 -0
  198. package/dist/tooltip/index.js.map +1 -0
  199. package/dist/transfer/index.js +6 -0
  200. package/dist/transfer/index.js.map +1 -0
  201. package/dist/tree/index.js +4 -0
  202. package/dist/tree/index.js.map +1 -0
  203. package/dist/tree-select/index.js +6 -0
  204. package/dist/tree-select/index.js.map +1 -0
  205. package/package.json +107 -0
@@ -0,0 +1,448 @@
1
+ import { cn } from './chunk-YNNAOXU5.js';
2
+ import { ResponsiveContainer, LineChart as LineChart$1, BarChart as BarChart$1, AreaChart as AreaChart$1, ComposedChart as ComposedChart$1, PieChart as PieChart$1, Tooltip, Legend, Pie, Cell, CartesianGrid, XAxis, YAxis, Area, Bar, Line } from 'recharts';
3
+ import React from 'react';
4
+ import { cva } from 'class-variance-authority';
5
+ import { jsx, jsxs, Fragment } from 'react/jsx-runtime';
6
+
7
+ var chartContainerVariants = cva(
8
+ "w-full rounded-lg border border-border bg-card shadow-sm p-6 transition-all duration-200 hover:shadow-md",
9
+ {
10
+ variants: {
11
+ size: {
12
+ sm: "h-[var(--chart-height-sm)]",
13
+ md: "h-[var(--chart-height-md)]",
14
+ lg: "h-[var(--chart-height-lg)]",
15
+ xl: "h-[var(--chart-height-xl)]"
16
+ }
17
+ },
18
+ defaultVariants: {
19
+ size: "md"
20
+ }
21
+ }
22
+ );
23
+ var defaultColors = [
24
+ "var(--color-primary)",
25
+ "var(--color-secondary)",
26
+ "var(--color-success)",
27
+ "var(--color-warning)",
28
+ "var(--color-error)",
29
+ "var(--color-info)"
30
+ ];
31
+ var getChartColor = (index) => {
32
+ return defaultColors[index % defaultColors.length];
33
+ };
34
+ var tooltipStyle = {
35
+ backgroundColor: "var(--color-card)",
36
+ border: "1px solid var(--color-border)",
37
+ borderRadius: "var(--radius-md)",
38
+ fontSize: "var(--font-size-xs)",
39
+ boxShadow: "var(--shadow-md)"
40
+ };
41
+ var legendStyle = {
42
+ fontSize: "var(--font-size-xs)"
43
+ };
44
+ var axisTickStyle = {
45
+ fontSize: "var(--font-size-xs)",
46
+ fill: "var(--color-text-secondary)"
47
+ };
48
+ var axisLineStyle = {
49
+ stroke: "var(--color-border)"
50
+ };
51
+ var gridStyle = {
52
+ stroke: "var(--color-border)",
53
+ opacity: 0.3
54
+ };
55
+ var cursorStyle = {
56
+ fill: "var(--color-surface)",
57
+ opacity: 0.5
58
+ };
59
+ var renderSeriesItem = (seriesItem, index, defaultType) => {
60
+ const color = seriesItem.color || getChartColor(index);
61
+ const type = seriesItem.type || defaultType;
62
+ const key = `${type}-${seriesItem.dataKey}`;
63
+ switch (type) {
64
+ case "line":
65
+ return /* @__PURE__ */ jsx(
66
+ Line,
67
+ {
68
+ type: "monotone",
69
+ dataKey: seriesItem.dataKey,
70
+ stroke: color,
71
+ strokeWidth: 2.5,
72
+ name: seriesItem.name || seriesItem.dataKey,
73
+ dot: { fill: color, strokeWidth: 2, r: 4 },
74
+ activeDot: { r: 6, strokeWidth: 0 }
75
+ },
76
+ key
77
+ );
78
+ case "bar":
79
+ return /* @__PURE__ */ jsx(
80
+ Bar,
81
+ {
82
+ dataKey: seriesItem.dataKey,
83
+ fill: color,
84
+ name: seriesItem.name || seriesItem.dataKey,
85
+ radius: [4, 4, 0, 0]
86
+ },
87
+ key
88
+ );
89
+ case "area":
90
+ return /* @__PURE__ */ jsx(
91
+ Area,
92
+ {
93
+ type: "monotone",
94
+ dataKey: seriesItem.dataKey,
95
+ stroke: color,
96
+ fill: color,
97
+ fillOpacity: 0.2,
98
+ strokeWidth: 2.5,
99
+ name: seriesItem.name || seriesItem.dataKey
100
+ },
101
+ key
102
+ );
103
+ default:
104
+ return null;
105
+ }
106
+ };
107
+ var CartesianChartElements = ({
108
+ xAxisKey,
109
+ showGrid,
110
+ showTooltip,
111
+ showLegend,
112
+ xAxisLabel,
113
+ yAxisLabel
114
+ }) => /* @__PURE__ */ jsxs(Fragment, { children: [
115
+ showGrid && /* @__PURE__ */ jsx(
116
+ CartesianGrid,
117
+ {
118
+ strokeDasharray: "3 3",
119
+ ...gridStyle
120
+ }
121
+ ),
122
+ /* @__PURE__ */ jsx(
123
+ XAxis,
124
+ {
125
+ dataKey: xAxisKey,
126
+ stroke: "var(--color-text-secondary)",
127
+ tick: axisTickStyle,
128
+ axisLine: axisLineStyle,
129
+ tickLine: axisLineStyle,
130
+ label: xAxisLabel ? { value: xAxisLabel, position: "bottom", ...axisTickStyle } : void 0
131
+ }
132
+ ),
133
+ /* @__PURE__ */ jsx(
134
+ YAxis,
135
+ {
136
+ stroke: "var(--color-text-secondary)",
137
+ tick: axisTickStyle,
138
+ axisLine: axisLineStyle,
139
+ tickLine: axisLineStyle,
140
+ label: yAxisLabel ? {
141
+ value: yAxisLabel,
142
+ angle: -90,
143
+ position: "left",
144
+ ...axisTickStyle
145
+ } : void 0
146
+ }
147
+ ),
148
+ showTooltip && /* @__PURE__ */ jsx(
149
+ Tooltip,
150
+ {
151
+ contentStyle: tooltipStyle,
152
+ cursor: cursorStyle
153
+ }
154
+ ),
155
+ showLegend && /* @__PURE__ */ jsx(
156
+ Legend,
157
+ {
158
+ wrapperStyle: legendStyle,
159
+ iconType: "circle",
160
+ iconSize: 8
161
+ }
162
+ )
163
+ ] });
164
+ var LineChart = React.memo(
165
+ ({
166
+ data,
167
+ xAxisKey,
168
+ series,
169
+ size = "md",
170
+ className,
171
+ loading = false,
172
+ showGrid = true,
173
+ showLegend = true,
174
+ showTooltip = true,
175
+ xAxisLabel,
176
+ yAxisLabel
177
+ }) => {
178
+ if (loading) {
179
+ return /* @__PURE__ */ jsx(
180
+ "div",
181
+ {
182
+ className: cn(
183
+ chartContainerVariants({ size }),
184
+ "flex items-center justify-center",
185
+ className
186
+ ),
187
+ children: /* @__PURE__ */ jsx("div", { className: "animate-pulse text-text-muted", children: "Loading chart..." })
188
+ }
189
+ );
190
+ }
191
+ return /* @__PURE__ */ jsx("div", { className: cn(chartContainerVariants({ size }), className), children: /* @__PURE__ */ jsx(
192
+ ResponsiveContainer,
193
+ {
194
+ width: "100%",
195
+ height: "100%",
196
+ children: /* @__PURE__ */ jsxs(LineChart$1, { data, children: [
197
+ /* @__PURE__ */ jsx(
198
+ CartesianChartElements,
199
+ {
200
+ xAxisKey,
201
+ showGrid,
202
+ showTooltip,
203
+ showLegend,
204
+ xAxisLabel,
205
+ yAxisLabel
206
+ }
207
+ ),
208
+ series.map(
209
+ (seriesItem, index) => renderSeriesItem(seriesItem, index, "line")
210
+ )
211
+ ] })
212
+ }
213
+ ) });
214
+ }
215
+ );
216
+ LineChart.displayName = "LineChart";
217
+ var BarChart = React.memo(
218
+ ({
219
+ data,
220
+ xAxisKey,
221
+ series,
222
+ size = "md",
223
+ className,
224
+ loading = false,
225
+ showGrid = true,
226
+ showLegend = true,
227
+ showTooltip = true,
228
+ xAxisLabel,
229
+ yAxisLabel
230
+ }) => {
231
+ if (loading) {
232
+ return /* @__PURE__ */ jsx(
233
+ "div",
234
+ {
235
+ className: cn(
236
+ chartContainerVariants({ size }),
237
+ "flex items-center justify-center",
238
+ className
239
+ ),
240
+ children: /* @__PURE__ */ jsx("div", { className: "animate-pulse text-text-muted", children: "Loading chart..." })
241
+ }
242
+ );
243
+ }
244
+ return /* @__PURE__ */ jsx("div", { className: cn(chartContainerVariants({ size }), className), children: /* @__PURE__ */ jsx(
245
+ ResponsiveContainer,
246
+ {
247
+ width: "100%",
248
+ height: "100%",
249
+ children: /* @__PURE__ */ jsxs(BarChart$1, { data, children: [
250
+ /* @__PURE__ */ jsx(
251
+ CartesianChartElements,
252
+ {
253
+ xAxisKey,
254
+ showGrid,
255
+ showTooltip,
256
+ showLegend,
257
+ xAxisLabel,
258
+ yAxisLabel
259
+ }
260
+ ),
261
+ series.map(
262
+ (seriesItem, index) => renderSeriesItem(seriesItem, index, "bar")
263
+ )
264
+ ] })
265
+ }
266
+ ) });
267
+ }
268
+ );
269
+ BarChart.displayName = "BarChart";
270
+ var AreaChart = React.memo(
271
+ ({
272
+ data,
273
+ xAxisKey,
274
+ series,
275
+ size = "md",
276
+ className,
277
+ loading = false,
278
+ showGrid = true,
279
+ showLegend = true,
280
+ showTooltip = true,
281
+ xAxisLabel,
282
+ yAxisLabel
283
+ }) => {
284
+ if (loading) {
285
+ return /* @__PURE__ */ jsx(
286
+ "div",
287
+ {
288
+ className: cn(
289
+ chartContainerVariants({ size }),
290
+ "flex items-center justify-center",
291
+ className
292
+ ),
293
+ children: /* @__PURE__ */ jsx("div", { className: "animate-pulse text-text-muted", children: "Loading chart..." })
294
+ }
295
+ );
296
+ }
297
+ return /* @__PURE__ */ jsx("div", { className: cn(chartContainerVariants({ size }), className), children: /* @__PURE__ */ jsx(
298
+ ResponsiveContainer,
299
+ {
300
+ width: "100%",
301
+ height: "100%",
302
+ children: /* @__PURE__ */ jsxs(AreaChart$1, { data, children: [
303
+ /* @__PURE__ */ jsx(
304
+ CartesianChartElements,
305
+ {
306
+ xAxisKey,
307
+ showGrid,
308
+ showTooltip,
309
+ showLegend,
310
+ xAxisLabel,
311
+ yAxisLabel
312
+ }
313
+ ),
314
+ series.map(
315
+ (seriesItem, index) => renderSeriesItem(seriesItem, index, "area")
316
+ )
317
+ ] })
318
+ }
319
+ ) });
320
+ }
321
+ );
322
+ AreaChart.displayName = "AreaChart";
323
+ var ComposedChart = React.memo(
324
+ ({
325
+ data,
326
+ xAxisKey,
327
+ series,
328
+ size = "md",
329
+ className,
330
+ loading = false,
331
+ showGrid = true,
332
+ showLegend = true,
333
+ showTooltip = true,
334
+ xAxisLabel,
335
+ yAxisLabel
336
+ }) => {
337
+ if (loading) {
338
+ return /* @__PURE__ */ jsx(
339
+ "div",
340
+ {
341
+ className: cn(
342
+ chartContainerVariants({ size }),
343
+ "flex items-center justify-center",
344
+ className
345
+ ),
346
+ children: /* @__PURE__ */ jsx("div", { className: "animate-pulse text-text-muted", children: "Loading chart..." })
347
+ }
348
+ );
349
+ }
350
+ return /* @__PURE__ */ jsx("div", { className: cn(chartContainerVariants({ size }), className), children: /* @__PURE__ */ jsx(
351
+ ResponsiveContainer,
352
+ {
353
+ width: "100%",
354
+ height: "100%",
355
+ children: /* @__PURE__ */ jsxs(ComposedChart$1, { data, children: [
356
+ /* @__PURE__ */ jsx(
357
+ CartesianChartElements,
358
+ {
359
+ xAxisKey,
360
+ showGrid,
361
+ showTooltip,
362
+ showLegend,
363
+ xAxisLabel,
364
+ yAxisLabel
365
+ }
366
+ ),
367
+ series.map(
368
+ (seriesItem, index) => renderSeriesItem(seriesItem, index, "line")
369
+ )
370
+ ] })
371
+ }
372
+ ) });
373
+ }
374
+ );
375
+ ComposedChart.displayName = "ComposedChart";
376
+ var PieChart = React.memo(
377
+ ({
378
+ data,
379
+ dataKey,
380
+ nameKey,
381
+ size = "md",
382
+ className,
383
+ loading = false,
384
+ showLegend = true,
385
+ showTooltip = true,
386
+ innerRadius = 0
387
+ }) => {
388
+ if (loading) {
389
+ return /* @__PURE__ */ jsx(
390
+ "div",
391
+ {
392
+ className: cn(
393
+ chartContainerVariants({ size }),
394
+ "flex items-center justify-center",
395
+ className
396
+ ),
397
+ children: /* @__PURE__ */ jsx("div", { className: "animate-pulse text-text-muted", children: "Loading chart..." })
398
+ }
399
+ );
400
+ }
401
+ return /* @__PURE__ */ jsx("div", { className: cn(chartContainerVariants({ size }), className), children: /* @__PURE__ */ jsx(
402
+ ResponsiveContainer,
403
+ {
404
+ width: "100%",
405
+ height: "100%",
406
+ children: /* @__PURE__ */ jsxs(PieChart$1, { children: [
407
+ showTooltip && /* @__PURE__ */ jsx(Tooltip, { contentStyle: tooltipStyle }),
408
+ showLegend && /* @__PURE__ */ jsx(
409
+ Legend,
410
+ {
411
+ wrapperStyle: legendStyle,
412
+ iconType: "circle",
413
+ iconSize: 8
414
+ }
415
+ ),
416
+ /* @__PURE__ */ jsx(
417
+ Pie,
418
+ {
419
+ data,
420
+ dataKey,
421
+ nameKey,
422
+ cx: "50%",
423
+ cy: "50%",
424
+ innerRadius,
425
+ outerRadius: 80,
426
+ label: { ...axisTickStyle, fill: "var(--color-text-primary)" },
427
+ paddingAngle: 2,
428
+ children: data.map((_, index) => /* @__PURE__ */ jsx(
429
+ Cell,
430
+ {
431
+ fill: getChartColor(index),
432
+ stroke: "var(--color-card)",
433
+ strokeWidth: 2
434
+ },
435
+ `cell-${index}`
436
+ ))
437
+ }
438
+ )
439
+ ] })
440
+ }
441
+ ) });
442
+ }
443
+ );
444
+ PieChart.displayName = "PieChart";
445
+
446
+ export { AreaChart, BarChart, ComposedChart, LineChart, PieChart, axisLineStyle, axisTickStyle, chartContainerVariants, cursorStyle, getChartColor, gridStyle, legendStyle, tooltipStyle };
447
+ //# sourceMappingURL=chunk-BP434VYV.js.map
448
+ //# sourceMappingURL=chunk-BP434VYV.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/chart/utils.ts","../src/chart/index.tsx"],"names":["RechartsLineChart","RechartsBarChart","RechartsAreaChart","RechartsComposedChart","RechartsPieChart"],"mappings":"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","file":"chunk-BP434VYV.js","sourcesContent":["import { cva } from 'class-variance-authority'\n\nexport const chartContainerVariants = cva(\n 'w-full rounded-lg border border-border bg-card shadow-sm p-6 transition-all duration-200 hover:shadow-md',\n {\n variants: {\n size: {\n sm: 'h-[var(--chart-height-sm)]',\n md: 'h-[var(--chart-height-md)]',\n lg: 'h-[var(--chart-height-lg)]',\n xl: 'h-[var(--chart-height-xl)]',\n },\n },\n defaultVariants: {\n size: 'md',\n },\n },\n)\n\n// Default color palette using theme colors\nexport const defaultColors = [\n 'var(--color-primary)',\n 'var(--color-secondary)',\n 'var(--color-success)',\n 'var(--color-warning)',\n 'var(--color-error)',\n 'var(--color-info)',\n]\n\nexport const getChartColor = (index: number): string | undefined => {\n return defaultColors[index % defaultColors.length]\n}\n\n// Shared style objects for Recharts components (uses CSS variables directly)\nexport const tooltipStyle = {\n backgroundColor: 'var(--color-card)',\n border: '1px solid var(--color-border)',\n borderRadius: 'var(--radius-md)',\n fontSize: 'var(--font-size-xs)',\n boxShadow: 'var(--shadow-md)',\n}\n\nexport const legendStyle = {\n fontSize: 'var(--font-size-xs)',\n}\n\nexport const axisTickStyle = {\n fontSize: 'var(--font-size-xs)',\n fill: 'var(--color-text-secondary)',\n}\n\nexport const axisLineStyle = {\n stroke: 'var(--color-border)',\n}\n\nexport const gridStyle = {\n stroke: 'var(--color-border)',\n opacity: 0.3,\n}\n\nexport const cursorStyle = {\n fill: 'var(--color-surface)',\n opacity: 0.5,\n}\n","import {\n Area,\n Bar,\n CartesianGrid,\n Cell,\n Legend,\n Line,\n Pie,\n AreaChart as RechartsAreaChart,\n BarChart as RechartsBarChart,\n ComposedChart as RechartsComposedChart,\n LineChart as RechartsLineChart,\n PieChart as RechartsPieChart,\n ResponsiveContainer,\n Tooltip,\n XAxis,\n YAxis,\n} from 'recharts'\nimport React from 'react'\n\nimport { cn } from '../utils'\nimport type {\n AreaChartProps,\n BarChartProps,\n ChartSeries,\n ComposedChartProps,\n LineChartProps,\n PieChartProps,\n} from './types'\nimport {\n axisLineStyle,\n axisTickStyle,\n chartContainerVariants,\n cursorStyle,\n getChartColor,\n gridStyle,\n legendStyle,\n tooltipStyle,\n} from './utils'\n\n// Shared rendering logic for series\nconst renderSeriesItem = (\n seriesItem: ChartSeries,\n index: number,\n defaultType: 'line' | 'bar' | 'area',\n) => {\n const color = seriesItem.color || getChartColor(index)\n const type = seriesItem.type || defaultType\n const key = `${type}-${seriesItem.dataKey}`\n\n switch (type) {\n case 'line':\n return (\n <Line\n key={key}\n type=\"monotone\"\n dataKey={seriesItem.dataKey}\n stroke={color}\n strokeWidth={2.5}\n name={seriesItem.name || seriesItem.dataKey}\n dot={{ fill: color, strokeWidth: 2, r: 4 }}\n activeDot={{ r: 6, strokeWidth: 0 }}\n />\n )\n case 'bar':\n return (\n <Bar\n key={key}\n dataKey={seriesItem.dataKey}\n fill={color}\n name={seriesItem.name || seriesItem.dataKey}\n radius={[4, 4, 0, 0]}\n />\n )\n case 'area':\n return (\n <Area\n key={key}\n type=\"monotone\"\n dataKey={seriesItem.dataKey}\n stroke={color}\n fill={color}\n fillOpacity={0.2}\n strokeWidth={2.5}\n name={seriesItem.name || seriesItem.dataKey}\n />\n )\n default:\n return null\n }\n}\n\n// Shared chart elements\nconst CartesianChartElements: React.FC<{\n xAxisKey: string\n showGrid?: boolean\n showTooltip?: boolean\n showLegend?: boolean\n xAxisLabel?: string\n yAxisLabel?: string\n}> = ({\n xAxisKey,\n showGrid,\n showTooltip,\n showLegend,\n xAxisLabel,\n yAxisLabel,\n}) => (\n <>\n {showGrid && (\n <CartesianGrid\n strokeDasharray=\"3 3\"\n {...gridStyle}\n />\n )}\n <XAxis\n dataKey={xAxisKey}\n stroke=\"var(--color-text-secondary)\"\n tick={axisTickStyle}\n axisLine={axisLineStyle}\n tickLine={axisLineStyle}\n label={\n xAxisLabel\n ? { value: xAxisLabel, position: 'bottom', ...axisTickStyle }\n : undefined\n }\n />\n <YAxis\n stroke=\"var(--color-text-secondary)\"\n tick={axisTickStyle}\n axisLine={axisLineStyle}\n tickLine={axisLineStyle}\n label={\n yAxisLabel\n ? {\n value: yAxisLabel,\n angle: -90,\n position: 'left',\n ...axisTickStyle,\n }\n : undefined\n }\n />\n {showTooltip && (\n <Tooltip\n contentStyle={tooltipStyle}\n cursor={cursorStyle}\n />\n )}\n {showLegend && (\n <Legend\n wrapperStyle={legendStyle}\n iconType=\"circle\"\n iconSize={8}\n />\n )}\n </>\n)\n\n// Line Chart Component\nexport const LineChart = React.memo<LineChartProps>(\n ({\n data,\n xAxisKey,\n series,\n size = 'md',\n className,\n loading = false,\n showGrid = true,\n showLegend = true,\n showTooltip = true,\n xAxisLabel,\n yAxisLabel,\n }) => {\n if (loading) {\n return (\n <div\n className={cn(\n chartContainerVariants({ size }),\n 'flex items-center justify-center',\n className,\n )}\n >\n <div className=\"animate-pulse text-text-muted\">Loading chart...</div>\n </div>\n )\n }\n\n return (\n <div className={cn(chartContainerVariants({ size }), className)}>\n <ResponsiveContainer\n width=\"100%\"\n height=\"100%\"\n >\n <RechartsLineChart data={data}>\n <CartesianChartElements\n xAxisKey={xAxisKey}\n showGrid={showGrid}\n showTooltip={showTooltip}\n showLegend={showLegend}\n xAxisLabel={xAxisLabel}\n yAxisLabel={yAxisLabel}\n />\n {series.map((seriesItem, index) =>\n renderSeriesItem(seriesItem, index, 'line'),\n )}\n </RechartsLineChart>\n </ResponsiveContainer>\n </div>\n )\n },\n)\n\nLineChart.displayName = 'LineChart'\n\n// Bar Chart Component\nexport const BarChart = React.memo<BarChartProps>(\n ({\n data,\n xAxisKey,\n series,\n size = 'md',\n className,\n loading = false,\n showGrid = true,\n showLegend = true,\n showTooltip = true,\n xAxisLabel,\n yAxisLabel,\n }) => {\n if (loading) {\n return (\n <div\n className={cn(\n chartContainerVariants({ size }),\n 'flex items-center justify-center',\n className,\n )}\n >\n <div className=\"animate-pulse text-text-muted\">Loading chart...</div>\n </div>\n )\n }\n\n return (\n <div className={cn(chartContainerVariants({ size }), className)}>\n <ResponsiveContainer\n width=\"100%\"\n height=\"100%\"\n >\n <RechartsBarChart data={data}>\n <CartesianChartElements\n xAxisKey={xAxisKey}\n showGrid={showGrid}\n showTooltip={showTooltip}\n showLegend={showLegend}\n xAxisLabel={xAxisLabel}\n yAxisLabel={yAxisLabel}\n />\n {series.map((seriesItem, index) =>\n renderSeriesItem(seriesItem, index, 'bar'),\n )}\n </RechartsBarChart>\n </ResponsiveContainer>\n </div>\n )\n },\n)\n\nBarChart.displayName = 'BarChart'\n\n// Area Chart Component\nexport const AreaChart = React.memo<AreaChartProps>(\n ({\n data,\n xAxisKey,\n series,\n size = 'md',\n className,\n loading = false,\n showGrid = true,\n showLegend = true,\n showTooltip = true,\n xAxisLabel,\n yAxisLabel,\n }) => {\n if (loading) {\n return (\n <div\n className={cn(\n chartContainerVariants({ size }),\n 'flex items-center justify-center',\n className,\n )}\n >\n <div className=\"animate-pulse text-text-muted\">Loading chart...</div>\n </div>\n )\n }\n\n return (\n <div className={cn(chartContainerVariants({ size }), className)}>\n <ResponsiveContainer\n width=\"100%\"\n height=\"100%\"\n >\n <RechartsAreaChart data={data}>\n <CartesianChartElements\n xAxisKey={xAxisKey}\n showGrid={showGrid}\n showTooltip={showTooltip}\n showLegend={showLegend}\n xAxisLabel={xAxisLabel}\n yAxisLabel={yAxisLabel}\n />\n {series.map((seriesItem, index) =>\n renderSeriesItem(seriesItem, index, 'area'),\n )}\n </RechartsAreaChart>\n </ResponsiveContainer>\n </div>\n )\n },\n)\n\nAreaChart.displayName = 'AreaChart'\n\n// Composed Chart Component (supports mixing line, bar, area)\nexport const ComposedChart = React.memo<ComposedChartProps>(\n ({\n data,\n xAxisKey,\n series,\n size = 'md',\n className,\n loading = false,\n showGrid = true,\n showLegend = true,\n showTooltip = true,\n xAxisLabel,\n yAxisLabel,\n }) => {\n if (loading) {\n return (\n <div\n className={cn(\n chartContainerVariants({ size }),\n 'flex items-center justify-center',\n className,\n )}\n >\n <div className=\"animate-pulse text-text-muted\">Loading chart...</div>\n </div>\n )\n }\n\n return (\n <div className={cn(chartContainerVariants({ size }), className)}>\n <ResponsiveContainer\n width=\"100%\"\n height=\"100%\"\n >\n <RechartsComposedChart data={data}>\n <CartesianChartElements\n xAxisKey={xAxisKey}\n showGrid={showGrid}\n showTooltip={showTooltip}\n showLegend={showLegend}\n xAxisLabel={xAxisLabel}\n yAxisLabel={yAxisLabel}\n />\n {series.map((seriesItem, index) =>\n renderSeriesItem(seriesItem, index, 'line'),\n )}\n </RechartsComposedChart>\n </ResponsiveContainer>\n </div>\n )\n },\n)\n\nComposedChart.displayName = 'ComposedChart'\n\n// Pie Chart Component\nexport const PieChart = React.memo<PieChartProps>(\n ({\n data,\n dataKey,\n nameKey,\n size = 'md',\n className,\n loading = false,\n showLegend = true,\n showTooltip = true,\n innerRadius = 0,\n }) => {\n if (loading) {\n return (\n <div\n className={cn(\n chartContainerVariants({ size }),\n 'flex items-center justify-center',\n className,\n )}\n >\n <div className=\"animate-pulse text-text-muted\">Loading chart...</div>\n </div>\n )\n }\n\n return (\n <div className={cn(chartContainerVariants({ size }), className)}>\n <ResponsiveContainer\n width=\"100%\"\n height=\"100%\"\n >\n <RechartsPieChart>\n {showTooltip && <Tooltip contentStyle={tooltipStyle} />}\n {showLegend && (\n <Legend\n wrapperStyle={legendStyle}\n iconType=\"circle\"\n iconSize={8}\n />\n )}\n <Pie\n data={data}\n dataKey={dataKey}\n nameKey={nameKey}\n cx=\"50%\"\n cy=\"50%\"\n innerRadius={innerRadius}\n outerRadius={80}\n label={{ ...axisTickStyle, fill: 'var(--color-text-primary)' }}\n paddingAngle={2}\n >\n {data.map((_, index) => (\n <Cell\n key={`cell-${index}`}\n fill={getChartColor(index)}\n stroke=\"var(--color-card)\"\n strokeWidth={2}\n />\n ))}\n </Pie>\n </RechartsPieChart>\n </ResponsiveContainer>\n </div>\n )\n },\n)\n\nPieChart.displayName = 'PieChart'\n\nexport type * from './types'\nexport {\n chartContainerVariants,\n getChartColor,\n tooltipStyle,\n legendStyle,\n axisTickStyle,\n axisLineStyle,\n gridStyle,\n cursorStyle,\n} from './utils'\n"]}
@@ -0,0 +1,65 @@
1
+ import { cn } from './chunk-YNNAOXU5.js';
2
+ import { cva } from 'class-variance-authority';
3
+ import React from 'react';
4
+ import { jsx } from 'react/jsx-runtime';
5
+
6
+ var ribbonVariants = cva(
7
+ "absolute z-10 rounded-md font-semibold whitespace-nowrap",
8
+ {
9
+ variants: {
10
+ size: {
11
+ xs: "px-2 py-0.5 text-xs",
12
+ sm: "px-3 py-1 text-xs",
13
+ md: "px-4 py-1.5 text-sm",
14
+ lg: "px-5 py-2 text-base"
15
+ },
16
+ position: {
17
+ "top-left": "-top-2 -left-2",
18
+ "top-right": "-top-2 -right-2",
19
+ "bottom-left": "-bottom-2 -left-2",
20
+ "bottom-right": "-bottom-2 -right-2"
21
+ }
22
+ },
23
+ defaultVariants: {
24
+ size: "md",
25
+ position: "top-right"
26
+ }
27
+ }
28
+ );
29
+ var ribbonColorStyles = {
30
+ default: "bg-surface text-text-primary",
31
+ primary: "bg-primary text-white",
32
+ secondary: "bg-secondary text-white",
33
+ accent: "bg-accent text-white",
34
+ success: "bg-success text-white",
35
+ error: "bg-error text-white",
36
+ warning: "bg-warning text-white",
37
+ info: "bg-info text-white"
38
+ };
39
+ var Ribbon = React.memo(
40
+ ({
41
+ children,
42
+ color = "primary",
43
+ size = "md",
44
+ position = "top-right",
45
+ className
46
+ }) => {
47
+ return /* @__PURE__ */ jsx(
48
+ "div",
49
+ {
50
+ className: cn(
51
+ ribbonVariants({ size, position }),
52
+ ribbonColorStyles[color],
53
+ className
54
+ ),
55
+ children
56
+ }
57
+ );
58
+ }
59
+ );
60
+ Ribbon.displayName = "Ribbon";
61
+ var ribbon_default = Ribbon;
62
+
63
+ export { Ribbon, ribbon_default };
64
+ //# sourceMappingURL=chunk-C7SXY3ZV.js.map
65
+ //# sourceMappingURL=chunk-C7SXY3ZV.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/ribbon/index.tsx"],"names":[],"mappings":";;;;;AAMA,IAAM,cAAA,GAAiB,GAAA;AAAA,EACrB,0DAAA;AAAA,EACA;AAAA,IACE,QAAA,EAAU;AAAA,MACR,IAAA,EAAM;AAAA,QACJ,EAAA,EAAI,qBAAA;AAAA,QACJ,EAAA,EAAI,mBAAA;AAAA,QACJ,EAAA,EAAI,qBAAA;AAAA,QACJ,EAAA,EAAI;AAAA,OACN;AAAA,MACA,QAAA,EAAU;AAAA,QACR,UAAA,EAAY,gBAAA;AAAA,QACZ,WAAA,EAAa,iBAAA;AAAA,QACb,aAAA,EAAe,mBAAA;AAAA,QACf,cAAA,EAAgB;AAAA;AAClB,KACF;AAAA,IACA,eAAA,EAAiB;AAAA,MACf,IAAA,EAAM,IAAA;AAAA,MACN,QAAA,EAAU;AAAA;AACZ;AAEJ,CAAA;AAEA,IAAM,iBAAA,GAAoB;AAAA,EACxB,OAAA,EAAS,8BAAA;AAAA,EACT,OAAA,EAAS,uBAAA;AAAA,EACT,SAAA,EAAW,yBAAA;AAAA,EACX,MAAA,EAAQ,sBAAA;AAAA,EACR,OAAA,EAAS,uBAAA;AAAA,EACT,KAAA,EAAO,qBAAA;AAAA,EACP,OAAA,EAAS,uBAAA;AAAA,EACT,IAAA,EAAM;AACR,CAAA;AAEO,IAAM,SAAS,KAAA,CAAM,IAAA;AAAA,EAC1B,CAAC;AAAA,IACC,QAAA;AAAA,IACA,KAAA,GAAQ,SAAA;AAAA,IACR,IAAA,GAAO,IAAA;AAAA,IACP,QAAA,GAAW,WAAA;AAAA,IACX;AAAA,GACF,KAAM;AACJ,IAAA,uBACE,GAAA;AAAA,MAAC,KAAA;AAAA,MAAA;AAAA,QACC,SAAA,EAAW,EAAA;AAAA,UACT,cAAA,CAAe,EAAE,IAAA,EAAM,QAAA,EAAU,CAAA;AAAA,UACjC,kBAAkB,KAAK,CAAA;AAAA,UACvB;AAAA,SACF;AAAA,QAEC;AAAA;AAAA,KACH;AAAA,EAEJ;AACF;AAEA,MAAA,CAAO,WAAA,GAAc,QAAA;AAGrB,IAAO,cAAA,GAAQ","file":"chunk-C7SXY3ZV.js","sourcesContent":["import { cva } from 'class-variance-authority'\nimport React from 'react'\n\nimport { cn } from '../utils'\nimport type { RibbonProps } from './types'\n\nconst ribbonVariants = cva(\n 'absolute z-10 rounded-md font-semibold whitespace-nowrap',\n {\n variants: {\n size: {\n xs: 'px-2 py-0.5 text-xs',\n sm: 'px-3 py-1 text-xs',\n md: 'px-4 py-1.5 text-sm',\n lg: 'px-5 py-2 text-base',\n },\n position: {\n 'top-left': '-top-2 -left-2',\n 'top-right': '-top-2 -right-2',\n 'bottom-left': '-bottom-2 -left-2',\n 'bottom-right': '-bottom-2 -right-2',\n },\n },\n defaultVariants: {\n size: 'md',\n position: 'top-right',\n },\n },\n)\n\nconst ribbonColorStyles = {\n default: 'bg-surface text-text-primary',\n primary: 'bg-primary text-white',\n secondary: 'bg-secondary text-white',\n accent: 'bg-accent text-white',\n success: 'bg-success text-white',\n error: 'bg-error text-white',\n warning: 'bg-warning text-white',\n info: 'bg-info text-white',\n}\n\nexport const Ribbon = React.memo<RibbonProps>(\n ({\n children,\n color = 'primary',\n size = 'md',\n position = 'top-right',\n className,\n }) => {\n return (\n <div\n className={cn(\n ribbonVariants({ size, position }),\n ribbonColorStyles[color],\n className,\n )}\n >\n {children}\n </div>\n )\n },\n)\n\nRibbon.displayName = 'Ribbon'\n\nexport type * from './types'\nexport default Ribbon\n"]}