15 changed files with 528 additions and 0 deletions
			
			
		| @ -0,0 +1,4 @@ | |||
| # -*- coding: utf-8 -*- | |||
| 
 | |||
| from . import report | |||
| from . import models | |||
| @ -0,0 +1,45 @@ | |||
| # -*- coding: utf-8 -*- | |||
| ################################################################################### | |||
| # | |||
| #    Cybrosys Technologies Pvt. Ltd. | |||
| #    Copyright (C) 2017-TODAY Cybrosys Technologies(<https://www.cybrosys.com>). | |||
| #    Author: LINTO C.T.(<https://www.cybrosys.com>) | |||
| # | |||
| #    This program is free software: you can modify | |||
| #    it under the terms of the GNU Affero General Public License (AGPL) as | |||
| #    published by the Free Software Foundation, either version 3 of the | |||
| #    License, or (at your option) any later version. | |||
| # | |||
| #    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 for more details. | |||
| # | |||
| #    You should have received a copy of the GNU Affero General Public License | |||
| #    along with this program.  If not, see <http://www.gnu.org/licenses/>. | |||
| # | |||
| ################################################################################### | |||
| { | |||
|     'name': 'Aged Partner Balance Bill-Wise', | |||
|     'version': '10.0.1.0.0', | |||
|     'category': 'Accounting', | |||
|     'summary': 'Bill-Wise Aged Partner Balance', | |||
|     'description': """ | |||
|     This module provides features to take a pdf report of bill-wise aged partner balance. | |||
|     """, | |||
|     'author': 'Cybrosys Techno Solutions', | |||
|     'website': "https://www.cybrosys.com", | |||
|     'company': 'Cybrosys Techno Solutions', | |||
|     'maintainer': 'Cybrosys Techno Solutions', | |||
|     'depends': ['account_accountant'], | |||
|     'data': [ | |||
|              'report/report_agedpartnerbalance.xml', | |||
|              'views/report_aged_partner_billwise.xml', | |||
|             ], | |||
|     'demo': [], | |||
|     'images': ['static/description/banner.jpg'], | |||
|     'license': 'LGPL-3', | |||
|     'installable': True, | |||
|     'application': False, | |||
|     'auto_install': False, | |||
| } | |||
| @ -0,0 +1,3 @@ | |||
| # -*- coding: utf-8 -*- | |||
| 
 | |||
| from . import report_aged_partner_balance | |||
| @ -0,0 +1,15 @@ | |||
| # -*- coding: utf-8 -*- | |||
| 
 | |||
| from odoo import fields, models | |||
| 
 | |||
| 
 | |||
| class AgedTrialBalanceBillwise(models.TransientModel): | |||
|     _inherit = 'account.aged.trial.balance' | |||
|     _description = 'Account Aged Trial balance Report Bill-wise' | |||
| 
 | |||
|     report_type = fields.Selection([('bill', 'Bill-wise'), ('customer', 'Customer-wise')], default='customer', | |||
|                                    string="Report Type") | |||
| 
 | |||
|     def _print_report(self, data): | |||
|         data['form']['report_type'] = self.report_type | |||
|         return super(AgedTrialBalanceBillwise, self)._print_report(data) | |||
| @ -0,0 +1,3 @@ | |||
| # -*- coding: utf-8 -*- | |||
| 
 | |||
| from . import account_aged_partner_balance | |||
| @ -0,0 +1,231 @@ | |||
| # -*- coding: utf-8 -*- | |||
| 
 | |||
| import time | |||
| from datetime import datetime | |||
| from dateutil.relativedelta import relativedelta | |||
| from odoo import api, models, _ | |||
| from odoo.tools import float_is_zero | |||
| 
 | |||
| 
 | |||
| class ReportAgedPartnerBalanceBillwise(models.AbstractModel): | |||
| 
 | |||
|     _inherit = 'report.account.report_agedpartnerbalance' | |||
| 
 | |||
|     def _get_billwise_move_lines(self, account_type, date_from, target_move, period_length): | |||
|         periods = {} | |||
|         start = datetime.strptime(date_from, "%Y-%m-%d") | |||
|         for i in range(5)[::-1]: | |||
|             stop = start - relativedelta(days=period_length) | |||
|             periods[str(i)] = { | |||
|                 'name': (i!=0 and (str((5-(i+1)) * period_length) + '-' + str((5-i) * period_length)) or ('+'+str(4 * period_length))), | |||
|                 'stop': start.strftime('%Y-%m-%d'), | |||
|                 'start': (i!=0 and stop.strftime('%Y-%m-%d') or False), | |||
|             } | |||
|             start = stop - relativedelta(days=1) | |||
|         res = [] | |||
|         total = [] | |||
|         cr = self.env.cr | |||
|         user_company = self.env.user.company_id.id | |||
|         move_state = ['draft', 'posted'] | |||
|         if target_move == 'posted': | |||
|             move_state = ['posted'] | |||
|         arg_list = (tuple(move_state), tuple(account_type)) | |||
|         #build the reconciliation clause to see what partner needs to be printed | |||
|         reconciliation_clause = '(l.reconciled IS FALSE)' | |||
|         cr.execute('SELECT debit_move_id, credit_move_id FROM account_partial_reconcile where create_date > %s', (date_from,)) | |||
|         reconciled_after_date = [] | |||
|         for row in cr.fetchall(): | |||
|             reconciled_after_date += [row[0], row[1]] | |||
|         if reconciled_after_date: | |||
|             reconciliation_clause = '(l.reconciled IS FALSE OR l.id IN %s)' | |||
|             arg_list += (tuple(reconciled_after_date),) | |||
|         arg_list += (date_from, user_company) | |||
|         query = ''' | |||
|             SELECT DISTINCT l.partner_id, UPPER(res_partner.name) | |||
|             FROM account_move_line AS l left join res_partner on l.partner_id = res_partner.id, account_account, account_move am | |||
|             WHERE (l.account_id = account_account.id) | |||
|                 AND (l.move_id = am.id) | |||
|                 AND (am.state IN %s) | |||
|                 AND (account_account.internal_type IN %s) | |||
|                 AND ''' + reconciliation_clause + ''' | |||
|                 AND (l.date <= %s) | |||
|                 AND l.company_id = %s | |||
|             ORDER BY UPPER(res_partner.name)''' | |||
|         cr.execute(query, arg_list) | |||
| 
 | |||
|         partners = cr.dictfetchall() | |||
|         # put a total of 0 | |||
|         for i in range(7): | |||
|             total.append(0) | |||
| 
 | |||
|         # Build a string like (1,2,3) for easy use in SQL query | |||
|         partner_ids = [partner['partner_id'] for partner in partners if partner['partner_id']] | |||
|         lines = dict((partner['partner_id'] or False, []) for partner in partners) | |||
|         if not partner_ids: | |||
|             return [], [], [] | |||
| 
 | |||
|         # This dictionary will store the not due amount of all partners | |||
|         undue_amounts = {} | |||
|         query = '''SELECT l.id | |||
|                 FROM account_move_line AS l, account_account, account_move am | |||
|                 WHERE (l.account_id = account_account.id) AND (l.move_id = am.id) | |||
|                     AND (am.state IN %s) | |||
|                     AND (account_account.internal_type IN %s) | |||
|                     AND (COALESCE(l.date_maturity,l.date) > %s)\ | |||
|                     AND ((l.partner_id IN %s) OR (l.partner_id IS NULL)) | |||
|                 AND (l.date <= %s) | |||
|                 AND l.company_id = %s''' | |||
|         cr.execute(query, (tuple(move_state), tuple(account_type), date_from, tuple(partner_ids), date_from, user_company)) | |||
|         aml_ids = cr.fetchall() | |||
|         aml_ids = aml_ids and [x[0] for x in aml_ids] or [] | |||
|         for line in self.env['account.move.line'].browse(aml_ids): | |||
|             partner_id = line.partner_id.id or False | |||
|             if partner_id not in undue_amounts: | |||
|                 undue_amounts[partner_id] = 0.0 | |||
|             line_amount = line.balance | |||
|             if line.balance == 0: | |||
|                 continue | |||
|             for partial_line in line.matched_debit_ids: | |||
|                 if partial_line.create_date[:10] <= date_from: | |||
|                     line_amount += partial_line.amount | |||
|             for partial_line in line.matched_credit_ids: | |||
|                 if partial_line.create_date[:10] <= date_from: | |||
|                     line_amount -= partial_line.amount | |||
|             undue_amounts[partner_id] += line_amount | |||
|             lines[partner_id].append({ | |||
|                 'line': line, | |||
|                 'amount': line_amount, | |||
|                 'period': 6, | |||
|                 }) | |||
|         # Use one query per period and store results in history (a list variable) | |||
|         # Each history will contain: history[1] = {'<partner_id>': <partner_debit-credit>} | |||
|         history = [] | |||
|         for i in range(5): | |||
|             args_list = (tuple(move_state), tuple(account_type), tuple(partner_ids),) | |||
|             dates_query = '(COALESCE(l.date_maturity,l.date)' | |||
| 
 | |||
|             if periods[str(i)]['start'] and periods[str(i)]['stop']: | |||
|                 dates_query += ' BETWEEN %s AND %s)' | |||
|                 args_list += (periods[str(i)]['start'], periods[str(i)]['stop']) | |||
|             elif periods[str(i)]['start']: | |||
|                 dates_query += ' >= %s)' | |||
|                 args_list += (periods[str(i)]['start'],) | |||
|             else: | |||
|                 dates_query += ' <= %s)' | |||
|                 args_list += (periods[str(i)]['stop'],) | |||
|             args_list += (date_from, user_company) | |||
| 
 | |||
|             query = '''SELECT l.id | |||
|                     FROM account_move_line AS l, account_account, account_move am | |||
|                     WHERE (l.account_id = account_account.id) AND (l.move_id = am.id) | |||
|                         AND (am.state IN %s) | |||
|                         AND (account_account.internal_type IN %s) | |||
|                         AND ((l.partner_id IN %s) OR (l.partner_id IS NULL)) | |||
|                         AND ''' + dates_query + ''' | |||
|                     AND (l.date <= %s) | |||
|                     AND l.company_id = %s''' | |||
|             cr.execute(query, args_list) | |||
|             partners_amount = {} | |||
|             aml_ids = cr.fetchall() | |||
|             aml_ids = aml_ids and [x[0] for x in aml_ids] or [] | |||
|             for line in self.env['account.move.line'].browse(aml_ids): | |||
|                 partner_id = line.partner_id.id or False | |||
|                 if partner_id not in partners_amount: | |||
|                     partners_amount[partner_id] = 0.0 | |||
|                 line_amount = line.balance | |||
|                 if line.balance == 0: | |||
|                     continue | |||
|                 for partial_line in line.matched_debit_ids: | |||
|                     if partial_line.create_date[:10] <= date_from: | |||
|                         line_amount += partial_line.amount | |||
|                 for partial_line in line.matched_credit_ids: | |||
|                     if partial_line.create_date[:10] <= date_from: | |||
|                         line_amount -= partial_line.amount | |||
| 
 | |||
|                 partners_amount[partner_id] += line_amount | |||
|                 lines[partner_id].append({ | |||
|                     'line': line, | |||
|                     'amount': line_amount, | |||
|                     'period': i + 1, | |||
|                     }) | |||
|             history.append(partners_amount) | |||
|         for partner in partners: | |||
|             at_least_one_amount = False | |||
|             values = {} | |||
|             undue_amt = 0.0 | |||
|             if partner['partner_id'] in undue_amounts:  # Making sure this partner actually was found by the query | |||
|                 undue_amt = undue_amounts[partner['partner_id']] | |||
| 
 | |||
|             total[6] = total[6] + undue_amt | |||
|             values['direction'] = undue_amt | |||
|             if not float_is_zero(values['direction'], precision_rounding=self.env.user.company_id.currency_id.rounding): | |||
|                 at_least_one_amount = True | |||
| 
 | |||
|             for i in range(5): | |||
|                 during = False | |||
|                 if partner['partner_id'] in history[i]: | |||
|                     during = [history[i][partner['partner_id']]] | |||
|                 # Adding counter | |||
|                 total[(i)] = total[(i)] + (during and during[0] or 0) | |||
|                 values[str(i)] = during and during[0] or 0.0 | |||
|                 if not float_is_zero(values[str(i)], precision_rounding=self.env.user.company_id.currency_id.rounding): | |||
|                     at_least_one_amount = True | |||
|             values['total'] = sum([values['direction']] + [values[str(i)] for i in range(5)]) | |||
|             ## Add for total | |||
|             total[(i + 1)] += values['total'] | |||
|             values['partner_id'] = partner['partner_id'] | |||
|             if partner['partner_id']: | |||
|                 browsed_partner = self.env['res.partner'].browse(partner['partner_id']) | |||
|                 values['name'] = browsed_partner.name and len(browsed_partner.name) >= 45 and browsed_partner.name[0:40] + '...' or browsed_partner.name | |||
|                 values['trust'] = browsed_partner.trust | |||
|             else: | |||
|                 values['name'] = _('Unknown Partner') | |||
|                 values['trust'] = False | |||
|             if at_least_one_amount: | |||
|                 res.append(values) | |||
|         return res, total, lines | |||
| 
 | |||
|     @api.model | |||
|     def render_html(self, docids, data=None): | |||
|         total = [] | |||
|         model = self.env.context.get('active_model') | |||
|         docs = self.env[model].browse(self.env.context.get('active_id')) | |||
| 
 | |||
|         target_move = data['form'].get('target_move', 'all') | |||
|         date_from = data['form'].get('date_from', time.strftime('%Y-%m-%d')) | |||
| 
 | |||
|         if data['form']['result_selection'] == 'customer': | |||
|             account_type = ['receivable'] | |||
|         elif data['form']['result_selection'] == 'supplier': | |||
|             account_type = ['payable'] | |||
|         else: | |||
|             account_type = ['payable', 'receivable'] | |||
| 
 | |||
|         if data['form'].get('report_type') == 'bill': | |||
|             movelines, total, dummy = self._get_billwise_move_lines(account_type, date_from, target_move, data['form']['period_length']) | |||
|             for partner in dummy: | |||
|                 for line in dummy[partner]: | |||
|                     line['intervals'] = { | |||
|                         '0': 0, | |||
|                         '1': 0, | |||
|                         '2': 0, | |||
|                         '3': 0, | |||
|                         '4': 0, | |||
|                         '5': 0, | |||
|                         'total': 0 | |||
|                     } | |||
|                     line['intervals'][str(line['period']-1)] = line['amount'] | |||
|                     line['intervals']['total'] += line['amount'] | |||
|         else: | |||
|             movelines, total, dummy = self._get_partner_move_lines(account_type, date_from, target_move, data['form']['period_length']) | |||
|         docargs = { | |||
|             'doc_ids': self.ids, | |||
|             'doc_model': model, | |||
|             'data': data['form'], | |||
|             'docs': docs, | |||
|             'time': time, | |||
|             'lines': dummy, | |||
|             'get_partner_lines': movelines, | |||
|             'get_direction': total, | |||
|         } | |||
|         return self.env['report'].render('account.report_agedpartnerbalance', docargs) | |||
| @ -0,0 +1,106 @@ | |||
| <?xml version="1.0" encoding="utf-8"?> | |||
| <odoo> | |||
|     <template id="report_agedpartnerbalance" inherit_id="account.report_agedpartnerbalance"> | |||
|         <xpath expr="//div[@class='page']/div[2]" position="after"> | |||
|             <div class="row mb32"> | |||
|                 <div class="col-xs-3"> | |||
|                     <strong>Report Type:</strong> | |||
|                     <p> | |||
|                         <span t-if="data['report_type'] == 'bill'">Bill-Wise</span> | |||
|                         <span t-if="data['report_type'] == 'customer'">Customer-Wise</span> | |||
|                     </p> | |||
|                 </div> | |||
|             </div> | |||
|         </xpath> | |||
|         <xpath expr="//div[@class='page']/table[1]" position="replace"> | |||
|             <table class="table table-condensed"> | |||
|                 <thead> | |||
|                     <tr> | |||
|                         <th>Partners</th> | |||
|                         <th class="text-right"> | |||
|                             <span>Not due</span> | |||
|                         </th> | |||
|                         <th class="text-right"><span t-esc="data['4']['name']"/></th> | |||
|                         <th class="text-right"><span t-esc="data['3']['name']"/></th> | |||
|                         <th class="text-right"><span t-esc="data['2']['name']"/></th> | |||
|                         <th class="text-right"><span t-esc="data['1']['name']"/></th> | |||
|                         <th class="text-right"><span t-esc="data['0']['name']"/></th> | |||
|                         <th class="text-right">Total</th> | |||
|                     </tr> | |||
|                     <tr t-if="get_partner_lines"> | |||
|                         <th style="border-bottom:2px solid !important;">Account Total</th> | |||
|                         <th style="border-bottom:2px solid !important;" class="text-right"><span t-esc="get_direction[6]" t-options="{'widget': 'monetary', 'display_currency': res_company.currency_id}"/></th> | |||
|                         <th style="border-bottom:2px solid !important;" class="text-right"><span t-esc="get_direction[4]" t-options="{'widget': 'monetary', 'display_currency': res_company.currency_id}"/></th> | |||
|                         <th style="border-bottom:2px solid !important;" class="text-right"><span t-esc="get_direction[3]" t-options="{'widget': 'monetary', 'display_currency': res_company.currency_id}"/></th> | |||
|                         <th style="border-bottom:2px solid !important;" class="text-right"><span t-esc="get_direction[2]" t-options="{'widget': 'monetary', 'display_currency': res_company.currency_id}"/></th> | |||
|                         <th style="border-bottom:2px solid !important;" class="text-right"><span t-esc="get_direction[1]" t-options="{'widget': 'monetary', 'display_currency': res_company.currency_id}"/></th> | |||
|                         <th style="border-bottom:2px solid !important;" class="text-right"><span t-esc="get_direction[0]" t-options="{'widget': 'monetary', 'display_currency': res_company.currency_id}"/></th> | |||
|                         <th style="border-bottom:2px solid !important;" class="text-right"><span t-esc="get_direction[5]" t-options="{'widget': 'monetary', 'display_currency': res_company.currency_id}"/></th> | |||
|                     </tr> | |||
|                 </thead> | |||
|                 <tbody> | |||
|                     <t t-foreach="get_partner_lines" t-as="partner"> | |||
|                         <tr style="font-weight:bold !important;border-top:1px solid !important;"> | |||
|                             <td style="border-top:1px solid !important;"> | |||
|                                 <span t-esc="partner['name']"/> | |||
|                             </td> | |||
|                             <td class="text-right" style="border-top:1px solid !important;"> | |||
|                                 <span t-esc="partner['direction']" t-options="{'widget': 'monetary', 'display_currency': res_company.currency_id}"/> | |||
|                             </td> | |||
|                             <td class="text-right" style="border-top:1px solid !important;"> | |||
|                                 <span t-esc="partner['4']" t-options="{'widget': 'monetary', 'display_currency': res_company.currency_id}"/> | |||
|                             </td> | |||
|                             <td class="text-right" style="border-top:1px solid !important;"> | |||
|                                 <span t-esc="partner['3']" t-options="{'widget': 'monetary', 'display_currency': res_company.currency_id}"/> | |||
|                             </td> | |||
|                             <td class="text-right" style="border-top:1px solid !important;"> | |||
|                                 <span t-esc="partner['2']" t-options="{'widget': 'monetary', 'display_currency': res_company.currency_id}"/> | |||
|                             </td> | |||
|                             <td class="text-right" style="border-top:1px solid !important;"> | |||
|                                 <span t-esc="partner['1']" t-options="{'widget': 'monetary', 'display_currency': res_company.currency_id}"/> | |||
|                             </td> | |||
|                             <td class="text-right" style="border-top:1px solid !important;"> | |||
|                                 <span t-esc="partner['0']" t-options="{'widget': 'monetary', 'display_currency': res_company.currency_id}"/> | |||
|                             </td> | |||
|                             <td class="text-right" style="border-top:1px solid !important;"> | |||
|                                 <span t-esc="partner['total']" t-options="{'widget': 'monetary', 'display_currency': res_company.currency_id}"/> | |||
|                             </td> | |||
|                         </tr> | |||
|                         <t t-if="data['report_type'] == 'bill'"> | |||
|                             <t t-foreach="lines[partner['partner_id']]" t-as="line"> | |||
|                                 <t t-if="line['amount'] > 0"> | |||
|                                     <tr> | |||
|                                         <td class="text-right"> | |||
|                                             <span t-esc="line['line'].invoice_id.number"/> | |||
|                                         </td> | |||
|                                         <td class="text-right"> | |||
|                                             <span t-esc="line['intervals'].get('5')" t-options="{'widget': 'monetary', 'display_currency': res_company.currency_id}"/> | |||
|                                         </td> | |||
|                                         <td class="text-right"> | |||
|                                             <span t-esc="line['intervals'].get('4')" t-options="{'widget': 'monetary', 'display_currency': res_company.currency_id}"/> | |||
|                                         </td> | |||
|                                         <td class="text-right"> | |||
|                                             <span t-esc="line['intervals'].get('3')" t-options="{'widget': 'monetary', 'display_currency': res_company.currency_id}"/> | |||
|                                         </td> | |||
|                                         <td class="text-right"> | |||
|                                             <span t-esc="line['intervals'].get('2')" t-options="{'widget': 'monetary', 'display_currency': res_company.currency_id}"/> | |||
|                                         </td> | |||
|                                         <td class="text-right"> | |||
|                                             <span t-esc="line['intervals'].get('1')" t-options="{'widget': 'monetary', 'display_currency': res_company.currency_id}"/> | |||
|                                         </td> | |||
|                                         <td class="text-right"> | |||
|                                             <span t-esc="line['intervals'].get('0')" t-options="{'widget': 'monetary', 'display_currency': res_company.currency_id}"/> | |||
|                                         </td> | |||
|                                         <td class="text-right"> | |||
|                                             <span t-esc="line['intervals'].get('total')" t-options="{'widget': 'monetary', 'display_currency': res_company.currency_id}"/> | |||
|                                         </td> | |||
|                                     </tr> | |||
|                                 </t> | |||
|                             </t> | |||
|                         </t> | |||
|                     </t> | |||
|                 </tbody> | |||
|             </table> | |||
|         </xpath> | |||
|     </template> | |||
| </odoo> | |||
| After Width: | Height: | Size: 125 KiB | 
| After Width: | Height: | Size: 47 KiB | 
| After Width: | Height: | Size: 34 KiB | 
| After Width: | Height: | Size: 50 KiB | 
| After Width: | Height: | Size: 33 KiB | 
| @ -0,0 +1,108 @@ | |||
| <section class="oe_container"> | |||
|     <div class="oe_row oe_spaced"> | |||
|         <h2 class="oe_slogan">Aged Partner Balance Bill-Wise</h2> | |||
|         <h3 class="oe_slogan"></h3> | |||
|         <h4 class="oe_slogan"><a href="https://www.cybrosys.com">Cybrosys Technologies</a> </h4> | |||
|     </div> | |||
|     <div class="oe_row oe_spaced" style="padding-left:65px;"> | |||
|         <div> | |||
|             <span style="color:green;"> ☑ </span> Bill-wise aged partner balance report.<br/> | |||
|             <span style="color:green;"> ☑ </span> Customer-wise aged partner balance report.<br/> | |||
|         </div> | |||
|     </div> | |||
| </section> | |||
| 
 | |||
| <section class="oe_container oe_dark"> | |||
|     <div class="oe_row oe_spaced"> | |||
|         <div class="oe_picture"> | |||
|             <h3 class="oe_slogan">Overview</h3> | |||
|             <p class="oe_mt32 text-justify" style="text-align: center;"> | |||
|                 By default, Odoo doesn't have a bill-wise aged partner balance report. | |||
|                 With this module, we can have a pdf report of bill-wise and customer-wise(Odoo's default) | |||
|                 aged partner balance reports. | |||
|             </p> | |||
|         </div> | |||
|     </div> | |||
| </section> | |||
| 
 | |||
| <section class="oe_container"> | |||
|     <div class="oe_row oe_spaced"> | |||
|         <div style="text-align: center;"> | |||
|             <p> | |||
|                 <h4>Specify Report Type</h4> | |||
|             <p> | |||
|         </div> | |||
|         <div style="text-align: center;"> | |||
|             <div class="oe_demo oe_picture oe_screenshot"> | |||
|                 <img style="border:10px solid white;height:400px;" src="report_type_wiz.png"> | |||
|             </div> | |||
|         </div> | |||
|         <div style="text-align: center;"> | |||
|             <p> | |||
|                 A new field is added to the aged partner balance wizard to specify the report type. | |||
|                 We can have two types of reports, bill-wise or customer-wise. Bill-wise option will output | |||
|                 a bill-wise aged partner balance and customer-wise option will output a customer wise | |||
|                 aged partner balance report. | |||
|             </p> | |||
|         </div> | |||
|     </div> | |||
| </section> | |||
| 
 | |||
| <section class="oe_container oe_dark"> | |||
|     <div class="oe_row oe_spaced"> | |||
|         <div style="text-align: center;"> | |||
|             <p> | |||
|                 <h4>Bill-Wise Report</h4> | |||
|             <p> | |||
|         </div> | |||
|         <div style="text-align: center;"> | |||
|             <div class="oe_demo oe_picture oe_screenshot"> | |||
|                 <img style="border:10px solid white;" src="bill-wise-repo.png"> | |||
|             </div> | |||
|         </div> | |||
|     </div> | |||
| </section> | |||
| 
 | |||
| <section class="oe_container"> | |||
|     <div class="oe_row oe_spaced"> | |||
|         <div style="text-align: center;"> | |||
|             <p> | |||
|                 <h4>Customer-Wise Report</h4> | |||
|             <p> | |||
|         </div> | |||
|         <div style="text-align: center;"> | |||
|             <div class="oe_demo oe_picture oe_screenshot"> | |||
|                 <img style="border:10px solid white;" src="customer-wise.png"> | |||
|             </div> | |||
|         </div> | |||
|         <div class="oe_row oe_spaced" style="padding-left:65px;"> | |||
|             <p>Type of report will be mentioned in the report.</p> | |||
|         </div> | |||
|     </div> | |||
| </section> | |||
| 
 | |||
| <section class="oe_container oe_dark"> | |||
|     <h2 class="oe_slogan" style="margin-top:20px;" >Need Any Help?</h2> | |||
|     <div class="oe_slogan" style="margin-top:10px !important;"> | |||
|         <div> | |||
|             <a  class="btn btn-primary btn-lg mt8" | |||
|             style="color: #FFFFFF !important;border-radius: 0;" href="https://www.cybrosys.com"><i | |||
|             class="fa fa-envelope"></i> Email </a> <a | |||
|             class="btn btn-primary btn-lg mt8" style="color: #FFFFFF !important;border-radius: 0;" | |||
|             href="https://www.cybrosys.com/contact/"><i | |||
|             class="fa fa-phone"></i> Contact Us </a> <a | |||
|             class="btn btn-primary btn-lg mt8" style="color: #FFFFFF !important;border-radius: 0;" | |||
|             href="https://www.cybrosys.com/odoo-customization-and-installation/"><i | |||
|             class="fa fa-check-square"></i> Request Customization </a> | |||
|         </div> | |||
|         <br> | |||
|         <img src="cybro_logo.png" style="width: 190px; margin-bottom: 20px;" class="center-block"> | |||
|         <div> | |||
|           <a href="https://twitter.com/cybrosys" target="_blank"><i class="fa fa-2x fa-twitter" style="color:white;background: #00a0d1;width:35px;"></i></a></td> | |||
|           <a href="https://www.linkedin.com/company/cybrosys-technologies-pvt-ltd" target="_blank"><i class="fa fa-2x fa-linkedin" style="color:white;background: #31a3d6;width:35px;padding-left: 3px;"></i></a></td> | |||
|           <a href="https://www.facebook.com/cybrosystechnologies" target="_blank"><i class="fa fa-2x fa-facebook" style="color:white;background: #3b5998;width:35px;padding-left: 8px;"></i></a></td> | |||
|           <a href="https://plus.google.com/106641282743045431892/about" target="_blank"><i class="fa fa-2x fa-google-plus" style="color:white;background: #c53c2c;width:35px;padding-left: 3px;"></i></a></td> | |||
|           <a href="https://in.pinterest.com/cybrosys" target="_blank"><i class="fa fa-2x fa-pinterest" style="color:white;background: #ac0f18;width:35px;padding-left: 3px;"></i></a></td> | |||
|         </div> | |||
|     </div> | |||
| </section> | |||
| After Width: | Height: | Size: 61 KiB | 
| @ -0,0 +1,13 @@ | |||
| <?xml version="1.0" encoding="utf-8"?> | |||
| <odoo> | |||
|     <record id="aged_balance_view_billwise" model="ir.ui.view"> | |||
|         <field name="name">Aged Partner Balance Billwise</field> | |||
|         <field name="model">account.aged.trial.balance</field> | |||
|         <field name="inherit_id" ref="account.account_aged_balance_view" /> | |||
|         <field name="arch" type="xml"> | |||
|             <xpath expr="//field[@name='result_selection']" position="after"> | |||
|                 <field name="report_type" /> | |||
|             </xpath> | |||
|         </field> | |||
|     </record> | |||
| </odoo> | |||
					Loading…
					
					
				
		Reference in new issue