stage.ejs 7.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114
  1. <% include ../tender/tender_sub_menu.ejs %>
  2. <div class="panel-content">
  3. <div class="panel-title">
  4. <div class="title-main d-flex">
  5. <% include ../tender/tender_sub_mini_menu.ejs %>
  6. <h2>
  7. 期列表
  8. </h2>
  9. <div class="ml-auto">
  10. <% if (ctx.session.sessionUser.accountId === ctx.tender.data.user_id && ctx.tender.data.ledger_status === auditConst.status.checked &&
  11. (stages.length === 0 || stages[0].status === auditConst.status.checked)) { %>
  12. <% if (ctx.helper.checkZero(ctx.tender.info.deal_param.contractPrice) && stages.length === 0) { %>
  13. <a href="#add-qi" data-toggle="modal" data-target="#tips" class="btn btn-primary btn-sm">开始新一期</a>
  14. <% } else { %>
  15. <a href="#add-qi" data-toggle="modal" data-target="#add-qi" class="btn btn-primary btn-sm">开始新一期</a>
  16. <% } %>
  17. <% } %>
  18. </div>
  19. </div>
  20. </div>
  21. <div class="content-wrap">
  22. <div class="c-body">
  23. <div class="sjs-height-0">
  24. <table class="table table-bordered">
  25. <thead>
  26. <tr>
  27. <th class="text-center" width="80px">计量期数</th>
  28. <th class="text-center" width="70px">计量月份</th>
  29. <th class="text-center" width="110px">本期合同计量</th>
  30. <th class="text-center" width="110px">本期数量变更计量</th>
  31. <th class="text-center" width="110px">本期完成计量</th>
  32. <th class="text-center" width="110px">截止上期完成计量</th>
  33. <th class="text-center" width="110px">截止本期完成计量</th>
  34. <th class="text-center" width="110px">本期应付</th>
  35. <th class="text-center" width="110px">本期实付</th>
  36. <th class="text-center" width="200px">审批进度</th>
  37. <th class="text-center" width="90px">操作</th>
  38. </tr>
  39. </thead>
  40. <tbody>
  41. <% for (const [i,s] of stages.entries()) { %>
  42. <tr>
  43. <td>
  44. <a href="<%- '/tender/' + ctx.tender.id + '/measure/stage/' + s.order %>" target="_blank">第 <%- s.order %> 期</a>
  45. <% if ((i === 0 || (stages[i-1] && stages[i-1].status !== auditConst.status.checked)) && s.user_id === ctx.session.sessionUser.accountId) { %>
  46. <a href="#edit" class="edit-stage" data-index="<%- i %>" data-toggle="modal" data-target="#edit"><i class="fa fa-pencil-square-o "></i></a>
  47. <% } %>
  48. </td>
  49. <td class="text-center"><%- s.s_time %></td>
  50. <!--<td class="text-center"><%- s.period %></td>-->
  51. <% if (ctx.tender.info.display.thousandth) { %>
  52. <td class="text-right"><%- (s.contract_tp ? ctx.helper.formatNum(s.contract_tp, '#,##0.######') : '')%></td>
  53. <td class="text-right"><%- (s.qc_tp ? ctx.helper.formatNum(s.qc_tp, '#,##0.######') : '')%></td>
  54. <td class="text-right"><%- (s.tp ? ctx.helper.formatNum(s.tp, '#,##0.######') : '')%></td>
  55. <td class="text-right"><%- (s.pre_tp ? ctx.helper.formatNum(s.pre_tp, '#,##0.######') : '')%></td>
  56. <td class="text-right"><%- (s.end_tp ? ctx.helper.formatNum(s.end_tp, '#,##0.######') : '')%></td>
  57. <td class="text-right"><%- (s.yf_tp ? ctx.helper.formatNum(s.yf_tp, '#,##0.######') : '') %></td>
  58. <td class="text-right"><%- (s.sf_tp ? ctx.helper.formatNum(s.sf_tp, '#,##0.######') : '') %></td>
  59. <% } else { %>
  60. <td class="text-right"><%- (s.contract_tp ? s.contract_tp : '')%></td>
  61. <td class="text-right"><%- (s.qc_tp ? s.qc_tp : '')%></td>
  62. <td class="text-right"><%- (s.tp ? s.tp : '')%></td>
  63. <td class="text-right"><%- (s.pre_tp ? s.pre_tp : '')%></td>
  64. <td class="text-right"><%- (s.end_tp ? s.end_tp : '')%></td>
  65. <td class="text-right"><%- (s.yf_tp ? s.yf_tp : '') %></td>
  66. <td class="text-right"><%- (s.sf_tp ? s.sf_tp : '') %></td>
  67. <% } %>
  68. <td class="<%- auditConst.auditProgressClass[s.status] %>">
  69. <% if (s.curAuditor) { %>
  70. <a href="#sp-list" data-toggle="modal" data-target="#sp-list" s-order="<%- s.order %>"><%- s.curAuditor.name %><%if (s.curAuditor.role !== '' && s.curAuditor.role !== null) { %>-<%- s.curAuditor.role %><% } %></a>
  71. <% } %>
  72. <%- auditConst.auditProgress[s.status] %>
  73. </td>
  74. <td class="text-center">
  75. <% if (s.status === auditConst.status.uncheck && s.user_id === ctx.session.sessionUser.accountId) { %>
  76. <a href="<%- '/tender/' + ctx.tender.id + '/measure/stage/' + s.order %>" target="_blank" class="btn <%- auditConst.statusButtonClass[s.status] %> btn-sm"><%- auditConst.statusButton[s.status] %></a>
  77. <% } else if (s.status === auditConst.status.checkNo && s.curAuditor && s.user_id === ctx.session.sessionUser.accountId) { %>
  78. <a href="<%- '/tender/' + ctx.tender.id + '/measure/stage/' + s.order %>" target="_blank" class="btn <%- auditConst.statusButtonClass[s.status] %> btn-sm"><%- auditConst.statusButton[s.status] %></a>
  79. <% } else if (s.status === auditConst.status.checking && s.curAuditor && s.curAuditor.aid === ctx.session.sessionUser.accountId) { %>
  80. <a href="<%- '/tender/' + ctx.tender.id + '/measure/stage/' + s.order %>" target="_blank" class="btn <%- auditConst.statusButtonClass[s.status] %> btn-sm"><%- auditConst.statusButton[s.status] %></a>
  81. <% } else if (s.status === auditConst.status.checkNoPre && s.curAuditor && s.curAuditor2.aid === ctx.session.sessionUser.accountId) { %>
  82. <a href="<%- '/tender/' + ctx.tender.id + '/measure/stage/' + s.order %>" target="_blank" class="btn <%- auditConst.statusButtonClass[s.status] %> btn-sm"><%- auditConst.statusButton[s.status] %></a>
  83. <% } else { %>
  84. <span class="<%- auditConst.auditStringClass[s.status] %>"><%- auditConst.auditString[s.status] %></span>
  85. <% } %>
  86. </td>
  87. </tr>
  88. <% } %>
  89. </tbody>
  90. </table>
  91. </div>
  92. </div>
  93. </div>
  94. </div>
  95. <script src="/public/js/sub_menu.js"></script>
  96. <script>
  97. const stages = JSON.parse('<%- JSON.stringify(stages) %>');
  98. $.subMenu({
  99. menu: '#sub-menu', miniMenu: '#sub-mini-menu', miniMenuList: '#mini-menu-list',
  100. toMenu: '#to-menu', toMiniMenu: '#to-mini-menu',
  101. key: 'menu.1.0.0',
  102. miniHint: '#sub-mini-hint', hintKey: 'menu.hint.1.0.1',
  103. callback: function (info) {
  104. if (info.mini) {
  105. $('.panel-title').addClass('fluid');
  106. $('#sub-menu').removeClass('panel-sidebar');
  107. } else {
  108. $('.panel-title').removeClass('fluid');
  109. $('#sub-menu').addClass('panel-sidebar');
  110. }
  111. autoFlashHeight();
  112. }
  113. });
  114. </script>