123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961 |
- <?php
- /**
- * Created by PhpStorm.
- * User: wuzhenke
- * Date: 2019/1/22
- * Time: 15:38
- */
- namespace App\Services\Jobfair;
- use App\Exceptions\ResponseException;
- use App\Repositories\CompanyContactsRepository;
- use App\Repositories\Jobfair\JobfairCompanyRepository;
- use App\Repositories\Jobfair\JobfairJobsContactRepository;
- use App\Repositories\Jobfair\JobfairJobRepository;
- use App\Repositories\Jobfair\JobfairPutJobRepository;
- use App\Repositories\MemberLogRepository;
- use Exception;
- use Illuminate\Support\Facades\DB;
- use App\Repositories\JobsRepository;
- use App\Repositories\JobsContactRepository;
- use App\Services\Jobfair\JobfairPutJobService;
- class JobfairJobsService
- {
- protected $jobfairJobRepository;
- protected $jobfairJobsContactRepository;
- protected $memberLogRepository;
- protected $jobfairCompanyRepository;
- protected $jobfairPutJobRepository;
- protected $companyContactsRepository;
- protected $jobsRepository;
- protected $jobsContactRepository;
- protected $jobfairPutJobService;
- /**
- * JobfairJobsService constructor.
- * @param $jobfairJobRepository
- * @param $jobfairJobsContactRepository
- * @param $jobfairCompanyRepository
- * @param $jobfairPutJobRepository
- * @param $companyContactsRepository
- * @param $jobsRepository
- * @param $jobsContactRepository
- * @param $jobfairPutJobService
- */
- public function __construct(JobfairJobRepository $jobfairJobRepository, CompanyContactsRepository $companyContactsRepository, JobfairPutJobRepository $jobfairPutJobRepository, JobfairCompanyRepository $jobfairCompanyRepository, JobfairJobsContactRepository $jobfairJobsContactRepository, MemberLogRepository $memberLogRepository,JobsRepository $jobsRepository, JobsContactRepository $jobsContactRepository,JobfairPutJobService $jobfairPutJobService)
- {
- $this->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('抱歉,您只能操作自己的招聘会职位!');
- }
- }
- }
|