importRejectedNumber.blade.php 6.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. @extends('layouts.app')
  2. @section('title')退回件-导入@endsection
  3. @section('content')
  4. <div id="nav2">
  5. @component('order.issue.menu')@endcomponent
  6. </div>
  7. <div class="container-fluid" id="issue_import_div">
  8. <div class="card col-md-8 offset-md-2">
  9. <div class="card-body">
  10. @can('退货管理-编辑')
  11. <div class="form-group row text-center">
  12. <div class="col-12 text-danger">
  13. 退回单号修改<br/>
  14. 【退回单号,原单单号】 必填项;【到付金额】 非必填项<br/>
  15. <span class="text-muted" style="opacity:0.7">
  16. 如果在导入后出现部分数据导入失败,修改对应错误的数据继续导入即可,
  17. </span>
  18. </div>
  19. </div>
  20. <div class="form-group row">
  21. <div class="col-8 offset-2">
  22. <button type="button" class="btn form-control btn-primary" @click="showPasteDataModal">文本导入</button>
  23. </div>
  24. </div>
  25. <hr/>
  26. @endcan
  27. </form>
  28. </div>
  29. </div>
  30. <div class="modal fade" id="pasteData" role="dialog" tabindex="-1" aria-labelledby="pasteDataTetlie" aria-hidden="true">
  31. <div class="modal-dialog modal-dialog-centered modal-lg" role="document">
  32. <div class="modal-content">
  33. <div class="modal-header">
  34. <div class="row modal-title font-weight-bold w-100 text-nowrap ml-1 noselect" id="pasteDataTitle">
  35. <span v-for="(row,i) in rows" draggable="true"
  36. @drop="drop($event,i)" @dragover="dragover($event)" @dragstart="dragstart($event,i)"
  37. class="col-4 border text-center" style="cursor: move"
  38. :class="requiredRows.includes(row)?'text-danger':''">@{{ row }}</span>
  39. </div>
  40. </div>
  41. <div class="modal-body text-center">
  42. <button type="button" id="popover" class="btn btn-danger" v-if="popoverContent"
  43. data-container="body" data-toggle="popover" data-placement="bottom"
  44. :data-content="popoverContent" data-html="true">
  45. 部分数据导入失败
  46. </button>
  47. <textarea id="pasteDataText" class="w-100" style="height: 400px" v-model="pasteDataText"
  48. @keydown.tab="forbidTab($event)" @keyup.tab="replaceSpacing()"
  49. placeholder="内容可为EXCEL复制,也可手动输入使用“TAB”缩进符区分列,以表头顺序为准" @click="hidePopover"></textarea>
  50. </div>
  51. <div class="modal-footer">
  52. <button class="btn btn-primary" @click="importPasteData">开始导入</button>
  53. </div>
  54. </div>
  55. </div>
  56. </div>
  57. </div>
  58. @endsection
  59. @section('lastScript')
  60. <script>
  61. let listVue = new Vue({
  62. el:'#issue_import_div',
  63. data:{
  64. rows:['退回单号','原单单号','到付金额'],
  65. requiredRows:['退回单号','原单单号','到付金额'],
  66. popoverContent:'',
  67. pasteDataText: '',
  68. },
  69. mounted:function(){
  70. $('[data-toggle="popover"]').popover();
  71. },
  72. methods:{
  73. showPasteDataModal(){
  74. $('#popover').attr('hidden','hidden')
  75. $('#pasteData').modal('show')
  76. },
  77. drop(e,index){
  78. e.preventDefault();
  79. if (this.dom !== e.target.innerHTML){
  80. this.dom.innerHTML = e.target.innerHTML;
  81. let temp=JSON.parse(JSON.stringify(this.rows[index]));
  82. this.$set(this.rows,index,this.rows[e.dataTransfer.getData('text/html')]);
  83. this.$set(this.rows,Number(e.dataTransfer.getData('text/html')),temp);
  84. }
  85. },
  86. dragover(e){
  87. e.preventDefault();
  88. },
  89. dragstart(e,index){
  90. this.dom = e.target.innerHTML;
  91. e.dataTransfer.setData("text/html",index);
  92. },
  93. importPasteData(){
  94. if(!this.pasteDataText){
  95. tempTip.setDuration(2000)
  96. tempTip.show('导入文本不能为空')
  97. }
  98. let _this = this
  99. let data = {dataText:this.pasteDataText}
  100. tempTip.setDuration(99999)
  101. tempTip.setIndex(1051)
  102. tempTip.waitingTip('正在执行中,请稍后')
  103. axios.post('{{url('apiLocal/rejectedBill/importRejectedNumber')}}',data).then(function (response) {
  104. tempTip.cancelWaitingTip()
  105. if(response.data.success){
  106. $('#pasteData').modal('hide')
  107. tempTip.setDuration(2000)
  108. tempTip.showSuccess('导入完毕')
  109. }else{
  110. let content = '';
  111. for (const key in response.data.error) {
  112. content+=key+':'+response.data.error[key] + "</br>"
  113. }
  114. _this.popoverContent = content
  115. setTimeout(function () {
  116. $("#popover").removeAttr('hidden').popover('show')
  117. },1);
  118. }
  119. }).catch(function(error){
  120. tempTip.cancelWaitingTip()
  121. tempTip.setDuration(2000)
  122. tempTip.show('导入失败'+error)
  123. })
  124. },
  125. forbidTab(e){
  126. e.preventDefault();
  127. },
  128. replaceSpacing(){
  129. this.pasteDataText += "\t";
  130. },
  131. hidePopover(){
  132. let _this = this;
  133. setTimeout(function () {
  134. _this.popoverContent = ''
  135. $("#popover").removeAttr('hidden').popover('hide')
  136. },1)
  137. }
  138. }
  139. });
  140. </script>
  141. @endsection