<?php

namespace app\admin\service\statistics;

use app\model\Member;
use support\Db;

class MemberService
{
    public static function getMember()
    {
        $data = [];

        // 会员数量
        $data['memberCount'] = Member::where('member_is_owner', 'N')->count();
        // 业主数量
        $data['ownerCount'] = Member::where('member_is_owner', 'Y')->count();
        // 用户总数
        $data['userCount'] = $data['memberCount'] + $data['ownerCount'];
        // 今日新增用户数
        $todayTime = strtotime(date('Y-m-d 00:00:00'));
        $data['todayCount'] = Member::where('member_addtimes', '>', $todayTime)->where('member_is_owner', 'N')->count();
        // 本月新增用户数
        $monthTime = strtotime(date('Y-m-01 00:00:00'));
        $data['monthCount'] = Member::where('member_addtimes', '>', $monthTime)->where('member_is_owner', 'N')->count();

        // 折线图-会员
        $newAddition = Db::select("SELECT DATE_FORMAT(FROM_UNIXTIME(member_addtimes), '%Y/%m') AS `month`,count(*) as `num` FROM app_member where member_is_owner='N' group by month order by month asc ");

        $category = [];
        foreach ($newAddition as $item) {
            $category[] = $item->month;
//            $newAdditionData['member']['category'][] = $item->month;
//            $newAdditionData['member']['data'][] = $item->num;
        }
        // 折线图-业主
        $newAdditionOwner = Db::select("SELECT DATE_FORMAT(FROM_UNIXTIME(member_addtimes), '%Y/%m') AS `month`,count(*) as `num` FROM app_member where member_is_owner='Y' group by month order by month asc ");
        foreach ($newAdditionOwner as $item) {
            if (!in_array($item->month, $category)) {
                $category[] = $item->month;
            }
//            $newAdditionData['owner']['category'][] = $item->month;
//            $newAdditionData['owner']['data'][] = $item->num;
        }
        sort($category);
        $newAdditionData = [];
        foreach ($category as $item) {
            $isHaveMember = false;
            $isHaveOwner = false;
            foreach ($newAddition as $item2) {
                if ($item == $item2->month) {
                    $isHaveMember = true;
                    $newAdditionData['member']['category'][] = $item;
                    $newAdditionData['member']['data'][] = $item2->num;
                }
            }
            foreach ($newAdditionOwner as $item3) {
                if ($item == $item3->month) {
                    $isHaveOwner = true;
                    $newAdditionData['owner']['category'][] = $item;
                    $newAdditionData['owner']['data'][] = $item3->num;
                }
            }
            if (!$isHaveOwner) {
                $newAdditionData['owner']['category'][] = $item;
                $newAdditionData['owner']['data'][] = 0;
            }
            if (!$isHaveMember) {
                $newAdditionData['member']['category'][] = $item;
                $newAdditionData['member']['data'][] = 0;
            }
        }

        $data['addition'] = $newAdditionData;

        // 饼图
        $newAdditionBing = Db::select("
            SELECT CASE
                WHEN TIMESTAMPDIFF(YEAR, member_cert_birth, CURDATE()) BETWEEN 0 AND 1 THEN '0'
                WHEN TIMESTAMPDIFF(YEAR, member_cert_birth, CURDATE()) BETWEEN 1 AND 39 THEN '39'
                WHEN TIMESTAMPDIFF(YEAR, member_cert_birth, CURDATE()) BETWEEN 40 AND 50 THEN '41-50'
                WHEN TIMESTAMPDIFF(YEAR, member_cert_birth, CURDATE()) BETWEEN 51 AND 60 THEN '51-60'
                WHEN TIMESTAMPDIFF(YEAR, member_cert_birth, CURDATE()) BETWEEN 61 AND 70 THEN '61-70'
                WHEN TIMESTAMPDIFF(YEAR, member_cert_birth, CURDATE()) BETWEEN 71 AND 80 THEN '71-80'
                ELSE '81以上'
              END AS age_group,
              COUNT(*) AS number_of_people
            FROM
              app_member_cert
            GROUP BY
              age_group
            ORDER BY
              age_group;
        ");
        $newAdditionBingData = [];
        foreach ($newAdditionBing as $item) {
            if ($item->age_group == '0') {
                $item->age_group = '未知';
            } elseif ($item->age_group == '39') {
                $item->age_group = '40以下';
            }
            $newAdditionBingData[] = [
                'name' => $item->age_group,
                'value' => $item->number_of_people
            ];
        }

        $data['additionBing'] = $newAdditionBingData;

        return $data;
    }
}