Odoo18-Base/addons/hr_expense/report/hr_expense_report.xml
2025-03-10 11:12:23 +07:00

114 lines
6.0 KiB
XML

<?xml version="1.0" encoding="utf-8"?>
<odoo>
<template id="report_expense_sheet">
<t t-call="web.html_container">
<t t-foreach="docs" t-as="o">
<t t-call="web.external_layout">
<div class="page">
<h2>Expenses Report</h2>
<div class="row mt32 mb32">
<div class="col-2">
<strong>Employee:</strong>
<p t-field="o.employee_id.name"/>
</div>
<div class="col-2">
<strong>Date:</strong>
<p t-field="o.accounting_date"/>
</div>
<div class="col-3">
<strong>Description:</strong>
<p t-field="o.name"/>
</div>
<div class="col-2">
<strong>Validated By:</strong>
<p t-field="o.user_id"/>
</div>
<div class="col-3">
<strong>Payment By:</strong>
<p t-field="o.payment_mode"/>
</div>
</div>
<table class="table table-sm">
<thead>
<tr>
<th>Date</th>
<th>Name</th>
<th class="text-center">Ref.</th>
<th>Unit Price</th>
<th>Taxes</th>
<th class="text-center">Qty</th>
<th class="text-end">Price</th>
<th t-if="o.is_multiple_currency" class="text-end">Price in Company Currency</th>
</tr>
</thead>
<tbody>
<tr t-foreach="o.expense_line_ids" t-as="line">
<td><span t-field="line.date"/></td>
<td>
<span t-field="line.name"/>
<span t-field="line.description"/><br/>
<span>
<div t-foreach="line.analytic_distribution" t-as="distribution">
<t t-esc="line.env['account.analytic.account'].browse(int(distribution))[0].name"/>: <t t-esc="line.analytic_distribution.get(distribution)"/>
</div>
</span>
</td>
<td style="text-center">
<span t-field="line.reference"/>
</td>
<td>
<span t-field="line.unit_amount"/>
</td>
<t t-set="taxes" t-value="', '.join([(tax.description or tax.name) for tax in line.tax_ids])"/>
<td t-attf-class="text-end {{ 'text-nowrap' if len(taxes) &lt; 10 else '' }}">
<span t-out="taxes" id="line_tax_ids">Tax 15%</span>
</td>
<td class="text-center">
<span t-field="line.quantity"/>
</td>
<td class="text-end">
<span t-field="line.total_amount"
t-options='{"widget": "monetary", "display_currency": line.currency_id}'/>
</td>
<td t-if="o.is_multiple_currency" class="text-end">
<span t-field="line.total_amount_company"/>
</td>
</tr>
</tbody>
</table>
<div class="row justify-content-end">
<div class="col-4">
<table class="table table-sm">
<tr class="border-black">
<td><strong>Total</strong></td>
<td class="text-end">
<span t-field="o.total_amount"
t-options='{"widget": "monetary", "display_currency": o.currency_id}'/>
</td>
</tr>
</table>
</div>
</div>
<p>Certified honest and conform,<br/>(Date and signature).<br/><br/></p>
</div>
</t>
</t>
</t>
</template>
<record id="action_report_hr_expense_sheet" model="ir.actions.report">
<field name="name">Expenses Report</field>
<field name="model">hr.expense.sheet</field>
<field name="report_type">qweb-pdf</field>
<field name="report_name">hr_expense.report_expense_sheet</field>
<field name="report_file">hr_expense.report_expense_sheet</field>
<field name="print_report_name">'Expenses - %s - %s' % (object.employee_id.name, (object.name).replace('/', ''))</field>
<field name="binding_model_id" ref="model_hr_expense_sheet"/>
<field name="binding_type">report</field>
</record>
</odoo>