2013-09-02 13:52:10 +00:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
|
|
import openerp
|
2014-01-07 13:59:33 +00:00
|
|
|
from openerp import SUPERUSER_ID
|
2013-09-02 13:52:10 +00:00
|
|
|
from openerp.addons.web import http
|
|
|
|
from openerp.addons.web.http import request
|
2013-12-05 15:08:01 +00:00
|
|
|
from openerp.addons.website_partner.controllers import main as website_partner
|
2013-10-11 16:13:10 +00:00
|
|
|
from openerp.tools.translate import _
|
|
|
|
|
2014-01-29 12:13:16 +00:00
|
|
|
import werkzeug.urls
|
2013-09-02 13:52:10 +00:00
|
|
|
|
|
|
|
|
2013-10-07 14:53:22 +00:00
|
|
|
class WebsiteMembership(http.Controller):
|
|
|
|
_references_per_page = 20
|
2013-09-02 13:52:10 +00:00
|
|
|
|
2014-01-20 15:37:33 +00:00
|
|
|
@http.route([
|
2014-03-14 16:23:46 +00:00
|
|
|
'/members',
|
|
|
|
'/members/page/<int:page>',
|
|
|
|
'/members/association/<int:membership_id>',
|
|
|
|
'/members/association/<int:membership_id>/page/<int:page>',
|
2014-01-07 13:59:33 +00:00
|
|
|
|
|
|
|
'/members/country/<int:country_id>',
|
|
|
|
'/members/country/<country_name>-<int:country_id>',
|
2014-03-14 16:23:46 +00:00
|
|
|
'/members/country/<int:country_id>/page/<int:page>',
|
|
|
|
'/members/country/<country_name>-<int:country_id>/page/<int:page>',
|
2014-01-07 13:59:33 +00:00
|
|
|
|
|
|
|
'/members/association/<int:membership_id>/country/<country_name>-<int:country_id>',
|
|
|
|
'/members/association/<int:membership_id>/country/<int:country_id>',
|
2014-03-14 16:23:46 +00:00
|
|
|
'/members/association/<int:membership_id>/country/<country_name>-<int:country_id>/page/<int:page>',
|
|
|
|
'/members/association/<int:membership_id>/country/<int:country_id>/page/<int:page>',
|
2014-01-20 15:37:33 +00:00
|
|
|
], type='http', auth="public", website=True, multilang=True)
|
2014-01-07 13:59:33 +00:00
|
|
|
def members(self, membership_id=None, country_name=None, country_id=0, page=0, **post):
|
2013-10-07 14:53:22 +00:00
|
|
|
cr, uid, context = request.cr, request.uid, request.context
|
|
|
|
product_obj = request.registry['product.product']
|
2014-01-30 20:57:13 +00:00
|
|
|
country_obj = request.registry['res.country']
|
2013-10-07 14:53:22 +00:00
|
|
|
membership_line_obj = request.registry['membership.membership_line']
|
2013-10-11 16:13:10 +00:00
|
|
|
partner_obj = request.registry['res.partner']
|
|
|
|
post_name = post.get('name', '')
|
2014-01-30 20:57:13 +00:00
|
|
|
current_country = None
|
2013-09-02 13:52:10 +00:00
|
|
|
|
2013-10-11 16:13:10 +00:00
|
|
|
# base domain for groupby / searches
|
2014-01-30 20:57:13 +00:00
|
|
|
base_line_domain = [("partner.website_published", "=", True),('state', 'in', ['free', 'paid'])]
|
2013-10-07 14:53:22 +00:00
|
|
|
if membership_id:
|
2013-11-21 14:28:39 +00:00
|
|
|
base_line_domain.append(('membership_id', '=', membership_id))
|
2013-11-14 11:39:27 +00:00
|
|
|
membership = product_obj.browse(cr, uid, membership_id, context=context)
|
2013-10-11 16:13:10 +00:00
|
|
|
else:
|
2013-11-14 11:39:27 +00:00
|
|
|
membership = None
|
2013-10-07 14:53:22 +00:00
|
|
|
if post_name:
|
2014-01-29 16:35:57 +00:00
|
|
|
base_line_domain += ['|', ('partner.name', 'ilike', post_name),
|
|
|
|
('partner.website_description', 'ilike', post_name)]
|
2013-10-11 16:13:10 +00:00
|
|
|
|
|
|
|
# group by country, based on all customers (base domain)
|
|
|
|
membership_line_ids = membership_line_obj.search(cr, uid, base_line_domain, context=context)
|
|
|
|
countries = partner_obj.read_group(
|
2013-12-05 15:08:01 +00:00
|
|
|
cr, uid, [('member_lines', 'in', membership_line_ids), ("website_published", "=", True)], ["id", "country_id"],
|
2013-10-11 16:13:10 +00:00
|
|
|
groupby="country_id", orderby="country_id", context=request.context)
|
2013-11-21 14:28:39 +00:00
|
|
|
countries_total = sum(country_dict['country_id_count'] for country_dict in countries)
|
2014-01-30 20:57:13 +00:00
|
|
|
|
|
|
|
line_domain = list(base_line_domain)
|
|
|
|
if country_id:
|
|
|
|
line_domain.append(('partner.country_id', '=', country_id))
|
|
|
|
current_country = country_obj.read(cr, uid, country_id, ['id', 'name'], context)
|
|
|
|
if not any(x['country_id'][0] == country_id for x in countries):
|
|
|
|
countries.append({
|
|
|
|
'country_id_count': 0,
|
|
|
|
'country_id': (country_id, current_country["name"])
|
|
|
|
})
|
|
|
|
countries.sort(key=lambda d: d['country_id'][1])
|
|
|
|
|
2013-10-11 16:13:10 +00:00
|
|
|
countries.insert(0, {
|
|
|
|
'country_id_count': countries_total,
|
|
|
|
'country_id': (0, _("All Countries"))
|
|
|
|
})
|
|
|
|
|
|
|
|
# displayed membership lines
|
2013-10-07 14:53:22 +00:00
|
|
|
membership_line_ids = membership_line_obj.search(cr, uid, line_domain, context=context)
|
|
|
|
membership_lines = membership_line_obj.browse(cr, uid, membership_line_ids, context=context)
|
2014-01-29 17:15:54 +00:00
|
|
|
membership_lines.sort(key=lambda x: x.membership_id.website_sequence)
|
2013-10-11 16:13:10 +00:00
|
|
|
partner_ids = [m.partner and m.partner.id for m in membership_lines]
|
2013-11-21 14:28:39 +00:00
|
|
|
google_map_partner_ids = ",".join(map(str, partner_ids))
|
2013-09-02 13:52:10 +00:00
|
|
|
|
2013-12-05 15:08:01 +00:00
|
|
|
partners_data = {}
|
2013-12-11 11:26:17 +00:00
|
|
|
for partner in partner_obj.read(cr, openerp.SUPERUSER_ID, partner_ids, request.website.get_partner_white_list_fields(), context=context):
|
2013-12-05 15:08:01 +00:00
|
|
|
partners_data[partner.get("id")] = partner
|
|
|
|
|
2013-10-07 14:53:22 +00:00
|
|
|
# format domain for group_by and memberships
|
2014-01-29 17:15:54 +00:00
|
|
|
membership_ids = product_obj.search(cr, uid, [('membership', '=', True)], order="website_sequence", context=context)
|
2013-11-14 11:39:27 +00:00
|
|
|
memberships = product_obj.browse(cr, uid, membership_ids, context=context)
|
2013-09-02 13:52:10 +00:00
|
|
|
|
2013-10-07 14:53:22 +00:00
|
|
|
# request pager for lines
|
2014-03-14 16:23:46 +00:00
|
|
|
pager = request.website.pager(url="/members", total=len(membership_line_ids), page=page, step=self._references_per_page, scope=7, url_args=post)
|
2013-09-02 13:52:10 +00:00
|
|
|
|
2013-09-04 15:32:36 +00:00
|
|
|
values = {
|
2013-12-05 15:08:01 +00:00
|
|
|
'partners_data': partners_data,
|
2013-10-11 16:13:10 +00:00
|
|
|
'membership_lines': membership_lines,
|
|
|
|
'memberships': memberships,
|
|
|
|
'membership': membership,
|
|
|
|
'countries': countries,
|
2014-01-30 20:57:13 +00:00
|
|
|
'current_country': current_country and [current_country['id'], current_country['name']] or None,
|
|
|
|
'current_country_id': current_country and current_country['id'] or 0,
|
2013-09-02 13:52:10 +00:00
|
|
|
'google_map_partner_ids': google_map_partner_ids,
|
|
|
|
'pager': pager,
|
2013-10-11 16:13:10 +00:00
|
|
|
'post': post,
|
2014-01-29 12:13:16 +00:00
|
|
|
'search': "?%s" % werkzeug.url_encode(post),
|
2013-09-04 15:32:36 +00:00
|
|
|
}
|
2013-09-10 13:41:33 +00:00
|
|
|
return request.website.render("website_membership.index", values)
|
2013-09-02 13:52:10 +00:00
|
|
|
|
2014-03-14 16:23:46 +00:00
|
|
|
@http.route(['/members/<int:partner_id>', '/members/<partner_name>-<int:partner_id>'], type='http', auth="public", website=True, multilang=True)
|
2014-01-07 13:59:33 +00:00
|
|
|
def partners_ref(self, partner_id, **post):
|
|
|
|
partner = request.registry['res.partner'].browse(request.cr, SUPERUSER_ID, partner_id, context=request.context)
|
2013-12-05 15:08:01 +00:00
|
|
|
values = website_partner.get_partner_template_value(partner)
|
|
|
|
if not values:
|
2013-11-21 14:32:16 +00:00
|
|
|
return self.members(**post)
|
2013-12-16 13:40:33 +00:00
|
|
|
values['main_object'] = values['partner']
|
2013-10-07 14:53:22 +00:00
|
|
|
return request.website.render("website_membership.partner", values)
|