information.ejs 52 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696
  1. <% include ../tender/tender_sub_menu.ejs %>
  2. <div class="panel-content">
  3. <div class="panel-title" style="padding-right: 0px"><!--收起详解目录添加类名 fluid -->
  4. <div class="title-main d-flex"><!--工具-->
  5. <% include ../tender/tender_sub_mini_menu.ejs %>
  6. <div style="width: 100%">
  7. <div id="left-header" class="d-inline-block" style="min-width: 203px;">
  8. <div class="d-inline-block">
  9. <div class="btn-group btn-group-toggle group-tab">
  10. <a class="btn btn-sm btn-light active" href="javascript:void(0);">变更详情</a>
  11. <a class="btn btn-sm btn-light" href="/tender/<%- ctx.tender.id %>/change/<%- ctx.change.cid %>/report">输出报表</a>
  12. <% if (ctx.subProject.page_show.openChangePlan) { %>
  13. <a class="btn btn-sm btn-light" href="/tender/<%- ctx.tender.id %>/change/<%- ctx.change.cid %>/relation">关联数据</a>
  14. <% } %>
  15. </div>
  16. </div>
  17. </div>
  18. <% if (ctx.change.readOnly && (ctx.helper._.findIndex(ctx.change.auditors, { uid: ctx.session.sessionUser.accountId }) !== -1 || ctx.session.sessionUser.is_admin)) { %>
  19. <div class="d-inline-block ml-auto">
  20. <a href="javascript: void(0);" class="btn btn-outline-primary btn-sm mr-2" id="checkAndChange">检查并更新变更清单</a>
  21. </div>
  22. <% } %>
  23. <div class="pull-right mr-3" id="sp-btn">
  24. <% if (ctx.change.cancancel) { %>
  25. <a href="javascript: void(0);" data-toggle="modal" data-target="#sp-down-cancel" class="btn btn-danger btn-sm mr-2">撤回</a>
  26. <% } %>
  27. <% if (ctx.change.status === auditConst.status.uncheck) { %>
  28. <% if (ctx.session.sessionUser.accountId === ctx.change.uid) { %>
  29. <span class="d-inline-block need-check-revising">
  30. <a id="sub-sp-btn" href="#sub-sp" data-toggle="modal" data-target="#sub-sp" class="btn btn-primary btn-sm">上报审批</a>
  31. </span>
  32. <% } else { %>
  33. <a id="sub-sp-btn" href="#sub-sp" data-toggle="modal" data-target="#sub-sp" class="btn btn-outline-secondary btn-sm">上报中</a>
  34. <% } %>
  35. <% } else if (ctx.change.status === auditConst.status.checking) { %>
  36. <% if (ctx.change.curAuditorIds.indexOf(ctx.session.sessionUser.accountId) >= 0) { %>
  37. <span class="d-inline-block need-check-revising">
  38. <a id="sp-done-btn" href="javascript: void(0);" data-toggle="modal" data-target="#sp-done" class="btn btn-success btn-sm">审批通过</a>
  39. </span>
  40. <a href="#sp-back" data-toggle="modal" data-target="#sp-back" class="btn btn-warning btn-sm">审批退回</a>
  41. <% } else { %>
  42. <a href="#sp-list" data-toggle="modal" data-target="#sp-list" class="btn btn-outline-secondary btn-sm">审批中</a>
  43. <% } %>
  44. <% } else if (ctx.change.status === auditConst.status.checkNoPre) { %>
  45. <% if (ctx.change.curAuditorIds.indexOf(ctx.session.sessionUser.accountId) >= 0) { %>
  46. <span class="d-inline-block need-check-revising">
  47. <a id="sp-done-btn" href="javascript: void(0);" data-toggle="modal" data-target="#sp-done" class="btn btn-success btn-sm">审批通过</a>
  48. </span>
  49. <a href="#sp-back" data-toggle="modal" data-target="#sp-back" class="btn btn-warning btn-sm">审批退回</a>
  50. <% } else { %>
  51. <a href="#sp-list" data-toggle="modal" data-target="#sp-list" class="btn btn-outline-warning btn-sm text-muted">审批退回</a>
  52. <% } %>
  53. <% } else if (ctx.change.status === auditConst.status.checked) { %>
  54. <a href="#sp-list" data-toggle="modal" data-target="#sp-list" class="btn btn-outline-success btn-sm">审批完成</a>
  55. <% if (ctx.change.auditors !== undefined && ctx.change.finalAuditorIds.indexOf(ctx.session.sessionUser.accountId) >= 0) { %>
  56. <!--重新审批-->
  57. <a href="#sp-down-back" data-toggle="modal" data-target="#sp-down-back" class="btn btn-warning btn-sm ml-2">重新审批</a>
  58. <% } %>
  59. <% if (ctx.session.sessionUser.accountId === ctx.change.uid) { %>
  60. <a href="javascript: void(0);" data-toggle="modal" data-target="#sp-down-revise" class="btn btn-warning btn-sm ml-2">修订变更</a>
  61. <% } %>
  62. <% } else if (ctx.change.status === auditConst.status.checkNo || ctx.change.status === auditConst.status.revise) { %>
  63. <a href="#sp-list" data-type="hide" data-toggle="modal" data-target="#sp-list" class="btn btn-outline-warning btn-sm text-muted sp-list-btn">审批<% if (ctx.change.status === auditConst.status.checkNo) { %>退回<% } else { %>修订<% } %></a>
  64. <% if (ctx.session.sessionUser.accountId === ctx.change.uid) { %>
  65. <span class="d-inline-block need-check-revising">
  66. <a href="#sp-list" data-type="show" data-toggle="modal" data-target="#sp-list" class="btn btn-primary btn-sm sp-list-btn">重新上报</a>
  67. </span>
  68. <% } %>
  69. <% if (ctx.change.status === auditConst.status.revise && (ctx.session.sessionUser.accountId === ctx.change.uid || ctx.session.sessionUser.is_admin)) { %>
  70. <a href="#sub-revoke" data-toggle="modal" data-target="#sub-revoke" class="btn btn-warning btn-sm ml-2">撤销修订</a>
  71. <% } %>
  72. <% } %>
  73. </div>
  74. <!--info状态区分-->
  75. <% if (!change.readOnly || change.shenpiPower || (change.status === auditConst.status.checked && (ctx.session.sessionUser.is_admin || ctx.helper._.findIndex(change.auditors, { uid: ctx.session.sessionUser.accountId }) !== -1))) { %>
  76. <div class="pull-right px-3" id="show-save-btn" style="display: none">
  77. <!-- <span>您修改了变更信息,记得保存修改。</span>-->
  78. <button class="btn btn-sm btn-primary save_change_btn" id="save_change"><i class="fa fa-save"></i> 保存修改</button>
  79. <button class="btn btn-sm btn-light" id="cancel_change">取消</button>
  80. </div>
  81. <% } %>
  82. </div>
  83. </div>
  84. </div>
  85. <div class="content-wrap">
  86. <div class="c-header p-0"></div>
  87. <div class="w-100 sub-content row">
  88. <div class="c-body" id="left-view" style="width: 33.33%">
  89. <div class="sjs-bar-1">
  90. <input type="hidden" id="tenderId" value="<%- tender.id %>">
  91. <input type="hidden" id="changeId" value="<%- change.cid %>">
  92. <ul class="nav nav-tabs">
  93. <li class="nav-item">
  94. <a class="nav-link active" data-toggle="tab" data-tab="bgxinxi" href="#bgxinxi" role="tab">变更信息</a>
  95. </li>
  96. <li class="nav-item">
  97. <a class="nav-link" data-toggle="tab" data-tab="bgfujian" href="#bgfujian" role="tab">附件</a>
  98. </li>
  99. <li class="nav-item ml-auto pt-1 mr-3" id="copy_btn">
  100. <% if(!change.readOnly) { %>
  101. <a class="btn btn-sm btn-primary" href="#add-bj" data-toggle="modal" data-target="#add-bj">拷贝其他变更令数据</a>
  102. <% } %>
  103. </li>
  104. <li class="nav-item ml-auto pt-1" id="fujian_btn" style="display:none;">
  105. <!--所有附件 翻页-->
  106. <button data-toggle="modal" class="btn btn-sm btn-primary" id="bach-download">批量下载</button>
  107. <!-- <a href="javascript: void(0);" data-toggle="modal" class="btn btn-sm btn-primary" id="bach-download"><i class="fa fa-download "></i> 批量下载</a> -->
  108. <a href="javascript:void(0);" class="page-select ml-2" content="pre"><i class="fa fa-chevron-left"></i></a> <span id="currentPage">1</span>/<span id="totalPage">10</span> <a href="javascript:void(0);" class="page-select mr-2" content="next"><i class="fa fa-chevron-right"></i></a>
  109. <% if (change.filePermission) { %>
  110. <a href="#addfujian" data-toggle="modal" class="btn btn-sm btn-light text-primary" data-placement="bottom" title="" data-original-title="上传附件">上传附件</a>
  111. <% } %>
  112. <a href="javascript: void(0);" id="zipDown" download style="display: none;"></a>
  113. </li>
  114. </ul>
  115. </div>
  116. <div class="tab-content">
  117. <div class="tab-pane active" id="bgxinxi">
  118. <div class="sjs-sh-1" style="overflow-y: auto;">
  119. <% if (!change.readOnly || change.shenpiPower) { %>
  120. <div class="p-2" id="change_form">
  121. <% if (ctx.subProject.page_show.openChangeState) { %>
  122. <div class="form-group">
  123. <label>变更状态</label>
  124. <div>
  125. <% if (!change.readOnly) { %>
  126. <% for (const cs of changeState) { %>
  127. <div class="form-check form-check-inline">
  128. <input class="form-check-input" type="radio" id="state_<%- cs.order %>" value="<%- cs.order %>" name="state" <% if (cs.order === change.state) { %>checked<% } %>>
  129. <label class="form-check-label" for="state_<%- cs.order %>"><%- cs.name %></label>
  130. </div>
  131. <% } %>
  132. <% } else if (change.shenpiPower) { %>
  133. <% const cState = ctx.helper._.find(changeState, { order: change.state }) %>
  134. <div class="form-check form-check-inline">
  135. <input class="form-check-input" type="radio" id="state_<%- cState.order %>" name="state" disabled checked>
  136. <label class="form-check-label" for="state_<%- cState.order %>"><%- cState.name %></label>
  137. </div>
  138. <% } %>
  139. </div>
  140. </div>
  141. <% } %>
  142. <div class="form-group">
  143. <label><b class="text-danger">*&nbsp;</b>申请编号</label>
  144. <a href="javascript:void(0);" class="pull-right reduction-code" data-toggle="tooltip" data-placement="bottom" title="" data-code="<%- change.code %>" data-original-title="重置"><i class="fa fa-repeat"></i></a>
  145. <input class="form-control form-control-sm" name="code" value="<%- change.code %>" type="text">
  146. </div>
  147. <div class="form-group">
  148. <label><b class="text-danger">*&nbsp;</b>变更工程名称</label>
  149. <input class="form-control form-control-sm" name="name" value="<%- change.name %>" type="text">
  150. </div>
  151. <div class="form-group">
  152. <label>桩号</label>
  153. <input class="form-control form-control-sm" name="peg" value="<%- change.peg %>" type="text">
  154. </div>
  155. <div class="form-group">
  156. <label>原设计图名称</label>
  157. <input class="form-control form-control-sm" name="org_name" placeholder="" type="text" value="<%- change.org_name %>">
  158. </div>
  159. <div class="form-group">
  160. <label>原图号</label>
  161. <input class="form-control form-control-sm" name="org_code" placeholder="" type="text" value="<%- change.org_code %>">
  162. </div>
  163. <div class="form-group">
  164. <label>变更设计图名称</label>
  165. <input class="form-control form-control-sm" name="new_name" placeholder="" type="text" value="<%- change.new_name %>">
  166. </div>
  167. <div class="form-group">
  168. <label>变更图号</label>
  169. <input class="form-control form-control-sm" name="new_code" placeholder="" type="text" value="<%- change.new_code %>">
  170. </div>
  171. <div class="form-group">
  172. <label><b class="text-danger">*&nbsp;</b>工程变更理由及内容</label>
  173. <textarea class="form-control form-control-sm" name="content" rows="6"><%- ctx.helper.replaceStr(change.content, /<br><br>/g, '\r\n') %></textarea>
  174. </div>
  175. <div class="form-group">
  176. <label>工程变更合同依据</label>
  177. <textarea class="form-control form-control-sm" name="basis" rows="6"><%- ctx.helper.replaceStr(change.basis, /<br><br>/g, '\r\n') %></textarea>
  178. </div>
  179. <div class="form-group">
  180. <label>变更工程量数量计算式</label>
  181. <textarea class="form-control form-control-sm" name="expr" rows="2"><%- ctx.helper.replaceStr(change.expr, /<br><br>/g, '\r\n') %></textarea>
  182. </div>
  183. <div class="form-group">
  184. <label>备注</label>
  185. <textarea class="form-control form-control-sm" name="memo" rows="3"><%- ctx.helper.replaceStr(change.memo, /<br><br>/g, '\r\n') %></textarea>
  186. </div>
  187. <div class="form-group">
  188. <label>工程变更类型</label>
  189. <div class="checkbox">
  190. <% const changeType = change.type !== null && change.type !== '' ? change.type.split(',') : '' %>
  191. <% for (const t in changeConst.type) { %>
  192. <% const cType = changeConst.type[t] %>
  193. <label class="checkbox-inline">
  194. <input value="<%- cType.value %>" name="type[]"
  195. type="checkbox"<% if (changeType.indexOf(cType.value.toString()) !== -1) { %> checked<% } %>><%- cType.name %>
  196. </label>
  197. <% } %>
  198. </div>
  199. </div>
  200. <div class="form-group">
  201. <label>工程变更类别 </label>
  202. <select class="form-control form-control-sm" name="class">
  203. <% for (const cc of changeClass) { %>
  204. <% if (cc.checked) { %>
  205. <option value="<%- cc.value %>"<% if (cc.value === change.class) { %> selected<% } %>><%- cc.new_name ? cc.new_name : cc.name %></option>
  206. <% } %>
  207. <% } %>
  208. </select>
  209. </div>
  210. <div class="form-group">
  211. <label>工程变更性质 </label>
  212. <select class="form-control form-control-sm" name="quality">
  213. <% for (const q in changeConst.quality) { %>
  214. <% const cQuality = changeConst.quality[q] %>
  215. <option value="<%- cQuality.value %>"<% if (cQuality.value === change.quality) { %> selected<% } %>><%- cQuality.name %></option>
  216. <% } %>
  217. </select>
  218. </div>
  219. <div class="form-group">
  220. <label>变更提出单位</label>
  221. <a href="#editcompany" style="float:right;" class="" data-toggle="modal">编辑</a>
  222. <select class="form-control form-control-sm" id="company" name="company">
  223. <% for (const company of companyList) { %>
  224. <option <% if (company.name === change.company) { %>selected<% } %>><%- company.name %></option>
  225. <% } %>
  226. <% for (const u of unitList) { %>
  227. <option <% if (u.name === change.company) { %>selected<% } %>><%- u.name %></option>
  228. <% } %>
  229. </select>
  230. </div>
  231. <div class="form-group">
  232. <label>费用承担方</label>
  233. <div class="radio">
  234. <% for (const c in changeConst.charge) { %>
  235. <% const cCharge = changeConst.charge[c] %>
  236. <label class="radio-inline">
  237. <input value="<%- cCharge.value %>" name="charge" type="radio"<% if (cCharge.value === change.charge) { %> checked<% } %>> <%- cCharge.name %>
  238. </label>
  239. <% } %>
  240. </div>
  241. </div>
  242. <div class="form-group">
  243. <label>批复文号</label>
  244. <input class="form-control form-control-sm" id="w_code" name="w_code" placeholder="" type="text" value="<%- change.w_code %>">
  245. </div>
  246. </div>
  247. <% } else { %>
  248. <div class="p-2">
  249. <% if (ctx.subProject.page_show.openChangeState) { %>
  250. <div class="form-group">
  251. <label>变更状态</label>
  252. <div>
  253. <% const cState = ctx.helper._.find(changeState, { order: change.state }) %>
  254. <div class="form-check form-check-inline">
  255. <input class="form-check-input" type="radio" id="state_<%- cState.order %>" name="state" disabled checked>
  256. <label class="form-check-label" for="state_<%- cState.order %>"><%- cState.name %></label>
  257. </div>
  258. </div>
  259. </div>
  260. <% } %>
  261. <div class="form-group">
  262. <label>申请编号</label>
  263. <input class="form-control form-control-sm" value="<%- change.code %>" type="text" readonly>
  264. </div>
  265. <% if (change.status === auditConst.status.checked) { %>
  266. <div class="form-group">
  267. <label>变更令号(批复编号)</label>
  268. <input class="form-control form-control-sm" value="<%- change.p_code %>" type="text" readonly>
  269. </div>
  270. <% } %>
  271. <div class="form-group">
  272. <label>变更工程名称</label>
  273. <input class="form-control form-control-sm" value="<%- change.name %>" type="text" readonly>
  274. </div>
  275. <div class="form-group">
  276. <label>桩号</label>
  277. <input class="form-control form-control-sm" value="<%- change.peg %>" type="text" readonly>
  278. </div>
  279. <div class="form-group">
  280. <label>原设计图名称</label>
  281. <input class="form-control form-control-sm" placeholder="" type="text" value="<%- change.org_name %>" readonly>
  282. </div>
  283. <div class="form-group">
  284. <label>原图号</label>
  285. <input class="form-control form-control-sm" placeholder="" type="text" value="<%- change.org_code %>" readonly>
  286. </div>
  287. <div class="form-group">
  288. <label>变更设计图名称</label>
  289. <input class="form-control form-control-sm" placeholder="" type="text" value="<%- change.new_name %>" readonly>
  290. </div>
  291. <div class="form-group">
  292. <label>变更图号</label>
  293. <input class="form-control form-control-sm" placeholder="" type="text" value="<%- change.new_code %>" readonly>
  294. </div>
  295. <div class="form-group">
  296. <label>工程变更理由及内容</label>
  297. <textarea class="form-control form-control-sm" rows="6" readonly><%- ctx.helper.replaceStr(change.content, /<br><br>/g, '\r\n') %></textarea>
  298. </div>
  299. <div class="form-group">
  300. <label>工程变更合同依据</label>
  301. <textarea class="form-control form-control-sm" rows="6" readonly><%- ctx.helper.replaceStr(change.basis, /<br><br>/g, '\r\n') %></textarea>
  302. </div>
  303. <div class="form-group">
  304. <label>变更工程量数量计算式</label>
  305. <textarea class="form-control form-control-sm" rows="2" readonly><%- ctx.helper.replaceStr(change.expr, /<br><br>/g, '\r\n') %></textarea>
  306. </div>
  307. <div class="form-group">
  308. <label>备注</label>
  309. <textarea class="form-control form-control-sm" rows="3" readonly><%- ctx.helper.replaceStr(change.memo, /<br><br>/g, '\r\n') %></textarea>
  310. </div>
  311. <div class="form-group">
  312. <label>工程变更类型</label>
  313. <div class="checkbox">
  314. <% const changeType = change.type !== null && change.type !== '' ? change.type.split(',') : '' %>
  315. <% for (const t in changeConst.type) { %>
  316. <% const cType = changeConst.type[t] %>
  317. <label class="checkbox-inline">
  318. <% if (changeType.indexOf(cType.value.toString()) !== -1) { %>
  319. <input value="<%- cType.value %>" type="checkbox" disabled checked><%- cType.name %>
  320. <% } %>
  321. </label>
  322. <% } %>
  323. </div>
  324. </div>
  325. <div class="form-group">
  326. <label>工程变更类别 </label>
  327. <select class="form-control form-control-sm" disabled>
  328. <% for (const cc of changeClass) { %>
  329. <% if (cc.value === change.class) { %>
  330. <option value="<%- cc.value %>"><%- cc.new_name ? cc.new_name : cc.name %></option>
  331. <% } %>
  332. <% } %>
  333. </select>
  334. </div>
  335. <div class="form-group">
  336. <label>工程变更性质 </label>
  337. <select class="form-control form-control-sm" disabled>
  338. <% for (const q in changeConst.quality) { %>
  339. <% const cQuality = changeConst.quality[q] %>
  340. <% if (cQuality.value === change.quality) { %>
  341. <option value="<%- cQuality.value %>"><%- cQuality.name %></option>
  342. <% } %>
  343. <% } %>
  344. </select>
  345. </div>
  346. <div class="form-group">
  347. <label>变更提出单位</label>
  348. <select class="form-control form-control-sm" disabled>
  349. <option><%- change.company %></option>
  350. </select>
  351. </div>
  352. <div class="form-group">
  353. <label>费用承担方</label>
  354. <div class="radio">
  355. <% for (const c in changeConst.charge) { %>
  356. <% const cCharge = changeConst.charge[c] %>
  357. <label class="radio-inline">
  358. <% if (cCharge.value === change.charge) { %>
  359. <input value="<%- cCharge.value %>" type="radio" disabled checked> <%- cCharge.name %>
  360. <% } %>
  361. </label>
  362. <% } %>
  363. </div>
  364. </div>
  365. <div class="form-group">
  366. <label>批复文号</label>
  367. <input class="form-control form-control-sm" id="w_code" placeholder="" type="text" value="<%- change.w_code %>" <% if (!(change.shenpiPower || (change.status === auditConst.status.checked && (ctx.session.sessionUser.is_admin || ctx.helper._.findIndex(change.auditors, { uid: ctx.session.sessionUser.accountId }) !== -1)))) { %>readonly<% } %>>
  368. </div>
  369. </div>
  370. <% } %>
  371. </div>
  372. </div>
  373. <div class="tab-pane" id="bgfujian">
  374. <div class="sjs-sh-1" style="overflow: auto">
  375. <div class="p-2">
  376. <table class="table table-bordered" style="word-break:break-all; table-layout: fixed">
  377. <thead>
  378. <tr>
  379. <td width="25" style="background-color: #e9ecef;"><input type="checkbox" id="check-all-file" ></td>
  380. <th width="40">序号</th>
  381. <th>名称</th>
  382. <th width="100">上传时间/大小</th>
  383. <th width="60">操作</th>
  384. </tr>
  385. </thead>
  386. <tbody id="attList">
  387. <% if (attList !== undefined && attList !== '') { %>
  388. <% for (const [index,att] of attList.entries()) { %>
  389. <tr>
  390. <td width="25"><input type="checkbox" class="check-file" file-id=<%- att.id %>></td>
  391. <td><%- index+1 %></td>
  392. <td><a href="javascript: void(0);" class="file-atn" f-id="<%- att.id %>"><%- att.filename %><%- att.fileext %></a></td>
  393. <td><%- moment(att.in_time * 1000).format('YYYY-MM-DD') %><br><%- ctx.helper.bytesToSize(att.filesize) %></td>
  394. <td>
  395. <a href="/change/download/file/<%- att.id %>" class="mr-2" title="下载"><span class="fa fa-download text-primary"></span></a>
  396. <% if (att.uid === ctx.session.sessionUser.accountId && ((change.status === auditConst.status.checked ? Boolean(att.extra_upload) : true ) || deleteFilePermission)) { %>
  397. <a href="javascript:void(0)" class="mr-2 delete-file" data-attid="<%- att.id %>" title="删除附件"><span class="fa fa-trash text-danger"></span></a>
  398. <% } %>
  399. </td>
  400. </tr>
  401. <% } %>
  402. <% } %>
  403. </tbody>
  404. </table>
  405. <a href="" id="file-upload" target="_blank" style="display: none;"></a>
  406. </div>
  407. </div>
  408. </div>
  409. </div>
  410. </div>
  411. <div class="c-body" id="right-view" style="width: 66.67%">
  412. <div class="resize-x" id="right-spr" r-Type="width" div1="#left-view" div2="#right-view" title="调整大小" a-type="percent"><!--调整左右高度条--></div>
  413. <!--上半部分-->
  414. <div class="w-100 sub-content">
  415. <div class="sjs-height-1">
  416. <div class="c-body" style="width: 100%">
  417. <div class="m-1" id="list-tab">
  418. <% if (!change.readOnly) { %>
  419. <div class="d-inline-block ml-1">
  420. <!-- <a href="#addlist" data-toggle="modal" class="btn btn-sm btn-light text-primary" id="open-list-modal" data-toggle="tooltip" data-placement="bottom" title="" data-original-title="添加清单"><i class="fa fa-plus" aria-hidden="true"></i> <span class="order_text"><% if (change.order_by === 0) { %>添加<% } else { %>插入<% } %></span>台账清单</a>-->
  421. <a href="javascript:void(0);" id="set-site-btn" class="btn btn-sm btn-light text-primary" data-placement="bottom" title="" data-original-title="添加清单"><i class="fa fa-plus" aria-hidden="true"></i> <span class="order_text"><% if (change.order_by === 0) { %>添加<% } else { %>插入<% } %></span>台账清单</a>
  422. </div>
  423. <% if (ctx.subProject.page_show.openChangeWhiteList) { %>
  424. <div class="d-inline-block mr-1 judge-hide">
  425. <a href="javascript:void(0);" class="btn btn-sm btn-light text-primary" id="add-white-btn" data-original-title="添加清单"><i class="fa fa-plus" aria-hidden="true"></i> <span class="order_text"><% if (change.order_by === 0) { %>添加<% } else { %>插入<% } %></span>空白清单</a>
  426. </div>
  427. <% } %>
  428. <div class="d-inline-block mr-2 judge-show" style="display: none;">
  429. <div class="dropdown">
  430. <button class="btn btn-sm btn-light dropdown-toggle text-primary" type="button" id="dropdownMenuButton" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">
  431. <i class="fa fa-list-ol"></i> 显示层级
  432. </button>
  433. <div class="dropdown-menu" aria-labelledby="dropdownMenuButton">
  434. <a class="dropdown-item" name="showLevel" tag="1" href="javascript: void(0);">第一层</a>
  435. <a class="dropdown-item" name="showLevel" tag="2" href="javascript: void(0);">第二层</a>
  436. <a class="dropdown-item" name="showLevel" tag="3" href="javascript: void(0);">第三层</a>
  437. <a class="dropdown-item" name="showLevel" tag="4" href="javascript: void(0);">第四层</a>
  438. <a class="dropdown-item" name="showLevel" tag="5" href="javascript: void(0);">第五层</a>
  439. <a class="dropdown-item" name="showLevel" tag="last" href="javascript: void(0);">最底层</a>
  440. <a class="dropdown-item" name="showLevel" tag="leafXmj" href="javascript: void(0);">只显示项目节</a>
  441. </div>
  442. </div>
  443. </div>
  444. <div class="d-inline-block mr-2 judge-hide">
  445. <button type="button" class="btn btn-sm btn-light text-primary dropdown-toggle" data-toggle="dropdown" id="bpaixu">清单排序:<% if (change.order_by === 0) { %>清单编号<% } else { %>添加顺序<% } %></button>
  446. <div class="dropdown-menu" aria-labelledby="bpaixu">
  447. <ul class="list-unstyled px-3 mb-0">
  448. <li class="mb-2">
  449. <div class="custom-control custom-radio">
  450. <input type="radio" class="custom-control-input" name="paixu" id="order_0" value="0" <% if (change.order_by === 0) { %>checked<% } %>>
  451. <label class="custom-control-label" for="order_0">清单编号</label>
  452. </div>
  453. </li>
  454. <li class="mb-2">
  455. <div class="custom-control custom-radio">
  456. <input type="radio" class="custom-control-input" name="paixu" id="order_1" value="1" <% if (change.order_by === 1) { %>checked<% } %>>
  457. <label class="custom-control-label" for="order_1">添加顺序</label>
  458. </div>
  459. </li>
  460. </ul>
  461. </div>
  462. </div>
  463. <div class="d-inline-block mr-2 judge-hide" id="upAndMoveBtn" <% if (change.order_by === 0) { %>style="display: none!important;" <% } %>>
  464. <a href="javascript:void(0)" id="up-move" class="btn btn-sm btn-light text-primary" data-toggle="tooltip" data-placement="bottom" title="" data-original-title="上移"><i class="fa fa-arrow-up" aria-hidden="true"></i></a>
  465. <a href="javascript:void(0)" id="down-move" class="btn btn-sm btn-light text-primary" data-toggle="tooltip" data-placement="bottom" title="" data-original-title="下移"><i class="fa fa-arrow-down" aria-hidden="true"></i></a>
  466. </div>
  467. <% } %>
  468. <div class="d-inline-block mr-2">
  469. <div class="custom-control custom-checkbox">
  470. <input type="checkbox" class="custom-control-input change-detail-checkbox" id="customCheck1">
  471. <label class="custom-control-label" for="customCheck1">变更详情</label>
  472. </div>
  473. </div>
  474. <% if (change.readOnly && !change.shenpiPower) { %>
  475. <div class="d-inline-block mr-2">
  476. <div class="custom-control custom-checkbox">
  477. <input type="checkbox" class="custom-control-input" id="show-table-detail">
  478. <label class="custom-control-label" for="show-table-detail">审批过程</label>
  479. </div>
  480. </div>
  481. <% } %>
  482. <% if (showPlanBtn) { %>
  483. <div class="d-inline-block mr-2">
  484. <a class="btn btn-sm btn-primary" href="#bgfadb" data-toggle="modal" data-target="#bgfadb">差值对比</a>
  485. </div>
  486. <% } %>
  487. <div class="d-inline-block mr-2">
  488. <a class="btn btn-sm btn-primary" href="#qdgather" data-toggle="modal" data-target="#qdgather">清单汇总</a>
  489. </div>
  490. <div class="d-inline-block mr-2">
  491. <div class="input-group input-group-sm">
  492. <div class="input-group-prepend">
  493. <span class="input-group-text" id="basic-addon1">表达式</span>
  494. </div>
  495. <input type="text" class="form-control form-control-sm m-0 judge-hide" id="camount-expr" readonly="readOnly" autocomplete="off">
  496. <input type="text" class="form-control form-control-sm m-0 judge-show" id="ledger-camount-expr" readonly="readOnly" autocomplete="off" style="display: none">
  497. </div>
  498. </div>
  499. <div class="d-inline-block pull-right">
  500. <div class="btn-group btn-group-toggle group-tab">
  501. <a class="btn btn-sm btn-light change-mode <% if (changeMode === 0) { %>active<% } %>" data-type="0" href="javascript:void(0);">清单模式</a>
  502. <a class="btn btn-sm btn-light change-mode <% if (changeMode === 1) { %>active<% } %>" data-type="1" href="javascript:void(0);">台账模式</a>
  503. </div>
  504. </div>
  505. </div>
  506. <div class="sjs-height-change judge-hide" id="change-spread"></div>
  507. <div class="sjs-height-change judge-show" style="display: none;" id="ledger-spread"></div>
  508. </div>
  509. </div>
  510. <!--下半部分-->
  511. <div class="bcontent-wrap">
  512. <div id="change-pos-resize" class="resize-y" r-Type="height" div1=".sjs-height-1" div2=".bcontent-wrap" title="调整大小"><!--调整上下高度条--></div>
  513. <div class="judge-hide">
  514. <div class="bc-bar mb-1">
  515. <ul class="nav nav-tabs">
  516. <li class="nav-item">
  517. <a class="nav-link active" href="#">所属项目节</a>
  518. </li>
  519. <li class="nav-item">
  520. <div class="d-inline-block">
  521. <div class="input-group input-group-sm ml-2">
  522. <div class="input-group-prepend">
  523. <span class="input-group-text" id="basic-addon3">表达式</span>
  524. </div>
  525. <input type="text" class="form-control form-control-sm m-0" id="xmj-camount-expr" readonly="readOnly" autocomplete="off">
  526. </div>
  527. </div>
  528. </li>
  529. </ul>
  530. </div>
  531. <div class="sp-wrap" id="xmj-spread"></div>
  532. </div>
  533. <div class="judge-show" style="display: none;">
  534. <div class="bc-bar mb-1">
  535. <ul class="nav nav-tabs">
  536. <li class="nav-item">
  537. <a class="nav-link active" href="#">计量单元</a>
  538. </li>
  539. <li class="nav-item">
  540. <div class="d-inline-block">
  541. <div class="input-group input-group-sm ml-2">
  542. <div class="input-group-prepend">
  543. <span class="input-group-text" id="basic-addon2">表达式</span>
  544. </div>
  545. <input type="text" class="form-control form-control-sm m-0" id="pos-camount-expr" readonly="readOnly" autocomplete="off">
  546. </div>
  547. </div>
  548. </li>
  549. </ul>
  550. </div>
  551. <div class="sp-wrap" id="pos-spread"></div>
  552. </div>
  553. </div>
  554. </div>
  555. </div>
  556. </div>
  557. </div>
  558. </div>
  559. <script>
  560. let changeMode = parseInt('<%- changeMode %>');
  561. const tenderName = JSON.parse(unescape('<%- escape(JSON.stringify(tender.data.name)) %>'));
  562. const tenderId = '<%- tender.id %>';
  563. const deleteFilePermission = <%- deleteFilePermission %>;
  564. const totalPriceUnit = '<%- tpUnit %>';
  565. const unitPriceUnit = '<%- upUnit %>';
  566. const accountId = parseInt('<%- ctx.session.sessionUser.accountId %>');
  567. const ledgeStatus = '<%- tender.ledger_status %>';
  568. const ledgerConsts = JSON.parse('<%- JSON.stringify(ledgerConsts) %>');
  569. const changeName = JSON.parse(unescape('<%- escape(JSON.stringify(change.name)) %>'));
  570. let changeTp = parseFloat('<%- change.total_price ? change.total_price : 0 %>');
  571. let changePp = parseFloat('<%- change.positive_tp ? change.positive_tp : 0 %>');
  572. let changeNp = parseFloat('<%- change.negative_tp ? change.negative_tp : 0 %>');
  573. let changeVp = parseFloat('<%- change.valuation_tp ? change.valuation_tp : 0 %>');
  574. let changeUp = parseFloat('<%- change.unvaluation_tp ? change.unvaluation_tp : 0 %>');
  575. const changeStatus = parseFloat('<%- change.status %>');
  576. let changeOrder = parseInt('<%- change.order_by %>');
  577. const touristPermission = parseInt('<%- ctx.tender.touristPermission.file %>');
  578. const precision = JSON.parse('<%- JSON.stringify(precision) %>');
  579. const whiteList = JSON.parse('<%- JSON.stringify(whiteList) %>');
  580. const auditConst = JSON.parse('<%- JSON.stringify(auditConst) %>');
  581. let attData = JSON.parse(unescape('<%- escape(JSON.stringify(attList)) %>'));
  582. let currPageFileData = [];
  583. const change_uid = parseInt('<%- change.uid %>');
  584. const settleBills = JSON.parse(unescape('<%- escape(JSON.stringify(settleBills)) %>'));
  585. const settlePos = JSON.parse(unescape('<%- escape(JSON.stringify(settlePos)) %>'));
  586. const auditType = JSON.parse('<%- JSON.stringify(auditType) %>');
  587. autoFlashHeight();
  588. $('a[href="#sub-sp"').click(function() {
  589. if (parseInt(ledgeStatus) === ledgerConsts.uncheck) {
  590. $('#warning-ledger').modal('show');
  591. return false;
  592. }
  593. });
  594. const readOnly = <%- change.readOnly %>;
  595. const revising = <%- revising %>;
  596. const shenpiPower = <%- change.shenpiPower %>;
  597. const filePermission = <%- change.filePermission %>;
  598. const changeSpread = SpreadJsObj.createNewSpread($('#change-spread')[0]);
  599. const changeSpreadSheet = changeSpread.getActiveSheet();
  600. const xmjSpread = SpreadJsObj.createNewSpread($('#xmj-spread')[0]);
  601. let changeList = JSON.parse(unescape('<%- escape(JSON.stringify(changeList)) %>'));
  602. console.log(changeList);
  603. const style1 = new GC.Spread.Sheets.Style();
  604. style1.locked = true;
  605. const changePlanList = JSON.parse(unescape('<%- escape(JSON.stringify(planList)) %>'));
  606. const planList = [];
  607. if (changePlanList.length > 0) {
  608. for (const cp of changePlanList) {
  609. const planIndex = _.findIndex(planList, { code: cp.code, name: cp.name, unit: cp.unit, unit_price: cp.unit_price});
  610. if (planIndex !== -1) {
  611. planList[planIndex].spamount = ZhCalc.add(planList[planIndex].spamount, cp.spamount);
  612. } else {
  613. planList.push(cp);
  614. }
  615. }
  616. }
  617. const openChangeState = <%- ctx.subProject.page_show.openChangeState ? true : false %>;
  618. const startLimit = 10;
  619. const settleStatus = JSON.parse('<%- JSON.stringify(settleStatus) %>');
  620. const removeSettleNum = <%- removeSettleNum %>;
  621. if (removeSettleNum > 0) {
  622. toastr.warning('结算发生变化,已移除 ' + removeSettleNum + ' 条已结算清单。');
  623. }
  624. const changeLedgerList = JSON.parse(unescape('<%- escape(JSON.stringify(changeLedgerList)) %>'));
  625. const changePosList = JSON.parse(unescape('<%- escape(JSON.stringify(changePosList)) %>'));
  626. let ledgerList, posList;
  627. let changeUnits = JSON.parse('<%- JSON.stringify(changeUnits) %>');
  628. changeUnits = _.map(changeUnits, 'unit');
  629. changeUnits.push('');
  630. let changeUsedData = JSON.parse(unescape('<%- escape(JSON.stringify(changeUsedData)) %>'));
  631. const change = JSON.parse(unescape('<%- escape(JSON.stringify(change)) %>'));
  632. const isNewPriceLedgerData = JSON.parse(unescape('<%- escape(JSON.stringify(isNewPriceLedgerData)) %>'));
  633. </script>
  634. <% if (!change.readOnly || change.shenpiPower) { %>
  635. <script>
  636. const unitList = JSON.parse(unescape('<%- escape(JSON.stringify(unitList)) %>'));
  637. let back_changeInfo = {
  638. code: JSON.parse(unescape('<%- escape(JSON.stringify(change.code ? change.code : '')) %>')),
  639. name: JSON.parse(unescape('<%- escape(JSON.stringify(change.name ? change.name : '')) %>')),
  640. peg: JSON.parse(unescape('<%- escape(JSON.stringify(change.peg ? change.peg : '')) %>')),
  641. org_name: JSON.parse(unescape('<%- escape(JSON.stringify(change.org_name ? change.org_name: '')) %>')),
  642. org_code: JSON.parse(unescape('<%- escape(JSON.stringify(change.org_code ? change.org_code : '')) %>')),
  643. new_name: JSON.parse(unescape('<%- escape(JSON.stringify(change.new_name ? change.new_name : '')) %>')),
  644. new_code: JSON.parse(unescape('<%- escape(JSON.stringify(change.new_code ? change.new_code : '')) %>')),
  645. content: JSON.parse(unescape('<%- escape(JSON.stringify(change.content ? ctx.helper.replaceRntoBr(change.content) : '')) %>')),
  646. basis: JSON.parse(unescape('<%- escape(JSON.stringify(change.basis ? ctx.helper.replaceRntoBr(change.basis) : '')) %>')),
  647. expr: JSON.parse(unescape('<%- escape(JSON.stringify(change.expr ? ctx.helper.replaceRntoBr(change.expr) : '')) %>')),
  648. memo: JSON.parse(unescape('<%- escape(JSON.stringify(change.memo ? ctx.helper.replaceRntoBr(change.memo) : '')) %>')),
  649. type: '<%- change.type %>',
  650. class: '<%- ctx.helper._.find(changeClass, { value: change.class }).checked ? change.class : changeClass[0].value %>',// 防止下拉不存在导致数据丢失上报问题
  651. quality: '<%- change.quality %>',
  652. company: JSON.parse(unescape('<%- escape(JSON.stringify((change.company ? change.company : (companyList && companyList[0] ? companyList[0].name : (unitList && unitList[0] ? unitList[0].name : ''))))) %>')),
  653. charge: '<%- change.charge %>',
  654. state: '<%- change.state %>',
  655. w_code: JSON.parse(unescape('<%- escape(JSON.stringify(change.w_code ? change.w_code : '')) %>')),
  656. };
  657. let changeInfo = Object.assign({}, back_changeInfo);
  658. // 判断是否有更改过
  659. function judgeChange() {
  660. let change = false;
  661. if (!isObjEqual(changeInfo, back_changeInfo)) {
  662. change = true;
  663. }
  664. if (change) {
  665. $('#show-save-btn').show();
  666. $('#sp-btn').hide();
  667. $('.title-main').addClass('bg-warning');
  668. } else {
  669. $('#show-save-btn').hide();
  670. $('#sp-btn').show();
  671. $('.title-main').removeClass('bg-warning');
  672. }
  673. }
  674. </script>
  675. <% } %>
  676. <% if (!change.readOnly) { %>
  677. <script>
  678. const shenpi_status = <%- ctx.tender.info.shenpi.change %>;
  679. const shenpiConst = JSON.parse('<%- JSON.stringify(shenpiConst) %>');
  680. const changesUid = <%- change.uid %>;
  681. const openChangeWhiteList = <%- ctx.subProject.page_show.openChangeWhiteList %>;
  682. let deLimit = parseInt('<%- deLimit %>');
  683. console.log(changeInfo);
  684. </script>
  685. <script src="/public/js/change_audit.js"></script>
  686. <% } else { %>
  687. <script>
  688. const auditors2 = JSON.parse(unescape('<%- escape(JSON.stringify(change.auditors2)) %>'));
  689. auditors2.shift();
  690. const aidList = [];
  691. for (let i = 0; i < auditors2.length; i++) {
  692. aidList.push(auditors2[i][0].audit_order);
  693. }
  694. let w_code = JSON.parse(unescape('<%- escape(JSON.stringify(change.w_code ? change.w_code : '')) %>'));
  695. </script>
  696. <% } %>