2018-01-16 11:28:15 +05:30
|
|
|
# -*- coding: utf-8 -*-
|
2018-01-16 02:34:37 -08:00
|
|
|
# Part of Odoo, Flectra. See LICENSE file for full copyright and licensing details.
|
2018-01-16 11:28:15 +05:30
|
|
|
|
|
|
|
from datetime import datetime
|
|
|
|
from dateutil.relativedelta import relativedelta
|
|
|
|
|
2018-01-16 02:34:37 -08:00
|
|
|
from flectra import fields, models, _
|
2018-01-16 11:28:15 +05:30
|
|
|
|
|
|
|
|
|
|
|
class CrmTeam(models.Model):
|
|
|
|
_inherit = "crm.team"
|
|
|
|
|
|
|
|
website_ids = fields.One2many('website', 'salesteam_id', string='Websites', help="Websites using this sales channel")
|
|
|
|
abandoned_carts_count = fields.Integer(
|
|
|
|
compute='_compute_abandoned_carts',
|
|
|
|
string='Number of Abandoned Carts', readonly=True)
|
|
|
|
abandoned_carts_amount = fields.Integer(
|
|
|
|
compute='_compute_abandoned_carts',
|
|
|
|
string='Amount of Abandoned Carts', readonly=True)
|
|
|
|
|
|
|
|
def _compute_abandoned_carts(self):
|
|
|
|
# abandoned carts to recover are draft sales orders that have no order lines,
|
|
|
|
# a partner other than the public user, and created over an hour ago
|
|
|
|
# and the recovery mail was not yet sent
|
|
|
|
website_teams = self.filtered(lambda team: team.team_type == 'website')
|
|
|
|
if website_teams:
|
|
|
|
abandoned_carts_data = self.env['sale.order'].read_group([
|
|
|
|
('is_abandoned_cart', '=', True),
|
|
|
|
('cart_recovery_email_sent', '=', False)
|
|
|
|
], ['amount_total', 'team_id'], ['team_id'])
|
|
|
|
counts = {data['team_id'][0]: data['team_id_count'] for data in abandoned_carts_data}
|
|
|
|
amounts = {data['team_id'][0]: data['amount_total'] for data in abandoned_carts_data}
|
|
|
|
for team in website_teams:
|
|
|
|
team.abandoned_carts_count = counts.get(team.id, 0)
|
|
|
|
team.abandoned_carts_amount = amounts.get(team.id, 0)
|
|
|
|
|
|
|
|
def _compute_dashboard_button_name(self):
|
|
|
|
website_teams = self.filtered(lambda team: team.team_type == 'website' and not team.use_quotations)
|
|
|
|
website_teams.update({'dashboard_button_name': _("Online Sales")})
|
|
|
|
super(CrmTeam, self - website_teams)._compute_dashboard_button_name()
|
|
|
|
|
|
|
|
def get_abandoned_carts(self):
|
|
|
|
self.ensure_one()
|
|
|
|
return {
|
|
|
|
'name': _('Abandoned Carts'),
|
|
|
|
'type': 'ir.actions.act_window',
|
|
|
|
'view_type': 'form',
|
|
|
|
'view_mode': 'tree,form',
|
|
|
|
'domain': [('is_abandoned_cart', '=', True)],
|
|
|
|
'search_view_id': self.env.ref('sale.sale_order_view_search_inherit_sale').id,
|
|
|
|
'context': {
|
|
|
|
'search_default_team_id': self.id,
|
|
|
|
'default_team_id': self.id,
|
|
|
|
'search_default_recovery_email': 1,
|
|
|
|
'create': False
|
|
|
|
},
|
|
|
|
'res_model': 'sale.order',
|
|
|
|
'help': _('''<p class="oe_view_nocontent_create">
|
|
|
|
You can find all abandoned carts here, i.e. the carts generated by your website's visitors from over an hour ago that haven't been confirmed yet.</p>
|
|
|
|
<p>You should send an email to the customers to encourage them!</p>
|
|
|
|
'''),
|
|
|
|
}
|