|  | @@ -0,0 +1,280 @@
 | 
											
												
													
														|  | 
 |  | +<?php
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +namespace app\admin\service\consultant;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +use app\model\Consultant;
 | 
											
												
													
														|  | 
 |  | +use app\model\SysDept;
 | 
											
												
													
														|  | 
 |  | +use app\model\SysUser;
 | 
											
												
													
														|  | 
 |  | +use support\Request;
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +class ConsultantService
 | 
											
												
													
														|  | 
 |  | +{
 | 
											
												
													
														|  | 
 |  | +    public static function index(Request $request)
 | 
											
												
													
														|  | 
 |  | +    {
 | 
											
												
													
														|  | 
 |  | +        $format = $request->get('format', 'normal');
 | 
											
												
													
														|  | 
 |  | +        $limit = (int)$request->get('pageSize', $format === 'tree' ? 1000 : 10);
 | 
											
												
													
														|  | 
 |  | +        $limit = $limit <= 0 ? 10 : $limit;
 | 
											
												
													
														|  | 
 |  | +        $params = $request->get();
 | 
											
												
													
														|  | 
 |  | +        $page = (int)$request->get('page');
 | 
											
												
													
														|  | 
 |  | +        $page = $page > 0 ? $page : 1;
 | 
											
												
													
														|  | 
 |  | +        $where = [];
 | 
											
												
													
														|  | 
 |  | +        $whereDept = [];
 | 
											
												
													
														|  | 
 |  | +        $whereTopDept = [];
 | 
											
												
													
														|  | 
 |  | +        if (!empty($params['name'])) {
 | 
											
												
													
														|  | 
 |  | +            $where[] = ['name', 'like', "%{$params['name']}%"];
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        if (!empty($params['mobile'])) {
 | 
											
												
													
														|  | 
 |  | +            $where[] = ['mobile', 'like', "%{$params['mobile']}%"];
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        if (!empty($params['status'])) {
 | 
											
												
													
														|  | 
 |  | +            $where[] = ['status', '=', $params['status']];
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        if (!empty($params['dept_id'])) {
 | 
											
												
													
														|  | 
 |  | +            $deptId = end($params['dept_id']);
 | 
											
												
													
														|  | 
 |  | +            $whereDept[] = ['dept_id', '=', $deptId];
 | 
											
												
													
														|  | 
 |  | +            $whereTopDept[] = ['top_dept_id', '=', $deptId];
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        if (!empty($params['type'])) {
 | 
											
												
													
														|  | 
 |  | +            $where[] = ['type', '=', $params['type']];
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        $paginator = Consultant::where(function ($query) use ($whereDept, $whereTopDept) {
 | 
											
												
													
														|  | 
 |  | +                $query->orWhere($whereDept)
 | 
											
												
													
														|  | 
 |  | +                ->orWhere($whereTopDept);
 | 
											
												
													
														|  | 
 |  | +        })->where($where)->paginate($limit, '*', 'page', $page);
 | 
											
												
													
														|  | 
 |  | +        $total = $paginator->total();
 | 
											
												
													
														|  | 
 |  | +        $items = $paginator->items();
 | 
											
												
													
														|  | 
 |  | +        if (!empty($items)) {
 | 
											
												
													
														|  | 
 |  | +            $teamKeys = TeamService::getKeys();
 | 
											
												
													
														|  | 
 |  | +            foreach ($items as &$item) {
 | 
											
												
													
														|  | 
 |  | +                $teamName = [];
 | 
											
												
													
														|  | 
 |  | +                if (isset($teamKeys[$item->top_dept_id])) {
 | 
											
												
													
														|  | 
 |  | +                    $teamName[] = $teamKeys[$item->top_dept_id];
 | 
											
												
													
														|  | 
 |  | +                }
 | 
											
												
													
														|  | 
 |  | +                if (isset($teamKeys[$item->dept_id])) {
 | 
											
												
													
														|  | 
 |  | +                    $teamName[] = $teamKeys[$item->dept_id];
 | 
											
												
													
														|  | 
 |  | +                }
 | 
											
												
													
														|  | 
 |  | +                $item->team_name = !empty($teamName) ? implode('-', $teamName) : '';
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        $data = [
 | 
											
												
													
														|  | 
 |  | +            'total' => $total,
 | 
											
												
													
														|  | 
 |  | +            'rows' => $items
 | 
											
												
													
														|  | 
 |  | +        ];
 | 
											
												
													
														|  | 
 |  | +        return json_success('success', $data);
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    /**
 | 
											
												
													
														|  | 
 |  | +     * Notes: 添加员工
 | 
											
												
													
														|  | 
 |  | +     * User: yb
 | 
											
												
													
														|  | 
 |  | +     * Date: 2024/8/2
 | 
											
												
													
														|  | 
 |  | +     * Time: 11:03
 | 
											
												
													
														|  | 
 |  | +     * @param $params
 | 
											
												
													
														|  | 
 |  | +     */
 | 
											
												
													
														|  | 
 |  | +    public static function add($params)
 | 
											
												
													
														|  | 
 |  | +    {
 | 
											
												
													
														|  | 
 |  | +        if (!self::checkMobile($params['mobile'])) {
 | 
											
												
													
														|  | 
 |  | +            return json_fail('请输入正确的手机号');
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        //查询员工是否已被注册
 | 
											
												
													
														|  | 
 |  | +        if (Consultant::where('mobile', $params['mobile'])->exists()) {
 | 
											
												
													
														|  | 
 |  | +            return json_fail('手机号已存在,员工已被注册');
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        //校验密码规则
 | 
											
												
													
														|  | 
 |  | +        if (!empty($params['password'])) {
 | 
											
												
													
														|  | 
 |  | +            $passwordLen = strlen($params['password']);
 | 
											
												
													
														|  | 
 |  | +            if ($passwordLen > 20 || $passwordLen < 6) {
 | 
											
												
													
														|  | 
 |  | +                return json_fail('请输入6-20位密码');
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        //查询上级团队
 | 
											
												
													
														|  | 
 |  | +        $topDeptId = SysDept::where('dept_id', $params['dept_id'])->where('dept_category', TeamService::DEPT_CATEGORY)->value('dept_super_id');
 | 
											
												
													
														|  | 
 |  | +        if (!is_numeric($topDeptId)) {
 | 
											
												
													
														|  | 
 |  | +            return json_fail('团队不存在');
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        if (empty($params['password'])) {
 | 
											
												
													
														|  | 
 |  | +            $showPassword = substr($params['mobile'], 4);
 | 
											
												
													
														|  | 
 |  | +            $password = self::handlePassword($showPassword);
 | 
											
												
													
														|  | 
 |  | +        } else {
 | 
											
												
													
														|  | 
 |  | +            $password = self::handlePassword($params['password']);
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        $type = 2;
 | 
											
												
													
														|  | 
 |  | +        if (!empty($params['type'])) {
 | 
											
												
													
														|  | 
 |  | +            if (in_array($params['type'], [1,2])) {
 | 
											
												
													
														|  | 
 |  | +                $type = $params['type'];
 | 
											
												
													
														|  | 
 |  | +                if ($type == 2) {
 | 
											
												
													
														|  | 
 |  | +                    $params['relation_user_id'] = null;
 | 
											
												
													
														|  | 
 |  | +                }
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +        $insertData = [
 | 
											
												
													
														|  | 
 |  | +            'name' => $params['name'],
 | 
											
												
													
														|  | 
 |  | +            'mobile' => $params['mobile'],
 | 
											
												
													
														|  | 
 |  | +            'dept_id' => $params['dept_id'],
 | 
											
												
													
														|  | 
 |  | +            'top_dept_id' => $topDeptId,
 | 
											
												
													
														|  | 
 |  | +            'gender' => $params['gender'] ?? 1,
 | 
											
												
													
														|  | 
 |  | +            'password' => $password,
 | 
											
												
													
														|  | 
 |  | +            'status' => $params['status'] ?? 1,
 | 
											
												
													
														|  | 
 |  | +            'relation_user_id' => $params['relation_user_id'] ?? null,
 | 
											
												
													
														|  | 
 |  | +            'type' => $type,
 | 
											
												
													
														|  | 
 |  | +            'created_at' => time()
 | 
											
												
													
														|  | 
 |  | +        ];
 | 
											
												
													
														|  | 
 |  | +        $result = Consultant::insert($insertData);
 | 
											
												
													
														|  | 
 |  | +        if ($result) {
 | 
											
												
													
														|  | 
 |  | +            return json_success('新增成功');
 | 
											
												
													
														|  | 
 |  | +        } else {
 | 
											
												
													
														|  | 
 |  | +            return json_fail('新增失败');
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    /**
 | 
											
												
													
														|  | 
 |  | +     * Notes: 更新员工信息
 | 
											
												
													
														|  | 
 |  | +     * User: yb
 | 
											
												
													
														|  | 
 |  | +     * Date: 2024/8/2
 | 
											
												
													
														|  | 
 |  | +     * Time: 11:54
 | 
											
												
													
														|  | 
 |  | +     * @param $params
 | 
											
												
													
														|  | 
 |  | +     */
 | 
											
												
													
														|  | 
 |  | +    public static function update($params)
 | 
											
												
													
														|  | 
 |  | +    {
 | 
											
												
													
														|  | 
 |  | +        if (empty($params['id'])) {
 | 
											
												
													
														|  | 
 |  | +            return json_fail('员工id不能为空');
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        //查找员工信息
 | 
											
												
													
														|  | 
 |  | +        $info = Consultant::find($params['id']);
 | 
											
												
													
														|  | 
 |  | +        if (empty($info)) {
 | 
											
												
													
														|  | 
 |  | +            return json_fail('员工不存在');
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        if (!self::checkMobile($params['mobile'])) {
 | 
											
												
													
														|  | 
 |  | +            return json_fail('请输入正确的手机号');
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        //查询员工是否已被注册
 | 
											
												
													
														|  | 
 |  | +        if (Consultant::where('mobile', $params['mobile'])->where('id', '<>', $params['id'])->exists()) {
 | 
											
												
													
														|  | 
 |  | +            return json_fail('手机号已存在,员工已被注册');
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        //校验密码规则
 | 
											
												
													
														|  | 
 |  | +        if (!empty($params['password'])) {
 | 
											
												
													
														|  | 
 |  | +            $passwordLen = strlen($params['password']);
 | 
											
												
													
														|  | 
 |  | +            if ($passwordLen > 20 || $passwordLen < 6) {
 | 
											
												
													
														|  | 
 |  | +                return json_fail('请输入6-20位密码');
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +            $password = self::handlePassword($params['password']);
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        $type = 2;
 | 
											
												
													
														|  | 
 |  | +        if (!empty($params['type'])) {
 | 
											
												
													
														|  | 
 |  | +            if (in_array($params['type'], [1,2])) {
 | 
											
												
													
														|  | 
 |  | +                $type = $params['type'];
 | 
											
												
													
														|  | 
 |  | +                if ($type == 2) {
 | 
											
												
													
														|  | 
 |  | +                    $params['relation_user_id'] = null;
 | 
											
												
													
														|  | 
 |  | +                }
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        $updateData = [
 | 
											
												
													
														|  | 
 |  | +            'name' => $params['name'],
 | 
											
												
													
														|  | 
 |  | +            'mobile' => $params['mobile'],
 | 
											
												
													
														|  | 
 |  | +            'gender' => $params['gender'] ?? 1,
 | 
											
												
													
														|  | 
 |  | +            'status' => $params['status'] ?? 1,
 | 
											
												
													
														|  | 
 |  | +            'relation_user_id' => $params['relation_user_id'] ?? null,
 | 
											
												
													
														|  | 
 |  | +            'type' => $type,
 | 
											
												
													
														|  | 
 |  | +            'updated_at' => time()
 | 
											
												
													
														|  | 
 |  | +        ];
 | 
											
												
													
														|  | 
 |  | +        if (!empty($params['password'])) {
 | 
											
												
													
														|  | 
 |  | +            $updateData['password'] = $password;
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        $result = Consultant::where('id', $params['id'])->update($updateData);
 | 
											
												
													
														|  | 
 |  | +        if ($result) {
 | 
											
												
													
														|  | 
 |  | +            return json_success('更新成功');
 | 
											
												
													
														|  | 
 |  | +        } else {
 | 
											
												
													
														|  | 
 |  | +            return json_fail('更新失败');
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    /**
 | 
											
												
													
														|  | 
 |  | +     * Notes: 删除员工
 | 
											
												
													
														|  | 
 |  | +     * User: yb
 | 
											
												
													
														|  | 
 |  | +     * Date: 2024/8/2
 | 
											
												
													
														|  | 
 |  | +     * Time: 13:33
 | 
											
												
													
														|  | 
 |  | +     * @param $ids
 | 
											
												
													
														|  | 
 |  | +     * @return \support\Response
 | 
											
												
													
														|  | 
 |  | +     */
 | 
											
												
													
														|  | 
 |  | +    public static function delete($ids)
 | 
											
												
													
														|  | 
 |  | +    {
 | 
											
												
													
														|  | 
 |  | +        if (!$ids) {
 | 
											
												
													
														|  | 
 |  | +            return json_fail("数据错误");
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        if (!is_array($ids)) {
 | 
											
												
													
														|  | 
 |  | +            $ids = [$ids];
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +        //查询员工下是否存在客户
 | 
											
												
													
														|  | 
 |  | +        try {
 | 
											
												
													
														|  | 
 |  | +            if (is_array($ids)) {
 | 
											
												
													
														|  | 
 |  | +                Consultant::whereIn('id', $ids)->delete();
 | 
											
												
													
														|  | 
 |  | +            } else {
 | 
											
												
													
														|  | 
 |  | +                Consultant::where('id', $ids)->delete();
 | 
											
												
													
														|  | 
 |  | +            }
 | 
											
												
													
														|  | 
 |  | +        } catch (\Exception $e) {
 | 
											
												
													
														|  | 
 |  | +            return json_fail('删除失败');
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +        return json_success('删除成功');
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    /**
 | 
											
												
													
														|  | 
 |  | +     * Notes:
 | 
											
												
													
														|  | 
 |  | +     * User: yb
 | 
											
												
													
														|  | 
 |  | +     * Date: 2024/8/5
 | 
											
												
													
														|  | 
 |  | +     * Time: 10:52
 | 
											
												
													
														|  | 
 |  | +     */
 | 
											
												
													
														|  | 
 |  | +    public static function userList()
 | 
											
												
													
														|  | 
 |  | +    {
 | 
											
												
													
														|  | 
 |  | +        $deptIds = SysDept::where('dept_category', '=', '获客团队')->pluck('dept_id');
 | 
											
												
													
														|  | 
 |  | +        $deptIds = $deptIds->toArray();
 | 
											
												
													
														|  | 
 |  | +        $userList = SysUser::whereIn('join_user_dept_id', $deptIds)->select(['user_id', 'user_name', 'user_mobile'])->get();
 | 
											
												
													
														|  | 
 |  | +        return json_success('请求成功', $userList);
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    /**
 | 
											
												
													
														|  | 
 |  | +     * Notes:校验手机号
 | 
											
												
													
														|  | 
 |  | +     * User: yb
 | 
											
												
													
														|  | 
 |  | +     * Date: 2024/8/2
 | 
											
												
													
														|  | 
 |  | +     * Time: 11:12
 | 
											
												
													
														|  | 
 |  | +     * @param $mobile
 | 
											
												
													
														|  | 
 |  | +     * @return bool
 | 
											
												
													
														|  | 
 |  | +     */
 | 
											
												
													
														|  | 
 |  | +    protected static function checkMobile($mobile)
 | 
											
												
													
														|  | 
 |  | +    {
 | 
											
												
													
														|  | 
 |  | +        if (preg_match('/^1[0-9]\d{9}$/', $mobile)) {
 | 
											
												
													
														|  | 
 |  | +            return true;
 | 
											
												
													
														|  | 
 |  | +        } else {
 | 
											
												
													
														|  | 
 |  | +            return false;
 | 
											
												
													
														|  | 
 |  | +        }
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    /**
 | 
											
												
													
														|  | 
 |  | +     * Notes: 处理密码
 | 
											
												
													
														|  | 
 |  | +     * User: yb
 | 
											
												
													
														|  | 
 |  | +     * Date: 2024/8/2
 | 
											
												
													
														|  | 
 |  | +     * Time: 11:19
 | 
											
												
													
														|  | 
 |  | +     * @param $password
 | 
											
												
													
														|  | 
 |  | +     * @return mixed
 | 
											
												
													
														|  | 
 |  | +     */
 | 
											
												
													
														|  | 
 |  | +    protected static function handlePassword($password)
 | 
											
												
													
														|  | 
 |  | +    {
 | 
											
												
													
														|  | 
 |  | +        return md5(md5($password));
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +    /**
 | 
											
												
													
														|  | 
 |  | +     * Notes: 处理出生日期
 | 
											
												
													
														|  | 
 |  | +     * User: yb
 | 
											
												
													
														|  | 
 |  | +     * Date: 2024/8/2
 | 
											
												
													
														|  | 
 |  | +     * Time: 11:28
 | 
											
												
													
														|  | 
 |  | +     * @param $birth
 | 
											
												
													
														|  | 
 |  | +     * @return false|string
 | 
											
												
													
														|  | 
 |  | +     */
 | 
											
												
													
														|  | 
 |  | +    protected static function handleBirth($birth)
 | 
											
												
													
														|  | 
 |  | +    {
 | 
											
												
													
														|  | 
 |  | +        return date('Y-m-d',strtotime($birth));
 | 
											
												
													
														|  | 
 |  | +    }
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  | 
 |  | +}
 |