index.blade.php 9.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191
  1. @extends('layouts.app')
  2. @section('title')快递查询-包裹管理@endsection
  3. @section('content')
  4. <span id="nav2">
  5. @component('package.menu')@endcomponent
  6. </span>
  7. <div id="list">
  8. <div class="container-fluid">
  9. <div id="form_div"></div>
  10. <table class="table table-striped table-sm text-nowrap table-hover">
  11. <tr>
  12. <th>单号</th>
  13. <th>状态</th>
  14. <th>快递公司</th>
  15. <th>货主</th>
  16. <th>发出日期</th>
  17. <th>收货日期</th>
  18. <th>称重日期</th>
  19. <th>异常标记</th>
  20. <th>快递路由</th>
  21. <th>客服备注</th>
  22. </tr>
  23. <tr v-for="(package,i) in packages" @click="selectTr===i+1?selectTr=0:selectTr=i+1" :class="selectTr===i+1?'focusing' : ''">
  24. <td>@{{ package.logistic_number }}</td>
  25. <td>@{{ package.status }}</td>
  26. <td>@{{ package.order != null ? package.order.logistic.name : '#' }}</td>
  27. <td>@{{ package.order != null ? package.order.owner.name : '#' }}</td>
  28. <td>@{{ package.sent_at }}</td>
  29. <td>@{{ package.received_at }}</td>
  30. <td>@{{ package.weighed_at }}</td>
  31. <td>@{{ package.exception }}</td>
  32. <td>
  33. <div v-if="package.transfer_status && package.transfer_status.length>0" class="text-overflow-warp-200 up" :id="'route-'+i">
  34. <p v-for="route in package.transfer_status">
  35. @{{ route.accept_address+" "+ route.remark+" "+route.accept_time}}
  36. </p>
  37. </div>
  38. <div class="text-overflow-warp-200 " v-if=" package.transfer_status && !showList[i] && package.transfer_status.length > 0">
  39. @{{ package.transfer_status[0].accept_address+" "+ package.transfer_status[0].remark+" "+package.transfer_status[0].accept_time}}
  40. </div>
  41. <div @click="showRoute(i)" v-if="package.transfer_status && package.transfer_status.length > 1">
  42. <label class="text-center mt-0 p-0 cursor-pointer pull-left">
  43. <span class="fa" :class="package.isShowRoute ? 'fa-angle-double-down' : 'fa-angle-double-right'"></span>
  44. &nbsp;<span v-if="package.transfer_status && showList[i]">收起</span><span v-else>展开</span>&nbsp;@{{ package.transfer_status.length }} 条
  45. </label>
  46. </div>
  47. </td>
  48. <td>@{{ package.remark }}</td>
  49. </tr>
  50. </table>
  51. <div class="text-info h5 btn btn">{{$orderPackages->count()}}/{{$orderPackages->total()}}</div>
  52. {{$orderPackages->appends($paginateParams)->links()}}
  53. </div>
  54. </div>
  55. @endsection
  56. @section('lastScript')
  57. <script type="text/javascript" src="{{mix('js/queryForm/export.js')}}"></script>
  58. <script type="text/javascript" src="{{mix('js/queryForm/queryForm.js')}}"></script>
  59. <script type="text/javascript" src="{{mix('js/queryForm/header.js')}}"></script>
  60. <script>
  61. let vue = new Vue({
  62. el: "#list",
  63. data: {
  64. packages: [
  65. @foreach($orderPackages as $package)
  66. {!! $package !!},
  67. @endforeach
  68. ],
  69. logistics: [
  70. @foreach($logistics as $logistic)
  71. {
  72. name: '{{$logistic->id}}', value: '{{$logistic->name}}'
  73. },
  74. @endforeach
  75. ],
  76. owners: [
  77. @foreach($owners as $owner)
  78. {
  79. name: '{{$owner->id}}', value: '{{$owner->name}}'
  80. },
  81. @endforeach
  82. ],
  83. showList:{},
  84. selectTr:0
  85. },
  86. created(){
  87. $.each(this.packages,function (index,item){
  88. if (item.transfer_status!=null&&item.transfer_status.length>1) {
  89. item.transfer_status.sort(function (item1, item2) {
  90. let date1 = new Date(item1.accept_time);
  91. let date2 = new Date(item2.accept_time);
  92. if (date1 - date2 > 0) return -1;
  93. if (date1 - date2 < 0) return 1;
  94. return 0;
  95. });
  96. }
  97. });
  98. },
  99. mounted() {
  100. let _this = this;
  101. $(".up").slideUp();
  102. let data = [
  103. [
  104. /*"","","","","","","","","","",""*/
  105. {name: 'logistic_number', type: 'input', tip: '可支持多快递单号,糊模查找需要在左边打上%符号', placeholder: '快递单号'},
  106. {
  107. name: 'status',
  108. type: 'select',
  109. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的状态'],
  110. placeholder: '状态',
  111. data: [{name: '无', value: '无'}, {name: '已称重', value: '已称重'}, {
  112. name: '已揽收',
  113. value: '已揽收'
  114. }, {name: '在途', value: '在途'}, {name: '在途异常', value: '在途异常'}, {
  115. name: '派送中',
  116. value: '派送中'
  117. }, {name: '派送异常', value: '派送异常'}, {name: '返回中', value: '返回中'}, {
  118. name: '返回异常',
  119. value: '返回异常'
  120. }, {name: '返回派件', value: '返回派件'}, {name: '其他异常', value: '其他异常'},]
  121. },
  122. {name: 'sent_at_start', type: 'dateTime', tip: '选择显示发出时间的起始时间'},
  123. {name: 'received_at_start', type: 'dateTime', tip: '选择显示收货时间的起始时间'},
  124. {
  125. name: 'is_weighed',
  126. type: 'select',
  127. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的状态'],
  128. placeholder: '是否称重',
  129. data: [{name: false, value: '无'}, {name: true, value: '已称重'}]
  130. },
  131. {name: 'default_date', type: 'checkbox', tip: '默认15天', data: [{name: 'ture', value: '默认15天'}]},
  132. ], [
  133. {
  134. name: 'logistic_id',
  135. type: 'select_multiple_select',
  136. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的快递'],
  137. placeholder: ['快递', '定位或多选快递'],
  138. data: _this.logistics
  139. },
  140. {
  141. name: 'owner_id',
  142. type: 'select_multiple_select',
  143. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的货主'],
  144. placeholder: ['货主', '定位或多选货主'],
  145. data: _this.owners
  146. },
  147. {name: 'sent_at_end', type: 'dateTime', tip: '选择显示发出时间的截止时间'},
  148. {name: 'received_at_end', type: 'dateTime', tip: '选择显示收货时间的截止时间'},
  149. {
  150. name: 'is_exception',
  151. type: 'select',
  152. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的状态'],
  153. placeholder: '是否有异常',
  154. data: [{name: '是', value: '是'}, {name: '否', value: '否'}]
  155. },
  156. ]
  157. ];
  158. _this.form = new query({
  159. el: '#form_div',
  160. condition: data,
  161. });
  162. _this.form.init();
  163. },
  164. methods:{
  165. showRoute(id){
  166. if (this.showList[id]){
  167. this.$set(this.showList,id,false);
  168. $("#route-"+id).slideUp();
  169. }else{
  170. this.$set(this.showList,id,true);
  171. $("#route-"+id).slideDown();
  172. }
  173. this.$forceUpdate();
  174. },
  175. },
  176. filters:{
  177. toObjected:function(value){
  178. return JSON.parse(value);
  179. }
  180. },
  181. });
  182. </script>
  183. @endsection