jlzf-change-new.js 16 KB

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