jlzf-change-new.js 15 KB

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