@xyo-network/react-payload-table 7.6.3 → 8.0.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/browser/components/DynamicTable/DynamicTableRow.d.ts.map +1 -1
- package/dist/browser/components/DynamicTable/Table.d.ts.map +1 -1
- package/dist/browser/components/Table/TableBody.d.ts.map +1 -1
- package/dist/browser/components/Table/TableFooter.d.ts.map +1 -1
- package/dist/browser/components/Table/TableHead.d.ts.map +1 -1
- package/dist/browser/components/Table/TableRow.d.ts.map +1 -1
- package/dist/browser/index.mjs +60 -16
- package/dist/browser/index.mjs.map +7 -1
- package/package.json +69 -65
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"DynamicTableRow.d.ts","sourceRoot":"","sources":["../../../../src/components/DynamicTable/DynamicTableRow.tsx"],"names":[],"mappings":"AAKA,OAAO,KAAK,EACmB,aAAa,EAC3C,MAAM,eAAe,CAAA;AAOtB,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAOzD,OAAO,KAAkB,MAAM,OAAO,CAAA;AAGtC,OAAO,KAAK,EACV,+BAA+B,EAEhC,MAAM,sCAAsC,CAAA;AAG7C,MAAM,WAAW,2BAA4B,SAAQ,aAAa;IAChE,gDAAgD;IAChD,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,OAAO,CAAC,EAAE,+BAA+B,CAAA;IACzC,2EAA2E;IAC3E,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,OAAO,CAAC,EAAE,OAAO,GAAG;QAAE,OAAO,CAAC,EAAE,MAAM,EAAE,CAAA;KAAE,CAAA;CAC3C;AAED,eAAO,MAAM,sBAAsB,EAAE,KAAK,CAAC,EAAE,CAAC,2BAA2B,
|
|
1
|
+
{"version":3,"file":"DynamicTableRow.d.ts","sourceRoot":"","sources":["../../../../src/components/DynamicTable/DynamicTableRow.tsx"],"names":[],"mappings":"AAKA,OAAO,KAAK,EACmB,aAAa,EAC3C,MAAM,eAAe,CAAA;AAOtB,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAOzD,OAAO,KAAkB,MAAM,OAAO,CAAA;AAGtC,OAAO,KAAK,EACV,+BAA+B,EAEhC,MAAM,sCAAsC,CAAA;AAG7C,MAAM,WAAW,2BAA4B,SAAQ,aAAa;IAChE,gDAAgD;IAChD,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,OAAO,CAAC,EAAE,+BAA+B,CAAA;IACzC,2EAA2E;IAC3E,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,OAAO,CAAC,EAAE,OAAO,GAAG;QAAE,OAAO,CAAC,EAAE,MAAM,EAAE,CAAA;KAAE,CAAA;CAC3C;AAED,eAAO,MAAM,sBAAsB,EAAE,KAAK,CAAC,EAAE,CAAC,2BAA2B,CAqGxE,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Table.d.ts","sourceRoot":"","sources":["../../../../src/components/DynamicTable/Table.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAkB/C,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAGzD,OAAO,KAA4B,MAAM,OAAO,CAAA;AAGhD,OAAO,KAAK,EAAE,+BAA+B,EAAE,MAAM,sCAAsC,CAAA;AAG3F,MAAM,WAAW,wBAAyB,SAAQ,UAAU;IAC1D,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,OAAO,CAAC,EAAE,+BAA+B,CAAA;IACzC,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,UAAU,CAAC,EAAE,CAAC,KAAK,EAAE,OAAO,KAAK,IAAI,CAAA;IACrC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,IAAI,CAAA;IAC3B,WAAW,CAAC,EAAE,MAAM,CAAA;CACrB;AAyDD,eAAO,MAAM,mBAAmB,EAAE,KAAK,CAAC,EAAE,CAAC,wBAAwB,
|
|
1
|
+
{"version":3,"file":"Table.d.ts","sourceRoot":"","sources":["../../../../src/components/DynamicTable/Table.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAkB/C,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAGzD,OAAO,KAA4B,MAAM,OAAO,CAAA;AAGhD,OAAO,KAAK,EAAE,+BAA+B,EAAE,MAAM,sCAAsC,CAAA;AAG3F,MAAM,WAAW,wBAAyB,SAAQ,UAAU;IAC1D,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,OAAO,CAAC,EAAE,+BAA+B,CAAA;IACzC,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,UAAU,CAAC,EAAE,CAAC,KAAK,EAAE,OAAO,KAAK,IAAI,CAAA;IACrC,QAAQ,CAAC,EAAE,OAAO,EAAE,GAAG,IAAI,CAAA;IAC3B,WAAW,CAAC,EAAE,MAAM,CAAA;CACrB;AAyDD,eAAO,MAAM,mBAAmB,EAAE,KAAK,CAAC,EAAE,CAAC,wBAAwB,CA2GlE,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TableBody.d.ts","sourceRoot":"","sources":["../../../../src/components/Table/TableBody.tsx"],"names":[],"mappings":"AAMA,OAAO,KAAK,MAAM,OAAO,CAAA;AAGzB,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAA;AAE7D,eAAO,MAAM,gBAAgB,EAAE,KAAK,CAAC,EAAE,CAAC,qBAAqB,
|
|
1
|
+
{"version":3,"file":"TableBody.d.ts","sourceRoot":"","sources":["../../../../src/components/Table/TableBody.tsx"],"names":[],"mappings":"AAMA,OAAO,KAAK,MAAM,OAAO,CAAA;AAGzB,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAA;AAE7D,eAAO,MAAM,gBAAgB,EAAE,KAAK,CAAC,EAAE,CAAC,qBAAqB,CAsD5D,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TableFooter.d.ts","sourceRoot":"","sources":["../../../../src/components/Table/TableFooter.tsx"],"names":[],"mappings":"AAIA,OAAO,KAAK,MAAM,OAAO,CAAA;AAGzB,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,kBAAkB,CAAA;AAE/D,eAAO,MAAM,kBAAkB,EAAE,KAAK,CAAC,EAAE,CAAC,uBAAuB,
|
|
1
|
+
{"version":3,"file":"TableFooter.d.ts","sourceRoot":"","sources":["../../../../src/components/Table/TableFooter.tsx"],"names":[],"mappings":"AAIA,OAAO,KAAK,MAAM,OAAO,CAAA;AAGzB,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,kBAAkB,CAAA;AAE/D,eAAO,MAAM,kBAAkB,EAAE,KAAK,CAAC,EAAE,CAAC,uBAAuB,CA8BhE,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TableHead.d.ts","sourceRoot":"","sources":["../../../../src/components/Table/TableHead.tsx"],"names":[],"mappings":"AAIA,OAAO,KAAkB,MAAM,OAAO,CAAA;AAEtC,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,+BAA+B,CAAA;AAE3E,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAA;AAE7D,eAAO,MAAM,gBAAgB,EAAE,KAAK,CAAC,EAAE,CAAC,qBAAqB,CAAC,sBAAsB,CAAC,
|
|
1
|
+
{"version":3,"file":"TableHead.d.ts","sourceRoot":"","sources":["../../../../src/components/Table/TableHead.tsx"],"names":[],"mappings":"AAIA,OAAO,KAAkB,MAAM,OAAO,CAAA;AAEtC,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,+BAA+B,CAAA;AAE3E,OAAO,KAAK,EAAE,qBAAqB,EAAE,MAAM,kBAAkB,CAAA;AAE7D,eAAO,MAAM,gBAAgB,EAAE,KAAK,CAAC,EAAE,CAAC,qBAAqB,CAAC,sBAAsB,CAAC,CAwBpF,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TableRow.d.ts","sourceRoot":"","sources":["../../../../src/components/Table/TableRow.tsx"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,eAAe,CAAA;AAMlD,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAA;AAE1C,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAIzD,OAAO,KAAkB,MAAM,OAAO,CAAA;AAGtC,OAAO,KAAK,EAAE,wBAAwB,EAAE,sBAAsB,EAAE,MAAM,+BAA+B,CAAA;AAGrG,MAAM,WAAW,oBAAqB,SAAQ,aAAa;IACzD,gDAAgD;IAChD,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,eAAe,CAAC,EAAE,sBAAsB,EAAE,CAAA;IAC1C,OAAO,CAAC,EAAE,wBAAwB,CAAA;IAClC,2EAA2E;IAC3E,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,WAAW,CAAC,EAAE,CAAC,KAAK,EAAE,IAAI,KAAK,IAAI,CAAA;IACnC,OAAO,CAAC,EAAE,OAAO,CAAA;CAClB;AAED,eAAO,MAAM,eAAe,EAAE,KAAK,CAAC,EAAE,CAAC,oBAAoB,
|
|
1
|
+
{"version":3,"file":"TableRow.d.ts","sourceRoot":"","sources":["../../../../src/components/Table/TableRow.tsx"],"names":[],"mappings":"AAKA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,eAAe,CAAA;AAMlD,OAAO,KAAK,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAA;AAE1C,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,4BAA4B,CAAA;AAIzD,OAAO,KAAkB,MAAM,OAAO,CAAA;AAGtC,OAAO,KAAK,EAAE,wBAAwB,EAAE,sBAAsB,EAAE,MAAM,+BAA+B,CAAA;AAGrG,MAAM,WAAW,oBAAqB,SAAQ,aAAa;IACzD,gDAAgD;IAChD,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,eAAe,CAAC,EAAE,sBAAsB,EAAE,CAAA;IAC1C,OAAO,CAAC,EAAE,wBAAwB,CAAA;IAClC,2EAA2E;IAC3E,aAAa,CAAC,EAAE,MAAM,CAAA;IACtB,cAAc,CAAC,EAAE,MAAM,CAAA;IACvB,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,WAAW,CAAC,EAAE,CAAC,KAAK,EAAE,IAAI,KAAK,IAAI,CAAA;IACnC,OAAO,CAAC,EAAE,OAAO,CAAA;CAClB;AAED,eAAO,MAAM,eAAe,EAAE,KAAK,CAAC,EAAE,CAAC,oBAAoB,CAsG1D,CAAA"}
|
package/dist/browser/index.mjs
CHANGED
|
@@ -191,8 +191,24 @@ var PayloadDynamicTableRow = ({
|
|
|
191
191
|
},
|
|
192
192
|
"hash"
|
|
193
193
|
);
|
|
194
|
-
const schema = (props2) => /* @__PURE__ */ jsx(TableCell, { align: "left", ...props2, children: /* @__PURE__ */ jsx(
|
|
195
|
-
|
|
194
|
+
const schema = (props2) => /* @__PURE__ */ jsx(TableCell, { align: "left", ...props2, children: /* @__PURE__ */ jsx(
|
|
195
|
+
Typography,
|
|
196
|
+
{
|
|
197
|
+
variant: "body2",
|
|
198
|
+
noWrap: true,
|
|
199
|
+
sx: { fontFamily: "monospace" },
|
|
200
|
+
children: payload?.schema
|
|
201
|
+
}
|
|
202
|
+
) }, "payloads");
|
|
203
|
+
const details = (props2) => /* @__PURE__ */ jsx(TableCell, { align: "left", ...props2, children: /* @__PURE__ */ jsx(
|
|
204
|
+
Typography,
|
|
205
|
+
{
|
|
206
|
+
variant: "body2",
|
|
207
|
+
noWrap: true,
|
|
208
|
+
sx: { fontFamily: "monospace" },
|
|
209
|
+
children: payloadFieldCount
|
|
210
|
+
}
|
|
211
|
+
) }, "payloads");
|
|
196
212
|
const render = (props2) => {
|
|
197
213
|
const Render = payload ? resolver?.resolve(payload)?.components.table.cell : void 0;
|
|
198
214
|
return Render ? /* @__PURE__ */ jsx(Render, { payload, ...props2 }) : /* @__PURE__ */ jsx(TableCell, { align: "left", ...props2 }, "payloads");
|
|
@@ -296,7 +312,15 @@ var PayloadDynamicTable = ({
|
|
|
296
312
|
};
|
|
297
313
|
return breakPoint ? /* @__PURE__ */ jsxs(Table, { stickyHeader: true, ...props, children: [
|
|
298
314
|
/* @__PURE__ */ jsx2(TableHead, { children: /* @__PURE__ */ jsx2(TableRow2, { children: (columns ?? payloadDynamicTableColumnConfigDefaults())[breakPoint]?.map((column) => {
|
|
299
|
-
return /* @__PURE__ */ jsx2(
|
|
315
|
+
return /* @__PURE__ */ jsx2(
|
|
316
|
+
TableCell2,
|
|
317
|
+
{
|
|
318
|
+
align: column.alignment ?? "left",
|
|
319
|
+
sx: { width: column.width },
|
|
320
|
+
children: /* @__PURE__ */ jsx2(Typography2, { variant: "body2", noWrap: true, children: column.name })
|
|
321
|
+
},
|
|
322
|
+
column.name
|
|
323
|
+
);
|
|
300
324
|
}) }) }),
|
|
301
325
|
/* @__PURE__ */ jsxs(TableBody, { sx: { overflowY: "scroll " }, children: [
|
|
302
326
|
payloadPairs?.map(([payload, hash]) => {
|
|
@@ -307,7 +331,7 @@ var PayloadDynamicTable = ({
|
|
|
307
331
|
errorComponent: (e) => /* @__PURE__ */ jsxs(Alert, { severity: "error", children: [
|
|
308
332
|
"Error Loading Payload:",
|
|
309
333
|
" ",
|
|
310
|
-
/* @__PURE__ */ jsx2(Typography2, { fontWeight: "bold", children: e.message })
|
|
334
|
+
/* @__PURE__ */ jsx2(Typography2, { sx: { fontWeight: "bold" }, children: e.message })
|
|
311
335
|
] }),
|
|
312
336
|
children: /* @__PURE__ */ jsx2(
|
|
313
337
|
PayloadDynamicTableRow,
|
|
@@ -335,13 +359,15 @@ var PayloadDynamicTable = ({
|
|
|
335
359
|
count: payloadCount,
|
|
336
360
|
rowsPerPage,
|
|
337
361
|
page,
|
|
338
|
-
SelectProps: {
|
|
339
|
-
inputProps: { "aria-label": "rows per page" },
|
|
340
|
-
native: true
|
|
341
|
-
},
|
|
342
362
|
onPageChange: handleChangePage,
|
|
343
363
|
onRowsPerPageChange: handleChangeRowsPerPage,
|
|
344
|
-
ActionsComponent: TablePaginationActions
|
|
364
|
+
ActionsComponent: TablePaginationActions,
|
|
365
|
+
slotProps: {
|
|
366
|
+
select: {
|
|
367
|
+
inputProps: { "aria-label": "rows per page" },
|
|
368
|
+
native: true
|
|
369
|
+
}
|
|
370
|
+
}
|
|
345
371
|
}
|
|
346
372
|
) }) })
|
|
347
373
|
] }) : null;
|
|
@@ -442,7 +468,15 @@ var PayloadTableRow = ({
|
|
|
442
468
|
}
|
|
443
469
|
return schema2;
|
|
444
470
|
};
|
|
445
|
-
const schema = (props2) => /* @__PURE__ */ jsx3(TableCell3, { title: payload?.schema, align: "center", ...props2, children: /* @__PURE__ */ jsx3(
|
|
471
|
+
const schema = (props2) => /* @__PURE__ */ jsx3(TableCell3, { title: payload?.schema, align: "center", ...props2, children: /* @__PURE__ */ jsx3(
|
|
472
|
+
Typography3,
|
|
473
|
+
{
|
|
474
|
+
variant: "body2",
|
|
475
|
+
noWrap: true,
|
|
476
|
+
sx: { fontFamily: "monospace" },
|
|
477
|
+
children: clickableFields?.includes("schema") ? /* @__PURE__ */ jsx3(Link, { sx: { cursor: "pointer" }, children: reduceSchemaDepth(payload?.schema, maxSchemaDepth) }) : reduceSchemaDepth(payload?.schema, maxSchemaDepth)
|
|
478
|
+
}
|
|
479
|
+
) }, "payloads");
|
|
446
480
|
const valid = (props2) => /* @__PURE__ */ jsx3(TableCell3, { align: "center", ...props2, children: isValid === void 0 && payload != void 0 ? /* @__PURE__ */ jsx3(WarningAmberRoundedIcon2, { fontSize: "small", color: "warning" }) : isValid === true ? /* @__PURE__ */ jsx3(CheckCircleOutlineRoundedIcon2, { fontSize: "small", color: "success" }) : isValid === false ? /* @__PURE__ */ jsx3(ErrorOutlineRoundedIcon2, { color: "error", fontSize: "small" }) : /* @__PURE__ */ jsx3(ErrorOutlineRoundedIcon2, { sx: { color: alpha("#fff", 0) }, fontSize: "small" }) }, "valid");
|
|
447
481
|
const tableCells = {
|
|
448
482
|
hash,
|
|
@@ -480,7 +514,7 @@ var PayloadTableBody = ({
|
|
|
480
514
|
errorComponent: (e) => /* @__PURE__ */ jsxs3(Alert2, { severity: "error", children: [
|
|
481
515
|
"Error Loading Payload:",
|
|
482
516
|
" ",
|
|
483
|
-
/* @__PURE__ */ jsx4(Typography4, { fontWeight: "bold", children: e.message })
|
|
517
|
+
/* @__PURE__ */ jsx4(Typography4, { sx: { fontWeight: "bold" }, children: e.message })
|
|
484
518
|
] }),
|
|
485
519
|
children: /* @__PURE__ */ jsx4(
|
|
486
520
|
PayloadTableRow,
|
|
@@ -600,9 +634,11 @@ var PayloadTableFooter = ({
|
|
|
600
634
|
count: count ?? 0,
|
|
601
635
|
rowsPerPage: rowsPerPage ?? 10,
|
|
602
636
|
page: page ?? 0,
|
|
603
|
-
|
|
604
|
-
|
|
605
|
-
|
|
637
|
+
slotProps: {
|
|
638
|
+
select: {
|
|
639
|
+
inputProps: { "aria-label": "rows per page" },
|
|
640
|
+
native: true
|
|
641
|
+
}
|
|
606
642
|
},
|
|
607
643
|
onPageChange: handleChangePage ?? (() => {
|
|
608
644
|
}),
|
|
@@ -631,7 +667,15 @@ var PayloadTableHead = ({ columns, ...props }) => {
|
|
|
631
667
|
const breakPoint = useBreakpoint4();
|
|
632
668
|
const columnsMemo = useMemo4(() => columns ?? payloadTableColumnConfigDefaults(), [columns]);
|
|
633
669
|
return /* @__PURE__ */ jsx7(TableHead2, { ...props, children: /* @__PURE__ */ jsx7(TableRow5, { children: breakPoint ? columnsMemo[breakPoint]?.map((column, index) => {
|
|
634
|
-
return /* @__PURE__ */ jsx7(
|
|
670
|
+
return /* @__PURE__ */ jsx7(
|
|
671
|
+
TableCell4,
|
|
672
|
+
{
|
|
673
|
+
align: index === 0 ? "left" : "center",
|
|
674
|
+
sx: { width: index === 0 ? "100%" : void 0 },
|
|
675
|
+
children: /* @__PURE__ */ jsx7(Typography5, { variant: "body2", noWrap: true, children: payloadColumnNames[column] })
|
|
676
|
+
},
|
|
677
|
+
column
|
|
678
|
+
);
|
|
635
679
|
}) : null }) });
|
|
636
680
|
};
|
|
637
681
|
|
|
@@ -762,4 +806,4 @@ export {
|
|
|
762
806
|
payloadDynamicTableColumnConfigDefaults,
|
|
763
807
|
payloadTableColumnConfigDefaults
|
|
764
808
|
};
|
|
765
|
-
//# sourceMappingURL=index.mjs.map
|
|
809
|
+
//# sourceMappingURL=index.mjs.map
|
|
@@ -1 +1,7 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/components/DynamicTable/DynamicTableRow.tsx","../../src/components/DynamicTable/PayloadDynamicTableColumnConfig.ts","../../src/components/DynamicTable/Table.tsx","../../src/components/Table/PayloadTableColumnConfig.ts","../../src/components/Table/Table.tsx","../../src/components/Table/TableBody.tsx","../../src/components/Table/TableRow.tsx","../../src/components/Table/TableFooter.tsx","../../src/components/Table/TablePagination.tsx","../../src/components/Table/TableHead.tsx","../../src/components/Table/TableRowNoData.tsx"],"sourcesContent":["import {\n CheckCircleOutlineRounded as CheckCircleOutlineRoundedIcon,\n ErrorOutlineRounded as ErrorOutlineRoundedIcon,\n WarningAmberRounded as WarningAmberRoundedIcon,\n} from '@mui/icons-material'\nimport type {\n AvatarProps, TableCellProps, TableRowProps,\n} from '@mui/material'\nimport {\n TableCell, TableRow, Typography,\n} from '@mui/material'\nimport { usePromise } from '@xylabs/react-promise'\nimport { useBreakpoint } from '@xylabs/react-shared'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type { Payload } from '@xyo-network/payload-model'\nimport { PayloadValidator } from '@xyo-network/payload-validator'\nimport { useNetwork } from '@xyo-network/react-network'\nimport type { PayloadRenderProps } from '@xyo-network/react-payload-plugin'\nimport { usePayloadRenderPluginResolver } from '@xyo-network/react-payload-plugin-resolver'\nimport { HashTableCell, usePayloadHash } from '@xyo-network/react-shared'\nimport type { ComponentType } from 'react'\nimport React, { useMemo } from 'react'\n\nimport type { TableCellRenderer } from '../lib/index.ts'\nimport type {\n PayloadDynamicTableColumnConfig,\n PayloadDynamicTableColumnSlug,\n} from './PayloadDynamicTableColumnConfig.ts'\nimport { payloadDynamicTableColumnConfigDefaults } from './PayloadDynamicTableColumnConfig.ts'\n\nexport interface PayloadDynamicTableRowProps extends TableRowProps {\n /** @deprecated - archives are no longer used */\n archive?: string\n columns?: PayloadDynamicTableColumnConfig\n /** @deprecated - use event listeners instead of link building via props */\n exploreDomain?: string\n network?: string\n payload?: Payload & { sources?: string[] }\n}\n\nexport const PayloadDynamicTableRow: React.FC<PayloadDynamicTableRowProps> = ({\n columns,\n network: networkProp,\n payload,\n ...props\n}) => {\n const breakPoint = useBreakpoint()\n const payloadHash = usePayloadHash(payload)\n const { network } = useNetwork()\n const { resolver } = usePayloadRenderPluginResolver()\n const [validationErrors = []] = usePromise(async () => (payload ? await new PayloadValidator(payload).validate() : undefined), [payload])\n const isValid = validationErrors.length === 0\n const payloadFieldCount = payload ? Object.keys(PayloadBuilder.hashableFields(payload)).length : 0\n\n const hash: TableCellRenderer = props => (\n <HashTableCell\n key=\"hash\"\n align=\"left\"\n value={payloadHash}\n dataType=\"payload\"\n network={networkProp ?? network?.slug}\n {...props}\n />\n )\n\n const schema: TableCellRenderer = props => (\n <TableCell key=\"payloads\" align=\"left\" {...props}>\n <Typography fontFamily=\"monospace\" variant=\"body2\" noWrap>\n {payload?.schema}\n </Typography>\n </TableCell>\n )\n\n const details: TableCellRenderer = props => (\n <TableCell key=\"payloads\" align=\"left\" {...props}>\n <Typography fontFamily=\"monospace\" variant=\"body2\" noWrap>\n {payloadFieldCount}\n </Typography>\n </TableCell>\n )\n\n const render: TableCellRenderer = (props) => {\n const Render: ComponentType<PayloadRenderProps & TableCellProps> | undefined\n = payload ? resolver?.resolve(payload)?.components.table.cell : undefined\n return Render ? <Render payload={payload} {...props} /> : <TableCell key=\"payloads\" align=\"left\" {...props}></TableCell>\n }\n\n const icon: TableCellRenderer = (props) => {\n const Avatar: ComponentType<PayloadRenderProps & AvatarProps> | undefined\n = payload ? resolver?.resolve(payload)?.components.avatar.image : undefined\n\n return (\n <TableCell key=\"payloads\" align=\"left\" {...props}>\n {Avatar\n ? <Avatar payload={payload} />\n : null}\n </TableCell>\n )\n }\n\n const valid: TableCellRenderer = props => (\n <TableCell key=\"valid\" align=\"center\" {...props}>\n {isValid === undefined && payload != undefined\n ? <WarningAmberRoundedIcon fontSize=\"small\" color=\"warning\" />\n : isValid === true\n ? <CheckCircleOutlineRoundedIcon fontSize=\"small\" color=\"success\" />\n : isValid === false\n ? <ErrorOutlineRoundedIcon color=\"error\" fontSize=\"small\" />\n // nbsp to keep row height consistent even when no data is provided for the row\n : <Typography> </Typography>}\n </TableCell>\n )\n\n const tableCells: Record<PayloadDynamicTableColumnSlug, TableCellRenderer> = {\n details,\n hash,\n icon,\n render,\n schema,\n valid,\n }\n\n const columnsMemo = useMemo(() => columns ?? payloadDynamicTableColumnConfigDefaults(), [columns])\n\n return breakPoint\n ? (\n <TableRow style={{ maxWidth: '100vw' }} {...props}>\n {columnsMemo[breakPoint]?.map((column) => {\n return column.slug ? tableCells[column.slug]({}) : null\n })}\n </TableRow>\n )\n : null\n}\n","export type PayloadDynamicTableColumnSlug = 'hash' | 'schema' | 'valid' | 'details' | 'render' | 'icon'\n\nexport interface PayloadDynamicTableColumnHeadData {\n alignment?: 'left' | 'center' | 'right'\n name?: string\n slug?: 'hash' | 'schema' | 'valid' | 'details' | 'render' | 'icon'\n width?: string | number\n}\n\nexport interface PayloadDynamicTableColumnConfig {\n xs?: PayloadDynamicTableColumnHeadData[]\n // eslint-disable-next-line @typescript-eslint/member-ordering\n sm?: PayloadDynamicTableColumnHeadData[]\n // eslint-disable-next-line @typescript-eslint/member-ordering\n md?: PayloadDynamicTableColumnHeadData[]\n // eslint-disable-next-line @typescript-eslint/member-ordering\n lg?: PayloadDynamicTableColumnHeadData[]\n xl?: PayloadDynamicTableColumnHeadData[]\n}\n\nexport const payloadDynamicTableColumnConfigDefaults = (): PayloadDynamicTableColumnConfig => {\n const xs: PayloadDynamicTableColumnHeadData[] = [\n {\n alignment: 'left', name: 'Hash', slug: 'hash', width: '100%',\n },\n {\n alignment: 'left', name: 'Schema', slug: 'schema', width: '50px',\n },\n {\n alignment: 'left', name: 'Valid', slug: 'valid', width: '50px',\n },\n ]\n const sm: PayloadDynamicTableColumnHeadData[] = [\n {\n alignment: 'left', name: 'Icon', slug: 'icon', width: '50px',\n },\n {\n alignment: 'left', name: 'Hash', slug: 'hash', width: '100%',\n },\n {\n alignment: 'left', name: 'Schema', slug: 'schema', width: '50px',\n },\n {\n alignment: 'left', name: 'Valid', slug: 'valid', width: '50px',\n },\n ]\n const md: PayloadDynamicTableColumnHeadData[] = [\n {\n alignment: 'left', name: 'Icon', slug: 'icon', width: '50px',\n },\n {\n alignment: 'left', name: 'Hash', slug: 'hash', width: '100%',\n },\n {\n alignment: 'left', name: 'Schema', slug: 'schema', width: '50px',\n },\n {\n alignment: 'left', name: 'Valid', slug: 'valid', width: '50px',\n },\n ]\n const lg: PayloadDynamicTableColumnHeadData[] = [\n {\n alignment: 'left', name: 'Icon', slug: 'icon', width: '50px',\n },\n {\n alignment: 'left', name: 'Hash', slug: 'hash', width: '100%',\n },\n {\n alignment: 'left', name: 'Schema', slug: 'schema', width: '50px',\n },\n {\n alignment: 'left', name: 'Render', slug: 'render', width: '50px',\n },\n {\n alignment: 'left', name: 'Valid', slug: 'valid', width: '50px',\n },\n ]\n const xl: PayloadDynamicTableColumnHeadData[] = [\n {\n alignment: 'left', name: 'Icon', slug: 'icon', width: '50px',\n },\n {\n alignment: 'left', name: 'Hash', slug: 'hash', width: '100%',\n },\n {\n alignment: 'left', name: 'Schema', slug: 'schema', width: '50px',\n },\n {\n alignment: 'left', name: 'Render', slug: 'render', width: '50px',\n },\n {\n alignment: 'left', name: 'Valid', slug: 'valid', width: '50px',\n },\n ]\n return {\n lg, md, sm, xl, xs,\n }\n}\n","import {\n FirstPage as FirstPageIcon, KeyboardArrowLeft, KeyboardArrowRight, LastPage as LastPageIcon,\n} from '@mui/icons-material'\nimport type { TableProps } from '@mui/material'\nimport {\n Alert,\n Box,\n IconButton,\n Table,\n TableBody,\n TableCell,\n TableFooter,\n TableHead,\n TablePagination,\n TableRow,\n Typography,\n useTheme,\n} from '@mui/material'\nimport { ThrownErrorBoundary } from '@xylabs/react-error'\nimport { useResetState } from '@xylabs/react-hooks'\nimport { useBreakpoint } from '@xylabs/react-shared'\nimport type { Payload } from '@xyo-network/payload-model'\nimport { usePayloadHashes } from '@xyo-network/react-shared'\nimport type { ReactNode } from 'react'\nimport React, { useMemo, useState } from 'react'\n\nimport { PayloadDynamicTableRow } from './DynamicTableRow.tsx'\nimport type { PayloadDynamicTableColumnConfig } from './PayloadDynamicTableColumnConfig.ts'\nimport { payloadDynamicTableColumnConfigDefaults } from './PayloadDynamicTableColumnConfig.ts'\n\nexport interface PayloadDynamicTableProps extends TableProps {\n archive?: string\n columns?: PayloadDynamicTableColumnConfig\n exploreDomain?: string\n onRowClick?: (value: Payload) => void\n payloads?: Payload[] | null\n rowsPerPage?: number\n}\n\ninterface TablePaginationActionsProps {\n count: number\n onPageChange: (event: React.MouseEvent<HTMLButtonElement>, newPage: number) => void\n page: number\n rowsPerPage: number\n}\n\nconst TablePaginationActions: React.FC<TablePaginationActionsProps> = (props) => {\n const theme = useTheme()\n const {\n count, page, rowsPerPage, onPageChange,\n } = props\n\n const handleFirstPageButtonClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n onPageChange(event, 0)\n }\n\n const handleBackButtonClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n onPageChange(event, page - 1)\n }\n\n const handleNextButtonClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n onPageChange(event, page + 1)\n }\n\n const handleLastPageButtonClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n onPageChange(event, Math.max(0, Math.ceil(count / rowsPerPage) - 1))\n }\n\n return (\n <Box sx={{ flexShrink: 0, ml: 2.5 }}>\n <IconButton onClick={handleFirstPageButtonClick} disabled={page === 0} aria-label=\"first page\">\n {theme.direction === 'rtl'\n ? <LastPageIcon />\n : <FirstPageIcon />}\n </IconButton>\n <IconButton onClick={handleBackButtonClick} disabled={page === 0} aria-label=\"previous page\">\n {theme.direction === 'rtl'\n ? <KeyboardArrowRight />\n : <KeyboardArrowLeft />}\n </IconButton>\n <IconButton onClick={handleNextButtonClick} disabled={page >= Math.ceil(count / rowsPerPage) - 1} aria-label=\"next page\">\n {theme.direction === 'rtl'\n ? <KeyboardArrowLeft />\n : <KeyboardArrowRight />}\n </IconButton>\n <IconButton onClick={handleLastPageButtonClick} disabled={page >= Math.ceil(count / rowsPerPage) - 1} aria-label=\"last page\">\n {theme.direction === 'rtl'\n ? <FirstPageIcon />\n : <LastPageIcon />}\n </IconButton>\n </Box>\n )\n}\n\nexport const PayloadDynamicTable: React.FC<PayloadDynamicTableProps> = ({\n archive,\n children,\n columns,\n exploreDomain,\n onRowClick,\n rowsPerPage: rowsPerPageProp = 10,\n payloads,\n ...props\n}) => {\n const breakPoint = useBreakpoint()\n const [page, setPage] = useState(0)\n const [rowsPerPage, setRowsPerPage] = useResetState(rowsPerPageProp)\n const payloadCount = payloads ? payloads.length : 0\n // Avoid a layout jump when reaching the last page with empty rows.\n const emptyRows = page > 0 ? Math.max(0, (1 + page) * rowsPerPage - payloadCount) : 0\n\n const pagedPayloads = useMemo(() => payloads?.slice(page * rowsPerPage, page * rowsPerPage + rowsPerPage), [payloads, page, rowsPerPage])\n\n const payloadPairs = usePayloadHashes(pagedPayloads)\n\n const handleChangePage = (event: React.MouseEvent<HTMLButtonElement> | null, newPage: number) => {\n setPage(newPage)\n }\n\n const handleChangeRowsPerPage = (event: React.ChangeEvent<HTMLInputElement | HTMLTextAreaElement>) => {\n setRowsPerPage(Number.parseInt(event.target.value, 10))\n setPage(0)\n }\n\n return breakPoint\n ? (\n <Table stickyHeader {...props}>\n <TableHead>\n <TableRow>\n {(columns ?? payloadDynamicTableColumnConfigDefaults())[breakPoint]?.map((column) => {\n return (\n <TableCell key={column.name} align={column.alignment ?? 'left'} width={column.width}>\n <Typography variant=\"body2\" noWrap>\n {column.name}\n </Typography>\n </TableCell>\n )\n })}\n </TableRow>\n </TableHead>\n <TableBody sx={{ overflowY: 'scroll ' }}>\n {payloadPairs?.map(([payload, hash]) => {\n return (\n <ThrownErrorBoundary\n boundaryName=\"PayloadTableBody\"\n key={hash}\n errorComponent={e => (\n <Alert severity=\"error\">\n Error Loading Payload:\n {' '}\n <Typography fontWeight=\"bold\">{e.message}</Typography>\n </Alert>\n )}\n >\n <PayloadDynamicTableRow\n archive={archive}\n onClick={\n onRowClick\n ? () => {\n onRowClick(payload)\n }\n : undefined\n }\n exploreDomain={exploreDomain}\n payload={payload}\n />\n </ThrownErrorBoundary>\n )\n })}\n {children}\n {emptyRows ? (Array.from({ length: emptyRows }).fill(<PayloadDynamicTableRow />) as ReactNode[]) : null}\n </TableBody>\n <TableFooter>\n <TableRow>\n <TablePagination\n rowsPerPageOptions={[5, 10, 25, { label: 'All', value: -1 }]}\n colSpan={5}\n count={payloadCount}\n rowsPerPage={rowsPerPage}\n page={page}\n SelectProps={{\n inputProps: { 'aria-label': 'rows per page' },\n native: true,\n }}\n onPageChange={handleChangePage}\n onRowsPerPageChange={handleChangeRowsPerPage}\n ActionsComponent={TablePaginationActions}\n />\n </TableRow>\n </TableFooter>\n </Table>\n )\n : null\n}\n","import type { TableColumnConfig, TableColumnNames } from './lib/index.ts'\n\nexport type PayloadTableColumnConfig = TableColumnConfig<PayloadTableColumnSlug>\n\nexport type PayloadTableColumnSlug = 'hash' | 'schema' | 'valid' | string\n\nexport const payloadColumnNames: TableColumnNames<PayloadTableColumnSlug> = {\n hash: 'Hash',\n schema: 'Schema',\n valid: 'Valid',\n}\n\nexport const payloadTableColumnConfigDefaults = (): PayloadTableColumnConfig => {\n const xs: PayloadTableColumnSlug[] = ['hash', 'schema', 'valid']\n const sm: PayloadTableColumnSlug[] = ['hash', 'schema', 'valid']\n const md: PayloadTableColumnSlug[] = ['hash', 'schema', 'valid']\n const lg: PayloadTableColumnSlug[] = ['hash', 'schema', 'valid']\n const xl: PayloadTableColumnSlug[] = ['hash', 'schema', 'valid']\n return {\n lg, md, sm, xl, xs,\n }\n}\n","import { type Hash, isDefinedNotNull } from '@xylabs/sdk-js'\nimport type { Payload } from '@xyo-network/payload-model'\nimport type { TableExProps } from '@xyo-network/react-table'\nimport { TableEx } from '@xyo-network/react-table'\nimport type { ComponentType } from 'react'\nimport React, { useMemo, useState } from 'react'\n\nimport type { PayloadTableColumnConfig, PayloadTableColumnSlug } from './PayloadTableColumnConfig.ts'\nimport { PayloadTableBody } from './TableBody.tsx'\nimport { PayloadTableFooter } from './TableFooter.tsx'\nimport { PayloadTableHead } from './TableHead.tsx'\nimport { TableRowNoData } from './TableRowNoData.tsx'\nimport type {\n PayloadTableBodyProps, PayloadTableFooterProps, PayloadTableHeadProps,\n} from './types/index.ts'\n\nexport interface PayloadTableProps extends TableExProps {\n PayloadTableBodyComponent?: ComponentType<PayloadTableBodyProps>\n PayloadTableFooterComponent?: ComponentType<PayloadTableFooterProps>\n PayloadTableHeadComponent?: ComponentType<PayloadTableHeadProps>\n /** @deprecated - archives are no longer used */\n archive?: string\n clickableFields?: PayloadTableColumnSlug[]\n columns?: PayloadTableColumnConfig\n /** Total number of payloads passed */\n count?: number\n /** @deprecated - use events to build links instead of passing props */\n exploreDomain?: string\n /** External trigger to fetch more payloads */\n fetchMorePayloads?: () => void\n loading?: boolean\n /** set number of schema parts to display starting from the end */\n maxSchemaDepth?: number\n onHashClick?: (value: Hash) => void\n onRowClick?: (value: Payload) => void\n payloads?: Payload[] | null\n rowsPerPage?: number\n}\n\nexport const PayloadTableWithRef: React.FC<PayloadTableProps> = (\n {\n clickableFields,\n onHashClick,\n onRowClick,\n fetchMorePayloads,\n rowsPerPage: rowsPerPageProp = 25,\n payloads,\n columns,\n PayloadTableHeadComponent = PayloadTableHead,\n PayloadTableBodyComponent = PayloadTableBody,\n PayloadTableFooterComponent = PayloadTableFooter,\n maxSchemaDepth,\n count = 0,\n loading = false,\n variant = 'scrollable',\n ...props\n },\n) => {\n const [page, setPage] = useState(0)\n const [rowsPerPage, setRowsPerPage] = useState(rowsPerPageProp)\n const [previousRowsPerPage, setPreviousRowsPerPage] = useState(rowsPerPageProp)\n if (rowsPerPageProp !== previousRowsPerPage) {\n setPreviousRowsPerPage(rowsPerPageProp)\n setRowsPerPage(rowsPerPageProp)\n }\n const [visiblePayloads, setVisiblePayloads] = useState<Payload[]>([])\n\n // Avoid a layout jump when reaching the last page with empty rows.\n const emptyRows = page > 0 ? Math.max(0, (1 + page) * rowsPerPage - count || 0) : 0\n\n // React to various prop changes to derive new visible payloads\n // count is needed to show initial payloads added async to the same payloads reference\n const [previousPayloads, setPreviousPayloads] = useState(payloads)\n if (payloads !== previousPayloads) {\n // If the payload reference changes, assume we have a new list and reset current page\n setPreviousPayloads(payloads)\n setPage(0)\n if (isDefinedNotNull(payloads)) {\n setVisiblePayloads(payloads.slice(page * rowsPerPage, page * rowsPerPage + rowsPerPage))\n }\n }\n\n const handleAdditionalPayloads = () => {\n if (fetchMorePayloads && payloads) {\n const buffer = rowsPerPage * 2\n const lastVisiblePayload = visiblePayloads?.at(-1)\n if (lastVisiblePayload) {\n const lastVisibleIndex = payloads?.indexOf(lastVisiblePayload)\n if (lastVisibleIndex !== undefined && payloads.length - (lastVisibleIndex + 1) <= buffer) {\n fetchMorePayloads()\n }\n }\n }\n }\n\n const handleChangePage = (_event: React.MouseEvent<HTMLButtonElement> | null, newPage: number) => {\n handleAdditionalPayloads()\n setPage(newPage)\n }\n\n const handleChangeRowsPerPage = (event: React.ChangeEvent<HTMLInputElement | HTMLTextAreaElement>) => {\n setRowsPerPage(Number.parseInt(event.target.value, 10))\n setPage(0)\n }\n\n const noResults = useMemo(() => {\n return !loading && (visiblePayloads.length === 0)\n }, [loading, visiblePayloads])\n\n return (\n <TableEx variant={variant} {...props}>\n <PayloadTableHeadComponent columns={columns} />\n <PayloadTableBodyComponent\n clickableFields={clickableFields}\n payloads={visiblePayloads}\n maxSchemaDepth={maxSchemaDepth}\n onRowClick={onRowClick}\n onHashClick={onHashClick}\n emptyRows={emptyRows}\n noResults={noResults}\n NoResultRowComponent={TableRowNoData}\n />\n <PayloadTableFooterComponent\n count={count}\n variant={variant}\n rowsPerPage={rowsPerPage}\n handleChangePage={handleChangePage}\n handleChangeRowsPerPage={handleChangeRowsPerPage}\n fetchMorePayloads={fetchMorePayloads}\n loading={loading}\n page={page}\n />\n </TableEx>\n )\n}\n\nPayloadTableWithRef.displayName = 'PayloadTable'\n\nexport const PayloadTable = PayloadTableWithRef\n","import {\n Alert, TableBody, Typography,\n} from '@mui/material'\nimport { ThrownErrorBoundary } from '@xylabs/react-error'\nimport { usePayloadHashes } from '@xyo-network/react-shared'\nimport type { ReactNode } from 'react'\nimport React from 'react'\n\nimport { PayloadTableRow } from './TableRow.tsx'\nimport type { PayloadTableBodyProps } from './types/index.ts'\n\nexport const PayloadTableBody: React.FC<PayloadTableBodyProps> = ({\n children,\n clickableFields,\n payloads,\n maxSchemaDepth,\n onHashClick,\n onRowClick,\n emptyRows,\n noResults,\n NoResultRowComponent,\n ...props\n}) => {\n const payloadPairs = usePayloadHashes(payloads)\n\n return (\n <TableBody {...props}>\n {noResults && NoResultRowComponent\n ? <NoResultRowComponent />\n : null}\n {payloadPairs?.map(([payload, hash]) => {\n return (\n <ThrownErrorBoundary\n boundaryName=\"PayloadTableBody\"\n key={hash}\n errorComponent={e => (\n <Alert severity=\"error\">\n Error Loading Payload:\n {' '}\n <Typography fontWeight=\"bold\">{e.message}</Typography>\n </Alert>\n )}\n >\n <PayloadTableRow\n clickableFields={clickableFields}\n maxSchemaDepth={maxSchemaDepth}\n onClick={\n onRowClick\n ? () => {\n onRowClick(payload)\n }\n : undefined\n }\n onHashClick={onHashClick}\n payload={payload}\n />\n </ThrownErrorBoundary>\n )\n })}\n {children}\n {emptyRows ? (Array.from({ length: emptyRows }).fill(<PayloadTableRow />) as ReactNode[]) : null}\n </TableBody>\n )\n}\n","import {\n CheckCircleOutlineRounded as CheckCircleOutlineRoundedIcon,\n ErrorOutlineRounded as ErrorOutlineRoundedIcon,\n WarningAmberRounded as WarningAmberRoundedIcon,\n} from '@mui/icons-material'\nimport type { TableRowProps } from '@mui/material'\nimport {\n alpha, Link, TableCell, TableRow, Typography,\n} from '@mui/material'\nimport { usePromise } from '@xylabs/react-promise'\nimport { useBreakpoint } from '@xylabs/react-shared'\nimport type { Hash } from '@xylabs/sdk-js'\nimport { isDefined } from '@xylabs/sdk-js'\nimport type { Payload } from '@xyo-network/payload-model'\nimport { PayloadValidator } from '@xyo-network/payload-validator'\nimport { useEvent } from '@xyo-network/react-event'\nimport { HashTableCell, usePayloadHash } from '@xyo-network/react-shared'\nimport React, { useMemo } from 'react'\n\nimport type { TableCellRenderer } from '../lib/index.ts'\nimport type { PayloadTableColumnConfig, PayloadTableColumnSlug } from './PayloadTableColumnConfig.ts'\nimport { payloadTableColumnConfigDefaults } from './PayloadTableColumnConfig.ts'\n\nexport interface PayloadTableRowProps extends TableRowProps {\n /** @deprecated - archives are no longer used */\n archive?: string\n clickableFields?: PayloadTableColumnSlug[]\n columns?: PayloadTableColumnConfig\n /** @deprecated - use event listeners instead of link building via props */\n exploreDomain?: string\n maxSchemaDepth?: number\n network?: string\n onHashClick?: (value: Hash) => void\n payload?: Payload\n}\n\nexport const PayloadTableRow: React.FC<PayloadTableRowProps> = ({\n clickableFields,\n columns,\n maxSchemaDepth,\n network: networkProp,\n onHashClick,\n payload,\n ...props\n}) => {\n const breakPoint = useBreakpoint()\n const payloadHash = usePayloadHash(payload)\n const [anchorRef, dispatch] = useEvent<HTMLAnchorElement>()\n const [errors = []] = usePromise(async () => (payload ? await new PayloadValidator(payload).validate() : undefined), [payload])\n const isValid = errors.length === 0\n\n const hash: TableCellRenderer = props => (\n <HashTableCell\n dataType=\"payload\"\n key=\"hash\"\n onHashClick={onHashClick}\n value={payloadHash}\n width=\"100%\"\n {...props}\n >\n {isDefined(payloadHash) && (\n <>\n {clickableFields?.includes('hash')\n ? (\n <Link onClick={() => dispatch('hash', 'click', payloadHash)} ref={anchorRef} sx={{ cursor: 'pointer' }}>{payloadHash}</Link>\n )\n : payloadHash}\n </>\n )}\n </HashTableCell>\n )\n\n const reduceSchemaDepth = (schema?: string, maxSchemaDepth?: number) => {\n if (isDefined(maxSchemaDepth)) {\n const parts = schema?.split('.') ?? []\n const partsToRemove = Math.max(parts.length - maxSchemaDepth, 0)\n if (partsToRemove > 0) {\n return (\n <>\n <>…</>\n {\n\n `${parts.slice(partsToRemove).reduce((previousValue, part) => previousValue + '.' + part, '')}`\n }\n </>\n )\n }\n }\n return schema\n }\n\n const schema: TableCellRenderer = props => (\n <TableCell title={payload?.schema} key=\"payloads\" align=\"center\" {...props}>\n <Typography fontFamily=\"monospace\" variant=\"body2\" noWrap>\n {clickableFields?.includes('schema')\n ? (\n <Link sx={{ cursor: 'pointer' }}>{reduceSchemaDepth(payload?.schema, maxSchemaDepth)}</Link>\n )\n : reduceSchemaDepth(payload?.schema, maxSchemaDepth)}\n\n </Typography>\n </TableCell>\n )\n\n const valid: TableCellRenderer = props => (\n <TableCell key=\"valid\" align=\"center\" {...props}>\n {isValid === undefined && payload != undefined\n ? <WarningAmberRoundedIcon fontSize=\"small\" color=\"warning\" />\n : isValid === true\n ? <CheckCircleOutlineRoundedIcon fontSize=\"small\" color=\"success\" />\n : isValid === false\n ? <ErrorOutlineRoundedIcon color=\"error\" fontSize=\"small\" />\n // to keep row height consistent when no data provided, may need fix later\n : <ErrorOutlineRoundedIcon sx={{ color: alpha('#fff', 0) }} fontSize=\"small\" />}\n </TableCell>\n )\n\n const tableCells: Record<PayloadTableColumnSlug, TableCellRenderer> = {\n hash,\n schema,\n valid,\n }\n\n const columnsMemo = useMemo(() => columns ?? payloadTableColumnConfigDefaults(), [columns])\n\n return isDefined(breakPoint)\n ? (\n <TableRow style={{ maxWidth: '100vw' }} {...props}>\n {columnsMemo[breakPoint]?.map((column) => {\n return tableCells[column]({})\n })}\n </TableRow>\n )\n : null\n}\n","import {\n styled, TablePagination, TableRow,\n} from '@mui/material'\nimport { TableFooterEx } from '@xyo-network/react-table'\nimport React from 'react'\n\nimport { TablePaginationActions } from './TablePagination.tsx'\nimport type { PayloadTableFooterProps } from './types/index.ts'\n\nexport const PayloadTableFooter: React.FC<PayloadTableFooterProps> = ({\n count,\n variant,\n page,\n rowsPerPage,\n handleChangePage,\n handleChangeRowsPerPage,\n fetchMorePayloads,\n loading,\n}) => (\n <TableFooterEx variant={variant}>\n <TableRow>\n <StyledTablePagination\n rowsPerPageOptions={[5, 10, 25, { label: 'All', value: -1 }]}\n count={count ?? 0}\n rowsPerPage={rowsPerPage ?? 10}\n page={page ?? 0}\n SelectProps={{\n inputProps: { 'aria-label': 'rows per page' },\n native: true,\n }}\n onPageChange={handleChangePage ?? (() => { /* noop */ })}\n onRowsPerPageChange={handleChangeRowsPerPage ?? (() => { /* noop */ })}\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ActionsComponent={(props: any) => <TablePaginationActions enableNextPage={!!fetchMorePayloads} loading={loading} {...props} />}\n />\n </TableRow>\n </TableFooterEx>\n)\n\nconst StyledTablePagination = styled(TablePagination)(({ theme }) => ({\n '& > .MuiToolbar-root': { paddingLeft: theme.spacing(1) },\n 'borderTop': '1px solid',\n 'borderTopColor': theme.vars.palette.divider,\n}))\n","import {\n FirstPage as FirstPageIcon, KeyboardArrowLeft, KeyboardArrowRight, LastPage as LastPageIcon,\n} from '@mui/icons-material'\nimport {\n Box, CircularProgress, IconButton, useTheme,\n} from '@mui/material'\nimport { useEvent } from '@xyo-network/react-event'\nimport React from 'react'\n\nimport type { PaginationNouns } from './types/index.ts'\n\nexport interface TablePaginationActionsProps {\n count: number\n enableNextPage?: boolean\n loading?: boolean\n onPageChange: (event: React.MouseEvent<HTMLButtonElement>, newPage: number) => void\n page: number\n rowsPerPage: number\n}\n\nexport function TablePaginationActions({\n count, enableNextPage, loading, onPageChange, page, rowsPerPage,\n}: Readonly<TablePaginationActionsProps>) {\n const theme = useTheme()\n const [paginationRef, paginationDispatch] = useEvent<HTMLButtonElement, PaginationNouns>()\n\n const handleFirstPageButtonClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n paginationDispatch('firstPage', 'click', 'true')\n onPageChange(event, 0)\n }\n\n const handleBackButtonClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n paginationDispatch('previousPage', 'click', (page - 1)?.toString())\n onPageChange(event, page - 1)\n }\n\n const handleNextButtonClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n paginationDispatch('nextPage', 'click', (page + 1)?.toString())\n onPageChange(event, page + 1)\n }\n\n const handleLastPageButtonClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n paginationDispatch('lastPage', 'click', 'true')\n onPageChange(event, Math.max(0, Math.ceil(count / rowsPerPage) - 1))\n }\n\n return (\n <>\n {loading\n ? (\n <CircularProgress\n size=\"small\"\n sx={{\n height: theme.spacing(2), position: 'absolute', width: theme.spacing(2),\n }}\n />\n )\n : null}\n <Box sx={{ flexShrink: 0, ml: 2.5 }}>\n <IconButton onClick={handleFirstPageButtonClick} disabled={page === 0} aria-label=\"first page\">\n {theme.direction === 'rtl'\n ? <LastPageIcon />\n : <FirstPageIcon />}\n </IconButton>\n <IconButton ref={paginationRef} onClick={handleBackButtonClick} disabled={page === 0} aria-label=\"previous page\">\n {theme.direction === 'rtl'\n ? <KeyboardArrowRight />\n : <KeyboardArrowLeft />}\n </IconButton>\n <IconButton\n ref={paginationRef}\n onClick={handleNextButtonClick}\n disabled={!enableNextPage && page >= Math.ceil(count / rowsPerPage) - 1}\n aria-label=\"next page\"\n >\n {theme.direction === 'rtl'\n ? <KeyboardArrowLeft />\n : <KeyboardArrowRight />}\n </IconButton>\n <IconButton onClick={handleLastPageButtonClick} disabled={page >= Math.ceil(count / rowsPerPage) - 1} aria-label=\"last page\">\n {theme.direction === 'rtl'\n ? <FirstPageIcon />\n : <LastPageIcon />}\n </IconButton>\n </Box>\n </>\n )\n}\n","import {\n TableCell, TableHead, TableRow, Typography,\n} from '@mui/material'\nimport { useBreakpoint } from '@xylabs/react-shared'\nimport React, { useMemo } from 'react'\n\nimport type { PayloadTableColumnSlug } from './PayloadTableColumnConfig.ts'\nimport { payloadColumnNames, payloadTableColumnConfigDefaults } from './PayloadTableColumnConfig.ts'\nimport type { PayloadTableHeadProps } from './types/index.ts'\n\nexport const PayloadTableHead: React.FC<PayloadTableHeadProps<PayloadTableColumnSlug>> = ({ columns, ...props }) => {\n const breakPoint = useBreakpoint()\n const columnsMemo = useMemo(() => columns ?? payloadTableColumnConfigDefaults(), [columns])\n return (\n <TableHead {...props}>\n <TableRow>\n {breakPoint\n ? columnsMemo[breakPoint]?.map((column, index) => {\n return (\n <TableCell key={column} width={index === 0 ? '100%' : undefined} align={index === 0 ? 'left' : 'center'}>\n <Typography variant=\"body2\" noWrap>\n {payloadColumnNames[column]}\n </Typography>\n </TableCell>\n )\n })\n : null}\n </TableRow>\n </TableHead>\n )\n}\n","import type { TableRowProps, TypographyProps } from '@mui/material'\nimport {\n styled, TableCell, TableRow, Typography,\n} from '@mui/material'\nimport React from 'react'\n\nexport interface TableRowNoDataProps extends TableRowProps {\n additionalCells?: number\n hideBorder?: boolean\n typographyProps?: TypographyProps\n}\n\nexport const TableRowNoData: React.FC<TableRowNoDataProps> = ({\n additionalCells, hideBorder = false, typographyProps, ...props\n}) => {\n return (\n <TableRow {...props}>\n <StyledTableCell hideBorder={hideBorder}>\n <Typography variant=\"body2\" {...typographyProps}>\n No Data To Display...\n </Typography>\n </StyledTableCell>\n {additionalCells\n ? Array.from({ length: additionalCells })\n .fill(null)\n // eslint-disable-next-line react-x/no-array-index-key\n .map((_fill, index) => <StyledTableCell key={`empty-row-${index}`} hideBorder={hideBorder} />)\n : null}\n </TableRow>\n )\n}\n\ninterface StyledTableCellProps {\n hideBorder?: boolean\n}\n\nconst StyledTableCell = styled(TableCell, {\n name: 'StyledTableCell',\n shouldForwardProp: (prop: string) => prop !== 'hideBorder',\n})<StyledTableCellProps>(({ hideBorder }) => ({ ...(hideBorder && { border: 'none' }) }))\n"],"mappings":"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","names":["props","TableCell","TableRow","Typography","useBreakpoint","useMemo","jsx","useBreakpoint","useMemo","TableRow","TableCell","Typography","useMemo","useState","Alert","TableBody","Typography","ThrownErrorBoundary","usePayloadHashes","CheckCircleOutlineRoundedIcon","ErrorOutlineRoundedIcon","WarningAmberRoundedIcon","TableCell","TableRow","Typography","usePromise","useBreakpoint","PayloadValidator","HashTableCell","usePayloadHash","useMemo","jsx","jsxs","useBreakpoint","usePayloadHash","usePromise","PayloadValidator","props","HashTableCell","schema","maxSchemaDepth","TableCell","Typography","WarningAmberRoundedIcon","CheckCircleOutlineRoundedIcon","ErrorOutlineRoundedIcon","useMemo","TableRow","jsx","jsxs","usePayloadHashes","TableBody","ThrownErrorBoundary","Alert","Typography","TablePagination","TableRow","FirstPageIcon","KeyboardArrowLeft","KeyboardArrowRight","LastPageIcon","Box","IconButton","useTheme","useEvent","Fragment","jsx","jsxs","TablePaginationActions","jsx","TableRow","TablePaginationActions","TablePagination","TableCell","TableHead","TableRow","Typography","useBreakpoint","useMemo","jsx","useBreakpoint","useMemo","TableHead","TableRow","TableCell","Typography","styled","TableCell","TableRow","Typography","jsx","jsxs","jsx","jsxs","useState","useMemo"]}
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/components/DynamicTable/DynamicTableRow.tsx", "../../src/components/DynamicTable/PayloadDynamicTableColumnConfig.ts", "../../src/components/DynamicTable/Table.tsx", "../../src/components/Table/PayloadTableColumnConfig.ts", "../../src/components/Table/Table.tsx", "../../src/components/Table/TableBody.tsx", "../../src/components/Table/TableRow.tsx", "../../src/components/Table/TableFooter.tsx", "../../src/components/Table/TablePagination.tsx", "../../src/components/Table/TableHead.tsx", "../../src/components/Table/TableRowNoData.tsx"],
|
|
4
|
+
"sourcesContent": ["import {\n CheckCircleOutlineRounded as CheckCircleOutlineRoundedIcon,\n ErrorOutlineRounded as ErrorOutlineRoundedIcon,\n WarningAmberRounded as WarningAmberRoundedIcon,\n} from '@mui/icons-material'\nimport type {\n AvatarProps, TableCellProps, TableRowProps,\n} from '@mui/material'\nimport {\n TableCell, TableRow, Typography,\n} from '@mui/material'\nimport { usePromise } from '@xylabs/react-promise'\nimport { useBreakpoint } from '@xylabs/react-shared'\nimport { PayloadBuilder } from '@xyo-network/payload-builder'\nimport type { Payload } from '@xyo-network/payload-model'\nimport { PayloadValidator } from '@xyo-network/payload-validator'\nimport { useNetwork } from '@xyo-network/react-network'\nimport type { PayloadRenderProps } from '@xyo-network/react-payload-plugin'\nimport { usePayloadRenderPluginResolver } from '@xyo-network/react-payload-plugin-resolver'\nimport { HashTableCell, usePayloadHash } from '@xyo-network/react-shared'\nimport type { ComponentType } from 'react'\nimport React, { useMemo } from 'react'\n\nimport type { TableCellRenderer } from '../lib/index.ts'\nimport type {\n PayloadDynamicTableColumnConfig,\n PayloadDynamicTableColumnSlug,\n} from './PayloadDynamicTableColumnConfig.ts'\nimport { payloadDynamicTableColumnConfigDefaults } from './PayloadDynamicTableColumnConfig.ts'\n\nexport interface PayloadDynamicTableRowProps extends TableRowProps {\n /** @deprecated - archives are no longer used */\n archive?: string\n columns?: PayloadDynamicTableColumnConfig\n /** @deprecated - use event listeners instead of link building via props */\n exploreDomain?: string\n network?: string\n payload?: Payload & { sources?: string[] }\n}\n\nexport const PayloadDynamicTableRow: React.FC<PayloadDynamicTableRowProps> = ({\n columns,\n network: networkProp,\n payload,\n ...props\n}) => {\n const breakPoint = useBreakpoint()\n const payloadHash = usePayloadHash(payload)\n const { network } = useNetwork()\n const { resolver } = usePayloadRenderPluginResolver()\n const [validationErrors = []] = usePromise(async () => (payload ? await new PayloadValidator(payload).validate() : undefined), [payload])\n const isValid = validationErrors.length === 0\n const payloadFieldCount = payload ? Object.keys(PayloadBuilder.hashableFields(payload)).length : 0\n\n const hash: TableCellRenderer = props => (\n <HashTableCell\n key=\"hash\"\n align=\"left\"\n value={payloadHash}\n dataType=\"payload\"\n network={networkProp ?? network?.slug}\n {...props}\n />\n )\n\n const schema: TableCellRenderer = props => (\n <TableCell key=\"payloads\" align=\"left\" {...props}>\n <Typography\n variant=\"body2\"\n noWrap\n sx={{ fontFamily: 'monospace' }}\n >\n {payload?.schema}\n </Typography>\n </TableCell>\n )\n\n const details: TableCellRenderer = props => (\n <TableCell key=\"payloads\" align=\"left\" {...props}>\n <Typography\n variant=\"body2\"\n noWrap\n sx={{ fontFamily: 'monospace' }}\n >\n {payloadFieldCount}\n </Typography>\n </TableCell>\n )\n\n const render: TableCellRenderer = (props) => {\n const Render: ComponentType<PayloadRenderProps & TableCellProps> | undefined\n = payload ? resolver?.resolve(payload)?.components.table.cell : undefined\n return Render ? <Render payload={payload} {...props} /> : <TableCell key=\"payloads\" align=\"left\" {...props}></TableCell>\n }\n\n const icon: TableCellRenderer = (props) => {\n const Avatar: ComponentType<PayloadRenderProps & AvatarProps> | undefined\n = payload ? resolver?.resolve(payload)?.components.avatar.image : undefined\n\n return (\n <TableCell key=\"payloads\" align=\"left\" {...props}>\n {Avatar\n ? <Avatar payload={payload} />\n : null}\n </TableCell>\n )\n }\n\n const valid: TableCellRenderer = props => (\n <TableCell key=\"valid\" align=\"center\" {...props}>\n {isValid === undefined && payload != undefined\n ? <WarningAmberRoundedIcon fontSize=\"small\" color=\"warning\" />\n : isValid === true\n ? <CheckCircleOutlineRoundedIcon fontSize=\"small\" color=\"success\" />\n : isValid === false\n ? <ErrorOutlineRoundedIcon color=\"error\" fontSize=\"small\" />\n // nbsp to keep row height consistent even when no data is provided for the row\n : <Typography> </Typography>}\n </TableCell>\n )\n\n const tableCells: Record<PayloadDynamicTableColumnSlug, TableCellRenderer> = {\n details,\n hash,\n icon,\n render,\n schema,\n valid,\n }\n\n const columnsMemo = useMemo(() => columns ?? payloadDynamicTableColumnConfigDefaults(), [columns])\n\n return breakPoint\n ? (\n <TableRow style={{ maxWidth: '100vw' }} {...props}>\n {columnsMemo[breakPoint]?.map((column) => {\n return column.slug ? tableCells[column.slug]({}) : null\n })}\n </TableRow>\n )\n : null\n}\n", "export type PayloadDynamicTableColumnSlug = 'hash' | 'schema' | 'valid' | 'details' | 'render' | 'icon'\n\nexport interface PayloadDynamicTableColumnHeadData {\n alignment?: 'left' | 'center' | 'right'\n name?: string\n slug?: 'hash' | 'schema' | 'valid' | 'details' | 'render' | 'icon'\n width?: string | number\n}\n\nexport interface PayloadDynamicTableColumnConfig {\n xs?: PayloadDynamicTableColumnHeadData[]\n // eslint-disable-next-line @typescript-eslint/member-ordering\n sm?: PayloadDynamicTableColumnHeadData[]\n // eslint-disable-next-line @typescript-eslint/member-ordering\n md?: PayloadDynamicTableColumnHeadData[]\n // eslint-disable-next-line @typescript-eslint/member-ordering\n lg?: PayloadDynamicTableColumnHeadData[]\n xl?: PayloadDynamicTableColumnHeadData[]\n}\n\nexport const payloadDynamicTableColumnConfigDefaults = (): PayloadDynamicTableColumnConfig => {\n const xs: PayloadDynamicTableColumnHeadData[] = [\n {\n alignment: 'left', name: 'Hash', slug: 'hash', width: '100%',\n },\n {\n alignment: 'left', name: 'Schema', slug: 'schema', width: '50px',\n },\n {\n alignment: 'left', name: 'Valid', slug: 'valid', width: '50px',\n },\n ]\n const sm: PayloadDynamicTableColumnHeadData[] = [\n {\n alignment: 'left', name: 'Icon', slug: 'icon', width: '50px',\n },\n {\n alignment: 'left', name: 'Hash', slug: 'hash', width: '100%',\n },\n {\n alignment: 'left', name: 'Schema', slug: 'schema', width: '50px',\n },\n {\n alignment: 'left', name: 'Valid', slug: 'valid', width: '50px',\n },\n ]\n const md: PayloadDynamicTableColumnHeadData[] = [\n {\n alignment: 'left', name: 'Icon', slug: 'icon', width: '50px',\n },\n {\n alignment: 'left', name: 'Hash', slug: 'hash', width: '100%',\n },\n {\n alignment: 'left', name: 'Schema', slug: 'schema', width: '50px',\n },\n {\n alignment: 'left', name: 'Valid', slug: 'valid', width: '50px',\n },\n ]\n const lg: PayloadDynamicTableColumnHeadData[] = [\n {\n alignment: 'left', name: 'Icon', slug: 'icon', width: '50px',\n },\n {\n alignment: 'left', name: 'Hash', slug: 'hash', width: '100%',\n },\n {\n alignment: 'left', name: 'Schema', slug: 'schema', width: '50px',\n },\n {\n alignment: 'left', name: 'Render', slug: 'render', width: '50px',\n },\n {\n alignment: 'left', name: 'Valid', slug: 'valid', width: '50px',\n },\n ]\n const xl: PayloadDynamicTableColumnHeadData[] = [\n {\n alignment: 'left', name: 'Icon', slug: 'icon', width: '50px',\n },\n {\n alignment: 'left', name: 'Hash', slug: 'hash', width: '100%',\n },\n {\n alignment: 'left', name: 'Schema', slug: 'schema', width: '50px',\n },\n {\n alignment: 'left', name: 'Render', slug: 'render', width: '50px',\n },\n {\n alignment: 'left', name: 'Valid', slug: 'valid', width: '50px',\n },\n ]\n return {\n lg, md, sm, xl, xs,\n }\n}\n", "import {\n FirstPage as FirstPageIcon, KeyboardArrowLeft, KeyboardArrowRight, LastPage as LastPageIcon,\n} from '@mui/icons-material'\nimport type { TableProps } from '@mui/material'\nimport {\n Alert,\n Box,\n IconButton,\n Table,\n TableBody,\n TableCell,\n TableFooter,\n TableHead,\n TablePagination,\n TableRow,\n Typography,\n useTheme,\n} from '@mui/material'\nimport { ThrownErrorBoundary } from '@xylabs/react-error'\nimport { useResetState } from '@xylabs/react-hooks'\nimport { useBreakpoint } from '@xylabs/react-shared'\nimport type { Payload } from '@xyo-network/payload-model'\nimport { usePayloadHashes } from '@xyo-network/react-shared'\nimport type { ReactNode } from 'react'\nimport React, { useMemo, useState } from 'react'\n\nimport { PayloadDynamicTableRow } from './DynamicTableRow.tsx'\nimport type { PayloadDynamicTableColumnConfig } from './PayloadDynamicTableColumnConfig.ts'\nimport { payloadDynamicTableColumnConfigDefaults } from './PayloadDynamicTableColumnConfig.ts'\n\nexport interface PayloadDynamicTableProps extends TableProps {\n archive?: string\n columns?: PayloadDynamicTableColumnConfig\n exploreDomain?: string\n onRowClick?: (value: Payload) => void\n payloads?: Payload[] | null\n rowsPerPage?: number\n}\n\ninterface TablePaginationActionsProps {\n count: number\n onPageChange: (event: React.MouseEvent<HTMLButtonElement>, newPage: number) => void\n page: number\n rowsPerPage: number\n}\n\nconst TablePaginationActions: React.FC<TablePaginationActionsProps> = (props) => {\n const theme = useTheme()\n const {\n count, page, rowsPerPage, onPageChange,\n } = props\n\n const handleFirstPageButtonClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n onPageChange(event, 0)\n }\n\n const handleBackButtonClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n onPageChange(event, page - 1)\n }\n\n const handleNextButtonClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n onPageChange(event, page + 1)\n }\n\n const handleLastPageButtonClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n onPageChange(event, Math.max(0, Math.ceil(count / rowsPerPage) - 1))\n }\n\n return (\n <Box sx={{ flexShrink: 0, ml: 2.5 }}>\n <IconButton onClick={handleFirstPageButtonClick} disabled={page === 0} aria-label=\"first page\">\n {theme.direction === 'rtl'\n ? <LastPageIcon />\n : <FirstPageIcon />}\n </IconButton>\n <IconButton onClick={handleBackButtonClick} disabled={page === 0} aria-label=\"previous page\">\n {theme.direction === 'rtl'\n ? <KeyboardArrowRight />\n : <KeyboardArrowLeft />}\n </IconButton>\n <IconButton onClick={handleNextButtonClick} disabled={page >= Math.ceil(count / rowsPerPage) - 1} aria-label=\"next page\">\n {theme.direction === 'rtl'\n ? <KeyboardArrowLeft />\n : <KeyboardArrowRight />}\n </IconButton>\n <IconButton onClick={handleLastPageButtonClick} disabled={page >= Math.ceil(count / rowsPerPage) - 1} aria-label=\"last page\">\n {theme.direction === 'rtl'\n ? <FirstPageIcon />\n : <LastPageIcon />}\n </IconButton>\n </Box>\n )\n}\n\nexport const PayloadDynamicTable: React.FC<PayloadDynamicTableProps> = ({\n archive,\n children,\n columns,\n exploreDomain,\n onRowClick,\n rowsPerPage: rowsPerPageProp = 10,\n payloads,\n ...props\n}) => {\n const breakPoint = useBreakpoint()\n const [page, setPage] = useState(0)\n const [rowsPerPage, setRowsPerPage] = useResetState(rowsPerPageProp)\n const payloadCount = payloads ? payloads.length : 0\n // Avoid a layout jump when reaching the last page with empty rows.\n const emptyRows = page > 0 ? Math.max(0, (1 + page) * rowsPerPage - payloadCount) : 0\n\n const pagedPayloads = useMemo(() => payloads?.slice(page * rowsPerPage, page * rowsPerPage + rowsPerPage), [payloads, page, rowsPerPage])\n\n const payloadPairs = usePayloadHashes(pagedPayloads)\n\n const handleChangePage = (event: React.MouseEvent<HTMLButtonElement> | null, newPage: number) => {\n setPage(newPage)\n }\n\n const handleChangeRowsPerPage = (event: React.ChangeEvent<HTMLInputElement | HTMLTextAreaElement>) => {\n setRowsPerPage(Number.parseInt(event.target.value, 10))\n setPage(0)\n }\n\n return breakPoint\n ? (\n <Table stickyHeader {...props}>\n <TableHead>\n <TableRow>\n {(columns ?? payloadDynamicTableColumnConfigDefaults())[breakPoint]?.map((column) => {\n return (\n <TableCell\n key={column.name}\n align={column.alignment ?? 'left'}\n sx={{ width: column.width }}\n >\n <Typography variant=\"body2\" noWrap>\n {column.name}\n </Typography>\n </TableCell>\n )\n })}\n </TableRow>\n </TableHead>\n <TableBody sx={{ overflowY: 'scroll ' }}>\n {payloadPairs?.map(([payload, hash]) => {\n return (\n <ThrownErrorBoundary\n boundaryName=\"PayloadTableBody\"\n key={hash}\n errorComponent={e => (\n <Alert severity=\"error\">\n Error Loading Payload:\n {' '}\n <Typography sx={{ fontWeight: 'bold' }}>\n {e.message}\n </Typography>\n </Alert>\n )}\n >\n <PayloadDynamicTableRow\n archive={archive}\n onClick={\n onRowClick\n ? () => {\n onRowClick(payload)\n }\n : undefined\n }\n exploreDomain={exploreDomain}\n payload={payload}\n />\n </ThrownErrorBoundary>\n )\n })}\n {children}\n {emptyRows ? (Array.from({ length: emptyRows }).fill(<PayloadDynamicTableRow />) as ReactNode[]) : null}\n </TableBody>\n <TableFooter>\n <TableRow>\n <TablePagination\n rowsPerPageOptions={[5, 10, 25, { label: 'All', value: -1 }]}\n colSpan={5}\n count={payloadCount}\n rowsPerPage={rowsPerPage}\n page={page}\n onPageChange={handleChangePage}\n onRowsPerPageChange={handleChangeRowsPerPage}\n ActionsComponent={TablePaginationActions}\n slotProps={{\n select: {\n inputProps: { 'aria-label': 'rows per page' },\n native: true,\n },\n }}\n />\n </TableRow>\n </TableFooter>\n </Table>\n )\n : null\n}\n", "import type { TableColumnConfig, TableColumnNames } from './lib/index.ts'\n\nexport type PayloadTableColumnConfig = TableColumnConfig<PayloadTableColumnSlug>\n\nexport type PayloadTableColumnSlug = 'hash' | 'schema' | 'valid' | string\n\nexport const payloadColumnNames: TableColumnNames<PayloadTableColumnSlug> = {\n hash: 'Hash',\n schema: 'Schema',\n valid: 'Valid',\n}\n\nexport const payloadTableColumnConfigDefaults = (): PayloadTableColumnConfig => {\n const xs: PayloadTableColumnSlug[] = ['hash', 'schema', 'valid']\n const sm: PayloadTableColumnSlug[] = ['hash', 'schema', 'valid']\n const md: PayloadTableColumnSlug[] = ['hash', 'schema', 'valid']\n const lg: PayloadTableColumnSlug[] = ['hash', 'schema', 'valid']\n const xl: PayloadTableColumnSlug[] = ['hash', 'schema', 'valid']\n return {\n lg, md, sm, xl, xs,\n }\n}\n", "import { type Hash, isDefinedNotNull } from '@xylabs/sdk-js'\nimport type { Payload } from '@xyo-network/payload-model'\nimport type { TableExProps } from '@xyo-network/react-table'\nimport { TableEx } from '@xyo-network/react-table'\nimport type { ComponentType } from 'react'\nimport React, { useMemo, useState } from 'react'\n\nimport type { PayloadTableColumnConfig, PayloadTableColumnSlug } from './PayloadTableColumnConfig.ts'\nimport { PayloadTableBody } from './TableBody.tsx'\nimport { PayloadTableFooter } from './TableFooter.tsx'\nimport { PayloadTableHead } from './TableHead.tsx'\nimport { TableRowNoData } from './TableRowNoData.tsx'\nimport type {\n PayloadTableBodyProps, PayloadTableFooterProps, PayloadTableHeadProps,\n} from './types/index.ts'\n\nexport interface PayloadTableProps extends TableExProps {\n PayloadTableBodyComponent?: ComponentType<PayloadTableBodyProps>\n PayloadTableFooterComponent?: ComponentType<PayloadTableFooterProps>\n PayloadTableHeadComponent?: ComponentType<PayloadTableHeadProps>\n /** @deprecated - archives are no longer used */\n archive?: string\n clickableFields?: PayloadTableColumnSlug[]\n columns?: PayloadTableColumnConfig\n /** Total number of payloads passed */\n count?: number\n /** @deprecated - use events to build links instead of passing props */\n exploreDomain?: string\n /** External trigger to fetch more payloads */\n fetchMorePayloads?: () => void\n loading?: boolean\n /** set number of schema parts to display starting from the end */\n maxSchemaDepth?: number\n onHashClick?: (value: Hash) => void\n onRowClick?: (value: Payload) => void\n payloads?: Payload[] | null\n rowsPerPage?: number\n}\n\nexport const PayloadTableWithRef: React.FC<PayloadTableProps> = (\n {\n clickableFields,\n onHashClick,\n onRowClick,\n fetchMorePayloads,\n rowsPerPage: rowsPerPageProp = 25,\n payloads,\n columns,\n PayloadTableHeadComponent = PayloadTableHead,\n PayloadTableBodyComponent = PayloadTableBody,\n PayloadTableFooterComponent = PayloadTableFooter,\n maxSchemaDepth,\n count = 0,\n loading = false,\n variant = 'scrollable',\n ...props\n },\n) => {\n const [page, setPage] = useState(0)\n const [rowsPerPage, setRowsPerPage] = useState(rowsPerPageProp)\n const [previousRowsPerPage, setPreviousRowsPerPage] = useState(rowsPerPageProp)\n if (rowsPerPageProp !== previousRowsPerPage) {\n setPreviousRowsPerPage(rowsPerPageProp)\n setRowsPerPage(rowsPerPageProp)\n }\n const [visiblePayloads, setVisiblePayloads] = useState<Payload[]>([])\n\n // Avoid a layout jump when reaching the last page with empty rows.\n const emptyRows = page > 0 ? Math.max(0, (1 + page) * rowsPerPage - count || 0) : 0\n\n // React to various prop changes to derive new visible payloads\n // count is needed to show initial payloads added async to the same payloads reference\n const [previousPayloads, setPreviousPayloads] = useState(payloads)\n if (payloads !== previousPayloads) {\n // If the payload reference changes, assume we have a new list and reset current page\n setPreviousPayloads(payloads)\n setPage(0)\n if (isDefinedNotNull(payloads)) {\n setVisiblePayloads(payloads.slice(page * rowsPerPage, page * rowsPerPage + rowsPerPage))\n }\n }\n\n const handleAdditionalPayloads = () => {\n if (fetchMorePayloads && payloads) {\n const buffer = rowsPerPage * 2\n const lastVisiblePayload = visiblePayloads?.at(-1)\n if (lastVisiblePayload) {\n const lastVisibleIndex = payloads?.indexOf(lastVisiblePayload)\n if (lastVisibleIndex !== undefined && payloads.length - (lastVisibleIndex + 1) <= buffer) {\n fetchMorePayloads()\n }\n }\n }\n }\n\n const handleChangePage = (_event: React.MouseEvent<HTMLButtonElement> | null, newPage: number) => {\n handleAdditionalPayloads()\n setPage(newPage)\n }\n\n const handleChangeRowsPerPage = (event: React.ChangeEvent<HTMLInputElement | HTMLTextAreaElement>) => {\n setRowsPerPage(Number.parseInt(event.target.value, 10))\n setPage(0)\n }\n\n const noResults = useMemo(() => {\n return !loading && (visiblePayloads.length === 0)\n }, [loading, visiblePayloads])\n\n return (\n <TableEx variant={variant} {...props}>\n <PayloadTableHeadComponent columns={columns} />\n <PayloadTableBodyComponent\n clickableFields={clickableFields}\n payloads={visiblePayloads}\n maxSchemaDepth={maxSchemaDepth}\n onRowClick={onRowClick}\n onHashClick={onHashClick}\n emptyRows={emptyRows}\n noResults={noResults}\n NoResultRowComponent={TableRowNoData}\n />\n <PayloadTableFooterComponent\n count={count}\n variant={variant}\n rowsPerPage={rowsPerPage}\n handleChangePage={handleChangePage}\n handleChangeRowsPerPage={handleChangeRowsPerPage}\n fetchMorePayloads={fetchMorePayloads}\n loading={loading}\n page={page}\n />\n </TableEx>\n )\n}\n\nPayloadTableWithRef.displayName = 'PayloadTable'\n\nexport const PayloadTable = PayloadTableWithRef\n", "import {\n Alert, TableBody, Typography,\n} from '@mui/material'\nimport { ThrownErrorBoundary } from '@xylabs/react-error'\nimport { usePayloadHashes } from '@xyo-network/react-shared'\nimport type { ReactNode } from 'react'\nimport React from 'react'\n\nimport { PayloadTableRow } from './TableRow.tsx'\nimport type { PayloadTableBodyProps } from './types/index.ts'\n\nexport const PayloadTableBody: React.FC<PayloadTableBodyProps> = ({\n children,\n clickableFields,\n payloads,\n maxSchemaDepth,\n onHashClick,\n onRowClick,\n emptyRows,\n noResults,\n NoResultRowComponent,\n ...props\n}) => {\n const payloadPairs = usePayloadHashes(payloads)\n\n return (\n <TableBody {...props}>\n {noResults && NoResultRowComponent\n ? <NoResultRowComponent />\n : null}\n {payloadPairs?.map(([payload, hash]) => {\n return (\n <ThrownErrorBoundary\n boundaryName=\"PayloadTableBody\"\n key={hash}\n errorComponent={e => (\n <Alert severity=\"error\">\n Error Loading Payload:\n {' '}\n <Typography sx={{ fontWeight: 'bold' }}>\n {e.message}\n </Typography>\n </Alert>\n )}\n >\n <PayloadTableRow\n clickableFields={clickableFields}\n maxSchemaDepth={maxSchemaDepth}\n onClick={\n onRowClick\n ? () => {\n onRowClick(payload)\n }\n : undefined\n }\n onHashClick={onHashClick}\n payload={payload}\n />\n </ThrownErrorBoundary>\n )\n })}\n {children}\n {emptyRows ? (Array.from({ length: emptyRows }).fill(<PayloadTableRow />) as ReactNode[]) : null}\n </TableBody>\n )\n}\n", "import {\n CheckCircleOutlineRounded as CheckCircleOutlineRoundedIcon,\n ErrorOutlineRounded as ErrorOutlineRoundedIcon,\n WarningAmberRounded as WarningAmberRoundedIcon,\n} from '@mui/icons-material'\nimport type { TableRowProps } from '@mui/material'\nimport {\n alpha, Link, TableCell, TableRow, Typography,\n} from '@mui/material'\nimport { usePromise } from '@xylabs/react-promise'\nimport { useBreakpoint } from '@xylabs/react-shared'\nimport type { Hash } from '@xylabs/sdk-js'\nimport { isDefined } from '@xylabs/sdk-js'\nimport type { Payload } from '@xyo-network/payload-model'\nimport { PayloadValidator } from '@xyo-network/payload-validator'\nimport { useEvent } from '@xyo-network/react-event'\nimport { HashTableCell, usePayloadHash } from '@xyo-network/react-shared'\nimport React, { useMemo } from 'react'\n\nimport type { TableCellRenderer } from '../lib/index.ts'\nimport type { PayloadTableColumnConfig, PayloadTableColumnSlug } from './PayloadTableColumnConfig.ts'\nimport { payloadTableColumnConfigDefaults } from './PayloadTableColumnConfig.ts'\n\nexport interface PayloadTableRowProps extends TableRowProps {\n /** @deprecated - archives are no longer used */\n archive?: string\n clickableFields?: PayloadTableColumnSlug[]\n columns?: PayloadTableColumnConfig\n /** @deprecated - use event listeners instead of link building via props */\n exploreDomain?: string\n maxSchemaDepth?: number\n network?: string\n onHashClick?: (value: Hash) => void\n payload?: Payload\n}\n\nexport const PayloadTableRow: React.FC<PayloadTableRowProps> = ({\n clickableFields,\n columns,\n maxSchemaDepth,\n network: networkProp,\n onHashClick,\n payload,\n ...props\n}) => {\n const breakPoint = useBreakpoint()\n const payloadHash = usePayloadHash(payload)\n const [anchorRef, dispatch] = useEvent<HTMLAnchorElement>()\n const [errors = []] = usePromise(async () => (payload ? await new PayloadValidator(payload).validate() : undefined), [payload])\n const isValid = errors.length === 0\n\n const hash: TableCellRenderer = props => (\n <HashTableCell\n dataType=\"payload\"\n key=\"hash\"\n onHashClick={onHashClick}\n value={payloadHash}\n width=\"100%\"\n {...props}\n >\n {isDefined(payloadHash) && (\n <>\n {clickableFields?.includes('hash')\n ? (\n <Link onClick={() => dispatch('hash', 'click', payloadHash)} ref={anchorRef} sx={{ cursor: 'pointer' }}>{payloadHash}</Link>\n )\n : payloadHash}\n </>\n )}\n </HashTableCell>\n )\n\n const reduceSchemaDepth = (schema?: string, maxSchemaDepth?: number) => {\n if (isDefined(maxSchemaDepth)) {\n const parts = schema?.split('.') ?? []\n const partsToRemove = Math.max(parts.length - maxSchemaDepth, 0)\n if (partsToRemove > 0) {\n return (\n <>\n <>…</>\n {\n\n `${parts.slice(partsToRemove).reduce((previousValue, part) => previousValue + '.' + part, '')}`\n }\n </>\n )\n }\n }\n return schema\n }\n\n const schema: TableCellRenderer = props => (\n <TableCell title={payload?.schema} key=\"payloads\" align=\"center\" {...props}>\n <Typography\n variant=\"body2\"\n noWrap\n sx={{ fontFamily: 'monospace' }}\n >\n {clickableFields?.includes('schema')\n ? (\n <Link sx={{ cursor: 'pointer' }}>{reduceSchemaDepth(payload?.schema, maxSchemaDepth)}</Link>\n )\n : reduceSchemaDepth(payload?.schema, maxSchemaDepth)}\n\n </Typography>\n </TableCell>\n )\n\n const valid: TableCellRenderer = props => (\n <TableCell key=\"valid\" align=\"center\" {...props}>\n {isValid === undefined && payload != undefined\n ? <WarningAmberRoundedIcon fontSize=\"small\" color=\"warning\" />\n : isValid === true\n ? <CheckCircleOutlineRoundedIcon fontSize=\"small\" color=\"success\" />\n : isValid === false\n ? <ErrorOutlineRoundedIcon color=\"error\" fontSize=\"small\" />\n // to keep row height consistent when no data provided, may need fix later\n : <ErrorOutlineRoundedIcon sx={{ color: alpha('#fff', 0) }} fontSize=\"small\" />}\n </TableCell>\n )\n\n const tableCells: Record<PayloadTableColumnSlug, TableCellRenderer> = {\n hash,\n schema,\n valid,\n }\n\n const columnsMemo = useMemo(() => columns ?? payloadTableColumnConfigDefaults(), [columns])\n\n return isDefined(breakPoint)\n ? (\n <TableRow style={{ maxWidth: '100vw' }} {...props}>\n {columnsMemo[breakPoint]?.map((column) => {\n return tableCells[column]({})\n })}\n </TableRow>\n )\n : null\n}\n", "import {\n styled, TablePagination, TableRow,\n} from '@mui/material'\nimport { TableFooterEx } from '@xyo-network/react-table'\nimport React from 'react'\n\nimport { TablePaginationActions } from './TablePagination.tsx'\nimport type { PayloadTableFooterProps } from './types/index.ts'\n\nexport const PayloadTableFooter: React.FC<PayloadTableFooterProps> = ({\n count,\n variant,\n page,\n rowsPerPage,\n handleChangePage,\n handleChangeRowsPerPage,\n fetchMorePayloads,\n loading,\n}) => (\n <TableFooterEx variant={variant}>\n <TableRow>\n <StyledTablePagination\n rowsPerPageOptions={[5, 10, 25, { label: 'All', value: -1 }]}\n count={count ?? 0}\n rowsPerPage={rowsPerPage ?? 10}\n page={page ?? 0}\n slotProps={{\n select: {\n inputProps: { 'aria-label': 'rows per page' },\n native: true,\n },\n }}\n onPageChange={handleChangePage ?? (() => { /* noop */ })}\n onRowsPerPageChange={handleChangeRowsPerPage ?? (() => { /* noop */ })}\n // eslint-disable-next-line @typescript-eslint/no-explicit-any\n ActionsComponent={(props: any) => <TablePaginationActions enableNextPage={!!fetchMorePayloads} loading={loading} {...props} />}\n />\n </TableRow>\n </TableFooterEx>\n)\n\nconst StyledTablePagination = styled(TablePagination)(({ theme }) => ({\n '& > .MuiToolbar-root': { paddingLeft: theme.spacing(1) },\n 'borderTop': '1px solid',\n 'borderTopColor': theme.vars.palette.divider,\n}))\n", "import {\n FirstPage as FirstPageIcon, KeyboardArrowLeft, KeyboardArrowRight, LastPage as LastPageIcon,\n} from '@mui/icons-material'\nimport {\n Box, CircularProgress, IconButton, useTheme,\n} from '@mui/material'\nimport { useEvent } from '@xyo-network/react-event'\nimport React from 'react'\n\nimport type { PaginationNouns } from './types/index.ts'\n\nexport interface TablePaginationActionsProps {\n count: number\n enableNextPage?: boolean\n loading?: boolean\n onPageChange: (event: React.MouseEvent<HTMLButtonElement>, newPage: number) => void\n page: number\n rowsPerPage: number\n}\n\nexport function TablePaginationActions({\n count, enableNextPage, loading, onPageChange, page, rowsPerPage,\n}: Readonly<TablePaginationActionsProps>) {\n const theme = useTheme()\n const [paginationRef, paginationDispatch] = useEvent<HTMLButtonElement, PaginationNouns>()\n\n const handleFirstPageButtonClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n paginationDispatch('firstPage', 'click', 'true')\n onPageChange(event, 0)\n }\n\n const handleBackButtonClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n paginationDispatch('previousPage', 'click', (page - 1)?.toString())\n onPageChange(event, page - 1)\n }\n\n const handleNextButtonClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n paginationDispatch('nextPage', 'click', (page + 1)?.toString())\n onPageChange(event, page + 1)\n }\n\n const handleLastPageButtonClick = (event: React.MouseEvent<HTMLButtonElement>) => {\n paginationDispatch('lastPage', 'click', 'true')\n onPageChange(event, Math.max(0, Math.ceil(count / rowsPerPage) - 1))\n }\n\n return (\n <>\n {loading\n ? (\n <CircularProgress\n size=\"small\"\n sx={{\n height: theme.spacing(2), position: 'absolute', width: theme.spacing(2),\n }}\n />\n )\n : null}\n <Box sx={{ flexShrink: 0, ml: 2.5 }}>\n <IconButton onClick={handleFirstPageButtonClick} disabled={page === 0} aria-label=\"first page\">\n {theme.direction === 'rtl'\n ? <LastPageIcon />\n : <FirstPageIcon />}\n </IconButton>\n <IconButton ref={paginationRef} onClick={handleBackButtonClick} disabled={page === 0} aria-label=\"previous page\">\n {theme.direction === 'rtl'\n ? <KeyboardArrowRight />\n : <KeyboardArrowLeft />}\n </IconButton>\n <IconButton\n ref={paginationRef}\n onClick={handleNextButtonClick}\n disabled={!enableNextPage && page >= Math.ceil(count / rowsPerPage) - 1}\n aria-label=\"next page\"\n >\n {theme.direction === 'rtl'\n ? <KeyboardArrowLeft />\n : <KeyboardArrowRight />}\n </IconButton>\n <IconButton onClick={handleLastPageButtonClick} disabled={page >= Math.ceil(count / rowsPerPage) - 1} aria-label=\"last page\">\n {theme.direction === 'rtl'\n ? <FirstPageIcon />\n : <LastPageIcon />}\n </IconButton>\n </Box>\n </>\n )\n}\n", "import {\n TableCell, TableHead, TableRow, Typography,\n} from '@mui/material'\nimport { useBreakpoint } from '@xylabs/react-shared'\nimport React, { useMemo } from 'react'\n\nimport type { PayloadTableColumnSlug } from './PayloadTableColumnConfig.ts'\nimport { payloadColumnNames, payloadTableColumnConfigDefaults } from './PayloadTableColumnConfig.ts'\nimport type { PayloadTableHeadProps } from './types/index.ts'\n\nexport const PayloadTableHead: React.FC<PayloadTableHeadProps<PayloadTableColumnSlug>> = ({ columns, ...props }) => {\n const breakPoint = useBreakpoint()\n const columnsMemo = useMemo(() => columns ?? payloadTableColumnConfigDefaults(), [columns])\n return (\n <TableHead {...props}>\n <TableRow>\n {breakPoint\n ? columnsMemo[breakPoint]?.map((column, index) => {\n return (\n <TableCell\n key={column}\n align={index === 0 ? 'left' : 'center'}\n sx={{ width: index === 0 ? '100%' : undefined }}\n >\n <Typography variant=\"body2\" noWrap>\n {payloadColumnNames[column]}\n </Typography>\n </TableCell>\n )\n })\n : null}\n </TableRow>\n </TableHead>\n )\n}\n", "import type { TableRowProps, TypographyProps } from '@mui/material'\nimport {\n styled, TableCell, TableRow, Typography,\n} from '@mui/material'\nimport React from 'react'\n\nexport interface TableRowNoDataProps extends TableRowProps {\n additionalCells?: number\n hideBorder?: boolean\n typographyProps?: TypographyProps\n}\n\nexport const TableRowNoData: React.FC<TableRowNoDataProps> = ({\n additionalCells, hideBorder = false, typographyProps, ...props\n}) => {\n return (\n <TableRow {...props}>\n <StyledTableCell hideBorder={hideBorder}>\n <Typography variant=\"body2\" {...typographyProps}>\n No Data To Display...\n </Typography>\n </StyledTableCell>\n {additionalCells\n ? Array.from({ length: additionalCells })\n .fill(null)\n // eslint-disable-next-line react-x/no-array-index-key\n .map((_fill, index) => <StyledTableCell key={`empty-row-${index}`} hideBorder={hideBorder} />)\n : null}\n </TableRow>\n )\n}\n\ninterface StyledTableCellProps {\n hideBorder?: boolean\n}\n\nconst StyledTableCell = styled(TableCell, {\n name: 'StyledTableCell',\n shouldForwardProp: (prop: string) => prop !== 'hideBorder',\n})<StyledTableCellProps>(({ hideBorder }) => ({ ...(hideBorder && { border: 'none' }) }))\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["props", "TableCell", "TableRow", "Typography", "useBreakpoint", "useMemo", "jsx", "useBreakpoint", "useMemo", "TableRow", "TableCell", "Typography", "useMemo", "useState", "Alert", "TableBody", "Typography", "ThrownErrorBoundary", "usePayloadHashes", "CheckCircleOutlineRoundedIcon", "ErrorOutlineRoundedIcon", "WarningAmberRoundedIcon", "TableCell", "TableRow", "Typography", "usePromise", "useBreakpoint", "PayloadValidator", "HashTableCell", "usePayloadHash", "useMemo", "jsx", "jsxs", "useBreakpoint", "usePayloadHash", "usePromise", "PayloadValidator", "props", "HashTableCell", "schema", "maxSchemaDepth", "TableCell", "Typography", "WarningAmberRoundedIcon", "CheckCircleOutlineRoundedIcon", "ErrorOutlineRoundedIcon", "useMemo", "TableRow", "jsx", "jsxs", "usePayloadHashes", "TableBody", "ThrownErrorBoundary", "Alert", "Typography", "TablePagination", "TableRow", "FirstPageIcon", "KeyboardArrowLeft", "KeyboardArrowRight", "LastPageIcon", "Box", "IconButton", "useTheme", "useEvent", "Fragment", "jsx", "jsxs", "TablePaginationActions", "jsx", "TableRow", "TablePaginationActions", "TablePagination", "TableCell", "TableHead", "TableRow", "Typography", "useBreakpoint", "useMemo", "jsx", "useBreakpoint", "useMemo", "TableHead", "TableRow", "TableCell", "Typography", "styled", "TableCell", "TableRow", "Typography", "jsx", "jsxs", "jsx", "jsxs", "useState", "useMemo"]
|
|
7
|
+
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@xyo-network/react-payload-table",
|
|
3
|
-
"version": "
|
|
3
|
+
"version": "8.0.1",
|
|
4
4
|
"description": "Common React library for all XYO projects that use React",
|
|
5
5
|
"keywords": [
|
|
6
6
|
"xyo",
|
|
@@ -41,46 +41,44 @@
|
|
|
41
41
|
"README.md"
|
|
42
42
|
],
|
|
43
43
|
"dependencies": {
|
|
44
|
-
"@xyo-network/react-event": "~
|
|
45
|
-
"@xyo-network/react-
|
|
46
|
-
"@xyo-network/react-
|
|
47
|
-
"@xyo-network/react-
|
|
48
|
-
"@xyo-network/react-shared": "~
|
|
44
|
+
"@xyo-network/react-event": "~8.0.1",
|
|
45
|
+
"@xyo-network/react-payload-plugin-resolver": "~8.0.1",
|
|
46
|
+
"@xyo-network/react-network": "~8.0.1",
|
|
47
|
+
"@xyo-network/react-table": "~8.0.1",
|
|
48
|
+
"@xyo-network/react-shared": "~8.0.1"
|
|
49
49
|
},
|
|
50
50
|
"devDependencies": {
|
|
51
51
|
"@bitauth/libauth": "~3.0.0",
|
|
52
|
-
"@
|
|
53
|
-
"@
|
|
54
|
-
"@mui/
|
|
55
|
-
"@mui/
|
|
56
|
-
"@mui/system": "^7.3.11",
|
|
57
|
-
"@mui/x-tree-view": "~8.27.2",
|
|
52
|
+
"@mui/icons-material": "^9.0.1",
|
|
53
|
+
"@mui/material": "^9.0.1",
|
|
54
|
+
"@mui/system": "^9.0.1",
|
|
55
|
+
"@mui/x-tree-view": "~9.1.0",
|
|
58
56
|
"@opentelemetry/api": "^1.9.1",
|
|
59
57
|
"@opentelemetry/sdk-trace-base": "^2.7.1",
|
|
60
58
|
"@react-spring/web": "~10.0.3",
|
|
61
59
|
"@scure/base": "~2.2.0",
|
|
62
|
-
"@storybook/react-vite": "~10.
|
|
63
|
-
"@textea/json-viewer": "~4.0.1",
|
|
60
|
+
"@storybook/react-vite": "~10.4.0",
|
|
64
61
|
"@types/react": "^19.2.14",
|
|
65
|
-
"@xylabs/pixel": "~5.1.
|
|
66
|
-
"@xylabs/react-async-effect": "~
|
|
67
|
-
"@xylabs/react-button": "~
|
|
68
|
-
"@xylabs/react-error": "~
|
|
69
|
-
"@xylabs/react-flexbox": "~
|
|
70
|
-
"@xylabs/react-hooks": "~
|
|
71
|
-
"@xylabs/react-identicon": "~
|
|
72
|
-
"@xylabs/react-link": "~
|
|
73
|
-
"@xylabs/react-promise": "~
|
|
74
|
-
"@xylabs/react-quick-tip-button": "~
|
|
75
|
-
"@xylabs/react-select": "~
|
|
76
|
-
"@xylabs/react-shared": "~
|
|
77
|
-
"@xylabs/react-theme": "~
|
|
78
|
-
"@xylabs/sdk-js": "^5.1.
|
|
79
|
-
"@xylabs/
|
|
80
|
-
"@xylabs/
|
|
81
|
-
"@xylabs/
|
|
82
|
-
"@xylabs/tsconfig
|
|
83
|
-
"@xylabs/tsconfig-
|
|
62
|
+
"@xylabs/pixel": "~5.1.3",
|
|
63
|
+
"@xylabs/react-async-effect": "~8.0.3",
|
|
64
|
+
"@xylabs/react-button": "~8.0.3",
|
|
65
|
+
"@xylabs/react-error": "~8.0.3",
|
|
66
|
+
"@xylabs/react-flexbox": "~8.0.3",
|
|
67
|
+
"@xylabs/react-hooks": "~8.0.3",
|
|
68
|
+
"@xylabs/react-identicon": "~8.0.3",
|
|
69
|
+
"@xylabs/react-link": "~8.0.3",
|
|
70
|
+
"@xylabs/react-promise": "~8.0.3",
|
|
71
|
+
"@xylabs/react-quick-tip-button": "~8.0.3",
|
|
72
|
+
"@xylabs/react-select": "~8.0.3",
|
|
73
|
+
"@xylabs/react-shared": "~8.0.3",
|
|
74
|
+
"@xylabs/react-theme": "~8.0.3",
|
|
75
|
+
"@xylabs/sdk-js": "^5.1.3",
|
|
76
|
+
"@xylabs/sdk-react": "~8.0.3",
|
|
77
|
+
"@xylabs/threads": "~5.1.3",
|
|
78
|
+
"@xylabs/toolchain": "~8.0.6",
|
|
79
|
+
"@xylabs/tsconfig": "^8.0.6",
|
|
80
|
+
"@xylabs/tsconfig-dom": "^8.0.6",
|
|
81
|
+
"@xylabs/tsconfig-react": "~8.0.6",
|
|
84
82
|
"@xyo-network/account": "~5.6.2",
|
|
85
83
|
"@xyo-network/account-model": "^5.6.3",
|
|
86
84
|
"@xyo-network/boundwitness-builder": "^5.6.2",
|
|
@@ -94,7 +92,7 @@
|
|
|
94
92
|
"@xyo-network/manifest-model": "~5.6.3",
|
|
95
93
|
"@xyo-network/module-model": "^5.6.4",
|
|
96
94
|
"@xyo-network/network": "~5.6.3",
|
|
97
|
-
"@xyo-network/node-core-types": "~4.2.
|
|
95
|
+
"@xyo-network/node-core-types": "~4.2.2",
|
|
98
96
|
"@xyo-network/node-memory": "~5.6.4",
|
|
99
97
|
"@xyo-network/node-model": "^5.6.4",
|
|
100
98
|
"@xyo-network/payload-builder": "^5.6.2",
|
|
@@ -113,60 +111,62 @@
|
|
|
113
111
|
"bowser": "^2.14.1",
|
|
114
112
|
"buffer": "^6.0.3",
|
|
115
113
|
"chalk": "^5.6.2",
|
|
114
|
+
"clsx": "~2.1.1",
|
|
116
115
|
"debug": "~4.4.3",
|
|
117
|
-
"eslint": "^10.
|
|
116
|
+
"eslint": "^10.4.0",
|
|
118
117
|
"ethers": "^6.16.0",
|
|
119
118
|
"fast-deep-equal": "~3.1.3",
|
|
120
119
|
"hash-wasm": "~4.12.0",
|
|
121
|
-
"js-cookie": "~3.0.
|
|
120
|
+
"js-cookie": "~3.0.6",
|
|
122
121
|
"lru-cache": "^11.3.6",
|
|
123
122
|
"md5": "~2.3.0",
|
|
124
|
-
"mixpanel-browser": "~2.
|
|
123
|
+
"mixpanel-browser": "~2.79.0",
|
|
124
|
+
"numeral": "~2.0.6",
|
|
125
125
|
"observable-fns": "~0.6.1",
|
|
126
126
|
"pako": "^2.1.0",
|
|
127
127
|
"query-string": "~9.3.1",
|
|
128
128
|
"react": "^19.2.6",
|
|
129
129
|
"react-dom": "^19.2.6",
|
|
130
130
|
"react-is": "^19.2.6",
|
|
131
|
-
"react-router-dom": "^7.15.
|
|
131
|
+
"react-router-dom": "^7.15.1",
|
|
132
132
|
"recharts": "~3.8.1",
|
|
133
133
|
"spark-md5": "~3.0.2",
|
|
134
|
-
"storybook": "^10.
|
|
135
|
-
"typescript": "^
|
|
136
|
-
"
|
|
134
|
+
"storybook": "^10.4.0",
|
|
135
|
+
"typescript": "^6.0.3",
|
|
136
|
+
"viem": "^2.49.3",
|
|
137
|
+
"vite": "^8.0.13",
|
|
137
138
|
"wasm-feature-detect": "~1.8.0",
|
|
138
139
|
"zod": "^4.4.3",
|
|
139
|
-
"
|
|
140
|
-
"@xyo-network/react-crypto-market-uniswap-plugin": "~
|
|
141
|
-
"@xyo-network/react-
|
|
140
|
+
"zustand": "~5.0.13",
|
|
141
|
+
"@xyo-network/react-crypto-market-uniswap-plugin": "~8.0.1",
|
|
142
|
+
"@xyo-network/react-payload-plugin": "~8.0.1",
|
|
143
|
+
"@xyo-network/react-storybook": "~8.0.1"
|
|
142
144
|
},
|
|
143
145
|
"peerDependencies": {
|
|
144
146
|
"@bitauth/libauth": "~3.0",
|
|
145
|
-
"@
|
|
146
|
-
"@
|
|
147
|
-
"@mui/
|
|
148
|
-
"@mui/
|
|
149
|
-
"@mui/system": "^7.3",
|
|
150
|
-
"@mui/x-tree-view": "~8.27",
|
|
147
|
+
"@mui/icons-material": "^9.0",
|
|
148
|
+
"@mui/material": "^9.0",
|
|
149
|
+
"@mui/system": "^9.0",
|
|
150
|
+
"@mui/x-tree-view": "~9.1",
|
|
151
151
|
"@opentelemetry/api": "^1.9",
|
|
152
152
|
"@opentelemetry/sdk-trace-base": "^2.7",
|
|
153
153
|
"@react-spring/web": "~10.0",
|
|
154
154
|
"@scure/base": "~2.2",
|
|
155
|
-
"@textea/json-viewer": "~4.0",
|
|
156
155
|
"@xylabs/pixel": "~5.1",
|
|
157
|
-
"@xylabs/react-async-effect": "~
|
|
158
|
-
"@xylabs/react-button": "~
|
|
159
|
-
"@xylabs/react-error": "~
|
|
160
|
-
"@xylabs/react-flexbox": "~
|
|
161
|
-
"@xylabs/react-hooks": "~
|
|
162
|
-
"@xylabs/react-identicon": "~
|
|
163
|
-
"@xylabs/react-link": "~
|
|
164
|
-
"@xylabs/react-promise": "~
|
|
165
|
-
"@xylabs/react-quick-tip-button": "~
|
|
166
|
-
"@xylabs/react-select": "~
|
|
167
|
-
"@xylabs/react-shared": "~
|
|
168
|
-
"@xylabs/react-theme": "~
|
|
156
|
+
"@xylabs/react-async-effect": "~8.0",
|
|
157
|
+
"@xylabs/react-button": "~8.0",
|
|
158
|
+
"@xylabs/react-error": "~8.0",
|
|
159
|
+
"@xylabs/react-flexbox": "~8.0",
|
|
160
|
+
"@xylabs/react-hooks": "~8.0",
|
|
161
|
+
"@xylabs/react-identicon": "~8.0",
|
|
162
|
+
"@xylabs/react-link": "~8.0",
|
|
163
|
+
"@xylabs/react-promise": "~8.0",
|
|
164
|
+
"@xylabs/react-quick-tip-button": "~8.0",
|
|
165
|
+
"@xylabs/react-select": "~8.0",
|
|
166
|
+
"@xylabs/react-shared": "~8.0",
|
|
167
|
+
"@xylabs/react-theme": "~8.0",
|
|
169
168
|
"@xylabs/sdk-js": "^5.1",
|
|
169
|
+
"@xylabs/sdk-react": "~8.0",
|
|
170
170
|
"@xylabs/threads": "~5.1",
|
|
171
171
|
"@xyo-network/account": "~5.6",
|
|
172
172
|
"@xyo-network/account-model": "^5.6",
|
|
@@ -200,6 +200,7 @@
|
|
|
200
200
|
"bowser": "^2.14",
|
|
201
201
|
"buffer": "^6.0",
|
|
202
202
|
"chalk": "^5.6",
|
|
203
|
+
"clsx": "~2.1",
|
|
203
204
|
"debug": "~4.4",
|
|
204
205
|
"ethers": "^6.16",
|
|
205
206
|
"fast-deep-equal": "~3.1",
|
|
@@ -207,7 +208,8 @@
|
|
|
207
208
|
"js-cookie": "~3.0",
|
|
208
209
|
"lru-cache": "^11.3",
|
|
209
210
|
"md5": "~2.3",
|
|
210
|
-
"mixpanel-browser": "~2.
|
|
211
|
+
"mixpanel-browser": "~2.79",
|
|
212
|
+
"numeral": "~2.0",
|
|
211
213
|
"observable-fns": "~0.6",
|
|
212
214
|
"pako": "^2.1",
|
|
213
215
|
"query-string": "~9.3",
|
|
@@ -217,8 +219,10 @@
|
|
|
217
219
|
"react-router-dom": "^7.15",
|
|
218
220
|
"recharts": "~3.8",
|
|
219
221
|
"spark-md5": "~3.0",
|
|
222
|
+
"viem": "^2.48",
|
|
220
223
|
"wasm-feature-detect": "~1.8",
|
|
221
|
-
"zod": "^4.4"
|
|
224
|
+
"zod": "^4.4",
|
|
225
|
+
"zustand": "~5.0"
|
|
222
226
|
},
|
|
223
227
|
"publishConfig": {
|
|
224
228
|
"access": "public"
|