From 5099e1378ee8427eef11dff2fbfda1e24748682b Mon Sep 17 00:00:00 2001 From: weiz Date: Mon, 25 Dec 2023 16:22:47 +0800 Subject: [PATCH] ProjectInsuranceManagement --- .../ProjectInsuranceManagementController.php | 108 ++++++++++++++ .../project/ProjectPersonnelController.php | 8 +- .../ProjectInsuranceManagementLists.php | 87 +++++++++++ .../ProjectInsuranceManagementLogic.php | 137 ++++++++++++++++++ .../ProjectInsuranceManagementValidate.php | 131 +++++++++++++++++ .../project/ProjectInsuranceManagement.php | 47 ++++++ 6 files changed, 516 insertions(+), 2 deletions(-) create mode 100644 app/adminapi/controller/project/ProjectInsuranceManagementController.php create mode 100644 app/adminapi/lists/project/ProjectInsuranceManagementLists.php create mode 100644 app/adminapi/logic/project/ProjectInsuranceManagementLogic.php create mode 100644 app/adminapi/validate/project/ProjectInsuranceManagementValidate.php create mode 100644 app/common/model/project/ProjectInsuranceManagement.php diff --git a/app/adminapi/controller/project/ProjectInsuranceManagementController.php b/app/adminapi/controller/project/ProjectInsuranceManagementController.php new file mode 100644 index 000000000..9136b4255 --- /dev/null +++ b/app/adminapi/controller/project/ProjectInsuranceManagementController.php @@ -0,0 +1,108 @@ +dataLists(new ProjectInsuranceManagementLists()); + } + + + /** + * @notes 添加保险管理 + * @return \think\response\Json + * @author likeadmin + * @date 2023/12/25 15:58 + */ + public function add() + { + $params = (new ProjectInsuranceManagementValidate())->post()->goCheck('add'); + $result = ProjectInsuranceManagementLogic::add($params); + if (true === $result) { + return $this->success('添加成功', [], 1, 1); + } + return $this->fail(ProjectInsuranceManagementLogic::getError()); + } + + + /** + * @notes 编辑保险管理 + * @return \think\response\Json + * @author likeadmin + * @date 2023/12/25 15:58 + */ + public function edit() + { + $params = (new ProjectInsuranceManagementValidate())->post()->goCheck('edit'); + $result = ProjectInsuranceManagementLogic::edit($params); + if (true === $result) { + return $this->success('编辑成功', [], 1, 1); + } + return $this->fail(ProjectInsuranceManagementLogic::getError()); + } + + + /** + * @notes 删除保险管理 + * @return \think\response\Json + * @author likeadmin + * @date 2023/12/25 15:58 + */ + public function delete() + { + $params = (new ProjectInsuranceManagementValidate())->post()->goCheck('delete'); + ProjectInsuranceManagementLogic::delete($params); + return $this->success('删除成功', [], 1, 1); + } + + + /** + * @notes 获取保险管理详情 + * @return \think\response\Json + * @author likeadmin + * @date 2023/12/25 15:58 + */ + public function detail() + { + $params = (new ProjectInsuranceManagementValidate())->goCheck('detail'); + $result = ProjectInsuranceManagementLogic::detail($params); + return $this->data($result); + } + + +} \ No newline at end of file diff --git a/app/adminapi/controller/project/ProjectPersonnelController.php b/app/adminapi/controller/project/ProjectPersonnelController.php index 18912cf95..b6be0fee6 100644 --- a/app/adminapi/controller/project/ProjectPersonnelController.php +++ b/app/adminapi/controller/project/ProjectPersonnelController.php @@ -20,6 +20,7 @@ use app\adminapi\controller\BaseAdminController; use app\adminapi\lists\project\ProjectPersonnelLists; use app\adminapi\logic\project\ProjectPersonnelLogic; use app\adminapi\validate\project\ProjectPersonnelValidate; +use app\common\model\project\Project; use app\common\model\project\ProjectPersonnel; @@ -114,17 +115,20 @@ class ProjectPersonnelController extends BaseAdminController } $pageNo = empty($params['page_no']) ? 1 : $params['page_no']; $pageSize = empty($params['page_size']) ? 15 : $params['page_size']; - $data = ProjectPersonnel::field('id,name,idcard,work_type,unit_price,daily_living_expenses') + $data = ProjectPersonnel::field(['id', 'project_id', 'name', 'idcard', 'mobile', 'work_type', 'unit_price', 'daily_living_expenses', 'idcard_front', 'idcard_backend', 'bank_card', 'bank_no', 'deposit_bank', 'remark', 'opening_income']) ->where('project_id',$params['project_id']) ->page($pageNo, $pageSize) ->order(['id' => 'desc']) ->select() ->each(function($item){ $item['work_type_text'] = $item->work_type_text; + $project = Project::field('name,project_code')->where('id',$item['project_id'])->findOrEmpty(); + $item['project_name'] = $project['name']; + $item['project_code'] = $project['project_code']; return $item; }) ->toArray(); - $count = ProjectPersonnel::field('id,name,idcard,work_type,unit_price,daily_living_expenses')->where('project_id',$params['project_id'])->count(); + $count = ProjectPersonnel::field('id')->where('project_id',$params['project_id'])->count(); $result = [ 'count' => $count, 'page_no' => $pageNo, diff --git a/app/adminapi/lists/project/ProjectInsuranceManagementLists.php b/app/adminapi/lists/project/ProjectInsuranceManagementLists.php new file mode 100644 index 000000000..6c3517771 --- /dev/null +++ b/app/adminapi/lists/project/ProjectInsuranceManagementLists.php @@ -0,0 +1,87 @@ + ['type', 'insurance_no', 'insurance_company', 'invoice_no', 'handler'], + ]; + } + + + /** + * @notes 获取保险管理列表 + * @return array + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\DbException + * @throws \think\db\exception\ModelNotFoundException + * @author likeadmin + * @date 2023/12/25 15:58 + */ + public function lists(): array + { + return ProjectInsuranceManagement::where($this->searchWhere) + ->field(['id', 'project_id', 'project_person_id', 'insurance_date', 'due_date', 'type', 'insurance_no', 'insurance', 'insured_amount', 'insurance_company', 'insurance_detail', 'invoice_no', 'handler', 'annex']) + ->limit($this->limitOffset, $this->limitLength) + ->order(['id' => 'desc']) + ->select()->each(function($item){ + $project = Project::field('name,project_code')->where('id',$item['project_id'])->findOrEmpty(); + $person = ProjectPersonnel::field('name,idcard')->where('id',$item['project_person_id'])->findOrEmpty(); + $item['project_name'] = $project['name']; + $item['project_code'] = $project['project_code']; + $item['person_name'] = $person['name']; + $item['person_idcard'] = $person['idcard']; + return $item; + }) + ->toArray(); + } + + + /** + * @notes 获取保险管理数量 + * @return int + * @author likeadmin + * @date 2023/12/25 15:58 + */ + public function count(): int + { + return ProjectInsuranceManagement::where($this->searchWhere)->count(); + } + +} \ No newline at end of file diff --git a/app/adminapi/logic/project/ProjectInsuranceManagementLogic.php b/app/adminapi/logic/project/ProjectInsuranceManagementLogic.php new file mode 100644 index 000000000..8adcad3f5 --- /dev/null +++ b/app/adminapi/logic/project/ProjectInsuranceManagementLogic.php @@ -0,0 +1,137 @@ + $params['project_id'], + 'project_person_id' => $params['project_person_id'], + 'insurance_date' => strtotime($params['insurance_date']), + 'due_date' => strtotime($params['due_date']), + 'type' => $params['type'], + 'insurance_no' => $params['insurance_no'], + 'insurance' => $params['insurance'], + 'insured_amount' => $params['insured_amount'], + 'insurance_company' => $params['insurance_company'], + 'insurance_detail' => $params['insurance_detail'], + 'invoice_no' => $params['invoice_no'], + 'handler' => $params['handler'], + 'annex' => !empty($params['annex']) ? $params['annex'] : null, + ]); + Db::commit(); + return true; + } catch (\Exception $e) { + Db::rollback(); + self::setError($e->getMessage()); + return false; + } + } + + + /** + * @notes 编辑保险管理 + * @param array $params + * @return bool + * @author likeadmin + * @date 2023/12/25 15:58 + */ + public static function edit(array $params): bool + { + Db::startTrans(); + try { + ProjectInsuranceManagement::where('id', $params['id'])->update([ + 'project_id' => $params['project_id'], + 'project_person_id' => $params['project_person_id'], + 'insurance_date' => strtotime($params['insurance_date']), + 'due_date' => strtotime($params['due_date']), + 'type' => $params['type'], + 'insurance_no' => $params['insurance_no'], + 'insurance' => $params['insurance'], + 'insured_amount' => $params['insured_amount'], + 'insurance_company' => $params['insurance_company'], + 'insurance_detail' => $params['insurance_detail'], + 'invoice_no' => $params['invoice_no'], + 'handler' => $params['handler'], + 'annex' => !empty($params['annex']) ? $params['annex'] : null, + ]); + Db::commit(); + return true; + } catch (\Exception $e) { + Db::rollback(); + self::setError($e->getMessage()); + return false; + } + } + + + /** + * @notes 删除保险管理 + * @param array $params + * @return bool + * @author likeadmin + * @date 2023/12/25 15:58 + */ + public static function delete(array $params): bool + { + return ProjectInsuranceManagement::destroy($params['id']); + } + + + /** + * @notes 获取保险管理详情 + * @param $params + * @return array + * @author likeadmin + * @date 2023/12/25 15:58 + */ + public static function detail($params): array + { + $data = ProjectInsuranceManagement::findOrEmpty($params['id'])->toArray(); + $project = Project::field('name,project_code')->where('id',$data['project_id'])->findOrEmpty(); + $person = ProjectPersonnel::field('name,idcard')->where('id',$data['project_person_id'])->findOrEmpty(); + $data['project_name'] = $project['name']; + $data['project_code'] = $project['project_code']; + $data['person_name'] = $person['name']; + $data['person_idcard'] = $person['idcard']; + return $data; + } +} \ No newline at end of file diff --git a/app/adminapi/validate/project/ProjectInsuranceManagementValidate.php b/app/adminapi/validate/project/ProjectInsuranceManagementValidate.php new file mode 100644 index 000000000..cf91e730d --- /dev/null +++ b/app/adminapi/validate/project/ProjectInsuranceManagementValidate.php @@ -0,0 +1,131 @@ + 'require', + 'project_id' => 'require|checkProject', + 'project_person_id' => 'require|checkProjectPerson', + 'insurance_date' => 'require|dateFormat:Y-m-d', + 'due_date' => 'require|dateFormat:Y-m-d', + 'annex' => 'checkFile', + ]; + + protected $message = [ + 'id.require' => '缺少必要参数', + 'project_id.require' => '请选择项目', + 'project_person_id.require' => '请选择项目人员', + 'insurance_date.require' => '请选择投保日期', + 'insurance_date.dateFormat' => '投保日期格式错误', + 'due_date.require' => '请选择到期日期', + 'due_date.dateFormat' => '到期日期格式错误', + ]; + + + /** + * @notes 添加场景 + * @return ProjectInsuranceManagementValidate + * @author likeadmin + * @date 2023/12/25 15:58 + */ + public function sceneAdd() + { + return $this->remove('id',true); + } + + + /** + * @notes 编辑场景 + * @return ProjectInsuranceManagementValidate + * @author likeadmin + * @date 2023/12/25 15:58 + */ + public function sceneEdit() + {} + + + /** + * @notes 删除场景 + * @return ProjectInsuranceManagementValidate + * @author likeadmin + * @date 2023/12/25 15:58 + */ + public function sceneDelete() + { + return $this->only(['id']); + } + + + /** + * @notes 详情场景 + * @return ProjectInsuranceManagementValidate + * @author likeadmin + * @date 2023/12/25 15:58 + */ + public function sceneDetail() + { + return $this->only(['id']); + } + + public function checkProject($value): bool|string + { + $data = Project::where('id',$value)->findOrEmpty(); + if($data->isEmpty()){ + return '项目不存在'; + } + return true; + } + + public function checkProjectPerson($value,$rule,$data): bool|string + { + $person = ProjectPersonnel::where('id',$value)->findOrEmpty(); + if($person->isEmpty()){ + return '项目人员不存在'; + } + if($person['project_id'] != $data['project_id']){ + return '项目人员无效'; + } + return true; + } + + public function checkFile($value): bool|string + { + if($value != ''){ + $file = json_decode($value,true); + if(empty($file)){ + return '附件必须是json数组'; + } + } + return true; + } +} \ No newline at end of file diff --git a/app/common/model/project/ProjectInsuranceManagement.php b/app/common/model/project/ProjectInsuranceManagement.php new file mode 100644 index 000000000..76c55535c --- /dev/null +++ b/app/common/model/project/ProjectInsuranceManagement.php @@ -0,0 +1,47 @@ +