JobfairoutJobsService.php 17 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388
  1. <?php
  2. /**
  3. * Created by PhpStorm.
  4. * User: wuzhenke
  5. * Date: 2019/1/22
  6. * Time: 15:38
  7. */
  8. namespace App\Services\Jobfairout;
  9. use App\Exceptions\ResponseException;
  10. use App\Repositories\CompanyContactsRepository;
  11. use App\Repositories\Jobfairout\JobfairoutCompanyRepository;
  12. use App\Repositories\Jobfair\JobfairJobsContactRepository;
  13. use App\Repositories\Jobfair\JobfairJobRepository;
  14. use App\Repositories\Jobfairout\JobfairoutPutJobRepository;
  15. use App\Repositories\MemberLogRepository;
  16. use Exception;
  17. use Illuminate\Support\Facades\DB;
  18. class JobfairoutJobsService
  19. {
  20. protected $jobfairJobRepository;
  21. protected $jobfairJobsContactRepository;
  22. protected $memberLogRepository;
  23. protected $jobfairoutCompanyRepository;
  24. protected $jobfairoutPutJobRepository;
  25. protected $companyContactsRepository;
  26. /**
  27. * JobfairJobsService constructor.
  28. * @param $jobfairJobRepository
  29. * @param $jobfairJobsContactRepository
  30. * @param $jobfairoutCompanyRepository
  31. * @param $jobfairoutPutJobRepository
  32. * @param $companyContactsRepository
  33. */
  34. public function __construct(JobfairJobRepository $jobfairJobRepository, CompanyContactsRepository $companyContactsRepository, JobfairoutPutJobRepository $jobfairoutPutJobRepository, JobfairoutCompanyRepository $jobfairoutCompanyRepository, JobfairJobsContactRepository $jobfairJobsContactRepository, MemberLogRepository $memberLogRepository)
  35. {
  36. $this->jobfairJobRepository = $jobfairJobRepository;
  37. $this->jobfairJobsContactRepository = $jobfairJobsContactRepository;
  38. $this->memberLogRepository = $memberLogRepository;
  39. $this->jobfairoutCompanyRepository = $jobfairoutCompanyRepository;
  40. $this->jobfairoutPutJobRepository = $jobfairoutPutJobRepository;
  41. $this->companyContactsRepository = $companyContactsRepository;
  42. }
  43. /**招聘会职位库
  44. * @return array
  45. */
  46. public function jobfairoutJobsList()
  47. {
  48. $user = auth('web-company')->user();
  49. $where = [
  50. 'company_id'=>$user->id,
  51. 'type'=>2,
  52. ];
  53. $list = $this->jobfairJobRepository->getJobList($where);
  54. return $res = [
  55. 'list'=>$list,
  56. ];
  57. }
  58. /**招聘会职位添加
  59. * @return array
  60. */
  61. public function jobfairoutJobsAdd()
  62. {
  63. $user = auth('web-company')->user();
  64. $user->landline =explode('-', $user->landline_tel);
  65. $jobfairJobContact = $this->jobfairJobsContactRepository->getContact(['pid'=>'']);
  66. $companyContact = $this->companyContactsRepository->getContacts(['company_id'=>$user->id]);
  67. return $result = [
  68. 'company' =>$user,
  69. 'jobfairJobContact' =>$jobfairJobContact,
  70. 'companyContact' =>$companyContact,
  71. ];
  72. }
  73. /**招聘会职位修改
  74. * @param $id
  75. * @return array|bool
  76. */
  77. public function jobfairoutJobsEdit($id, $user)
  78. {
  79. $jobfair_job = $this->jobfairJobRepository->editJob($id);
  80. if (!$jobfair_job || $jobfair_job->company_id != $user->id) {
  81. return false;
  82. }
  83. $companyContact = $this->companyContactsRepository->getContacts(['company_id'=>$user->id]);
  84. $jobfair_job->tag = explode(',', $jobfair_job->tag);
  85. $jobfair_job->age = explode('-', $jobfair_job->age);
  86. $jobfair_job->jobsContact->landline_tel =$jobfair_job->jobsContact->landline_tel?explode('-', $jobfair_job->jobsContact->landline_tel):[];
  87. return $result = [
  88. 'company' =>$user,
  89. 'jobsInfo'=>$jobfair_job,
  90. 'companyContact'=>$companyContact,
  91. ];
  92. }
  93. /**招聘会职位删除
  94. * @param $request
  95. * @return \Illuminate\Http\JsonResponse
  96. */
  97. public function jobfairoutJobsDel($request)
  98. {
  99. $user = auth('web-company')->user();
  100. $id = $request->y_id;
  101. $where['company_id'] = $user->id;
  102. if (!is_array($id)) {
  103. $ids = explode(',', $id);
  104. } else {
  105. $ids = $id;
  106. }
  107. DB::beginTransaction();
  108. try {
  109. if (!$this->jobfairJobRepository->deleteJobs($where, $ids)) {
  110. throw new Exception('招聘会职位删除失败!');
  111. }
  112. $this->jobfairJobsContactRepository->deleteJobContact($ids);
  113. $this->jobfairPutJobRepository->delJobIds($ids);
  114. $this->memberLogRepository->createLog($user, 1036, [implode(',', $ids)]);
  115. DB::commit();
  116. return response()->json(['status'=>1, 'msg'=>'招聘会职位删除成功!']);
  117. } catch (Exception $e) {
  118. DB::rollback();
  119. return response()->json(['status'=>0, 'msg'=>$e->getMessage()]);
  120. }
  121. }
  122. /**招聘会职位添加和修改
  123. * @param $data
  124. * @return \Illuminate\Http\JsonResponse
  125. */
  126. public function jobsSave($data, $user)
  127. {
  128. $message = '招聘会职位添加成功!';
  129. if ($id = $data['id']) {
  130. $message = '招聘会职位修改成功!';
  131. $company_id = $this->jobfairJobRepository->getColumn(['id'=>$id],'company_id');
  132. if($company_id != $user->id) {
  133. return response()->json(['status' => 0, 'msg' => '参数错误!']);
  134. }
  135. }
  136. $comArr = ['id','companyname','created_at','audit','trade','scale','map_x','map_y','map_zoom'];
  137. $contact = ['mobile','email','qq','landline_tel','address','contact','contact_show','email_show','landline_tel_show','telephone_show'];
  138. $data_job = [];
  139. $data_contact = [];
  140. if ($data['basis_contact']) {
  141. foreach ($contact as $key => $val) {
  142. $data_contact[$val] = $user->$val;
  143. }
  144. } else {
  145. $data_contact['contact'] = $data['contact'];
  146. $data_contact['mobile'] = $data['telephone'];
  147. $data_contact['email'] = $data['email'];
  148. $data_contact['landline_tel'] = $data['landline_tel'];
  149. $data_contact['address'] = $data['address'];
  150. $data_contact['landline_tel_show'] = $data['landline_tel_show'];
  151. $data_contact['contact_show'] = $data['contact_show'];
  152. $data_contact['email_show'] = $data['email_show'];
  153. $data_contact['telephone_show'] = $data['telephone_show'];
  154. }
  155. foreach ($comArr as $key => $val) {
  156. if ($val == "id") {
  157. $data_job['company_id'] = $user->id;
  158. } elseif ($val == 'companyname') {
  159. $data_job['company_name'] = $user->companyname;
  160. } elseif ($val == 'created_at') {
  161. $data_job['company_addtime'] = strtotime($user->created_at);
  162. } elseif ($val == 'audit') {
  163. $data_job['company_audit'] = $user->audit;
  164. } else {
  165. $data_job[$val] = $user->$val;
  166. }
  167. }
  168. $jobArr = ['nature','sex','age','amount','district','tag','education','experience','wage','wage_min','wage_max','jobs_content','major','zcid','zc_name'];
  169. foreach ($jobArr as $key => $val) {
  170. $data_job[$val] = $data[$val];
  171. }
  172. $data_job['type'] = 2;
  173. switch ($data_job['sex']) {
  174. case 0:
  175. $data_job['sex_cn']='不限';
  176. break;
  177. case 1:
  178. $data_job['sex_cn']='男';
  179. break;
  180. case 2:
  181. $data_job['sex_cn']='女';
  182. break;
  183. }
  184. if ($data['wage']==-1) {
  185. $data_job['wage'] = -1;
  186. $data_job['wage_min']=0;
  187. $data_job['wage_max']=0;
  188. $data_job['wage_cn'] ='面议';
  189. } else {
  190. if (intval($data_job['wage'])!=0) {
  191. $wage = explode('~', format_wage(get_category($data_job['wage'])));
  192. $data_job['wage_max'] = 0;
  193. if (isset($wage[1])) {
  194. $data_job['wage_max'] =intval($wage[1]);
  195. }
  196. $data_job['wage_min'] =intval($wage[0]);
  197. $data_job['wage_cn'] =get_category($data_job['wage']);
  198. } else {
  199. $data_job['wage_min']=$data['wage_min'];
  200. $data_job['wage_max']=$data['wage_max'];
  201. $data_job['wage_cn'] =$data['wage_min'].'~'.$data['wage_max'].'/月';
  202. }
  203. }
  204. if ($data['syqxz_min'] && $data['syqxz_min'] < $data_job['wage_min']*0.8) {
  205. return response()->json(['status' => 0, 'msg' => '试用期薪资不得低于正式工资的80%']);
  206. }
  207. if($data['ygxs'] == 363){
  208. $data_job['wage_cn'] = $data['wage_min'].'/小时';
  209. }
  210. $jobcategory = explode('.', $data['jobcategory']);
  211. $data_job['topclass'] =$jobcategory[0];
  212. $data_job['category'] =$jobcategory[1];
  213. $data_job['subclass'] =$jobcategory[2];
  214. $data_job['category_cn'] =get_job_category_cn($data['jobcategory']);
  215. unset($data['jobcategory']);
  216. $data_job['trade_cn'] =get_category($data_job['trade']);
  217. $data_job['major_cn'] =get_category_major($data_job['major']);
  218. $data_job['nature_cn'] =get_category($data_job['nature']);
  219. $data_job['scale_cn'] =get_category($data_job['scale']);
  220. $data_job['district'] = getDistrict($data_job['district']);
  221. $data_job['district_cn'] =get_district_cn($data_job['district']);
  222. $data_job['tag_cn'] =get_tag_cn($data_job['tag']);
  223. $data_job['education_cn'] =get_category($data_job['education']);
  224. $data_job['experience_cn'] =get_category($data_job['experience']);
  225. $data_job['zc_cn'] =get_category($data_job['zcid']);
  226. $data_job['age'] =implode('-', $data['age']);
  227. $data_job['jobs_name'] = $data['jobs_name'];
  228. $data_job['syq'] = $data['syq'];
  229. $data_job['syqxz_min'] = $data['syqxz_min'];
  230. $data_job['ygxs'] = $data['ygxs'];
  231. $data_job['techlevel'] = $data['techlevel'];
  232. DB::beginTransaction();
  233. try {
  234. if ($id) {
  235. $data_job['audit'] = 2;
  236. if (!$this->jobfairJobRepository->update($data_job, $id)) {
  237. throw new Exception('修改招聘会职位失败');
  238. }
  239. if (!$this->jobfairJobsContactRepository->update($data_contact, $id)) {
  240. throw new Exception('修改联系方式失败');
  241. }
  242. $this->memberLogRepository->createLog($user, 1035, [$id]);
  243. } else {
  244. if (!$this->jobfairJobRepository->store($data_job)) {
  245. throw new Exception('添加招聘会职位失败');
  246. }
  247. $data_contact['pid'] = DB::getPdo()->lastInsertId();
  248. if (!$this->jobfairJobsContactRepository->store($data_contact)) {
  249. throw new Exception('添加联系方式失败');
  250. }
  251. $this->memberLogRepository->createLog($user, 1034, $data_contact['pid']);
  252. }
  253. DB::commit();
  254. return response()->json(['status' => 1, 'msg' => $message]);
  255. } catch (Exception $e) {
  256. DB::rollback();
  257. return response()->json(['status' => 0, 'msg' => $e->getMessage()]);
  258. }
  259. }
  260. /**职位添加到招聘会中
  261. * @param $request
  262. * @return array
  263. */
  264. public function jobfairoutJobsToJobfair($request)
  265. {
  266. $jids = $request->y_id;
  267. if (!$jids || !$request->exid_list) {
  268. return ['state'=>0,'msg'=>'请选择职位或加入的招聘会'];
  269. }
  270. $exidArr = explode(',', $request->exid_list);
  271. $exInfo = $this->jobfairoutCompanyRepository->findWhereIn('id', $exidArr, ['id','company_id','jobfair_id'])->toArray();
  272. $jobsInfo = $this->jobfairJobRepository->findWhereIn('id', $jids)->toArray();
  273. $jobName = [];
  274. foreach ($jobsInfo as $key => $val) {
  275. if ($val['audit'] != 1) {
  276. $jobName[]=$val['jobs_name'];
  277. }
  278. }
  279. if ($jobName) {
  280. return ['state'=>0,'msg'=>'【'.implode('、', $jobName).'】的职位状态为审核中或审核失败,无法添加至招聘会'];
  281. }
  282. DB::beginTransaction();
  283. try {
  284. $error = '';
  285. foreach ($exInfo as $key => $val) {
  286. $insert_data = [];
  287. foreach ($jobsInfo as $ke => $va) {
  288. $doneArr = $this->jobfairoutPutJobRepository->findDone(['job_id'=>$va['id'], 'exid'=>$val['id'], 'jobfair_id'=>$val['jobfair_id']]);
  289. if ($doneArr) {
  290. $error .= '【'.$doneArr->jobs->jobs_name.'】';
  291. // return ['state'=>0,'msg'=>'【'.$doneArr->jobs->jobs_name.'】,已添加至举行的招聘会中,不可重复添加'];
  292. continue;
  293. }
  294. $insert_data['exid'] = $val['id'];
  295. $insert_data['jobfair_id'] = $val['jobfair_id'];
  296. $insert_data['job_id'] = $va['id'];
  297. $insert_data['jobs_name'] = $va['jobs_name'];
  298. $insert_data['company_id'] = $va['company_id'];
  299. $insert_data['company_name'] = $va['company_name'];
  300. $insert_data['company_audit'] = $va['company_audit'];
  301. $insert_data['stick'] = $va['stick'];
  302. $insert_data['nature'] = $va['nature'];
  303. $insert_data['nature_cn'] = $va['nature_cn'];
  304. $insert_data['sex'] = $va['sex'];
  305. $insert_data['sex_cn'] = $va['sex_cn'];
  306. $insert_data['age'] = $va['age'];
  307. $insert_data['amount'] = $va['amount'];
  308. $insert_data['topclass'] = $va['topclass'];
  309. $insert_data['category'] = $va['category'];
  310. $insert_data['subclass'] = $va['subclass'];
  311. $insert_data['category_cn'] = $va['category_cn'];
  312. $insert_data['trade'] = $va['trade'];
  313. $insert_data['trade_cn'] = $va['trade_cn'];
  314. $insert_data['scale'] = $va['scale'];
  315. $insert_data['scale_cn'] = $va['scale_cn'];
  316. $insert_data['district'] = $va['district'];
  317. $insert_data['district_cn'] = $va['district_cn'];
  318. $insert_data['tag'] = $va['tag'];
  319. $insert_data['tag_cn'] = $va['tag_cn'];
  320. $insert_data['education'] = $va['education'];
  321. $insert_data['education_cn'] = $va['education_cn'];
  322. $insert_data['experience'] = $va['experience'];
  323. $insert_data['experience_cn'] = $va['experience_cn'];
  324. $insert_data['wage'] = $va['wage'];
  325. $insert_data['wage_min'] = $va['wage_min'];
  326. $insert_data['wage_max'] = $va['wage_max'];
  327. $insert_data['wage_cn'] = $va['wage_cn'];
  328. $insert_data['jobs_content'] = $va['jobs_content'];
  329. $insert_data['audit'] = $va['audit'];
  330. $insert_data['display'] = $va['display'];
  331. $insert_data['click'] = $va['click'];
  332. $insert_data['robot'] = $va['robot'];
  333. $insert_data['map_x'] = $va['map_x'];
  334. $insert_data['map_y'] = $va['map_y'];
  335. $insert_data['map_zoom'] = $va['map_zoom'];
  336. $insert_data['add_mode'] = $va['add_mode'];
  337. $insert_data['is_entrust'] = $va['is_entrust'];
  338. $insert_data['department'] = $va['department'];
  339. $insert_data['major'] = $va['major'];
  340. $insert_data['major_cn'] = $va['major_cn'];
  341. $insert_data['zcid'] = $va['zcid'];
  342. $insert_data['zc_cn'] = $va['zc_cn'];
  343. $insert_data['zc_name'] = $va['zc_name'];
  344. $insert_data['syq'] = $va['syq'];
  345. $insert_data['syqxz_min'] = $va['syqxz_min'];
  346. $insert_data['ygxs'] = $va['ygxs'];
  347. $insert_data['techlevel'] = $va['techlevel'];
  348. if (!$inser_id = $this->jobfairoutPutJobRepository->create($insert_data)) {
  349. throw new \Exception($va['jobs_name'] . '添加失败');
  350. }
  351. }
  352. }
  353. if($error){
  354. $error .= '已添加至举行的招聘会中,不可重复添加';
  355. }
  356. DB::commit();
  357. } catch (\Exception $e) {
  358. DB::rollback();
  359. return ['state'=>0,'msg'=>$e->getMessage()];
  360. }
  361. return ['state'=>1,'msg'=>'添加成功','error'=>$error];
  362. }
  363. public function isOwn($idsArr,$user)
  364. {
  365. $jobsIdArr = $this->jobfairJobRepository->getPluck(['company_id'=>$user->id],'id')->toArray();
  366. if(array_diff($idsArr,$jobsIdArr))
  367. {
  368. throw new ResponseException('抱歉,您只能操作自己的招聘会职位!');
  369. }
  370. }
  371. }