index.blade.php 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242
  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" class="d-none">
  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. <th>情况说明</th>
  23. <th>问题类别</th>
  24. <th>说明</th>
  25. <th>操作者</th>
  26. <th>时间</th>
  27. </tr>
  28. <tr v-for="(package,i) in packages" @click="selectTr===i+1?selectTr=0:selectTr=i+1" :class="selectTr===i+1?'focusing' : ''">
  29. <td>
  30. <select class="form-control-sm" v-model="package.exception_type" @change="package.showEditButton = true">
  31. <option :disabled="!exception_editable" v-for="(value,index) in exception_types" :value="value" :name="value" :key="index">@{{ value }}</option>
  32. </select>
  33. <button class="btn btn-info btn-sm text-white mr-1" @click="updateExceptionType(package)" v-if="package.showEditButton">
  34. 更新状态</button>
  35. </td>
  36. <td>@{{ i+1 }}</td>
  37. <td>@{{ package.logistic_number }}</td>
  38. <td>@{{ package.status }}</td>
  39. <td>@{{ package.order != null ? package.order.logistic.name : '#' }}</td>
  40. <td>@{{ package.order != null ? package.order.owner.name : '#' }}</td>
  41. <td>@{{ package.sent_at }}</td>
  42. <td>@{{ package.received_at }}</td>
  43. <td>@{{ package.weighed_at }}</td>
  44. <td>
  45. <div v-if="package.transfer_status && package.transfer_status.length>0" class="text-overflow-warp-200 up" :id="'route-'+i">
  46. <p v-for="route in package.transfer_status">
  47. @{{ route.accept_address+" "+ route.remark+" "+route.accept_time}}
  48. </p>
  49. </div>
  50. <div class="text-overflow-warp-200 " v-if=" package.transfer_status && !showList[i] && package.transfer_status.length > 0">
  51. @{{ package.transfer_status[0].accept_address+" "+ package.transfer_status[0].remark+" "+package.transfer_status[0].accept_time}}
  52. </div>
  53. <div @click="showRoute(i)" v-if="package.transfer_status && package.transfer_status.length > 1">
  54. <label class="text-center mt-0 p-0 cursor-pointer pull-left">
  55. <span class="fa" :class="package.isShowRoute ? 'fa-angle-double-down' : 'fa-angle-double-right'"></span>
  56. &nbsp;<span v-if="package.transfer_status && showList[i]">收起</span><span v-else>展开</span>&nbsp;@{{ package.transfer_status.length }} 条
  57. </label>
  58. </div>
  59. </td>
  60. <td class="text-overflow-warp-200 " v-if="package.order && package.order.issue">@{{ package.order.issue.result_explain }}</td>
  61. <td class="text-overflow-warp-200 " v-if="package.order && package.order.issue && package.order.issue.issue_type">@{{ package.order.issue.issue_type.name }}</td>
  62. <td class="text-overflow-warp-200 " v-if="package.order && package.order.issue && package.order.issue.logs.length >0"><span v-for="log in package.order.issue.logs">@{{ log.content }}<br></span></td>
  63. <td class="text-overflow-warp-200 " v-if="package.order && package.order.issue && package.order.issue.logs.length >0"><span v-for="log in package.order.issue.logs">@{{ log.user.name }}<br></span></td>
  64. <td class="text-overflow-warp-200 " v-if="package.order && package.order.issue && package.order.issue.logs.length >0"><span v-for="log in package.order.issue.logs">@{{ log.created_at }}<br></span></td>
  65. </tr>
  66. </table>
  67. <div class="text-info h5 btn btn">{{$orderPackages->count()}}/{{$orderPackages->total()}}</div>
  68. {{$orderPackages->appends($paginateParams)->links()}}
  69. </div>
  70. </div>
  71. @endsection
  72. @section('lastScript')
  73. <script type="text/javascript" src="{{mix('js/queryForm/queryForm.js')}}"></script>
  74. <script>
  75. let vue = new Vue({
  76. el: "#list",
  77. data: {
  78. packages: [
  79. @foreach($orderPackages as $package)
  80. {!! $package !!},
  81. @endforeach
  82. ],
  83. logistics: [
  84. @foreach($logistics as $logistic)
  85. {
  86. name: '{{$logistic->id}}', value: '{{$logistic->name}}'
  87. },
  88. @endforeach
  89. ],
  90. owners: [
  91. @foreach($owners as $owner)
  92. {
  93. name: '{{$owner->id}}', value: '{{$owner->name}}'
  94. },
  95. @endforeach
  96. ],
  97. showList: {},
  98. selectTr: 0,
  99. exception_types: [
  100. '疑似库内丢件',
  101. '揽件异常',
  102. '中转异常',
  103. '疑似丢件',
  104. '派件异常',
  105. '其他',
  106. '无',
  107. ],
  108. exception_editable: @can('包裹管理-快递-异常类型-编辑') true @else false @endcan,
  109. selectedExceptionType: '修改异常类型'
  110. },
  111. created() {
  112. $.each(this.packages, function (index, item) {
  113. if (item.transfer_status != null && item.transfer_status.length > 1) {
  114. item.transfer_status.sort(function (item1, item2) {
  115. let date1 = new Date(item1.accept_time);
  116. let date2 = new Date(item2.accept_time);
  117. if (date1 - date2 > 0) return -1;
  118. if (date1 - date2 < 0) return 1;
  119. return 0;
  120. });
  121. }
  122. });
  123. },
  124. mounted() {
  125. $('#list').removeClass('d-none');
  126. let _this = this;
  127. $(".up").slideUp();
  128. let data = [
  129. [
  130. /*"","","","","","","","","","",""*/
  131. {name: 'logistic_number', type: 'input', tip: '可支持多快递单号,糊模查找需要在左边打上%符号', placeholder: '快递单号'},
  132. {
  133. name: 'status',
  134. type: 'select',
  135. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的状态'],
  136. placeholder: '状态',
  137. data: [{name: '无', value: '无'}, {name: '已称重', value: '已称重'}, {
  138. name: '已揽收',
  139. value: '已揽收'
  140. }, {name: '在途', value: '在途'}, {name: '在途异常', value: '在途异常'}, {
  141. name: '派送中',
  142. value: '派送中'
  143. }, {
  144. name: '已收件',
  145. value: '已收件'
  146. }, {name: '派送异常', value: '派送异常'}, {name: '返回中', value: '返回中'}, {
  147. name: '返回异常',
  148. value: '返回异常'
  149. }, {name: '返回派件', value: '返回派件'}, {name: '其他异常', value: '其他异常'},]
  150. },
  151. {name: 'sent_at_start', type: 'dateTime', tip: '选择显示发出时间的起始时间'},
  152. {name: 'received_at_start', type: 'dateTime', tip: '选择显示收货时间的起始时间'},
  153. {
  154. name: 'is_weighed',
  155. type: 'select',
  156. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的状态'],
  157. placeholder: '是否称重',
  158. data: [{name: false, value: '无'}, {name: true, value: '已称重'}]
  159. },
  160. {name: 'default_date', type: 'checkbox', tip: '默认15天', data: [{name: 'ture', value: '默认15天'}]},
  161. ], [
  162. {
  163. name: 'logistic_id',
  164. type: 'select_multiple_select',
  165. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的快递'],
  166. placeholder: ['快递', '定位或多选快递'],
  167. data: _this.logistics
  168. },
  169. {
  170. name: 'owner_id',
  171. type: 'select_multiple_select',
  172. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的货主'],
  173. placeholder: ['货主', '定位或多选货主'],
  174. data: _this.owners
  175. },
  176. {name: 'sent_at_end', type: 'dateTime', tip: '选择显示发出时间的截止时间'},
  177. {name: 'received_at_end', type: 'dateTime', tip: '选择显示收货时间的截止时间'},
  178. {
  179. name: 'is_exception',
  180. type: 'select',
  181. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的状态'],
  182. placeholder: '是否有异常',
  183. data: [{name: '是', value: '是'}, {name: '否', value: '否'}]
  184. },
  185. {
  186. name: 'exception_type',
  187. type: 'select',
  188. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的状态'],
  189. placeholder: '异常类型',
  190. data: [
  191. {name: '疑似库内丢件', value: '疑似库内丢件'},
  192. {name: '揽件异常', value: '揽件异常'},
  193. {name: '中转异常', value: '中转异常'},
  194. {name: '疑似丢件', value: '疑似丢件'},
  195. {name: '派件异常', value: '派件异常'},
  196. {name: '其他', value: '其他'},
  197. {name: '无', value: '无'}
  198. ]
  199. },
  200. ]
  201. ];
  202. _this.form = new query({
  203. el: '#form_div',
  204. condition: data,
  205. });
  206. _this.form.init();
  207. },
  208. methods: {
  209. showRoute(id) {
  210. if (this.showList[id]) {
  211. this.$set(this.showList, id, false);
  212. $("#route-" + id).slideUp();
  213. } else {
  214. this.$set(this.showList, id, true);
  215. $("#route-" + id).slideDown();
  216. }
  217. this.$forceUpdate();
  218. },
  219. updateExceptionType(orderPackages) {
  220. let url = '{{ url("package/logistic") }}' +'/'+ orderPackages.id;
  221. let data = {id:orderPackages['id'],exception_type: orderPackages.exception_type}
  222. axios.patch(url, data).then((res)=>{
  223. window.tempTip.showSuccess('异常状态修改成功');
  224. });
  225. }
  226. },
  227. filters: {
  228. toObjected: function (value) {
  229. return JSON.parse(value);
  230. }
  231. },
  232. });
  233. </script>
  234. @endsection