| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153 |
- <?php
- namespace App\Http\Controllers;
- use App\Events\UpdateOrderPackageExceptionListenerEvent;
- use App\Exceptions\Exception;
- use App\Filters\OrderPackageFilters;
- use App\Logistic;
- use App\OrderPackage;
- use App\Owner;
- use App\Services\common\ExportService;
- use App\Services\UserService;
- use Illuminate\Http\Request;
- class PackageLogisticController extends Controller
- {
- /**
- * PackageLogisticsController constructor.
- */
- public function __construct()
- {
- $this->middleware('auth');
- }
- public function index(Request $request, OrderPackageFilters $filters)
- {
- /** @var UserService $userService */
- $userService = app('UserService');
- $owner_ids = $userService->getPermittingOwnerIds(auth()->user());
- $paginateParams = $request->input();
- $orderPackages = OrderPackage::query()
- ->filter($filters)
- ->with(['order.logistic',
- 'orderPackageRemarks'=>function ($query){
- $query->with('user')->orderByDesc('created_at');
- },
- 'order.owner',
- 'order.issue' => function ($query) {
- $query->with(['issueType', 'logs' => function ($query) {
- $query->with('user')->orderBy('created_at', 'DESC');
- }]);
- }])
- ->orderByDesc('id')
- ->paginate($request->paginate ?? 50);
- $logistics = Logistic::all();
- $owners = Owner::find($owner_ids);
- return view('package.logistic.index', compact('orderPackages', 'logistics', 'owners', 'paginateParams'));
- }
- public function update(Request $request)
- {
- $data = [];
- if ('无' == $request->input('exception_type')) {
- $data['exception_type'] = $request->input('exception_type');
- $data['exception'] = "否";
- } else {
- $data['exception_type'] = $request->input('exception_type');
- }
- OrderPackage::query()->where('id', $request['id'])->update($data);
- //更新统计数据
- event(new UpdateOrderPackageExceptionListenerEvent([$request['id']]));
- }
- public function batchUpdate(Request $request)
- {
- $data = [];
- if (array_key_exists('exception_type', $request->all())) {
- if ('无' == $request->input('exception_type')) {
- $data['exception_type'] = $request->input('exception_type');
- $data['exception'] = "否";
- } else {
- $data['exception_type'] = $request->input('exception_type');
- }
- } else if (array_key_exists('status', $request->all())) {
- $data['status'] = $request->input('status');
- }
- $logistic_numbers = $request->input('logistic_numbers');
- OrderPackage::query()->whereIn('logistic_number', $logistic_numbers)->update($data);
- //更新统计数据
- event(new UpdateOrderPackageExceptionListenerEvent($logistic_numbers));
- }
- /**
- * @throws Exception
- */
- public function export(Request $request, OrderPackageFilters $filters)
- {
- /** @var UserService $userService */
- $userService = app('UserService');
- $owner_ids = $userService->getPermittingOwnerIds(auth()->user());
- $query = OrderPackage::query()
- ->filter($filters)
- ->whereIn('owner_id', $owner_ids)
- ->with(['order.logistic', 'order.owner', 'order.issue' => function ($query) {
- $query->with(['issueType', 'logs' => function ($query) {
- $query->with('user')->orderBy('created_at', 'DESC');
- }]);
- }]);
- if ($request->exists('checkAllSign')) {
- $orderPackages = $query->orderByDesc('id')->get();
- } else {
- $orderPackages = $query
- ->whereIn('logistic_number', explode(',', $request['data']))
- ->orderByDesc('id')->get();
- }
- $row = ["异常类型", "单号", "状态", "快递公司", "货主", "省份", "发出日期", "收货日期", "称重日期", "快递路由", "客服备注", "情况说明", "问题类别", "说明", "操作者", "时间",];
- $json = [];
- foreach ($orderPackages as $orderPackage) {
- $transfer_status = "";
- if (is_array($orderPackage->transfer_status) && !empty($orderPackage->transfer_status)) {
- foreach ($orderPackage->transfer_status as $transfer) {
- $transferItemStr = "";
- $transferItemStr = $transferItemStr . $transfer['accept_address'] . " " . $transfer['remark'] . " " . $transfer['accept_time'];
- $transfer_status = $transfer_status . $transferItemStr . ",\r\n";
- }
- }
- $remark = "";
- if (is_array($orderPackage->remark) && !empty($orderPackage->remark)) {
- foreach ($orderPackage->remark as $remarkItem) {
- $remark = $remark . $remarkItem . ",\r\n";
- }
- }
- $logsContent = "";
- $users = "";
- $logCreatedAt = "";
- if ($orderPackage->order && $orderPackage->order->issue) {
- foreach ($orderPackage->order->issue->logs as $log) {
- $logsContent = $logsContent . $log->content . ",\r\n";
- $users = $users . $log->user->name . ",\r\n";
- $logCreatedAt = $logCreatedAt . $log->created_at . ",\r\n";
- }
- }
- $data = [
- $orderPackage->exception_type,
- $orderPackage->logistic_number,
- $orderPackage->status,
- $orderPackage->order->logistic->name,
- $orderPackage->order->owner->name,
- $orderPackage->order->province,
- $orderPackage->sent_at,
- $orderPackage->received_at,
- $orderPackage->weighed_at,
- $transfer_status,
- $remark,
- $logsContent,
- $users,
- $logCreatedAt,
- ];
- $json[] = $data;
- }
- return app(ExportService::class)->json($row, $json, "包裹快递");
- }
- }
|