import React, { useContext } from "react" import classnames from "classnames" import { flexRender, Row } from "@tanstack/react-table" import { GenericObject } from "../../types" import { buildCss } from "../../utilities/props" import { globalProps } from "../../utilities/globalProps" import { isChrome } from "../Utilities/BrowserCheck" import LoadingInline from "../../pb_loading_inline/_loading_inline" import { SubRowHeaderRow } from "../Components/SubRowHeaderRow" import { LoadingCell } from "../Components/LoadingCell" import { renderCollapsibleTrail } from "../Components/CollapsibleTrail" import AdvancedTableContext from "../Context/AdvancedTableContext" type TableBodyProps = { className?: string collapsibleTrail?: boolean dark?: boolean id?: string subRowHeaders?: string[] } export const TableBody = ({ className, collapsibleTrail = true, dark = false, id, subRowHeaders, ...props }: TableBodyProps) => { const { columnDefinitions, enableToggleExpansion, handleExpandOrCollapse, isPinnedLeft = false, inlineRowLoading, loading, responsive, table, } = useContext(AdvancedTableContext) const classes = classnames( buildCss("pb_advanced_table_body"), { 'pinned-left': responsive === "scroll" && isPinnedLeft }, globalProps(props), className ) const columnPinning = table.getState().columnPinning; return ( <> {table.getRowModel().rows.map((row: Row) => { const isExpandable = row.getIsExpanded() const isFirstChildofSubrow = row.depth > 0 && row.index === 0 const rowHasNoChildren = row.original.children && !row.original.children.length ? true : false const numberOfColumns = table.getAllFlatColumns().length const isDataLoading = isExpandable && (inlineRowLoading && rowHasNoChildren) && (row.depth < columnDefinitions[0].cellAccessors?.length) const rowBackground = isExpandable && ((!inlineRowLoading && row.getCanExpand()) || (inlineRowLoading && rowHasNoChildren)) return ( {isFirstChildofSubrow && subRowHeaders && ( )} 0 ? `depth-sub-row-${row.depth}` : "" }`} id={`${row.index}-${row.id}-${row.depth}-row`} > {row.getVisibleCells().map((cell, i) => { const isPinnedLeft = columnPinning.left.includes(cell.column.id) return ( {collapsibleTrail && i === 0 && row.depth > 0 && renderCollapsibleTrail(row.depth)} {loading ? ( ) : ( flexRender(cell.column.columnDef.cell, cell.getContext()) )} ) })} {/* Display LoadingInline if Row Data is querying and there are no children already */} {isDataLoading ? ( ) : null} ) })} ) }