jlzf-change-update.js 19 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388
  1. $(function(){
  2. var cid = $.trim($('#cid').val());
  3. var table = $('#tablelist').removeAttr('width').DataTable({
  4. columnDefs: [
  5. { className: 'allwidth1', width: 100, targets: 0 },
  6. { className: 'allwidth2', width: 150, targets: 1 },
  7. { className: 'allwidth4', width: 40, targets: 8 },
  8. { className: 'allwidth5', width: 60, targets: 2 },
  9. { className: 'allwidth3',width: 80, targets: '_all' }
  10. ],
  11. fixedColumns: {
  12. leftColumns: 4
  13. }
  14. });
  15. //自动添加清单数据到localstorage里
  16. if($('#changelist').val() != ''){
  17. var clist = $('#changelist').val().split(',');
  18. $.each(clist,function(k,v){
  19. var vmsg = v.split('->');
  20. var vnum = vmsg[1].split(';');
  21. localStorage.setItem('update_'+cid+'_clistid_'+vmsg[0],vnum[5]);
  22. })
  23. }
  24. if($('#changewhitelist').val() != ''){
  25. var cwlist = $('#changewhitelist').val().split(',');
  26. $.each(cwlist,function(k,v){
  27. var vmsg = v.split('->');
  28. localStorage.setItem('update_'+ cid +'_new_clistid_'+vmsg[0],vmsg[1]);
  29. })
  30. }
  31. $('.addlistbtn').on('click',function(){
  32. //生成table清单
  33. if($(this).hasClass('btn-default')){
  34. maketablelist('addwhite');
  35. }else{
  36. maketablelist();
  37. }
  38. $('#addlist').modal('hide');
  39. });
  40. $('body').on("valuechange", '.clist input', function (e, previous) {
  41. //获取小数位的设置点数
  42. var decimalsetarr = $('#changedecimalnum').val().split('_');
  43. var decimal = decimalsetarr[0];
  44. //if 输入变更数量
  45. var site = $(this).parents('td').attr('sortnum');
  46. if(site == 6) {
  47. var num = $(this).val();
  48. var unitprice = $(this).parents('.clist').children('td').eq(3).text() || $(this).parents('.clist').children('td').eq(3).children('input').val();
  49. var total = $.trim(num) != '' && $.trim(unitprice) != '' ? roundnum(parseFloat(unitprice).mul(parseFloat(num)),decimal) : '';
  50. $(this).parents('.clist').children('td').eq(7).text(total);
  51. }
  52. //if 输入单价
  53. else if(site == 3) {
  54. var unitprice = $(this).val();
  55. var thistr = $(this).parents('tr').attr('newlist_tid');
  56. var $thisstr = $('#list tr[newlist_tid="'+thistr+'"]');
  57. $thisstr.children('td').eq(site).children('input').val(unitprice);
  58. var onum = $thisstr.children('td').eq(4).children('input').val();
  59. var num = $thisstr.children('td').eq(6).children('input').val();
  60. var ototal = $.trim(onum) != '' && $.trim(unitprice) != '' ? roundnum(parseFloat(unitprice).mul(parseFloat(onum)),2) : '';
  61. var total = $.trim(num) != '' && $.trim(unitprice) != '' ? roundnum(parseFloat(unitprice).mul(parseFloat(num)),decimal) : '';
  62. $thisstr.children('td').eq(5).text(ototal);
  63. $thisstr.children('td').eq(7).text(total);
  64. }
  65. //if 输入的是原设计数量
  66. else if(site == 4) {
  67. var onum = $(this).val();
  68. var unitprice = $(this).parents('.clist').children('td').eq(3).children('input').val();
  69. var ototal = $.trim(onum) != '' && $.trim(unitprice) != '' ? roundnum(parseFloat(unitprice).mul(parseFloat(onum)),2) : '';
  70. $(this).parents('.clist').children('td').eq(5).text(ototal);
  71. }else{
  72. var thistr = $(this).parents('tr').attr('newlist_tid');
  73. var $thisstr = $('#list tr[newlist_tid="'+thistr+'"]');
  74. $thisstr.children('td').eq(site).children('input').val($(this).val());
  75. }
  76. //统计合计金额
  77. totalamount(decimal);
  78. //更改localstorage
  79. //if 签约清单
  80. if($(this).parents('.clist').hasClass('clid')){
  81. var id = $(this).parents('.clist').attr('list_id');
  82. if($.trim($(this).val()) != ''){
  83. localStorage.setItem('update_'+cid+'_clistid_'+id, $.trim($(this).val()));
  84. var cnum = $.trim($(this).val());
  85. var $thisstr2 = $('#list tr[list_id="'+id+'"]');
  86. updatelist(id,cnum,$thisstr2);
  87. }else{
  88. localStorage.removeItem('update_'+cid+'_clistid_'+id);
  89. removelist(id);
  90. }
  91. }
  92. //else 新增空白清单
  93. else{
  94. var newid = $(this).parents('.clist').attr('newlist_tid');
  95. var $thisstr = $('#list tr[newlist_tid="'+newid+'"]');
  96. var listtrmsg = updateandgetwhitelist(newid,$thisstr);
  97. localStorage.setItem('update_'+ cid +'_new_clistid_'+newid,listtrmsg);
  98. }
  99. });
  100. //单位选择要另外处理
  101. $('body').on("change", '.clist select', function () {
  102. var newid = $(this).parents('.clist').attr('newlist_tid');
  103. var $thisstr = $('#list tr[newlist_tid="'+newid+'"]');
  104. $thisstr.children('td').eq(2).children('select').val($(this).val());
  105. var listtrmsg = updateandgetwhitelist(newid,$thisstr);
  106. localStorage.setItem('update_'+ cid +'_new_clistid_'+newid,listtrmsg);
  107. });
  108. //小数位数设置提交到本变更令中
  109. $('#setdnum').click(function(){
  110. if(/^[0-6]$/.test(parseInt($('#costdnum').val())) && /^[0-6]$/.test(parseInt($('#numberdnum').val()))){
  111. var costdnum = parseInt($('#costdnum').val()),
  112. numbernum = parseInt($('#numberdnum').val());
  113. decimalnumsetmodal(costdnum,numbernum,'update');
  114. }else{
  115. toastr.error('请输入范围内正确的位数要求');
  116. }
  117. });
  118. //删除清单功能
  119. $('body').on('click', "#tablelist .btn-sm",function(){
  120. if($(this).attr('list_id') !== undefined){
  121. var id = $(this).attr('list_id');
  122. //删除localstorage记录和reductionList记录
  123. localStorage.removeItem('update_'+ cid +'_clistid_'+id);
  124. var reductionlist = $('#reductionList').val().split(',');
  125. if($.trim(reductionlist) != ''){
  126. $.each(reductionlist,function(k,v){
  127. if(v == id){
  128. reductionlist.splice(k,1);
  129. return false;
  130. }
  131. });
  132. }
  133. $('#reductionList').val(reductionlist.join(','));
  134. //先删所有后还原
  135. var $rowtr = $('#addlist').find('tbody').children('tr');
  136. $rowtr.removeClass('success');
  137. $rowtr.find('input').prop('checked',false);
  138. var z = 0;
  139. for(var i = 0; i < reductionlist.length; i++){
  140. var j = z;
  141. for(; j < $rowtr.length; j++){
  142. if(reductionlist[i] == $rowtr.eq(j).children('td').eq(0).attr('list_id')){
  143. $rowtr.eq(j).addClass('success');
  144. $rowtr.eq(j).find('input').prop('checked',true);
  145. z = ++j;
  146. break;
  147. }
  148. }
  149. }
  150. maketablelist();
  151. }else{
  152. var id = $(this).attr('newlist_tid');
  153. //删除localstorage记录
  154. localStorage.removeItem('update_'+ cid +'_new_clistid_'+id);
  155. maketablelist();
  156. }
  157. //console.log($thisstr);
  158. //$thisstr.remove();
  159. });
  160. function maketablelist(status){
  161. //获取小数位的设置点数
  162. var decimalsetarr = $('#changedecimalnum').val().split('_');
  163. var decimal = decimalsetarr[0];
  164. //var step = makedecimals(decimalsetarr[1]);
  165. //设置数量0. n位数初始值
  166. var zero = makedecimalzero(decimalsetarr[1]);
  167. //设置金额0. n位数初始值
  168. var costzero = makedecimalzero(decimal);
  169. var html = '';
  170. var deteletr2 = 'class="btn btn-default btn-sm" title="删除清单"><span class="glyphicon glyphicon-trash text-danger"></span></a></td>';
  171. //获取清单列表
  172. var totalnum = 0;
  173. var clist = new Array();
  174. var rlist = new Array();
  175. $('.checklist').find('.listcheckbox').each(function(){
  176. if($(this).prop("checked")){
  177. var id = $(this).parents('.checklist').children('td').eq(0).attr('list_id');
  178. var num = $(this).parents('.checklist').children('td').eq(1).text();
  179. var name = $(this).parents('.checklist').children('td').eq(2).text();
  180. var unit = $(this).parents('.checklist').children('td').eq(3).text();
  181. var price = $(this).parents('.checklist').children('td').eq(4).text();
  182. var oamount = $(this).parents('.checklist').children('td').eq(5).text();
  183. var ototal = $(this).parents('.checklist').children('td').eq(6).text();
  184. //获取localstorage里的数据
  185. var scnum = 0;
  186. var sctotal = 0;
  187. var trlist = [num,name,unit,price,oamount];
  188. if(localStorage.hasOwnProperty('update_'+cid+'_clistid_'+id)){
  189. scnum = localStorage.getItem('update_'+cid+'_clistid_'+id);
  190. sctotal = roundnum(parseFloat(price).mul(parseFloat(scnum)),decimal);
  191. }else{
  192. //新增一个localstorage
  193. scnum = zero;
  194. localStorage.setItem('update_'+ cid +'_clistid_'+id,scnum);
  195. }
  196. trlist.push(scnum);
  197. clist.push(id+'->'+trlist.join(';'));
  198. rlist.push(id);
  199. sctotal = parseFloat(sctotal) != 0 ? roundnum(sctotal,decimal) : costzero;
  200. var deteletr = '<td><a list_id="'+ id +'" '+ deteletr2;
  201. html += '<tr class="clist clid" list_id="'+ id +'"><td sortnum="0">'+ num +'</td><td sortnum="1">'+ name +'</td><td sortnum="2">'+ unit +'</td><td sortnum="3">'+ price +'</td><td sortnum="4">'+ oamount +'</td><td sortnum="5">'+ ototal +'</td><td sortnum="6"><input class="form-control input-sm" type="text" onkeyup="RegNum(this,event,'+ decimalsetarr[1] +')" placeholder="请输入变更数量" value="'+ scnum +'"></td><td sortnum="7">'+ sctotal +'</td>'+ deteletr +'</tr>';
  202. }
  203. });
  204. //添加到form中list
  205. $('#changelist').val(clist.join(','));
  206. $('#reductionList').val(rlist.join(','));
  207. //获取localstorage里的数据
  208. var newid = 1;
  209. var addArr = new Array();
  210. var storage = window.localStorage;
  211. var n = 20+cid.toString().length;
  212. for(var i = 0; i < storage.length; i++){
  213. var key = storage.key(i);
  214. if(key.substring(0,n) == 'update_'+ cid +'_new_clistid_'){
  215. //排序
  216. newid++;
  217. var id2 = key.split('_');
  218. addArr.push(id2[4]);
  219. }
  220. }
  221. addArr.sort(function(a,b){
  222. return a - b;
  223. });
  224. var wlist = new Array();
  225. var optionselect = ['m','km','m2','m3','kg','t','m3·km','总额','月','项','处','个','根','棵','块','每一试桩','桥长米','公路公里','株','组','座','元','工日','套','台班','艘班','m/处','m/道','m/座','m2/m','m3/m','m3/处','根/米','亩','m3/m2'];
  226. //按添加顺序输出localstorage的内容
  227. for(var z= 0; z< addArr.length; z++){
  228. var trlist = storage.getItem('update_'+ cid +'_new_clistid_'+addArr[z]).split(';');
  229. var num2 = trlist[0];
  230. var name2 = trlist[1];
  231. var unit2 = trlist[2];
  232. var price2 = trlist[3];
  233. var oamount2 = trlist[4];
  234. var scnum = trlist[5];
  235. //不为空的就显示出来,全部为空的就自动删除
  236. if(num2 != '' || name2 != '' || price2 != '' || oamount2 != '' || scnum != ''){
  237. wlist.push(addArr[z]+'->'+trlist.join(';'));
  238. var ototal2 = price2 != '' && oamount2 != '' ? roundnum(parseFloat(price2).mul(parseFloat(oamount2)),2) : '';
  239. var sctotal2 = price2 != '' && scnum != '' ? roundnum(parseFloat(price2).mul(parseFloat(scnum)),decimal) : '';
  240. var optionlist = '';
  241. for(var j = 0; j < optionselect.length; j++){
  242. if(unit2 == optionselect[j]){
  243. optionlist += '<option selected="selected">'+ optionselect[j] +'</option>';
  244. }else{
  245. optionlist += '<option>'+ optionselect[j] +'</option>';
  246. }
  247. }
  248. var deteletr = '<td><a newlist_tid="'+ addArr[z] +'" '+ deteletr2;
  249. html += '<tr class="clist" newlist_tid="'+ addArr[z] +'"><td sortnum="0"><input class="form-control input-sm" type="text" value="'+ num2 +'" placeholder="请输入清单编号"></td><td sortnum="1"><input class="form-control input-sm" type="text" value="'+ name2 +'" placeholder="请输入名称"></td><td sortnum="2"><select class="form-control input-sm">'+ optionlist +'</select></td><td sortnum="3"><input class="form-control input-sm" type="text" onkeyup="RegNum(this,event,2)" value="'+ price2 +'" placeholder="请输入单价"></td><td sortnum="4"><input class="form-control input-sm" type="text" onkeyup="RegNum(this,event,'+ decimalsetarr[1] +')" value="'+ oamount2 +'" placeholder="请输入数量"></td><td sortnum="5">'+ ototal2 +'</td><td sortnum="6"><input class="form-control input-sm" type="text" onkeyup="RegNum(this,event,'+ decimalsetarr[1] +')" value="'+ scnum +'" placeholder="请输入变更数量"></td><td sortnum="7">'+ sctotal2 +'</td>'+ deteletr +'</tr>';
  250. }
  251. }
  252. //添加到form中list
  253. $('#changewhitelist').val(wlist.join(','));
  254. //获取添加的空白清单
  255. if(status == 'addwhite'){
  256. var optionlist2 = '';
  257. for(var j = 0; j < optionselect.length; j++){
  258. optionlist2 += '<option>'+ optionselect[j] +'</option>';
  259. }
  260. var deteletr = '<td><a newlist_tid="'+ newid +'" '+ deteletr2;
  261. var addtr = '<tr class="clist" newlist_tid="'+ newid +'"><td sortnum="0"><input class="form-control input-sm" type="text" placeholder="请输入清单编号"></td><td sortnum="1"><input class="form-control input-sm" type="text" placeholder="请输入名称"></td><td sortnum="2"><select class="form-control input-sm">'+ optionlist2 +'</select></td><td sortnum="3"><input class="form-control input-sm" type="text" onkeyup="RegNum(this,event,2)" placeholder="请输入单价" value="0.00"></td><td sortnum="4"><input class="form-control input-sm" ttype="text" onkeyup="RegNum(this,event,'+ decimalsetarr[1] +')" placeholder="请输入数量" value="'+ zero +'"></td><td sortnum="5">'+ costzero +'</td><td sortnum="6"><input class="form-control input-sm" type="text" onkeyup="RegNum(this,event,'+ decimalsetarr[1] +')" placeholder="请输入变更数量" value="'+ zero +'"></td><td sortnum="7">'+ costzero +'</td>'+ deteletr +'</tr>';
  262. html += addtr;
  263. }
  264. table.destroy();
  265. $('#list').html(html);
  266. table = $('#tablelist').removeAttr('width').DataTable({
  267. columnDefs: [
  268. { className: 'allwidth1', width: 100, targets: 0 },
  269. { className: 'allwidth2', width: 150, targets: 1 },
  270. { className: 'allwidth4', width: 40, targets: 8 },
  271. { className: 'allwidth5', width: 60, targets: 2 },
  272. { className: 'allwidth3',width: 80, targets: '_all' }
  273. ],
  274. fixedColumns: {
  275. leftColumns: 4
  276. }
  277. });
  278. totalamount(decimal);
  279. }
  280. });
  281. var updateflag = 0;
  282. var cid = $.trim($('#cid').val());
  283. function checkform(){
  284. if($.trim($('#pnum').val()) == ''){
  285. var str = updateflag == 0 ? '至少' : '';
  286. toastr.error('请'+str+'输入申请编号');
  287. return false;
  288. }
  289. if($('#pname').val() == ''){
  290. var str = updateflag == 0 ? '至少' : '';
  291. toastr.error('请'+str+'输入工程名称');
  292. return false;
  293. }
  294. if(updateflag == 1){
  295. if($('#description').val() == ''){
  296. toastr.error('请输入工程变更理由及内容');
  297. return false;
  298. }
  299. if($('#changelist').val() == '' && $('#changewhitelist').val() == ''){
  300. toastr.error('请至少添加一项变更清单或空白清单');
  301. return false;
  302. }
  303. if($('#changelist').val() != '' || $('#list .clid').length/2 != 0){
  304. var clistnum = $('#list .clid').length/2;
  305. if($('#changelist').val() == '' || $('#changelist').val().split(',').length != clistnum){
  306. toastr.error('请输入所有所需变更的签约清单的申报变更数量');
  307. return false;
  308. }
  309. }
  310. if($('#changewhitelist').val() != ''){
  311. var wlist = $('#changewhitelist').val().split(',');
  312. var existempty = 0;
  313. var emptysite = 0;
  314. var pnum = '';
  315. $.each(wlist,function(k,v){
  316. var adtrlist = v.split('->')[1].split(';');
  317. if(existempty == 1){
  318. return false;
  319. }
  320. $.each(adtrlist,function(ak,av){
  321. if(av == '' && ak != 2){
  322. existempty = 1;
  323. emptysite = k+1;
  324. pnum = adtrlist[0];
  325. return false;
  326. }
  327. });
  328. });
  329. if(existempty){
  330. var currnum = emptysite + $('#list .clid').length/2;
  331. toastr.error('变更清单第'+ currnum +'行,清单编号为:'+ pnum +' 存在未填写的内容,请填写完整。若不需要此空白清单请把整行填写过的内容清除');
  332. return false;
  333. }
  334. }
  335. if($('#changeaudit').val() == ''){
  336. toastr.error('请添加审批人');
  337. return false;
  338. }
  339. var addArr = new Array();
  340. var storage = window.localStorage;
  341. var n = cid.toString().length;
  342. for(var i = 0; i < storage.length; i++){
  343. var key = storage.key(i);
  344. if(key.substring(0,20+n) == 'update_'+ cid +'_new_clistid_' || key.substring(0,16+n) == 'update_'+ cid +'_clistid_'){
  345. addArr.push(key);
  346. }
  347. }
  348. if(addArr){
  349. $.each(addArr,function(k,v){
  350. storage.removeItem(v);
  351. })
  352. }
  353. }
  354. var ajaxflag = 0;
  355. $.ajax({
  356. type: 'post',
  357. url: '/change/check/pnum',
  358. data: {pnum:$.trim($('#pnum').val()),status:'update',pmid:$('#pmid').val(),cid:cid},
  359. async: false,
  360. dataType: 'json',
  361. success: function(result){
  362. if(result.code == 400){
  363. toastr.error(result.msg);
  364. ajaxflag = 1;
  365. }
  366. }
  367. });
  368. if(ajaxflag != 0){
  369. return false;
  370. }
  371. return true;
  372. }