jlzf-change-new.js 18 KB

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