# -*- coding: utf-8 -*- import openerp from openerp import SUPERUSER_ID from openerp.addons.web import http from openerp.addons.web.http import request from openerp.addons.website_partner.controllers import main as website_partner from openerp.tools.translate import _ import werkzeug.urls class WebsiteMembership(http.Controller): _references_per_page = 20 @http.route([ '/members/', '/members/page//', '/members/association//', '/members/association//page//', '/members/country/', '/members/country/-', '/members/country//page//', '/members/country/-/page//', '/members/association//country/-', '/members/association//country/', '/members/association//country/-/page//', '/members/association//country//page//', ], type='http', auth="public", website=True, multilang=True) def members(self, membership_id=None, country_name=None, country_id=0, page=0, **post): cr, uid, context = request.cr, request.uid, request.context product_obj = request.registry['product.product'] membership_line_obj = request.registry['membership.membership_line'] partner_obj = request.registry['res.partner'] post_name = post.get('name', '') # base domain for groupby / searches base_line_domain = [] if membership_id: base_line_domain.append(('membership_id', '=', membership_id)) membership = product_obj.browse(cr, uid, membership_id, context=context) else: membership = None if post_name: base_line_domain += ['|', ('partner.name', 'ilike', "%%%s%%" % post_name), ('partner.website_description', 'ilike', "%%%s%%" % post_name)] # 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( cr, uid, [('member_lines', 'in', membership_line_ids), ("website_published", "=", True)], ["id", "country_id"], groupby="country_id", orderby="country_id", context=request.context) countries_total = sum(country_dict['country_id_count'] for country_dict in countries) countries.insert(0, { 'country_id_count': countries_total, 'country_id': (0, _("All Countries")) }) # displayed membership lines line_domain = list(base_line_domain) if country_id: line_domain.append(('partner.country_id', '=', country_id)) 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) partner_ids = [m.partner and m.partner.id for m in membership_lines] google_map_partner_ids = ",".join(map(str, partner_ids)) partners_data = {} for partner in partner_obj.read(cr, openerp.SUPERUSER_ID, partner_ids, request.website.get_partner_white_list_fields(), context=context): partners_data[partner.get("id")] = partner # format domain for group_by and memberships membership_ids = product_obj.search(cr, uid, [('membership', '=', True)], context=context) memberships = product_obj.browse(cr, uid, membership_ids, context=context) # request pager for lines pager = request.website.pager(url="/members/", total=len(membership_line_ids), page=page, step=self._references_per_page, scope=7, url_args=post) values = { 'partners_data': partners_data, 'membership_lines': membership_lines, 'memberships': memberships, 'membership': membership, 'countries': countries, 'google_map_partner_ids': google_map_partner_ids, 'pager': pager, 'post': post, 'search': "?%s" % werkzeug.url_encode(post), } return request.website.render("website_membership.index", values) @http.route(['/members//', '/members/-/'], type='http', auth="public", website=True, multilang=True) def partners_ref(self, partner_id, **post): partner = request.registry['res.partner'].browse(request.cr, SUPERUSER_ID, partner_id, context=request.context) values = website_partner.get_partner_template_value(partner) if not values: return self.members(**post) values['main_object'] = values['partner'] return request.website.render("website_membership.partner", values)