You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
71 lines
2.9 KiB
71 lines
2.9 KiB
# -*- coding: utf-8 -*-
|
|
#############################################################################
|
|
#
|
|
# Cybrosys Technologies Pvt. Ltd.
|
|
#
|
|
# Copyright (C) 2025-TODAY Cybrosys Technologies(<https://www.cybrosys.com>)
|
|
# Author: SREERAG PM (<https://www.cybrosys.com>)
|
|
#
|
|
# You can modify it under the terms of the GNU AFFERO
|
|
# GENERAL PUBLIC LICENSE (AGPL v3), Version 3.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU AFFERO GENERAL PUBLIC LICENSE (AGPL v3) for more details.
|
|
#
|
|
# You should have received a copy of the GNU AFFERO GENERAL PUBLIC LICENSE
|
|
# (AGPL v3) along with this program.
|
|
# If not, see <http://www.gnu.org/licenses/>.
|
|
#
|
|
#############################################################################
|
|
from odoo import models, fields
|
|
from odoo import tools
|
|
|
|
|
|
class SubscriptionReport(models.Model):
|
|
_name = "subscription.report"
|
|
_description = "Subscription Analysis"
|
|
_auto = False
|
|
|
|
total_recurring_price = fields.Float('Recurring Price', readonly=True,
|
|
help='Total recurring price '
|
|
'associated with this '
|
|
'subscription analysis.')
|
|
quantity = fields.Float('Quantity', readonly=True,
|
|
help='The quantity associated with this '
|
|
'subscription analysis.')
|
|
user_id = fields.Many2one('res.users', 'Salesperson', readonly=True,
|
|
help='The salesperson associated with'
|
|
' this record.')
|
|
plan_id = fields.Many2one('subscription.package.plan',
|
|
'Subscription Template', readonly=True,
|
|
help='The subscription template '
|
|
'associated with this record.')
|
|
|
|
def _query(self):
|
|
select_ = """
|
|
SELECT min(sl.id) as id,
|
|
sl.product_qty as quantity,
|
|
sub.total_recurring_price as total_recurring_price,
|
|
sub.user_id as user_id,
|
|
sub.plan_id as plan_id,
|
|
sub.name as name
|
|
"""
|
|
from_ = """
|
|
subscription_package_product_line sl
|
|
join subscription_package sub on (sl.subscription_id = sub.id)
|
|
"""
|
|
groupby_ = """
|
|
GROUP BY sl.product_qty,
|
|
sub.total_recurring_price,
|
|
sub.user_id,
|
|
sub.plan_id,
|
|
sub.name
|
|
"""
|
|
return '%s FROM ( %s ) %s' % (select_, from_, groupby_)
|
|
|
|
def init(self):
|
|
tools.drop_view_if_exists(self.env.cr, self._table)
|
|
self.env.cr.execute("""CREATE or REPLACE VIEW %s as (%s)""" % (
|
|
self._table, self._query()))
|
|
|