index.ejs 11 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181
  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. <% if (tender.user_id === uid) { %>
  72. <div class="ml-auto">
  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-1"><i class="fa fa-cog"></i></a>
  75. </div>
  76. <% } %>
  77. </div>
  78. </div>
  79. <div class="content-wrap">
  80. <div class="c-body">
  81. <input id="tenderName" value="<%= tender.name %>" type="hidden">
  82. <input id="dealCode" value="<%= dealCode %>" type="hidden">
  83. <input id="tenderId" value="<%= tender.id %>" type="hidden">
  84. <div class="sjs-height-0">
  85. <table class="table table-bordered" id="change-table">
  86. <thead>
  87. <tr><th width="3%">序号</th>
  88. <th width="18%" id="sort_change">申请编号/变更令号</th><th width="24%">变更工程名称</th>
  89. <th width="7%">变更性质</th><% if (ctx.session.sessionProject.page_show.openChangeState) { %><th width="7%">变更令状态</th><% } %>
  90. <th width="7%">变更金额</th><th width="7%">正变更金额</th>
  91. <th width="7%">负变更金额</th><th width="7%">审批状态</th>
  92. <th width="14%">审批进度</th><th width="4%"></th>
  93. </tr>
  94. </thead>
  95. <tbody id="changeList">
  96. <% const qualityArray = []; %>
  97. <% for (const t in changeConst.quality) { %>
  98. <% const cQuality = changeConst.quality[t] %>
  99. <% qualityArray[cQuality.value] = cQuality.name %>
  100. <% } %>
  101. <% if (changes.length > 0) { %>
  102. <% for (const [index, c] of changes.entries()) { %>
  103. <tr>
  104. <td class="text-center"><%- (pageInfo.page-1)*pageInfo.pageSize + index+1 %></td>
  105. <td><a href="/tender/<%- tender.id %>/change/<%- c.cid %>/information"><% if (c.status !== auditConst.status.checked) { %><%- c.code %><% } else { %><%- c.p_code %><% } %></a></td>
  106. <td><%- c.name %></td>
  107. <td><%- qualityArray[c.quality] %><% c.quality %></td>
  108. <% if (ctx.session.sessionProject.page_show.openChangeState) { %>
  109. <td><%- ctx.helper._.find(changeState, { order: c.state }).name %></td>
  110. <% } %>
  111. <td style="text-align: right"><%= ctx.helper.roundNum(c.total_price, tpUnit) %></td>
  112. <td style="text-align: right"><%= ctx.helper.roundNum(c.positive_tp, tpUnit) %></td>
  113. <td style="text-align: right"><%= ctx.helper.roundNum(c.negative_tp, tpUnit) %></td>
  114. <% if (c.status === auditConst.status.uncheck && ctx.tender.isTourist) { %>
  115. <td>
  116. 上报中
  117. </td>
  118. <% } else if (c.status === auditConst.status.revise && ctx.tender.isTourist) { %>
  119. <td>
  120. 修订中
  121. </td>
  122. <% } else if (c.auditStatus) { %>
  123. <td>
  124. <a href="/tender/<%- tender.id %>/change/<%- c.cid %>/information" class="btn <%- auditConst.statusButtonClass[c.status] %> btn-sm">
  125. <%- auditConst.statusButton[c.status] %>
  126. </a>
  127. </td>
  128. <% } else { %>
  129. <td>
  130. <span class="<%- auditConst.statusClass[c.status] %>"><%- auditConst.statusString[c.status] %></span>
  131. </td>
  132. <% } %>
  133. <% if (c.status === auditConst.status.uncheck) { %>
  134. <td>
  135. 待上报
  136. </td>
  137. <% } else if (c.status === auditConst.status.revise) { %>
  138. <td>
  139. 待修订
  140. </td>
  141. <% } else if (c.changeAudit) { %>
  142. <td>
  143. <%- c.changeAudit.name %>-<%- c.changeAudit.jobs %>
  144. <span class="<%- auditConst.auditStatusClass[c.changeAudit.status] %>"><%- auditConst.auditStatusString[c.changeAudit.status] %></span>
  145. </td>
  146. <% } else { %><td></td><% } %>
  147. <td><% if ((c.status === auditConst.status.uncheck || (((c.status === auditConst.status.back || c.status === auditConst.status.revise) && c.stageChangeNum === 0) && c.uid === uid)) && !ctx.tender.isTourist) { %><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>
  148. </tr>
  149. <% } %>
  150. <% } %>
  151. </tbody>
  152. </table>
  153. <!--翻页-->
  154. <% include ../layout/page.ejs %>
  155. </div>
  156. </div>
  157. </div>
  158. </div>
  159. <script src="/public/js/sub_menu.js"></script>
  160. <script src="/public/js/colResizable/colResizable-1.6.min.js"></script>
  161. <script>
  162. $.subMenu({
  163. menu: '#sub-menu', miniMenu: '#sub-mini-menu', miniMenuList: '#mini-menu-list',
  164. toMenu: '#to-menu', toMiniMenu: '#to-mini-menu',
  165. key: 'menu.1.0.0',
  166. miniHint: '#sub-mini-hint', hintKey: 'menu.hint.1.0.1',
  167. callback: function (info) {
  168. if (info.mini) {
  169. $('.panel-title').addClass('fluid');
  170. $('#sub-menu').removeClass('panel-sidebar');
  171. } else {
  172. $('.panel-title').removeClass('fluid');
  173. $('#sub-menu').addClass('panel-sidebar');
  174. }
  175. autoFlashHeight();
  176. }
  177. });
  178. const openChangePlan = parseInt('<%- ctx.session.sessionProject.page_show.openChangePlan %>');
  179. const changePlanList = JSON.parse(unescape('<%- escape(JSON.stringify(changePlanList)) %>'));
  180. </script>
  181. <script src="/public/js/change.js"></script>