diff --git a/account_partner_aged_statement_webkit/i18n/fr.po b/account_partner_aged_statement_webkit/i18n/fr.po index bff78e7a..656a44d8 100644 --- a/account_partner_aged_statement_webkit/i18n/fr.po +++ b/account_partner_aged_statement_webkit/i18n/fr.po @@ -106,6 +106,59 @@ msgid "\n" "
\n" "\n" "

\n" +"   REFERENCES
\n" +"   Total overdue amount: ${object.credit} ${user.company_id.currency_id.name}
\n" +"

\n" +"\n" +"
\n" +"
\n" +"
\n" +"

\n" +" ${user.company_id.name}

\n" +"
\n" +"
\n" +" \n" +" % if user.company_id.street:\n" +" ${user.company_id.street}
\n" +" % endif\n" +" % if user.company_id.street2:\n" +" ${user.company_id.street2}
\n" +" % endif\n" +" % if user.company_id.city or user.company_id.zip:\n" +" ${user.company_id.zip} ${user.company_id.city}
\n" +" % endif\n" +" % if user.company_id.country_id:\n" +" ${user.company_id.state_id and ('%s, ' % user.company_id.state_id.name) or ''} ${user.company_id.country_id.name or ''}
\n" +" % endif\n" +"
\n" +" % if user.company_id.phone:\n" +"
\n" +" Phone:  ${user.company_id.phone}\n" +"
\n" +" % endif\n" +" % if user.company_id.website:\n" +"
\n" +" Web : ${user.company_id.website}\n" +"
\n" +" %endif\n" +"

\n" +"
\n" +"\n" +" " +msgstr "\n" +"
\n" +"\n" +" \n" +" % for line in user.company_id.overdue_msg.split('\\n'):\n" +"

${line}

\n" +" % endfor\n" +"\n" +"
\n" +" ${user.name}\n" +"
\n" +"
\n" +"\n" +"

\n" "   RÉFÉRENCES
\n" "   Total du montant en retard: ${object.credit} ${user.company_id.currency_id.name}
\n" "

\n" @@ -145,7 +198,6 @@ msgid "\n" "
\n" "\n" " " -msgstr "" #. module: account_partner_aged_statement_webkit #: report:addons/account_partner_aged_statement_webkit/report/partner_aged_statement.mako:63 diff --git a/account_partner_aged_statement_webkit/report/partner_aged_statement.mako b/account_partner_aged_statement_webkit/report/partner_aged_statement.mako index 08780055..b3a580e9 100644 --- a/account_partner_aged_statement_webkit/report/partner_aged_statement.mako +++ b/account_partner_aged_statement_webkit/report/partner_aged_statement.mako @@ -33,9 +33,9 @@
<%from datetime import date %> ${_('Date')}: ${formatLang(str(date.today()), date=True)} -
+
${_('Partner')}: ${partner.name} -
+
${_('Subject')}: ${_('Overdue Statement')}

@@ -46,15 +46,15 @@

%endfor %endif -
+
${user.name} -
-
+
+
%if (partner.credit + partner.debit == 0) :
${_('Nothing due for this partner')}
%else:
${_('Aged Balance')}
-
+
%if get_balance(partner, company): @@ -81,11 +81,11 @@ %endfor
%endif -
-
+
+
${_('List of Due Invoices')}
%if getLines30(partner, company): -
+
${_('0-30')}
diff --git a/account_partner_aged_statement_webkit/report/partner_aged_statement_report.py b/account_partner_aged_statement_webkit/report/partner_aged_statement_report.py index 6a01a3bd..7c9f9aa5 100644 --- a/account_partner_aged_statement_webkit/report/partner_aged_statement_report.py +++ b/account_partner_aged_statement_webkit/report/partner_aged_statement_report.py @@ -21,7 +21,7 @@ ############################################################################### import time - +import pytz from datetime import datetime from dateutil.relativedelta import relativedelta @@ -56,12 +56,15 @@ class PartnerAgedTrialReport(aged_trial_report): }) self.partner_invoices_dict = {} self.ttype = 'receipt' + tz = self.localcontext.get('tz', False) + tz = tz and pytz.timezone(tz) or pytz.utc + self.today = datetime.now(tz) def _get_balance(self, partner, company): """ Get the lines of balance to display in the report """ - today = datetime.now() + today = self.today date_30 = today - relativedelta(days=30) date_60 = today - relativedelta(days=60) date_90 = today - relativedelta(days=90) @@ -257,7 +260,7 @@ class PartnerAgedTrialReport(aged_trial_report): return self.partner_invoices_dict[partner.id] def _lines_get_30(self, partner, company): - today = datetime.now() + today = self.today stop = today - relativedelta(days=30) today = today.strftime(DEFAULT_SERVER_DATE_FORMAT) @@ -271,7 +274,7 @@ class PartnerAgedTrialReport(aged_trial_report): return movelines def _lines_get_30_60(self, partner, company): - today = datetime.now() + today = self.today start = today - relativedelta(days=30) stop = start - relativedelta(days=30) @@ -282,12 +285,12 @@ class PartnerAgedTrialReport(aged_trial_report): movelines = self._get_current_invoice_lines(partner, company, today) movelines = [ line for line in movelines - if stop < line['date_due'] <= start + if line['date_due'] and stop < line['date_due'] <= start ] return movelines def _lines_get60(self, partner, company): - today = datetime.now() + today = self.today start = today - relativedelta(days=60) today = today.strftime(DEFAULT_SERVER_DATE_FORMAT) @@ -304,51 +307,11 @@ class PartnerAgedTrialReport(aged_trial_report): company_pool = pooler.get_pool(self.cr.dbname)['res.company'] message = company_pool.browse( self.cr, self.uid, company.id, {'lang': obj.lang}).overdue_msg - return message.split('\n') - - def _get_fiscalyear(self, data): - now = data['fInvoicesorm']['date_from'] - domain = [ - ('company_id', '=', self._company.id), - ('date_start', '<', now), - ('date_stop', '>', now), - ] - fiscalyears_obj = pooler.get_pool(self.cr.dbname)['account.fiscalyear'] - fiscalyears = fiscalyears_obj.search( - self.cr, self.uid, domain, limit=1, context=self.localcontext) - if fiscalyears: - return fiscalyears_obj.browse( - self.cr, self.uid, fiscalyears[0], context=self.localcontext - ).name - else: - return '' - - def _get_account(self, data): - account_obj = pooler.get_pool(self.cr.dbname).get('account.account') - accounts = account_obj.search( - self.cr, self.uid, - [('parent_id', '=', False), ('company_id', '=', self._company.id)], - limit=1, context=self.localcontext) - if accounts: - return account_obj.browse( - self.cr, self.uid, accounts[0], - context=self.localcontext).name - else: - return '' + return message and message.split('\n') or '' def _get_company(self, data): return self._company.name - def _get_journal(self, data): - codes = [] - if data.get('form', False) and data['form'].get('journal_ids', False): - self.cr.execute( - 'select code from account_journal where id IN %s', - (tuple(data['form']['journal_ids']),) - ) - codes = [x for x, in self.cr.fetchall()] - return codes - def _get_currency(self, data): return self._company.currency_id.symbol