PackageLogisticController.php 8.2 KB

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