diff options
| author | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 21:51:50 +0700 |
|---|---|---|
| committer | stephanchrst <stephanchrst@gmail.com> | 2022-05-10 21:51:50 +0700 |
| commit | 3751379f1e9a4c215fb6eb898b4ccc67659b9ace (patch) | |
| tree | a44932296ef4a9b71d5f010906253d8c53727726 /addons/website_membership/controllers/main.py | |
| parent | 0a15094050bfde69a06d6eff798e9a8ddf2b8c21 (diff) | |
initial commit 2
Diffstat (limited to 'addons/website_membership/controllers/main.py')
| -rw-r--r-- | addons/website_membership/controllers/main.py | 173 |
1 files changed, 173 insertions, 0 deletions
diff --git a/addons/website_membership/controllers/main.py b/addons/website_membership/controllers/main.py new file mode 100644 index 00000000..40adb96e --- /dev/null +++ b/addons/website_membership/controllers/main.py @@ -0,0 +1,173 @@ +# -*- coding: utf-8 -*- +# Part of Odoo. See LICENSE file for full copyright and licensing details. + +import werkzeug.urls + +from odoo import fields + +from odoo import http +from odoo.http import request +from odoo.addons.http_routing.models.ir_http import unslug +from odoo.tools.translate import _ + + +class WebsiteMembership(http.Controller): + _references_per_page = 20 + + @http.route([ + '/members', + '/members/page/<int:page>', + '/members/association/<membership_id>', + '/members/association/<membership_id>/page/<int:page>', + + '/members/country/<int:country_id>', + '/members/country/<country_name>-<int:country_id>', + '/members/country/<int:country_id>/page/<int:page>', + '/members/country/<country_name>-<int:country_id>/page/<int:page>', + + '/members/association/<membership_id>/country/<country_name>-<int:country_id>', + '/members/association/<membership_id>/country/<int:country_id>', + '/members/association/<membership_id>/country/<country_name>-<int:country_id>/page/<int:page>', + '/members/association/<membership_id>/country/<int:country_id>/page/<int:page>', + ], type='http', auth="public", website=True, sitemap=True) + def members(self, membership_id=None, country_name=None, country_id=0, page=1, **post): + Product = request.env['product.product'] + Country = request.env['res.country'] + MembershipLine = request.env['membership.membership_line'] + Partner = request.env['res.partner'] + + post_name = post.get('search') or post.get('name', '') + current_country = None + today = fields.Date.today() + + # base domain for groupby / searches + base_line_domain = [ + ("partner.website_published", "=", True), ('state', '=', 'paid'), + ('date_to', '>=', today), ('date_from', '<=', today) + ] + if membership_id and membership_id != 'free': + membership_id = int(membership_id) + base_line_domain.append(('membership_id', '=', membership_id)) + + if post_name: + base_line_domain += ['|', ('partner.name', 'ilike', post_name), ('partner.website_description', 'ilike', post_name)] + + # group by country, based on all customers (base domain) + if membership_id != 'free': + membership_lines = MembershipLine.sudo().search(base_line_domain) + country_domain = [('member_lines', 'in', membership_lines.ids)] + if not membership_id: + country_domain = ['|', country_domain[0], ('membership_state', '=', 'free')] + else: + country_domain = [('membership_state', '=', 'free')] + if post_name: + country_domain += ['|', ('name', 'ilike', post_name), ('website_description', 'ilike', post_name)] + + countries = Partner.sudo().read_group(country_domain + [("website_published", "=", True)], ["id", "country_id"], groupby="country_id", orderby="country_id") + countries_total = sum(country_dict['country_id_count'] for country_dict in countries) + + line_domain = list(base_line_domain) + if country_id: + line_domain.append(('partner.country_id', '=', country_id)) + current_country = Country.browse(country_id).read(['id', 'name'])[0] + if not any(x['country_id'][0] == country_id for x in countries if x['country_id']): + countries.append({ + 'country_id_count': 0, + 'country_id': (country_id, current_country["name"]) + }) + countries = [d for d in countries if d['country_id']] + countries.sort(key=lambda d: d['country_id'][1]) + + countries.insert(0, { + 'country_id_count': countries_total, + 'country_id': (0, _("All Countries")) + }) + + # format domain for group_by and memberships + memberships = Product.search([('membership', '=', True)], order="website_sequence") + + # make sure we don't access to lines with unpublished membershipts + line_domain.append(('membership_id', 'in', memberships.ids)) + + limit = self._references_per_page + offset = limit * (page - 1) + + count_members = 0 + membership_lines = MembershipLine.sudo() + # displayed non-free membership lines + if membership_id != 'free': + count_members = MembershipLine.sudo().search_count(line_domain) + if offset <= count_members: + membership_lines = MembershipLine.sudo().search(line_domain, offset, limit) + page_partner_ids = set(m.partner.id for m in membership_lines) + + # get google maps localization of partners + google_map_partner_ids = [] + if request.website.is_view_active('website_membership.opt_index_google_map'): + google_map_partner_ids = MembershipLine.search(line_domain).get_published_companies(limit=2000) + + search_domain = [('membership_state', '=', 'free'), ('website_published', '=', True)] + if post_name: + search_domain += ['|', ('name', 'ilike', post_name), ('website_description', 'ilike', post_name)] + if country_id: + search_domain += [('country_id', '=', country_id)] + free_partners = Partner.sudo().search(search_domain) + + memberships_data = [] + for membership_record in memberships: + memberships_data.append({'id': membership_record.id, 'name': membership_record.name}) + + memberships_partner_ids = {} + for line in membership_lines: + memberships_partner_ids.setdefault(line.membership_id.id, []).append(line.partner.id) + + if free_partners: + memberships_data.append({'id': 'free', 'name': _('Free Members')}) + if not membership_id or membership_id == 'free': + if count_members < offset + limit: + free_start = max(offset - count_members, 0) + free_end = max(offset + limit - count_members, 0) + memberships_partner_ids['free'] = free_partners.ids[free_start:free_end] + page_partner_ids |= set(memberships_partner_ids['free']) + google_map_partner_ids += free_partners.ids[:2000-len(google_map_partner_ids)] + count_members += len(free_partners) + + google_map_partner_ids = ",".join(str(it) for it in google_map_partner_ids) + google_maps_api_key = request.website.google_maps_api_key + + partners = {p.id: p for p in Partner.sudo().browse(list(page_partner_ids))} + + base_url = '/members%s%s' % ('/association/%s' % membership_id if membership_id else '', + '/country/%s' % country_id if country_id else '') + + # request pager for lines + pager = request.website.pager(url=base_url, total=count_members, page=page, step=limit, scope=7, url_args=post) + + values = { + 'partners': partners, + 'memberships_data': memberships_data, + 'memberships_partner_ids': memberships_partner_ids, + 'membership_id': membership_id, + 'countries': countries, + 'current_country': current_country and [current_country['id'], current_country['name']] or None, + 'current_country_id': current_country and current_country['id'] or 0, + 'google_map_partner_ids': google_map_partner_ids, + 'pager': pager, + 'post': post, + 'search': "?%s" % werkzeug.urls.url_encode(post), + 'search_count': count_members, + 'google_maps_api_key': google_maps_api_key, + } + return request.render("website_membership.index", values) + + # Do not use semantic controller due to SUPERUSER_ID + @http.route(['/members/<partner_id>'], type='http', auth="public", website=True) + def partners_detail(self, partner_id, **post): + _, partner_id = unslug(partner_id) + if partner_id: + partner = request.env['res.partner'].sudo().browse(partner_id) + if partner.exists() and partner.website_published: # TODO should be done with access rules + values = {} + values['main_object'] = values['partner'] = partner + return request.render("website_membership.partner", values) + return self.members(**post) |
