'积分管理',
'setmeal'=>'套餐管理',
'order'=>'充值/订单',
'increment'=>'增值服务',
'down_resume'=>'下载的简历',
'apply'=>'收到的简历',
'interview'=>'面试邀请',
'companyimg'=>'企业风采管理',
];
/**
* 直接在case里头判断的话,case 完了的代码会产生css影响
*/
if (!Admin::user()->can('company_comBusiness_points')) {
unset($types["points"]);
}
if (!Admin::user()->can('company_comBusiness_setmeal')) {
unset($types["setmeal"]);
}
foreach ($types as $key => $val) {
$form=null;
$memberSetform=null;
switch ($key) {
case 'points':
$grid = new Grid(new MembersPoint());
$grid->model()->where('uid', $id)->where('utype', 1)->when(get_subsite_id()>0, function ($querys) {
$querys->whereHas('companys', function ($query) {
$query->where('subsite_id', get_subsite_id());
});
})->whereHas('companys')->orderBy('created_at', 'desc');
$grid->column('companys.companyname', '企业名称');
$grid->points('积分');
$grid->column('companys.username', '用户名称');
$grid->column('companys.created_at', '注册时间');
$grid->disableActions();
$grid->disableTools();
$grid->setPaginatorBaseUrl($key);
$grid->disableRowSelector();
$form=$this->PointeditForm()->edit($id);
$form->setAction(admin_base_path("firm/comBusiness/update/{$id}"));
$form->setTitle("修改");
break;
case 'setmeal':
$grid = new Grid(new MembersSetmeal);
$grid->model()->where('uid', $id)->where('utype', 1)->whereHas('companys')->when(get_subsite_id()>0, function ($querys) {
$querys->whereHas('companys', function ($query) {
$query->where('subsite_id', get_subsite_id());
});
})->orderBy('id', 'desc');
$grid->id('id');
$grid->setmeal_name('套餐名称');
$grid->column('companys.companyname', '公司名称');
$grid->column('companys.username', '用户名称');
$grid->starttime('开始时间')->display(function ($starttime) {
return date('Y-m-d H:i:s', $starttime);
});
$grid->endtime('结束时间')->display(function ($endtime) {
if ($endtime) {
return $endtime;
}
return "永久";
});
$grid->disableActions();
$grid->disableTools();
$grid->setName($key);
$grid->setPaginatorBaseUrl($key);
$grid->disableRowSelector();
$memberSetmealInfo=MembersSetmeal::where(['uid'=>$id])->first();
//套餐修改的form表单
$memberSetform=$this->eidtMemberSetForm()->edit($memberSetmealInfo->id);
$memberSetform->setAction(admin_base_path("firm/companysetmeal/index/{$memberSetmealInfo->id}"));
$memberSetform->setTitle("套餐更换");
//修改套餐内容的Form 表单
$form=$this->eidtForm()->edit($memberSetmealInfo->id);
$form->setTitle("套餐修改");
$form->setAction(admin_base_path("firm/companysetmeal/index/{$memberSetmealInfo->id}"));
break;
case "order":
$utype = 1;
$grid = new Grid(new Order);
$grid ->model()->where('uid', $id)->where('utype', $utype)->when(get_subsite_id()>0, function ($querys) {
$relations = 'companys';
$querys->whereHas($relations, function ($query) {
$query->where('subsite_id', get_subsite_id());
});
})->orderBy('created_at', 'desc')->orderBy("is_pay", 'asc');
$grid->id('ID');
$grid->is_pay('支付状态')->display(function ($is_pay) {
if ($is_pay == 1) {
return '待付款';
} elseif ($is_pay == 2) {
return "已付款";
} else {
return '已取消';
}
});
$grid->amount('金额')->width(150);
$grid->column('companys.companyname', '企业名称')->width(200);
$grid->service_name('说明')->width(150);
$grid->column('companys.username', '企业会员')->width(200);
$grid->oid('订单号')->width(200);
$grid->created_at('申请时间');
$grid->payment_cn('支付方式')->width(150);
$grid->disableActions();
$grid->disableTools();
$grid->setName($key);
// $tab_content[$key] = $grid;
$grid->setPaginatorBaseUrl($key);
$grid->disableRowSelector();
break;
case 'increment':
$grid = new Grid(new Order);
$grid->model()->where('uid', $id)->where('uid', $id)->where('utype', 1)->when(get_subsite_id()>0, function ($querys) {
$querys->whereHas('companys', function ($query) {
$query->where('subsite_id', get_subsite_id());
});
});
$grid->id('ID');
$grid->service_name('服务内容');
$grid->column('companys.companyname', '企业名称');
$grid->column('companys.username', '申请会员');
$grid->amount('金额');
$grid->created_at('申请时间');
$grid->disableActions();
$grid->disableTools();
$grid->setName($key);
$grid->setPaginatorBaseUrl($key);
$grid->disableRowSelector();
// $tab_content[$key] = $grid;
break;
case 'down_resume':
$grid = new Grid(new CompanyDownResume);
$grid->model()->where('company_uid', $id)->whereHas('resumes');
$grid->id('ID');
$grid->column('resumes.fullname', '姓名');
$grid->column('resumes.birthdate', '年龄')->display(function ($birthdate) {
return date('Y')-$birthdate;
});
$grid->column('resumes.sex_cn', '性别');
$grid->column('resumes.education_cn', '学历');
$grid->column('resumes.experience_cn', '工作经验');
$grid->column('resumes.wage_cn', '期望薪资');
$grid->down_addtime('下载时间')->display(function ($down_addtime) {
return date('Y-m-d H:i:s', $down_addtime);
});
$grid->disableActions();
$grid->disableTools();
$grid->setName($key);
$grid->setPaginatorBaseUrl($key);
$grid->disableRowSelector();
// $tab_content[$key] = $grid;
break;
case "apply":
$grid = new Grid(new PersonalJobsApply);
$grid->model()->where('company_id', $id)->whereHas('resumes');
$grid->id('ID');
$grid->column('resumes.fullname', '姓名');
$grid->column('resumes.birthdate', '年龄')->display(function ($birthdate) {
return date('Y')-$birthdate;
});
$grid->column('resumes.sex_cn', '性别');
$grid->column('resumes.education_cn', '学历');
$grid->column('resumes.experience_cn', '工作经验');
$grid->column('jobs_name', '应聘职位');
$grid->column('created_at', '投递时间');
$grid->disableActions();
$grid->disableTools();
$grid->setName($key);
$grid->setPaginatorBaseUrl($key);
$grid->disableRowSelector();
//$grid->model()->eloquent()->withPath('aaa');
// $tab_content[$key] = $grid;
break;
case "interview":
$grid = new Grid(new CompanyInterView);
$grid->model()->where('company_id', $id)->whereHas('resumes');
$grid->id('ID');
$grid->column('resumes.fullname', '姓名');
$grid->column('resumes.birthdate', '年龄')->display(function ($birthdate) {
return date('Y')-$birthdate;
});
$grid->column('resumes.sex_cn', '性别');
$grid->column('resumes.education_cn', '学历');
$grid->column('resumes.experience_cn', '工作经验');
$grid->column('resumes.wage_cn', '期望薪资');
$grid->column('interview_time', '面试时间')->display(function ($interview_time) {
return date('Y-m-d H:i:s', $interview_time);
});
$grid->disableActions();
$grid->disableTools();
// $tab_content[$key] = $grid;
$grid->setName($key);
$grid->setPaginatorBaseUrl($key);
$grid->disableRowSelector();
break;
case 'companyimg':
$grid = new Grid(new CompanyImg);
$grid->model()->where('company_id', $id)->when(get_subsite_id()>0, function ($query) {
$query->where('subsite_id', get_subsite_id());
})->whereHas('companys')->orderByRaw('field(audit,0,2,1,3)')->orderBy('created_at', 'desc');
$grid->id('ID');
$grid->image()->image();
$grid->company_id('企业名称')->display(function ($company_id) {
$companyname = Company::where('id', $company_id)->select(['companyname'])->first();
return $companyname['companyname'];
})->width(200);
$grid->audit('审核状态')->display(function ($audit) {
switch ($audit) {
case 1:
return '审核通过';
break;
case 2:
return '审核中';
break;
case 3:
return '审核未通过';
break;
case 0:
return '未审核';
break;
}
});
$grid->subsite_id('所属分站')->display(function ($subsite_id) {
if ($subsite_id == 0) {
return "总站";
} else {
$subsite = Subsite::findOrFail($subsite_id);
return $subsite->sitename;
}
});
$grid->created_at('添加时间');
$grid->disableActions();
$grid->disableTools();
$grid->setName($key);
$grid->setPaginatorBaseUrl($key);
$grid->disableRowSelector();
break;
}
if (!empty($grid)){
$tab->add($val, view('admin.company.content')->with(['contents'=>$grid,'form'=>$form,'memberSetform'=>$memberSetform] ), $type == $key);
}
}
return $content
->header('企业信息')
->description('列表')
->body($tab->render());
}
public function update($id,MemberPointRepository $memberPointRepository){
$data = $this->PointeditForm($id)->getValidateInput();
if($data['points']){
if ($data['regpoints'] == 1) {
//增加积分
$pointData['points'] = $data['points'];
if (false == $memberPointRepository->reportDeal($id, 1, 1, $data['points'])) {
admin_toastr('企业增加积分失败', 'error');
}
} else {
//减少积分
if (false == $memberPointRepository->reportDeal($id, 1, 2, $data['points'])) {
admin_toastr('企业增加积分失败', 'error');
}
}
}
$amount = 0;
if ($data['is_money']) {
$amount = $data['amount'];
$company=Company::find($id);
$logData['log_uid'] = $id;
$logData['log_utype'] = 1;
$logData['log_username'] = $company->username;
$logData['log_value'] = "操作人:".Admin::user()->username.",说明:修改会员:{$company->username},(+{$data['points']})积分,收到".$amount."元。";
$logData['log_amount'] = $amount;
$logData['log_ismoney'] = $data['is_money'];
$logData['log_type'] = 2;
$logData['log_mode'] = 1;
if (!MembersChargeLog::create($logData)) {
admin_toastr('企业增加记录失败', 'error');
}
}
admin_toastr('积分修改成功', 'success');
return back();
}
//积分表单
public function PointeditForm(){
Permission::check('company_comBusiness_points');
$form = new ValidateForm(new Company);
$form->radio('regpoints', '管理积分')->options([0=>'减少', 1=>'增加' ])->default('1');
$form->number('points', '赠送数量')->min(0);
$form->switch('is_money', '是否收费');
$form->number('amount', '收费金额')->min(0);
return $form;
}
//套餐内容表单
public function eidtForm()
{
Permission::check('company_comBusiness_setmeal');
$form= new Form(new MembersSetmeal);
$form->display('id');
$form->display('companys.companyname', '企业名称');
$form->display('setmeal_name', '套餐名称');
$form->display('setmealtime', '服务时间')->with(function () {
return '起:'.date('Y-m-d H:i:s', $this->starttime).' ~ 止:'.($this->endtime ==0?"无限制":$this->endtime);
});
$form->datetime('endtime', '到期时间');
//
$form->text('dayes', '服务天数')->help("默认为空表示不做修改,0为不限制,如填写3则延长3天,-3则减少3天");
$form->hidden('days', "服务天数");
$form->number('jobs_meanwhile', '在招职位数')->min(0);
$form->number('jobfair_num', '招聘会场次')->min(0);
$form->number('refresh_jobs_free', '职位免费刷新数')->min(0);
$form->number('download_resume', '下载简历数')->min(0);
$form->number('download_resume_max', '下载简历数上限')->min(0);
$form->number('companys.sms_num', '短信数')->min(0);
$form->radio('show_apply_contact', '收到简历的联系方式')->options([0=>'需下载',1=>'免费查看']);
$form->text('added', '其他说明');
$form->hidden('uid');
$form->hidden('utype');
$form->hidden('companys.username');
$form->hidden('starttime');
$form->hidden('setmeal')->default(2);
return $form;
}
//改变套餐的表单
public function eidtMemberSetForm()
{
Permission::check('company_comBusiness_setmeal');
$form= new Form(new MembersSetmeal);
$setmeal = Setmeal::where('display', 1)->list()->pluck('setmeal_name', 'id')->toArray();
empty(\request('setmeal_id')) ? request()->offsetSet('setmeal_id', key($setmeal)) : "" ;
$form->radio('setmeal_id', '会员套餐')->options($setmeal)->default(key($setmeal))->rules(['required'], ['required'=>'请选择相应的会员套餐'])->setMustMark();
$form->switch('is_money', '是否已收费');
$form->text('amount', '收费金额');
$form->hidden('setmeal')->default(1);
return $form;
}
}