info_modal.ejs 25 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397
  1. <% if (auditStatus === 1 || auditStatus === 2) { %>
  2. <!--变更单位-->
  3. <div class="modal fade" id="editcompany" tabindex="-1" role="dialog" aria-labelledby="myModalLabel">
  4. <div class="modal-dialog" role="document">
  5. <div class="modal-content">
  6. <div class="modal-header">
  7. <h5 class="modal-title" id="myModalLabel">变更单位</h5>
  8. <button type="button" class="close" data-dismiss="modal" aria-label="Close">
  9. <span aria-hidden="true">&times;</span>
  10. </button>
  11. </div>
  12. <div class="modal-body">
  13. <div id="companyshow">
  14. <% for (const company of companyList) { %>
  15. <div class="form-group">
  16. <input type="text" id="<%= company.id %>" class="form-control" value="<%= company.name %>">
  17. </div>
  18. <% } %>
  19. </div>
  20. <div class="alert alert-warning" role="alert">修改后,已创建的变更不受影响。</div>
  21. <p><button class="btn btn-primary btn-sm" id="addcompany" role="button" title="填写公司"><b class="fa fa-plus"></b></button></p>
  22. <div id="companyadddiv">
  23. <!--<input type="text" class="form-control" placeholder="请输入公司名称">-->
  24. </div>
  25. </div>
  26. <div class="modal-footer">
  27. <button type="button" class="btn btn-secondary" data-dismiss="modal">取消</button>
  28. <button type="button" id="updatecompany" class="btn btn-primary">确定</button>
  29. </div>
  30. </div>
  31. </div>
  32. </div>
  33. <!--上报审批-->
  34. <div class="modal fade" id="sub-ap" data-backdrop="static">
  35. <div class="modal-dialog" role="document">
  36. <div class="modal-content">
  37. <div class="modal-header">
  38. <h5 class="modal-title up-change">上报审批</h5>
  39. <h5 class="modal-title save-change">保存修改</h5>
  40. </div>
  41. <form method="post" action="/tender/<%- tender.id %>/change/<%- change.cid %>/save">
  42. <div class="modal-body">
  43. <!--如未创建清单-->
  44. <!--<h5>还没添加任何变更清单,无法提交。</h5>-->
  45. <!--可以提交审批 但需要设置审批流程-->
  46. <div class="form-group">
  47. <label>搜索审批人</label>
  48. <div class="input-group">
  49. <input class="form-control" placeholder="请输入姓名进行检索" type="text" id="search_audit_input">
  50. <div class="input-group-append">
  51. <button class="btn btn-outline-secondary" type="button" id="search_audit_btn"><i class="fa fa-search"></i></button>
  52. </div>
  53. </div>
  54. </div>
  55. <div id="search_audit_list">
  56. </div>
  57. <div class="card mt-3">
  58. <div class="card-header">
  59. 审批流程
  60. </div>
  61. <ul class="list-group list-group-flush">
  62. <% for (const audit of auditList) { %>
  63. <% if (audit.usite === 0) { %>
  64. <li class="list-group-item">
  65. <i class="fa fa-play-circle fa-rotate-90"></i>
  66. <%= audit.name %><small class="text-muted"><%= audit.jobs %></small>
  67. </li>
  68. <% } %>
  69. <% } %>
  70. </ul>
  71. <ul class="list-group list-group-flush" id="auditList">
  72. <% for (const audit of auditList) { %>
  73. <% if (audit.usite !== 0) { %>
  74. <li class="list-group-item" data-auditmsg="<%= audit.uid + '/%/' + audit.name + '/%/' + audit.jobs + '/%/' + audit.company %>"
  75. data-auditid="<%= audit.uid %>">
  76. <a href="javascript:void(0)" class="text-danger pull-right remove_audit_btn">移除</a>
  77. <% if (audit.usite === auditList.length-1) { %><i class="fa fa-stop-circle"></i>
  78. <% } else { %><i class="fa fa-chevron-circle-down"></i>
  79. <% } %>
  80. <%= audit.name %><small class="text-muted"><%= audit.jobs %></small>
  81. </li>
  82. <% } %>
  83. <% } %>
  84. </ul>
  85. <input type="hidden" id="auditIdList" value="">
  86. </div>
  87. </div>
  88. <div class="modal-footer">
  89. <button type="button" class="btn btn-secondary" data-dismiss="modal">关闭</button>
  90. <button type="button" data-sumbit="sumbit_change" data-category="up_change" class="btn btn-primary up-change">确认上报</button>
  91. <button type="button" data-sumbit="sumbit_change" data-category="save_change" class="btn btn-success save-change">保存修改</button>
  92. </div>
  93. </form>
  94. </div>
  95. </div>
  96. </div>
  97. <script src="/public/js/change_company.js"></script>
  98. <!--添加清单-->
  99. <div class="modal fade " tabindex="-1" role="dialog" aria-hidden="true" id="addlist">
  100. <div class="modal-dialog modal-xl">
  101. <div class="modal-content">
  102. <div class="modal-header">
  103. <h5 class="modal-title" id="mySmallModalLabel">从清单中选择</h5>
  104. <button type="button" class="close" data-dismiss="modal" aria-label="Close">
  105. <span aria-hidden="true">&times;</span>
  106. </button>
  107. </div>
  108. <div class="modal-body">
  109. <div class="row">
  110. <div class="col-7">
  111. <div style="height:400px;overflow-y:auto">
  112. <table class="table table-striped table-bordered table-condensed">
  113. <thead><tr><th>序号</th><th>清单编号</th><th>名称</th><th>单位</th><th>单价</th><th>数量</th><th>金额</th></tr></thead>
  114. <tbody id="table-list-select">
  115. </tbody>
  116. </table>
  117. </div>
  118. </div>
  119. <div class="col-5">
  120. <div style="height:400px;overflow-y:auto">
  121. <table class="table table-sm table-bordered">
  122. <thead>
  123. <tr><th>项目节编号</th><th>名称</th><th>部位明细</th><th>选择</th></tr>
  124. </thead>
  125. <tbody id="code-list" data-index="">
  126. <!--<tr><td colspan="3">自行编辑变更详情</td><td><input type="checkbox"></td></tr>-->
  127. <!--<tr><td>1-4-5-1-1-1-1</td><td>桥台桩基础</td><td>0#桥台1#桩</td><td><input type="checkbox"></td></tr>-->
  128. <!--<tr><td>1-4-5-1-1-1-1</td><td>桥台桩基础</td><td>0#桥台2#桩</td><td><input type="checkbox"></td></tr>-->
  129. <!--<tr><td>1-4-5-1-1-1-1</td><td>桥台桩基础</td><td>0#桥台3#桩</td><td><input type="checkbox"></td></tr>-->
  130. <!--<tr><td>1-4-5-1-1-1-1</td><td>桥台桩基础</td><td>0#桥台4#桩</td><td><input type="checkbox"></td></tr>-->
  131. </tbody>
  132. </table>
  133. </div>
  134. </div>
  135. </div>
  136. </div>
  137. <div class="modal-footer">
  138. <button type="button" class="add-list-btn btn btn-outline-primary">添加空白清单</button>
  139. <button type="button" class="btn btn-secondary" data-dismiss="modal" id="cancel-list-btn">取消</button>
  140. <button type="button" class="add-list-btn btn btn-primary">添加</button>
  141. </div>
  142. </div>
  143. </div>
  144. </div>
  145. <% } %>
  146. <% if (auditStatus === 3 || auditStatus === 4 || auditStatus === 5 || auditStatus === 7) { %>
  147. <!--审批流程/结果-->
  148. <div class="modal fade" id="sp-list" data-backdrop="static">
  149. <div class="modal-dialog modal-lg" role="document">
  150. <div class="modal-content">
  151. <div class="modal-header">
  152. <h5 class="modal-title">审批流程</h5>
  153. </div>
  154. <div class="modal-body">
  155. <div class="row">
  156. <div class="col-4">
  157. <div class="card mt-3">
  158. <ul class="list-group list-group-flush">
  159. <% for (const [index,a] of auditList2.entries()) { %>
  160. <li class="list-group-item">
  161. <% if (a.usite === 0 ) { %>
  162. <i class="fa fa-play-circle fa-rotate-90"></i>
  163. <% } else if (index+1 !== auditList2.length) { %>
  164. <i class="fa fa-chevron-circle-down"></i>
  165. <% } else if (index+1 === auditList2.length) { %>
  166. <i class="fa fa-stop-circle"></i>
  167. <% } %>
  168. <%= a.name %> <small class="text-muted"><%= a.jobs %></small>
  169. </li>
  170. <% } %>
  171. </ul>
  172. </div>
  173. </div>
  174. <div class="col-8 modal-height-500" style="overflow: auto">
  175. <% for (const time in auditList3) { %>
  176. <div class="card mt-3">
  177. <ul class="list-group list-group-flush">
  178. <% for (const [aindex,al] of auditList3[time].entries()) { %>
  179. <li class="list-group-item">
  180. <% if (al.usite === 0 && al.status === 2) { %>
  181. <span class="pull-right">重新上报中</span>
  182. <% } else if (al.usite === 0 && al.status === 3) { %>
  183. <span class="text-success pull-right">上报</span>
  184. <% } else if (al.usite !== 0 && al.status === 2) { %>
  185. <span class="pull-right">审批中</span>
  186. <% } else if (al.usite !== 0 && al.status === 3) { %>
  187. <span class="text-success pull-right">审批通过</span>
  188. <% } else if (al.usite !== 0 && al.status === 4) { %>
  189. <span class="text-danger pull-right">审批终止</span>
  190. <% } else if (al.usite !== 0 && (al.status === 5 || al.status === 6)) { %>
  191. <span class="text-warning pull-right">审批退回 </span>
  192. <% } %>
  193. <h5 class="card-title">
  194. <% if (al.usite === 0 && al.status === 2 ) { %>
  195. <i class="fa fa-play-circle fa-rotate-90"></i>
  196. <% } else if (al.usite === 0 && al.status === 3 ) { %>
  197. <i class="fa fa-play-circle fa-rotate-90 text-success"></i>
  198. <% } else if (al.status === 1 || al.status === 2) { %>
  199. <i class="fa <% if (aindex+1 === auditList3[time].length) { %>fa-stop-circle<% } else { %>fa-chevron-circle-down<% } %> "></i>
  200. <% } else if (al.status === 3) { %>
  201. <i class="fa <% if (aindex+1 === auditList3[time].length) { %>fa-stop-circle<% } else { %>fa-chevron-circle-down<% } %> text-success"></i>
  202. <% } else if (al.status === 4) { %>
  203. <i class="fa <% if (aindex+1 === auditList3[time].length) { %>fa-stop-circle<% } else { %>fa-chevron-circle-down<% } %> text-danger"></i>
  204. <% } else if (al.status === 5 || al.status === 6) { %>
  205. <i class="fa <% if (aindex+1 === auditList3[time].length) { %>fa-stop-circle<% } else { %>fa-chevron-circle-down<% } %> text-warning"></i>
  206. <% } %>
  207. <%= al.name %>&nbsp;<small class="text-muted"><%= al.jobs %></small>
  208. </h5>
  209. <% if (al.sin_time !== null || (al.sdesc !== '' && al.sdesc !== null)) { %>
  210. <p class="card-text"><%= al.sdesc %>&nbsp;<%= moment(al.sin_time).format('YYYY-MM-DD') %></p>
  211. <% } %>
  212. </li>
  213. <% } %>
  214. </ul>
  215. </div>
  216. <% } %>
  217. </div>
  218. </div>
  219. </div>
  220. <div class="modal-footer">
  221. <button type="button" class="btn btn-secondary" data-dismiss="modal">关闭</button>
  222. </div>
  223. </div>
  224. </div>
  225. </div>
  226. <% } %>
  227. <% if (auditStatus === 6) { %>
  228. <!--审批通过-->
  229. <div class="modal fade" id="sp-done" data-backdrop="static">
  230. <div class="modal-dialog" role="document">
  231. <div class="modal-content">
  232. <div class="modal-header">
  233. <h5 class="modal-title">审批通过</h5>
  234. </div>
  235. <form action="/change/approval?_csrf=<%= ctx.csrf %>" method="post" id="success-approval">
  236. <div class="modal-body">
  237. <div class="card mt-3">
  238. <ul class="list-group list-group-flush">
  239. <% for (const [index,a] of auditList.entries()) { %>
  240. <li class="list-group-item">
  241. <% if (a.status === 3 && a.usort === 0) { %>
  242. <span class="text-success pull-right">上报</span>
  243. <% } else if (a.status === 3 && a.usort !== 0) { %>
  244. <span class="text-success pull-right">审批通过</span>
  245. <% } else if (a.status === 2) { %>
  246. <span class="pull-right">审批中</span>
  247. <% } %>
  248. <h5 class="card-title">
  249. <% if (a.usort === 0) { %>
  250. <i class="fa fa-play-circle fa-rotate-90 <% if (a.status === 3) { %>text-success<% } %>"></i>
  251. <% } else if (a.usort !== 0 && index+1 !== auditList.length) { %>
  252. <i class="fa fa-chevron-circle-down <% if (a.status === 3) { %>text-success<% } %>"></i>
  253. <% } else if (a.usort !== 0 && index+1 === auditList.length) { %>
  254. <i class="fa fa-stop-circle"></i>
  255. <% } %>
  256. <%= a.name %>&nbsp;<small class="text-muted"><%= a.jobs%></small>
  257. </h5>
  258. <% if (a.sin_time !== null || (a.sdesc !== '' && a.sdesc !== null)) { %>
  259. <p class="card-text"><%= a.sdesc %>&nbsp;<%= moment(a.sin_time).format('YYYY-MM-DD') %></p>
  260. <% } %>
  261. <% if (a.status === 2) { %>
  262. <div class="form-group">
  263. <label>审批意见<b class="text-danger">*</b></label>
  264. <textarea class="form-control" name="sdesc"></textarea>
  265. <input type="hidden" name="audit_id" value="<%= a.id %>">
  266. <% if (a.usort !== 0 && index+1 === auditList.length) { %>
  267. <!--终审填写批复编号-->
  268. <div class="form-group mt-3">
  269. <label><b class="text-danger">*&nbsp;</b>批复编号</label>
  270. <input class="form-control" value="<%= change.name %>" name="p_code" type="text">
  271. </div>
  272. <% } else { %>
  273. <input type="hidden" name="audit_next_id" value="<%= auditList[index+1].id %>">
  274. <% } %>
  275. </div>
  276. <% } %>
  277. </li>
  278. <% } %>
  279. </ul>
  280. </div>
  281. </div>
  282. <div class="modal-footer">
  283. <input type="hidden" name="status" value="3">
  284. <input type="hidden" name="w_code" value="">
  285. <input type="hidden" name="change_id" value="<%= change.cid %>">
  286. <input type="hidden" name="bills_list" id="change-list-approval" value="">
  287. <button type="button" class="btn btn-secondary" data-dismiss="modal">关闭</button>
  288. <button type="button" class="btn btn-success approval-btn">确认通过</button>
  289. </div>
  290. </form>
  291. </div>
  292. </div>
  293. </div>
  294. <!--审批退回-->
  295. <div class="modal fade" id="sp-back" data-backdrop="static">
  296. <div class="modal-dialog" role="document">
  297. <div class="modal-content">
  298. <div class="modal-header">
  299. <h5 class="modal-title">审批退回</h5>
  300. </div>
  301. <form action="/change/approval?_csrf=<%= ctx.csrf %>" method="post" id="fail-approval">
  302. <div class="modal-body">
  303. <div class="card mt-3">
  304. <ul class="list-group list-group-flush">
  305. <% for (const [index,a] of auditList.entries()) { %>
  306. <li class="list-group-item">
  307. <% if (a.status === 3 && a.usort === 0) { %>
  308. <span class="text-success pull-right">上报</span>
  309. <% } else if (a.status === 3 && a.usort !== 0) { %>
  310. <span class="text-success pull-right">审批通过</span>
  311. <% } else if (a.status === 2) { %>
  312. <span class="pull-right">审批中</span>
  313. <% } %>
  314. <h5 class="card-title">
  315. <% if (a.usort === 0) { %>
  316. <i class="fa fa-play-circle fa-rotate-90 <% if (a.status === 3) { %>text-success<% } %>"></i>
  317. <% } else if (a.usort !== 0 && index+1 !== auditList.length) { %>
  318. <i class="fa fa-chevron-circle-down <% if (a.status === 3) { %>text-success<% } %>"></i>
  319. <% } else if (a.usort !== 0 && index+1 === auditList.length) { %>
  320. <i class="fa fa-stop-circle"></i>
  321. <% } %>
  322. <%= a.name %>&nbsp;<small class="text-muted"><%= a.jobs%></small>
  323. </h5>
  324. <% if (a.sin_time !== null || (a.sdesc !== '' && a.sdesc !== null)) { %>
  325. <p class="card-text"><%= a.sdesc %>&nbsp;<%= moment(a.sin_time).format('YYYY-MM-DD') %></p>
  326. <% } %>
  327. <% if (a.status === 2) { %>
  328. <div class="form-group">
  329. <label>审批意见<b class="text-danger">*</b></label>
  330. <textarea class="form-control" name="sdesc"></textarea>
  331. <input type="hidden" name="audit_id" value="<%= a.id %>">
  332. </div>
  333. <div class="alert alert-warning">
  334. <div class="form-check form-check-inline">
  335. <input class="form-check-input" type="radio" name="status" id="change-back" value="5">
  336. <label class="form-check-label" for="change-back">退回上报 <%= auditList[0].name %></label>
  337. </div>
  338. <% if (index !== 1) { %>
  339. <div class="form-check form-check-inline">
  340. <input class="form-check-input" type="radio" name="status" id="chagne-backnew" value="6">
  341. <label class="form-check-label" for="chagne-backnew">退回上一审批人 <%= auditList[index-1].name %></label>
  342. <input type="hidden" name="audit_last_id" value="<%= auditList[index-1].id %>">
  343. </div>
  344. <% } %>
  345. <div class="form-check form-check-inline">
  346. <input class="form-check-input" type="radio" name="status" id="change-stop" value="4">
  347. <label class="form-check-label" for="change-stop">终止</label>
  348. </div>
  349. </div>
  350. <div class="alert alert-danger change-approval-stop" style="display: none">
  351. 审批终止,将结束本次审批,本条变更令作废。
  352. </div>
  353. <% } %>
  354. </li>
  355. <% } %>
  356. </ul>
  357. </div>
  358. </div>
  359. <div class="modal-footer">
  360. <input type="hidden" name="w_code" value="">
  361. <input type="hidden" name="change_id" value="<%= change.cid %>">
  362. <button type="button" class="btn btn-secondary" data-dismiss="modal">关闭</button>
  363. <button type="button" class="btn btn-warning change-approval-back approval-btn">确认退回</button>
  364. <button type="button" class="btn btn-danger change-approval-stop approval-btn" style="display: none">确认终止</button>
  365. </div>
  366. </form>
  367. </div>
  368. </div>
  369. </div>
  370. <% } %>
  371. <!--添加附件-->
  372. <div class="modal fade" tabindex="-1" role="dialog" aria-hidden="true" id="addfujian">
  373. <div class="modal-dialog" role="document">
  374. <div class="modal-content">
  375. <div class="modal-header">
  376. <h5 class="modal-title" id="myModalLabel">上传附件</h5>
  377. <button type="button" class="close" data-dismiss="modal" aria-label="Close">
  378. <span aria-hidden="true">&times;</span>
  379. </button>
  380. </div>
  381. <div class="modal-body">
  382. <p>上传文件大小最大:30MB</p>
  383. <p><input class="btn btn-primary" value="选择文件" type="file" id="upload-file" /></p>
  384. </div>
  385. <div class="modal-footer">
  386. <button type="button" class="btn btn-secondary" data-dismiss="modal">取消</button>
  387. <button type="button" class="btn btn-primary" id="upload-file-btn">添加</button>
  388. </div>
  389. </div>
  390. </div>
  391. </div>