From 696ef7c54440a7c193d01c41e2c645bcd03033f7 Mon Sep 17 00:00:00 2001 From: weiz Date: Tue, 16 Jan 2024 11:26:24 +0800 Subject: [PATCH] add project_labor_budget --- .../project/ProjectLaborBudgetController.php | 108 +++++++++++ .../ProjectLaborBudgetDetailController.php | 108 +++++++++++ .../project/ProjectLaborBudgetDetailLists.php | 89 +++++++++ .../lists/project/ProjectLaborBudgetLists.php | 88 +++++++++ .../project/ProjectLaborBudgetDetailLogic.php | 133 +++++++++++++ .../logic/project/ProjectLaborBudgetLogic.php | 167 ++++++++++++++++ .../ProjectLaborBudgetDetailValidate.php | 120 ++++++++++++ .../project/ProjectLaborBudgetValidate.php | 183 ++++++++++++++++++ .../model/project/ProjectLaborBudget.php | 36 ++++ .../project/ProjectLaborBudgetDetail.php | 34 ++++ 10 files changed, 1066 insertions(+) create mode 100644 app/adminapi/controller/project/ProjectLaborBudgetController.php create mode 100644 app/adminapi/controller/project/ProjectLaborBudgetDetailController.php create mode 100644 app/adminapi/lists/project/ProjectLaborBudgetDetailLists.php create mode 100644 app/adminapi/lists/project/ProjectLaborBudgetLists.php create mode 100644 app/adminapi/logic/project/ProjectLaborBudgetDetailLogic.php create mode 100644 app/adminapi/logic/project/ProjectLaborBudgetLogic.php create mode 100644 app/adminapi/validate/project/ProjectLaborBudgetDetailValidate.php create mode 100644 app/adminapi/validate/project/ProjectLaborBudgetValidate.php create mode 100644 app/common/model/project/ProjectLaborBudget.php create mode 100644 app/common/model/project/ProjectLaborBudgetDetail.php diff --git a/app/adminapi/controller/project/ProjectLaborBudgetController.php b/app/adminapi/controller/project/ProjectLaborBudgetController.php new file mode 100644 index 000000000..46ceae196 --- /dev/null +++ b/app/adminapi/controller/project/ProjectLaborBudgetController.php @@ -0,0 +1,108 @@ +dataLists(new ProjectLaborBudgetLists()); + } + + + /** + * @notes 添加人工预算 + * @return \think\response\Json + * @author likeadmin + * @date 2024/01/16 09:26 + */ + public function add() + { + $params = (new ProjectLaborBudgetValidate())->post()->goCheck('add'); + $result = ProjectLaborBudgetLogic::add($params); + if (true === $result) { + return $this->success('添加成功', [], 1, 1); + } + return $this->fail(ProjectLaborBudgetLogic::getError()); + } + + + /** + * @notes 编辑人工预算 + * @return \think\response\Json + * @author likeadmin + * @date 2024/01/16 09:26 + */ + public function edit() + { + $params = (new ProjectLaborBudgetValidate())->post()->goCheck('edit'); + $result = ProjectLaborBudgetLogic::edit($params); + if (true === $result) { + return $this->success('编辑成功', [], 1, 1); + } + return $this->fail(ProjectLaborBudgetLogic::getError()); + } + + + /** + * @notes 删除人工预算 + * @return \think\response\Json + * @author likeadmin + * @date 2024/01/16 09:26 + */ + public function delete() + { + $params = (new ProjectLaborBudgetValidate())->post()->goCheck('delete'); + ProjectLaborBudgetLogic::delete($params); + return $this->success('删除成功', [], 1, 1); + } + + + /** + * @notes 获取人工预算详情 + * @return \think\response\Json + * @author likeadmin + * @date 2024/01/16 09:26 + */ + public function detail() + { + $params = (new ProjectLaborBudgetValidate())->goCheck('detail'); + $result = ProjectLaborBudgetLogic::detail($params); + return $this->data($result); + } + + +} \ No newline at end of file diff --git a/app/adminapi/controller/project/ProjectLaborBudgetDetailController.php b/app/adminapi/controller/project/ProjectLaborBudgetDetailController.php new file mode 100644 index 000000000..e7a1159d5 --- /dev/null +++ b/app/adminapi/controller/project/ProjectLaborBudgetDetailController.php @@ -0,0 +1,108 @@ +dataLists(new ProjectLaborBudgetDetailLists()); + } + + + /** + * @notes 添加人工预算明细 + * @return \think\response\Json + * @author likeadmin + * @date 2024/01/16 09:26 + */ + public function add() + { + $params = (new ProjectLaborBudgetDetailValidate())->post()->goCheck('add'); + $result = ProjectLaborBudgetDetailLogic::add($params); + if (true === $result) { + return $this->success('添加成功', [], 1, 1); + } + return $this->fail(ProjectLaborBudgetDetailLogic::getError()); + } + + + /** + * @notes 编辑人工预算明细 + * @return \think\response\Json + * @author likeadmin + * @date 2024/01/16 09:26 + */ + public function edit() + { + $params = (new ProjectLaborBudgetDetailValidate())->post()->goCheck('edit'); + $result = ProjectLaborBudgetDetailLogic::edit($params); + if (true === $result) { + return $this->success('编辑成功', [], 1, 1); + } + return $this->fail(ProjectLaborBudgetDetailLogic::getError()); + } + + + /** + * @notes 删除人工预算明细 + * @return \think\response\Json + * @author likeadmin + * @date 2024/01/16 09:26 + */ + public function delete() + { + $params = (new ProjectLaborBudgetDetailValidate())->post()->goCheck('delete'); + ProjectLaborBudgetDetailLogic::delete($params); + return $this->success('删除成功', [], 1, 1); + } + + + /** + * @notes 获取人工预算明细详情 + * @return \think\response\Json + * @author likeadmin + * @date 2024/01/16 09:26 + */ + public function detail() + { + $params = (new ProjectLaborBudgetDetailValidate())->goCheck('detail'); + $result = ProjectLaborBudgetDetailLogic::detail($params); + return $this->data($result); + } + + +} \ No newline at end of file diff --git a/app/adminapi/lists/project/ProjectLaborBudgetDetailLists.php b/app/adminapi/lists/project/ProjectLaborBudgetDetailLists.php new file mode 100644 index 000000000..8d04f6494 --- /dev/null +++ b/app/adminapi/lists/project/ProjectLaborBudgetDetailLists.php @@ -0,0 +1,89 @@ + ['project_id', 'labor_budget_id'], + ]; + } + + + /** + * @notes 获取人工预算明细列表 + * @return array + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\DbException + * @throws \think\db\exception\ModelNotFoundException + * @author likeadmin + * @date 2024/01/16 09:26 + */ + public function lists(): array + { + return ProjectLaborBudgetDetail::where($this->searchWhere) + ->field('id,project_id,labor_budget_id,job_type_id,desc,unit,num,price,amount,remark') + ->limit($this->limitOffset, $this->limitLength) + ->order(['id' => 'desc']) + ->select()->each(function($data){ + $labor_budget = ProjectLaborBudget::field('labor_budget_code')->where('id',$data['labor_budget_id'])->findOrEmpty(); + $project = Project::field('name,project_code')->where('id',$data['project_id'])->findOrEmpty(); + $job_type = ProjectJobType::field('type_name')->where('id',$data['job_type_id'])->findOrEmpty(); + $data['labor_budget_code'] = $labor_budget['labor_budget_code']; + $data['project_name'] = $project['name']; + $data['project_code'] = $project['project_code']; + $data['job_type_name'] = $job_type['type_name']; + return $data; + }) + ->toArray(); + } + + + /** + * @notes 获取人工预算明细数量 + * @return int + * @author likeadmin + * @date 2024/01/16 09:26 + */ + public function count(): int + { + return ProjectLaborBudgetDetail::where($this->searchWhere)->count(); + } + +} \ No newline at end of file diff --git a/app/adminapi/lists/project/ProjectLaborBudgetLists.php b/app/adminapi/lists/project/ProjectLaborBudgetLists.php new file mode 100644 index 000000000..6b9af4d4d --- /dev/null +++ b/app/adminapi/lists/project/ProjectLaborBudgetLists.php @@ -0,0 +1,88 @@ + ['project_id'], + '%like%' => ['labor_budget_code'], + ]; + } + + + /** + * @notes 获取人工预算列表 + * @return array + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\DbException + * @throws \think\db\exception\ModelNotFoundException + * @author likeadmin + * @date 2024/01/16 09:26 + */ + public function lists(): array + { + return ProjectLaborBudget::where($this->searchWhere) + ->field(['id', 'project_id', 'labor_budget_code', 'remark', 'annex']) + ->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['total_num'] = ProjectLaborBudgetDetail::where('labor_budget_id',$data['id'])->sum('num'); + //预算总金额 + $data['total_amount'] = ProjectLaborBudgetDetail::where('labor_budget_id',$data['id'])->sum('amount'); + }) + ->toArray(); + } + + + /** + * @notes 获取人工预算数量 + * @return int + * @author likeadmin + * @date 2024/01/16 09:26 + */ + public function count(): int + { + return ProjectLaborBudget::where($this->searchWhere)->count(); + } + +} \ No newline at end of file diff --git a/app/adminapi/logic/project/ProjectLaborBudgetDetailLogic.php b/app/adminapi/logic/project/ProjectLaborBudgetDetailLogic.php new file mode 100644 index 000000000..cd2f33f4f --- /dev/null +++ b/app/adminapi/logic/project/ProjectLaborBudgetDetailLogic.php @@ -0,0 +1,133 @@ +where('id',$params['labor_budget_id'])->findOrEmpty(); + Db::startTrans(); + try { + ProjectLaborBudgetDetail::create([ + 'project_id' => $labor_budget['project_id'], + 'labor_budget_id' => $params['labor_budget_id'], + 'job_type_id' => $params['job_type_id'], + 'desc' => $params['desc'] ?? '', + 'unit' => $params['unit'] ?? '', + 'num' => $params['num'], + 'price' => $params['price'], + 'amount' => $params['num'] * $params['price'], + 'remark' => $params['remark'] ?? '', + ]); + 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/16 09:26 + */ + public static function edit(array $params): bool + { + $labor_budget = ProjectLaborBudget::field('project_id')->where('id',$params['labor_budget_id'])->findOrEmpty(); + Db::startTrans(); + try { + ProjectLaborBudgetDetail::where('id', $params['id'])->update([ + 'project_id' => $labor_budget['project_id'], + 'labor_budget_id' => $params['labor_budget_id'], + 'job_type_id' => $params['job_type_id'], + 'desc' => $params['desc'] ?? '', + 'unit' => $params['unit'] ?? '', + 'num' => $params['num'], + 'price' => $params['price'], + 'amount' => $params['num'] * $params['price'], + 'remark' => $params['remark'] ?? '', + ]); + 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/16 09:26 + */ + public static function delete(array $params): bool + { + return ProjectLaborBudgetDetail::destroy($params['id']); + } + + + /** + * @notes 获取人工预算明细详情 + * @param $params + * @return array + * @author likeadmin + * @date 2024/01/16 09:26 + */ + public static function detail($params): array + { + $data = ProjectLaborBudgetDetail::field('id,project_id,labor_budget_id,job_type_id,desc,unit,num,price,amount,remark')->findOrEmpty($params['id']); + $labor_budget = ProjectLaborBudget::field('labor_budget_code')->where('id',$data['labor_budget_id'])->findOrEmpty(); + $project = Project::field('name,project_code')->where('id',$data['project_id'])->findOrEmpty(); + $job_type = ProjectJobType::field('type_name')->where('id',$data['job_type_id'])->findOrEmpty(); + $data['labor_budget_code'] = $labor_budget['labor_budget_code']; + $data['project_name'] = $project['name']; + $data['project_code'] = $project['project_code']; + $data['job_type_name'] = $job_type['type_name']; + return $data->toArray(); + } +} \ No newline at end of file diff --git a/app/adminapi/logic/project/ProjectLaborBudgetLogic.php b/app/adminapi/logic/project/ProjectLaborBudgetLogic.php new file mode 100644 index 000000000..259fa43dd --- /dev/null +++ b/app/adminapi/logic/project/ProjectLaborBudgetLogic.php @@ -0,0 +1,167 @@ + $params['org_id'], + 'dept_id' => $params['dept_id'], + 'project_id' => $params['project_id'], + 'labor_budget_code' => data_unique_code('项目人工预算'), + 'remark' => $params['remark'] ?? '', + 'annex' => $params['annex'] ? json_encode($params['annex']) : null, + ]); + foreach ($params['labor_budget_detail'] as $item) + { + ProjectLaborBudgetDetail::create([ + 'project_id' => $params['project_id'], + 'labor_budget_id' => $res->id, + 'job_type_id' => $item['job_type_id'], + 'desc' => $item['desc'] ?? '', + 'unit' => $item['unit'] ?? '', + 'price' => $item['price'], + 'num' => $item['num'], + 'amount' => $item['price'] * $item['num'], + 'remark' => $item['remark'] ?? '', + ]); + } + 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/16 09:26 + */ + public static function edit(array $params): bool + { + Db::startTrans(); + try { + ProjectLaborBudget::where('id', $params['id'])->update([ + 'org_id' => $params['org_id'], + 'dept_id' => $params['dept_id'], + 'project_id' => $params['project_id'], + 'remark' => $params['remark'] ?? '', + 'annex' => $params['annex'] ? json_encode($params['annex']) : null, + 'update_time' =>time(), + ]); + foreach ($params['labor_budget_detail'] as $item) + { + if(isset($item['id']) && $item['id'] != ''){ + ProjectLaborBudgetDetail::where('id',$item['id'])->update([ + 'project_id' => $params['project_id'], + 'job_type_id' => $item['job_type_id'], + 'desc' => $item['desc'] ?? '', + 'unit' => $item['unit'] ?? '', + 'price' => $item['price'], + 'num' => $item['num'], + 'amount' => $item['price'] * $item['num'], + 'remark' => $item['remark'] ?? '', + ]); + }else{ + ProjectLaborBudgetDetail::create([ + 'project_id' => $params['project_id'], + 'labor_budget_id' => $params['id'], + 'job_type_id' => $item['job_type_id'], + 'desc' => $item['desc'] ?? '', + 'unit' => $item['unit'] ?? '', + 'price' => $item['price'], + 'num' => $item['num'], + 'amount' => $item['price'] * $item['num'], + 'remark' => $item['remark'] ?? '', + ]); + } + } + 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/16 09:26 + */ + public static function delete(array $params): bool + { + return ProjectLaborBudget::destroy($params['id']); + } + + + /** + * @notes 获取人工预算详情 + * @param $params + * @return array + * @author likeadmin + * @date 2024/01/16 09:26 + */ + public static function detail($params): array + { + $data = ProjectLaborBudget::field('id,org_id,dept_id,project_id,labor_budget_code,remark,annex')->findOrEmpty($params['id']); + $org = Orgs::field('name')->where('id',$data['org_id'])->findOrEmpty(); + $dept = Dept::field('name')->where('id',$data['dept_id'])->findOrEmpty(); + $project = Project::field('name,project_code')->where('id',$data['project_id'])->findOrEmpty(); + $data['org_name'] = $org['name']; + $data['dept_name'] = $dept['name']; + $data['project_name'] = $project['name']; + $data['project_code'] = $project['project_code']; + return $data->toArray(); + } +} \ No newline at end of file diff --git a/app/adminapi/validate/project/ProjectLaborBudgetDetailValidate.php b/app/adminapi/validate/project/ProjectLaborBudgetDetailValidate.php new file mode 100644 index 000000000..f9af67ab9 --- /dev/null +++ b/app/adminapi/validate/project/ProjectLaborBudgetDetailValidate.php @@ -0,0 +1,120 @@ + 'require', + 'labor_budget_id' => 'require|checkLaborBudget', + 'job_type_id' => 'require|checkJobType', + 'num' => 'require|float|gt:0', + 'price' => 'require|float|egt:0', + ]; + + + /** + * 参数描述 + * @var string[] + */ + protected $field = [ + 'id' => 'id', + 'labor_budget_id' => '人工预算id', + 'job_type_id' => '工种id', + 'num' => '数量', + 'price' => '单价', + ]; + + + /** + * @notes 添加场景 + * @return ProjectLaborBudgetDetailValidate + * @author likeadmin + * @date 2024/01/16 09:26 + */ + public function sceneAdd() + { + return $this->remove('id',true); + } + + + /** + * @notes 编辑场景 + * @return ProjectLaborBudgetDetailValidate + * @author likeadmin + * @date 2024/01/16 09:26 + */ + public function sceneEdit() + {} + + + /** + * @notes 删除场景 + * @return ProjectLaborBudgetDetailValidate + * @author likeadmin + * @date 2024/01/16 09:26 + */ + public function sceneDelete() + { + return $this->only(['id']); + } + + + /** + * @notes 详情场景 + * @return ProjectLaborBudgetDetailValidate + * @author likeadmin + * @date 2024/01/16 09:26 + */ + public function sceneDetail() + { + return $this->only(['id']); + } + + public function checkLaborBudget($value): bool|string + { + $data = ProjectLaborBudget::where('id',$value)->findOrEmpty(); + if($data->isEmpty()){ + return '人工预算信息不存在'; + } + return true; + } + + public function checkJobType($value): bool|string + { + $data = ProjectJobType::where('id',$value)->findOrEmpty(); + if($data->isEmpty()){ + return '工种信息不存在'; + } + return true; + } + +} \ No newline at end of file diff --git a/app/adminapi/validate/project/ProjectLaborBudgetValidate.php b/app/adminapi/validate/project/ProjectLaborBudgetValidate.php new file mode 100644 index 000000000..54eb7568c --- /dev/null +++ b/app/adminapi/validate/project/ProjectLaborBudgetValidate.php @@ -0,0 +1,183 @@ + 'require', + 'org_id' => 'require|checkOrg', + 'dept_id' => 'require|checkDept', + 'project_id' => 'require|checkProject', + 'annex' => 'checkAnnex', + 'labor_budget_detail' => 'require|checkLaborBudgetDetail' + ]; + + + protected $message = [ + 'id.require' => '缺少必要参数', + 'org_id.require' => '请选择组织', + 'dept_id.require' => '请选择部门', + 'project_id.require' => '请选择项目', + 'labor_budget_detail.require' => '请填写人工预算清单' + ]; + + + /** + * @notes 添加场景 + * @return ProjectLaborBudgetValidate + * @author likeadmin + * @date 2024/01/16 09:26 + */ + public function sceneAdd() + { + return $this->remove('id',true); + } + + + /** + * @notes 编辑场景 + * @return ProjectLaborBudgetValidate + * @author likeadmin + * @date 2024/01/16 09:26 + */ + public function sceneEdit() + {} + + + /** + * @notes 删除场景 + * @return ProjectLaborBudgetValidate + * @author likeadmin + * @date 2024/01/16 09:26 + */ + public function sceneDelete() + { + return $this->only(['id']); + } + + + /** + * @notes 详情场景 + * @return ProjectLaborBudgetValidate + * @author likeadmin + * @date 2024/01/16 09:26 + */ + public function sceneDetail() + { + return $this->only(['id']); + } + + public function checkOrg($value): bool|string + { + $org = Orgs::where('id',$value)->findOrEmpty(); + if($org->isEmpty()){ + return '组织不存在'; + } + return true; + } + + public function checkDept($value,$rule,$data): bool|string + { + $dept = Dept::where('id',$value)->findOrEmpty(); + if($dept->isEmpty()){ + return '部门不存在'; + } + if($dept['org_id'] != $data['org_id']){ + return '部门无效'; + } + return true; + } + + public function checkProject($value): bool|string + { + $project = Project::where('id',$value)->findOrEmpty(); + if($project->isEmpty()){ + return '项目信息不存在'; + } + if($project['is_budget'] != 1){ + return '该项目没有编制总预算,不能添加材料预算'; + } + return true; + } + + public function checkAnnex($value): bool|string + { + if(!empty($value) && $value != ''){ + if(!is_array($value)){ + return '附件格式错误'; + } + } + return true; + } + + public function checkLaborBudgetDetail($value): bool|string + { + if(empty($value) || !is_array($value)){ + return '人工预算清单数据格式错误'; + } + foreach($value as $v) { + if(isset($v['id']) && $v['id'] != ''){ + $data = ProjectLaborBudgetDetail::where('id',$v['id'])->findOrEmpty(); + if($data->isEmpty()){ + return '人工预算明细信息不存在'; + } + } + if(empty($v['job_type_id'])){ + return '请选择工种'; + }else{ + $job_type = ProjectJobType::where('id',$v['job_type_id'])->findOrEmpty(); + if($job_type->isEmpty()){ + return '工种信息不存在'; + } + } + if(empty($v['num'])){ + return '数量不能为空'; + }else{ + if(!is_numeric($v['num']) || $v['num'] < 0){ + return '数量必须是大于0的数字'; + } + } + if(empty($v['price'])){ + return '单价不能为空'; + }else{ + if(!is_numeric($v['price']) || $v['price'] < 0){ + return '单价必须是大于0的数字'; + } + } + } + return true; + } + +} \ No newline at end of file diff --git a/app/common/model/project/ProjectLaborBudget.php b/app/common/model/project/ProjectLaborBudget.php new file mode 100644 index 000000000..72291f838 --- /dev/null +++ b/app/common/model/project/ProjectLaborBudget.php @@ -0,0 +1,36 @@ +