revise_compare.js 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320
  1. 'use strict';
  2. /**
  3. * 台账修订页面js
  4. *
  5. * @author Mai
  6. * @date
  7. * @version
  8. */
  9. const billsCompareField = [
  10. 'code', 'b_code', 'name', 'unit', 'unit_price', 'dgn_qty1', 'dgn_qty2', 'dgn_price',
  11. 'sgfh_qty', 'sgfh_tp', 'sjcl_qty', 'sjcl_tp', 'qtcl_qty', 'qtcl_tp', 'quantity', 'total_price',
  12. 'deal_qty', 'deal_tp'
  13. ];
  14. const posCompareField = [
  15. 'name', 'position', 'sgfh_qty', 'sjcl_qty', 'qtcl_qty', 'quantity'
  16. ];
  17. const compareColor = {
  18. add: '#D9EDF7'
  19. }
  20. $(document).ready(() => {
  21. let searchLedger;
  22. autoFlashHeight();
  23. // 初始化spread
  24. const billsSpread = SpreadJsObj.createNewSpread($('#bills-spread')[0]);
  25. const billsSheet = billsSpread.getActiveSheet();
  26. sjsSettingObj.setFxTreeStyle(billsSpreadSetting, sjsSettingObj.FxTreeStyle.jz);
  27. if (thousandth) sjsSettingObj.setTpThousandthFormat(billsSpreadSetting);
  28. billsSpreadSetting.getColor = function (sheet, data, row, col, defaultColor) {
  29. // 增
  30. if (data.differ.indexOf('add') >= 0) return '#cce5ff';
  31. // 删
  32. if (data.differ.indexOf('del') >= 0) return '#DCDCDC';
  33. // 结构变动
  34. if (data.differ.indexOf('tree') >= 0) return '#d0f6fd';
  35. // 修改计算或文字
  36. if (data.differ.indexOf('calc') >= 0) return '#f8d7da';
  37. if (data.differ.indexOf('info') >= 0) return '#d4edda';
  38. // 层次结构
  39. if (data.level === 2) {
  40. return '#C4CAFB';
  41. } else if ((!data.b_code || data.b_code === '') && data.level > 2) {
  42. return '#DFE8F9';
  43. } else {
  44. return defaultColor;
  45. }
  46. };
  47. SpreadJsObj.initSheet(billsSheet, billsSpreadSetting);
  48. const posSpread = SpreadJsObj.createNewSpread($('#pos-spread')[0]);
  49. const posSheet = posSpread.getActiveSheet();
  50. sjsSettingObj.setGridSelectStyle(posSpreadSetting);
  51. if (thousandth) sjsSettingObj.setTpThousandthFormat(posSpreadSetting);
  52. SpreadJsObj.initSheet(posSheet, posSpreadSetting);
  53. const posSearch = $.posSearch({selector: '#pos-search', searchSpread: posSpread});
  54. // 初始化 节点树结构
  55. const treeSetting = {
  56. id: 'ledger_id',
  57. pid: 'ledger_pid',
  58. order: 'order',
  59. level: 'level',
  60. full_path: 'full_path',
  61. rootId: -1,
  62. keys: ['id', 'tender_id', 'ledger_id'],
  63. calcFields: ['sgfh_tp', 'sjcl_tp', 'qtcl_tp', 'total_price'],
  64. findNode: function (tree, node, parent) {
  65. const sameId = tree.datas.find(x => {return x.id === node.id});
  66. if (sameId) {
  67. sameId.org_pid = parent ? parent[tree.setting.id] : tree.setting.rootId;
  68. if (sameId[tree.setting.pid] !== sameId.org_pid) {
  69. sameId.changeParent = true;
  70. }
  71. return sameId;
  72. } else {
  73. const siblings = parent ? parent.children : tree.children;
  74. return siblings.find(function (x) {
  75. return node.b_code
  76. ? x.b_code === node.b_code && x.name === node.name && x.unit === node.unit && x.unit_price === node.unit_price
  77. : x.code === node.code && x.name === node.name;
  78. });
  79. }
  80. },
  81. loadInfo1: function (node, source) {
  82. for (const f of billsCompareField) {
  83. node['new_' + f] = source[f];
  84. }
  85. node.id = source.id;
  86. node.isNew = true;
  87. },
  88. loadInfo2: function (node, source) {
  89. for (const f of billsCompareField) {
  90. node['org_' + f] = source[f];
  91. }
  92. node.isOrg = true;
  93. },
  94. afterLoad: function (tree) {
  95. for (const data of tree.datas) {
  96. data.differ = [];
  97. data.differ_str = [];
  98. if (data.isNew && !data.isOrg) {
  99. data.differ.push('add');
  100. data.differ_str.push('增');
  101. } else if (!data.isNew && data.isOrg) {
  102. data.differ.push('del');
  103. data.differ_str.push('删');
  104. } else {
  105. if (data.changeParent) data.differ.push('tree');
  106. if (!data.children || data.children.length === 0) {
  107. const orgCalc = getCompare(data, compareFields.leafCalc, 'org_', 0);
  108. const newCalc = getCompare(data, compareFields.leafCalc, 'new_', 0);
  109. if (!_.isMatch(newCalc, orgCalc)) data.differ.push('calc');
  110. } else {
  111. const orgCalc = getCompare(data, compareFields.parentCalc, 'org_', 0);
  112. const newCalc = getCompare(data, compareFields.parentCalc, 'new_', 0);
  113. if (!_.isMatch(newCalc, orgCalc)) data.push('calc');
  114. }
  115. const orgInfo = getCompare(data, compareFields.info, 'org_', '');
  116. const newInfo = getCompare(data, compareFields.info, 'new_', '');
  117. if (!_.isMatch(newInfo, orgInfo)) data.differ.push('info');
  118. if (data.differ.length > 0) data.differ_str.push('改');
  119. }
  120. }
  121. }
  122. };
  123. if (!isTz) {
  124. treeSetting.calcFields.push('deal_tp');
  125. }
  126. treeSetting.calcFun = function (node) {
  127. node.dgn_price = ZhCalc.round(ZhCalc.div(node.total_price, node.dgn_qty1), 2);
  128. };
  129. const billsTree = createNewPathTree('compare', treeSetting);
  130. // 初始化 计量单元
  131. const pos = new PosData({ id: 'id', ledgerId: 'lid' });
  132. // 清单 相关方法&绑定spreadjs事件
  133. const billsTreeSpreadObj = {
  134. selectionChanged: function (e, info) {
  135. if (info.newSelections) {
  136. if (!info.oldSelections || info.newSelections[0].row !== info.oldSelections[0].row) {
  137. posSpreadObj.loadCurPosData();
  138. posSearch.search($('#pos-keyword').val());
  139. }
  140. }
  141. },
  142. };
  143. billsSpread.bind(spreadNS.Events.SelectionChanged, billsTreeSpreadObj.selectionChanged);
  144. // 计量单元 相关方法&绑定spreadjs事件
  145. const posSpreadObj = {
  146. /**
  147. * 加载计量单元 根据当前台账选择节点
  148. */
  149. loadCurPosData: function () {
  150. const node = SpreadJsObj.getSelectObject(billsSheet);
  151. if (node) {
  152. const posData = pos.getLedgerPos(node.id) || [];
  153. SpreadJsObj.loadSheetData(posSheet, 'data', posData);
  154. } else {
  155. SpreadJsObj.loadSheetData(posSheet, 'data', []);
  156. }
  157. },
  158. };
  159. // 加载清单&计量单元数据
  160. postData('/tender/' + window.location.pathname.split('/')[2] + '/revise/load', {filter: 'bills;pos;reviseBills;revisePos'}, function (result) {
  161. const tenderTreeSetting = {
  162. id: 'ledger_id',
  163. pid: 'ledger_pid',
  164. order: 'order',
  165. level: 'level',
  166. rootId: -1,
  167. keys: ['id', 'tender_id', 'ledger_id'],
  168. calcFields: ['deal_tp', 'sgfh_tp', 'sjcl_tp', 'qtcl_tp', 'total_price'],
  169. };
  170. const reviseLedger = {
  171. billsTree: createNewPathTree('ledger', tenderTreeSetting),
  172. };
  173. reviseLedger.billsTree.loadDatas(result.reviseBills);
  174. const orgLedger = {
  175. billsTree: createNewPathTree('ledger', tenderTreeSetting),
  176. };
  177. 202-orgLedger.billsTree.loadDatas(result.bills);
  178. billsTree.loadCompareData(reviseLedger, orgLedger);
  179. console.log(billsTree.nodes);
  180. SpreadJsObj.loadSheetData(billsSheet, SpreadJsObj.DataType.Tree, billsTree);
  181. pos.loadDatas(result.pos);
  182. posSpreadObj.loadCurPosData();
  183. }, null);
  184. $.divResizer({
  185. select: '#revise-resize',
  186. callback: function () {
  187. billsSpread.refresh();
  188. let bcontent = $(".bcontent-wrap") ? $(".bcontent-wrap").height() : 0;
  189. $(".sp-wrap").height(bcontent-30);
  190. posSpread.refresh();
  191. }
  192. });
  193. $.divResizer({
  194. select: '#revise-right-spr',
  195. callback: function () {
  196. billsSpread.refresh();
  197. if (posSpread) {
  198. posSpread.refresh();
  199. }
  200. if (searchLedger) {
  201. searchLedger.spread.refresh();
  202. }
  203. }
  204. });
  205. $.subMenu({
  206. menu: '#sub-menu', miniMenu: '#sub-mini-menu', miniMenuList: '#mini-menu-list',
  207. toMenu: '#to-menu', toMiniMenu: '#to-mini-menu',
  208. key: 'menu.1.0.0',
  209. miniHint: '#sub-mini-hint', hintKey: 'menu.hint.1.0.1',
  210. callback: function (info) {
  211. if (info.mini) {
  212. $('.panel-title').addClass('fluid');
  213. $('#sub-menu').removeClass('panel-sidebar');
  214. } else {
  215. $('.panel-title').removeClass('fluid');
  216. $('#sub-menu').addClass('panel-sidebar');
  217. }
  218. autoFlashHeight();
  219. billsSpread.refresh();
  220. if (posSpread) {
  221. posSpread.refresh();
  222. }
  223. if (searchLedger) {
  224. searchLedger.spread.refresh();
  225. }
  226. }
  227. });
  228. // 展开收起标准节点
  229. $('a', '#side-menu').bind('click', function (e) {
  230. e.preventDefault();
  231. const tab = $(this), tabPanel = $(tab.attr('content'));
  232. // 展开工具栏、切换标签
  233. if (!tab.hasClass('active')) {
  234. const close = $('.active', '#side-menu').length === 0;
  235. $('a', '#side-menu').removeClass('active');
  236. tab.addClass('active');
  237. $('.tab-content .tab-pane').removeClass('active');
  238. tabPanel.addClass('active');
  239. showSideTools(tab.hasClass('active'));
  240. if (tab.attr('content') === '#search') {
  241. if (!searchLedger) {
  242. searchLedger = $.billsSearch({
  243. selector: '#search',
  244. searchSpread: billsSpread,
  245. resultSpreadSetting: {
  246. cols: [
  247. {title: '项目节编号', field: 'code', hAlign: 0, width: 90, formatter: '@', readOnly: true},
  248. {title: '清单编号', field: 'b_code', hAlign: 0, width: 80, formatter: '@', readOnly: true},
  249. {title: '名称', field: 'name', width: 150, hAlign: 0, formatter: '@', readOnly: true},
  250. {title: '单位', field: 'unit', width: 50, hAlign: 1, formatter: '@', readOnly: true},
  251. ],
  252. emptyRows: 0,
  253. headRows: 1,
  254. headRowHeight: [32],
  255. headColWidth: [30],
  256. defaultRowHeight: 21,
  257. headerFont: '12px 微软雅黑',
  258. font: '12px 微软雅黑',
  259. selectedBackColor: '#fffacd',
  260. },
  261. afterLocated: function () {
  262. posSpreadObj.loadCurPosData();
  263. }
  264. });
  265. }
  266. searchLedger.spread.refresh();
  267. }
  268. }
  269. else {// 收起工具栏
  270. tab.removeClass('active');
  271. tabPanel.removeClass('active');
  272. showSideTools(tab.hasClass('active'));
  273. }
  274. billsSpread.refresh();
  275. if (posSpread) {
  276. posSpread.refresh();
  277. }
  278. });
  279. // 显示层次
  280. (function (select, sheet) {
  281. $(select).click(function () {
  282. if (!sheet.zh_tree) return;
  283. const tag = $(this).attr('tag');
  284. const tree = sheet.zh_tree;
  285. switch (tag) {
  286. case "1":
  287. case "2":
  288. case "3":
  289. case "4":
  290. case "5":
  291. tree.expandByLevel(parseInt(tag));
  292. SpreadJsObj.refreshTreeRowVisible(sheet);
  293. break;
  294. case "last":
  295. tree.expandByCustom(() => { return true; });
  296. SpreadJsObj.refreshTreeRowVisible(sheet);
  297. break;
  298. case "leafXmj":
  299. tree.expandToLeafXmj();
  300. SpreadJsObj.refreshTreeRowVisible(sheet);
  301. break;
  302. }
  303. });
  304. })('a[name=showLevel]', billsSheet);
  305. });