diff --git a/addons/website_hr_recruitment/controllers/main.py b/addons/website_hr_recruitment/controllers/main.py index 64fda74368f..84f1973cd8c 100644 --- a/addons/website_hr_recruitment/controllers/main.py +++ b/addons/website_hr_recruitment/controllers/main.py @@ -9,19 +9,18 @@ from openerp.addons.web.http import request class website_hr_recruitment(http.Controller): @http.route([ '/jobs', + '/jobs/country/', '/jobs/department/', - '/jobs/office/', - '/jobs/country/' + '/jobs/country//department/', + '/jobs/office/', + '/jobs/country//office/', + '/jobs/department//office/', + '/jobs/country//department//office/', ], type='http', auth="public", website=True) - def jobs(self, department=None, office=None, country=None): + def jobs(self, country=None, department=None, office_id=None): context=dict(request.context, show_address=True, no_tag_br=True) cr, uid = request.cr, request.uid - # office is restriced, deslugify manually - office_id = 0 - if office: - office_id = int(office.split('-')[-1]) - # Search all available jobs as uid JobsObj = request.registry['hr.job'] job_ids = JobsObj.search(cr, uid, [], order="website_published desc,no_of_recruitment desc", context=context) @@ -30,21 +29,32 @@ class website_hr_recruitment(http.Controller): jobs = JobsObj.browse(cr, 1, job_ids, context=context) # Deduce departments and offices of those jobs + countries = set(j.address_id.country_id for j in jobs if j.address_id and j.address_id.country_id) departments = set(j.department_id for j in jobs if j.department_id) offices = set(j.address_id for j in jobs if j.address_id) countries = set(o.country_id for o in offices if o.country_id) + # Default search by user country + if not country and not department and not office_id: + country_code = request.session['geoip'].get('country_code') + if country_code: + country_ids = request.registry.get('res.country').search(cr, uid, [('code', '=', country_code)], context=context) + if country_ids: + country = country_ids[0] + # Filter the matching one + jobs = [j for j in jobs if country==None or j.address_id==None or j.address_id.country_id and j.address_id.country_id.id == country.id] jobs = [j for j in jobs if department==None or j.department_id and j.department_id.id == department.id] - jobs = [j for j in jobs if office==None or j.address_id and j.address_id.id == office_id] - jobs = [j for j in jobs if country==None or j.address_id and j.address_id.country_id and j.address_id.country_id.id == country.id] + jobs = [j for j in jobs if office_id==None or j.address_id and j.address_id.id == office_id] # Render page return request.website.render("website_hr_recruitment.index", { 'jobs': jobs, + 'countries': countries, 'departments': departments, 'offices': offices, - 'department_id': department and department.id, + 'country_id': country, + 'department_id': department, 'office_id': office_id, 'countries': countries }) diff --git a/addons/website_hr_recruitment/views/templates.xml b/addons/website_hr_recruitment/views/templates.xml index 8530c277400..f0eb4569e07 100644 --- a/addons/website_hr_recruitment/views/templates.xml +++ b/addons/website_hr_recruitment/views/templates.xml @@ -230,13 +230,32 @@ + +