| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243 |
- <?php
- namespace App\Services;
- use App\Order;
- use App\OrderIssue;
- use App\OrderIssueType;
- use App\OrderPackage;
- use App\Traits\ServiceAppAop;
- use App\WorkOrder;
- use App\WorkOrderType;
- use Illuminate\Database\Eloquent\Builder;
- use Illuminate\Support\Carbon;
- use Illuminate\Support\Facades\Auth;
- class WorkOrderService
- {
- use ServiceAppAop;
- protected $modelClass = WorkOrder::class;
- protected $work_type_relation = [
- '拦截' => '订单拦截',
- '信息更改' => '订单收件信息修改',
- '其他' => '订单其他异常',
- '快递异常' => '订单快递异常',
- '错漏发' => '快递错漏发',
- '破损' => '快递破损',
- ];
- /**
- * 获取可生成工单的问题件类型
- * @return Builder[]|\Illuminate\Database\Eloquent\Collection
- */
- public function getIssueType()
- {
- return OrderIssueType::query()->whereIn('name', ['拦截', '信息更改', '其他', '快递异常', '错漏发', '破损'])->get();
- }
- /**
- * 生成工单
- * @param $params
- * @return array|bool[]
- */
- public function build($params): array
- {
- $types = [];
- $work_order_types = [];
- $data = Carbon::now();
- $creator_id = Auth::user()['id'];
- $parent = WorkOrderType::query()->firstOrCreate(['name' => '订单', 'prent_id' => 0, 'level' => 1]);
- foreach ($params as $param) {
- $order = Order::query()->where('code', $param['order_no'])->first();
- $type_name = $param['order_issue_type'];
- if (!$param['order_issue_type']) {
- $order_issue_type_id = 0;
- $work_order_type_id = 0;
- } else {
- if (!array_key_exists($type_name, $types)) {
- $types[$type_name] = OrderIssueType::query()->where('name', $type_name)->first();
- $work_order_type_name = $this->work_type_relation[$type_name] ?? $type_name;
- $work_order_types[$type_name] = WorkOrderType::query()->firstOrCreate(
- ['name' => $work_order_type_name],
- ['prent_id' => $parent['id'], 'table_name' => 'orders', 'level' => 2]
- );
- }
- $order_issue_type_id = $types[$type_name]['id'] ?? 0;
- $work_order_type_id = $work_order_types[$type_name]['id'] ?? 0;
- }
- switch ($type_name) {
- case '拦截':
- $remark = "拦截订单";
- break;
- case '信息更改':
- case '其他':
- case '快递异常':
- case '错漏发':
- case '破损':
- $remark = $param['remark'] ?? '';
- break;
- default:
- $work_order_type_id = 0;
- $remark = $param['remark'] ?? '';
- $order_issue_type_id = 0;
- break;
- }
- $inner_params[] = [
- 'order_id' => $order['id'],
- 'creator_id' => $creator_id,
- 'work_order_type_id' => $work_order_type_id ?? 0,
- 'owner_id' => $order['owner_id'] ?? '',
- 'grad' => $param['grad'] ?? 1,
- 'remark' => $remark,
- 'outer_table_name' => 'orders',
- 'order_issue_type_id' => $order_issue_type_id ?? 0,
- 'uniquely_tag' => $order['code'] ?? null,
- 'status' => 1,
- 'created_at' => $data,
- 'updated_at' => $data,
- ];
- }
- if (isset($inner_params)) {
- WorkOrder::query()->insert($inner_params);
- $workOrders = WorkOrder::query()->with('owner','order')->whereIn('order_id',data_get($inner_params,"*.order_id"))->where('created_at',">=",$data)->get();
- foreach ($workOrders as $workOrder){
- $user = Auth::user();
- $remark = $workOrder->remark;
- $ownerName = $workOrder->owner->name ?? '';
- $clientCode = $workOrder->order->client_code ?? '';
- $msg = $user["name"]."建立了新工单<br/>".$ownerName.":".$clientCode."<br/>".$remark;
- NotificationService::SingleRegister($msg,$clientCode,"订单管理-问题件");
- }
- return ['success' => true];
- }
- return ['success' => false, 'message' => '参数异常'];
- }
- /**
- * 工单审核
- * @param $wordOrder
- * @return array
- */
- public function review($wordOrder): array
- {
- $wordOrder->update(['reviewer_id' => Auth::user()['id'], 'review_at' => Carbon::now(), 'status' => '2',]);
- $workOrders = WorkOrder::query()->with(['type', 'creator', 'order' => function ($query) {
- /** @var $query Builder */
- $query->with('packages', 'issue', 'logistic');
- }, 'reviewer'])->whereIn('id', [$wordOrder['id']])->get();
- $this->tags($workOrders);
- return ['success' => true, 'data' => $workOrders->first()];
- }
- /**
- * 批量审核工单
- * @param $workOrders
- * @return array
- */
- public function batchReview($workOrders): array
- {
- $ids = $workOrders->map(function ($item) {
- return $item->id;
- })->toArray();
- WorkOrder::query()->whereIn('id', $ids)->update(['review_at' => Carbon::now(), 'reviewer_id' => Auth::user()['id'], 'status' => '2']);
- $wordOrders = WorkOrder::query()->with(['type', 'creator', 'order' => function ($query) {
- /** @var $query Builder */
- $query->with('packages', 'issue', 'logistic');
- }, 'reviewer'])->whereIn('id', $ids)->get();
- $this->tags($wordOrders);
- return ['success' => true, 'data' => $wordOrders];
- }
- /**
- * 生成问题件
- * @param $work_orders
- * @return array
- */
- public function buildOrderIssue($work_orders): array
- {
- foreach ($work_orders as $work_order) {
- $inner_params[] = [
- 'order_id' => $work_order->order_id,
- 'order_issue_type_id' => $work_order->order_issue_type_id,
- 'result_explain' => $work_order->remark,
- ];
- }
- if (!isset($inner_params)) return ['success' => false, 'message' => '创建问题件失败'];
- return app('OrderIssueService')->buildOrderIssue($inner_params);
- }
- /**
- * 按 指定工单类型 和 唯一标识 确认工单是否存在
- * @param $work_order_type_id
- * @param $uniquely_tag
- * @return array|false[]
- */
- public function exists($work_order_type_id, $uniquely_tag): array
- {
- $query = WorkOrder::query()->where('work_order_type_id', $work_order_type_id);
- if (is_array($uniquely_tag)) $query->whereIn('uniquely_tag', $uniquely_tag);
- if (is_string($uniquely_tag)) $query->where('uniquely_tag', $uniquely_tag);
- $items = $query->get();
- if (count($items) > 0) {
- $exists_nos = $items->map(function ($item) {
- return $item->uniquely_tag;
- });
- return ['success' => true, 'data' => $exists_nos];
- }
- return ['success' => false];
- }
- /**
- * 标记已有 问题件的工单
- * @param $workOrders
- */
- public function tags(&$workOrders)
- {
- $order_ids = $workOrders->map(function ($item) {
- return $item->order_id;
- });
- $order_issues = OrderIssue::query()->whereIn('order_id', $order_ids)->get();
- foreach ($order_issues as $order_issue) {
- $codes[$order_issue->order_id] = true;
- }
- if (!isset($codes)) return;
- foreach ($workOrders as &$workOrder) {
- if (array_key_exists($workOrder->order_id, $codes)) $workOrder->is_issue_order = true;
- else $workOrder->is_issue_order = false;
- }
- }
- /**
- * 判断是否拦截工单
- * @param $logistic_number
- * @return bool
- */
- public function isIntercept($logistic_number): bool
- {
- $package_query = OrderPackage::query()->select('order_id')->where('logistic_number', $logistic_number);
- $order_issue_query = OrderIssueType::query()->select('id')->where('name', '拦截');
- return WorkOrder::query()->whereIn('order_id', $package_query)->whereIn('order_issue_type_id', $order_issue_query)->exists();
- }
- public function tagWorkOrder(&$orders)
- {
- $orderNos = data_get($orders,'*.orderno');
- $workOrders = WorkOrder::query()->with('order')->where('order_id',function($query)use($orderNos) {
- $query->from('orders')->select('id')->whereIn('code', $orderNos);
- })->get();
- $tags = [];
- $workOrders->each(function($workOrder)use(&$tags){
- $order_code = $workOrder->order->code ?? null;
- if ($order_code) $tags[$order_code]= true;
- });
- foreach ($orders as &$order) {
- if (array_key_exists($order->orderno,$tags)) $order->is_work_order= true;
- else $order->is_work_order = false;
- }
- }
- }
|