@xyo-network/react-payload-table 7.5.7 → 7.5.11

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (31) hide show
  1. package/dist/browser/components/Table/TableRowNoData.d.ts.map +1 -1
  2. package/dist/browser/index.mjs +438 -460
  3. package/dist/browser/index.mjs.map +1 -1
  4. package/package.json +182 -44
  5. package/src/components/DynamicTable/DynamicTable.stories.tsx +0 -72
  6. package/src/components/DynamicTable/DynamicTableRow.tsx +0 -134
  7. package/src/components/DynamicTable/PayloadDynamicTableColumnConfig.ts +0 -98
  8. package/src/components/DynamicTable/Table.tsx +0 -194
  9. package/src/components/DynamicTable/index.ts +0 -3
  10. package/src/components/Table/FetchMoreTable.stories.tsx +0 -100
  11. package/src/components/Table/PayloadTableColumnConfig.ts +0 -22
  12. package/src/components/Table/Table.stories.tsx +0 -98
  13. package/src/components/Table/Table.tsx +0 -139
  14. package/src/components/Table/TableBody.tsx +0 -64
  15. package/src/components/Table/TableFooter.tsx +0 -44
  16. package/src/components/Table/TableHead.tsx +0 -31
  17. package/src/components/Table/TablePagination.tsx +0 -88
  18. package/src/components/Table/TableRow.tsx +0 -135
  19. package/src/components/Table/TableRowNoData.tsx +0 -39
  20. package/src/components/Table/index.ts +0 -7
  21. package/src/components/Table/lib/TableColumns.ts +0 -12
  22. package/src/components/Table/lib/index.ts +0 -1
  23. package/src/components/Table/types/PaginationEventNouns.ts +0 -1
  24. package/src/components/Table/types/PayloadTableBodyProps.ts +0 -21
  25. package/src/components/Table/types/PayloadTableFooterProps.ts +0 -13
  26. package/src/components/Table/types/PayloadTableHeadProps.ts +0 -7
  27. package/src/components/Table/types/index.ts +0 -4
  28. package/src/components/index.ts +0 -2
  29. package/src/components/lib/index.ts +0 -3
  30. package/src/global.d.ts +0 -1
  31. package/src/index.ts +0 -1
@@ -1 +1 @@
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> &nbsp;</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, index) => {\n return (\n <TableCell key={index} 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], index) => {\n return (\n <ThrownErrorBoundary\n boundaryName=\"PayloadTableBody\"\n key={`${hash}-${index}`}\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], index) => {\n return (\n <ThrownErrorBoundary\n boundaryName=\"PayloadTableBody\"\n key={`${hash}-${index}`}\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 <>&#x2026;</>\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 ?? (() => {})}\n onRowsPerPageChange={handleChangeRowsPerPage ?? (() => {})}\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={index} 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 .map((_fill, index) => <StyledTableCell key={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":["CheckCircleOutlineRounded","CheckCircleOutlineRoundedIcon","ErrorOutlineRounded","ErrorOutlineRoundedIcon","WarningAmberRounded","WarningAmberRoundedIcon","TableCell","TableRow","Typography","usePromise","useBreakpoint","PayloadBuilder","PayloadValidator","useNetwork","usePayloadRenderPluginResolver","HashTableCell","usePayloadHash","React","useMemo","payloadDynamicTableColumnConfigDefaults","xs","alignment","name","slug","width","sm","md","lg","xl","PayloadDynamicTableRow","columns","network","networkProp","payload","props","breakPoint","useBreakpoint","payloadHash","usePayloadHash","useNetwork","resolver","usePayloadRenderPluginResolver","validationErrors","usePromise","PayloadValidator","validate","undefined","isValid","length","payloadFieldCount","Object","keys","PayloadBuilder","hashableFields","hash","HashTableCell","key","align","value","dataType","slug","schema","TableCell","Typography","fontFamily","variant","noWrap","details","render","Render","resolve","components","table","cell","icon","Avatar","avatar","image","valid","WarningAmberRoundedIcon","fontSize","color","CheckCircleOutlineRoundedIcon","ErrorOutlineRoundedIcon","tableCells","columnsMemo","useMemo","payloadDynamicTableColumnConfigDefaults","TableRow","style","maxWidth","map","column","FirstPage","FirstPageIcon","KeyboardArrowLeft","KeyboardArrowRight","LastPage","LastPageIcon","Alert","Box","IconButton","Table","TableBody","TableCell","TableFooter","TableHead","TablePagination","TableRow","Typography","useTheme","ThrownErrorBoundary","useResetState","useBreakpoint","usePayloadHashes","React","useMemo","useState","TablePaginationActions","props","theme","useTheme","count","page","rowsPerPage","onPageChange","handleFirstPageButtonClick","event","handleBackButtonClick","handleNextButtonClick","handleLastPageButtonClick","Math","max","ceil","React","Box","sx","flexShrink","ml","IconButton","onClick","disabled","aria-label","direction","LastPageIcon","FirstPageIcon","KeyboardArrowRight","KeyboardArrowLeft","PayloadDynamicTable","archive","children","columns","exploreDomain","onRowClick","rowsPerPageProp","payloads","breakPoint","useBreakpoint","setPage","useState","setRowsPerPage","useResetState","payloadCount","length","emptyRows","pagedPayloads","useMemo","slice","payloadPairs","usePayloadHashes","handleChangePage","newPage","handleChangeRowsPerPage","Number","parseInt","target","value","Table","stickyHeader","TableHead","TableRow","payloadDynamicTableColumnConfigDefaults","map","column","index","TableCell","key","align","alignment","width","Typography","variant","noWrap","name","TableBody","overflowY","payload","hash","ThrownErrorBoundary","boundaryName","errorComponent","e","Alert","severity","fontWeight","message","PayloadDynamicTableRow","undefined","Array","from","fill","TableFooter","TablePagination","rowsPerPageOptions","label","colSpan","SelectProps","inputProps","native","onRowsPerPageChange","ActionsComponent","payloadColumnNames","hash","schema","valid","payloadTableColumnConfigDefaults","xs","sm","md","lg","xl","isDefinedNotNull","TableEx","React","useMemo","useState","Alert","TableBody","Typography","ThrownErrorBoundary","usePayloadHashes","React","CheckCircleOutlineRounded","CheckCircleOutlineRoundedIcon","ErrorOutlineRounded","ErrorOutlineRoundedIcon","WarningAmberRounded","WarningAmberRoundedIcon","alpha","Link","TableCell","TableRow","Typography","usePromise","useBreakpoint","isDefined","PayloadValidator","useEvent","HashTableCell","usePayloadHash","React","useMemo","PayloadTableRow","clickableFields","columns","maxSchemaDepth","network","networkProp","onHashClick","payload","props","breakPoint","useBreakpoint","payloadHash","usePayloadHash","anchorRef","dispatch","useEvent","errors","usePromise","PayloadValidator","validate","undefined","isValid","length","hash","React","HashTableCell","dataType","key","value","width","isDefined","includes","Link","onClick","ref","sx","cursor","reduceSchemaDepth","schema","parts","split","partsToRemove","Math","max","slice","reduce","previousValue","part","TableCell","title","align","Typography","fontFamily","variant","noWrap","valid","WarningAmberRoundedIcon","fontSize","color","CheckCircleOutlineRoundedIcon","ErrorOutlineRoundedIcon","alpha","tableCells","columnsMemo","useMemo","payloadTableColumnConfigDefaults","TableRow","style","maxWidth","map","column","PayloadTableBody","children","clickableFields","payloads","maxSchemaDepth","onHashClick","onRowClick","emptyRows","noResults","NoResultRowComponent","props","payloadPairs","usePayloadHashes","React","TableBody","map","payload","hash","index","ThrownErrorBoundary","boundaryName","key","errorComponent","e","Alert","severity","Typography","fontWeight","message","PayloadTableRow","onClick","undefined","Array","from","length","fill","styled","TablePagination","TableRow","TableFooterEx","React","FirstPage","FirstPageIcon","KeyboardArrowLeft","KeyboardArrowRight","LastPage","LastPageIcon","Box","CircularProgress","IconButton","useTheme","useEvent","React","TablePaginationActions","count","enableNextPage","loading","onPageChange","page","rowsPerPage","theme","useTheme","paginationRef","paginationDispatch","useEvent","handleFirstPageButtonClick","event","handleBackButtonClick","toString","handleNextButtonClick","handleLastPageButtonClick","Math","max","ceil","React","CircularProgress","size","sx","height","spacing","position","width","Box","flexShrink","ml","IconButton","onClick","disabled","aria-label","direction","LastPageIcon","FirstPageIcon","ref","KeyboardArrowRight","KeyboardArrowLeft","PayloadTableFooter","count","variant","page","rowsPerPage","handleChangePage","handleChangeRowsPerPage","fetchMorePayloads","loading","React","TableFooterEx","TableRow","StyledTablePagination","rowsPerPageOptions","label","value","SelectProps","inputProps","native","onPageChange","onRowsPerPageChange","ActionsComponent","props","TablePaginationActions","enableNextPage","styled","TablePagination","theme","paddingLeft","spacing","vars","palette","divider","TableCell","TableHead","TableRow","Typography","useBreakpoint","React","useMemo","PayloadTableHead","columns","props","breakPoint","useBreakpoint","columnsMemo","useMemo","payloadTableColumnConfigDefaults","React","TableHead","TableRow","map","column","index","TableCell","key","width","undefined","align","Typography","variant","noWrap","payloadColumnNames","styled","TableCell","TableRow","Typography","React","TableRowNoData","additionalCells","hideBorder","typographyProps","props","React","TableRow","StyledTableCell","Typography","variant","Array","from","length","fill","map","_fill","index","key","styled","TableCell","name","shouldForwardProp","prop","border","PayloadTableWithRef","clickableFields","onHashClick","onRowClick","fetchMorePayloads","rowsPerPage","rowsPerPageProp","payloads","columns","PayloadTableHeadComponent","PayloadTableHead","PayloadTableBodyComponent","PayloadTableBody","PayloadTableFooterComponent","PayloadTableFooter","maxSchemaDepth","count","loading","variant","props","page","setPage","useState","setRowsPerPage","previousRowsPerPage","setPreviousRowsPerPage","visiblePayloads","setVisiblePayloads","emptyRows","Math","max","previousPayloads","setPreviousPayloads","isDefinedNotNull","slice","handleAdditionalPayloads","buffer","lastVisiblePayload","at","lastVisibleIndex","indexOf","undefined","length","handleChangePage","_event","newPage","handleChangeRowsPerPage","event","Number","parseInt","target","value","noResults","useMemo","React","TableEx","NoResultRowComponent","TableRowNoData","displayName","PayloadTable"]}
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> &nbsp;</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 <>&#x2026;</>\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"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@xyo-network/react-payload-table",
3
- "version": "7.5.7",
3
+ "version": "7.5.11",
4
4
  "description": "Common React library for all XYO projects that use React",
5
5
  "keywords": [
6
6
  "xyo",
@@ -36,61 +36,199 @@
36
36
  },
37
37
  "./package.json": "./package.json"
38
38
  },
39
- "module": "dist/browser/index.mjs",
40
- "types": "dist/browser/index.d.ts",
41
39
  "files": [
42
40
  "dist",
43
- "src"
41
+ "README.md"
44
42
  ],
45
43
  "dependencies": {
46
- "@xylabs/react-error": "~7.1.17",
47
- "@xylabs/react-hooks": "~7.1.17",
48
- "@xylabs/react-promise": "~7.1.17",
49
- "@xylabs/react-shared": "~7.1.17",
50
- "@xylabs/sdk-js": "~5.0.90",
51
- "@xyo-network/payload-builder": "~5.3.17",
52
- "@xyo-network/payload-model": "~5.3.17",
53
- "@xyo-network/payload-validator": "~5.3.17",
54
- "@xyo-network/react-event": "7.5.7",
55
- "@xyo-network/react-network": "7.5.7",
56
- "@xyo-network/react-payload-plugin-resolver": "7.5.7",
57
- "@xyo-network/react-shared": "7.5.7",
58
- "@xyo-network/react-table": "7.5.7"
44
+ "@xyo-network/react-network": "~7.5.11",
45
+ "@xyo-network/react-event": "~7.5.11",
46
+ "@xyo-network/react-shared": "~7.5.11",
47
+ "@xyo-network/react-table": "~7.5.11",
48
+ "@xyo-network/react-payload-plugin-resolver": "~7.5.11"
59
49
  },
60
50
  "devDependencies": {
61
- "@emotion/react": "~11.14.0",
62
- "@emotion/styled": "~11.14.1",
63
- "@mui/icons-material": "~7.3.9",
64
- "@mui/material": "~7.3.9",
65
- "@storybook/react-vite": "~10.3.3",
51
+ "@bitauth/libauth": "~3.0.0",
52
+ "@emotion/react": "^11.14.0",
53
+ "@emotion/styled": "^11.14.1",
54
+ "@metamask/providers": "^22.1.1",
55
+ "@mui/icons-material": "^7.3.10",
56
+ "@mui/material": "^7.3.10",
57
+ "@mui/system": "^7.3.10",
58
+ "@mui/x-tree-view": "~8.27.2",
59
+ "@opentelemetry/api": "^1.9.1",
60
+ "@opentelemetry/sdk-trace-base": "^2.7.0",
61
+ "@scure/base": "~2.2.0",
62
+ "@scure/bip39": "~2.2.0",
63
+ "@storybook/react-vite": "~10.3.5",
64
+ "@textea/json-viewer": "~4.0.1",
65
+ "@types/node": "~25.6.0",
66
66
  "@types/react": "^19.2.14",
67
- "@xylabs/sdk-js": "~5.0.90",
68
- "@xylabs/ts-scripts-common": "~7.5.6",
69
- "@xylabs/ts-scripts-yarn3": "~7.5.6",
70
- "@xylabs/tsconfig": "~7.5.6",
71
- "@xylabs/tsconfig-dom": "~7.5.6",
72
- "@xylabs/tsconfig-react": "~7.5.6",
73
- "@xyo-network/react-crypto-market-uniswap-plugin": "7.5.7",
74
- "@xyo-network/react-payload-plugin": "7.5.7",
75
- "@xyo-network/react-storybook": "7.5.7",
76
- "react": "^19.2.4",
77
- "react-dom": "^19.2.4",
78
- "react-router-dom": "^7.13.2",
79
- "storybook": "~10.3.3",
67
+ "@xylabs/geo": "^5.0.100",
68
+ "@xylabs/react-async-effect": "~7.1.20",
69
+ "@xylabs/react-button": "~7.1.20",
70
+ "@xylabs/react-dialogs": "~7.1.20",
71
+ "@xylabs/react-error": "~7.1.20",
72
+ "@xylabs/react-flexbox": "~7.1.20",
73
+ "@xylabs/react-hooks": "~7.1.20",
74
+ "@xylabs/react-identicon": "~7.1.20",
75
+ "@xylabs/react-link": "~7.1.20",
76
+ "@xylabs/react-promise": "~7.1.20",
77
+ "@xylabs/react-quick-tip-button": "~7.1.20",
78
+ "@xylabs/react-select": "~7.1.20",
79
+ "@xylabs/react-shared": "~7.1.20",
80
+ "@xylabs/react-theme": "~7.1.20",
81
+ "@xylabs/sdk-js": "^5.0.100",
82
+ "@xylabs/threads": "~5.0.100",
83
+ "@xylabs/toolchain": "~7.11.9",
84
+ "@xylabs/tsconfig": "^7.11.9",
85
+ "@xylabs/tsconfig-dom": "^7.11.9",
86
+ "@xylabs/tsconfig-react": "~7.11.9",
87
+ "@xylabs/zod": "~5.0.100",
88
+ "@xyo-network/account": "~5.5.1",
89
+ "@xyo-network/account-model": "^5.5.1",
90
+ "@xyo-network/api": "~5.5.1",
91
+ "@xyo-network/api-models": "~5.5.1",
92
+ "@xyo-network/boundwitness-builder": "^5.5.1",
93
+ "@xyo-network/boundwitness-model": "^5.5.1",
94
+ "@xyo-network/boundwitness-validator": "^5.5.1",
95
+ "@xyo-network/boundwitness-wrapper": "~5.5.1",
96
+ "@xyo-network/config-payload-plugin": "~5.5.1",
97
+ "@xyo-network/diviner-model": "^5.5.5",
98
+ "@xyo-network/diviner-schema-list-model": "~5.5.2",
99
+ "@xyo-network/diviner-schema-stats-model": "~5.5.2",
100
+ "@xyo-network/huri": "^5.5.1",
101
+ "@xyo-network/manifest-model": "~5.5.1",
102
+ "@xyo-network/module-abstract": "^5.5.5",
103
+ "@xyo-network/module-model": "^5.5.5",
104
+ "@xyo-network/network": "~5.5.1",
105
+ "@xyo-network/node-core-types": "~4.1.10",
106
+ "@xyo-network/node-memory": "~5.5.5",
107
+ "@xyo-network/node-model": "^5.5.5",
108
+ "@xyo-network/payload-builder": "^5.5.1",
109
+ "@xyo-network/payload-model": "^5.5.1",
110
+ "@xyo-network/payload-plugin": "^5.5.1",
111
+ "@xyo-network/payload-validator": "^5.5.1",
112
+ "@xyo-network/payload-wrapper": "~5.5.1",
113
+ "@xyo-network/payloadset-plugin": "^5.5.5",
114
+ "@xyo-network/query-payload-plugin": "~5.5.1",
115
+ "@xyo-network/schema-cache": "~5.5.1",
116
+ "@xyo-network/schema-payload-plugin": "~5.5.1",
117
+ "@xyo-network/sdk-js": "^5.5.5",
118
+ "@xyo-network/sdk-protocol-js": "~5.5.1",
119
+ "@xyo-network/typeof": "~5.3.30",
120
+ "@xyo-network/uniswap-crypto-market-payload-plugin": "~5.4.9",
121
+ "@xyo-network/wallet": "~5.5.1",
122
+ "@xyo-network/wallet-model": "^5.5.1",
123
+ "ajv": "^8.18.0",
124
+ "async-mutex": "^0.5.0",
125
+ "axios": "^1.15.2",
126
+ "bn.js": "^5.2.3",
127
+ "bowser": "^2.14.1",
128
+ "buffer": "^6.0.3",
129
+ "chalk": "^5.6.2",
130
+ "debug": "~4.4.3",
131
+ "esbuild": "~0.28.0",
132
+ "eslint": "^10.2.1",
133
+ "ethers": "^6.16.0",
134
+ "fast-deep-equal": "~3.1.3",
135
+ "hash-wasm": "~4.12.0",
136
+ "idb": "^8.0.3",
137
+ "js-cookie": "~3.0.5",
138
+ "lru-cache": "^11.3.5",
139
+ "mapbox-gl": "^3.22.0",
140
+ "observable-fns": "~0.6.1",
141
+ "pako": "^2.1.0",
142
+ "react": "^19.2.5",
143
+ "react-dom": "^19.2.5",
144
+ "react-router-dom": "^7.14.2",
145
+ "spark-md5": "~3.0.2",
146
+ "store2": "~2.14.4",
147
+ "storybook": "^10.3.5",
80
148
  "typescript": "^5.9.3",
81
- "vite": "~8.0.3",
82
- "zod": "^4.3.6"
149
+ "vite": "^8.0.10",
150
+ "wasm-feature-detect": "~1.8.0",
151
+ "webextension-polyfill": "^0.12.0",
152
+ "zod": "^4.3.6",
153
+ "@xyo-network/react-crypto-market-uniswap-plugin": "~7.5.11",
154
+ "@xyo-network/react-payload-plugin": "~7.5.11",
155
+ "@xyo-network/react-storybook": "~7.5.11"
83
156
  },
84
157
  "peerDependencies": {
85
- "@mui/icons-material": ">=6 <8",
86
- "@mui/material": ">=6 <8",
87
- "react": "^19",
88
- "react-dom": "^19",
89
- "react-router-dom": "^7",
90
- "zod": "^4"
158
+ "@emotion/react": "^11.14.0",
159
+ "@emotion/styled": "^11.14.1",
160
+ "@mui/icons-material": "^7.3.10",
161
+ "@mui/material": "^7.3.10",
162
+ "@mui/system": "^7.3.10",
163
+ "@mui/x-tree-view": "~8.27.2",
164
+ "@opentelemetry/api": "^1.9.1",
165
+ "@opentelemetry/sdk-trace-base": "^2.7.0",
166
+ "@scure/base": "~2.2.0",
167
+ "@textea/json-viewer": "~4.0.1",
168
+ "@xylabs/react-async-effect": "~7.1.20",
169
+ "@xylabs/react-button": "~7.1.20",
170
+ "@xylabs/react-dialogs": "~7.1.20",
171
+ "@xylabs/react-error": "~7.1.20",
172
+ "@xylabs/react-flexbox": "~7.1.20",
173
+ "@xylabs/react-hooks": "~7.1.20",
174
+ "@xylabs/react-identicon": "~7.1.20",
175
+ "@xylabs/react-link": "~7.1.20",
176
+ "@xylabs/react-promise": "~7.1.20",
177
+ "@xylabs/react-quick-tip-button": "~7.1.20",
178
+ "@xylabs/react-select": "~7.1.20",
179
+ "@xylabs/react-shared": "~7.1.20",
180
+ "@xylabs/react-theme": "~7.1.20",
181
+ "@xylabs/sdk-js": "^5.0.100",
182
+ "@xylabs/tsconfig": "^7.11.9",
183
+ "@xylabs/tsconfig-dom": "^7.11.9",
184
+ "@xylabs/zod": "~5.0.100",
185
+ "@xyo-network/account": "~5.5.1",
186
+ "@xyo-network/account-model": "^5.5.1",
187
+ "@xyo-network/boundwitness-builder": "^5.5.1",
188
+ "@xyo-network/boundwitness-model": "^5.5.1",
189
+ "@xyo-network/boundwitness-validator": "^5.5.1",
190
+ "@xyo-network/boundwitness-wrapper": "~5.5.1",
191
+ "@xyo-network/config-payload-plugin": "~5.5.1",
192
+ "@xyo-network/diviner-model": "^5.5.5",
193
+ "@xyo-network/diviner-schema-list-model": "~5.5.2",
194
+ "@xyo-network/diviner-schema-stats-model": "~5.5.2",
195
+ "@xyo-network/manifest-model": "~5.5.1",
196
+ "@xyo-network/module-abstract": "^5.5.5",
197
+ "@xyo-network/module-model": "^5.5.5",
198
+ "@xyo-network/network": "~5.5.1",
199
+ "@xyo-network/node-core-types": "~4.1.10",
200
+ "@xyo-network/node-memory": "~5.5.5",
201
+ "@xyo-network/node-model": "^5.5.5",
202
+ "@xyo-network/payload-builder": "^5.5.1",
203
+ "@xyo-network/payload-model": "^5.5.1",
204
+ "@xyo-network/payload-plugin": "^5.5.1",
205
+ "@xyo-network/payload-validator": "^5.5.1",
206
+ "@xyo-network/payloadset-plugin": "^5.5.5",
207
+ "@xyo-network/query-payload-plugin": "~5.5.1",
208
+ "@xyo-network/schema-cache": "~5.5.1",
209
+ "@xyo-network/schema-payload-plugin": "~5.5.1",
210
+ "@xyo-network/typeof": "~5.3.30",
211
+ "@xyo-network/wallet-model": "^5.5.1",
212
+ "ajv": "^8.18.0",
213
+ "async-mutex": "^0.5.0",
214
+ "axios": "^1.15.2",
215
+ "bn.js": "^5.2.3",
216
+ "bowser": "^2.14.1",
217
+ "buffer": "^6.0.3",
218
+ "chalk": "^5.6.2",
219
+ "ethers": "^6.16.0",
220
+ "fast-deep-equal": "~3.1.3",
221
+ "js-cookie": "~3.0.5",
222
+ "lru-cache": "^11.3.5",
223
+ "pako": "^2.1.0",
224
+ "react": "^19.2.5",
225
+ "react-dom": "^19.2.5",
226
+ "react-router-dom": "^7.14.2",
227
+ "spark-md5": "~3.0.2",
228
+ "zod": "^4.3.6"
91
229
  },
92
230
  "publishConfig": {
93
231
  "access": "public"
94
232
  },
95
233
  "docs": "dist/docs.json"
96
- }
234
+ }