liugc 1 год назад
Родитель
Сommit
743a6a29e8

+ 108 - 0
app/adminapi/controller/training/TrainingWorkerCourseController.php

@@ -0,0 +1,108 @@
+<?php
+// +----------------------------------------------------------------------
+// | likeadmin快速开发前后端分离管理后台(PHP版)
+// +----------------------------------------------------------------------
+// | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
+// | 开源版本可自由商用,可去除界面版权logo
+// | gitee下载:https://gitee.com/likeshop_gitee/likeadmin
+// | github下载:https://github.com/likeshop-github/likeadmin
+// | 访问官网:https://www.likeadmin.cn
+// | likeadmin团队 版权所有 拥有最终解释权
+// +----------------------------------------------------------------------
+// | author: likeadminTeam
+// +----------------------------------------------------------------------
+
+
+namespace app\adminapi\controller\training;
+
+
+use app\adminapi\controller\BaseAdminController;
+use app\adminapi\lists\training\TrainingWorkerCourseLists;
+use app\adminapi\logic\training\TrainingWorkerCourseLogic;
+use app\adminapi\validate\training\TrainingWorkerCourseValidate;
+
+
+/**
+ * TrainingWorkerCourse控制器
+ * Class TrainingWorkerCourseController
+ * @package app\adminapi\controller
+ */
+class TrainingWorkerCourseController extends BaseAdminController
+{
+
+
+    /**
+     * @notes 获取列表
+     * @return \think\response\Json
+     * @author likeadmin
+     * @date 2025/02/16 16:44
+     */
+    public function lists()
+    {
+        return $this->dataLists(new TrainingWorkerCourseLists());
+    }
+
+
+    /**
+     * @notes 添加
+     * @return \think\response\Json
+     * @author likeadmin
+     * @date 2025/02/16 16:44
+     */
+    public function add()
+    {
+        $params = (new TrainingWorkerCourseValidate())->post()->goCheck('add');
+        $result = TrainingWorkerCourseLogic::add($params);
+        if (true === $result) {
+            return $this->success('添加成功', [], 1, 1);
+        }
+        return $this->fail(TrainingWorkerCourseLogic::getError());
+    }
+
+
+    /**
+     * @notes 编辑
+     * @return \think\response\Json
+     * @author likeadmin
+     * @date 2025/02/16 16:44
+     */
+    public function edit()
+    {
+        $params = (new TrainingWorkerCourseValidate())->post()->goCheck('edit');
+        $result = TrainingWorkerCourseLogic::edit($params);
+        if (true === $result) {
+            return $this->success('编辑成功', [], 1, 1);
+        }
+        return $this->fail(TrainingWorkerCourseLogic::getError());
+    }
+
+
+    /**
+     * @notes 删除
+     * @return \think\response\Json
+     * @author likeadmin
+     * @date 2025/02/16 16:44
+     */
+    public function delete()
+    {
+        $params = (new TrainingWorkerCourseValidate())->post()->goCheck('delete');
+        TrainingWorkerCourseLogic::delete($params);
+        return $this->success('删除成功', [], 1, 1);
+    }
+
+
+    /**
+     * @notes 获取详情
+     * @return \think\response\Json
+     * @author likeadmin
+     * @date 2025/02/16 16:44
+     */
+    public function detail()
+    {
+        $params = (new TrainingWorkerCourseValidate())->goCheck('detail');
+        $result = TrainingWorkerCourseLogic::detail($params);
+        return $this->data($result);
+    }
+
+
+}

+ 78 - 0
app/adminapi/lists/training/TrainingWorkerCourseLists.php

@@ -0,0 +1,78 @@
+<?php
+// +----------------------------------------------------------------------
+// | likeadmin快速开发前后端分离管理后台(PHP版)
+// +----------------------------------------------------------------------
+// | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
+// | 开源版本可自由商用,可去除界面版权logo
+// | gitee下载:https://gitee.com/likeshop_gitee/likeadmin
+// | github下载:https://github.com/likeshop-github/likeadmin
+// | 访问官网:https://www.likeadmin.cn
+// | likeadmin团队 版权所有 拥有最终解释权
+// +----------------------------------------------------------------------
+// | author: likeadminTeam
+// +----------------------------------------------------------------------
+
+namespace app\adminapi\lists\training;
+
+
+use app\adminapi\lists\BaseAdminDataLists;
+use app\common\model\training\TrainingWorkerCourse;
+use app\common\lists\ListsSearchInterface;
+
+
+/**
+ * TrainingWorkerCourse列表
+ * Class TrainingWorkerCourseLists
+ * @package app\adminapi\lists
+ */
+class TrainingWorkerCourseLists extends BaseAdminDataLists implements ListsSearchInterface
+{
+
+
+    /**
+     * @notes 设置搜索条件
+     * @return \string[][]
+     * @author likeadmin
+     * @date 2025/02/16 16:44
+     */
+    public function setSearch(): array
+    {
+        return [
+            '=' => ['master_worker_id', 'training_task_id', 'training_course_id', 'play_time', 'exam_start_time', 'exam_end_time', 'study_status', 'question_all_score', 'question_qualified_score', 'exam_score'],
+
+        ];
+    }
+
+
+    /**
+     * @notes 获取列表
+     * @return array
+     * @throws \think\db\exception\DataNotFoundException
+     * @throws \think\db\exception\DbException
+     * @throws \think\db\exception\ModelNotFoundException
+     * @author likeadmin
+     * @date 2025/02/16 16:44
+     */
+    public function lists(): array
+    {
+        return TrainingWorkerCourse::where($this->searchWhere)
+            ->field(['id', 'master_worker_id', 'training_task_id', 'training_course_id', 'play_time', 'exam_start_time', 'exam_end_time', 'study_status', 'question_all_score', 'question_qualified_score', 'exam_score'])
+            ->limit($this->limitOffset, $this->limitLength)
+            ->order(['id' => 'desc'])
+            ->select()
+            ->toArray();
+    }
+
+
+    /**
+     * @notes 获取数量
+     * @return int
+     * @author likeadmin
+     * @date 2025/02/16 16:44
+     */
+    public function count(): int
+    {
+        return TrainingWorkerCourse::where($this->searchWhere)->count();
+    }
+
+}

+ 124 - 0
app/adminapi/logic/training/TrainingWorkerCourseLogic.php

@@ -0,0 +1,124 @@
+<?php
+// +----------------------------------------------------------------------
+// | likeadmin快速开发前后端分离管理后台(PHP版)
+// +----------------------------------------------------------------------
+// | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
+// | 开源版本可自由商用,可去除界面版权logo
+// | gitee下载:https://gitee.com/likeshop_gitee/likeadmin
+// | github下载:https://github.com/likeshop-github/likeadmin
+// | 访问官网:https://www.likeadmin.cn
+// | likeadmin团队 版权所有 拥有最终解释权
+// +----------------------------------------------------------------------
+// | author: likeadminTeam
+// +----------------------------------------------------------------------
+
+namespace app\adminapi\logic\training;
+
+
+use app\common\model\training\TrainingWorkerCourse;
+use app\common\logic\BaseLogic;
+use think\facade\Db;
+
+
+/**
+ * TrainingWorkerCourse逻辑
+ * Class TrainingWorkerCourseLogic
+ * @package app\adminapi\logic
+ */
+class TrainingWorkerCourseLogic extends BaseLogic
+{
+
+
+    /**
+     * @notes 添加
+     * @param array $params
+     * @return bool
+     * @author likeadmin
+     * @date 2025/02/16 16:44
+     */
+    public static function add(array $params): bool
+    {
+        Db::startTrans();
+        try {
+            TrainingWorkerCourse::create([
+                'master_worker_id' => $params['master_worker_id'],
+                'training_task_id' => $params['training_task_id'],
+                'training_course_id' => $params['training_course_id'],
+                'play_time' => $params['play_time'],
+                'exam_start_time' => $params['exam_start_time'],
+                'exam_end_time' => $params['exam_end_time'],
+                'study_status' => $params['study_status'],
+                'question_all_score' => $params['question_all_score'],
+                'question_qualified_score' => $params['question_qualified_score'],
+                'exam_score' => $params['exam_score'],
+            ]);
+
+            Db::commit();
+            return true;
+        } catch (\Exception $e) {
+            Db::rollback();
+            self::setError($e->getMessage());
+            return false;
+        }
+    }
+
+
+    /**
+     * @notes 编辑
+     * @param array $params
+     * @return bool
+     * @author likeadmin
+     * @date 2025/02/16 16:44
+     */
+    public static function edit(array $params): bool
+    {
+        Db::startTrans();
+        try {
+            TrainingWorkerCourse::where('id', $params['id'])->update([
+                'master_worker_id' => $params['master_worker_id'],
+                'training_task_id' => $params['training_task_id'],
+                'training_course_id' => $params['training_course_id'],
+                'play_time' => $params['play_time'],
+                'exam_start_time' => $params['exam_start_time'],
+                'exam_end_time' => $params['exam_end_time'],
+                'study_status' => $params['study_status'],
+                'question_all_score' => $params['question_all_score'],
+                'question_qualified_score' => $params['question_qualified_score'],
+                'exam_score' => $params['exam_score'],
+            ]);
+
+            Db::commit();
+            return true;
+        } catch (\Exception $e) {
+            Db::rollback();
+            self::setError($e->getMessage());
+            return false;
+        }
+    }
+
+
+    /**
+     * @notes 删除
+     * @param array $params
+     * @return bool
+     * @author likeadmin
+     * @date 2025/02/16 16:44
+     */
+    public static function delete(array $params): bool
+    {
+        return TrainingWorkerCourse::destroy($params['id']);
+    }
+
+
+    /**
+     * @notes 获取详情
+     * @param $params
+     * @return array
+     * @author likeadmin
+     * @date 2025/02/16 16:44
+     */
+    public static function detail($params): array
+    {
+        return TrainingWorkerCourse::findOrEmpty($params['id'])->toArray();
+    }
+}

+ 2 - 0
app/adminapi/logic/training/TrainingWorkerTaskLogic.php

@@ -45,6 +45,7 @@ class TrainingWorkerTaskLogic extends BaseLogic
                 'shop_goods_id' => $params['shop_goods_id'],
                 'training_task_id' => $params['training_task_id'],
                 'lead_master_worker_id' => $params['lead_master_worker_id'],
+                'operate_status' => $params['operate_status']??0,
             ]);
 
             Db::commit();
@@ -73,6 +74,7 @@ class TrainingWorkerTaskLogic extends BaseLogic
                 'shop_goods_id' => $params['shop_goods_id'],
                 'training_task_id' => $params['training_task_id'],
                 'lead_master_worker_id' => $params['lead_master_worker_id'],
+                'operate_status' => $params['operate_status']??0,
             ]);
 
             Db::commit();

+ 116 - 0
app/adminapi/validate/training/TrainingWorkerCourseValidate.php

@@ -0,0 +1,116 @@
+<?php
+// +----------------------------------------------------------------------
+// | likeadmin快速开发前后端分离管理后台(PHP版)
+// +----------------------------------------------------------------------
+// | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
+// | 开源版本可自由商用,可去除界面版权logo
+// | gitee下载:https://gitee.com/likeshop_gitee/likeadmin
+// | github下载:https://github.com/likeshop-github/likeadmin
+// | 访问官网:https://www.likeadmin.cn
+// | likeadmin团队 版权所有 拥有最终解释权
+// +----------------------------------------------------------------------
+// | author: likeadminTeam
+// +----------------------------------------------------------------------
+
+namespace app\adminapi\validate\training;
+
+
+use app\common\validate\BaseValidate;
+
+
+/**
+ * TrainingWorkerCourse验证器
+ * Class TrainingWorkerCourseValidate
+ * @package app\adminapi\validate
+ */
+class TrainingWorkerCourseValidate extends BaseValidate
+{
+
+     /**
+      * 设置校验规则
+      * @var string[]
+      */
+    protected $rule = [
+        'id' => 'require',
+        'master_worker_id' => 'require',
+        'training_task_id' => 'require',
+        'training_course_id' => 'require',
+        'play_time' => 'require',
+        'exam_start_time' => 'require',
+        'exam_end_time' => 'require',
+        'study_status' => 'require',
+        'question_all_score' => 'require',
+        'question_qualified_score' => 'require',
+        'exam_score' => 'require',
+
+    ];
+
+
+    /**
+     * 参数描述
+     * @var string[]
+     */
+    protected $field = [
+        'id' => 'id',
+        'master_worker_id' => '师傅id',
+        'training_task_id' => '培训任务ID',
+        'training_course_id' => '课程ID',
+        'play_time' => '播放时间秒',
+        'exam_start_time' => '考试开始时间秒',
+        'exam_end_time' => '考试结束时间秒',
+        'study_status' => '状态 0未学习  1学习中  2待考试  3考试中  4考试不合格   5已学完',
+        'question_all_score' => '试题总分',
+        'question_qualified_score' => '合格分',
+        'exam_score' => '实际考试得分',
+
+    ];
+
+
+    /**
+     * @notes 添加场景
+     * @return TrainingWorkerCourseValidate
+     * @author likeadmin
+     * @date 2025/02/16 16:44
+     */
+    public function sceneAdd()
+    {
+        return $this->only(['master_worker_id','training_task_id','training_course_id','play_time','exam_start_time','exam_end_time','study_status','question_all_score','question_qualified_score','exam_score']);
+    }
+
+
+    /**
+     * @notes 编辑场景
+     * @return TrainingWorkerCourseValidate
+     * @author likeadmin
+     * @date 2025/02/16 16:44
+     */
+    public function sceneEdit()
+    {
+        return $this->only(['id','master_worker_id','training_task_id','training_course_id','play_time','exam_start_time','exam_end_time','study_status','question_all_score','question_qualified_score','exam_score']);
+    }
+
+
+    /**
+     * @notes 删除场景
+     * @return TrainingWorkerCourseValidate
+     * @author likeadmin
+     * @date 2025/02/16 16:44
+     */
+    public function sceneDelete()
+    {
+        return $this->only(['id']);
+    }
+
+
+    /**
+     * @notes 详情场景
+     * @return TrainingWorkerCourseValidate
+     * @author likeadmin
+     * @date 2025/02/16 16:44
+     */
+    public function sceneDetail()
+    {
+        return $this->only(['id']);
+    }
+
+}

+ 34 - 0
app/common/model/training/TrainingWorkerCourse.php

@@ -0,0 +1,34 @@
+<?php
+// +----------------------------------------------------------------------
+// | likeadmin快速开发前后端分离管理后台(PHP版)
+// +----------------------------------------------------------------------
+// | 欢迎阅读学习系统程序代码,建议反馈是我们前进的动力
+// | 开源版本可自由商用,可去除界面版权logo
+// | gitee下载:https://gitee.com/likeshop_gitee/likeadmin
+// | github下载:https://github.com/likeshop-github/likeadmin
+// | 访问官网:https://www.likeadmin.cn
+// | likeadmin团队 版权所有 拥有最终解释权
+// +----------------------------------------------------------------------
+// | author: likeadminTeam
+// +----------------------------------------------------------------------
+
+namespace app\common\model\training;
+
+
+use app\common\model\BaseModel;
+
+
+
+/**
+ * TrainingWorkerCourse模型
+ * Class TrainingWorkerCourse
+ * @package app\common\model
+ */
+class TrainingWorkerCourse extends BaseModel
+{
+    
+    protected $name = 'training_worker_course';
+    
+
+    
+}

+ 93 - 0
app/workerapi/controller/TrainingController.php

@@ -0,0 +1,93 @@
+<?php
+
+namespace app\workerapi\controller;
+
+use app\common\logic\MasterWorkerExamineLogic;
+use app\common\model\dict\DictData;
+use app\workerapi\lists\MasterWorkerLists;
+use app\workerapi\lists\ServiceWorkLists;
+use app\workerapi\lists\TeamServiceWorkLists;
+use app\workerapi\logic\LoginLogic;
+use app\workerapi\logic\MasterWorkerInfoLogic;
+use app\workerapi\logic\MasterWorkerLogic;
+use app\workerapi\logic\MasterWorkerTeamLogic;
+use app\workerapi\logic\TrainingLogic;
+use app\workerapi\validate\BankAccountValidate;
+use app\workerapi\validate\MasterWokerInfoValidate;
+use app\workerapi\validate\MasterWokerTeamValidate;
+use app\workerapi\validate\MasterWokerValidate;
+
+class TrainingController extends BaseApiController
+{
+    public array $notNeedLogin = [''];
+
+    /**
+     * 获取培训信息
+     * @return \think\response\Json
+     */
+    public function getTrainingInfo()
+    {
+        $result = TrainingLogic::getDetail($this->userId);
+        return $this->data($result);
+    }
+
+    /**
+     * 团队成员列表展示和分配
+     * @return \think\response\Json
+     */
+    public function getMemberList()
+    {
+        return $this->dataLists(new MasterWorkerLists());
+    }
+
+    /**
+     * 添加团队成员
+     * @return \think\response\Json
+     */
+    public function addTeamMember()
+    {
+        $params = (new MasterWokerTeamValidate())->post()->goCheck('add');
+        /*$res = LoginLogic::confirmMobile($params);
+        if(!$res){
+            return $this->fail(LoginLogic::getError());
+        }*/
+        $result = MasterWorkerTeamLogic::addTeamMember($params,$this->userId);
+        if($result === false){
+            return $this->fail(MasterWorkerTeamLogic::getError());
+        }
+        return $this->success('', [], 1, 1);
+    }
+
+    /**
+     * 分配工单给团队成员
+     * @return \think\response\Json
+     */
+    public function allocation()
+    {
+        $params = (new MasterWokerTeamValidate())->post()->goCheck('allocation');
+        $result = MasterWorkerTeamLogic::allocation($params,$this->userInfo);
+        if($result === false){
+            return $this->fail(MasterWorkerTeamLogic::getError());
+        }
+        return $this->success('', [], 1, 1);
+    }
+    /**
+     * 团队工单状态统计
+     * @return \think\response\Json
+     */
+    public function getTeamWorkCount()
+    {
+        $result = MasterWorkerTeamLogic::MemberWorkStatistics($this->userInfo);
+        return $this->data($result);
+    }
+
+    /**
+     * 团队工单查询
+     * @return \think\response\Json
+     */
+    public function getTeamWorkLists()
+    {
+        return $this->dataLists(new TeamServiceWorkLists());
+    }
+
+}

+ 169 - 0
app/workerapi/logic/TrainingLogic.php

@@ -0,0 +1,169 @@
+<?php
+namespace app\workerapi\logic;
+use app\adminapi\logic\master_worker_register\MasterWorkerRegisterLogic;
+use app\common\enum\worker\WorkerAccountLogEnum;
+use app\common\enum\YesNoEnum;
+use app\common\logic\BaseLogic;
+use app\common\model\bank_account\BankAccount;
+use app\common\model\master_worker\MasterWorker;
+use app\common\model\master_worker\MasterWorkerAccountLog;
+use app\common\model\master_worker\MasterWorkerAgree;
+use app\common\model\master_worker\MasterWorkerInfo;
+use app\common\model\master_worker\MasterWorkerTeam;
+use app\common\model\training\TrainingCourse;
+use app\common\model\training\TrainingWorkerTask;
+use app\common\model\works\ServiceWork;
+use app\common\service\FileService;
+use app\workerapi\lists\MasterWorkerLists;
+use app\workerapi\lists\ServiceWorkLists;
+use think\Exception;
+use think\facade\Config;
+use think\facade\Db;
+
+
+class TrainingLogic extends  BaseLogic
+{
+    public static function getDetail(int $masterWorkerId)
+    {
+        try {
+
+            //shop_goods_id  INT ( 10 ) DEFAULT 0  NOT NULL COMMENT '商品id(套餐)',
+	        //shop_orders_id int(10) NOT NULL DEFAULT '0' COMMENT '购买单号id',
+            // 检查是否已经购买套餐
+            $shop_orders = Db::name('shop_orders')->where('worker_id',$masterWorkerId)->where('shop_goods_id',1)->find();
+           //   `worker_id` int(11) NOT NULL COMMENT '师傅ID',  `pay_status` tinyint(1) NOT NULL COMMENT '支付状态:0-待支付 1-已支付 2-已取消',  `refund_status` tinyint(1) DEFAULT '0' COMMENT '退款状态 0-
+
+            $task_info = ['id'=>0];
+            $task = TrainingWorkerTask::where('master_worker_id',$masterWorkerId)->findOrEmpty();
+            if (!$task->isEmpty()) {
+                $task_info = $task->toArray();
+                // 0 不展示按钮 1 去学习 2 已学完
+                $task_info['learning_status'] = $task_info['shop_orders_id']>0?($task_info['training_status'] <2?1:2):0;
+                $task_info['bank_status'] = BankAccount::where('worker_id',$masterWorkerId)->where('audit_state',1)->value('id')?1:0;
+                $masterWorker = MasterWorker::where('id',$masterWorkerId)->find();
+                $task_info['category_status'] = empty($masterWorker['category_ids'])?0:1;
+                $task_info['service_status'] = (empty($masterWorker['lon']) || empty($masterWorker['lat']))?0:1;
+            }
+            $task_info['free_videos'] = TrainingCourse::where('course_lock',1)->select()->toArray();
+            return $task_info;
+        } catch (\Exception $e) {
+            self::setError($e->getMessage());
+            return [];
+        }
+    }
+
+    public static function addTeamMember(array $params,int $masterWorkerId)
+    {
+        try {
+            $team = MasterWorkerTeam::where('master_worker_id',$masterWorkerId)->findOrEmpty();
+            if ($team->isEmpty()) {
+                throw new \Exception('团队不存在');
+            }
+            $masterWorker =  \app\common\model\master_worker\MasterWorker::where('mobile',$params['mobile'])->findOrEmpty();
+            if (!$masterWorker->isEmpty()) {
+                throw new \Exception('该手机号已占用');
+            }
+            // 新增工程师
+            $mwId = MasterWorkerRegisterLogic::createMasterWorker([
+                'mobile' => $params['mobile'],
+                'lon' => isset($params['lon'])?$params['lon']:0,
+                'lat' => isset($params['lat'])?$params['lat']:0,
+            ]);
+            MasterWorker::where('id',$mwId)->update(['team_id'=>$team->id,'team_role'=>2]);
+            return true;
+        } catch (\Exception $e) {
+            self::setError($e->getMessage());
+            return false;
+        }
+    }
+
+
+    public static function getMemberList(int $masterWorkerId)
+    {
+        try {
+            $team = MasterWorkerTeam::where('master_worker_id',$masterWorkerId)->findOrEmpty();
+            if ($team->isEmpty()) {
+                throw new \Exception('团队不存在');
+            }
+            return MasterWorker::where('team_id',$team['id'])->where('team_role',2)->field(['id','nickname','avatar','mobile','real_name','team_role'])->select()->toArray();
+        } catch (\Exception $e) {
+            self::setError($e->getMessage());
+            return [];
+        }
+    }
+
+
+    /**
+     * 分配给团队成员
+     * @param int $teamId
+     * @param int $masterWorkerId
+     * @return array
+     */
+    public static function allocation($params,$userInfo){
+        Db::startTrans();
+        try {
+            $work = ServiceWork::findOrEmpty($params['work_id']);
+            if($work->isEmpty()){
+                throw new Exception('工单不存在');
+            }
+            if($work->work_status != 1 ){
+                throw new \Exception('工单已被领取,不可分配');
+            }
+            if($work->master_worker_id == $params['master_worker_id']){
+                throw new \Exception('分配的工程师相同');
+            }
+            $worker = MasterWorker::where(['id'=>$params['master_worker_id'],'team_id' =>$userInfo['team_id'],'team_role' =>2,'is_disable' =>0])->findOrEmpty();
+            if($worker->isEmpty()){
+                throw new \Exception('成员工程师不存在或被禁用');
+            }
+            if($worker->master_worker_id){
+                MasterWorker::setWorktotal('dec',$worker->master_worker_id);
+            }
+            $work->master_worker_id = $params['master_worker_id'];
+            $work->work_status = 1;
+            $work->dispatch_time = time();
+            MasterWorker::setWorktotal('inc',$params['master_worker_id']);
+            $work->save();
+            $work_log = [
+                'work_id'=>$work->id,
+                'master_worker_id'=>$work->master_worker_id,
+                'opera_log'=>'团队负责人['.$userInfo['user_id'].']'.$userInfo['real_name'].'于'.date('Y-m-d H:i:s',time()).'分配了工程师成员'.'编号['.$worker->worker_number.']'.$worker->real_name
+            ];
+            ServiceWorkerAllocateWorkerLogic::add($work_log);
+            Db::commit();
+            return true;
+        }catch(\Exception $e){
+            Db::rollback();
+            self::setError($e->getMessage());
+            return false;
+        }
+    }
+
+    /**
+     * 团队成员工单统计
+     * @param int $teamId
+     * @param int $masterWorkerId
+     * @return array
+     */
+    public static function MemberWorkStatistics($userInfo){
+        $lists = ServiceWork::whereIn('master_worker_id',
+                    MasterWorker::where('team_id', $userInfo['team_id'])->where('team_role', 2)->column('id')
+                )->group('work_status')
+                ->field('work_status, COUNT(id) as count_num')
+                ->order('work_status asc')
+                ->select()->toArray();
+        $lists = array_column($lists,'count_num','work_status');
+        $work_status_txt = array_slice(ServiceWork::WORK_STATUS_TXT, 1, 8,true);
+        $res = [];
+        foreach ($work_status_txt as $work_status => $name) {
+            $res[] = [
+                'work_status' => $work_status,
+                'work_status_text' => $name,
+                'count_num' => $lists[$work_status]??0,
+            ];
+        }
+        return $res;
+    }
+
+
+}