From d5bf964c212deaaacb789b624ccba46962dd75d2 Mon Sep 17 00:00:00 2001 From: weiz <736250432@qq.com> Date: Sat, 13 Apr 2024 10:55:31 +0800 Subject: [PATCH] update --- .../CostApprovedProjectController.php | 2 +- .../MarketingContractRefluxController.php | 97 +++++++++++++++++++ .../MarketingContractRefluxValidate.php | 69 +++++++++++++ .../model/marketing/MarketingContract.php | 6 ++ .../marketing/MarketingContractReflux.php | 38 ++++++++ 5 files changed, 211 insertions(+), 1 deletion(-) create mode 100644 app/adminapi/controller/marketing/MarketingContractRefluxController.php create mode 100644 app/adminapi/validate/marketing/MarketingContractRefluxValidate.php create mode 100644 app/common/model/marketing/MarketingContractReflux.php diff --git a/app/adminapi/controller/cost_project/CostApprovedProjectController.php b/app/adminapi/controller/cost_project/CostApprovedProjectController.php index d6b03dd6d..c102c8117 100644 --- a/app/adminapi/controller/cost_project/CostApprovedProjectController.php +++ b/app/adminapi/controller/cost_project/CostApprovedProjectController.php @@ -59,7 +59,7 @@ $where[] = ['contract_id', 'in', $contract_ids1]; } if (!empty($params['contract_num'])) { - $contract_ids2 = MarketingContract::where('contract_num', 'like', '%' . $params['contract_num'] . '%')->column('id'); + $contract_ids2 = MarketingContract::where('contract_code', 'like', '%' . $params['contract_num'] . '%')->column('id'); $where[] = ['contract_id', 'in', $contract_ids2]; } if (!empty($params['part_b'])) { diff --git a/app/adminapi/controller/marketing/MarketingContractRefluxController.php b/app/adminapi/controller/marketing/MarketingContractRefluxController.php new file mode 100644 index 000000000..ce9ab5720 --- /dev/null +++ b/app/adminapi/controller/marketing/MarketingContractRefluxController.php @@ -0,0 +1,97 @@ +request->get(); + $where = []; + $page_no = !empty($params['page_no']) ? $params['page_no'] : 1; + $page_size = !empty($params['page_size']) ? $params['page_size'] : 15; + if (!empty($params['contract_name'])) { + $contract_ids1 = MarketingContract::where('contract_name', 'like', '%' . $params['contract_name'] . '%')->column('id'); + $where[] = ['contract_id', 'in', $contract_ids1]; + } + if (!empty($params['contract_num'])) { + $contract_ids2 = MarketingContract::where('contract_code', 'like', '%' . $params['contract_num'] . '%')->column('id'); + $where[] = ['contract_id', 'in', $contract_ids2]; + } + if (!empty($params['part_b'])) { + $contract_ids3 = MarketingContract::where('part_b', 'like', '%' . $params['part_b'] . '%')->column('id'); + $where[] = ['contract_id', 'in', $contract_ids3]; + } + if (!empty($params['contract_type'])) { + $where[] = ['contract_type', '=', $params['contract_type']]; + } + $lists = MarketingContract::field('id,contract_code,contract_name,contract_type,business_nature,part_a,signed_amount,signed_dept,create_time') + ->where($where)->where('reflux_status', 0) + ->page($page_no, $page_size) + ->order('id desc') + ->select() + ->each(function ($data) { + $custom = MarketingCustom::field('name')->where('id', 'part_a')->findOrEmpty(); + $dept = Dept::field('name')->where('id', $data['signed_dept'])->findOrEmpty(); + $data['part_a_name'] = $custom['name']; + $data['signed_dept_name'] = $dept['name']; + $data['contract_type_text'] = $data->contract_type_text; + $data['business_nature_text'] = $data->business_nature_text; + }) + ->toArray(); + $count = MarketingCustom::where($where)->where('status', 1)->count(); + return $this->success('成功', compact('count', 'lists', 'page_no', 'page_size')); + } + + public function reflux(): bool|Json + { + $params = (new MarketingContractRefluxValidate())->post()->goCheck('reflux'); + Db::startTrans(); + try { + MarketingContractReflux::where('id', $params['id'])->update([ + 'contract_id' => $params['contract_id'], + 'reflux_date' => !empty($params['reflux_date']) ? strtotime($params['reflux_date']) : 0, + 'annex' => $params['annex'] ? json_encode($params['annex']) : null, + ]); + MarketingContract::where('id', $params['contract_id'])->update([ + 'reflux_status' => 1 + ]); + Db::commit(); + return true; + } catch (\Exception $e) { + Db::rollback(); + return $this->fail($e->getMessage()); + } + } + + } \ No newline at end of file diff --git a/app/adminapi/validate/marketing/MarketingContractRefluxValidate.php b/app/adminapi/validate/marketing/MarketingContractRefluxValidate.php new file mode 100644 index 000000000..c3ef6f4ee --- /dev/null +++ b/app/adminapi/validate/marketing/MarketingContractRefluxValidate.php @@ -0,0 +1,69 @@ + 'require|checkContract', + 'reflux_date' => 'require|dateFormat:Y-m-d', + 'annex' => 'checkAnnex', + ]; + + + /** + * 参数描述 + * @var string[] + */ + protected $field = [ + 'contract_id' => '关联合同', + 'reflux_date' => '回流日期', + ]; + + + /** + * @notes 添加场景 + * @return MarketingContractRefluxValidate + * @author likeadmin + * @date 2024/04/03 09:19 + */ + public function sceneReflux() + { + return $this->only(['contract_id', 'reflux_date', 'annex']); + } + + + public function checkContract($value): bool|string + { + $data = MarketingContract::where('id', $value)->findOrEmpty(); + return $data->isEmpty() ? '合同数据不存在' : true; + } + + } \ No newline at end of file diff --git a/app/common/model/marketing/MarketingContract.php b/app/common/model/marketing/MarketingContract.php index 8d4767a75..84beb0dc0 100644 --- a/app/common/model/marketing/MarketingContract.php +++ b/app/common/model/marketing/MarketingContract.php @@ -104,6 +104,12 @@ return $arr[$data['review_status']]; } + public function getRefluxStatusTextAttr($value, $data): string + { + $arr = [0 => '未回流', 1 => '已回流']; + return $arr[$data['reflux_status']]; + } + public function getStartDateAttr($value): string { diff --git a/app/common/model/marketing/MarketingContractReflux.php b/app/common/model/marketing/MarketingContractReflux.php new file mode 100644 index 000000000..ff1a0616e --- /dev/null +++ b/app/common/model/marketing/MarketingContractReflux.php @@ -0,0 +1,38 @@ +