IndexController.php 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319
  1. <?php
  2. namespace App\Admin\Controllers\Ic;
  3. use App\Admin\Extensions\Form\ValidateForm;
  4. use App\Http\Controllers\Controller;
  5. use App\Models\Company;
  6. use App\Models\JobfairsIc;
  7. use App\Models\JobFairsIcAppoint;
  8. use App\Models\PostAppointIc;
  9. use Encore\Admin\Auth\Permission;
  10. use Encore\Admin\Grid;
  11. use Encore\Admin\Layout\Content;
  12. use Illuminate\Http\Request;
  13. use Illuminate\Support\Facades\DB;
  14. class IndexController extends Controller
  15. {
  16. public function postInfoList(Content $content, Request $request)
  17. {
  18. Permission::check('icPostInfoList');
  19. $search_data = $request->all();
  20. $where = [];
  21. foreach ($search_data as $k => $v) {
  22. if ($k == 'realname') {
  23. $where[] = [$k, 'like', "%$v%"];
  24. } elseif (in_array($k, ['sex', 'education'])) {
  25. $where[] = ['post_appoint_ic.' . $k, '=', $v];
  26. }
  27. }
  28. $perpage = 20;
  29. $list = PostAppointIc::where($where)
  30. ->leftJoin("jobs", "jobs.id", '=', 'post_appoint_ic.job_id')
  31. ->select('post_appoint_ic.*', 'jobs.jobs_name', 'jobs.company_name')
  32. ->orderBy('updated_at', 'desc')
  33. ->paginate($perpage);
  34. foreach ($list as $k => $v) {
  35. $v->native_place_cn = get_district_cn($v->native_place);
  36. $v->education = get_category($v->education);
  37. if ($v->sex == 1) {
  38. $list[$k]['sex'] = '男';
  39. } else {
  40. $list[$k]['sex'] = '女';
  41. }
  42. if ($v->status == 0) {
  43. $list[$k]['status'] = '未下载';
  44. } else {
  45. $list[$k]['status'] = '已下载';
  46. }
  47. }
  48. return $content
  49. ->header('信息管理')
  50. ->description('投递岗位人员信息列表')
  51. ->body(view('admin.ic.post_appoint_list')->with([
  52. 'list' => $list,
  53. 'search_data' => $search_data,
  54. ]));
  55. }
  56. public function postStatus(Request $request)
  57. {
  58. Permission::check('icPostInfoList');
  59. $info = PostAppointIc::where(['id' => $request->id])->first();
  60. if ($info) {
  61. $info->status = 1;
  62. $info->save();
  63. return response()->json(['status' => 1, 'msg' => '跳转下载中!', 'data' => 'ok', 'url' => $info->attachment]);
  64. } else {
  65. return response()->json(['status' => 0, 'msg' => '找不到记录!', 'data' => 'fail']);
  66. }
  67. //return "/storage/recruit/word/" . $recruit->name_en . '/' .$appoint->audit .$word_url;
  68. }
  69. /**
  70. * 宣讲会管理
  71. * @param Content $content
  72. * @return Content
  73. */
  74. public function index(Content $content)
  75. {
  76. Permission::check('icJobFairsListList');
  77. return $content
  78. ->header('招聘会管理')
  79. ->description('')
  80. ->body($this->grid());
  81. }
  82. protected function grid()
  83. {
  84. $grid = new Grid(new JobfairsIc);
  85. $grid->model()->orderBy('ordid', 'DESC');
  86. $grid->model()->paginate(20);
  87. $grid->disableCreateButton(false);
  88. $grid->perPages([10, 20, 30, 40, 50, 100]);
  89. $grid->id('ID');
  90. $grid->title('标题');
  91. $grid->column('holddate_start', '开始时间');
  92. $grid->column('holddate_end', '结束时间');
  93. $grid->address('举办地址');
  94. $grid->contact('联系人');
  95. $grid->phone('联系电话');
  96. $grid->column('display', '状态')->display(function ($display) {
  97. return $display == 1 ? '正常' : '暂停';
  98. });
  99. $grid->created_at('创建时间');
  100. $grid->filter(function ($filter) {
  101. // 在这里添加字段过滤器
  102. $filter->column(1 / 2, function ($filter) {
  103. $filter->like('title', '标题');
  104. });
  105. });
  106. $grid->actions(function ($actions) {
  107. $actions->append('<a href="/ST3IXxKlOa4eGEv0eTw0CfORI9444Mgj/ic/jobfairs_appoint_list?id=' . $actions->row['id'] . '" class="btn btn-primary btn-xs" >报名管理</a>');
  108. $actions->disableEdit(false);
  109. $actions->disableDelete(false);
  110. $actions->disableView();
  111. });
  112. return $grid;
  113. }
  114. public function create(Content $content)
  115. {
  116. return $content
  117. ->header('招聘会创建')
  118. ->description('带*号必填项')
  119. ->body(view('admin.ic.jobfairs')->with(['grid' => $this->form()->render()]));
  120. }
  121. public function edit($id, Content $content)
  122. {
  123. return $content
  124. ->header('招聘会编辑')
  125. ->description('带*号必填项')
  126. ->body(view('admin.ic.jobfairs')->with(['grid' => $this->editForm($id)->edit($id)->render()]));
  127. }
  128. public function show($id, Content $content)
  129. {
  130. return redirect(route('ic.index'));
  131. }
  132. protected function editForm($id)
  133. {
  134. $info = JobfairsIc::find($id);
  135. $form = new ValidateForm(new JobfairsIc);
  136. $form->text('title', '标题')->rules('required|max:100', ['required' => '标题不能为空。', 'max' => '标题长度不能大于100。'])->setMustMark();
  137. $form->datetime('holddate_start', '开始时间')->format('YYYY-MM-DD HH:mm:ss')->rules('required', ['required' => '开始时间不能为空。'])->setMustMark();
  138. $form->datetime('holddate_end', '结束时间')->format('YYYY-MM-DD HH:mm:ss')->rules('required', ['required' => '结束时间不能为空。'])->setMustMark();
  139. $form->text('contact', '联系人')->rules('required', ['required' => '联系人不能为空。'])->setMustMark();
  140. $form->text('phone', '联系电话')->rules('required', ['required' => '联系电话不能为空。'])->setMustMark();
  141. $form->number('need_num', '需要人数')->min(0)->rules('required', ['required' => '请输入需要人数。'])->setMustMark();
  142. $display_option = [
  143. 'on' => ['value' => 1, 'text' => '正常', 'color' => 'success'],
  144. 'off' => ['value' => 2, 'text' => '暂停', 'color' => 'danger'],
  145. ];
  146. $form->switch('display', '状态')->states($display_option)->default('1')->setMustMark();
  147. $form->text('ordid', '排序')->default(100)->rules('required', ['required' => '请输入排序。'])->help('(数字越大越靠前)')->setMustMark();
  148. $form->textarea('jobfair_introduction', '招聘会简介')->rows(10)->attribute(['maxlength' => 2000])->setMustMark();
  149. $form->listbox('companys', '参与企业列表')->rules('required', ['required' => '请选择参与企业'])->options(Company::icCompanys())->attribute('hight', '200px')->setMustMark();
  150. $form->text('address', '举办地址')->rules('required', ['required' => '举办地址不能为空。'])->setMustMark();
  151. $form->html('<div id="searchResultPanel" style="border:1px solid #C0C0C0;height:100px; display:none;"></div>');
  152. $form->html(' <div class="fr">
  153. <input name="map_x" type="hidden" id="x" value="'.$info['map_x'].'">
  154. <input name="map_y" type="hidden" id="y" value="'.$info['map_y'].'">
  155. <input name="map_zoom" type="hidden" id="zoom" value="'.$info['map_zoom'].'">
  156. <div class="form-control" style=height:380px;border:1px solid #CCCCCC; cursor: pointer;" id="container"></div></div>', '地图标注')->setMustMark();
  157. return $form;
  158. }
  159. protected function form()
  160. {
  161. $form = new ValidateForm(new JobfairsIc);
  162. $form->text('title', '标题')->rules('required|max:100', ['required' => '标题不能为空。', 'max' => '标题长度不能大于100。'])->setMustMark();
  163. $form->datetime('holddate_start', '开始时间')->format('YYYY-MM-DD HH:mm:ss')->rules('required', ['required' => '开始时间不能为空。'])->setMustMark();
  164. $form->datetime('holddate_end', '结束时间')->format('YYYY-MM-DD HH:mm:ss')->rules('required', ['required' => '结束时间不能为空。'])->setMustMark();
  165. $form->text('contact', '联系人')->rules('required', ['required' => '联系人不能为空。'])->setMustMark();
  166. $form->text('phone', '联系电话')->rules('required', ['required' => '联系电话不能为空。'])->setMustMark();
  167. $form->number('need_num', '需要人数')->min(0)->rules('required', ['required' => '请输入需要人数。'])->setMustMark();
  168. $display_option = [
  169. 'on' => ['value' => 1, 'text' => '正常', 'color' => 'success'],
  170. 'off' => ['value' => 2, 'text' => '暂停', 'color' => 'danger'],
  171. ];
  172. $form->switch('display', '状态')->states($display_option)->default('1')->setMustMark();
  173. $form->text('ordid', '排序')->default(100)->rules('required', ['required' => '请输入排序。'])->help('(数字越大越靠前)')->setMustMark();
  174. $form->textarea('jobfair_introduction', '招聘会简介')->rows(10)->attribute(['maxlength' => 2000])->setMustMark();
  175. $form->listbox('companys', '参与企业列表')->rules('required', ['required' => '请选择参与企业'])->options(Company::icCompanys())->attribute('hight', '200px')->setMustMark();
  176. $form->text('address', '举办地址')->rules('required', ['required' => '举办地址不能为空。'])->setMustMark();
  177. $form->html('<div id="searchResultPanel" style="border:1px solid #C0C0C0;height:100px; display:none;"></div>');
  178. $form->html(' <div class="fr">
  179. <input name="map_x" type="hidden" id="x" value="'.subsite_config('aix.system.map.map.map_x').'">
  180. <input name="map_y" type="hidden" id="y" value="'.subsite_config('aix.system.map.map.map_y').'">
  181. <input name="map_zoom" type="hidden" id="zoom" value="'.subsite_config('aix.system.map.map.max_level').'">
  182. <div class="form-control" style=height:380px;border:1px solid #CCCCCC; cursor: pointer;" id="container"></div></div>', '地图标注')->setMustMark();
  183. return $form;
  184. }
  185. public function store(Request $request){
  186. $verify = $this->form()->getValidateInput();
  187. $input = $request->post();
  188. $verify['companys'] = implode(',',$verify['companys']);
  189. $verify['map_x'] = $input['map_x'];
  190. $verify['map_y'] = $input['map_y'];
  191. $verify['map_zoom'] = $input['map_zoom'];
  192. try {
  193. JobfairsIc::create($verify);
  194. DB::commit();
  195. }catch (\Exception $e) {
  196. DB::rollback();
  197. return admin_toastr($e->getMessage(), 'error');
  198. }
  199. }
  200. public function update($id,Request $request)
  201. {
  202. $verify = $this->form()->getValidateInput();
  203. $input = $request->post();
  204. $verify['companys'] = implode(',',$verify['companys']);
  205. $verify['map_x'] = $input['map_x'];
  206. $verify['map_y'] = $input['map_y'];
  207. $verify['map_zoom'] = $input['map_zoom'];
  208. try {
  209. JobfairsIc::where('id',$id)->update($verify);
  210. DB::commit();
  211. }catch (\Exception $e) {
  212. DB::rollback();
  213. return admin_toastr($e->getMessage(), 'error');
  214. }
  215. }
  216. public function destroy($id)
  217. {
  218. if ($this->form()->destroy($id)) {
  219. $data = [
  220. 'status' => true,
  221. 'message' => trans('admin.delete_succeeded'),
  222. ];
  223. } else {
  224. $data = [
  225. 'status' => false,
  226. 'message' => trans('admin.delete_failed'),
  227. ];
  228. }
  229. return response()->json($data);
  230. }
  231. public function jobfairsAppointList(Content $content,Request $request)
  232. {
  233. $search_data = $request->all();
  234. $where = [
  235. ['pid', '=', $search_data['id']],
  236. ];
  237. foreach ($search_data as $k => $v) {
  238. if ($k == 'realname') {
  239. $where[] = [$k, 'like', "%$v%"];
  240. } elseif (in_array($k, ['sex', 'education'])) {
  241. $where[] = [$k, '=', $v];
  242. }
  243. }
  244. $perpage = 20;
  245. $list = JobFairsIcAppoint::where($where)
  246. ->orderBy('updated_at', 'desc')
  247. ->paginate($perpage);
  248. foreach ($list as $k => $v) {
  249. if ($v->fresh == 1) {
  250. $list[$k]['fresh'] = '是';
  251. } else {
  252. $list[$k]['fresh'] = '否';
  253. }
  254. if ($v->sex == 1) {
  255. $list[$k]['sex'] = '男';
  256. } else {
  257. $list[$k]['sex'] = '女';
  258. }
  259. if ($v->status == 0) {
  260. $list[$k]['status'] = '未下载';
  261. } else {
  262. $list[$k]['status'] = '已下载';
  263. }
  264. if (empty($v->attachment)) {
  265. $list[$k]['is_attachment'] = '未上传';
  266. } else {
  267. $list[$k]['is_attachment'] = '已上传';
  268. }
  269. }
  270. return $content
  271. ->header('报名管理')
  272. ->description('招聘会报名的人员信息管理')
  273. ->body(view('admin.ic.jobfairs_appoint_list')->with([
  274. 'list' => $list,
  275. 'search_data' => $search_data,
  276. ]));
  277. }
  278. public function jobfairsAppointStatus(Request $request)
  279. {
  280. $info = JobFairsIcAppoint::where(['id' => $request->id])->first();
  281. if ($info && $info->attachment) {
  282. $info->status = 1;
  283. $info->save();
  284. return response()->json(['status' => 1, 'msg' => '跳转下载中!', 'data' => 'ok', 'url' => $info->attachment]);
  285. } else {
  286. return response()->json(['status' => 0, 'msg' => '用户未上传简历!', 'data' => 'fail']);
  287. }
  288. //return "/storage/recruit/word/" . $recruit->name_en . '/' .$appoint->audit .$word_url;
  289. }
  290. }