index.ejs 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  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. <div>
  7. <div class="d-inline-block">
  8. <div class="btn-group" id="sort-dropdown">
  9. <button type="button" class="btn btn-sm btn-light text-primary dropdown-toggle" data-toggle="dropdown" id="bpaixu">排序:创建时间</button>
  10. <div class="dropdown-menu" aria-labelledby="bpaixu">
  11. <ul class="list-unstyled px-3 mb-0" id="sort-radio">
  12. <li class="mb-2">
  13. <div class="custom-control custom-radio">
  14. <input type="radio" class="custom-control-input" id="pai1" name="paizhi" value="time" checked="">
  15. <label class="custom-control-label" for="pai1">创建时间</label>
  16. </div>
  17. </li>
  18. <li class="mb-2">
  19. <div class="custom-control custom-radio">
  20. <input type="radio" class="custom-control-input" id="pai3" name="paizhi" value="code">
  21. <label class="custom-control-label" for="pai3">变更令号</label>
  22. </div>
  23. </li>
  24. </ul>
  25. <ul class="list-unstyled px-3 pt-2 mb-0 border-top" id="order-radio">
  26. <li class="mb-2">
  27. <div class="custom-control custom-radio">
  28. <input type="radio" class="custom-control-input" id="pdown" name="paixu" value="desc" checked="">
  29. <label class="custom-control-label" for="pdown">降序</label>
  30. </div>
  31. </li>
  32. <li class="mb-2">
  33. <div class="custom-control custom-radio">
  34. <input type="radio" class="custom-control-input" id="pup" name="paixu" value="asc">
  35. <label class="custom-control-label" for="pup">升序</label>
  36. </div>
  37. </li>
  38. </ul>
  39. </div>
  40. </div>
  41. </div>
  42. <div class="d-inline-block">
  43. <div class="btn-group">
  44. <button type="button" class="btn btn-sm btn-light text-primary dropdown-toggle" data-toggle="dropdown" id="zhankai" data-value="<%- status %>"><% if (status !== 0) { %><%- filter.statusString[status] %>(<%- filter.count[status] %>)<% } else { %>全部<% } %></button>
  45. <div class="dropdown-menu" aria-labelledby="zhankai" id="status_select">
  46. <% if (status !== 0) { %><a class="dropdown-item" data-val="0" href="javascript:void(0);">全部</a><% } %>
  47. <% for (const fs in filter.status) { %>
  48. <% const f = filter.status[fs]; %>
  49. <% if (f !== status) { %><a class="dropdown-item" data-val="<%- f %>" href="javascript:void(0);"><%- filter.statusString[f] %>(<%- filter.count[f] %>)</a><% } %>
  50. <% } %>
  51. </div>
  52. </div>
  53. </div>
  54. <% if (ctx.session.sessionProject.page_show.openChangeState) { %>
  55. <div class="d-inline-block">
  56. <div class="btn-group">
  57. <button type="button" class="btn btn-sm btn-light text-primary dropdown-toggle" data-toggle="dropdown" id="state_zhankai" data-value="<%- state %>">变更令状态:<% if (state !== 0) { %><%- ctx.helper._.find(changeState, { order: state }).name %>(<%- ctx.helper._.find(changeState, { order: state }).count %>)<% } else { %>全部<% } %></button>
  58. <div class="dropdown-menu" aria-labelledby="state_zhankai" id="state_select">
  59. <% if (state !== 0) { %><a class="dropdown-item" data-val="0" href="javascript:void(0);">全部</a><% } %>
  60. <% for (const cs of changeState) { %>
  61. <% if (cs.order !== state) { %><a class="dropdown-item" data-val="<%- cs.order %>" href="javascript:void(0);"><%- cs.name %>(<%- cs.count %>)</a><% } %>
  62. <% } %>
  63. </div>
  64. </div>
  65. </div>
  66. <% } %>
  67. <div class="d-inline-block">
  68. <span class="ml-3">本页小计:<%- page_total %>元</span><span class="ml-3">合计:<%- tp %>元</span>
  69. </div>
  70. </div>
  71. <div class="ml-auto">
  72. <% if (tender.user_id === ctx.session.sessionUser.accountId) { %>
  73. <a href="#add-bj" data-toggle="modal" data-target="#add-bj" class="btn btn-sm btn-primary pull-right ml-1">新建变更令</a>
  74. <a href="#setting" data-toggle="modal" data-target="#setting" class="btn btn-sm btn-outline-primary pull-right ml-2"><i class="fa fa-cog"></i></a>
  75. <a href="#batch-sb" data-toggle="modal" data-target="#batch-sb" class="btn btn-sm btn-primary pull-right ml-2">批量上报</a>
  76. <% } %>
  77. <a href="#batch-sp" data-toggle="modal" data-target="#batch-sp" class="btn btn-sm btn-success pull-right">批量审批</a>
  78. </div>
  79. </div>
  80. </div>
  81. <div class="content-wrap">
  82. <div class="c-body">
  83. <input id="tenderName" value="<%= tender.name %>" type="hidden">
  84. <input id="dealCode" value="<%= dealCode %>" type="hidden">
  85. <input id="tenderId" value="<%= tender.id %>" type="hidden">
  86. <div class="sjs-height-0">
  87. <table class="table table-bordered" id="change-table">
  88. <thead class="text-center">
  89. <tr><th width="3%">序号</th>
  90. <th width="18%" id="sort_change">申请编号/变更令号</th><th width="24%">变更工程名称</th>
  91. <th width="7%">变更性质</th><% if (ctx.session.sessionProject.page_show.openChangeState) { %><th width="7%">变更令状态</th><% } %>
  92. <th width="7%">变更金额</th><th width="7%">计价金额</th>
  93. <th width="7%">不计价金额</th><th width="7%">审批状态</th>
  94. <th width="14%">审批进度</th><th width="4%">操作</th>
  95. </tr>
  96. </thead>
  97. <tbody id="changeList">
  98. <% const qualityArray = []; %>
  99. <% for (const t in changeConst.quality) { %>
  100. <% const cQuality = changeConst.quality[t] %>
  101. <% qualityArray[cQuality.value] = cQuality.name %>
  102. <% } %>
  103. <% if (changes.length > 0) { %>
  104. <% for (const [index, c] of changes.entries()) { %>
  105. <tr>
  106. <td class="text-center"><%- (pageInfo.page-1)*pageInfo.pageSize + index+1 %></td>
  107. <td><a href="/tender/<%- tender.id %>/change/<%- c.cid %>/information"><% if (c.status !== auditConst.status.checked) { %><%- c.code %><% } else { %><%- c.p_code %><% } %></a></td>
  108. <td><%- c.name %></td>
  109. <td><%- qualityArray[c.quality] %><% c.quality %></td>
  110. <% if (ctx.session.sessionProject.page_show.openChangeState) { %>
  111. <td><%- ctx.helper._.find(changeState, { order: c.state }).name %></td>
  112. <% } %>
  113. <td style="text-align: right"><%= ctx.helper.roundNum(c.total_price, tpUnit) %></td>
  114. <td style="text-align: right"><%= ctx.helper.roundNum(c.valuation_tp, tpUnit) %></td>
  115. <td style="text-align: right"><%= ctx.helper.roundNum(c.unvaluation_tp, tpUnit) %></td>
  116. <td class="text-center">
  117. <% if (c.status === auditConst.status.uncheck && c.uid === ctx.session.sessionUser.accountId) { %>
  118. <a href="<%- '/tender/' + ctx.tender.id + '/change/' + c.cid %>/information" class="btn <%- auditConst.statusButtonClass[c.status] %> btn-sm"><%- auditConst.statusButton[c.status] %></a>
  119. <% } else if ((c.status === auditConst.status.checkNo || c.status === auditConst.status.revise) && c.curAuditors && c.uid === ctx.session.sessionUser.accountId) { %>
  120. <a href="<%- '/tender/' + ctx.tender.id + '/change/' + c.cid %>/information" class="btn <%- auditConst.statusButtonClass[c.status] %> btn-sm"><%- auditConst.statusButton[c.status] %></a>
  121. <% } else if (c.status === auditConst.status.checking && c.curAuditors && c.curAuditors.findIndex(x => { return x.uid === ctx.session.sessionUser.accountId; }) >= 0) { %>
  122. <% const curAudit = c.curAuditors.find(x => { return x.uid === ctx.session.sessionUser.accountId; }); %>
  123. <% if (curAudit.status === auditConst.status.checking) { %>
  124. <a href="<%- '/tender/' + ctx.tender.id + '/change/' + c.cid %>/information" class="btn <%- auditConst.statusButtonClass[c.status] %> btn-sm"><%- auditConst.statusButton[c.status] %></a>
  125. <% } else { %>
  126. <span class="<%- auditConst.auditStringClass[curAudit.status] %>"><%- auditConst.auditString[curAudit.status] %></span>
  127. <% } %>
  128. <% } else if (c.status === auditConst.status.checkNoPre && c.curAuditor2 && c.curAuditor2.findIndex(x => { return x.uid === ctx.session.sessionUser.accountId; }) >= 0) { %>
  129. <% const curAudit = c.curAuditors2.find(x => { return x.uid === ctx.session.sessionUser.accountId; }); %>
  130. <% if (curAudit.status === auditConst.status.checking) { %>
  131. <a href="<%- '/tender/' + ctx.tender.id + '/change/' + c.cid %>/information" class="btn <%- auditConst.statusButtonClass[c.status] %> btn-sm"><%- auditConst.statusButton[c.status] %></a>
  132. <% } else { %>
  133. <span class="<%- auditConst.auditStringClass[curAudit.status] %>"><%- auditConst.auditString[curAudit.status] %></span>
  134. <% } %>
  135. <% } else { %>
  136. <span class="<%- auditConst.auditStringClass[c.status] %>"><%- auditConst.auditString[c.status] %></span>
  137. <% } %>
  138. </td>
  139. <td class="<%- auditConst.auditProgressClass[c.status] %>">
  140. <% if (c.status === auditConst.status.checked && c.final_auditor_str) { %>
  141. <a href="#sp-list" data-toggle="modal" data-target="#sp-list" c-id="<%- c.cid %>"><%- c.final_auditor_str %></a>
  142. <% } else if (c.curAuditors.length > 0) { %>
  143. <% if (c.curAuditors[0].audit_type === auditType.key.common) { %>
  144. <a href="#sp-list" data-toggle="modal" data-target="#sp-list" c-id="<%- c.cid %>"><%- c.curAuditors[0].name %><%if (c.curAuditors[0].role !== '' && c.curAuditors[0].role !== null) { %>-<%- c.curAuditors[0].role %><% } %></a>
  145. <% } else { %>
  146. <a href="#sp-list" data-toggle="modal" data-target="#sp-list" c-id="<%- c.cid %>"><%- ctx.helper.transFormToChinese(c.curAuditors[0].audit_order) + '审' %></a>
  147. <% } %>
  148. <% } %>
  149. <%- auditConst.auditProgress[c.status] %>
  150. </td>
  151. <td class="text-center"><% if (c.uid === ctx.session.sessionUser.accountId && (c.status === auditConst.status.uncheck || ((c.status === auditConst.status.checkNo || c.status === auditConst.status.revise) && c.stageChangeNum === 0 && !c.isSettle))) { %><a href="#del-bg" cid="<%= c.cid %>" data-toggle="modal" data-target="#del-bg" class="btn btn-outline-danger btn-sm delete-cid-modal">删除</a><% } %></td>
  152. </tr>
  153. <% } %>
  154. <% } %>
  155. </tbody>
  156. </table>
  157. <!--翻页-->
  158. <% include ../layout/page.ejs %>
  159. </div>
  160. </div>
  161. </div>
  162. </div>
  163. <script src="/public/js/sub_menu.js"></script>
  164. <script src="/public/js/colResizable/colResizable-1.6.min.js"></script>
  165. <script>
  166. $.subMenu({
  167. menu: '#sub-menu', miniMenu: '#sub-mini-menu', miniMenuList: '#mini-menu-list',
  168. toMenu: '#to-menu', toMiniMenu: '#to-mini-menu',
  169. key: 'menu.1.0.0',
  170. miniHint: '#sub-mini-hint', hintKey: 'menu.hint.1.0.1',
  171. callback: function (info) {
  172. if (info.mini) {
  173. $('.panel-title').addClass('fluid');
  174. $('#sub-menu').removeClass('panel-sidebar');
  175. } else {
  176. $('.panel-title').removeClass('fluid');
  177. $('#sub-menu').addClass('panel-sidebar');
  178. }
  179. autoFlashHeight();
  180. }
  181. });
  182. const openChangePlan = parseInt('<%- ctx.session.sessionProject.page_show.openChangePlan %>');
  183. const changePlanList = JSON.parse(unescape('<%- escape(JSON.stringify(changePlanList)) %>'));
  184. </script>
  185. <script src="/public/js/change.js"></script>