JobfairController.php 56 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110
  1. <?php
  2. namespace App\Admin\Controllers\Jobfair;
  3. use App\Http\Controllers\Controller;
  4. use App\Http\Controllers\Statistics\CompanyController;
  5. use App\Models\Company;
  6. use App\Models\Jobfair\Floorplan;
  7. use App\Models\Jobfair\FloorplanStand;
  8. use App\Models\Jobfair\Jobfair;
  9. use App\Models\Jobfair\JobfairCompany;
  10. use App\Models\Jobfair\JobfairFloorplan;
  11. use App\Models\Jobfair\JobfairManagement;
  12. use App\Models\Jobfair\JobfairPersonSigned;
  13. use App\Models\MemberInfo;
  14. use App\Models\Subsite;
  15. use App\Models\SubsiteJobfair;
  16. use Encore\Admin\Controllers\HasResourceActions;
  17. use Encore\Admin\Facades\Admin;
  18. use Encore\Admin\Form;
  19. use Encore\Admin\Grid;
  20. use Encore\Admin\Layout\Content;
  21. use Encore\Admin\Show;
  22. use Illuminate\Http\Request;
  23. use Illuminate\Support\Facades\DB;
  24. use Illuminate\Support\Facades\Cache;
  25. use App\Models\Jobfair\JobfairPutJob;
  26. use App\Admin\Exports\Jobfair\HaibaoExport;
  27. use App\Admin\Exports\Jobfair\QiandaoExport;
  28. use Illuminate\Support\Collection;
  29. class JobfairController extends Controller
  30. {
  31. use HasResourceActions;
  32. /**
  33. * Index interface.
  34. *
  35. * @param Content $content
  36. * @return Content
  37. */
  38. public function index(Content $content)
  39. {
  40. return $content
  41. ->header('招聘会列表')
  42. ->description('')
  43. ->body($this->grid());
  44. }
  45. /**
  46. * Show interface.
  47. *
  48. * @param mixed $id
  49. * @param Content $content
  50. * @return Content
  51. */
  52. public function show($id, Content $content)
  53. {
  54. return $content
  55. ->header('招聘会详情')
  56. ->description('')
  57. ->body($this->detail($id));
  58. }
  59. /**
  60. * Edit interface.
  61. *
  62. * @param mixed $id
  63. * @param Content $content
  64. * @return Content
  65. */
  66. public function edit($id, Content $content)
  67. {
  68. return $content
  69. ->header('招聘会编辑')
  70. ->description('')
  71. ->body(view('admin.jobfair.jobfair')->with(['content'=>$this->editForm($id)])->render());
  72. }
  73. /**
  74. * Create interface.
  75. *
  76. * @param Content $content
  77. * @return Content
  78. */
  79. public function create(Content $content)
  80. {
  81. return $content
  82. ->header('招聘会创建')
  83. ->description('带*号必填项')
  84. ->body(view('admin.jobfair.jobfair')->with(['content'=>$this->createForm()])->render());
  85. }
  86. /**
  87. * Make a grid builder.
  88. *
  89. * @return Grid
  90. */
  91. protected function grid()
  92. {
  93. $grid = new Grid(new Jobfair);
  94. $grid->model()->when(get_subsite_id()>0, function ($query) {
  95. $query->where('subsite_id',get_subsite_id());
  96. })->orderBy('id', 'desc');
  97. $grid->holddate_start('举办时间')->display(function ($holddate_start) {
  98. 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>";
  99. });
  100. $grid->title('招聘会标题')->display(function ($title) {
  101. return '<a href="'.route('jobfair.show.com',$this->id).'" target="_blank">'.$title.'</a>';
  102. })->width(300);
  103. $grid->jobfair_type('招聘会类型')->display(function ($jobfair_type) {
  104. $managements = JobfairManagement::all()->pluck('name', 'id');
  105. foreach ($managements as $key=>$value){
  106. if($jobfair_type == $key){
  107. return $value;
  108. break;
  109. }
  110. }
  111. });
  112. $grid->predetermined_status('预定状态')->display(function ($predetermined_status) {
  113. if ($predetermined_status==1) {
  114. if($this->predetermined_end > time() && $this->predetermined_start < time()){
  115. return "允许预订";
  116. }elseif($this->predetermined_start > time()){
  117. return "未开始";
  118. }else{
  119. return "停止预订";
  120. }
  121. } else {
  122. return "停止预订";
  123. }
  124. });
  125. $grid->mstatus('预定情况')->display(function () {
  126. $standAudit = 0;
  127. $standAuditList = [];
  128. $standAuditListName = [];
  129. $standSuccess = 0;
  130. $standSuccessList = [];
  131. $standSuccessListName = [];
  132. $standLock = 0;
  133. $standLockListName = [];
  134. $standFreeList = [];
  135. $standNum = 0;
  136. $FloorplanStand = FloorplanStand::where('jobfair_id', $this->id)->get();
  137. $JobfairCompany = JobfairCompany::where('jobfair_id', $this->id)->whereIn('audit', [1,2])->get();
  138. if (!$FloorplanStand->isEmpty()) {
  139. foreach ($FloorplanStand as $key => $val) {
  140. if ($val->type==2) {
  141. $standLock++;
  142. $standLockListName[]=$val->name;
  143. }
  144. if ($val->type==1) {
  145. $standFreeList[]=$val->id;
  146. }
  147. $standNum++;
  148. }
  149. }
  150. if (!$JobfairCompany->isEmpty()) {
  151. foreach ($JobfairCompany as $key => $val) {
  152. if ($val->audit==1) {
  153. $standSuccess++;
  154. $standSuccessList[]=$val->position_id;
  155. $standSuccessListName[]=$val->position;
  156. } elseif ($val->audit==2) {
  157. $standAudit++;
  158. $standAuditList[]=$val->position_id;
  159. $standAuditListName[] = $val->position;
  160. }
  161. }
  162. }
  163. $standFreeList = array_diff($standFreeList, array_unique(array_merge($standSuccessList, $standAuditList)));
  164. $standFreeListName = FloorplanStand::whereIN('id', $standFreeList)->pluck('name')->all();
  165. return '<span class="vtip" title="空闲展位号['.implode(',', $standFreeListName).']" style="color:#000000;padding-right:10px">['.count($standFreeList).']</span>
  166. <span class="vtip" title="审核中展位号['.implode(',', $standAuditListName).']" style="color:#FFCC33;padding-right:10px">['.$standAudit.']</span>
  167. <span class="vtip" title="预定成功展位号['.implode(',', $standSuccessListName).']" style="color:#CC00CC;padding-right:10px">['.$standSuccess.']</span>
  168. <span class="vtip" title="锁定展位号['.implode(',', $standLockListName).']" style="color:#CCCCCC;padding-right:10px">['.$standLock.']</span>
  169. <span class="vtip" title="展位总数['.$standNum.']" style="color:#3300FF;padding-right:10px">['.$standNum.']</span>';
  170. });
  171. $grid->showendtime('显示截止时间')->display(function ($showendtime) {
  172. return $showendtime ? date('Y-m-d H:i:s', $showendtime) : '不限制';
  173. });
  174. if(get_subsite_id() == 0 && get_subsite_open()){
  175. $grid->subsite_id('所属分站')->display(function ($subsite_id) {
  176. if ($subsite_id) {
  177. $Subsite = Subsite::find($subsite_id);
  178. return isset($Subsite->sitename) ? $Subsite->sitename : '未知';
  179. }
  180. return '总站';
  181. });
  182. }
  183. $grid->created_at('创建时间');
  184. $grid->actions(function ($actions) use ($grid) {
  185. if (Admin::user()->can('jobfair_manager_signed') && (get_subsite_id() == 0 || $actions->row['subsite_id']== get_subsite_id())) {
  186. $actions->append('<a href="'.route('jobfair.signed',['id'=>$actions->row['id']]).'"><button class="btn btn-primary btn-xs business" title="签到" >签到</button></a>');
  187. }
  188. $actions->append('<a href="'.route('jobfair.export_poster',['id'=>$actions->row['id']]).'" target="_blank"><button class="btn btn-primary btn-xs business" title="导出企业海报" >导出企业海报</button></a>');
  189. $actions->append('<a href="'.route('jobfair.export_signin',['id'=>$actions->row['id']]).'" target="_blank"><button class="btn btn-primary btn-xs business" title="导出企业签到" >导出企业签到</button></a>');
  190. if (Admin::user()->can('jobfair_manager_edit') && (get_subsite_id() == 0 || $actions->row['subsite_id']== get_subsite_id())) {
  191. $actions->disableEdit(false);
  192. }
  193. if (Admin::user()->can('jobfair_manager_delete') && (get_subsite_id() == 0 || $actions->row['subsite_id']== get_subsite_id())) {
  194. $actions->disableDelete(false);
  195. }
  196. });
  197. if (Admin::user()->can('jobfair_manager_delete')) {
  198. $grid->tools(function ($tools) {
  199. $tools->batch(function ($batch) {
  200. $batch->disableDelete(false);
  201. });
  202. });
  203. $grid->disableRowSelector();
  204. }
  205. $grid->filter(function ($filter) {
  206. $filter->like('title', '招聘会标题');
  207. $filter->equal('jobfair_type', '招聘会类型')->select(JobfairManagement::all()->pluck('name', 'id'));
  208. $filter->equal('predetermined_status', '预定状态')->select([
  209. 1 => '允许预订',
  210. 2 => '停止预订',
  211. ]);
  212. $filter->between('created_at', '创建时间')->datetime();
  213. if(get_subsite_id() == 0 && get_subsite_open()){
  214. $filter->equal('subsite_id', '所属分站')->select(array_column(get_all_subsite(), 'sitename', 'id'));
  215. }
  216. });
  217. if (Admin::user()->can('jobfair_manager_create')) {
  218. $grid->disableCreateButton(false);
  219. }
  220. return $grid;
  221. }
  222. /**
  223. * Make a show builder.
  224. *
  225. * @param mixed $id
  226. * @return Show
  227. */
  228. protected function detail($id)
  229. {
  230. $show = new Show(Jobfair::findOrFail($id));
  231. $show->id('ID');
  232. $show->holddate_start('举办时间')->as(function ($holddate_start) {
  233. return date('Y-m-d H:i:s', $holddate_start).'至'.date('Y-m-d H:i:s', $this->holddate_end);
  234. });
  235. $show->title('招聘会标题')->as(function ($title) {
  236. return $title;
  237. });
  238. $show->jobfair_type('招聘会类型')->as(function ($jobfair_type) {
  239. $managements = JobfairManagement::all()->pluck('name', 'id');
  240. foreach ($managements as $key=>$value){
  241. if($jobfair_type == $key){
  242. return $value;
  243. break;
  244. }
  245. }
  246. });
  247. $show->predetermined_status('预定状态')->as(function ($predetermined_status) {
  248. if ($predetermined_status==1) {
  249. if($this->predetermined_end > time() && $this->predetermined_start < time()){
  250. return "允许预订";
  251. }elseif($this->predetermined_start > time()){
  252. return "未开始";
  253. }else{
  254. return "停止预订";
  255. }
  256. } else {
  257. return "停止预订";
  258. }
  259. });
  260. $show->showendtime('显示截止时间')->as(function ($showendtime) {
  261. return $showendtime ? date('Y-m-d H:i:s', $showendtime) : '不限制';
  262. });
  263. $show->subsite_id('所属分站')->as(function ($subsite_id) {
  264. if ($subsite_id) {
  265. $Subsite = Subsite::find($subsite_id);
  266. return isset($Subsite->sitename) ? $Subsite->sitename : '未知';
  267. }
  268. return '总站';
  269. });
  270. $show->created_at('创建时间');
  271. $show->updated_at('更新时间');
  272. return $show;
  273. }
  274. /**
  275. * Make a form builder.
  276. *
  277. * @return Form
  278. */
  279. protected function form()
  280. {
  281. $form = new Form(new Jobfair);
  282. $form->display('ID');
  283. $form->display('Created at');
  284. $form->display('Updated at');
  285. return $form;
  286. }
  287. /**
  288. * Make a form builder.
  289. *
  290. * @return Form
  291. */
  292. protected function editForm($id)
  293. {
  294. $Jobfair = Jobfair::findOrFail($id);
  295. $JobfairFloorplan = JobfairFloorplan::where(['jobfair_id'=>$Jobfair->id])->get();
  296. $parmArr = '';
  297. foreach ($JobfairFloorplan as $key => $val) {
  298. $parmName = [];
  299. $FloorplanStand = FloorplanStand::where(['jobfair_id'=>$Jobfair->id,'floorplan_id'=>$val->id])->get();
  300. foreach ($FloorplanStand as $key1 => $val1) {
  301. $parmName[$key1]['name'] = $val1->name;
  302. $parmName[$key1]['type'] = $val1->type;
  303. $parmName[$key1]['left'] = $val1->left;
  304. $parmName[$key1]['top'] = $val1->top;
  305. $parmName[$key1]['id'] = $val1->id;
  306. $parmName[$key1]['equipment_id'] = $val1->equipment_id;
  307. $parmName[$key1]['sortindex'] = $val1->sortindex;
  308. if ($val1->type==2) {
  309. $status = 4;
  310. } else {
  311. if ($val1->id) {
  312. $JobfairCompany = JobfairCompany::where(['position_id'=>$val1->id])->get();
  313. //先给默认值没预定
  314. $status = 1;
  315. //有预定开始循环
  316. foreach ($JobfairCompany as $value){
  317. //第一次循环默认没审核
  318. static $status = 1;
  319. if ($value) {
  320. if($status == 3){
  321. //预定成功直接返回,不做判断
  322. continue;
  323. }elseif ($status == 2 && $value->audit == 3) {
  324. //未审核并且其他审核未通过,不修改值
  325. continue;
  326. }elseif($status == 1){
  327. //第一次进入或未审核
  328. if ($value->audit==1) {
  329. $status = 3;
  330. } elseif ($value->audit==2) {
  331. $status = 2;
  332. } else {
  333. $status = 1;
  334. }
  335. }
  336. }
  337. }
  338. } else {
  339. $status = 1;
  340. }
  341. }
  342. $parmName[$key1]['status'] = $status;
  343. }
  344. $parmArr.="<div class=\"jobfair-item\" data-id=".$val->id.">
  345. <div class=\"jobfair-name\" title=\"\"><input type=\"text\" name=\"jobfairName[]\" value=".$val->name." /></div>
  346. <div class=\"imgbox\"><img src=".upload_asset($val->bg_images)." alt=\"\"></div>
  347. <strong class=\"edit\" ls=\"\" data-toggle=\"modal\" data-target=\"#myModal\">编辑</strong>";
  348. $jonfair_company = JobfairCompany::where('jobfair_id',$id)->get();
  349. if($jonfair_company->isEmpty()){
  350. $parmArr.=" <strong class=\"delete\">删除</strong>";
  351. }
  352. $parmArr.= "<input type=\"hidden\" name=\"thumbnailId[]\" value=".json_encode($parmName)." />
  353. <input type=\"hidden\" name=\"thumbnailImg[]\" value=".$val->bg_images." />
  354. <input type=\"hidden\" name=\"Floorplan_id[]\" value=".$val->id." />
  355. </div>";
  356. }
  357. $form = new Form(new Jobfair());
  358. $form->hidden('id')->default($Jobfair->id);
  359. $form->tab('基本信息',function ($form) use($Jobfair,$id){
  360. $form->text('title', '招聘会标题')->placeholder('如:2017年5月1日(星期六)医药行业主题招聘会')->default($Jobfair->title)->setMustMark();
  361. $form->text('industry', '行业主题')->default($Jobfair->industry);
  362. $form->text('contact', '联系人')->default($Jobfair->contact)->setMustMark();
  363. $form->text('phone', '联系电话')->default($Jobfair->phone)->help('多个号码请用英文半角“,”隔开!')->setMustMark();
  364. $form->select('jobfair_type', '分类')->options(JobfairManagement::all()->pluck('name', 'id'))->default($Jobfair->jobfair_type);
  365. if ($Jobfair->subsite_id==0) {
  366. $subsites = Subsite::where(array('effective'=>1))->orderBy('order', 'asc')->get()->pluck('sitename', 'id')->toArray();
  367. } else {
  368. $subsites = Subsite::where(array(array('effective','=',1),array('id','<>', $Jobfair->subsite_id)))->orderBy('order', 'asc')->get()->pluck('sitename', 'id')->toArray();
  369. $subsites[0] = '总站';
  370. }
  371. if ($subsites && get_subsite_open()) {
  372. $relations = SubsiteJobfair::where(array('jobfair_id'=>$id))->get()->pluck('subsite_id')->toArray();
  373. $form->multipleSelect('subsite_id', '同步分站')->options($subsites)->default($relations);
  374. }
  375. $form->editor('jobfair_introduction', '招聘会简介')->default($Jobfair->jobfair_introduction)->setMustMark();
  376. })->tab('举办信息',function ($form) use($Jobfair,$parmArr){
  377. $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();
  378. $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();
  379. $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();
  380. $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();
  381. $form->datetime('showendtime', '显示截止时间')->format('YYYY-MM-DD HH:mm:ss')->default($Jobfair->showendtime ? date('Y-m-d H:i:s', $Jobfair->showendtime) : '')->help('不填不限制');
  382. $form->select('areaid', '举办场地')->options(Floorplan::all()->pluck('name', 'id'))->default($Jobfair->areaid)->setMustMark();
  383. $form->html("<div id='position_id'>".$parmArr."</div>");
  384. $form->text('address', '举办地址')->default($Jobfair->address)->setMustMark();
  385. $form->html('<div id="searchResultPanel" style="border:1px solid #C0C0C0;height:100px; display:none;"></div>');
  386. $map_x = $Jobfair->map_x ? $Jobfair->map_x : subsite_config('aix.system.map.map.map_x');
  387. $map_y = $Jobfair->map_y ? $Jobfair->map_y : subsite_config('aix.system.map.map.map_y');
  388. $form->html(' <div class="fr">
  389. <input name="map_x" type="hidden" id="x" value="'.$map_x.'">
  390. <input name="map_y" type="hidden" id="y" value="'.$map_y.'">
  391. <input name="map_zoom" type="hidden" id="zoom" value="'.subsite_config('aix.system.map.map.max_level').'">
  392. <div class="form-control" style="height:380px;border:1px solid #CCCCCC; cursor: pointer;" id="container"></div>
  393. </div>', '地图标注')->setMustMark();
  394. $form->text('bus', '乘车路线')->default($Jobfair->bus);
  395. })->tab('设置',function ($form) use($Jobfair){
  396. $form->radio('display', '显示状态')->options([1=>'正常',2=>'暂停'])->default($Jobfair->display);
  397. $form->radio('predetermined_status', '预定状态')->options([1=>'允许预订',2=>'停止预订'])->default($Jobfair->predetermined_status);
  398. $form->radio('more_stand', '预定多个展位')->options([1=>'允许',0=>'不允许'])->default($Jobfair->more_stand)->help('同一家企业允许预订一场招聘会多个展位!');
  399. $form->radio('is_commonweal', '招聘会')->options([1=>'场次',2=>'积分',3=>'公益'])->default($Jobfair->is_commonweal)->help('选择公益招聘会,企业预订免费!')->attribute('class', "is_commonweal");
  400. $form->number('predetermined_point', '预定消耗积分')->min(0)->default($Jobfair->predetermined_point)->help('选择积分招聘会,企业预订则抵扣积分!');
  401. $form->number('jobsfair_num', '预定消耗场次')->min(0)->default($Jobfair->jobsfair_num)->help('选择场次招聘会,企业预订则抵扣场次!');
  402. $form->number('nosign_point', '未签到扣减积分')->min(0)->default($Jobfair->nosign_point)->help('单位:积分');
  403. $form->number('late_point', '迟到早退扣减积分')->min(0)->default($Jobfair->late_point)->help('单位:积分');
  404. $form->number('ordid', '排序')->min(0)->default($Jobfair->ordid)->help('数字越大,排序越靠前');
  405. $form->hidden('_method')->default('put');
  406. $form->html('<template id="thumbnailTpl">
  407. <div class="jobfair-item">
  408. <div class="jobfair-name" title=""><input type="text" name="jobfairName[]" value="" /></div>
  409. <div class="imgbox"><img src="" alt=""></div>
  410. <strong class="edit" ls="" data-toggle="modal" data-target="#myModal">编辑</strong>
  411. <strong class="delete">删除</strong>
  412. <input type="hidden" name="thumbnailId[]" value="" />
  413. <input type="hidden" name="thumbnailImg[]" value="" />
  414. <input type="hidden" name="Floorplan_id[]" value="" />
  415. </div>
  416. </template>');
  417. });
  418. $form->disableReset();
  419. return $form->render();
  420. }
  421. protected function createForm()
  422. {
  423. $form = new Form(new Jobfair);
  424. $parmArr = '';
  425. if (isset(session('content')['jobfairName'])&&!empty(session('content')['jobfairName'])) {
  426. foreach (session('content')['jobfairName'] as $key => $val) {
  427. $parmName = [];
  428. $mk = json_decode(session('content')['thumbnailId'][$key], true);
  429. foreach ($mk as $key1 => $val1) {
  430. $parmName[$key1]['name'] = $val1['name'];
  431. $parmName[$key1]['type'] = $val1['type'];
  432. $parmName[$key1]['left'] = $val1['left'];
  433. $parmName[$key1]['top'] = $val1['top'];
  434. $parmName[$key1]['id'] = $val1['id'];
  435. $parmName[$key1]['equipment_id'] = $val1['equipment_id'];
  436. $parmName[$key1]['sortindex'] = $val1['sortindex'];
  437. if ($val1['type']==2) {
  438. $status = 4;
  439. } else {
  440. if ($val1['id']) {
  441. $JobfairCompany = JobfairCompany::where(['position_id'=>$val1['id']])->first();
  442. if ($JobfairCompany) {
  443. if ($JobfairCompany->audit==1) {
  444. $status = 3;
  445. } elseif ($JobfairCompany->audit==2) {
  446. $status = 2;
  447. } else {
  448. $status = 1;
  449. }
  450. } else {
  451. $status = 1;
  452. }
  453. } else {
  454. $status = 1;
  455. }
  456. }
  457. $parmName[$key1]['status'] = $status;
  458. }
  459. $parmArr.="<div class=\"jobfair-item\" data-id=".session('content')['Floorplan_id'][$key].">
  460. <div class=\"jobfair-name\" title=\"\"><input type=\"text\" name=\"jobfairName[]\" value=".session('content')['jobfairName'][$key]." /></div>
  461. <div class=\"imgbox\"><img src=".upload_asset(session('content')['thumbnailImg'][$key])." alt=\"\"></div>
  462. <strong class=\"edit\" ls=\"\" data-toggle=\"modal\" data-target=\"#myModal\">编辑</strong>
  463. <strong class=\"delete\">删除</strong>
  464. <input type=\"hidden\" name=\"thumbnailId[]\" value=".json_encode($parmName)." />
  465. <input type=\"hidden\" name=\"thumbnailImg[]\" value=".session('content')['thumbnailImg'][$key]." />
  466. <input type=\"hidden\" name=\"Floorplan_id[]\" value=".session('content')['Floorplan_id'][$key]." />
  467. </div>";
  468. }
  469. }
  470. $form->tab('基本信息',function ($form){
  471. $form->text('title', '招聘会标题')->placeholder('如:2017年5月1日(星期六)医药行业主题招聘会')->default(session('content')['title'])->setMustMark();
  472. $form->text('industry', '行业主题')->default(session('content')['industry']);
  473. $form->text('contact', '联系人')->default(session('content')['contact'])->setMustMark();
  474. $form->text('phone', '联系电话')->default(session('content')['phone'])->help('多个号码请用英文半角“,”隔开!')->setMustMark();
  475. $form->select('jobfair_type', '分类')->options(JobfairManagement::all()->pluck('name', 'id'))->default(session('content')['jobfair_type'] ? session('content')['jobfair_type'] : 1);
  476. if (get_subsite_id()==0) {
  477. $subsites = Subsite::where(array('effective'=>1))->orderBy('order', 'asc')->get()->pluck('sitename', 'id')->toArray();
  478. } else {
  479. $subsites = Subsite::where(array(array('effective','=',1),array('id','<>', get_subsite_id())))->orderBy('order', 'asc')->get()->pluck('sitename', 'id')->toArray();
  480. $subsites[0] = '总站';
  481. }
  482. if ($subsites && get_subsite_open()) {
  483. $form->multipleSelect('subsites', '同步分站')->options($subsites);
  484. }
  485. $form->hidden('subsite_id')->value(get_subsite_id());
  486. $form->editor('jobfair_introduction', '招聘会简介')->default(session('content')['jobfair_introduction'])->setMustMark();
  487. })->tab('举办信息',function ($form) use($parmArr){
  488. $form->datetime('holddate_start', '举办开始时间')->format('YYYY-MM-DD HH:mm:ss')->default(session('content')['holddate_start'])->setMustMark();
  489. $form->datetime('holddate_end', '举办结束时间')->format('YYYY-MM-DD HH:mm:ss')->default(session('content')['holddate_end'])->setMustMark();
  490. $form->datetime('predetermined_start', '预定开始时间')->format('YYYY-MM-DD HH:mm:ss')->default(session('content')['predetermined_start'])->setMustMark();
  491. $form->datetime('predetermined_end', '预定结束时间')->format('YYYY-MM-DD HH:mm:ss')->default(session('content')['predetermined_end'])->setMustMark();
  492. $form->datetime('showendtime', '显示截止时间')->format('YYYY-MM-DD HH:mm:ss')->help('不填不限制')->default(session('content')['showendtime']);
  493. $form->select('areaid', '举办场地')->options(Floorplan::all()->pluck('name', 'id'))->default(session('content')['areaid'])->setMustMark();
  494. $form->html("<div id='position_id'>$parmArr</div>");
  495. $form->text('address', '举办地址')->default(session('content')['address'])->setMustMark();
  496. $form->html('<div id="searchResultPanel" style="border:1px solid #C0C0C0;height:100px; display:none;"></div>');
  497. $form->html(' <div class="fr">
  498. <input name="map_x" type="hidden" id="x" value="'.subsite_config('aix.system.map.map.map_x').'">
  499. <input name="map_y" type="hidden" id="y" value="'.subsite_config('aix.system.map.map.map_y').'">
  500. <input name="map_zoom" type="hidden" id="zoom" value="'.subsite_config('aix.system.map.map.max_level').'">
  501. <div class="form-control" style=height:380px;border:1px solid #CCCCCC; cursor: pointer;" id="container"></div></div>', '地图标注')->setMustMark();
  502. $form->text('bus', '乘车路线')->default(session('content')['bus']);
  503. })->tab('设置',function ($form){
  504. $form->radio('display', '显示状态')->options([1=>'正常',2=>'暂停'])->default(1);
  505. $form->radio('predetermined_status', '预定状态')->options([1=>'允许预订',2=>'停止预订'])->default(1);
  506. $form->radio('more_stand', '预定多个展位')->options([1=>'允许',0=>'不允许'])->default(1)->help('同一家企业允许预订一场招聘会多个展位!');
  507. $form->radio('is_commonweal', '招聘会')->options([1=>'场次',2=>'积分',3=>'公益'])->default(3)->help('选择公益招聘会,企业预订免费!')->attribute('class', "is_commonweal");
  508. $form->number('predetermined_point', '预定消耗积分')->min(0)->default(100)->help('选择积分招聘会,企业预订则抵扣积分!');
  509. $form->number('jobsfair_num', '预定消耗场次')->min(0)->default(1)->help('选择场次招聘会,企业预订则抵扣场次!');
  510. $form->number('nosign_point', '未签到扣减积分')->min(0)->default(300)->help('单位:积分');
  511. $form->number('late_point', '迟到早退扣减积分')->min(0)->default(100)->help('单位:积分');
  512. $form->number('ordid', '排序')->min(0)->default(0)->help('数字越大,排序越靠前');
  513. $form->html('<template id="thumbnailTpl">
  514. <div class="jobfair-item">
  515. <div class="jobfair-name" title=""><input type="text" name="jobfairName[]" value="" /></div>
  516. <div class="imgbox"><img src="" alt=""></div>
  517. <strong class="edit" ls="" data-toggle="modal" data-target="#myModal">编辑</strong>
  518. <strong class="delete">删除</strong>
  519. <input type="hidden" name="thumbnailId[]" value="" />
  520. <input type="hidden" name="thumbnailImg[]" value="" />
  521. <input type="hidden" name="Floorplan_id[]" value="" />
  522. </div>
  523. </template>');
  524. });
  525. $form->disableReset();
  526. return $form->render();
  527. }
  528. public function jobfairAdd(Request $request)
  529. {
  530. $id = $request->id;
  531. if (!$id) {
  532. return response()->json(['code'=>0,'info'=>'请选择举办场地!','data'=>'']);
  533. }
  534. $Floorplan = Floorplan::findOrfail($id)->toArray();
  535. $Floorplan['unique_id'] = md5(uniqid(md5(microtime(true)), true));
  536. return response()->json(['code'=>1,'info'=>'成功!','data'=>$Floorplan]);
  537. }
  538. public function store(Request $request)
  539. {
  540. $request->validate([
  541. 'title' => 'required',
  542. 'holddate_start' => 'required',
  543. 'holddate_end' => 'required',
  544. 'predetermined_start' => 'required',
  545. 'predetermined_end' => 'required',
  546. 'areaid' => 'required',
  547. 'address' => 'required', //举办地址。
  548. 'contact' => 'required',
  549. 'phone' => 'required|max:100',
  550. 'jobfair_introduction' => 'required',
  551. ],[
  552. 'title.required'=>'请填写标题',
  553. 'holddate_start.required'=>'请填写举办开始时间',
  554. 'holddate_end.required'=>'请填写举办结束时间',
  555. 'predetermined_start.required'=>'请填写预定开始时间',
  556. 'predetermined_end.required'=>'请填写预定结束时间',
  557. 'areaid.required'=>'请填写举办场地',
  558. 'address.required'=>'请填写举办地址',
  559. 'contact.required'=>'请填写联系人',
  560. 'phone.required'=>'请填写联系方式',
  561. 'phone.max'=>'联系方式最多不超过100字',
  562. 'jobfair_introduction.required'=>'请填写简介',
  563. ]);
  564. 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) ) {
  565. admin_toastr('举办/预定时间不能含有中文!', 'error');
  566. return back()->with(['content'=>$request->all()]);
  567. }
  568. 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) ) {
  569. admin_toastr('积分/场次/联系电话不能含有中文!', 'error');
  570. return back()->with(['content'=>$request->all()]);
  571. }
  572. foreach (explode(',',$request->phone) as $value){
  573. if(!(preg_match ('/^1[3-9]{1}[0-9]{9}$/', $value) || preg_match ('/^([0-9]{3,4}-)?[0-9]{7,8}$/', $value))){
  574. admin_toastr('请输入正确的联系电话', 'error');
  575. return back()->with(['content'=>$request->all()]);
  576. }
  577. }
  578. if ($request->holddate_start >= $request->holddate_end) {
  579. admin_toastr('举办开始时间不能大于结束时间!!', 'error');
  580. return back()->with(['content'=>$request->all()]);
  581. }
  582. if ($request->predetermined_start >= $request->holddate_start) {
  583. admin_toastr('预订开始时间不能大于举办开始时间!!', 'error');
  584. return back()->with(['content'=>$request->all()]);
  585. }
  586. if ($request->predetermined_start >= $request->predetermined_end) {
  587. admin_toastr('预订开始时间不能大于结束时间!!', 'error');
  588. return back()->with(['content'=>$request->all()]);
  589. }
  590. if ($request->predetermined_end > $request->holddate_end) {
  591. admin_toastr('预订结束时间不能大于举办结束时间!!', 'error');
  592. return back()->with(['content'=>$request->all()]);
  593. }
  594. $jobfair = [];
  595. $jobfair['title'] = $request->title;
  596. $jobfair['industry'] = $request->industry;
  597. $jobfair['holddate_start'] = strtotime($request->holddate_start);
  598. $jobfair['holddate_end'] = strtotime($request->holddate_end);
  599. $jobfair['areaid'] = $request->areaid;
  600. $jobfair['jobfair_type'] = $request->jobfair_type;
  601. $jobfair['showendtime'] = strtotime($request->showendtime);
  602. $jobfair['address'] = $request->address;
  603. $jobfair['bus'] = $request->bus;
  604. $jobfair['contact'] = $request->contact;
  605. $apiAddress = $this->apiAddress($request->address);
  606. if (!$apiAddress) {
  607. admin_toastr('请添加地图标注!!', 'error');
  608. return back()->with(['content'=>$request->all()]);
  609. }
  610. $jobfair['map_x'] = $apiAddress['lng'];
  611. $jobfair['map_y'] = $apiAddress['lat'];
  612. $jobfair['phone'] = $request->phone;
  613. $jobfair['display'] = $request->display;
  614. $jobfair['is_commonweal'] = $request->is_commonweal;
  615. $jobfair['predetermined_point'] = $request->predetermined_point;
  616. $jobfair['jobsfair_num'] = $request->jobsfair_num;
  617. $jobfair['nosign_point'] = $request->nosign_point;
  618. $jobfair['late_point'] = $request->late_point;
  619. $jobfair['ordid'] = $request->ordid;
  620. $jobfair['more_stand'] = $request->more_stand;
  621. $jobfair['jobfair_introduction'] = $request->jobfair_introduction;
  622. $jobfair['subsite_id'] = get_subsite_id();
  623. $jobfair['predetermined_status'] = $request->predetermined_status;
  624. $jobfair['predetermined_start'] = $request->predetermined_start ? strtotime($request->predetermined_start) : $request->predetermined_start;
  625. $jobfair['predetermined_end'] = $request->predetermined_end ? strtotime($request->predetermined_end) : $request->predetermined_end;
  626. $jobfairName = $request->jobfairName;
  627. if (empty($jobfairName)) {
  628. admin_toastr('请重新分配举办场地!!', 'error');
  629. return back()->with(['content'=>$request->all()]);
  630. }
  631. DB::beginTransaction();
  632. try {
  633. $Jobfair = Jobfair::create($jobfair);
  634. $subsites = \Illuminate\Support\Facades\Request::input('subsites');
  635. if (get_subsite_id() == 0 && $subsites) {
  636. $subsites = array_merge(array(get_subsite_id()), $subsites);
  637. } else {
  638. $subsites = array(get_subsite_id());
  639. }
  640. $set_data = array();
  641. foreach ($subsites as $k => $v) {
  642. if ($v !== null) {
  643. $set_data[] = array(
  644. 'jobfair_id' => $Jobfair->id,
  645. 'subsite_id'=> $v,
  646. 'created_at'=>date('Y-m-d H:i:s'),
  647. 'updated_at'=>date('Y-m-d H:i:s'),
  648. );
  649. }
  650. }
  651. SubsiteJobfair::insert($set_data);
  652. $jobfairFloorplan = [];
  653. foreach ($jobfairName as $key => $val) {
  654. $jobfairFloorplan['jobfair_id'] = $Jobfair->id;
  655. $jobfairFloorplan['name'] = $val;
  656. $jobfairFloorplan['bg_images'] = $request->thumbnailImg[$key];
  657. $JobfairFloor = JobfairFloorplan::create($jobfairFloorplan);
  658. $thumbnailId = json_decode($request->thumbnailId[$key], true);
  659. $jobfairFloorplanStands = [];
  660. foreach ($thumbnailId as $key1 => $val1) {
  661. $jobfairFloorplanStands[$key1]['jobfair_id'] = $Jobfair->id;
  662. $jobfairFloorplanStands[$key1]['floorplan_id'] = $JobfairFloor->id;
  663. $jobfairFloorplanStands[$key1]['name'] = $val1['name'];
  664. $jobfairFloorplanStands[$key1]['type'] = $val1['type'];
  665. $jobfairFloorplanStands[$key1]['left'] = $val1['left'];
  666. $jobfairFloorplanStands[$key1]['top'] = $val1['top'];
  667. $jobfairFloorplanStands[$key1]['sortindex'] = $val1['sortindex'] ? $val1['sortindex'] : 1000+$key1;
  668. $jobfairFloorplanStands[$key1]['equipment_id'] = $val1['equipment_id'];
  669. $jobfairFloorplanStands[$key1]['created_at'] = date('Y-m-d H:i:s');
  670. $jobfairFloorplanStands[$key1]['updated_at'] = date('Y-m-d H:i:s');
  671. }
  672. if ($jobfairFloorplanStands) {
  673. FloorplanStand::insert($jobfairFloorplanStands);
  674. }
  675. }
  676. DB::commit();
  677. admin_toastr('操作成功!', 'success');
  678. return redirect(route('jobfair.index'));
  679. } catch (\Exception $e) {
  680. DB::rollback();
  681. admin_toastr($e->getMessage(), 'error');
  682. return back();
  683. }
  684. }
  685. public function update(Request $request)
  686. {
  687. $request->validate([
  688. 'title' => 'required',
  689. 'holddate_start' => 'required',
  690. 'holddate_end' => 'required',
  691. 'predetermined_start' => 'required',
  692. 'predetermined_end' => 'required',
  693. 'areaid' => 'required',
  694. 'address' => 'required', //举办地址。
  695. 'contact' => 'required',
  696. 'phone' => 'required|max:100',
  697. 'jobfair_introduction' => 'required',
  698. ],[
  699. 'title.required'=>'请填写标题',
  700. 'holddate_start.required'=>'请填写举办开始时间',
  701. 'holddate_end.required'=>'请填写举办结束时间',
  702. 'predetermined_start.required'=>'请填写预定开始时间',
  703. 'predetermined_end.required'=>'请填写预定结束时间',
  704. 'areaid.required'=>'请填写举办场地',
  705. 'address.required'=>'请填写举办地址',
  706. 'contact.required'=>'请填写联系人',
  707. 'phone.required'=>'请填写联系方式',
  708. 'phone.max'=>'联系方式最多不超过100字',
  709. 'jobfair_introduction.required'=>'请填写简介',
  710. ]);
  711. 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) ) {
  712. admin_toastr('举办/预定时间不能含有中文!', 'error');
  713. return back();
  714. }
  715. 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) ) {
  716. admin_toastr('积分/场次/联系电话不能含有中文!', 'error');
  717. return back();
  718. }
  719. foreach (explode(',',$request->phone) as $value){
  720. if(!(preg_match ('/^1[3-9]{1}[0-9]{9}$/', $value) || preg_match ('/^([0-9]{3,4}-)?[0-9]{7,8}$/', $value))){
  721. admin_toastr('请输入正确的联系电话', 'error');
  722. return back();
  723. }
  724. }
  725. $jobfair_id = $request->id;
  726. if (empty($jobfair_id)) {
  727. admin_toastr('招聘会不存在!', 'error');
  728. return back();
  729. }
  730. if ($request->holddate_start >= $request->holddate_end) {
  731. admin_toastr('举办开始时间不能大于结束时间!!', 'error');
  732. return back();
  733. }
  734. if ($request->predetermined_start >= $request->predetermined_end) {
  735. admin_toastr('预订开始时间不能大于结束时间!!', 'error');
  736. return back();
  737. }
  738. if ($request->predetermined_end > $request->holddate_end) {
  739. admin_toastr('预订结束时间不能大于举办结束时间!!', 'error');
  740. return back();
  741. }
  742. $jobfair = [];
  743. $JobfairFloorplanArr = JobfairFloorplan::where('jobfair_id', $jobfair_id)->pluck('id')->toArray();
  744. $FloorplanStandArr = FloorplanStand::where('jobfair_id', $jobfair_id)->pluck('id')->toArray();
  745. $jobfair['title'] = $request->title;
  746. $jobfair['industry'] = $request->industry;
  747. $jobfair['holddate_start'] = strtotime($request->holddate_start);
  748. $jobfair['holddate_end'] = strtotime($request->holddate_end);
  749. $jobfair['areaid'] = $request->areaid;
  750. $jobfair['jobfair_type'] = $request->jobfair_type;
  751. $jobfair['showendtime'] = strtotime($request->showendtime);
  752. $jobfair['address'] = $request->address;
  753. $jobfair['bus'] = $request->bus;
  754. $jobfair['contact'] = $request->contact;
  755. $apiAddress = $this->apiAddress($request->address);
  756. if (!$apiAddress) {
  757. admin_toastr('请添加地图标注!!', 'error');
  758. return back();
  759. }
  760. $jobfair['map_x'] = $apiAddress['lng'];
  761. $jobfair['map_y'] = $apiAddress['lat'];
  762. $jobfair['phone'] = $request->phone;
  763. $jobfair['display'] = $request->display;
  764. $jobfair['is_commonweal'] = $request->is_commonweal;
  765. $jobfair['predetermined_point'] = $request->predetermined_point;
  766. $jobfair['jobsfair_num'] = $request->jobsfair_num;
  767. $jobfair['nosign_point'] = $request->nosign_point;
  768. $jobfair['late_point'] = $request->late_point;
  769. $jobfair['ordid'] = $request->ordid;
  770. $jobfair['jobfair_introduction'] = $request->jobfair_introduction;
  771. $jobfair['more_stand'] = $request->more_stand;
  772. if(is_array($request->subsite_id)){
  773. $subsiteArr = $request->subsite_id;
  774. $subsite_id = [];
  775. foreach ($subsiteArr as $key => $val) {
  776. if ($val!==null) {
  777. $subsite_id[] = $val;
  778. }
  779. }
  780. $own_subsite_id = Jobfair::findOrFail($jobfair_id)->subsite_id;
  781. $subsiteJobfair = [
  782. [
  783. 'jobfair_id'=>$jobfair_id,
  784. 'subsite_id'=> $own_subsite_id,
  785. 'created_at'=>date('Y-m-d H:i:s'),
  786. 'updated_at'=>date('Y-m-d H:i:s'),
  787. ]
  788. ];
  789. if ($subsite_id) {
  790. $subsiteArr = [];
  791. foreach ($subsite_id as $key => $val) {
  792. $subsiteArr[$key]['jobfair_id'] = $jobfair_id;
  793. $subsiteArr[$key]['subsite_id'] = $val;
  794. $subsiteArr[$key]['created_at'] = date('Y-m-d H:i:s');
  795. $subsiteArr[$key]['updated_at'] = date('Y-m-d H:i:s');
  796. }
  797. if (in_array($own_subsite_id, $subsite_id)) {
  798. $subsiteJobfair = $subsiteArr;
  799. } else {
  800. $subsiteJobfair = array_merge($subsiteJobfair, $subsiteArr);
  801. }
  802. }
  803. }
  804. $jobfair['predetermined_status'] = $request->predetermined_status;
  805. $jobfair['predetermined_start'] = $request->predetermined_start ? strtotime($request->predetermined_start) : $request->predetermined_start;
  806. $jobfair['predetermined_end'] = $request->predetermined_end ? strtotime($request->predetermined_end) : $request->predetermined_end;
  807. $Floorplan_id = $request->Floorplan_id ? $request->Floorplan_id : [];
  808. DB::beginTransaction();
  809. try {
  810. Jobfair::where('id', $jobfair_id)->update($jobfair);
  811. if(isset($subsiteJobfair)){
  812. SubsiteJobfair::where('jobfair_id', $jobfair_id)->delete();
  813. SubsiteJobfair::insert($subsiteJobfair);
  814. }
  815. $jobfairArr = [];
  816. $floorStandArrId = [];
  817. if ($Floorplan_id) {
  818. foreach ($Floorplan_id as $key => $val) {
  819. if (in_array($val, $JobfairFloorplanArr)) {
  820. JobfairFloorplan::where('id', $val)->update(['name'=>$request->jobfairName[$key]]);
  821. $floorplan_id_new = $val;
  822. } else {
  823. $jobfairArr['name'] = $request->jobfairName[$key];
  824. $jobfairArr['bg_images'] = $request->thumbnailImg[$key];
  825. $jobfairArr['jobfair_id'] = $jobfair_id;
  826. $JobfairFloorplan = JobfairFloorplan::create($jobfairArr);
  827. $floorplan_id_new = $JobfairFloorplan->id;
  828. }
  829. $thumbnailId = json_decode($request->thumbnailId[$key], true);
  830. $jobfairFloorplanStands = [];
  831. if ($thumbnailId) {
  832. foreach ($thumbnailId as $key1 => $val1) {
  833. if ($val1['id']) {
  834. $floorStandArrId[] = $val1['id'];
  835. FloorplanStand::where('id', $val1['id'])->update(['name'=>$val1['name'],'type'=>$val1['type'],'left'=>$val1['left'],'top'=>$val1['top']]);
  836. } else {
  837. $jobfairFloorplanStands[$key1]['jobfair_id'] = $jobfair_id;
  838. $jobfairFloorplanStands[$key1]['floorplan_id'] = $floorplan_id_new;
  839. $jobfairFloorplanStands[$key1]['name'] = $val1['name'];
  840. $jobfairFloorplanStands[$key1]['type'] = $val1['type'];
  841. $jobfairFloorplanStands[$key1]['left'] = $val1['left'];
  842. $jobfairFloorplanStands[$key1]['top'] = $val1['top'];
  843. $jobfairFloorplanStands[$key1]['sortindex'] = isset($val1['sortindex']) ? $val1['sortindex'] : 1000+$key1;
  844. $jobfairFloorplanStands[$key1]['equipment_id'] = $val1['equipment_id'];
  845. $jobfairFloorplanStands[$key1]['created_at'] = date('Y-m-d H:i:s');
  846. $jobfairFloorplanStands[$key1]['updated_at'] = date('Y-m-d H:i:s');
  847. }
  848. }
  849. }
  850. if ($jobfairFloorplanStands) {
  851. FloorplanStand::insert($jobfairFloorplanStands);
  852. }
  853. }
  854. }
  855. $floorplan_arr_id = array_diff($JobfairFloorplanArr, $Floorplan_id);
  856. if (!empty($floorplan_arr_id)) {
  857. JobfairFloorplan::destroy($floorplan_arr_id);
  858. }
  859. $floorStand_arr_id = array_diff($FloorplanStandArr, $floorStandArrId);
  860. if (!empty($floorStand_arr_id)) {
  861. FloorplanStand::destroy($floorStand_arr_id);
  862. }
  863. DB::commit();
  864. admin_toastr('操作成功!', 'success');
  865. return redirect(route('jobfair.index'));
  866. } catch (\Exception $e) {
  867. DB::rollback();
  868. admin_toastr($e->getMessage(), 'error');
  869. return back();
  870. }
  871. }
  872. public function signed(Request $request, content $content)
  873. {
  874. $jobfair_id = $request->id;
  875. if (!$jobfair_id) {
  876. admin_toastr('招聘会不存在!', 'error');
  877. return back();
  878. }
  879. $form = new \Encore\Admin\Widgets\Form();//表单使用admin提供的表单
  880. $form->action(route('jobfair.singedupdate'));
  881. $form->hidden('jobfair_id')->default($jobfair_id);
  882. $form->text('hash_id', '扫码枪')->placeholder('请将输入法切为英文模式后扫码');
  883. $form->disableReset();
  884. return $content
  885. ->header('招聘会签到')
  886. ->description('')
  887. ->body(view('admin.jobfair.singed')->with(['content'=>$form->render()]));
  888. }
  889. public function singedUpdate(Request $request)
  890. {
  891. $jobfair_id = $request->jobfair_id;
  892. $hash_id = $request->hash_id;
  893. $hash_array = explode('/',$hash_id);
  894. $hash_id = $hash_array[count($hash_array)-1];
  895. $res = hashid_decode($hash_id);
  896. if(!$res){
  897. admin_toastr('二维码错误!', 'error');
  898. return back();
  899. }
  900. if (!$jobfair_id) {
  901. admin_toastr('招聘会不存在!', 'error');
  902. return back();
  903. }
  904. $Jobfair = Jobfair::findOrFail($jobfair_id);
  905. if (!$Jobfair) {
  906. admin_toastr('招聘会不存在!', 'error');
  907. return back();
  908. }
  909. if (time()>=$Jobfair->holddate_end) {
  910. admin_toastr('该招聘会已结束!', 'error');
  911. return back();
  912. }
  913. if (time()<=$Jobfair->holddate_start) {
  914. if (($Jobfair->holddate_start-time())>3600) {
  915. admin_toastr('只能在招聘会开始之前1小时之内签到!', 'error');
  916. return back();
  917. }
  918. }
  919. if($res['utype'] == 1){
  920. //企业签到
  921. $JobfairCompany = JobfairCompany::where(['company_id'=>$res['id'],'jobfair_id'=>$jobfair_id,'audit'=>1])->first();
  922. if (!$JobfairCompany) {
  923. admin_toastr('该参会企业不存在!', 'error');
  924. return back();
  925. }
  926. if ($JobfairCompany->type) {
  927. admin_toastr('该参会企业已经签到过了!', 'error');
  928. return back();
  929. }
  930. $date['type'] = 4;
  931. $date['signed_time'] = time();
  932. //允许迟到半小时
  933. if ($Jobfair->holddate_start < strtotime("-30 minute")) {
  934. $date['type'] = 1;
  935. }
  936. //修改状态
  937. $result = JobfairCompany::where(['company_id'=>$res['id'],'jobfair_id'=>$jobfair_id])->update($date);
  938. //在jobfair_person_signeds插入数据
  939. $company = Company::find($res['id']);
  940. $info['name'] = $company->companyname;
  941. $info['address'] = $company->address;
  942. $info['jobfairid'] = $jobfair_id;
  943. $info['sign_type'] = 2;
  944. $info['utype'] = 1;
  945. $info['uid'] = $company->id;
  946. JobfairPersonSigned::create($info);
  947. Cache::put($hash_id, time(),72000);
  948. }else {
  949. $memberInfo = MemberInfo::where(['uid' => $res['id']])->first();
  950. $info['name'] = $memberInfo->realname;
  951. $info['uid'] = $memberInfo->uid;
  952. $info['jobfairid'] = $jobfair_id;
  953. $info['idcard'] = $memberInfo->id_card;
  954. $info['sex'] = $memberInfo->sex;
  955. $info['address'] = $memberInfo->householdaddress_cn;
  956. $info1 = $this->subIdcard($info['idcard'] );
  957. $info = array_merge($info,$info1);
  958. $info['sign_type'] = 2;
  959. $result = JobfairPersonSigned::create($info);
  960. }
  961. if ($result) {
  962. admin_toastr('签到成功!', 'success');
  963. return back();
  964. } else {
  965. admin_toastr('签到失败!', 'error');
  966. return back();
  967. }
  968. }
  969. protected function apiAddress($address)
  970. {
  971. $url='https://api.map.baidu.com/geocoder/v2/?address='.$address.'&output=json&ak='.subsite_config('aix.system.map.map.map_ak').'&s=1';
  972. if ($result=file_get_contents($url)) {
  973. $data = array();
  974. $res= json_decode($result, true);
  975. if ($res['status']==0) {
  976. $results = $res['result'];
  977. $data['lng'] = $results['location']['lng'];
  978. $data['lat'] = $results['location']['lat'];
  979. }
  980. return $data;
  981. }
  982. }
  983. public function exportPoster(Request $request){
  984. $id = $request->id;
  985. $data=array();
  986. $Jobfaircompany = JobfairCompany::where(array('audit'=>1,'jobfair_id'=>$id))->get();
  987. foreach ($Jobfaircompany as $key =>$c){
  988. $company = Company::where('id',$c->company_id)->first();
  989. $data[$key]['company_name'] = $company->companyname;
  990. $position_id = FloorplanStand::where('id',$c->position_id)->first()->toArray();
  991. $data[$key]['position_id'] = $position_id['equipment_id'];
  992. $jobfair_put_jobs = JobfairPutJob::where(array('jobfair_id'=>$id,'company_id'=>$c->company_id))->get();
  993. $data[$key]['jobs_list']=$jobfair_put_jobs;
  994. $company = Company::where('id',$c->company_id)->first();
  995. $data[$key]['contact']=$company->contact;
  996. if($company->mobile){
  997. $data[$key]['mobile']=$company->mobile;
  998. }else{
  999. $data[$key]['mobile']=$company->landline_tel;
  1000. }
  1001. $data[$key]['address']=$company->address;
  1002. }
  1003. $jobfarinfo = Jobfair::where('id',$id)->first()->toArray();
  1004. $export = new HaibaoExport($jobfarinfo['title'].'海报');
  1005. $c = new Collection($data);
  1006. $export->setCustomerData($c)->export();//这里不需要return
  1007. }
  1008. public function exportSignin(Request $request){
  1009. $id = $request->id;
  1010. $info = JobfairCompany::where('jobfair_id',$id)->get()->toArray();
  1011. $jobfair = Jobfair::where('id',$id)->first()->toArray();
  1012. $data = array();
  1013. foreach ($info as $key=>$i){
  1014. $data[$key]['position_id'] = $i['position'];
  1015. $companys = Company::where('id',$i['company_id'])->first();
  1016. if($companys){
  1017. $data[$key]['companyname'] = $companys->companyname;
  1018. switch($i['type']){
  1019. case 0:
  1020. $type = '未签到';
  1021. break;
  1022. case 1:
  1023. $type = '迟到';
  1024. break;
  1025. case 2:
  1026. $type = '早退';
  1027. break;
  1028. case 3:
  1029. $type = '迟到/早退';
  1030. break;
  1031. case 4:
  1032. $type = '已签到';
  1033. break;
  1034. }
  1035. $data[$key]['type'] = $type;
  1036. $data[$key]['signed_time'] = $i['signed_time']?date('Y-m-d H:i:s',$i['signed_time']):'';
  1037. }else{
  1038. $data[$key]['position_id'] = '';
  1039. $data[$key]['companyname'] = '';
  1040. $data[$key]['type'] = '';
  1041. $data[$key]['signed_time'] ='';
  1042. }
  1043. }
  1044. array_multisort(array_column($data,'position_id'),SORT_ASC,$data);
  1045. $export = new QiandaoExport($jobfair['title'].'签到导出'.date('YmdHis',time()));
  1046. $c = new Collection($data);
  1047. $export->setCustomerData($c)->export();//这里不需要return
  1048. }
  1049. //根据身份证截取信息
  1050. protected function subIdcard($idcard)
  1051. {
  1052. $data = [];
  1053. $sexInt = (int)substr($idcard, 16, 1);
  1054. $data['sex'] = $sexInt % 2 == 0 ? '2' : '1';
  1055. $data['birthday'] = substr($idcard,6,4);
  1056. return $data;
  1057. }
  1058. }