PackageLogisticController.php 10 KB

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