Browse Source

合伙人推荐官统计

gorden 4 months ago
parent
commit
5bdf10eef3

+ 54 - 5
app/admin/controller/member/MemberController.php

@@ -362,23 +362,72 @@ class MemberController
      *
      * @return \support\Response
      */
-    public function statistics()
+    public function statistics(Request $request)
     {
+        $memberType = $request->get('member_type');
         $todayStart = strtotime(date('Y-m-d'));
         $todayEnd = strtotime(date('Y-m-d 23:59:59'));
-        $todayCount = Member::where('member_addtimes', '>=', $todayStart)->where('member_addtimes', '<=', $todayEnd)->count();
+        $todayCount = Member::when(empty($memberType), function ($query) use ($todayStart, $todayEnd) {
+            $query->where('member_addtimes', '>=', $todayStart)->where('member_addtimes', '<=', $todayEnd);
+        })->when(!empty($memberType), function ($query) use ($memberType, $todayStart, $todayEnd) {
+            if ($memberType == 'PARTNER') {
+                $query->where("member_is_partner", 'Y')
+                    ->whereRaw("CAST(UNIX_TIMESTAMP(JSON_UNQUOTE(JSON_EXTRACT(member_partner_json,'$.datetime'))) as SIGNED) >= {$todayStart}")
+                    ->whereRaw("CAST(UNIX_TIMESTAMP(JSON_UNQUOTE(JSON_EXTRACT(member_partner_json,'$.datetime'))) as SIGNED) <= {$todayEnd}");
+            } elseif ($memberType == 'REFERRER') {
+                $query->where('member_is_referrer', 'Y')
+                    ->whereRaw("CAST(UNIX_TIMESTAMP(JSON_UNQUOTE(JSON_EXTRACT(member_referrer_json,'$.datetime'))) as SIGNED) >= {$todayStart}")
+                    ->whereRaw("CAST(UNIX_TIMESTAMP(JSON_UNQUOTE(JSON_EXTRACT(member_referrer_json,'$.datetime'))) as SIGNED) <= {$todayEnd}");
+            }
+        })->count();
 
         $yesterdayStart = strtotime(date('Y-m-d', strtotime("-1 day")));
         $yesterdayEnd = strtotime(date('Y-m-d 23:59:59', strtotime("-1 day")));
-        $yesterdayCount = Member::where('member_addtimes', '>=', $yesterdayStart)->where('member_addtimes', '<=', $yesterdayEnd)->count();
+        $yesterdayCount = Member::when(empty($memberType), function ($query) use ($yesterdayStart, $yesterdayEnd) {
+            $query->where('member_addtimes', '>=', $yesterdayStart)->where('member_addtimes', '<=', $yesterdayEnd);
+        })->when(!empty($memberType), function ($query) use ($memberType, $yesterdayStart, $yesterdayEnd) {
+            if ($memberType == 'PARTNER') {
+                $query->where("member_is_partner", 'Y')
+                    ->whereRaw("CAST(UNIX_TIMESTAMP(JSON_UNQUOTE(JSON_EXTRACT(member_partner_json,'$.datetime'))) as SIGNED) >= {$yesterdayStart}")
+                    ->whereRaw("CAST(UNIX_TIMESTAMP(JSON_UNQUOTE(JSON_EXTRACT(member_partner_json,'$.datetime'))) as SIGNED) <= {$yesterdayEnd}");
+            } elseif ($memberType == 'REFERRER') {
+                $query->where('member_is_referrer', 'Y')
+                    ->whereRaw("CAST(UNIX_TIMESTAMP(JSON_UNQUOTE(JSON_EXTRACT(member_referrer_json,'$.datetime'))) as SIGNED) >= {$yesterdayStart}")
+                    ->whereRaw("CAST(UNIX_TIMESTAMP(JSON_UNQUOTE(JSON_EXTRACT(member_referrer_json,'$.datetime'))) as SIGNED) <= {$yesterdayEnd}");
+            }
+        })->count();
 
         $monthStart = strtotime(date('Y-m-01'));
         $monthEnd = strtotime(date('Y-m-t 23:59:59'));
-        $monthCount = Member::where('member_addtimes', '>=', $monthStart)->where('member_addtimes', '<=', $monthEnd)->count();
+        $monthCount = Member::when(empty($memberType), function ($query) use ($monthStart, $monthEnd) {
+            $query->where('member_addtimes', '>=', $monthStart)->where('member_addtimes', '<=', $monthEnd);
+        })->when(!empty($memberType), function ($query) use ($memberType, $monthStart, $monthEnd) {
+            if ($memberType == 'PARTNER') {
+                $query->where("member_is_partner", 'Y')
+                    ->whereRaw("CAST(UNIX_TIMESTAMP(JSON_UNQUOTE(JSON_EXTRACT(member_partner_json,'$.datetime'))) as SIGNED) >= {$monthStart}")
+                    ->whereRaw("CAST(UNIX_TIMESTAMP(JSON_UNQUOTE(JSON_EXTRACT(member_partner_json,'$.datetime'))) as SIGNED) <= {$monthEnd}");
+            } elseif ($memberType == 'REFERRER') {
+                $query->where('member_is_referrer', 'Y')
+                    ->whereRaw("CAST(UNIX_TIMESTAMP(JSON_UNQUOTE(JSON_EXTRACT(member_referrer_json,'$.datetime'))) as SIGNED) >= {$monthStart}")
+                    ->whereRaw("CAST(UNIX_TIMESTAMP(JSON_UNQUOTE(JSON_EXTRACT(member_referrer_json,'$.datetime'))) as SIGNED) <= {$monthEnd}");
+            }
 
+        })->count();
         $lastMonthStart = strtotime(date('Y-m-01', strtotime("last day of -1 month")));
         $lastMonthEnd = strtotime(date('Y-m-t 23:59:59', strtotime("last day of -1 month")));
-        $lastMonthCount = Member::where('member_addtimes', '>=', $lastMonthStart)->where('member_addtimes', '<=', $lastMonthEnd)->count();
+        $lastMonthCount = Member::when(empty($memberType), function ($query) use ($lastMonthStart, $lastMonthEnd) {
+            $query->where('member_addtimes', '>=', $lastMonthStart)->where('member_addtimes', '<=', $lastMonthEnd);
+        })->when(!empty($memberType), function ($query) use ($memberType, $lastMonthStart, $lastMonthEnd) {
+            if ($memberType == 'PARTNER') {
+                $query->where("member_is_partner", 'Y')
+                    ->whereRaw("CAST(UNIX_TIMESTAMP(JSON_UNQUOTE(JSON_EXTRACT(member_partner_json,'$.datetime'))) as SIGNED) >= {$lastMonthStart}")
+                    ->whereRaw("CAST(UNIX_TIMESTAMP(JSON_UNQUOTE(JSON_EXTRACT(member_partner_json,'$.datetime'))) as SIGNED) <= {$lastMonthEnd}");
+            } elseif ($memberType == 'REFERRER') {
+                $query->where('member_is_referrer', 'Y')
+                    ->whereRaw("CAST(UNIX_TIMESTAMP(JSON_UNQUOTE(JSON_EXTRACT(member_referrer_json,'$.datetime'))) as SIGNED) >= {$lastMonthStart}")
+                    ->whereRaw("CAST(UNIX_TIMESTAMP(JSON_UNQUOTE(JSON_EXTRACT(member_referrer_json,'$.datetime'))) as SIGNED) <= {$lastMonthEnd}");
+            }
+        })->count();
 
         return json_success('', [
             'todayCount' => $todayCount,

+ 257 - 0
app/admin/controller/member/PartnerController.php

@@ -0,0 +1,257 @@
+<?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 PartnerController 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_partner_json,'$.datetime'))) as SIGNED) >= {$addtime[0]}")
+                    ->whereRaw("CAST(UNIX_TIMESTAMP(JSON_UNQUOTE(JSON_EXTRACT(member_partner_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_partner_json,'$.datetime'))) as SIGNED) as partner_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('partner_add_times', 'DESC')
+            ->forPage($page, $pageSize)
+            ->get()
+            ->toArray();
+
+        foreach ($rows as &$row) {
+            $row['partner_add_times'] = date('Y-m-d H:i:s',$row['partner_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'));
+    }
+}

+ 257 - 0
app/admin/controller/member/ReferrerController.php

@@ -0,0 +1,257 @@
+<?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'));
+    }
+}

+ 17 - 1
app/admin/service/member/MemberService.php

@@ -112,7 +112,7 @@ class MemberService
                     $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',
+            ->select('member_id', 'member_is_vip', 'member_is_owner', 'join_invite_member_id', 'member_is_partner','member_partner_json', 'member_is_referrer','member_referrer_json', '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'
@@ -266,6 +266,20 @@ class MemberService
             $fans2Count = Member::whereIn('join_invite_member_id', $fans1Ids)
                 ->count();
             $row['fans_total'] = count($fans1) + $fans2Count;
+
+            // 合伙人信息
+            if ($row['member_is_partner'] == 'Y' && !empty($row['member_partner_json'])){
+                $partnerJson = json_decode($row['member_partner_json'],true);
+                $row['partner_add_times'] = $partnerJson['datetime'] ?? '';
+                unset($row['member_partner_json']);
+            }
+
+            // 推荐信息
+            if ($row['member_is_referrer'] == 'Y' && !empty($row['member_referrer_json'])){
+                $referrerJson = json_decode($row['member_referrer_json'],true);
+                $row['referrer_add_times'] = $referrerJson['datetime'] ?? '';
+                unset($row['member_referrer_json']);
+            }
         }
 
         return json_success('', compact('rows', 'page', 'pageSize', 'total','authTotal'));
@@ -534,6 +548,7 @@ class MemberService
             $partnerJson = json_decode($member['member_partner_json'], true);
             if (isset($partnerJson['duedate'])) {
                 $member['partner_info'] = [
+                    'add_times'=>$partnerJson['datetime'],
                     'surplus' => ceil((strtotime($partnerJson['duedate'] . ' 23:59:59') - time()) / (3600 * 24)),
                     'dates' => date('Y/m/d 00:00:00', strtotime($partnerJson['datetime'])) . '-' . date('Y/m/d 23:59:59', strtotime($partnerJson['duedate']))
                 ];
@@ -543,6 +558,7 @@ class MemberService
             $referrerJson = json_decode($member['member_referrer_json'], true);
             if (isset($referrerJson['duedate'])) {
                 $member['referrer_info'] = [
+                    'add_times'=>$referrerJson['datetime'],
                     'surplus' => ceil((strtotime($referrerJson['duedate'] . ' 23:59:59') - time()) / (3600 * 24)),
                     'dates' => date('Y/m/d 00:00:00', strtotime($referrerJson['datetime'])) . '-' . date('Y/m/d 23:59:59', strtotime($referrerJson['duedate']))
                 ];

+ 12 - 0
route/admin.php

@@ -805,6 +805,18 @@ Route::group('/admin', function () {
         })->middleware([
             \app\middleware\AdminAuthCheck::class
         ]);
+        // 会员合伙人
+        Route::group('/partner', function () {
+            Route::get('/list', [\app\admin\controller\member\PartnerController::class, 'list']);
+        })->middleware([
+            \app\middleware\AdminAuthCheck::class
+        ]);
+        // 康养推荐官
+        Route::group('/referrer', function () {
+            Route::get('/list', [\app\admin\controller\member\ReferrerController::class, 'list']);
+        })->middleware([
+            \app\middleware\AdminAuthCheck::class
+        ]);
         // 业主管理
         Route::group('/owner', function () {
             Route::get('/selectList', [\app\admin\controller\member\OwnerController::class, 'selectList']);