1 # -*- coding: utf-8 -*-
4 from openerp import SUPERUSER_ID
5 from openerp.addons.web import http
6 from openerp.addons.web.http import request
7 from openerp.addons.website_partner.controllers import main as website_partner
8 from openerp.tools.translate import _
13 class WebsiteMembership(http.Controller):
14 _references_per_page = 20
18 '/members/page/<int:page>/',
19 '/members/association/<int:membership_id>/',
20 '/members/association/<int:membership_id>/page/<int:page>/',
22 '/members/country/<int:country_id>',
23 '/members/country/<country_name>-<int:country_id>',
24 '/members/country/<int:country_id>/page/<int:page>/',
25 '/members/country/<country_name>-<int:country_id>/page/<int:page>/',
27 '/members/association/<int:membership_id>/country/<country_name>-<int:country_id>',
28 '/members/association/<int:membership_id>/country/<int:country_id>',
29 '/members/association/<int:membership_id>/country/<country_name>-<int:country_id>/page/<int:page>/',
30 '/members/association/<int:membership_id>/country/<int:country_id>/page/<int:page>/',
31 ], type='http', auth="public", website=True, multilang=True)
32 def members(self, membership_id=None, country_name=None, country_id=0, page=0, **post):
33 cr, uid, context = request.cr, request.uid, request.context
34 product_obj = request.registry['product.product']
35 country_obj = request.registry['res.country']
36 membership_line_obj = request.registry['membership.membership_line']
37 partner_obj = request.registry['res.partner']
38 post_name = post.get('name', '')
39 current_country = None
41 # base domain for groupby / searches
42 base_line_domain = [("partner.website_published", "=", True),('state', 'in', ['free', 'paid'])]
44 base_line_domain.append(('membership_id', '=', membership_id))
45 membership = product_obj.browse(cr, uid, membership_id, context=context)
49 base_line_domain += ['|', ('partner.name', 'ilike', post_name),
50 ('partner.website_description', 'ilike', post_name)]
52 # group by country, based on all customers (base domain)
53 membership_line_ids = membership_line_obj.search(cr, uid, base_line_domain, context=context)
54 countries = partner_obj.read_group(
55 cr, uid, [('member_lines', 'in', membership_line_ids), ("website_published", "=", True)], ["id", "country_id"],
56 groupby="country_id", orderby="country_id", context=request.context)
57 countries_total = sum(country_dict['country_id_count'] for country_dict in countries)
59 line_domain = list(base_line_domain)
61 line_domain.append(('partner.country_id', '=', country_id))
62 current_country = country_obj.read(cr, uid, country_id, ['id', 'name'], context)
63 if not any(x['country_id'][0] == country_id for x in countries):
65 'country_id_count': 0,
66 'country_id': (country_id, current_country["name"])
68 countries.sort(key=lambda d: d['country_id'][1])
71 'country_id_count': countries_total,
72 'country_id': (0, _("All Countries"))
75 # displayed membership lines
76 membership_line_ids = membership_line_obj.search(cr, uid, line_domain, context=context)
77 membership_lines = membership_line_obj.browse(cr, uid, membership_line_ids, context=context)
78 membership_lines.sort(key=lambda x: x.membership_id.website_sequence)
79 partner_ids = [m.partner and m.partner.id for m in membership_lines]
80 google_map_partner_ids = ",".join(map(str, partner_ids))
83 for partner in partner_obj.read(cr, openerp.SUPERUSER_ID, partner_ids, request.website.get_partner_white_list_fields(), context=context):
84 partners_data[partner.get("id")] = partner
86 # format domain for group_by and memberships
87 membership_ids = product_obj.search(cr, uid, [('membership', '=', True)], order="website_sequence", context=context)
88 memberships = product_obj.browse(cr, uid, membership_ids, context=context)
90 # request pager for lines
91 pager = request.website.pager(url="/members/", total=len(membership_line_ids), page=page, step=self._references_per_page, scope=7, url_args=post)
94 'partners_data': partners_data,
95 'membership_lines': membership_lines,
96 'memberships': memberships,
97 'membership': membership,
98 'countries': countries,
99 'current_country': current_country and [current_country['id'], current_country['name']] or None,
100 'current_country_id': current_country and current_country['id'] or 0,
101 'google_map_partner_ids': google_map_partner_ids,
104 'search': "?%s" % werkzeug.url_encode(post),
106 return request.website.render("website_membership.index", values)
108 @http.route(['/members/<int:partner_id>/', '/members/<partner_name>-<int:partner_id>/'], type='http', auth="public", website=True, multilang=True)
109 def partners_ref(self, partner_id, **post):
110 partner = request.registry['res.partner'].browse(request.cr, SUPERUSER_ID, partner_id, context=request.context)
111 values = website_partner.get_partner_template_value(partner)
113 return self.members(**post)
114 values['main_object'] = values['partner']
115 return request.website.render("website_membership.partner", values)