PackageLogisticController.php 9.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  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 Illuminate\Support\Carbon;
  13. use Oursdreams\Export\Export;
  14. class PackageLogisticController extends Controller
  15. {
  16. /**
  17. * PackageLogisticsController constructor.
  18. */
  19. public function __construct()
  20. {
  21. $this->middleware('auth');
  22. }
  23. public function index(Request $request, OrderPackageFilters $filters)
  24. {
  25. /** @var UserService $userService */
  26. $userService = app('UserService');
  27. $owner_ids = $userService->getPermittingOwnerIds(auth()->user());
  28. $paginateParams = $request->input();
  29. $orderPackages = OrderPackage::query()
  30. ->filter($filters)
  31. ->whereIn('owner_id', $owner_ids)
  32. ->with([
  33. 'order.logistic',
  34. 'order.batch:id,wms_type',
  35. 'order.OracleDOCOrderHeader:orderno,notes,WaveNo',
  36. 'rejectedBill' => function ($query) {
  37. $query->select('id', 'logistic_number', 'logistic_number_return')->where('logistic_number', '原单退回');
  38. },
  39. 'orderPackageRemarks' => function ($query) {
  40. $query->with('user')->orderByDesc('created_at');
  41. },
  42. 'order.owner',
  43. 'order.issue' => function ($query) {
  44. $query->with(['issueType', 'logs' => function ($query) {
  45. $query->with('user')->orderBy('created_at', 'DESC');
  46. }]);
  47. }])
  48. ->orderByDesc('id')
  49. ->simplePaginate($request->paginate ?? 50);
  50. $logistics = Logistic::all();
  51. $owners = app("OwnerService")->getIntersectPermitting();
  52. return view('package.logistic.index', compact('orderPackages', 'logistics', 'owners', 'paginateParams'));
  53. }
  54. /**
  55. * 获取查询条件下的总条数
  56. * @param Request $request
  57. * @param OrderPackageFilters $filters
  58. * @return array
  59. */
  60. public function getTotal(Request $request, OrderPackageFilters $filters): array
  61. {
  62. /** @var UserService $userService */
  63. $userService = app('UserService');
  64. $owner_ids = $userService->getPermittingOwnerIds(auth()->user());
  65. $total = OrderPackage::query()
  66. ->selectRaw("count(*) as total")
  67. ->filter($filters)
  68. ->whereIn('owner_id', $owner_ids)
  69. ->first();
  70. return ['success' => true, 'data' => ['total' => $total->total]];
  71. }
  72. public function update(Request $request)
  73. {
  74. $data = [];
  75. if ('无' == $request->input('exception_type')) {
  76. $data['exception_type'] = $request->input('exception_type');
  77. $data['exception'] = "否";
  78. } else {
  79. $data['exception_type'] = $request->input('exception_type');
  80. }
  81. OrderPackage::query()->where('id', $request['id'])->update($data);
  82. //更新统计数据
  83. event(new UpdateOrderPackageExceptionListenerEvent([$request['id']]));
  84. }
  85. public function batchUpdate(Request $request)
  86. {
  87. $status = $request->input('status');
  88. if (!empty($status)) {
  89. $data = [
  90. 'status' => OrderPackage::switchStatus($status),
  91. //标记为手动更新
  92. 'is_manual_update' => true,
  93. ];
  94. if ($status === '已签收') {
  95. $data['exception_status'] = 0;
  96. }
  97. OrderPackage::query()->whereIn('logistic_number', $request->input('logistic_numbers'))->update($data);
  98. } else if (!empty($request->input('exceptionStatus'))) {
  99. OrderPackage::query()->whereIn('logistic_number', $request->input('logistic_numbers'))->update([
  100. 'exception_status' => OrderPackage::switchExceptionStatus($request->input('exceptionStatus')),
  101. //标记为手动更新
  102. 'is_manual_update' => true,
  103. ]);
  104. }
  105. }
  106. /**
  107. * @throws Exception
  108. */
  109. public function export(Request $request, OrderPackageFilters $filters)
  110. {
  111. ini_set('max_execution_time', 300);
  112. /** @var UserService $userService */
  113. $userService = app('UserService');
  114. $owner_ids = $userService->getPermittingOwnerIds(auth()->user());
  115. $query = OrderPackage::query()
  116. ->whereIn('owner_id', $owner_ids)
  117. ->filter($filters)
  118. ->with([
  119. 'order.logistic',
  120. 'rejectedBill' => function ($query) {
  121. $query->select('id', 'logistic_number', 'logistic_number_return')->where('logistic_number', '原单退回');
  122. },
  123. 'orderPackageRemarks' => function ($query) {
  124. $query->with('user')->orderByDesc('created_at');
  125. },
  126. 'order.owner',
  127. 'order.issue' => function ($query) {
  128. $query->with(['issueType', 'logs' => function ($query) {
  129. $query->with('user')->orderBy('created_at', 'DESC');
  130. }]);
  131. }])
  132. ->orderByDesc('id');
  133. if ($request->exists('checkAllSign')) {
  134. $orderPackages = $query->orderByDesc('id')->get();
  135. } else {
  136. $orderPackages = $query
  137. ->whereIn('logistic_number', explode(',', $request['data']))
  138. ->orderByDesc('id')->get();
  139. }
  140. $row = [
  141. '单号',
  142. '状态',
  143. '快递公司',
  144. '货主',
  145. '省份',
  146. '复核时间',
  147. '收货时间',
  148. '称重时间',
  149. '快递路由',
  150. '退件状态',
  151. '订单备注',
  152. '客服备注',
  153. '情况说明',
  154. '问题类别',
  155. '波次规则',
  156. '波次号',
  157. '说明',
  158. '操作者',
  159. '时间',
  160. ];
  161. $json = [];
  162. foreach ($orderPackages as $orderPackage) {
  163. $transfer_status = "";
  164. if (is_array($orderPackage->transfer_status) && !empty($orderPackage->transfer_status)) {
  165. foreach ($orderPackage->transfer_status as $transfer) {
  166. $transferItemStr = "";
  167. $transferItemStr = $transferItemStr . $transfer['accept_address'] ?? '' . " " . $transfer['remark'] ?? '' . " " . $transfer['accept_time'] ?? '';
  168. $transfer_status = $transfer_status . $transferItemStr . ",\r\n";
  169. }
  170. }
  171. $remark = "";
  172. if (!empty($orderPackage->orderPackageRemarks)) {
  173. foreach ($orderPackage->orderPackageRemarks as $remarkItem) {
  174. $remark = $remark . $remarkItem->content ?? '' . '-' . $remarkItem->user->name ?? '' . '-' . $remarkItem->created_at ?? '' . ",\r\n";
  175. }
  176. }
  177. $logsContent = "";
  178. $users = "";
  179. $logCreatedAt = "";
  180. if ($orderPackage->order && $orderPackage->order->issue) {
  181. foreach ($orderPackage->order->issue->logs as $log) {
  182. $logsContent = $logsContent . $log->content . ",\r\n";
  183. $name = '';
  184. if (!empty($log->user)) {
  185. $name = $log->user->name;
  186. }
  187. $users = $users . $name . ",\r\n";
  188. $logCreatedAt = $logCreatedAt . $log->created_at . ",\r\n";
  189. }
  190. }
  191. $data = [
  192. $orderPackage->logistic_number ?? '',//单号
  193. $orderPackage->status ?? '',//状态
  194. $orderPackage->order->logistic->name ?? '',//快递公司
  195. $orderPackage->order->owner->name ?? '',//货主
  196. $orderPackage->order->province ?? '',//省份
  197. $orderPackage->sent_at ? $orderPackage->sent_at->toDateTimeString() : '',//复核时间
  198. $orderPackage->received_at ? $orderPackage->received_at->toDateTimeString() : '',//收货时间
  199. $orderPackage->weighed_at ? $orderPackage->weighed_at->toDateTimeString() : '',//称重时间
  200. $transfer_status ?? '',//快递路由
  201. empty($orderPackage->rejectedBill) ? '无' : '有',//退件状态
  202. $orderPackage->order->OracleDOCOrderHeader->notes ?? '',//订单备注
  203. $remark ?? '',//客服备注
  204. $orderPackage->order->issue->result_explain ?? '',//情况说明
  205. $orderPackage->order->issue->issueType->name ?? '',//问题类别
  206. $orderPackage->order->batch->wms_type ?? '',//波次规则
  207. $orderPackage->order->OracleDOCOrderHeader->waveno ?? '',//波次号
  208. $logsContent ?? '',//说明
  209. $users ?? '',//操作者
  210. $logCreatedAt ?? '',//时间
  211. ];
  212. $json[] = $data;
  213. }
  214. return Export::make($row, $json, "包裹快递");
  215. }
  216. }