JobfairCompanyController.php 32 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810
  1. <?php
  2. namespace App\Admin\Controllers\Jobfair;
  3. use App\Http\Controllers\Controller;
  4. use App\Models\Company;
  5. use App\Models\Jobfair\FloorplanStand;
  6. use App\Models\Jobfair\Jobfair;
  7. use App\Models\Jobfair\JobfairCompany;
  8. use App\Models\Jobfair\JobfairFloorplan;
  9. use App\Models\Jobfair\JobfairPutJob;
  10. use App\Models\MembersHandsel;
  11. use App\Models\MembersPoint;
  12. use App\Models\MembersSetmeal;
  13. use App\Models\Pms;
  14. use App\Models\Subsite;
  15. use Encore\Admin\Controllers\HasResourceActions;
  16. use Encore\Admin\Facades\Admin;
  17. use Encore\Admin\Form;
  18. use Encore\Admin\Grid;
  19. use Encore\Admin\Layout\Content;
  20. use Encore\Admin\Show;
  21. use Illuminate\Http\Request;
  22. use App\Admin\Exports\Jobfair\CompanyExport;
  23. use App\Services\Common\SmsService;
  24. use Aix\Sms\Contracts\Smser;
  25. use App\Services\Common\EmailService;
  26. class JobfairCompanyController extends Controller
  27. {
  28. use HasResourceActions;
  29. protected $smsService;
  30. protected $emailService;
  31. public function __construct(SmsService $smsService,EmailService $emailService)
  32. {
  33. $this->smsService = $smsService;
  34. $this->emailService = $emailService;
  35. }
  36. /**
  37. * Index interface.
  38. *
  39. * @param Content $content
  40. * @return Content
  41. */
  42. public function index(Content $content,Request $request)
  43. {
  44. $is_export = $request->has('_export_');
  45. $jobfair_id = isset($request['jobfair_companys']['jobfair_id']) ? $request['jobfair_companys']['jobfair_id'] : false;
  46. $jobfair_id1 = isset($request->jobfair_id) ? $request->jobfair_id : false;
  47. $grid=$this->grid($jobfair_id,$jobfair_id1,$is_export)->render();
  48. return $content
  49. ->header('参会企业')
  50. ->description('')
  51. ->body(view('admin.jobfair.jobfair_company')->with(['grid'=>$grid]));
  52. }
  53. /**
  54. * Show interface.
  55. *
  56. * @param mixed $id
  57. * @param Content $content
  58. * @return Content
  59. */
  60. public function show($id, Content $content)
  61. {
  62. return $content
  63. ->header('参会企业详情')
  64. ->description('')
  65. ->body($this->detail($id));
  66. }
  67. /**
  68. * Edit interface.
  69. *
  70. * @param mixed $id
  71. * @param Content $content
  72. * @return Content
  73. */
  74. public function edit($id, Content $content, Request $request)
  75. {
  76. return $content
  77. ->header('参会企业编辑')
  78. ->description('')
  79. ->body($this->editForm($request, $id)->edit($id));
  80. }
  81. /**
  82. * Create interface.
  83. *
  84. * @param Content $content
  85. * @return Content
  86. */
  87. public function create(Content $content)
  88. {
  89. return $content
  90. ->header('参会企业创建')
  91. ->description('')
  92. ->body($this->createForm());
  93. }
  94. /**
  95. * Make a grid builder.
  96. *
  97. * @return Grid
  98. */
  99. protected function grid($jobfair_id,$jobfair_id1,$is_export)
  100. {
  101. $grid = new Grid(new JobfairCompany);
  102. if($is_export){
  103. $grid->model()->when(get_subsite_id()>0, function ($query) {
  104. $query->whereHas('jobfair', function ($query) {
  105. $query->where('subsite_id', get_subsite_id());
  106. });
  107. })->orderByRaw("FIELD(audit, 2,1,3)")->orderBy('updated_at', 'desc');
  108. }elseif($jobfair_id || $jobfair_id1){
  109. $grid->model()->joinFloorplanStand()->when(get_subsite_id()>0, function ($query) {
  110. $query->whereHas('jobfair', function ($query) {
  111. $query->where('subsite_id', get_subsite_id());
  112. });
  113. })->when($jobfair_id1==true && $jobfair_id==false,function ($query) use ($jobfair_id1){
  114. $query->where('jobfair_companys.jobfair_id',$jobfair_id1);
  115. })
  116. ->select('jobfair_companys.*','jobfair_floorplan_stands.sortindex')
  117. ->orderBy("jobfair_floorplan_stands.sortindex");
  118. }else{
  119. $grid->model()->when(get_subsite_id()>0, function ($query) {
  120. $query->whereHas('jobfair', function ($query) {
  121. $query->where('subsite_id', get_subsite_id());
  122. });
  123. })->orderByRaw("FIELD(audit, 2,1,3)")->orderBy('updated_at', 'desc');
  124. }
  125. $grid->column('companys.companyname', '参会企业')->display(function ($companyname) {
  126. return '<a href="'.route('jobs.company',['id'=>$this->company_id]).'" target="_blank">'.$companyname.'</a>';
  127. })->width(200);
  128. $grid->jobs_name('企业职位')->display(function () {
  129. if($this->jobfairPutJob->isEmpty()){
  130. return '暂无职位';
  131. }else{
  132. return '<a href="'.route('jobfairPutJobs.index',['jobfair_id'=>$this->jobfair_id,'company_id'=>$this->company_id]).'">点击查看</a>';
  133. }
  134. });
  135. $grid->column('jobfair.holddate_start', '举办时间')->display(function ($holddate_start) {
  136. if($holddate_start){
  137. return date('Y-m-d H:i',$holddate_start);
  138. }else{
  139. return '';
  140. }
  141. });
  142. $grid->column('jobfair.title', '招聘会标题')->display(function ($jobfair_title) {
  143. return '<a href="'.route('jobfair.show.com',$this->jobfair_id).'" target="_blank">'.$jobfair_title.'</a>';
  144. })->width(200);
  145. $grid->type('签到状态')->display(function ($type) {
  146. if ($type==0) {
  147. return '<span>未签到</span>';
  148. } elseif ($type==1) {
  149. return '<span style="color: #FF3300">迟到</span>';
  150. } elseif ($type==2) {
  151. return '<span style="color: #FF3300">早退</span>';
  152. } elseif ($type==3) {
  153. return '<span style="color: #FF3300">迟到/早退</span>';
  154. } elseif ($type==4) {
  155. return ' <span style="color: #009900">已签到</span>';
  156. }
  157. });
  158. // $grid->column('jobfairFloorPlanStands.floorplan_id', '展位图名称')->display(function ($floorplan_id) {
  159. // $JobfairFloorplan = JobfairFloorplan::find($floorplan_id);
  160. // return isset($JobfairFloorplan->name) ? $JobfairFloorplan->name : '未知';
  161. // })->width(200);
  162. $grid->column('jobfairFloorPlanStands.name', '展位号');
  163. $grid->audit('预订状态')->display(function ($audit) {
  164. if ($audit==1) {
  165. return ' <span style="color: #009900">预定成功</span>';
  166. } elseif ($audit==2) {
  167. return'<span style="color:#FF6600">等待确认</span>';
  168. } else {
  169. return '<span style="color: #FF3300">审核未通过</span>';
  170. }
  171. });
  172. $grid->pay_type('支付方式')->display(function ($pay_type) {
  173. if ($pay_type==1) {
  174. return '<span style="color: #009900">场次</span>';
  175. } elseif ($pay_type==2) {
  176. return '<span style="color: #009900">积分</span>';
  177. } else {
  178. return '<span style="color: #009900">公益</span>';
  179. }
  180. });
  181. $grid->etype('预订方式')->display(function ($etype) {
  182. if ($etype==1) {
  183. return '<span style="color: #009900">在线预订</span>';
  184. } elseif ($etype==2) {
  185. return '<span style="color: #009900">电话预定</span>';
  186. } else {
  187. return '<span style="color: #009900">现场预定</span>';
  188. }
  189. });
  190. if(get_subsite_open()){
  191. $grid->column('jobfair.subsite_id', '所属分站')->display(function ($subsite_id) {
  192. if ($subsite_id) {
  193. $Subsite = Subsite::find($subsite_id);
  194. return isset($Subsite->sitename) ? $Subsite->sitename : '未知';
  195. }
  196. return '总站';
  197. });
  198. }
  199. $grid->created_at('创建时间');
  200. // $grid->disableCreateButton();
  201. $grid->actions(function ($actions) use ($grid) {
  202. if (Admin::user()->can('company_manager_bussiness')) {
  203. $actions->append("<button class='btn btn-primary btn-xs business' id=".$actions->row['company_id'].">业务</button>");
  204. }
  205. if (Admin::user()->can('jobfair_companys_audit')) {
  206. $actions->append("<button class='btn btn-primary btn-xs jobaudit' data-code=".$actions->row['id'].">审核</button>");
  207. }
  208. if (Admin::user()->can('jobfair_companys_edit')) {
  209. $actions->disableEdit(false);
  210. }
  211. if (Admin::user()->can('jobfair_companys_delete')) {
  212. $actions->disableDelete(false);
  213. }
  214. });
  215. if (Admin::user()->can('jobfair_companys_delete')) {
  216. $grid->tools(function ($tools) {
  217. $tools->batch(function ($batch) {
  218. $batch->disableDelete(false);
  219. });
  220. });
  221. $grid->disableRowSelector(false);
  222. }
  223. if (Admin::user()->can('jobfair_companys_export')) {
  224. $grid->disableExport(false); //显示导出按钮
  225. $grid->exporter(new CompanyExport()); //传入自己在第1步创建的导出类
  226. }
  227. if (Admin::user()->can('jobfair_companys_create')) {
  228. $grid->disableCreateButton(false);
  229. }
  230. $grid->tools(function ($tools) {
  231. if (Admin::user()->can('jobfair_companys_audit')) {
  232. $but = <<<EOT
  233. <div class="btn-group" data-toggle="buttons">
  234. <label class="btn btn-google btn-sm" id="Audit_Companys" title="参会状态">
  235. <i class="fa fa-audio-description"></i>
  236. <input type="radio" class="user-gender">审核企业
  237. </label>
  238. </div>
  239. EOT;
  240. $tools->append($but);
  241. }
  242. if (Admin::user()->can('jobfair_companys_signed')) {
  243. $signed = <<<EOT
  244. <div class="btn-group" data-toggle="buttons">
  245. <label class="btn btn-google btn-sm" id="signed" title="签到">
  246. <i class="fa fa-audio-description"></i>
  247. <input type="radio" class="user-gender">签到
  248. </label>
  249. </div>
  250. EOT;
  251. $tools->append($signed);
  252. }
  253. });
  254. $grid->filter(function ($filter) {
  255. // 去掉默认的id过滤器
  256. $filter->disableIdFilter();
  257. $filter->column(1/2, function ($filter) {
  258. $filter->like('companys.companyname', '参会企业');
  259. $filter->equal('jobfair_companys.jobfair_id', '招聘会标题')->select(Jobfair::select('title', 'id')->when(get_subsite_id()>0,function ($query){
  260. $query->whereHas('subsites', function ($query) {
  261. $query->where('subsite_jobfairs.subsite_id', get_subsite_id())->where('subsites.effective', 1);
  262. });
  263. })->pluck('title', 'id')->all());
  264. $filter->equal('jobfair_companys.audit', '预订状态')->select([
  265. 1=>'预定成功',
  266. 2=>'等待确认',
  267. 3=>'审核未通过',
  268. ]);
  269. $filter->equal('jobfair_companys.type', '签到状态')->select([
  270. 0=>'未签到',
  271. 1=>'迟到',
  272. 2=>'早退',
  273. 3=>'迟到/早退',
  274. 4=>'已签到',
  275. ]);
  276. if( get_subsite_id() == 0 && get_subsite_open()){
  277. $filter->equal('jobfair.subsite_id', '所属分站')->select(array_column(get_all_subsite(), 'sitename', 'id'));
  278. }
  279. });
  280. $filter->column(1/2, function ($filter) {
  281. $filter->equal('jobfair_companys.pay_type', '支付方式')->select([
  282. 1=>'场次',
  283. 2=>'积分',
  284. 3=>'公益',
  285. ]);
  286. $filter->like('jobfair_companys.position', '预定展位');
  287. $filter->equal('jobfair_companys.etype', '预订方式')->select([
  288. 1=>'在线预订',
  289. 2=>'电话预定',
  290. 3=>'现场预定'
  291. ]);
  292. $filter->where(function ($query) {
  293. switch ($this->input) {
  294. case 3:
  295. $query->whereRaw("jobfair_companys.updated_at>='".date('Y-m-d H:i:s', strtotime('-3 day'))."'");
  296. break;
  297. case 7:
  298. $query->whereRaw("jobfair_companys.updated_at>='".date('Y-m-d H:i:s', strtotime('-7 day'))."'");
  299. break;
  300. case 30:
  301. $query->whereRaw("jobfair_companys.updated_at>='".date('Y-m-d H:i:s', strtotime('-30 day'))."'");
  302. break;
  303. }
  304. }, '更新时间', 'updated_at')->select([
  305. 3=>'三天内',
  306. 7=>'一周内',
  307. 30=>'一月内',
  308. ]);
  309. });
  310. });
  311. return $grid;
  312. }
  313. /**
  314. * Make a show builder.
  315. *
  316. * @param mixed $id
  317. * @return Show
  318. */
  319. protected function detail($id)
  320. {
  321. $show = new Show(JobfairCompany::findOrFail($id));
  322. $jobfairCompany = JobfairCompany::findOrFail($id);
  323. $show->id('ID');
  324. $show->companys()->companyname('参会企业')->as(function ($companys){
  325. return $companys->companyname;
  326. });
  327. $show->jobfair()->title('招聘会标题')->as(function ($jobfair){
  328. return $jobfair->title;
  329. });
  330. $show->type('签到状态')->as(function ($type) {
  331. if ($type==0) {
  332. return '未签到';
  333. } elseif ($type==1) {
  334. return '迟到';
  335. } elseif ($type==2) {
  336. return '早退';
  337. } elseif ($type==3) {
  338. return '迟到/早退';
  339. } elseif ($type==4) {
  340. return '已签到';
  341. }
  342. });
  343. $show->position('展位号');
  344. $show->audit('预订状态')->as(function ($audit) {
  345. if ($audit==1) {
  346. return '预定成功';
  347. } elseif ($audit==2) {
  348. return '等待确认';
  349. } else {
  350. return '审核未通过';
  351. }
  352. });
  353. $show->pay_type('支付方式')->as(function ($pay_type) {
  354. if ($pay_type==1) {
  355. return '场次';
  356. } elseif ($pay_type==2) {
  357. return '积分';
  358. } else {
  359. return '公益';
  360. }
  361. });
  362. $show->etype('预订方式')->as(function ($etype) {
  363. if ($etype==1) {
  364. return '在线预订';
  365. } elseif ($etype==2) {
  366. return '电话预定';
  367. } else {
  368. return '现场预定';
  369. }
  370. });
  371. $show->subsite_id('所属分站')->as(function () use ($jobfairCompany) {
  372. $subsite_id = Jobfair::findOrFail($jobfairCompany->jobfair_id)->subsite_id;
  373. if ($subsite_id) {
  374. $Subsite = Subsite::find($subsite_id);
  375. return isset($Subsite->sitename) ? $Subsite->sitename : '未知';
  376. }
  377. return '总站';
  378. });
  379. $show->created_at('创建时间');
  380. $show->updated_at('更新时间');
  381. return $show;
  382. }
  383. /**
  384. * Make a form builder.
  385. *
  386. * @return Form
  387. */
  388. protected function form()
  389. {
  390. $form = new Form(new JobfairCompany);
  391. $form->display('ID');
  392. $form->display('Created at');
  393. $form->display('Updated at');
  394. return $form;
  395. }
  396. protected function createForm()
  397. {
  398. $form = new Form(new JobfairCompany);
  399. $form->select('company_id', '企业名称')->options(
  400. Company::where('audit', 1)->pluck('companyname', 'id')->all()
  401. )->rules([
  402. 'required',
  403. ])->setMustMark();
  404. $form->select('jobfair_id', '招聘会名称')->options(
  405. Jobfair::where('display', 1)->where('predetermined_status',1)->where('holddate_end', '>', time())->pluck('title', 'id')->all()
  406. )->load('position', route('floorplans.floorPlans'))->rules([
  407. 'required',
  408. ])->setMustMark();
  409. $form->select('position', '展位图名称')->load('position_id', route('floorplans.floorPlansId'))->rules([
  410. 'required',
  411. ])->setMustMark();
  412. $form->select('position_id', '展位号')->rules([
  413. 'required',
  414. ])->setMustMark();
  415. $form->select('etype', '预定方式')->options([3=>'现场预定'])->default(3)->help('现场预定不消耗场次或积分!');
  416. $form->hidden('pay_type')->default(3);
  417. $form->saving(function (Form $form){
  418. $company_id = $form->company_id;
  419. $Jobfair = Jobfair::findOrFail($form->jobfair_id);
  420. if ($Jobfair->more_stand==0) {
  421. $count = JobfairCompany::where(['company_id'=>$company_id,'jobfair_id'=>$form->jobfair_id])->count();
  422. if ($count>=1) {
  423. admin_toastr('同一家企业不可预订一场招聘会多个展位!', 'error');
  424. return redirect(route('jobfair.company.create'));
  425. }
  426. }
  427. });
  428. $form->saved(function (Form $form) {
  429. $model = $form->model();
  430. $model->audit = 1;
  431. $model->position = FloorplanStand::findOrFail($form->position_id)->name;
  432. $model->note = '该企业现场预定展位!';
  433. $model->type = 0;
  434. $model->signed_time = time();
  435. $model->save();
  436. });
  437. return $form;
  438. }
  439. /**
  440. * Make a form builder.
  441. *
  442. * @return Form
  443. */
  444. protected function editForm($request, $id)
  445. {
  446. $form = new Form(new JobfairCompany);
  447. $jonfairCompany = JobfairCompany::findOrFail($id);
  448. $request->session()->put('jobfair_plan_id', $jonfairCompany->jobfair_id);
  449. $form->display('companys.companyname', '企业名称')->setMustMark();
  450. $form->display('jobfair.title', '招聘会名称')->setMustMark();
  451. $FloorplanStand = FloorplanStand::with('jobfair_floorPlan')->where('id', $jonfairCompany->position_id)->first();
  452. $stand_id = isset($FloorplanStand->jobfair_floorPlan->id) ? $FloorplanStand->jobfair_floorPlan->id : '';
  453. $form->select('position_floor_plans', '展位图名称')->options(JobfairFloorplan::where('jobfair_id', $jonfairCompany->jobfair_id)->pluck('name', 'id')->all())->load('position_id', route('floorplans.floorPlansId'))->default($stand_id)->rules([
  454. 'required',
  455. ])->setMustMark();
  456. $list = $this->positionColumn($jonfairCompany->jobfair_id,$stand_id);
  457. $list[$jonfairCompany->position_id] = $jonfairCompany->position;
  458. $form->select('position_id', '展位号')->options($list)->default($jonfairCompany->position_id)->rules([
  459. 'required',
  460. ])->setMustMark();
  461. $form->hidden('position');
  462. $form->saving(function (Form $form) {
  463. $form->position = FloorplanStand::findOrFail($form->position_id)->name;
  464. });
  465. return $form;
  466. }
  467. /**
  468. * Store a newly created resource in storage.
  469. *
  470. * @return mixed
  471. */
  472. public function store()
  473. {
  474. return $this->createForm()->store();
  475. }
  476. /**
  477. * Update the specified resource in storage.
  478. *
  479. * @param int $id
  480. *
  481. * @return \Illuminate\Http\Response|\Symfony\Component\HttpFoundation\Response
  482. */
  483. public function update(Request $request, $id)
  484. {
  485. $data = $request->all();
  486. unset($data['position_floor_plans']);
  487. return $this->editForm($request, $id)->update($id, $data);
  488. }
  489. public function auditCompanys(Request $request)
  490. {
  491. $id = $request->id;
  492. $form = new \Encore\Admin\Widgets\Form();
  493. $form->action(route('jobfair.company.auditr'));
  494. $form->disableReset();
  495. $form->hidden('id', 'ID')->default($id);
  496. $form->radio('audit', '审核')->options([1=>'预订成功',3=>'审核未通过'])->default(1);
  497. $form->textarea('note', '备注');
  498. $form->html('<label style="color: rgb(0, 153, 0)"><input type="checkbox" name="pms_notice" value="1" checked="checked">站内信通知</label>');
  499. return json_encode(['html'=>$form->render(),'detail'=>'审核企业']);
  500. }
  501. public function auditCompanysR(Request $request)
  502. {
  503. $id = $request->id;
  504. $audit = $request->audit;
  505. $note = $request->note;
  506. $pms_notice = $request->pms_notice;
  507. if($audit==3){
  508. if (empty($note)) {
  509. admin_toastr('参会企业审核未通过必须填写备注!', 'error');
  510. return back();
  511. }
  512. }
  513. $arr = array_filter(explode(',', $id));
  514. if (empty($arr)) {
  515. admin_toastr('请选择参会企业', 'error');
  516. return back();
  517. }
  518. $arr_id = [];
  519. $JobfairCompany = JobfairCompany::whereHas('jobfair',function ($query){
  520. $query->where('holddate_end', '>', time());
  521. })->whereIn('id', $arr)->get();
  522. if($JobfairCompany->isEmpty()){
  523. admin_toastr('招聘会已过期', 'error');
  524. return back();
  525. }
  526. \DB::beginTransaction();
  527. try {
  528. foreach ($JobfairCompany as $key => $val) {
  529. if ($audit==1) { //预订成功
  530. if ($val->audit==2) {
  531. $arr_id[] = $val->id;
  532. if($val->companys->mobile && $val->companys->mobile_audit == 1){
  533. $this->smsService->sendSms(
  534. $val->companys->mobile,
  535. Smser::TEMPLATE_JOBFAIR_APPLY_OK,
  536. [
  537. 'jobfair_name'=>$val->jobfair->title,
  538. 'jobfair_time'=>date('Y-m-d H:i',$val->jobfair->holddate_start),
  539. 'jobfair_addr'=>$val->jobfair->address,
  540. 'position'=>$val->jobfairFloorPlanStands->name,
  541. ]);
  542. }
  543. if($val->companys->email && $val->companys->email_audit == 1){
  544. $this->emailService->sendMail($val->companys->email, EmailService::TEMPLATE_JOBFAIR_APPLY_OK,
  545. ['title'=>'招聘会预订成功'],
  546. [
  547. 'jobfair_name'=>$val->jobfair->title,
  548. 'jobfair_time'=>date('Y-m-d H:i',$val->jobfair->holddate_start),
  549. 'jobfair_addr'=>$val->jobfair->address,
  550. 'position'=>$val->jobfairFloorPlanStands->name,
  551. ]
  552. );
  553. }
  554. }
  555. } else { //审核未通过。
  556. if ($val->audit==2 || $val->audit==1) {
  557. $arr_id[] = $val->id;
  558. if($val->companys->mobile && $val->companys->mobile_audit == 1){
  559. $this->smsService->sendSms(
  560. $val->companys->mobile,
  561. Smser::TEMPLATE_JOBFAIR_APPLY_ERROR,
  562. [
  563. 'jobfair_name'=>$val->jobfair->title
  564. ]);
  565. }
  566. if($val->companys->email && $val->companys->email_audit == 1){
  567. $this->emailService->sendMail($val->companys->email, EmailService::TEMPLATE_JOBFAIR_APPLY_ERROR, ['title'=>'招聘会预订失败'], ['jobfair_name'=>$val->jobfair->title]);
  568. }
  569. }
  570. if ($val->jobfair) {
  571. if ($val->pay_type==1) {//场次
  572. MembersSetmeal::where('uid', $val->company_id)->where('utype', 1)
  573. ->increment('jobfair_num', $val->jobfair->jobsfair_num);
  574. }elseif ($val->pay_type==2) { //积分
  575. MembersPoint::where('uid', $val->company_id)->where('utype', 1)
  576. ->increment('points', $val->jobfair->predetermined_point);
  577. MembersHandsel::create([
  578. 'uid'=>$val->company_id,
  579. 'utype'=>1,
  580. 'htype_cn'=>'返还预定招聘会的积分',
  581. 'operate'=>1,
  582. 'points'=>$val->jobfair->predetermined_point
  583. ]);
  584. }
  585. }
  586. }
  587. }
  588. if ($arr_id) {
  589. $newReult = JobfairCompany::with(['jobfair', 'companys'])->whereHas('jobfair')
  590. ->whereHas('companys')->whereIn('id', $arr_id)->get();
  591. foreach ($newReult as $key => $val) {
  592. if ($val->jobfair && $val->companys) {
  593. $newDate[$key]['utype'] = $val->companys->utype;
  594. $newDate[$key]['msgtype'] = 2;
  595. $newDate[$key]['msgfromuid'] = 0;
  596. $newDate[$key]['msgfrom'] = 'admin';
  597. $newDate[$key]['msgtoname'] = $val->companys->username;
  598. $newDate[$key]['msgtouid'] = $val->companys->id;
  599. $title = strstr($val->jobfair->title, '招聘会') ? $val->jobfair->title : $val->jobfair->title . '招聘会';
  600. if ($audit == 1) {
  601. $newDate[$key]['message'] = '您申请的<a href="' . route('jobfair.show', $val->jobfair->id) . '">' . $title . '</a>' . $val->position . '展位已审核通过,请尽快提交招聘会职位。';
  602. } else {
  603. $newDate[$key]['message'] = '您申请的<a href="' . route('jobfair.show', $val->jobfair->id) . '">' . $title . '</a>' . $val->position . '展位已审核失败,请尽快查收。失败原因(' . $note . ')';
  604. }
  605. $newDate[$key]['created_at'] = date('Y-m-d H:i:s');
  606. $newDate[$key]['updated_at'] = date('Y-m-d H:i:s');
  607. }
  608. }
  609. if ($pms_notice && $newDate) {
  610. Pms::insert($newDate);
  611. }
  612. JobfairCompany::whereIn('id', $arr_id)->update(['audit' => $audit, 'note' => $note]);
  613. } else {
  614. admin_toastr('操作失败', 'error');
  615. return back();
  616. }
  617. \DB::commit();
  618. admin_toastr('操作成功', 'success');
  619. } catch (\Exception $e) {
  620. \DB::rollback();
  621. admin_toastr('操作失败', $e->getMessage());
  622. }
  623. return back();
  624. }
  625. public function signedCompanys(Request $request)
  626. {
  627. $id = $request->id;
  628. $arr = array_filter(explode(',', $id));
  629. if (empty($id)) {
  630. return response()->json(['code'=>0,'info'=>'数据异常!']);
  631. }
  632. if (empty($arr)) {
  633. return response()->json(['code'=>0,'info'=>'请选择参会企业!']);
  634. }
  635. $need_id_n = [];
  636. $need_id_p = [];
  637. $JobfairCompany = JobfairCompany::with(['jobfair'=>function ($query) {
  638. $query->where('holddate_start', '<=', time()+7200)->where('holddate_end', '>=', time())->orWhere('holddate_start', '<=', time());
  639. }])->whereIn('id', $arr)->where('type', 0)->get();
  640. foreach ($JobfairCompany as $key => $val) {
  641. if ($val->jobfair) {
  642. if (time()>=$val->jobfair->holddate_start && time()<=$val->jobfair->holddate_end) {
  643. $need_id_n[] = $val->id;
  644. } else {
  645. if (time()<$val->jobfair->holddate_start) {
  646. if (($val->jobfair->holddate_start-time())<7200) {
  647. $need_id_p[] = $val->id;
  648. }
  649. }
  650. }
  651. }
  652. }
  653. if (!$need_id_n&&!$need_id_p) {
  654. return response()->json(['code'=>0,'info'=>'该企业已签到过或招聘会已结束或签到时间不在招聘会开始时间2小时之内!']);
  655. }
  656. \DB::beginTransaction();
  657. try {
  658. if ($need_id_n) {
  659. JobfairCompany::whereIn('id', $need_id_n)->update(['type'=>1,'signed_time'=>time()]);
  660. }
  661. if ($need_id_p) {
  662. JobfairCompany::whereIn('id', $need_id_p)->update(['type'=>4,'signed_time'=>time()]);
  663. }
  664. \DB::commit();
  665. return response()->json(['code'=>1,'info'=>'签到成功!']);
  666. } catch (\Exception $e) {
  667. \DB::rollback();
  668. return response()->json(['code'=>0,'info'=>'签到失败!']);
  669. }
  670. }
  671. public function floorPlans(Request $request)
  672. {
  673. $jobfair_id = $request->get('q');
  674. $request->session()->put('jobfair_plan_id', $jobfair_id);
  675. return JobfairFloorplan::where('jobfair_id', $jobfair_id)->get(['id','name as text']);
  676. }
  677. public function floorPlansId(Request $request)
  678. {
  679. $jobfair_id = $request->session()->get('jobfair_plan_id', '');
  680. $floor_plan_id = $request->get('q');
  681. if ($jobfair_id) {
  682. $standFreeList = $this->lastJobfairPosition($jobfair_id, $floor_plan_id);
  683. return FloorplanStand::whereIN('id', $standFreeList)->get(['id','name as text']);
  684. }
  685. return [];
  686. }
  687. protected function lastJobfairPosition($jobfair_id, $floor_plan_id)
  688. {
  689. $standAudit = 0;
  690. $standAuditList = [];
  691. $standSuccess = 0;
  692. $standSuccessList = [];
  693. $standLock = 0;
  694. $standLockList = [];
  695. $standFreeList = [];
  696. $standNum = 0;
  697. $FloorplanStand = FloorplanStand::where('jobfair_id', $jobfair_id)->where('floorplan_id', $floor_plan_id)->get();
  698. $JobfairCompany = JobfairCompany::where('jobfair_id', $jobfair_id)->whereIn('audit', [1,2])->get();
  699. if (!$FloorplanStand->isEmpty()) {
  700. foreach ($FloorplanStand as $key => $val) {
  701. $standFreeList[]=$val->id;
  702. // if ($val->type==2) {
  703. // $standLock++;
  704. // $standLockList[]=$val->id;
  705. // }
  706. // if ($val->type==1) {
  707. // $standFreeList[]=$val->id;
  708. // }
  709. $standNum++;
  710. }
  711. }
  712. if (!$JobfairCompany->isEmpty()) {
  713. foreach ($JobfairCompany as $key => $val) {
  714. if ($val->audit==1) {
  715. $standSuccess++;
  716. $standSuccessList[]=$val->position_id;
  717. } elseif ($val->audit==2) {
  718. $standAudit++;
  719. $standAuditList[]=$val->position_id;
  720. }
  721. }
  722. }
  723. return array_diff($standFreeList, array_unique(array_merge($standSuccessList, $standAuditList)));
  724. }
  725. public function positionColumn($jobfair_id, $floor_plan_id)
  726. {
  727. $standFreeList = $this->lastJobfairPosition($jobfair_id, $floor_plan_id);
  728. return FloorplanStand::whereIN('id', $standFreeList)->pluck('name as text','id')->toArray();
  729. }
  730. public function destroy($id)
  731. {
  732. $ids = array();
  733. if ($id) {
  734. $ids = explode(',', $id);
  735. }
  736. if (!$ids) {
  737. return admin_toastr('请勾选需要删除的参展职位', 'error');
  738. }
  739. \DB::beginTransaction();
  740. try {
  741. JobfairCompany::whereIn('id', $ids)->delete();
  742. JobfairPutJob::whereIn('exid', $ids)->delete();
  743. $data = [
  744. 'status' => true,
  745. 'message' => '删除成功!',
  746. ];
  747. \DB::commit();
  748. return response()->json($data);
  749. } catch (\Exception $e) {
  750. \DB::rollback();
  751. $data = [
  752. 'status' => false,
  753. 'message' => '删除失败!',
  754. ];
  755. return response()->json($data);
  756. }
  757. }
  758. }