fun.ejs 48 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699
  1. <% include ./sub_menu.ejs %>
  2. <div class="panel-content">
  3. <div class="panel-title">
  4. <div class="title-main">
  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-8">
  13. <div class=row>
  14. <div class="col-6">
  15. <div class="card mb-3">
  16. <div class="card-header d-flex justify-content-between">
  17. <div>台账分解</div>
  18. </div>
  19. <div class="card-body">
  20. <div class="form-group mb-1">
  21. <div>
  22. <div class="form-check">
  23. <input class="form-check-input" type="checkbox" id="pos_calc_detail" name="pos_calc_detail" <% if(ctx.subProject.page_show.posCalcDetail) { %>checked<% } %> onchange="updateSetting();">
  24. <label class="form-check-label" for="pos_calc_detail">设计量明细</label>
  25. </div>
  26. <div class="form-check">
  27. <input class="form-check-input" type="checkbox" id="ledger_ass" name="ledger_ass" <% if(funRela.ledgerAss) { %>checked<% } %> onchange="updateSetting();">
  28. <label class="form-check-label" for="ledger_ass">台账协同</label>
  29. </div>
  30. </div>
  31. </div>
  32. </div>
  33. </div>
  34. </div>
  35. </div>
  36. <div class="row">
  37. <div class="col-6">
  38. <div class="card mb-3">
  39. <div class="card-header d-flex justify-content-between">
  40. <div>超计控制</div>
  41. </div>
  42. <div class="card-body">
  43. <div class="form-group mb-1">
  44. <div>
  45. <div class="form-check">
  46. <input class="form-check-input" type="checkbox" id="ban_over" name="ban_over" <% if (funRela.banOver) { %>checked<% } %> onchange="updateSetting();">
  47. <label class="form-check-label" for="ban_over">超计时限制上报审批/审批通过</label>
  48. </div>
  49. <div class="form-check">
  50. <input class="form-check-input" type="checkbox" id="hint_over" name="hint_over" <% if (funRela.hintOver) { %>checked<% } %> onchange="updateSetting();">
  51. <label class="form-check-label" for="hint_over">超计时标红显示</label>
  52. </div>
  53. </div>
  54. </div>
  55. </div>
  56. </div>
  57. </div>
  58. <div class="col-6">
  59. <div class="card mb-3">
  60. <div class="card-header d-flex justify-content-between">
  61. <div>变更令调用控制</div>
  62. </div>
  63. <div class="card-body">
  64. <div class="form-group mb-1">
  65. <div>
  66. <div class="form-check form-check-inline">
  67. <input class="form-check-input" type="checkbox" id="ban_minus_cb" name="ban_minus_cb" <% if (funRela.banMinusChangeBills) { %>checked<% } %> onchange="updateSetting();">
  68. <label class="form-check-label" for="ban_minus_cb">强制调用负变更(限制上报审批/审批通过)</label>
  69. </div>
  70. <div class="alert-warning p-1"><i class="fa Example of exclamation-circle fa-exclamation-circle "></i> 变更令开始调用后,负变更清单必须在本期全部调用</div>
  71. </div>
  72. <div>
  73. <div class="form-check form-check-inline">
  74. <input class="form-check-input" type="checkbox" id="minusNoValue" name="minusNoValue" <% if (funRela.minusNoValue) { %>checked<% } %> onchange="updateSetting();">
  75. <label class="form-check-label" for="minusNoValue">计量不计价</label>
  76. </div>
  77. </div>
  78. </div>
  79. </div>
  80. </div>
  81. </div>
  82. </div>
  83. <div class="row">
  84. <div class="col-6">
  85. <div class="card mb-3">
  86. <div class="card-header d-flex justify-content-between">
  87. <div>合同支付</div>
  88. </div>
  89. <div class="card-body">
  90. <div class="form-group mb-1">
  91. <div>
  92. <div class="form-check">
  93. <input class="form-check-input" type="checkbox" id="lockPayExpr" name="lockPayExpr" <% if (funRela.lockPayExpr) { %>checked<% } %> onchange="updateSetting();">
  94. <label class="form-check-label" for="lockPayExpr">锁定往期带基数计算的合同支付项</label>
  95. </div>
  96. <div class="form-check">
  97. <input class="form-check-input" type="checkbox" id="showMinusCol" name="showMinusCol" <% if (funRela.showMinusCol) { %>checked<% } %> onchange="updateSetting();">
  98. <label class="form-check-label" for="showMinusCol">显示扣款列</label>
  99. </div>
  100. <div class="alert-warning p-1"><i class="fa Example of exclamation-circle fa-exclamation-circle "></i> 隐藏此列不会修改本期应付计算,旧项目请谨慎修改,防止误解</div>
  101. <div class="form-check">
  102. <input class="form-check-input" type="checkbox" id="closeWapYfSf" <% if (ctx.subProject.page_show.closeWapYfSf) { %>checked<% } %> onchange="updateSetting();">
  103. <label class="form-check-label" for="closeWapYfSf">wap关闭「本期支付」相关信息 <a href="javascript:void(0);" data-toggle="tooltip" data-placement="bottom" title="" data-original-title="本期计量关联的“本期应付“、”本期实付”均不显示"><i class="fa fa-question-circle "></i></a></label>
  104. </div>
  105. </div>
  106. </div>
  107. </div>
  108. </div>
  109. </div>
  110. <div class="col-6">
  111. <div class="card mb-3">
  112. <div class="card-header d-flex justify-content-between">
  113. <div>中间计量模式设置</div>
  114. </div>
  115. <div class="card-body">
  116. <div class="form-group mb-1">
  117. <div>
  118. <% for (const i in imType) { %>
  119. <div class="form-check form-check-inline">
  120. <input class="form-check-input" type="radio" id="radio_<%- i %>" value="<%- imType[i].value %>" <% if (funRela.imType === imType[i].value) { %>checked<% } %> name="im_type" onchange="updateSetting();">
  121. <label class="form-check-label" for="radio_<%- i %>" name="im_type"><%- imType[i].name %></label>
  122. </div>
  123. <% } %>
  124. </div>
  125. <div class="mt-3">
  126. <label class="form-text alert alert-danger">切换模式,仅对未开始第一期计量的标段生效。</label>
  127. </div>
  128. </div>
  129. </div>
  130. </div>
  131. </div>
  132. </div>
  133. <div class="row">
  134. <div class="col-6">
  135. <div class="card mb-3 ">
  136. <div class="card-header d-flex justify-content-between">
  137. <div>计量期上报/审批</div>
  138. </div>
  139. <div class="card-body pb-2">
  140. <div class="form-group mb-1">
  141. <nav class="nav nav-tabs">
  142. <a class="nav-link nav-item active" data-toggle="tab" name="stage-setting" type="audit" onclick="changeSettingTab(this);">审批</a>
  143. <a class="nav-link nav-item" data-toggle="tab" name="stage-setting" type="start" onclick="changeSettingTab(this);">上报</a>
  144. <div class="ml-auto">
  145. <div class="custom-control custom-switch" id="switch-stage-start" style="display: none;">
  146. <input type="checkbox" class="custom-control-input" id="openStageStart" <% if(ctx.subProject.page_show.openStageStart) { %>checked<% } %> onchange="updateSetting();">
  147. <label class="custom-control-label" for="openStageStart"></label>
  148. </div>
  149. <div class="custom-control custom-switch" id="switch-stage-audit">
  150. <input type="checkbox" class="custom-control-input" id="openStageAudit" <% if(ctx.subProject.page_show.openStageAudit) { %>checked<% } %> onchange="updateSetting();">
  151. <label class="custom-control-label" for="openStageAudit"></label>
  152. </div>
  153. </div>
  154. </nav>
  155. <div class="tab-content my-2">
  156. <div class="tab-pane fade active show" id="stage-audit-tab" role="tabpanel" aria-labelledby="home-tab">
  157. <div class="input-group input-group-sm mt-2 col-6">
  158. <div class="input-group-prepend">
  159. <span class="input-group-text">预警:</span>
  160. </div>
  161. <input type="number" class="form-control" value="<%- ctx.subProject.page_show.stageAuditEarly %>" <% if(!ctx.subProject.page_show.openStageAudit) { %>disabled<% } %> id="stage-audit-early" oninput="limitDecimal(this);" min="0" max="30" onchange="updateSetting();">
  162. <div class="input-group-append">
  163. <span class="input-group-text">天</span>
  164. </div>
  165. </div>
  166. <div class="text-muted ml-4 mt-2"><small>审批停留时长符合设置天数(包含节假日),审批流程提醒为预警</small></div>
  167. <div class="input-group input-group-sm mt-2 col-6">
  168. <div class="input-group-prepend">
  169. <span class="input-group-text">紧急:</span>
  170. </div>
  171. <input type="number" class="form-control" value="<%- ctx.subProject.page_show.stageAuditWorry %>" <% if(!ctx.subProject.page_show.openStageAudit) { %>disabled<% } %> id="stage-audit-worry" oninput="limitDecimal(this);" min="0" max="30" onchange="updateSetting();">
  172. <div class="input-group-append">
  173. <span class="input-group-text">天</span>
  174. </div>
  175. </div>
  176. <div class="text-muted ml-4 mt-2"><small>审批停留时长符合设置天数(包含节假日),审批流程提醒为紧急</small></div>
  177. </div>
  178. <div class="tab-pane fade" id="stage-start-tab" role="tabpanel" aria-labelledby="profile-tab">
  179. <div class="input-group input-group-sm mb-2">
  180. <div class="input-group-prepend">
  181. <span class="input-group-text">开始日期:</span>
  182. <span class="input-group-text" style="width: 90px;padding-left: 12px;">每月</span>
  183. </div>
  184. <select class="form-control form-control-sm" id="start_day" style="width: 90px!important;flex: none;" <% if (ctx.subProject.page_show.openStageStart) { %>disabled<% } %>>
  185. <option value="0">请选择日</option>
  186. <% for (let i = 1; i <= 31;i++) { %>
  187. <option value="<%- i %>" <% if (funSet.stage_start.start_day === i) {%>selected<% } %>><%- i %></option>
  188. <% } %>
  189. </select>
  190. <span class="text-danger mx-2"></span>
  191. </div>
  192. <div class="input-group input-group-sm mb-2">
  193. <div class="input-group-prepend">
  194. <span class="input-group-text">截止日期:</span>
  195. </div>
  196. <select class="form-control form-control-sm" id="end_month" style="width: 90px!important;flex: none;" <% if (ctx.subProject.page_show.openStageStart) { %>disabled<% } %>>
  197. <option value="0">请选择月</option>
  198. <% for (const i of endMonth) { %>
  199. <option value="<%- i.val %>" <% if (funSet.stage_start.end_month === i.val) {%>selected<% } %> ><%- i.name %></option>
  200. <% } %>
  201. </select>
  202. <select class="form-control form-control-sm" id="end_day" style="width: 90px!important;flex: none;" <% if (ctx.subProject.page_show.openStageStart) { %>disabled<% } %>>
  203. <option value="0">请选择日</option>
  204. <% for (let i = 1; i <= 31;i++) { %>
  205. <option value="<%- i %>" <% if (funSet.stage_start.end_day === i) {%>selected<% } %>><%- i %></option>
  206. <% } %>
  207. </select>
  208. <span class="text-danger mx-2"></span>
  209. </div>
  210. <div class="mt-3">
  211. <label class="form-text alert alert-danger">开启选项后,超出范围内的日期,则不允许上报期计量。</label>
  212. </div>
  213. </div>
  214. </div>
  215. </div>
  216. </div>
  217. </div>
  218. </div>
  219. <div class="col-6">
  220. <div class="card mb-3">
  221. <div class="card-header d-flex justify-content-between">
  222. <div>计量相关设置</div>
  223. </div>
  224. <div class="card-body">
  225. <div class="form-group mb-1">
  226. <div class="form-check form-check-inline">
  227. <input class="form-check-input" type="checkbox" id="openContractExpr" <% if (ctx.subProject.page_show.openContractExpr) { %>checked<% } %> onchange="updateSetting();">
  228. <label class="form-check-label" for="openContractExpr">开启「本期合同计量设置公式」</label>
  229. </div>
  230. </div>
  231. <div class="form-group mb-1">
  232. <div class="form-check form-check-inline">
  233. <input class="form-check-input" type="checkbox" id="close1stStageCheckDealParam" <% if (ctx.subProject.page_show.close1stStageCheckDealParam) { %>checked<% } %> onchange="updateSetting();">
  234. <label class="form-check-label" for="close1stStageCheckDealParam">关闭「开始第一期计量判断合同参数」功能</label>
  235. </div>
  236. </div>
  237. <div class="form-group mb-1">
  238. <div class="form-check form-check-inline">
  239. <input class="form-check-input" type="checkbox" id="openMultiStageCalc" <% if (ctx.subProject.page_show.openMultiStageCalc) { %>checked<% } %> onchange="updateSetting();">
  240. <label class="form-check-label" for="openMultiStageCalc">开启「待上报时,允许新增下一期」功能</label>
  241. </div>
  242. </div>
  243. <div class="form-group mb-1">
  244. <div class="form-check form-check-inline">
  245. <input class="form-check-input" type="checkbox" id="correctCalcContractTp" <% if (ctx.subProject.page_show.correctCalcContractTp) { %>checked<% } %> onchange="updateSetting();">
  246. <label class="form-check-label" for="correctCalcContractTp">开启「反算本期合同计量」功能</label>
  247. <a href="" data-toggle="tooltip" data-placement="bottom" title="" data-original-title="开启此选项,清单最后一次合同计量,将反算本期合同计量金额"><i class="fa fa-question-circle "></i></a>
  248. </div>
  249. </div>
  250. </div>
  251. </div>
  252. </div>
  253. </div>
  254. <div class="row">
  255. <div class="col-6">
  256. <div class="card mb-3">
  257. <div class="card-header d-flex justify-content-between">
  258. <div>工程变更</div>
  259. </div>
  260. <div class="card-body">
  261. <div class="alert alert-dark py-1 px-2 mb-2" role="alert">
  262. 页面显示
  263. </div>
  264. <div class="form-group mb-1">
  265. <div class="form-check form-check-inline">
  266. <input class="form-check-input" type="checkbox" id="openChangeProject" <% if(ctx.subProject.page_show.openChangeProject) { %>checked<% } %> onchange="updateSetting(1);">
  267. <label class="form-check-label" for="openChangeProject">显示「变更立项」页面</label>
  268. </div>
  269. </div>
  270. <div class="form-group mb-1">
  271. <div class="form-check form-check-inline">
  272. <input class="form-check-input" type="checkbox" id="openChangeApply" <% if(ctx.subProject.page_show.openChangeApply) { %>checked<% } %> onchange="updateSetting(2);">
  273. <label class="form-check-label" for="openChangeApply">显示「变更申请」页面</label>
  274. </div>
  275. </div>
  276. <div class="form-group mb-1">
  277. <div class="form-check form-check-inline">
  278. <input class="form-check-input" type="checkbox" id="openChangePlan" <% if(ctx.subProject.page_show.openChangePlan) { %>checked<% } %> onchange="updateSetting(3);">
  279. <label class="form-check-label" for="openChangePlan">显示「变更方案」页面</label>
  280. </div>
  281. </div>
  282. <div class="alert alert-dark py-1 px-2 mb-2" role="alert">
  283. 功能设置
  284. </div>
  285. <div class="mb-1">
  286. <div class="form-check form-check-inline">
  287. <input class="form-check-input" type="checkbox" id="inlineCheckbox11" checked disabled>
  288. <label class="form-check-label" for="inlineCheckbox11">开启自定义变更类别</label>
  289. </div>
  290. <a class="pull-right mr-3" href="#bgclass" data-toggle="modal" data-target="#bgclass">设置</a>
  291. </div>
  292. <div class="mb-1">
  293. <div class="form-check form-check-inline">
  294. <input class="form-check-input" type="checkbox" id="openChangeState" <% if (ctx.subProject.page_show.openChangeState) { %>checked<% } %> onchange="updateSetting();">
  295. <label class="form-check-label" for="openChangeState">开启变更令状态功能 </label>&nbsp;
  296. <a href="javascript:void(0);" data-toggle="tooltip" data-placement="bottom" title="" data-original-title="变更令提供临时、立项、批复状态,可设置计量上限"><i class="fa fa-question-circle "></i></a>
  297. </div>
  298. <a class="pull-right mr-3 <% if (!ctx.subProject.page_show.openChangeState) { %>text-secondary<% } %>" href="javascript:void(0);" id="openBgStatus">设置</a>
  299. </div>
  300. <div class="mb-1">
  301. <div class="form-check form-check-inline">
  302. <input class="form-check-input" type="checkbox" id="openChangeWhiteList" <% if (ctx.subProject.page_show.openChangeWhiteList) { %>checked<% } %> onchange="updateSetting();">
  303. <label class="form-check-label" for="openChangeWhiteList">开启“添加空白清单”功能</label>
  304. </div>
  305. </div>
  306. </div>
  307. </div>
  308. </div>
  309. <div class="col-6" <% if (!ctx.subProject.page_show.openMaterial) { %>style="display: none;"<% } %>>
  310. <div class="card mb-3">
  311. <div class="card-header d-flex justify-content-between">
  312. <div>材料调差</div>
  313. </div>
  314. <div class="card-body">
  315. <div class="form-group mb-1">
  316. <div class="form-check form-check-inline">
  317. <input class="form-check-input" type="checkbox" id="openMaterialTax" <% if(ctx.subProject.page_show.openMaterialTax) { %>checked<% } %> onchange="updateSetting();">
  318. <label class="form-check-label" for="openMaterialTax">使用材料税</label>
  319. </div>
  320. </div>
  321. <div class="form-group mb-1">
  322. <div class="form-check form-check-inline">
  323. <input class="form-check-input" type="checkbox" id="openMaterialChecklist" <% if(ctx.subProject.page_show.openMaterialChecklist) { %>checked<% } %> onchange="updateSetting();">
  324. <label class="form-check-label" for="openMaterialChecklist">开启「批量设置调差清单」添加调差工料功能</label>
  325. </div>
  326. </div>
  327. <div class="form-group mb-1">
  328. <div class="form-check form-check-inline">
  329. <input class="form-check-input" type="checkbox" id="openMaterialSelf" <% if(ctx.subProject.page_show.openMaterialSelf) { %>checked<% } %> onchange="updateSetting();">
  330. <label class="form-check-label" for="openMaterialSelf">开启调差清单-所属项目节「单独添加工料」功能
  331. <a href="javascript:void(0);" data-toggle="tooltip" data-placement="bottom" title="" data-original-title="开启该选项,调差清单的所属项目节,允许单独添加工料"><i class="fa fa-question-circle "></i></a></label>
  332. </div>
  333. </div>
  334. <div class="form-group mb-1">
  335. <div class="form-check form-check-inline">
  336. <input class="form-check-input" type="checkbox" id="openMaterialEditForAudit" <% if(ctx.subProject.page_show.openMaterialEditForAudit) { %>checked<% } %> onchange="updateSetting();">
  337. <label class="form-check-label" for="openMaterialEditForAudit">开启「审核人修改数据」功能
  338. <a href="javascript:void(0);" data-toggle="tooltip" data-placement="bottom" title="" data-original-title="开启该选项,审核人允许修改部分调差工料数据"><i class="fa fa-question-circle "></i></a></label>
  339. </div>
  340. </div>
  341. <div class="form-group mb-1">
  342. <div class="form-check form-check-inline">
  343. <input class="form-check-input" type="checkbox" id="openMaterialStageRepeat" <% if(ctx.subProject.page_show.openMaterialStageRepeat) { %>checked<% } %> onchange="updateSetting();">
  344. <label class="form-check-label" for="openMaterialStageRepeat">开启「材料调差重复使用计量期」</label>
  345. </div>
  346. </div>
  347. <div class="form-group mb-1">
  348. <div class="form-check form-check-inline">
  349. <input class="form-check-input" type="checkbox" id="openMaterialListQty" <% if(ctx.subProject.page_show.openMaterialListQty) { %>checked<% } %> onchange="updateSetting();">
  350. <label class="form-check-label" for="openMaterialListQty">开启「修改调差数量」功能
  351. <a href="javascript:void(0);" data-toggle="tooltip" data-placement="bottom" title="" data-original-title="开启该选项,可在调差清单页修改本期调差数量"><i class="fa fa-question-circle "></i></a></label>
  352. </div>
  353. </div>
  354. </div>
  355. </div>
  356. </div>
  357. </div>
  358. <div class="card mb-3">
  359. <div class="card-header d-flex justify-content-between">
  360. <div>动态决算</div>
  361. </div>
  362. <div class="card-body">
  363. <div class="form-group mb-4">
  364. <div>
  365. <div class="form-check form-check-inline">
  366. <input class="form-check-input" type="checkbox" id="budget_zb" name="budget_zb" <% if (funRela.budgetZb) { %>checked<% } %> onchange="updateSetting();">
  367. <label class="form-check-label" for="budget_zb">招标预算</label>
  368. </div>
  369. </div>
  370. <div>
  371. <div class="form-check form-check-inline">
  372. <input class="form-check-input" type="checkbox" id="budget_ctrl" name="budget_ctrl" <% if (funRela.budgetCtrl) { %>checked<% } %> onchange="updateSetting();">
  373. <label class="form-check-label" for="budget_ctrl">控制目标</label>
  374. </div>
  375. </div>
  376. <div>
  377. <div class="form-check form-check-inline">
  378. <input class="form-check-input" type="checkbox" id="need_gcl" name="need_gcl" <% if (funRela.needGcl) { %>checked<% } %> onchange="updateSetting();">
  379. <label class="form-check-label" for="need_gcl">显示清单信息</label>
  380. </div>
  381. </div>
  382. <div class="mt-3">
  383. <label class="form-text alert alert-danger">做施工图三级清单预算时,请进行勾选。</label>
  384. </div>
  385. </div>
  386. </div>
  387. </div>
  388. </div>
  389. </div>
  390. </div>
  391. </div>
  392. </div>
  393. </div>
  394. <script src="/public/js/setting.js"></script>
  395. <script>
  396. let changeClass = JSON.parse(unescape('<%- escape(JSON.stringify(funSet.change_class)) %>'));
  397. let changeState = JSON.parse(unescape('<%- escape(JSON.stringify(funSet.change_state)) %>'));
  398. const changeSettingTab = function(tab) {
  399. const type = tab.getAttribute('type');
  400. if (type === 'start') {
  401. $('#switch-stage-start').show();
  402. $('#switch-stage-audit').hide();
  403. $('#stage-start-tab').addClass('active').addClass('show');
  404. $('#stage-audit-tab').removeClass('active').removeClass('show');
  405. } else if (type === 'audit') {
  406. $('#switch-stage-start').hide();
  407. $('#switch-stage-audit').show();
  408. $('#stage-audit-tab').addClass('active').addClass('show');
  409. $('#stage-start-tab').removeClass('active').removeClass('show');
  410. }
  411. }
  412. $(() => {
  413. autoFlashHeight();
  414. // 自定义变更类别
  415. $('body').on('click', '#change_class_div input[type="checkbox"]', function () {
  416. if ($(this).is(':checked')) {
  417. $(this).parents('.input-group-prepend').siblings('input').removeAttr('readonly');
  418. } else {
  419. $(this).parents('.input-group-prepend').siblings('input').attr('readonly', true).val('');
  420. }
  421. });
  422. $('body').on('change', '#change_class_div input[type="text"]', function () {
  423. if ($(this).val().length > 8) {
  424. toastr.error('类别名称不能超过8个字符');
  425. }
  426. });
  427. $("#bgclass").on('show.bs.modal', function () {
  428. let html = '';
  429. for (const cc of changeClass) {
  430. html += `<div class="input-group input-group-sm mb-1">
  431. <div class="input-group-prepend">
  432. <div class="input-group-text">
  433. <input type="checkbox" value="${cc.value}" aria-label="Checkbox for following text input" ${cc.checked ? 'checked' : ''}>
  434. </div>
  435. <span class="input-group-text">${cc.name}</span>
  436. </div>
  437. <input type="text" class="form-control" value="${cc.new_name}" ${!cc.checked ? 'readonly' : ''} aria-label="Text input with checkbox" placeholder="">
  438. </div>`;
  439. }
  440. $('#change_class_div').html(html);
  441. });
  442. $('#set_change_class_btn').click(function () {
  443. updateSetting(false, 1);
  444. });
  445. $('#openBgStatus').click(function () {
  446. if ($('#openChangeState').is(':checked')) {
  447. $('#bgstatus').modal('show');
  448. }
  449. });
  450. $("#bgstatus").on('show.bs.modal', function () {
  451. let html = '';
  452. for (const cs of changeState) {
  453. html += `<tr data-order="${cs.order}">
  454. <td>${cs.name}</td>
  455. <td>
  456. <div class="input-group input-group-sm" style="width:90px">
  457. <input type="number" class="form-control" max="100" min="0" step="1" value="${cs.value}">
  458. <div class="input-group-append">
  459. <span class="input-group-text" id="set_change_state_btn">%</span>
  460. </div>
  461. </div>
  462. </td>
  463. </tr>`;
  464. }
  465. $('#change_state_table').html(html);
  466. });
  467. $('#set_change_state_btn').click(function () {
  468. if ($('#openChangeState').is(':checked')) {
  469. updateSetting(false, 2);
  470. } else {
  471. toastr.error('未开启变更令状态功能,不能设置计量上限默认值');
  472. }
  473. });
  474. });
  475. // 根据Min Max限制Input输入
  476. function limitInputMinMax (obj) {
  477. if (obj.max && _.toNumber(obj.value) > _.toNumber(obj.max)) {
  478. obj.value = obj.max;
  479. }
  480. if(obj.min && _.toNumber(obj.value) < _.toNumber(obj.min)) {
  481. obj.value = obj.min;
  482. }
  483. }
  484. // 根据Maxlength限制input输入
  485. function limitMaxLength (obj) {
  486. if (obj.maxLength >= 0 && obj.value.length > obj.maxLength) {
  487. obj.value = obj.value.substr(0, obj.maxLength);
  488. }
  489. }
  490. // 根据正则限制输入
  491. function limitReg(obj, reg) {
  492. obj.value = obj.value.replace(reg, '');
  493. }
  494. // 小数位数 input 输入限制
  495. function limitDecimal(obj) {
  496. limitReg(obj, /[^\d]/g);
  497. limitMaxLength(obj);
  498. limitInputMinMax(obj);
  499. }
  500. const updateSetting = function (tab = false, set_type = 0) {
  501. if (!$('#openChangeApply')[0].checked && $('#openChangeProject')[0].checked && tab === 1) {
  502. $('#openChangeApply').prop('checked', true);
  503. $('#openChangePlan').prop('checked', true);
  504. } else if (!$('#openChangeApply')[0].checked && $('#openChangeProject')[0].checked && tab === 2) {
  505. $('#openChangeProject').prop('checked', false);
  506. }
  507. if (!$('#openChangePlan')[0].checked && $('#openChangeApply')[0].checked && tab === 2) {
  508. $('#openChangePlan').prop('checked', true);
  509. } else if (!$('#openChangePlan')[0].checked && $('#openChangeApply')[0].checked && tab === 3) {
  510. $('#openChangeApply').prop('checked', false);
  511. $('#openChangeProject').prop('checked', false);
  512. }
  513. const pushData = {};
  514. if($('#openStageStart')[0].checked) {
  515. // 判断是否已选开始日,截止月日
  516. const startDay = parseInt($('#start_day').val());
  517. const endMonth = parseInt($('#end_month').val());
  518. const endDay = parseInt($('#end_day').val());
  519. let flag = false;
  520. if (startDay === 0) {
  521. $('#start_day').siblings('span').text('请选择日');
  522. flag = true;
  523. } else {
  524. $('#start_day').siblings('span').text('');
  525. }
  526. const endErrorMsg = [];
  527. if (endMonth === 0) {
  528. endErrorMsg.push('请选择月');
  529. flag = true;
  530. }
  531. if (endDay === 0) {
  532. endErrorMsg.push('请选择日');
  533. flag = true;
  534. }
  535. if (endErrorMsg.length > 0) {
  536. $('#end_day').siblings('span').text(endErrorMsg.join(' '));
  537. } else {
  538. // 本月截止日不允许小于开始日
  539. if (endMonth === 1 && startDay > endDay) {
  540. $('#end_day').siblings('span').text('截止日期选择不正确,请重新选择');
  541. flag = true;
  542. } else if (endMonth === 2 && startDay <= endDay){
  543. $('#end_day').siblings('span').text('次月截止日不允许大于开始日');
  544. flag = true;
  545. } else {
  546. $('#end_day').siblings('span').text('');
  547. }
  548. }
  549. if (flag) {
  550. $('#openStageStart')[0].checked = 0;
  551. $('#openStageStart').prop('checked', false);
  552. return;
  553. }
  554. pushData.stage_start = {
  555. start_day: startDay,
  556. end_month: endMonth,
  557. end_day: endDay,
  558. }
  559. $('#start_day').attr('disabled', true);
  560. $('#end_month').attr('disabled', true);
  561. $('#end_day').attr('disabled', true);
  562. } else {
  563. $('#start_day').removeAttr('disabled');
  564. $('#end_month').removeAttr('disabled');
  565. $('#end_day').removeAttr('disabled');
  566. }
  567. if ($('#openStageAudit')[0].checked) {
  568. $('#stage-audit-early').removeAttr('disabled');
  569. $('#stage-audit-worry').removeAttr('disabled');
  570. } else {
  571. $('#stage-audit-early').attr('disabled', 'disabled');
  572. $('#stage-audit-worry').attr('disabled', 'disabled');
  573. }
  574. if (set_type === 1) {
  575. // 自定义变更类别
  576. const change_class = [];
  577. let flag = false;
  578. let allUnchecked = true;
  579. $('#change_class_div .input-group').each(function () {
  580. const one_class = _.find(changeClass, { value: parseInt($(this).find('input[type="checkbox"]').val())});
  581. if ($(this).find('input[type="checkbox"]').is(':checked') && $(this).find('input[type="text"]').val().length > 8) {
  582. toastr.error(one_class.name + ' 类别名称字符不能超过8个');
  583. flag = true;
  584. }
  585. const new_name = $(this).find('input[type="checkbox"]').is(':checked') ? $(this).find('input[type="text"]').val() : '';
  586. if (new_name) {
  587. const classInfo = _.find(changeClass, function(item) {
  588. return item.name === new_name && item.value !== one_class.value;
  589. })
  590. if (classInfo) {
  591. toastr.error(one_class.name + '的类别名称不能与其他变更名称相同');
  592. flag = true;
  593. }
  594. if (_.findIndex(change_class, { new_name }) !== -1) {
  595. toastr.error(one_class.name + '的类别名称不能与其他类别名称相同');
  596. flag = true;
  597. }
  598. }
  599. if ($(this).find('input[type="checkbox"]').is(':checked')) {
  600. allUnchecked = false;
  601. }
  602. const one_updateClass = {
  603. value: one_class.value,
  604. name: one_class.name,
  605. new_name,
  606. checked: $(this).find('input[type="checkbox"]').is(':checked'),
  607. }
  608. change_class.push(one_updateClass);
  609. });
  610. if (flag) {
  611. return;
  612. }
  613. if (allUnchecked) {
  614. toastr.error('至少保留一个变更类别');
  615. return;
  616. }
  617. pushData.change_class = change_class;
  618. } else if (set_type === 2) {
  619. // 变更令状态功能-设置计量调用上限
  620. const change_state = [];
  621. let flag = false;
  622. const reg = /^(\d{1,2}|100)$/;
  623. $('#change_state_table tr').each(function () {
  624. const one_state = _.find(changeState, { order: parseInt($(this).attr('data-order'))});
  625. const value = parseFloat($(this).find('input[type="number"]').val());
  626. if (!(_.isNumber(value) && reg.test(value))) {
  627. toastr.error(one_state.name + '的计量上限默认值只能输入0-100之间的整数');
  628. flag = true;
  629. }
  630. const one_updateState = {
  631. order: one_state.order,
  632. name: one_state.name,
  633. value: value,
  634. }
  635. change_state.push(one_updateState);
  636. });
  637. if (flag) {
  638. return;
  639. }
  640. pushData.change_state = change_state;
  641. }
  642. postData('/sp/<%- ctx.subProject.id %>/setting/fun/update', {
  643. imType: parseInt($('[name=im_type]:checked').val()),
  644. banOver: $('[name=ban_over]')[0].checked,
  645. hintOver: $('#hint_over')[0].checked,
  646. banMinusChangeBills: $('[name=ban_minus_cb]')[0].checked,
  647. minusNoValue: $('[name=minusNoValue]')[0].checked,
  648. lockPayExpr: $('#lockPayExpr')[0].checked,
  649. showMinusCol: $('#showMinusCol')[0].checked,
  650. needGcl: $('#need_gcl')[0].checked,
  651. budgetZb: $('#budget_zb')[0].checked,
  652. budgetCtrl: $('#budget_ctrl')[0].checked,
  653. openChangeProject: $('#openChangeProject')[0].checked,
  654. openChangeApply: $('#openChangeApply')[0].checked,
  655. openChangePlan: $('#openChangePlan')[0].checked,
  656. openChangeWhiteList: $('#openChangeWhiteList')[0].checked,
  657. openChangeState: $('#openChangeState')[0].checked,
  658. openMaterialTax: $('#openMaterialTax')[0].checked,
  659. openMaterialChecklist: $('#openMaterialChecklist')[0].checked,
  660. openMaterialSelf: $('#openMaterialSelf')[0].checked,
  661. openMaterialEditForAudit: $('#openMaterialEditForAudit')[0].checked,
  662. openMaterialStageRepeat: $('#openMaterialStageRepeat')[0].checked,
  663. openMaterialListQty: $('#openMaterialListQty')[0].checked,
  664. openStageStart: $('#openStageStart')[0].checked,
  665. openContractExpr: $('#openContractExpr')[0].checked,
  666. correctCalcContractTp: $('#correctCalcContractTp')[0].checked,
  667. close1stStageCheckDealParam: $('#close1stStageCheckDealParam')[0].checked,
  668. openMultiStageCalc: $('#openMultiStageCalc')[0].checked,
  669. closeWapYfSf: $('#closeWapYfSf')[0].checked,
  670. addFunSet: _.size(pushData) !== 0 ? pushData : null,
  671. openStageAudit: $('#openStageAudit')[0].checked,
  672. stageAuditEarly: parseInt($('#stage-audit-early').val()),
  673. stageAuditWorry: parseInt($('#stage-audit-worry').val()),
  674. posCalcDetail: $('#pos_calc_detail')[0].checked ? 1 : 0,
  675. ledgerAss: $('#ledger_ass')[0].checked,
  676. }, function (result) {
  677. if ($('#openChangeState').is(':checked')) {
  678. $('#openBgStatus').removeClass('text-secondary');
  679. } else {
  680. $('#openBgStatus').addClass('text-secondary');
  681. }
  682. if (set_type === 1) {
  683. changeClass = pushData.change_class;
  684. toastr.success('设置成功');
  685. $('#bgclass').modal('hide');
  686. } else if (set_type === 2) {
  687. changeState = pushData.change_state;
  688. toastr.success('设置成功');
  689. $('#bgstatus').modal('hide');
  690. }
  691. });
  692. }
  693. </script>