@carto/ps-react-ui 4.11.3 → 4.12.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/chat.js +962 -733
- package/dist/chat.js.map +1 -1
- package/dist/csv-item-hH_Gt7ur.js +32 -0
- package/dist/csv-item-hH_Gt7ur.js.map +1 -0
- package/dist/{echart-BMPpj7n_.js → echart-Bdvbfx9s.js} +2 -2
- package/dist/echart-Bdvbfx9s.js.map +1 -0
- package/dist/{option-builders-F-c9ELi1.js → option-builders-DPeoyQaM.js} +41 -33
- package/dist/option-builders-DPeoyQaM.js.map +1 -0
- package/dist/png-item-9dNbB37T.js +57 -0
- package/dist/png-item-9dNbB37T.js.map +1 -0
- package/dist/table-B3ZWWhJt.js +383 -0
- package/dist/table-B3ZWWhJt.js.map +1 -0
- package/dist/types/chat/containers/chat-footer.d.ts +1 -1
- package/dist/types/chat/containers/styles.d.ts +79 -12
- package/dist/types/chat/index.d.ts +1 -1
- package/dist/types/chat/types.d.ts +21 -0
- package/dist/types/chat/use-typewriter.d.ts +5 -3
- package/dist/types/widgets/utils/chart-config/index.d.ts +1 -1
- package/dist/types/widgets-v2/actions/download/constants.d.ts +12 -0
- package/dist/types/widgets-v2/actions/download/csv-item.d.ts +38 -0
- package/dist/types/widgets-v2/actions/download/icons.d.ts +6 -0
- package/dist/types/widgets-v2/actions/download/index.d.ts +3 -1
- package/dist/types/widgets-v2/actions/index.d.ts +1 -1
- package/dist/types/widgets-v2/pie/skeleton.d.ts +9 -0
- package/dist/widgets/bar.js +1 -1
- package/dist/widgets/histogram.js +1 -1
- package/dist/widgets/pie.js +1 -1
- package/dist/widgets/scatterplot.js +5 -5
- package/dist/widgets/timeseries.js +1 -1
- package/dist/widgets/utils.js +1 -1
- package/dist/widgets-v2/actions.js +40 -36
- package/dist/widgets-v2/actions.js.map +1 -1
- package/dist/widgets-v2/bar.js +69 -76
- package/dist/widgets-v2/bar.js.map +1 -1
- package/dist/widgets-v2/category.js +50 -55
- package/dist/widgets-v2/category.js.map +1 -1
- package/dist/widgets-v2/echart.js +1 -1
- package/dist/widgets-v2/formula.js +37 -43
- package/dist/widgets-v2/formula.js.map +1 -1
- package/dist/widgets-v2/histogram.js +141 -147
- package/dist/widgets-v2/histogram.js.map +1 -1
- package/dist/widgets-v2/markdown.js +18 -17
- package/dist/widgets-v2/markdown.js.map +1 -1
- package/dist/widgets-v2/pie.js +174 -126
- package/dist/widgets-v2/pie.js.map +1 -1
- package/dist/widgets-v2/scatterplot.js +156 -166
- package/dist/widgets-v2/scatterplot.js.map +1 -1
- package/dist/widgets-v2/spread.js +36 -41
- package/dist/widgets-v2/spread.js.map +1 -1
- package/dist/widgets-v2/table.js +46 -55
- package/dist/widgets-v2/table.js.map +1 -1
- package/dist/widgets-v2/timeseries.js +83 -89
- package/dist/widgets-v2/timeseries.js.map +1 -1
- package/dist/widgets-v2.js +3 -3
- package/package.json +1 -1
- package/src/chat/bubbles/styles.ts +5 -1
- package/src/chat/containers/chat-content.tsx +4 -1
- package/src/chat/containers/chat-footer.test.tsx +59 -0
- package/src/chat/containers/chat-footer.tsx +124 -36
- package/src/chat/containers/styles.ts +107 -16
- package/src/chat/feedback/styles.ts +11 -4
- package/src/chat/index.ts +1 -0
- package/src/chat/types.ts +22 -0
- package/src/chat/use-typewriter.ts +32 -24
- package/src/widgets/utils/chart-config/index.ts +1 -0
- package/src/widgets/utils/chart-config/option-builders.test.ts +34 -0
- package/src/widgets/utils/chart-config/option-builders.ts +21 -0
- package/src/widgets-v2/actions/download/constants.ts +14 -0
- package/src/widgets-v2/actions/download/csv-item.test.tsx +77 -0
- package/src/widgets-v2/actions/download/csv-item.tsx +71 -0
- package/src/widgets-v2/actions/download/icons.tsx +10 -1
- package/src/widgets-v2/actions/download/index.ts +3 -1
- package/src/widgets-v2/actions/download/png-item.tsx +2 -1
- package/src/widgets-v2/actions/index.ts +5 -0
- package/src/widgets-v2/bar/download.tsx +16 -22
- package/src/widgets-v2/bar/options.ts +3 -2
- package/src/widgets-v2/category/download.test.ts +9 -0
- package/src/widgets-v2/category/download.ts +16 -20
- package/src/widgets-v2/echart/edge-label-clamp.ts +7 -4
- package/src/widgets-v2/formula/download.tsx +23 -29
- package/src/widgets-v2/histogram/download.ts +22 -26
- package/src/widgets-v2/histogram/options.ts +3 -2
- package/src/widgets-v2/markdown/{download.ts → download.tsx} +5 -2
- package/src/widgets-v2/pie/download.ts +16 -20
- package/src/widgets-v2/pie/skeleton.test.tsx +6 -3
- package/src/widgets-v2/pie/skeleton.tsx +69 -7
- package/src/widgets-v2/scatterplot/download.ts +16 -20
- package/src/widgets-v2/scatterplot/options.ts +3 -6
- package/src/widgets-v2/spread/download.ts +23 -27
- package/src/widgets-v2/table/download.test.ts +10 -0
- package/src/widgets-v2/table/download.ts +11 -15
- package/src/widgets-v2/table/helpers.test.ts +19 -0
- package/src/widgets-v2/table/helpers.ts +7 -12
- package/src/widgets-v2/timeseries/download.ts +36 -40
- package/src/widgets-v2/timeseries/options.ts +3 -2
- package/dist/echart-BMPpj7n_.js.map +0 -1
- package/dist/option-builders-F-c9ELi1.js.map +0 -1
- package/dist/png-item-BE9uEqlD.js +0 -45
- package/dist/png-item-BE9uEqlD.js.map +0 -1
- package/dist/table-C9IMbTr0.js +0 -385
- package/dist/table-C9IMbTr0.js.map +0 -1
- package/dist/types/chat/feedback/styles.d.ts +0 -211
- package/dist/types/widgets/utils/chart-config/option-builders.d.ts +0 -124
|
@@ -0,0 +1,383 @@
|
|
|
1
|
+
import { jsxs as ee, Fragment as me, jsx as d } from "react/jsx-runtime";
|
|
2
|
+
import { c as he } from "react/compiler-runtime";
|
|
3
|
+
import "react";
|
|
4
|
+
import { u as Se } from "./widget-context-DTGO0Yta.js";
|
|
5
|
+
import { v as be, u as ye, i as fe } from "./widget-store-registry-_W4Z4xp-.js";
|
|
6
|
+
import "zustand";
|
|
7
|
+
import { Box as pe, TableCell as oe, Checkbox as ue, TableRow as ge, TablePagination as Ce, TableSortLabel as Pe, TableHead as we, TableBody as xe, TableContainer as ze, Table as Ae, IconButton as se } from "@mui/material";
|
|
8
|
+
import { FirstPage as ke, KeyboardArrowLeft as Te, KeyboardArrowRight as Re, LastPage as Ie } from "@mui/icons-material";
|
|
9
|
+
import "./lasso-tool-CDFj4zKY.js";
|
|
10
|
+
import "./cjs-D4KH3azB.js";
|
|
11
|
+
import "@carto/ps-utils";
|
|
12
|
+
import { t as Oe } from "./exports-Cx-f6m6U.js";
|
|
13
|
+
const ve = {
|
|
14
|
+
fontWeight: 600,
|
|
15
|
+
color: "text.primary"
|
|
16
|
+
}, Ee = {
|
|
17
|
+
selectAll: "Select all rows",
|
|
18
|
+
selectRow: (t) => `Select row ${t}`,
|
|
19
|
+
rowsPerPage: "Rows per page:",
|
|
20
|
+
paginationOf: (t, e, i) => /* @__PURE__ */ ee(me, { children: [
|
|
21
|
+
/* @__PURE__ */ d(pe, { component: "span", sx: ve, children: `${t}–${e}` }),
|
|
22
|
+
` of ${i}`
|
|
23
|
+
] }),
|
|
24
|
+
firstPage: "First page",
|
|
25
|
+
previousPage: "Previous page",
|
|
26
|
+
nextPage: "Next page",
|
|
27
|
+
lastPage: "Last page"
|
|
28
|
+
}, Le = 10, De = [10, 25, 50, 100], D = {
|
|
29
|
+
container: {
|
|
30
|
+
width: "100%",
|
|
31
|
+
overflowX: "auto"
|
|
32
|
+
},
|
|
33
|
+
table: {
|
|
34
|
+
minWidth: 0
|
|
35
|
+
},
|
|
36
|
+
headerCell: {
|
|
37
|
+
fontWeight: 600,
|
|
38
|
+
backgroundColor: "background.paper"
|
|
39
|
+
},
|
|
40
|
+
/**
|
|
41
|
+
* Strip the bottom border from the last body row so the body flushes
|
|
42
|
+
* against the pagination border instead of doubling it up. Mirrors v1.
|
|
43
|
+
*/
|
|
44
|
+
row: {
|
|
45
|
+
"&:last-child td, &:last-child th": {
|
|
46
|
+
border: 0
|
|
47
|
+
}
|
|
48
|
+
},
|
|
49
|
+
rowClickable: {
|
|
50
|
+
cursor: "pointer"
|
|
51
|
+
},
|
|
52
|
+
pagination: {
|
|
53
|
+
borderTop: "1px solid",
|
|
54
|
+
borderColor: "divider"
|
|
55
|
+
},
|
|
56
|
+
paginationActions: {
|
|
57
|
+
display: "flex",
|
|
58
|
+
alignItems: "center",
|
|
59
|
+
gap: 0.25,
|
|
60
|
+
ml: 1
|
|
61
|
+
},
|
|
62
|
+
empty: {
|
|
63
|
+
textAlign: "center",
|
|
64
|
+
color: "text.secondary",
|
|
65
|
+
py: 3
|
|
66
|
+
}
|
|
67
|
+
};
|
|
68
|
+
function $e(t) {
|
|
69
|
+
const e = he(82), {
|
|
70
|
+
columns: i,
|
|
71
|
+
rows: o,
|
|
72
|
+
total: f,
|
|
73
|
+
page: s,
|
|
74
|
+
pageSize: g,
|
|
75
|
+
pageSizeOptions: p,
|
|
76
|
+
sort: c,
|
|
77
|
+
keyColumn: M,
|
|
78
|
+
selection: u,
|
|
79
|
+
selectable: $,
|
|
80
|
+
onSortChange: b,
|
|
81
|
+
onPageChange: T,
|
|
82
|
+
onPageSizeChange: w,
|
|
83
|
+
onSelectionChange: C,
|
|
84
|
+
onRowClick: V,
|
|
85
|
+
onRowHover: m,
|
|
86
|
+
labels: R,
|
|
87
|
+
emptyContent: N,
|
|
88
|
+
size: a
|
|
89
|
+
} = t, O = p === void 0 ? De : p, v = M === void 0 ? "id" : M, x = $ === void 0 ? !1 : $;
|
|
90
|
+
process.env.NODE_ENV !== "production" && o.some((r) => r[v] == null) && console.error(`<TableUI>: rows are missing the identity column \`${v}\`. Set the \`keyColumn\` prop to a column present on every row, or add the column to the data.`);
|
|
91
|
+
let B;
|
|
92
|
+
e[0] !== R ? (B = {
|
|
93
|
+
...Ee,
|
|
94
|
+
...R
|
|
95
|
+
}, e[0] = R, e[1] = B) : B = e[1];
|
|
96
|
+
const h = B, _ = Math.min(...O), H = f > _;
|
|
97
|
+
let E;
|
|
98
|
+
e[2] !== h ? (E = Be(h), e[2] = h, e[3] = E) : E = e[3];
|
|
99
|
+
const U = E;
|
|
100
|
+
let z;
|
|
101
|
+
e[4] !== u ? (z = u ?? [], e[4] = u, e[5] = z) : z = e[5];
|
|
102
|
+
let W;
|
|
103
|
+
e[6] !== z ? (W = new Set(z), e[6] = z, e[7] = W) : W = e[7];
|
|
104
|
+
const y = W;
|
|
105
|
+
let l;
|
|
106
|
+
e[8] !== v ? (l = (n, r) => n[v] ?? r, e[8] = v, e[9] = l) : l = e[9];
|
|
107
|
+
const I = l;
|
|
108
|
+
let j;
|
|
109
|
+
e[10] !== I || e[11] !== o ? (j = o.map(I), e[10] = I, e[11] = o, e[12] = j) : j = e[12];
|
|
110
|
+
const S = j;
|
|
111
|
+
let A;
|
|
112
|
+
e[13] !== S || e[14] !== y ? (A = S.length > 0 && S.every((n) => y.has(n)), e[13] = S, e[14] = y, e[15] = A) : A = e[15];
|
|
113
|
+
const P = A;
|
|
114
|
+
let L;
|
|
115
|
+
e[16] !== P || e[17] !== S || e[18] !== y ? (L = !P && S.some((n) => y.has(n)), e[16] = P, e[17] = S, e[18] = y, e[19] = L) : L = e[19];
|
|
116
|
+
const ae = L;
|
|
117
|
+
let ne;
|
|
118
|
+
e[20] !== b || e[21] !== c?.columnId || e[22] !== c?.direction ? (ne = (n) => {
|
|
119
|
+
if (!b)
|
|
120
|
+
return;
|
|
121
|
+
const k = c?.columnId === n && c?.direction === "asc" ? "desc" : "asc";
|
|
122
|
+
b({
|
|
123
|
+
columnId: n,
|
|
124
|
+
direction: k
|
|
125
|
+
});
|
|
126
|
+
}, e[20] = b, e[21] = c?.columnId, e[22] = c?.direction, e[23] = ne) : ne = e[23];
|
|
127
|
+
const te = ne;
|
|
128
|
+
let ie;
|
|
129
|
+
e[24] !== P || e[25] !== C || e[26] !== S || e[27] !== u ? (ie = () => {
|
|
130
|
+
if (C)
|
|
131
|
+
if (P)
|
|
132
|
+
C((u ?? []).filter((n) => !S.includes(n)));
|
|
133
|
+
else {
|
|
134
|
+
const n = new Set(u ?? []);
|
|
135
|
+
for (const r of S)
|
|
136
|
+
n.add(r);
|
|
137
|
+
C([...n]);
|
|
138
|
+
}
|
|
139
|
+
}, e[24] = P, e[25] = C, e[26] = S, e[27] = u, e[28] = ie) : ie = e[28];
|
|
140
|
+
const ce = ie;
|
|
141
|
+
let re;
|
|
142
|
+
e[29] !== C || e[30] !== u ? (re = (n) => {
|
|
143
|
+
if (!C)
|
|
144
|
+
return;
|
|
145
|
+
const r = new Set(u ?? []);
|
|
146
|
+
r.has(n) ? r.delete(n) : r.add(n), C([...r]);
|
|
147
|
+
}, e[29] = C, e[30] = u, e[31] = re) : re = e[31];
|
|
148
|
+
const de = re;
|
|
149
|
+
let G;
|
|
150
|
+
e[32] !== h || e[33] !== P || e[34] !== ce || e[35] !== x || e[36] !== ae ? (G = x ? /* @__PURE__ */ d(oe, { padding: "checkbox", sx: D.headerCell, children: /* @__PURE__ */ d(ue, { checked: P, indeterminate: ae, onChange: ce, inputProps: {
|
|
151
|
+
"aria-label": h.selectAll
|
|
152
|
+
} }) }) : null, e[32] = h, e[33] = P, e[34] = ce, e[35] = x, e[36] = ae, e[37] = G) : G = e[37];
|
|
153
|
+
let K;
|
|
154
|
+
if (e[38] !== i || e[39] !== te || e[40] !== b || e[41] !== c?.columnId || e[42] !== c?.direction) {
|
|
155
|
+
let n;
|
|
156
|
+
e[44] !== te || e[45] !== b || e[46] !== c?.columnId || e[47] !== c?.direction ? (n = (r) => {
|
|
157
|
+
const k = c?.columnId === r.id, J = k ? c?.direction : void 0;
|
|
158
|
+
return /* @__PURE__ */ d(oe, { align: r.align, sortDirection: J, sx: D.headerCell, style: r.width != null ? {
|
|
159
|
+
width: r.width
|
|
160
|
+
} : void 0, children: r.sortable && b ? /* @__PURE__ */ d(Pe, { active: k, direction: J ?? "asc", onClick: () => te(r.id), children: r.label }) : r.label }, r.id);
|
|
161
|
+
}, e[44] = te, e[45] = b, e[46] = c?.columnId, e[47] = c?.direction, e[48] = n) : n = e[48], K = i.map(n), e[38] = i, e[39] = te, e[40] = b, e[41] = c?.columnId, e[42] = c?.direction, e[43] = K;
|
|
162
|
+
} else
|
|
163
|
+
K = e[43];
|
|
164
|
+
let Z;
|
|
165
|
+
e[49] !== G || e[50] !== K ? (Z = /* @__PURE__ */ d(we, { children: /* @__PURE__ */ ee(ge, { children: [
|
|
166
|
+
G,
|
|
167
|
+
K
|
|
168
|
+
] }) }), e[49] = G, e[50] = K, e[51] = Z) : Z = e[51];
|
|
169
|
+
let X;
|
|
170
|
+
e[52] !== h || e[53] !== i || e[54] !== N || e[55] !== de || e[56] !== V || e[57] !== m || e[58] !== I || e[59] !== o || e[60] !== x || e[61] !== y ? (X = o.length === 0 ? /* @__PURE__ */ d(ge, { children: /* @__PURE__ */ d(oe, { colSpan: i.length + (x ? 1 : 0), sx: D.empty, children: N ?? null }) }) : o.map((n, r) => {
|
|
171
|
+
const k = I(n, r), J = y.has(k);
|
|
172
|
+
return /* @__PURE__ */ ee(ge, { hover: !0, selected: J, onClick: () => V?.(n), onMouseEnter: () => m?.(n), onMouseLeave: () => m?.(null), sx: {
|
|
173
|
+
...D.row,
|
|
174
|
+
...V ? D.rowClickable : null
|
|
175
|
+
}, children: [
|
|
176
|
+
x ? /* @__PURE__ */ d(oe, { padding: "checkbox", children: /* @__PURE__ */ d(ue, { checked: J, onClick: (F) => {
|
|
177
|
+
F.stopPropagation(), de(k);
|
|
178
|
+
}, inputProps: {
|
|
179
|
+
"aria-label": h.selectRow(k)
|
|
180
|
+
} }) }) : null,
|
|
181
|
+
i.map((F) => /* @__PURE__ */ d(oe, { align: F.align, children: F.formatter ? F.formatter(n[F.id], n) : Ne(n[F.id]) }, F.id))
|
|
182
|
+
] }, k);
|
|
183
|
+
}), e[52] = h, e[53] = i, e[54] = N, e[55] = de, e[56] = V, e[57] = m, e[58] = I, e[59] = o, e[60] = x, e[61] = y, e[62] = X) : X = e[62];
|
|
184
|
+
let q;
|
|
185
|
+
e[63] !== X ? (q = /* @__PURE__ */ d(xe, { children: X }), e[63] = X, e[64] = q) : q = e[64];
|
|
186
|
+
let Q;
|
|
187
|
+
e[65] !== a || e[66] !== Z || e[67] !== q ? (Q = /* @__PURE__ */ d(ze, { children: /* @__PURE__ */ ee(Ae, { stickyHeader: !0, size: a, sx: D.table, children: [
|
|
188
|
+
Z,
|
|
189
|
+
q
|
|
190
|
+
] }) }), e[65] = a, e[66] = Z, e[67] = q, e[68] = Q) : Q = e[68];
|
|
191
|
+
let Y;
|
|
192
|
+
e[69] !== U || e[70] !== h || e[71] !== T || e[72] !== w || e[73] !== s || e[74] !== g || e[75] !== O || e[76] !== H || e[77] !== f ? (Y = H ? /* @__PURE__ */ d(Ce, { component: "div", count: f, page: s, rowsPerPage: g, rowsPerPageOptions: [...O], onPageChange: (n, r) => T?.(r), onRowsPerPageChange: (n) => {
|
|
193
|
+
const r = parseInt(n.target.value, 10);
|
|
194
|
+
w?.(r);
|
|
195
|
+
}, labelRowsPerPage: h.rowsPerPage, labelDisplayedRows: (n) => {
|
|
196
|
+
const {
|
|
197
|
+
from: r,
|
|
198
|
+
to: k,
|
|
199
|
+
count: J
|
|
200
|
+
} = n;
|
|
201
|
+
return h.paginationOf(r, k, J);
|
|
202
|
+
}, ActionsComponent: U, sx: D.pagination }) : null, e[69] = U, e[70] = h, e[71] = T, e[72] = w, e[73] = s, e[74] = g, e[75] = O, e[76] = H, e[77] = f, e[78] = Y) : Y = e[78];
|
|
203
|
+
let le;
|
|
204
|
+
return e[79] !== Q || e[80] !== Y ? (le = /* @__PURE__ */ ee(pe, { sx: D.container, children: [
|
|
205
|
+
Q,
|
|
206
|
+
Y
|
|
207
|
+
] }), e[79] = Q, e[80] = Y, e[81] = le) : le = e[81], le;
|
|
208
|
+
}
|
|
209
|
+
function Ne(t) {
|
|
210
|
+
return t == null ? "" : typeof t == "string" || typeof t == "number" ? t : typeof t == "boolean" ? String(t) : Array.isArray(t) || typeof t == "object" ? JSON.stringify(t) : "";
|
|
211
|
+
}
|
|
212
|
+
function Be(t) {
|
|
213
|
+
return function({
|
|
214
|
+
count: i,
|
|
215
|
+
page: o,
|
|
216
|
+
rowsPerPage: f,
|
|
217
|
+
onPageChange: s
|
|
218
|
+
}) {
|
|
219
|
+
const g = Math.max(0, Math.ceil(i / f) - 1);
|
|
220
|
+
return /* @__PURE__ */ ee(pe, { sx: D.paginationActions, children: [
|
|
221
|
+
/* @__PURE__ */ d(se, { size: "small", onClick: (p) => s(p, 0), disabled: o === 0, "aria-label": t.firstPage, children: /* @__PURE__ */ d(ke, { fontSize: "small" }) }),
|
|
222
|
+
/* @__PURE__ */ d(se, { size: "small", onClick: (p) => s(p, o - 1), disabled: o === 0, "aria-label": t.previousPage, children: /* @__PURE__ */ d(Te, { fontSize: "small" }) }),
|
|
223
|
+
/* @__PURE__ */ d(se, { size: "small", onClick: (p) => s(p, o + 1), disabled: o >= g, "aria-label": t.nextPage, children: /* @__PURE__ */ d(Re, { fontSize: "small" }) }),
|
|
224
|
+
/* @__PURE__ */ d(se, { size: "small", onClick: (p) => s(p, g), disabled: o >= g, "aria-label": t.lastPage, children: /* @__PURE__ */ d(Ie, { fontSize: "small" }) })
|
|
225
|
+
] });
|
|
226
|
+
};
|
|
227
|
+
}
|
|
228
|
+
function We(t, e, i) {
|
|
229
|
+
if (t == null && e == null) return 0;
|
|
230
|
+
if (t == null) return 1;
|
|
231
|
+
if (e == null) return -1;
|
|
232
|
+
let o = 0;
|
|
233
|
+
return typeof t == "string" && typeof e == "string" ? o = t.localeCompare(e) : typeof t == "number" && typeof e == "number" ? o = t - e : typeof t == "boolean" && typeof e == "boolean" ? o = t === e ? 0 : t ? 1 : -1 : (typeof t == "object" || typeof e == "object") && (o = JSON.stringify(t).localeCompare(JSON.stringify(e))), i === "asc" ? o : -o;
|
|
234
|
+
}
|
|
235
|
+
function je(t, e, i) {
|
|
236
|
+
return [...t].sort((o, f) => We(o[e], f[e], i));
|
|
237
|
+
}
|
|
238
|
+
function Fe(t, e, i) {
|
|
239
|
+
if (i <= 0) return t.slice();
|
|
240
|
+
const o = e * i;
|
|
241
|
+
return t.slice(o, o + i);
|
|
242
|
+
}
|
|
243
|
+
function Me(t, e) {
|
|
244
|
+
if (!e || e.length === 0) return t;
|
|
245
|
+
const i = new Map(t.map((s) => [s.id, s])), o = [], f = /* @__PURE__ */ new Set();
|
|
246
|
+
for (const s of e) {
|
|
247
|
+
const g = i.get(s);
|
|
248
|
+
g && !f.has(s) && (o.push(g), f.add(s));
|
|
249
|
+
}
|
|
250
|
+
for (const s of t)
|
|
251
|
+
f.has(s.id) || o.push(s);
|
|
252
|
+
return o;
|
|
253
|
+
}
|
|
254
|
+
function He(t, e) {
|
|
255
|
+
const i = e.sort?.columnId != null ? je(t, e.sort.columnId, e.sort.direction) : t, o = Fe(i, e.page, e.pageSize);
|
|
256
|
+
return {
|
|
257
|
+
sorted: i,
|
|
258
|
+
visible: o
|
|
259
|
+
};
|
|
260
|
+
}
|
|
261
|
+
function it(t, e) {
|
|
262
|
+
const i = [e.map((o) => Ue(o.label))];
|
|
263
|
+
for (const o of t)
|
|
264
|
+
i.push(e.map((f) => Je(o[f.id])));
|
|
265
|
+
return Oe(i);
|
|
266
|
+
}
|
|
267
|
+
function Ue(t) {
|
|
268
|
+
return typeof t == "string" ? t : typeof t == "number" || typeof t == "boolean" ? String(t) : "";
|
|
269
|
+
}
|
|
270
|
+
function Je(t) {
|
|
271
|
+
return t == null ? "" : typeof t == "string" ? t : typeof t == "number" || typeof t == "boolean" ? String(t) : Array.isArray(t) || typeof t == "object" ? JSON.stringify(t) : "";
|
|
272
|
+
}
|
|
273
|
+
function rt(t) {
|
|
274
|
+
const e = he(57);
|
|
275
|
+
let i, o, f, s, g, p, c, M, u, $, b, T, w;
|
|
276
|
+
e[0] !== t ? ({
|
|
277
|
+
columns: i,
|
|
278
|
+
visibleColumns: w,
|
|
279
|
+
initialPageSize: $,
|
|
280
|
+
selection: u,
|
|
281
|
+
onSelectionChange: p,
|
|
282
|
+
onRowClick: s,
|
|
283
|
+
onRowHover: g,
|
|
284
|
+
remote: b,
|
|
285
|
+
total: M,
|
|
286
|
+
onSortChange: c,
|
|
287
|
+
onPageChange: o,
|
|
288
|
+
onPageSizeChange: f,
|
|
289
|
+
...T
|
|
290
|
+
} = t, e[0] = t, e[1] = i, e[2] = o, e[3] = f, e[4] = s, e[5] = g, e[6] = p, e[7] = c, e[8] = M, e[9] = u, e[10] = $, e[11] = b, e[12] = T, e[13] = w) : (i = e[1], o = e[2], f = e[3], s = e[4], g = e[5], p = e[6], c = e[7], M = e[8], u = e[9], $ = e[10], b = e[11], T = e[12], w = e[13]);
|
|
291
|
+
const C = $ === void 0 ? Le : $, V = b === void 0 ? !1 : b, m = Se(), R = be(m, Ve);
|
|
292
|
+
let N;
|
|
293
|
+
e[14] !== C ? (N = (l) => ({
|
|
294
|
+
sort: l.sort,
|
|
295
|
+
page: l.page ?? 0,
|
|
296
|
+
pageSize: l.pageSize ?? C,
|
|
297
|
+
columnOrder: l.columnOrder
|
|
298
|
+
}), e[14] = C, e[15] = N) : N = e[15];
|
|
299
|
+
const a = ye(m, N);
|
|
300
|
+
let O;
|
|
301
|
+
if (e[16] !== i || e[17] !== a.columnOrder || e[18] !== w) {
|
|
302
|
+
const l = Me(i, a.columnOrder);
|
|
303
|
+
O = w == null ? l : l.slice(0, w), e[16] = i, e[17] = a.columnOrder, e[18] = w, e[19] = O;
|
|
304
|
+
} else
|
|
305
|
+
O = e[19];
|
|
306
|
+
const v = O;
|
|
307
|
+
let x;
|
|
308
|
+
e: {
|
|
309
|
+
if (V) {
|
|
310
|
+
let A;
|
|
311
|
+
e[20] !== R ? (A = R ?? [], e[20] = R, e[21] = A) : A = e[21];
|
|
312
|
+
const P = M ?? 0;
|
|
313
|
+
let L;
|
|
314
|
+
e[22] !== A || e[23] !== P ? (L = {
|
|
315
|
+
rows: A,
|
|
316
|
+
totalRows: P
|
|
317
|
+
}, e[22] = A, e[23] = P, e[24] = L) : L = e[24], x = L;
|
|
318
|
+
break e;
|
|
319
|
+
}
|
|
320
|
+
let l;
|
|
321
|
+
e[25] !== R || e[26] !== a.page || e[27] !== a.pageSize || e[28] !== a.sort ? (l = He(R ?? [], {
|
|
322
|
+
sort: a.sort,
|
|
323
|
+
page: a.page,
|
|
324
|
+
pageSize: a.pageSize
|
|
325
|
+
}), e[25] = R, e[26] = a.page, e[27] = a.pageSize, e[28] = a.sort, e[29] = l) : l = e[29];
|
|
326
|
+
const {
|
|
327
|
+
sorted: I,
|
|
328
|
+
visible: j
|
|
329
|
+
} = l;
|
|
330
|
+
let S;
|
|
331
|
+
e[30] !== I.length || e[31] !== j ? (S = {
|
|
332
|
+
rows: j,
|
|
333
|
+
totalRows: I.length
|
|
334
|
+
}, e[30] = I.length, e[31] = j, e[32] = S) : S = e[32], x = S;
|
|
335
|
+
}
|
|
336
|
+
const {
|
|
337
|
+
rows: B,
|
|
338
|
+
totalRows: h
|
|
339
|
+
} = x;
|
|
340
|
+
let _;
|
|
341
|
+
e[33] !== m || e[34] !== c ? (_ = (l) => {
|
|
342
|
+
fe(m).setState({
|
|
343
|
+
sort: l,
|
|
344
|
+
page: 0
|
|
345
|
+
}), c?.(l);
|
|
346
|
+
}, e[33] = m, e[34] = c, e[35] = _) : _ = e[35];
|
|
347
|
+
const H = _;
|
|
348
|
+
let E;
|
|
349
|
+
e[36] !== m || e[37] !== o ? (E = (l) => {
|
|
350
|
+
fe(m).setState({
|
|
351
|
+
page: l
|
|
352
|
+
}), o?.(l);
|
|
353
|
+
}, e[36] = m, e[37] = o, e[38] = E) : E = e[38];
|
|
354
|
+
const U = E;
|
|
355
|
+
let z;
|
|
356
|
+
e[39] !== m || e[40] !== f ? (z = (l) => {
|
|
357
|
+
fe(m).setState({
|
|
358
|
+
pageSize: l,
|
|
359
|
+
page: 0
|
|
360
|
+
}), f?.(l);
|
|
361
|
+
}, e[39] = m, e[40] = f, e[41] = z) : z = e[41];
|
|
362
|
+
const W = z;
|
|
363
|
+
let y;
|
|
364
|
+
return e[42] !== U || e[43] !== W || e[44] !== H || e[45] !== s || e[46] !== g || e[47] !== p || e[48] !== v || e[49] !== B || e[50] !== u || e[51] !== h || e[52] !== a.page || e[53] !== a.pageSize || e[54] !== a.sort || e[55] !== T ? (y = /* @__PURE__ */ d($e, { ...T, columns: v, rows: B, total: h, page: a.page, pageSize: a.pageSize, sort: a.sort, selection: u, onSortChange: H, onPageChange: U, onPageSizeChange: W, onSelectionChange: p, onRowClick: s, onRowHover: g }), e[42] = U, e[43] = W, e[44] = H, e[45] = s, e[46] = g, e[47] = p, e[48] = v, e[49] = B, e[50] = u, e[51] = h, e[52] = a.page, e[53] = a.pageSize, e[54] = a.sort, e[55] = T, e[56] = y) : y = e[56], y;
|
|
365
|
+
}
|
|
366
|
+
function Ve(t) {
|
|
367
|
+
return t.data;
|
|
368
|
+
}
|
|
369
|
+
export {
|
|
370
|
+
Ee as D,
|
|
371
|
+
rt as T,
|
|
372
|
+
Le as a,
|
|
373
|
+
De as b,
|
|
374
|
+
$e as c,
|
|
375
|
+
We as d,
|
|
376
|
+
He as e,
|
|
377
|
+
je as f,
|
|
378
|
+
Fe as p,
|
|
379
|
+
Me as r,
|
|
380
|
+
D as s,
|
|
381
|
+
it as t
|
|
382
|
+
};
|
|
383
|
+
//# sourceMappingURL=table-B3ZWWhJt.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"table-B3ZWWhJt.js","sources":["../src/widgets-v2/table/labels.tsx","../src/widgets-v2/table/types.ts","../src/widgets-v2/table/style.ts","../src/widgets-v2/table/table-ui.tsx","../src/widgets-v2/table/helpers.ts","../src/widgets-v2/table/table.tsx"],"sourcesContent":["import { Box, type SxProps, type Theme } from '@mui/material'\nimport type { ReactNode } from 'react'\n\nexport interface TableLabels {\n selectAll: string\n selectRow: (rowId: string | number) => string\n rowsPerPage: string\n /**\n * Renders the displayed-rows summary in the pagination footer. Returns\n * a `ReactNode` so the default can emphasise the active range\n * (`from-to`) with a bolder weight while keeping the trailing\n * ` of total` muted. Override to localise wording or restyle.\n */\n paginationOf: (from: number, to: number, total: number) => ReactNode\n /** aria-label for the first-page pagination button. */\n firstPage: string\n /** aria-label for the previous-page pagination button. */\n previousPage: string\n /** aria-label for the next-page pagination button. */\n nextPage: string\n /** aria-label for the last-page pagination button. */\n lastPage: string\n}\n\nconst boldRange: SxProps<Theme> = { fontWeight: 600, color: 'text.primary' }\n\nexport const DEFAULT_TABLE_LABELS: TableLabels = {\n selectAll: 'Select all rows',\n selectRow: (id) => `Select row ${id}`,\n rowsPerPage: 'Rows per page:',\n paginationOf: (from, to, total) => (\n <>\n <Box component='span' sx={boldRange}>{`${from}–${to}`}</Box>\n {` of ${total}`}\n </>\n ),\n firstPage: 'First page',\n previousPage: 'Previous page',\n nextPage: 'Next page',\n lastPage: 'Last page',\n}\n","import type { ReactNode } from 'react'\nimport type { WidgetState } from '../stores'\n\n/**\n * Single row of tabular data.\n *\n * The default row-identity column is `id`. Consumers that don't have a\n * literal `id` field can point `<Table>` / `<TableUI>` at a different\n * column via the `keyColumn` prop; the library reads `row[keyColumn]`\n * for selection lookup, React keys, and aria labels.\n */\nexport interface TableRow extends Record<string, unknown> {\n /**\n * Default row identity. Required when no `keyColumn` is configured.\n * Omit when wiring `keyColumn` to a different column.\n */\n id?: string | number\n}\n\nexport type TableWidgetData = readonly TableRow[]\n\nexport type TableSortDirection = 'asc' | 'desc'\n\nexport interface TableSortState {\n columnId: string | null\n direction: TableSortDirection\n}\n\nexport interface TableColumn {\n /** Unique column identifier; matches the field name on each row. */\n id: string\n /** Header label. */\n label: ReactNode\n align?: 'left' | 'center' | 'right'\n width?: number | string\n sortable?: boolean\n /** Custom cell renderer. Falls back to a string-cast of the raw value. */\n formatter?: (value: unknown, row: TableRow) => ReactNode\n}\n\n/**\n * State extension carrying Table-specific UI state on the per-widget store.\n * Per R12: widget-specific UI state lives in widget-specific extensions of\n * `WidgetState`, not on the base type.\n */\nexport interface TableWidgetState extends WidgetState {\n /** Optional reordered column list driven by ChangeColumn. Falls back to props. */\n columnOrder?: readonly string[]\n sort?: TableSortState\n page: number\n pageSize: number\n}\n\nexport const DEFAULT_TABLE_PAGE_SIZE = 10\nexport const DEFAULT_TABLE_PAGE_SIZE_OPTIONS = [10, 25, 50, 100] as const\n","import type { SxProps, Theme } from '@mui/material'\n\nexport const styles = {\n container: {\n width: '100%',\n overflowX: 'auto',\n },\n\n table: {\n minWidth: 0,\n },\n headerCell: {\n fontWeight: 600,\n backgroundColor: 'background.paper',\n },\n /**\n * Strip the bottom border from the last body row so the body flushes\n * against the pagination border instead of doubling it up. Mirrors v1.\n */\n row: {\n '&:last-child td, &:last-child th': {\n border: 0,\n },\n },\n rowClickable: {\n cursor: 'pointer',\n },\n pagination: {\n borderTop: '1px solid',\n borderColor: 'divider',\n },\n paginationActions: {\n display: 'flex',\n alignItems: 'center',\n gap: 0.25,\n ml: 1,\n },\n empty: {\n textAlign: 'center',\n color: 'text.secondary',\n py: 3,\n },\n} satisfies Record<string, SxProps<Theme>>\n","import { useCallback, useMemo } from 'react'\nimport {\n Box,\n Checkbox,\n IconButton,\n Table as MuiTable,\n TableBody,\n TableCell,\n TableContainer,\n TableHead,\n TablePagination,\n TableRow as MuiTableRow,\n TableSortLabel,\n type TableProps as MuiTableProps,\n} from '@mui/material'\nimport type { TablePaginationActionsProps } from '@mui/material/TablePagination/TablePaginationActions'\nimport { FirstPage as FirstPageIcon } from '@mui/icons-material'\nimport { KeyboardArrowLeft } from '@mui/icons-material'\nimport { KeyboardArrowRight } from '@mui/icons-material'\nimport { LastPage as LastPageIcon } from '@mui/icons-material'\nimport { DEFAULT_TABLE_LABELS, type TableLabels } from './labels'\nimport {\n DEFAULT_TABLE_PAGE_SIZE_OPTIONS,\n type TableColumn,\n type TableRow,\n type TableSortDirection,\n type TableSortState,\n} from './types'\nimport { styles } from './style'\n\nexport interface TableUIProps<T extends TableRow = TableRow> {\n columns: readonly TableColumn[]\n /** Already-paginated, already-sorted rows for the current view. */\n rows: readonly T[]\n /** Total row count (across all pages). Required for pagination footer. */\n total: number\n page: number\n pageSize: number\n pageSizeOptions?: readonly number[]\n sort?: TableSortState\n /**\n * Column name to use as the row identity. Drives selection lookup,\n * React keys, and aria labels. Defaults to `'id'` — point it at\n * another column when your rows don't carry an `id` field.\n */\n keyColumn?: string\n /** Selected row ids. Destination-owned. */\n selection?: readonly (string | number)[]\n selectable?: boolean\n onSortChange?: (next: TableSortState) => void\n onPageChange?: (page: number) => void\n onPageSizeChange?: (pageSize: number) => void\n onSelectionChange?: (next: readonly (string | number)[]) => void\n onRowClick?: (row: T) => void\n onRowHover?: (row: T | null) => void\n labels?: Partial<TableLabels>\n /** Row rendered when `rows` is empty for the current page. */\n emptyContent?: React.ReactNode\n /**\n * Forwarded to MUI's `<Table size>` — `'small'` for compact rows,\n * `'medium'` for the default density. Leave `undefined` (the default)\n * to let MUI's own default kick in.\n */\n size?: MuiTableProps['size']\n}\n\n/**\n * Pure renderer for a paginated, sortable, optionally-selectable table.\n * Has no widget-store coupling — `<Table>` (the bridge) reads from the store\n * and feeds this UI with already-projected data.\n */\nexport function TableUI<T extends TableRow = TableRow>({\n columns,\n rows,\n total,\n page,\n pageSize,\n pageSizeOptions = DEFAULT_TABLE_PAGE_SIZE_OPTIONS,\n sort,\n keyColumn = 'id',\n selection,\n selectable = false,\n onSortChange,\n onPageChange,\n onPageSizeChange,\n onSelectionChange,\n onRowClick,\n onRowHover,\n labels,\n emptyContent,\n size,\n}: TableUIProps<T>) {\n if (process.env.NODE_ENV !== 'production') {\n // Dev-time guard: a nullish identity collapses every row into the\n // same selection-set entry, which manifests as \"click one → all\n // appear selected\". Surface it loudly instead of silently degrading.\n const missing = rows.some((r) => r[keyColumn] == null)\n if (missing) {\n // eslint-disable-next-line no-console\n console.error(\n `<TableUI>: rows are missing the identity column \\`${keyColumn}\\`. ` +\n 'Set the `keyColumn` prop to a column present on every row, or ' +\n 'add the column to the data.',\n )\n }\n }\n const _labels = useMemo(\n () => ({ ...DEFAULT_TABLE_LABELS, ...labels }),\n [labels],\n )\n // Auto-hide the pagination footer when every row already fits in the\n // smallest available page size — the Rows-per-page selector + prev /\n // next buttons would just be inert noise. Consumers force the footer\n // on by passing a smaller `pageSizeOptions[0]` than `total`.\n const minPageSize = Math.min(...pageSizeOptions)\n const showPagination = total > minPageSize\n // Own the `ActionsComponent` slot ourselves so the Meridian theme's\n // `theme.components.MuiTablePagination.defaultProps.ActionsComponent`\n // (which depends on `react-intl`) doesn't leak into the library. The\n // MUI / Meridian style overrides for `MuiIconButton` /\n // `MuiTablePagination` still apply.\n const PaginationActions = useMemo(\n () => makePaginationActions(_labels),\n [_labels],\n )\n const selectionSet = useMemo(\n () => new Set<string | number>(selection ?? []),\n [selection],\n )\n // Resolve each row's identity from `keyColumn`, falling back to the row's\n // index when the cell is nullish. The dev-time guard above surfaces the\n // misconfiguration loudly, but in production we must NOT collapse every\n // nullish-keyed row into the same selection-set entry (that's the\n // \"click one → all selected\" bug) — a per-index fallback keeps ids\n // distinct and React keys stable for a given page.\n const resolveRowId = useCallback(\n (row: T, index: number): string | number =>\n (row[keyColumn] ?? index) as string | number,\n [keyColumn],\n )\n const pageRowIds = useMemo(() => rows.map(resolveRowId), [rows, resolveRowId])\n const allOnPageSelected =\n pageRowIds.length > 0 && pageRowIds.every((id) => selectionSet.has(id))\n const someOnPageSelected =\n !allOnPageSelected && pageRowIds.some((id) => selectionSet.has(id))\n\n const handleSort = (columnId: string) => {\n if (!onSortChange) return\n const sameCol = sort?.columnId === columnId\n const nextDir: TableSortDirection =\n sameCol && sort?.direction === 'asc' ? 'desc' : 'asc'\n onSortChange({ columnId, direction: nextDir })\n }\n\n const handleSelectAllOnPage = () => {\n if (!onSelectionChange) return\n if (allOnPageSelected) {\n onSelectionChange(\n (selection ?? []).filter((id) => !pageRowIds.includes(id)),\n )\n } else {\n const merged = new Set<string | number>(selection ?? [])\n for (const id of pageRowIds) merged.add(id)\n onSelectionChange([...merged])\n }\n }\n\n const handleSelectRow = (rowId: string | number) => {\n if (!onSelectionChange) return\n const next = new Set<string | number>(selection ?? [])\n if (next.has(rowId)) next.delete(rowId)\n else next.add(rowId)\n onSelectionChange([...next])\n }\n\n return (\n <Box sx={styles.container}>\n <TableContainer>\n <MuiTable stickyHeader size={size} sx={styles.table}>\n <TableHead>\n <MuiTableRow>\n {selectable ? (\n <TableCell padding='checkbox' sx={styles.headerCell}>\n <Checkbox\n checked={allOnPageSelected}\n indeterminate={someOnPageSelected}\n onChange={handleSelectAllOnPage}\n inputProps={{ 'aria-label': _labels.selectAll }}\n />\n </TableCell>\n ) : null}\n {columns.map((column) => {\n const isSorted = sort?.columnId === column.id\n const direction = isSorted ? sort?.direction : undefined\n return (\n <TableCell\n key={column.id}\n align={column.align}\n sortDirection={direction}\n sx={styles.headerCell}\n style={\n column.width != null ? { width: column.width } : undefined\n }\n >\n {column.sortable && onSortChange ? (\n <TableSortLabel\n active={isSorted}\n direction={direction ?? 'asc'}\n onClick={() => handleSort(column.id)}\n >\n {column.label}\n </TableSortLabel>\n ) : (\n column.label\n )}\n </TableCell>\n )\n })}\n </MuiTableRow>\n </TableHead>\n <TableBody>\n {rows.length === 0 ? (\n <MuiTableRow>\n <TableCell\n colSpan={columns.length + (selectable ? 1 : 0)}\n sx={styles.empty}\n >\n {emptyContent ?? null}\n </TableCell>\n </MuiTableRow>\n ) : (\n rows.map((row, index) => {\n const rowId = resolveRowId(row, index)\n const isSelected = selectionSet.has(rowId)\n return (\n <MuiTableRow\n key={rowId}\n hover\n selected={isSelected}\n onClick={() => onRowClick?.(row)}\n onMouseEnter={() => onRowHover?.(row)}\n onMouseLeave={() => onRowHover?.(null)}\n sx={{\n ...styles.row,\n ...(onRowClick ? styles.rowClickable : null),\n }}\n >\n {selectable ? (\n <TableCell padding='checkbox'>\n <Checkbox\n checked={isSelected}\n onClick={(e) => {\n e.stopPropagation()\n handleSelectRow(rowId)\n }}\n inputProps={{\n 'aria-label': _labels.selectRow(rowId),\n }}\n />\n </TableCell>\n ) : null}\n {columns.map((column) => (\n <TableCell key={column.id} align={column.align}>\n {column.formatter\n ? column.formatter(row[column.id], row)\n : stringifyCell(row[column.id])}\n </TableCell>\n ))}\n </MuiTableRow>\n )\n })\n )}\n </TableBody>\n </MuiTable>\n </TableContainer>\n {showPagination ? (\n <TablePagination\n component='div'\n count={total}\n page={page}\n rowsPerPage={pageSize}\n rowsPerPageOptions={[...pageSizeOptions]}\n onPageChange={(_, next) => onPageChange?.(next)}\n onRowsPerPageChange={(e) => {\n const next = parseInt(e.target.value, 10)\n onPageSizeChange?.(next)\n }}\n labelRowsPerPage={_labels.rowsPerPage}\n labelDisplayedRows={({ from, to, count }) =>\n _labels.paginationOf(from, to, count)\n }\n ActionsComponent={PaginationActions}\n sx={styles.pagination}\n />\n ) : null}\n </Box>\n )\n}\n\nfunction stringifyCell(value: unknown): React.ReactNode {\n if (value == null) return ''\n if (typeof value === 'string' || typeof value === 'number') return value\n if (typeof value === 'boolean') return String(value)\n if (Array.isArray(value) || typeof value === 'object') {\n return JSON.stringify(value)\n }\n return ''\n}\n\n/**\n * Build the `ActionsComponent` used by `<TablePagination>` — four MUI\n * `IconButton`s for first / previous / next / last. We provide this\n * ourselves so the Meridian theme's `defaultProps.ActionsComponent`\n * (which depends on `react-intl`) is bypassed at the call site without\n * disturbing the rest of the Meridian theme. The factory closes over\n * the merged label set so aria-labels stay consistent with the rest\n * of the table's i18n surface.\n */\nfunction makePaginationActions(labels: TableLabels) {\n return function PaginationActions({\n count,\n page,\n rowsPerPage,\n onPageChange,\n }: TablePaginationActionsProps) {\n const lastPage = Math.max(0, Math.ceil(count / rowsPerPage) - 1)\n return (\n <Box sx={styles.paginationActions}>\n <IconButton\n size='small'\n onClick={(e) => onPageChange(e, 0)}\n disabled={page === 0}\n aria-label={labels.firstPage}\n >\n <FirstPageIcon fontSize='small' />\n </IconButton>\n <IconButton\n size='small'\n onClick={(e) => onPageChange(e, page - 1)}\n disabled={page === 0}\n aria-label={labels.previousPage}\n >\n <KeyboardArrowLeft fontSize='small' />\n </IconButton>\n <IconButton\n size='small'\n onClick={(e) => onPageChange(e, page + 1)}\n disabled={page >= lastPage}\n aria-label={labels.nextPage}\n >\n <KeyboardArrowRight fontSize='small' />\n </IconButton>\n <IconButton\n size='small'\n onClick={(e) => onPageChange(e, lastPage)}\n disabled={page >= lastPage}\n aria-label={labels.lastPage}\n >\n <LastPageIcon fontSize='small' />\n </IconButton>\n </Box>\n )\n }\n}\n","import { toCsvString } from '../actions/download'\nimport type {\n TableColumn,\n TableRow,\n TableSortDirection,\n TableWidgetData,\n} from './types'\n\n/**\n * Compares two values with a consistent ordering across primitive types.\n * Strings use locale comparison; numbers subtract; booleans rank false < true;\n * objects/arrays compare by JSON serialization. Null/undefined sort to the end\n * regardless of direction.\n */\nexport function compareValues(\n a: unknown,\n b: unknown,\n direction: TableSortDirection,\n): number {\n if (a == null && b == null) return 0\n if (a == null) return 1\n if (b == null) return -1\n let cmp = 0\n if (typeof a === 'string' && typeof b === 'string') {\n cmp = a.localeCompare(b)\n } else if (typeof a === 'number' && typeof b === 'number') {\n cmp = a - b\n } else if (typeof a === 'boolean' && typeof b === 'boolean') {\n cmp = a === b ? 0 : a ? 1 : -1\n } else if (typeof a === 'object' || typeof b === 'object') {\n cmp = JSON.stringify(a).localeCompare(JSON.stringify(b))\n }\n return direction === 'asc' ? cmp : -cmp\n}\n\n/** Returns a new array sorted by the named column. Does not mutate the input. */\nexport function sortRows<T extends TableRow>(\n rows: readonly T[],\n columnId: string,\n direction: TableSortDirection,\n): T[] {\n return [...rows].sort((a, b) =>\n compareValues(a[columnId], b[columnId], direction),\n )\n}\n\n/** Returns the slice for the requested page. Out-of-range pages return []. */\nexport function paginateRows<T>(\n rows: readonly T[],\n page: number,\n pageSize: number,\n): T[] {\n if (pageSize <= 0) return rows.slice()\n const start = page * pageSize\n return rows.slice(start, start + pageSize)\n}\n\n/**\n * Resolves the effective column list. When the widget store has a\n * `columnOrder` set (e.g. ChangeColumn was used), the column array is\n * reordered to match. Unknown ids in the order are skipped; columns not\n * present in the order keep their original relative position at the end.\n */\nexport function resolveColumns(\n columns: readonly TableColumn[],\n columnOrder: readonly string[] | undefined,\n): readonly TableColumn[] {\n if (!columnOrder || columnOrder.length === 0) return columns\n const byId = new Map(columns.map((c) => [c.id, c]))\n const ordered: TableColumn[] = []\n const seen = new Set<string>()\n for (const id of columnOrder) {\n const c = byId.get(id)\n if (c && !seen.has(id)) {\n ordered.push(c)\n seen.add(id)\n }\n }\n for (const c of columns) {\n if (!seen.has(c.id)) ordered.push(c)\n }\n return ordered\n}\n\n/** Applies sort and pagination to the input data. Pure. */\nexport function deriveVisibleRows<T extends TableRow>(\n rows: readonly T[],\n options: {\n sort?: { columnId: string | null; direction: TableSortDirection }\n page: number\n pageSize: number\n },\n): { sorted: readonly T[]; visible: T[] } {\n const sorted =\n options.sort?.columnId != null\n ? sortRows(rows, options.sort.columnId, options.sort.direction)\n : rows\n const visible = paginateRows(sorted, options.page, options.pageSize)\n return { sorted, visible }\n}\n\nexport function tableDataToCsv(\n data: TableWidgetData,\n columns: readonly TableColumn[],\n): string {\n // Pre-stringify with the table's own header/cell rules, then delegate the\n // CSV assembly (quoting + spreadsheet formula-injection guard) to the shared\n // `toCsvString` so escaping stays identical to every other widget's export.\n const rows: string[][] = [columns.map((c) => stringifyHeader(c.label))]\n for (const row of data) {\n rows.push(columns.map((c) => stringifyCell(row[c.id])))\n }\n return toCsvString(rows)\n}\n\nfunction stringifyHeader(label: unknown): string {\n if (typeof label === 'string') return label\n if (typeof label === 'number' || typeof label === 'boolean')\n return String(label)\n return ''\n}\n\nfunction stringifyCell(value: unknown): string {\n if (value == null) return ''\n if (typeof value === 'string') return value\n if (typeof value === 'number' || typeof value === 'boolean')\n return String(value)\n if (Array.isArray(value) || typeof value === 'object')\n return JSON.stringify(value)\n return ''\n}\n","import { useCallback, useMemo } from 'react'\nimport {\n getWidgetStore,\n useWidget,\n useWidgetId,\n useWidgetShallow,\n} from '../stores'\nimport { TableUI, type TableUIProps } from './table-ui'\nimport {\n DEFAULT_TABLE_PAGE_SIZE,\n type TableColumn,\n type TableRow,\n type TableSortState,\n type TableWidgetState,\n} from './types'\nimport { deriveVisibleRows, resolveColumns } from './helpers'\n\nexport interface TableProps<T extends TableRow = TableRow> extends Pick<\n TableUIProps<T>,\n | 'pageSizeOptions'\n | 'selectable'\n | 'labels'\n | 'emptyContent'\n | 'size'\n | 'keyColumn'\n> {\n /**\n * Column definitions. Order can be overridden by ChangeColumn via the\n * `columnOrder` field on the extended widget state.\n */\n columns: readonly TableColumn[]\n /**\n * When set, render only the first `visibleColumns` entries **after**\n * applying the user's `columnOrder` from the store. Useful for showing\n * a compact projection while letting consumers (e.g. `Widget.ChangeColumn`)\n * see the full column list. When omitted, every column renders.\n */\n visibleColumns?: number\n /** Initial page size (only on first mount; afterwards lives on the store). */\n initialPageSize?: number\n /** Selected row ids (destination-owned). */\n selection?: readonly (string | number)[]\n onSelectionChange?: (next: readonly (string | number)[]) => void\n onRowClick?: (row: T) => void\n onRowHover?: (row: T | null) => void\n /**\n * When `true`, the bridge stops sorting and paginating locally and\n * renders `data` as-is — the consumer is then responsible for\n * refetching the slice that matches the active `page` / `pageSize` /\n * `sort` from the outbound callbacks below. `total` is required in\n * this mode (the server already knows the full row count; the\n * widget can't infer it from a partial page).\n */\n remote?: boolean\n /**\n * Server-reported total row count. Required when `remote === true`;\n * ignored in local mode (where the bridge derives total from the\n * sorted result of `deriveVisibleRows`).\n */\n total?: number\n /** Fires after the store-level sort write so the consumer can refetch. */\n onSortChange?: (next: TableSortState) => void\n /** Fires after the store-level page write so the consumer can refetch. */\n onPageChange?: (page: number) => void\n /** Fires after the store-level pageSize write so the consumer can refetch. */\n onPageSizeChange?: (pageSize: number) => void\n}\n\n/**\n * Bridge component — reads the widget store's `data`, applies sort + pagination\n * locally, and feeds `<TableUI />`. Sort, page, and pageSize live on the\n * extended widget state ({@link TableWidgetState}).\n */\nexport function Table<T extends TableRow = TableRow>({\n columns,\n visibleColumns,\n initialPageSize = DEFAULT_TABLE_PAGE_SIZE,\n selection,\n onSelectionChange,\n onRowClick,\n onRowHover,\n remote = false,\n total: remoteTotal,\n onSortChange,\n onPageChange,\n onPageSizeChange,\n ...uiProps\n}: TableProps<T>) {\n const id = useWidgetId()\n const data = useWidget(id, (s) => s.data as readonly T[] | undefined)\n const ui = useWidgetShallow<\n {\n sort: TableSortState | undefined\n page: number\n pageSize: number\n columnOrder: readonly string[] | undefined\n },\n TableWidgetState\n >(id, (s) => ({\n sort: s.sort,\n page: s.page ?? 0,\n pageSize: s.pageSize ?? initialPageSize,\n columnOrder: s.columnOrder,\n }))\n\n const orderedColumns = useMemo(() => {\n const reordered = resolveColumns(columns, ui.columnOrder)\n return visibleColumns == null\n ? reordered\n : reordered.slice(0, visibleColumns)\n }, [columns, ui.columnOrder, visibleColumns])\n\n // In remote mode the consumer already paginated / sorted server-side,\n // so pass `data` and `total` straight through. Local mode keeps the\n // bridge-driven sort + slice via `deriveVisibleRows`.\n const { rows, totalRows } = useMemo(() => {\n if (remote) {\n return {\n rows: data ?? [],\n totalRows: remoteTotal ?? 0,\n }\n }\n const { sorted, visible } = deriveVisibleRows(data ?? [], {\n sort: ui.sort,\n page: ui.page,\n pageSize: ui.pageSize,\n })\n return { rows: visible, totalRows: sorted.length }\n }, [remote, data, remoteTotal, ui.sort, ui.page, ui.pageSize])\n\n const handleSortChange = useCallback(\n (next: TableSortState) => {\n getWidgetStore(id).setState({\n sort: next,\n page: 0,\n } as Partial<TableWidgetState>)\n onSortChange?.(next)\n },\n [id, onSortChange],\n )\n\n const handlePageChange = useCallback(\n (page: number) => {\n getWidgetStore(id).setState({ page } as Partial<TableWidgetState>)\n onPageChange?.(page)\n },\n [id, onPageChange],\n )\n\n const handlePageSizeChange = useCallback(\n (pageSize: number) => {\n getWidgetStore(id).setState({\n pageSize,\n page: 0,\n } as Partial<TableWidgetState>)\n onPageSizeChange?.(pageSize)\n },\n [id, onPageSizeChange],\n )\n\n return (\n <TableUI\n {...uiProps}\n columns={orderedColumns}\n rows={rows}\n total={totalRows}\n page={ui.page}\n pageSize={ui.pageSize}\n sort={ui.sort}\n selection={selection}\n onSortChange={handleSortChange}\n onPageChange={handlePageChange}\n onPageSizeChange={handlePageSizeChange}\n onSelectionChange={onSelectionChange}\n onRowClick={onRowClick}\n onRowHover={onRowHover}\n />\n )\n}\n"],"names":["boldRange","fontWeight","color","DEFAULT_TABLE_LABELS","selectAll","selectRow","id","rowsPerPage","paginationOf","from","to","total","jsxs","Fragment","jsx","Box","firstPage","previousPage","nextPage","lastPage","DEFAULT_TABLE_PAGE_SIZE","DEFAULT_TABLE_PAGE_SIZE_OPTIONS","styles","container","width","overflowX","table","minWidth","headerCell","backgroundColor","row","border","rowClickable","cursor","pagination","borderTop","borderColor","paginationActions","display","alignItems","gap","ml","empty","textAlign","py","TableUI","t0","$","_c","columns","rows","page","pageSize","pageSizeOptions","t1","sort","keyColumn","t2","selection","selectable","t3","onSortChange","onPageChange","onPageSizeChange","onSelectionChange","onRowClick","onRowHover","labels","emptyContent","size","undefined","process","env","NODE_ENV","some","r","console","error","t4","_labels","minPageSize","Math","min","showPagination","t5","makePaginationActions","PaginationActions","t6","t7","Set","selectionSet","t8","index","resolveRowId","t9","map","pageRowIds","t10","length","every","has","allOnPageSelected","t11","id_0","someOnPageSelected","t12","columnId","direction","nextDir","handleSort","t13","filter","id_1","includes","merged","id_2","add","handleSelectAllOnPage","t14","rowId","next","delete","handleSelectRow","t15","TableCell","Checkbox","t16","t17","column","isSorted","align","sortable","TableSortLabel","label","TableHead","MuiTableRow","t18","row_0","index_0","rowId_0","isSelected","e","stopPropagation","column_0","formatter","stringifyCell","t19","TableBody","t20","TableContainer","MuiTable","t21","TablePagination","_","next_0","e_0","next_1","parseInt","target","value","t22","count","String","Array","isArray","JSON","stringify","max","ceil","IconButton","FirstPageIcon","KeyboardArrowLeft","KeyboardArrowRight","LastPageIcon","compareValues","a","b","cmp","localeCompare","sortRows","paginateRows","slice","start","resolveColumns","columnOrder","byId","Map","c","ordered","seen","get","push","deriveVisibleRows","options","sorted","visible","tableDataToCsv","data","stringifyHeader","toCsvString","Table","remoteTotal","uiProps","visibleColumns","initialPageSize","remote","useWidgetId","useWidget","_temp","s_0","s","ui","useWidgetShallow","reordered","orderedColumns","bb0","totalRows","getWidgetStore","setState","handleSortChange","handlePageChange","handlePageSizeChange"],"mappings":"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"}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
import { ChatFooterProps } from '../types';
|
|
2
|
-
export declare function ChatFooter({ value, onChange, onSend, onStop, isGenerating, disabled, placeholder, labels, caption, sx, }: ChatFooterProps): import("react/jsx-runtime").JSX.Element;
|
|
2
|
+
export declare function ChatFooter({ value, onChange, onSend, onStop, isGenerating, disabled, placeholder, labels, caption, models, selectedModel, onModelChange, startToolbarSlot, endToolbarSlot, sx, }: ChatFooterProps): import("react/jsx-runtime").JSX.Element;
|
|
@@ -18,24 +18,91 @@ export declare const styles: {
|
|
|
18
18
|
};
|
|
19
19
|
footerWrapper: {
|
|
20
20
|
padding: ({ spacing }: Theme) => string;
|
|
21
|
-
position: "relative";
|
|
22
|
-
};
|
|
23
|
-
footerCorner: {
|
|
24
|
-
position: "absolute";
|
|
25
|
-
bottom: string;
|
|
26
|
-
right: string;
|
|
27
|
-
margin: string;
|
|
28
21
|
};
|
|
29
|
-
|
|
22
|
+
/**
|
|
23
|
+
* Rounded input box, matching the reference ChatFooter. A two-column grid:
|
|
24
|
+
* main column (input + optional slots) | send button, bottom-aligned so it
|
|
25
|
+
* stays at the end as the input grows. NO vertical padding — the textarea's own
|
|
26
|
+
* padding sets the ~32px single-line height, so the box hugs the input.
|
|
27
|
+
*/
|
|
28
|
+
footerBox: {
|
|
30
29
|
maxWidth: number;
|
|
30
|
+
width: string;
|
|
31
31
|
margin: string;
|
|
32
|
-
|
|
32
|
+
display: "grid";
|
|
33
|
+
gridTemplateColumns: string;
|
|
34
|
+
alignItems: "end";
|
|
35
|
+
columnGap: ({ spacing }: Theme) => string;
|
|
36
|
+
backgroundColor: ({ palette }: Theme) => string;
|
|
37
|
+
borderRadius: ({ spacing }: Theme) => string;
|
|
38
|
+
paddingInline: ({ spacing }: Theme) => string;
|
|
39
|
+
};
|
|
40
|
+
/** Main grid area: input stacked above the (optional) slots row. */
|
|
41
|
+
footerMain: {
|
|
42
|
+
minWidth: number;
|
|
43
|
+
display: "flex";
|
|
44
|
+
flexDirection: "column";
|
|
45
|
+
gap: ({ spacing }: Theme) => string;
|
|
46
|
+
};
|
|
47
|
+
/**
|
|
48
|
+
* Send-button grid area, bottom-aligned (matches the reference flex-end row) so
|
|
49
|
+
* the button stays at the bottom as the input grows. The small bottom padding
|
|
50
|
+
* keeps it off the box edge — in the single-line state it reads as vertically
|
|
51
|
+
* centered (4px top / 4px bottom around the 24px button in the 32px row).
|
|
52
|
+
*/
|
|
53
|
+
footerSend: {
|
|
54
|
+
alignSelf: "end";
|
|
55
|
+
paddingBottom: ({ spacing }: Theme) => string;
|
|
56
|
+
'& .MuiIconButton-root': {
|
|
57
|
+
padding: ({ spacing }: Theme) => string;
|
|
58
|
+
};
|
|
59
|
+
};
|
|
60
|
+
/** The chrome-less multiline input (no underline / no filled affordance). */
|
|
61
|
+
footerInput: {
|
|
62
|
+
width: string;
|
|
63
|
+
typography: string;
|
|
64
|
+
minHeight: string;
|
|
65
|
+
'& textarea': {
|
|
66
|
+
fontSize: ({ typography }: Theme) => string;
|
|
67
|
+
lineHeight: ({ typography }: Theme) => string;
|
|
68
|
+
letterSpacing: ({ typography }: Theme) => string;
|
|
69
|
+
};
|
|
70
|
+
'& textarea:not([aria-hidden])': {
|
|
33
71
|
resize: "none";
|
|
34
|
-
|
|
35
|
-
overflowY: "auto !important";
|
|
36
|
-
paddingRight: ({ spacing }: Theme) => string;
|
|
72
|
+
padding: ({ spacing }: Theme) => string;
|
|
37
73
|
};
|
|
38
74
|
};
|
|
75
|
+
/**
|
|
76
|
+
* Slots row under the input: start slot + model selector + end slot. The left
|
|
77
|
+
* padding lines the row's content up with the input text above it: the input
|
|
78
|
+
* text is inset ~12px from the box edge (InputBase root padding + the textarea's
|
|
79
|
+
* 10px left padding) while the model-selector text button only insets ~8px, so a
|
|
80
|
+
* 4px indent here makes the slot label share the placeholder's left edge instead
|
|
81
|
+
* of sitting further out.
|
|
82
|
+
*/
|
|
83
|
+
footerSlots: {
|
|
84
|
+
display: "flex";
|
|
85
|
+
alignItems: "center";
|
|
86
|
+
gap: ({ spacing }: Theme) => string;
|
|
87
|
+
minWidth: number;
|
|
88
|
+
flexWrap: "wrap";
|
|
89
|
+
paddingLeft: ({ spacing }: Theme) => string;
|
|
90
|
+
paddingBottom: ({ spacing }: Theme) => string;
|
|
91
|
+
};
|
|
92
|
+
modelSelector: {
|
|
93
|
+
textTransform: "none";
|
|
94
|
+
color: ({ palette }: Theme) => string;
|
|
95
|
+
maxWidth: string;
|
|
96
|
+
minWidth: number;
|
|
97
|
+
'& .MuiButton-endIcon': {
|
|
98
|
+
marginLeft: ({ spacing }: Theme) => string;
|
|
99
|
+
};
|
|
100
|
+
};
|
|
101
|
+
modelSelectorLabel: {
|
|
102
|
+
overflow: "hidden";
|
|
103
|
+
textOverflow: "ellipsis";
|
|
104
|
+
whiteSpace: "nowrap";
|
|
105
|
+
};
|
|
39
106
|
footerCaption: {
|
|
40
107
|
textAlign: "center";
|
|
41
108
|
};
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
export type { ChatSxProps, ChatErrorAction, ChatUserMessageProps, ChatAgentMessageProps, ChatErrorMessageProps, ChatSuggestionButtonProps, ChatThinkingProps, ChatLoaderProps, ChatContentProps, ChatContentRef, ChatHeaderProps, ChatFooterProps, ChatStarterItem, ChatStarterProps, ChatRatingActionProps, ChatToolItem, ChatToolTraceProps, ChatToolCodeAreaProps, ChatToolFullViewDialogProps, ChatToolGroupProps, } from './types';
|
|
1
|
+
export type { ChatSxProps, ChatErrorAction, ChatUserMessageProps, ChatAgentMessageProps, ChatErrorMessageProps, ChatSuggestionButtonProps, ChatThinkingProps, ChatLoaderProps, ChatContentProps, ChatContentRef, ChatHeaderProps, ChatFooterProps, ChatModelOption, ChatStarterItem, ChatStarterProps, ChatRatingActionProps, ChatToolItem, ChatToolTraceProps, ChatToolCodeAreaProps, ChatToolFullViewDialogProps, ChatToolGroupProps, } from './types';
|
|
2
2
|
export { CHAT_MAX_WIDTH, CHAT_SCROLL_DELAY, CHAT_DIVIDER_DELAY, CHAT_TOOL_CODE_AREA_MAX_HEIGHT, } from './const';
|
|
3
3
|
export { useTypewriter } from './use-typewriter';
|
|
4
4
|
export { ChatUserMessage } from './bubbles/chat-user-message';
|
|
@@ -91,9 +91,30 @@ export interface ChatFooterProps extends ChatSxProps {
|
|
|
91
91
|
send?: string;
|
|
92
92
|
/** Defaults to `'Stop'`. */
|
|
93
93
|
stop?: string;
|
|
94
|
+
/** `aria-label` for the model-selector trigger. Defaults to `'Select model'`. */
|
|
95
|
+
model?: string;
|
|
94
96
|
};
|
|
95
97
|
/** Helper text rendered under the input. Defaults to an AI disclaimer; pass `null` to hide. */
|
|
96
98
|
caption?: ReactNode;
|
|
99
|
+
/**
|
|
100
|
+
* Selectable models for the in-toolbar model selector. The selector is only
|
|
101
|
+
* rendered when this is a non-empty array; the component is otherwise
|
|
102
|
+
* model-agnostic (the host owns the list, selection, and default).
|
|
103
|
+
*/
|
|
104
|
+
models?: ChatModelOption[];
|
|
105
|
+
/** Currently selected model `value`. Controlled — the host owns the state. */
|
|
106
|
+
selectedModel?: string;
|
|
107
|
+
/** Called with the picked model `value` when the user selects one. */
|
|
108
|
+
onModelChange?: (value: string) => void;
|
|
109
|
+
/** Extra controls rendered at the start (left) of the toolbar, before the model selector. */
|
|
110
|
+
startToolbarSlot?: ReactNode;
|
|
111
|
+
/** Extra controls rendered at the end (right) of the toolbar, before the send/stop button. */
|
|
112
|
+
endToolbarSlot?: ReactNode;
|
|
113
|
+
}
|
|
114
|
+
/** An option for the `ChatFooter` model selector. */
|
|
115
|
+
export interface ChatModelOption {
|
|
116
|
+
value: string;
|
|
117
|
+
label: string;
|
|
97
118
|
}
|
|
98
119
|
export interface ChatStarterItem {
|
|
99
120
|
label: string;
|