<?php

namespace App\Admin\Controllers\Content;

use App\Admin\Extensions\Form\ValidateForm;
use App\Http\Controllers\Controller;
use App\Models\TalentHouse;
use App\Models\TalentHouseApply;
use App\Services\Common\Sm4Service;
use Encore\Admin\Controllers\HasResourceActions;
use Encore\Admin\Form;
use Encore\Admin\Grid;
use Encore\Admin\Layout\Content;
use Illuminate\Http\Request;
use Illuminate\Support\Facades\DB;

class BuyHouseController extends Controller
{
    use HasResourceActions;

    private $house_status = ['未知', '未开始', '申报中', '已结束'];

    /**
     * Index interface.
     *
     * @param Content $content
     * @return Content
     */
    public function index(Content $content)
    {
        return $content
            ->header('房源列表')
            ->description(' ')
            ->body(view('admin.content.buy_house')->with(['grid' => $this->grid()]));
    }

    /**
     * Edit interface.
     *
     * @param mixed $id
     * @param Content $content
     * @return Content
     */
    public function edit($id, Content $content)
    {
        return $content
            ->header('房源')
            ->description(' ')
            ->body($this->editForm($id)->edit($id));
    }

    /**
     * Create interface.
     *
     * @param Content $content
     * @return Content
     */
    public function create(Content $content)
    {
        return $content
            ->header('房源')
            ->description(' ')
            ->body($this->form());
    }


    /**
     * Make a grid builder.
     *
     * @return Grid
     */
    protected function grid()
    {
        $grid = new Grid(new TalentHouse());

        $grid->model()->orderBy('updated_at', 'DESC');

        $grid->id('ID');
        $grid->name('项目名称');
        $grid->small_img('缩略图')->display(function () {
            if ($this->small_img) {
                return '<span class="vtip" title="<img src=\'' . upload_asset($this->small_img) . '\'  height=120>">
                            <img class="avatar small" src="' . upload_asset($this->small_img) . '" align="absmiddle" style="width: 22px;height: 22px;">
                        </span>';
            } else {
                return '';
            }
        });
        $grid->status('状态')->display(function () {
            $time = time();
            if (strtotime($this->apply_time_start) > $time) {
                return '未开始';
            }
            if (strtotime($this->apply_time_end) < $time) {
                return '已结束';
            }
            return '申报中';
        });
        $grid->declare_time('申报时间')->display(function () {
            return date('Y-m-d', strtotime($this->declare_time));
        });
        $grid->column('报名时间')->display(function () {
            return date('Y-m-d', strtotime($this->apply_time_start)) . '至' . date('Y-m-d', strtotime($this->apply_time_end));
        });

        //新增按钮
        $grid->disableCreateButton(false);

        //批量删除
        $grid->tools(function ($tools) {
            $tools->batch(function ($batch) {
                $batch->disableDelete(false);
            });
        });

        $grid->actions(function ($actions) {
            $actions->disableEdit(false);
            $actions->disableDelete(false);
            if (strtotime($actions->row['supply_time']) <= time() && $actions->row['sync_status'] == 2) {
                $actions->append("&nbsp;<button class='btn btn-default btn-xs select_house' data-id=" . $actions->row['id'] . ">选房顺序号</button>");
                $actions->append("&nbsp;<button class='btn btn-warning btn-xs sync' data-id=" . $actions->row['id'] . ">同步到选房系统</button>");
            }
            if (strtotime($actions->row['supply_time']) <= time()) {
                $actions->append("&nbsp;<button class='btn btn-primary btn-xs export_pass' data-id=" . $actions->row['id'] . ">导出通过名单</button>");
                $actions->append("&nbsp;<button class='btn btn-danger btn-xs export_no_pass' data-id=" . $actions->row['id'] . ">导出不通过名单</button>");
            }
        });

        $grid->filter(function ($filter) {
            $filter->disableIdFilter();
            $filter->like('name', '项目名称');
            $status_option = ['全部', '未开始', '申报中', '已结束'];
            $filter->where(function ($query) {
                $date = date('Y-m-d H:i:s');
                if ($this->input == 1) {
                    $query->where('apply_time_start', '>', $date);
                }
                if ($this->input == 2) {
                    $query->where('apply_time_start', '<', $date)->where('apply_time_end', '>', $date);
                }
                if ($this->input == 3) {
                    $query->where('apply_time_end', '<', $date);
                }
            }, '状态', 'status')->radio($status_option);
        });
        return $grid;
    }

    /**
     * Make a form builder.
     *
     * @return Form
     */
    protected function form()
    {
        $form = new ValidateForm(new TalentHouse());
        $form->text('name', '项目名称')->rules('required|max:100', ['required' => '标题不能为空。', 'max' => '标题长度不能大于100。'])->setWidth(4)->setMustMark();
        $form->number('project_id', '选房系统项目id')->rules('required', ['required' => '项目id不能为空。若未确定id,请填0'])->setWidth(4)->setMustMark();
        $form->datetime('declare_time', '申报时间')->rules('required', ['required' => '申报时间不能为空。'])->setWidth(4)->setMustMark();
        $form->datetime('apply_time_start', '报名开始时间')->rules('required', ['required' => '报名开始时间不能为空。'])->setWidth(4)->setMustMark();
        $form->datetime('apply_time_end', '报名结束时间')->rules('required', ['required' => '报名结束时间不能为空。'])->setWidth(4)->setMustMark();
        $form->datetime('supply_time', '补件截止时间')->rules('required', ['required' => '补件截止时间不能为空。'])->setWidth(4)->setMustMark();
        $form->text('address', '地址')->rules('required|max:100', ['required' => '地址不能为空。', 'max' => '地址长度不能大于100。'])->setWidth(8)->setMustMark();
        $form->image('small_img', '缩略图')->uniqueName()->rules('image|mimes:jpeg,bmp,png', ['image' => '缩略图请选择图片文件。', 'mimes' => '请选择jpeg,bmp,png格式的缩略图上传。'])->setWidth(4);
        $form->textarea('describe', '描述')->rules('required|max:1024', ['required' => '描述不能为空。', 'max' => '描述长度不能大于1024。'])->setWidth(8)->setMustMark();
        $form->editor('content', '内容')->rules('required', ['required' => '内容不能为空。'])->setMustMark();

        $form->saved(function (Form $form) {
            //如果没有上传logo,判断是否
            $small_img = \Illuminate\Support\Facades\Request::input('small_img');
            if (!$form->model()->small_img && $small_img) {
                $form->model()->small_img = $small_img;
                $form->model()->save();
            }
        });

        $form->footer(function ($footer) {
            $footer->disableViewCheck();
            $footer->disableEditingCheck();
            $footer->disableCreatingCheck();
            $footer->disableReset();
        });
        return $form;
    }

    protected function editForm($id)
    {
        $form = new ValidateForm(new TalentHouse());
        $form->text('name', '项目名称')->rules('required|max:100', ['required' => '标题不能为空。', 'max' => '标题长度不能大于100。'])->setWidth(4)->setMustMark();
        $form->number('project_id', '选房系统项目id')->rules('required', ['required' => '项目id不能为空。若未确定id,请填0'])->setWidth(4)->setMustMark();
        $form->datetime('declare_time', '申报时间')->rules('required', ['required' => '申报时间不能为空。'])->setWidth(4)->setMustMark();
        $form->datetime('apply_time_start', '报名开始时间')->rules('required', ['required' => '报名开始时间不能为空。'])->setWidth(4)->setMustMark();
        $form->datetime('apply_time_end', '报名结束时间')->rules('required', ['required' => '报名结束时间不能为空。'])->setWidth(4)->setMustMark();
        $form->datetime('supply_time', '补件截止时间')->rules('required', ['required' => '补件截止时间不能为空。'])->setWidth(4)->setMustMark();
        $form->text('address', '地址')->rules('required|max:100', ['required' => '地址不能为空。', 'max' => '地址长度不能大于100。'])->setWidth(8)->setMustMark();
        $form->image('small_img', '缩略图')->uniqueName()->rules('image|mimes:jpeg,bmp,png', ['image' => '缩略图请选择图片文件。', 'mimes' => '请选择jpeg,bmp,png格式的缩略图上传。'])->setWidth(4);
        $form->textarea('describe', '描述')->rules('required|max:1024', ['required' => '描述不能为空。', 'max' => '描述长度不能大于1024。'])->setWidth(8)->setMustMark();
        $form->editor('content', '内容')->rules('required', ['required' => '内容不能为空。'])->setMustMark();

        $form->saved(function (Form $form) {
            //如果没有上传logo,判断是否
            $small_img = \Illuminate\Support\Facades\Request::input('small_img');
            if (!$form->model()->small_img && $small_img) {
                $form->model()->small_img = $small_img;
                $form->model()->save();
            }
        });

        $form->footer(function ($footer) {
            $footer->disableViewCheck();
            $footer->disableEditingCheck();
            $footer->disableCreatingCheck();
            $footer->disableReset();
        });
        $form->tools(function (Form\Tools $tools) {
            $tools->disableDelete();
            $tools->disableView();
        });
        return $form;
    }

    public function update($id)
    {
        return $this->editForm($id)->update($id);
    }

    public function destroy($id)
    {
        //是否存在报名列表
        $ids   = explode(',', $id);
        $check = TalentHouseApply::whereIn('house_id', $ids)->count();
        if ($check > 0) {
            return response()->json([
                'status'  => false,
                'message' => '存在申报信息的房源不允许删除!',
            ]);
        }

        if ($this->form()->destroy($id)) {
            $data = [
                'status'  => true,
                'message' => trans('admin.delete_succeeded'),
            ];
        } else {
            $data = [
                'status'  => false,
                'message' => trans('admin.delete_failed'),
            ];
        }
        return response()->json($data);
    }

    /**
     * 释放名额
     */
    public function sock(Request $request)
    {
        $id = $request->id;

        if (empty($id)) {
            return response()->json(['code' => 0, 'content' => '数据异常']);
        }

        $house = TalentHouse::find($id);
        if (strtotime($house['supply_time']) > time()) {
            return response()->json(['code' => 0, 'content' => '报名还未结束']);
        }
        if ($house['is_sock'] == 2) {
            return response()->json(['code' => 1]);
        }

        //释放名额
        TalentHouse::where('id', $id)->update(['is_sock' => 2]);
        TalentHouseApply::where('house_id', $id)->update(['is_sock' => 2]);

        return response()->json(['code' => 1]);
    }

    /**
     * 同步选房系统
     */
    public function sync(Request $request)
    {
        $id = $request->id;

        if (empty($id)) {
            return response()->json(['code' => 0, 'content' => '数据异常']);
        }

        $house = TalentHouse::find($id);
        if ($house['project_id'] == 0) {
            return response()->json(['code' => 0, 'content' => '请先填选房系统项目id']);
        }
        if (strtotime($house['supply_time']) > time()) {
            return response()->json(['code' => 0, 'content' => '报名还未结束']);
        }
        if ($house['sync_status'] == 1) {
            return response()->json(['code' => 1]);
        }

        //释放名额
        if ($house['is_sock'] == 1) {
            TalentHouse::where('id', $id)->update(['is_sock' => 2]);
            TalentHouseApply::where('house_id', $id)->update(['is_sock' => 2]);
        }

        //TODO:同步选房系统,等接口
        $apply = TalentHouseApply::with('idcard')->where('house_id', $id)->where('select_house_no', '<', 999999)->orderBy('select_house_no', 'asc')->get();
        if (empty($apply)) {
            return response()->json(['code' => 0, 'content' => '请先填写选房顺序号']);
        }
        $api_data = [
            'xmId'   => $house['project_id'],
            'xmName' => $house['name'],
            'data'   => [],
        ];
        foreach ($apply as $v) {
            $data_item          = [];
            $data_item['index'] = $v['select_house_no'];
            $data_item['xm1']   = $v['name'];
            $data_item['card1'] = $v['idcard']['id_card'];
            $family             = $v['family'] ? json_decode($v['family'], true) : [];
            $data_item['card3'] = $data_item['xm3'] = $data_item['card2'] = $data_item['xm2'] = '';

            //家庭关系
            if (!empty($family)) {
                $child_names = [];
                $child_cards = [];
                foreach ($family as $fa) {
                    if ($fa['relation'] == '配偶') {
                        $data_item['xm2']   = $fa['realname'] == '无' ? '' : $fa['realname'];
                        $data_item['card2'] = $fa['idcard'] == '无' ? '' : $fa['idcard'];
                    } else {
                        if ($fa['realname'] != '无') {
                            $child_names[] = $fa['realname'] == '无' ? '' : $fa['realname'];
                            $child_cards[] = $fa['idcard'] == '无' ? '' : $fa['idcard'];
                        }
                    }
                }
                $data_item['xm3']   = implode('/', $child_names);
                $data_item['card3'] = implode('/', $child_cards);
            }

            $data_item['hjh']    = '';
            $data_item['phone']  = $v['mobile'];
            $data_item['hunyin'] = $v['marry'] == 1 ? '未婚' : '已婚';
            $data_item['kx']     = '是';

            $api_data['data'][] = $data_item;
        }
        $sm4     = new Sm4Service();
        $sm4_key = 'ydkjjjrcgjrcdrjk';
        $ch      = curl_init();
        curl_setopt($ch, CURLOPT_URL, "http://jjzf.fjeda.com:9001/admin/xuanfang/importGaojiRencai");
        curl_setopt($ch, CURLOPT_HTTPHEADER, [
                'Content-Type: application/json; charset=utf-8'   //json版本需要填写  Content-Type: application/json;
            ]
        );
        curl_setopt($ch, CURLOPT_RETURNTRANSFER, 1);
        curl_setopt($ch, CURLOPT_TIMEOUT, 60);
        curl_setopt($ch, CURLOPT_SSL_VERIFYHOST, 0);
        curl_setopt($ch, CURLOPT_SSL_VERIFYPEER, 0);
        curl_setopt($ch, CURLOPT_POST, true);
        curl_setopt($ch, CURLOPT_POSTFIELDS, $sm4->encrypt($sm4_key, json_encode($api_data)));
        $result = curl_exec($ch);
        curl_close($ch);
        if (empty($result)) {
            return response()->json(['code' => 0, 'content' => '连接对方服务器失败,请联系管理员']);
        }
        $ret = json_decode($sm4->decrypt($sm4_key, $result), true);

        if ($ret['code'] == '0000') {
            TalentHouse::where('id', $id)->update(['sync_status' => 1]);
            return response()->json(['code' => 1]);
        } else {
            return response()->json(['code' => 0, 'content' => $ret['msg']]);
        }
    }

    /**
     * 导出
     */
    public function export(Request $request)
    {
        //数据获取
        $id     = $request->id;
        $status = $request->status;
        $house  = TalentHouse::find($id);
        $query  = TalentHouseApply::with(['house', 'idcard'])
            ->where('house_id', $id)
            ->where('is_back', 2)
            ->where('is_draft', 2)
            ->orderByRaw(DB::raw("FIELD(talent_level,'第一层次','第二层次','第三层次','第四层次','第五层次','第六层次','第七层次') asc"));
        if ($status == 1) {
            $filename = $house['name'] . '审核不通过名单.xls';
            $query    = $query->whereIn('status', [1, 3, 4]);
        } else {
            $filename = $house['name'] . '审核通过名单.xls';
            $query    = $query->where('status', 2);
        }
        $data = $query->get();
        if ($data->isEmpty()) {
            return '暂无数据';
        }


        //数据处理
        $status = ['', '待审核', '审核通过', '审核驳回', '审核不通过'];
        $marry  = ['未知', '未婚', '已婚', '离异', '丧偶'];
        $type   = ['', '优秀人才', '集成电路优秀人才'];
        $no     = 1;
        foreach ($data as $row) {
            $family = empty($row->family) ? '' : json_decode($row->family, true);
            if (!empty($family)) {
                $relation = [];
                $child    = [];
                $id_card  = [];
                foreach ($family as $v) {
                    $relation[] = $v['relation'];
                    $child[]    = $v['realname'];
                    $id_card[]  = $v['idcard'];
                }
                $row['relation']         = implode('/', $relation);
                $row['relation_name']    = implode('/', $child);
                $row['relation_id_card'] = implode('/', $id_card);
            }

            $row['no'] = $no;
            $no++;
            $row['marry_text'] = $marry[$row['marry']];
            $row['type_text']  = $type[$row['type']];
        }

        header("Content-type: application/vnd.ms-excel; charset=utf-8");
        header("Content-Disposition: attachment; filename=$filename");
        $view = view('admin.content.export_house_result')->with(['data' => $data, 'house' => $house, 'status' => $status]);
        $str  = response($view)->getContent();
        echo $str;
        exit;
    }

    /**
     * 图片
     */
    public function image(Request $request)
    {
        $src          = $request->src;
        $photo_data[] = [
            'alt' => '',
            'pid' => 1,
            'src' => $src,
        ];
        $photos       = [
            'title' => '图片信息',
            'id'    => 1,
            'start' => 0,
            'data'  => $photo_data,
        ];

        return view('admin.content.buy_house_image', ['src' => $src, 'photos' => $photos]);
    }
}