index.blade.php 16 KB

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