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.
		
		
		
		
		
			
		
			
				
					
					
						
							62 lines
						
					
					
						
							2.3 KiB
						
					
					
				
			
		
		
		
			
			
			
		
		
	
	
							62 lines
						
					
					
						
							2.3 KiB
						
					
					
				| # -*- coding: utf-8 -*- | |
| ############################################################################# | |
| # | |
| #    Cybrosys Technologies Pvt. Ltd. | |
| # | |
| #    Copyright (C) 2022-TODAY Cybrosys Technologies(<https://www.cybrosys.com>) | |
| #    Author: Cybrosys Techno Solutions(<https://www.cybrosys.com>) | |
| # | |
| #    You can modify it under the terms of the GNU LESSER | |
| #    GENERAL PUBLIC LICENSE (LGPL 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 LESSER GENERAL PUBLIC LICENSE (LGPL v3) for more details. | |
| # | |
| #    You should have received a copy of the GNU LESSER GENERAL PUBLIC LICENSE | |
| #    (LGPL 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) | |
|     quantity = fields.Float('Quantity', readonly=True) | |
|     user_id = fields.Many2one('res.users', 'Salesperson', readonly=True) | |
|     plan_id = fields.Many2one('subscription.package.plan', 'Subscription Template', readonly=True) | |
| 
 | |
|     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()))
 | |
| 
 |