<?php

namespace app\api\controller\coach;

use app\common\controller\Apic;
use think\Db;
/**
 * 售课
 */
class Lesson extends Apic
{
    // 无需登录的接口,*表示全部
    protected $noNeedLogin = [];
    // 无需鉴权的接口,*表示全部
    protected $noNeedRight = ['*'];

    //售课分类列表
    public function lesson_cate(){
        $list = Db::name('lesson_cate')->order('id asc')->select();
        $list = $this->list_lang($list,['name']);

        $this->success(1,$list);
    }

    //课时首页
    public function slot_list(){

        $date = input('date',date('Y-m-d'),'strtotime');
        $where = [
            'slot.starttime' => ['BETWEEN',[$date,$date+86399]],
            'slot.is_show' => 1,
        ];

        //课时
        $list = Db::name('lesson_slot')->alias('slot')
            ->field('slot.*,lesson.name,lesson.name_en,lesson.image,lesson.price')
            ->join('lesson','slot.lesson_id = lesson.id','LEFT')
            ->where($where);

        $list->where('find_in_set(:coach_ids,coach_ids)', ['coach_ids' => $this->auth->id]);

        $list = $list->order('slot.starttime asc')->select();
        if(empty($list)){
            $this->success(1,[]);
        }
        $list = list_domain_image($list,['image']);
        $list = $this->list_lang($list,['name']);


        foreach($list as $key => &$slot){
            //hours转换
            $slot['hours'] = floatval($slot['hours']);

            //已报名数量,(包含已支付,已点名,没有冲突)
            $pay_number = Db::name('lesson_order')->alias('order')
                ->field('order.id,user.avatar,order.usernumber')
                ->join('user','order.user_id = user.id','LEFT')
                ->where('order.slot_id',$slot['id'])
                ->where('order.order_status','IN',[10,20])
                ->select();
            $pay_number = list_domain_image($pay_number,['avatar']);

            $slot['usernumber'] = array_sum(array_column($pay_number,'usernumber'));
            $slot['useravatar'] = array_column($pay_number,'avatar');
        }

        $this->success(1,$list);
    }

    //课时列表首页
    //根据年,月获取当月剩余日期,有课程的标记1
    public function slot_index(){

        $getdate = input('date',date('Y-m'));
        if(empty($getdate)){
            $getdate = date('Y-m');
        }
        $year = substr($getdate,0,4);
        $month = substr($getdate,-2,2);

        //今天是哪日
        if($year == date('Y') && $month == date('m')){
            //如果是今年今月,默认今天开始
            $startday = date('d');
        }else{
            //从1号开始
            $startday = '01';
        }

        //一周
        $week_arr = [
            1 => '周一',
            2 => '周二',
            3 => '周三',
            4 => '周四',
            5 => '周五',
            6 => '周六',
            7 => '周日',
        ];

        //本月结束日
        $endday_arr = [
            '01' => 31,
            '02' => 28,
            '03' => 31,
            '04' => 30,
            '05' => 31,
            '06' => 30,
            '07' => 31,
            '08' => 31,
            '09' => 30,
            '10' => 31,
            '11' => 30,
            '12' => 31,
        ];
        if($year%4 == 0){
            $endday_arr['02'] = 29;
        }
        $endday = $endday_arr[$month];

        //拿数据
        $startdate = $getdate.'-'.$startday;
        $enddate   = $getdate.'-'.$endday;
        $where = [
            'starttime' => ['BETWEEN',[strtotime($startdate),strtotime($enddate)+86399]],
            'status'    => 0,
            'is_show' => 1,
        ];
        //dump($where);exit;
        $slots = Db::name('lesson_slot')
            ->where($where)
            ->where('find_in_set(:coach_ids,coach_ids)', ['coach_ids' => $this->auth->id])
            ->field('id,starttime')->select();

        $date_arr = [];
        for($i=intval($startday);$i<=$endday;$i++){

            $j = $i;
            if($j < 10){
                $j = 0 . $j;
            }
            $idate = $year.'-'.$month.'-'.$j;

            $itime = strtotime($idate);
            $week = $this->lang == 'en' ? date('D',$itime) : $week_arr[date('N',$itime)];

            $i_data = [
                'yeah' =>$year,
                'month'=>$month,
                'day'  => $j.'',
                'date' => $idate,
                'week' => $week,
                'is_today' => 0,
                'slot_num' => 0,
            ];

            foreach($slots as $slot){
                if(date('Y-m-d',$slot['starttime']) == $idate)
                {
                    $i_data['slot_num'] += 1;
                }
            }

            if($idate == date('Y-m-d')){
                $i_data['is_today'] = 1;
            }

            $date_arr[] = $i_data;
        }

        $this->success(1,$date_arr);
    }

    //课时详情
    public function slot_info(){
        $slot_id = input('slot_id',0);

        //课时
        $info = Db::name('lesson_slot')->alias('slot')
            ->field('slot.*,lesson.name,lesson.name_en,lesson.image,lesson.price')
            ->join('lesson','slot.lesson_id = lesson.id','LEFT')
            ->where('slot.id',$slot_id)->find();

        $info = info_domain_image($info,['image']);
        $info = $this->info_lang($info,['name']);
        //hours转换
        $info['hours'] = floatval($info['hours']);

        //已报名数量,(包含已支付,已点名,没有冲突)
        $pay_number = Db::name('lesson_order')->alias('order')
            ->field('order.id,user.firstname,user.lastname,user.nickname,user.avatar,order.usernumber,order.usernumber_sign')
            ->join('user','order.user_id = user.id','LEFT')
            ->where('order.slot_id',$info['id'])
            ->where('order.order_status','IN',[10,20])
            ->select();
        $pay_number = list_domain_image($pay_number,['avatar']);
        foreach($pay_number as $key => $val){
            $pay_number[$key]['showname'] = $val['firstname'].' '.$val['lastname'];
        }

        $info['usernumber'] = array_sum(array_column($pay_number,'usernumber'));

        $info['user_list'] = $pay_number;


        $this->success(1,$info);
    }

    //课时申请报名
    public function slot_sign(){
        $this->apiLimit();

        $slot_id = input('slot_id',0,'intval');
        $signdata  = input('signdata','','htmlspecialchars_decode');
        $signdata  = json_decode($signdata,true);

        //测试
        /*$signdata = [
            6 => 1,
            7 => 2,
        ];*/


        //检查课时状态
        $slot_info = Db::name('lesson_slot')->where('id',$slot_id)->find();
        if($slot_info['status'] == 20){
            $this->error('此课程已经点过名了');
        }
        if($slot_info['status'] != 0){
            $this->error('此课程不能提交点名');
        }

        //检查报名单数据
        //逐个检查报名单,对比数量和状态。并保存
        Db::startTrans();
        $order_list = Db::name('lesson_order')->where('slot_id',$slot_id)->where('order_status',10)->order('id asc')->lock(true)->select();
        if(count($order_list) != count($signdata)){
            Db::rollback();
            $this->error('点名数据错误');
        }
        if(empty($order_list)){
            Db::rollback();
            $this->error('无人报名,请直接取消课程');
        }
        foreach($order_list as $order){
            if(!isset($signdata[$order['id']])){
                Db::rollback();
                $this->error('点名数据错误');
            }
            $usernumber_sign = $signdata[$order['id']];

            if($usernumber_sign < 0 || $usernumber_sign > $order['usernumber']){
                Db::rollback();
                $this->error('点名数据错误');
            }

            $update = [
                'usernumber_sign' => $usernumber_sign,
                'order_status'    => 20,
                'finishtime'    => time(),
            ];
            $rs_sign = Db::name('lesson_order')->where('id',$order['id'])->update($update);
            if($rs_sign === false){
                Db::rollback();
                $this->error('点名失败');
            }
        }

        //修改课时状态
        $update = [
            'status'        => 20,
            'finishtime'    => time(),
        ];
        $slot_rs = Db::name('lesson_slot')->where('id',$slot_id)->update($update);
        if($slot_rs === false){
            Db::rollback();
            $this->error('点名失败');
        }

        Db::commit();
        $this->success('点名完成');
    }

    //我的课时记录,点过名的
    public function my_slot_history(){
        $date = strtotime(input('date',date('Y-m-01')));//月初
        $date_end = strtotime('+1 month', $date) - 1;//月末

        $cate_id = input('cate_id',0);
        $lesson_type = input('lesson_type',0);//私教课,普通课

        $where = [
            'slot.starttime' => ['BETWEEN',[$date,$date_end]],
            'slot.status' => 20,
        ];
        if($cate_id){
            $where['lesson.lessoncate_id'] = $cate_id;
        }
        if($lesson_type){
            $where['lesson.type'] = $lesson_type;
        }
        //课时
        $list = Db::name('lesson_slot')->alias('slot')
            ->field('slot.*,lesson.name,lesson.name_en')
            ->join('lesson','slot.lesson_id = lesson.id','LEFT')
            ->where($where);

        $list->where('find_in_set(:coach_ids,coach_ids)', ['coach_ids' => $this->auth->id]);

        $list = $list->order('slot.starttime asc')->select();

        $result = [
            'list' => [],
            'total' => 0,
            'total_hours' => 0,
        ];
        if(empty($list)){
            $this->success(1,$result);
        }

        $list = $this->list_lang($list,['name']);

        $total_hours = 0;
        foreach($list as $key => &$slot){
            //hours转换
            $slot['hours'] = floatval($slot['hours']);
            //已报名数量
            $pay_number = Db::name('lesson_order')->where('slot_id',$slot['id'])->where('order_status',20)->sum('usernumber');
            $slot['usernumber'] = $pay_number;

            $total_hours = bcadd($total_hours,$slot['hours'],1);
        }

        $buttom = __('共计N节课,M小时',['total'=>count($list),'total_hours'=>$total_hours]);

        $result = [
            'list' => $list,
            'buttom' => $buttom,
        ];
        $this->success(1,$result);
    }

}