Djcs3.js 44 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914
  1. import * as React from 'react';
  2. import Box from "@mui/material/Box";
  3. import Table from 'rsuite/Table';
  4. import 'rsuite/Table/styles/index.css';
  5. import Checkbox from 'rsuite/Checkbox';
  6. import 'rsuite/Checkbox/styles/index.css';
  7. import { CustomProvider } from 'rsuite';
  8. import zhCN from 'rsuite/locales/zh_CN';
  9. import Tab from "@mui/material/Tab";
  10. import TabContext from "@mui/lab/TabContext";
  11. import TabList from "@mui/lab/TabList";
  12. import TabPanel from "@mui/lab/TabPanel";
  13. import Stack from "@mui/material/Stack";
  14. import Service from './Service';
  15. import {TabulatorFull as Tabulator} from "tabulator-tables"; //import Tabulator library
  16. import './Tabulator.css';
  17. import {extractFuzhu, match_target} from './utils';
  18. import Button from '@mui/material/Button';
  19. import {shanchu_djcs, undo_djcs, redo_djcs, danxiangdinge_djcs, updateDercj_djcs, changguidinge_djcs, handleBeizhu_djcs, huan, updateShuliang_djcs} from './editor';
  20. import {copy} from './utils';
  21. const {Column, HeaderCell, Cell} = Table;
  22. function number_equal(a, b) {
  23. if (Number(a) - Number(b) < 0.0001 && Number(a) - Number(b) > -0.0001) {
  24. return true;
  25. }
  26. return false;
  27. }
  28. export default function Djcs3({name, bh, rgde, jxde, clde, beizhu, beizhuFK, clickCallback, loadingCallback, dingeclick}) {
  29. var editCheck = function(cell){
  30. //cell - the cell component for the editable cell
  31. //get row data
  32. //console.log(cell);
  33. if(cell._cell.row.data['序号']) return false;
  34. return true;
  35. }
  36. var editCheckRcj = function(cell){
  37. //cell - the cell component for the editable cell
  38. //get row data
  39. //console.log(cell);
  40. if(isQdrcj.current) return false;
  41. if (cell._cell.row.getData()['人材机编码'] == '00EXP001') {//回程费
  42. return false;
  43. }
  44. if (cell._cell.row.getData()['人材机编码'] == '99EXP007') {//
  45. return false;
  46. }
  47. if (cell._cell.row.getData()['人材机编码'] == '31130104') {//
  48. return false;
  49. }
  50. return true;
  51. }
  52. var editCheckJg = function(cell){
  53. //cell - the cell component for the editable cell
  54. //get row data
  55. //console.log(cell);
  56. if(isQdrcj.current) return false;
  57. if (cell._cell.row.getData()['人材机编码'] == '00EXP001') {//回程费
  58. return false;
  59. }
  60. if (cell._cell.row.getData()['人材机编码'] == '99EXP007') {//
  61. return false;
  62. }
  63. if (cell._cell.row.getData()['人材机编码'] == '31130104') {//
  64. return false;
  65. }
  66. if (cell._cell.row.getData()['甲供标志'] == 'true') {//
  67. return false;
  68. }
  69. return true;
  70. }
  71. var sparklineFormatter = function(cell, formatterParams, onRendered){
  72. for (let i = 0; i < highlight.current.length; i++) {
  73. let entry = highlight.current[i];
  74. if (entry.row + 1 == cell._cell.row.position && entry.col + 1 == cell._cell.column.getPosition()) {
  75. cell.getElement().style.fontWeight = 'bold';
  76. cell.getElement().style.color = 'green';
  77. cell.getElement().style.background = '#d7f1e1';
  78. }
  79. }
  80. return Number(cell.getValue()).toFixed(2).toString();
  81. };
  82. var sparklineFormatter2 = function(cell, formatterParams, onRendered){
  83. for (let i = 0; i < highlight.current.length; i++) {
  84. let entry = highlight.current[i];
  85. if (entry.row + 1 == cell._cell.row.position && entry.col + 1 == cell._cell.column.getPosition()) {
  86. cell.getElement().style.fontWeight = 'bold';
  87. cell.getElement().style.color = 'green';
  88. cell.getElement().style.background = '#d7f1e1';
  89. }
  90. }
  91. return cell.getValue();
  92. };
  93. function handleSelect(row){
  94. //e - the click event object
  95. //cell - cell component
  96. console.log('rowSelected');
  97. selectedRowKeysTable.current = [row._row['data']['key']];
  98. let bt = "Djcs" ;
  99. if (row._row.data['序号'] != null && row._row.data['序号'].length >0) {
  100. selectedRowKeysTableParent.current = row._row['data']['key'];
  101. setFuzhu([]);
  102. Service.generateQingdanrcj(name, bh,bt,row._row.data['清单编码']).then(x=>{
  103. let y =[];
  104. for (let i = 1; i < x.length; i++) {
  105. y.push({
  106. 'ID' : x[i][0],
  107. '人材机编码' : x[i][1],
  108. '名称' : x[i][2],
  109. '规格型号': x[i][3],
  110. '单位' : x[i][4],
  111. '单价' : x[i][5],
  112. '产地' : x[i][6],
  113. '供应厂商' : x[i][7],
  114. '人材机类别' : x[i][8],
  115. '甲供标志': x[i][9],
  116. '含量' : x[i][10],
  117. '合价' : x[i][11],
  118. '暂估价标志' : x[i][12],
  119. '主要材料标志' : x[i][13],
  120. '主材标志' : x[i][14],
  121. '设备标志' : x[i][15]
  122. });
  123. }
  124. setRcjhl(y);
  125. if (rcjTable.current) {
  126. rcjTable.current.replaceData(y);
  127. }
  128. isQdrcj.current=true;
  129. highlight.current = [];
  130. });
  131. Service.generateQingdanTuijian(name, bh,bt,row._row.data['清单编码']).then(x=>{
  132. setTuijian(x);
  133. if (tuijianTable.current) tuijianTable.current.replaceData(x);
  134. });
  135. } else {
  136. setTuijian([]);
  137. if (tuijianTable.current) tuijianTable.current.replaceData([]);
  138. let row_parent = row._row;
  139. while(row_parent.modules.dataTree.parent) {
  140. row_parent = row_parent.modules.dataTree.parent;
  141. }
  142. debmRef.current = row._row['data']['清单编码'];
  143. selectedRowKeysTableParent.current = row_parent['data']['key'];
  144. clickCallback(row_parent['data']['清单编码'], row._row['data']['清单编码']);
  145. Service.generateDingercj(name, bh,bt,row_parent['data']['清单编码'], row._row['data']['清单编码'], row._row['data']['单位'], row._row['data']['key']).then(x=>{
  146. let y =[];
  147. for (let i = 1; i < x[0].length; i++) {
  148. y.push({
  149. 'ID' : x[0][i][0],
  150. '人材机编码' : x[0][i][1],
  151. '名称' : x[0][i][2],
  152. '规格型号': x[0][i][3],
  153. '单位' : x[0][i][4],
  154. '单价' : x[0][i][5],
  155. '产地' : x[0][i][6],
  156. '供应厂商' : x[0][i][7],
  157. '人材机类别' : x[0][i][8],
  158. '甲供标志': x[0][i][9],
  159. '含量' : x[0][i][10],
  160. '合价' : x[0][i][11],
  161. '暂估价标志' : x[0][i][12],
  162. '主要材料标志' : x[0][i][13],
  163. '主材标志' : x[0][i][14],
  164. '设备标志' : x[0][i][15]
  165. });
  166. }
  167. setRcjhl(y);
  168. if (rcjTable.current) {
  169. rcjTable.current.replaceData(y);
  170. }
  171. isQdrcj.current = false;
  172. setFuzhuEnable(x[1]);
  173. let toHighlight = [];
  174. for(let i = 0; i < y.length; i++) {
  175. let entry = y[i];
  176. let bianhao = entry['人材机编码'];
  177. let rcjlb = entry['人材机类别'];
  178. if (Number(rcjlb) == 1 && rgdeRef.current ) {
  179. for (let j = 0;j < rgdeRef.current.length; j++) {
  180. if (rgdeRef.current[j]["CLBH"] == bianhao) {
  181. let danjia = Number(entry['单价']);
  182. if (!number_equal(danjia , rgdeRef.current[j]["YSJG"])) {
  183. console.log(`[${i},5]danjia bu yizhi`);
  184. toHighlight.push({row: i, col: 5, });
  185. }
  186. let hanliang = Number(entry['含量']);
  187. if (!number_equal(hanliang , rgdeRef.current[j]["gr"])) {
  188. console.log(`[${i}, 10]hanliang bu yizhi`);
  189. toHighlight.push({row: i, col: 10, });
  190. }
  191. }
  192. }
  193. }
  194. if (Number(rcjlb) == 3 && jxdeRef.current ) {
  195. for (let j = 0; j < jxdeRef.current.length; j++) {
  196. if (jxdeRef.current[j]["jxbh"] == bianhao) {
  197. let danjia = Number(entry['单价']);
  198. if (!number_equal(danjia , jxdeRef.current[j]["tbdj"])) {
  199. console.log(`[${i},5]danjia bu yizhi`);
  200. toHighlight.push({row: i, col: 5, });
  201. }
  202. let hanliang = Number(entry['含量']);
  203. if (!number_equal(hanliang , jxdeRef.current[j]["sl"])) {
  204. console.log(`[${i}, 10]hanliang bu yizhi`);
  205. toHighlight.push({row: i, col: 10, });
  206. }
  207. }
  208. }
  209. }
  210. if (Number(rcjlb) == 2 && cldeRef.current ) {
  211. for (let j = 0; j < cldeRef.current.length; j++) {
  212. if (cldeRef.current[j]["CLBH"] == bianhao) {
  213. let danjia = Number(entry['单价']);
  214. if (!number_equal(danjia , cldeRef.current[j]["YSJG"])) {
  215. console.log(`[${i},5]danjia bu yizhi`);
  216. toHighlight.push({row: i, col: 5, });
  217. }
  218. let hanliang = Number(entry['含量']);
  219. if (!number_equal(hanliang , cldeRef.current[j]["SL"])) {
  220. console.log(`[${i}, 10]hanliang bu yizhi`);
  221. toHighlight.push({row: i, col: 10, });
  222. }
  223. }
  224. }
  225. }
  226. }
  227. highlight.current = toHighlight;
  228. });
  229. }
  230. }
  231. const [detail, setDetail] = React.useState([
  232. ]);
  233. const myRef = React.useRef(null);
  234. const myTable = React.useRef(null);
  235. const tuijianRef = React.useRef(null);
  236. const tuijianTable = React.useRef(null);
  237. const rcj2Ref = React.useRef(null);
  238. const rcj2Table = React.useRef(null);
  239. const rcjRef = React.useRef(null);
  240. const rcjTable = React.useRef(null);
  241. const [value, setValue] = React.useState("1");
  242. const [rcjhl, setRcjhl] = React.useState([]);
  243. const [rcjhl2, setRcjhl2] = React.useState([]);
  244. const [fuzhu, setFuzhu] = React.useState([]);
  245. const [tuijian, setTuijian] = React.useState([]);
  246. const beizhuFKRef = React.useRef(null);
  247. const [fuzhuEnable, setFuzhuEnable] = React.useState(false);
  248. const onSelectChange = (newSelectedRowKeys) => {
  249. const [newData, newHl] = handleBeizhu_djcs(beizhuFKRef.current, selectedRowKeysTable.current[0], newSelectedRowKeys, fuzhu);
  250. if (newData) {
  251. myTable.current.updateData(newData.filter(x=>x['key'] == selectedRowKeysTableParent.current));
  252. let y =[];
  253. for (let i = 1; i < newHl.length; i++) {
  254. y.push({
  255. 'ID' : newHl[i][0],
  256. '人材机编码' : newHl[i][1],
  257. '名称' : newHl[i][2],
  258. '规格型号': newHl[i][3],
  259. '单位' : newHl[i][4],
  260. '单价' : newHl[i][5],
  261. '产地' : newHl[i][6],
  262. '供应厂商' : newHl[i][7],
  263. '人材机类别' : newHl[i][8],
  264. '甲供标志': newHl[i][9],
  265. '含量' : newHl[i][10],
  266. '合价' : newHl[i][11],
  267. '暂估价标志' : newHl[i][12],
  268. '主要材料标志' : newHl[i][13],
  269. '主材标志' : newHl[i][14],
  270. '设备标志' : newHl[i][15]
  271. });
  272. }
  273. setRcjhl(y);
  274. if (rcjTable.current) {
  275. rcjTable.current.replaceData(y);
  276. }
  277. }
  278. };
  279. const highlight = React.useRef([]);
  280. const rgdeRef = React.useRef(null);
  281. const jxdeRef = React.useRef(null);
  282. const cldeRef = React.useRef(null);
  283. const isQdrcj = React.useRef(false);
  284. const debmRef = React.useRef(null);
  285. const selectedRowKeysTable = React.useRef([]);
  286. const selectedRowKeysTableParent = React.useRef(null);
  287. const [checked, setChecked] = React.useState(false);
  288. const [indeterminate, setIndeterminate] = React.useState(false);
  289. const [checkedKeys, setCheckedKeys] = React.useState([]);
  290. const setCheckedKeys_ = (keys) => {
  291. setCheckedKeys(keys);
  292. if (keys.length == fuzhu.length) {
  293. setChecked(true);
  294. setIndeterminate(false);
  295. } else if (keys.length == 0) {
  296. setChecked(false);
  297. setIndeterminate(false);
  298. } else {
  299. setIndeterminate(true);
  300. setChecked(false);
  301. }
  302. onSelectChange(keys);
  303. };
  304. const setCheckedKeys_2 = (keys) => {
  305. setCheckedKeys(keys);
  306. if (keys.length == fuzhu.length) {
  307. setChecked(true);
  308. setIndeterminate(false);
  309. } else if (keys.length == 0) {
  310. setChecked(false);
  311. setIndeterminate(false);
  312. } else {
  313. setIndeterminate(true);
  314. setChecked(false);
  315. }
  316. //onSelectChange(keys);
  317. };
  318. const handleCheckAll = (value, checked) => {
  319. const keys = checked? fuzhu.map(item => item.id) : [];
  320. setCheckedKeys_(keys);
  321. }
  322. const handleCheck = (value, checked) => {
  323. const keys = checked? [...checkedKeys, value] : checkedKeys.filter(item => item != value);
  324. setCheckedKeys_(keys);
  325. }
  326. const CheckCell = ({rowData, onChange, checkedKeys, dataKey, disabled, ...props}) => {
  327. return <Cell {...props} style={{ padding: 0}}>
  328. <div style={{lineHeight: '40px'}}>
  329. <Checkbox value = {rowData[dataKey]}
  330. inline
  331. disabled={disabled}
  332. onChange={onChange}
  333. checked={checkedKeys.some(item => item === rowData[dataKey])}
  334. ></Checkbox>
  335. </div>
  336. </Cell>
  337. };
  338. const resetUI = () => {
  339. selectedRowKeysTable.current = [];
  340. selectedRowKeysTableParent.current = null;
  341. setRcjhl([]);
  342. if (rcjTable.current) {
  343. rcjTable.current.replaceData([]);
  344. }
  345. setFuzhu([]);
  346. isQdrcj.current = true;
  347. highlight.current = [];
  348. setTuijian([]);
  349. if (tuijianTable.current) tuijianTable.current.replaceData([]);
  350. };
  351. React.useEffect(() => {
  352. myTable.current = new Tabulator(myRef.current, {
  353. index: "key",
  354. height: 380,
  355. renderVertical: "basic",
  356. data: detail, //link data to table
  357. reactiveData: false, //enable data reactivity
  358. dataTreeStartExpanded:true,
  359. dataTree: true,
  360. selectableRows:1, //make rows selectable
  361. editTriggerEvent:"dblclick", //trigger edit on double click
  362. dataTreeStartExpanded:function(row, level){
  363. //console.log(row);
  364. //console.log(level);
  365. return true; //expand rows where the "driver" data field is true;
  366. },
  367. columns: [ //Define Table Columns
  368. {title:"序号", field:"序号", width:80, headerSort:false, frozen: true}, //never hide this column
  369. {title:"清单编码", field:"清单编码", width:120,headerSort:false, frozen: true, formatter:"textarea" },
  370. {title:"名称", field:"名称", width:150, headerSort:false, formatter:"textarea"}, //hide this column first
  371. {title:"项目特征", field:"项目特征", width:150 , headerSort:false, formatter:"textarea"},
  372. {title:"计算规则", field:"计算规则", width:250, headerSort:false, formatter:"textarea"},
  373. {title:"单位", field:"单位", width:100, headerSort:false},
  374. {title:"数量", field:"数量", width:100, headerSort:false, editor: "input", editable: editCheck },
  375. {title:"综合单价", field:"综合单价", width:100, headerSort:false, formatter:"money"},
  376. {title:"合价", field:"合价", width:100, headerSort:false, formatter:"money"},
  377. {title:"人工费", field:"人工费", width:100, headerSort:false, formatter:"money"},
  378. {title:"主材费", field:"主材费", width:100, headerSort:false, formatter:"money"},
  379. {title:"设备费", field:"设备费", width:100, headerSort:false, formatter:"money"},
  380. {title:"辅材费", field:"辅材费", width:100, headerSort:false, formatter:"money"},
  381. {title:"材料费", field:"材料费", width:100, headerSort:false, formatter:"money"},
  382. {title:"机械费", field:"机械费", width:100, headerSort:false, formatter:"money"},
  383. {title:"管理费", field:"管理费", width:100, headerSort:false, formatter:"money"},
  384. {title:"利润", field:"利润", width:100, headerSort:false, formatter:"money"},
  385. {title:"暂估价", field:"暂估价", width:100, headerSort:false, formatter:"money"},
  386. {title:"综合人工工日", field:"综合人工工日", width:100, headerSort:false},
  387. ]
  388. });
  389. myTable.current.on("cellDblClick", function(e, cell){
  390. //e - the click event object
  391. //cell - cell component
  392. console.log(cell);
  393. });
  394. myTable.current.on("rowSelected", handleSelect);
  395. myTable.current.on("cellEdited", function(cell){
  396. //console.log("edited");
  397. //console.log();
  398. let key = cell._cell.row.data['key'];
  399. myTable.current.deselectRow();
  400. let [success, data] = updateShuliang_djcs(cell._cell.row.data['数量'], selectedRowKeysTable.current[0]);
  401. if (success) {
  402. myTable.current.updateData(data.filter(x=>x['key'] == selectedRowKeysTableParent.current)).then(function() {
  403. let getRow = myTable.current.getRows(); //get array of currently selected row components.
  404. let component = null;
  405. for(let i = 0; i < getRow.length; i++) {
  406. let entry = getRow[i]._row.modules.dataTree.children;
  407. for(let j = 0; j < entry.length; j++) {
  408. let child = entry[j];
  409. if(child.data['key'] == key) {
  410. //console.log(child);
  411. component = child.component;
  412. break;
  413. }
  414. }
  415. }
  416. component.select();
  417. handleSelect(component);
  418. //handleSelect(getRow[0]);
  419. });
  420. }
  421. });
  422. myTable.current.on("tableBuilt", () => {
  423. Service.generateDjcs(name, bh).then(x=>{
  424. myTable.current.replaceData(x);
  425. });
  426. });
  427. }, [bh]);
  428. React.useEffect(
  429. () => {
  430. beizhuFKRef.current = beizhuFK;
  431. }, [beizhuFK]
  432. );
  433. React.useEffect(
  434. () => {
  435. console.log(beizhu);
  436. let result = [];
  437. if (beizhu != null) {
  438. let keys = Object.keys(beizhu["BZBH"]);
  439. for(let i = 0; i < keys.length; i++) {
  440. let key = keys[i];
  441. result.push({'id': i+1, 'key': i+1, '序号': i+1, '编号': beizhu["BZBH"][key], '说明': beizhu["SM"][key]});//序号很重要
  442. }
  443. setFuzhu(result);
  444. let newSelect = extractFuzhu(debmRef.current);
  445. setCheckedKeys_2(newSelect);
  446. }
  447. }, [beizhu]
  448. );
  449. React.useEffect(
  450. () => {
  451. if (tuijianRef.current != null ) {
  452. tuijianTable.current = new Tabulator(tuijianRef.current, {
  453. index: "key",
  454. height: 200,
  455. data: tuijian, //link data to table
  456. reactiveData: false, //enable data reactivity
  457. dataTreeStartExpanded:false,
  458. dataTree: false,
  459. selectableRows:1, //make rows selectable
  460. columns: [ //Define Table Columns
  461. {title:"ID", field:"ID", width:80, headerSort:false, }, //never hide this column
  462. {title:"定额编号", field:"定额编号", width:120,headerSort:false, formatter:"textarea" },
  463. {title:"工程量名称", field:"工程量名称", width:150, headerSort:false, formatter:"textarea"}, //hide this column first
  464. {title:"工作内容", field:"工作内容", width:150 , headerSort:false, formatter:"textarea"},
  465. ]
  466. });
  467. tuijianTable.current.on("tableBuilt", () => {
  468. tuijianTable.current.replaceData(tuijian);
  469. });
  470. }
  471. if (rcj2Ref.current != null ) {
  472. rcj2Table.current = new Tabulator(rcj2Ref.current, {
  473. index: "key",
  474. height: 200,
  475. data: rcjhl2, //link data to table
  476. reactiveData: false, //enable data reactivity
  477. dataTreeStartExpanded:false,
  478. dataTree: false,
  479. selectableRows:1, //make rows selectable
  480. columns: [ //Define Table Columns
  481. {title:"人材机编码", field:"人材机编码", width:120, headerSort:false, }, //never hide this column
  482. {title:"名称", field:"名称", width:120,headerSort:false, formatter:"textarea" },
  483. {title:"单位", field:"单位", width:150, headerSort:false, formatter:"textarea"}, //hide this column first
  484. {title:"单价", field:"单价", width:150 , headerSort:false, formatter:"money"},
  485. {title:"合价", field:"合价", width:150 , headerSort:false, formatter:"money"},
  486. {title:"含量", field:"含量", width:150 , headerSort:false, formatter:"textarea"},
  487. ]
  488. });
  489. rcj2Table.current.on("tableBuilt", () => {
  490. rcj2Table.current.replaceData(rcjhl2);
  491. });
  492. }
  493. if (rcjRef.current != null ) {
  494. rcjTable.current = new Tabulator(rcjRef.current, {
  495. index: "key",
  496. height: 200,
  497. data: rcjhl, //link data to table
  498. reactiveData: false, //enable data reactivity
  499. dataTreeStartExpanded:false,
  500. dataTree: false,
  501. selectableRows:1, //make rows selectable
  502. editTriggerEvent:"dblclick",
  503. columns: [ //Define Table Columns
  504. {title:"ID", field:"ID", width:80, headerSort:false, },
  505. {title:"人材机编码", field:"人材机编码", width:120, headerSort:false, formatter: sparklineFormatter2}, //never hide this column
  506. {title:"名称", field:"名称", width:120,headerSort:false, formatter:"textarea", editor: "input", editable: editCheckRcj },
  507. {title:"规格型号", field:"规格型号", width:80, headerSort:false, editor: "input", editable: editCheckRcj },
  508. {title:"单位", field:"单位", width:80, headerSort:false, formatter:"textarea"}, //hide this column first
  509. {title:"单价", field:"单价", width:80 , headerSort:false, formatter: sparklineFormatter, editor: "input", editable: editCheckRcj },
  510. {title:"产地", field:"产地", width:80, headerSort:false, },
  511. {title:"供应厂商", field:"供应厂商", width:80, headerSort:false, },
  512. {title:"人材机类别", field:"人材机类别", width:120, headerSort:false, },
  513. {title:"甲供标志", field:"甲供标志", width:80 , headerSort:false, formatter:"textarea"},
  514. {title:"含量", field:"含量", width:80 , headerSort:false, formatter:"money", formatterParams:{precision:4}, editor: "input", editable: editCheckRcj },
  515. {title:"合价", field:"合价", width:80 , headerSort:false, formatter:"money"},
  516. {title:"暂估价标志", field:"暂估价标志", width:80 , headerSort:false, formatter:"textarea"},
  517. {title:"主要材料标志", field:"主要材料标志", width:100 , headerSort:false, formatter:"textarea"},
  518. {title:"主材标志", field:"主材标志", width:80 , headerSort:false, formatter:"textarea"},
  519. {title:"设备标志", field:"设备标志", width:80 , headerSort:false, formatter:"textarea"},
  520. ]
  521. });
  522. rcjTable.current.on("tableBuilt", () => {
  523. rcjTable.current.replaceData(rcjhl);
  524. });
  525. rcjTable.current.on("cellEdited", function(cell){
  526. let data = copy(cell._cell.table.getData());
  527. for(let i = 0; i < data.length; i++) {
  528. data[i]['合价'] = Number(data[i]['单价']) * Number(data[i]['含量']);
  529. }
  530. setRcjhl(data);
  531. if (rcjTable.current) {
  532. rcjTable.current.replaceData(data);
  533. }
  534. let data2 = [['ID', '人材机编码', '名称', '规格型号', '单位', '单价', '产地', '供应厂商', '人材机类别', '甲供标志', '含量', '合价', '暂估价标志', '主要材料标志', '主材标志', '设备标志']]
  535. for (let i = 0; i < data.length; i++) {
  536. data2.push([data[i]['ID'], data[i]['人材机编码'], data[i]['名称'], data[i]['规格型号'], data[i]['单位'],
  537. data[i]['单价'], data[i]['产地'], data[i]['供应厂商'], data[i]['人材机类别'],
  538. data[i]['甲供标志'], data[i]['含量'], data[i]['合价'], data[i]['暂估价标志'], data[i]['主要材料标志'], data[i]['主材标志'], data[i]['设备标志']]);
  539. }
  540. let newData = updateDercj_djcs(selectedRowKeysTable.current[0], data2);
  541. myTable.current.updateData(newData.filter(x=>x['key'] == selectedRowKeysTableParent.current)).then(function() {
  542. let getRow = myTable.current.getRows(); //get array of currently selected row components.
  543. let component = null;
  544. for(let i = 0; i < getRow.length; i++) {
  545. let entry = getRow[i]._row.modules.dataTree.children;
  546. for(let j = 0; j < entry.length; j++) {
  547. let child = entry[j];
  548. if(child.data['key'] == selectedRowKeysTable.current[0]) {
  549. //console.log(child);
  550. component = child.component;
  551. break;
  552. }
  553. }
  554. }
  555. handleSelect(component);
  556. });
  557. });
  558. }
  559. }, [value]
  560. );
  561. React.useEffect(
  562. () => {
  563. myTable.current.deselectRow();
  564. //console.log(dingeclick);
  565. if (selectedRowKeysTable.current.length > 0 ) {
  566. const [success, data, key] = changguidinge_djcs(JSON.parse(dingeclick), selectedRowKeysTable.current[0]);
  567. if (success) {
  568. myTable.current.updateData(data.filter(x=>x['key'] == selectedRowKeysTableParent.current)).then(function(){
  569. let getRow = myTable.current.getRows(); //get array of currently selected row components.
  570. let component = null;
  571. for(let i = 0; i < getRow.length; i++) {
  572. let entry = getRow[i]._row.modules.dataTree.children;
  573. for(let j = 0; j < entry.length; j++) {
  574. let child = entry[j];
  575. if(child.data['key'] == key) {
  576. //console.log(child);
  577. component = child.component;
  578. break;
  579. }
  580. }
  581. }
  582. component.select();
  583. handleSelect(component);
  584. });
  585. }
  586. }
  587. }, [dingeclick]//常规添加定额
  588. );
  589. React.useEffect(
  590. () => {
  591. console.log("rgde changed");
  592. console.log(rgde);
  593. rgdeRef.current = rgde;
  594. jxdeRef.current = jxde;
  595. cldeRef.current = clde;
  596. if (isQdrcj.current) {
  597. highlight.current = [];
  598. } else {
  599. let toHighlight = [];
  600. for(let i = 0; i < rcjhl.length; i++) {
  601. let entry = rcjhl[i];
  602. let bianhao = entry['人材机编码'];
  603. let rcjlb = entry['人材机类别'];
  604. if (Number(rcjlb) == Number(1) && rgde) {
  605. for (let j = 0; j < rgde.length; j++) {
  606. if (rgde[j]["CLBH"] == bianhao) {
  607. let danjia = Number(entry['单价']);
  608. if (!number_equal(danjia , rgde[j]["YSJG"])) {
  609. console.log(`[${i},5]danjia bu yizhi`);
  610. toHighlight.push({row: i, col: 5});
  611. }
  612. let hanliang = Number(entry['含量']);
  613. if (!number_equal(hanliang , rgde[j]["gr"])) {
  614. console.log(`[${i}, 10]hanliang bu yizhi`);
  615. toHighlight.push({row: i, col: 10});
  616. }
  617. }
  618. }
  619. }
  620. if (Number(rcjlb) == Number(3) && jxde ) {
  621. for (let j = 0; j < jxde.length; j++) {
  622. if (jxde[j]["jxbh"] == bianhao) {
  623. let danjia = Number(entry['单价']);
  624. if (!number_equal(danjia , jxde[j]["tbdj"])) {
  625. console.log(`[${i},5]danjia bu yizhi`);
  626. toHighlight.push({row: i, col: 5, });
  627. }
  628. let hanliang = Number(entry['含量']);
  629. if (!number_equal(hanliang , jxde[j]["sl"])) {
  630. console.log(`[${i}, 10]hanliang bu yizhi`);
  631. toHighlight.push({row: i, col: 10, });
  632. }
  633. }
  634. }
  635. }
  636. if (Number(rcjlb) == Number(2) && clde ) {
  637. for (let j = 0; j < clde.length; j++) {
  638. if (clde[j]["CLBH"] == bianhao) {
  639. let danjia = Number(entry['单价']);
  640. if (!number_equal(danjia , clde[j]["YSJG"])) {
  641. console.log(`[${i},5]danjia bu yizhi`);
  642. toHighlight.push({row: i, col: 5, });
  643. }
  644. let hanliang = Number(entry['含量']);
  645. if (!number_equal(hanliang ,clde[j]["SL"])) {
  646. console.log(`[${i}, 10]hanliang bu yizhi`);
  647. toHighlight.push({row: i, col: 10, });
  648. }
  649. }
  650. }
  651. }
  652. }
  653. console.log(toHighlight);
  654. highlight.current = toHighlight;
  655. }
  656. let bzrcjhl = []
  657. if (rgde)
  658. for (let i = 0; i < rgde.length; i++) {
  659. bzrcjhl.push({'人材机编码': rgde[i]["CLBH"], '名称': rgde[i]["CLMC"], '单位': rgde[i]["JLDW"], '单价': rgde[i]["YSJG"], '合价': rgde[i]["gf"], '含量': rgde[i]["gr"]});
  660. }
  661. if (clde)
  662. for (let i = 0; i < clde.length; i++) {
  663. bzrcjhl.push({'人材机编码': clde[i]["CLBH"], '名称': clde[i]["CLMC"], '单位': clde[i]["JLDW"], '单价': clde[i]["YSJG"], '合价': clde[i]["HJ"], '含量': clde[i]["SL"]});
  664. }
  665. if (jxde)
  666. for (let i = 0; i < jxde.length; i++) {
  667. bzrcjhl.push({'人材机编码': jxde[i]["jxbh"], '名称': jxde[i]["jxmc"], '单位': jxde[i]["DW"], '单价': jxde[i]["tbdj"], '合价': jxde[i]["hj"], '含量': jxde[i]["sl"]});
  668. }
  669. setRcjhl2(bzrcjhl);
  670. if (rcj2Table.current) {
  671. rcj2Table.current.replaceData(bzrcjhl);
  672. }
  673. }, [rgde, jxde, clde]
  674. );
  675. const handleChange = (event, newValue) => {
  676. setValue(newValue);
  677. };
  678. return (
  679. <Stack spacing={1}>
  680. <Stack direction='row' spacing={2}>
  681. <Button variant="outlined" size="small" onClick={() => {
  682. if (selectedRowKeysTable.current.length > 0) {
  683. const [success, data] = danxiangdinge_djcs(selectedRowKeysTable.current[0]);
  684. if(success) {
  685. myTable.current.updateData(data.filter(x=>x['key'] == selectedRowKeysTableParent.current)).then(function(){
  686. resetUI();
  687. });
  688. }
  689. }
  690. }}
  691. >单项定额</Button>
  692. <Button variant="outlined" size="small" onClick={() => {
  693. if (selectedRowKeysTable.current.length > 0) {
  694. let newData = shanchu_djcs(selectedRowKeysTable.current[0]);
  695. myTable.current.updateData(newData.filter(x=>x['key'] == selectedRowKeysTableParent.current)).then(function(){
  696. if (newData.filter(x=>x['key'] == selectedRowKeysTable.current[0]).length == 0) {
  697. resetUI();
  698. }
  699. });
  700. }
  701. }}
  702. >删除</Button>
  703. <Button variant="outlined" size="small" onClick={() => {
  704. let newData = undo_djcs();
  705. myTable.current.updateData(newData).then(function(){
  706. resetUI();
  707. });
  708. }}
  709. >撤销</Button>
  710. <Button variant="outlined" size="small" onClick={() => {
  711. let newData = redo_djcs();
  712. myTable.current.updateData(newData).then(function(){
  713. resetUI();
  714. });
  715. }}
  716. >重做</Button>
  717. <Button variant="outlined" size="small" onClick={() => {
  718. console.log("save to cloud");
  719. loadingCallback();
  720. }}
  721. >保存</Button>
  722. </Stack>
  723. <div ref={myRef}>
  724. </div>
  725. <Box >
  726. <TabContext value={value}>
  727. <Box sx={{ borderBottom: 1, borderColor: 'divider' }}>
  728. <TabList onChange={handleChange} aria-label="lab API tabs example" sx={{minHeight: '24px'}} >
  729. <Tab sx={{p: 0, minHeight: '24px'}} label="人材机含量" value="1" />
  730. <Tab sx={{p: 0, minHeight: '24px'}} label="标准定额人材机含量" value="2" />
  731. <Tab sx={{p: 0, minHeight: '24px'}} label="定额附注" value="3" />
  732. <Tab sx={{p: 0, minHeight: '24px'}} label="组价推荐" value="4" />
  733. </TabList>
  734. </Box>
  735. <TabPanel value="1">
  736. <div ref={rcjRef}></div>
  737. </TabPanel>
  738. <TabPanel value="2">
  739. <div ref={rcj2Ref}></div>
  740. </TabPanel>
  741. <TabPanel value="3">
  742. <Box sx={{maxHeight: `200px`, minHeight: `200px`, height: `200px`}}>
  743. <CustomProvider locale={zhCN}>
  744. <Table rowHeight={rowData=>{
  745. return 40;
  746. }}
  747. height={200} data = {fuzhu} id="fuzhu">
  748. <Column width={80} align="center">
  749. <HeaderCell style={{padding: 0}}>
  750. <div style={{lineHeight: '40px'}}>
  751. <Checkbox inline checked={checked} indeterminate={indeterminate} onChange={handleCheckAll} disabled={!fuzhuEnable}
  752. ></Checkbox>
  753. </div>
  754. </HeaderCell>
  755. <CheckCell dataKey="id" checkedKeys={checkedKeys} onChange={handleCheck} disabled={!fuzhuEnable}></CheckCell>
  756. </Column>
  757. <Column width={80} align="center">
  758. <HeaderCell style={{ "font-size": "0.875rem" }}>序号</HeaderCell>
  759. <Cell dataKey="序号" style={{ "font-size": "0.875rem" }}></Cell>
  760. </Column>
  761. <Column width={120} align="center">
  762. <HeaderCell style={{ "font-size": "0.875rem" }}>编号</HeaderCell>
  763. <Cell dataKey="编号" style={{ "font-size": "0.875rem" }}></Cell>
  764. </Column>
  765. <Column fullText width={650} align="center">
  766. <HeaderCell style={{ "font-size": "0.875rem" }}>说明</HeaderCell>
  767. <Cell dataKey="说明" style={{ "font-size": "0.875rem" }}></Cell>
  768. </Column>
  769. </Table>
  770. </CustomProvider>
  771. </Box>
  772. </TabPanel>
  773. <TabPanel value="4">
  774. <div ref={tuijianRef}></div>
  775. </TabPanel>
  776. </TabContext>
  777. </Box>
  778. </Stack>
  779. );
  780. }