import.blade.php 8.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170
  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. <div class="form-group row text-center">
  11. <div class="col-12 text-danger">
  12. 注意:请保证表第一行有以下对应的字段名<br><span class="text-muted">(可不按顺序):</span><br>
  13. 原始运单号,问题类别,情况说明<br>
  14. <span class="text-muted" style="opacity:0.7"> 订单问题类别:('拦截', '快递异常', '信息更改', '联系不上', '其他', '错漏发', '仓库问题', '快递丢件', '破损', '撤销丢件', '二次加工', '全检问题', '系统问题', '延迟发货', '仓库丢件', )<br></span>
  15. </div>
  16. <div class="col-12 text-info ">
  17. 导入时间随文件大小可能达数十分钟以上,请耐心等候
  18. <hr>
  19. </div>
  20. </div>
  21. @can('订单管理-订单问题件生成-文本导入')
  22. <div class="form-group row text-center">
  23. <div class="col-12 text-danger">
  24. 订单问题类别:同Excel文件导入所要求的订单问题类别一致<br/>
  25. 注意:文本导入的问题件只有全部符合条件的才能生成问题件,自定义订单号可不填<br/>
  26. <span class="text-muted" style="opacity:0.7">
  27. 如果在导入后出现部分数据导入失败,修改对应错误的数据继续导入即可
  28. </span>
  29. </div>
  30. </div>
  31. <div class="form-group row">
  32. <div class="col-8 offset-2">
  33. <button type="button" class="btn form-control btn-primary" @click="showPasteDataModal">文本导入</button>
  34. </div>
  35. </div>
  36. <hr/>
  37. @endcan
  38. <form action="{{url('order/issue/batchImport')}}" method="post" enctype="multipart/form-data" class="form" target="_blank">
  39. @csrf
  40. <div class="form-group row">
  41. <label for="sku" class="col-2 col-form-label text-right">选择EXCEL</label>
  42. <div class="col-8">
  43. <div class="form-control">
  44. <input type="file" class="form-control-file @error('file') is-invalid @enderror"
  45. name="file" value="{{ old('file') }}" required>
  46. @error('file')
  47. <span class="invalid-feedback" role="alert">
  48. <strong>{{ $message }}</strong>
  49. </span>
  50. @enderror
  51. </div>
  52. </div>
  53. </div>
  54. <div class="form-group row">
  55. <div class="col-8 offset-2">
  56. <input type="submit" class="btn btn-success form-control" value="执行导入">
  57. </div>
  58. </div>
  59. </form>
  60. </div>
  61. </div>
  62. <div class="modal fade" id="pasteData" role="dialog" tabindex="-1" aria-labelledby="pasteDataTetlie" aria-hidden="true">
  63. <div class="modal-dialog modal-dialog-centered modal-lg" role="document">
  64. <div class="modal-content">
  65. <div class="modal-header">
  66. <div class="row modal-title font-weight-bold w-100 text-nowrap ml-1 noselect" id="pasteDataTitle">
  67. <span v-for="(row,i) in rows" draggable="true"
  68. @drop="drop($event,i)" @dragover="dragover($event)" @dragstart="dragstart($event,i)"
  69. class="col-3 border" style="cursor: move"
  70. :class="requiredRows.includes(row)?'text-danger':''">@{{ row }}</span>
  71. </div>
  72. </div>
  73. <div class="modal-body text-center">
  74. <button type="button" id="popover" class="btn btn-danger" v-if="popoverContent"
  75. data-container="body" data-toggle="popover" data-placement="bottom"
  76. :data-content="popoverContent" data-html="true">
  77. 部分数据导入失败
  78. </button>
  79. <textarea id="pasteDataText" class="w-100" style="height: 400px" v-model="pasteDataText"
  80. @keydown.tab="forbidTab($event)" @keyup.tab="replaceSpacing()"
  81. placeholder="内容可为EXCEL复制,也可手动输入使用“TAB”缩进符区分列,请注意表头顺序,可拖拽表头字段调整顺序,以该顺序为准"></textarea>
  82. </div>
  83. <div class="modal-footer">
  84. <button class="btn btn-primary" @click="importPasteData">开始导入</button>
  85. </div>
  86. </div>
  87. </div>
  88. </div>
  89. </div>
  90. @endsection
  91. @section('lastScript')
  92. <script>
  93. let listVue = new Vue({
  94. el:'#issue_import_div',
  95. data:{
  96. rows:['原始运单号','问题类别','情况说明','自定义订单号'],
  97. requiredRows:['原始运单号','问题类别','情况说明','自定义订单号'],
  98. popoverContent:'',
  99. pasteDataText: '',
  100. },
  101. mounted:function(){
  102. $('[data-toggle="popover"]').popover();
  103. },
  104. methods:{
  105. showPasteDataModal(){
  106. $('#popover').attr('hidden','hidden')
  107. $('#pasteData').modal('show')
  108. },
  109. drop(e,index){
  110. e.preventDefault();
  111. if (this.dom !== e.target.innerHTML){
  112. this.dom.innerHTML = e.target.innerHTML;
  113. let temp=JSON.parse(JSON.stringify(this.rows[index]));
  114. this.$set(this.rows,index,this.rows[e.dataTransfer.getData('text/html')]);
  115. this.$set(this.rows,Number(e.dataTransfer.getData('text/html')),temp);
  116. }
  117. },
  118. dragover(e){
  119. e.preventDefault();
  120. },
  121. dragstart(e,index){
  122. this.dom = e.target.innerHTML;
  123. e.dataTransfer.setData("text/html",index);
  124. },
  125. importPasteData(){
  126. if(!this.pasteDataText){
  127. tempTip.setDuration(2000)
  128. tempTip.show('导入文本不能为空')
  129. }
  130. let _this = this
  131. let data = {rows:this.rows,pasteDataText:this.pasteDataText}
  132. tempTip.setDuration(99999)
  133. tempTip.setIndex(1051)
  134. tempTip.waitingTip('正在执行中,请稍后')
  135. axios.post('{{url('apiLocal/order/issue/importPasteData')}}',data).then(function (response) {
  136. tempTip.cancelWaitingTip()
  137. if(response.data.success){
  138. $('#pasteData').modal('hide')
  139. tempTip.setDuration(2000)
  140. tempTip.showSuccess('导入完毕')
  141. }else{
  142. let content = '';
  143. for (const key in response.data.fail_info) {
  144. content+=key+':'+response.data.fail_info[key] + "</br>"
  145. }
  146. _this.popoverContent = content
  147. setTimeout(function () {
  148. $("#popover").removeAttr('hidden').popover('show')
  149. },1);
  150. }
  151. }).catch(function(error){
  152. tempTip.cancelWaitingTip()
  153. tempTip.setDuration(2000)
  154. tempTip.show('导入失败'+error)
  155. })
  156. },
  157. forbidTab(e){
  158. e.preventDefault();
  159. },
  160. replaceSpacing(){
  161. this.pasteDataText += "\t";
  162. },
  163. }
  164. });
  165. </script>
  166. @endsection