123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247 |
- <?php
- namespace App\Admin\Controllers\Content;
- use App\Admin\Extensions\Form\ValidateForm;
- use App\Http\Controllers\Controller;
- use App\Models\Category;
- use App\Models\Quanzhida;
- use App\Models\TalentHouse;
- use App\Models\TalentHouseApply;
- use Encore\Admin\Controllers\HasResourceActions;
- use Encore\Admin\Form;
- use Encore\Admin\Grid;
- use Encore\Admin\Layout\Content;
- use Illuminate\Http\Request;
- use Illuminate\Support\Facades\DB;
- class QuanzhidaController extends Controller
- {
- use HasResourceActions;
- /**
- * Index interface.
- *
- * @param Content $content
- * @return Content
- */
- public function index(Content $content)
- {
- return $content
- ->header('泉职大')
- ->description(' ')
- ->body(view('admin.content.quanzhida')->with(['grid' => $this->grid()]));
- }
- /**
- * Edit interface.
- *
- * @param mixed $id
- * @param Content $content
- * @return Content
- */
- public function edit($id, Content $content)
- {
- return $content
- ->header('岗位')
- ->description(' ')
- ->body($this->editForm($id)->edit($id));
- }
- /**
- * Create interface.
- *
- * @param Content $content
- * @return Content
- */
- public function create(Content $content)
- {
- return $content
- ->header('岗位')
- ->description(' ')
- ->body($this->form());
- }
- /**
- * Make a grid builder.
- *
- * @return Grid
- */
- protected function grid()
- {
- $grid = new Grid(new Quanzhida());
- $grid->model()->orderBy('updated_at', 'DESC');
- $grid->id('ID');
- $grid->company_name('公司名称');
- $grid->job_name('岗位名称');
- $grid->industry('行业领域');
- $grid->created_at('创建时间');
- //新增按钮
- $grid->disableCreateButton(false);
- //批量删除
- $grid->tools(function ($tools) {
- $tools->batch(function ($batch) {
- $batch->disableDelete(false);
- });
- });
- $grid->actions(function ($actions) {
- $actions->disableEdit(false);
- $actions->disableDelete(false);
- });
- $grid->filter(function ($filter) {
- $filter->disableIdFilter();
- $filter->like('company_name', '公司名称');
- $filter->like('job_name', '岗位名称');
- });
- return $grid;
- }
- /**
- * Make a form builder.
- *
- * @return Form
- */
- protected function form()
- {
- $form = new ValidateForm(new Quanzhida());
- $form->text('company_name', '公司名称')->rules('required|max:100', ['required' => '公司名称不能为空。', 'max' => '公司名称不能大于100。'])->setWidth(4)->setMustMark();
- $form->text('job_name', '岗位名称')->rules('required|max:60', ['required' => '岗位名称不能为空。', 'max' => '岗位名称不能大于60。'])->setWidth(4)->setMustMark();
- $form->number('wage_min', '最小薪资')->rules('required', ['required' => '最小薪资不能为空。若未确定,请填0'])->setWidth(4)->setMustMark();
- $form->number('wage_max', '最大薪资')->rules('required', ['required' => '最大薪资不能为空。若未确定,请填0'])->setWidth(4)->setMustMark();
- $form->text('industry', '所属行业领域')->rules('required|max:60', ['required' => '所属行业领域不能为空。', 'max' => '所属行业领域不能大于60。'])->setWidth(4)->setMustMark();
- $education = Category::where('alias','AIX_education')->pluck('demand','id');
- $education[0] = '不限';
- $form->select('education', '学历')->setWidth(4)->options($education)->setMustMark();
- $experience = Category::where('alias','AIX_experience')->pluck('demand','id');
- $experience[0] = '不限';
- $form->select('experience', '工作经验')->setWidth(4)->options($experience)->setMustMark();
- $form->text('region', '工作地点')->rules('required|max:60', ['required' => '工作地点不能为空。', 'max' => '工作地点不能大于60。'])->setWidth(4)->setMustMark();
- $form->footer(function ($footer) {
- $footer->disableViewCheck();
- $footer->disableEditingCheck();
- $footer->disableCreatingCheck();
- $footer->disableReset();
- });
- return $form;
- }
- protected function editForm($id)
- {
- $form = new ValidateForm(new Quanzhida());
- $form->text('company_name', '公司名称')->rules('required|max:100', ['required' => '公司名称不能为空。', 'max' => '公司名称不能大于100。'])->setWidth(4)->setMustMark();
- $form->text('job_name', '岗位名称')->rules('required|max:60', ['required' => '岗位名称不能为空。', 'max' => '岗位名称不能大于60。'])->setWidth(4)->setMustMark();
- $form->number('wage_min', '最小薪资')->rules('required', ['required' => '最小薪资不能为空。若未确定,请填0'])->setWidth(4)->setMustMark();
- $form->number('wage_max', '最大薪资')->rules('required', ['required' => '最大薪资不能为空。若未确定,请填0'])->setWidth(4)->setMustMark();
- $form->text('industry', '所属行业领域')->rules('required|max:60', ['required' => '所属行业领域不能为空。', 'max' => '所属行业领域不能大于60。'])->setWidth(4)->setMustMark();
- $education = Category::where('alias','AIX_education')->pluck('demand','id');
- $education[0] = '不限';
- $form->select('education', '学历')->setWidth(4)->options($education)->setMustMark();
- $experience = Category::where('alias','AIX_experience')->pluck('demand','id');
- $experience[0] = '不限';
- $form->select('experience', '工作经验')->setWidth(4)->options($experience)->setMustMark();
- $form->text('region', '工作地点')->rules('required|max:60', ['required' => '工作地点不能为空。', 'max' => '工作地点不能大于60。'])->setWidth(4)->setMustMark();
- $form->footer(function ($footer) {
- $footer->disableViewCheck();
- $footer->disableEditingCheck();
- $footer->disableCreatingCheck();
- $footer->disableReset();
- });
- $form->tools(function (Form\Tools $tools) {
- $tools->disableDelete();
- $tools->disableView();
- });
- return $form;
- }
- public function update($id)
- {
- return $this->editForm($id)->update($id);
- }
- 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 export(Request $request)
- {
- //数据获取
- $id = $request->id;
- $status = $request->status;
- $house = TalentHouse::find($id);
- $query = TalentHouseApply::with(['house', 'idcard'])
- ->where('house_id', $id)
- ->where('is_back', 2)
- ->where('is_draft', 2)
- ->orderByRaw(DB::raw("FIELD(talent_level,'第一层次','第二层次','第三层次','第四层次','第五层次','第六层次','第七层次') asc"));
- if ($status == 1) {
- $filename = $house['name'] . '审核不通过名单.xls';
- $query = $query->whereIn('status', [1, 3, 4]);
- } else {
- $filename = $house['name'] . '审核通过名单.xls';
- $query = $query->where('status', 2);
- }
- $data = $query->get();
- if ($data->isEmpty()) {
- return '暂无数据';
- }
- //数据处理
- $status = ['', '待审核', '审核通过', '审核驳回', '审核不通过'];
- $marry = ['未知', '未婚', '已婚', '离异', '丧偶'];
- $type = ['', '优秀人才', '集成电路优秀人才'];
- $no = 1;
- foreach ($data as $row) {
- $family = empty($row->family) ? '' : json_decode($row->family, true);
- if (!empty($family)) {
- $relation = [];
- $child = [];
- $id_card = [];
- foreach ($family as $v) {
- $relation[] = $v['relation'];
- $child[] = $v['realname'];
- $id_card[] = $v['idcard'];
- }
- $row['relation'] = implode('/', $relation);
- $row['relation_name'] = implode('/', $child);
- $row['relation_id_card'] = implode('/', $id_card);
- }
- $row['no'] = $no;
- $no++;
- $row['marry_text'] = $marry[$row['marry']];
- $row['type_text'] = $type[$row['type']];
- }
- header("Content-type: application/vnd.ms-excel; charset=utf-8");
- header("Content-Disposition: attachment; filename=$filename");
- $view = view('admin.content.export_house_result')->with(['data' => $data, 'house' => $house, 'status' => $status]);
- $str = response($view)->getContent();
- echo $str;
- exit;
- }
- }
|