PackageLogisticController.php 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869
  1. <?php
  2. namespace App\Http\Controllers;
  3. use App\Events\UpdateOrderPackageExceptionListenerEvent;
  4. use App\Filters\OrderPackageFilters;
  5. use App\Logistic;
  6. use App\OrderPackage;
  7. use App\Owner;
  8. use App\Services\UserService;
  9. use Illuminate\Http\Request;
  10. class PackageLogisticController extends Controller
  11. {
  12. /**
  13. * PackageLogisticsController constructor.
  14. */
  15. public function __construct()
  16. {
  17. $this->middleware('auth');
  18. }
  19. public function index(Request $request, OrderPackageFilters $filters)
  20. {
  21. /** @var UserService $userService */
  22. $userService = app('UserService');
  23. $owner_ids = $userService->getPermittingOwnerIds(auth()->user());
  24. $paginateParams = $request->input();
  25. $orderPackages = OrderPackage::query()
  26. ->filter($filters)
  27. ->whereIn('owner_id', $owner_ids)->with(['order.logistic', 'order.owner', 'order.issue' => function ($query) {
  28. $query->with(['issueType', 'logs'=>function($query) {
  29. $query->with('user')->orderBy('created_at', 'DESC');
  30. }]);
  31. }])->orderByDesc('id')->paginate($request->paginate ?? 50);
  32. $logistics = Logistic::all();
  33. $owners = Owner::find($owner_ids);
  34. return view('package.logistic.index', compact('orderPackages', 'logistics', 'owners', 'paginateParams'));
  35. }
  36. public function update(Request $request)
  37. {
  38. $data = [];
  39. if ('无' == $request->input('exception_type')) {
  40. $data['exception_type'] = $request->input('exception_type');
  41. $data['exception'] = "否";
  42. } else {
  43. $data['exception_type'] = $request->input('exception_type');
  44. }
  45. OrderPackage::query()->where('id', $request['id'])->update($data);
  46. //更新统计数据
  47. event(new UpdateOrderPackageExceptionListenerEvent([$request['id']]));
  48. }
  49. public function batchUpdate(Request $request)
  50. {
  51. if ('无' == $request->input('exception_type')) {
  52. $data['exception_type'] = $request->input('exception_type');
  53. $data['exception'] = "否";
  54. } else {
  55. $data['exception_type'] = $request->input('exception_type');
  56. }
  57. $logistic_numbers = $request->input('logistic_numbers');
  58. OrderPackage::query()->whereIn('logistic_number', $logistic_numbers)->update($data);
  59. //更新统计数据
  60. event(new UpdateOrderPackageExceptionListenerEvent($logistic_numbers));
  61. }
  62. }