info.ejs 49 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845
  1. <link rel="stylesheet" type="text/css" href="/public/css/datatable/dataTables.bootstrap4.min.css">
  2. <link rel="stylesheet" type="text/css" href="/public/css/datatable/fixedColumns.bootstrap4.min.css">
  3. <style type="text/css" class="init">
  4. #tablist li .active {
  5. background: #e4e7ea;
  6. font-weight: 600;
  7. }
  8. .qd-table .input-sm{
  9. /*height:calc(1.4125rem + 2px);*/
  10. /*padding:2px;*/
  11. }
  12. .qd-table>tbody>tr>td, .qd-table>tbody>tr>th, .qd-table>tfoot>tr>td, .qd-table>tfoot>tr>th, .qd-table>thead>tr>td, .qd-table>thead>tr>th {
  13. padding:5px 2px
  14. }
  15. #list td input{
  16. width: 100%;
  17. /*font-size: 0.9rem;*/
  18. }
  19. #list td select{
  20. /*width: 100%;*/
  21. /*font-size: 0.9rem;*/
  22. /*vertical-align: middle;*/
  23. /*line-height: calc(1.4125rem + 2px);*/
  24. }
  25. #list td a {
  26. cursor: pointer;
  27. }
  28. .allwidth1{
  29. }
  30. .allwidth2{
  31. }
  32. .allwidth3{
  33. text-align:right;
  34. }
  35. .allwidth3 input{
  36. text-align:right;
  37. }
  38. .allwidth5{
  39. text-align:center;
  40. }
  41. .allwidth4{
  42. text-align:center;
  43. }
  44. div.DTFC_LeftFootWrapper table, div.DTFC_RightFootWrapper table{
  45. border-top: 1px solid #ddd;
  46. }
  47. div.dataTables_scrollFootInner table{
  48. margin-top: 1px !important;
  49. }
  50. table.dataTable{
  51. border-collapse: collapse !important;
  52. }
  53. table.table-bordered.dataTable tbody th, table.table-bordered.dataTable tbody td{
  54. border-bottom-width: 1px;
  55. }
  56. div.dataTables_scrollFootInner table{
  57. margin-top: 0 !important;
  58. }
  59. .bg-con-warp:nth-child(2) th{
  60. text-align: center !important;
  61. }
  62. .change-title {
  63. font-size: 12px;
  64. margin: 0;
  65. height: 34px;
  66. line-height: 34px;
  67. display: block;
  68. }
  69. </style>
  70. <div class="panel-sidebar">
  71. <!--<div class="panel-title">-->
  72. <!--<div class="title-bar">-->
  73. <!--<h2 class="text-truncate" style="white-space:nowrap; overflow:hidden; text-overflow:ellipsis;" data-toggle="tooltip" data-placement="right" title="" data-original-title="<%- tender.name %>"><%- tender.name %></h2>-->
  74. <!--</div>-->
  75. <!--</div>-->
  76. <div class="sidebar-title" data-toggle="tooltip" data-placement="right" data-original-title="<%- tender.name %>">
  77. <%- (tender.name.length > 15 ? tender.name.substring(0,15) + '...' : tender.name) %>
  78. </div>
  79. <div class="scrollbar-auto">
  80. <div class="nav-box">
  81. <ul class="nav-list list-unstyled">
  82. <li class=""><a class="text-primary" href="/tender/<%- tender.id %>/change"><i class="fa fa-chevron-left "></i> <span>返回</span></a></li>
  83. </ul>
  84. </div>
  85. <div class="nav-box">
  86. <ul class="nav nav-tab nav-list list-unstyled" role="tablist" id="tablist" style="display: block">
  87. <li style="margin-bottom: 1rem;"><a href="#info" class="active" aria-controls="info" data-toggle="tab"><span class="ml-3">变更信息</span></a></li>
  88. <li style="margin-bottom: 1rem;"><a href="#bills" aria-controls="bills" data-toggle="tab"><span class="ml-3">变更清单</span></a></li>
  89. <li><a href="#files" aria-controls="files" data-toggle="tab"><span class="ml-3">附件</span></a></li>
  90. </ul>
  91. </div>
  92. <div class="contarl-box">
  93. <!--info状态区分-->
  94. <% if (auditStatus === 1) { %>
  95. <a href="#sub-ap" data-category="up_change" data-toggle="modal" data-target="#sub-ap" class="btn btn-primary btn-sm btn-block">上报审批</a>
  96. <% } else if (auditStatus === 2) { %>
  97. <a href="#sub-sp2" data-category="up_change" data-toggle="modal" data-target="#sub-sp2" class="btn btn-primary btn-sm btn-block">重新上报</a>
  98. <% } else if (auditStatus === 3) { %>
  99. <a href="#sp-list" data-toggle="modal" data-target="#sp-list" class="btn btn-outline-warning btn-sm btn-block text-muted">审批退回</a>
  100. <% } else if (auditStatus === 4) { %>
  101. <a href="#sp-list" data-toggle="modal" data-target="#sp-list" class="btn btn-outline-success btn-sm btn-block">审批完成</a>
  102. <% } else if (auditStatus === 5) { %>
  103. <a href="#sp-list" data-toggle="modal" data-target="#sp-list" class="btn btn-outline-danger btn-sm btn-block">审批终止</a>
  104. <% } else if (auditStatus === 6) { %>
  105. <a href="#sp-done" data-toggle="modal" data-target="#sp-done" class="btn btn-success btn-sm btn-block">审批通过</a>
  106. <a href="#sp-back" data-toggle="modal" data-target="#sp-back" class="btn btn-warning btn-sm btn-block">审批退回</a>
  107. <% } else if (auditStatus === 7) { %>
  108. <a href="#sp-list" data-toggle="modal" data-target="#sp-list" class="btn btn-outline-secondary btn-sm btn-block">审批中</a>
  109. <% } %>
  110. <% if (auditStatus === 4 && ctx.session.sessionUser.accountId === auditList[auditList.length-1].uid) { %>
  111. <% if (stageChangeNum === 0) { %>
  112. <!--重新审批-->
  113. <a href="javascript: void(0);" data-toggle="modal" data-target="#sp-down-back" class="btn btn-warning btn-sm btn-block">重新审批</a>
  114. <% } else { %>
  115. <button class="btn btn-outline-secondary btn-sm btn-block" data-toggle="tooltip" data-placement="bottom" title="已被调用">重新审批</button>
  116. <% } %>
  117. <% } %>
  118. </div>
  119. </div>
  120. </div>
  121. <div class="panel-content">
  122. <div class="panel-title pr-0">
  123. <div class="title-main d-flex justify-content-between">
  124. <h2 id="info_title" class="show_title">变更信息</h2>
  125. <div id="bills_title" class="show_title" style="line-height:34px;display: none">
  126. <div>
  127. <% if (auditStatus === 1 || auditStatus === 2) { %>
  128. <div class="d-inline-block">
  129. <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> 添加台账清单</a>
  130. </div>
  131. <div class="d-inline-block mr-3">
  132. <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> 添加空白清单</a>
  133. </div>
  134. <% } %>
  135. <div class="d-inline-block">
  136. <div class="custom-control custom-checkbox" style="line-height: normal;">
  137. <input type="checkbox" class="custom-control-input change-detail-checkbox" id="customCheck1">
  138. <label class="custom-control-label" for="customCheck1">变更详情</label>
  139. </div>
  140. </div>
  141. <% if (auditStatus === 3 || auditStatus === 4 || auditStatus === 5 || auditStatus === 7) { %>
  142. <div class="d-inline-block ml-3">
  143. <div class="custom-control custom-checkbox" style="line-height: normal;">
  144. <input type="checkbox" class="custom-control-input" id="show-table-detail">
  145. <label class="custom-control-label" for="show-table-detail">审批过程</label>
  146. </div>
  147. </div>
  148. <% } %>
  149. </div>
  150. </div>
  151. <div id="files_title" class="show_title" style="line-height:34px;display: none">
  152. <!-- <% if (auditStatus === 1 || auditStatus === 2 || auditStatus === 6) { %>
  153. <a href="#addfujian" data-toggle="modal" class="btn btn-sm btn-light text-primary" data-placement="bottom" title="" data-original-title="上传附件"><i class="fa fa-cloud-upload" aria-hidden="true"></i> 上传附件</a>
  154. <% } else { %>
  155. <h2 class="change-title">附件</h2>
  156. <% } %> -->
  157. <a href="#addfujian" data-toggle="modal" class="btn btn-sm btn-light text-primary" data-placement="bottom" title="" data-original-title="上传附件"><i class="fa fa-cloud-upload" aria-hidden="true"></i> 上传附件</a>
  158. <a href="javascript: void(0);" data-toggle="modal" class="btn btn-sm btn-light text-primary" id="bach-download"><i class="fa fa-download "></i> 批量下载</a>
  159. <a href="" id="downloadZip" style="display: none;" download></a>
  160. </div>
  161. <input id="tenderId" value="<%= tender.id %>" type="hidden">
  162. <input id="changeId" value="<%= change.cid %>" type="hidden">
  163. <!--info状态区分-->
  164. <% if (auditStatus === 1 || auditStatus === 2) { %>
  165. <div class="ml-auto px-4" id="show-save-btn" style="display: none">
  166. <span>您修改了变更内容,记得保存修改。</span>
  167. <button class="btn btn-sm btn-primary save_change_btn" id="save_change"><i class="fa fa-save"></i> 保存修改</button>
  168. <button class="btn btn-sm btn-light" id="cancel_change">取消</button>
  169. </div>
  170. <% } %>
  171. </div>
  172. </div>
  173. <div class="content-wrap tab-content">
  174. <div class="c-body tab-pane active" role="tabpanel" id="info">
  175. <div class="sjs-height-0 container-fluid">
  176. <!--变更信息-->
  177. <% if (auditStatus === 1 || auditStatus === 2) { %>
  178. <form action="/tender/<%- change.tid %>/change/save?_csrf=<%= ctx.csrf %>" method="post" id="change_form">
  179. <div class="row">
  180. <div class="col-md-4">
  181. <div class="form-group">
  182. <label><b class="text-danger">*&nbsp;</b>申请编号</label>
  183. <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>
  184. <input class="form-control form-control-sm" name="code" value="<%- change.code %>" type="text">
  185. </div>
  186. <div class="form-group">
  187. <label><b class="text-danger">*&nbsp;</b>工程名称</label>
  188. <input class="form-control form-control-sm" name="name" value="<%- change.name %>" type="text">
  189. </div>
  190. <div class="form-group">
  191. <label>桩号</label>
  192. <input class="form-control form-control-sm" name="peg" value="<%- change.peg %>" type="text">
  193. </div>
  194. <div class="form-group">
  195. <label>原设计图名称</label>
  196. <input class="form-control form-control-sm" name="org_name" placeholder="" type="text" value="<%- change.org_name %>">
  197. </div>
  198. <div class="form-group">
  199. <label>原图号</label>
  200. <input class="form-control form-control-sm" name="org_code" placeholder="" type="text" value="<%- change.org_code %>">
  201. </div>
  202. <div class="form-group">
  203. <label>变更设计图名称</label>
  204. <input class="form-control form-control-sm" name="new_name" placeholder="" type="text" value="<%- change.new_name %>">
  205. </div>
  206. <div class="form-group">
  207. <label>变更图号</label>
  208. <input class="form-control form-control-sm" name="new_code" placeholder="" type="text" value="<%- change.new_code %>">
  209. </div>
  210. </div>
  211. <div class="col-md-4" style="z-index:999">
  212. <div class="form-group">
  213. <label><b class="text-danger">*&nbsp;</b>工程变更理由及内容</label>
  214. <textarea class="form-control form-control-sm" name="content" rows="6"><%- change.content %></textarea>
  215. </div>
  216. <div class="form-group">
  217. <label>工程变更合同依据</label>
  218. <textarea class="form-control form-control-sm" name="basis" rows="6"><%- change.basis %></textarea>
  219. </div>
  220. <div class="form-group">
  221. <label>变更工程量数量计算式</label>
  222. <textarea class="form-control form-control-sm" name="expr" rows="2"><%- change.expr %></textarea>
  223. </div>
  224. <div class="form-group">
  225. <label>备注</label>
  226. <textarea class="form-control form-control-sm" name="memo" rows="3"><%- change.memo %></textarea>
  227. </div>
  228. </div>
  229. <div class="col-md-4">
  230. <div class="form-group">
  231. <label>变更类型</label>
  232. <div class="checkbox">
  233. <% const changeType = change.type !== null && change.type !== '' ? change.type.split(',') : '' %>
  234. <% for (const t in changeConst.type) { %>
  235. <% const cType = changeConst.type[t] %>
  236. <label class="checkbox-inline">
  237. <input value="<%- cType.value %>" name="type[]"
  238. type="checkbox"<% if (changeType.indexOf(cType.value.toString()) !== -1) { %> checked<% } %>><%- cType.name %>
  239. </label>
  240. <% } %>
  241. </div>
  242. </div>
  243. <div class="form-group">
  244. <label>变更类别 </label>
  245. <select class="form-control form-control-sm" name="class">
  246. <% for (const c in changeConst.class) { %>
  247. <% const cClass = changeConst.class[c] %>
  248. <option value="<%- cClass.value %>"<% if (cClass.value === change.class) { %> selected<% } %>><%- cClass.name %></option>
  249. <% } %>
  250. </select>
  251. </div>
  252. <div class="form-group">
  253. <label>变更性质 </label>
  254. <select class="form-control form-control-sm" name="quality">
  255. <% for (const q in changeConst.quality) { %>
  256. <% const cQuality = changeConst.quality[q] %>
  257. <option value="<%- cQuality.value %>"<% if (cQuality.value === change.quality) { %> selected<% } %>><%- cQuality.name %></option>
  258. <% } %>
  259. </select>
  260. </div>
  261. <div class="form-group">
  262. <label>变更提出单位</label>
  263. <a href="#editcompany" style="float:right;" class="" data-toggle="modal">编辑</a>
  264. <select class="form-control form-control-sm" id="company" name="company">
  265. <% for (const company of companyList) { %>
  266. <option <% if (company.name === change.company) { %>selected<% } %>><%- company.name %></option>
  267. <% } %>
  268. </select>
  269. </div>
  270. <div class="form-group">
  271. <label>费用承担方</label>
  272. <div class="radio">
  273. <% for (const c in changeConst.charge) { %>
  274. <% const cCharge = changeConst.charge[c] %>
  275. <label class="radio-inline">
  276. <input value="<%- cCharge.value %>" name="charge" type="radio"<% if (cCharge.value === change.charge) { %> checked<% } %>> <%- cCharge.name %>
  277. </label>
  278. <% } %>
  279. </div>
  280. </div>
  281. </div>
  282. </div>
  283. <!--清单、附件、审批人上传数据-->
  284. <input type="hidden" name="changelist" id="change-list" value="<%= changeListData %>">
  285. <input type="hidden" name="changewhitelist" id="change-whitelist" value="<%= changeWhiteListData %>">
  286. <input type="hidden" name="changeaudit" id="changeaudit" value="">
  287. <input type="hidden" name="changestatus" id="changeStatus">
  288. <input type="hidden" name="cid" value="<%= change.cid %>">
  289. <!--保留旧数据回溯-->
  290. <input type="hidden" id="back-change-list" value="<%= changeListData %>">
  291. <input type="hidden" id="back-change-whitelist" value="<%= changeWhiteListData %>">
  292. </form>
  293. <% } else { %>
  294. <div class="row">
  295. <div class="col-md-4">
  296. <form>
  297. <div class="form-group">
  298. <label>申请编号</label>
  299. <input class="form-control form-control-sm" value="<%- change.code %>" type="text" readonly>
  300. </div>
  301. <% if (auditStatus === 4) { %>
  302. <div class="form-group">
  303. <label>变更令号(批复编号)</label>
  304. <input class="form-control form-control-sm" value="<%- change.p_code %>" type="text" readonly>
  305. </div>
  306. <% } %>
  307. <div class="form-group">
  308. <label>工程名称</label>
  309. <input class="form-control form-control-sm" value="<%- change.name %>" type="text" readonly>
  310. </div>
  311. <div class="form-group">
  312. <label>桩号</label>
  313. <input class="form-control form-control-sm" value="<%- change.peg %>" type="text" readonly>
  314. </div>
  315. <div class="form-group">
  316. <label>原设计图名称</label>
  317. <input class="form-control form-control-sm" placeholder="" type="text" value="<%- change.org_name %>" readonly>
  318. </div>
  319. <div class="form-group">
  320. <label>原图号</label>
  321. <input class="form-control form-control-sm" placeholder="" type="text" value="<%- change.org_code %>" readonly>
  322. </div>
  323. <div class="form-group">
  324. <label>变更设计图名称</label>
  325. <input class="form-control form-control-sm" placeholder="" type="text" value="<%- change.new_name %>" readonly>
  326. </div>
  327. <div class="form-group">
  328. <label>变更图号</label>
  329. <input class="form-control form-control-sm" placeholder="" type="text" value="<%- change.new_code %>" readonly>
  330. </div>
  331. </form>
  332. </div>
  333. <div class="col-md-4" style="z-index:999">
  334. <form>
  335. <div class="form-group">
  336. <label>工程变更理由及内容</label>
  337. <textarea class="form-control form-control-sm" rows="6" readonly><%- change.content %></textarea>
  338. </div>
  339. <div class="form-group">
  340. <label>工程变更合同依据</label>
  341. <textarea class="form-control form-control-sm" rows="6" readonly><%- change.basis %></textarea>
  342. </div>
  343. <div class="form-group">
  344. <label>变更工程量数量计算式</label>
  345. <textarea class="form-control form-control-sm" rows="2" readonly><%- change.expr %></textarea>
  346. </div>
  347. <div class="form-group">
  348. <label>备注</label>
  349. <textarea class="form-control form-control-sm" rows="3" readonly><%- change.memo %></textarea>
  350. </div>
  351. </form>
  352. </div>
  353. <div class="col-md-4">
  354. <form>
  355. <div class="form-group">
  356. <label>变更类型</label>
  357. <div class="checkbox">
  358. <% const changeType = change.type !== null && change.type !== '' ? change.type.split(',') : '' %>
  359. <% for (const t in changeConst.type) { %>
  360. <% const cType = changeConst.type[t] %>
  361. <label class="checkbox-inline">
  362. <% if (changeType.indexOf(cType.value.toString()) !== -1) { %>
  363. <input value="<%- cType.value %>" type="checkbox" disabled checked><%- cType.name %>
  364. <% } %>
  365. </label>
  366. <% } %>
  367. </div>
  368. </div>
  369. <div class="form-group">
  370. <label>变更类别 </label>
  371. <select class="form-control form-control-sm" disabled>
  372. <% for (const c in changeConst.class) { %>
  373. <% const cClass = changeConst.class[c] %>
  374. <% if (cClass.value === change.class) { %>
  375. <option value="<%- cClass.value %>"><%- cClass.name %></option>
  376. <% } %>
  377. <% } %>
  378. </select>
  379. </div>
  380. <div class="form-group">
  381. <label>变更性质 </label>
  382. <select class="form-control form-control-sm" disabled>
  383. <% for (const q in changeConst.quality) { %>
  384. <% const cQuality = changeConst.quality[q] %>
  385. <% if (cQuality.value === change.quality) { %>
  386. <option value="<%- cQuality.value %>"><%- cQuality.name %></option>
  387. <% } %>
  388. <% } %>
  389. </select>
  390. </div>
  391. <div class="form-group">
  392. <label>变更提出单位</label>
  393. <select class="form-control form-control-sm" disabled>
  394. <option><%- change.company %></option>
  395. </select>
  396. </div>
  397. <div class="form-group">
  398. <label>费用承担方</label>
  399. <div class="radio">
  400. <% for (const c in changeConst.charge) { %>
  401. <% const cCharge = changeConst.charge[c] %>
  402. <label class="radio-inline">
  403. <% if (cCharge.value === change.charge) { %>
  404. <input value="<%- cCharge.value %>" type="radio" disabled checked> <%- cCharge.name %>
  405. <% } %>
  406. </label>
  407. <% } %>
  408. </div>
  409. </div>
  410. <div class="form-group">
  411. <label>批复文号</label>
  412. <input class="form-control form-control-sm" id="w_code" placeholder="" type="text" value="<%- change.w_code %>" <% if (auditStatus !== 6) { %>readonly<% } %>>
  413. </div>
  414. </form>
  415. </div>
  416. </div>
  417. <% } %>
  418. </div>
  419. </div>
  420. <div class="c-body tab-pane first-bill-pane" role="tabpanel" id="bills">
  421. <div class="sjs-height-0">
  422. <!--变更清单-->
  423. <% if (auditStatus === 1 || auditStatus === 2) { %>
  424. <table class="table table-striped table-bordered nowrap qd-table table-list" id="tablelist" cellspacing="0" style="margin-top:0 !important;width:100%">
  425. <thead>
  426. <tr>
  427. <th rowspan="2" class="text-center">清单编号</th>
  428. <th rowspan="2" class="text-center">名称</th>
  429. <th rowspan="2" class="text-center">变更部位</th>
  430. <th rowspan="2" class="text-center">变更详情</th>
  431. <th rowspan="2" class="text-center">单位</th>
  432. <th rowspan="2" class="text-center">单价</th>
  433. <th colspan="2" class="text-center">原设计</th>
  434. <th colspan="2" class="text-center">申报变更增(+)减(-)</th>
  435. <th rowspan="2" class="text-center">操作</th>
  436. </tr>
  437. <tr>
  438. <th class="text-center">数量</th>
  439. <th class="text-center">金额</th>
  440. <th class="text-center">数量</th>
  441. <th class="text-center">金额</th>
  442. </tr>
  443. </thead>
  444. <tbody id="list">
  445. <% let windex = 0; %>
  446. <% for (const [index,cl] of changeList.entries()) { %>
  447. <% if (cl.lid !== '0') { %>
  448. <tr class="clist clid" data-lid="<%= cl.lid %>_<%= index %>" data-index="<%= index %>">
  449. <td data-site="0"><%= cl.code %></td>
  450. <td data-site="1"><%= cl.name %></td>
  451. <td data-site="2"><%= cl.bwmx %></td>
  452. <td data-site="3"><input class="form-control form-control-sm" placeholder="变更详情" type="text" value="<%= cl.detail %>"></td>
  453. <td data-site="4"><%= cl.unit %></td>
  454. <td data-site="5"><%= ctx.helper.roundNum(cl.unit_price, upUnit) %></td>
  455. <td data-site="6"><%= ctx.helper.roundNum(cl.oamount, ctx.helper.findDecimal(cl.unit)) %></td>
  456. <td data-site="7"><%= ctx.helper.mul(cl.unit_price, cl.oamount, tpUnit) %></td>
  457. <td data-site="8"><input class="form-control form-control-sm" placeholder="变更数量" type="text" onkeyup="RegNum(this,event,<%= ctx.helper.findDecimal(cl.unit) %>)" value="<%= ctx.helper.roundNum(cl.camount, ctx.helper.findDecimal(cl.unit)) %>"></td>
  458. <td data-site="9"><%= ctx.helper.mul(cl.unit_price, cl.camount, tpUnit) %></td>
  459. <td><a class="text-danger">移除</a>
  460. </td>
  461. </tr>
  462. <% } else { %>
  463. <tr class="clist" data-lid="<%= windex %>" data-index="<%= windex %>">
  464. <td data-site="0"><input class="form-control form-control-sm" placeholder="清单编号" type="text" value="<%= cl.code %>"></td>
  465. <td data-site="1"><input class="form-control form-control-sm" placeholder="名称" type="text" value="<%= cl.name %>"></td>
  466. <td data-site="2"><input class="form-control form-control-sm" placeholder="变更部位" type="text" value="<%= cl.bwmx %>"></td>
  467. <td data-site="3"><input class="form-control form-control-sm" placeholder="变更详情" type="text" value="<%= cl.detail %>"></td>
  468. <td data-site="4">
  469. <select class="form-control form-control-sm input-sm">
  470. <option></option>
  471. <% for (const j in changeUnits) { %>
  472. <% if (changeUnits[j].unit !== undefined && changeUnits[j].unit === cl.unit) { %>
  473. <option selected="selected"><%= changeUnits[j].unit %></option>
  474. <% } else if(changeUnits[j].unit !== undefined) { %>
  475. <option><%= changeUnits[j].unit %></option>
  476. <% } %>
  477. <% } %>
  478. </select>
  479. </td>
  480. <td data-site="5"><input class="form-control form-control-sm" placeholder="单价" onkeyup="RegNum(this,event, <%= upUnit %>)" type="text" value="<%= ctx.helper.roundNum(cl.unit_price, upUnit) %>"></td>
  481. <td data-site="6"><input class="form-control form-control-sm" placeholder="数量" onkeyup="RegNum(this,event,<%= ctx.helper.findDecimal(cl.unit) %>)" type="text" value="<%= ctx.helper.roundNum(cl.oamount, ctx.helper.findDecimal(cl.unit)) %>"></td>
  482. <td data-site="7"><%= ctx.helper.mul(cl.unit_price, cl.oamount, tpUnit) %></td>
  483. <td data-site="8"><input class="form-control form-control-sm" placeholder="变更数量" onkeyup="RegNum(this,event,<%= ctx.helper.findDecimal(cl.unit) %>)" type="text" value="<%= ctx.helper.roundNum(cl.camount, ctx.helper.findDecimal(cl.unit)) %>"></td>
  484. <td data-site="9"><%= ctx.helper.mul(cl.unit_price, cl.camount, tpUnit) %></td>
  485. <td><a class="text-danger">移除</a>
  486. </td>
  487. </tr>
  488. <% windex++ %>
  489. <% } %>
  490. <% } %>
  491. </tbody>
  492. <tfoot>
  493. <tr class="info">
  494. <td>合计</td><td></td><td></td><td></td><td></td><td></td><td></td>
  495. <td class="otatalamount"><%= ctx.helper.roundNum(ototalCost, tpUnit) %></td><td></td>
  496. <td class="ctatalamount"><%= ctx.helper.roundNum(ctotalCost, tpUnit) %></td><td></td>
  497. </tr>
  498. </tfoot>
  499. </table>
  500. <% } else if (auditStatus === 3 || auditStatus === 4 || auditStatus === 5 || auditStatus === 7) { %>
  501. <table class="table table-striped table-bordered nowrap qd-table table-list" id="tablelist" cellspacing="0" style="width:100%">
  502. <thead>
  503. <tr>
  504. <th rowspan="2" class="text-center">清单编号</th>
  505. <th rowspan="2" class="text-center">名称</th>
  506. <th rowspan="2" class="text-center">变更部位</th>
  507. <th rowspan="2" class="text-center">变更详情</th>
  508. <th rowspan="2" class="text-center">单位</th>
  509. <th rowspan="2" class="text-center">单价</th>
  510. <th colspan="2" class="text-center">原设计</th>
  511. <th colspan="2" class="text-center">申报变更增(+)减(-)</th>
  512. <th colspan="2" class="text-center">审批后变更</th>
  513. </tr>
  514. <tr>
  515. <th class="text-center">数量</th>
  516. <th class="text-center">金额</th>
  517. <th class="text-center">数量</th>
  518. <th class="text-center">金额</th>
  519. <th class="text-center">数量</th>
  520. <th class="text-center">金额</th>
  521. </tr>
  522. </thead>
  523. <tbody id="list">
  524. <% for (const cl of changeList) { %>
  525. <tr>
  526. <td><%= cl.code %></td>
  527. <td><%= cl.name %></td>
  528. <td><%= cl.bwmx %></td>
  529. <td><%= cl.detail %></td>
  530. <td><%= cl.unit %></td>
  531. <td><%= ctx.helper.roundNum(cl.unit_price, upUnit) %></td>
  532. <td><%= ctx.helper.roundNum(cl.oamount, ctx.helper.findDecimal(cl.unit)) %></td>
  533. <td><%= ctx.helper.mul(cl.unit_price, cl.oamount, tpUnit) %></td>
  534. <td><%= ctx.helper.roundNum(cl.camount, ctx.helper.findDecimal(cl.unit)) %></td>
  535. <td><%= ctx.helper.mul(cl.unit_price, cl.camount, tpUnit) %></td>
  536. <td><%= cl.samount !== '' ? ctx.helper.roundNum(cl.samount, ctx.helper.findDecimal(cl.unit)) : '' %></td>
  537. <td><%= cl.samount !== '' ? ctx.helper.mul(cl.unit_price, cl.samount, tpUnit) : '' %></td>
  538. </td>
  539. </tr>
  540. <% } %>
  541. </tbody>
  542. <tfoot>
  543. <tr class="info">
  544. <td>合计</td><td></td><td></td><td></td><td></td><td></td><td></td>
  545. <td><%= ctx.helper.roundNum(ototalCost, tpUnit) %></td><td></td>
  546. <td><%= ctx.helper.roundNum(ctotalCost, tpUnit) %></td><td></td>
  547. <td><%= stotalCost !== 0 ? ctx.helper.roundNum(stotalCost, tpUnit) : '' %></td>
  548. </tr>
  549. </tfoot>
  550. </table>
  551. <table class="table table-striped table-bordered nowrap qd-table table-list" id="tablelist2" cellspacing="0" style="width:100%;display: none;">
  552. <thead>
  553. <tr>
  554. <th rowspan="2" class="text-center">清单编号</th>
  555. <th rowspan="2" class="text-center">名称</th>
  556. <th rowspan="2" class="text-center">变更部位</th>
  557. <th rowspan="2" class="text-center">变更详情</th>
  558. <th rowspan="2" class="text-center">单位</th>
  559. <th rowspan="2" class="text-center">单价</th>
  560. <th colspan="2" class="text-center">原设计</th>
  561. <th colspan="2" class="text-center">申报变更增(+)减(-)</th>
  562. <% for (const audit of auditList2) { %>
  563. <% if (audit.usite !== 0) { %>
  564. <th colspan="2" class="text-center"><%= audit.name %> 审批</th>
  565. <% } %>
  566. <% } %>
  567. </tr>
  568. <tr>
  569. <th class="text-center">数量</th>
  570. <th class="text-center">金额</th>
  571. <th class="text-center">数量</th>
  572. <th class="text-center">金额</th>
  573. <% for (const audit of auditList2) { %>
  574. <% if (audit.usite !== 0) { %>
  575. <th class="text-center">数量</th>
  576. <th class="text-center">金额</th>
  577. <% } %>
  578. <% } %>
  579. </tr>
  580. </thead>
  581. <tbody id="list">
  582. <% const audittotalCost = []; %>
  583. <% for (const [cindex,cl] of changeList.entries()) { %>
  584. <tr>
  585. <td><%= cl.code %></td>
  586. <td><%= cl.name %></td>
  587. <td><%= cl.bwmx %></td>
  588. <td><%= cl.detail %></td>
  589. <td><%= cl.unit %></td>
  590. <td><%= ctx.helper.roundNum(cl.unit_price, upUnit) %></td>
  591. <td><%= ctx.helper.roundNum(cl.oamount, ctx.helper.findDecimal(cl.unit)) %></td>
  592. <td><%= ctx.helper.mul(cl.unit_price, cl.oamount, tpUnit) %></td>
  593. <td><%= ctx.helper.roundNum(cl.camount, ctx.helper.findDecimal(cl.unit)) %></td>
  594. <td><%= ctx.helper.mul(cl.unit_price, cl.camount, tpUnit) %></td>
  595. <% for (const audit of auditList2) { %>
  596. <% if (audit.usite !== 0) { %>
  597. <td><%= audit.list_amount[cindex] !== undefined ? ctx.helper.roundNum(audit.list_amount[cindex], ctx.helper.findDecimal(cl.unit)) : '' %></td>
  598. <td><%= audit.list_amount[cindex] !== undefined ? ctx.helper.mul(cl.unit_price, audit.list_amount[cindex], tpUnit) : '' %></td>
  599. <% } %>
  600. <% } %>
  601. </td>
  602. </tr>
  603. <% } %>
  604. </tbody>
  605. <tfoot>
  606. <tr class="info">
  607. <td>合计</td><td></td><td></td><td></td><td></td><td></td><td></td>
  608. <td><%= ctx.helper.roundNum(ototalCost, tpUnit) %></td><td></td>
  609. <td><%= ctx.helper.roundNum(ctotalCost, tpUnit) %></td>
  610. <% for (const audit of auditList2) { %>
  611. <% if (audit.usite !== 0) { %>
  612. <td></td><td><%=audit.totalCost !== 0 ? ctx.helper.roundNum(audit.totalCost, tpUnit) : '' %></td>
  613. <% } %>
  614. <% } %>
  615. </tr>
  616. </tfoot>
  617. </table>
  618. <% } else if (auditStatus === 6) { %>
  619. <table class="table table-striped table-bordered nowrap qd-table table-list" id="tablelist" cellspacing="0" style="width:100%;">
  620. <thead>
  621. <tr>
  622. <th rowspan="2" class="text-center">清单编号</th>
  623. <th rowspan="2" class="text-center">名称</th>
  624. <th rowspan="2" class="text-center">变更部位</th>
  625. <th rowspan="2" class="text-center">变更详情</th>
  626. <th rowspan="2" class="text-center">单位</th>
  627. <th rowspan="2" class="text-center">单价</th>
  628. <th colspan="2" class="text-center">原设计</th>
  629. <th colspan="2" class="text-center">申报变更增(+)减(-)</th>
  630. <% for (const audit of auditList) { %>
  631. <% if (audit.usite !== 0) { %>
  632. <th colspan="2" class="text-center"><%= audit.name %> 审批</th>
  633. <% } %>
  634. <% } %>
  635. </tr>
  636. <tr>
  637. <th class="text-center">数量</th>
  638. <th class="text-center">金额</th>
  639. <th class="text-center">数量</th>
  640. <th class="text-center">金额</th>
  641. <% for (const audit of auditList) { %>
  642. <% if (audit.usite !== 0) { %>
  643. <th class="text-center">数量</th>
  644. <th class="text-center">金额</th>
  645. <% } %>
  646. <% } %>
  647. </tr>
  648. </thead>
  649. <tbody id="list">
  650. <% const audittotalCost = []; %>
  651. <% for (const [cindex,cl] of changeList.entries()) { %>
  652. <tr class="clist" data-lid="<%= cl.id %>">
  653. <td><%= cl.code %></td>
  654. <td><%= cl.name %></td>
  655. <td><%= cl.bwmx %></td>
  656. <td><%= cl.detail %></td>
  657. <td><%= cl.unit %></td>
  658. <td data-site="5"><%= ctx.helper.roundNum(cl.unit_price, upUnit) %></td>
  659. <td><%= ctx.helper.roundNum(cl.oamount, ctx.helper.findDecimal(cl.unit)) %></td>
  660. <td><%= ctx.helper.mul(cl.unit_price, cl.oamount, tpUnit) %></td>
  661. <td><%= ctx.helper.roundNum(cl.camount, ctx.helper.findDecimal(cl.unit)) %></td>
  662. <td><%= ctx.helper.mul(cl.unit_price, cl.camount, tpUnit) %></td>
  663. <% for (const audit of auditList) { %>
  664. <% if (audit.usite !== 0) { %>
  665. <% if (uid === audit.uid && audit.status === 2) { %>
  666. <td>
  667. <input class="form-control form-control-sm" style="min-width:80px" placeholder="变更数量" type="text"
  668. onkeyup="RegNum(this,event,<%= ctx.helper.findDecimal(cl.unit) %>)"
  669. value="<%= audit.list_amount[cindex] !== undefined ?
  670. ctx.helper.roundNum(audit.list_amount[cindex], ctx.helper.findDecimal(cl.unit)) : '' %>">
  671. </td>
  672. <% } else { %>
  673. <td><%= audit.list_amount[cindex] !== undefined ? ctx.helper.roundNum(audit.list_amount[cindex], ctx.helper.findDecimal(cl.unit)) : '' %></td>
  674. <% } %>
  675. <td<% if (uid === audit.uid) { %> class="amount_cost"<% } %>><%= audit.list_amount[cindex] !== undefined ? ctx.helper.mul(cl.unit_price, audit.list_amount[cindex], tpUnit) : '' %></td>
  676. <% } %>
  677. <% } %>
  678. </td>
  679. </tr>
  680. <% } %>
  681. </tbody>
  682. <tfoot>
  683. <tr class="info">
  684. <td>合计</td><td></td><td></td><td></td><td></td><td></td><td></td>
  685. <td><%= ctx.helper.roundNum(ototalCost, tpUnit) %></td><td></td>
  686. <td><%= ctx.helper.roundNum(ctotalCost, tpUnit) %></td>
  687. <% for (const audit of auditList) { %>
  688. <% if (audit.usite !== 0) { %>
  689. <td></td><td <% if (uid === audit.uid) { %>class="amount_totalcost"<% } %>><%=audit.totalCost !== 0 ? ctx.helper.roundNum(audit.totalCost, tpUnit) : '' %></td>
  690. <% } %>
  691. <% } %>
  692. </tr>
  693. </tfoot>
  694. </table>
  695. <% } %>
  696. </div>
  697. </div>
  698. <a href="" id="file-upload" target="_blank" style="display: none;"></a>
  699. <div class="c-body tab-pane" role="tabpanel" id="files">
  700. <div class="sjs-height-0">
  701. <table class="table table-bordered">
  702. <thead>
  703. <tr>
  704. <td width="25" style="background-color: #e9ecef;"><input type="checkbox" id="check-all-file" ></td>
  705. <th width="50">序号</th>
  706. <th>名称</th>
  707. <th width="90">大小</th>
  708. <th width="100">上传时间</th>
  709. <th width="100">操作</th>
  710. </tr>
  711. </thead>
  712. <tbody id="attList">
  713. <% if (attList !== undefined && attList !== '') { %>
  714. <% for (const [index,att] of attList.entries()) { %>
  715. <tr>
  716. <td width="25"><input type="checkbox" class="check-file" file-id=<%- att.id %>></td>
  717. <td><%- index+1 %></td>
  718. <td><a href="javascript: void(0);" class="file-atn" f-id="<%- att.id %>"><%- att.filename %><%- att.fileext %></a></td>
  719. <td><%- ctx.helper.bytesToSize(att.filesize) %></td>
  720. <td><%- moment(att.in_time * 1000).format('YYYY-MM-DD') %></td>
  721. <td>
  722. <a href="/change/download/file/<%- att.id %>" class="btn btn-light btn-sm" title="下载"><span class="fa fa-download text-primary"></span></a>
  723. <% if (att.uid === uid && (auditStatus === 4 ? Boolean(att.extra_upload) : true )) { %>
  724. <a class="btn btn-light btn-sm delete-file" data-attid="<%- att.id %>" title="删除附件"><span class="fa fa-trash text-danger"></span></a>
  725. <% } %>
  726. </td>
  727. </tr>
  728. <% } %>
  729. <% } %>
  730. </tbody>
  731. </table>
  732. </div>
  733. </div>
  734. </div>
  735. </div>
  736. <script>
  737. let table = '';
  738. const totalPriceUnit = '<%- tpUnit %>';
  739. const unitPriceUnit = '<%- upUnit %>';
  740. const accountId = '<%- uid %>';
  741. const ledgeStatus = '<%- tender.ledger_status %>';
  742. const ledgerConsts = JSON.parse('<%- JSON.stringify(ledgerConsts) %>');
  743. const auditStatus = '<%- auditStatus %>'
  744. const auditList = JSON.parse('<%- JSON.stringify(auditList) %>');
  745. autoFlashHeight();
  746. $('a[href="#sub-ap"').click(function() {
  747. if (parseInt(ledgeStatus) === ledgerConsts.uncheck) {
  748. $('#warning-ledger').modal('show');
  749. return false
  750. }
  751. });
  752. </script>
  753. <script src="/public/js/datatable/jquery.dataTables.min.js"></script>
  754. <script src="/public/js/datatable/dataTables.bootstrap4.min.js"></script>
  755. <script src="/public/js/datatable/dataTables.fixedColumns.min.js"></script>
  756. <script src="/public/js/datatable/jlzf-change-table.js"></script>
  757. <script src="/public/js/change_calculation.js"></script>
  758. <script>
  759. const whiteList = JSON.parse('<%- JSON.stringify(whiteList) %>');
  760. </script>
  761. <% if (auditStatus === 1 || auditStatus === 2) { %>
  762. <script>
  763. const changeUnits = JSON.parse('<%- JSON.stringify(changeUnits) %>');
  764. const precision = JSON.parse('<%- JSON.stringify(precision) %>');
  765. const accountGroup = JSON.parse('<%- JSON.stringify(accountGroup) %>');
  766. const accountList = JSON.parse('<%- JSON.stringify(accountList) %>');
  767. const shenpi_status = <%- ctx.tender.info.shenpi.change %>;
  768. const shenpiConst = JSON.parse('<%- JSON.stringify(shenpiConst) %>');
  769. const changesUid = <%- change.uid %>;
  770. const billsTable = {
  771. columnDefs: [
  772. { className: 'allwidth1', width: 100, targets: 0 },
  773. { className: 'allwidth2', width: 150, targets: [1,2,3] },
  774. { className: 'allwidth4', width: 40, targets: 10 },
  775. { className: 'allwidth5', width: 60, targets: 4 },
  776. { className: 'allwidth3',width: 80, targets: '_all' }
  777. ],
  778. fixedColumns: {
  779. leftColumns: 6
  780. }
  781. }
  782. let back_changeInfo = {
  783. code: '<%- change.code %>',
  784. name: '<%- change.name %>',
  785. peg: '<%- change.peg %>',
  786. org_name: '<%- change.org_name %>',
  787. org_code: '<%- change.org_code %>',
  788. new_name: '<%- change.new_name %>',
  789. new_code: '<%- change.new_code %>',
  790. content: '<%- ctx.helper.replaceRntoBr(change.content) %>',
  791. basis: '<%- ctx.helper.replaceRntoBr(change.basis) %>',
  792. expr: '<%- ctx.helper.replaceRntoBr(change.expr) %>',
  793. memo: '<%- ctx.helper.replaceRntoBr(change.memo) %>',
  794. type: '<%- change.type %>',
  795. class: '<%- change.class %>',
  796. quality: '<%- change.quality %>',
  797. company: '<%- change.company %>',
  798. charge: '<%- change.charge %>',
  799. };
  800. let changeInfo = Object.assign({}, back_changeInfo);
  801. </script>
  802. <script src="/public/js/decimal.min.js"></script>
  803. <script src="/public/js/zh_calc.js"></script>
  804. <script src="/public/js/path_tree.js"></script>
  805. <script src="/public/js/gcl_gather.js"></script>
  806. <script src="/public/js/jquery/jquery.form.min.js"></script>
  807. <script src="/public/js/change_set.js"></script>
  808. <% } else if (auditStatus === 3 || auditStatus === 4 || auditStatus === 5 || auditStatus === 7) { %>
  809. <script>
  810. const billsTable = {
  811. columnDefs: [
  812. { className: 'allwidth1', width: 100, targets: 0 },
  813. { className: 'allwidth2', width: 150, targets: [1,2,3] },
  814. { className: 'allwidth5', width: 60, targets: 4 },
  815. { className: 'allwidth3',width: 80, targets: '_all' }
  816. ],
  817. fixedColumns: {
  818. leftColumns: 6
  819. }
  820. }
  821. </script>
  822. <script src="/public/js/change_show.js"></script>
  823. <% } else if (auditStatus === 6) { %>
  824. <script>
  825. const billsTable = {
  826. columnDefs: [
  827. { className: 'allwidth1', width: 100, targets: 0 },
  828. { className: 'allwidth2', width: 150, targets: [1,2,3] },
  829. { className: 'allwidth5', width: 60, targets: 4 },
  830. { className: 'allwidth3',width: 80, targets: '_all' }
  831. ],
  832. fixedColumns: {
  833. leftColumns: 6
  834. }
  835. }
  836. </script>
  837. <script src="/public/js/change_approval.js"></script>
  838. <% } %>
  839. <script src="/public/js/change_detail.js"></script>