diff --git a/app/adminapi/controller/project/ProjectLoanApplyController.php b/app/adminapi/controller/project/ProjectLoanApplyController.php new file mode 100644 index 000000000..74fcc8e5d --- /dev/null +++ b/app/adminapi/controller/project/ProjectLoanApplyController.php @@ -0,0 +1,108 @@ +dataLists(new ProjectLoanApplyLists()); + } + + + /** + * @notes 添加借款申请 + * @return \think\response\Json + * @author likeadmin + * @date 2024/01/17 11:05 + */ + public function add() + { + $params = (new ProjectLoanApplyValidate())->post()->goCheck('add'); + $result = ProjectLoanApplyLogic::add($params); + if (true === $result) { + return $this->success('添加成功', [], 1, 1); + } + return $this->fail(ProjectLoanApplyLogic::getError()); + } + + + /** + * @notes 编辑借款申请 + * @return \think\response\Json + * @author likeadmin + * @date 2024/01/17 11:05 + */ + public function edit() + { + $params = (new ProjectLoanApplyValidate())->post()->goCheck('edit'); + $result = ProjectLoanApplyLogic::edit($params); + if (true === $result) { + return $this->success('编辑成功', [], 1, 1); + } + return $this->fail(ProjectLoanApplyLogic::getError()); + } + + + /** + * @notes 删除借款申请 + * @return \think\response\Json + * @author likeadmin + * @date 2024/01/17 11:05 + */ + public function delete() + { + $params = (new ProjectLoanApplyValidate())->post()->goCheck('delete'); + ProjectLoanApplyLogic::delete($params); + return $this->success('删除成功', [], 1, 1); + } + + + /** + * @notes 获取借款申请详情 + * @return \think\response\Json + * @author likeadmin + * @date 2024/01/17 11:05 + */ + public function detail() + { + $params = (new ProjectLoanApplyValidate())->goCheck('detail'); + $result = ProjectLoanApplyLogic::detail($params); + return $this->data($result); + } + + +} \ No newline at end of file diff --git a/app/adminapi/lists/project/ProjectLoanApplyLists.php b/app/adminapi/lists/project/ProjectLoanApplyLists.php new file mode 100644 index 000000000..af3590712 --- /dev/null +++ b/app/adminapi/lists/project/ProjectLoanApplyLists.php @@ -0,0 +1,86 @@ + ['project_id'], + '%like%' => ['apply_user', 'payee_name'], + ]; + } + + + /** + * @notes 获取借款申请列表 + * @return array + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\DbException + * @throws \think\db\exception\ModelNotFoundException + * @author likeadmin + * @date 2024/01/17 11:05 + */ + public function lists(): array + { + return ProjectLoanApply::where($this->searchWhere) + ->field(['id', 'loan_apply_code', 'project_id', 'apply_user', 'loan_date', 'loan_amount', 'payee_name', 'payee_bank', 'payee_account', 'remark']) + ->limit($this->limitOffset, $this->limitLength) + ->order(['id' => 'desc']) + ->select()->each(function($data){ + $project = Project::field('name,project_code')->where('id',$data['project_id'])->findOrEmpty(); + $data['project_name'] = $project['name']; + $data['project_code'] = $project['project_code']; + $data['has_return_amount'] = 0; + $data['not_return_amount'] = $data['loan_amount'] - $data['has_return_amount']; + return $data; + }) + ->toArray(); + } + + + /** + * @notes 获取借款申请数量 + * @return int + * @author likeadmin + * @date 2024/01/17 11:05 + */ + public function count(): int + { + return ProjectLoanApply::where($this->searchWhere)->count(); + } + +} \ No newline at end of file diff --git a/app/adminapi/logic/project/ProjectLoanApplyLogic.php b/app/adminapi/logic/project/ProjectLoanApplyLogic.php new file mode 100644 index 000000000..cdcf0c3fb --- /dev/null +++ b/app/adminapi/logic/project/ProjectLoanApplyLogic.php @@ -0,0 +1,132 @@ + data_unique_code('项目借款'), + 'project_id' => $params['project_id'], + 'apply_user' => $params['apply_user'], + 'loan_date' => strtotime($params['loan_date']), + 'loan_amount' => $params['loan_amount'], + 'payee_name' => $params['payee_name'], + 'payee_bank' => $params['payee_bank'], + 'payee_account' => $params['payee_account'], + 'remark' => $params['remark'] ?? '', + 'annex' => $params['annex'] ? json_encode($params['annex']) : null, + 'bank_account_id' => $params['bank_account_id'], + ]); + Db::commit(); + return true; + } catch (\Exception $e) { + Db::rollback(); + self::setError($e->getMessage()); + return false; + } + } + + + /** + * @notes 编辑借款申请 + * @param array $params + * @return bool + * @author likeadmin + * @date 2024/01/17 11:05 + */ + public static function edit(array $params): bool + { + Db::startTrans(); + try { + ProjectLoanApply::where('id', $params['id'])->update([ + 'project_id' => $params['project_id'], + 'apply_user' => $params['apply_user'], + 'loan_date' => strtotime($params['loan_date']), + 'loan_amount' => $params['loan_amount'], + 'payee_name' => $params['payee_name'], + 'payee_bank' => $params['payee_bank'], + 'payee_account' => $params['payee_account'], + 'remark' => $params['remark'] ?? '', + 'annex' => $params['annex'] ? json_encode($params['annex']) : null, + 'bank_account_id' => $params['bank_account_id'], + 'update_time' => time(), + ]); + Db::commit(); + return true; + } catch (\Exception $e) { + Db::rollback(); + self::setError($e->getMessage()); + return false; + } + } + + + /** + * @notes 删除借款申请 + * @param array $params + * @return bool + * @author likeadmin + * @date 2024/01/17 11:05 + */ + public static function delete(array $params): bool + { + return ProjectLoanApply::destroy($params['id']); + } + + + /** + * @notes 获取借款申请详情 + * @param $params + * @return array + * @author likeadmin + * @date 2024/01/17 11:05 + */ + public static function detail($params): array + { + $data = ProjectLoanApply::field('id,project_id,loan_apply_code,apply_user,loan_date,loan_amount,payee_name,payee_bank,payee_account,remark,annex,bank_account_id') + ->findOrEmpty($params['id']); + $project = Project::field('name,project_code')->where('id',$data['project_id'])->findOrEmpty(); + $data['project_name'] = $project['name']; + $data['project_code'] = $project['project_code']; + $data['bank_account'] = BankAccount::field('account_sn,deposit_bank,account_name,account')->where('id',$data['bank_account_id'])->findOrEmpty(); + return $data->toArray(); + } +} \ No newline at end of file diff --git a/app/adminapi/validate/project/ProjectLoanApplyValidate.php b/app/adminapi/validate/project/ProjectLoanApplyValidate.php new file mode 100644 index 000000000..26c22fb09 --- /dev/null +++ b/app/adminapi/validate/project/ProjectLoanApplyValidate.php @@ -0,0 +1,139 @@ + 'require', + 'project_id' => 'require|checkProject', + 'apply_user' => 'require', + 'loan_date' => 'require|dateFormat:Y-m-d', + 'loan_amount' => 'require|float|gt:0', + 'payee_name' => 'require', + 'payee_bank' => 'require', + 'payee_account' => 'require', + 'annex' => 'checkAnnex', + 'bank_account_id' => 'require|checkBankAccount', + ]; + + + /** + * 参数描述 + * @var string[] + */ + protected $field = [ + 'id' => 'id', + 'project_id' => '项目id', + 'apply_user' => '借款人', + 'loan_date' => '借款申请日期', + 'loan_amount' => '借款金额', + 'payee_name' => '收款人姓名', + 'payee_bank' => '收款银行', + 'payee_account' => '收款账号', + 'bank_account_id' => '付款银行账户id', + ]; + + + /** + * @notes 添加场景 + * @return ProjectLoanApplyValidate + * @author likeadmin + * @date 2024/01/17 11:05 + */ + public function sceneAdd() + { + return $this->remove('id',true); + } + + + /** + * @notes 编辑场景 + * @return ProjectLoanApplyValidate + * @author likeadmin + * @date 2024/01/17 11:05 + */ + public function sceneEdit() + {} + + + /** + * @notes 删除场景 + * @return ProjectLoanApplyValidate + * @author likeadmin + * @date 2024/01/17 11:05 + */ + public function sceneDelete() + { + return $this->only(['id']); + } + + + /** + * @notes 详情场景 + * @return ProjectLoanApplyValidate + * @author likeadmin + * @date 2024/01/17 11:05 + */ + 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 checkAnnex($value): bool|string + { + if(!empty($value) && $value != ''){ + if(!is_array($value)){ + return '附件格式错误'; + } + } + return true; + } + + public function checkBankAccount($value): bool|string + { + $data = BankAccount::where('id',$value)->findOrEmpty(); + if($data->isEmpty()){ + return '付款银行账户信息不存在'; + } + return true; + } + +} \ No newline at end of file diff --git a/app/common/model/project/ProjectLoanApply.php b/app/common/model/project/ProjectLoanApply.php new file mode 100644 index 000000000..1f28f008d --- /dev/null +++ b/app/common/model/project/ProjectLoanApply.php @@ -0,0 +1,41 @@ +