std_bills_lib.js 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364
  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 - 1; 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. if (stdBillsTree.items[args.row].children.length === 0) {
  144. //特征及内容转化
  145. pageCCOprObj.setItemContentNode(stdBillsTree.items[args.row], getBillsJobs(stdBillsTree.items[args.row]), getBillsFeatures(stdBillsTree.items[args.row]));
  146. ProjectController.addBills(projectObj.project, projectObj.mainController, stdBillsTree.items[args.row]);
  147. }
  148. });
  149. }, function () {
  150. that.stdBillsSpread.unbind(GC.Spread.Sheets.Events.CellDoubleClick);
  151. });
  152. $('#stdBillsSearch>span>button').click(function () {
  153. var keyword = $('#stdBillsSearch>input').val();
  154. if (!keyword || keyword === '') {return}
  155. var result = stdBillsTree.items.filter(function (item) {
  156. var codeIs = item.data.code ? item.data.code.indexOf(keyword) !== -1 : false;
  157. var nameIs = item.data.name ? item.data.name.indexOf(keyword) !== -1 : false;
  158. return codeIs || nameIs;
  159. });
  160. result.sort(function (x, y) {
  161. return x.serialNo() - y.serialNo();
  162. });
  163. if (result.length !== 0) {
  164. var sel = billsLibObj.stdBillsSpread.getActiveSheet().getSelections();
  165. stdBillsTreeController.setTreeSelected(result[0]);
  166. billsLibObj.stdBillsSpread.getActiveSheet().setSelection(result[0].serialNo(), sel[0].col, 1, 1);
  167. for (let node of result) {
  168. billsLibObj.stdBillsSpread.getActiveSheet().getRange(node.serialNo(), -1, 1, -1).backColor('lemonChiffon');
  169. }
  170. $('#nextStdBills').show();
  171. $('#nextStdBills').click(function () {
  172. var cur = stdBillsTree.selected, resultIndex = result.indexOf(cur), sel = billsLibObj.stdBillsSpread.getActiveSheet().getSelections();
  173. if (resultIndex === result.length - 1) {
  174. stdBillsTreeController.setTreeSelected(result[0]);
  175. billsLibObj.stdBillsSpread.getActiveSheet().setSelection(result[0].serialNo(), sel[0].col, 1, 1);
  176. } else {
  177. stdBillsTreeController.setTreeSelected(result[resultIndex + 1]);
  178. billsLibObj.stdBillsSpread.getActiveSheet().setSelection(result[resultIndex + 1].serialNo(), sel[0].col, 1, 1);
  179. }
  180. });
  181. } else {
  182. billsLibObj.clearHighLight(billsLibObj.stdBillsSpread);
  183. $('#nextStdBills').hide();
  184. }
  185. $('#stdBillsSearchResultCount').text('搜索结果:' + result.length);
  186. $('#stdBillsSearchResult').show();
  187. });
  188. },
  189. stdBillsTreeSetting: {
  190. "treeCol": 0,
  191. "emptyRows":0,
  192. "headRows":1,
  193. "headRowHeight":[
  194. 40
  195. ],
  196. "defaultRowHeight": 21,
  197. "cols":[{
  198. "width":150,
  199. "readOnly": true,
  200. "head":{
  201. "titleNames":["项目编码"],
  202. "spanCols":[1],
  203. "spanRows":[1],
  204. "vAlign":[1],
  205. "hAlign":[1],
  206. "font":["Arial"]
  207. },
  208. "data":{
  209. "field":"code",
  210. "vAlign":1,
  211. "hAlign":0,
  212. "font":"Arial"
  213. }
  214. }, {
  215. "width":120,
  216. "readOnly": true,
  217. "head":{
  218. "titleNames":["项目名称"],
  219. "spanCols":[1],
  220. "spanRows":[1],
  221. "vAlign":[1],
  222. "hAlign":[1],
  223. "font":["Arial"]
  224. },
  225. "data":{
  226. "field":"name",
  227. "vAlign":1,
  228. "hAlign":0,
  229. "font":"Arial"
  230. }
  231. }, {
  232. "width":40,
  233. "readOnly": true,
  234. "head":{
  235. "titleNames":["计量单位"],
  236. "spanCols":[1],
  237. "spanRows":[1],
  238. "vAlign":[1],
  239. "hAlign":[1],
  240. "font":["Arial"],
  241. "wordWrap": true
  242. },
  243. "data":{
  244. "field":"unit",
  245. "vAlign":1,
  246. "hAlign":1,
  247. "font":"Arial"
  248. }
  249. }, {
  250. "width":100,
  251. "readOnly": true,
  252. "showHint": true,
  253. "head":{
  254. "titleNames":["工程量计算规则"],
  255. "spanCols":[1],
  256. "spanRows":[1],
  257. "vAlign":[1],
  258. "hAlign":[1],
  259. "font":["Arial"]
  260. },
  261. "data":{
  262. "field":"ruleText",
  263. "vAlign":1,
  264. "hAlign":0,
  265. "font":"Arial"
  266. }
  267. }]
  268. },
  269. jobsSetting: {
  270. "emptyRows":0,
  271. "headRows":1,
  272. "headRowHeight":[25],
  273. "defaultRowHeight": 21,
  274. "cols":[{
  275. "width":200,
  276. "readOnly":true,
  277. "head":{
  278. "titleNames":["工作内容"],
  279. "spanCols":[1],
  280. "spanRows":[1],
  281. "vAlign":[1],
  282. "hAlign":[1],
  283. "font":["Arial"]
  284. },
  285. "data":{
  286. "field":"content",
  287. "vAlign":0,
  288. "hAlign":3,
  289. "font":"Arial"
  290. }
  291. }]
  292. },
  293. featuresSetting: {
  294. "emptyRows":0,
  295. "headRows":1,
  296. "headRowHeight":[25],
  297. "defaultRowHeight": 21,
  298. "cols":[{
  299. "width":200,
  300. "readOnly":true,
  301. "head":{
  302. "titleNames":["项目特征"],
  303. "spanCols":[1],
  304. "spanRows":[1],
  305. "vAlign":[1],
  306. "hAlign":[1],
  307. "font":["Arial"]
  308. },
  309. "data":{
  310. "field":"content",
  311. "vAlign":0,
  312. "hAlign":3,
  313. "font":"Arial"
  314. }
  315. }]
  316. }
  317. };
  318. function addEventOnResize(fn){
  319. let originFn = window.onresize;
  320. window.onresize =function () {
  321. originFn && originFn();
  322. fn();
  323. }
  324. }
  325. addEventOnResize(billsLibObj.refreshSettingForHint);
  326. $('#stdBillsTab').bind('click', function () {
  327. refreshSubSpread();//subSpread、jobSpread、itemSpread显示问题
  328. $(".main-data-side-q").height($(window).height() - $(".header").height() - $(".toolsbar").height() - $(".tools-bar-height-q").height() - 202);
  329. var select = $('#stdBillsLibSelect');
  330. billsLibObj.refreshBillsSpread();
  331. billsLibObj.refreshBillsRelaSpread();
  332. billsLibObj.checkBillsSpread();
  333. if (select[0].options.length === 0) {
  334. billsLibObj.loadStdBillsLib();
  335. };
  336. });
  337. $('#stdBillsLibSelect').change(function () {
  338. $('#stdBillsSearchResult').hide();
  339. $(".main-data-side-q").height($(window).height() - $(".header").height() - $(".toolsbar").height() - $(".tools-bar-height-q").height() - 202);
  340. billsLibObj.clearHighLight(billsLibObj.stdBillsSpread);
  341. var select = $(this);
  342. if (this.children.length !== 0) {
  343. billsLibObj.loadStdBills(select.val());
  344. }
  345. });
  346. // 关闭搜索结果
  347. $('#closeSearchStdBills').click(function () {
  348. $('#stdBillsSearchResult').hide();
  349. $(".main-data-side-q").height($(window).height() - $(".header").height() - $(".toolsbar").height() - $(".tools-bar-height-q").height() - 202);
  350. billsLibObj.clearHighLight(billsLibObj.stdBillsSpread);
  351. });