| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257 | 
							- <?php
 
- namespace app\admin\controller\member;
 
- use app\admin\service\member\MemberService;
 
- use app\controller\Curd;
 
- use app\model\CouponDetail;
 
- use app\model\Member;
 
- use app\model\MemberRole;
 
- use app\model\SysDept;
 
- use app\model\SysUser;
 
- use support\Request;
 
- class ReferrerController extends Curd
 
- {
 
-     public function list(Request $request)
 
-     {
 
-         $page = $request->get('page', 1);
 
-         $pageSize = $request->get('pageSize', 10);
 
-         $name = $request->get('name', '');
 
-         $nickname = $request->get('nickname', '');
 
-         $mobile = $request->get('mobile', '');
 
-         $level = $request->get('level', '');
 
-         $isAuth = $request->get('is_auth', '');
 
-         $addtime = $request->get('member_addtimes', []);
 
-         $type = $request->get('type', '');
 
-         $status = $request->get('member_status', '');
 
-         $memberIsPartner = $request->get('member_is_partner', '');
 
-         $memberIsReferrer = $request->get('member_is_referrer', '');
 
-         // 兼容老等级搜索
 
-         $levelIds = [];
 
-         if (!empty($level)) {
 
-             $levelName = MemberRole::where('member_role_id', $level)->value('member_role_name');
 
-             if (!empty($levelName)) {
 
-                 $levelIds = MemberRole::where('member_role_name', $levelName)->pluck('member_role_id')->toArray();
 
-             }
 
-         }
 
-         $rows = Member::with([
 
-             'account' => function ($query) {
 
-                 $query->where('member_account_status', 'ACTIVED');
 
-             }
 
-         ])->where('member_is_owner', 'N')
 
-             ->where('member_mobile', '<>', '0000')
 
-             ->leftJoin('member_info', 'member_info.join_info_member_id', 'member.member_id')
 
-             ->leftJoin('member_cert', 'member_cert.join_cert_member_id', 'member.member_id')
 
-             ->leftJoin('member_role', 'member_role.member_role_id', 'member.join_member_role_id')
 
-             ->when($name != '', function ($query) use ($name) {
 
-                 $query->where('member_cert.member_cert_name', 'like', '%' . $name . '%');
 
-             })->when($mobile != '', function ($query) use ($mobile) {
 
-                 $query->where('member.member_mobile', 'like', '%' . $mobile . '%');
 
-             })->when($level != '', function ($query) use ($level, $levelIds) {
 
-                 if ($level == 'other') {
 
-                     $query->where('member.join_member_role_id', NULL)->orWhere('member.join_member_role_id', '');
 
-                 } else if ($level == 'VIP') {
 
-                     $query->where('member.member_is_vip', 'Y');
 
-                 } else if (!empty($levelIds)) {
 
-                     $query->whereIn('member_role.member_role_id', $levelIds);
 
-                 } else {
 
-                     $query->where('member_role.member_role_id', $level);
 
-                 }
 
-             })->when($isAuth != '', function ($query) use ($isAuth) {
 
-                 if ($isAuth == 'Y') {
 
-                     $query->where('member_cert.member_cert_name', '<>', NULL)->where('member_cert.member_cert_nbr', '<>', NULL)->where('member_cert.member_cert_name', '<>', '')->where('member_cert.member_cert_nbr', '<>', '');
 
-                 } else {
 
-                     $query->where('member_cert.member_cert_name', NULL)->orWhere('member_cert.member_cert_nbr', NULL)->orWhere('member_cert.member_cert_name', '')->orWhere('member_cert.member_cert_nbr', '');
 
-                 }
 
-             })->when(!empty($addtime), function ($query) use ($addtime) {
 
-                 $addtime[0] = strtotime($addtime[0]);
 
-                 $addtime[1] = strtotime($addtime[1]);
 
-                 $query->whereRaw("CAST(UNIX_TIMESTAMP(JSON_UNQUOTE(JSON_EXTRACT(member_referrer_json,'$.datetime'))) as SIGNED) >= {$addtime[0]}")
 
-                     ->whereRaw("CAST(UNIX_TIMESTAMP(JSON_UNQUOTE(JSON_EXTRACT(member_referrer_json,'$.datetime'))) as SIGNED) <= {$addtime[1]}");
 
-             })->when(!empty($type), function ($query) use ($type) {
 
-                 if ($type == 'todayAdd') {
 
-                     $addtime[0] = strtotime(date('Y-m-d') . ' 00:00:00');
 
-                     $addtime[1] = strtotime(date('Y-m-d') . ' 23:59:59');
 
-                 } else if ($type == 'monthAdd') {
 
-                     $addtime[0] = strtotime(date('Y-m-01') . ' 00:00:00');
 
-                     $addtime[1] = strtotime(date('Y-m-t') . ' 23:59:59');
 
-                 }
 
-                 $query->whereBetween('member.member_addtimes', $addtime);
 
-             })->when(!empty($nickname), function ($query) use ($nickname) {
 
-                 $query->where(function ($query2) use ($nickname) {
 
-                     $query2->where('member_info.member_info_nickname', 'like', '%' . $nickname . '%')->orWhere('member.member_mobile', 'like', '%' . $nickname . '%');
 
-                 });
 
-             })->when(!empty($status), function ($query) use ($status) {
 
-                 $query->where('member_status', $status);
 
-             })->when(!empty($memberIsPartner), function ($query) use ($memberIsPartner) {
 
-                 if ($memberIsPartner == 'Y') {
 
-                     $query->where('member_is_partner', 'Y');
 
-                 }
 
-             })->when(!empty($memberIsReferrer), function ($query) use ($memberIsReferrer) {
 
-                 if ($memberIsReferrer == 'Y') {
 
-                     $query->where('member_is_referrer', 'Y');
 
-                 }
 
-             })
 
-             ->select('member_id', 'member_is_vip', 'member_is_owner', 'join_invite_member_id', 'member_is_partner', 'member_is_referrer', 'member_classify', 'member_status', 'member_mobile', 'member_from', 'member_addtimes', 'member_extend_json',
 
-                 'member_info.member_info_nickname', 'member_info.member_info_headimg', 'member_info.member_info_referee', 'member_info.member_info_business', 'member_info.member_info_service', 'member_info.member_info_city', 'member_info.member_info_address', 'member_info.member_info_gender', 'member_info.member_info_birthday',
 
-                 'member_role.member_role_id', 'member_role.member_role_name',
 
-                 'member_cert.member_cert_birth', 'member_cert.member_cert_gender', 'member_cert.member_cert_name', 'member_cert.member_cert_nbr', 'member_cert.member_cert_province', 'member_cert.member_cert_addr', 'member_cert.member_cert_face', 'member_cert.member_cert_photo', 'member_cert.member_cert_nation'
 
- //                'member_account.member_account_surplus'
 
-             )->selectRaw("CAST(UNIX_TIMESTAMP(JSON_UNQUOTE(JSON_EXTRACT(member_referrer_json,'$.datetime'))) as SIGNED) as referrer_add_times");
 
-         // 总条数
 
-         $total = $rows->count('member_id');
 
-         // 已认证条数
 
-         $authModel = clone $rows;
 
-         $authTotal = $authModel->where('member_cert.member_cert_name','<>','')
 
-             ->where('member_cert.member_cert_nbr','<>','')
 
-             ->count();
 
-         $rows = $rows->orderBy('referrer_add_times', 'DESC')
 
-             ->forPage($page, $pageSize)
 
-             ->get()
 
-             ->toArray();
 
-         foreach ($rows as &$row) {
 
-             $row['referrer_add_times'] = date('Y-m-d H:i:s',$row['referrer_add_times']);
 
-             $row['coupon_count'] = CouponDetail::where('join_coupon_detail_member_id', $row['member_id'])->count();
 
-             $row['member_mobile'] = substr($row['member_mobile'], 0, 3) . '****' . substr($row['member_mobile'], 7);
 
-             // 推荐人
 
-             if (!empty($row['join_invite_member_id'])) {
 
-                 $row['referrer_name'] = MemberService::getMemberNameByMemberId($row['join_invite_member_id']);
 
-             }
 
-             $row['info'] = [
 
-                 'member_info_nickname' => !empty($row['member_info_nickname']) ? $row['member_info_nickname'] : substr($row['member_mobile'], -4, 4) . '会员',
 
-                 'member_info_headimg' => !empty($row['member_info_headimg']) ? $row['member_info_headimg'] : '',
 
-                 'member_info_referee' => !empty($row['member_info_referee']) ? $row['member_info_referee'] : '',
 
-                 'member_info_business' => !empty($row['member_info_business']) ? $row['member_info_business'] : '',
 
-                 'member_info_service' => !empty($row['member_info_service']) ? $row['member_info_service'] : '',
 
-                 'member_info_city' => !empty($row['member_info_city']) ? explode('-', $row['member_info_city']) : '',
 
-                 'member_info_address' => !empty($row['member_info_address']) ? $row['member_info_address'] : '',
 
-                 'member_info_birthday' => !empty($row['member_info_birthday']) ? $row['member_info_birthday'] : '',
 
-                 'member_info_gender' => !empty($row['member_info_gender']) ? $row['member_info_gender'] : '',
 
-             ];
 
-             if (substr($row['info']['member_info_headimg'], 0, 2) == '..') {
 
-                 $row['info']['member_info_headimg'] = '';
 
-             }
 
-             if (!empty($row['info']['member_info_address']) && in_array($row['info']['member_info_address'], ['请选择', '省-市-区'])) {
 
-                 $row['info']['member_info_address'] = '';
 
-             }
 
-             $row['cert'] = [
 
-                 'member_cert_birth' => $row['member_cert_birth'],
 
-                 'member_cert_gender' => $row['member_cert_gender'],
 
-                 'member_cert_name' => $row['member_cert_name'],
 
-                 'member_cert_nbr' => $row['member_cert_nbr'],
 
-                 'member_cert_province' => !empty($row['member_cert_province']) && is_json($row['member_cert_province']) ? json_decode($row['member_cert_province']) : '',
 
-                 'member_cert_addr' => $row['member_cert_addr'],
 
-                 'member_cert_face' => !empty($row['member_cert_face']) ? getenv('STORAGE_DOMAIN') . $row['member_cert_face'] : '',
 
-                 'member_cert_photo' => !empty($row['member_cert_photo']) ? getenv('STORAGE_DOMAIN') . $row['member_cert_photo'] : '',
 
-                 'member_cert_nation' => $row['member_cert_nation'],
 
-             ];
 
-             $account = [];
 
-             if (!empty($row['account'])) {
 
-                 foreach ($row['account'] as $item) {
 
-                     if ($item['member_account_classify'] == 'WELFARE') {
 
-                         $account['welfare'] = [
 
-                             'member_account_name' => $item['member_account_name'],
 
-                             'member_account_income' => $item['member_account_income'],
 
-                             'member_account_expend' => $item['member_account_expend'],
 
-                             'member_account_surplus' => $item['member_account_surplus'],
 
-                             'member_account_added' => $item['member_account_added'],
 
-                         ];
 
-                     } else if ($item['member_account_classify'] == 'POINTS') {
 
-                         $account['points'] = [
 
-                             'member_account_name' => $item['member_account_name'],
 
-                             'member_account_income' => $item['member_account_income'],
 
-                             'member_account_expend' => $item['member_account_expend'],
 
-                             'member_account_surplus' => $item['member_account_surplus'],
 
-                             'member_account_added' => $item['member_account_added'],
 
-                         ];
 
-                     } else if ($item['member_account_classify'] == 'CASH') {
 
-                         $account['cash'] = [
 
-                             'member_account_name' => $item['member_account_name'],
 
-                             'member_account_income' => $item['member_account_income'],
 
-                             'member_account_expend' => $item['member_account_expend'],
 
-                             'member_account_surplus' => $item['member_account_surplus'],
 
-                             'member_account_added' => $item['member_account_added'],
 
-                         ];
 
-                     } else if ($item['member_account_classify'] == 'CARD') {
 
-                         $account['card'] = [
 
-                             'member_account_name' => $item['member_account_name'],
 
-                             'member_account_income' => $item['member_account_income'],
 
-                             'member_account_expend' => $item['member_account_expend'],
 
-                             'member_account_surplus' => $item['member_account_surplus'],
 
-                             'member_account_added' => $item['member_account_added'],
 
-                         ];
 
-                     } else if ($item['member_account_classify'] == 'VIP') {
 
-                         $account['vip'] = [
 
-                             'member_account_name' => $item['member_account_name'],
 
-                             'member_account_income' => $item['member_account_income'],
 
-                             'member_account_expend' => $item['member_account_expend'],
 
-                             'member_account_surplus' => $item['member_account_surplus'],
 
-                             'member_account_added' => $item['member_account_added'],
 
-                         ];
 
-                     }
 
-                 }
 
-             }
 
-             $row['account'] = $account;
 
-             $row['is_auth'] = "未认证";
 
-             if (!empty($row['member_cert_nbr']) && !empty($row['member_cert_name'])) {
 
-                 $row['is_auth'] = "已认证";
 
-             }
 
-             $row['source'] = "APP";
 
-             $row['belong'] = [];
 
-             $row['referee'] = [];
 
-             if (!empty($row['member_extend_json'])) {
 
-                 $extendJson = json_decode($row['member_extend_json'], true);
 
-                 if (isset($extendJson['come_from'])) {
 
-                     $row['source'] = $extendJson['come_from'] ?? '';
 
-                 }
 
-                 if (isset($extendJson['belong'])) {
 
-                     $user = SysUser::where('user_id', $extendJson['belong']['user_id'])->select('user_name', 'user_mobile')->first();
 
-                     if ($user) {
 
-                         $row['belong']['user_id'] = $extendJson['belong']['user_id'];
 
-                         $row['belong']['username'] = $user->user_name;
 
-                         $row['belong']['user_mobile'] = $user->user_mobile;
 
-                     }
 
-                     $row['belong']['deptName'] = SysDept::where('dept_id', $extendJson['belong']['premises'])->value('dept_name');
 
-                 }
 
-                 if (isset($extendJson['referee'])) {
 
-                     foreach ($extendJson['referee'] as $key => $referee) {
 
-                         if (preg_match('/^1[3-9]\d{9}$/', $referee)) {
 
-                             $member = Member::with([
 
-                                 'cert' => function ($query) {
 
-                                     $query->select('join_cert_member_id', 'member_cert_name');
 
-                                 }
 
-                             ])->where('member_mobile', $referee)->where('member_status', 'ACTIVED')
 
-                                 ->first();
 
-                             if ($member->cert && $member->cert->member_cert_name) {
 
-                                 $referee = $member->cert->member_cert_name . '-' . $referee;
 
-                             }
 
-                         }
 
-                         $row['referee'][] = [
 
-                             'name' => $referee,
 
-                             'time' => $key
 
-                         ];
 
-                     }
 
-                 }
 
-             }
 
-             // 粉丝
 
-             $fans1 = Member::where('join_invite_member_id', $row['member_id'])
 
-                 ->select('member_id')
 
-                 ->get()
 
-                 ->toArray();
 
-             $fans1Ids = array_column($fans1, 'member_id');
 
-             $fans2Count = Member::whereIn('join_invite_member_id', $fans1Ids)
 
-                 ->count();
 
-             $row['fans_total'] = count($fans1) + $fans2Count;
 
-         }
 
-         return json_success('', compact('rows', 'page', 'pageSize', 'total','authTotal'));
 
-     }
 
- }
 
 
  |