importRejectedNumber.blade.php 6.8 KB

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