Răsfoiți Sursa

修改拼团

dongxiaoqin 1 an în urmă
părinte
comite
cbdef3c5f9

+ 3 - 1
app/adminapi/lists/master_worker/MasterWorkerOnlineLists.php

@@ -82,7 +82,7 @@ class MasterWorkerOnlineLists extends BaseAdminDataLists implements ListsSearchI
      */
     public function lists(): array
     {
-        $fields = ['mw.id,mw.avatar,mw.real_name,mw.mobile,mw.work_total,mw.distance,mw.accept_order_status,mw.area_name,mw.service_area_id,mws.comprehensive_score, mws.weight_score,sa.service_name'];
+        $fields = ['mw.id,mw.avatar,mw.real_name,mw.mobile,mw.work_total,mw.distance,mw.accept_order_status,mw.area_name,mw.service_area_id,mws.comprehensive_score, mws.weight_score,sa.service_name,mwr.credential_images'];
         $orders = ['mw.id' => 'desc'];
         $queryWhere = $this->queryWhere();
         // 根据位置排序
@@ -98,6 +98,7 @@ class MasterWorkerOnlineLists extends BaseAdminDataLists implements ListsSearchI
         $list = MasterWorker::alias('mw')
             ->join('master_worker_score mws', 'mws.worker_id = mw.id')
             ->join('service_area sa', 'sa.id = mw.service_area_id')
+            ->join('master_worker_register mwr', 'mwr.worker_id = mw.id')
             ->where(['mw.is_disable' => 0, 'mw.work_status' => 0,'mw.audit_state' => 1])
             ->where($this->searchWhere)
             ->where($queryWhere)
@@ -112,6 +113,7 @@ class MasterWorkerOnlineLists extends BaseAdminDataLists implements ListsSearchI
                                     ->where('service_status','<',4)
                                     ->whereBetween('appointment_time',[strtotime(date("Y-m-d")),strtotime(date("Y-m-d 23:59:59"))])
                                     ->count();
+            $item['credential_images'] = $item['credential_images'] ? json_decode($item['credential_images'],true) : [];
         }
         return $list;
     }

+ 0 - 4
app/adminapi/logic/group_activity/GroupOrderLogic.php

@@ -65,10 +65,6 @@ class GroupOrderLogic extends BaseLogic
     {
         $detail = GroupOrder::findOrEmpty($params['id']);
         if (!$detail->isEmpty() && $detail->work_status == 0 && $detail->status == 1) {
-
-            // 异步调用 changeWorkStatus 方法
-            Queue::push(\app\job\AddServiceWorkJob::class, ['id' => $params['id']]);
-            
             $detail->work_status = 1;
             $detail->save();
         }

+ 0 - 143
app/job/AddServiceWorkJob.php

@@ -1,143 +0,0 @@
-<?php
-namespace app\job;
-
-use think\facade\Db;
-use think\queue\Job;
-use think\facade\Log;
-use app\common\enum\WorkEnum;
-use app\common\model\equity\UserEquity;
-use app\common\model\recharge\OrderGoods;
-use app\common\model\equity\UserEquityLog;
-use app\common\model\group_activity\GroupActivity;
-use app\common\model\works\GroupServiceWork;
-use app\common\model\group_activity\GroupOrder;
-use app\common\model\group_activity\GroupUserOrder;
-
-class AddServiceWorkJob
-{
-    public function fire(Job $job, $data)
-    {
-        
-        $group_order_id = $data['id'];//拼团订单ID
-        $goods = [];
-        $category = GroupOrder::alias('a')
-                    ->leftJoin('group_activity_category b','a.group_category_id=b.id')
-                    ->leftJoin('group_activity c','a.group_activity_id=c.id')
-                    ->where('a.id', $group_order_id)
-                    ->field('b.service_time,b.master_worker_id,c.price,c.work_amount,c.settlement_amount')
-                    ->findOrEmpty()
-                    ->toArray();
-        try {
-            //查询拼团用户订单
-            $userOrder = GroupUserOrder::alias('a')
-                        ->leftJoin('user b','a.user_id=b.id')
-                        ->where('group_order_id', $group_order_id)
-                        ->where('pay_status', 1)
-                        ->where('refund_status', 0)
-                        ->field('a.*,b.mobile')
-                        ->select()
-                        ->toArray();
-                      
-            if (empty($userOrder)) {
-                return true;
-            }
-
-            Db::startTrans();
-            foreach ($userOrder as $k => $item) {
-                if (empty($goods)) {
-                    $goods = UserEquity::alias('a')->leftJoin('goods b','a.goods_id=b.id')
-                        ->where('a.id', $item['user_equity_id'])
-                        ->field('a.number,a.goods_id,b.*')
-                        ->findOrEmpty()
-                        ->toArray();
-                }
-                //生成拼团服务工单
-                $work_data = [
-                    'work_sn' => generate_sn(GroupServiceWork::class, 'work_sn'),
-                    'real_name' => '',
-                    'mobile' => $item['mobile'],
-                    'address' => $item['area'].$item['address'],
-                    'title' => $goods['goods_name'],
-                    'category_type' => $goods['category_type'],
-                    'goods_category_ids' => $goods['goods_category_ids'],
-                    'goods_category_id' => $goods['goods_category_id'],
-                    'work_pay_status'=>WorkEnum::IS_PAY_STATUS,
-                    'master_worker_id' => $category['master_worker_id'],
-                    'appointment_time' => $category['service_time'],
-                    'dispatch_time' => time(),
-                    'receive_time' => time(),
-                    'user_id'=>$item['user_id'],
-                    'user_equity_id'=>0,
-                    'third_type'=>1,
-                    'work_total'=>$item['paid_amount'],
-                    'work_status' => 5,
-                    'user_confirm_status' => 3,
-                    'service_status' => 1,
-                    'remark' => '拼团用户订单:'.$item['id'],
-                    'user_equity_id' => $item['user_equity_id'],
-                    'group_order_id' => $group_order_id,
-                    'group_user_order_id' => $item['id'],
-                    'work_total' => $category['price'],
-                    'work_amount' => $category['work_amount'],
-                    'settlement_amount' => $category['settlement_amount'],
-                ];
-                   
-                $service_work = GroupServiceWork::create($work_data);
-
-                //生成订单服务详情
-                OrderGoods::create([
-                    'sn' => $service_work['sn'],
-                    'goods_id' => $goods['goods_id'],
-                    'category_type' => $goods['category_type'],
-                    'goods_category_ids' => $goods['goods_category_ids'],
-                    'goods_category_id' => $goods['goods_category_id'],
-                    'goods_name' => $goods['goods_name'],
-                    'goods_image' => $goods['goods_image'],
-                    'goods_video' => $goods['goods_video'],
-                    'goods_number' => $goods['goods_number'],
-                    'good_unit' => $goods['good_unit'],
-                    'goods_size' => $goods['goods_size'],
-                    'goods_type' => $goods['goods_type'],
-                    'goods_brand' => $goods['goods_brand'],
-                    'install_guide' => $goods['install_guide'],
-                    'goods_payment_type'=>$goods['goods_payment_type'],
-                    'base_service_fee' => $goods['base_service_fee'],
-                    'service_total' => $goods['service_total'],
-                    'service_fee' => $goods['service_fee'],
-                    'service_image' => $goods['service_image'],
-                    'warranty_period'=>$goods['warranty_period'],
-                    'fee_schedule' => $goods['fee_schedule'],
-                    'goods_status' => $goods['goods_status'],
-                ]);
-                
-                //更新用户的权益卡剩余次数
-                UserEquity::where('id', $item['user_equity_id'])->update(['number' => 0, 'update_time' => time()]);
-
-                //记录用户的权益卡使用记录
-                UserEquityLog::create([
-                    'user_id' => $item['user_id'],
-                    'number' => $goods['number'],
-                    'user_equity_id' => $item['user_equity_id'],
-                    'create_time' => time(),
-                ]);
-            }
-
-            GroupOrder::where('id', $group_order_id)->update(['work_status' => 2]);
-            Db::commit();
-            // 任务执行完毕后删除任务
-            $job->delete();
-            return true;
-        } catch (\Exception $e) {
-            Db::rollback();
-            Log::write("拼团订单批量生成服务工单异常:".$e->getMessage());
-            // 任务执行失败,重试任务
-            if ($job->attempts() > 3) {
-                // 超过最大重试次数,删除任务
-                $job->delete();
-            } else {
-                $job->release(10); // 10 秒后重试
-            }
-            return false;
-        }
-    }
-}