JobfairoutController.php 36 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690
  1. <?php
  2. namespace App\Admin\Controllers\Jobfairout;
  3. use App\Http\Controllers\Controller;
  4. use App\Models\Jobfairout\Jobfairout;
  5. use App\Models\Jobfairout\JobfairoutCompany;
  6. use App\Models\Jobfairout\JobfairoutFeedback;
  7. use App\Models\Jobfairout\JobfairoutPutJob;
  8. use App\Models\Jobfairout\JobfairoutReserve;
  9. use App\Models\Jobfairout\JobfairoutSchool;
  10. use App\Models\SubsiteJobfairout;
  11. use App\Admin\Exports\Jobfairout\PersonExport;
  12. use App\Admin\Exports\Jobfairout\JobsExport;
  13. use App\Admin\Exports\Jobfairout\FeedbackExport;
  14. use App\Models\Subsite;
  15. use Encore\Admin\Controllers\HasResourceActions;
  16. use Encore\Admin\Facades\Admin;
  17. use Encore\Admin\Form;
  18. use Encore\Admin\Grid;
  19. use Encore\Admin\Layout\Content;
  20. use Encore\Admin\Show;
  21. use Illuminate\Http\Request;
  22. use Illuminate\Support\Facades\DB;
  23. class JobfairoutController extends Controller
  24. {
  25. use HasResourceActions;
  26. /**
  27. * Index interface.
  28. *
  29. * @param Content $content
  30. * @return Content
  31. */
  32. public function index(Content $content)
  33. {
  34. return $content
  35. ->header('赴外招聘会列表')
  36. ->description('')
  37. ->body($this->grid());
  38. }
  39. /**
  40. * Show interface.
  41. *
  42. * @param mixed $id
  43. * @param Content $content
  44. * @return Content
  45. */
  46. public function show($id, Content $content)
  47. {
  48. // dd(\request()->route());
  49. return $content
  50. ->header('招聘会详情')
  51. ->description('')
  52. ->body($this->detail($id));
  53. }
  54. /**
  55. * Edit interface.
  56. *
  57. * @param mixed $id
  58. * @param Content $content
  59. * @return Content
  60. */
  61. public function edit($id, Content $content)
  62. {
  63. return $content
  64. ->header('赴外招聘会编辑')
  65. ->description('')
  66. ->body(view('admin.jobfairout.jobfairout')->with(['content'=>$this->editForm($id)])->render());
  67. }
  68. /**
  69. * Create interface.
  70. *
  71. * @param Content $content
  72. * @return Content
  73. */
  74. public function create(Content $content)
  75. {
  76. return $content
  77. ->header('赴外招聘会创建')
  78. ->description('带*号必填项')
  79. ->body(view('admin.jobfairout.jobfairout')->with(['content'=>$this->createForm()])->render());
  80. }
  81. /**
  82. * Make a grid builder.
  83. *
  84. * @return Grid
  85. */
  86. protected function grid()
  87. {
  88. $grid = new Grid(new Jobfairout);
  89. $grid->model()->when(get_subsite_id()>0, function ($query) {
  90. $query->where('subsite_id',get_subsite_id());
  91. })->orderBy('id', 'desc');
  92. $grid->holddate_start('举办时间')->display(function ($holddate_start) {
  93. return "<span style='color:#009900'>".date('Y-m-d H:i', $holddate_start)."&nbsp;至&nbsp;".date('Y-m-d H:i', $this->holddate_end)."</span>";
  94. });
  95. $grid->title('招聘会标题')->display(function ($title) {
  96. return "<a target='_blank' href='".route('jobfairout.show.com',$this->id)."'>".$title."</a>";
  97. })->width(300);
  98. $grid->type('赴外类型')->display(function ($type) {
  99. return $type==1?'本市':'赴外';
  100. });
  101. $grid->predetermined_status('预定状态')->display(function ($predetermined_status) {
  102. if ($predetermined_status==1) {
  103. if($this->predetermined_end > time() && $this->predetermined_start < time()){
  104. return "允许预订";
  105. }elseif($this->predetermined_start > time()){
  106. return "未开始";
  107. }else{
  108. return "停止预订";
  109. }
  110. } else {
  111. return "停止预订";
  112. }
  113. });
  114. $grid->mstatus('预定情况')->display(function () {
  115. $standSuccess = JobfairoutCompany::where(['audit'=>1,'jobfair_id'=>$this->id])->count();
  116. $standAudit = JobfairoutCompany::where(['audit'=>2,'jobfair_id'=>$this->id])->count();
  117. $standFree = $this->number - $standSuccess - $standAudit;
  118. return '<span class="vtip" title="空闲展位数" style="color:#000000;padding-right:10px">['.$standFree.']</span>
  119. <span class="vtip" title="审核中展位数" style="color:#FFCC33;padding-right:10px">['.$standAudit.']</span>
  120. <span class="vtip" title="预定成功展位数" style="color:#CC00CC;padding-right:10px">['.$standSuccess.']</span>
  121. <span class="vtip" title="展位总数" style="color:#3300FF;padding-right:10px">['.$this->number.']</span>';
  122. });
  123. $grid->showendtime('显示截止时间')->display(function ($showendtime) {
  124. return $showendtime ? date('Y-m-d H:i:s', $showendtime) : '不限制';
  125. });
  126. if(get_subsite_id() == 0 && get_subsite_open()){
  127. $grid->subsite_id('所属分站')->display(function ($subsite_id) {
  128. if ($subsite_id) {
  129. $Subsite = Subsite::find($subsite_id);
  130. return isset($Subsite->sitename) ? $Subsite->sitename : '未知';
  131. }
  132. return '总站';
  133. });
  134. }
  135. $grid->created_at('创建时间');
  136. $grid->actions(function ($actions) use ($grid) {
  137. if (Admin::user()->can('jobfairout_index_person')) {
  138. $actions->append('<button class="btn btn-primary btn-xs poster" title="导出参会人" onclick="window.open(\''.route('jobfairout.export.person',['id'=>$actions->row['id']]).'\')" >导出参会人</button>');
  139. }
  140. if (Admin::user()->can('jobfairout_index_jobs')) {
  141. $actions->append('<button class="btn btn-primary btn-xs jobs" title="导出职位" onclick="window.open(\''.route('jobfairout.export.jobs',['id'=>$actions->row['id']]).'\')" >导出职位</button>');
  142. }
  143. if (Admin::user()->can('jobfairout_index_feedback')) {
  144. $actions->append('<button class="btn btn-primary btn-xs feedback" title="导出反馈表" onclick="window.open(\'' . route('jobfairout.export.feedback', ['id' => $actions->row['id']]) . '\')" >导出反馈表</button>');
  145. }
  146. if (Admin::user()->can('jobfairout_index_poster')) {
  147. $actions->append('<button class="btn btn-primary btn-xs poster" title="查看海报" onclick="window.open(\'' . route('jobfairout.poster', ['id' => $actions->row['id']]) . '\')" >查看海报</button>');
  148. }
  149. if (Admin::user()->can('jobfairout_index_edit') && (get_subsite_id() == 0 || $actions->row['subsite_id']== get_subsite_id())) {
  150. $actions->disableEdit(false);
  151. }
  152. if (Admin::user()->can('jobfairout_index_delete') && (get_subsite_id() == 0 || $actions->row['subsite_id']== get_subsite_id())) {
  153. $actions->disableDelete(false);
  154. }
  155. });
  156. $grid->filter(function ($filter) {
  157. $filter->like('title', '招聘会标题');
  158. $filter->equal('type', '招聘会类型')->select(['1'=>'本市','2'=>'赴外']);
  159. $filter->equal('predetermined_status', '预定状态')->select([
  160. 1 => '允许预订',
  161. 2 => '停止预订',
  162. ]);
  163. $filter->between('created_at', '创建时间')->datetime();
  164. if(get_subsite_id() == 0 && get_subsite_open()){
  165. $filter->equal('subsite_id', '所属分站')->select(array_column(get_all_subsite(), 'sitename', 'id'));
  166. }
  167. });
  168. if (Admin::user()->can('jobfairout_index_create')) {
  169. $grid->disableCreateButton(false);
  170. }
  171. return $grid;
  172. }
  173. /**
  174. * Make a show builder.
  175. *
  176. * @param mixed $id
  177. * @return Show
  178. */
  179. protected function detail($id)
  180. {
  181. $show = new Show(Jobfairout::findOrFail($id));
  182. $show->id('ID');
  183. $show->holddate_start('举办时间')->as(function ($holddate_start) {
  184. return date('Y-m-d H:i:s', $holddate_start).'至'.date('Y-m-d H:i:s', $this->holddate_end);
  185. });
  186. $show->title('招聘会标题')->as(function ($title) {
  187. return $title;
  188. });
  189. $show->type('招聘会类型')->as(function ($type) {
  190. return $type==1?'本市':'赴外';
  191. });
  192. $show->predetermined_status('预定状态')->as(function ($predetermined_status) {
  193. if ($predetermined_status==1) {
  194. if($this->predetermined_end > time() && $this->predetermined_start < time()){
  195. return "允许预订";
  196. }elseif($this->predetermined_start > time()){
  197. return "未开始";
  198. }else{
  199. return "停止预订";
  200. }
  201. } else {
  202. return "停止预订";
  203. }
  204. });
  205. $show->showendtime('显示截止时间')->as(function ($showendtime) {
  206. return $showendtime ? date('Y-m-d H:i:s', $showendtime) : '不限制';
  207. });
  208. $show->subsite_id('所属分站')->as(function ($subsite_id) {
  209. if ($subsite_id) {
  210. $Subsite = Subsite::find($subsite_id);
  211. return isset($Subsite->sitename) ? $Subsite->sitename : '未知';
  212. }
  213. return '总站';
  214. });
  215. $show->created_at('创建时间');
  216. $show->updated_at('更新时间');
  217. return $show;
  218. }
  219. protected function createForm()
  220. {
  221. $form = new Form(new Jobfairout);
  222. $form->tab('基本信息',function ($form){
  223. $form->text('title', '招聘会标题')->placeholder('如:2017年5月1日(星期六)医药行业主题招聘会')->default(session('content')['title'])->setMustMark();
  224. $form->text('industry', '行业主题')->default(session('content')['industry']);
  225. $form->url('url', '招聘会链接地址')->default(session('content')['url']);
  226. $form->number('number', '展位数量')->min(1)->default(1)->help('展位数量');
  227. $form->text('contact', '联系人')->default(session('content')['contact'])->setMustMark();
  228. $form->text('phone', '联系电话')->default(session('content')['phone'])->help('多个号码请用英文半角“,”隔开!')->setMustMark();
  229. $form->select('type', '赴外类型')->options(['1'=>'本市','2'=>'赴外'])->default(session('content')['type'] ? session('content')['type'] : 1);
  230. if (get_subsite_id()==0) {
  231. $subsites = Subsite::where(array('effective'=>1))->orderBy('order', 'asc')->get()->pluck('sitename', 'id')->toArray();
  232. } else {
  233. $subsites = Subsite::where(array(array('effective','=',1),array('id','<>', get_subsite_id())))->orderBy('order', 'asc')->get()->pluck('sitename', 'id')->toArray();
  234. $subsites[0] = '总站';
  235. }
  236. if ($subsites && get_subsite_open()) {
  237. $form->multipleSelect('subsites', '同步分站')->options($subsites);
  238. }
  239. $form->hidden('subsite_id')->value(get_subsite_id());
  240. $form->editor('jobfair_introduction', '招聘会简介')->default(session('content')['jobfair_introduction'])->setMustMark();
  241. })->tab('举办信息',function ($form){
  242. $form->datetime('holddate_start', '举办开始时间')->format('YYYY-MM-DD HH:mm:ss')->default(session('content')['holddate_start'])->setMustMark();
  243. $form->datetime('holddate_end', '举办结束时间')->format('YYYY-MM-DD HH:mm:ss')->default(session('content')['holddate_end'])->setMustMark();
  244. $form->datetime('predetermined_start', '预定开始时间')->format('YYYY-MM-DD HH:mm:ss')->default(session('content')['predetermined_start'])->setMustMark();
  245. $form->datetime('predetermined_end', '预定结束时间')->format('YYYY-MM-DD HH:mm:ss')->default(session('content')['predetermined_end'])->setMustMark();
  246. $form->datetime('showendtime', '显示截止时间')->format('YYYY-MM-DD HH:mm:ss')->help('不填不限制')->default(session('content')['showendtime']);
  247. $schools = JobfairoutSchool::pluck('name', 'id')->toArray();
  248. $form->multipleSelect('school_id', '选择高校')->options($schools);
  249. $form->text('address', '举办地址')->default(session('content')['address'])->setMustMark();
  250. $form->html('<div id="searchResultPanel" style="border:1px solid #C0C0C0;height:100px; display:none;"></div>');
  251. $form->html(' <div class="fr">
  252. <input name="map_x" type="hidden" id="x" value="'.subsite_config('aix.system.map.map.map_x').'">
  253. <input name="map_y" type="hidden" id="y" value="'.subsite_config('aix.system.map.map.map_y').'">
  254. <input name="map_zoom" type="hidden" id="zoom" value="'.subsite_config('aix.system.map.map.max_level').'">
  255. <div class="form-control" style=height:380px;border:1px solid #CCCCCC; cursor: pointer;" id="container"></div></div>', '地图标注')->setMustMark();
  256. })->tab('设置',function ($form){
  257. $form->radio('display', '显示状态')->options([1=>'正常',2=>'暂停'])->default(1);
  258. $form->radio('predetermined_status', '预定状态')->options([1=>'允许预订',2=>'停止预订'])->default(1);
  259. $form->radio('is_commonweal', '招聘会')->options([1=>'场次',2=>'积分',3=>'公益'])->default(3)->help('选择公益招聘会,企业预订免费!')->attribute('class', "is_commonweal");
  260. $form->number('predetermined_point', '预定消耗积分')->min(1)->default(100)->help('选择积分招聘会,企业预订则抵扣积分!');
  261. $form->number('jobsfair_num', '预定消耗场次')->min(1)->default(1)->help('选择场次招聘会,企业预订则抵扣场次!');
  262. $form->number('nosign_point', '未签到扣减积分')->min(1)->default(300)->help('单位:积分');
  263. $form->number('late_point', '迟到早退扣减积分')->min(1)->default(100)->help('单位:积分');
  264. $form->number('ordid', '排序')->min(0)->default(0)->help('数字越大,排序越靠前');
  265. });
  266. $form->disableReset();
  267. return $form->render();
  268. }
  269. /**
  270. * Make a form builder.
  271. *
  272. * @return Form
  273. */
  274. protected function editForm($id)
  275. {
  276. $Jobfair = Jobfairout::findOrFail($id);
  277. $form = new Form(new Jobfairout());
  278. $form->hidden('id')->default($Jobfair->id);
  279. $form->tab('基本信息',function ($form) use($Jobfair,$id){
  280. $form->text('title', '招聘会标题')->placeholder('如:2017年5月1日(星期六)医药行业主题招聘会')->default($Jobfair->title)->setMustMark();
  281. $form->text('industry', '行业主题')->default($Jobfair->industry);
  282. $form->url('url', '招聘会链接地址')->default($Jobfair->url);
  283. $form->number('number', '展位数量')->min(1)->default($Jobfair->number)->help('展位数量');
  284. $form->text('contact', '联系人')->default($Jobfair->contact)->setMustMark();
  285. $form->text('phone', '联系电话')->default($Jobfair->phone)->help('多个号码请用英文半角“,”隔开!')->setMustMark();
  286. $form->select('type', '赴外类型')->options(['1'=>'本市','2'=>'赴外'])->default($Jobfair->type);
  287. if ($Jobfair->subsite_id==0) {
  288. $subsites = Subsite::where(array('effective'=>1))->orderBy('order', 'asc')->get()->pluck('sitename', 'id')->toArray();
  289. } else {
  290. $subsites = Subsite::where(array(array('effective','=',1),array('id','<>', $Jobfair->subsite_id)))->orderBy('order', 'asc')->get()->pluck('sitename', 'id')->toArray();
  291. $subsites[0] = '总站';
  292. }
  293. if ($subsites && get_subsite_open()) {
  294. $relations = SubsiteJobfairout::where(array('jobfair_id'=>$id))->get()->pluck('subsite_id')->toArray();
  295. $form->multipleSelect('subsite_id', '同步分站')->options($subsites)->default($relations);
  296. }
  297. $form->editor('jobfair_introduction', '招聘会简介')->default($Jobfair->jobfair_introduction)->setMustMark();
  298. })->tab('举办信息',function ($form) use($Jobfair){
  299. $form->datetime('holddate_start', '举办开始时间')->format('YYYY-MM-DD HH:mm:ss')->default($Jobfair->holddate_start ? date('Y-m-d H:i:s', $Jobfair->holddate_start) : '')->setMustMark();
  300. $form->datetime('holddate_end', '举办结束时间')->format('YYYY-MM-DD HH:mm:ss')->default($Jobfair->holddate_end ? date('Y-m-d H:i:s', $Jobfair->holddate_end) : '')->setMustMark();
  301. $form->datetime('predetermined_start', '预定开始时间')->format('YYYY-MM-DD HH:mm:ss')->default($Jobfair->predetermined_start ? date('Y-m-d H:i:s', $Jobfair->predetermined_start) : '')->setMustMark();
  302. $form->datetime('predetermined_end', '预定结束时间')->format('YYYY-MM-DD HH:mm:ss')->default($Jobfair->predetermined_end ? date('Y-m-d H:i:s', $Jobfair->predetermined_end) : '')->setMustMark();
  303. $form->datetime('showendtime', '显示截止时间')->format('YYYY-MM-DD HH:mm:ss')->default($Jobfair->showendtime ? date('Y-m-d H:i:s', $Jobfair->showendtime) : '')->help('不填不限制');
  304. $schools = JobfairoutSchool::pluck('name', 'id')->toArray();
  305. $form->multipleSelect('school_id', '选择高校')->options($schools)->default(explode(',',$Jobfair->school_id));
  306. $form->text('address', '举办地址')->default($Jobfair->address)->setMustMark();
  307. $form->html('<div id="searchResultPanel" style="border:1px solid #C0C0C0;height:100px; display:none;"></div>');
  308. $map_x = $Jobfair->map_x ? $Jobfair->map_x : subsite_config('aix.system.map.map.map_x');
  309. $map_y = $Jobfair->map_y ? $Jobfair->map_y : subsite_config('aix.system.map.map.map_y');
  310. $form->html(' <div class="fr">
  311. <input name="map_x" type="hidden" id="x" value="'.$map_x.'">
  312. <input name="map_y" type="hidden" id="y" value="'.$map_y.'">
  313. <input name="map_zoom" type="hidden" id="zoom" value="'.subsite_config('aix.system.map.map.max_level').'">
  314. <div class="form-control" style="height:380px;border:1px solid #CCCCCC; cursor: pointer;" id="container"></div>
  315. </div>', '地图标注')->setMustMark();
  316. })->tab('设置',function ($form) use($Jobfair){
  317. $form->radio('display', '显示状态')->options([1=>'正常',2=>'暂停'])->default($Jobfair->display);
  318. $form->radio('predetermined_status', '预定状态')->options([1=>'允许预订',2=>'停止预订'])->default($Jobfair->predetermined_status);
  319. $form->radio('is_commonweal', '招聘会')->options([1=>'场次',2=>'积分',3=>'公益'])->default($Jobfair->is_commonweal)->help('选择公益招聘会,企业预订免费!')->attribute('class', "is_commonweal");
  320. $form->number('predetermined_point', '预定消耗积分')->min(1)->default($Jobfair->predetermined_point)->help('选择积分招聘会,企业预订则抵扣积分!');
  321. $form->number('jobsfair_num', '预定消耗场次')->min(1)->default($Jobfair->jobsfair_num)->help('选择场次招聘会,企业预订则抵扣场次!');
  322. $form->number('nosign_point', '未签到扣减积分')->min(1)->default($Jobfair->nosign_point)->help('单位:积分');
  323. $form->number('late_point', '迟到早退扣减积分')->min(1)->default($Jobfair->late_point)->help('单位:积分');
  324. $form->number('ordid', '排序')->min(0)->default($Jobfair->ordid)->help('数字越大,排序越靠前');
  325. $form->hidden('_method')->default('put');
  326. });
  327. $form->disableReset();
  328. return $form->render();
  329. }
  330. public function store(Request $request)
  331. {
  332. $request->validate([
  333. 'title' => 'required',
  334. 'number' => 'required|integer',
  335. 'holddate_start' => 'required',
  336. 'holddate_end' => 'required',
  337. 'predetermined_start' => 'required',
  338. 'predetermined_end' => 'required',
  339. 'address' => 'required', //举办地址。
  340. 'contact' => 'required',
  341. 'phone' => 'required|max:100',
  342. 'jobfair_introduction' => 'required',
  343. ],[
  344. 'title.required'=>'请填写标题',
  345. 'number.required'=>'请填写展位数量',
  346. 'number.integer'=>'展位数量必须为数字',
  347. 'holddate_start.required'=>'请填写举办开始时间',
  348. 'holddate_end.required'=>'请填写举办结束时间',
  349. 'predetermined_start.required'=>'请填写预定开始时间',
  350. 'predetermined_end.required'=>'请填写预定结束时间',
  351. 'areaid.required'=>'请填写举办场地',
  352. 'address.required'=>'请填写举办地址',
  353. 'contact.required'=>'请填写联系人',
  354. 'phone.required'=>'请填写联系方式',
  355. 'phone.max'=>'联系方式最多不超过100字',
  356. 'jobfair_introduction.required'=>'请填写简介',
  357. ]);
  358. if ( preg_match ("/[\x{4e00}-\x{9fa5}]/u", $request->holddate_start) || preg_match ("/[\x{4e00}-\x{9fa5}]/u", $request->holddate_end) || preg_match ("/[\x{4e00}-\x{9fa5}]/u", $request->predetermined_start) || preg_match ("/[\x{4e00}-\x{9fa5}]/u", $request->predetermined_end) || preg_match ("/[\x{4e00}-\x{9fa5}]/u", $request->showendtime) ) {
  359. admin_toastr('举办/预定时间不能含有中文!', 'error');
  360. return back()->with(['content'=>$request->all()]);
  361. }
  362. if ( preg_match ("/[\x{4e00}-\x{9fa5}]/u", $request->phone) || preg_match ("/[\x{4e00}-\x{9fa5}]/u", $request->predetermined_point) || preg_match ("/[\x{4e00}-\x{9fa5}]/u", $request->jobsfair_num) || preg_match ("/[\x{4e00}-\x{9fa5}]/u", $request->nosign_point) || preg_match ("/[\x{4e00}-\x{9fa5}]/u", $request->late_point) || preg_match ("/[\x{4e00}-\x{9fa5}]/u", $request->ordid) ) {
  363. admin_toastr('积分/场次/联系电话不能含有中文!', 'error');
  364. return back()->with(['content'=>$request->all()]);
  365. }
  366. foreach (explode(',',$request->phone) as $value){
  367. if(!(preg_match ('/^1[3-9]{1}[0-9]{9}$/', $value) || preg_match ('/^([0-9]{3,4}-)?[0-9]{7,8}$/', $value))){
  368. admin_toastr('请输入正确的联系电话', 'error');
  369. return back()->with(['content'=>$request->all()]);
  370. }
  371. }
  372. if ($request->holddate_start >= $request->holddate_end) {
  373. admin_toastr('举办开始时间不能大于结束时间!!', 'error');
  374. return back()->with(['content'=>$request->all()]);
  375. }
  376. if ($request->predetermined_start >= $request->holddate_start) {
  377. admin_toastr('预订开始时间不能大于举办开始时间!!', 'error');
  378. return back()->with(['content'=>$request->all()]);
  379. }
  380. if ($request->predetermined_start >= $request->predetermined_end) {
  381. admin_toastr('预订开始时间不能大于结束时间!!', 'error');
  382. return back()->with(['content'=>$request->all()]);
  383. }
  384. if ($request->predetermined_end > $request->holddate_end) {
  385. admin_toastr('预订结束时间不能大于举办结束时间!!', 'error');
  386. return back()->with(['content'=>$request->all()]);
  387. }
  388. $jobfairout = [];
  389. $jobfairout['title'] = $request->title;
  390. $jobfairout['industry'] = $request->industry;
  391. $jobfairout['holddate_start'] = strtotime($request->holddate_start);
  392. $jobfairout['holddate_end'] = strtotime($request->holddate_end);
  393. $jobfairout['type'] = $request->type;
  394. $jobfairout['showendtime'] = strtotime($request->showendtime);
  395. $jobfairout['address'] = $request->address;
  396. $jobfairout['contact'] = $request->contact;
  397. $apiAddress = $this->apiAddress($request->address);
  398. if (!$apiAddress) {
  399. admin_toastr('请添加地图标注!!', 'error');
  400. return back()->with(['content'=>$request->all()]);
  401. }
  402. $jobfairout['map_x'] = $apiAddress['lng'];
  403. $jobfairout['map_y'] = $apiAddress['lat'];
  404. $jobfairout['phone'] = $request->phone;
  405. $jobfairout['display'] = $request->display;
  406. $jobfairout['is_commonweal'] = $request->is_commonweal;
  407. $jobfairout['predetermined_point'] = $request->predetermined_point;
  408. $jobfairout['jobsfair_num'] = $request->jobsfair_num;
  409. $jobfairout['nosign_point'] = $request->nosign_point;
  410. $jobfairout['late_point'] = $request->late_point;
  411. $jobfairout['ordid'] = $request->ordid;
  412. $jobfairout['number'] = $request->number;
  413. $jobfairout['jobfair_introduction'] = $request->jobfair_introduction;
  414. $jobfairout['subsite_id'] = get_subsite_id();
  415. $jobfairout['predetermined_status'] = $request->predetermined_status;
  416. $jobfairout['predetermined_start'] = $request->predetermined_start ? strtotime($request->predetermined_start) : $request->predetermined_start;
  417. $jobfairout['predetermined_end'] = $request->predetermined_end ? strtotime($request->predetermined_end) : $request->predetermined_end;
  418. $school_id = array_filter($request->school_id);
  419. $jobfairout['school_id'] = implode(',',$school_id);
  420. $jobfairout['url'] = $request->url;
  421. DB::beginTransaction();
  422. try {
  423. $Jobfair = Jobfairout::create($jobfairout);
  424. $subsites = \Illuminate\Support\Facades\Request::input('subsites');
  425. if (get_subsite_id() == 0 && $subsites) {
  426. $subsites = array_merge(array(get_subsite_id()), $subsites);
  427. } else {
  428. $subsites = array(get_subsite_id());
  429. }
  430. $set_data = array();
  431. foreach ($subsites as $k => $v) {
  432. if ($v !== null) {
  433. $set_data[] = array(
  434. 'jobfair_id' => $Jobfair->id,
  435. 'subsite_id'=> $v,
  436. 'created_at'=>date('Y-m-d H:i:s'),
  437. 'updated_at'=>date('Y-m-d H:i:s'),
  438. );
  439. }
  440. }
  441. SubsiteJobfairout::insert($set_data);
  442. DB::commit();
  443. admin_toastr('操作成功!', 'success');
  444. return redirect(route('jobfairout.index'));
  445. } catch (\Exception $e) {
  446. DB::rollback();
  447. admin_toastr($e->getMessage(), 'error');
  448. return back();
  449. }
  450. }
  451. public function update(Request $request)
  452. {
  453. $request->validate([
  454. 'title' => 'required',
  455. 'number' => 'required|integer',
  456. 'holddate_start' => 'required',
  457. 'holddate_end' => 'required',
  458. 'predetermined_start' => 'required',
  459. 'predetermined_end' => 'required',
  460. 'address' => 'required', //举办地址。
  461. 'contact' => 'required',
  462. 'phone' => 'required|max:100',
  463. 'jobfair_introduction' => 'required',
  464. ],[
  465. 'title.required'=>'请填写标题',
  466. 'number.required'=>'请填写展位数量',
  467. 'number.integer'=>'展位数量必须为数字',
  468. 'holddate_start.required'=>'请填写举办开始时间',
  469. 'holddate_end.required'=>'请填写举办结束时间',
  470. 'predetermined_start.required'=>'请填写预定开始时间',
  471. 'predetermined_end.required'=>'请填写预定结束时间',
  472. 'address.required'=>'请填写举办地址',
  473. 'contact.required'=>'请填写联系人',
  474. 'phone.required'=>'请填写联系方式',
  475. 'phone.max'=>'联系方式最多不超过100字',
  476. 'jobfair_introduction.required'=>'请填写简介',
  477. ]);
  478. if ( preg_match ("/[\x{4e00}-\x{9fa5}]/u", $request->holddate_start) || preg_match ("/[\x{4e00}-\x{9fa5}]/u", $request->holddate_end) || preg_match ("/[\x{4e00}-\x{9fa5}]/u", $request->predetermined_start) || preg_match ("/[\x{4e00}-\x{9fa5}]/u", $request->predetermined_end) || preg_match ("/[\x{4e00}-\x{9fa5}]/u", $request->showendtime) ) {
  479. admin_toastr('举办/预定时间不能含有中文!', 'error');
  480. return back();
  481. }
  482. if ( preg_match ("/[\x{4e00}-\x{9fa5}]/u", $request->phone) || preg_match ("/[\x{4e00}-\x{9fa5}]/u", $request->predetermined_point) || preg_match ("/[\x{4e00}-\x{9fa5}]/u", $request->jobsfair_num) || preg_match ("/[\x{4e00}-\x{9fa5}]/u", $request->nosign_point) || preg_match ("/[\x{4e00}-\x{9fa5}]/u", $request->late_point) || preg_match ("/[\x{4e00}-\x{9fa5}]/u", $request->ordid) ) {
  483. admin_toastr('积分/场次/联系电话不能含有中文!', 'error');
  484. return back();
  485. }
  486. foreach (explode(',',$request->phone) as $value){
  487. if(!(preg_match ('/^1[3-9]{1}[0-9]{9}$/', $value) || preg_match ('/^([0-9]{3,4}-)?[0-9]{7,8}$/', $value))){
  488. admin_toastr('请输入正确的联系电话', 'error');
  489. return back();
  490. }
  491. }
  492. $jobfairout_id = $request->id;
  493. if (empty($jobfairout_id)) {
  494. admin_toastr('招聘会不存在!', 'error');
  495. return back();
  496. }
  497. if ($request->holddate_start >= $request->holddate_end) {
  498. admin_toastr('举办开始时间不能大于结束时间!!', 'error');
  499. return back();
  500. }
  501. if ($request->predetermined_start >= $request->predetermined_end) {
  502. admin_toastr('预订开始时间不能大于结束时间!!', 'error');
  503. return back();
  504. }
  505. if ($request->predetermined_end > $request->holddate_end) {
  506. admin_toastr('预订结束时间不能大于举办结束时间!!', 'error');
  507. return back();
  508. }
  509. $jobfairout = [];
  510. $jobfairout['title'] = $request->title;
  511. $jobfairout['industry'] = $request->industry;
  512. $jobfairout['holddate_start'] = strtotime($request->holddate_start);
  513. $jobfairout['holddate_end'] = strtotime($request->holddate_end);
  514. $jobfairout['type'] = $request->type;
  515. $jobfairout['type'] = $request->type;
  516. $jobfairout['showendtime'] = strtotime($request->showendtime);
  517. $jobfairout['address'] = $request->address;
  518. $jobfairout['contact'] = $request->contact;
  519. $apiAddress = $this->apiAddress($request->address);
  520. if (!$apiAddress) {
  521. admin_toastr('请添加地图标注!!', 'error');
  522. return back();
  523. }
  524. $jobfairout['map_x'] = $apiAddress['lng'];
  525. $jobfairout['map_y'] = $apiAddress['lat'];
  526. $jobfairout['phone'] = $request->phone;
  527. $jobfairout['display'] = $request->display;
  528. $jobfairout['is_commonweal'] = $request->is_commonweal;
  529. $jobfairout['predetermined_point'] = $request->predetermined_point;
  530. $jobfairout['jobsfair_num'] = $request->jobsfair_num;
  531. $jobfairout['nosign_point'] = $request->nosign_point;
  532. $jobfairout['late_point'] = $request->late_point;
  533. $jobfairout['ordid'] = $request->ordid;
  534. $jobfairout['jobfair_introduction'] = $request->jobfair_introduction;
  535. $school_id = array_filter($request->school_id);
  536. $jobfairout['school_id'] = implode(',',$school_id);
  537. $jobfairout['url'] = $request->url;
  538. $jobfairout['number'] = $request->number;
  539. if(is_array($request->subsite_id)){
  540. $subsiteArr = $request->subsite_id;
  541. $subsite_id = [];
  542. foreach ($subsiteArr as $key => $val) {
  543. if ($val!==null) {
  544. $subsite_id[] = $val;
  545. }
  546. }
  547. $own_subsite_id = Jobfairout::findOrFail($jobfairout_id)->subsite_id;
  548. $subsiteJobfair = [
  549. [
  550. 'jobfair_id'=>$jobfairout_id,
  551. 'subsite_id'=> $own_subsite_id,
  552. 'created_at'=>date('Y-m-d H:i:s'),
  553. 'updated_at'=>date('Y-m-d H:i:s'),
  554. ]
  555. ];
  556. if ($subsite_id) {
  557. $subsiteArr = [];
  558. foreach ($subsite_id as $key => $val) {
  559. $subsiteArr[$key]['jobfair_id'] = $jobfairout_id;
  560. $subsiteArr[$key]['subsite_id'] = $val;
  561. $subsiteArr[$key]['created_at'] = date('Y-m-d H:i:s');
  562. $subsiteArr[$key]['updated_at'] = date('Y-m-d H:i:s');
  563. }
  564. if (in_array($own_subsite_id, $subsite_id)) {
  565. $subsiteJobfair = $subsiteArr;
  566. } else {
  567. $subsiteJobfair = array_merge($subsiteJobfair, $subsiteArr);
  568. }
  569. }
  570. }
  571. $jobfairout['predetermined_status'] = $request->predetermined_status;
  572. $jobfairout['predetermined_start'] = $request->predetermined_start ? strtotime($request->predetermined_start) : $request->predetermined_start;
  573. $jobfairout['predetermined_end'] = $request->predetermined_end ? strtotime($request->predetermined_end) : $request->predetermined_end;
  574. DB::beginTransaction();
  575. try {
  576. Jobfairout::where('id', $jobfairout_id)->update($jobfairout);
  577. if(isset($subsiteJobfair)){
  578. SubsiteJobfairout::where('jobfair_id', $jobfairout_id)->delete();
  579. SubsiteJobfairout::insert($subsiteJobfair);
  580. }
  581. DB::commit();
  582. admin_toastr('操作成功!', 'success');
  583. return redirect(route('jobfairout.index'));
  584. } catch (\Exception $e) {
  585. DB::rollback();
  586. admin_toastr($e->getMessage(), 'error');
  587. return back();
  588. }
  589. }
  590. public function destroy($id)
  591. {
  592. if (Jobfairout::destroy($id)) {
  593. $data = [
  594. 'status' => true,
  595. 'message' => trans('admin.delete_succeeded'),
  596. ];
  597. } else {
  598. $data = [
  599. 'status' => false,
  600. 'message' => trans('admin.delete_failed'),
  601. ];
  602. }
  603. return response()->json($data);
  604. }
  605. protected function apiAddress($address)
  606. {
  607. $url='https://api.map.baidu.com/geocoder/v2/?address='.$address.'&output=json&ak='.subsite_config('aix.system.map.map.map_ak')."&s=1";
  608. if ($result=file_get_contents($url)) {
  609. $data = array();
  610. $res= json_decode($result, true);
  611. if ($res['status']==0) {
  612. $results = $res['result'];
  613. $data['lng'] = $results['location']['lng'];
  614. $data['lat'] = $results['location']['lat'];
  615. }
  616. return $data;
  617. }
  618. }
  619. public function jobfairoutPoster(Request $request)
  620. {
  621. $id = $request->id;
  622. $poster = JobfairoutCompany::where('jobfair_id',$id)->get();
  623. $jonfairout_title= Jobfairout::where('id',$id)->value('title');
  624. return view('admin.jobfairout.jobfair_poster',['poster'=>$poster,'jonfairout_title'=>$jonfairout_title]);
  625. }
  626. public function exportPerson(Request $request){
  627. $id = $request->id;
  628. $Jobfair_reserve = JobfairoutReserve::where(array('jobfair_id'=>$id))->orderBy('company_id')->get();
  629. $export = new PersonExport();
  630. $export->setCustomerData($Jobfair_reserve)->export();//这里不需要return
  631. }
  632. public function exportJobs(Request $request){
  633. $id = $request->id;
  634. $Jobs = JobfairoutPutJob::where(['jobfair_id'=>$id,'audit'=>1])->orderBy('exid')->get();
  635. $export = new JobsExport();
  636. $export->setCustomerData($Jobs)->export();//这里不需要return
  637. }
  638. public function exportFeedback(Request $request){
  639. $id = $request->id;
  640. $feedback = JobfairoutFeedback::where(['jobfair_id'=>$id])->get();
  641. foreach ($feedback as &$value)
  642. {
  643. $value['resumeNum'] = explode(',',$value['resumeNum']);
  644. $value['agreeNum'] = explode(',',$value['agreeNum']);
  645. $value['signNum'] = explode(',',$value['signNum']);
  646. }
  647. $export = new FeedbackExport();
  648. $export->setCustomerData($feedback)->export();//这里不需要return
  649. }
  650. }