| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242 | <?phpnamespace App\Http\Controllers\Mobile\Active;use App\Http\Controllers\Mobile\MobileBaseController;use App\Services\Common\CategoryService;use App\Services\Common\HotWordService;use App\Services\Common\SearchService;use App\Services\Company\JobsService;use App\Services\Content\AdService;use Illuminate\Http\Request;class FudaController extends MobileBaseController{    protected $categoryService;    protected $adService;    protected $hotWordService;    protected $jobsService;    protected $searchService;    /**     * JobsController constructor.     * @param $JobsService     */    public function __construct(CategoryService $categoryService, AdService $adService, HotWordService $hotWordService, JobsService $jobsService, SearchService $searchService)    {        $this->categoryService = $categoryService;        $this->adService       = $adService;        $this->hotWordService  = $hotWordService;        $this->jobsService     = $jobsService;        $this->searchService   = $searchService;    }    public function index(Request $request)    {        if ($request->input('range-lng') != '' && $request->input('range-lat') != '') {            $request->session()->put('range-lng', $request->input('range-lng'));            $request->session()->put('range-lat', $request->input('range-lat'));            $request->session()->put('range-laction', 1);        };        //查询条件        $citycategory = $request->input('citycategory');        $search_type  = $request->input('search_type', 'jobs');        //职位搜索        $job_category = $this->categoryService->getJobsCategoryInfo();      //获取职位分类信息        $filter_where = [            'AIX_wage'        => 100,            'AIX_jobtag'      => 100,            'AIX_trade'       => 100,            'AIX_scale'       => 100,            'AIX_jobs_nature' => 100,            'AIX_education'   => 100,            'AIX_experience'  => 100,        ];        $categories   = $this->categoryService->getCategories($filter_where);     //过滤条件信息        //广告位        $ad_where         = [            'theme' => 'default',            'org'   => 'Home',            'alias' => 'AIX_jobs_list_right',            'num'   => '1',        ];        $ad_infos         = $this->adService->getAds($ad_where);        $hotWords         = $this->hotWordService->getHotWords(['type' => 1], 'list_order desc,w_hot desc', '21');    //热门关键词        $job_hotwords     = array_slice($hotWords->toArray(), 0, 10);        $company_hotwords = $this->hotWordService->getHotWords(['type' => 2], 'list_order desc,w_hot desc', '10');        $param_array = ['citycategory', 'wage', 'jobtag', 'trade', 'scale', 'nature', 'education', 'experience', 'settr', 'jobcategory', 'key', 'sort', 'search_cont', 'license', 'deliver', 'search_type', 'lng', 'lat', 'range', 'wa', 'range-lng', 'range-lat', 'keyword'];        $params      = [];        if ($request->all()) {            foreach ($request->all() as $k => $v) {                if (in_array($k, $param_array) && $v) {                    $params[$k] = $v;                }            }        }        $map_data = [];        if (array_has($params, 'lng') && array_has($params, 'lat') && (array_has($params, 'range') || array_has($params, 'wa'))) {            if (array_has($params, 'range')) {                $map_data = ['lng' => $params['lng'], 'lat' => $params['lat'], 'range' => $params['range']];            } elseif (array_has($params, 'wa')) {                $map_data = ['lng' => $params['lng'], 'lat' => $params['lat'], 'range' => round($params['wa'] / 1000, 2)];            } else {                $map_data = ['lng' => $params['lng'], 'lat' => $params['lat'], 'range' => config('aix.system.map.map.map_range')];            }        } elseif (array_has($params, 'range') && !array_has($params, 'citycategory') && session("range-laction")) {            $map_data = ['lng' => session("range-lng"), 'lat' => session("range-lat"), 'range' => $params['range']];        }        $show_range = false;        if ($map_data) {            $show_range = true;        }        $hidden_all_result = 0;        $show_login_notice = 0;        $list_limit        = '';        $order_by          = ['stime' => 'desc', 'refresh_time' => 'desc'];        $search_key        = '';        if ($params) {            $search_key = array_has($params, 'key') ? $params['key'] : '';            if (array_has($params, 'sort')) {                if ($params['sort'] == 'rtime') {                    $order_by = 'refresh_time';                } else {                    $order_by = $params['sort'];                }            } else {                $order_by = ['stime' => 'desc', 'refresh_time' => 'desc'];            }        }        $citys         = $this->categoryService->getCitys($citycategory);   //获取地标地段        $district_info = $this->categoryService->getDefaultDistrictInfo(); //获取默认地区信息        $where         = $this->setWhere($params, $citys, $job_category);   //组合where条件        $size          = 20;        $list          = $this->searchService->search('Job', $where, $order_by, $search_key, $size);        if ($list->total() > 0) {            $list_items = $this->jobsService->dealjobFilelds($list->items(), $map_data);        } else {            $list_items = [];        }        $mobile_dropload = false;        if ($list->total() > $size) {            $mobile_dropload = true;        }        if ($request->ajax()) {            if ($list->lastPage() < $list->currentPage()) {                return response()->json(['status' => 0]);            }            return response()->json(['status' => 1, 'data' => view('mobile.app.content.jobs.ajax_job_list', ['params' => $params, 'list_items' => $list_items])->render()]);        }        $return_data = [            'search_type'       => $search_type,            'city'              => $citys,            'categories'        => $categories,            'params'            => $params,            'district_info'     => $district_info,            'job_category'      => $job_category,            'ad_info'           => $ad_infos,            'hotWords'          => $hotWords,            'job_hotwords'      => $job_hotwords,            'company_hotwords'  => $company_hotwords,            'list'              => $list,            'list_items'        => $list_items,            'show_login_notice' => $show_login_notice,            'hidden_all_result' => $hidden_all_result,            'limit'             => $list_limit,            'mobile_dropload'   => $mobile_dropload,            'show_range'        => $show_range,            'current_url'       => \Illuminate\Support\Facades\Request::getRequestUri(),            'wap_title'         => '福州大学招聘会',        ];        return view('mobile.app.active.fuda', $return_data);    }    public function setWhere($params, $citys, $job_category)    {        $where = [];        //审核状态过滤        $where[] = ['audit', '=', 1];        $where[] = ['valid', '=', 1];        $where[] = ['display', '=', 1];        $where[] = ['created_at', '>=', '2024-04-06 00:00:00'];        if ($params) {            foreach ($params as $k => $v) {                if ($k == 'citycategory') {                    //地标地段                    $where[] = ['district', '=', $citys['select']['id']];                } elseif ($k == 'jobcategory') {                    //职位分类                    if ($job_category && $v && array_get($job_category['spell'], $v)) {                        if ($job_category && $v && array_get($job_category['spell'], $v)) {                            $where[] = ['intention_jobs_id', '=', $job_category['spell'][$v]['id']];                        }                    }                } elseif ($k == 'jobtag') {                    //职位亮点                    $where[] = ['tag', '=', $v];                } elseif ($k == 'search_cont') {                    if ($v == 'setmeal') {                        //名企招聘                        $where[] = ['setmeal_id', '>', 1];                    }                } elseif ($k == 'license') {                    //营业执照                    $where[] = ['company.certificate_img_audit', '=', 1];                } elseif ($k == 'settr') {                    //更新时间                    $update_time = date('Y-m-d H:i:s', strtotime(date('Y-m-d', strtotime('-' . $v . ' day'))));                    $where[]     = ['updated_at', '>=', $update_time];                } elseif ($k == 'deliver') {                    $where['apply'] = $v;                } elseif ($k == 'wa') {                    $where[] = ['range', '=', round($params['wa'] / 1000, 2)];                    if (!(array_has($params, 'lng') && array_has($params, 'lat'))) {                        $where[] = ['lng', '=', subsite_config('aix.system.map.map.map_x')];                        $where[] = ['lat', '=', subsite_config('aix.system.map.map.map_y')];                    }                } elseif ($k == 'wage') {                    //获取薪资最大值和最小值                    $filter_where = ['AIX_wage' => 100];                    $categories   = $this->categoryService->getCategories($filter_where);                    if ($categories) {                        $wage = $categories['AIX_wage'][$params['wage']]['origin_demand'];                        if ($wage) {                            $wage = format_wage($wage);                        }                        $wage_arr = explode_wage($wage);                        $where[]  = $wage_arr[0];                        $where[]  = $wage_arr[1];                    }                } elseif ($k == 'range') {                    if (!array_has($params, 'citycategory')) {                        if (!(array_has($params, 'lng') && array_has($params, 'lat'))) {                            if (session('range-laction')) {                                $where[] = ['range', '=', $params['range']];                                $where[] = ['lng', '=', session('range-lng')];                                $where[] = ['lat', '=', session('range-lat')];                            }                        }                    }                } elseif ($k == 'keyword') {                    $where[] = ['jobs_name', 'like', "*{$params['keyword']}*"];                } elseif ($k != 'sort' && $k != 'key' && $k != 'search_type' && $k != 'm_zoom' && $k != 'range-lng' && $k != 'range-lat') {                    $where[] = [$k, '=', $v];                }            }        }        return $where;    }}
 |