Qingdan3.js 64 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339134013411342134313441345134613471348134913501351135213531354135513561357135813591360136113621363136413651366136713681369137013711372137313741375137613771378137913801381138213831384138513861387138813891390139113921393139413951396139713981399140014011402140314041405140614071408140914101411141214131414141514161417141814191420142114221423142414251426142714281429143014311432143314341435143614371438
  1. import * as React from 'react';
  2. import Box from "@mui/material/Box";
  3. import { Table, ConfigProvider } from "antd";
  4. import { Grid } from '@mui/material';
  5. import Tooltip from '@mui/material/Tooltip';
  6. import AddIcon from '@mui/icons-material/Add';
  7. import SaveIcon from '@mui/icons-material/Save';
  8. import CancelIcon from '@mui/icons-material/Close';
  9. import EditIcon from '@mui/icons-material/Edit';
  10. import DeleteIcon from '@mui/icons-material/DeleteOutlined';
  11. import Tab from "@mui/material/Tab";
  12. import TabContext from "@mui/lab/TabContext";
  13. import TabList from "@mui/lab/TabList";
  14. import TabPanel from "@mui/lab/TabPanel";
  15. import Stack from "@mui/material/Stack";
  16. import Service from './Service';
  17. import Button from '@mui/material/Button';
  18. import ButtonGroup from '@mui/material/ButtonGroup';
  19. import {extractFuzhu} from './utils';
  20. import {shanchu, undo, redo, danxiangdinge, updateDercj, changguidinge, handleBeizhu, huan, updateShuliang, handleYuban, updateDeMingcheng, handleRcjbc} from './editor';
  21. import Backdrop from '@mui/material/Backdrop';
  22. import CircularProgress from '@mui/material/CircularProgress';
  23. import { DataGrid, GridRowModes, GridActionsCellItem, GridRowEditStopReasons, zhCN as zhCN_MUI, GridToolbarContainer } from '@mui/x-data-grid';
  24. import Dialog from '@mui/material/Dialog';
  25. import DialogTitle from '@mui/material/DialogTitle';
  26. import DialogContent from '@mui/material/DialogContent';
  27. import IconButton from '@mui/material/IconButton';
  28. import Typography from '@mui/material/Typography';
  29. import {
  30. SettingFilled,
  31. } from '@ant-design/icons';
  32. import { v4 as uuidv4 } from 'uuid';
  33. import zhCN from 'antd/locale/zh_CN';
  34. import {copy} from './utils';
  35. import {TabulatorFull as Tabulator} from "tabulator-tables"; //import Tabulator library
  36. import "tabulator-tables/dist/css/tabulator.min.css"; //import Tabulator stylesheet
  37. import './Tabulator.css';
  38. /**
  39. *
  40. 本条规定了工程量清单编码的表示方式:十二位阿拉伯数字及其设置规定。
  41. 各位数字的含义是:一、二位为专业工程代码(01—房屋建筑与装饰工程;02—仿古建筑工程;
  42. 03—通用安装工程;04—市政工程;05—园林绿化工程;06—矿山工程;07—构筑物工程;08—城市
  43. 轨道交通工程;09—爆破工程。以后进入国标的专业工程代码以此类推);三、四位为附录分类顺序码;
  44. 五、六位为分部工程顺序码;七、八、九位为分项工程项目名称顺序码;十至十二位为清单项目名称
  45. 顺序码。
  46. */
  47. export default function Qingdan3({name, bh, bt, rgde, jxde, clde, beizhu/*后台传回来的附注信息,要整理后才能成为展示用的行*/ , beizhuFK, clickCallback, loadingCallback, dingeclick, tihuanCallback, tihuanClick, suanshiCallback}) {
  48. const myTable = React.useRef(null);
  49. const myRef = React.useRef(null);
  50. const [valueTab, setValueTab] = React.useState("1");
  51. const handleChange = (event, newValue) => {
  52. setValueTab(newValue);
  53. };
  54. const [rcjhl, setRcjhl] = React.useState([]);
  55. const [rcjhl2, setRcjhl2] = React.useState([]);
  56. const [fuzhu, setFuzhu] = React.useState([]);//展示用的附注行
  57. const [yuban, setYuban] = React.useState([{'key': '0', '说明': '无'}, {'key': '1', '说明': '湿拌砂浆'}, {'key': '2', '说明': '散装干拌(混)砂浆'}, {'key': '3', '说明': '袋装干拌(混)砂浆'}]);
  58. const [tuijian, setTuijian] = React.useState([]);
  59. const [fuzhuEnable, setFuzhuEnable] = React.useState(false);
  60. const [yubanEnable, setYubanEnable] = React.useState(false);
  61. const hotRcjRef = React.useRef(null);
  62. const hotTuijianRef = React.useRef(null);
  63. const highlight = React.useRef([]);
  64. const debmRef = React.useRef(null);
  65. const lastClickRef = React.useRef(null);
  66. const tuijianRef = React.useRef(null);
  67. const tuijianTable = React.useRef(null);
  68. const rcj2Ref = React.useRef(null);
  69. const rcj2Table = React.useRef(null);
  70. const rcjRef = React.useRef(null);
  71. const rcjTable = React.useRef(null);
  72. const [detail, setDetail] = React.useState([
  73. ]);
  74. const selectedRowKeysTable = React.useRef([]);
  75. const selectedRowKeysTableParent = React.useRef(null);
  76. const beizhuFKRef = React.useRef(null);
  77. const rgdeRef = React.useRef(null);
  78. const jxdeRef = React.useRef(null);
  79. const cldeRef = React.useRef(null);
  80. const isQdrcj = React.useRef(false);
  81. const [selectedRowKeys, setSelectedRowKeys] = React.useState([]);
  82. const [selectedRowKeys2, setSelectedRowKeys2] = React.useState([]);
  83. const onSelectChange = (newSelectedRowKeys) => {
  84. console.log('selectedRowKeys changed: ', newSelectedRowKeys);
  85. setSelectedRowKeys(newSelectedRowKeys);
  86. const [newData, newHl] = handleBeizhu(beizhuFKRef.current, selectedRowKeysTable.current[0], newSelectedRowKeys, fuzhu);
  87. if (newData) {
  88. myTable.current.updateData(newData.filter(x=>x['key'] == selectedRowKeysTableParent.current));
  89. let y =[];
  90. for (let i = 1; i < newHl.length; i++) {
  91. y.push({
  92. 'ID' : newHl[i][0],
  93. '人材机编码' : newHl[i][1],
  94. '名称' : newHl[i][2],
  95. '规格型号': newHl[i][3],
  96. '单位' : newHl[i][4],
  97. '单价' : newHl[i][5],
  98. '产地' : newHl[i][6],
  99. '供应厂商' : newHl[i][7],
  100. '人材机类别' : newHl[i][8],
  101. '甲供标志': newHl[i][9],
  102. '含量' : newHl[i][10],
  103. '合价' : newHl[i][11],
  104. '暂估价标志' : newHl[i][12],
  105. '主要材料标志' : newHl[i][13],
  106. '主材标志' : newHl[i][14],
  107. '设备标志' : newHl[i][15]
  108. });
  109. }
  110. setRcjhl(y);
  111. if (rcjTable.current) {
  112. rcjTable.current.replaceData(y);
  113. }
  114. }
  115. };
  116. const onSelectChange2 = (newSelectedRowKeys) => {
  117. setSelectedRowKeys2(newSelectedRowKeys);
  118. const [newData, newHl] = handleYuban(selectedRowKeysTable.current[0], newSelectedRowKeys);
  119. if (newData) {
  120. myTable.current.updateData(newData.filter(x=>x['key'] == selectedRowKeysTableParent.current));
  121. let y =[];
  122. for (let i = 1; i < newHl.length; i++) {
  123. y.push({
  124. 'ID' : newHl[i][0],
  125. '人材机编码' : newHl[i][1],
  126. '名称' : newHl[i][2],
  127. '规格型号': newHl[i][3],
  128. '单位' : newHl[i][4],
  129. '单价' : newHl[i][5],
  130. '产地' : newHl[i][6],
  131. '供应厂商' : newHl[i][7],
  132. '人材机类别' : newHl[i][8],
  133. '甲供标志': newHl[i][9],
  134. '含量' : newHl[i][10],
  135. '合价' : newHl[i][11],
  136. '暂估价标志' : newHl[i][12],
  137. '主要材料标志' : newHl[i][13],
  138. '主材标志' : newHl[i][14],
  139. '设备标志' : newHl[i][15]
  140. });
  141. }
  142. setRcjhl(y);
  143. if (rcjTable.current) {
  144. rcjTable.current.replaceData(y);
  145. }
  146. }
  147. };
  148. /**fuzhu select */
  149. const rowSelection = {
  150. selectedRowKeys,
  151. onChange: onSelectChange,
  152. getCheckboxProps: (record) => {
  153. return {
  154. disabled: !fuzhuEnable
  155. };
  156. }
  157. };
  158. const rowSelection2 = {
  159. type: 'radio',
  160. selectedRowKeys: selectedRowKeys2,
  161. selections: [Table.SELECTION_NONE],
  162. onChange: onSelectChange2,
  163. getCheckboxProps: (record) => {
  164. return {
  165. disabled: !yubanEnable
  166. };
  167. }
  168. };
  169. var editCheck = function(cell){
  170. //cell - the cell component for the editable cell
  171. //get row data
  172. //console.log(cell);
  173. if(cell._cell.row.data['序号']) return false;
  174. return true;
  175. }
  176. var editCheckRcj = function(cell){
  177. //cell - the cell component for the editable cell
  178. //get row data
  179. //console.log(cell);
  180. if(isQdrcj.current) return false;
  181. if (cell._cell.row.getData()['人材机编码'] == '410000F') {
  182. return false;
  183. }
  184. return true;
  185. }
  186. var sparklineFormatter = function(cell, formatterParams, onRendered){
  187. for (let i = 0; i < highlight.current.length; i++) {
  188. let entry = highlight.current[i];
  189. if (entry.row + 1 == cell._cell.row.position && entry.col + 1 == cell._cell.column.getPosition()) {
  190. cell.getElement().style.fontWeight = 'bold';
  191. cell.getElement().style.color = 'green';
  192. cell.getElement().style.background = '#d7f1e1';
  193. }
  194. }
  195. return Number(cell.getValue()).toFixed(2).toString();
  196. };
  197. function handleSelect(row){
  198. selectedRowKeysTable.current = [row._row['data']['key']];
  199. if (row._row.data['序号'] != null && row._row.data['序号'].length >0) {
  200. selectedRowKeysTableParent.current = row._row['data']['key'];
  201. setFuzhu([]);
  202. setRcjrows([]);
  203. setYubanEnable(false);
  204. setSelectedRowKeys2([]);
  205. setShowToolbar(false);
  206. Service.generateQingdanrcj(name, bh,bt,row._row.data['清单编码']).then(x=>{
  207. let y =[];
  208. for (let i = 1; i < x.length; i++) {
  209. y.push({
  210. 'ID' : x[i][0],
  211. '人材机编码' : x[i][1],
  212. '名称' : x[i][2],
  213. '规格型号': x[i][3],
  214. '单位' : x[i][4],
  215. '单价' : x[i][5],
  216. '产地' : x[i][6],
  217. '供应厂商' : x[i][7],
  218. '人材机类别' : x[i][8],
  219. '甲供标志': x[i][9],
  220. '含量' : x[i][10],
  221. '合价' : x[i][11],
  222. '暂估价标志' : x[i][12],
  223. '主要材料标志' : x[i][13],
  224. '主材标志' : x[i][14],
  225. '设备标志' : x[i][15]
  226. });
  227. }
  228. setRcjhl(y);
  229. if (rcjTable.current) {
  230. rcjTable.current.replaceData(y);
  231. }
  232. isQdrcj.current = true;
  233. highlight.current = [];
  234. });
  235. Service.generateQingdanTuijian(name, bh,bt,row._row.data['清单编码']).then(x=>{
  236. setTuijian(x);
  237. if (tuijianTable.current) tuijianTable.current.replaceData(x);
  238. });
  239. }else{
  240. setTuijian([]);
  241. if (tuijianTable.current) tuijianTable.current.replaceData([]);
  242. let row_parent = row._row;
  243. while(row_parent.modules.dataTree.parent) {
  244. row_parent = row_parent.modules.dataTree.parent;
  245. }
  246. //console.log(name, bh,bt,qdbm, selected[1]);
  247. debmRef.current = row._row['data']['清单编码'];
  248. selectedRowKeysTableParent.current = row_parent['data']['key'];
  249. let qdbm = row_parent['data']['清单编码'];
  250. let debm = row._row['data']['清单编码'];
  251. console.log('debm=');
  252. console.log(debm);
  253. let danwei = row._row['data']['单位'];
  254. clickCallback(qdbm, debm);
  255. Service.generateDingercj(name, bh,bt,qdbm, debm, danwei).then(x=>{
  256. console.log(x);
  257. let y =[];
  258. for (let i = 1; i < x[0].length; i++) {
  259. y.push({
  260. 'ID' : x[0][i][0],
  261. '人材机编码' : x[0][i][1],
  262. '名称' : x[0][i][2],
  263. '规格型号': x[0][i][3],
  264. '单位' : x[0][i][4],
  265. '单价' : x[0][i][5],
  266. '产地' : x[0][i][6],
  267. '供应厂商' : x[0][i][7],
  268. '人材机类别' : x[0][i][8],
  269. '甲供标志': x[0][i][9],
  270. '含量' : x[0][i][10],
  271. '合价' : x[0][i][11],
  272. '暂估价标志' : x[0][i][12],
  273. '主要材料标志' : x[0][i][13],
  274. '主材标志' : x[0][i][14],
  275. '设备标志' : x[0][i][15]
  276. });
  277. }
  278. setRcjhl(y);
  279. if (rcjTable.current) {
  280. rcjTable.current.replaceData(y);
  281. }
  282. setShowToolbar(true);
  283. setFuzhuEnable(x[1]);
  284. setYubanEnable(x[1]);
  285. setSelectedRowKeys2(x[2]);
  286. setRcjrows(x[3]);
  287. //hotRcjRef.current?.hotInstance?.loadData(x);
  288. isQdrcj.current = false;
  289. let toHighlight = [];
  290. for(let i = 0; i < y.length; i++) {
  291. let entry = y[i];
  292. let bianhao = entry['人材机编码'];
  293. let rcjlb = entry['人材机类别'];
  294. let hit = false;
  295. if (Number(rcjlb) == 1 && rgdeRef.current ) {
  296. for (let j = 0;j < rgdeRef.current.length; j++) {
  297. if (rgdeRef.current[j]["CLBH"] == bianhao) {
  298. if(rgdeRef.current[j]["CLMC"] == entry['名称'])hit = true;
  299. let danjia = Number(entry['单价']);
  300. if (danjia != rgdeRef.current[j]["YSJG"]) {
  301. //console.log(`[${i},5]danjia bu yizhi`);
  302. toHighlight.push({row: i, col: 5, renderer: "customStylesRenderer"});
  303. }
  304. let hanliang = Number(entry['含量']);
  305. if (hanliang != rgdeRef.current[j]["gr"]) {
  306. //console.log(`[${i}, 10]hanliang bu yizhi`);
  307. toHighlight.push({row: i, col: 10, renderer: "customStylesRenderer"});
  308. }
  309. }
  310. }
  311. }
  312. if (Number(rcjlb) == 3 && jxdeRef.current ) {
  313. for (let j = 0; j < jxdeRef.current.length; j++) {
  314. if (jxdeRef.current[j]["jxbh"] == bianhao) {
  315. if(jxdeRef.current[j]["jxmc"] == entry['名称'])hit = true;
  316. let danjia = Number(entry['单价']);
  317. if (danjia != jxdeRef.current[j]["tbdj"]) {
  318. //console.log(`[${i},5]danjia bu yizhi`);
  319. toHighlight.push({row: i, col: 5, renderer: "customStylesRenderer"});
  320. }
  321. let hanliang = Number(entry['含量']);
  322. if (hanliang != jxdeRef.current[j]["sl"]) {
  323. //console.log(`[${i}, 10]hanliang bu yizhi`);
  324. toHighlight.push({row: i, col: 10, renderer: "customStylesRenderer"});
  325. }
  326. }
  327. }
  328. }
  329. if (Number(rcjlb) == 2 && cldeRef.current ) {
  330. for (let j = 0; j < cldeRef.current.length; j++) {
  331. if (cldeRef.current[j]["CLBH"] == bianhao) {
  332. if(cldeRef.current[j]["CLMC"] == entry['名称'])hit = true;
  333. let danjia = Number(entry['单价']);
  334. if (danjia != cldeRef.current[j]["YSJG"]) {
  335. //console.log(`[${i},5]danjia bu yizhi`);
  336. toHighlight.push({row: i, col: 5, renderer: "customStylesRenderer"});
  337. }
  338. let hanliang = Number(entry['含量']);
  339. if (hanliang != cldeRef.current[j]["SL"]) {
  340. //console.log(`[${i}, 10]hanliang bu yizhi`);
  341. toHighlight.push({row: i, col: 10, renderer: "customStylesRenderer"});
  342. }
  343. }
  344. }
  345. }
  346. if (!hit) {
  347. toHighlight.push({row: i, col: 1, renderer: "customStylesRenderer"});
  348. }
  349. }
  350. highlight.current = toHighlight;
  351. });
  352. }
  353. }
  354. /**补充人材机 */
  355. const [rcjrows, setRcjrows] = React.useState([]);
  356. //const [rowModesModel, setRowModesModel] = React.useState({});
  357. const [showToolbar, setShowToolbar] = React.useState(false);
  358. const rcjcolumns = [
  359. {
  360. field: 'actions',
  361. type: 'actions',
  362. headerName: '操作',
  363. width: 100,
  364. cellClassName: 'actions',
  365. getActions: ({ id }) => {
  366. return [
  367. <GridActionsCellItem
  368. icon={<DeleteIcon />}
  369. label="Delete"
  370. onClick={handleDeleteClick(id)}
  371. color="inherit"
  372. />,
  373. ];
  374. },
  375. },
  376. { field: '人材机编码', headerName: '人材机编码', width: 120, editable: false },
  377. {
  378. field: '名称',
  379. headerName: '名称',
  380. width: 120,
  381. align: 'left',
  382. headerAlign: 'left',
  383. editable: true,
  384. },
  385. {
  386. field: '规格型号',
  387. headerName: '规格型号',
  388. width: 100,
  389. editable: true,
  390. },
  391. {
  392. field: '单位',
  393. headerName: '单位',
  394. width: 80,
  395. editable: true,
  396. },
  397. {
  398. field: '单价',
  399. headerName: '单价',
  400. width: 80,
  401. editable: true,
  402. },
  403. {
  404. field: '产地',
  405. headerName: '产地',
  406. width: 80,
  407. editable: true,
  408. },
  409. {
  410. field: '供应厂商',
  411. headerName: '供应厂商',
  412. width: 80,
  413. editable: true,
  414. },
  415. {
  416. field: '人材机类别',
  417. headerName: '人材机类别',
  418. width: 120,
  419. editable: true,
  420. },
  421. {
  422. field: '甲供标志',
  423. headerName: '甲供标志',
  424. width: 80,
  425. editable: true,
  426. },
  427. {
  428. field: '含量',
  429. headerName: '含量',
  430. width: 80,
  431. editable: true,
  432. },
  433. /* {
  434. field: '合价',
  435. headerName: '合价',
  436. width: 80,
  437. editable: true,
  438. },*/
  439. {
  440. field: '暂估价标志',
  441. headerName: '暂估价标志',
  442. width: 100,
  443. editable: true,
  444. },
  445. {
  446. field: '主要材料标志',
  447. headerName: '主要材料标志',
  448. width: 120,
  449. editable: true,
  450. },
  451. {
  452. field: '主材标志',
  453. headerName: '主材标志',
  454. width: 80,
  455. editable: true,
  456. },
  457. {
  458. field: '设备标志',
  459. headerName: '设备标志',
  460. width: 80,
  461. editable: true,
  462. },
  463. ];
  464. const handleDeleteClick = (id) => () => {
  465. setRcjrows(rcjrows.filter((row) => row.id !== id));
  466. const [newData, newHl] = handleRcjbc(selectedRowKeysTable.current[0], rcjrows.filter((row) => row.id !== id));
  467. if (newData) {
  468. myTable.current.updateData(newData.filter(x=>x['key'] == selectedRowKeysTableParent.current));
  469. let y =[];
  470. for (let i = 1; i < newHl.length; i++) {
  471. y.push({
  472. 'ID' : newHl[i][0],
  473. '人材机编码' : newHl[i][1],
  474. '名称' : newHl[i][2],
  475. '规格型号': newHl[i][3],
  476. '单位' : newHl[i][4],
  477. '单价' : newHl[i][5],
  478. '产地' : newHl[i][6],
  479. '供应厂商' : newHl[i][7],
  480. '人材机类别' : newHl[i][8],
  481. '甲供标志': newHl[i][9],
  482. '含量' : newHl[i][10],
  483. '合价' : newHl[i][11],
  484. '暂估价标志' : newHl[i][12],
  485. '主要材料标志' : newHl[i][13],
  486. '主材标志' : newHl[i][14],
  487. '设备标志' : newHl[i][15]
  488. });
  489. }
  490. setRcjhl(y);
  491. if (rcjTable.current) {
  492. rcjTable.current.replaceData(y);
  493. }
  494. }
  495. };
  496. const processRowUpdate = (newRow) => {
  497. const updatedRow = { ...newRow, isNew: false };
  498. setRcjrows(rcjrows.map((row) => (row.id === newRow.id ? updatedRow : row)));
  499. const [newData, newHl] = handleRcjbc(selectedRowKeysTable.current[0], rcjrows.map((row) => (row.id === newRow.id ? updatedRow : row)));
  500. if (newData) {
  501. myTable.current.updateData(newData.filter(x=>x['key'] == selectedRowKeysTableParent.current));
  502. let y =[];
  503. for (let i = 1; i < newHl.length; i++) {
  504. y.push({
  505. 'ID' : newHl[i][0],
  506. '人材机编码' : newHl[i][1],
  507. '名称' : newHl[i][2],
  508. '规格型号': newHl[i][3],
  509. '单位' : newHl[i][4],
  510. '单价' : newHl[i][5],
  511. '产地' : newHl[i][6],
  512. '供应厂商' : newHl[i][7],
  513. '人材机类别' : newHl[i][8],
  514. '甲供标志': newHl[i][9],
  515. '含量' : newHl[i][10],
  516. '合价' : newHl[i][11],
  517. '暂估价标志' : newHl[i][12],
  518. '主要材料标志' : newHl[i][13],
  519. '主材标志' : newHl[i][14],
  520. '设备标志' : newHl[i][15]
  521. });
  522. }
  523. setRcjhl(y);
  524. if (rcjTable.current) {
  525. rcjTable.current.replaceData(y);
  526. }
  527. }
  528. return updatedRow;
  529. };
  530. function EditToolbar(props) {
  531. const { setRcjrows } = props;
  532. const handleClick = () => {
  533. const id = uuidv4();
  534. let a = [];
  535. setRcjrows((oldRows) => {
  536. a = [
  537. ...oldRows,
  538. { id, '人材机编码': '410000F', '名称': '', '规格型号': '', '单位': '', '单价':'0','产地': '', '供应厂商': '', '人材机类别':'2',
  539. '甲供标志':'', '含量':'1', '暂估价标志':'', '主要材料标志':'true', '主材标志':'true', '设备标志':'' },
  540. ];
  541. return a;
  542. });
  543. const [newData, newHl] = handleRcjbc(selectedRowKeysTable.current[0], a);
  544. if (newData) {
  545. myTable.current.updateData(newData.filter(x=>x['key'] == selectedRowKeysTableParent.current));
  546. let y =[];
  547. for (let i = 1; i < newHl.length; i++) {
  548. y.push({
  549. 'ID' : newHl[i][0],
  550. '人材机编码' : newHl[i][1],
  551. '名称' : newHl[i][2],
  552. '规格型号': newHl[i][3],
  553. '单位' : newHl[i][4],
  554. '单价' : newHl[i][5],
  555. '产地' : newHl[i][6],
  556. '供应厂商' : newHl[i][7],
  557. '人材机类别' : newHl[i][8],
  558. '甲供标志': newHl[i][9],
  559. '含量' : newHl[i][10],
  560. '合价' : newHl[i][11],
  561. '暂估价标志' : newHl[i][12],
  562. '主要材料标志' : newHl[i][13],
  563. '主材标志' : newHl[i][14],
  564. '设备标志' : newHl[i][15]
  565. });
  566. }
  567. setRcjhl(y);
  568. if (rcjTable.current) {
  569. rcjTable.current.replaceData(y);
  570. }
  571. }
  572. };
  573. return (
  574. <GridToolbarContainer>
  575. <Button disabled={!showToolbar}
  576. color="primary" startIcon={<AddIcon />} onClick={handleClick}>
  577. 补充
  578. </Button>
  579. </GridToolbarContainer>
  580. );
  581. }
  582. React.useEffect(() => {
  583. myTable.current = new Tabulator(myRef.current, {
  584. index: "key",
  585. height: 380,
  586. data: detail, //link data to table
  587. reactiveData: false, //enable data reactivity
  588. dataTreeStartExpanded:true,
  589. dataTree: true,
  590. selectableRows:1, //make rows selectable
  591. editTriggerEvent:"dblclick", //trigger edit on double click
  592. dataTreeStartExpanded:function(row, level){
  593. //console.log(row);
  594. //console.log(level);
  595. return true; //expand rows where the "driver" data field is true;
  596. },
  597. columns: [ //Define Table Columns
  598. {title:"序号", field:"序号", width:80, headerSort:false, frozen: true}, //never hide this column
  599. {title:"清单编码", field:"清单编码", width:120,headerSort:false, frozen: true ,formatter:"textarea" },
  600. {title:"名称", field:"名称", width:150, headerSort:false, formatter:"textarea", editor: "input", editable: editCheck}, //hide this column first
  601. {title:"项目特征", field:"项目特征", width:200 , headerSort:false, formatter:"textarea"},
  602. {title:"计算规则", field:"计算规则", width:200, headerSort:false, formatter:"textarea"},
  603. {title:"单位", field:"单位", width:100, headerSort:false},
  604. {title:"数量", field:"数量", width:100, headerSort:false, editor: "input", editable: editCheck },
  605. {title:"综合单价", field:"综合单价", width:100, headerSort:false, formatter:"money"},
  606. {title:"合价", field:"合价", width:100, headerSort:false, formatter:"money"},
  607. {title:"人工费", field:"人工费", width:100, headerSort:false, formatter:"money"},
  608. {title:"主材费", field:"主材费", width:100, headerSort:false, formatter:"money"},
  609. {title:"设备费", field:"设备费", width:100, headerSort:false, formatter:"money"},
  610. {title:"辅材费", field:"辅材费", width:100, headerSort:false, formatter:"money"},
  611. {title:"材料费", field:"材料费", width:100, headerSort:false, formatter:"money"},
  612. {title:"机械费", field:"机械费", width:100, headerSort:false, formatter:"money"},
  613. {title:"管理费", field:"管理费", width:100, headerSort:false, formatter:"money"},
  614. {title:"利润", field:"利润", width:100, headerSort:false, formatter:"money"},
  615. {title:"暂估价", field:"暂估价", width:100, headerSort:false, formatter:"money"},
  616. {title:"综合人工工日", field:"综合人工工日", width:100, headerSort:false},
  617. ]
  618. });
  619. myTable.current.on("cellDblClick", function(e, cell){
  620. //e - the click event object
  621. //cell - cell component
  622. console.log(cell);
  623. });
  624. myTable.current.on("rowSelected", handleSelect);
  625. myTable.current.on("cellEdited", function(cell){
  626. //console.log("edited");
  627. //console.log();
  628. let key = cell._cell.row.data['key'];
  629. myTable.current.deselectRow();
  630. if(cell._cell.column.field == '名称') {
  631. let newData = updateDeMingcheng(cell._cell.row.data['名称'], selectedRowKeysTable.current[0]);
  632. myTable.current.updateData(newData.filter(x=>x['key'] == selectedRowKeysTableParent.current)).then(function() {
  633. let getRow = myTable.current.getRows(); //get array of currently selected row components.
  634. let component = null;
  635. for(let i = 0; i < getRow.length; i++) {
  636. let entry = getRow[i]._row.modules.dataTree.children;
  637. for(let j = 0; j < entry.length; j++) {
  638. let child = entry[j];
  639. if(child.data['key'] == key) {
  640. //console.log(child);
  641. component = child.component;
  642. break;
  643. }
  644. }
  645. }
  646. component.select();
  647. handleSelect(component);
  648. //handleSelect(getRow[0]);
  649. });
  650. }
  651. else{
  652. let [success, data] = updateShuliang(cell._cell.row.data['数量'], selectedRowKeysTable.current[0]);
  653. if (success) {
  654. myTable.current.updateData(data.filter(x=>x['key'] == selectedRowKeysTableParent.current)).then(function() {
  655. let getRow = myTable.current.getRows(); //get array of currently selected row components.
  656. let component = null;
  657. for(let i = 0; i < getRow.length; i++) {
  658. let entry = getRow[i]._row.modules.dataTree.children;
  659. for(let j = 0; j < entry.length; j++) {
  660. let child = entry[j];
  661. if(child.data['key'] == key) {
  662. //console.log(child);
  663. component = child.component;
  664. break;
  665. }
  666. }
  667. }
  668. component.select();
  669. handleSelect(component);
  670. //handleSelect(getRow[0]);
  671. });
  672. }
  673. }
  674. });
  675. myTable.current.on("tableBuilt", () => {
  676. Service.generateQingdanmingxi(name, bh, bt).then(x=>{
  677. myTable.current.replaceData(x);
  678. });
  679. });
  680. }, [bh, bt]);
  681. React.useEffect(
  682. () => {
  683. //console.log("rgde changed");
  684. //console.log(rgde);
  685. rgdeRef.current = rgde;
  686. jxdeRef.current = jxde;
  687. cldeRef.current = clde;
  688. if (isQdrcj.current) {
  689. highlight.current = [];
  690. } else {
  691. let toHighlight = [];
  692. for(let i = 0; i < rcjhl.length; i++) {
  693. let entry = rcjhl[i];
  694. let bianhao = entry['人材机编码'];
  695. let rcjlb = entry['人材机类别'];
  696. let hit = false;
  697. if (Number(rcjlb) == Number(1) && rgde) {
  698. for (let j = 0; j < rgde.length; j++) {
  699. if (rgde[j]["CLBH"] == bianhao) {
  700. if(rgde[j]["CLMC"] == entry['名称'])hit = true;
  701. let danjia = Number(entry['单价']);
  702. if (danjia != rgde[j]["YSJG"]) {
  703. //console.log(`[${i},5]danjia bu yizhi`);
  704. toHighlight.push({row: i, col: 5, renderer: "customStylesRenderer"});
  705. }
  706. let hanliang = Number(entry['含量']);
  707. if (hanliang != rgde[j]["gr"]) {
  708. //console.log(`[${i}, 10]hanliang bu yizhi`);
  709. toHighlight.push({row: i, col: 10, renderer: "customStylesRenderer"});
  710. }
  711. }
  712. }
  713. }
  714. if (Number(rcjlb) == Number(3) && jxde ) {
  715. for (let j = 0; j < jxde.length; j++) {
  716. if (jxde[j]["jxbh"] == bianhao) {
  717. if(jxde[j]["jxmc"] == entry['名称'])hit = true;
  718. let danjia = Number(entry['单价']);
  719. if (danjia != jxde[j]["tbdj"]) {
  720. //console.log(`[${i},5]danjia bu yizhi`);
  721. toHighlight.push({row: i, col: 5, renderer: "customStylesRenderer"});
  722. }
  723. let hanliang = Number(entry['含量']);
  724. if (hanliang != jxde[j]["sl"]) {
  725. //console.log(`[${i}, 10]hanliang bu yizhi`);
  726. toHighlight.push({row: i, col: 10, renderer: "customStylesRenderer"});
  727. }
  728. }
  729. }
  730. }
  731. if (Number(rcjlb) == Number(2) && clde ) {
  732. for (let j = 0; j < clde.length; j++) {
  733. if (clde[j]["CLBH"] == bianhao) {
  734. if(clde[j]["CLMC"] == entry['名称'])hit = true;
  735. let danjia = Number(entry['单价']);
  736. if (danjia != clde[j]["YSJG"]) {
  737. //console.log(`[${i},5]danjia bu yizhi`);
  738. toHighlight.push({row: i, col: 5, renderer: "customStylesRenderer"});
  739. }
  740. let hanliang = Number(entry['含量']);
  741. if (hanliang != clde[j]["SL"]) {
  742. //console.log(`[${i}, 10]hanliang bu yizhi`);
  743. toHighlight.push({row: i, col: 10, renderer: "customStylesRenderer"});
  744. }
  745. }
  746. }
  747. }
  748. if (!hit) {
  749. toHighlight.push({row: i, col: 1, renderer: "customStylesRenderer"});
  750. }
  751. }
  752. //console.log(toHighlight);
  753. highlight.current = toHighlight;
  754. }
  755. let bzrcjhl = [/*["人材机编码", "名称", "单位", "单价", "合价", "含量"]*/]
  756. if (rgde)
  757. for (let i = 0; i < rgde.length; i++) {
  758. bzrcjhl.push({'人材机编码': rgde[i]["CLBH"], '名称': rgde[i]["CLMC"], '单位': rgde[i]["JLDW"], '单价': rgde[i]["YSJG"], '合价': rgde[i]["gf"], '含量': rgde[i]["gr"]});
  759. }
  760. if (clde)
  761. for (let i = 0; i < clde.length; i++) {
  762. bzrcjhl.push({'人材机编码': clde[i]["CLBH"], '名称': clde[i]["CLMC"], '单位': clde[i]["JLDW"], '单价': clde[i]["YSJG"], '合价': clde[i]["HJ"], '含量': clde[i]["SL"]});
  763. }
  764. if (jxde)
  765. for (let i = 0; i < jxde.length; i++) {
  766. bzrcjhl.push({'人材机编码': jxde[i]["jxbh"], '名称': jxde[i]["jxmc"], '单位': jxde[i]["DW"], '单价': jxde[i]["tbdj"], '合价': jxde[i]["hj"], '含量': jxde[i]["sl"]});
  767. }
  768. setRcjhl2(bzrcjhl);
  769. }, [rgde, jxde, clde]
  770. );
  771. React.useEffect(
  772. () => {
  773. console.log(beizhu);
  774. let result = [];
  775. if (beizhu != null) {
  776. let keys = Object.keys(beizhu["BZBH"]);
  777. for(let i = 0; i < keys.length; i++) {
  778. let key = keys[i];
  779. result.push({'key': i+1, '序号': i+1, '编号': beizhu["BZBH"][key], '说明': beizhu["SM"][key]});//序号很重要
  780. }
  781. setFuzhu(result);
  782. let newSelect = extractFuzhu(debmRef.current);
  783. setSelectedRowKeys(newSelect);
  784. //setSelectedRowKeys([1]);
  785. }
  786. }, [beizhu]
  787. );
  788. React.useEffect(
  789. () => {
  790. beizhuFKRef.current = beizhuFK;
  791. }, [beizhuFK]
  792. );
  793. React.useEffect(
  794. () => {
  795. myTable.current.deselectRow();
  796. //console.log(dingeclick);
  797. if (selectedRowKeysTable.current.length > 0 ) {
  798. const [success, data, key] = changguidinge(JSON.parse(dingeclick), selectedRowKeysTable.current[0]);
  799. if (success) {
  800. myTable.current.updateData(data.filter(x=>x['key'] == selectedRowKeysTableParent.current)).then(function(){
  801. let getRow = myTable.current.getRows(); //get array of currently selected row components.
  802. let component = null;
  803. for(let i = 0; i < getRow.length; i++) {
  804. let entry = getRow[i]._row.modules.dataTree.children;
  805. for(let j = 0; j < entry.length; j++) {
  806. let child = entry[j];
  807. if(child.data['key'] == key) {
  808. //console.log(child);
  809. component = child.component;
  810. break;
  811. }
  812. }
  813. }
  814. component.select();
  815. handleSelect(component);
  816. });
  817. }
  818. }
  819. }, [dingeclick]//常规添加定额
  820. );
  821. React.useEffect(
  822. () => {
  823. //console.log(dingeclick);
  824. if (selectedRowKeysTable.current.length > 0 ) {
  825. const data = huan(JSON.parse(tihuanClick), selectedRowKeysTable.current[0]);
  826. myTable.current.updateData(data.filter(x=>x['key'] == selectedRowKeysTableParent.current)).then(function(){
  827. let getRow = myTable.current.getRows(); //get array of currently selected row components.
  828. let component = null;
  829. for(let i = 0; i < getRow.length; i++) {
  830. let entry = getRow[i]._row.modules.dataTree.children;
  831. for(let j = 0; j < entry.length; j++) {
  832. let child = entry[j];
  833. if(child.data['key'] == selectedRowKeysTable.current[0]) {
  834. //console.log(child);
  835. component = child.component;
  836. break;
  837. }
  838. }
  839. }
  840. handleSelect(component);
  841. });
  842. }
  843. }, [tihuanClick]//替换定额人材机
  844. );
  845. React.useEffect(
  846. () => {
  847. if (tuijianRef.current != null ) {
  848. tuijianTable.current = new Tabulator(tuijianRef.current, {
  849. index: "key",
  850. height: 200,
  851. data: tuijian, //link data to table
  852. reactiveData: false, //enable data reactivity
  853. dataTreeStartExpanded:false,
  854. dataTree: false,
  855. selectableRows:1, //make rows selectable
  856. columns: [ //Define Table Columns
  857. {title:"ID", field:"ID", width:80, headerSort:false, }, //never hide this column
  858. {title:"定额编号", field:"定额编号", width:120,headerSort:false, formatter:"textarea" },
  859. {title:"工程量名称", field:"工程量名称", width:150, headerSort:false, formatter:"textarea"}, //hide this column first
  860. {title:"工作内容", field:"工作内容", width:150 , headerSort:false, formatter:"textarea"},
  861. ]
  862. });
  863. tuijianTable.current.on("tableBuilt", () => {
  864. tuijianTable.current.replaceData(tuijian);
  865. });
  866. }
  867. if (rcj2Ref.current != null ) {
  868. rcj2Table.current = new Tabulator(rcj2Ref.current, {
  869. index: "key",
  870. height: 200,
  871. data: rcjhl2, //link data to table
  872. reactiveData: false, //enable data reactivity
  873. dataTreeStartExpanded:false,
  874. dataTree: false,
  875. selectableRows:1, //make rows selectable
  876. columns: [ //Define Table Columns
  877. {title:"人材机编码", field:"人材机编码", width:100, headerSort:false, }, //never hide this column
  878. {title:"名称", field:"名称", width:120,headerSort:false, formatter:"textarea" },
  879. {title:"单位", field:"单位", width:150, headerSort:false, formatter:"textarea"}, //hide this column first
  880. {title:"单价", field:"单价", width:150 , headerSort:false, formatter:"money"},
  881. {title:"合价", field:"合价", width:150 , headerSort:false, formatter:"money"},
  882. {title:"含量", field:"含量", width:150 , headerSort:false, formatter:"textarea"},
  883. ]
  884. });
  885. rcj2Table.current.on("tableBuilt", () => {
  886. rcj2Table.current.replaceData(rcjhl2);
  887. });
  888. }
  889. if (rcjRef.current != null ) {
  890. rcjTable.current = new Tabulator(rcjRef.current, {
  891. index: "key",
  892. height: 250,
  893. data: rcjhl, //link data to table
  894. reactiveData: false, //enable data reactivity
  895. dataTreeStartExpanded:false,
  896. dataTree: false,
  897. selectableRows:1, //make rows selectable
  898. editTriggerEvent:"dblclick",
  899. rowFormatter:function(row){
  900. //row - row component
  901. var data = row.getData();
  902. if (data['人材机编码'] == '410000F') {
  903. row.getElement().style.backgroundColor = "#ffff00";
  904. }
  905. },
  906. columns: [ //Define Table Columns
  907. {title:"ID", field:"ID", width:80, headerSort:false, },
  908. {title:"人材机编码", field:"人材机编码", width:100, headerSort:false, }, //never hide this column
  909. {title:"名称", field:"名称", width:120,headerSort:false, formatter:"textarea", editor: "input", editable: editCheckRcj },
  910. {title:"规格型号", field:"规格型号", width:80, headerSort:false, editor: "input", editable: editCheckRcj },
  911. {title:"单位", field:"单位", width:80, headerSort:false, formatter:"textarea"}, //hide this column first
  912. {title:"单价", field:"单价", width:80 , headerSort:false, formatter: sparklineFormatter, editor: "input", editable: editCheckRcj },
  913. {title:"产地", field:"产地", width:80, headerSort:false, },
  914. {title:"供应厂商", field:"供应厂商", width:80, headerSort:false, },
  915. {title:"人材机类别", field:"人材机类别", width:80, headerSort:false, },
  916. {title:"甲供标志", field:"甲供标志", width:80 , headerSort:false, formatter:"textarea"},
  917. {title:"含量", field:"含量", width:80 , headerSort:false, formatter:"money", formatterParams:{precision:4}, editor: "input", editable: editCheckRcj },
  918. {title:"合价", field:"合价", width:80 , headerSort:false, formatter:"money"},
  919. {title:"暂估价标志", field:"暂估价标志", width:80 , headerSort:false, formatter:"textarea"},
  920. {title:"主要材料标志", field:"主要材料标志", width:100 , headerSort:false, formatter:"textarea"},
  921. {title:"主材标志", field:"主材标志", width:80 , headerSort:false, formatter:"textarea"},
  922. {title:"设备标志", field:"设备标志", width:80 , headerSort:false, formatter:"textarea"},
  923. ]
  924. });
  925. rcjTable.current.on("tableBuilt", () => {
  926. rcjTable.current.replaceData(rcjhl);
  927. });
  928. rcjTable.current.on("cellDblClick", function(e, cell){
  929. //e - the click event object
  930. //cell - cell component
  931. let determine = cell._cell.row.getData()['人材机编码'] != '410000F';
  932. if(cell._cell.column.getPosition() == 2 && !isQdrcj.current && determine) {
  933. tihuanCallback(cell._cell.row.position, cell._cell.column.getPosition());
  934. }
  935. });
  936. rcjTable.current.on("cellEdited", function(cell){
  937. let data = copy(cell._cell.table.getData());
  938. for(let i = 0; i < data.length; i++) {
  939. data[i]['合价'] = Number(data[i]['单价']) * Number(data[i]['含量']);
  940. }
  941. setRcjhl(data);
  942. if (rcjTable.current) {
  943. rcjTable.current.replaceData(data);
  944. }
  945. let data2 = [['ID', '人材机编码', '名称', '规格型号', '单位', '单价', '产地', '供应厂商', '人材机类别', '甲供标志', '含量', '合价', '暂估价标志', '主要材料标志', '主材标志', '设备标志']]
  946. for (let i = 0; i < data.length; i++) {
  947. data2.push([data[i]['ID'], data[i]['人材机编码'], data[i]['名称'], data[i]['规格型号'], data[i]['单位'],
  948. data[i]['单价'], data[i]['产地'], data[i]['供应厂商'], data[i]['人材机类别'],
  949. data[i]['甲供标志'], data[i]['含量'], data[i]['合价'], data[i]['暂估价标志'], data[i]['主要材料标志'], data[i]['主材标志'], data[i]['设备标志']]);
  950. }
  951. let newData = updateDercj(selectedRowKeysTable.current[0], data2);
  952. myTable.current.updateData(newData.filter(x=>x['key'] == selectedRowKeysTableParent.current)).then(function() {
  953. let getRow = myTable.current.getRows(); //get array of currently selected row components.
  954. let component = null;
  955. for(let i = 0; i < getRow.length; i++) {
  956. let entry = getRow[i]._row.modules.dataTree.children;
  957. for(let j = 0; j < entry.length; j++) {
  958. let child = entry[j];
  959. if(child.data['key'] == selectedRowKeysTable.current[0]) {
  960. //console.log(child);
  961. component = child.component;
  962. break;
  963. }
  964. }
  965. }
  966. handleSelect(component);
  967. });
  968. });
  969. }
  970. }, [valueTab]
  971. );
  972. return (
  973. <Stack spacing={2}>
  974. <Box>
  975. <Stack direction='row' spacing={2}>
  976. <Button variant="outlined" size="small" onClick={() => {
  977. if (selectedRowKeysTable.current.length > 0) {
  978. let getRow = myTable.current.getRows(); //get array of currently selected row components.
  979. let hit = false;
  980. for(let i = 0; i < getRow.length; i++) {
  981. if (getRow[i]._row.data['key'] == selectedRowKeysTable.current[0]) {
  982. hit = true;
  983. }
  984. }
  985. if (hit) {
  986. suanshiCallback();
  987. }
  988. }
  989. }}
  990. >定额(算式)</Button>
  991. <Button variant="outlined" size="small" onClick={() => {
  992. if (selectedRowKeysTable.current.length > 0) {
  993. const [success, data] = danxiangdinge(selectedRowKeysTable.current[0]);
  994. if(success) {
  995. myTable.current.updateData(data.filter(x=>x['key'] == selectedRowKeysTableParent.current)).then(function(){
  996. selectedRowKeysTable.current = [];
  997. selectedRowKeysTableParent.current = null;
  998. setRcjhl([]);
  999. if (rcjTable.current) {
  1000. rcjTable.current.replaceData([]);
  1001. }
  1002. setFuzhu([]);
  1003. setRcjrows([]);
  1004. setShowToolbar(false);
  1005. setSelectedRowKeys2([]);
  1006. setYubanEnable(false);
  1007. isQdrcj.current = true;
  1008. highlight.current = [];
  1009. });
  1010. }
  1011. }
  1012. }}
  1013. >单项定额</Button>
  1014. <Button variant="outlined" size="small" onClick={() => {
  1015. if (selectedRowKeysTable.current.length > 0) {
  1016. let newData = shanchu(selectedRowKeysTable.current[0]);
  1017. myTable.current.updateData(newData.filter(x=>x['key'] == selectedRowKeysTableParent.current)).then(function(){
  1018. if (newData.filter(x=>x['key'] == selectedRowKeysTable.current[0]).length == 0) {
  1019. selectedRowKeysTable.current = [];
  1020. selectedRowKeysTableParent.current = [];
  1021. setRcjhl([]);
  1022. if (rcjTable.current) {
  1023. rcjTable.current.replaceData([]);
  1024. }
  1025. setFuzhu([]);
  1026. setRcjrows([]);
  1027. setShowToolbar(false);
  1028. setSelectedRowKeys2([]);
  1029. setYubanEnable(false);
  1030. isQdrcj.current = true;
  1031. highlight.current = [];
  1032. }
  1033. });
  1034. }
  1035. }}
  1036. >删除</Button>
  1037. <Button variant="outlined" size="small" onClick={() => {
  1038. let newData = undo();
  1039. myTable.current.updateData(newData).then(function(){
  1040. selectedRowKeysTable.current = [];
  1041. selectedRowKeysTableParent.current = null;
  1042. setRcjhl([]);
  1043. if (rcjTable.current) {
  1044. rcjTable.current.replaceData([]);
  1045. }
  1046. setFuzhu([]);
  1047. setRcjrows([]);
  1048. setShowToolbar(false);
  1049. setSelectedRowKeys2([]);
  1050. setYubanEnable(false);
  1051. isQdrcj.current = true;
  1052. highlight.current = [];
  1053. });
  1054. }}
  1055. >撤销</Button>
  1056. <Button variant="outlined" size="small" onClick={() => {
  1057. let newData = redo();
  1058. myTable.current.updateData(newData).then(function(){
  1059. selectedRowKeysTable.current = [];
  1060. selectedRowKeysTableParent.current = null;
  1061. setRcjhl([]);
  1062. if (rcjTable.current) {
  1063. rcjTable.current.replaceData([]);
  1064. }
  1065. setFuzhu([]);
  1066. setRcjrows([]);
  1067. setShowToolbar(false);
  1068. setSelectedRowKeys2([]);
  1069. setYubanEnable(false);
  1070. isQdrcj.current = true;
  1071. highlight.current = [];
  1072. });
  1073. }}
  1074. >重做</Button>
  1075. <Button variant="outlined" size="small" onClick={() => {
  1076. console.log("save to cloud");
  1077. loadingCallback();
  1078. }}
  1079. >保存</Button>
  1080. </Stack>
  1081. <div style={{width: "70vw"}}>
  1082. <div ref={myRef}>
  1083. </div>
  1084. </div>
  1085. </Box>
  1086. <Box >
  1087. <TabContext value={valueTab}>
  1088. <Box sx={{ borderBottom: 1, borderColor: 'divider' }}>
  1089. <TabList sx={{minHeight: '24px'}} onChange={handleChange} aria-label="lab API tabs example">
  1090. <Tab sx={{p: 0, minHeight: '24px'}} label="人材机含量" value="1" />
  1091. <Tab sx={{p: 0, minHeight: '24px'}} label="标准定额人材机含量" value="2" />
  1092. <Tab sx={{p: 0, minHeight: '24px'}} label="人材机补充" value="3" />
  1093. <Tab sx={{p: 0, minHeight: '24px'}} label="定额附注" value="4" />
  1094. <Tab sx={{p: 0, minHeight: '24px'}} label="预拌砂浆" value="5" />
  1095. <Tab sx={{p: 0, minHeight: '24px'}} label="组价推荐" value="6" />
  1096. </TabList>
  1097. </Box>
  1098. <TabPanel sx={{p: 1}} value="1">
  1099. <div style={{width:"70vw"}}>
  1100. <div ref={rcjRef}></div>
  1101. </div>
  1102. </TabPanel>
  1103. <TabPanel sx={{p: 1}} value="2">
  1104. <div ref={rcj2Ref}></div>
  1105. </TabPanel>
  1106. <TabPanel sx={{p: 1}} value="3">
  1107. <Box
  1108. sx={{
  1109. height: 200,
  1110. width: '100%',
  1111. '& .actions': {
  1112. color: 'text.secondary',
  1113. },
  1114. '& .textPrimary': {
  1115. color: 'text.primary',
  1116. },
  1117. }}
  1118. >
  1119. <DataGrid disableColumnMenu disableColumnSorting
  1120. hideFooter={true}
  1121. rows={rcjrows}
  1122. columns={rcjcolumns}
  1123. processRowUpdate={processRowUpdate}
  1124. slotProps={{
  1125. toolbar: { setRcjrows },
  1126. }}
  1127. slots={{
  1128. toolbar: EditToolbar,
  1129. }}
  1130. localeText={zhCN_MUI.components.MuiDataGrid.defaultProps.localeText}
  1131. />
  1132. </Box>
  1133. </TabPanel>
  1134. <TabPanel sx={{p: 1}} value="4">
  1135. <Box sx={{maxHeight: `190px`}}>
  1136. <ConfigProvider
  1137. locale={zhCN}
  1138. theme={{
  1139. components: {
  1140. Table: {
  1141. /* here is your component tokens */
  1142. cellPaddingBlock : 8
  1143. },
  1144. },
  1145. }}
  1146. >
  1147. <Table
  1148. scroll={{ x: 'max-content' , y : 190}}
  1149. pagination={false}
  1150. rowSelection={rowSelection}
  1151. columns={
  1152. [
  1153. { title: '序号', dataIndex: '序号', width : 80},
  1154. {
  1155. title: '编号',
  1156. dataIndex: '编号',
  1157. },
  1158. {
  1159. title: '说明',
  1160. dataIndex: '说明',
  1161. width: 550
  1162. },
  1163. ]
  1164. }
  1165. dataSource={fuzhu} />
  1166. </ConfigProvider>
  1167. </Box>
  1168. </TabPanel>
  1169. <TabPanel sx={{p: 1}} value="5">
  1170. <Box sx={{maxHeight: `190px`}}>
  1171. <ConfigProvider
  1172. locale={zhCN}
  1173. theme={{
  1174. components: {
  1175. Table: {
  1176. /* here is your component tokens */
  1177. cellPaddingBlock : 8
  1178. },
  1179. },
  1180. }}
  1181. >
  1182. <Table
  1183. scroll={{ x: 'max-content' , y : 190}}
  1184. pagination={false}
  1185. rowSelection={rowSelection2}
  1186. columns={
  1187. [
  1188. {
  1189. title: '说明',
  1190. dataIndex: '说明',
  1191. width: 550
  1192. },
  1193. ]
  1194. }
  1195. dataSource={yuban} />
  1196. </ConfigProvider>
  1197. </Box>
  1198. </TabPanel>
  1199. <TabPanel sx={{p: 1}} value="6">
  1200. <div ref={tuijianRef}></div>
  1201. </TabPanel>
  1202. </TabContext>
  1203. </Box>
  1204. </Stack>
  1205. );
  1206. }