diff --git a/app/adminapi/controller/finance/FinanceRefundRecordController.php b/app/adminapi/controller/finance/FinanceRefundRecordController.php new file mode 100644 index 000000000..f63fb2548 --- /dev/null +++ b/app/adminapi/controller/finance/FinanceRefundRecordController.php @@ -0,0 +1,108 @@ +dataLists(new FinanceRefundRecordLists()); + } + + + /** + * @notes 添加 + * @return \think\response\Json + * @author likeadmin + * @date 2023/12/15 14:41 + */ + public function add() + { + $params = (new FinanceRefundRecordValidate())->post()->goCheck('add'); + $result = FinanceRefundRecordLogic::add($params); + if (true === $result) { + return $this->success('添加成功', [], 1, 1); + } + return $this->fail(FinanceRefundRecordLogic::getError()); + } + + + /** + * @notes 编辑 + * @return \think\response\Json + * @author likeadmin + * @date 2023/12/15 14:41 + */ + public function edit() + { + $params = (new FinanceRefundRecordValidate())->post()->goCheck('edit'); + $result = FinanceRefundRecordLogic::edit($params); + if (true === $result) { + return $this->success('编辑成功', [], 1, 1); + } + return $this->fail(FinanceRefundRecordLogic::getError()); + } + + + /** + * @notes 删除 + * @return \think\response\Json + * @author likeadmin + * @date 2023/12/15 14:41 + */ + public function delete() + { + $params = (new FinanceRefundRecordValidate())->post()->goCheck('delete'); + FinanceRefundRecordLogic::delete($params); + return $this->success('删除成功', [], 1, 1); + } + + + /** + * @notes 获取详情 + * @return \think\response\Json + * @author likeadmin + * @date 2023/12/15 14:41 + */ + public function detail() + { + $params = (new FinanceRefundRecordValidate())->goCheck('detail'); + $result = FinanceRefundRecordLogic::detail($params); + return $this->data($result); + } + + +} \ No newline at end of file diff --git a/app/adminapi/lists/finance/FinanceRefundRecordLists.php b/app/adminapi/lists/finance/FinanceRefundRecordLists.php new file mode 100644 index 000000000..614d34b8d --- /dev/null +++ b/app/adminapi/lists/finance/FinanceRefundRecordLists.php @@ -0,0 +1,86 @@ + ['frr.supplier_id', 'frr.contract_id'], + ]; + } + + + /** + * @notes 获取列表 + * @return array + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\DbException + * @throws \think\db\exception\ModelNotFoundException + * @author likeadmin + * @date 2023/12/15 14:41 + */ + public function lists(): array + { + return Db::name('FinanceRefundRecord')->alias('frr') + ->where($this->searchWhere) + ->leftJoin('procurement_contract pc','pc.id = frr.contract_id') + ->leftJoin('project p','p.id = pc.project_id') + ->field('frr.*, p.id as project_id, p.name as project_name, pc.contract_no') + ->limit($this->limitOffset, $this->limitLength) + ->order(['frr.id' => 'desc']) + ->select()->each(function($item, $key){ + //关联数据 供应商后续添加 + $item['supplier_name'] = '供应商名称'; + $item['supplier_no'] = '供应编号'; + $item['contract_type'] = '1'; + return $item; + }) + ->toArray(); + } + + + /** + * @notes 获取数量 + * @return int + * @author likeadmin + * @date 2023/12/15 14:41 + */ + public function count(): int + { + return FinanceRefundRecord::where($this->searchWhere)->count(); + } + +} \ No newline at end of file diff --git a/app/adminapi/logic/finance/FinanceRefundRecordLogic.php b/app/adminapi/logic/finance/FinanceRefundRecordLogic.php new file mode 100644 index 000000000..1cba22c16 --- /dev/null +++ b/app/adminapi/logic/finance/FinanceRefundRecordLogic.php @@ -0,0 +1,136 @@ + $params['supplier_id'] ?? 0, + 'contract_id' => $params['contract_id'] ?? 0, + 'refund_amount' => $params['refund_amount'] ?? 0, + 'refund_amount_daxie' => $params['refund_amount_daxie'] ?? '', + 'refund_date' => $params['refund_date'] ?? '', + 'refund_type' => $params['refund_type'] ?? 0, + 'reason' => $params['reason'] ?? '', + 'remark' => $params['remark'] ?? '', + 'annex' => $params['annex'] ?? '', + 'bank_account_id' => $params['bank_account_id'] ?? 0, + 'is_calculate_interest' => $params['is_calculate_interest'] ?? 0, + 'interest_calculation_start_date' => $params['interest_calculation_start_date'] ?? '', + ]); + + 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/15 14:41 + */ + public static function edit(array $params): bool + { + Db::startTrans(); + try { + FinanceRefundRecord::where('id', $params['id'])->update([ + 'supplier_id' => $params['supplier_id'] ?? 0, + 'contract_id' => $params['contract_id'] ?? 0, + 'refund_amount' => $params['refund_amount'] ?? 0, + 'refund_amount_daxie' => $params['refund_amount_daxie'] ?? '', + 'refund_date' => $params['refund_date'] ?? '', + 'refund_type' => $params['refund_type'] ?? 0, + 'reason' => $params['reason'] ?? '', + 'remark' => $params['remark'] ?? '', + 'annex' => $params['annex'] ?? '', + 'bank_account_id' => $params['bank_account_id'] ?? 0, + 'is_calculate_interest' => $params['is_calculate_interest'] ?? 0, + 'interest_calculation_start_date' => $params['interest_calculation_start_date'] ?? '', + ]); + + 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/15 14:41 + */ + public static function delete(array $params): bool + { + return FinanceRefundRecord::destroy($params['id']); + } + + + /** + * @notes 获取详情 + * @param $params + * @return array + * @author likeadmin + * @date 2023/12/15 14:41 + */ + public static function detail($params): array + { + $financeRefundRecord = FinanceRefundRecord::findOrEmpty($params['id']); + $financeRefundRecord->contract; + $financeRefundRecord->supplier = null; + $financeRefundRecord->project = null; + if (!empty($financeRefundRecord->contract->project_id)) { + $financeRefundRecord->project = Project::findOrEmpty($financeRefundRecord->contract->project_id); + } + return $financeRefundRecord->toArray(); + } +} \ No newline at end of file diff --git a/app/adminapi/validate/finance/FinanceRefundRecordValidate.php b/app/adminapi/validate/finance/FinanceRefundRecordValidate.php new file mode 100644 index 000000000..138697761 --- /dev/null +++ b/app/adminapi/validate/finance/FinanceRefundRecordValidate.php @@ -0,0 +1,106 @@ + 'require', + 'supplier_id' => 'require', + 'contract_id' => 'require', + 'refund_amount' => 'require', + 'refund_date' => 'require', + 'refund_type' => 'require', + 'bank_account_id' => 'require', + ]; + + + /** + * 参数描述 + * @var string[] + */ + protected $field = [ + 'id' => 'id', + 'supplier_id' => '供应商id', + 'contract_id' => '合同id', + 'refund_amount' => '退款金额', + 'refund_date' => '退款日期', + 'refund_type' => '退款方式', + 'bank_account_id' => '收款账户id', + ]; + + + /** + * @notes 添加场景 + * @return FinanceRefundRecordValidate + * @author likeadmin + * @date 2023/12/15 14:41 + */ + public function sceneAdd() + { + return $this->only(['supplier_id','contract_id','refund_amount','refund_date','refund_type','bank_account_id']); + } + + + /** + * @notes 编辑场景 + * @return FinanceRefundRecordValidate + * @author likeadmin + * @date 2023/12/15 14:41 + */ + public function sceneEdit() + { + return $this->only(['id','supplier_id','contract_id','refund_amount','refund_date','refund_type','bank_account_id']); + } + + + /** + * @notes 删除场景 + * @return FinanceRefundRecordValidate + * @author likeadmin + * @date 2023/12/15 14:41 + */ + public function sceneDelete() + { + return $this->only(['id']); + } + + + /** + * @notes 详情场景 + * @return FinanceRefundRecordValidate + * @author likeadmin + * @date 2023/12/15 14:41 + */ + public function sceneDetail() + { + return $this->only(['id']); + } + +} \ No newline at end of file diff --git a/app/common/model/finance/FinanceRefundRecord.php b/app/common/model/finance/FinanceRefundRecord.php new file mode 100644 index 000000000..734515a36 --- /dev/null +++ b/app/common/model/finance/FinanceRefundRecord.php @@ -0,0 +1,37 @@ +belongsTo(\app\common\model\contract\ProcurementContract::class, 'contract_id'); + } +} \ No newline at end of file