smsService = $smsService;
$this->emailService = $emailService;
}
/**
* Index interface.
*
* @param Content $content
* @return Content
*/
public function index(Content $content,Request $request)
{
$is_export = $request->has('_export_');
$jobfair_id = isset($request['jobfair_companys']['jobfair_id']) ? $request['jobfair_companys']['jobfair_id'] : false;
$jobfair_id1 = isset($request->jobfair_id) ? $request->jobfair_id : false;
$grid=$this->grid($jobfair_id,$jobfair_id1,$is_export)->render();
return $content
->header('参会企业')
->description('')
->body(view('admin.jobfair.jobfair_company')->with(['grid'=>$grid]));
}
/**
* Show interface.
*
* @param mixed $id
* @param Content $content
* @return Content
*/
public function show($id, Content $content)
{
return $content
->header('参会企业详情')
->description('')
->body($this->detail($id));
}
/**
* Edit interface.
*
* @param mixed $id
* @param Content $content
* @return Content
*/
public function edit($id, Content $content, Request $request)
{
return $content
->header('参会企业编辑')
->description('')
->body($this->editForm($request, $id)->edit($id));
}
/**
* Create interface.
*
* @param Content $content
* @return Content
*/
public function create(Content $content)
{
return $content
->header('参会企业创建')
->description('')
->body($this->createForm());
}
/**
* Make a grid builder.
*
* @return Grid
*/
protected function grid($jobfair_id,$jobfair_id1,$is_export)
{
$grid = new Grid(new JobfairCompany);
if($is_export){
$grid->model()->when(get_subsite_id()>0, function ($query) {
$query->whereHas('jobfair', function ($query) {
$query->where('subsite_id', get_subsite_id());
});
})->orderByRaw("FIELD(audit, 2,1,3)")->orderBy('updated_at', 'desc');
}elseif($jobfair_id || $jobfair_id1){
$grid->model()->joinFloorplanStand()->when(get_subsite_id()>0, function ($query) {
$query->whereHas('jobfair', function ($query) {
$query->where('subsite_id', get_subsite_id());
});
})->when($jobfair_id1==true && $jobfair_id==false,function ($query) use ($jobfair_id1){
$query->where('jobfair_companys.jobfair_id',$jobfair_id1);
})
->select('jobfair_companys.*','jobfair_floorplan_stands.sortindex')
->orderBy("jobfair_floorplan_stands.sortindex");
}else{
$grid->model()->when(get_subsite_id()>0, function ($query) {
$query->whereHas('jobfair', function ($query) {
$query->where('subsite_id', get_subsite_id());
});
})->orderByRaw("FIELD(audit, 2,1,3)")->orderBy('updated_at', 'desc');
}
$grid->column('companys.companyname', '参会企业')->display(function ($companyname) {
return ''.$companyname.'';
})->width(200);
$grid->jobs_name('企业职位')->display(function () {
if($this->jobfairPutJob->isEmpty()){
return '暂无职位';
}else{
return '点击查看';
}
});
$grid->column('jobfair.holddate_start', '举办时间')->display(function ($holddate_start) {
if($holddate_start){
return date('Y-m-d H:i',$holddate_start);
}else{
return '';
}
});
$grid->column('jobfair.title', '招聘会标题')->display(function ($jobfair_title) {
return ''.$jobfair_title.'';
})->width(200);
$grid->type('签到状态')->display(function ($type) {
if ($type==0) {
return '未签到';
} elseif ($type==1) {
return '迟到';
} elseif ($type==2) {
return '早退';
} elseif ($type==3) {
return '迟到/早退';
} elseif ($type==4) {
return ' 已签到';
}
});
// $grid->column('jobfairFloorPlanStands.floorplan_id', '展位图名称')->display(function ($floorplan_id) {
// $JobfairFloorplan = JobfairFloorplan::find($floorplan_id);
// return isset($JobfairFloorplan->name) ? $JobfairFloorplan->name : '未知';
// })->width(200);
$grid->column('jobfairFloorPlanStands.name', '展位号');
$grid->audit('预订状态')->display(function ($audit) {
if ($audit==1) {
return ' 预定成功';
} elseif ($audit==2) {
return'等待确认';
} else {
return '审核未通过';
}
});
$grid->pay_type('支付方式')->display(function ($pay_type) {
if ($pay_type==1) {
return '场次';
} elseif ($pay_type==2) {
return '积分';
} else {
return '公益';
}
});
$grid->etype('预订方式')->display(function ($etype) {
if ($etype==1) {
return '在线预订';
} elseif ($etype==2) {
return '电话预定';
} else {
return '现场预定';
}
});
if(get_subsite_open()){
$grid->column('jobfair.subsite_id', '所属分站')->display(function ($subsite_id) {
if ($subsite_id) {
$Subsite = Subsite::find($subsite_id);
return isset($Subsite->sitename) ? $Subsite->sitename : '未知';
}
return '总站';
});
}
$grid->created_at('创建时间');
// $grid->disableCreateButton();
$grid->actions(function ($actions) use ($grid) {
if (Admin::user()->can('company_manager_bussiness')) {
$actions->append("");
}
if (Admin::user()->can('jobfair_companys_audit')) {
$actions->append("");
}
if (Admin::user()->can('jobfair_companys_edit')) {
$actions->disableEdit(false);
}
if (Admin::user()->can('jobfair_companys_delete')) {
$actions->disableDelete(false);
}
});
if (Admin::user()->can('jobfair_companys_delete')) {
$grid->tools(function ($tools) {
$tools->batch(function ($batch) {
$batch->disableDelete(false);
});
});
$grid->disableRowSelector(false);
}
if (Admin::user()->can('jobfair_companys_export')) {
$grid->disableExport(false); //显示导出按钮
$grid->exporter(new CompanyExport()); //传入自己在第1步创建的导出类
}
if (Admin::user()->can('jobfair_companys_create')) {
$grid->disableCreateButton(false);
}
$grid->tools(function ($tools) {
if (Admin::user()->can('jobfair_companys_audit')) {
$but = <<
EOT;
$tools->append($but);
}
if (Admin::user()->can('jobfair_companys_signed')) {
$signed = <<
EOT;
$tools->append($signed);
}
});
$grid->filter(function ($filter) {
// 去掉默认的id过滤器
$filter->disableIdFilter();
$filter->column(1/2, function ($filter) {
$filter->like('companys.companyname', '参会企业');
$filter->equal('jobfair_companys.jobfair_id', '招聘会标题')->select(Jobfair::select('title', 'id')->when(get_subsite_id()>0,function ($query){
$query->whereHas('subsites', function ($query) {
$query->where('subsite_jobfairs.subsite_id', get_subsite_id())->where('subsites.effective', 1);
});
})->pluck('title', 'id')->all());
$filter->equal('jobfair_companys.audit', '预订状态')->select([
1=>'预定成功',
2=>'等待确认',
3=>'审核未通过',
]);
$filter->equal('jobfair_companys.type', '签到状态')->select([
0=>'未签到',
1=>'迟到',
2=>'早退',
3=>'迟到/早退',
4=>'已签到',
]);
if( get_subsite_id() == 0 && get_subsite_open()){
$filter->equal('jobfair.subsite_id', '所属分站')->select(array_column(get_all_subsite(), 'sitename', 'id'));
}
});
$filter->column(1/2, function ($filter) {
$filter->equal('jobfair_companys.pay_type', '支付方式')->select([
1=>'场次',
2=>'积分',
3=>'公益',
]);
$filter->like('jobfair_companys.position', '预定展位');
$filter->equal('jobfair_companys.etype', '预订方式')->select([
1=>'在线预订',
2=>'电话预定',
3=>'现场预定'
]);
$filter->where(function ($query) {
switch ($this->input) {
case 3:
$query->whereRaw("jobfair_companys.updated_at>='".date('Y-m-d H:i:s', strtotime('-3 day'))."'");
break;
case 7:
$query->whereRaw("jobfair_companys.updated_at>='".date('Y-m-d H:i:s', strtotime('-7 day'))."'");
break;
case 30:
$query->whereRaw("jobfair_companys.updated_at>='".date('Y-m-d H:i:s', strtotime('-30 day'))."'");
break;
}
}, '更新时间', 'updated_at')->select([
3=>'三天内',
7=>'一周内',
30=>'一月内',
]);
});
});
return $grid;
}
/**
* Make a show builder.
*
* @param mixed $id
* @return Show
*/
protected function detail($id)
{
$show = new Show(JobfairCompany::findOrFail($id));
$jobfairCompany = JobfairCompany::findOrFail($id);
$show->id('ID');
$show->companys()->companyname('参会企业')->as(function ($companys){
return $companys->companyname;
});
$show->jobfair()->title('招聘会标题')->as(function ($jobfair){
return $jobfair->title;
});
$show->type('签到状态')->as(function ($type) {
if ($type==0) {
return '未签到';
} elseif ($type==1) {
return '迟到';
} elseif ($type==2) {
return '早退';
} elseif ($type==3) {
return '迟到/早退';
} elseif ($type==4) {
return '已签到';
}
});
$show->position('展位号');
$show->audit('预订状态')->as(function ($audit) {
if ($audit==1) {
return '预定成功';
} elseif ($audit==2) {
return '等待确认';
} else {
return '审核未通过';
}
});
$show->pay_type('支付方式')->as(function ($pay_type) {
if ($pay_type==1) {
return '场次';
} elseif ($pay_type==2) {
return '积分';
} else {
return '公益';
}
});
$show->etype('预订方式')->as(function ($etype) {
if ($etype==1) {
return '在线预订';
} elseif ($etype==2) {
return '电话预定';
} else {
return '现场预定';
}
});
$show->subsite_id('所属分站')->as(function () use ($jobfairCompany) {
$subsite_id = Jobfair::findOrFail($jobfairCompany->jobfair_id)->subsite_id;
if ($subsite_id) {
$Subsite = Subsite::find($subsite_id);
return isset($Subsite->sitename) ? $Subsite->sitename : '未知';
}
return '总站';
});
$show->created_at('创建时间');
$show->updated_at('更新时间');
return $show;
}
/**
* Make a form builder.
*
* @return Form
*/
protected function form()
{
$form = new Form(new JobfairCompany);
$form->display('ID');
$form->display('Created at');
$form->display('Updated at');
return $form;
}
protected function createForm()
{
$form = new Form(new JobfairCompany);
$form->select('company_id', '企业名称')->options(
Company::where('audit', 1)->pluck('companyname', 'id')->all()
)->rules([
'required',
])->setMustMark();
$form->select('jobfair_id', '招聘会名称')->options(
Jobfair::where('display', 1)->where('predetermined_status',1)->where('holddate_end', '>', time())->pluck('title', 'id')->all()
)->load('position', route('floorplans.floorPlans'))->rules([
'required',
])->setMustMark();
$form->select('position', '展位图名称')->load('position_id', route('floorplans.floorPlansId'))->rules([
'required',
])->setMustMark();
$form->select('position_id', '展位号')->rules([
'required',
])->setMustMark();
$form->select('etype', '预定方式')->options([3=>'现场预定'])->default(3)->help('现场预定不消耗场次或积分!');
$form->hidden('pay_type')->default(3);
$form->saving(function (Form $form){
$company_id = $form->company_id;
$Jobfair = Jobfair::findOrFail($form->jobfair_id);
if ($Jobfair->more_stand==0) {
$count = JobfairCompany::where(['company_id'=>$company_id,'jobfair_id'=>$form->jobfair_id])->count();
if ($count>=1) {
admin_toastr('同一家企业不可预订一场招聘会多个展位!', 'error');
return redirect(route('jobfair.company.create'));
}
}
});
$form->saved(function (Form $form) {
$model = $form->model();
$model->audit = 1;
$model->position = FloorplanStand::findOrFail($form->position_id)->name;
$model->note = '该企业现场预定展位!';
$model->type = 0;
$model->signed_time = time();
$model->save();
});
return $form;
}
/**
* Make a form builder.
*
* @return Form
*/
protected function editForm($request, $id)
{
$form = new Form(new JobfairCompany);
$jonfairCompany = JobfairCompany::findOrFail($id);
$request->session()->put('jobfair_plan_id', $jonfairCompany->jobfair_id);
$form->display('companys.companyname', '企业名称')->setMustMark();
$form->display('jobfair.title', '招聘会名称')->setMustMark();
$FloorplanStand = FloorplanStand::with('jobfair_floorPlan')->where('id', $jonfairCompany->position_id)->first();
$stand_id = isset($FloorplanStand->jobfair_floorPlan->id) ? $FloorplanStand->jobfair_floorPlan->id : '';
$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([
'required',
])->setMustMark();
$list = $this->positionColumn($jonfairCompany->jobfair_id,$stand_id);
$list[$jonfairCompany->position_id] = $jonfairCompany->position;
$form->select('position_id', '展位号')->options($list)->default($jonfairCompany->position_id)->rules([
'required',
])->setMustMark();
$form->hidden('position');
$form->saving(function (Form $form) {
$form->position = FloorplanStand::findOrFail($form->position_id)->name;
});
return $form;
}
/**
* Store a newly created resource in storage.
*
* @return mixed
*/
public function store()
{
return $this->createForm()->store();
}
/**
* Update the specified resource in storage.
*
* @param int $id
*
* @return \Illuminate\Http\Response|\Symfony\Component\HttpFoundation\Response
*/
public function update(Request $request, $id)
{
$data = $request->all();
unset($data['position_floor_plans']);
return $this->editForm($request, $id)->update($id, $data);
}
public function auditCompanys(Request $request)
{
$id = $request->id;
$form = new \Encore\Admin\Widgets\Form();
$form->action(route('jobfair.company.auditr'));
$form->disableReset();
$form->hidden('id', 'ID')->default($id);
$form->radio('audit', '审核')->options([1=>'预订成功',3=>'审核未通过'])->default(1);
$form->textarea('note', '备注');
$form->html('');
return json_encode(['html'=>$form->render(),'detail'=>'审核企业']);
}
public function auditCompanysR(Request $request)
{
$id = $request->id;
$audit = $request->audit;
$note = $request->note;
$pms_notice = $request->pms_notice;
if($audit==3){
if (empty($note)) {
admin_toastr('参会企业审核未通过必须填写备注!', 'error');
return back();
}
}
$arr = array_filter(explode(',', $id));
if (empty($arr)) {
admin_toastr('请选择参会企业', 'error');
return back();
}
$arr_id = [];
$JobfairCompany = JobfairCompany::whereHas('jobfair',function ($query){
$query->where('holddate_end', '>', time());
})->whereIn('id', $arr)->get();
if($JobfairCompany->isEmpty()){
admin_toastr('招聘会已过期', 'error');
return back();
}
\DB::beginTransaction();
try {
foreach ($JobfairCompany as $key => $val) {
if ($audit==1) { //预订成功
if ($val->audit==2) {
$arr_id[] = $val->id;
if($val->companys->mobile && $val->companys->mobile_audit == 1){
$this->smsService->sendSms(
$val->companys->mobile,
Smser::TEMPLATE_JOBFAIR_APPLY_OK,
[
'jobfair_name'=>$val->jobfair->title,
'jobfair_time'=>date('Y-m-d H:i',$val->jobfair->holddate_start),
'jobfair_addr'=>$val->jobfair->address,
'position'=>$val->jobfairFloorPlanStands->name,
]);
}
if($val->companys->email && $val->companys->email_audit == 1){
$this->emailService->sendMail($val->companys->email, EmailService::TEMPLATE_JOBFAIR_APPLY_OK,
['title'=>'招聘会预订成功'],
[
'jobfair_name'=>$val->jobfair->title,
'jobfair_time'=>date('Y-m-d H:i',$val->jobfair->holddate_start),
'jobfair_addr'=>$val->jobfair->address,
'position'=>$val->jobfairFloorPlanStands->name,
]
);
}
}
} else { //审核未通过。
if ($val->audit==2 || $val->audit==1) {
$arr_id[] = $val->id;
if($val->companys->mobile && $val->companys->mobile_audit == 1){
$this->smsService->sendSms(
$val->companys->mobile,
Smser::TEMPLATE_JOBFAIR_APPLY_ERROR,
[
'jobfair_name'=>$val->jobfair->title
]);
}
if($val->companys->email && $val->companys->email_audit == 1){
$this->emailService->sendMail($val->companys->email, EmailService::TEMPLATE_JOBFAIR_APPLY_ERROR, ['title'=>'招聘会预订失败'], ['jobfair_name'=>$val->jobfair->title]);
}
}
if ($val->jobfair) {
if ($val->pay_type==1) {//场次
MembersSetmeal::where('uid', $val->company_id)->where('utype', 1)
->increment('jobfair_num', $val->jobfair->jobsfair_num);
}elseif ($val->pay_type==2) { //积分
MembersPoint::where('uid', $val->company_id)->where('utype', 1)
->increment('points', $val->jobfair->predetermined_point);
MembersHandsel::create([
'uid'=>$val->company_id,
'utype'=>1,
'htype_cn'=>'返还预定招聘会的积分',
'operate'=>1,
'points'=>$val->jobfair->predetermined_point
]);
}
}
}
}
if ($arr_id) {
$newReult = JobfairCompany::with(['jobfair', 'companys'])->whereHas('jobfair')
->whereHas('companys')->whereIn('id', $arr_id)->get();
foreach ($newReult as $key => $val) {
if ($val->jobfair && $val->companys) {
$newDate[$key]['utype'] = $val->companys->utype;
$newDate[$key]['msgtype'] = 2;
$newDate[$key]['msgfromuid'] = 0;
$newDate[$key]['msgfrom'] = 'admin';
$newDate[$key]['msgtoname'] = $val->companys->username;
$newDate[$key]['msgtouid'] = $val->companys->id;
$title = strstr($val->jobfair->title, '招聘会') ? $val->jobfair->title : $val->jobfair->title . '招聘会';
if ($audit == 1) {
$newDate[$key]['message'] = '您申请的' . $title . '' . $val->position . '展位已审核通过,请尽快提交招聘会职位。';
} else {
$newDate[$key]['message'] = '您申请的' . $title . '' . $val->position . '展位已审核失败,请尽快查收。失败原因(' . $note . ')';
}
$newDate[$key]['created_at'] = date('Y-m-d H:i:s');
$newDate[$key]['updated_at'] = date('Y-m-d H:i:s');
}
}
if ($pms_notice && $newDate) {
Pms::insert($newDate);
}
JobfairCompany::whereIn('id', $arr_id)->update(['audit' => $audit, 'note' => $note]);
} else {
admin_toastr('操作失败', 'error');
return back();
}
\DB::commit();
admin_toastr('操作成功', 'success');
} catch (\Exception $e) {
\DB::rollback();
admin_toastr('操作失败', $e->getMessage());
}
return back();
}
public function signedCompanys(Request $request)
{
$id = $request->id;
$arr = array_filter(explode(',', $id));
if (empty($id)) {
return response()->json(['code'=>0,'info'=>'数据异常!']);
}
if (empty($arr)) {
return response()->json(['code'=>0,'info'=>'请选择参会企业!']);
}
$need_id_n = [];
$need_id_p = [];
$JobfairCompany = JobfairCompany::with(['jobfair'=>function ($query) {
$query->where('holddate_start', '<=', time()+7200)->where('holddate_end', '>=', time())->orWhere('holddate_start', '<=', time());
}])->whereIn('id', $arr)->where('type', 0)->get();
foreach ($JobfairCompany as $key => $val) {
if ($val->jobfair) {
if (time()>=$val->jobfair->holddate_start && time()<=$val->jobfair->holddate_end) {
$need_id_n[] = $val->id;
} else {
if (time()<$val->jobfair->holddate_start) {
if (($val->jobfair->holddate_start-time())<7200) {
$need_id_p[] = $val->id;
}
}
}
}
}
if (!$need_id_n&&!$need_id_p) {
return response()->json(['code'=>0,'info'=>'该企业已签到过或招聘会已结束或签到时间不在招聘会开始时间2小时之内!']);
}
\DB::beginTransaction();
try {
if ($need_id_n) {
JobfairCompany::whereIn('id', $need_id_n)->update(['type'=>1,'signed_time'=>time()]);
}
if ($need_id_p) {
JobfairCompany::whereIn('id', $need_id_p)->update(['type'=>4,'signed_time'=>time()]);
}
\DB::commit();
return response()->json(['code'=>1,'info'=>'签到成功!']);
} catch (\Exception $e) {
\DB::rollback();
return response()->json(['code'=>0,'info'=>'签到失败!']);
}
}
public function floorPlans(Request $request)
{
$jobfair_id = $request->get('q');
$request->session()->put('jobfair_plan_id', $jobfair_id);
return JobfairFloorplan::where('jobfair_id', $jobfair_id)->get(['id','name as text']);
}
public function floorPlansId(Request $request)
{
$jobfair_id = $request->session()->get('jobfair_plan_id', '');
$floor_plan_id = $request->get('q');
if ($jobfair_id) {
$standFreeList = $this->lastJobfairPosition($jobfair_id, $floor_plan_id);
return FloorplanStand::whereIN('id', $standFreeList)->get(['id','name as text']);
}
return [];
}
protected function lastJobfairPosition($jobfair_id, $floor_plan_id)
{
$standAudit = 0;
$standAuditList = [];
$standSuccess = 0;
$standSuccessList = [];
$standLock = 0;
$standLockList = [];
$standFreeList = [];
$standNum = 0;
$FloorplanStand = FloorplanStand::where('jobfair_id', $jobfair_id)->where('floorplan_id', $floor_plan_id)->get();
$JobfairCompany = JobfairCompany::where('jobfair_id', $jobfair_id)->whereIn('audit', [1,2])->get();
if (!$FloorplanStand->isEmpty()) {
foreach ($FloorplanStand as $key => $val) {
$standFreeList[]=$val->id;
// if ($val->type==2) {
// $standLock++;
// $standLockList[]=$val->id;
// }
// if ($val->type==1) {
// $standFreeList[]=$val->id;
// }
$standNum++;
}
}
if (!$JobfairCompany->isEmpty()) {
foreach ($JobfairCompany as $key => $val) {
if ($val->audit==1) {
$standSuccess++;
$standSuccessList[]=$val->position_id;
} elseif ($val->audit==2) {
$standAudit++;
$standAuditList[]=$val->position_id;
}
}
}
return array_diff($standFreeList, array_unique(array_merge($standSuccessList, $standAuditList)));
}
public function positionColumn($jobfair_id, $floor_plan_id)
{
$standFreeList = $this->lastJobfairPosition($jobfair_id, $floor_plan_id);
return FloorplanStand::whereIN('id', $standFreeList)->pluck('name as text','id')->toArray();
}
public function destroy($id)
{
$ids = array();
if ($id) {
$ids = explode(',', $id);
}
if (!$ids) {
return admin_toastr('请勾选需要删除的参展职位', 'error');
}
\DB::beginTransaction();
try {
JobfairCompany::whereIn('id', $ids)->delete();
JobfairPutJob::whereIn('exid', $ids)->delete();
$data = [
'status' => true,
'message' => '删除成功!',
];
\DB::commit();
return response()->json($data);
} catch (\Exception $e) {
\DB::rollback();
$data = [
'status' => false,
'message' => '删除失败!',
];
return response()->json($data);
}
}
}