IndexController.php 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322
  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->url('外部链接');
  95. $grid->contact('联系人');
  96. $grid->phone('联系电话');
  97. $grid->column('display', '状态')->display(function ($display) {
  98. return $display == 1 ? '正常' : '暂停';
  99. });
  100. $grid->created_at('创建时间');
  101. $grid->filter(function ($filter) {
  102. // 在这里添加字段过滤器
  103. $filter->column(1 / 2, function ($filter) {
  104. $filter->like('title', '标题');
  105. });
  106. });
  107. $grid->actions(function ($actions) {
  108. $actions->append('<a href="/ST3IXxKlOa4eGEv0eTw0CfORI9444Mgj/ic/jobfairs_appoint_list?id=' . $actions->row['id'] . '" class="btn btn-primary btn-xs" >报名管理</a>');
  109. $actions->disableEdit(false);
  110. $actions->disableDelete(false);
  111. $actions->disableView();
  112. });
  113. return $grid;
  114. }
  115. public function create(Content $content)
  116. {
  117. return $content
  118. ->header('招聘会创建')
  119. ->description('带*号必填项')
  120. ->body(view('admin.ic.jobfairs')->with(['grid' => $this->form()->render()]));
  121. }
  122. public function edit($id, Content $content)
  123. {
  124. return $content
  125. ->header('招聘会编辑')
  126. ->description('带*号必填项')
  127. ->body(view('admin.ic.jobfairs')->with(['grid' => $this->editForm($id)->edit($id)->render()]));
  128. }
  129. public function show($id, Content $content)
  130. {
  131. return redirect(route('ic.index'));
  132. }
  133. protected function editForm($id)
  134. {
  135. $info = JobfairsIc::find($id);
  136. $form = new ValidateForm(new JobfairsIc);
  137. $form->text('title', '标题')->rules('required|max:100', ['required' => '标题不能为空。', 'max' => '标题长度不能大于100。'])->setMustMark();
  138. $form->datetime('holddate_start', '开始时间')->format('YYYY-MM-DD HH:mm:ss')->rules('required', ['required' => '开始时间不能为空。'])->setMustMark();
  139. $form->datetime('holddate_end', '结束时间')->format('YYYY-MM-DD HH:mm:ss')->rules('required', ['required' => '结束时间不能为空。'])->setMustMark();
  140. $form->text('contact', '联系人')->rules('required', ['required' => '联系人不能为空。'])->setMustMark();
  141. $form->text('phone', '联系电话')->rules('required', ['required' => '联系电话不能为空。'])->setMustMark();
  142. $form->text('url', '外部链接')->setMustMark();
  143. $form->number('need_num', '需要人数')->min(0)->rules('required', ['required' => '请输入需要人数。'])->setMustMark();
  144. $display_option = [
  145. 'on' => ['value' => 1, 'text' => '正常', 'color' => 'success'],
  146. 'off' => ['value' => 2, 'text' => '暂停', 'color' => 'danger'],
  147. ];
  148. $form->switch('display', '状态')->states($display_option)->default('1')->setMustMark();
  149. $form->text('ordid', '排序')->default(100)->rules('required', ['required' => '请输入排序。'])->help('(数字越大越靠前)')->setMustMark();
  150. $form->textarea('jobfair_introduction', '招聘会简介')->rows(10)->attribute(['maxlength' => 2000])->setMustMark();
  151. $form->listbox('companys', '参与企业列表')->rules('required', ['required' => '请选择参与企业'])->options(Company::icCompanys())->attribute('hight', '200px')->setMustMark();
  152. $form->text('address', '举办地址')->rules('required', ['required' => '举办地址不能为空。'])->setMustMark();
  153. $form->html('<div id="searchResultPanel" style="border:1px solid #C0C0C0;height:100px; display:none;"></div>');
  154. $form->html(' <div class="fr">
  155. <input name="map_x" type="hidden" id="x" value="'.$info['map_x'].'">
  156. <input name="map_y" type="hidden" id="y" value="'.$info['map_y'].'">
  157. <input name="map_zoom" type="hidden" id="zoom" value="'.$info['map_zoom'].'">
  158. <div class="form-control" style=height:380px;border:1px solid #CCCCCC; cursor: pointer;" id="container"></div></div>', '地图标注')->setMustMark();
  159. return $form;
  160. }
  161. protected function form()
  162. {
  163. $form = new ValidateForm(new JobfairsIc);
  164. $form->text('title', '标题')->rules('required|max:100', ['required' => '标题不能为空。', 'max' => '标题长度不能大于100。'])->setMustMark();
  165. $form->datetime('holddate_start', '开始时间')->format('YYYY-MM-DD HH:mm:ss')->rules('required', ['required' => '开始时间不能为空。'])->setMustMark();
  166. $form->datetime('holddate_end', '结束时间')->format('YYYY-MM-DD HH:mm:ss')->rules('required', ['required' => '结束时间不能为空。'])->setMustMark();
  167. $form->text('contact', '联系人')->rules('required', ['required' => '联系人不能为空。'])->setMustMark();
  168. $form->text('phone', '联系电话')->rules('required', ['required' => '联系电话不能为空。'])->setMustMark();
  169. $form->text('url', '外部链接')->setMustMark();
  170. $form->number('need_num', '需要人数')->min(0)->rules('required', ['required' => '请输入需要人数。'])->setMustMark();
  171. $display_option = [
  172. 'on' => ['value' => 1, 'text' => '正常', 'color' => 'success'],
  173. 'off' => ['value' => 2, 'text' => '暂停', 'color' => 'danger'],
  174. ];
  175. $form->switch('display', '状态')->states($display_option)->default('1')->setMustMark();
  176. $form->text('ordid', '排序')->default(100)->rules('required', ['required' => '请输入排序。'])->help('(数字越大越靠前)')->setMustMark();
  177. $form->textarea('jobfair_introduction', '招聘会简介')->rows(10)->attribute(['maxlength' => 2000])->setMustMark();
  178. $form->listbox('companys', '参与企业列表')->rules('required', ['required' => '请选择参与企业'])->options(Company::icCompanys())->attribute('hight', '200px')->setMustMark();
  179. $form->text('address', '举办地址')->rules('required', ['required' => '举办地址不能为空。'])->setMustMark();
  180. $form->html('<div id="searchResultPanel" style="border:1px solid #C0C0C0;height:100px; display:none;"></div>');
  181. $form->html(' <div class="fr">
  182. <input name="map_x" type="hidden" id="x" value="'.subsite_config('aix.system.map.map.map_x').'">
  183. <input name="map_y" type="hidden" id="y" value="'.subsite_config('aix.system.map.map.map_y').'">
  184. <input name="map_zoom" type="hidden" id="zoom" value="'.subsite_config('aix.system.map.map.max_level').'">
  185. <div class="form-control" style=height:380px;border:1px solid #CCCCCC; cursor: pointer;" id="container"></div></div>', '地图标注')->setMustMark();
  186. return $form;
  187. }
  188. public function store(Request $request){
  189. $verify = $this->form()->getValidateInput();
  190. $input = $request->post();
  191. $verify['companys'] = implode(',',$verify['companys']);
  192. $verify['map_x'] = $input['map_x'];
  193. $verify['map_y'] = $input['map_y'];
  194. $verify['map_zoom'] = $input['map_zoom'];
  195. try {
  196. JobfairsIc::create($verify);
  197. DB::commit();
  198. }catch (\Exception $e) {
  199. DB::rollback();
  200. return admin_toastr($e->getMessage(), 'error');
  201. }
  202. }
  203. public function update($id,Request $request)
  204. {
  205. $verify = $this->form()->getValidateInput();
  206. $input = $request->post();
  207. $verify['companys'] = implode(',',$verify['companys']);
  208. $verify['map_x'] = $input['map_x'];
  209. $verify['map_y'] = $input['map_y'];
  210. $verify['map_zoom'] = $input['map_zoom'];
  211. try {
  212. JobfairsIc::where('id',$id)->update($verify);
  213. DB::commit();
  214. }catch (\Exception $e) {
  215. DB::rollback();
  216. return admin_toastr($e->getMessage(), 'error');
  217. }
  218. }
  219. public function destroy($id)
  220. {
  221. if ($this->form()->destroy($id)) {
  222. $data = [
  223. 'status' => true,
  224. 'message' => trans('admin.delete_succeeded'),
  225. ];
  226. } else {
  227. $data = [
  228. 'status' => false,
  229. 'message' => trans('admin.delete_failed'),
  230. ];
  231. }
  232. return response()->json($data);
  233. }
  234. public function jobfairsAppointList(Content $content,Request $request)
  235. {
  236. $search_data = $request->all();
  237. $where = [
  238. ['pid', '=', $search_data['id']],
  239. ];
  240. foreach ($search_data as $k => $v) {
  241. if ($k == 'realname') {
  242. $where[] = [$k, 'like', "%$v%"];
  243. } elseif (in_array($k, ['sex', 'education'])) {
  244. $where[] = [$k, '=', $v];
  245. }
  246. }
  247. $perpage = 20;
  248. $list = JobFairsIcAppoint::where($where)
  249. ->orderBy('updated_at', 'desc')
  250. ->paginate($perpage);
  251. foreach ($list as $k => $v) {
  252. if ($v->fresh == 1) {
  253. $list[$k]['fresh'] = '是';
  254. } else {
  255. $list[$k]['fresh'] = '否';
  256. }
  257. if ($v->sex == 1) {
  258. $list[$k]['sex'] = '男';
  259. } else {
  260. $list[$k]['sex'] = '女';
  261. }
  262. if ($v->status == 0) {
  263. $list[$k]['status'] = '未下载';
  264. } else {
  265. $list[$k]['status'] = '已下载';
  266. }
  267. if (empty($v->attachment)) {
  268. $list[$k]['is_attachment'] = '未上传';
  269. } else {
  270. $list[$k]['is_attachment'] = '已上传';
  271. }
  272. }
  273. return $content
  274. ->header('报名管理')
  275. ->description('招聘会报名的人员信息管理')
  276. ->body(view('admin.ic.jobfairs_appoint_list')->with([
  277. 'list' => $list,
  278. 'search_data' => $search_data,
  279. ]));
  280. }
  281. public function jobfairsAppointStatus(Request $request)
  282. {
  283. $info = JobFairsIcAppoint::where(['id' => $request->id])->first();
  284. if ($info && $info->attachment) {
  285. $info->status = 1;
  286. $info->save();
  287. return response()->json(['status' => 1, 'msg' => '跳转下载中!', 'data' => 'ok', 'url' => $info->attachment]);
  288. } else {
  289. return response()->json(['status' => 0, 'msg' => '用户未上传简历!', 'data' => 'fail']);
  290. }
  291. //return "/storage/recruit/word/" . $recruit->name_en . '/' .$appoint->audit .$word_url;
  292. }
  293. }