@anoki/fse-ui 1.0.0-beta1.45.3 → 1.0.0-beta1.45.4

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 (82) hide show
  1. package/dist/components/ui/Table/Table.css +1 -1
  2. package/dist/components/ui/TableMobile/TableMobile.css +1 -1
  3. package/dist/index.cjs314.js +1 -1
  4. package/dist/index.cjs328.js +1 -1
  5. package/dist/index.cjs333.js +1 -1
  6. package/dist/index.cjs344.js +1 -1
  7. package/dist/index.cjs433.js +1 -1
  8. package/dist/{index.cjs494.js → index.cjs488.js} +1 -1
  9. package/dist/{index.cjs494.js.map → index.cjs488.js.map} +1 -1
  10. package/dist/index.cjs529.js +1 -1
  11. package/dist/index.cjs552.js +1 -1
  12. package/dist/index.cjs561.js +1 -1
  13. package/dist/index.cjs563.js +1 -1
  14. package/dist/index.cjs578.js +38 -1
  15. package/dist/index.cjs578.js.map +1 -1
  16. package/dist/index.cjs579.js +1 -1
  17. package/dist/index.cjs579.js.map +1 -1
  18. package/dist/index.cjs580.js +1 -1
  19. package/dist/index.cjs580.js.map +1 -1
  20. package/dist/index.cjs581.js +1 -1
  21. package/dist/index.cjs581.js.map +1 -1
  22. package/dist/index.cjs582.js +1 -38
  23. package/dist/index.cjs582.js.map +1 -1
  24. package/dist/index.cjs583.js +1 -1
  25. package/dist/index.cjs583.js.map +1 -1
  26. package/dist/index.cjs584.js +1 -1
  27. package/dist/index.cjs584.js.map +1 -1
  28. package/dist/index.cjs585.js +1 -1
  29. package/dist/index.cjs585.js.map +1 -1
  30. package/dist/index.cjs586.js +1 -1
  31. package/dist/index.cjs586.js.map +1 -1
  32. package/dist/index.cjs591.js +1 -1
  33. package/dist/index.cjs591.js.map +1 -1
  34. package/dist/index.cjs592.js +1 -1
  35. package/dist/index.cjs592.js.map +1 -1
  36. package/dist/index.cjs593.js +1 -1
  37. package/dist/index.cjs593.js.map +1 -1
  38. package/dist/index.cjs594.js +1 -1
  39. package/dist/index.cjs594.js.map +1 -1
  40. package/dist/index.cjs74.js +1 -1
  41. package/dist/index.cjs74.js.map +1 -1
  42. package/dist/index.es314.js +1 -1
  43. package/dist/index.es328.js +1 -1
  44. package/dist/index.es333.js +1 -1
  45. package/dist/index.es344.js +1 -1
  46. package/dist/index.es433.js +1 -1
  47. package/dist/{index.es494.js → index.es488.js} +1 -1
  48. package/dist/{index.es494.js.map → index.es488.js.map} +1 -1
  49. package/dist/index.es529.js +3 -3
  50. package/dist/index.es552.js +1 -1
  51. package/dist/index.es561.js +1 -1
  52. package/dist/index.es563.js +4 -4
  53. package/dist/index.es578.js +64 -518
  54. package/dist/index.es578.js.map +1 -1
  55. package/dist/index.es579.js +8 -126
  56. package/dist/index.es579.js.map +1 -1
  57. package/dist/index.es580.js +13 -128
  58. package/dist/index.es580.js.map +1 -1
  59. package/dist/index.es581.js +61 -64
  60. package/dist/index.es581.js.map +1 -1
  61. package/dist/index.es582.js +65 -69
  62. package/dist/index.es582.js.map +1 -1
  63. package/dist/index.es583.js +4 -9
  64. package/dist/index.es583.js.map +1 -1
  65. package/dist/index.es584.js +520 -11
  66. package/dist/index.es584.js.map +1 -1
  67. package/dist/index.es585.js +126 -61
  68. package/dist/index.es585.js.map +1 -1
  69. package/dist/index.es586.js +128 -3
  70. package/dist/index.es586.js.map +1 -1
  71. package/dist/index.es591.js +21 -11
  72. package/dist/index.es591.js.map +1 -1
  73. package/dist/index.es592.js +11 -26
  74. package/dist/index.es592.js.map +1 -1
  75. package/dist/index.es593.js +27 -4
  76. package/dist/index.es593.js.map +1 -1
  77. package/dist/index.es594.js +4 -22
  78. package/dist/index.es594.js.map +1 -1
  79. package/dist/index.es74.js +104 -104
  80. package/dist/index.es74.js.map +1 -1
  81. package/package.json +1 -1
  82. /package/dist/components/ui/{DoctorModal/DoctorModalFooter/DoctorModalFooter.css → ConsentModal/ConsentModalFooter/ConsentModalFooter.css} +0 -0
@@ -1,4 +1,4 @@
1
- import { j as n } from "./index.es241.js";
1
+ import { j as i } from "./index.es241.js";
2
2
  import { clsx as _ } from "./index.es243.js";
3
3
  import './components/ui/TableMobile/TableMobile.css';/* empty css */
4
4
  import * as B from "react";
@@ -10,42 +10,42 @@ import { TriangleUp as q } from "./index.es197.js";
10
10
  import { TriangleDown as v } from "./index.es198.js";
11
11
  import { Download as F } from "./index.es190.js";
12
12
  import { Info as G } from "./index.es199.js";
13
- const nn = ({
13
+ const ii = ({
14
14
  data: t,
15
15
  columns: e,
16
- pagination: l = !0,
16
+ pagination: c = !0,
17
17
  resultsPerPage: r = 5,
18
18
  totalResults: h,
19
19
  initialCurrentPage: N = 1,
20
- serverSidePagination: o = !1,
21
- totalItems: i,
22
- hasNextPage: c,
20
+ serverSidePagination: a = !1,
21
+ totalItems: n,
22
+ hasNextPage: l,
23
23
  hasPreviousPage: y,
24
- onNextPage: d,
25
- onPreviousPage: m,
24
+ onNextPage: m,
25
+ onPreviousPage: d,
26
26
  onPageChange: x,
27
- setCurrentPage: a,
28
- sortConfig: p = null,
27
+ setCurrentPage: o,
28
+ sortConfig: b = null,
29
29
  onSortChange: V
30
30
  }) => {
31
- const [w, k] = U(N), L = (b) => {
32
- k(b), a == null || a(b);
33
- }, j = B.useMemo(() => p ? [...t].sort((b, u) => {
34
- const M = b[p.key], I = u[p.key], z = typeof M == "object" && "firstLine" in M ? M.firstLine : M, A = typeof I == "object" && "firstLine" in I ? I.firstLine : I;
35
- return z < A ? p.direction === "asc" ? -1 : 1 : z > A ? p.direction === "asc" ? 1 : -1 : 0;
36
- }) : t, [t, p]), s = o ? 0 : (w - 1) * r, D = o ? j.length : Math.min(s + r, j.length), f = j.slice(s, D);
37
- return /* @__PURE__ */ n.jsxs($, { className: "w-full h-full", gap: "x16", children: [
38
- f.map((b, u) => /* @__PURE__ */ n.jsx(
31
+ const [w, k] = U(N), L = (p) => {
32
+ k(p), o == null || o(p);
33
+ }, j = B.useMemo(() => b ? [...t].sort((p, u) => {
34
+ const M = p[b.key], I = u[b.key], z = typeof M == "object" && "firstLine" in M ? M.firstLine : M, A = typeof I == "object" && "firstLine" in I ? I.firstLine : I;
35
+ return z < A ? b.direction === "asc" ? -1 : 1 : z > A ? b.direction === "asc" ? 1 : -1 : 0;
36
+ }) : t, [t, b]), s = a ? 0 : (w - 1) * r, D = a ? j.length : Math.min(s + r, j.length), f = j.slice(s, D);
37
+ return /* @__PURE__ */ i.jsxs($, { className: "w-full h-full", gap: "x16", children: [
38
+ f.map((p, u) => /* @__PURE__ */ i.jsx(
39
39
  J,
40
40
  {
41
41
  columns: e,
42
- data: b,
43
- sortConfig: p,
42
+ data: p,
43
+ sortConfig: b,
44
44
  onSortChange: V
45
45
  },
46
46
  u
47
47
  )),
48
- l && /* @__PURE__ */ n.jsx(
48
+ c && /* @__PURE__ */ i.jsx(
49
49
  K,
50
50
  {
51
51
  currentPage: w,
@@ -53,103 +53,103 @@ const nn = ({
53
53
  resultsPerPage: r,
54
54
  setCurrentPage: L,
55
55
  onPageChange: x,
56
- serverSide: o,
57
- totalItems: i,
58
- hasNextPage: c,
56
+ serverSide: a,
57
+ totalItems: n,
58
+ hasNextPage: l,
59
59
  hasPreviousPage: y,
60
- onNextPage: d,
61
- onPreviousPage: m,
62
- currentResultsPerPage: o ? j.length : r,
60
+ onNextPage: m,
61
+ onPreviousPage: d,
62
+ currentResultsPerPage: a ? j.length : r,
63
63
  className: "mt-x16"
64
64
  }
65
65
  )
66
66
  ] });
67
- }, H = ({ data: t }) => t.type === "link" && t.link ? /* @__PURE__ */ n.jsx("a", { href: t.link, "aria-label": t.ariaLabel, children: t.label }) : /* @__PURE__ */ n.jsx("button", { onClick: t.action, "aria-label": t.ariaLabel, children: t.label }), J = ({
67
+ }, H = ({ data: t }) => t.type === "link" && t.link ? /* @__PURE__ */ i.jsx("a", { href: t.link, "aria-label": t.ariaLabel, children: t.label }) : /* @__PURE__ */ i.jsx("button", { onClick: t.action, "aria-label": t.ariaLabel, children: t.label }), J = ({
68
68
  columns: t,
69
69
  sortConfig: e,
70
- data: l,
70
+ data: c,
71
71
  onSortChange: r
72
72
  }) => {
73
- const h = (i) => {
74
- if (!i) return "";
75
- if (typeof i == "object" && "firstLine" in i) {
76
- const c = i;
77
- return `${c.firstLine}${c.secondLine ? ` ${c.secondLine}` : ""}`;
73
+ const h = (n) => {
74
+ if (!n) return "";
75
+ if (typeof n == "object" && "firstLine" in n) {
76
+ const l = n;
77
+ return `${l.firstLine}${l.secondLine ? ` ${l.secondLine}` : ""}`;
78
78
  }
79
- return typeof i == "object" && "label" in i && "type" in i ? /* @__PURE__ */ n.jsx(H, { data: i }) : i;
80
- }, N = (i) => {
81
- switch (i) {
79
+ return typeof n == "object" && "label" in n && "type" in n ? /* @__PURE__ */ i.jsx(H, { data: n }) : n;
80
+ }, N = (n) => {
81
+ switch (n) {
82
82
  case "info":
83
- return /* @__PURE__ */ n.jsx(G, {});
83
+ return /* @__PURE__ */ i.jsx(G, {});
84
84
  case "download":
85
- return /* @__PURE__ */ n.jsx(F, {});
85
+ return /* @__PURE__ */ i.jsx(F, {});
86
86
  default:
87
- return i;
87
+ return n;
88
88
  }
89
- }, o = (i) => {
89
+ }, a = (n) => {
90
90
  if (!r || !e) return;
91
- const c = e.key === i && e.direction === "asc" ? "desc" : "asc";
92
- r(i, c);
91
+ const l = e.key === n && e.direction === "asc" ? "desc" : "asc";
92
+ r(n, l);
93
93
  };
94
- return /* @__PURE__ */ n.jsx(
94
+ return /* @__PURE__ */ i.jsx(
95
95
  "div",
96
96
  {
97
97
  className: _("ui-card-table shadow br-x4 text-slate-28 fs-custom "),
98
- children: t.map((i, c) => {
99
- if (!i.key || i.key === "actionData")
100
- return /* @__PURE__ */ n.jsx(
98
+ children: t.map((n, l) => {
99
+ if (!n.key || n.key === "actionData")
100
+ return /* @__PURE__ */ i.jsx(
101
101
  T,
102
102
  {
103
103
  p: "x16",
104
104
  className: "ui-table-header",
105
105
  justifyContent: "space-between",
106
- children: /* @__PURE__ */ n.jsx($, { justifyContent: "end", gap: "x4", className: "w-full", children: /* @__PURE__ */ n.jsx(T, { justifyContent: "end", className: "table-mobile-actions", children: h(l.actionData) }) })
106
+ children: /* @__PURE__ */ i.jsx($, { justifyContent: "end", gap: "x4", className: "w-full", children: /* @__PURE__ */ i.jsx(T, { justifyContent: "end", className: "table-mobile-actions", children: h(c.actionData) }) })
107
107
  },
108
- c
108
+ l
109
109
  );
110
- const y = l[i.key], d = i, m = (e == null ? void 0 : e.key) === i.key, x = m ? e.direction : null;
111
- return /* @__PURE__ */ n.jsx(
110
+ const y = c[n.key], m = n, d = (e == null ? void 0 : e.key) === n.key, x = d ? e.direction : null;
111
+ return /* @__PURE__ */ i.jsx(
112
112
  T,
113
113
  {
114
114
  p: "x16",
115
115
  className: "ui-table-header",
116
116
  justifyContent: "space-between",
117
- children: /* @__PURE__ */ n.jsxs($, { justifyContent: "center", gap: "x4", className: "w-full", children: [
118
- /* @__PURE__ */ n.jsx(
117
+ children: /* @__PURE__ */ i.jsxs($, { justifyContent: "center", gap: "x4", className: "w-full", children: [
118
+ /* @__PURE__ */ i.jsx(
119
119
  E,
120
120
  {
121
121
  justifyContent: "space-between",
122
122
  alignItems: "center",
123
- icon: N(d.icon),
124
- noIcon: !N(d.icon),
125
- textLabel: d.label,
126
- iconPosition: d.iconPosition,
127
- popupInfo: d.popupInfo,
123
+ icon: N(m.icon),
124
+ noIcon: !N(m.icon),
125
+ textLabel: m.label,
126
+ iconPosition: m.iconPosition,
127
+ popupInfo: m.popupInfo,
128
128
  positionPopUp: "left",
129
129
  classNameText: "fw-bold text-slate-28 fs-custom md-fs-6",
130
- children: d.sortable && /* @__PURE__ */ n.jsxs(
130
+ children: m.sortable && /* @__PURE__ */ i.jsxs(
131
131
  "span",
132
132
  {
133
133
  className: "sort-indicator",
134
- onClick: (a) => {
135
- a.stopPropagation(), o(i.key);
134
+ onClick: (o) => {
135
+ o.stopPropagation(), a(n.key);
136
136
  },
137
137
  children: [
138
- /* @__PURE__ */ n.jsx(
138
+ /* @__PURE__ */ i.jsx(
139
139
  q,
140
140
  {
141
- filled: m && x === "desc",
141
+ filled: d && x === "desc",
142
142
  className: _("sort-indicator__triangle", {
143
- active: m && x === "desc"
143
+ active: d && x === "desc"
144
144
  })
145
145
  }
146
146
  ),
147
- /* @__PURE__ */ n.jsx(
147
+ /* @__PURE__ */ i.jsx(
148
148
  v,
149
149
  {
150
- filled: m && x === "asc",
150
+ filled: d && x === "asc",
151
151
  className: _("sort-indicator__triangle", {
152
- active: m && x === "asc"
152
+ active: d && x === "asc"
153
153
  })
154
154
  }
155
155
  )
@@ -158,10 +158,10 @@ const nn = ({
158
158
  )
159
159
  }
160
160
  ),
161
- /* @__PURE__ */ n.jsx(T, { children: h(y) })
161
+ /* @__PURE__ */ i.jsx(T, { children: h(y) })
162
162
  ] })
163
163
  },
164
- c
164
+ l
165
165
  );
166
166
  })
167
167
  }
@@ -169,91 +169,91 @@ const nn = ({
169
169
  }, K = ({
170
170
  currentPage: t = 1,
171
171
  totalResults: e = 0,
172
- resultsPerPage: l,
172
+ resultsPerPage: c,
173
173
  setCurrentPage: r,
174
174
  onPageChange: h,
175
175
  className: N,
176
- serverSide: o = !1,
177
- totalItems: i,
178
- hasNextPage: c,
176
+ serverSide: a = !1,
177
+ totalItems: n,
178
+ hasNextPage: l,
179
179
  hasPreviousPage: y,
180
- onNextPage: d,
181
- onPreviousPage: m,
182
- currentResultsPerPage: x = l
180
+ onNextPage: m,
181
+ onPreviousPage: d,
182
+ currentResultsPerPage: x = c
183
183
  }) => {
184
- const a = Math.ceil(o ? (i || e) / l : e / l), p = (s) => {
184
+ const o = Math.ceil(a ? (n || e) / c : e / c), b = (s) => {
185
185
  r == null || r(s), h && h(s);
186
186
  }, V = () => {
187
187
  const s = t + 1;
188
- o && d && d(), p(s);
188
+ a && m && m(), b(s);
189
189
  }, w = () => {
190
190
  const s = t - 1;
191
- o && m && m(), p(s);
192
- }, k = o ? !c : t === a, L = o ? !y : t === 1, j = () => {
191
+ a && d && d(), b(s);
192
+ }, k = a ? !l : t === o, L = a ? !y : t === 1, j = () => {
193
193
  const s = [];
194
- if (a <= 5)
195
- for (let f = 1; f <= a; f++)
194
+ if (o <= 5)
195
+ for (let f = 1; f <= o; f++)
196
196
  s.push(f);
197
197
  else {
198
198
  s.push(1);
199
- let f = Math.max(2, t - 1), b = Math.min(a - 1, t + 1);
200
- t <= 3 ? b = 4 : t >= a - 2 && (f = a - 3), f > 2 && s.push("...");
201
- for (let u = f; u <= b; u++)
199
+ let f = Math.max(2, t - 1), p = Math.min(o - 1, t + 1);
200
+ t <= 3 ? p = 4 : t >= o - 2 && (f = o - 3), f > 2 && s.push("...");
201
+ for (let u = f; u <= p; u++)
202
202
  s.push(u);
203
- b < a - 1 && s.push("..."), s.push(a);
203
+ p < o - 1 && s.push("..."), s.push(o);
204
204
  }
205
205
  return s;
206
206
  };
207
- return /* @__PURE__ */ n.jsxs("div", { className: _("pagination", N), children: [
208
- /* @__PURE__ */ n.jsxs("div", { className: "pagination__info", children: [
207
+ return /* @__PURE__ */ i.jsxs("div", { className: _("pagination-mobile", N), children: [
208
+ /* @__PURE__ */ i.jsxs("div", { className: "pagination-mobile__info", children: [
209
209
  "Stai visualizzando",
210
210
  " ",
211
- /* @__PURE__ */ n.jsx("span", { className: "pagination__info__resultsPerPage", children: o ? x : t === a && e % l !== 0 ? e % l : l }),
211
+ /* @__PURE__ */ i.jsx("span", { className: "pagination-mobile__info__resultsPerPage", children: a ? x : t === o && e % c !== 0 ? e % c : c }),
212
212
  " ",
213
213
  "di ",
214
- o && i || e,
214
+ a && n || e,
215
215
  " risultati"
216
216
  ] }),
217
- /* @__PURE__ */ n.jsxs("div", { className: "pagination__nav", children: [
218
- /* @__PURE__ */ n.jsx(
217
+ /* @__PURE__ */ i.jsxs("div", { className: "pagination-mobile__nav", children: [
218
+ /* @__PURE__ */ i.jsx(
219
219
  "button",
220
220
  {
221
221
  className: _(
222
- "pagination__button",
223
- L && "pagination__button--disabled"
222
+ "pagination-mobile__button",
223
+ L && "pagination-mobile__button--disabled"
224
224
  ),
225
225
  onClick: w,
226
226
  disabled: L,
227
227
  "aria-label": "Previous page",
228
- children: /* @__PURE__ */ n.jsx("svg", { className: "pagination__button-arrow", viewBox: "0 0 24 24", children: /* @__PURE__ */ n.jsx("path", { d: "M15 18l-6-6 6-6" }) })
228
+ children: /* @__PURE__ */ i.jsx("svg", { className: "pagination-mobile__button-arrow", viewBox: "0 0 24 24", children: /* @__PURE__ */ i.jsx("path", { d: "M15 18l-6-6 6-6" }) })
229
229
  }
230
230
  ),
231
231
  j().map(
232
- (s, D) => s === "..." ? /* @__PURE__ */ n.jsx("span", { className: "pagination__ellipsis", children: "..." }, `ellipsis-${D}`) : /* @__PURE__ */ n.jsx(
232
+ (s, D) => s === "..." ? /* @__PURE__ */ i.jsx("span", { className: "pagination-mobile__ellipsis", children: "..." }, `ellipsis-${D}`) : /* @__PURE__ */ i.jsx(
233
233
  "button",
234
234
  {
235
235
  className: _(
236
- "pagination__button",
237
- t === s && "pagination__button--active"
236
+ "pagination-mobile__button",
237
+ t === s && "pagination-mobile__button--active"
238
238
  ),
239
- onClick: () => p(s),
239
+ onClick: () => b(s),
240
240
  disabled: s === t,
241
241
  children: s
242
242
  },
243
243
  s
244
244
  )
245
245
  ),
246
- /* @__PURE__ */ n.jsx(
246
+ /* @__PURE__ */ i.jsx(
247
247
  "button",
248
248
  {
249
249
  className: _(
250
- "pagination__button",
251
- k && "pagination__button--disabled"
250
+ "pagination-mobile__button",
251
+ k && "pagination-mobile__button--disabled"
252
252
  ),
253
253
  onClick: V,
254
254
  disabled: k,
255
255
  "aria-label": "Next page",
256
- children: /* @__PURE__ */ n.jsx("svg", { className: "pagination__button-arrow", viewBox: "0 0 24 24", children: /* @__PURE__ */ n.jsx("path", { d: "M9 6l6 6-6 6" }) })
256
+ children: /* @__PURE__ */ i.jsx("svg", { className: "pagination-mobile__button-arrow", viewBox: "0 0 24 24", children: /* @__PURE__ */ i.jsx("path", { d: "M9 6l6 6-6 6" }) })
257
257
  }
258
258
  )
259
259
  ] })
@@ -261,7 +261,7 @@ const nn = ({
261
261
  };
262
262
  export {
263
263
  J as CardTable,
264
- nn as TableMobile,
264
+ ii as TableMobile,
265
265
  K as TableMobilePagination
266
266
  };
267
267
  //# sourceMappingURL=index.es74.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.es74.js","sources":["../src/components/ui/TableMobile/index.tsx"],"sourcesContent":["import {\n ActionData,\n ActionIconText,\n Col,\n ColumnConfig,\n DoubleLineData,\n Row,\n TableRowData,\n} from \"@/components\";\nimport clsx from \"clsx\";\nimport \"./TableMobile.scss\";\nimport { Download, Info, TriangleDown, TriangleUp } from \"@/icons\";\nimport { ReactNode } from \"react\";\nimport * as React from \"react\";\nimport { CommonIconsType } from \"@/types/icons.ts\";\nimport { useState } from \"react\";\n\nexport type TableMobileProps = {\n data: TableRowData[];\n columns: ColumnConfig[];\n pagination?: boolean;\n resultsPerPage?: number;\n totalResults?: number;\n initialCurrentPage?: number;\n serverSidePagination?: boolean;\n totalItems?: number;\n hasNextPage?: boolean;\n hasPreviousPage?: boolean;\n onNextPage?: () => void;\n onPreviousPage?: () => void;\n onPageChange?: (page: number) => void;\n setCurrentPage?: (page: number) => void;\n sortConfig?: { key: string; direction: \"asc\" | \"desc\" } | null;\n onSortChange?: (key: string, direction: \"asc\" | \"desc\") => void;\n};\n\nexport const TableMobile = ({\n data,\n columns,\n pagination = true,\n resultsPerPage = 5,\n totalResults,\n initialCurrentPage = 1,\n serverSidePagination = false,\n totalItems,\n hasNextPage,\n hasPreviousPage,\n onNextPage,\n onPreviousPage,\n onPageChange,\n setCurrentPage: externalSetCurrentPage,\n sortConfig = null,\n onSortChange,\n}: TableMobileProps) => {\n const [currentPage, setInternalCurrentPage] = useState(initialCurrentPage);\n const handleSetCurrentPage = (page: number) => {\n setInternalCurrentPage(page);\n externalSetCurrentPage?.(page);\n };\n\n const sortedData = React.useMemo(() => {\n if (!sortConfig) return data;\n\n return [...data].sort((a, b) => {\n const aValue = a[sortConfig.key];\n const bValue = b[sortConfig.key];\n\n const aText =\n typeof aValue === \"object\" && \"firstLine\" in aValue\n ? aValue.firstLine\n : aValue;\n const bText =\n typeof bValue === \"object\" && \"firstLine\" in bValue\n ? bValue.firstLine\n : bValue;\n\n if (aText < bText) {\n return sortConfig.direction === \"asc\" ? -1 : 1;\n }\n if (aText > bText) {\n return sortConfig.direction === \"asc\" ? 1 : -1;\n }\n return 0;\n });\n }, [data, sortConfig]);\n\n const startIndex = serverSidePagination\n ? 0\n : (currentPage - 1) * resultsPerPage;\n const endIndex = serverSidePagination\n ? sortedData.length\n : Math.min(startIndex + resultsPerPage, sortedData.length);\n const currentPageData = sortedData.slice(startIndex, endIndex);\n\n return (\n <Col className={\"w-full h-full\"} gap={\"x16\"}>\n {currentPageData.map((data, index) => (\n <CardTable\n columns={columns}\n key={index}\n data={data}\n sortConfig={sortConfig}\n onSortChange={onSortChange}\n />\n ))}\n\n {pagination && (\n <TableMobilePagination\n currentPage={currentPage}\n totalResults={totalResults || sortedData.length}\n resultsPerPage={resultsPerPage}\n setCurrentPage={handleSetCurrentPage}\n onPageChange={onPageChange}\n serverSide={serverSidePagination}\n totalItems={totalItems}\n hasNextPage={hasNextPage}\n hasPreviousPage={hasPreviousPage}\n onNextPage={onNextPage}\n onPreviousPage={onPreviousPage}\n currentResultsPerPage={\n serverSidePagination ? sortedData.length : resultsPerPage\n }\n className=\"mt-x16\"\n />\n )}\n </Col>\n );\n};\n\nexport type CardTableProps = {\n columns: ColumnConfig[];\n data: TableRowData;\n sortConfig: { key: string; direction: \"asc\" | \"desc\" } | null;\n onSortChange?: (key: string, direction: \"asc\" | \"desc\") => void;\n};\n\nconst ActionContent: React.FC<{ data: ActionData }> = ({ data }) => {\n if (data.type === \"link\" && data.link) {\n return (\n <a href={data.link} aria-label={data.ariaLabel}>\n {data.label}\n </a>\n );\n }\n return (\n <button onClick={data.action} aria-label={data.ariaLabel}>\n {data.label}\n </button>\n );\n};\n\nexport const CardTable = ({\n columns,\n sortConfig,\n data,\n onSortChange,\n}: CardTableProps) => {\n const renderColumnValue = (value: any): ReactNode => {\n if (!value) return \"\";\n\n if (typeof value === \"object\" && \"firstLine\" in value) {\n const doubleLineValue = value as DoubleLineData;\n return `${doubleLineValue.firstLine}${doubleLineValue.secondLine ? ` ${doubleLineValue.secondLine}` : \"\"}`;\n }\n\n if (typeof value === \"object\" && \"label\" in value && \"type\" in value) {\n return <ActionContent data={value} />;\n }\n\n return value;\n };\n\n const renderIcon = (icon: React.ReactNode | CommonIconsType) => {\n switch (icon) {\n case \"info\":\n return <Info />;\n case \"download\":\n return <Download />;\n default:\n return icon;\n }\n };\n\n const handleSortClick = (key: string) => {\n if (!onSortChange || !sortConfig) return;\n\n const newDirection =\n sortConfig.key === key\n ? sortConfig.direction === \"asc\"\n ? \"desc\"\n : \"asc\"\n : \"asc\";\n\n onSortChange(key, newDirection);\n };\n\n return (\n <div\n className={clsx(\"ui-card-table shadow br-x4 text-slate-28 fs-custom \")}\n >\n {columns.map((column, index) => {\n if (!column.key || column.key === \"actionData\") {\n return (\n <Row\n key={index}\n p={\"x16\"}\n className={\"ui-table-header\"}\n justifyContent={\"space-between\"}\n >\n <Col justifyContent={\"end\"} gap={\"x4\"} className={\"w-full\"}>\n <Row justifyContent={\"end\"} className=\"table-mobile-actions\">\n {renderColumnValue(data.actionData)}\n </Row>\n </Col>\n </Row>\n );\n }\n\n const columnValue = data[column.key];\n const config = column;\n const isSorted = sortConfig?.key === column.key;\n const sortDirection = isSorted ? sortConfig.direction : null;\n\n return (\n <Row\n key={index}\n p={\"x16\"}\n className={\"ui-table-header\"}\n justifyContent={\"space-between\"}\n >\n <Col justifyContent={\"center\"} gap={\"x4\"} className={\"w-full\"}>\n <ActionIconText\n justifyContent={\"space-between\"}\n alignItems={\"center\"}\n icon={renderIcon(config.icon)}\n noIcon={!renderIcon(config.icon)}\n textLabel={config.label}\n iconPosition={config.iconPosition}\n popupInfo={config.popupInfo}\n positionPopUp={\"left\"}\n classNameText={\"fw-bold text-slate-28 fs-custom md-fs-6\"}\n >\n {config.sortable && (\n <span\n className=\"sort-indicator\"\n onClick={(e) => {\n e.stopPropagation();\n handleSortClick(column.key!);\n }}\n >\n <TriangleUp\n filled={isSorted && sortDirection === \"desc\"}\n className={clsx(\"sort-indicator__triangle\", {\n active: isSorted && sortDirection === \"desc\",\n })}\n />\n <TriangleDown\n filled={isSorted && sortDirection === \"asc\"}\n className={clsx(\"sort-indicator__triangle\", {\n active: isSorted && sortDirection === \"asc\",\n })}\n />\n </span>\n )}\n </ActionIconText>\n <Row>{renderColumnValue(columnValue)}</Row>\n </Col>\n </Row>\n );\n })}\n </div>\n );\n};\n\nexport type TableMobilePaginationProps = {\n currentPage?: number;\n totalResults?: number;\n resultsPerPage: number;\n setCurrentPage?: (page: number) => void;\n onPageChange?: (page: number) => void;\n className?: string;\n serverSide?: boolean;\n totalItems?: number;\n hasNextPage?: boolean;\n hasPreviousPage?: boolean;\n onNextPage?: () => void;\n onPreviousPage?: () => void;\n currentResultsPerPage?: number;\n};\n\nexport const TableMobilePagination: React.FC<TableMobilePaginationProps> = ({\n currentPage = 1,\n totalResults = 0,\n resultsPerPage,\n setCurrentPage,\n onPageChange,\n className,\n serverSide = false,\n totalItems,\n hasNextPage,\n hasPreviousPage,\n onNextPage,\n onPreviousPage,\n currentResultsPerPage = resultsPerPage,\n}) => {\n const totalPages = serverSide\n ? Math.ceil((totalItems || totalResults) / resultsPerPage)\n : Math.ceil(totalResults / resultsPerPage);\n\n const handlePageChange = (page: number) => {\n setCurrentPage?.(page);\n if (onPageChange) {\n onPageChange(page);\n }\n };\n\n const handleNextPage = () => {\n const nextPage = currentPage + 1;\n if (serverSide && onNextPage) {\n onNextPage();\n }\n handlePageChange(nextPage);\n };\n\n const handlePreviousPage = () => {\n const prevPage = currentPage - 1;\n if (serverSide && onPreviousPage) {\n onPreviousPage();\n }\n handlePageChange(prevPage);\n };\n\n const isNextDisabled = serverSide ? !hasNextPage : currentPage === totalPages;\n const isPrevDisabled = serverSide ? !hasPreviousPage : currentPage === 1;\n\n const getPageNumbers = () => {\n const pages = [];\n const maxVisiblePages = 5;\n\n if (totalPages <= maxVisiblePages) {\n for (let i = 1; i <= totalPages; i++) {\n pages.push(i);\n }\n } else {\n pages.push(1);\n\n let start = Math.max(2, currentPage - 1);\n let end = Math.min(totalPages - 1, currentPage + 1);\n\n if (currentPage <= 3) {\n end = 4;\n } else if (currentPage >= totalPages - 2) {\n start = totalPages - 3;\n }\n\n if (start > 2) {\n pages.push(\"...\");\n }\n\n for (let i = start; i <= end; i++) {\n pages.push(i);\n }\n\n if (end < totalPages - 1) {\n pages.push(\"...\");\n }\n\n pages.push(totalPages);\n }\n\n return pages;\n };\n\n return (\n <div className={clsx(\"pagination\", className)}>\n <div className=\"pagination__info\">\n Stai visualizzando{\" \"}\n <span className=\"pagination__info__resultsPerPage\">\n {serverSide\n ? currentResultsPerPage\n : currentPage === totalPages && totalResults % resultsPerPage !== 0\n ? totalResults % resultsPerPage\n : resultsPerPage}\n </span>{\" \"}\n di {serverSide ? totalItems || totalResults : totalResults} risultati\n </div>\n <div className=\"pagination__nav\">\n <button\n className={clsx(\n \"pagination__button\",\n isPrevDisabled && \"pagination__button--disabled\",\n )}\n onClick={handlePreviousPage}\n disabled={isPrevDisabled}\n aria-label=\"Previous page\"\n >\n <svg className=\"pagination__button-arrow\" viewBox=\"0 0 24 24\">\n <path d=\"M15 18l-6-6 6-6\" />\n </svg>\n </button>\n\n {getPageNumbers().map((page, index) =>\n page === \"...\" ? (\n <span key={`ellipsis-${index}`} className=\"pagination__ellipsis\">\n ...\n </span>\n ) : (\n <button\n key={page}\n className={clsx(\n \"pagination__button\",\n currentPage === page && \"pagination__button--active\",\n )}\n onClick={() => handlePageChange(page as number)}\n disabled={page === currentPage}\n >\n {page}\n </button>\n ),\n )}\n\n <button\n className={clsx(\n \"pagination__button\",\n isNextDisabled && \"pagination__button--disabled\",\n )}\n onClick={handleNextPage}\n disabled={isNextDisabled}\n aria-label=\"Next page\"\n >\n <svg className=\"pagination__button-arrow\" viewBox=\"0 0 24 24\">\n <path d=\"M9 6l6 6-6 6\" />\n </svg>\n </button>\n </div>\n </div>\n );\n};\n"],"names":["TableMobile","data","columns","pagination","resultsPerPage","totalResults","initialCurrentPage","serverSidePagination","totalItems","hasNextPage","hasPreviousPage","onNextPage","onPreviousPage","onPageChange","externalSetCurrentPage","sortConfig","onSortChange","currentPage","setInternalCurrentPage","useState","handleSetCurrentPage","page","sortedData","React","a","b","aValue","bValue","aText","bText","startIndex","endIndex","currentPageData","jsxs","Col","index","jsx","CardTable","TableMobilePagination","ActionContent","renderColumnValue","value","doubleLineValue","renderIcon","icon","Info","Download","handleSortClick","key","newDirection","clsx","column","Row","columnValue","config","isSorted","sortDirection","ActionIconText","e","TriangleUp","TriangleDown","setCurrentPage","className","serverSide","currentResultsPerPage","totalPages","handlePageChange","handleNextPage","nextPage","handlePreviousPage","prevPage","isNextDisabled","isPrevDisabled","getPageNumbers","pages","i","start","end"],"mappings":"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"}
1
+ {"version":3,"file":"index.es74.js","sources":["../src/components/ui/TableMobile/index.tsx"],"sourcesContent":["import {\n ActionData,\n ActionIconText,\n Col,\n ColumnConfig,\n DoubleLineData,\n Row,\n TableRowData,\n} from \"@/components\";\nimport clsx from \"clsx\";\nimport \"./TableMobile.scss\";\nimport { Download, Info, TriangleDown, TriangleUp } from \"@/icons\";\nimport { ReactNode } from \"react\";\nimport * as React from \"react\";\nimport { CommonIconsType } from \"@/types/icons.ts\";\nimport { useState } from \"react\";\n\nexport type TableMobileProps = {\n data: TableRowData[];\n columns: ColumnConfig[];\n pagination?: boolean;\n resultsPerPage?: number;\n totalResults?: number;\n initialCurrentPage?: number;\n serverSidePagination?: boolean;\n totalItems?: number;\n hasNextPage?: boolean;\n hasPreviousPage?: boolean;\n onNextPage?: () => void;\n onPreviousPage?: () => void;\n onPageChange?: (page: number) => void;\n setCurrentPage?: (page: number) => void;\n sortConfig?: { key: string; direction: \"asc\" | \"desc\" } | null;\n onSortChange?: (key: string, direction: \"asc\" | \"desc\") => void;\n};\n\nexport const TableMobile = ({\n data,\n columns,\n pagination = true,\n resultsPerPage = 5,\n totalResults,\n initialCurrentPage = 1,\n serverSidePagination = false,\n totalItems,\n hasNextPage,\n hasPreviousPage,\n onNextPage,\n onPreviousPage,\n onPageChange,\n setCurrentPage: externalSetCurrentPage,\n sortConfig = null,\n onSortChange,\n}: TableMobileProps) => {\n const [currentPage, setInternalCurrentPage] = useState(initialCurrentPage);\n const handleSetCurrentPage = (page: number) => {\n setInternalCurrentPage(page);\n externalSetCurrentPage?.(page);\n };\n\n const sortedData = React.useMemo(() => {\n if (!sortConfig) return data;\n\n return [...data].sort((a, b) => {\n const aValue = a[sortConfig.key];\n const bValue = b[sortConfig.key];\n\n const aText =\n typeof aValue === \"object\" && \"firstLine\" in aValue\n ? aValue.firstLine\n : aValue;\n const bText =\n typeof bValue === \"object\" && \"firstLine\" in bValue\n ? bValue.firstLine\n : bValue;\n\n if (aText < bText) {\n return sortConfig.direction === \"asc\" ? -1 : 1;\n }\n if (aText > bText) {\n return sortConfig.direction === \"asc\" ? 1 : -1;\n }\n return 0;\n });\n }, [data, sortConfig]);\n\n const startIndex = serverSidePagination\n ? 0\n : (currentPage - 1) * resultsPerPage;\n const endIndex = serverSidePagination\n ? sortedData.length\n : Math.min(startIndex + resultsPerPage, sortedData.length);\n const currentPageData = sortedData.slice(startIndex, endIndex);\n\n return (\n <Col className={\"w-full h-full\"} gap={\"x16\"}>\n {currentPageData.map((data, index) => (\n <CardTable\n columns={columns}\n key={index}\n data={data}\n sortConfig={sortConfig}\n onSortChange={onSortChange}\n />\n ))}\n\n {pagination && (\n <TableMobilePagination\n currentPage={currentPage}\n totalResults={totalResults || sortedData.length}\n resultsPerPage={resultsPerPage}\n setCurrentPage={handleSetCurrentPage}\n onPageChange={onPageChange}\n serverSide={serverSidePagination}\n totalItems={totalItems}\n hasNextPage={hasNextPage}\n hasPreviousPage={hasPreviousPage}\n onNextPage={onNextPage}\n onPreviousPage={onPreviousPage}\n currentResultsPerPage={\n serverSidePagination ? sortedData.length : resultsPerPage\n }\n className=\"mt-x16\"\n />\n )}\n </Col>\n );\n};\n\nexport type CardTableProps = {\n columns: ColumnConfig[];\n data: TableRowData;\n sortConfig: { key: string; direction: \"asc\" | \"desc\" } | null;\n onSortChange?: (key: string, direction: \"asc\" | \"desc\") => void;\n};\n\nconst ActionContent: React.FC<{ data: ActionData }> = ({ data }) => {\n if (data.type === \"link\" && data.link) {\n return (\n <a href={data.link} aria-label={data.ariaLabel}>\n {data.label}\n </a>\n );\n }\n return (\n <button onClick={data.action} aria-label={data.ariaLabel}>\n {data.label}\n </button>\n );\n};\n\nexport const CardTable = ({\n columns,\n sortConfig,\n data,\n onSortChange,\n}: CardTableProps) => {\n const renderColumnValue = (value: any): ReactNode => {\n if (!value) return \"\";\n\n if (typeof value === \"object\" && \"firstLine\" in value) {\n const doubleLineValue = value as DoubleLineData;\n return `${doubleLineValue.firstLine}${doubleLineValue.secondLine ? ` ${doubleLineValue.secondLine}` : \"\"}`;\n }\n\n if (typeof value === \"object\" && \"label\" in value && \"type\" in value) {\n return <ActionContent data={value} />;\n }\n\n return value;\n };\n\n const renderIcon = (icon: React.ReactNode | CommonIconsType) => {\n switch (icon) {\n case \"info\":\n return <Info />;\n case \"download\":\n return <Download />;\n default:\n return icon;\n }\n };\n\n const handleSortClick = (key: string) => {\n if (!onSortChange || !sortConfig) return;\n\n const newDirection =\n sortConfig.key === key\n ? sortConfig.direction === \"asc\"\n ? \"desc\"\n : \"asc\"\n : \"asc\";\n\n onSortChange(key, newDirection);\n };\n\n return (\n <div\n className={clsx(\"ui-card-table shadow br-x4 text-slate-28 fs-custom \")}\n >\n {columns.map((column, index) => {\n if (!column.key || column.key === \"actionData\") {\n return (\n <Row\n key={index}\n p={\"x16\"}\n className={\"ui-table-header\"}\n justifyContent={\"space-between\"}\n >\n <Col justifyContent={\"end\"} gap={\"x4\"} className={\"w-full\"}>\n <Row justifyContent={\"end\"} className=\"table-mobile-actions\">\n {renderColumnValue(data.actionData)}\n </Row>\n </Col>\n </Row>\n );\n }\n\n const columnValue = data[column.key];\n const config = column;\n const isSorted = sortConfig?.key === column.key;\n const sortDirection = isSorted ? sortConfig.direction : null;\n\n return (\n <Row\n key={index}\n p={\"x16\"}\n className={\"ui-table-header\"}\n justifyContent={\"space-between\"}\n >\n <Col justifyContent={\"center\"} gap={\"x4\"} className={\"w-full\"}>\n <ActionIconText\n justifyContent={\"space-between\"}\n alignItems={\"center\"}\n icon={renderIcon(config.icon)}\n noIcon={!renderIcon(config.icon)}\n textLabel={config.label}\n iconPosition={config.iconPosition}\n popupInfo={config.popupInfo}\n positionPopUp={\"left\"}\n classNameText={\"fw-bold text-slate-28 fs-custom md-fs-6\"}\n >\n {config.sortable && (\n <span\n className=\"sort-indicator\"\n onClick={(e) => {\n e.stopPropagation();\n handleSortClick(column.key!);\n }}\n >\n <TriangleUp\n filled={isSorted && sortDirection === \"desc\"}\n className={clsx(\"sort-indicator__triangle\", {\n active: isSorted && sortDirection === \"desc\",\n })}\n />\n <TriangleDown\n filled={isSorted && sortDirection === \"asc\"}\n className={clsx(\"sort-indicator__triangle\", {\n active: isSorted && sortDirection === \"asc\",\n })}\n />\n </span>\n )}\n </ActionIconText>\n <Row>{renderColumnValue(columnValue)}</Row>\n </Col>\n </Row>\n );\n })}\n </div>\n );\n};\n\nexport type TableMobilePaginationProps = {\n currentPage?: number;\n totalResults?: number;\n resultsPerPage: number;\n setCurrentPage?: (page: number) => void;\n onPageChange?: (page: number) => void;\n className?: string;\n serverSide?: boolean;\n totalItems?: number;\n hasNextPage?: boolean;\n hasPreviousPage?: boolean;\n onNextPage?: () => void;\n onPreviousPage?: () => void;\n currentResultsPerPage?: number;\n};\n\nexport const TableMobilePagination: React.FC<TableMobilePaginationProps> = ({\n currentPage = 1,\n totalResults = 0,\n resultsPerPage,\n setCurrentPage,\n onPageChange,\n className,\n serverSide = false,\n totalItems,\n hasNextPage,\n hasPreviousPage,\n onNextPage,\n onPreviousPage,\n currentResultsPerPage = resultsPerPage,\n}) => {\n const totalPages = serverSide\n ? Math.ceil((totalItems || totalResults) / resultsPerPage)\n : Math.ceil(totalResults / resultsPerPage);\n\n const handlePageChange = (page: number) => {\n setCurrentPage?.(page);\n if (onPageChange) {\n onPageChange(page);\n }\n };\n\n const handleNextPage = () => {\n const nextPage = currentPage + 1;\n if (serverSide && onNextPage) {\n onNextPage();\n }\n handlePageChange(nextPage);\n };\n\n const handlePreviousPage = () => {\n const prevPage = currentPage - 1;\n if (serverSide && onPreviousPage) {\n onPreviousPage();\n }\n handlePageChange(prevPage);\n };\n\n const isNextDisabled = serverSide ? !hasNextPage : currentPage === totalPages;\n const isPrevDisabled = serverSide ? !hasPreviousPage : currentPage === 1;\n\n const getPageNumbers = () => {\n const pages = [];\n const maxVisiblePages = 5;\n\n if (totalPages <= maxVisiblePages) {\n for (let i = 1; i <= totalPages; i++) {\n pages.push(i);\n }\n } else {\n pages.push(1);\n\n let start = Math.max(2, currentPage - 1);\n let end = Math.min(totalPages - 1, currentPage + 1);\n\n if (currentPage <= 3) {\n end = 4;\n } else if (currentPage >= totalPages - 2) {\n start = totalPages - 3;\n }\n\n if (start > 2) {\n pages.push(\"...\");\n }\n\n for (let i = start; i <= end; i++) {\n pages.push(i);\n }\n\n if (end < totalPages - 1) {\n pages.push(\"...\");\n }\n\n pages.push(totalPages);\n }\n\n return pages;\n };\n\n return (\n <div className={clsx(\"pagination-mobile\", className)}>\n <div className=\"pagination-mobile__info\">\n Stai visualizzando{\" \"}\n <span className=\"pagination-mobile__info__resultsPerPage\">\n {serverSide\n ? currentResultsPerPage\n : currentPage === totalPages && totalResults % resultsPerPage !== 0\n ? totalResults % resultsPerPage\n : resultsPerPage}\n </span>{\" \"}\n di {serverSide ? totalItems || totalResults : totalResults} risultati\n </div>\n <div className=\"pagination-mobile__nav\">\n <button\n className={clsx(\n \"pagination-mobile__button\",\n isPrevDisabled && \"pagination-mobile__button--disabled\",\n )}\n onClick={handlePreviousPage}\n disabled={isPrevDisabled}\n aria-label=\"Previous page\"\n >\n <svg className=\"pagination-mobile__button-arrow\" viewBox=\"0 0 24 24\">\n <path d=\"M15 18l-6-6 6-6\" />\n </svg>\n </button>\n\n {getPageNumbers().map((page, index) =>\n page === \"...\" ? (\n <span key={`ellipsis-${index}`} className=\"pagination-mobile__ellipsis\">\n ...\n </span>\n ) : (\n <button\n key={page}\n className={clsx(\n \"pagination-mobile__button\",\n currentPage === page && \"pagination-mobile__button--active\",\n )}\n onClick={() => handlePageChange(page as number)}\n disabled={page === currentPage}\n >\n {page}\n </button>\n ),\n )}\n\n <button\n className={clsx(\n \"pagination-mobile__button\",\n isNextDisabled && \"pagination-mobile__button--disabled\",\n )}\n onClick={handleNextPage}\n disabled={isNextDisabled}\n aria-label=\"Next page\"\n >\n <svg className=\"pagination-mobile__button-arrow\" viewBox=\"0 0 24 24\">\n <path d=\"M9 6l6 6-6 6\" />\n </svg>\n </button>\n </div>\n </div>\n );\n};\n"],"names":["TableMobile","data","columns","pagination","resultsPerPage","totalResults","initialCurrentPage","serverSidePagination","totalItems","hasNextPage","hasPreviousPage","onNextPage","onPreviousPage","onPageChange","externalSetCurrentPage","sortConfig","onSortChange","currentPage","setInternalCurrentPage","useState","handleSetCurrentPage","page","sortedData","React","a","b","aValue","bValue","aText","bText","startIndex","endIndex","currentPageData","jsxs","Col","index","jsx","CardTable","TableMobilePagination","ActionContent","renderColumnValue","value","doubleLineValue","renderIcon","icon","Info","Download","handleSortClick","key","newDirection","clsx","column","Row","columnValue","config","isSorted","sortDirection","ActionIconText","e","TriangleUp","TriangleDown","setCurrentPage","className","serverSide","currentResultsPerPage","totalPages","handlePageChange","handleNextPage","nextPage","handlePreviousPage","prevPage","isNextDisabled","isPrevDisabled","getPageNumbers","pages","i","start","end"],"mappings":"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"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@anoki/fse-ui",
3
- "version": "1.0.0-beta1.45.3",
3
+ "version": "1.0.0-beta1.45.4",
4
4
  "description": "FSE UI components library",
5
5
  "type": "module",
6
6
  "main": "dist/index.cjs.js",