jobfairJobRepository = $jobfairJobRepository; $this->jobfairJobsContactRepository = $jobfairJobsContactRepository; $this->memberLogRepository = $memberLogRepository; $this->jobfairCompanyRepository = $jobfairCompanyRepository; $this->jobfairPutJobRepository = $jobfairPutJobRepository; $this->companyContactsRepository = $companyContactsRepository; $this->jobsRepository = $jobsRepository; $this->jobsContactRepository = $jobsContactRepository; $this->jobfairPutJobService = $jobfairPutJobService; } /**招聘会职位库 * @return array */ public function jobfairJobsList() { $user = auth('web-company')->user(); $where = [ 'company_id'=>$user->id, 'type'=>1, ]; $list = $this->jobfairJobRepository->getJobList($where); return $res = [ 'list'=>$list, ]; } /**招聘会职位添加 * @return array */ public function jobfairJobsAdd() { $user = auth('web-company')->user(); $user->landline =explode('-', $user->landline_tel); $jobfairJobContact = $this->jobfairJobsContactRepository->getContact(['pid'=>'']); $companyContact = $this->companyContactsRepository->getContacts(['company_id'=>$user->id]); return $result = [ 'company' =>$user, 'jobfairJobContact' =>$jobfairJobContact, 'companyContact' =>$companyContact, ]; } /**招聘会职位修改 * @param $id * @return array|bool */ public function jobfairJobsEdit($id, $user) { $jobfair_job = $this->jobfairJobRepository->editJob($id); if (!$jobfair_job || $jobfair_job->company_id != $user->id) { return false; } $companyContact = $this->companyContactsRepository->getContacts(['company_id'=>$user->id]); $jobfair_job->tag = explode(',', $jobfair_job->tag); $jobfair_job->age = explode('-', $jobfair_job->age); if($jobfair_job->jobsContact){ $jobfair_job->jobsContact->landline_tel =$jobfair_job->jobsContact->landline_tel?explode('-', $jobfair_job->jobsContact->landline_tel):[]; } return $result = [ 'company' =>$user, 'jobsInfo'=>$jobfair_job, 'companyContact'=>$companyContact, ]; } /**招聘会职位删除 * @param $request * @return \Illuminate\Http\JsonResponse */ public function jobfairJobsDel($request) { $user = auth('web-company')->user(); $id = $request->y_id; $where['company_id'] = $user->id; if (!is_array($id)) { $ids = explode(',', $id); } else { $ids = $id; } $this->isOwn($ids,$user); DB::beginTransaction(); try { if (!$this->jobfairJobRepository->deleteJobs($where, $ids)) { throw new Exception('招聘会职位删除失败!'); } $this->jobfairJobsContactRepository->deleteJobContact($ids); $this->jobfairPutJobRepository->delJobIds($ids); $this->memberLogRepository->createLog($user, 1036, [implode(',', $ids)]); DB::commit(); return response()->json(['status'=>1, 'msg'=>'招聘会职位删除成功!']); } catch (Exception $e) { DB::rollback(); return response()->json(['status'=>0, 'msg'=>$e->getMessage()]); } } /**招聘会职位状态修改 * @param $request * @return \Illuminate\Http\JsonResponse */ public function jobfairJobsDis($request) { $id = $request->id; $display = $request->display == 1 ? 2 : 1; if (!$this->jobfairJobRepository->displayswitch($id, $display)) { return response()->json(['status'=>0, 'msg'=>'招聘会职位修改状态失败!']); } return response()->json(['status'=>1, 'msg'=>'招聘会职位修改状态成功!']); } /**招聘会职位添加和修改 * @param $data * @return \Illuminate\Http\JsonResponse */ public function jobsSave($data, $user) { $message = '招聘会职位添加成功!'; if ($id = $data['id']) { $message = '招聘会职位修改成功!'; $company_id = $this->jobfairJobRepository->getColumn(['id'=>$id],'company_id'); if($company_id != $user->id) { return response()->json(['status' => 0, 'msg' => '参数错误!']); } } $comArr = ['id','companyname','created_at','audit','trade','scale','map_x','map_y','map_zoom']; $contact = ['mobile','email','qq','landline_tel','address','contact','contact_show','email_show','landline_tel_show','telephone_show']; $data_job = []; $data_contact = []; if ($data['basis_contact']) { foreach ($contact as $key => $val) { $data_contact[$val] = $user->$val; } } else { $data_contact['contact'] = $data['contact']; $data_contact['mobile'] = $data['telephone']; $data_contact['email'] = $data['email']; $data_contact['landline_tel'] = $data['landline_tel']; $data_contact['address'] = $data['address']; $data_contact['landline_tel_show'] = $data['landline_tel_show']; $data_contact['contact_show'] = $data['contact_show']; $data_contact['email_show'] = $data['email_show']; $data_contact['telephone_show'] = $data['telephone_show']; } if (!$data_contact['landline_tel'] || $data_contact['landline_tel']=="--" || $data_contact["landline_tel"]=="-") {$data_contact["landline_tel"]="";} $last_tel=substr($data_contact['landline_tel'],-1); if ($last_tel=="-"){ $new_tel = substr($data_contact['landline_tel'],0,strlen($data_contact['landline_tel'])-1); $data_contact['landline_tel']=$new_tel; } foreach ($comArr as $key => $val) { if ($val == "id") { $data_job['company_id'] = $user->id; } elseif ($val == 'companyname') { $data_job['company_name'] = $user->companyname; } elseif ($val == 'created_at') { $data_job['company_addtime'] = strtotime($user->created_at); } elseif ($val == 'audit') { $data_job['company_audit'] = $user->audit; } else { $data_job[$val] = $user->$val; } } $jobArr = ['nature','sex','age','amount','district','tag','education','experience','wage','wage_min','wage_max','jobs_content','major']; foreach ($jobArr as $key => $val) { $data_job[$val] = $data[$val]; } switch ($data_job['sex']) { case 0: $data_job['sex_cn']='不限'; break; case 1: $data_job['sex_cn']='男'; break; case 2: $data_job['sex_cn']='女'; break; } if ($data['wage']==-1) { $data_job['wage'] = -1; $data_job['wage_min']=0; $data_job['wage_max']=0; $data_job['wage_cn'] ='面议'; } else { if (intval($data_job['wage'])!=0) { $wage = explode('~', format_wage(get_category($data_job['wage']))); $data_job['wage_max'] = 0; if (isset($wage[1])) { $data_job['wage_max'] =intval($wage[1]); } $data_job['wage_min'] =intval($wage[0]); $data_job['wage_cn'] =get_category($data_job['wage']); } else { $data_job['wage_min']=$data['wage_min']; $data_job['wage_max']=$data['wage_max']; $data_job['wage_cn'] =$data['wage_min'].'~'.$data['wage_max'].'/月'; } } if ($data['syqxz_min'] && $data['syqxz_min'] < $data_job['wage_min']*0.8) { return response()->json(['status' => 0, 'msg' => '试用期薪资不得低于正式工资的80%']); } if($data['ygxs'] == 363){ $data_job['wage_cn'] = $data['wage_min'].'/小时'; } $jobcategory = explode('.', $data['jobcategory']); $data_job['topclass'] =$jobcategory[0]; $data_job['category'] =$jobcategory[1]; $data_job['subclass'] =$jobcategory[2]; $data_job['category_cn'] =get_job_category_cn($data['jobcategory']); unset($data['jobcategory']); $data_job['trade_cn'] =get_category($data_job['trade']); $data_job['major_cn'] =get_category_major($data_job['major']); $data_job['nature_cn'] =get_category($data_job['nature']); $data_job['scale_cn'] =get_category($data_job['scale']); $data_job['district'] = getDistrict($data_job['district']); $data_job['district_cn'] =get_district_cn($data_job['district']); $data_job['tag_cn'] =get_tag_cn($data_job['tag']); $data_job['education_cn'] =get_category($data_job['education']); $data_job['experience_cn'] =get_category($data_job['experience']); // $data_job['zc_cn'] =get_category($data_job['zcid']); $data_job['age'] =implode('-', $data['age']); $data_job['jobs_name'] = $data['jobs_name']; // $data_job['map_x'] = $data['map_x']; // $data_job['map_y'] = $data['map_y']; $data_job['syq'] = $data['syq']; $data_job['syqxz_min'] = $data['syqxz_min']; //$data_job['deadline'] = $data['deadline']; $data_job['ygxs'] = $data['ygxs']; $data_job['techlevel'] = $data['techlevel']; // $put_jobs = $this->jobfairPutJobRepository->getOpenPutJobs(['job_id'=>$id]); DB::beginTransaction(); try { if ($id) { $data_job['audit'] = 2; if (!$this->jobfairJobRepository->update($data_job, $id)) { throw new Exception('修改招聘会职位失败'); } if($this->jobfairJobsContactRepository->getContact(['pid'=>$id])){ if (!$this->jobfairJobsContactRepository->update($data_contact, $id)) { throw new Exception('修改联系方式失败'); } }else{ $data_contact['pid'] = $id; if (!$this->jobfairJobsContactRepository->create($data_contact)) { throw new Exception('修改联系方式失败'); } } //修改参展职位(注释 审核时同步) // if($put_jobs->isNotEmpty()){ // $jobfairJob = $this->jobfairJobRepository->find($id); // foreach ($put_jobs as $val){ // $val['jobs_name'] = $jobfairJob['jobs_name']; // $val['company_id'] = $jobfairJob['company_id']; // $val['company_name'] = $jobfairJob['company_name']; // $val['company_audit'] = $jobfairJob['company_audit']; // $val['stick'] = $jobfairJob['stick']; // $val['nature'] = $jobfairJob['nature']; // $val['nature_cn'] = $jobfairJob['nature_cn']; // $val['sex'] = $jobfairJob['sex']; // $val['sex_cn'] = $jobfairJob['sex_cn']; // $val['age'] = $jobfairJob['age']; // $val['amount'] = $jobfairJob['amount']; // $val['topclass'] = $jobfairJob['topclass']; // $val['category'] = $jobfairJob['category']; // $val['subclass'] = $jobfairJob['subclass']; // $val['category_cn'] = $jobfairJob['category_cn']; // $val['trade'] = $jobfairJob['trade']; // $val['trade_cn'] = $jobfairJob['trade_cn']; // $val['scale'] = $jobfairJob['scale']; // $val['scale_cn'] = $jobfairJob['scale_cn']; // $val['district'] = $jobfairJob['district']; // $val['district_cn'] = $jobfairJob['district_cn']; // $val['tag'] = $jobfairJob['tag']; // $val['tag_cn'] = $jobfairJob['tag_cn']; // $val['education'] = $jobfairJob['education']; // $val['education_cn'] = $jobfairJob['education_cn']; // $val['experience'] = $jobfairJob['experience']; // $val['experience_cn'] = $jobfairJob['experience_cn']; // $val['wage'] = $jobfairJob['wage']; // $val['wage_min'] = $jobfairJob['wage_min']; // $val['wage_max'] = $jobfairJob['wage_max']; // $val['wage_cn'] = $jobfairJob['wage_cn']; // $val['negotiable'] = $jobfairJob['negotiable']; // $val['audit'] = $jobfairJob['audit']; // $val['display'] = $jobfairJob['display']; // $val['click'] = $jobfairJob['click']; // $val['robot'] = $jobfairJob['robot']; // $val['map_x'] = $jobfairJob['map_x']; // $val['map_y'] = $jobfairJob['map_y']; // $val['map_zoom'] = $jobfairJob['map_zoom']; // $val['add_mode'] = $jobfairJob['add_mode']; // $val['is_entrust'] = $jobfairJob['is_entrust']; // $val['department'] = $jobfairJob['department']; // $val['major'] = $jobfairJob['major']; // $val['major_cn'] = $jobfairJob['major_cn']; // $val['zcid'] = $jobfairJob['zcid']; // $val['zc_cn'] = $jobfairJob['zc_cn']; // $val['zc_name'] = $jobfairJob['zc_name']; // $val->save(); // } // } $this->memberLogRepository->createLog($user, 1035, [$data_job['jobs_name'],$id]); } else { if (!$this->jobfairJobRepository->store($data_job)) { throw new Exception('添加招聘会职位失败'); } $data_contact['pid'] = DB::getPdo()->lastInsertId(); if (!$this->jobfairJobsContactRepository->store($data_contact)) { throw new Exception('添加联系方式失败'); } $this->memberLogRepository->createLog($user, 1034, [$data_job['jobs_name'],$data_contact['pid']]); } DB::commit(); return response()->json(['status' => 1, 'msg' => $message]); } catch (Exception $e) { DB::rollback(); return response()->json(['status' => 0, 'msg' => $e->getMessage()]); } } /**职位添加到招聘会中 * @param $request * @return array */ public function jobfairJobsToJobfair($request) { $jids = $request->y_id; if (!$jids || !$request->exid_list) { return ['state'=>0,'msg'=>'请选择职位或加入的招聘会']; } $exidArr = explode(',', $request->exid_list); $exInfo = $this->jobfairCompanyRepository->findWhereIn('id', $exidArr, ['id','company_id','jobfair_id','position_id'])->toArray(); $jobsInfo = $this->jobfairJobRepository->findWhereIn('id', $jids)->toArray(); $jobName = []; foreach ($jobsInfo as $key => $val) { if ($val['audit'] != 1) { $jobName[]=$val['jobs_name']; } } if ($jobName) { return ['state'=>0,'msg'=>'【'.implode('、', $jobName).'】,的职位状态为审核中或审核失败,无法添加至招聘会']; } DB::beginTransaction(); try { $error = ''; foreach ($exInfo as $key => $val) { $insert_data = []; foreach ($jobsInfo as $ke => $va) { $doneArr = $this->jobfairPutJobRepository->findDone(['job_id'=>$va['id'], 'exid'=>$val['id'], 'jobfair_id'=>$val['jobfair_id']]); if ($doneArr) { $error .= '【'.$doneArr->jobs->jobs_name.'】'; // return ['state'=>0,'msg'=>'【'.$doneArr->jobs->jobs_name.'】,已添加至举行的招聘会中,不可重复添加']; continue; } $this->jobfairJobRepository->update(['display'=>1],$va['id']); $insert_data['exid'] = $val['id']; $insert_data['jobfair_id'] = $val['jobfair_id']; $insert_data['position_id'] = $val['position_id']; $insert_data['job_id'] = $va['id']; $insert_data['jobs_name'] = $va['jobs_name']; $insert_data['company_id'] = $va['company_id']; $insert_data['company_name'] = $va['company_name']; $insert_data['company_audit'] = $va['company_audit']; $insert_data['stick'] = $va['stick']; $insert_data['nature'] = $va['nature']; $insert_data['nature_cn'] = $va['nature_cn']; $insert_data['sex'] = $va['sex']; $insert_data['sex_cn'] = $va['sex_cn']; $insert_data['age'] = $va['age']; $insert_data['amount'] = $va['amount']; $insert_data['topclass'] = $va['topclass']; $insert_data['category'] = $va['category']; $insert_data['subclass'] = $va['subclass']; $insert_data['category_cn'] = $va['category_cn']; $insert_data['trade'] = $va['trade']; $insert_data['trade_cn'] = $va['trade_cn']; $insert_data['scale'] = $va['scale']; $insert_data['scale_cn'] = $va['scale_cn']; $insert_data['district'] = $va['district']; $insert_data['district_cn'] = $va['district_cn']; $insert_data['tag'] = $va['tag']; $insert_data['tag_cn'] = $va['tag_cn']; $insert_data['education'] = $va['education']; $insert_data['education_cn'] = $va['education_cn']; $insert_data['experience'] = $va['experience']; $insert_data['experience_cn'] = $va['experience_cn']; $insert_data['wage'] = $va['wage']; $insert_data['wage_min'] = $va['wage_min']; $insert_data['wage_max'] = $va['wage_max']; $insert_data['wage_cn'] = $va['wage_cn']; $insert_data['negotiable'] = $va['negotiable']; $insert_data['jobs_content'] = $va['jobs_content']; $insert_data['audit'] = $va['audit']; $insert_data['display'] = 1; $insert_data['click'] = $va['click']; $insert_data['robot'] = $va['robot']; $insert_data['map_x'] = $va['map_x']; $insert_data['map_y'] = $va['map_y']; $insert_data['map_zoom'] = $va['map_zoom']; $insert_data['add_mode'] = $va['add_mode']; $insert_data['is_entrust'] = $va['is_entrust']; $insert_data['department'] = $va['department']; $insert_data['major'] = $va['major']; $insert_data['major_cn'] = $va['major_cn']; $insert_data['zcid'] = $va['zcid']; $insert_data['zc_cn'] = $va['zc_cn']; $insert_data['zc_name'] = $va['zc_name']; $insert_data['syq'] = $va['syq']; $insert_data['syqxz_min'] = $va['syqxz_min']; $insert_data['ygxs'] = $va['ygxs']; $insert_data['techlevel'] = $va['techlevel']; if (!$inser_id = $this->jobfairPutJobRepository->createData($insert_data)) { throw new \Exception($va['jobs_name'] . '添加失败'); } } } if($error){ $error .= '已添加至举行的招聘会中,不可重复添加'; } DB::commit(); } catch (\Exception $e) { DB::rollback(); return ['state'=>0,'msg'=>$e->getMessage()]; } return ['state'=>1,'msg'=>'添加成功','error'=>$error]; } /**手机端招聘会职位添加和修改 * @param $data * @return \Illuminate\Http\JsonResponse */ public function jobsSaveMobile($data, $user) { $message = '招聘会职位添加成功!'; if ($id = $data['id']) { $message = '招聘会职位修改成功!'; $company_id = $this->jobfairJobRepository->getColumn(['id'=>$id],'company_id'); if($company_id != $user->id) { return response()->json(['status' => 0, 'msg' => '参数错误!']); } } $exid = $data['exid']; $comArr = ['id','companyname','created_at','audit','trade','scale','map_x','map_y','map_zoom']; $contact = ['mobile','email','qq','landline_tel','address','contact','contact_show','email_show','landline_tel_show','telephone_show']; $data_job = []; $data_contact = []; if ($data['basis_contact']) { foreach ($contact as $key => $val) { $data_contact[$val] = $user->$val; } } else { $data_contact['contact'] = $data['contact']; $data_contact['mobile'] = $data['telephone']; $data_contact['email'] = $data['email']; $data_contact['landline_tel'] = $data['landline_tel']; $data_contact['address'] = $data['address']; $data_contact['landline_tel_show'] = $data['landline_tel_show']; $data_contact['contact_show'] = $data['contact_show']; $data_contact['email_show'] = $data['email_show']; $data_contact['telephone_show'] = $data['telephone_show']; } if ($data_contact['landline_tel']=="--" || $data_contact["landline_tel"]=="-") {$data_contact["landline_tel"]="";} $last_tel=substr($data_contact['landline_tel'],-1); if ($last_tel=="-"){ $new_tel = substr($data_contact['landline_tel'],0,strlen($data_contact['landline_tel'])-1); $data_contact['landline_tel']=$new_tel; } foreach ($comArr as $key => $val) { if ($val == "id") { $data_job['company_id'] = $user->id; } elseif ($val == 'companyname') { $data_job['company_name'] = $user->companyname; } elseif ($val == 'created_at') { $data_job['company_addtime'] = strtotime($user->created_at); } elseif ($val == 'audit') { $data_job['company_audit'] = $user->audit; } else { $data_job[$val] = $user->$val; } } $jobArr = ['nature','age','amount','district','tag','wage','wage_min','wage_max','jobs_content','syq',]; foreach ($jobArr as $key => $val) { $data_job[$val] = $data[$val]; } if ($data['wage']==-1) { $data_job['wage'] = -1; $data_job['wage_min']=0; $data_job['wage_max']=0; $data_job['wage_cn'] ='面议'; } else { if (intval($data_job['wage'])!=0) { $wage = explode('~', format_wage(get_category($data_job['wage']))); $data_job['wage_max'] = 0; if (isset($wage[1])) { $data_job['wage_max'] =intval($wage[1]); } $data_job['wage_min'] =intval($wage[0]); $data_job['wage_cn'] =get_category($data_job['wage']); } else { $data_job['wage_min']=$data['wage_min']; $data_job['wage_max']=$data['wage_max']; $data_job['wage_cn'] =$data['wage_min'].'~'.$data['wage_max'].'/月'; } } if ($data['syqxz_min'] && $data['syqxz_min'] < $data_job['wage_min']*0.8 ) { return response()->json(['status' => 0, 'msg' => '试用期薪资不得低于正式工资的80%']); } if($data['ygxs'] == 363){ $data_job['wage_cn'] = $data['wage_min'].'/小时'; } $jobcategory = explode('.', $data['jobcategory']); $data_job['topclass'] =$jobcategory[0]; $data_job['category'] =$jobcategory[1]; $data_job['subclass'] =$jobcategory[2]; $data_job['category_cn'] =get_job_category_cn($data['jobcategory']); unset($data['jobcategory']); $data_job['trade_cn'] =get_category($data_job['trade']); $data_job['nature_cn'] =get_category($data_job['nature']); $data_job['scale_cn'] =get_category($data_job['scale']); $data_job['district_cn'] =get_district_cn($data_job['district']); $data_job['tag_cn'] =get_tag_cn($data_job['tag']); $data_job['age'] =implode('-', $data['age']); $data_job['jobs_name'] = $data['jobs_name']; $data_job['syq'] = $data['syq']; $data_job['syqxz_min'] = $data['syqxz_min']; $data_job['ygxs'] = $data['ygxs']; $data_job['techlevel'] = $data['techlevel']; DB::beginTransaction(); try { if ($id) { $data_job['audit'] = 2; if (!$this->jobfairJobRepository->update($data_job, $id)) { throw new Exception('修改招聘会职位失败'); } if (!$this->jobfairJobsContactRepository->update($data_contact, $id)) { throw new Exception('修改联系方式失败'); } $this->memberLogRepository->createLog($user, 1035, [$data_job['jobs_name'],$id]); } else { if (!$this->jobfairJobRepository->store($data_job)) { throw new Exception('添加招聘会职位失败'); } $data_contact['pid'] = DB::getPdo()->lastInsertId(); if (!$this->jobfairJobsContactRepository->store($data_contact)) { throw new Exception('添加联系方式失败'); } $jobfairCompany = $this->jobfairCompanyRepository->getOne(['id'=>$exid]); if($jobfairCompany) { $this->jobfairPutJobService->addData([$data_contact['pid']],$exid,$jobfairCompany->jobfair_id,$jobfairCompany->position_id); } $this->memberLogRepository->createLog($user, 1034, [$data_job['jobs_name'],$data_contact['pid']]); } DB::commit(); return response()->json(['status' => 1, 'msg' => $message]); } catch (Exception $e) { DB::rollback(); return response()->json(['status' => 0, 'msg' => $e->getMessage()]); } } /**手机端职位添加到招聘会中 * @param $request * @return array */ public function jobfairJobsToJobfairMobile($request) { $jids = $request->jobs_id; if (!$jids || !$request->exid) { return ['status'=>0,'msg'=>'请选择职位或加入的招聘会']; } $exInfo = $this->jobfairCompanyRepository->find($request->exid, ['id','company_id','jobfair_id','position_id'])->toArray(); $jobsInfo = $this->jobfairJobRepository->findWhereIn('id', $jids)->toArray(); $fairJob_ids = $this->jobfairPutJobRepository->getFairJobIds(['exid'=>$request->exid]); $diff_ids = array_diff($fairJob_ids,$jids); DB::beginTransaction(); try { $error = ''; $insert_data = []; foreach ($jobsInfo as $ke => $va) { $doneArr = $this->jobfairPutJobRepository->findDone(['job_id'=>$va['id'], 'exid'=>$exInfo['id'], 'jobfair_id'=>$exInfo['jobfair_id']]); if ($doneArr) { $error .= '【'.$doneArr->jobs->jobs_name.'】'; continue; } $this->jobfairJobRepository->update(['display'=>1],$va['id']); $insert_data['exid'] = $exInfo['id']; $insert_data['jobfair_id'] = $exInfo['jobfair_id']; $insert_data['position_id'] = $exInfo['position_id']; $insert_data['job_id'] = $va['id']; $insert_data['jobs_name'] = $va['jobs_name']; $insert_data['company_id'] = $va['company_id']; $insert_data['company_name'] = $va['company_name']; $insert_data['company_audit'] = $va['company_audit']; $insert_data['stick'] = $va['stick']; $insert_data['nature'] = $va['nature']; $insert_data['nature_cn'] = $va['nature_cn']; $insert_data['sex'] = $va['sex']; $insert_data['sex_cn'] = $va['sex_cn']; $insert_data['age'] = $va['age']; $insert_data['amount'] = $va['amount']; $insert_data['topclass'] = $va['topclass']; $insert_data['category'] = $va['category']; $insert_data['subclass'] = $va['subclass']; $insert_data['category_cn'] = $va['category_cn']; $insert_data['trade'] = $va['trade']; $insert_data['trade_cn'] = $va['trade_cn']; $insert_data['scale'] = $va['scale']; $insert_data['scale_cn'] = $va['scale_cn']; $insert_data['district'] = $va['district']; $insert_data['district_cn'] = $va['district_cn']; $insert_data['tag'] = $va['tag']; $insert_data['tag_cn'] = $va['tag_cn']; $insert_data['education'] = $va['education']; $insert_data['education_cn'] = $va['education_cn']; $insert_data['experience'] = $va['experience']; $insert_data['experience_cn'] = $va['experience_cn']; $insert_data['wage'] = $va['wage']; $insert_data['wage_min'] = $va['wage_min']; $insert_data['wage_max'] = $va['wage_max']; $insert_data['wage_cn'] = $va['wage_cn']; $insert_data['negotiable'] = $va['negotiable']; $insert_data['jobs_content'] = $va['jobs_content']; $insert_data['audit'] = $va['audit']; $insert_data['display'] = 1; $insert_data['click'] = $va['click']; $insert_data['robot'] = $va['robot']; $insert_data['map_x'] = $va['map_x']; $insert_data['map_y'] = $va['map_y']; $insert_data['map_zoom'] = $va['map_zoom']; $insert_data['add_mode'] = $va['add_mode']; $insert_data['is_entrust'] = $va['is_entrust']; $insert_data['department'] = $va['department']; $insert_data['major'] = $va['major']; $insert_data['major_cn'] = $va['major_cn']; $insert_data['zcid'] = $va['zcid']; $insert_data['zc_cn'] = $va['zc_cn']; $insert_data['zc_name'] = $va['zc_name']; $insert_data['syq'] = $va['syq']; $insert_data['syqxz_min'] = $va['syqxz_min']; $insert_data['ygxs'] = $va['ygxs']; $insert_data['techlevel'] = $va['techlevel']; if (!$inser_id = $this->jobfairPutJobRepository->createData($insert_data)) { throw new \Exception($va['jobs_name'] . '发布失败'); } } if($diff_ids) { $this->jobfairPutJobRepository->delWhereJobs($diff_ids,['exid'=>$request->exid]); } if($error){ $error .= '已添加至举行的招聘会中,不可重复添加'; } DB::commit(); } catch (\Exception $e) { DB::rollback(); return ['status'=>0,'msg'=>$e->getMessage()]; } return ['status'=>1,'msg'=>'发布成功','error'=>$error]; } /**平板添加网络职位到招聘会中 * @param $request * @return array */ public function jobsToJobfairPad($request,$user) { $jids = $request->jobs_id; if (!$jids || !$request->exid) { return ['status'=>0,'msg'=>'请选择职位加入招聘会']; } $exInfo = $this->jobfairCompanyRepository->find($request->exid, ['id','company_id','jobfair_id','position_id'])->toArray(); $jobsInfo = $this->jobsRepository->findWhereIn('id', $jids)->toArray(); DB::beginTransaction(); try { $error = ''; $insert_data = []; foreach ($jobsInfo as $ke => $va) { //先判断职位库是否有该职位 $is_jobfiar_sync = $this->jobfairJobRepository->getCrmInfo(['jobs_name' => $va['jobs_name'], 'company_id' => $exInfo['company_id'], 'type' => 1]); if ($is_jobfiar_sync) { //如果有该职位,再去判断参展职位是否添加 $doneArr = $this->jobfairPutJobRepository->findDone(['jobs_name' => $va['jobs_name'], 'exid' => $exInfo['id']]); if ($doneArr) { $error .= '【' . $doneArr->jobs->jobs_name . '】'; continue; } else { //添加到参展职位 $insert_data['exid'] = $exInfo['id']; $insert_data['jobfair_id'] = $exInfo['jobfair_id']; $insert_data['position_id'] = $exInfo['position_id']; $insert_data['job_id'] = $is_jobfiar_sync['id']; $insert_data['jobs_name'] = $is_jobfiar_sync['jobs_name']; $insert_data['company_id'] = $is_jobfiar_sync['company_id']; $insert_data['company_name'] = $is_jobfiar_sync['company_name']; $insert_data['company_audit'] = $is_jobfiar_sync['company_audit']; $insert_data['stick'] = $is_jobfiar_sync['stick']; $insert_data['nature'] = $is_jobfiar_sync['nature']; $insert_data['nature_cn'] = $is_jobfiar_sync['nature_cn']; $insert_data['sex'] = $is_jobfiar_sync['sex']; $insert_data['sex_cn'] = $is_jobfiar_sync['sex_cn']; $insert_data['age'] = $is_jobfiar_sync['age']; $insert_data['amount'] = $is_jobfiar_sync['amount']; $insert_data['topclass'] = $is_jobfiar_sync['topclass']; $insert_data['category'] = $is_jobfiar_sync['category']; $insert_data['subclass'] = $is_jobfiar_sync['subclass']; $insert_data['category_cn'] = $is_jobfiar_sync['category_cn']; $insert_data['trade'] = $is_jobfiar_sync['trade']; $insert_data['trade_cn'] = $is_jobfiar_sync['trade_cn']; $insert_data['scale'] = $is_jobfiar_sync['scale']; $insert_data['scale_cn'] = $is_jobfiar_sync['scale_cn']; $insert_data['district'] = $is_jobfiar_sync['district']; $insert_data['district_cn'] = $is_jobfiar_sync['district_cn']; $insert_data['tag'] = $is_jobfiar_sync['tag']; $insert_data['tag_cn'] = $is_jobfiar_sync['tag_cn']; $insert_data['education'] = $is_jobfiar_sync['education']; $insert_data['education_cn'] = $is_jobfiar_sync['education_cn']; $insert_data['experience'] = $is_jobfiar_sync['experience']; $insert_data['experience_cn'] = $is_jobfiar_sync['experience_cn']; $insert_data['wage'] = $is_jobfiar_sync['wage']; $insert_data['wage_min'] = $is_jobfiar_sync['wage_min']; $insert_data['wage_max'] = $is_jobfiar_sync['wage_max']; $insert_data['wage_cn'] = $is_jobfiar_sync['wage_cn']; $insert_data['negotiable'] = $is_jobfiar_sync['negotiable']; $insert_data['jobs_content'] = $is_jobfiar_sync['jobs_content']; $insert_data['audit'] = $is_jobfiar_sync['audit']; $insert_data['display'] = $is_jobfiar_sync['display']; $insert_data['click'] = $is_jobfiar_sync['click']; $insert_data['robot'] = $is_jobfiar_sync['robot']; $insert_data['map_x'] = $is_jobfiar_sync['map_x']; $insert_data['map_y'] = $is_jobfiar_sync['map_y']; $insert_data['map_zoom'] = $is_jobfiar_sync['map_zoom']; $insert_data['add_mode'] = $is_jobfiar_sync['add_mode']; $insert_data['is_entrust'] = $is_jobfiar_sync['is_entrust']; $insert_data['department'] = $is_jobfiar_sync['department']; $insert_data['major'] = $is_jobfiar_sync['major']; $insert_data['major_cn'] = $is_jobfiar_sync['major_cn']; $insert_data['zcid'] = $is_jobfiar_sync['zcid']; $insert_data['zc_cn'] = $is_jobfiar_sync['zc_cn']; $insert_data['zc_name'] = $is_jobfiar_sync['zc_name']; $insert_data['syq'] = $is_jobfiar_sync['syq']; $insert_data['syqxz_min'] = $is_jobfiar_sync['syqxz_min']; $insert_data['ygxs'] = $is_jobfiar_sync['ygxs']; $insert_data['techlevel'] = $is_jobfiar_sync['techlevel']; if (!$inser_id = $this->jobfairPutJobRepository->createData($insert_data)) { throw new \Exception($va['jobs_name'] . '发布失败'); } } } else { $insertData = []; $jobCatact = $this->jobsContactRepository->getContactInfo(['job_id' => $va['id']]); if ($jobCatact) { $contactArr = ['contact', 'qq', 'mobile', 'notify', 'landline_tel', 'email', 'address', 'notify_mobile', 'contact_show', 'telephone_show', 'email_show', 'landline_tel_show']; //添加到职位库和参展职位 foreach ($contactArr as $key => $val) { if ($val == 'mobile') { $insertArr[$val] = $jobCatact->telephone; } elseif ($val == 'landline_tel') { if (isset($jobCatact->landline_tel)) { $insertArr[$val] = implode('-', $jobCatact->landline_tel); } else { $insertArr[$val] = '--'; } } else { $insertArr[$val] = $jobCatact->$val; } } }else{ $contactArr = ['contact', 'qq', 'mobile', 'landline_tel', 'email', 'address', 'contact_show', 'telephone_show', 'email_show', 'landline_tel_show']; foreach ($contactArr as $key => $val) { $insertArr[$val] = $user[$val] ? $user[$val] : ''; } } $jobfairArr = [ 'jobs_name', 'company_id', 'company_name', 'company_addtime', 'company_audit', 'stick', 'amount', 'negotiable', 'jobs_content', 'audit', 'click', 'display', 'robot', 'map_x', 'map_y', 'map_zoom', 'add_mode', 'department', 'nature', 'sex', 'age', 'topclass', 'category', 'subclass', 'trade', 'scale', 'district', 'education', 'experience', 'wage', 'wage_max', 'wage_min', 'ygxs', 'syq', 'syqxz_min', 'techlevel' ]; foreach ($jobfairArr as $key => $val) { $insertData[$val] = $va[$val]; } if ($va['topclass'] && $va['category'] && $va['subclass']) { $insertData['category_cn'] = get_job_category_cn($va['topclass'] . "." . $va['category'] . '.' . $va['subclass']); } else { $insertData['category_cn'] = ''; } if (!empty($insertData['age'])) { $insertData['age'] = implode('-', $insertData['age']); } $insertData['nature_cn'] = $va['nature'] ? get_category($va['nature']) : ''; $insertData['trade_cn'] = $va['trade'] ? get_category($va['trade']) : ''; $insertData['scale_cn'] = $va['scale'] ? get_category($va['scale']) : ''; $insertData['education_cn'] = $va['education'] ? get_category($va['education']) : ''; $insertData['experience_cn'] = $va['experience'] ? get_category($va['experience']) : ""; if (intval($insertData['wage']) == 0) { if ($insertData['wage_max']) { $insertData['wage_cn'] = $insertData['wage_min'] . '~' . $insertData['wage_max'] . '/月'; } else { $insertData['wage_cn'] = $insertData['wage_min'] . '/月以上'; } } elseif (intval($insertData['wage']) == -1) { $insertData['wage_cn'] = '面议'; } else { $insertData['wage_cn'] = $va['wage'] ? get_category($va['wage']) : ''; } if ($va['ygxs'] == 363) { $insertData['wage_cn'] = $insertData['wage_min'] . '/小时'; $insertData['wage_min'] = $insertData['wage_min'] * 100; $insertData['wage_max'] = $insertData['wage_max'] * 100; } $insertData['ygxs'] = $va['ygxs'] ? $va['ygxs'] : ''; $insertData['syq'] = $va['syq'] ? $va['syq'] : ''; $insertData['syqxz_min'] = $va['syqxz_min'] ? $va['syqxz_min'] : ''; $insertData['techlevel'] = $va['techlevel'] ? $va['techlevel'] : ''; $insertData['district_cn'] = get_district_cn($va['district']); if ($va['tag'][0]) { $insertData['tag_cn'] = get_tag_cn(implode(',', $va['tag'])); } else { $insertData['tag_cn'] = ''; } switch ($va['sex']) { case 1: $insertData['sex_cn'] = '男'; break; case 2: $insertData['sex_cn'] = '女'; break; case 0: $insertData['sex_cn'] = '不限'; break; } $insertData['type'] = 1; if (!$jobfair_jobid = $this->jobfairJobRepository->create($insertData)) { throw new \Exception('转入招聘会职位库失败!'); } $insertData['job_id'] = $jobfair_jobid->id; $insertData['exid'] = $exInfo['id']; $insertData['jobfair_id'] = $exInfo['jobfair_id']; $insertData['position_id'] = $exInfo['position_id']; unset($insertData['company_addtime']); unset($insertData['type']); if (!$this->jobfairPutJobRepository->createData($insertData)) { throw new \Exception('转入招聘会职位库失败!'); } if ($insertArr) { $insertArr['pid'] = $jobfair_jobid->id; $this->jobfairJobsContactRepository->create($insertArr); } } } if ($error) { $error .= '已添加至举行的招聘会中,不可重复添加'; } DB::commit(); } catch (\Exception $e) { DB::rollback(); return ['status'=>0,'msg'=>$e->getMessage()]; } return ['status'=>1,'msg'=>'发布成功','error'=>$error]; } public function isOwn($idsArr,$user) { $idsArr = is_array($idsArr) ? $idsArr : explode(',',$idsArr); $jobsIdArr = $this->jobfairJobRepository->getPluck(['company_id'=>$user->id],'id')->toArray(); if(array_diff($idsArr,$jobsIdArr)) { throw new ResponseException('抱歉,您只能操作自己的招聘会职位!'); } } }