jlzf-change-new.js 18 KB

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