['plan_id'] ]; } /** * @notes 获取施工汇报列表 * @return array * @throws \think\db\exception\DataNotFoundException * @throws \think\db\exception\DbException * @throws \think\db\exception\ModelNotFoundException * @author likeadmin * @date 2023/12/22 16:08 */ public function lists(): array { $params = $this->request->get(['project_id']); $where = []; if(isset($params['project_id']) && $params['project_id'] != 0){ $plan_ids = BuildPlan::where('project_id',$params['project_id'])->column('id'); $where[] = ['plan_id','in',$plan_ids]; } return BuildReport::where($this->searchWhere)->where($where) ->field(['id', 'report_code', 'plan_id', 'scene_file', 'report_workload', 'report_amount', 'remark', 'add_user', 'create_time']) ->limit($this->limitOffset, $this->limitLength) ->order(['id' => 'desc']) ->select()->each(function($data){ $plan = BuildPlan::where('id',$data['plan_id'])->findOrEmpty(); $project = Project::field('name')->where('id',$plan['project_id'])->findOrEmpty(); $process = BuildProcessSettings::field('division_id,process_step_no,process_step,quality_control_points,annex')->where('id',$plan['process_id'])->findOrEmpty(); $division = BuildDivision::field('subentry_engineering')->where('id',$process['division_id'])->findOrEmpty(); $projectMember = ProjectMember::field('admin_id')->where('id',$plan['project_member_id'])->findOrEmpty(); $admin = Admin::field('name')->where('id','in',[$projectMember['admin_id'],$data['add_user']])->column('name','id'); $data['zy_code'] = $plan['zy_code']; $data['project_name'] = $project['name']; $data['subentry_engineering'] = $division['subentry_engineering']; $data['process_step'] = $process['process_step']; $data['process_step_no'] = $process['process_step_no']; $data['quality_control_points'] = $process['quality_control_points']; $data['process_file'] = $process['annex']; $data['project_member_name'] = $admin[$projectMember['admin_id']]; $data['work_user'] = $plan['work_user']; $data['work_content'] = $plan['work_content']; $data['plan_start_date'] = $plan['plan_start_date']; $data['plan_end_date'] = $plan['plan_end_date']; $data['unit'] = $plan['unit']; $data['workload'] = $plan['workload']; $data['price'] = $plan['price']; $data['residue_workload'] = ($data['workload'] - $data['report_workload']) <=0 ? 0 : $data['workload'] - $data['report_workload']; $data['completion_degree'] = round($data['report_workload'] / $data['workload'],3).'%'; $data['add_user_name'] = $admin[$data['add_user']]; }) ->toArray(); } /** * @notes 获取施工汇报数量 * @return int * @author likeadmin * @date 2023/12/22 16:08 */ public function count(): int { $params = $this->request->get(['project_id']); $where = []; if(isset($params['project_id']) && $params['project_id'] != 0){ $plan_ids = BuildPlan::where('project_id',$params['project_id'])->column('id'); $where[] = ['plan_id','in',$plan_ids]; } return BuildReport::where($this->searchWhere)->where($where)->count(); } }