|
@ -2,15 +2,23 @@ |
|
|
<!-- Copyright 2018 Eficent Business and IT Consulting Services S.L. |
|
|
<!-- Copyright 2018 Eficent Business and IT Consulting Services S.L. |
|
|
License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). --> |
|
|
License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl). --> |
|
|
<odoo> |
|
|
<odoo> |
|
|
|
|
|
<template id="report_assets_common" name="oca_statements report assets" inherit_id="web.report_assets_common"> |
|
|
|
|
|
<xpath expr="." position="inside"> |
|
|
|
|
|
<link href="/customer_outstanding_statement/static/src/less/layout_statement.less" rel="stylesheet"/> |
|
|
|
|
|
</xpath> |
|
|
|
|
|
</template> |
|
|
|
|
|
|
|
|
<template id="customer_outstanding_statement.statement_document"> |
|
|
<template id="customer_outstanding_statement.statement_document"> |
|
|
<t t-call="web.external_layout"> |
|
|
<t t-call="web.external_layout"> |
|
|
<div class="page"> |
|
|
<div class="page"> |
|
|
<div class="row"> |
|
|
<div class="row"> |
|
|
<div class="col-xs-5 col-xs-offset-7"> |
|
|
|
|
|
<span t-field="o.name"/><br/> |
|
|
|
|
|
<span t-raw="o.contact_address.replace('\n\n', '\n').replace('\n', '<br>')"/> |
|
|
|
|
|
|
|
|
<div name="statement_address" class="col-xs-5 col-xs-offset-7"> |
|
|
|
|
|
<address t-esc="o" |
|
|
|
|
|
t-options='{"widget": "contact", "fields": ["address", "name"], "no_marker": True}'/> |
|
|
|
|
|
<div t-if="o.vat" class="mt16"><t t-esc="o.country_id.vat_label or 'TIN'"/>: |
|
|
<span t-field="o.vat"/> |
|
|
<span t-field="o.vat"/> |
|
|
</div> |
|
|
</div> |
|
|
|
|
|
</div> |
|
|
<h4 style="padding-left:15em;padding-top:2em"> |
|
|
<h4 style="padding-left:15em;padding-top:2em"> |
|
|
Outstanding Statement |
|
|
Outstanding Statement |
|
|
</h4> |
|
|
</h4> |
|
@ -23,163 +31,133 @@ |
|
|
<br/> |
|
|
<br/> |
|
|
<t t-foreach="Lines[o.id]" t-as="currency"> |
|
|
<t t-foreach="Lines[o.id]" t-as="currency"> |
|
|
<br t-if="not currency_first"/> |
|
|
<br t-if="not currency_first"/> |
|
|
<p t-if="account_type == 'receivable'"> |
|
|
|
|
|
+ Customer Outstanding Statement at <span t-esc="Date_end[o.id]" /> in <span t-esc="Currencies[o.id][currency].name"/>: |
|
|
|
|
|
+ </p> |
|
|
|
|
|
<p t-if="account_type == 'payable'"> |
|
|
|
|
|
+ Supplier Outstanding Statement at <span t-esc="Date_end[o.id]" /> in <span t-esc="Currencies[o.id][currency].name"/>: |
|
|
|
|
|
|
|
|
<p> |
|
|
|
|
|
<span t-esc="'Customer' if account_type == 'receivable' else 'Supplier'"/> |
|
|
|
|
|
Outstanding Statement at |
|
|
|
|
|
<span t-esc="Date_end[o.id]"/> |
|
|
|
|
|
in <span t-esc="Currencies[o.id][currency].name"/>: |
|
|
|
|
|
|
|
|
</p> |
|
|
</p> |
|
|
<table class="table table-condensed" style="border: 1px solid black; border-collapse: collapse;"> |
|
|
|
|
|
|
|
|
<table class="table table-condensed table-statement"> |
|
|
<thead> |
|
|
<thead> |
|
|
<tr> |
|
|
<tr> |
|
|
<th style="border-right: 1px solid black;">Reference number</th> |
|
|
|
|
|
<th class="text-center" style="border-right: 1px solid black;">Date</th> |
|
|
|
|
|
<th class="text-center" style="border-right: 1px solid black;">Due Date</th> |
|
|
|
|
|
<th style="border-right: 1px solid black;">Description</th> |
|
|
|
|
|
<th class="text-right" style="border-right: 1px solid black;">Original Amount</th> |
|
|
|
|
|
<th class="text-right" style="border-right: 1px solid black;">Open Amount</th> |
|
|
|
|
|
<th class="text-right" style="border-right: 1px solid black;">Balance</th> |
|
|
|
|
|
|
|
|
<th>Reference number</th> |
|
|
|
|
|
<th>Date</th> |
|
|
|
|
|
<th>Due Date</th> |
|
|
|
|
|
<th>Description</th> |
|
|
|
|
|
<th class="amount">Original Amount</th> |
|
|
|
|
|
<th class="amount">Open Amount</th> |
|
|
|
|
|
<th class="amount">Balance</th> |
|
|
</tr> |
|
|
</tr> |
|
|
</thead> |
|
|
</thead> |
|
|
<tr t-foreach="Lines[o.id][currency]" t-as="line"> |
|
|
|
|
|
<t t-if="not line['blocked']"> |
|
|
|
|
|
<td style="border-right: 1px solid black;"> |
|
|
|
|
|
|
|
|
<tr t-foreach="Lines[o.id][currency]" t-as="line" |
|
|
|
|
|
t-att-class="'statement-blocked' if line['blocked'] else ''"> |
|
|
|
|
|
|
|
|
|
|
|
<td> |
|
|
<span t-esc="line['move_id']"/> |
|
|
<span t-esc="line['move_id']"/> |
|
|
</td> |
|
|
</td> |
|
|
<td style="border-right: 1px solid black;"> |
|
|
|
|
|
|
|
|
<td> |
|
|
<span t-esc="line['date']"/> |
|
|
<span t-esc="line['date']"/> |
|
|
</td> |
|
|
</td> |
|
|
<td style="border-right: 1px solid black;"> |
|
|
|
|
|
|
|
|
<td> |
|
|
<span t-esc="line['date_maturity']"/> |
|
|
<span t-esc="line['date_maturity']"/> |
|
|
</td> |
|
|
</td> |
|
|
<td style="border-right: 1px solid black;"> |
|
|
|
|
|
|
|
|
<td> |
|
|
<t t-if="line['name'] != '/'"> |
|
|
<t t-if="line['name'] != '/'"> |
|
|
<t t-if="not line['ref']"><span t-esc="line['name']"/></t> |
|
|
|
|
|
|
|
|
<t t-if="not line['ref']"> |
|
|
|
|
|
<span t-esc="line['name']"/> |
|
|
|
|
|
</t> |
|
|
<t t-if="line['ref'] and line['name']"> |
|
|
<t t-if="line['ref'] and line['name']"> |
|
|
<t t-if="line['name'] not in line['ref']"><span t-esc="line['name']"/></t> |
|
|
|
|
|
<t t-if="line['ref'] not in line['name']"><span t-esc="line['ref']"/></t> |
|
|
|
|
|
|
|
|
<t t-if="line['name'] not in line['ref']"> |
|
|
|
|
|
<span t-esc="line['name']"/> |
|
|
</t> |
|
|
</t> |
|
|
|
|
|
<t t-if="line['ref'] not in line['name']"> |
|
|
|
|
|
<span t-esc="line['ref']"/> |
|
|
</t> |
|
|
</t> |
|
|
<t t-if="line['name'] == '/'"><span t-esc="line['ref']"/></t> |
|
|
|
|
|
</td> |
|
|
|
|
|
<td class="text-right" style="border-right: 1px solid black;"> |
|
|
|
|
|
<span t-esc="line['amount']" t-esc-options='{"widget": "monetary", "display_currency": "currency"}'/> |
|
|
|
|
|
</td> |
|
|
|
|
|
<td class="text-right" style="border-right: 1px solid black;"> |
|
|
|
|
|
<span t-esc="line['open_amount']" t-esc-options='{"widget": "monetary", "display_currency": "currency"}'/> |
|
|
|
|
|
</td> |
|
|
|
|
|
<td class="text-right" style="border-right: 1px solid black;"> |
|
|
|
|
|
<span t-esc="line['balance']" t-esc-options='{"widget": "monetary", "display_currency": "currency"}'/> |
|
|
|
|
|
</td> |
|
|
|
|
|
</t> |
|
|
</t> |
|
|
<t t-if="line['blocked']"> |
|
|
|
|
|
<td style="border-right: 1px solid black; background-color: grey;"> |
|
|
|
|
|
<span t-esc="line['move_id']"/> |
|
|
|
|
|
</td> |
|
|
|
|
|
<td style="border-right: 1px solid black; background-color: grey;"> |
|
|
|
|
|
<span t-esc="line['date']"/> |
|
|
|
|
|
</td> |
|
|
|
|
|
<td style="border-right: 1px solid black; background-color: grey;"> |
|
|
|
|
|
<span t-esc="line['date_maturity']"/> |
|
|
|
|
|
</td> |
|
|
|
|
|
<td style="border-right: 1px solid black; background-color: grey;"> |
|
|
|
|
|
<t t-if="line['name'] != '/'"> |
|
|
|
|
|
<t t-if="not line['ref']"><span t-esc="line['name']"/></t> |
|
|
|
|
|
<t t-if="line['ref'] and line['name']"> |
|
|
|
|
|
<t t-if="line['name'] not in line['ref']"><span t-esc="line['name']"/></t> |
|
|
|
|
|
<t t-if="line['ref'] not in line['name']"><span t-esc="line['ref']"/></t> |
|
|
|
|
|
</t> |
|
|
</t> |
|
|
|
|
|
<t t-if="line['name'] == '/'"> |
|
|
|
|
|
<span t-esc="line['ref']"/> |
|
|
</t> |
|
|
</t> |
|
|
<t t-if="line['name'] == '/'"><span t-esc="line['ref']"/></t> |
|
|
|
|
|
</td> |
|
|
</td> |
|
|
<td class="text-right" style="border-right: 1px solid black; background-color: grey;"> |
|
|
|
|
|
<span t-esc="line['amount']" t-esc-options='{"widget": "monetary", "display_currency": "currency"}'/> |
|
|
|
|
|
|
|
|
<td class="amount"> |
|
|
|
|
|
<span t-esc="line['amount']" |
|
|
|
|
|
t-options="{'widget': 'monetary', 'display_currency': currency}"/> |
|
|
</td> |
|
|
</td> |
|
|
<td class="text-right" style="border-right: 1px solid black; background-color: grey;"> |
|
|
|
|
|
<span t-esc="line['open_amount']" t-esc-options='{"widget": "monetary", "display_currency": "currency"}'/> |
|
|
|
|
|
|
|
|
<td class="amount"> |
|
|
|
|
|
<span t-esc="line['open_amount']" |
|
|
|
|
|
t-options="{'widget': 'monetary', 'display_currency': currency}"/> |
|
|
</td> |
|
|
</td> |
|
|
<td class="text-right" style="border-right: 1px solid black; background-color: grey;"> |
|
|
|
|
|
<span t-esc="line['balance']" t-esc-options='{"widget": "monetary", "display_currency": "currency"}'/> |
|
|
|
|
|
|
|
|
<td class="amount"> |
|
|
|
|
|
<span t-esc="line['balance']" |
|
|
|
|
|
t-options="{'widget': 'monetary', 'display_currency': currency}"/> |
|
|
</td> |
|
|
</td> |
|
|
</t> |
|
|
|
|
|
</tr> |
|
|
</tr> |
|
|
<tr> |
|
|
<tr> |
|
|
<td style="border-right: 1px solid black;"/> |
|
|
|
|
|
<td style="border-right: 1px solid black;"> |
|
|
|
|
|
|
|
|
<td/> |
|
|
|
|
|
<td> |
|
|
<span t-esc="Date_end[o.id]"/> |
|
|
<span t-esc="Date_end[o.id]"/> |
|
|
</td> |
|
|
</td> |
|
|
<td style="border-right: 1px solid black;"/> |
|
|
|
|
|
<td style="border-right: 1px solid black;"> |
|
|
|
|
|
|
|
|
<td/> |
|
|
|
|
|
<td> |
|
|
Ending Balance |
|
|
Ending Balance |
|
|
</td> |
|
|
</td> |
|
|
<td style="border-right: 1px solid black;"/> |
|
|
|
|
|
<td style="border-right: 1px solid black;"/> |
|
|
|
|
|
<td class="text-right" style="border-right: 1px solid black;"> |
|
|
|
|
|
<span t-esc="Amount_Due[o.id][currency]" t-esc-options='{"widget": "monetary", "display_currency": "currency"}'/> |
|
|
|
|
|
|
|
|
<td/> |
|
|
|
|
|
<td/> |
|
|
|
|
|
<td class="amount"> |
|
|
|
|
|
<span t-esc="Amount_Due[o.id][currency]" |
|
|
|
|
|
t-options="{'widget': 'monetary', 'display_currency': currency}"/> |
|
|
</td> |
|
|
</td> |
|
|
</tr> |
|
|
</tr> |
|
|
</table> |
|
|
</table> |
|
|
<p> |
|
|
<p> |
|
|
Aging Report at <span t-esc="Date_end[o.id]"/> in <span t-esc="Currencies[o.id][currency].name"/>: |
|
|
Aging Report at <span t-esc="Date_end[o.id]"/> in <span t-esc="Currencies[o.id][currency].name"/>: |
|
|
</p> |
|
|
</p> |
|
|
<table class="table table-condensed" t-if="Show_Buckets" style="border: 1px solid black; border-collapse: collapse;"> |
|
|
|
|
|
|
|
|
<table class="table table-condensed table-statement" t-if="Show_Buckets"> |
|
|
<thead> |
|
|
<thead> |
|
|
<tr> |
|
|
<tr> |
|
|
<th class="text-center" style="border-right: 1px solid black;">Current Due</th> |
|
|
|
|
|
<th class="text-center" style="border-right: 1px solid black;">1-30 Days Due</th> |
|
|
|
|
|
<th class="text-center" style="border-right: 1px solid black;">30-60 Days Due</th> |
|
|
|
|
|
<th class="text-center" style="border-right: 1px solid black;">60-90 Days Due</th> |
|
|
|
|
|
<th class="text-center" style="border-right: 1px solid black;">90-120 Days Due</th> |
|
|
|
|
|
<th class="text-center" style="border-right: 1px solid black;">+120 Days Due</th> |
|
|
|
|
|
<th class="text-right" style="border-right: 1px solid black;">Balance Due</th> |
|
|
|
|
|
|
|
|
<th class="amount">Current Due</th> |
|
|
|
|
|
<th class="amount">1-30 Days</th> |
|
|
|
|
|
<th class="amount">30-60 Days</th> |
|
|
|
|
|
<th class="amount">60-90 Days</th> |
|
|
|
|
|
<th class="amount">90-120 Days</th> |
|
|
|
|
|
<th class="amount">+120 Days</th> |
|
|
|
|
|
<th class="amount">Balance Due</th> |
|
|
</tr> |
|
|
</tr> |
|
|
</thead> |
|
|
</thead> |
|
|
<tr t-if="currency in Buckets[o.id]"> |
|
|
|
|
|
<td class="text-right" style="border-right: 1px solid black;"> |
|
|
|
|
|
<span t-esc="Buckets[o.id][currency]['current']" t-esc-options='{"widget": "monetary", "display_currency": "currency"}'/> |
|
|
|
|
|
</td> |
|
|
|
|
|
<td class="text-right" style="border-right: 1px solid black;"> |
|
|
|
|
|
<span t-esc="Buckets[o.id][currency]['b_1_30']" t-esc-options='{"widget": "monetary", "display_currency": "currency"}'/> |
|
|
|
|
|
</td> |
|
|
|
|
|
<td class="text-right" style="border-right: 1px solid black;"> |
|
|
|
|
|
<span t-esc="Buckets[o.id][currency]['b_30_60']" t-esc-options='{"widget": "monetary", "display_currency": "currency"}'/> |
|
|
|
|
|
</td> |
|
|
|
|
|
<td class="text-right" style="border-right: 1px solid black;"> |
|
|
|
|
|
<span t-esc="Buckets[o.id][currency]['b_60_90']" t-esc-options='{"widget": "monetary", "display_currency": "currency"}'/> |
|
|
|
|
|
</td> |
|
|
|
|
|
<td class="text-right" style="border-right: 1px solid black;"> |
|
|
|
|
|
<span t-esc="Buckets[o.id][currency]['b_90_120']" t-esc-options='{"widget": "monetary", "display_currency": "currency"}'/> |
|
|
|
|
|
</td> |
|
|
|
|
|
<td class="text-right" style="border-right: 1px solid black;"> |
|
|
|
|
|
<span t-esc="Buckets[o.id][currency]['b_over_120']" t-esc-options='{"widget": "monetary", "display_currency": "currency"}'/> |
|
|
|
|
|
</td> |
|
|
|
|
|
<td class="text-right" style="border-right: 1px solid black;"> |
|
|
|
|
|
<span t-esc="Buckets[o.id][currency]['balance']" t-esc-options='{"widget": "monetary", "display_currency": "currency"}'/> |
|
|
|
|
|
</td> |
|
|
|
|
|
</tr> |
|
|
|
|
|
<tr t-if="currency not in Buckets[o.id]"> |
|
|
|
|
|
<td class="text-right" style="border-right: 1px solid black;"> |
|
|
|
|
|
<span t-esc="0.0" t-esc-options='{"widget": "monetary", "display_currency": "currency"}'/> |
|
|
|
|
|
|
|
|
<t t-set="buckets" t-value="Buckets[o.id].get(currency, {})"/> |
|
|
|
|
|
<tbody> |
|
|
|
|
|
<tr> |
|
|
|
|
|
<td class="amount"> |
|
|
|
|
|
<span t-esc="buckets.get('current', 0.0)" |
|
|
|
|
|
t-options="{'widget': 'monetary', 'display_currency': currency}"/> |
|
|
</td> |
|
|
</td> |
|
|
<td class="text-right" style="border-right: 1px solid black;"> |
|
|
|
|
|
<span t-esc="0.0" t-esc-options='{"widget": "monetary", "display_currency": "currency"}'/> |
|
|
|
|
|
|
|
|
<td class="amount"> |
|
|
|
|
|
<span t-esc="buckets.get('b_1_30', 0.0)" |
|
|
|
|
|
t-options="{'widget': 'monetary', 'display_currency': currency}"/> |
|
|
</td> |
|
|
</td> |
|
|
<td class="text-right" style="border-right: 1px solid black;"> |
|
|
|
|
|
<span t-esc="0.0" t-esc-options='{"widget": "monetary", "display_currency": "currency"}'/> |
|
|
|
|
|
|
|
|
<td class="amount"> |
|
|
|
|
|
<span t-esc="buckets.get('b_30_60', 0.0)" |
|
|
|
|
|
t-options="{'widget': 'monetary', 'display_currency': currency}"/> |
|
|
</td> |
|
|
</td> |
|
|
<td class="text-right" style="border-right: 1px solid black;"> |
|
|
|
|
|
<span t-esc="0.0" t-esc-options='{"widget": "monetary", "display_currency": "currency"}'/> |
|
|
|
|
|
|
|
|
<td class="amount"> |
|
|
|
|
|
<span t-esc="buckets.get('b_60_90', 0.0)" |
|
|
|
|
|
t-options="{'widget': 'monetary', 'display_currency': currency}"/> |
|
|
</td> |
|
|
</td> |
|
|
<td class="text-right" style="border-right: 1px solid black;"> |
|
|
|
|
|
<span t-esc="0.0" t-esc-options='{"widget": "monetary", "display_currency": "currency"}'/> |
|
|
|
|
|
|
|
|
<td class="amount"> |
|
|
|
|
|
<span t-esc="buckets.get('b_90_120', 0.0)" |
|
|
|
|
|
t-options="{'widget': 'monetary', 'display_currency': currency}"/> |
|
|
</td> |
|
|
</td> |
|
|
<td class="text-right" style="border-right: 1px solid black;"> |
|
|
|
|
|
<span t-esc="0.0" t-esc-options='{"widget": "monetary", "display_currency": "currency"}'/> |
|
|
|
|
|
|
|
|
<td class="amount"> |
|
|
|
|
|
<span t-esc="buckets.get('b_over_120', 0.0)" |
|
|
|
|
|
t-options="{'widget': 'monetary', 'display_currency': currency}"/> |
|
|
</td> |
|
|
</td> |
|
|
<td class="text-right" style="border-right: 1px solid black;"> |
|
|
|
|
|
<span t-esc="0.0" t-esc-options='{"widget": "monetary", "display_currency": "currency"}'/> |
|
|
|
|
|
|
|
|
<td class="amount"> |
|
|
|
|
|
<span t-esc="buckets.get('balance', 0.0)" |
|
|
|
|
|
t-options="{'widget': 'monetary', 'display_currency': currency}"/> |
|
|
</td> |
|
|
</td> |
|
|
</tr> |
|
|
</tr> |
|
|
|
|
|
</tbody> |
|
|
</table> |
|
|
</table> |
|
|
</t> |
|
|
</t> |
|
|
</t> |
|
|
</t> |
|
@ -205,7 +183,7 @@ |
|
|
model="res.partner" |
|
|
model="res.partner" |
|
|
report_type="qweb-pdf" |
|
|
report_type="qweb-pdf" |
|
|
menu="False" |
|
|
menu="False" |
|
|
string="Statement Action to PDF" |
|
|
|
|
|
|
|
|
string="Outstanding Statement" |
|
|
name="customer_outstanding_statement.statement" |
|
|
name="customer_outstanding_statement.statement" |
|
|
file="customer_outstanding_statement.statement" |
|
|
file="customer_outstanding_statement.statement" |
|
|
/> |
|
|
/> |
|
|