PackageLogisticController.php 6.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Events\UpdateOrderPackageExceptionListenerEvent;
  4. use App\Exceptions\Exception;
  5. use App\Filters\OrderPackageFilters;
  6. use App\Logistic;
  7. use App\OrderPackage;
  8. use App\Owner;
  9. use App\Services\common\ExportService;
  10. use App\Services\UserService;
  11. use Illuminate\Http\Request;
  12. use Oursdreams\Export\Export;
  13. class PackageLogisticController extends Controller
  14. {
  15. /**
  16. * PackageLogisticsController constructor.
  17. */
  18. public function __construct()
  19. {
  20. $this->middleware('auth');
  21. }
  22. public function index(Request $request, OrderPackageFilters $filters)
  23. {
  24. /** @var UserService $userService */
  25. $userService = app('UserService');
  26. $owner_ids = $userService->getPermittingOwnerIds(auth()->user());
  27. $paginateParams = $request->input();
  28. $orderPackages = OrderPackage::query()
  29. ->filter($filters)
  30. ->with(['order.logistic',
  31. 'orderPackageRemarks'=>function ($query){
  32. $query->with('user')->orderByDesc('created_at');
  33. },
  34. 'order.owner',
  35. 'order.issue' => function ($query) {
  36. $query->with(['issueType', 'logs' => function ($query) {
  37. $query->with('user')->orderBy('created_at', 'DESC');
  38. }]);
  39. }])
  40. ->orderByDesc('id')
  41. ->paginate($request->paginate ?? 50);
  42. $logistics = Logistic::all();
  43. $owners = Owner::find($owner_ids);
  44. return view('package.logistic.index', compact('orderPackages', 'logistics', 'owners', 'paginateParams'));
  45. }
  46. public function update(Request $request)
  47. {
  48. $data = [];
  49. if ('无' == $request->input('exception_type')) {
  50. $data['exception_type'] = $request->input('exception_type');
  51. $data['exception'] = "否";
  52. } else {
  53. $data['exception_type'] = $request->input('exception_type');
  54. }
  55. OrderPackage::query()->where('id', $request['id'])->update($data);
  56. //更新统计数据
  57. event(new UpdateOrderPackageExceptionListenerEvent([$request['id']]));
  58. }
  59. public function batchUpdate(Request $request)
  60. {
  61. $data = [];
  62. if (array_key_exists('exception_type', $request->all())) {
  63. if ('无' == $request->input('exception_type')) {
  64. $data['exception_type'] = $request->input('exception_type');
  65. $data['exception'] = "否";
  66. } else {
  67. $data['exception_type'] = $request->input('exception_type');
  68. }
  69. } else if (array_key_exists('status', $request->all())) {
  70. $data['status'] = $request->input('status');
  71. }
  72. $logistic_numbers = $request->input('logistic_numbers');
  73. OrderPackage::query()->whereIn('logistic_number', $logistic_numbers)->update($data);
  74. //更新统计数据
  75. event(new UpdateOrderPackageExceptionListenerEvent($logistic_numbers));
  76. }
  77. /**
  78. * @throws Exception
  79. */
  80. public function export(Request $request, OrderPackageFilters $filters)
  81. {
  82. /** @var UserService $userService */
  83. $userService = app('UserService');
  84. $owner_ids = $userService->getPermittingOwnerIds(auth()->user());
  85. $query = OrderPackage::query()
  86. ->filter($filters)
  87. ->whereIn('owner_id', $owner_ids)
  88. ->with(['order.logistic', 'order.owner', 'order.issue' => function ($query) {
  89. $query->with(['issueType', 'logs' => function ($query) {
  90. $query->with('user')->orderBy('created_at', 'DESC');
  91. }]);
  92. }]);
  93. if ($request->exists('checkAllSign')) {
  94. $orderPackages = $query->orderByDesc('id')->get();
  95. } else {
  96. $orderPackages = $query
  97. ->whereIn('logistic_number', explode(',', $request['data']))
  98. ->orderByDesc('id')->get();
  99. }
  100. $row = ["异常类型", "单号", "状态", "快递公司", "货主", "省份", "发出日期", "收货日期", "称重日期", "快递路由", "客服备注", "情况说明", "问题类别", "说明", "操作者", "时间",];
  101. $json = [];
  102. foreach ($orderPackages as $orderPackage) {
  103. $transfer_status = "";
  104. if (is_array($orderPackage->transfer_status) && !empty($orderPackage->transfer_status)) {
  105. foreach ($orderPackage->transfer_status as $transfer) {
  106. $transferItemStr = "";
  107. $transferItemStr = $transferItemStr . $transfer['accept_address'] . " " . $transfer['remark'] . " " . $transfer['accept_time'];
  108. $transfer_status = $transfer_status . $transferItemStr . ",\r\n";
  109. }
  110. }
  111. $remark = "";
  112. if (is_array($orderPackage->remark) && !empty($orderPackage->remark)) {
  113. foreach ($orderPackage->remark as $remarkItem) {
  114. $remark = $remark . $remarkItem . ",\r\n";
  115. }
  116. }
  117. $logsContent = "";
  118. $users = "";
  119. $logCreatedAt = "";
  120. if ($orderPackage->order && $orderPackage->order->issue) {
  121. foreach ($orderPackage->order->issue->logs as $log) {
  122. $logsContent = $logsContent . $log->content . ",\r\n";
  123. $users = $users . $log->user->name . ",\r\n";
  124. $logCreatedAt = $logCreatedAt . $log->created_at . ",\r\n";
  125. }
  126. }
  127. $data = [
  128. $orderPackage->exception_type,
  129. $orderPackage->logistic_number,
  130. $orderPackage->status,
  131. $orderPackage->order->logistic->name,
  132. $orderPackage->order->owner->name,
  133. $orderPackage->order->province,
  134. $orderPackage->sent_at,
  135. $orderPackage->received_at,
  136. $orderPackage->weighed_at,
  137. $transfer_status,
  138. $remark,
  139. $logsContent,
  140. $users,
  141. $logCreatedAt,
  142. ];
  143. $json[] = $data;
  144. }
  145. return Export::make($row, $json, "包裹快递");
  146. }
  147. }