From 02b24964bf0e702679cdfd0512dc094b5a3d79c8 Mon Sep 17 00:00:00 2001 From: weiz <736250432@qq.com> Date: Sat, 16 Mar 2024 13:36:02 +0800 Subject: [PATCH] =?UTF-8?q?=E6=96=B0=E5=A2=9E=E9=80=A0=E4=BB=B7=E5=92=A8?= =?UTF-8?q?=E8=AF=A2-=E9=A1=B9=E7=9B=AE=E8=B4=A2=E5=8A=A1=E6=A8=A1?= =?UTF-8?q?=E5=9D=97?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../zjzx_finance/ZjzxInvoiceController.php | 93 ++++++++++++ .../zjzx_finance/ZjzxRefundController.php | 93 ++++++++++++ .../zjzx_finance/ZjzxSettlementController.php | 108 ++++++++++++++ .../lists/zjzx_finance/ZjzxInvoiceLists.php | 82 +++++++++++ .../lists/zjzx_finance/ZjzxRefundLists.php | 79 ++++++++++ .../zjzx_finance/ZjzxSettlementLists.php | 81 +++++++++++ .../logic/zjzx_finance/ZjzxInvoiceLogic.php | 137 ++++++++++++++++++ .../logic/zjzx_finance/ZjzxRefundLogic.php | 122 ++++++++++++++++ .../zjzx_finance/ZjzxSettlementLogic.php | 116 +++++++++++++++ .../CostApprovedProjectValidate.php | 10 ++ .../zjzx_finance/ZjzxInvoiceValidate.php | 125 ++++++++++++++++ .../zjzx_finance/ZjzxRefundValidate.php | 114 +++++++++++++++ .../zjzx_finance/ZjzxSettlementValidate.php | 102 +++++++++++++ .../cost_project/CostApprovedProject.php | 4 + app/common/model/zjzx_finance/ZjzxInvoice.php | 24 +++ app/common/model/zjzx_finance/ZjzxRefund.php | 23 +++ .../model/zjzx_finance/ZjzxSettlement.php | 23 +++ 17 files changed, 1336 insertions(+) create mode 100644 app/adminapi/controller/zjzx_finance/ZjzxInvoiceController.php create mode 100644 app/adminapi/controller/zjzx_finance/ZjzxRefundController.php create mode 100644 app/adminapi/controller/zjzx_finance/ZjzxSettlementController.php create mode 100644 app/adminapi/lists/zjzx_finance/ZjzxInvoiceLists.php create mode 100644 app/adminapi/lists/zjzx_finance/ZjzxRefundLists.php create mode 100644 app/adminapi/lists/zjzx_finance/ZjzxSettlementLists.php create mode 100644 app/adminapi/logic/zjzx_finance/ZjzxInvoiceLogic.php create mode 100644 app/adminapi/logic/zjzx_finance/ZjzxRefundLogic.php create mode 100644 app/adminapi/logic/zjzx_finance/ZjzxSettlementLogic.php create mode 100644 app/adminapi/validate/zjzx_finance/ZjzxInvoiceValidate.php create mode 100644 app/adminapi/validate/zjzx_finance/ZjzxRefundValidate.php create mode 100644 app/adminapi/validate/zjzx_finance/ZjzxSettlementValidate.php create mode 100644 app/common/model/zjzx_finance/ZjzxInvoice.php create mode 100644 app/common/model/zjzx_finance/ZjzxRefund.php create mode 100644 app/common/model/zjzx_finance/ZjzxSettlement.php diff --git a/app/adminapi/controller/zjzx_finance/ZjzxInvoiceController.php b/app/adminapi/controller/zjzx_finance/ZjzxInvoiceController.php new file mode 100644 index 000000000..e73582413 --- /dev/null +++ b/app/adminapi/controller/zjzx_finance/ZjzxInvoiceController.php @@ -0,0 +1,93 @@ +dataLists(new ZjzxInvoiceLists()); + } + + + /** + * @notes 添加造价咨询--开票台账 + * @return \think\response\Json + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function add() + { + $params = (new ZjzxInvoiceValidate())->post()->goCheck('add'); + $result = ZjzxInvoiceLogic::add($params); + if (true === $result) { + return $this->success('添加成功', [], 1, 1); + } + return $this->fail(ZjzxInvoiceLogic::getError()); + } + + + /** + * @notes 编辑造价咨询--开票台账 + * @return \think\response\Json + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function edit() + { + $params = (new ZjzxInvoiceValidate())->post()->goCheck('edit'); + $result = ZjzxInvoiceLogic::edit($params); + if (true === $result) { + return $this->success('编辑成功', [], 1, 1); + } + return $this->fail(ZjzxInvoiceLogic::getError()); + } + + + /** + * @notes 删除造价咨询--开票台账 + * @return \think\response\Json + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function delete() + { + $params = (new ZjzxInvoiceValidate())->post()->goCheck('delete'); + ZjzxInvoiceLogic::delete($params); + return $this->success('删除成功', [], 1, 1); + } + + + /** + * @notes 获取造价咨询--开票台账详情 + * @return \think\response\Json + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function detail() + { + $params = (new ZjzxInvoiceValidate())->goCheck('detail'); + $result = ZjzxInvoiceLogic::detail($params); + return $this->data($result); + } + + +} \ No newline at end of file diff --git a/app/adminapi/controller/zjzx_finance/ZjzxRefundController.php b/app/adminapi/controller/zjzx_finance/ZjzxRefundController.php new file mode 100644 index 000000000..f102592bb --- /dev/null +++ b/app/adminapi/controller/zjzx_finance/ZjzxRefundController.php @@ -0,0 +1,93 @@ +dataLists(new ZjzxRefundLists()); + } + + + /** + * @notes 添加造价咨询--到账台账 + * @return \think\response\Json + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function add() + { + $params = (new ZjzxRefundValidate())->post()->goCheck('add'); + $result = ZjzxRefundLogic::add($params); + if (true === $result) { + return $this->success('添加成功', [], 1, 1); + } + return $this->fail(ZjzxRefundLogic::getError()); + } + + + /** + * @notes 编辑造价咨询--到账台账 + * @return \think\response\Json + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function edit() + { + $params = (new ZjzxRefundValidate())->post()->goCheck('edit'); + $result = ZjzxRefundLogic::edit($params); + if (true === $result) { + return $this->success('编辑成功', [], 1, 1); + } + return $this->fail(ZjzxRefundLogic::getError()); + } + + + /** + * @notes 删除造价咨询--到账台账 + * @return \think\response\Json + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function delete() + { + $params = (new ZjzxRefundValidate())->post()->goCheck('delete'); + ZjzxRefundLogic::delete($params); + return $this->success('删除成功', [], 1, 1); + } + + + /** + * @notes 获取造价咨询--到账台账详情 + * @return \think\response\Json + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function detail() + { + $params = (new ZjzxRefundValidate())->goCheck('detail'); + $result = ZjzxRefundLogic::detail($params); + return $this->data($result); + } + + +} \ No newline at end of file diff --git a/app/adminapi/controller/zjzx_finance/ZjzxSettlementController.php b/app/adminapi/controller/zjzx_finance/ZjzxSettlementController.php new file mode 100644 index 000000000..62e735935 --- /dev/null +++ b/app/adminapi/controller/zjzx_finance/ZjzxSettlementController.php @@ -0,0 +1,108 @@ +dataLists(new ZjzxSettlementLists()); + } + + + /** + * @notes 添加造价咨询--项目结算 + * @return \think\response\Json + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function add() + { + $params = (new ZjzxSettlementValidate())->post()->goCheck('add'); + $result = ZjzxSettlementLogic::add($params); + if (true === $result) { + return $this->success('添加成功', [], 1, 1); + } + return $this->fail(ZjzxSettlementLogic::getError()); + } + + + /** + * @notes 编辑造价咨询--项目结算 + * @return \think\response\Json + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function edit() + { + $params = (new ZjzxSettlementValidate())->post()->goCheck('edit'); + $result = ZjzxSettlementLogic::edit($params); + if (true === $result) { + return $this->success('编辑成功', [], 1, 1); + } + return $this->fail(ZjzxSettlementLogic::getError()); + } + + + /** + * @notes 删除造价咨询--项目结算 + * @return \think\response\Json + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function delete() + { + $params = (new ZjzxSettlementValidate())->post()->goCheck('delete'); + ZjzxSettlementLogic::delete($params); + return $this->success('删除成功', [], 1, 1); + } + + + /** + * @notes 获取造价咨询--项目结算详情 + * @return \think\response\Json + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function detail() + { + $params = (new ZjzxSettlementValidate())->goCheck('detail'); + $result = ZjzxSettlementLogic::detail($params); + return $this->data($result); + } + + +} \ No newline at end of file diff --git a/app/adminapi/lists/zjzx_finance/ZjzxInvoiceLists.php b/app/adminapi/lists/zjzx_finance/ZjzxInvoiceLists.php new file mode 100644 index 000000000..642195518 --- /dev/null +++ b/app/adminapi/lists/zjzx_finance/ZjzxInvoiceLists.php @@ -0,0 +1,82 @@ + ['project_id', 'invoice_type'], + '%like%' => ['invoice_code', 'apply_company'], + ]; + } + + + /** + * @notes 获取造价咨询--开票台账列表 + * @return array + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\DbException + * @throws \think\db\exception\ModelNotFoundException + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function lists(): array + { + return ZjzxInvoice::where($this->searchWhere) + ->field(['id', 'project_id', 'invoice_code', 'invoice_type', 'apply_amount', 'create_user', 'create_time']) + ->limit($this->limitOffset, $this->limitLength) + ->order(['id' => 'desc']) + ->select()->each(function($data){ + $project = CostProject::field('project_num,project_name,contract_id')->where('id',$data['project_id'])->findOrEmpty(); + $contract = CostApprovedProject::field('contract_name,contract_type,part_a,part_b,money,create_time')->where('id',$project['contract_id'])->findOrEmpty(); + $data['project_num'] = $project['project_num']; + $data['project_name'] = $project['project_name']; + $data['contract_name'] = $contract['contract_name']; + $data['contract_type'] = $contract->contract_type_text; + $data['part_a'] = $contract['part_a']; + $data['part_b'] = $contract['part_b']; + $data['sign_money'] = $contract['money']; + $data['sign_time'] = $contract['create_time']; + $data['invoice_type_text'] = $data->invoice_type_text; + $refund = ZjzxRefund::where('invoice_id',$data['id'])->findOrEmpty(); + $data['is_refund'] = !$refund->isEmpty() ? '已到账' : '未到账'; + $data['refund_amount'] = !$refund->isEmpty() ? ZjzxRefund::where('invoice_id',$data['id'])->sum('amount') : 0.00; + }) + ->toArray(); + } + + + /** + * @notes 获取造价咨询--开票台账数量 + * @return int + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function count(): int + { + return ZjzxInvoice::where($this->searchWhere)->count(); + } + +} \ No newline at end of file diff --git a/app/adminapi/lists/zjzx_finance/ZjzxRefundLists.php b/app/adminapi/lists/zjzx_finance/ZjzxRefundLists.php new file mode 100644 index 000000000..12750bde7 --- /dev/null +++ b/app/adminapi/lists/zjzx_finance/ZjzxRefundLists.php @@ -0,0 +1,79 @@ + ['project_id', 'invoice_id'], + '%like%' => ['create_user'], + ]; + } + + + /** + * @notes 获取造价咨询--到账台账列表 + * @return array + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\DbException + * @throws \think\db\exception\ModelNotFoundException + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function lists(): array + { + return ZjzxRefund::where($this->searchWhere) + ->field(['id', 'project_id', 'invoice_id', 'amount', 'date']) + ->limit($this->limitOffset, $this->limitLength) + ->order(['id' => 'desc']) + ->select()->each(function($data){ + $project = CostProject::field('project_num,project_name,contract_id')->where('id',$data['project_id'])->findOrEmpty(); + $contract = CostApprovedProject::field('contract_name,contract_type,part_a,part_b')->where('id',$project['contract_id'])->findOrEmpty(); + $invoice = ZjzxInvoice::field('invoice_code,apply_amount')->where('id',$data['invoice_id'])->findOrEmpty(); + $data['project_num'] = $project['project_num']; + $data['project_name'] = $project['project_name']; + $data['contract_name'] = $contract['contract_name']; + $data['contract_type'] = $contract->contract_type_text; + $data['part_a'] = $contract['part_a']; + $data['part_b'] = $contract['part_b']; + $data['invoice_code'] = $invoice['invoice_code']; + $data['apply_amount'] = $invoice['apply_amount']; + }) + ->toArray(); + } + + + /** + * @notes 获取造价咨询--到账台账数量 + * @return int + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function count(): int + { + return ZjzxRefund::where($this->searchWhere)->count(); + } + +} \ No newline at end of file diff --git a/app/adminapi/lists/zjzx_finance/ZjzxSettlementLists.php b/app/adminapi/lists/zjzx_finance/ZjzxSettlementLists.php new file mode 100644 index 000000000..364a58bd7 --- /dev/null +++ b/app/adminapi/lists/zjzx_finance/ZjzxSettlementLists.php @@ -0,0 +1,81 @@ + ['project_id', 'date'], + ]; + } + + + /** + * @notes 获取造价咨询--项目结算列表 + * @return array + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\DbException + * @throws \think\db\exception\ModelNotFoundException + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function lists(): array + { + return ZjzxSettlement::where($this->searchWhere) + ->field(['id', 'project_id', 'amount', 'date']) + ->limit($this->limitOffset, $this->limitLength) + ->order(['id' => 'desc']) + ->select()->each(function($data){ + $project = CostProject::field('project_num,project_name,contract_id')->where('id',$data['project_id'])->findOrEmpty(); + $contract = CostApprovedProject::field('contract_name,contract_type,part_a,part_b,money,create_time')->where('id',$project['contract_id'])->findOrEmpty(); + $data['invoice_type_text'] = $data->invoice_type_text; + $data['project_num'] = $project['project_num']; + $data['project_name'] = $project['project_name']; + $data['contract_name'] = $contract['contract_name']; + $data['contract_type'] = $contract->contract_type_text; + $data['part_a'] = $contract['part_a']; + $data['part_b'] = $contract['part_b']; + $data['sign_money'] = $contract['money']; + $data['sign_time'] = $contract['create_time']; + $data['total_invoice_amount'] = ZjzxInvoice::where('project_id',$data['project_id'])->sum('apply_amount'); + $data['total_refund_amount'] = ZjzxRefund::where('project_id',$data['project_id'])->sum('amount'); + }) + ->toArray(); + } + + + /** + * @notes 获取造价咨询--项目结算数量 + * @return int + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function count(): int + { + return ZjzxSettlement::where($this->searchWhere)->count(); + } + +} \ No newline at end of file diff --git a/app/adminapi/logic/zjzx_finance/ZjzxInvoiceLogic.php b/app/adminapi/logic/zjzx_finance/ZjzxInvoiceLogic.php new file mode 100644 index 000000000..76ef1afa7 --- /dev/null +++ b/app/adminapi/logic/zjzx_finance/ZjzxInvoiceLogic.php @@ -0,0 +1,137 @@ + $params['project_id'], + 'invoice_code' => data_unique_code('XMKP'), + 'invoice_type' => $params['invoice_type'], + 'apply_amount' => $params['apply_amount'], + 'apply_company' => $params['apply_company'], + 'apply_company_number' => $params['apply_company_number'], + 'apply_company_address' => $params['apply_company_address'] ?? '', + 'apply_company_telephone' => $params['apply_company_telephone'] ?? '', + 'apply_company_bank' => $params['apply_company_bank'] ?? '', + 'apply_company_account' => $params['apply_company_account'] ?? '', + 'apply_contact' => $params['apply_contact'] ?? '', + 'apply_email' => $params['apply_email'] ?? '', + 'pay_type' => $params['pay_type'] ?? '', + 'invoice_content' => $params['invoice_content'] ?? '', + 'create_user' => $params['create_user'], + 'create_time' => !empty($params['create_time']) ? strtotime($params['create_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/03/15 17:05 + */ + public static function edit(array $params): bool + { + Db::startTrans(); + try { + ZjzxInvoice::where('id', $params['id'])->update([ + 'project_id' => $params['project_id'], + 'invoice_type' => $params['invoice_type'], + 'apply_amount' => $params['apply_amount'], + 'apply_company' => $params['apply_company'], + 'apply_company_number' => $params['apply_company_number'], + 'apply_company_address' => $params['apply_company_address'] ?? '', + 'apply_company_telephone' => $params['apply_company_telephone'] ?? '', + 'apply_company_bank' => $params['apply_company_bank'] ?? '', + 'apply_company_account' => $params['apply_company_account'] ?? '', + 'apply_contact' => $params['apply_contact'] ?? '', + 'apply_email' => $params['apply_email'] ?? '', + 'pay_type' => $params['pay_type'] ?? '', + 'invoice_content' => $params['invoice_content'] ?? '', + 'create_user' => $params['create_user'], + 'create_time' => !empty($params['create_time']) ? strtotime($params['create_time']) : time(), + '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/03/15 17:05 + */ + public static function delete(array $params): bool + { + return ZjzxInvoice::destroy($params['id']); + } + + + /** + * @notes 获取造价咨询--开票台账详情 + * @param $params + * @return array + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public static function detail($params): array + { + $data = ZjzxInvoice::withoutField('update_time,delete_time')->findOrEmpty($params['id']); + $project = CostProject::field('project_num,project_name,contract_id')->where('id',$data['project_id'])->findOrEmpty(); + $contract = CostApprovedProject::field('contract_name,contract_type,part_a,part_b,money,create_time')->where('id',$project['contract_id'])->findOrEmpty(); + $data['invoice_type_text'] = $data->invoice_type_text; + $data['project_num'] = $project['project_num']; + $data['project_name'] = $project['project_name']; + $data['contract_name'] = $contract['contract_name']; + $data['contract_type'] = $contract->contract_type_text; + $data['part_a'] = $contract['part_a']; + $data['part_b'] = $contract['part_b']; + $data['sign_money'] = $contract['money']; + $data['sign_time'] = $contract['create_time']; + $data['total_invoice_amount'] = ZjzxInvoice::where('project_id',$data['project_id'])->sum('apply_amount'); + $data['total_refund_amount'] = ZjzxRefund::where('project_id',$data['project_id'])->sum('amount'); + return $data->toArray(); + } +} \ No newline at end of file diff --git a/app/adminapi/logic/zjzx_finance/ZjzxRefundLogic.php b/app/adminapi/logic/zjzx_finance/ZjzxRefundLogic.php new file mode 100644 index 000000000..78ba9be68 --- /dev/null +++ b/app/adminapi/logic/zjzx_finance/ZjzxRefundLogic.php @@ -0,0 +1,122 @@ + $params['project_id'], + 'invoice_id' => $params['invoice_id'], + 'amount' => $params['amount'], + 'date' => !empty($params['date']) ? strtotime($params['date']) : 0, + 'remark' => $params['remark'] ?? '', + 'create_user' => $params['create_user'], + 'create_time' => !empty($params['create_time']) ? strtotime($params['create_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/03/15 17:05 + */ + public static function edit(array $params): bool + { + Db::startTrans(); + try { + ZjzxRefund::where('id', $params['id'])->update([ + 'project_id' => $params['project_id'], + 'invoice_id' => $params['invoice_id'], + 'amount' => $params['amount'], + 'date' => !empty($params['date']) ? strtotime($params['date']) : 0, + 'remark' => $params['remark'] ?? '', + 'create_user' => $params['create_user'], + 'create_time' => !empty($params['create_time']) ? strtotime($params['create_time']) : time(), + '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/03/15 17:05 + */ + public static function delete(array $params): bool + { + return ZjzxRefund::destroy($params['id']); + } + + + /** + * @notes 获取造价咨询--到账台账详情 + * @param $params + * @return array + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public static function detail($params): array + { + $data = ZjzxRefund::withoutField('update_time,delete_time')->findOrEmpty($params['id']); + $project = CostProject::field('project_num,project_name,contract_id')->where('id',$data['project_id'])->findOrEmpty(); + $contract = CostApprovedProject::field('contract_name,contract_type,part_a,part_b,money,create_time')->where('id',$project['contract_id'])->findOrEmpty(); + $invoice = ZjzxInvoice::field('invoice_code,apply_amount')->where('id',$data['invoice_id'])->findOrEmpty(); + $data['project_num'] = $project['project_num']; + $data['project_name'] = $project['project_name']; + $data['contract_name'] = $contract['contract_name']; + $data['contract_type'] = $contract->contract_type_text; + $data['part_a'] = $contract['part_a']; + $data['part_b'] = $contract['part_b']; + $data['sign_money'] = $contract['money']; + $data['sign_time'] = $contract['create_time']; + $data['invoice_code'] = $invoice['invoice_code']; + $data['apply_amount'] = $invoice['apply_amount']; + $data['total_invoice_amount'] = ZjzxInvoice::where('project_id',$data['project_id'])->sum('apply_amount');//累计开票金额 + $data['total_refund_amount'] = ZjzxRefund::where('project_id',$data['project_id'])->sum('amount');//累计到账金额 + return $data->toArray(); + } +} \ No newline at end of file diff --git a/app/adminapi/logic/zjzx_finance/ZjzxSettlementLogic.php b/app/adminapi/logic/zjzx_finance/ZjzxSettlementLogic.php new file mode 100644 index 000000000..863a8161d --- /dev/null +++ b/app/adminapi/logic/zjzx_finance/ZjzxSettlementLogic.php @@ -0,0 +1,116 @@ + $params['project_id'], + 'amount' => $params['amount'], + 'date' => !empty($params['date']) ? strtotime($params['date']) : 0, + 'remark' => $params['remark'] ?? '', + 'annex' => $params['annex'] ? json_encode($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 2024/03/15 17:05 + */ + public static function edit(array $params): bool + { + Db::startTrans(); + try { + ZjzxSettlement::where('id', $params['id'])->update([ + 'project_id' => $params['project_id'], + 'amount' => $params['amount'], + 'date' => !empty($params['date']) ? strtotime($params['date']) : 0, + 'remark' => $params['remark'] ?? '', + 'annex' => $params['annex'] ? json_encode($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 2024/03/15 17:05 + */ + public static function delete(array $params): bool + { + return ZjzxSettlement::destroy($params['id']); + } + + + /** + * @notes 获取造价咨询--项目结算详情 + * @param $params + * @return array + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public static function detail($params): array + { + $data = ZjzxSettlement::withoutField('create_time,update_time,delete_time')->findOrEmpty($params['id']); + $project = CostProject::field('project_num,project_name,contract_id')->where('id',$data['project_id'])->findOrEmpty(); + $contract = CostApprovedProject::field('contract_name,contract_type,part_a,part_b,money,create_time')->where('id',$project['contract_id'])->findOrEmpty(); + $data['invoice_type_text'] = $data->invoice_type_text; + $data['project_num'] = $project['project_num']; + $data['project_name'] = $project['project_name']; + $data['contract_name'] = $contract['contract_name']; + $data['contract_type'] = $contract->contract_type_text; + $data['part_a'] = $contract['part_a']; + $data['part_b'] = $contract['part_b']; + $data['sign_money'] = $contract['money']; + $data['sign_time'] = $contract['create_time']; + $data['total_invoice_amount'] = ZjzxInvoice::where('project_id',$data['project_id'])->sum('apply_amount'); + $data['total_refund_amount'] = ZjzxRefund::where('project_id',$data['project_id'])->sum('amount'); + return $data->toArray(); + } +} \ No newline at end of file diff --git a/app/adminapi/validate/cost_project/CostApprovedProjectValidate.php b/app/adminapi/validate/cost_project/CostApprovedProjectValidate.php index d74cd3248..f8444d4e5 100644 --- a/app/adminapi/validate/cost_project/CostApprovedProjectValidate.php +++ b/app/adminapi/validate/cost_project/CostApprovedProjectValidate.php @@ -35,6 +35,7 @@ class CostApprovedProjectValidate extends BaseValidate protected $rule = [ 'id' => 'require|checkData', 'contract_name' => 'require', + 'contract_type' => 'require|checkContractType', 'part_a' => 'require', 'part_b' => 'require', 'business_nature' => 'checkBusinessNature', @@ -70,6 +71,7 @@ class CostApprovedProjectValidate extends BaseValidate protected $field = [ 'id' => 'id', 'contract_name' => '合同名称', + 'contract_type' => '合同类型', 'part_a' => '甲方签约单位', 'part_b' => '乙方签约单位', 'business_nature' => '业务性质', @@ -151,6 +153,14 @@ class CostApprovedProjectValidate extends BaseValidate return true; } + public function checkContractType($value){ + $dict = DictData::where('type_value','cost_contract_type')->column('value'); + if(!in_array($value,$dict)){ + return '合同类型数据值无效'; + } + return true; + } + public function checkBusinessNature($value): bool|string { $dict = DictData::where('type_value','cost_consultation_business_nature')->column('value'); diff --git a/app/adminapi/validate/zjzx_finance/ZjzxInvoiceValidate.php b/app/adminapi/validate/zjzx_finance/ZjzxInvoiceValidate.php new file mode 100644 index 000000000..f357f677f --- /dev/null +++ b/app/adminapi/validate/zjzx_finance/ZjzxInvoiceValidate.php @@ -0,0 +1,125 @@ + 'require|checkData', + 'project_id' => 'require|checkProject', + 'invoice_type' => 'require|checkInvoiceType', + 'apply_amount' => 'require|float|gt:0', + 'apply_company' => 'require', + 'apply_company_number' => 'require', + 'apply_email' => 'email', + 'create_user' => 'require', + 'create_time' => 'require|dateFormat:Y-m-d H:i:s' + ]; + + + /** + * 参数描述 + * @var string[] + */ + protected $field = [ + 'id' => 'id', + 'project_id' => '项目id', + 'invoice_code' => '开票编号', + 'invoice_type' => '发票类型', + 'apply_amount' => '开票申请金额', + 'apply_company' => '开票单位名称', + 'apply_company_number' => '纳税人识别号', + 'apply_company_address' => '开票单位注册地址', + 'apply_company_telephone' => '开票单位电话', + 'apply_company_bank' => '开户银行', + 'apply_company_account' => '开户账号', + 'apply_contact' => '开票联系人', + 'pay_type' => '对应付款方式', + 'invoice_content' => '开票内容', + 'apply_email' => '发票接收邮箱', + 'create_user' => '开票申请人', + 'create_time' => '开票申请时间' + ]; + + + /** + * @notes 添加场景 + * @return ZjzxInvoiceValidate + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function sceneAdd() + { + return $this->remove('id',true); + } + + + /** + * @notes 编辑场景 + * @return ZjzxInvoiceValidate + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function sceneEdit() + { + return $this->remove('id','checkData'); + } + + + /** + * @notes 删除场景 + * @return ZjzxInvoiceValidate + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function sceneDelete() + { + return $this->only(['id']); + } + + + /** + * @notes 详情场景 + * @return ZjzxInvoiceValidate + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function sceneDetail() + { + return $this->only(['id']); + } + + public function checkData($value): bool|string + { + $data = ZjzxInvoice::where('id',$value)->findOrEmpty(); + return $data->isEmpty() ? '数据不存在' : true; + } + + public function checkProject($value): bool|string + { + $data = CostProject::where('id',$value)->findOrEmpty(); + return $data->isEmpty() ? '项目信息不存在' : true; + } + + public function checkInvoiceType($value): bool|string + { + $dict = DictData::where('type_value','zjzx_invoice_type')->column('value'); + return !in_array($value,$dict) ? '发票类型数据值无效' : true; + } + +} \ No newline at end of file diff --git a/app/adminapi/validate/zjzx_finance/ZjzxRefundValidate.php b/app/adminapi/validate/zjzx_finance/ZjzxRefundValidate.php new file mode 100644 index 000000000..5ee0def63 --- /dev/null +++ b/app/adminapi/validate/zjzx_finance/ZjzxRefundValidate.php @@ -0,0 +1,114 @@ + 'require|checkData', + 'project_id' => 'require|checkProject', + 'invoice_id' => 'require|checkInvoice', + 'amount' => 'require|float|gt:0', + 'date' => 'require|dateFormat:Y-m-d', + 'create_user' => 'require', + 'create_time' => 'require|dateFormat:Y-m-d H:i:s', + ]; + + + /** + * 参数描述 + * @var string[] + */ + protected $field = [ + 'id' => 'id', + 'project_id' => '项目id', + 'invoice_id' => '开票id', + 'amount' => '本次到账金额', + 'date' => '到账日期', + 'remark' => '说明', + 'create_user' => '登记人', + 'create_time' => '登记时间', + ]; + + + /** + * @notes 添加场景 + * @return ZjzxRefundValidate + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function sceneAdd() + { + return $this->remove('id',true); + } + + + /** + * @notes 编辑场景 + * @return ZjzxRefundValidate + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function sceneEdit() + { + return $this->only(['id','project_id','invoice_id','amount','date','remark','create_user','create_time']); + } + + + /** + * @notes 删除场景 + * @return ZjzxRefundValidate + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function sceneDelete() + { + return $this->only(['id'])->remove('id','checkData'); + } + + + /** + * @notes 详情场景 + * @return ZjzxRefundValidate + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function sceneDetail() + { + return $this->only(['id']); + } + + public function checkData($value): bool|string + { + $data = ZjzxRefund::where('id',$value)->findOrEmpty(); + return $data->isEmpty() ? '数据不存在' : true; + } + + public function checkProject($value): bool|string + { + $data = CostProject::where('id',$value)->findOrEmpty(); + return $data->isEmpty() ? '项目信息不存在' : true; + } + + public function checkInvoice($value,$rule,$params): bool|string + { + $data = ZjzxInvoice::where('id',$value)->where('project_id',$params['project_id'])->findOrEmpty(); + return $data->isEmpty() ? '开票单据信息不存在' : true; + } + +} \ No newline at end of file diff --git a/app/adminapi/validate/zjzx_finance/ZjzxSettlementValidate.php b/app/adminapi/validate/zjzx_finance/ZjzxSettlementValidate.php new file mode 100644 index 000000000..ceb158862 --- /dev/null +++ b/app/adminapi/validate/zjzx_finance/ZjzxSettlementValidate.php @@ -0,0 +1,102 @@ + 'require|checkData', + 'project_id' => 'require|checkProject', + 'amount' => 'require', + 'date' => 'require', + 'annex' => 'checkAnnex' + ]; + + + /** + * 参数描述 + * @var string[] + */ + protected $field = [ + 'id' => 'id', + 'project_id' => '项目id', + 'amount' => '结算金额', + 'date' => '结算日期', + 'remark' => '结算备注', + ]; + + + /** + * @notes 添加场景 + * @return ZjzxSettlementValidate + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function sceneAdd() + { + return $this->only(['project_id','amount','date','remark','annex']); + } + + + /** + * @notes 编辑场景 + * @return ZjzxSettlementValidate + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function sceneEdit() + { + return $this->only(['id','project_id','amount','date','remark','annex']); + } + + + /** + * @notes 删除场景 + * @return ZjzxSettlementValidate + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function sceneDelete() + { + return $this->only(['id'])->remove('id','checkData'); + } + + + /** + * @notes 详情场景 + * @return ZjzxSettlementValidate + * @author likeadmin + * @date 2024/03/15 17:05 + */ + public function sceneDetail() + { + return $this->only(['id']); + } + + public function checkData($value): bool|string + { + $data = ZjzxSettlement::where('id',$value)->findOrEmpty(); + return $data->isEmpty() ? '数据不存在' : true; + } + + public function checkProject($value): bool|string + { + $data = CostProject::where('id',$value)->findOrEmpty(); + return $data->isEmpty() ? '项目信息不存在' : true; + } + +} \ No newline at end of file diff --git a/app/common/model/cost_project/CostApprovedProject.php b/app/common/model/cost_project/CostApprovedProject.php index 0d93faad2..cdeee3f03 100644 --- a/app/common/model/cost_project/CostApprovedProject.php +++ b/app/common/model/cost_project/CostApprovedProject.php @@ -31,6 +31,10 @@ class CostApprovedProject extends BaseModel protected $name = 'cost_approved_project'; protected $deleteTime = 'delete_time'; + public function getContractTypeTextAttr($value,$data){ + $dict = DictData::where('type_value','cost_contract_type')->column('name','value'); + return !empty($data['contract_type']) ? $dict[$data['contract_type']] : ''; + } public function getBusinessNatureTextAttr($value,$data){ $dict = DictData::where('type_value','cost_consultation_business_nature')->column('name','value'); return !empty($data['business_nature']) ? $dict[$data['business_nature']] : ''; diff --git a/app/common/model/zjzx_finance/ZjzxInvoice.php b/app/common/model/zjzx_finance/ZjzxInvoice.php new file mode 100644 index 000000000..2a031c641 --- /dev/null +++ b/app/common/model/zjzx_finance/ZjzxInvoice.php @@ -0,0 +1,24 @@ +column('name','value'); + return !empty($data['invoice_type']) ? $dict[$data['invoice_type']] : ''; + } +} \ No newline at end of file diff --git a/app/common/model/zjzx_finance/ZjzxRefund.php b/app/common/model/zjzx_finance/ZjzxRefund.php new file mode 100644 index 000000000..2293435ab --- /dev/null +++ b/app/common/model/zjzx_finance/ZjzxRefund.php @@ -0,0 +1,23 @@ +