session("user")['type']]);
    }
    public function list() {
        $params = $this->request;
        $order = trim($params["order"]) ?: "desc";
        $offset = trim($params["offset"]) ?: 0;
        $limit = trim($params["limit"]) ?: 10;
        $where = [];
        $where[] = ["type", "=", $this->user["type"]];
        $where[] = ["enterpriseId", "=", $this->user["uid"]];
        if ($params["year"]) {
            $where[] = ["year", "=", $params["year"]];
        }
        if (\StrUtil::isNotEmpAndNull($params["name"])) {
            $where[] = ["name", "like", "%" . $params["name"] . "%"];
        }
        if (\StrUtil::isNotEmpAndNull($params["idCard"])) {
            $where[] = ["idCard", "like", "%" . $params["idCard"] . "%"];
        }
        if ($params["talentArrange"]) {
            $where[] = ["talentArrange", "=", $params["talentArrange"]];
        }
        if (\StrUtil::isNotEmpAndNull($params["spouseName"])) {
            $where[] = ["spouseName", "like", "%" . $params["spouseName"] . "%"];
        }
        if (\StrUtil::isNotEmpAndNull($params["spouseIdcard"])) {
            $where[] = ["spouseIdcard", "like", "%" . $params["spouseIdcard"] . "%"];
        }
        if (\StrUtil::isNotEmpAndNull($params["childName"])) {
            $where[] = ["childName", "like", "%" . $params["childName"] . "%"];
        }
        if (\StrUtil::isNotEmpAndNull($params["childIdCard"])) {
            $where[] = ["childIdCard", "like", "%" . $params["childIdCard"] . "%"];
        }
        if ($params["marryStatus"]) {
            $where[] = ["marryStatus", "=", $params["marryStatus"]];
        }
        $count = houseModel::where($where)->count();
        $list = houseModel::where($where)->limit($offset, $limit)->order("createTime $order")->select()->toArray();
        //获取字典表婚姻状态
        $marryMap = DictApi::selectByParentCode("marry_status");
        $cardTypeMap = DictApi::selectByParentCode("card_type");
        $streetMap = DictApi::selectByParentCode("street");
        $levelMap = DictApi::selectByParentCode("talent_arrange");
        $whrCondition = [];
        $whrCondition[] = ["type", "=", $this->user["type"]];
        $conditionMap = \app\common\model\TalentCondition::where($whrCondition)->column("name", "id");
        foreach ($list as &$item) {
            $item["marryStatusName"] = $marryMap[$item["marryStatus"]];
            $item["cardTypeName"] = $cardTypeMap[$item["cardType"]];
            $item["spouseCardTypeName"] = $cardTypeMap[$item["spouseCardType"]];
            $item["childCardTypeName"] = $cardTypeMap[$item["childCardType"]];
            $item["streetName"] = $streetMap[$item["street"]];
            $item["talentArrangeName"] = $levelMap[$item["talentArrange"]];
            $item["identifyConditionCH"] = $conditionMap[$item["identifyCondition"]];
        }unset($item);
        return json(["rows" => $list, "total" => $count]);
    }
    /**
     * 申请
     */
    public function apply(\think\Request $request) {
        $param = $request->param();
        $id = isset($param["id"]) ? $param["id"] : 0;
        $vars = [];
        if ($id) {
            $info = HouseApi::getInfoById($id);
            $childrenList = HouseApi::getChildren($id);
            $houseInfo = HouseApi::getHouseInfo($info["idCard"]);
            $dicts = DictApi::selectByParentCode("card_type");
            $vars["dicts"] = $dicts;
            $vars["row"] = $info;
            $vars["hand"] = $houseInfo ? 2 : 1;
            $vars["childrenList"] = $childrenList;
        }
        if ($request->isPost()) {
            return $this->save($info, $request);
        }
        $batch = $info["year"] ?: BatchApi::getValidBatch(ProjectState::HOUSE, $this->user["type"])["batch"];
        $vars["year"] = $batch;
        $vars["type"] = $this->user["type"];
        return view("", $vars);
    }
    public function detail(\think\Request $request) {
        $info = HouseApi::getInfoById($id);
        $childrenList = HouseApi::getChildren($id);
        $dicts = DictApi::selectByParentCode("card_type");
        $vars["dicts"] = $dicts;
        $vars["row"] = $info;
        $vars["childrenList"] = $childrenList;
        $vars["type"] = $this->user["type"];
        return view("", $vars);
    }
    private function other_validate(&$info, $type) {
        //校验配偶是否在库
        if ($info["spouseIsLibrary"] && $info["spouseIsLibrary"] == 1) {
            if (\StrUtil::isEmpOrNull($info["spouseIdcard"])) {
                return new Response(Response::ERROR, "请填写配偶证件号码");
            }
            if (\StrUtil::isEmpOrNull($info["spouseName"])) {
                return new Response(Response::ERROR, "请填写配偶姓名");
            }
            $where = [];
            $where[] = ["card_number", "=", $info["spouseIdcard"]];
            $where[] = ["name", "=", $info["spouseName"]];
            $where[] = ["checkState", "=", \app\common\api\TalentState::CERTIFICATED];
            $where[] = ["isEffect", "<>", 4];
            $where[] = ["delete", "=", 0];
            $count = Db::table("new_talent_info")->where($where)->count();
            if ($count == 0) {
                return new Response(Response::ERROR, "人才库中未查询到配偶相关信息");
            }
        }
        $ti = \app\common\api\VerifyApi::getTalentInfoById($info["talentId"]);
        $info["provinceCode"] = $ti["province"];
        $info["provinceName"] = $ti["provinceName"];
        $info["cityCode"] = $ti["city"];
        $info["cityName"] = $ti["cityName"];
        $info["countyCode"] = $ti["county"];
        $info["countyName"] = $ti["countyName"];
        $info["street"] = $ti["street"];
        $info["bank"] = $ti["bank"];
        $info["bankAccount"] = $ti["bank_account"];
        $info["bankNetwork"] = $ti["bank_branch_name"];
        $info["bankNumber"] = $ti["bank_number"];
        /*         * 校验上一年度人才层次 */
        if ($type == 1) {
            $responseObj = $this->getTalentArrange($ti, $info["year"]);
            if ($responseObj->code == 500) {
                return $responseObj;
            }
            $resInfo = $responseObj->obj;
            $info["talentArrange"] = $resInfo["talentArrange"];
            $info["identifyCondition"] = $resInfo["identifyCondition"];
            $info["idenfityConditionName"] = $resInfo["identifyConditionName"];
            $info["identifyGetTime"] = $resInfo["identifyGetTime"];
            //设置上一年度人才层次有效月份
            $info["monthCount"] = count($resInfo["monthList"]);
            if ($info["monthCount"] < 9) {
                return new Response(Response::ERROR, "申报年度人才证书有效期未满足九个月,无法申报购房补贴");
            }
            $info["talentArrangeMonths"] = implode(",", $resInfo["monthList"]);
        }
        return new Response(Response::SUCCESS, "");
    }
    private function validateIsEdit($checkState) {
        if ($checkState != MainState::SAVE && $checkState != MainState::FIRST_REJECT) {
            return new Response(Response::ERROR, "正在审核中,无法修改");
        }
        return new Response(Response::SUCCESS, "");
    }
    /**
     * 提交表单
     */
    public function submitToCheck() {
        try {
            $id = $this->request["id"];
            $info = HouseApi::getInfoById($id);
            if (!$info) {
                throw new ValidateException("提交审核失败,请先填写基础信息");
            }
            if ($info["enterpriseId"] != $this->user["uid"]) {
                throw new ValidateException("没有对应的人才认定申报信息");
            }
            $batch = BatchApi::checkBatchValid(["type" => ProjectState::HOUSE, "year" => $info["year"], "first_submit_time" => $info["firstSubmitTime"]], $this->user["type"]);
            if ($batch["code"] != 200) {
                throw new ValidateException($batch["msg"]);
            }
            $response = $this->validateIsEdit($info["checkState"]);
            if ($response->code != 200) {
                throw new ValidateException($response->msg);
            }
            validate(\app\enterprise\validate\HouseValidator::class)->check($info);
            $response = $this->other_validate($info, 2);
            if ($response->code != 200) {
                throw new ValidateException($response->msg);
            }
            $where = [];
            $where[] = ["mainId", "=", $id];
            $where[] = ["type", "=", ProjectState::HOUSE];
            $uploadedFileTypes = Db::table("new_talent_file")->where($where)->column("distinct typeId");
            $where = [];
            $where[] = ["project", "=", ProjectState::HOUSE];
            $where[] = ["type", "=", $this->user["type"]];
            $where[] = ["must", "=", 1];
            $where[] = ["active", "=", 1];
            $where[] = ["delete", "=", 0];
            $where[] = ["id", "not in", $uploadedFileTypes];
            $unUploadfiletypes = Db::table("new_common_filetype")->where($where)->select()->toArray();
            if ($unUploadfiletypes) {
                $msg = "以下附件为必传:
";
                foreach ($unUploadfiletypes as $ft) {
                    $msg .= "*" . $ft["name"] . "
";
                }
                throw new ValidateException($msg);
            }
            $data["id"] = $id;
            $data["checkState"] = LaState::LA_NEED_FIRST_CHECK;
            if (!$info["firstSubmitTime"]) {
                $data["firstSubmitTime"] = date("Y-m-d H:i:s");
            }
            $data["newSubmitTime"] = date("Y-m-d H:i:s");
            $data["checkMsg"] = "";
            $data["files"] = "";
            $data["fields"] = "";
            $res = LaModel::update($data);
            if ($res) {
                $user = session("user");
                $log["id"] = getStringId();
                $log["active"] = 1;
                $log["state"] = 1;
                $log["step"] = 0;
                $log["stateChange"] = LaState::getStateDesc($info["checkState"]) . "->" . LaState::getStateDesc($data["checkState"]);
                $log["type"] = ProjectState::LIVINGALLOWANCE;
                $log["mainId"] = $id;
                $log["description"] = "确认提交审核";
                $log["createUser"] = $user ? sprintf("%s(%s)", $user["account"], $user["companyName"] ?: $user["rolename"]) : "系统";
                $log["createTime"] = date("Y-m-d H:i:s");
                TalentLog::create($log);
                return json(["code" => 200, "msg" => "提交审核成功"]);
            }
            throw new ValidateException("提交审核失败");
        } catch (ValidateException $e) {
            $responseObj = new \stdClass();
            $responseObj->code = 500;
            $responseObj->msg = $e->getMessage();
            return json($responseObj);
        } catch (\think\Exception $e) {
            $res = ["code" => 500, "msg" => "发生预料外错误,请联系管理员处理,错误代码:" . $e->getCode()];
            $logInfo = [
                "enterprise_id" => $this->user["uid"],
                "data" => $data,
                "controller" => $this->request->controller(),
                "action" => $this->request->action(),
                "errCode" => $e->getCode(),
                "errMsg" => $e->getMessage()
            ];
            Log::write($logInfo, "error");
            return json($res);
        }
    }
    public function save($info, \think\Request $request) {
        try {
            $batch = BatchApi::checkBatchValid(["type" => ProjectState::HOUSE, "year" => $info["year"], "first_submit_time" => $info["firstSubmitTime"]], $this->user["type"]);
            if ($batch["code"] != 200) {
                throw new ValidateException($batch["msg"]);
            }
            if ($info) {
                $response = $this->validateIsEdit($info["checkState"]);
                if ($response->code != 200) {
                    throw new ValidateException($response->msg);
                }
            }
            $data = $request->param();
            $data["year"] = $batch["batch"];
            $data["type"] = $this->user["type"];
            validate(\app\enterprise\validate\HouseValidator::class)->check($data);
            $response = $this->other_validate($data, $info ? 2 : 1);
            if ($response->code != 200) {
                throw new ValidateException($response->msg);
            }
            $id = $data["id"];
            if ($id) {
                if (!$info || $info["id"] != $id || $info["enterpriseId"] != $this->user["uid"]) {
                    throw new ValidateException("没有对应的人才认定申报信息");
                }
                $data["checkState"] = $info["checkState"];
            } else {
                $data["id"] = getStringId();
                $data["checkState"] = MainState::SAVE;
                $data["createUser"] = $this->user["uid"];
                $data["createTime"] = date("Y-m-d H:i:s");
                $data["enterpriseId"] = $this->user["uid"];
                $data["isConflict"] = 2;
                $data["isRecover"] = 2;
                $houseInfo = HouseApi::getHouseInfo($data["idCard"]);
                $data["number"] = !$houseInfo ? 1 : $houseInfo["count"] + 1;
            }
            $childList = $data["childList"];
            unset($data["jstime"]);
            unset($data["childList"]);
            if ($id) {
                $res = houseModel::update($data);
            } else {
                $res = houseModel::insertGetId($data);
            }
            foreach ($childList as &$children) {
                $children["pId"] = $data["id"];
                if (\StrUtil::isEmpOrNull($children["id"])) {
                    $children["id"] = getStringId();
                    $children["createTime"] = date("Y-m-d H:i:s");
                } else {
                    $children["updateTime"] = date("Y-m-d H:i:s");
                }
            }
            if ($childList) {
                \app\common\model\HousePurchaseChildren::insertAll($childList);
            }
            //添加日志
            \app\common\model\TalentChecklog::create([
                'id' => getStringId(),
                'mainId' => $data['id'],
                'type' => intval(ProjectState::HOUSE),
                'typeFileId' => null,
                'active' => 1,
                'state' => 1,
                'step' => 0,
                'stateChange' => "保存未提交",
                'description' => "添加购房补贴申报",
                'createTime' => date("Y-m-d H:i:s", time()),
                'createUser' => "申报用户"
            ]);
            return json(new Response(Response::SUCCESS, "添加成功", $data));
        } catch (ValidateException $e) {
            return json(new Response(Response::ERROR, $e->getMessage()));
        } catch (\think\Exception $e) {
            $logInfo = [
                "enterprise_id" => $this->user["uid"],
                "data" => $data,
                "controller" => $this->request->controller(),
                "action" => $this->request->action(),
                "errCode" => $e->getCode(),
                "errMsg" => $e->getMessage()
            ];
            Log::write($logInfo, "error");
            return json(new Response(Response::ERROR, "发生预料外错误,请联系管理员处理,错误代码:" . $e->getCode()));
        }
    }
    public function delete() {
        $id = $this->request->param("id");
        $info = CommonLaApi::getInfoById($id);
        if (!$info || $info["enterpriseId"] != $this->user["uid"]) {
            return json(["msg" => "操作失败"]);
        }
        $checkState = $info["checkState"];
        if ($checkState != LaState::LA_SAVE) {
            return json(["msg" => "该申报已提交审核,无法删除"]);
        }
        TalentModel::delete($id);
        $where = [["mainId", "=", $id], ["type", "=", ProjectState::LIVINGALLOWANCE]];
        $list = Db::table("new_talent_file")->where($where)->select()->toArray();
        foreach ($list as $key => $file) {
            if (!empty($file["url"])) {
                $filepath = "storage/" . $file["url"];
                if (file_exists($filepath)) {
                    @unlink($filepath);
                }
            }
            Db::table("new_talent_file")->delete($file["id"]);
        }
        return json(["msg" => "删除成功"]);
    }
    public function getTalentInfo($id, $year, $declareType) {
        $ti = \app\common\api\VerifyApi::getTalentInfoById($id);
        $response = $this->getTalentArrange($ti, $year);
        if ($response->code == 500) {
            return $response;
        }
        $resTalentInfo = $response->obj;
        $ti["talentArrange"] = $resTalentInfo["talentArrange"];
        $ti["identifyCondition"] = $resTalentInfo["identifyCondition"];
        $ti["identifyConditionName"] = $resTalentInfo["identifyConditionName"];
        $ti["identifyMonth"] = $resTalentInfo["identifyMonth"];
        $ti["identifyGetTime"] = $resTalentInfo["identifyGetTime"];
        $ti["certificateStartTime"] = $resTalentInfo["certificateStartTime"];
        $ti["certificateOutTime"] = $resTalentInfo["certificateOutTime"];
        //查询房产库中是否存在房产信息
        $houseInfo = HouseApi::getHouseInfo($ti["card_number"]);
        return new Response(Response::SUCCESS, "", ["talentInfo" => $ti, "houseInfo" => $houseInfo]);
    }
    /**
     * @param talentInfo
     * @param year
     * @description 获取上一年度的人才层次,规则如下:上一年度存在多个人才层次则取占比大的人才层次,占比相同则取人才层次高者
     * @returns com.stylefeng.guns.core.common.model.ResponseObj
     * @author Liu
     * @date 2020/5/6
     * */
    private function getTalentArrange($talentInfo, $year) {
        /**
         * 判定在申报年度内或之前是否认定,申报年度之后认定无效,根据公布入选月份判断(此处还要考虑人才层次变更)
         */
        $year = substr($year, 0, 4);
        $identifyTimeField = "identifyMonth";
        $oldStartTimeField = "oldIdentifyMonth";
        $newStartTimeField = "newIdentifyMonth";
        if ($talentInfo["enterpriseType"] == CommonConst::ENTERPRISE_JC) {
            $identifyTimeField = "identifyGetTime";
            $oldStartTimeField = "oldIdentifyGetTime";
            $newStartTimeField = "newIdentifyGetTime";
        }
        $where = [];
        $where[] = ["idCard", "=", $talentInfo["card_number"]];
        $where[] = ["checkState", "=", MainState::PASS];
        $where[] = ["isPublic", "=", 6];
        $where[] = [$oldStartTimeField, "<=", $year . "-12-31"];
        $typeChanges = \app\enterprise\model\TalentTypeChange::where($where)->field("oldTalentArrange,oldIdentifyCondition,oldIdentifyGetTime,oldIdentifyOutTime,oldIdentifyConditionName,oldIdentifyMonth,oldCertificateStartTime,oldCertificateOutTime,newIdentifyMonth,newIdentifyGetTime")->order("createTime desc")->select()->toArray();
        if (!$typeChanges && strtotime($year . "-12-31") > strtotime($talentInfo[$identifyTimeField])) {
            return new Response(Response::ERROR, "在上一年度未认定优秀人才,无法申报");
        } else {
            $typeChanges[] = [
                "oldTalentArrange" => $talentInfo["talent_arrange"],
                "oldIdentifyCondition" => $talentInfo["talent_condition"],
                "oldIdentifyGetTime" => $talentInfo["identifyGetTime"],
                "oldIdentifyOutTime" => $talentInfo["identifyExpireTime"],
                "oldIdentifyConditionName" => $talentInfo["identifyConditionName"],
                "oldIdentifyMonth" => $talentInfo["identifyMonth"],
                "oldCertificateStartTime" => $talentInfo["certificateGetTime"],
                "oldCertificateOutTime" => $talentInfo["certificateExpireTime"] ?: date("Y-m-d", strtotime(sprintf("%s +6 years -1 days", $talentInfo["certificateGetTime"]))),
                "newIdentifyMonth" => ($year + 1) . "-01-01",
                "newIdentifyGetTime" => ($year + 1) . "-01-01"
            ];
            $totalMonth = \DateUtil::getMonthBetweenDates($year . "-01-01", $year . "-12-31");
            usort($typeChanges, function($a, $b) {
                return (int) $b["oldTalentArrange"] - (int) $a["oldTalentArrange"];
            });
            $months = []; //当年度可用月份
            $talentArrange = 8; //当年度最高层次
            $resTalentInfo = [];
            foreach ($typeChanges as $typeChange) {
                $startTime = $typeChange[$oldStartTimeField];
                $endTime = $typeChange[$newStartTimeField];
                $monthList = \DateUtil::getMonthBetweenDatesNotEnd($startTime, $endTime);
                $res = \DateUtil::getEveryMonthDayBetween($endTime, $endTime, $monthList);
                $intersectMonthList = array_intersect($totalMonth, $monthList);
                if (count($intersectMonthList) > 0) {
                    if ($typeChange["oldTalentArrange"] < $talentArrange) {
                        //按当年度最高
                        $talentArrange = $typeChange["oldTalentArrange"];
                        $resTalentInfo = [
                            "talentArrange" => $typeChange["oldTalentArrange"],
                            "identifyCondition" => $typeChange["oldIdentifyCondition"],
                            "identifyGetTime" => $typeChange["oldIdentifyGetTime"],
                            "identifyConditionName" => $typeChange["oldIdentifyConditionName"],
                            "certificateStartTime" => $typeChange["oldCertificateStartTime"],
                            "certificateOutTime" => $typeChange["oldCertificateOutTime"],
                            "identifyMonth" => $typeChange["oldIdentifyMonth"],
                            "dayMap" => $res
                        ];
                    }
                    $months = array_unique(array_merge($months, $intersectMonthList));
                }
            }
            $resTalentInfo["monthList"] = $months;
            if (count($months) < 9) {
                return new Response(Response::ERROR, "申报年度人才证书有效期未满足九个月,无法申报购房补贴");
            }
            return new Response(Response::SUCCESS, "", $resTalentInfo);
        }
    }
}