<?php
// +----------------------------------------------------------------------
// | 萤火商城系统 [ 致力于通过产品和服务,帮助商家高效化开拓市场 ]
// +----------------------------------------------------------------------
// | Copyright (c) 2017~2023 https://www.yiovo.com All rights reserved.
// +----------------------------------------------------------------------
// | Licensed 这不是一个自由软件,不允许对程序代码以任何形式任何目的的再发行
// +----------------------------------------------------------------------
// | Author: 萤火科技 <admin@yiovo.com>
// +----------------------------------------------------------------------
declare (strict_types=1);

namespace app\api\model\dealer;

use app\api\service\User as UserService;
use app\common\enum\dealer\DealerUserEnum;
use app\common\enum\ServerEnum;
use app\common\model\Order as OrderModel;
use app\common\model\dealer\Order as DealerOrderModel;
use app\api\model\Order as OrderApiModel;
use app\common\enum\order\PayStatus as PayStatusEnum;
use app\common\model\UserAddress as UserAddessModel;
use cores\exception\BaseException;
use app\api\model\User as UserApiModel;
use app\common\enum\user\UserTypeEnum;


/**
 * 分销商订单模型
 * Class Order
 * @package app\api\model\dealer
 */
class Order extends DealerOrderModel
{
    /**
     * 隐藏字段
     * @var array
     */
    protected $hidden = [
        'store_id',
        'update_time',
    ];

    /**
     * 获取分销商订单列表
     * @param array $param
     * @return \think\Paginator
     * @throws \cores\exception\BaseException
     * @throws \think\db\exception\DbException
     */
    public function getList(array $param = []): \think\Paginator
    {
        // 当前用户ID
        $userId = UserService::getCurrentLoginUserId();
        // 检索查询条件
        $filter = $this->getFilter($param);
        // 获取分销商订单列表
        $list = $this->getNewQuery()
            ->with(['user.avatar', 'order'])
            ->where($filter)
            ->where('first_user_id|second_user_id|third_user_id', '=', $userId)
            ->where('is_invalid', '=', 0)
            ->order(['create_time' => 'desc'])
            ->paginate(15);
        // 数据整理
        foreach ($list as &$item) {
            $with = ['goods' => ['image'],'user','address'];
            $where = ['order_id' => $item['order_id']];
            // 查询订单记录
            $order_goods = OrderApiModel::detail($where, $with);
            $address = UserAddessModel::where('address_id',$item['user']->address_id)->find();
            // 我的佣金
            $money = [
                $item['first_user_id'] => $item['first_money'],
                $item['second_user_id'] => $item['second_money'],
                $item['third_user_id'] => $item['third_money'],
            ];
            $item['goods'] = $order_goods['goods'] ?? [];
            $item['address_name'] =$address['name'];
            $item['order_no'] = $item['order']['order_no'] ?? "";
            $item['my_money'] = $money[$userId];
        }
        return $list;
    }

    /**
     * 设置检索查询条件
     * @param array $param
     * @return array
     */
    private function getFilter(array $param = []): array
    {
        // 默认参数
        $params = $this->setQueryDefaultValue($param, [
            'settled' => -1, // 是否已结算佣金
        ]);
        // 检索查询条件
        $filter = [];
        // 是否结算佣金
        $params['settled'] > -1 && $filter[] = ['is_settled', '=', (bool)$params['settled']];
        return $filter;
    }

    /**
     * 创建分销商订单记录
     * @param OrderModel $order 订单记录
     * @return bool
     * @throws \think\db\exception\DataNotFoundException
     * @throws \think\db\exception\DbException
     * @throws \think\db\exception\ModelNotFoundException
     */
    public static function createOrder(OrderModel $order): bool
    {
        // 分销订单模型
        $model = new static;
        // 分销商基本设置
        $setting = Setting::getItem('basic');
        // 是否开启分销功能
        if (!$setting['is_open']) {
            return false;
        }
        // 获取当前买家的所有上级分销商用户id
        $dealerUser = $model->getDealerUserId((int)$order['user_id'], (int)$setting['level'], (bool)$setting['self_buy']);
        // 非分销订单
        if (!$dealerUser['first_user_id']) {
            return false;
        }
        //如果上级已经不是分销商
        if(!User::isDealerUser($dealerUser['first_user_id'])){
            return false;
        }
        //如果上级已经不是分销商
        if(!UserApiModel::where('user_id',$dealerUser['first_user_id'])->value('user_type') !== UserTypeEnum::DEALER){
            return false;
        }
        // 计算订单分销佣金
        $capital = static::getCapitalByOrder($order);
        // 保存分销订单记录
        return $model->save([
            'user_id' => $order['user_id'],
            'order_id' => $order['order_id'],
            'order_price' => $capital['orderPrice'],
            'first_money' => max($capital['first_money'], 0),
            'second_money' => max($capital['second_money'], 0),
            'third_money' => max($capital['third_money'], 0),
            'first_user_id' => $dealerUser['first_user_id'],
            'second_user_id' => $dealerUser['second_user_id'],
            'third_user_id' => $dealerUser['third_user_id'],
            'is_settled' => 0,
            'store_id' => $model::$storeId
        ]);
    }

    /**
     * 获取当前买家的所有上级分销商用户ID
     * @param int $userId 用户ID
     * @param int $level 推荐等级
     * @param bool $selfBuy 分销商自购
     * @return array
     */
    private function getDealerUserId(int $userId, int $level, bool $selfBuy): array
    {
        $dealerUser = [
            'first_user_id' => $level >= 1 ? Referee::getRefereeUserId($userId, 1, true) : 0,
            'second_user_id' => $level >= 2 ? Referee::getRefereeUserId($userId, 2, true) : 0,
            'third_user_id' => $level == 3 ? Referee::getRefereeUserId($userId, 3, true) : 0
        ];
        // 分销商自购
        if ($selfBuy && User::isDealerUser($userId)) {
            return [
                'first_user_id' => $userId,
                'second_user_id' => $dealerUser['first_user_id'],
                'third_user_id' => $dealerUser['second_user_id'],
            ];
        }
        return $dealerUser;
    }

    /**
     * 获取当前用户分销订单数量
     * @param string $dataType 订单类型 (all全部 payment待发货 service待服务 payment待支付 complete 已完成)
     * @return int
     * @throws BaseException
     */
    public function getCount(string $dataType = 'all', $dealer_order_ids = []): int
    {
        // 设置订单类型条件
        $dataTypeFilter = $this->getFilterDataType($dataType);
        // 当前用户ID
        $userId = UserService::getCurrentLoginUserId();
        // 查询数据
        $query = $this->where('user_id', '=', $userId);
        if ($dealer_order_ids) {
            $query->whereIn('order_id', $dealer_order_ids);
        }
        return $query->where($dataTypeFilter)
            ->where('is_delete', '=', 0)
            ->count();
    }

    /**
     * 设置订单类型条件
     * @param string $dataType
     * @return array
     */
    private function getFilterDataType(string $dataType): array
    {
        // 筛选条件
        $filter = [];
        // 订单数据类型
        switch ($dataType) {
            case 'all':
                break;
            //待确认
            case 'confirm':
                $filter[] = ['pay_status', '=', PayStatusEnum::SUCCESS];
                $filter[] = ['order_status', '=', DealerUserEnum::NORMAL];
                break;
            //待服务
            case 'service':
                $filter[] = ['pay_status', '=', PayStatusEnum::SUCCESS];
                $filter[] = ['order_status', '=', ServerEnum::APPLYSERVER];
                break;
            //待支付
            case 'payment':
                $filter = [
                    ['pay_status', '=', PayStatusEnum::PENDING],
                    ['order_status', '=', ServerEnum::APPLYPAY]
                ];
                break;
            //已完成
            case 'complete':
                $filter = [
                    ['order_status', '=', ServerEnum::COMPLETED]
                ];
                break;
        }
        return $filter;
    }
}