import * as React from 'react'; import Box from "@mui/material/Box"; import 'handsontable/dist/handsontable.full.min.css'; //import 'handsontable/styles/ht-theme-main.min.css'; import { HandsonTable } from 'handsontable/base'; import {HotTable} from "@handsontable/react"; import { registerAllModules } from 'handsontable/registry'; import {RichTreeView } from "@mui/x-tree-view/RichTreeView"; import { Grid } from '@mui/material'; import Tab from "@mui/material/Tab"; import TabContext from "@mui/lab/TabContext"; import TabList from "@mui/lab/TabList"; import TabPanel from "@mui/lab/TabPanel"; import Stack from "@mui/material/Stack"; //import { registerPlugin, NestedRows } from 'handsontable/plugins'; //registerPlugin(NestedRows); import Service from './Service'; import { textRenderer, registerRenderer } from 'handsontable/renderers'; import Button from '@mui/material/Button'; import ButtonGroup from '@mui/material/ButtonGroup'; import {danxiangdinge_index} from './utils'; import {shanchu, undo, redo, quanbushanchu, danxiangdinge, updateDercj} from './editor'; import { HyperFormula } from 'hyperformula'; registerAllModules(); /** * 本条规定了工程量清单编码的表示方式:十二位阿拉伯数字及其设置规定。 各位数字的含义是:一、二位为专业工程代码(01—房屋建筑与装饰工程;02—仿古建筑工程; 03—通用安装工程;04—市政工程;05—园林绿化工程;06—矿山工程;07—构筑物工程;08—城市 轨道交通工程;09—爆破工程。以后进入国标的专业工程代码以此类推);三、四位为附录分类顺序码; 五、六位为分部工程顺序码;七、八、九位为分项工程项目名称顺序码;十至十二位为清单项目名称 顺序码。 */ function copy(input) { return JSON.parse(JSON.stringify(input)); } export default function Qingdan({name, bh, bt, rgde, jxde, clde, beizhu, clickCallback}) { const hyperformulaInstance = HyperFormula.buildEmpty({ // to use an external HyperFormula instance, // initialize it with the `'internal-use-in-handsontable'` license key licenseKey: 'internal-use-in-handsontable', }); function coverRenderer(_instance, td, _row, _col, _prop, value, _cellProperties) { let z = _instance.getDataAtRow(_row); if(z[1] == null || z[1].length == 0) { const button = document.createElement('button'); button.innerText="删除"; //img.src = value; /*button.addEventListener('click', (event) => { console.log(hotRef.current?.hotInstance?.getData()[selectedRow.current]); hotRef.current?.hotInstance?.alter('remove_row', selectedRow.current, 1); //console.log(plugin); event.preventDefault(); });*/ button.addEventListener('mousedown', (event) => { setDetail(shanchu(hotRef, selectedRow)); //console.log(plugin); event.preventDefault(); }); td.innerText = ''; td.appendChild(button); } else { const button = document.createElement('button'); button.innerText="全部删除"; //img.src = value; button.addEventListener('mousedown', (event) => { setDetail(quanbushanchu(hotRef, selectedRow)); event.preventDefault(); }); td.innerText = ''; td.appendChild(button); } return td; } registerRenderer('customStylesRenderer', (hotInstance, TD, row, column, ...rest) => { textRenderer(hotInstance, TD, row, column, ...rest); for (let i = 0; i < highlight.current.length; i++) { let entry = highlight.current[i]; if (entry.row == row && entry.col == column) { TD.style.fontWeight = 'bold'; TD.style.color = 'green'; TD.style.background = '#d7f1e1'; } } }); registerRenderer('highlightRowRenderer', (hotInstance, TD, row, column, ...rest) => { if (row == selectedRow.current) { if(column > 0 ) { textRenderer(hotInstance, TD, row, column, ...rest); TD.style.color = 'green'; TD.style.background = '#d7f1e1'; } if (column == 0) { coverRenderer(hotInstance, TD, row, column, ...rest); } } else { textRenderer(hotInstance, TD, row, column, ...rest); } }); const [detail, setDetail] = React.useState([ {"序号": null, "清单编码" : null, "名称" : null,"项目特征" : null, "计算规则" : null, "单位" : null, "数量": null, "综合单价" : null, "合价" : null, "人工费": null, "主材费" : null, "设备费": null, "辅材费": null, "材料费" : null, "机械费" : null, "管理费": null, "利润": null, "暂估价" : null, "综合人工工日" : null, "备注" : null}] ); const [value, setValue] = React.useState("1"); const [rcjhl, setRcjhl] = React.useState([]); const [rcjhl2, setRcjhl2] = React.useState([]); const [fuzhu, setFuzhu] = React.useState([]); const [tuijian, setTuijian] = React.useState([]); const highlight = React.useRef([]); const selectedRow = React.useRef(-1); const hotRef = React.useRef(null); const hotRcjRef = React.useRef(null); const hotTuijianRef = React.useRef(null); const rgdeRef = React.useRef(null); const jxdeRef = React.useRef(null); const cldeRef = React.useRef(null); const isQdrcj = React.useRef(false); React.useEffect( () => { Service.generateQingdanmingxi(name, bh, bt).then(x=>{ //console.log(x); //let y = x.map(t=>{ // t["操作"]=`
`; // return t; //}); setDetail(x); setRcjhl([]); selectedRow.current = -1; }); }, [bh, bt] ); React.useEffect( () => { //console.log(beizhu); let result = [["序号", "编号", "说明"]]; if (beizhu != null) { let keys = Object.keys(beizhu["BZBH"]); for(let i = 0; i < keys.length; i++) { let key = keys[i]; result.push([i+1, beizhu["BZBH"][key], beizhu["SM"][key]]); } setFuzhu(result); } }, [beizhu] ); React.useEffect( () => { //console.log("rgde changed"); //console.log(rgde); rgdeRef.current = rgde; jxdeRef.current = jxde; cldeRef.current = clde; if (isQdrcj.current) { highlight.current = []; } else { let toHighlight = []; for(let i = 1; i < rcjhl.length; i++) { let entry = rcjhl[i]; let bianhao = entry[1]; let rcjlb = entry[8]; let hit = false; if (Number(rcjlb) == Number(1) && rgde) { for (let j = 0; j < rgde.length; j++) { if (rgde[j]["CLBH"] == bianhao) { if(rgde[j]["CLMC"] == entry[2])hit = true; let danjia = Number(entry[5]); if (danjia != rgde[j]["YSJG"]) { //console.log(`[${i},5]danjia bu yizhi`); toHighlight.push({row: i, col: 5, renderer: "customStylesRenderer"}); } let hanliang = Number(entry[10]); if (hanliang != rgde[j]["gr"]) { //console.log(`[${i}, 10]hanliang bu yizhi`); toHighlight.push({row: i, col: 10, renderer: "customStylesRenderer"}); } } } } if (Number(rcjlb) == Number(3) && jxde ) { for (let j = 0; j < jxde.length; j++) { if (jxde[j]["jxbh"] == bianhao) { if(jxde[j]["jxmc"] == entry[2])hit = true; let danjia = Number(entry[5]); if (danjia != jxde[j]["tbdj"]) { //console.log(`[${i},5]danjia bu yizhi`); toHighlight.push({row: i, col: 5, renderer: "customStylesRenderer"}); } let hanliang = Number(entry[10]); if (hanliang != jxde[j]["sl"]) { //console.log(`[${i}, 10]hanliang bu yizhi`); toHighlight.push({row: i, col: 10, renderer: "customStylesRenderer"}); } } } } if (Number(rcjlb) == Number(2) && clde ) { for (let j = 0; j < clde.length; j++) { if (clde[j]["CLBH"] == bianhao) { if(clde[j]["CLMC"] == entry[2])hit = true; let danjia = Number(entry[5]); if (danjia != clde[j]["YSJG"]) { //console.log(`[${i},5]danjia bu yizhi`); toHighlight.push({row: i, col: 5, renderer: "customStylesRenderer"}); } let hanliang = Number(entry[10]); if (hanliang != clde[j]["SL"]) { //console.log(`[${i}, 10]hanliang bu yizhi`); toHighlight.push({row: i, col: 10, renderer: "customStylesRenderer"}); } } } } if (!hit) { toHighlight.push({row: i, col: 1, renderer: "customStylesRenderer"}); } } //console.log(toHighlight); highlight.current = toHighlight; } let bzrcjhl = [["人材机编码", "名称", "单位", "单价", "合价", "含量"]] if (rgde) for (let i = 0; i < rgde.length; i++) { bzrcjhl.push([rgde[i]["CLBH"], rgde[i]["CLMC"], rgde[i]["JLDW"], rgde[i]["YSJG"], rgde[i]["gf"], rgde[i]["gr"]]); } if (clde) for (let i = 0; i < clde.length; i++) { bzrcjhl.push([clde[i]["CLBH"], clde[i]["CLMC"], clde[i]["JLDW"], clde[i]["YSJG"], clde[i]["HJ"], clde[i]["SL"]]); } if (jxde) for (let i = 0; i < jxde.length; i++) { bzrcjhl.push([jxde[i]["jxbh"], jxde[i]["jxmc"], jxde[i]["DW"], jxde[i]["tbdj"], jxde[i]["hj"], jxde[i]["sl"]]); } setRcjhl2(bzrcjhl); }, [rgde, jxde, clde] ); const handleChange = (event, newValue) => { setValue(newValue); }; const afterUpdateData = (x, initial, source)=>{ console.log(source); let plugin = hotRef.current?.hotInstance.getPlugin("NestedRows"); let ui = plugin.collapsingUI; //ui.collapseRow(1); hotRef.current?.hotInstance?.scrollViewportTo({ row: selectedRow.current }); }; const handleSelection = (row, column) => { selectedRow.current = row; let selected = hotRef.current?.hotInstance?.getData()[row]; if (!selected) return; if (selected[1] != null) { Service.generateQingdanrcj(name, bh,bt,selected[2]).then(x=>{ //setRcjhl(x); hotRcjRef.current?.hotInstance?.loadData(x); isQdrcj.current = true; highlight.current = []; }); Service.generateQingdanTuijian(name, bh,bt,selected[2]).then(x=>{ //setTuijian(x); hotTuijianRef.current?.hotInstance?.loadData(x); //isQdrcj.current = true; //setHighlight([]); }); }else{ let qdbm = null; for (let i = row - 1; i > -1; i= i - 1) { let above = hotRef.current?.hotInstance?.getData()[i]; if (above[1] != null) { qdbm = above[2]; break; } } //console.log(name, bh,bt,qdbm, selected[1]); clickCallback(qdbm, selected[2]); Service.generateDingercj(name, bh,bt,qdbm, selected[2], selected[6]).then(x=>{ console.log(x); //setRcjhl(x); hotRcjRef.current?.hotInstance?.loadData(x); isQdrcj.current = false; let toHighlight = []; for(let i = 1; i < x.length; i++) { let entry = x[i]; let bianhao = entry[1]; let rcjlb = entry[8]; let hit = false; if (Number(rcjlb) == 1 && rgdeRef.current ) { for (let j = 0;j < rgdeRef.current.length; j++) { if (rgdeRef.current[j]["CLBH"] == bianhao) { if(rgdeRef.current[j]["CLMC"] == entry[2])hit = true; let danjia = Number(entry[5]); if (danjia != rgdeRef.current[j]["YSJG"]) { //console.log(`[${i},5]danjia bu yizhi`); toHighlight.push({row: i, col: 5, renderer: "customStylesRenderer"}); } let hanliang = Number(entry[10]); if (hanliang != rgdeRef.current[j]["gr"]) { //console.log(`[${i}, 10]hanliang bu yizhi`); toHighlight.push({row: i, col: 10, renderer: "customStylesRenderer"}); } } } } if (Number(rcjlb) == 3 && jxdeRef.current ) { for (let j = 0; j < jxdeRef.current.length; j++) { if (jxdeRef.current[j]["jxbh"] == bianhao) { if(jxdeRef.current[j]["jxmc"] == entry[2])hit = true; let danjia = Number(entry[5]); if (danjia != jxdeRef.current[j]["tbdj"]) { //console.log(`[${i},5]danjia bu yizhi`); toHighlight.push({row: i, col: 5, renderer: "customStylesRenderer"}); } let hanliang = Number(entry[10]); if (hanliang != jxdeRef.current[j]["sl"]) { //console.log(`[${i}, 10]hanliang bu yizhi`); toHighlight.push({row: i, col: 10, renderer: "customStylesRenderer"}); } } } } if (Number(rcjlb) == 2 && cldeRef.current ) { for (let j = 0; j < cldeRef.current.length; j++) { if (cldeRef.current[j]["CLBH"] == bianhao) { if(cldeRef.current[j]["CLMC"] == entry[2])hit = true; let danjia = Number(entry[5]); if (danjia != cldeRef.current[j]["YSJG"]) { //console.log(`[${i},5]danjia bu yizhi`); toHighlight.push({row: i, col: 5, renderer: "customStylesRenderer"}); } let hanliang = Number(entry[10]); if (hanliang != cldeRef.current[j]["SL"]) { //console.log(`[${i}, 10]hanliang bu yizhi`); toHighlight.push({row: i, col: 10, renderer: "customStylesRenderer"}); } } } } if (!hit) { toHighlight.push({row: i, col: 1, renderer: "customStylesRenderer"}); } } highlight.current = toHighlight; }); } hotRef.current?.hotInstance?.render(); }; return ( { let plugin = hotRef.current?.hotInstance.getPlugin("NestedRows"); let ui = plugin.collapsingUI; console.log(ui); }} //afterSelection={handleSelection} afterSelection={handleSelection} ref = {hotRef} cells={(row, col, prop) => { return { // row options, which apply to each cell of the second row // and to each cell of the fifth row renderer: "highlightRowRenderer" }; } } colWidths={(index) => { if (index == 4 || index == 5) return 300; else return 100; }} readOnly={true} /*afterUndo={(action) => { console.log(action); console.log(hotRef.current?.hotInstance?.getData()); }}*/ //trimRows={true} contextMenu={false} bindRowsWithHeaders={true} fixedRowsTop={0} fixedColumnsStart={2} manualColumnResize={true} rowHeaders={true} columns = {[ { data: '操作' }, { data: '序号' }, { data: '清单编码' }, { data: '名称' }, { data: '项目特征' }, { data: '计算规则' }, { data: '单位' }, { data: '数量' }, { data: '综合单价' }, { data: '合价' }, { data: '人工费' }, { data: '主材费' }, { data: '设备费' }, { data: '辅材费' }, { data: '材料费' }, { data: '机械费' }, { data: '管理费' }, { data: '利润' }, { data: '暂估价' }, { data: '综合人工工日' }, { data: '备注' }, ]} colHeaders={["操作", "序号", "清单编码", "名称", "项目特征", "计算规则", "单位", "数量", "综合单价", "合价", "人工费", "主材费", "设备费", "辅材费", "材料费", "机械费", "管理费", "利润" , "暂估价", "综合人工工日", "备注" ]} height="400" selectionMode="single" autoWrapRow={false} autoWrapCol={false} licenseKey="non-commercial-and-evaluation" // for non-commercial use only /> { if (row === 0) { return { readOnly: true, renderer: "customStylesRenderer" }; } if (col <= 1 || col === 11) { return { readOnly: true, renderer: "customStylesRenderer" }; } return {renderer: "customStylesRenderer"}; }} fixedRowsTop={1} selectionMode="single" autoWrapRow={false} autoWrapCol={false} ref = {hotRcjRef} afterChange={(changes, source) => { //console.log(hotRcjRef.current?.hotInstance?.getData()); updateDercj(selectedRow.current, hotRcjRef.current?.hotInstance?.getData()); }} licenseKey="non-commercial-and-evaluation" // for non-commercial use only /> ); }