std_bills_lib.js 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378
  1. /**
  2. * Standard Bills Lib
  3. * Created by Mai on 2017/5/16.
  4. */
  5. var billsLibObj = {
  6. stdBillsSpread: null,
  7. stdBillsJobSpread: null,
  8. stdBillsFeatureSpread: null,
  9. refreshSettingForHint: function () {
  10. TREE_SHEET_HELPER.initSetting($('#stdBillsSpread')[0], billsLibObj.stdBillsTreeSetting);
  11. },
  12. checkBillsSpread: function () {
  13. if (!this.stdBillsSpread) {
  14. this.stdBillsSpread = SheetDataHelper.createNewSpread($('#stdBillsSpread')[0]);
  15. // 刷新setting中记录的spread的位置
  16. this.refreshSettingForHint();
  17. }
  18. },
  19. refreshBillsSpread: function () {
  20. if (this.stdBillsSpread) {
  21. this.stdBillsSpread.refresh();
  22. }
  23. },
  24. checkBillsRelaSpread: function () {
  25. if (!this.stdBillsJobSpread) {
  26. this.stdBillsJobSpread = SheetDataHelper.createNewSpread($('#stdBillsJobs')[0]);
  27. }
  28. if (!this.stdBillsFeatureSpread) {
  29. this.stdBillsFeatureSpread = SheetDataHelper.createNewSpread($('#stdBillsFeatures')[0]);
  30. }
  31. },
  32. refreshBillsRelaSpread: function () {
  33. if (this.stdBillsJobSpread) {
  34. this.stdBillsJobSpread.refresh();
  35. }
  36. if (this.stdBillsFeatureSpread) {
  37. this.stdBillsFeatureSpread.refresh();
  38. }
  39. },
  40. clearHighLight: function (spread) {
  41. if (spread) {
  42. let sheet = spread.getActiveSheet();
  43. sheet.suspendPaint();
  44. sheet.getRange(0, -1, sheet.getRowCount(), -1, GC.Spread.Sheets.SheetArea.viewport).backColor(undefined);
  45. sheet.resumePaint();
  46. }
  47. },
  48. loadStdBillsLib: function () {
  49. let i, select = $('#stdBillsLibSelect');
  50. select.empty();
  51. let bills_lib = projectInfoObj.projectInfo.engineeringInfo.bill_lib;
  52. bills_lib.forEach(function (data) {
  53. var option = $('<option>').val(data.id).text(data.name);
  54. select.append(option);
  55. });
  56. if (select.children.length !== 0) {
  57. billsLibObj.loadStdBills(select.val());
  58. }
  59. },
  60. loadStdBills: function (stdBillsLibID) {
  61. var that = this;
  62. var stdBillsJobData, stdBillsFeatureData, stdBills;
  63. var stdBillsTree = idTree.createNew({id: 'ID', pid: 'ParentID', nid: 'NextSiblingID', rootId: -1, autoUpdate: true});
  64. var stdBillsTreeController = TREE_SHEET_CONTROLLER.createNew(stdBillsTree, billsLibObj.stdBillsSpread.getActiveSheet(), billsLibObj.stdBillsTreeSetting);
  65. var findData = function (value, field, Array) {
  66. var i = 0;
  67. for (i = 0; i < Array.length; i++) {
  68. if (value[field] === Array[i][field]) {
  69. return Array[i];
  70. }
  71. }
  72. return null;
  73. };
  74. var getBillsJobs = function (node) {
  75. var jobs = [], i, jobData = null;
  76. if (stdBillsJobData && node && node.data.jobs) {
  77. for (i = 0; i < node.data.jobs.length; i++) {
  78. jobData = findData(node.data.jobs[i], 'id', stdBillsJobData);
  79. if (jobData) {
  80. jobs.push(jobData);
  81. }
  82. }
  83. }
  84. return jobs;
  85. };
  86. var getBillsFeatures = function (node) {
  87. var features = [], i, featureData = null;
  88. if (stdBillsFeatureData && node && node.data.items) {
  89. for (i = 0; i < node.data.items.length; i++) {
  90. featureData = findData(node.data.items[i], 'id', stdBillsFeatureData);
  91. if (featureData) {
  92. features.push(featureData);
  93. }
  94. }
  95. }
  96. return features;
  97. };
  98. var showJobs = function (jobs) {
  99. SheetDataHelper.loadSheetHeader(billsLibObj.jobsSetting, billsLibObj.stdBillsJobSpread.getActiveSheet());
  100. SheetDataHelper.loadSheetData(billsLibObj.jobsSetting, billsLibObj.stdBillsJobSpread.getActiveSheet(), jobs);
  101. };
  102. var showFeatures = function (features) {
  103. SheetDataHelper.loadSheetHeader(billsLibObj.featuresSetting, billsLibObj.stdBillsFeatureSpread.getActiveSheet());
  104. SheetDataHelper.loadSheetData(billsLibObj.featuresSetting, billsLibObj.stdBillsFeatureSpread.getActiveSheet(), features);
  105. };
  106. var showJobsAndFeatures = function (node) {
  107. $('#stdBillsJobTab').show();
  108. $('#stdBillsRemarkTab').hide();
  109. billsLibObj.refreshBillsRelaSpread();
  110. billsLibObj.checkBillsRelaSpread();
  111. showJobs(getBillsJobs(node));
  112. showFeatures(getBillsFeatures(node));
  113. };
  114. var showBillsRemark = function (node) {
  115. $('#stdBillsJobTab').hide();
  116. $('#stdBillsRemarkTab').show();
  117. $('#stdBillsRemark').text(node && node.data.recharge ? node.data.recharge : '');
  118. };
  119. var showBillsRela = function (node) {
  120. if (node && node.children.length === 0) {
  121. showJobsAndFeatures(node);
  122. } else {
  123. showBillsRemark(node);
  124. }
  125. };
  126. CommonAjax.post('/stdBillsEditor/getJobContent', {userId: userID, billsLibId: stdBillsLibID}, function (datas) {
  127. stdBillsJobData = datas;
  128. }, function () {
  129. stdBillsJobData = [];
  130. });
  131. CommonAjax.post('/stdBillsEditor/getItemCharacter', {userId: userID, billsLibId: stdBillsLibID}, function (datas) {
  132. stdBillsFeatureData = datas;
  133. }, function () {
  134. stdBillsFeatureData = [];
  135. });
  136. CommonAjax.post('/stdBillsEditor/getBills', {userId: userID, billsLibId: stdBillsLibID}, function (datas) {
  137. stdBills = datas;
  138. stdBillsTree.loadDatas(stdBills);
  139. stdBillsTreeController.showTreeData();
  140. showBillsRela(stdBillsTree.firstNode());
  141. stdBillsTreeController.bind(TREE_SHEET_CONTROLLER.eventName.treeSelectedChanged, showBillsRela);
  142. that.stdBillsSpread.bind(GC.Spread.Sheets.Events.CellDoubleClick, function (sender, args) {
  143. let selectNode = stdBillsTree.items[args.row];
  144. if (stdBillsTree.items[args.row].children.length === 0) {
  145. //特征及内容转化
  146. pageCCOprObj.setItemContentNode(stdBillsTree.items[args.row], getBillsJobs(stdBillsTree.items[args.row]), getBillsFeatures(stdBillsTree.items[args.row]));
  147. if (/\//.test(selectNode.data.unit)) {
  148. let existB = projectObj.project.Bills.sameStdCodeBillsData(selectNode.data.code);
  149. if (existB) {
  150. let std = JSON.parse(JSON.stringify(selectNode.data));
  151. std.unit = existB.unit;
  152. ProjectController.addBills(projectObj.project, projectObj.mainController, std);
  153. } else {
  154. ConfirmModal.stdBillsUnit.check(selectNode.data, function (std) {
  155. ProjectController.addBills(projectObj.project, projectObj.mainController, std);
  156. });
  157. }
  158. } else {
  159. ProjectController.addBills(projectObj.project, projectObj.mainController, selectNode.data);
  160. }
  161. }
  162. });
  163. }, function () {
  164. that.stdBillsSpread.unbind(GC.Spread.Sheets.Events.CellDoubleClick);
  165. });
  166. $('#stdBillsSearch>span>button').click(function () {
  167. var keyword = $('#stdBillsSearch>input').val();
  168. if (!keyword || keyword === '') {return}
  169. var result = stdBillsTree.items.filter(function (item) {
  170. var codeIs = item.data.code ? item.data.code.indexOf(keyword) !== -1 : false;
  171. var nameIs = item.data.name ? item.data.name.indexOf(keyword) !== -1 : false;
  172. return codeIs || nameIs;
  173. });
  174. result.sort(function (x, y) {
  175. return x.serialNo() - y.serialNo();
  176. });
  177. if (result.length !== 0) {
  178. var sel = billsLibObj.stdBillsSpread.getActiveSheet().getSelections();
  179. stdBillsTreeController.setTreeSelected(result[0]);
  180. billsLibObj.stdBillsSpread.getActiveSheet().setSelection(result[0].serialNo(), sel[0].col, 1, 1);
  181. for (let node of result) {
  182. billsLibObj.stdBillsSpread.getActiveSheet().getRange(node.serialNo(), -1, 1, -1).backColor('lemonChiffon');
  183. }
  184. $('#nextStdBills').show();
  185. $('#nextStdBills').click(function () {
  186. var cur = stdBillsTree.selected, resultIndex = result.indexOf(cur), sel = billsLibObj.stdBillsSpread.getActiveSheet().getSelections();
  187. if (resultIndex === result.length - 1) {
  188. stdBillsTreeController.setTreeSelected(result[0]);
  189. billsLibObj.stdBillsSpread.getActiveSheet().setSelection(result[0].serialNo(), sel[0].col, 1, 1);
  190. } else {
  191. stdBillsTreeController.setTreeSelected(result[resultIndex + 1]);
  192. billsLibObj.stdBillsSpread.getActiveSheet().setSelection(result[resultIndex + 1].serialNo(), sel[0].col, 1, 1);
  193. }
  194. });
  195. } else {
  196. billsLibObj.clearHighLight(billsLibObj.stdBillsSpread);
  197. $('#nextStdBills').hide();
  198. }
  199. $('#stdBillsSearchResultCount').text('搜索结果:' + result.length);
  200. $('#stdBillsSearchResult').show();
  201. });
  202. },
  203. stdBillsTreeSetting: {
  204. "treeCol": 0,
  205. "emptyRows":0,
  206. "headRows":1,
  207. "headRowHeight":[
  208. 40
  209. ],
  210. "defaultRowHeight": 21,
  211. "cols":[{
  212. "width":160,
  213. "readOnly": true,
  214. "head":{
  215. "titleNames":["项目编码"],
  216. "spanCols":[1],
  217. "spanRows":[1],
  218. "vAlign":[1],
  219. "hAlign":[1],
  220. "font":["Arial"]
  221. },
  222. "data":{
  223. "field":"code",
  224. "vAlign":1,
  225. "hAlign":0,
  226. "font":"Arial"
  227. }
  228. }, {
  229. "width":150,
  230. "readOnly": true,
  231. "head":{
  232. "titleNames":["项目名称"],
  233. "spanCols":[1],
  234. "spanRows":[1],
  235. "vAlign":[1],
  236. "hAlign":[1],
  237. "font":["Arial"]
  238. },
  239. "data":{
  240. "field":"name",
  241. "vAlign":1,
  242. "hAlign":0,
  243. "font":"Arial"
  244. }
  245. }, {
  246. "width":50,
  247. "readOnly": true,
  248. "head":{
  249. "titleNames":["计量单位"],
  250. "spanCols":[1],
  251. "spanRows":[1],
  252. "vAlign":[1],
  253. "hAlign":[1],
  254. "font":["Arial"],
  255. "wordWrap": true
  256. },
  257. "data":{
  258. "field":"unit",
  259. "vAlign":1,
  260. "hAlign":1,
  261. "font":"Arial"
  262. }
  263. }, {
  264. "width":100,
  265. "readOnly": true,
  266. "showHint": true,
  267. "head":{
  268. "titleNames":["工程量计算规则"],
  269. "spanCols":[1],
  270. "spanRows":[1],
  271. "vAlign":[1],
  272. "hAlign":[1],
  273. "font":["Arial"]
  274. },
  275. "data":{
  276. "field":"ruleText",
  277. "vAlign":1,
  278. "hAlign":0,
  279. "font":"Arial"
  280. }
  281. }]
  282. },
  283. jobsSetting: {
  284. "emptyRows":0,
  285. "headRows":1,
  286. "headRowHeight":[25],
  287. "defaultRowHeight": 21,
  288. "cols":[{
  289. "width":160,
  290. "readOnly":true,
  291. "head":{
  292. "titleNames":["工作内容"],
  293. "spanCols":[1],
  294. "spanRows":[1],
  295. "vAlign":[1],
  296. "hAlign":[1],
  297. "font":["Arial"]
  298. },
  299. "data":{
  300. "field":"content",
  301. "vAlign":0,
  302. "hAlign":3,
  303. "font":"Arial"
  304. }
  305. }]
  306. },
  307. featuresSetting: {
  308. "emptyRows":0,
  309. "headRows":1,
  310. "headRowHeight":[25],
  311. "defaultRowHeight": 21,
  312. "cols":[{
  313. "width":160,
  314. "readOnly":true,
  315. "head":{
  316. "titleNames":["项目特征"],
  317. "spanCols":[1],
  318. "spanRows":[1],
  319. "vAlign":[1],
  320. "hAlign":[1],
  321. "font":["Arial"]
  322. },
  323. "data":{
  324. "field":"content",
  325. "vAlign":0,
  326. "hAlign":3,
  327. "font":"Arial"
  328. }
  329. }]
  330. }
  331. };
  332. function addEventOnResize(fn){
  333. let originFn = window.onresize;
  334. window.onresize =function () {
  335. originFn && originFn();
  336. fn();
  337. }
  338. }
  339. addEventOnResize(billsLibObj.refreshSettingForHint);
  340. $('#stdBillsTab').bind('click', function () {
  341. refreshSubSpread();//subSpread、jobSpread、itemSpread显示问题
  342. $(".main-data-side-q").height($(window).height() - $(".header").height() - $(".toolsbar").height() - $(".tools-bar-height-q").height() - 202);
  343. var select = $('#stdBillsLibSelect');
  344. billsLibObj.refreshBillsSpread();
  345. billsLibObj.refreshBillsRelaSpread();
  346. billsLibObj.checkBillsSpread();
  347. if (select[0].options.length === 0) {
  348. billsLibObj.loadStdBillsLib();
  349. };
  350. });
  351. $('#stdBillsLibSelect').change(function () {
  352. $('#stdBillsSearchResult').hide();
  353. $(".main-data-side-q").height($(window).height() - $(".header").height() - $(".toolsbar").height() - $(".tools-bar-height-q").height() - 202);
  354. billsLibObj.clearHighLight(billsLibObj.stdBillsSpread);
  355. var select = $(this);
  356. if (this.children.length !== 0) {
  357. billsLibObj.loadStdBills(select.val());
  358. }
  359. });
  360. // 关闭搜索结果
  361. $('#closeSearchStdBills').click(function () {
  362. $('#stdBillsSearchResult').hide();
  363. $(".main-data-side-q").height($(window).height() - $(".header").height() - $(".toolsbar").height() - $(".tools-bar-height-q").height() - 202);
  364. billsLibObj.clearHighLight(billsLibObj.stdBillsSpread);
  365. });