index.ejs 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  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 || addPermission) { %>
  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. <% if (need_checking) { %>
  78. <a href="#batch-sp" data-toggle="modal" data-target="#batch-sp" class="btn btn-sm btn-success pull-right">批量审批</a>
  79. <% } %>
  80. </div>
  81. </div>
  82. </div>
  83. <div class="content-wrap">
  84. <div class="c-body">
  85. <input id="tenderName" value="<%= tender.name %>" type="hidden">
  86. <input id="dealCode" value="<%= dealCode %>" type="hidden">
  87. <input id="tenderId" value="<%= tender.id %>" type="hidden">
  88. <div class="sjs-height-0">
  89. <table class="table table-bordered" id="change-table">
  90. <thead class="text-center">
  91. <tr><th width="3%">序号</th>
  92. <th width="16%" id="sort_change">申请编号/变更令号</th><th width="22%">变更工程名称</th>
  93. <th width="7%">变更性质</th><% if (ctx.session.sessionProject.page_show.openChangeState) { %><th width="7%">变更令状态</th><% } %>
  94. <th width="7%">变更金额</th><th width="7%">计价金额</th>
  95. <th width="7%">不计价金额</th><th width="6%">创建人</th><th width="7%">审批状态</th>
  96. <th width="12%">审批进度</th><th width="4%">操作</th>
  97. </tr>
  98. </thead>
  99. <tbody id="changeList">
  100. <% const qualityArray = []; %>
  101. <% for (const t in changeConst.quality) { %>
  102. <% const cQuality = changeConst.quality[t] %>
  103. <% qualityArray[cQuality.value] = cQuality.name %>
  104. <% } %>
  105. <% if (changes.length > 0) { %>
  106. <% for (const [index, c] of changes.entries()) { %>
  107. <tr>
  108. <td class="text-center"><%- (pageInfo.page-1)*pageInfo.pageSize + index+1 %></td>
  109. <td><a href="/tender/<%- tender.id %>/change/<%- c.cid %>/information"><% if (c.status !== auditConst.status.checked) { %><%- c.code %><% } else { %><%- c.p_code %><% } %></a></td>
  110. <td><%- c.name %></td>
  111. <td><%- qualityArray[c.quality] %><% c.quality %></td>
  112. <% if (ctx.session.sessionProject.page_show.openChangeState) { %>
  113. <td><%- ctx.helper._.find(changeState, { order: c.state }).name %></td>
  114. <% } %>
  115. <td style="text-align: right"><%= ctx.helper.roundNum(c.total_price, tpUnit) %></td>
  116. <td style="text-align: right"><%= ctx.helper.roundNum(c.valuation_tp, tpUnit) %></td>
  117. <td style="text-align: right"><%= ctx.helper.roundNum(c.unvaluation_tp, tpUnit) %></td>
  118. <td style="text-align: center"><%- c.username %></td>
  119. <td class="text-center">
  120. <% if (c.status === auditConst.status.uncheck && c.uid === ctx.session.sessionUser.accountId) { %>
  121. <a href="<%- '/tender/' + ctx.tender.id + '/change/' + c.cid %>/information" class="btn <%- auditConst.statusButtonClass[c.status] %> btn-sm"><%- auditConst.statusButton[c.status] %></a>
  122. <% } else if ((c.status === auditConst.status.checkNo || c.status === auditConst.status.revise) && c.curAuditors && c.uid === ctx.session.sessionUser.accountId) { %>
  123. <a href="<%- '/tender/' + ctx.tender.id + '/change/' + c.cid %>/information" class="btn <%- auditConst.statusButtonClass[c.status] %> btn-sm"><%- auditConst.statusButton[c.status] %></a>
  124. <% } else if (c.status === auditConst.status.checking && c.curAuditors && c.curAuditors.findIndex(x => { return x.uid === ctx.session.sessionUser.accountId; }) >= 0) { %>
  125. <% const curAudit = c.curAuditors.find(x => { return x.uid === ctx.session.sessionUser.accountId; }); %>
  126. <% if (curAudit.status === auditConst.status.checking) { %>
  127. <a href="<%- '/tender/' + ctx.tender.id + '/change/' + c.cid %>/information" class="btn <%- auditConst.statusButtonClass[c.status] %> btn-sm"><%- auditConst.statusButton[c.status] %></a>
  128. <% } else { %>
  129. <span class="<%- auditConst.auditStringClass[c.status] %>"><%- auditConst.auditString[c.status] %></span>
  130. <% } %>
  131. <% } else if (c.status === auditConst.status.checkNoPre && c.curAuditor2 && c.curAuditor2.findIndex(x => { return x.uid === ctx.session.sessionUser.accountId; }) >= 0) { %>
  132. <% const curAudit = c.curAuditors2.find(x => { return x.uid === ctx.session.sessionUser.accountId; }); %>
  133. <% if (curAudit.status === auditConst.status.checking) { %>
  134. <a href="<%- '/tender/' + ctx.tender.id + '/change/' + c.cid %>/information" class="btn <%- auditConst.statusButtonClass[c.status] %> btn-sm"><%- auditConst.statusButton[c.status] %></a>
  135. <% } else { %>
  136. <span class="<%- auditConst.auditStringClass[curAudit.status] %>"><%- auditConst.auditString[curAudit.status] %></span>
  137. <% } %>
  138. <% } else { %>
  139. <span class="<%- auditConst.auditStringClass[c.status] %>"><%- auditConst.auditString[c.status] %></span>
  140. <% } %>
  141. </td>
  142. <td class="<%- auditConst.auditProgressClass[c.status] %>">
  143. <% if (c.status === auditConst.status.checked && c.final_auditor_str) { %>
  144. <a href="#sp-list" data-toggle="modal" data-target="#sp-list" c-id="<%- c.cid %>"><%- c.final_auditor_str %></a>
  145. <% } else if (c.curAuditors.length > 0) { %>
  146. <% if (c.curAuditors[0].audit_type === auditType.key.common) { %>
  147. <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>
  148. <% } else { %>
  149. <a href="#sp-list" data-toggle="modal" data-target="#sp-list" c-id="<%- c.cid %>"><%- ctx.helper.transFormToChinese(c.curAuditors[0].audit_order) + '审' %></a>
  150. <% } %>
  151. <% } %>
  152. <%- auditConst.auditProgress[c.status] %>
  153. </td>
  154. <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>
  155. </tr>
  156. <% } %>
  157. <% } %>
  158. </tbody>
  159. </table>
  160. <!--翻页-->
  161. <% include ../layout/page.ejs %>
  162. </div>
  163. </div>
  164. </div>
  165. </div>
  166. <script src="/public/js/sub_menu.js"></script>
  167. <script src="/public/js/colResizable/colResizable-1.6.min.js"></script>
  168. <link href="/public/css/bootstrap/select2.min.css" rel="stylesheet" />
  169. <link rel="stylesheet" href="/public/css/bootstrap/select2-bootstrap4.min.css">
  170. <script src="/public/js/bootstrap/select2.min.js"></script>
  171. <script>
  172. $.subMenu({
  173. menu: '#sub-menu', miniMenu: '#sub-mini-menu', miniMenuList: '#mini-menu-list',
  174. toMenu: '#to-menu', toMiniMenu: '#to-mini-menu',
  175. key: 'menu.1.0.0',
  176. miniHint: '#sub-mini-hint', hintKey: 'menu.hint.1.0.1',
  177. callback: function (info) {
  178. if (info.mini) {
  179. $('.panel-title').addClass('fluid');
  180. $('#sub-menu').removeClass('panel-sidebar');
  181. } else {
  182. $('.panel-title').removeClass('fluid');
  183. $('#sub-menu').addClass('panel-sidebar');
  184. }
  185. autoFlashHeight();
  186. }
  187. });
  188. const openChangePlan = parseInt('<%- ctx.session.sessionProject.page_show.openChangePlan %>');
  189. const changePlanList = JSON.parse(unescape('<%- escape(JSON.stringify(changePlanList)) %>'));
  190. </script>
  191. <script src="/public/js/change.js"></script>