dataLists(new ProjectPersonnelLists()); } /** * @notes 添加项目人员 * @return \think\response\Json * @author likeadmin * @date 2023/12/22 14:38 */ public function add() { $params = (new ProjectPersonnelValidate())->post()->goCheck('add'); $result = ProjectPersonnelLogic::add($params,$this->adminId); if (true === $result) { return $this->success('添加成功', [], 1, 1); } return $this->fail(ProjectPersonnelLogic::getError()); } /** * @notes 编辑项目人员 * @return \think\response\Json * @author likeadmin * @date 2023/12/22 14:38 */ public function edit() { $params = (new ProjectPersonnelValidate())->post()->goCheck('edit'); $result = ProjectPersonnelLogic::edit($params,$this->adminId); if (true === $result) { return $this->success('编辑成功', [], 1, 1); } return $this->fail(ProjectPersonnelLogic::getError()); } /** * @notes 删除项目人员 * @return \think\response\Json * @author likeadmin * @date 2023/12/22 14:38 */ public function delete() { $params = (new ProjectPersonnelValidate())->post()->goCheck('delete'); ProjectPersonnelLogic::delete($params); return $this->success('删除成功', [], 1, 1); } /** * @notes 获取项目人员详情 * @return \think\response\Json * @author likeadmin * @date 2023/12/22 14:38 */ public function detail() { $params = (new ProjectPersonnelValidate())->goCheck('detail'); $result = ProjectPersonnelLogic::detail($params); return $this->data($result); } //某个项目下的人员列表 public function listToProject(): \think\response\Json { $params = $this->request->get(['project_id','page_size','page_no']); if(empty($params['project_id'])){ return $this->fail('参数错误'); } $pageNo = empty($params['page_no']) ? 1 : $params['page_no']; $pageSize = empty($params['page_size']) ? 15 : $params['page_size']; $data = ProjectPersonnel::field(['id', 'project_id', 'name', 'idcard', 'mobile', 'work_type', 'unit_price', 'daily_living_expenses', 'idcard_front', 'idcard_backend', 'bank_card', 'bank_no', 'deposit_bank', 'remark', 'opening_income']) ->where('project_id',$params['project_id']) ->page($pageNo, $pageSize) ->order(['id' => 'desc']) ->select() ->each(function($item){ $item['work_type_text'] = $item->work_type_text; $project = Project::field('name,project_code')->where('id',$item['project_id'])->findOrEmpty(); $item['project_name'] = $project['name']; $item['project_code'] = $project['project_code']; return $item; }) ->toArray(); $count = ProjectPersonnel::field('id')->where('project_id',$params['project_id'])->count(); $result = [ 'count' => $count, 'page_no' => $pageNo, 'page_size' => $pageSize, 'lists' => $data ]; return $this->success('请求成功',$result); } //某个人员下的劳动合同列表 public function laborContracts(): \think\response\Json { $params = $this->request->get(['person_id','page_no','page_size']); if(empty($params['person_id'])){ return $this->fail('缺少必要参数'); } $pageNo = empty($params['page_no']) ? 1 : $params['page_no']; $pageSize = empty($params['page_size']) ? 15 : $params['page_size']; $person = ProjectPersonnel::field('id,name,idcard')->where('id',$params['person_id'])->findOrEmpty(); if($person->isEmpty()){ return $this->fail('项目人员信息不存在'); } $data = ProjectLaborContract::field('id,contract_status,contract_type,contract_title,signing_date,start_date,end_date,remark,annex') ->where('project_person_id',$params['person_id']) ->page($pageNo,$pageSize)->order('id desc') ->select()->each(function($item)use($person){ $item['person_name'] = $person['name']; $item['person_idcard'] = $person['idcard']; $item['contract_status_text'] = $item->contract_status_text; $item['contract_type_text'] = $item->contract_type_text; $item['contract_title_text'] = $item->contract_title_text; return $item; }) ->toArray(); $count = ProjectLaborContract::field('id')->where('project_person_id',$params['person_id'])->count(); $result = [ 'count' => $count, 'page_no' => $pageNo, 'page_size' => $pageSize, 'lists' => $data ]; return $this->success('请求成功',$result); } //某个人员下的保险列表 public function insurances(): \think\response\Json { $params = $this->request->get(['person_id','page_no','page_size']); if(empty($params['person_id'])){ return $this->fail('缺少必要参数'); } $pageNo = empty($params['page_no']) ? 1 : $params['page_no']; $pageSize = empty($params['page_size']) ? 15 : $params['page_size']; $person = ProjectPersonnel::field('id,name,idcard')->where('id',$params['person_id'])->findOrEmpty(); if($person->isEmpty()){ return $this->fail('项目人员信息不存在'); } $data = ProjectInsuranceManagement::field('id,insurance_date,due_date,type,insurance_no,insurance,insured_amount,insurance_company') ->where('project_person_id',$params['person_id']) ->page($pageNo,$pageSize)->order('id desc') ->select()->each(function($item)use($person){ $item['person_name'] = $person['name']; $item['person_idcard'] = $person['idcard']; return $item; }) ->toArray(); $count = ProjectInsuranceManagement::field('id')->where('project_person_id',$params['person_id'])->count(); $result = [ 'count' => $count, 'page_no' => $pageNo, 'page_size' => $pageSize, 'lists' => $data ]; return $this->success('请求成功',$result); } //某个人员下的考勤明细列表 public function attendances(): \think\response\Json { $params = $this->request->get(['person_id','page_no','page_size']); if(empty($params['person_id'])){ return $this->fail('缺少必要参数'); } $pageNo = empty($params['page_no']) ? 1 : $params['page_no']; $pageSize = empty($params['page_size']) ? 15 : $params['page_size']; $person = ProjectPersonnel::field('id,name,idcard,work_type')->where('id',$params['person_id'])->findOrEmpty(); if($person->isEmpty()){ return $this->fail('项目人员信息不存在'); } $data = ProjectAttendanceDetail::field('id,attendance_code,attendance_date,work_start_time,work_end_time,work_record_num,daily_salary,daily_living,daily_subsidy,daily_other,daily_income,remark') ->where('person_id',$params['person_id']) ->page($pageNo,$pageSize)->order('id desc') ->select()->each(function($item)use($person){ $item['person_name'] = $person['name']; $item['person_idcard'] = $person['idcard']; $item['work_type_text'] = $person->work_type_text; return $item; }) ->toArray(); $count = ProjectAttendanceDetail::field('id')->where('person_id',$params['person_id'])->count(); $result = [ 'count' => $count, 'page_no' => $pageNo, 'page_size' => $pageSize, 'lists' => $data ]; return $this->success('请求成功',$result); } //某个员工下的施工记录列表 public function buildworks(): \think\response\Json { $params = $this->request->get(['person_id','page_no','page_size']); if(empty($params['person_id'])){ return $this->fail('缺少必要参数'); } $pageNo = empty($params['page_no']) ? 1 : $params['page_no']; $pageSize = empty($params['page_size']) ? 15 : $params['page_size']; $person = ProjectPersonnel::field('id,name,idcard,work_type')->where('id',$params['person_id'])->findOrEmpty(); if($person->isEmpty()){ return $this->fail('项目人员信息不存在'); } $data = BuildReportDetail::field('id,report_id,work_num,create_time') ->where('person_id',$params['person_id']) ->page($pageNo,$pageSize)->order('id desc') ->select()->each(function($item)use($person){ $report = BuildReport::field('report_code,plan_id')->where('id',$item['report_id'])->findOrEmpty(); $plan = BuildPlan::field('process_id,zy_code,unit,price')->where('id',$report['plan_id'])->findOrEmpty(); $process = BuildProcessSettings::field('division_id,process_step')->where('id',$plan['process_id'])->findOrEmpty(); $division = BuildDivision::field('subentry_engineering')->where('id',$process['division_id'])->findOrEmpty(); $item['report_code'] = $report['report_code']; $item['zy_code'] = $plan['zy_code']; $item['process_step'] = $process['process_step']; $item['subentry_engineering'] = $division['subentry_engineering']; $item['report_date'] = date('Y-m-d',strtotime($item['create_time'])); $item['person_name'] = $person['name']; $item['person_idcard'] = $person['idcard']; $item['work_type_text'] = $person->work_type_text; $item['unit'] = $plan['unit']; $item['price'] = $plan['price']; $item['amount'] = $plan['price'] * $item['work_num']; unset($item['create_time']); return $item; }) ->toArray(); $count = BuildReportDetail::field('id')->where('person_id',$params['person_id'])->count(); $result = [ 'count' => $count, 'page_no' => $pageNo, 'page_size' => $pageSize, 'lists' => $data ]; return $this->success('请求成功',$result); } //某个人员下的工资付款列表 public function payments(): \think\response\Json { $params = $this->request->get(['person_id','page_no','page_size']); if(empty($params['person_id'])){ return $this->fail('缺少必要参数'); } $pageNo = empty($params['page_no']) ? 1 : $params['page_no']; $pageSize = empty($params['page_size']) ? 15 : $params['page_size']; $person = ProjectPersonnel::field('id,name,idcard,work_type')->where('id',$params['person_id'])->findOrEmpty(); if($person->isEmpty()){ return $this->fail('项目人员信息不存在'); } $data = ProjectSalaryDetail::field(['id', 'salary_payment_id', 'person_id', 'apply_date', 'apply_amount', 'remark']) ->where('person_id',$params['person_id']) ->page($pageNo,$pageSize)->order('id desc') ->select()->each(function($item)use($person){ $payment = ProjectSalaryPayment::field('payment_code,project_id')->where('id',$item['salary_payment_id'])->findOrEmpty(); $project = Project::field('name,project_code')->where('id',$payment['project_id'])->findOrEmpty(); $person = ProjectPersonnel::field('name,idcard,work_type')->where('id',$item['person_id'])->findOrEmpty(); $item['payment_code'] = $payment['payment_code']; $item['project_name'] = $project['name']; $item['project_code'] = $project['project_code']; $item['person_name'] = $person['name']; $item['person_idcard'] = $person['idcard']; $item['person_work_type_text'] = $person->work_type_text; //总考勤收入 $daily_income = ProjectAttendanceDetail::where('person_id',$item['person_id'])->sum('daily_income'); //总施工收入 $build_report_details = BuildReportDetail::field('report_id,work_num')->where('person_id',$item['person_id'])->select()->each(function($item2){ $report = BuildReport::field('plan_id')->where('id',$item2['report_id'])->findOrEmpty(); $plan = BuildPlan::field('price')->where('id',$report['plan_id'])->findOrEmpty(); $item2['amount'] = $item2['work_num'] * $plan['price']; })->toArray(); $work_income = 0; foreach($build_report_details as $v){ $work_income += $v['amount']; } $item['total_income'] = $daily_income + $work_income; //总支出 $item['total_pay_out'] = ProjectSalaryDetail::where('person_id',$item['person_id'])->sum('apply_amount'); $item['balance'] = $item['total_income'] - $item['total_pay_out']; return $item; }) ->toArray(); $count = BuildReportDetail::field('id')->where('person_id',$params['person_id'])->count(); $result = [ 'count' => $count, 'page_no' => $pageNo, 'page_size' => $pageSize, 'lists' => $data ]; return $this->success('请求成功',$result); } }