| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322 | <?phpnamespace App\Admin\Controllers\Ic;use App\Admin\Extensions\Form\ValidateForm;use App\Http\Controllers\Controller;use App\Models\Company;use App\Models\JobfairsIc;use App\Models\JobFairsIcAppoint;use App\Models\PostAppointIc;use Encore\Admin\Auth\Permission;use Encore\Admin\Grid;use Encore\Admin\Layout\Content;use Illuminate\Http\Request;use Illuminate\Support\Facades\DB;class IndexController extends Controller{    public function postInfoList(Content $content, Request $request)    {        Permission::check('icPostInfoList');        $search_data = $request->all();        $where = [];        foreach ($search_data as $k => $v) {            if ($k == 'realname') {                $where[] = [$k, 'like', "%$v%"];            } elseif (in_array($k, ['sex', 'education'])) {                $where[] = ['post_appoint_ic.' . $k, '=', $v];            }        }        $perpage = 20;        $list    = PostAppointIc::where($where)            ->leftJoin("jobs", "jobs.id", '=', 'post_appoint_ic.job_id')            ->select('post_appoint_ic.*', 'jobs.jobs_name', 'jobs.company_name')            ->orderBy('updated_at', 'desc')            ->paginate($perpage);        foreach ($list as $k => $v) {            $v->native_place_cn = get_district_cn($v->native_place);            $v->education       = get_category($v->education);            if ($v->sex == 1) {                $list[$k]['sex'] = '男';            } else {                $list[$k]['sex'] = '女';            }            if ($v->status == 0) {                $list[$k]['status'] = '未下载';            } else {                $list[$k]['status'] = '已下载';            }        }        return $content            ->header('信息管理')            ->description('投递岗位人员信息列表')            ->body(view('admin.ic.post_appoint_list')->with([                'list'        => $list,                'search_data' => $search_data,            ]));    }    public function postStatus(Request $request)    {        Permission::check('icPostInfoList');        $info = PostAppointIc::where(['id' => $request->id])->first();        if ($info) {            $info->status = 1;            $info->save();            return response()->json(['status' => 1, 'msg' => '跳转下载中!', 'data' => 'ok', 'url' => $info->attachment]);        } else {            return response()->json(['status' => 0, 'msg' => '找不到记录!', 'data' => 'fail']);        }        //return "/storage/recruit/word/" . $recruit->name_en . '/' .$appoint->audit .$word_url;    }    /**     * 宣讲会管理     * @param Content $content     * @return Content     */    public function index(Content $content)    {        Permission::check('icJobFairsListList');        return $content            ->header('招聘会管理')            ->description('')            ->body($this->grid());    }    protected function grid()    {        $grid = new Grid(new JobfairsIc);        $grid->model()->orderBy('ordid', 'DESC');        $grid->model()->paginate(20);        $grid->disableCreateButton(false);        $grid->perPages([10, 20, 30, 40, 50, 100]);        $grid->id('ID');        $grid->title('标题');        $grid->column('holddate_start', '开始时间');        $grid->column('holddate_end', '结束时间');        $grid->address('举办地址');        $grid->url('外部链接');        $grid->contact('联系人');        $grid->phone('联系电话');        $grid->column('display', '状态')->display(function ($display) {            return $display == 1 ? '正常' : '暂停';        });        $grid->created_at('创建时间');        $grid->filter(function ($filter) {            // 在这里添加字段过滤器            $filter->column(1 / 2, function ($filter) {                $filter->like('title', '标题');            });        });        $grid->actions(function ($actions) {            $actions->append('<a href="/ST3IXxKlOa4eGEv0eTw0CfORI9444Mgj/ic/jobfairs_appoint_list?id=' . $actions->row['id'] . '"  class="btn btn-primary btn-xs" >报名管理</a>');            $actions->disableEdit(false);            $actions->disableDelete(false);            $actions->disableView();        });        return $grid;    }    public function create(Content $content)    {        return $content            ->header('招聘会创建')            ->description('带*号必填项')            ->body(view('admin.ic.jobfairs')->with(['grid' => $this->form()->render()]));    }    public function edit($id, Content $content)    {        return $content            ->header('招聘会编辑')            ->description('带*号必填项')            ->body(view('admin.ic.jobfairs')->with(['grid' => $this->editForm($id)->edit($id)->render()]));    }    public function show($id, Content $content)    {        return redirect(route('ic.index'));    }    protected function editForm($id)    {        $info = JobfairsIc::find($id);        $form = new ValidateForm(new JobfairsIc);        $form->text('title', '标题')->rules('required|max:100', ['required' => '标题不能为空。', 'max' => '标题长度不能大于100。'])->setMustMark();        $form->datetime('holddate_start', '开始时间')->format('YYYY-MM-DD HH:mm:ss')->rules('required', ['required' => '开始时间不能为空。'])->setMustMark();        $form->datetime('holddate_end', '结束时间')->format('YYYY-MM-DD HH:mm:ss')->rules('required', ['required' => '结束时间不能为空。'])->setMustMark();        $form->text('contact', '联系人')->rules('required', ['required' => '联系人不能为空。'])->setMustMark();        $form->text('phone', '联系电话')->rules('required', ['required' => '联系电话不能为空。'])->setMustMark();        $form->text('url', '外部链接')->setMustMark();        $form->number('need_num', '需要人数')->min(0)->rules('required', ['required' => '请输入需要人数。'])->setMustMark();        $display_option = [            'on'  => ['value' => 1, 'text' => '正常', 'color' => 'success'],            'off' => ['value' => 2, 'text' => '暂停', 'color' => 'danger'],        ];        $form->switch('display', '状态')->states($display_option)->default('1')->setMustMark();        $form->text('ordid', '排序')->default(100)->rules('required', ['required' => '请输入排序。'])->help('(数字越大越靠前)')->setMustMark();        $form->textarea('jobfair_introduction', '招聘会简介')->rows(10)->attribute(['maxlength' => 2000])->setMustMark();        $form->listbox('companys', '参与企业列表')->rules('required', ['required' => '请选择参与企业'])->options(Company::icCompanys())->attribute('hight', '200px')->setMustMark();        $form->text('address', '举办地址')->rules('required', ['required' => '举办地址不能为空。'])->setMustMark();        $form->html('<div id="searchResultPanel" style="border:1px solid #C0C0C0;height:100px; display:none;"></div>');        $form->html(' <div class="fr">            <input name="map_x" type="hidden" id="x" value="'.$info['map_x'].'">            <input name="map_y" type="hidden" id="y" value="'.$info['map_y'].'">            <input name="map_zoom" type="hidden" id="zoom" value="'.$info['map_zoom'].'">            <div class="form-control" style=height:380px;border:1px solid  #CCCCCC; cursor: pointer;" id="container"></div></div>', '地图标注')->setMustMark();        return $form;    }    protected function form()    {        $form = new ValidateForm(new JobfairsIc);        $form->text('title', '标题')->rules('required|max:100', ['required' => '标题不能为空。', 'max' => '标题长度不能大于100。'])->setMustMark();        $form->datetime('holddate_start', '开始时间')->format('YYYY-MM-DD HH:mm:ss')->rules('required', ['required' => '开始时间不能为空。'])->setMustMark();        $form->datetime('holddate_end', '结束时间')->format('YYYY-MM-DD HH:mm:ss')->rules('required', ['required' => '结束时间不能为空。'])->setMustMark();        $form->text('contact', '联系人')->rules('required', ['required' => '联系人不能为空。'])->setMustMark();        $form->text('phone', '联系电话')->rules('required', ['required' => '联系电话不能为空。'])->setMustMark();        $form->text('url', '外部链接')->setMustMark();        $form->number('need_num', '需要人数')->min(0)->rules('required', ['required' => '请输入需要人数。'])->setMustMark();        $display_option = [            'on'  => ['value' => 1, 'text' => '正常', 'color' => 'success'],            'off' => ['value' => 2, 'text' => '暂停', 'color' => 'danger'],        ];        $form->switch('display', '状态')->states($display_option)->default('1')->setMustMark();        $form->text('ordid', '排序')->default(100)->rules('required', ['required' => '请输入排序。'])->help('(数字越大越靠前)')->setMustMark();        $form->textarea('jobfair_introduction', '招聘会简介')->rows(10)->attribute(['maxlength' => 2000])->setMustMark();        $form->listbox('companys', '参与企业列表')->rules('required', ['required' => '请选择参与企业'])->options(Company::icCompanys())->attribute('hight', '200px')->setMustMark();        $form->text('address', '举办地址')->rules('required', ['required' => '举办地址不能为空。'])->setMustMark();        $form->html('<div id="searchResultPanel" style="border:1px solid #C0C0C0;height:100px; display:none;"></div>');        $form->html(' <div class="fr">            <input name="map_x" type="hidden" id="x" value="'.subsite_config('aix.system.map.map.map_x').'">            <input name="map_y" type="hidden" id="y" value="'.subsite_config('aix.system.map.map.map_y').'">            <input name="map_zoom" type="hidden" id="zoom" value="'.subsite_config('aix.system.map.map.max_level').'">            <div class="form-control" style=height:380px;border:1px solid  #CCCCCC; cursor: pointer;" id="container"></div></div>', '地图标注')->setMustMark();        return $form;    }    public function store(Request $request){        $verify = $this->form()->getValidateInput();        $input = $request->post();        $verify['companys'] = implode(',',$verify['companys']);        $verify['map_x'] = $input['map_x'];        $verify['map_y'] = $input['map_y'];        $verify['map_zoom'] = $input['map_zoom'];        try {            JobfairsIc::create($verify);            DB::commit();        }catch (\Exception $e) {            DB::rollback();            return admin_toastr($e->getMessage(), 'error');        }    }    public function update($id,Request $request)    {        $verify = $this->form()->getValidateInput();        $input = $request->post();        $verify['companys'] = implode(',',$verify['companys']);        $verify['map_x'] = $input['map_x'];        $verify['map_y'] = $input['map_y'];        $verify['map_zoom'] = $input['map_zoom'];        try {            JobfairsIc::where('id',$id)->update($verify);            DB::commit();        }catch (\Exception $e) {            DB::rollback();            return admin_toastr($e->getMessage(), 'error');        }    }    public function destroy($id)    {        if ($this->form()->destroy($id)) {            $data = [                'status'  => true,                'message' => trans('admin.delete_succeeded'),            ];        } else {            $data = [                'status'  => false,                'message' => trans('admin.delete_failed'),            ];        }        return response()->json($data);    }    public function jobfairsAppointList(Content $content,Request $request)    {        $search_data = $request->all();        $where = [            ['pid', '=', $search_data['id']],        ];        foreach ($search_data as $k => $v) {            if ($k == 'realname') {                $where[] = [$k, 'like', "%$v%"];            } elseif (in_array($k, ['sex', 'education'])) {                $where[] = [$k, '=', $v];            }        }        $perpage = 20;        $list    = JobFairsIcAppoint::where($where)            ->orderBy('updated_at', 'desc')            ->paginate($perpage);        foreach ($list as $k => $v) {            if ($v->fresh == 1) {                $list[$k]['fresh'] = '是';            } else {                $list[$k]['fresh'] = '否';            }            if ($v->sex == 1) {                $list[$k]['sex'] = '男';            } else {                $list[$k]['sex'] = '女';            }            if ($v->status == 0) {                $list[$k]['status'] = '未下载';            } else {                $list[$k]['status'] = '已下载';            }            if (empty($v->attachment)) {                $list[$k]['is_attachment'] = '未上传';            } else {                $list[$k]['is_attachment'] = '已上传';            }        }        return $content            ->header('报名管理')            ->description('招聘会报名的人员信息管理')            ->body(view('admin.ic.jobfairs_appoint_list')->with([                'list'        => $list,                'search_data' => $search_data,            ]));    }    public function jobfairsAppointStatus(Request $request)    {        $info = JobFairsIcAppoint::where(['id' => $request->id])->first();        if ($info && $info->attachment) {            $info->status = 1;            $info->save();            return response()->json(['status' => 1, 'msg' => '跳转下载中!', 'data' => 'ok', 'url' => $info->attachment]);        } else {            return response()->json(['status' => 0, 'msg' => '用户未上传简历!', 'data' => 'fail']);        }        //return "/storage/recruit/word/" . $recruit->name_en . '/' .$appoint->audit .$word_url;    }}
 |