diff --git a/app/adminapi/controller/project/ProjectSubpackageBudgetController.php b/app/adminapi/controller/project/ProjectSubpackageBudgetController.php new file mode 100644 index 000000000..75ca04e1b --- /dev/null +++ b/app/adminapi/controller/project/ProjectSubpackageBudgetController.php @@ -0,0 +1,108 @@ +dataLists(new ProjectSubpackageBudgetLists()); + } + + + /** + * @notes 添加分包预算 + * @return \think\response\Json + * @author likeadmin + * @date 2024/01/10 15:19 + */ + public function add() + { + $params = (new ProjectSubpackageBudgetValidate())->post()->goCheck('add'); + $result = ProjectSubpackageBudgetLogic::add($params); + if (true === $result) { + return $this->success('添加成功', [], 1, 1); + } + return $this->fail(ProjectSubpackageBudgetLogic::getError()); + } + + + /** + * @notes 编辑分包预算 + * @return \think\response\Json + * @author likeadmin + * @date 2024/01/10 15:19 + */ + public function edit() + { + $params = (new ProjectSubpackageBudgetValidate())->post()->goCheck('edit'); + $result = ProjectSubpackageBudgetLogic::edit($params); + if (true === $result) { + return $this->success('编辑成功', [], 1, 1); + } + return $this->fail(ProjectSubpackageBudgetLogic::getError()); + } + + + /** + * @notes 删除分包预算 + * @return \think\response\Json + * @author likeadmin + * @date 2024/01/10 15:19 + */ + public function delete() + { + $params = (new ProjectSubpackageBudgetValidate())->post()->goCheck('delete'); + ProjectSubpackageBudgetLogic::delete($params); + return $this->success('删除成功', [], 1, 1); + } + + + /** + * @notes 获取分包预算详情 + * @return \think\response\Json + * @author likeadmin + * @date 2024/01/10 15:19 + */ + public function detail() + { + $params = (new ProjectSubpackageBudgetValidate())->goCheck('detail'); + $result = ProjectSubpackageBudgetLogic::detail($params); + return $this->data($result); + } + + +} \ No newline at end of file diff --git a/app/adminapi/controller/project/ProjectSubpackageBudgetDetailController.php b/app/adminapi/controller/project/ProjectSubpackageBudgetDetailController.php new file mode 100644 index 000000000..6cd4b1176 --- /dev/null +++ b/app/adminapi/controller/project/ProjectSubpackageBudgetDetailController.php @@ -0,0 +1,108 @@ +dataLists(new ProjectSubpackageBudgetDetailLists()); + } + + + /** + * @notes 添加分包预算明细 + * @return \think\response\Json + * @author likeadmin + * @date 2024/01/10 15:19 + */ + public function add() + { + $params = (new ProjectSubpackageBudgetDetailValidate())->post()->goCheck('add'); + $result = ProjectSubpackageBudgetDetailLogic::add($params); + if (true === $result) { + return $this->success('添加成功', [], 1, 1); + } + return $this->fail(ProjectSubpackageBudgetDetailLogic::getError()); + } + + + /** + * @notes 编辑分包预算明细 + * @return \think\response\Json + * @author likeadmin + * @date 2024/01/10 15:19 + */ + public function edit() + { + $params = (new ProjectSubpackageBudgetDetailValidate())->post()->goCheck('edit'); + $result = ProjectSubpackageBudgetDetailLogic::edit($params); + if (true === $result) { + return $this->success('编辑成功', [], 1, 1); + } + return $this->fail(ProjectSubpackageBudgetDetailLogic::getError()); + } + + + /** + * @notes 删除分包预算明细 + * @return \think\response\Json + * @author likeadmin + * @date 2024/01/10 15:19 + */ + public function delete() + { + $params = (new ProjectSubpackageBudgetDetailValidate())->post()->goCheck('delete'); + ProjectSubpackageBudgetDetailLogic::delete($params); + return $this->success('删除成功', [], 1, 1); + } + + + /** + * @notes 获取分包预算明细详情 + * @return \think\response\Json + * @author likeadmin + * @date 2024/01/10 15:19 + */ + public function detail() + { + $params = (new ProjectSubpackageBudgetDetailValidate())->goCheck('detail'); + $result = ProjectSubpackageBudgetDetailLogic::detail($params); + return $this->data($result); + } + + +} \ No newline at end of file diff --git a/app/adminapi/lists/project/ProjectSubpackageBudgetDetailLists.php b/app/adminapi/lists/project/ProjectSubpackageBudgetDetailLists.php new file mode 100644 index 000000000..ce23eb032 --- /dev/null +++ b/app/adminapi/lists/project/ProjectSubpackageBudgetDetailLists.php @@ -0,0 +1,90 @@ + ['project_id', 'subpackage_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/10 15:19 + */ + public function lists(): array + { + return ProjectSubpackageBudgetDetail::where($this->searchWhere) + ->field('id,project_id,subpackage_budget_id,work_type,work_content,project_features,unit,num,price,amount,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(); + $subpackage_budget = ProjectSubpackageBudget::field('subpackage_budget_code')->where('id',$data['subpackage_budget_id'])->findOrEmpty(); + $data['project_name'] = $project['name']; + $data['project_code'] = $project['project_code']; + $data['subpackage_budget_code'] = $subpackage_budget['subpackage_budget_code']; + //已分包工作量 + $data['has_subcontract_num'] = 0; + //剩余工作量 + $data['residue_num'] = $data['num'] - $data['has_subcontract_num']; + return $data; + }) + ->toArray(); + } + + + /** + * @notes 获取分包预算明细数量 + * @return int + * @author likeadmin + * @date 2024/01/10 15:19 + */ + public function count(): int + { + return ProjectSubpackageBudgetDetail::where($this->searchWhere)->count(); + } + +} \ No newline at end of file diff --git a/app/adminapi/lists/project/ProjectSubpackageBudgetLists.php b/app/adminapi/lists/project/ProjectSubpackageBudgetLists.php new file mode 100644 index 000000000..f16d5fa2d --- /dev/null +++ b/app/adminapi/lists/project/ProjectSubpackageBudgetLists.php @@ -0,0 +1,92 @@ + ['project_id'], + ]; + } + + + /** + * @notes 获取分包预算列表 + * @return array + * @throws \think\db\exception\DataNotFoundException + * @throws \think\db\exception\DbException + * @throws \think\db\exception\ModelNotFoundException + * @author likeadmin + * @date 2024/01/10 15:19 + */ + public function lists(): array + { + return ProjectSubpackageBudget::where($this->searchWhere) + ->field('id,project_id,subpackage_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'] = ProjectSubpackageBudgetDetail::where('subpackage_budget_id',$data['id'])->sum('num'); + //预算总金额 + $data['total_amount'] = ProjectSubpackageBudgetDetail::where('subpackage_budget_id',$data['id'])->sum('amount'); + //已分包工作量 + $data['has_subcontract_num'] = 0; + //剩余工作量 + $data['residue_num'] = $data['total_num'] - $data['has_subcontract_num']; + return $data; + }) + ->toArray(); + } + + + /** + * @notes 获取分包预算数量 + * @return int + * @author likeadmin + * @date 2024/01/10 15:19 + */ + public function count(): int + { + return ProjectSubpackageBudget::where($this->searchWhere)->count(); + } + +} \ No newline at end of file diff --git a/app/adminapi/logic/project/ProjectSubpackageBudgetDetailLogic.php b/app/adminapi/logic/project/ProjectSubpackageBudgetDetailLogic.php new file mode 100644 index 000000000..9120651e6 --- /dev/null +++ b/app/adminapi/logic/project/ProjectSubpackageBudgetDetailLogic.php @@ -0,0 +1,133 @@ +findOrEmpty(); + Db::startTrans(); + try { + ProjectSubpackageBudgetDetail::create([ + 'project_id' => $subpackage_budget['project_id'], + 'subpackage_budget_id' => $params['subpackage_budget_id'], + 'work_type' => $params['work_type'], + 'work_content' => $params['work_content'], + 'project_features' => $params['project_features'] ?? '', + '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/10 15:19 + */ + public static function edit(array $params): bool + { + $subpackage_budget = ProjectSubpackageBudget::where('id',$params['subpackage_budget_id'])->findOrEmpty(); + Db::startTrans(); + try { + ProjectSubpackageBudgetDetail::where('id', $params['id'])->update([ + 'project_id' => $subpackage_budget['project_id'], + 'subpackage_budget_id' => $params['subpackage_budget_id'], + 'work_type' => $params['work_type'], + 'work_content' => $params['work_content'], + 'project_features' => $params['project_features'] ?? '', + '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/10 15:19 + */ + public static function delete(array $params): bool + { + return ProjectSubpackageBudgetDetail::destroy($params['id']); + } + + + /** + * @notes 获取分包预算明细详情 + * @param $params + * @return array + * @author likeadmin + * @date 2024/01/10 15:19 + */ + public static function detail($params): array + { + $data = ProjectSubpackageBudgetDetail::field('id,project_id,subpackage_budget_id,work_type,work_content,project_features,unit,num,price,amount,remark') + ->findOrEmpty($params['id']); + $project = Project::field('name,project_code')->where('id',$data['project_id'])->findOrEmpty(); + $subpackage_budget = ProjectSubpackageBudget::field('subpackage_budget_code')->where('id',$data['subpackage_budget_id'])->findOrEmpty(); + $data['project_name'] = $project['name']; + $data['project_code'] = $project['project_code']; + $data['subpackage_budget_code'] = $subpackage_budget['subpackage_budget_code']; + return $data->toArray(); + } +} \ No newline at end of file diff --git a/app/adminapi/logic/project/ProjectSubpackageBudgetLogic.php b/app/adminapi/logic/project/ProjectSubpackageBudgetLogic.php new file mode 100644 index 000000000..3e1284d3a --- /dev/null +++ b/app/adminapi/logic/project/ProjectSubpackageBudgetLogic.php @@ -0,0 +1,173 @@ + $params['org_id'], + 'dept_id' => $params['dept_id'], + 'project_id' => $params['project_id'], + 'subpackage_budget_code' => data_unique_code('项目分包预算'), + 'remark' => $params['remark'] ?? '', + 'annex' => !empty($params['annex']) ? $params['annex'] : null, + ]); + foreach ($detail as $item) + { + ProjectSubpackageBudgetDetail::create([ + 'project_id' => $params['project_id'], + 'subpackage_budget_id' => $res->id, + 'work_type' => $item['work_type'], + 'work_content' => $item['work_content'], + 'project_features' => $item['project_features'] ?? '', + 'unit' => $item['unit'], + 'num' => $item['num'], + 'price' => $item['price'], + 'amount' => $item['num'] * $item['price'], + '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/10 15:19 + */ + public static function edit(array $params): bool + { + $detail = json_decode($params['subpackage_budget_detail'],true); + Db::startTrans(); + try { + ProjectSubpackageBudget::where('id', $params['id'])->update([ + 'org_id' => $params['org_id'], + 'dept_id' => $params['dept_id'], + 'project_id' => $params['project_id'], + 'subpackage_budget_code' => data_unique_code('项目分包预算'), + 'remark' => $params['remark'] ?? '', + 'annex' => !empty($params['annex']) ? $params['annex'] : null, + ]); + foreach ($detail as $item) + { + if(isset($item['id']) && $item['id'] != ''){ + ProjectSubpackageBudgetDetail::where('id',$item['id'])->update([ + 'project_id' => $params['project_id'], + 'subpackage_budget_id' => $params['id'], + 'work_type' => $item['work_type'], + 'work_content' => $item['work_content'], + 'project_features' => $item['project_features'] ?? '', + 'unit' => $item['unit'], + 'num' => $item['num'], + 'price' => $item['price'], + 'amount' => $item['num'] * $item['price'], + 'remark' => $item['remark'] ?? '', + ]); + }else{ + ProjectSubpackageBudgetDetail::create([ + 'project_id' => $params['project_id'], + 'subpackage_budget_id' => $params['id'], + 'work_type' => $item['work_type'], + 'work_content' => $item['work_content'], + 'project_features' => $item['project_features'] ?? '', + 'unit' => $item['unit'], + 'num' => $item['num'], + 'price' => $item['price'], + 'amount' => $item['num'] * $item['price'], + '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/10 15:19 + */ + public static function delete(array $params): bool + { + return ProjectSubpackageBudget::destroy($params['id']); + } + + + /** + * @notes 获取分包预算详情 + * @param $params + * @return array + * @author likeadmin + * @date 2024/01/10 15:19 + */ + public static function detail($params): array + { + $data = ProjectSubpackageBudget::field('id,org_id,dept_id,project_id,subpackage_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/ProjectSubpackageBudgetDetailValidate.php b/app/adminapi/validate/project/ProjectSubpackageBudgetDetailValidate.php new file mode 100644 index 000000000..63bd88b59 --- /dev/null +++ b/app/adminapi/validate/project/ProjectSubpackageBudgetDetailValidate.php @@ -0,0 +1,113 @@ + 'require', + 'subpackage_budget_id' => 'require|checkSubpackageBudget', + 'work_type' => 'require', + 'work_content' => 'require', + 'unit' => 'require', + 'num' => 'require|float|egt:0', + 'price' => 'require|float|egt:0', + ]; + + /** + * 参数描述 + * @var string[] + */ + protected $field = [ + 'id' => 'id', + 'subpackage_budget_id' => '分包预算id', + 'work_type' => '工作类型', + 'work_content' => '工作内容', + 'unit' => '单位', + 'num' => '工作量', + 'price' => '单价', + ]; + + + /** + * @notes 添加场景 + * @return ProjectSubpackageBudgetDetailValidate + * @author likeadmin + * @date 2024/01/10 15:19 + */ + public function sceneAdd() + { + return $this->remove('id',true); + } + + + /** + * @notes 编辑场景 + * @return ProjectSubpackageBudgetDetailValidate + * @author likeadmin + * @date 2024/01/10 15:19 + */ + public function sceneEdit() + {} + + + /** + * @notes 删除场景 + * @return ProjectSubpackageBudgetDetailValidate + * @author likeadmin + * @date 2024/01/10 15:19 + */ + public function sceneDelete() + { + return $this->only(['id']); + } + + + /** + * @notes 详情场景 + * @return ProjectSubpackageBudgetDetailValidate + * @author likeadmin + * @date 2024/01/10 15:19 + */ + public function sceneDetail() + { + return $this->only(['id']); + } + + public function checkSubpackageBudget($value): bool|string + { + $data = ProjectSubpackageBudget::where('id',$value)->findOrEmpty(); + if($data->isEmpty()){ + return '分包预算信息不存在'; + } + return true; + } + +} \ No newline at end of file diff --git a/app/adminapi/validate/project/ProjectSubpackageBudgetValidate.php b/app/adminapi/validate/project/ProjectSubpackageBudgetValidate.php new file mode 100644 index 000000000..7d7e1f489 --- /dev/null +++ b/app/adminapi/validate/project/ProjectSubpackageBudgetValidate.php @@ -0,0 +1,188 @@ + 'require', + 'org_id' => 'require|checkOrg', + 'dept_id' => 'require|checkDept', + 'project_id' => 'require|checkProject', + 'annex' => 'checkAnnex', + 'subpackage_budget_detail' => 'require|checkSubpackageBudgetDetail' + ]; + + /** + * 参数描述 + * @var string[] + */ + protected $field = [ + 'id' => 'id', + 'org_id' => '组织id', + 'dept_id' => '部门id', + 'project_id' => '项目id', + 'material_budget_detail' => '分包预算明细' + ]; + + + /** + * @notes 添加场景 + * @return ProjectSubpackageBudgetValidate + * @author likeadmin + * @date 2024/01/10 15:19 + */ + public function sceneAdd() + { + return $this->remove('id',true); + } + + + /** + * @notes 编辑场景 + * @return ProjectSubpackageBudgetValidate + * @author likeadmin + * @date 2024/01/10 15:19 + */ + public function sceneEdit() + {} + + + /** + * @notes 删除场景 + * @return ProjectSubpackageBudgetValidate + * @author likeadmin + * @date 2024/01/10 15:19 + */ + public function sceneDelete() + { + return $this->only(['id']); + } + + + /** + * @notes 详情场景 + * @return ProjectSubpackageBudgetValidate + * @author likeadmin + * @date 2024/01/10 15:19 + */ + 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 != ''){ + $annex = json_decode($value,true); + if(empty($annex) || !is_array($annex)){ + return '附件格式错误'; + } + } + return true; + } + + public function checkSubpackageBudgetDetail($value): bool|string + { + $detail = json_decode($value,true); + if(empty($detail) || !is_array($detail)){ + return '分包预算明细数据格式错误'; + } + foreach($detail as $v) { + if(isset($v['id']) && $v['id'] != ''){ + $data_detail = ProjectSubpackageBudgetDetail::where('id',$v['id'])->findOrEmpty(); + if($data_detail->isEmpty()){ + return '分包预算明细信息不存在'; + } + } + if(empty($v['work_type'])){ + return '请填写工作类型'; + } + if(empty($v['work_content'])){ + return '请填写工作内容'; + } + if(empty($v['unit'])){ + 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/ProjectSubpackageBudget.php b/app/common/model/project/ProjectSubpackageBudget.php new file mode 100644 index 000000000..978958498 --- /dev/null +++ b/app/common/model/project/ProjectSubpackageBudget.php @@ -0,0 +1,36 @@ +