importRejectedNumber.blade.php 6.7 KB

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