index.blade.php 29 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560
  1. @extends('layouts.app')
  2. @section('title')快递查询-包裹管理@endsection
  3. @section('head')
  4. <style>
  5. .package-logistic-index{
  6. position:relative;
  7. }
  8. /*备注容器*/
  9. .order-package-remarks{
  10. position:relative;
  11. }
  12. /*新建按钮*/
  13. .btn-create-remark {
  14. width: 25px;
  15. height: 25px;
  16. line-height: 25px;
  17. text-align: center;
  18. position: absolute;
  19. display: none;
  20. background-color: rgb(92, 141, 236);
  21. border: blue solid 1px;
  22. color: #111;
  23. box-shadow: 0 0 6px #4747f1;
  24. float: left;
  25. }
  26. .order-package-remarks:hover .btn-create-remark{
  27. display: block;
  28. }
  29. /*新建输入框*/
  30. .remark-input {
  31. height: 30px;
  32. line-height: 30px;
  33. padding-left: 16px;
  34. margin-left: 35px;
  35. box-shadow: 0 0 6px #fff6a1;
  36. border-radius: 5px;
  37. }
  38. /*删除按钮*/
  39. .order-package-remarks table .destroy {
  40. float: right;
  41. position: absolute;
  42. right: 0;
  43. padding: 0 !important;
  44. width: 29px !important;
  45. min-width: 30px !important;
  46. border: 0 solid transparent !important;
  47. }
  48. .remark-created_at{
  49. border-right: none !important;
  50. }
  51. .btn-destroy-remark {
  52. display: none;
  53. background-color: rgba(0, 0, 0, 0);
  54. border: red solid 1px;
  55. color: red;
  56. box-shadow: 0 0 6px #ac4a4a;
  57. }
  58. .order-package-remarks table:hover .btn-destroy-remark{
  59. display: block;
  60. }
  61. </style>
  62. @stop
  63. @section('content')
  64. <div id="list" class="d-none package-logistic-index">
  65. <div class="container-fluid">
  66. <div id="form_div"></div>
  67. <div class="ml-3 form-inline" id="btn">
  68. @can('包裹管理-快递-异常类型-编辑')
  69. <span class="dropdown">
  70. <button type="button"
  71. class="btn btn-outline-dark btn-sm form-control-sm dropdown-toggle tooltipTarget"
  72. data-toggle="dropdown" title="导出所有页将会以搜索条件得到的筛选结果,将其全部记录(每一页)导出">导出Excel
  73. </button>
  74. <div class="dropdown-menu">
  75. <a class="dropdown-item" @click="orderPackageExport(false)" href="javascript:">导出勾选内容</a>
  76. <a class="dropdown-item" @click="orderPackageExport(true)" href="javascript:">导出所有页</a>
  77. </div>
  78. </span>
  79. <span class="ml-1">
  80. <select class="form-control-sm ml-2" v-model="batchStatus">
  81. <option v-for="(value,index) in statuses" :value="value"
  82. :name="value" :key="index">@{{ value }}
  83. </option>
  84. </select>
  85. <button @click="batchStatusUpdate()" type="button"
  86. class="btn btn-sm ml-2 btn-outline-danger">批量状态修改
  87. </button>
  88. </span>
  89. <span class="ml-1">
  90. <!-- Button trigger modal -->
  91. <button
  92. type="button"
  93. class="btn btn-sm ml-2 btn-outline-info"
  94. data-toggle="modal" data-target="#staticBackdrop">
  95. 批量添加备注
  96. </button>
  97. </span>
  98. <span class="ml-1">
  99. <button type="button" class="btn btn-outline-dark btn-sm form-control-sm tooltipTarget"
  100. @click="copyLogisticNumber" style="background: #dad7e8;">复制快递单号</button>
  101. </span>
  102. @endcan
  103. </div>
  104. <table class="table table-striped table-bordered table-hover card-body td-min-width-80" id="table">
  105. <tr v-for="(package,i) in packages" @click="selectTr===i+1?selectTr=0:selectTr=i+1"
  106. :class="selectTr===i+1?'focusing' : ''">
  107. <td>
  108. <input class="checkItem" type="checkbox" :value="package.logistic_number">
  109. </td>
  110. <td>
  111. <span style="position:relative">
  112. @{{ i+1 }}
  113. <span class="badge badge-danger" v-if="package.order.issue">问题件</span>
  114. <span
  115. style="display: inline-block;width: 15px;height: 15px;border-radius: 50%;position: absolute;top: 2px; margin-left: 3px;box-shadow: 0 0 3px #211f1f"
  116. :style="package.sync_routes_flag?'background-color:#4ed32d':'background-color:#e83939'"></span>
  117. <span v-if="package.is_manual_update">
  118. <i class="fa fa-hand-paper-o" aria-hidden="true"
  119. style="color: red;position: absolute;left: 50px;top: 3px;"></i>
  120. </span>
  121. </span>
  122. </td>
  123. <td>@{{ package.logistic_number }}</td>
  124. <td>@{{ package.status }}</td>
  125. <td>@{{ package.order != null ? package.order.logistic.name : '#' }}</td>
  126. <td>@{{ package.order != null ? package.order.owner.name : '#' }}</td>
  127. <td>@{{ package.order != null ? package.order.province : '#' }}</td>
  128. <td>@{{ package.sent_at }}</td>
  129. <td>@{{ package.received_at }}</td>
  130. <td>@{{ package.weighed_at }}</td>
  131. <td>
  132. <div v-if="package.transfer_status && package.transfer_status.length>0"
  133. class="text-overflow-warp-200 up" :id="'route-'+i">
  134. <p v-for="route in package.transfer_status">
  135. @{{ route.accept_address+" "+ route.remark+" "+route.accept_time}}
  136. </p>
  137. </div>
  138. <div class="text-overflow-warp-200 " v-if=" package.transfer_status && !showList[i] && package.transfer_status.length > 0">
  139. @{{ package.transfer_status[0].accept_address+" "+ package.transfer_status[0].remark+" "+package.transfer_status[0].accept_time}}
  140. </div>
  141. <div @click="showRoute(i)" v-if="package.transfer_status && package.transfer_status.length > 1">
  142. <label class="text-center mt-0 p-0 cursor-pointer pull-left">
  143. <span class="fa"
  144. :class="package.isShowTransferStatus ? 'fa-angle-double-down' : 'fa-angle-double-right'"></span>
  145. &nbsp;<span v-if="package.transfer_status && showList[i]">收起</span><span
  146. v-else>展开</span>&nbsp;@{{ package.transfer_status.length }} 条
  147. </label>
  148. </div>
  149. </td>
  150. <!--退件状态-->
  151. <td>@{{ package.order.issue?package.order.issue.is_new_rejecting:'' }}</td>
  152. <td class="m-0 p-0 order-package-remarks" style="padding-left: 0 !important;padding-right: 0 !important">
  153. @can('包裹管理-快递-客服备注')
  154. <label :for="'create_remark_'+package.id" class="btn-create-remark" @click="package.input_remark=!package.input_remark">
  155. </label>
  156. <input :id="'create_remark_'+package.id" @keyup.enter="submitRemark(package)" v-model="remark" v-show="package.input_remark" type="text" class="remark-input">
  157. <table class="table m-0 p-0 ">
  158. <tr v-show="package.order_package_remarks.length > 0 && package.showMoreRemark===true" v-for="(item,index) of package.order_package_remarks" :key="item.id">
  159. <td :title="item.content" style="width: 100px;overflow:hidden !important;">@{{ item.content }}</td>
  160. <td class="text-secondary">@{{ item.user.name }}</td>
  161. <td class="text-secondary remark-created_at">@{{ item.created_at }}</td>
  162. <td class="destroy"><button class="btn-destroy-remark" @click="destroyRemark(package,item.id)">删</button></td>
  163. </tr>
  164. <tr v-show="(!package.showMoreRemark) && package.order_package_remarks.length > 0" >
  165. <td :title="package.order_package_remarks[0]? package.order_package_remarks[0].content:''" style="width: 100px;overflow:hidden !important;">@{{ package.order_package_remarks[0]?package.order_package_remarks[0].content:'' }}</td>
  166. <td class="text-secondary">@{{ package.order_package_remarks[0]?package.order_package_remarks[0].user.name:'' }}</td>
  167. <td class="text-secondary remark-created_at">@{{ package.order_package_remarks[0]?package.order_package_remarks[0].created_at:'' }}</td>
  168. <td class="destroy"><button class="btn-destroy-remark" @click="destroyRemark(package,package.order_package_remarks[0].id)">删</button></td>
  169. </tr>
  170. </table>
  171. <div
  172. class="float-left"
  173. @click="package.showMoreRemark = !package.showMoreRemark" v-show="package.order_package_remarks && package.order_package_remarks.length > 1">
  174. <label class="text-center mt-0 p-0 cursor-pointer pull-left">
  175. <span class="fa"
  176. :class="package.showMoreRemark ? 'fa-angle-double-down' : 'fa-angle-double-right'"></span>
  177. &nbsp;<span v-if="package.order_package_remarks && package.showMoreRemark">收起</span><span
  178. v-else>展开</span>&nbsp;@{{ package.order_package_remarks.length }} 条
  179. </label>
  180. </div>
  181. @endcan
  182. </td>
  183. <td class="text-overflow-warp-200"><span v-if="package.order && package.order.issue">@{{ package.order.issue.result_explain }}</span>
  184. </td>
  185. <td class="text-overflow-warp-200"><span
  186. v-if="package.order && package.order.issue && package.order.issue.issue_type">@{{ package.order.issue.issue_type.name }}</span>
  187. </td>
  188. <td class="text-overflow-warp-200"><span
  189. v-if="package.order && package.order.issue && package.order.issue.logs.length >0"><span
  190. v-for="log in package.order.issue.logs">@{{ log.content }}<br></span></span></td>
  191. <td class="text-overflow-warp-200"><span
  192. v-if="package.order && package.order.issue && package.order.issue.logs.length >0"><span
  193. v-for="log in package.order.issue.logs">@{{ log.user.name }}<br></span></span></td>
  194. <td class="text-overflow-warp-200"><span
  195. v-if="package.order && package.order.issue && package.order.issue.logs.length >0"><span
  196. v-for="log in package.order.issue.logs">@{{ log.created_at }}<br></span></span></td>
  197. </tr>
  198. </table>
  199. <div class="text-info h5 btn btn">{{$orderPackages->count()}}/{{$orderPackages->total()}}</div>
  200. {{$orderPackages->appends($paginateParams)->links()}}
  201. <!-- Modal -->
  202. <div class="modal fade" id="staticBackdrop" data-backdrop="static" data-keyboard="false" tabindex="-1" aria-labelledby="staticBackdropLabel" aria-hidden="true" z-index="51">
  203. <div class="modal-dialog">
  204. <div class="modal-content">
  205. <div class="modal-header">
  206. <h5 class="modal-title" id="staticBackdropLabel">添加备注</h5>
  207. <button type="button" class="close" data-dismiss="modal" aria-label="Close">
  208. <span aria-hidden="true">&times;</span>
  209. </button>
  210. </div>
  211. <div class="modal-body">
  212. <div class="form-group">
  213. <textarea v-model="bench_remark" style="width:80%;margin: 0 auto;" class="form-control" id="exampleFormControlTextarea1" rows="3"></textarea>
  214. </div>
  215. </div>
  216. <div class="modal-footer">
  217. <button @click="bench_remark = ''" type="button" class="btn btn-secondary" data-dismiss="modal">关闭</button>
  218. <button @click="submitBenchRemark" type="button" class="btn btn-primary">提交</button>
  219. </div>
  220. </div>
  221. </div>
  222. </div>
  223. </div>
  224. <textarea id="clipboardDiv" style="opacity:0"></textarea>
  225. </div>
  226. @endsection
  227. @section('lastScript')
  228. <script type="text/javascript" src="{{mix('js/queryForm/export.js')}}"></script>
  229. <script type="text/javascript" src="{{mix('js/queryForm/queryForm.js')}}"></script>
  230. <script type="text/javascript" src="{{mix('js/queryForm/header.js')}}"></script>{{--新版2--}}
  231. <script>
  232. let vue = new Vue({
  233. el: "#list",
  234. data: {
  235. packages: [
  236. @foreach($orderPackages as $package)
  237. {!! $package !!},
  238. @endforeach
  239. ],
  240. logistics: [
  241. @foreach($logistics as $logistic)
  242. {
  243. name: '{{$logistic->id}}', value: '{{$logistic->name}}'
  244. },
  245. @endforeach
  246. ],
  247. owners: [
  248. @foreach($owners as $owner)
  249. {
  250. name: '{{$owner->id}}', value: '{{$owner->name}}'
  251. },
  252. @endforeach
  253. ],
  254. showList: {},
  255. showRemarkList: {},
  256. selectTr: 0,
  257. statuses: [
  258. '无',
  259. '已称重',
  260. '已揽收',
  261. '揽件异常',
  262. '疑似库内丢件',
  263. '在途',
  264. '在途异常',
  265. '派送中',
  266. '派送异常',
  267. '返回中',
  268. '返回异常',
  269. '返回派件',
  270. '其他异常',
  271. '已签收',
  272. ],
  273. batchStatus: null,
  274. remarkHover: null,
  275. remark: null,
  276. isShowRemarkInput: false,
  277. showBenchRemarkWrapper: false,
  278. bench_remark: '',
  279. },
  280. created() {
  281. $.each(this.packages, function (index, item) {
  282. item.isShowTransferStatus = false;
  283. item.isShowRemark = false;
  284. if (item.transfer_status != null && item.transfer_status.length > 1) {
  285. item.transfer_status.sort(function (item1, item2) {
  286. let date1 = new Date(item1.accept_time);
  287. let date2 = new Date(item2.accept_time);
  288. if (date1 - date2 > 0) return -1;
  289. if (date1 - date2 < 0) return 1;
  290. return 0;
  291. });
  292. }
  293. });
  294. },
  295. mounted() {
  296. $('#list').removeClass('d-none');
  297. let _this = this;
  298. $(".up").slideUp();
  299. let data = [
  300. [
  301. {name: 'logistic_number', type: 'input', tip: '可支持多快递单号,糊模查找需要在右边打上%符号', placeholder: '快递单号'},
  302. {name: 'remark', type: 'input', tip: '糊模查找需要在右边打上%符号', placeholder: '客服备注'},
  303. {
  304. name: 'status',
  305. type: 'select_multiple_select',
  306. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的状态'],
  307. placeholder: ['状态','定位或多选状态'],
  308. data: [
  309. {name: '1', value: '无'},
  310. {name: '2', value: '已称重'},
  311. {name: '3', value: '已揽收'},
  312. {name: '4', value: '揽件异常'},
  313. {name: '5', value: '疑似库内丢件'},
  314. {name: '6', value: '在途'},
  315. {name: '7', value: '在途异常'},
  316. {name: '8', value: '派送中'},
  317. {name: '9', value: '派送异常'},
  318. {name: '10', value: '返回中'},
  319. {name: '11', value: '返回异常'},
  320. {name: '12', value: '返回派件'},
  321. {name: '13', value: '其他异常'},
  322. {name: '14', value: '已签收'},
  323. ]
  324. },
  325. {name: 'sent_at_start', type: 'dateTime', tip: '选择显示发出时间的起始时间'},
  326. {
  327. name: 'is_weighed',
  328. type: 'select',
  329. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的状态'],
  330. placeholder: '是否称重',
  331. data: [{name: false, value: '无'}, {name: true, value: '已称重'}]
  332. },
  333. {name: 'received_at_start', type: 'dateTime', tip: '选择显示收货时间的起始时间'},
  334. {name: 'default_date', type: 'checkbox', tip: '默认15天', data: [{name: 'ture', value: '默认15天'}]},
  335. {name: 'default_logistics', type: 'checkbox', tip: '默认承运商', data: [{name: 'ture', value: '默认承运商'}]},
  336. ], [
  337. {
  338. name: 'logistic',
  339. type: 'select_multiple_select',
  340. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的快递'],
  341. placeholder: ['快递', '定位或多选快递'],
  342. data: _this.logistics
  343. },
  344. {
  345. name: 'owner',
  346. type: 'select_multiple_select',
  347. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的货主'],
  348. placeholder: ['货主', '定位或多选货主'],
  349. data: _this.owners
  350. },
  351. {
  352. name: 'has_transfer_status',
  353. type: 'select',
  354. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的状态'],
  355. placeholder: '是否有物流信息',
  356. data: [{name: '是', value: '是'}, {name: '否', value: '否'}]
  357. },
  358. {name: 'sent_at_end', type: 'dateTime', tip: '选择显示发出时间的截止时间'},
  359. {
  360. name: 'sync_routes_flag',
  361. type: 'select',
  362. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的状态'],
  363. placeholder: '是否有查询记录',
  364. data: [{name: true, value: '是'}, {name: false, value: '否'}]
  365. },
  366. {name: 'received_at_end', type: 'dateTime', tip: '选择显示收货时间的截止时间'},
  367. {
  368. name: 'is_issue',
  369. type: 'select',
  370. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的状态'],
  371. placeholder: '是否为问题件',
  372. data: [{name: '是', value: '是'}, {name: '否', value: '否'}]
  373. },
  374. {
  375. name: 'is_new_rejecting',
  376. type: 'select',
  377. tip: ['输入关键词快速定位下拉列表,回车确定', '选择要显示的状态'],
  378. placeholder: '退件状态',
  379. data: [{name: '无', value: '无'}, {name: '有', value: '有'},{name: '已处理', value: '已处理'}]
  380. },
  381. ]
  382. ];
  383. _this.form = new query({
  384. el: '#form_div',
  385. condition: data,
  386. appendDom : "btn",
  387. });
  388. _this.form.init();
  389. let column = [
  390. {name: 'index', value: '序号', neglect: true},
  391. {name: 'logistic_number', value: '单号'},
  392. {name: 'status', value: '状态'},
  393. {name: 'logistic_name', value: '快递公司'},
  394. {name: 'owner_name', value: '货主'},
  395. {name: 'province', value: '省份'},
  396. {name: 'sent_at', value: '发出日期'},
  397. {name: 'received_at', value: '收货日期'},
  398. {name: 'weighed_at', value: '称重日期'},
  399. {name: 'transfer_status', value: '快递路由'},
  400. {name: 'is_new_rejecting', value: '退件状态'},
  401. {name: 'remark', value: '客服备注'},
  402. {name: 'result_explain', value: '情况说明'},
  403. {name: 'issue_type', value: '问题类别'},
  404. {name: 'content', value: '说明'},
  405. {name: 'operation_name', value: '操作者'},
  406. {name: 'operation_date', value: '时间'},
  407. ];
  408. new Header({
  409. el: "table",
  410. name: "package",
  411. column: column,
  412. data: this.packages,
  413. restorationColumn: 'addtime',
  414. fixedTop: ($('#form_div').height()) + ($('#btn').height()) + 1,
  415. }).init();
  416. },
  417. methods: {
  418. showRoute(id) {
  419. if (this.showList[id]) {
  420. this.$set(this.showList, id, false);
  421. $("#route-" + id).slideUp();
  422. } else {
  423. this.$set(this.showList, id, true);
  424. $("#route-" + id).slideDown();
  425. }
  426. this.$forceUpdate();
  427. },
  428. showRemarkItem(id) {
  429. if (this.showRemarkList[id]) {
  430. this.$set(this.showRemarkList, id, false);
  431. $("#remark-" + id).slideUp();
  432. } else {
  433. this.$set(this.showRemarkList, id, true);
  434. $("#remark-" + id).slideDown();
  435. }
  436. this.$forceUpdate();
  437. },
  438. batchStatusUpdate() {
  439. if(!confirm('是否却认操作')) return;
  440. let _this = this;
  441. if (checkData.length === 0) {
  442. tempTip.show('没有勾选记录');
  443. return
  444. }
  445. axios.put('{{url('package/logistic/batchUpdate')}}', {
  446. status: this.batchStatus,
  447. logistic_numbers: checkData
  448. }).then(() => {
  449. tempTip.setDuration(1000);
  450. tempTip.showSuccess('批量状态成功');
  451. location.reload();
  452. })
  453. },
  454. submitBenchRemark() {
  455. let _this = this;
  456. if (checkData.length === 0) {
  457. tempTip.show('没有勾选记录');
  458. return
  459. }
  460. axios.post('{{url('apiLocal/package/logistic/benchRemark')}}', {
  461. remark: this.bench_remark,
  462. logistic_numbers: checkData
  463. }).then(() => {
  464. location.reload();
  465. })
  466. },
  467. submitRemark(orderPackage) {
  468. if (this.remark === null) {
  469. return
  470. }
  471. let url = '{{url('apiLocal/package/logistic/')}}';
  472. let _this = this;
  473. tempTip.setDuration(2000);
  474. tempTip.showSuccess('正在操作请稍后!');
  475. axios.put(url, {remark: _this.remark, orderPackageId: orderPackage.id}).then(response=>{
  476. if (response.data.success) {
  477. orderPackage.order_package_remarks = response.data.data
  478. tempTip.setDuration(2000);
  479. tempTip.showSuccess('成功!');
  480. _this.remark = '';
  481. orderPackage.input_remark = false;
  482. } else {
  483. tempTip.setDuration(5000);
  484. tempTip.show(response.data.fail_info);
  485. }
  486. }).catch(function (err) {
  487. tempTip.setDuration(3000);
  488. tempTip.show("网络错误:" + err)
  489. });
  490. },
  491. destroyRemark(orderPackage,remarkId) {
  492. let url = '{{url('apiLocal/package/logistic/delete')}}';
  493. if (!confirm('是否却认删除', false)) {
  494. return;
  495. };
  496. let _this = this;
  497. tempTip.setDuration(2000);
  498. tempTip.showSuccess('正在操作请稍后!');
  499. axios.post(url, {orderPackageId: orderPackage.id,remarkId:remarkId}).then(response=>{
  500. if (response.data.success) {
  501. orderPackage.order_package_remarks = response.data.data
  502. tempTip.setDuration(2000);
  503. tempTip.showSuccess('成功!');
  504. } else {
  505. tempTip.setDuration(5000);
  506. tempTip.show(response.data.fail_info);
  507. }
  508. }).catch(function (err) {
  509. tempTip.setDuration(3000);
  510. tempTip.show("网络错误:" + err)
  511. });
  512. },
  513. copyLogisticNumber() {
  514. if (checkData.length === 0) {
  515. tempTip.show('没有勾选');
  516. return;
  517. }
  518. this.copyText(checkData.join('\n'));
  519. },
  520. copyText(text) {
  521. try {
  522. $('#clipboardDiv').text(text).select().focus();
  523. document.execCommand("Copy");
  524. tempTip.setIndex(1052)
  525. tempTip.setDuration(2000)
  526. tempTip.showSuccess('复制成功')
  527. } catch (e) {
  528. tempTip.setIndex(1052)
  529. tempTip.setDuration(2000)
  530. tempTip.showSuccess('复制失败:' + e)
  531. }
  532. },
  533. orderPackageExport(sign) {
  534. let url = '{{url('package/logistic/export')}}';
  535. let token = '{{ csrf_token() }}';
  536. if (sign) {
  537. excelExport(true, checkData, url, this.total, token);
  538. } else {
  539. excelExport(false, checkData, url, null, token);
  540. }
  541. },
  542. },
  543. filters: {
  544. toObjected: function (value) {
  545. return JSON.parse(value);
  546. }
  547. },
  548. });
  549. </script>
  550. @endsection