shenpi.ejs 23 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245
  1. <% include ./sub_menu.ejs %>
  2. <div class="panel-content">
  3. <div class="panel-title">
  4. <div class="title-main d-flex">
  5. <h2>审批流程设置</h2>
  6. </div>
  7. </div>
  8. <div class="content-wrap">
  9. <div class="c-body">
  10. <div class="sjs-height-0">
  11. <div class="row m-0 mt-3">
  12. <div class="col-7">
  13. <% for (const sp of shenpi.sp_lc) { %>
  14. <div class="card mb-3">
  15. <div class="card-body <%- sp.code %>_div">
  16. <!-- <a class="pull-right set-otherTender" data-name="<%- sp.name %>" data-code="<%- sp.code %>" href="#batch" data-toggle="modal" data-target="#batch">设置其他标段</a>-->
  17. <!-- <a class="pull-right set-otherShenpi mr-3" data-name="<%- sp.name %>" data-code="<%- sp.code %>" href="javascript: void(0);">设置其他流程</a>-->
  18. <h5 class="card-title"><%- sp.name %></h5>
  19. <div class="form-group">
  20. <div class="form-group form-check">
  21. <% for (const st in shenpi.sp_status_list) { %>
  22. <% if (shenpi.sp_status_list[st]) { %>
  23. <div class="custom-control custom-checkbox custom-control-inline">
  24. <input type="radio" class="custom-control-input" data-code="<%- sp.code %>" value="<%- shenpi.sp_status_list[st].status %>" name="<%- sp.code %>" id="<%- sp.code %>_<%- shenpi.sp_status_list[st].status %>" <%if (sp.status === shenpi.sp_status_list[st].status) { %>checked<% } %>>
  25. <label class="custom-control-label" for="<%- sp.code %>_<%- shenpi.sp_status_list[st].status %>"><%- shenpi.sp_status_list[st].name %></label>
  26. </div>
  27. <% } %>
  28. <% } %>
  29. </div>
  30. </div>
  31. <div class="alert alert-warning"><%- shenpi.sp_status_list[sp.status].name %>:<%- shenpi.sp_status_list[sp.status].msg %></div>
  32. <div class="lc-show">
  33. <% if (sp.status === shenpi.sp_status.gdspl) { %>
  34. <% if (sp.groupList && sp.groupList.length > 0) { %>
  35. <!-- 切换 编辑 新建审批组-->
  36. <div class="d-flex justify-content-start align-items-center mb-3">
  37. <span class="col-auto">当前审批组:</span>
  38. <span style="width: 200px;">
  39. <select class="form-control form-control-sm group-list">
  40. <% for (const group of sp.groupList) { %>
  41. <option value="<%- group.id %>" <% if (group.is_select === 1) { %>selected<% } %>><%- group.name %></option>
  42. <% } %>
  43. </select>
  44. </span>
  45. <span class="pl-3"><a href="javascript:void(0);" class="show-spzsave edit-spzsave" data-group="<%- sp.groupList.find(x => { return x.is_select === 1 }).id %>" data-code="<%- sp.code %>"><i class="fa fa-edit"></i> 编辑审批组</a></span>
  46. <span class="pl-3"><a href="javascript:void(0);" class="show-spzsave" data-code="<%- sp.code %>"><i class="fa fa-plus"></i> 添加审批组</a></span>
  47. </div>
  48. <% } %>
  49. <ul class="list-unstyled">
  50. <% if (sp.auditGroupList.length > 0) { %>
  51. <% for (const [i, auditGroup] of sp.auditGroupList.entries()) { %>
  52. <li class="d-flex justify-content-start mb-3 align-items-center">
  53. <span class="col-auto"><%- ctx.helper.transFormToChinese(i+1) %>审</span>
  54. <span class="col-7 spr-span">
  55. <span class="d-inline-block">
  56. <select class="form-control form-control-sm audit-type-key" data-type="<%- auditGroup[0].audit_type %>">
  57. <% for (const at of auditType.types) { %>
  58. <% if (at.valid && at.valid.indexOf(sp.code) < 0) continue; %>
  59. <option value="<%- at.value %>" <% if (auditGroup[0].audit_type === at.value) { %>selected<%} %>><%- at.name %></option>
  60. <% } %>
  61. </select>
  62. </span>
  63. <% for (const audit of auditGroup) { %>
  64. <span class="d-inline-block"><span class="badge badge-light"><%- audit.name %> <span class="dropdown">
  65. <a href="javascript:void(0);" class="btn-sm text-danger px-1" title="移除" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false"><i class="fa fa-remove"></i></a>
  66. <div class="dropdown-menu">
  67. <a class="dropdown-item" href="javascript:void(0);">确认移除审批人?</a>
  68. <div class="dropdown-divider"></div>
  69. <div class="px-2 py-1 text-center">
  70. <button class="remove-audit btn btn-sm btn-danger" data-id="<%- audit.audit_id %>">移除</button>
  71. <button class="btn btn-sm btn-secondary">取消</button>
  72. </div>
  73. </div>
  74. </span></span></span>
  75. <% } %>
  76. <% if (auditGroup[0].audit_type !== auditType.key.common) { %>
  77. <span class="d-inline-block">
  78. <div class="dropdown text-right">
  79. <button class="btn btn-outline-primary btn-sm dropdown-toggle" type="button" id="<%- sp.code %>_dropdownMenuButton" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
  80. 选择审批人
  81. </button>
  82. <div class="dropdown-menu dropdown-menu-right" id="<%- sp.code %>_dropdownMenu" aria-labelledby="<%- sp.code %>_dropdownMenuButton" style="width:220px">
  83. <div class="mb-2 p-2"><input class="form-control form-control-sm gr-search"
  84. placeholder="姓名/手机 检索" autocomplete="off" data-code="<%- sp.code %>"></div>
  85. <dl class="list-unstyled book-list">
  86. <% accountGroup.forEach((group, idx) => { %>
  87. <dt><a href="javascript: void(0);" class="acc-btn" data-groupid="<%- idx %>" data-type="hide"><i class="fa fa-plus-square"></i></a> <%- group.groupName %></dt>
  88. <div class="dd-content" data-toggleid="<%- idx %>">
  89. <% group.groupList.forEach(item => { %>
  90. <dd class="border-bottom p-2 mb-0 " data-id="<%- item.id %>" >
  91. <p class="mb-0 d-flex"><span class="text-primary"><%- item.name %></span><span
  92. class="ml-auto"><%- item.mobile %></span></p>
  93. <span class="text-muted"><%- item.role %></span>
  94. </dd>
  95. <% });%>
  96. </div>
  97. <% }) %>
  98. </dl>
  99. </div>
  100. </div>
  101. </span>
  102. <% } %>
  103. <% if (auditGroup[0].audit_type === auditType.key.union) { %>
  104. <button class="btn btn-outline-primary btn-sm" sp_type="<%- sp.code %>" audit_order="<%- auditGroup[0].audit_order %>" name="union-set">协同设置</button>
  105. <% } %>
  106. <% if (auditGroup[0].audit_type === auditType.key.and && auditType.info[auditType.key.and].setValid.indexOf(sp.code) >= 0) { %>
  107. <button class="btn btn-outline-primary btn-sm" sp_type="<%- sp.code %>" audit_order="<%- auditGroup[0].audit_order %>" name="and-set">会签设置</button>
  108. <% } %>
  109. <% if (auditGroup[0].audit_type === auditType.key.or && auditType.info[auditType.key.or].setValid.indexOf(sp.code) >= 0) { %>
  110. <button class="btn btn-outline-primary btn-sm" sp_type="<%- sp.code %>" audit_order="<%- auditGroup[0].audit_order %>" name="or-set">或签设置</button>
  111. <% } %>
  112. <% if (auditGroup[0].audit_type === auditType.key.multi) { %>
  113. <button class="btn btn-outline-primary btn-sm" sp_type="<%- sp.code %>" audit_order="<%- auditGroup[0].audit_order %>" name="multi-set">分组设置</button>
  114. <% } %>
  115. </span>
  116. </li>
  117. <% } %>
  118. <li>
  119. <span class="pl-3"><a href="javascript:void(0);" class="add-audit" ><i class="fa fa-plus"></i> 添加流程</a></span>
  120. <% if (sp.code === 'contract' && (!sp.groupList || (sp.groupList && sp.groupList.length === 0))) { %>
  121. <span class="pl-3"><a href="javascript:void(0);" class="show-spzsave" data-code="<%- sp.code %>"><i class="fa fa-save"></i> 存为审批组</a></span>
  122. <% } %>
  123. </li>
  124. <% } else { %>
  125. <li class="d-flex justify-content-start mb-3 align-items-center">
  126. <span class="col-auto">一审</span>
  127. <span class="col-7 spr-span">
  128. <span class="d-inline-block">
  129. <select class="form-control form-control-sm audit-type-key" data-type="<%- auditType.key.common %>">
  130. <% for (const at of auditType.types) { %>
  131. <% if (at.valid && at.valid.indexOf(sp.code) < 0) continue; %>
  132. <option value="<%- at.value %>" <% if (auditType.key.common === at.value) { %>selected<%} %>><%- at.name %></option>
  133. <% } %>
  134. </select>
  135. </span>
  136. <span class="d-inline-block">
  137. <div class="dropdown text-right">
  138. <button class="btn btn-outline-primary btn-sm dropdown-toggle" type="button" id="<%- sp.code %>_dropdownMenuButton" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
  139. 选择审批人
  140. </button>
  141. <div class="dropdown-menu dropdown-menu-right" id="<%- sp.code %>_dropdownMenu" aria-labelledby="<%- sp.code %>_dropdownMenuButton" style="width:220px">
  142. <div class="mb-2 p-2"><input class="form-control form-control-sm gr-search"
  143. placeholder="姓名/手机 检索" autocomplete="off" data-code="<%- sp.code %>"></div>
  144. <dl class="list-unstyled book-list">
  145. <% accountGroup.forEach((group, idx) => { %>
  146. <dt><a href="javascript: void(0);" class="acc-btn" data-groupid="<%- idx %>" data-type="hide"><i class="fa fa-plus-square"></i></a> <%- group.groupName %></dt>
  147. <div class="dd-content" data-toggleid="<%- idx %>">
  148. <% group.groupList.forEach(item => { %>
  149. <dd class="border-bottom p-2 mb-0 " data-id="<%- item.id %>" >
  150. <p class="mb-0 d-flex"><span class="text-primary"><%- item.name %></span><span
  151. class="ml-auto"><%- item.mobile %></span></p>
  152. <span class="text-muted"><%- item.role %></span>
  153. </dd>
  154. <% });%>
  155. </div>
  156. <% }) %>
  157. </dl>
  158. </div>
  159. </div>
  160. </span>
  161. </span>
  162. </li>
  163. <% } %>
  164. </ul>
  165. <% } else if (sp.status === shenpi.sp_status.gdzs) { %>
  166. <ul class="list-unstyled">
  167. <li class="d-flex justify-content-start mb-3">
  168. <span class="col-auto">授权审批人</span>
  169. <span class="col-7">
  170. <span class="d-inline-block"></span>
  171. </span>
  172. </li>
  173. <% if (sp.audit) { %>
  174. <li class="d-flex justify-content-start mb-3 align-items-center">
  175. <span class="col-auto">终审</span>
  176. <span class="col-7 spr-span">
  177. <span class="d-inline-block"></span>
  178. <span class="d-inline-block"><span class="badge badge-light"><%- sp.audit.name %> <span class="dropdown">
  179. <a href="javascript:void(0);" class="btn-sm text-danger px-1" title="移除" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false"><i class="fa fa-remove"></i></a>
  180. <div class="dropdown-menu">
  181. <a class="dropdown-item" href="javascript:void(0);">确认移除审批人?</a>
  182. <div class="dropdown-divider"></div>
  183. <div class="px-2 py-1 text-center">
  184. <button class="remove-audit btn btn-sm btn-danger" data-id="<%- sp.audit.audit_id %>">移除</button>
  185. <button class="btn btn-sm btn-secondary">取消</button>
  186. </div>
  187. </div>
  188. </span>
  189. <!--<a href="javascript:void(0);" class="remove-audit btn-sm text-danger px-1" title="移除" data-id=""><i class="fa fa-remove"></i></a></span> </span>-->
  190. </span></span></span>
  191. </li>
  192. <% } else { %>
  193. <li class="d-flex justify-content-start mb-3 align-items-center">
  194. <span class="col-auto">终审</span>
  195. <span class="col-7 spr-span">
  196. <span class="d-inline-block">
  197. <div class="dropdown text-right">
  198. <button class="btn btn-outline-primary btn-sm dropdown-toggle" type="button" id="<%- sp.code %>_dropdownMenuButton" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
  199. 选择审批人
  200. </button>
  201. <div class="dropdown-menu dropdown-menu-right" id="<%- sp.code %>_dropdownMenu" aria-labelledby="<%- sp.code %>_dropdownMenuButton" style="width:220px">
  202. <div class="mb-2 p-2"><input class="form-control form-control-sm gr-search"
  203. placeholder="姓名/手机 检索" autocomplete="off" data-code="<%- sp.code %>"></div>
  204. <dl class="list-unstyled book-list">
  205. <% accountGroup.forEach((group, idx) => { %>
  206. <dt><a href="javascript: void(0);" class="acc-btn" data-groupid="<%- idx %>" data-type="hide"><i class="fa fa-plus-square"></i></a> <%- group.groupName %></dt>
  207. <div class="dd-content" data-toggleid="<%- idx %>">
  208. <% group.groupList.forEach(item => { %>
  209. <dd class="border-bottom p-2 mb-0 " data-id="<%- item.id %>" >
  210. <p class="mb-0 d-flex"><span class="text-primary"><%- item.name %></span><span
  211. class="ml-auto"><%- item.mobile %></span></p>
  212. <span class="text-muted"><%- item.role %></span>
  213. </dd>
  214. <% });%>
  215. </div>
  216. <% }) %>
  217. </dl>
  218. </div>
  219. </div>
  220. </span>
  221. </span>
  222. </li>
  223. <% } %>
  224. </ul>
  225. <% } %>
  226. </div>
  227. </div>
  228. </div>
  229. <% } %>
  230. </div>
  231. </div>
  232. </div>
  233. </div>
  234. </div>
  235. </div>
  236. <script>
  237. const sp_lc = JSON.parse(unescape('<%- escape(JSON.stringify(shenpi.sp_lc)) %>'));
  238. const sp_type = JSON.parse('<%- JSON.stringify(shenpi.sp_type) %>');
  239. const sp_status = JSON.parse('<%- JSON.stringify(shenpi.sp_status) %>');
  240. const sp_status_list = JSON.parse('<%- JSON.stringify(shenpi.sp_status_list) %>');
  241. const accountGroup = JSON.parse(unescape('<%- escape(JSON.stringify(accountGroup)) %>'));
  242. const accountList = JSON.parse(unescape('<%- escape(JSON.stringify(accountList)) %>'));
  243. const auditType = JSON.parse(unescape('<%- escape(JSON.stringify(auditType)) %>'));
  244. const cur_uid = JSON.parse('<%- JSON.stringify(ctx.subProject.user_id) %>');
  245. </script>