<?php

namespace app\api\controller;

use app\common\controller\Api;
use think\Db;

/**
 * 礼物接口
 */
class Gift extends Api
{
    protected $noNeedLogin = ['getGiftList','getGiftType'];
    protected $noNeedRight = '*';

    public function _initialize()
    {
        parent::_initialize();
        $this->giftModel = new \app\common\model\Gift();
        $this->gifttypeModel = new \app\common\model\GiftType();
    }

    /**
     * 获取礼物列表
     */
    public function getGiftList() {
        $type = input('type',0);

        // 获取基本信息
        $where = ['is_show'=>1];
        if($type){
            $where['type'] = $type;
        }

        $giftList = Db::name('gift')->where($where)->order("sort","asc")->select();
        $giftList = list_domain_image($giftList,['image','special']);
        $this->success("获取成功!",$giftList);
    }

    /**
     * 获取礼物类型
     */
    public function getGiftType() {
        // 获取基本信息
        $where = [];
        $where["is_show"] = 1;
        $giftList = $this->gifttypeModel->field("id,name")->where($where)->order("weight","desc")->select();
        $this->success("获取成功!",$giftList);
    }

    /**
     * 获取我的背包礼物
     */
    public function getMyBackGift() {

        $userid = $this->request->request("user_id", $this->auth->id);
        //$page = $this->request->request('page',1); // 分页
        //$pageNum = $this->request->request('pageNum',10); // 分页
        // 分页搜索构建
        //$pageStart = ($page-1)*$pageNum;
        $list = \app\common\model\GiftBack::field("id,name,image,gif_image,value,sum(number) as number")
            ->where(["user_id"=>$userid,"is_use"=>0])
          //  ->limit($pageStart,$pageNum)
            ->group("name")
            ->select();
        $this->success("获取成功!",$list);
    }


    /**
     * 获取我的礼物墙
     */
    public function getMyGiftWall() {
        $user_id = input("user_id", 0);

        $userid = $user_id ? $user_id : $this->auth->id;

        $list = \app\common\model\GiftUserParty::alias('a')->join("hx_gift g", "g.id = a.gift_id", "inner")->field("gift_id,g.name,g.image,sum(number) as number")
            ->where(["user_to_id" => $userid,])
            ->group("gift_id")
            ->order('g.value desc')
            ->select();
        $this->success("获取成功!", $list);
    }

    /**
     * 获取我的礼物墙
     */
    public function getMyGiftWall_typing() {
        $user_id = $this->request->request("user_id", 0);

        $userid = $user_id ? $user_id : $this->auth->id;

        $list = Db::name('gift_user_typing')->alias('log')
            ->join('gift', 'gift.id = log.gift_id', 'LEFT')->field('log.*,sum(number) as number,gift.name,gift.image,gift.special')
            ->where(['log.user_to_id' => $userid])
            ->group('log.gift_id')
            ->order('gift.price desc')
            ->select();
        $list = list_domain_image($list,['image','special']);
        $this->success("获取成功!", $list);
    }

    /**
     * 获取我的收送礼明细
     */
    public function my_gift_log(){
        $user_id = $this->auth->id;
        $type    = input('type',1);

        $where = [];
        if($type == 1){
            $where['user_id'] = $user_id;//我送出
            $joinstr = 'gup.user_to_id = user.id';
        }else{
            $where['user_to_id'] = $user_id;//我收到
            $joinstr = 'gup.user_id = user.id';
        }

        $list = Db::name('gift_user_party')->alias('gup')
            ->join('user',$joinstr,'LEFT')->field('gup.*,user.nickname')
            ->where($where)->order('id desc')->autopage()->select();
        $list = list_domain_image($list,['gift_gif_image']);

        $rs = [];
        if(empty($list)){
            $this->success(1,$rs);
        }

        foreach($list as $key => $val){
            if($type == 1){
                $remark = '赠送'.$val['nickname'].','.$val['gift_name'].'*'.$val['number'].',价值'.$val['value'].'钻石';
            }else{
                $remark = $val['nickname'].'赠送,'.$val['gift_name'].'*'.$val['number'].',价值'.$val['value'].'钻石';
            }
            $rs[] = [
                'id'         => $val['id'],
                'gift_image' => $val['gift_gif_image'],
                'createtime' => $val['createtime'],
                'remark'     => $remark
            ];
        }
        $this->success(1,$rs);
    }

    //聊天送礼物
    public function givegift_typing() {
        // 接口防并发
        if (!$this->apiLimit(1, 1000)) {
            $this->error(__('Operation frequently'));
        }

        $user_id = input('user_id');// 赠送对象
        $gift_id = input('gift_id');// 礼物ID
        $number  = input('number',1,'intval');//数量

        if (!$user_id || !$gift_id || $number < 1)
        {
            $this->error();
        }

        // 不可以赠送给自己
        if($this->auth->id == $user_id)
        {
            $this->error("不可以赠送给自己");
        }

        // 获取礼物信息
        $giftinfo = Db::name('gift')->where('id',$gift_id)->find();
        if (!$giftinfo)
        {
            $this->error("请选择礼物");
        }
        $giftvalue = bcmul($giftinfo['price'],$number);

        //被赠送人信息
        $touserinfo = Db::name('user')->where('id',$user_id)->find();
        if (!$touserinfo)
        {
            $this->error("不存在的用户");
        }

        // 判断当前用户余额
        $user_gold = model('wallet')->getWallet($this->auth->id,'gold');
        if($user_gold < $giftvalue)
        {
            $this->error("您的金币余额不足");
        }


        Db::startTrans();


        // 添加礼物赠送记录表
        $data = [
            'user_id'     => $this->auth->id,
            'user_to_id'  => $user_id,
            'gift_id'     => $giftinfo['id'],
            'gift_name'   => $giftinfo['name'],
            'number'      => $number,
            'price'       => $giftinfo['price'],
            'total_price' => $giftvalue,
            'createtime'  => time(),
        ];
        $log_id = Db::name('gift_user_typing')->insertGetId($data);
        if(!$log_id){
            Db::rollback();
            $this->error('赠送失败');
        }

        if($giftvalue > 0){

            // 扣除当前用户余额
            $wallet_rs = model('wallet')->lockChangeAccountRemain($this->auth->id,'gold',-$giftvalue,53,'赠送礼物:'.$giftinfo["name"],'gift_user_typing',$log_id);
            if($wallet_rs['status'] === false){
                Db::rollback();
                $this->error($wallet_rs['msg']);
            }

            // 添加赠送用户余额
            $money_to_gold = config('site.money_to_gold');
            $gift_plat_scale = config('site.gift_plat_scale');

            $giftmoney = bcdiv($giftvalue,$money_to_gold,2);

            $money = bcdiv(bcmul($giftmoney,100 - $gift_plat_scale,2),100,2);
            $wallet_rs = model('wallet')->lockChangeAccountRemain($user_id,'money',$money,54,'获得礼物:'.$giftinfo["name"],'gift_user_typing',$log_id);
            if($wallet_rs['status'] === false){
                Db::rollback();
                $this->error($wallet_rs['msg']);
            }
        }



        Db::commit();
        $this->success('赠送成功');

    }
}