ledger_audit.js 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124
  1. 'use strict';
  2. /**
  3. *
  4. *
  5. * @author Mai
  6. * @date 2018/5/30
  7. * @version
  8. */
  9. function getTenderId() {
  10. return window.location.pathname.split('/')[2];
  11. }
  12. function checkTzMeasureType () {
  13. return tender.measure_type === measureType.tz.value;
  14. }
  15. $(document).ready(() => {
  16. autoFlashHeight();
  17. const ledgerSpread = SpreadJsObj.createNewSpread($('#ledger-spread')[0]);
  18. const ledgerTree = createNewPathTree('active', {
  19. id: 'ledger_id',
  20. pid: 'ledger_pid',
  21. order: 'order',
  22. level: 'level',
  23. rootId: -1,
  24. keys: ['id', 'tender_id', 'ledger_id'],
  25. preUrl: '/ledger'
  26. });
  27. ledgerTree.loadDatas(ledger);
  28. SpreadJsObj.initSheet(ledgerSpread.getActiveSheet(), ledgerSpreadSetting);
  29. SpreadJsObj.loadSheetData(ledgerSpread.getActiveSheet(), 'tree', ledgerTree);
  30. // 初始化 部位明细
  31. const pos = new PosData({
  32. id: 'id', masterId: 'lid',
  33. });
  34. const posSpread = SpreadJsObj.createNewSpread($('#pos-spread')[0]);
  35. // 台账模式加载部位明细数据
  36. if (checkTzMeasureType()) {
  37. SpreadJsObj.initSheet(posSpread.getActiveSheet(), posSpreadSetting);
  38. postData('/api/tender/' + getTenderId() + '/pos', null, function (data) {
  39. pos.loadDatas(data);
  40. });
  41. }
  42. ledgerSpread.bind(GC.Spread.Sheets.Events.SelectionChanged, function (e, info) {
  43. const sheet = ledgerSpread.getActiveSheet();
  44. let node;
  45. if (!sheet || !sheet.zh_tree) {
  46. node = null;
  47. } else {
  48. const sel = sheet.getSelections()[0];
  49. node = sheet.zh_tree.nodes[sel.row];
  50. }
  51. if (node) {
  52. const posData = pos.masterRange[itemsPre + node.id] || [];
  53. SpreadJsObj.loadSheetData(posSpread.getActiveSheet(), 'data', posData);
  54. } else {
  55. SpreadJsObj.loadSheetData(posSpread.getActiveSheet(), 'data', []);
  56. }
  57. });
  58. let dealBills;
  59. // 展开收起 签约清单|清单意见
  60. $('a', '.side-menu').bind('click', function () {
  61. const tab = $(this), tabPanel = $(tab.attr('content'));
  62. const showSideTools = function (show) {
  63. if (show) {
  64. $('.c-body.col-12').removeClass('col-12').addClass('col-8');
  65. $('.c-body.col-0').removeClass('col-0').addClass('col-4').show();
  66. } else {
  67. $('.c-body.col-8').removeClass('col-8').addClass('col-12');
  68. $('.c-body.col-4').removeClass('col-4').addClass('col-0').hide();
  69. }
  70. };
  71. if (!tab.hasClass('active')) {
  72. $('a', '#side-menu').removeClass('active');
  73. tab.addClass('active');
  74. showSideTools(tab.hasClass('active'));
  75. $('.tab-content .tab-pane').hide();
  76. tabPanel.show();
  77. if (tab.attr('content') === '#deal-bills' && !dealBills) {
  78. dealBills = new DealBills($('#deal-bills-spread')[0], {
  79. cols: [
  80. {title: '清单编号', field: 'code', width: 120, formatter: '@', readOnly: true},
  81. {title: '名称', field: 'name', width: 230, formatter: '@', readOnly: true},
  82. {title: '单位', field: 'unit', width: 50, formatter: '@', readOnly: true},
  83. {title: '单价', field: 'unit_price', width: 50, readOnly: true},
  84. {title: '数量', field: 'quantity', width: 50, readOnly: true},
  85. ],
  86. emptyRows: 0,
  87. headRows: 1,
  88. headRowHeight: [40],
  89. defaultRowHeight: 21,
  90. });
  91. dealBills.loadData();
  92. }
  93. } else {
  94. tab.removeClass('active');
  95. showSideTools(tab.hasClass('active'));
  96. tabPanel.hide();
  97. }
  98. ledgerSpread.refresh();
  99. });
  100. class DealBills {
  101. constructor (obj, spreadSetting) {
  102. this.obj = obj;
  103. this.url = '/api/tender/' + getTenderId() + '/deal';
  104. this.spreadSetting = spreadSetting;
  105. this.spread = SpreadJsObj.createNewSpread(this.obj);
  106. SpreadJsObj.initSheet(this.spread.getActiveSheet(), this.spreadSetting);
  107. }
  108. loadData () {
  109. const self = this;
  110. postData(this.url+'/get-data', {}, function (data) {
  111. SpreadJsObj.loadSheetData(self.spread.getActiveSheet(), 'data', data);
  112. });
  113. }
  114. }
  115. });