Djcs3.js 43 KB

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