list.ejs 7.8 KB

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