| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437 | <?phpnamespace App\Admin\Controllers\Company;use App\Admin\Extensions\Form\ValidateForm;use App\Admin\Extensions\Form\ValueForm;use App\Http\Controllers\Controller;use App\Models\Company;use App\Models\CompanyDownResume;use App\Models\CompanyImg;use App\Models\CompanyInterView;use App\Models\MembersChargeLog;use App\Models\MembersPoint;use App\Models\MembersSetmeal;use App\Models\Order;use App\Models\PersonalJobsApply;use App\Models\Setmeal;use App\Models\Subsite;use App\Repositories\MemberPointRepository;use Encore\Admin\Auth\Permission;use Encore\Admin\Facades\Admin;use Encore\Admin\Grid;use Encore\Admin\Layout\Content;use Encore\Admin\Widgets\Tab;use Illuminate\Http\Request;use Encore\Admin\Form;class CompanySetController extends Controller{    //企业相关内容    public function comBusiness(Content $content, Request $request, $id, $type = 'points')    {        if (!intval($id)) {           admin_toastr('参数错误');           return back();        }        $tab = new Tab();        $types = [            'points'=>'积分管理',            '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 '<span style="color:#009900">审核通过</span>';                                break;                            case 2:                                return '<span style="color:#FF6600">审核中</span>';                                break;                            case 3:                                return '<span style="color:#FF0000">审核未通过</span>';                                break;                            case 0:                                return '<span style="color:#FF6600">未审核</span>';                                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;    }}
 |