From 99411967019bbf0d7b0b971eae0db2c2c58025f0 Mon Sep 17 00:00:00 2001 From: skyouc <958836976@qq.com> Date: 星期六, 30 八月 2025 16:27:47 +0800 Subject: [PATCH] 修改任务状态 --- rsf-admin/src/page/basicInfo/whMat/whMatCreate.jsx | 893 +++++++++++++++++++++++++++++++++++++++------------------- 1 files changed, 599 insertions(+), 294 deletions(-) diff --git a/rsf-admin/src/page/basicInfo/whMat/whMatCreate.jsx b/rsf-admin/src/page/basicInfo/whMat/whMatCreate.jsx index 9276214..fbc038f 100644 --- a/rsf-admin/src/page/basicInfo/whMat/whMatCreate.jsx +++ b/rsf-admin/src/page/basicInfo/whMat/whMatCreate.jsx @@ -1,327 +1,632 @@ import React, { useState, useRef, useEffect, useMemo } from "react"; import { - CreateBase, - Form, - useTranslate, - Toolbar, - SaveButton, - TextInput, - required, - NumberInput, -} from 'react-admin'; + CreateBase, + Form, + useTranslate, + Toolbar, + SaveButton, + TextInput, + ReferenceInput, + AutocompleteInput, + required, + NumberInput, +} from "react-admin"; import { - Dialog, - DialogActions, - DialogContent, - DialogTitle, - Stack, - Grid, - Box, - TableRow, - IconButton, - Table, - TableBody, - TableCell, - TableContainer, - TableHead, - Paper, - Checkbox -} from '@mui/material'; + Dialog, + DialogActions, + DialogContent, + DialogTitle, + Stack, + Grid, + Box, + TableRow, + IconButton, + Table, + TableBody, + TableCell, + TableContainer, + TableHead, + Paper, + Checkbox, + Button, +} from "@mui/material"; import DialogCloseButton from "@/page/components/DialogCloseButton"; -import { styled } from '@mui/material/styles'; -import KeyboardArrowDownIcon from '@mui/icons-material/KeyboardArrowDown'; -import KeyboardArrowRightIcon from '@mui/icons-material/KeyboardArrowRight'; - +import { styled } from "@mui/material/styles"; +import KeyboardArrowDownIcon from "@mui/icons-material/KeyboardArrowDown"; +import KeyboardArrowRightIcon from "@mui/icons-material/KeyboardArrowRight"; +import { Search } from "@mui/icons-material"; +import WhTable from "./whTable"; const columns = [ - { - id: 'checkbox', - label: 1, - align: 'center', - minWidth: 50, - }, - { - id: 'name', - label: 'table.field.dept.name', - minWidth: 170, - }, - { - id: 'fullName', - label: 'table.field.dept.fullName', - minWidth: 170, - }, - { - id: 'leader', - label: 'table.field.dept.leader', - minWidth: 170, - }, - { - id: 'updateTime', - label: 'common.field.updateTime', - minWidth: 170, - format: (val) => { - return new Date(val).toLocaleString(); - } - }, + { + id: "matnrCode", + label: "table.field.whMat.matnrCode", + minWidth: 160, + }, + { + id: "matnrName", + label: "table.field.whMat.matnrName", + }, + { + id: "matnrGroupId", + label: "table.field.whMat.matnrGroupId", + }, + { + id: "spec", + label: "table.field.whMat.spec", + }, + { + id: "color", + label: "table.field.whMat.color", + }, + { + id: "size", + label: "table.field.whMat.size", + }, + { + id: "minWeight", + label: "table.field.whMat.minWeight", + }, + { + id: "maxWeight", + label: "table.field.whMat.maxWeight", + }, ]; const WhMatCreate = (props) => { - const translate = useTranslate(); - const { editRecord, open, setOpen, callback, resource } = props; + const translate = useTranslate(); + const { editRecord, open, setOpen, callback, resource } = props; - const handleClose = (event, reason) => { - if (reason !== "backdropClick") { - setOpen(false); - } - }; + const handleClose = (event, reason) => { + if (reason !== "backdropClick") { + setOpen(false); + } + }; - const onSubmit = (data) => { - const _params = { ...data }; - }; + const onSubmit = (data) => { + const _params = { ...data }; + }; - return ( - <> - <CreateBase> - <Dialog - open={open} - onClose={handleClose} - aria-labelledby="form-dialog-title" - fullWidth - disableRestoreFocus - maxWidth="lg" // 'xs' | 'sm' | 'md' | 'lg' | 'xl' - > - <Form record={editRecord} onSubmit={onSubmit}> - <DialogTitle id="form-dialog-title" sx={{ - position: 'sticky', - top: 0, - backgroundColor: 'background.paper', - zIndex: 1000 - }} - > - {editRecord ? translate('update.title') : translate('create.title')} - <Box sx={{ position: 'absolute', top: 8, right: 8, zIndex: 1001 }}> - <DialogCloseButton onClose={handleClose} /> - </Box> - </DialogTitle> - <DialogContent sx={{ mt: 2 }}> - <WhMatCreateContent /> - </DialogContent> - <DialogActions sx={{ position: 'sticky', bottom: 0, backgroundColor: 'background.paper', zIndex: 1000 }}> - <Toolbar sx={{ width: '100%', justifyContent: 'space-between' }} > - <SaveButton /> - </Toolbar> - </DialogActions> - </Form> - </Dialog> - </CreateBase> - </> - ); + return ( + <> + <CreateBase> + <Dialog + open={open} + onClose={handleClose} + aria-labelledby="form-dialog-title" + fullWidth + disableRestoreFocus + maxWidth="lg" // 'xs' | 'sm' | 'md' | 'lg' | 'xl' + > + <Form record={editRecord} onSubmit={onSubmit}> + <DialogTitle + id="form-dialog-title" + sx={{ + position: "sticky", + top: 0, + backgroundColor: "background.paper", + zIndex: 1000, + }} + > + {editRecord + ? translate("update.title") + : translate("create.title")} + <Box + sx={{ position: "absolute", top: 8, right: 8, zIndex: 1001 }} + > + <DialogCloseButton onClose={handleClose} /> + </Box> + </DialogTitle> + <DialogContent sx={{ mt: 2 }}> + <WhMatCreateContent /> + </DialogContent> + <DialogActions + sx={{ + position: "sticky", + bottom: 0, + backgroundColor: "background.paper", + zIndex: 1000, + }} + > + <Toolbar sx={{ width: "100%", justifyContent: "space-between" }}> + <SaveButton /> + </Toolbar> + </DialogActions> + </Form> + </Dialog> + </CreateBase> + </> + ); }; const StyledTableRow = styled(TableRow)(({ theme }) => ({ - '& .MuiButtonBase-root': { - padding: '0px 8px' - } + "& .MuiButtonBase-root": { + padding: "0px 0px", + }, })); const StyledTableCell = styled(TableCell)(({ theme }) => ({ - overflow: 'hidden', - textOverflow: 'ellipsis', - whiteSpace: 'nowrap', - maxWidth: 600, + "& .MuiButtonBase-root": { + padding: "0px 0px", + }, + overflow: "hidden", + textOverflow: "ellipsis", + whiteSpace: "nowrap", + maxWidth: 600, })); const TreeTableRow = (props) => { - const { row, depth = 0, openNodes, setOpenNodes, onEdit, onDelete } = props; - const isOpen = openNodes[row.id] || false; - const [checked, setChecked] = useState(false); - const toggleNode = (id) => { - setOpenNodes(prevState => ({ ...prevState, [id]: !prevState[id] })); - }; - return ( - <React.Fragment> - <StyledTableRow hover tabIndex={-1} key={row.id}> - <StyledTableCell sx={{ padding: 0, width: 60 }}> - {row.children && ( - <IconButton - aria-label="expand row" - size="small" - style={{ paddingLeft: (depth * 16) }} - onClick={() => toggleNode(row.id)} - > - {isOpen ? <KeyboardArrowDownIcon /> : <KeyboardArrowRightIcon />} - </IconButton> - )} + const { row, depth = 0, openNodes, setOpenNodes, onEdit, onDelete } = props; + const isOpen = openNodes[row.id] || false; + const [checked, setChecked] = useState(false); + const toggleNode = (id) => { + setOpenNodes((prevState) => ({ ...prevState, [id]: !prevState[id] })); + }; + return ( + <React.Fragment> + <StyledTableRow hover tabIndex={-1} key={row.id}> + <StyledTableCell sx={{ padding: 0, width: 20 }}> + {row.children && ( + <IconButton + aria-label="expand row" + size="small" + style={{ marginLeft: depth * 16 + 8 }} + onClick={() => toggleNode(row.id)} + > + {isOpen ? <KeyboardArrowDownIcon /> : <KeyboardArrowRightIcon />} + </IconButton> + )} + </StyledTableCell> + <StyledTableCell style={{ paddingLeft: depth * 16 + 16 }}> + <Checkbox + key={row.id} + checked={row.checked} + // onChange={() => { row.checked = !row.checked; }} + /> + </StyledTableCell> + {columns.map((column, idx) => { + if (column.id !== "actions") { + const value = row[column.id]; + return ( + <> + <StyledTableCell + key={column.id} + align={column.align || "left"} + // style={{ paddingLeft: idx === 0 && (depth * 16 + 16) }} + onClick={() => toggleNode(row.id)} + > + {column.format ? column.format(value) : value} </StyledTableCell> - <StyledTableCell key="checkbox" align="center" style={{ paddingLeft: (depth * 16 + 16) }}> - <Checkbox - checked={row.checked} - onChange={() => {row.checked = !row.checked;}} - /> - </StyledTableCell> - {columns.map((column, idx) => { - if (column.id !== 'actions' && column.id !== 'checkbox') { - const value = row[column.id]; - return ( - <> - <StyledTableCell - key={column.id} - align={column.align || 'left'} - style={{ paddingLeft: idx === 0 && (depth * 16 + 16) }} - onClick={() => toggleNode(row.id)} - > - {column.format ? column.format(value) : value} - </StyledTableCell> - </> - - ) - } - })} - {/* <StyledTableCell> - <Tooltip title="Edit"> - <IconButton onClick={() => onEdit(row)}> - <Edit /> - </IconButton> - </Tooltip> - <Tooltip title="Delete"> - <IconButton onClick={() => onDelete(row)}> - <Delete /> - </IconButton> - </Tooltip> - </StyledTableCell> */} - </StyledTableRow> - {row.children && isOpen && ( - row.children.map((child) => ( - <TreeTableRow - key={child.id} - row={child} - depth={depth + 1} - openNodes={openNodes} - setOpenNodes={setOpenNodes} - /> - )) - )} - </React.Fragment> - ); + </> + ); + } + })} + </StyledTableRow> + {row.children && + isOpen && + row.children.map((child) => ( + <TreeTableRow + key={child.id} + row={child} + depth={depth + 1} + openNodes={openNodes} + setOpenNodes={setOpenNodes} + /> + ))} + </React.Fragment> + ); }; const WhMatCreateContent = (props) => { - const translate = useTranslate(); - const [treeData, setTreeData] = useState([ + const translate = useTranslate(); + const [selAll, setSelAll] = useState(false); + const [treeData, setTreeData] = useState([ + { + id: 1, + matnrCode: "root1", + matnrName: "鏍硅妭鐐�", + matnrGroupId: "admin", + sort: 1, + checked: false, + children: [ { - id: 1, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, checked: false, children: [ - { - id: 29, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: [ - { id: 30, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 31, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 32, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 33, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 34, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 35, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - ] - }, - { id: 24, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 25, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 26, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 27, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 28, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - - ] + id: 29, + matnrCode: "root29", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: [ + { + id: 30, + matnrCode: "root30", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + { + id: 31, + matnrCode: "root31", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + { + id: 32, + matnrCode: "root32", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + { + id: 33, + matnrCode: "root33", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + { + id: 34, + matnrCode: "root34", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + { + id: 35, + matnrCode: "root35", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + ], }, - { id: 2, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 3, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 4, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 5, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 6, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 7, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 8, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 9, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 10, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 11, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 12, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 13, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 14, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 15, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 16, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 17, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 18, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 19, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 20, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 21, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 22, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, - { id: 23, name: 'root', fullName: '鏍硅妭鐐�', leader: 'admin', sort: 1, children: null }, + { + id: 24, + matnrCode: "root24", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + { + id: 25, + matnrCode: "root25", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + { + id: 26, + matnrCode: "root26", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + { + id: 27, + matnrCode: "root27", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + { + id: 28, + matnrCode: "root28", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + ], + }, + { + id: 2, + matnrCode: "root2", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + { + id: 3, + matnrCode: "root3", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + { + id: 4, + matnrCode: "root4", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + ]); + const [openNodes, setOpenNodes] = React.useState({}); + const handleSearch = () => { + console.log("handleSearch"); + }; + const selectAll = () => { + selAll ? setSelAll(false) : setSelAll(true); + }; - ]); - const [openNodes, setOpenNodes] = React.useState({}); + useEffect(() => { + const setAllChecked = (nodes, checked) => { + nodes.forEach((node) => { + node.checked = !checked; + if (node.children) { + setAllChecked(node.children, checked); + } + }); + }; - return ( - <> - <Grid container rowSpacing={2} columnSpacing={2}> - <Grid item xs={6} display="flex" gap={1}> - <TextInput - label="table.field.dept.name" - source="name" - parse={v => v} - validate={required()} - /> - </Grid> - <Grid item xs={6} display="flex" gap={1}> - <TextInput - label="table.field.dept.fullName" - source="fullName" - parse={v => v} - /> - </Grid> - <Grid item xs={6} display="flex" gap={1}> - <TextInput - label="table.field.dept.leader" - source="leader" - parse={v => v} - /> - </Grid> - <Grid item xs={6} display="flex" gap={1}> - <NumberInput - label="table.field.dept.sort" - source="sort" - /> - </Grid> + if (selAll) { + setAllChecked(treeData, true); + } else { + setAllChecked(treeData, false); + } + }, [selAll]); - </Grid> - <TableContainer component={Paper}> - <Table size="small"> - <TableHead> - <TableRow> - <StyledTableCell sx={{ padding: 0, width: 60 }} /> - {columns.map((column, idx) => ( - <StyledTableCell - key={idx} - align={column.align || 'left'} - style={{ - minWidth: column.minWidth - }} - > - {typeof column.label === 'string' ? translate(column.label) : <Checkbox />} - </StyledTableCell> - ))} - </TableRow> - </TableHead> - <TableBody> - {treeData && treeData.length > 0 && ( - treeData.map((row) => ( - <TreeTableRow - key={row.id} - row={row} - openNodes={openNodes} - setOpenNodes={setOpenNodes} - /> - )) - )} - </TableBody> - </Table> - </TableContainer> - </> + const [treeDatas, setTreeDatas] = useState([ + { + id: 1, + matnrCode: "root1", + matnrName: "鏍硅妭鐐�", + matnrGroupId: "admin", + sort: 1, + checked: false, + children: [ + { + id: 29, + matnrCode: "root29", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: [ + { + id: 30, + matnrCode: "root30", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + { + id: 31, + matnrCode: "root31", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + { + id: 32, + matnrCode: "root32", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + { + id: 33, + matnrCode: "root33", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + { + id: 34, + matnrCode: "root34", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + { + id: 35, + matnrCode: "root35", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + ], + }, + { + id: 24, + matnrCode: "root24", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + { + id: 25, + matnrCode: "root25", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + { + id: 26, + matnrCode: "root26", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + { + id: 27, + matnrCode: "root27", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + { + id: 28, + matnrCode: "root28", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + ], + }, + { + id: 2, + matnrCode: "root2", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + { + id: 3, + matnrCode: "root3", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + { + id: 4, + matnrCode: "root4", + fullName: "鏍硅妭鐐�", + leader: "admin", + sort: 1, + checked: false, + children: null, + }, + ]); - ); + return ( + <> + <Grid container rowSpacing={2} columnSpacing={2}> + <Grid item xs={3} display="flex" gap={1}> + <TextInput label="table.field.whMat.matnrCode" source="matnrCode" /> + </Grid> + <Grid item xs={3} display="flex" gap={1}> + <TextInput label="table.field.whMat.matnrName" source="matnrName" /> + </Grid> + <Grid item xs={3} display="flex" gap={1}> + <ReferenceInput source="groupId" reference="matnrGroup"> + <AutocompleteInput + label="table.field.whMat.matnrGroupId" + optionText="name" + filterToQuery={(val) => ({ name: val })} + /> + </ReferenceInput> + </Grid> + <Grid item xs={3} display="flex" gap={1}> + <TextInput label="table.field.whMat.spec" source="spec" /> + </Grid> + + <Grid item xs={3} display="flex" gap={1}> + <TextInput label="table.field.whMat.color" source="color" /> + </Grid> + <Grid item xs={3} display="flex" gap={1}> + <TextInput label="table.field.whMat.size" source="size" /> + </Grid> + <Grid item xs={3} display="flex" gap={1}> + <TextInput label="table.field.whMat.minWeight" source="minWeight" /> + </Grid> + <Grid item xs={3} display="flex" gap={1}> + <TextInput label="table.field.whMat.maxWeight" source="maxWeight" /> + </Grid> + </Grid> + <Box sx={{ mt: 2, mb: 2 }}> + <Stack direction="row" spacing={1} justifyContent="flex-end"> + <Button + variant="outlined" + color="primary" + startIcon={<Search />} + onClick={handleSearch} + > + {translate("ra.action.search")} + </Button> + </Stack> + </Box> + <TableContainer component={Paper}> + <Table size="small"> + <TableHead> + <TableRow> + <StyledTableCell sx={{ padding: 0, width: 0 }} /> + <StyledTableCell sx={{ width: 0 }}> + <Checkbox checked={selAll} onClick={selectAll} /> + </StyledTableCell> + {columns.map((column, idx) => ( + <StyledTableCell + key={idx} + align={column.align || "left"} + style={{ + minWidth: column.minWidth, + }} + > + {translate(column.label)} + </StyledTableCell> + ))} + </TableRow> + </TableHead> + <TableBody> + {treeData && + treeData.length > 0 && + treeData.map((row) => ( + <TreeTableRow + key={row.id} + row={row} + openNodes={openNodes} + setOpenNodes={setOpenNodes} + /> + ))} + </TableBody> + </Table> + </TableContainer> + {/* <WhTable data={treeDatas} /> */} + </> + ); }; -export default WhMatCreate; \ No newline at end of file +export default WhMatCreate; -- Gitblit v1.9.1