Fine tuning hr_expense_usability

This commit is contained in:
Alexis de Lattre
2017-06-08 00:53:39 +02:00
parent 1d765aa4f7
commit aca7911d81
8 changed files with 285 additions and 315 deletions

View File

@@ -1,3 +1,4 @@
# -*- coding: utf-8 -*- # -*- coding: utf-8 -*-
from . import hr_expense from . import hr_expense
from .post_install import create_private_car_expense_products

View File

@@ -13,16 +13,16 @@
'author': 'Akretion', 'author': 'Akretion',
'website': 'http://www.akretion.com', 'website': 'http://www.akretion.com',
'depends': [ 'depends': [
'hr_expense',
'hr_expense_sequence', 'hr_expense_sequence',
], ],
'data': [ 'data': [
'private_car_data.xml',
'hr_employee_view.xml', 'hr_employee_view.xml',
'hr_expense_view.xml', 'hr_expense_view.xml',
'product_view.xml', 'product_view.xml',
'hr_expense_data.xml',
'security/expense_security.xml', 'security/expense_security.xml',
], ],
'post_init_hook': 'create_private_car_expense_products',
'demo': ['private_car_demo.xml'], 'demo': ['private_car_demo.xml'],
'installable': True, 'installable': True,
} }

View File

@@ -6,6 +6,7 @@
from odoo import models, fields, api, _ from odoo import models, fields, api, _
from odoo.exceptions import UserError, ValidationError from odoo.exceptions import UserError, ValidationError
from odoo.tools import float_compare, float_is_zero from odoo.tools import float_compare, float_is_zero
import odoo.addons.decimal_precision as dp
# I had to choose between several ideas when I developped this module : # I had to choose between several ideas when I developped this module :
@@ -20,14 +21,14 @@ from odoo.tools import float_compare, float_is_zero
# Idea : we create only one "private car expense" product, and we # Idea : we create only one "private car expense" product, and we
# create a new object to store the price depending on the CV, etc... # create a new object to store the price depending on the CV, etc...
# Drawback : need to create a new object # Drawback : need to create a new object
# => that's what is implemented in this module
# 3) single generic "My private car" product selectable by the user ; # 3) single generic "My private car" product selectable by the user ;
# several specific private car products NOT selectable by the user # several specific private car products NOT selectable by the user
# Idea : When the user selects the generic "My private car" product, # Idea : When the user selects the generic "My private car" product,
# it is automatically replaced by the specific one via the on_change # it is automatically replaced by the specific one via the on_change
# Drawback : none ? :) # Drawback : decimal precision 'Product Price' on standard_price of product
# => that's what is implemented in this module # (but we need 3)
class ProductTemplate(models.Model): class ProductTemplate(models.Model):
_inherit = 'product.template' _inherit = 'product.template'
@@ -140,7 +141,6 @@ class HrEmployee(models.Model):
_inherit = 'hr.employee' _inherit = 'hr.employee'
def compute_private_car_total_km_this_year(self): def compute_private_car_total_km_this_year(self):
print "compute_private_car_total_km_this_year self=", self
res = {} res = {}
private_car_products = self.env['product.product'].search( private_car_products = self.env['product.product'].search(
[('private_car_expense_ok', '=', True)]) [('private_car_expense_ok', '=', True)])
@@ -180,6 +180,25 @@ class HrEmployee(models.Model):
"employee is compatible with the number of kilometers " "employee is compatible with the number of kilometers "
"reimbursed to this employee during the civil year.") "reimbursed to this employee during the civil year.")
def _get_accounting_partner_from_employee(self):
# By default, odoo uses self.employee_id.address_home_id
# which users usually don't configure
# (even demo data doesn't bother to set it...)
# So I decided to put a fallback on employee.user_id.partner_id
self.ensure_one()
if self.address_home_id:
partner = self.address_home_id.commercial_partner_id
elif self.user_id:
# We don't use "commercial partner" here...
partner = self.user_id.partner_id
else:
raise UserError(_(
"The employee '%s' doesn't have a Home Address and isn't "
"linked to an Odoo user. You have to set one of these two "
"fields on the employee form in order to get a partner from "
"the employee for the Journal Items.") % self.display_name)
return partner
class HrExpense(models.Model): class HrExpense(models.Model):
_inherit = 'hr.expense' _inherit = 'hr.expense'
@@ -188,6 +207,9 @@ class HrExpense(models.Model):
date = fields.Date(track_visibility='onchange', required=True) date = fields.Date(track_visibility='onchange', required=True)
currency_id = fields.Many2one(track_visibility='onchange', required=True) currency_id = fields.Many2one(track_visibility='onchange', required=True)
total_amount = fields.Float(track_visibility='onchange') total_amount = fields.Float(track_visibility='onchange')
# I want a specific precision for unit_amount of expense
# main reason is KM cost which is 3 by default
unit_amount = fields.Float(digits=dp.get_precision('Expense Unit Price'))
private_car_plate = fields.Char( private_car_plate = fields.Char(
string='Private Car Plate', size=32, track_visibility='onchange', string='Private Car Plate', size=32, track_visibility='onchange',
readonly=True, states={'draft': [('readonly', False)]}) readonly=True, states={'draft': [('readonly', False)]})
@@ -276,7 +298,8 @@ class HrExpense(models.Model):
if self.product_id.private_car_expense_ok: if self.product_id.private_car_expense_ok:
original_unit_amount = self.product_id.price_compute( original_unit_amount = self.product_id.price_compute(
'standard_price')[self.product_id.id] 'standard_price')[self.product_id.id]
prec = self.env['decimal.precision'].precision_get('Product Price') prec = self.env['decimal.precision'].precision_get(
'Expense Unit Price')
if float_compare( if float_compare(
original_unit_amount, self.unit_amount, original_unit_amount, self.unit_amount,
precision_digits=prec): precision_digits=prec):
@@ -308,7 +331,8 @@ class HrExpense(models.Model):
return res return res
@api.constrains( @api.constrains(
'product_id', 'private_car_plate', 'payment_mode', 'tax_ids') 'product_id', 'private_car_plate', 'payment_mode', 'tax_ids',
'untaxed_amount_usability', 'tax_amount', 'quantity', 'unit_amount')
def _check_expense(self): def _check_expense(self):
generic_private_car_product = self.env.ref( generic_private_car_product = self.env.ref(
'hr_expense_usability.generic_private_car_expense') 'hr_expense_usability.generic_private_car_expense')
@@ -374,7 +398,38 @@ class HrExpense(models.Model):
"The amount tax of expense '%s' is %s, " "The amount tax of expense '%s' is %s, "
"but no tax is selected.") "but no tax is selected.")
% (exp.name, exp.tax_amount)) % (exp.name, exp.tax_amount))
# TODO: check all have the same sign sign = {
'untaxed_amount_usability': 0,
'tax_amount': 0,
'total_amount': 0,
}
for field_name in sign.iterkeys():
sign[field_name] = float_compare(
exp[field_name], 0, precision_rounding=prec)
if (
sign['total_amount'] < 0 and (
sign['untaxed_amount_usability'] > 0 or
sign['tax_amount'] > 0)):
raise ValidationError(_(
"On the expense '%s', the total amount (%s) is "
"negative, so the untaxed amount (%s) and the "
"tax amount (%s) should be negative or null.") % (
exp.name,
exp.total_amount,
exp.untaxed_amount_usability,
exp.tax_amount))
if (
sign['total_amount'] > 0 and (
sign['untaxed_amount_usability'] < 0 or
sign['tax_amount'] < 0)):
raise ValidationError(_(
"On the expense '%s', the total amount (%s) is "
"positive, so the untaxed amount (%s) and the "
"tax amount (%s) should be positive or null.") % (
exp.name,
exp.total_amount,
exp.untaxed_amount_usability,
exp.tax_amount))
def action_move_create(self): def action_move_create(self):
'''disable account.move creation per hr.expense''' '''disable account.move creation per hr.expense'''
@@ -419,12 +474,19 @@ class HrExpenseSheet(models.Model):
sheet.untaxed_amount_company_currency = untaxed sheet.untaxed_amount_company_currency = untaxed
sheet.tax_amount_company_currency = total - untaxed sheet.tax_amount_company_currency = total - untaxed
@api.one
@api.constrains('expense_line_ids')
def _check_amounts(self):
'''Remove the constraint 'You cannot have a positive and negative
amounts on the same expense report.' '''
return True
def _prepare_move(self): def _prepare_move(self):
self.ensure_one() self.ensure_one()
if not self.journal_id: if not self.journal_id:
raise UserError(_( raise UserError(_(
"No journal selected for expense report %s.") "No journal selected for expense report %s.")
% self.number) % self.display_name)
date = self.accounting_date or fields.Date.context_today(self) date = self.accounting_date or fields.Date.context_today(self)
vals = { vals = {
'journal_id': self.journal_id.id, 'journal_id': self.journal_id.id,
@@ -437,35 +499,28 @@ class HrExpenseSheet(models.Model):
def _prepare_payable_move_line(self, total_company_currency): def _prepare_payable_move_line(self, total_company_currency):
self.ensure_one() self.ensure_one()
debit = credit = 0.0 debit = credit = False
prec = self.company_id.currency_id.rounding prec = self.company_id.currency_id.rounding
if float_compare( if float_compare(
total_company_currency, 0, precision_rounding=prec) > 0: total_company_currency, 0, precision_rounding=prec) > 0:
credit = total_company_currency credit = total_company_currency
else: else:
debit = total_company_currency * -1 debit = total_company_currency * -1
if not self.employee_id.address_home_id: partner = self.employee_id._get_accounting_partner_from_employee()
raise UserError(_(
"The employee '%s' doesn't have a Home Address. "
"The partner selected as 'Home Address' on the employee "
"will be used as the partner for the accounting entry.")
% (self.employee_id.display_name))
partner = self.employee_id.address_home_id
# by default date_maturity = move date # by default date_maturity = move date
vals = { vals = {
'account_id': partner.property_account_payable_id.id, 'account_id': partner.property_account_payable_id.id,
'partner_id': partner.id, 'partner_id': partner.id,
'name': self.name[:60], 'name': self.name[:64],
'credit': credit, 'credit': credit,
'debit': debit, 'debit': debit,
} }
return vals return vals
# TODO: set tax properties for those who use them
def _prepare_expense_move_lines(self): def _prepare_expense_move_lines(self):
self.ensure_one() self.ensure_one()
mlines = [] mlines = []
partner_id = self.employee_id.address_home_id.id partner = self.employee_id._get_accounting_partner_from_employee()
prec = self.company_id.currency_id.rounding prec = self.company_id.currency_id.rounding
for exp in self.expense_line_ids: for exp in self.expense_line_ids:
# Expense # Expense
@@ -482,7 +537,7 @@ class HrExpenseSheet(models.Model):
exp.product_id.categ_id.display_name)) exp.product_id.categ_id.display_name))
mlines.append({ mlines.append({
'type': 'expense', 'type': 'expense',
'partner_id': partner_id, 'partner_id': partner.id,
'account_id': account.id, 'account_id': account.id,
'analytic_account_id': exp.analytic_account_id.id or False, 'analytic_account_id': exp.analytic_account_id.id or False,
'amount': exp.untaxed_amount_company_currency, 'amount': exp.untaxed_amount_company_currency,
@@ -503,7 +558,7 @@ class HrExpenseSheet(models.Model):
analytic_account_id = False analytic_account_id = False
mlines.append({ mlines.append({
'type': 'tax', 'type': 'tax',
'partner_id': partner_id, 'partner_id': partner.id,
'account_id': tax_account_id, 'account_id': tax_account_id,
'analytic_account_id': analytic_account_id, 'analytic_account_id': analytic_account_id,
'amount': exp.tax_amount_company_currency, 'amount': exp.tax_amount_company_currency,
@@ -525,15 +580,14 @@ class HrExpenseSheet(models.Model):
key = (False, False, False, i) key = (False, False, False, i)
if key in group_mlines: if key in group_mlines:
group_mlines[key]['amount'] += mline['amount'] group_mlines[key]['amount'] += mline['amount']
group_mlines[key]['name'] = '%s %s' % ( group_mlines[key]['name'] = self.name[:64]
self.number, self.name[:60])
else: else:
group_mlines[key] = mline group_mlines[key] = mline
res_mlines = [] res_mlines = []
total_cc = 0.0 total_cc = 0.0
for gmlines in group_mlines.itervalues(): for gmlines in group_mlines.itervalues():
total_cc += gmlines['amount'] total_cc += gmlines['amount']
credit = debit = 0.0 credit = debit = False
cmp_amount = float_compare( cmp_amount = float_compare(
gmlines['amount'], 0, precision_rounding=prec) gmlines['amount'], 0, precision_rounding=prec)
if cmp_amount > 0: if cmp_amount > 0:
@@ -585,5 +639,5 @@ class HrExpenseSheet(models.Model):
return vals return vals
# TODO: for multi-company with expenses envir., we would need a field # TODO: for multi-company with expenses envir., we would need a field
# 'default_expense_journal' on company # 'default_expense_journal' on company (otherwise, it takes the
# TODO: test if state => paid(done) when reconciled via bank statement... # first purchase journal, which is probably not the good one

View File

@@ -0,0 +1,34 @@
<?xml version="1.0" encoding="utf-8"?>
<!--
© 2014-2017 Akretion (http://www.akretion.com)
@author: Alexis de Lattre <alexis.delattre@akretion.com>
License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
-->
<odoo noupdate="1">
<record id="generic_private_car_expense" model="product.product">
<field name="name">My Private Car Expense (in km)</field>
<field name="default_code">PrivateCarExp</field>
<field name="categ_id" ref="hr_expense.cat_expense"/>
<field name="sale_ok" eval="False"/>
<field name="purchase_ok" eval="False"/>
<field name="can_be_expensed" eval="True"/>
<field name="type">service</field>
<field name="list_price">0</field>
<field name="uom_id" ref="product.product_uom_km"/>
<field name="uom_po_id" ref="product.product_uom_km"/>
<field name="taxes_id" eval="False"/>
<field name="supplier_taxes_id" eval="False"/>
</record>
<!-- KM cost is decimal precision = 3
but decimal precision 'Product Price' is 2 by default,
and companies may not want to change it -->
<record forcecreate="True" id="decimal_price" model="decimal.precision">
<field name="name">Expense Unit Price</field>
<field name="digits">3</field>
</record>
</odoo>

View File

@@ -57,6 +57,36 @@
</field> </field>
</record> </record>
<record id="hr_expense_view_pivot" model="ir.ui.view">
<field name="name">usability.hr.expense.pivot</field>
<field name="model">hr.expense</field>
<field name="inherit_id" ref="hr_expense.hr_expense_view_pivot"/>
<field name="arch" type="xml">
<field name="total_amount" position="replace">
<field name="total_amount_company_currency" type="measure"/>
</field>
<field name="create_date" position="replace">
<field name="date" interval="month" type="col"/>
</field>
</field>
</record>
<record id="hr_expense_view_graph" model="ir.ui.view">
<field name="name">usability.hr.expense.graph</field>
<field name="model">hr.expense</field>
<field name="inherit_id" ref="hr_expense.hr_expense_view_graph"/>
<field name="arch" type="xml">
<field name="total_amount" position="replace">
<field name="total_amount_company_currency" type="measure"/>
</field>
<field name="create_date" position="replace">
<field name="date" interval="month" type="col"/>
</field>
</field>
</record>
<record id="view_hr_expense_sheet_form" model="ir.ui.view"> <record id="view_hr_expense_sheet_form" model="ir.ui.view">
<field name="name">usability.hr.expense.sheet.form</field> <field name="name">usability.hr.expense.sheet.form</field>
<field name="model">hr.expense.sheet</field> <field name="model">hr.expense.sheet</field>
@@ -75,11 +105,15 @@
<field name="currency_id" invisible="1"/> <field name="currency_id" invisible="1"/>
<field name="company_currency_id" invisible="1"/> <field name="company_currency_id" invisible="1"/>
<field name="untaxed_amount_company_currency" sum="Untaxed Total"/> <field name="untaxed_amount_company_currency" sum="Untaxed Total"/>
<field name="tax_amount_company_currency" sum="Tax Total"/>
<field name="total_amount_company_currency" sum="Total"/> <field name="total_amount_company_currency" sum="Total"/>
</xpath> </xpath>
<xpath expr="//field[@name='expense_line_ids']/tree/field[@name='total_amount']" position="attributes"> <xpath expr="//field[@name='expense_line_ids']/tree/field[@name='total_amount']" position="attributes">
<attribute name="sum"></attribute> <attribute name="sum"></attribute>
</xpath> </xpath>
<xpath expr="//field[@name='expense_line_ids']/tree/field[@name='analytic_account_id']" position="before">
<field name="account_id" groups="account.group_account_user"/>
</xpath>
<field name="account_move_id" position="attributes"> <field name="account_move_id" position="attributes">
<attribute name="invisible">0</attribute> <attribute name="invisible">0</attribute>
<attribute name="groups">account.group_account_user</attribute> <attribute name="groups">account.group_account_user</attribute>
@@ -111,5 +145,27 @@
</field> </field>
</record> </record>
<record id="view_hr_expense_sheet_pivot" model="ir.ui.view">
<field name="name">usability.hr.expense.sheet.pivot</field>
<field name="model">hr.expense.sheet</field>
<field name="inherit_id" ref="hr_expense.view_hr_expense_sheet_pivot"/>
<field name="arch" type="xml">
<field name="total_amount" position="replace">
<field name="total_amount_company_currency" type="measure"/>
</field>
</field>
</record>
<record id="view_hr_expense_sheet_graph" model="ir.ui.view">
<field name="name">usability.hr.expense.sheet.graph</field>
<field name="model">hr.expense.sheet</field>
<field name="inherit_id" ref="hr_expense.view_hr_expense_sheet_graph"/>
<field name="arch" type="xml">
<field name="total_amount" position="replace">
<field name="total_amount_company_currency" type="measure"/>
</field>
</field>
</record>
</odoo> </odoo>

View File

@@ -0,0 +1,89 @@
# -*- coding: utf-8 -*-
# © 2016-2017 Akretion (Alexis de Lattre <alexis.delattre@akretion.com>)
# License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
from odoo import api, SUPERUSER_ID
PRODUCTS = {
'FR': [
{'default_code': '1-3CV_0-5000km',
'name': u"Frais kilométriques: 1-3 CV, < 5 000 km",
'cost': 0.41},
{'default_code': '4CV_0-5000km',
'name': u"Frais kilométriques: 4 CV, < 5 000 km",
'cost': 0.493},
{'default_code': '5CV_0-5000km',
'name': u"Frais kilométriques: 5 CV, < 5 000 km",
'cost': 0.543},
{'default_code': '6CV_0-5000km',
'name': u"Frais kilométriques: 6 CV, < 5 000 km",
'cost': 0.568},
{'default_code': '7+CV_0-5000km',
'name': u"Frais kilométriques: 7+ CV, < 5 000 km",
'cost': 0.595},
{'default_code': '1-3CV_5-20000km',
'name': u"Frais kilométriques: 1-3 CV, 5-20 000 km",
'cost': 0.245},
{'default_code': '4CV_5-20000km',
'name': u"Frais kilométriques: 4 CV, 5-20 000 km",
'cost': 0.277},
{'default_code': '5CV_5-20000km',
'name': u"Frais kilométriques: 5 CV, 5-20 000 km",
'cost': 0.305},
{'default_code': '6CV_5-20000km',
'name': u"Frais kilométriques: 6 CV, 5-20 000 km",
'cost': 0.32},
{'default_code': '7+CV_5-20000km',
'name': u"Frais kilométriques: 7+ CV, 5-20 000 km",
'cost': 0.337},
{'default_code': '1-3CV_+20000km',
'name': u"Frais kilométriques: 1-3 CV, > 20 000 km",
'cost': 0.245},
{'default_code': '4CV_+20000km',
'name': u"Frais kilométriques: 4 CV, > 20 000 km",
'cost': 0.277},
{'default_code': '5CV_+20000km',
'name': u"Frais kilométriques: 5 CV, > 20 000 km",
'cost': 0.305},
{'default_code': '6CV_+20000km',
'name': u"Frais kilométriques: 6 CV, > 20 000 km",
'cost': 0.32},
{'default_code': '7+CV_+20000km',
'name': u"Frais kilométriques: 7+ CV, > 20 000 km",
'cost': 0.337},
]
}
def create_private_car_expense_products(cr, registry):
with api.Environment.manage():
env = api.Environment(cr, SUPERUSER_ID, {})
companies = env['res.company'].search([])
country_codes = []
for company in companies:
company_country_code = company.country_id.code and\
company.country_id.code.upper() or False
if company_country_code not in country_codes:
country_codes.append(company_country_code)
categ_id = env.ref('hr_expense.cat_expense').id
km_uom_id = env.ref('product.product_uom_km').id
for country_code in country_codes:
if country_code in PRODUCTS:
for product in PRODUCTS[country_code]:
env['product.product'].create({
'name': product['name'],
'default_code': product.get('default_code'),
'categ_id': categ_id,
'sale_ok': False,
'purchase_ok': False,
'can_be_expensed': False,
'private_car_expense_ok': True,
'type': 'service',
'list_price': False,
'standard_price': product['cost'],
'uom_id': km_uom_id,
'uom_po_id': km_uom_id,
'taxes_id': False,
'supplier_taxes_id': False,
})
return

View File

@@ -1,281 +0,0 @@
<?xml version="1.0" encoding="utf-8"?>
<!--
© 2014-2017 Akretion (http://www.akretion.com)
@author: Alexis de Lattre <alexis.delattre@akretion.com>
License AGPL-3.0 or later (http://www.gnu.org/licenses/agpl).
-->
<odoo noupdate="1">
<record id="generic_private_car_expense" model="product.product">
<field name="name">My Private Car Expense (in km)</field>
<field name="default_code">PrivateCarExp</field>
<field name="categ_id" ref="hr_expense.cat_expense"/>
<field name="sale_ok" eval="False"/>
<field name="purchase_ok" eval="False"/>
<field name="can_be_expensed" eval="True"/>
<field name="type">service</field>
<field name="list_price">0</field>
<field name="uom_id" ref="product.product_uom_km"/>
<field name="uom_po_id" ref="product.product_uom_km"/>
<field name="taxes_id" eval="False"/>
<field name="supplier_taxes_id" eval="False"/>
</record>
<record id="1-3cv_0-5000km_private_car_expense" model="product.product">
<field name="name">1-3CV 0-5000km Private Car Expenses</field>
<field name="default_code">1-3CV/0-5000km</field>
<field name="categ_id" ref="hr_expense.cat_expense"/>
<field name="sale_ok" eval="False"/>
<field name="purchase_ok" eval="False"/>
<field name="can_be_expensed" eval="False"/>
<field name="private_car_expense_ok" eval="True"/>
<field name="type">service</field>
<field name="list_price">0</field>
<field name="standard_price">0.41</field>
<field name="uom_id" ref="product.product_uom_km"/>
<field name="uom_po_id" ref="product.product_uom_km"/>
<field name="taxes_id" eval="False"/>
<field name="supplier_taxes_id" eval="False"/>
</record>
<record id="4cv_0-5000km_private_car_expense" model="product.product">
<field name="name">4CV 0-5000km Private Car Expenses</field>
<field name="default_code">4CV/0-5000km</field>
<field name="categ_id" ref="hr_expense.cat_expense"/>
<field name="sale_ok" eval="False"/>
<field name="purchase_ok" eval="False"/>
<field name="can_be_expensed" eval="False"/>
<field name="private_car_expense_ok" eval="True"/>
<field name="type">service</field>
<field name="list_price">0</field>
<field name="standard_price">0.493</field>
<field name="uom_id" ref="product.product_uom_km"/>
<field name="uom_po_id" ref="product.product_uom_km"/>
<field name="taxes_id" eval="False"/>
<field name="supplier_taxes_id" eval="False"/>
</record>
<record id="5cv_0-5000km_private_car_expense" model="product.product">
<field name="name">5CV 0-5000km Private Car Expenses</field>
<field name="default_code">5CV/0-5000km</field>
<field name="categ_id" ref="hr_expense.cat_expense"/>
<field name="sale_ok" eval="False"/>
<field name="purchase_ok" eval="False"/>
<field name="can_be_expensed" eval="False"/>
<field name="private_car_expense_ok" eval="True"/>
<field name="type">service</field>
<field name="list_price">0</field>
<field name="standard_price">0.543</field>
<field name="uom_id" ref="product.product_uom_km"/>
<field name="uom_po_id" ref="product.product_uom_km"/>
<field name="taxes_id" eval="False"/>
<field name="supplier_taxes_id" eval="False"/>
</record>
<record id="6cv_0-5000km_private_car_expense" model="product.product">
<field name="name">6CV 0-5000km Private Car Expenses</field>
<field name="default_code">6CV/0-5000km</field>
<field name="categ_id" ref="hr_expense.cat_expense"/>
<field name="sale_ok" eval="False"/>
<field name="purchase_ok" eval="False"/>
<field name="can_be_expensed" eval="False"/>
<field name="private_car_expense_ok" eval="True"/>
<field name="type">service</field>
<field name="list_price">0</field>
<field name="standard_price">0.568</field>
<field name="uom_id" ref="product.product_uom_km"/>
<field name="uom_po_id" ref="product.product_uom_km"/>
<field name="taxes_id" eval="False"/>
<field name="supplier_taxes_id" eval="False"/>
</record>
<record id="7cv+_0-5000km_private_car_expense" model="product.product">
<field name="name">7CV+ 0-5000km Private Car Expenses</field>
<field name="default_code">7CV+/0-5000km</field>
<field name="categ_id" ref="hr_expense.cat_expense"/>
<field name="sale_ok" eval="False"/>
<field name="purchase_ok" eval="False"/>
<field name="can_be_expensed" eval="False"/>
<field name="private_car_expense_ok" eval="True"/>
<field name="type">service</field>
<field name="list_price">0</field>
<field name="standard_price">0.595</field>
<field name="uom_id" ref="product.product_uom_km"/>
<field name="uom_po_id" ref="product.product_uom_km"/>
<field name="taxes_id" eval="False"/>
<field name="supplier_taxes_id" eval="False"/>
</record>
<record id="1-3cv_5-20000km_private_car_expense" model="product.product">
<field name="name">1-3CV 5-20000km Private Car Expenses</field>
<field name="default_code">1-3CV/5-20000km</field>
<field name="categ_id" ref="hr_expense.cat_expense"/>
<field name="sale_ok" eval="False"/>
<field name="purchase_ok" eval="False"/>
<field name="can_be_expensed" eval="False"/>
<field name="private_car_expense_ok" eval="True"/>
<field name="type">service</field>
<field name="list_price">0</field>
<field name="standard_price">0.245</field>
<field name="uom_id" ref="product.product_uom_km"/>
<field name="uom_po_id" ref="product.product_uom_km"/>
<field name="taxes_id" eval="False"/>
<field name="supplier_taxes_id" eval="False"/>
</record>
<record id="4cv_5-20000km_private_car_expense" model="product.product">
<field name="name">4CV 5-20000km Private Car Expenses</field>
<field name="default_code">4CV/5-20000km</field>
<field name="categ_id" ref="hr_expense.cat_expense"/>
<field name="sale_ok" eval="False"/>
<field name="purchase_ok" eval="False"/>
<field name="can_be_expensed" eval="False"/>
<field name="private_car_expense_ok" eval="True"/>
<field name="type">service</field>
<field name="list_price">0</field>
<field name="standard_price">0.277</field>
<field name="uom_id" ref="product.product_uom_km"/>
<field name="uom_po_id" ref="product.product_uom_km"/>
<field name="taxes_id" eval="False"/>
<field name="supplier_taxes_id" eval="False"/>
</record>
<record id="5cv_5-20000km_private_car_expense" model="product.product">
<field name="name">5CV 5-20000km Private Car Expenses</field>
<field name="default_code">5CV/5-20000km</field>
<field name="categ_id" ref="hr_expense.cat_expense"/>
<field name="sale_ok" eval="False"/>
<field name="purchase_ok" eval="False"/>
<field name="can_be_expensed" eval="False"/>
<field name="private_car_expense_ok" eval="True"/>
<field name="type">service</field>
<field name="list_price">0</field>
<field name="standard_price">0.305</field>
<field name="uom_id" ref="product.product_uom_km"/>
<field name="uom_po_id" ref="product.product_uom_km"/>
<field name="taxes_id" eval="False"/>
<field name="supplier_taxes_id" eval="False"/>
</record>
<record id="6cv_5-20000km_private_car_expense" model="product.product">
<field name="name">6CV 5-20000km Private Car Expenses</field>
<field name="default_code">6CV/5-20000km</field>
<field name="categ_id" ref="hr_expense.cat_expense"/>
<field name="sale_ok" eval="False"/>
<field name="purchase_ok" eval="False"/>
<field name="can_be_expensed" eval="False"/>
<field name="private_car_expense_ok" eval="True"/>
<field name="type">service</field>
<field name="list_price">0</field>
<field name="standard_price">0.32</field>
<field name="uom_id" ref="product.product_uom_km"/>
<field name="uom_po_id" ref="product.product_uom_km"/>
<field name="taxes_id" eval="False"/>
<field name="supplier_taxes_id" eval="False"/>
</record>
<record id="7cv+_5-20000km_private_car_expense" model="product.product">
<field name="name">7CV+ 5-20000km Private Car Expenses</field>
<field name="default_code">7CV+/5-20000km</field>
<field name="categ_id" ref="hr_expense.cat_expense"/>
<field name="sale_ok" eval="False"/>
<field name="purchase_ok" eval="False"/>
<field name="can_be_expensed" eval="False"/>
<field name="private_car_expense_ok" eval="True"/>
<field name="type">service</field>
<field name="list_price">0</field>
<field name="standard_price">0.337</field>
<field name="uom_id" ref="product.product_uom_km"/>
<field name="uom_po_id" ref="product.product_uom_km"/>
<field name="taxes_id" eval="False"/>
<field name="supplier_taxes_id" eval="False"/>
</record>
<record id="1-3cv_20000km+_private_car_expense" model="product.product">
<field name="name">1-3CV 20000km+ Private Car Expenses</field>
<field name="default_code">1-3CV/20000km+</field>
<field name="categ_id" ref="hr_expense.cat_expense"/>
<field name="sale_ok" eval="False"/>
<field name="purchase_ok" eval="False"/>
<field name="can_be_expensed" eval="False"/>
<field name="private_car_expense_ok" eval="True"/>
<field name="type">service</field>
<field name="list_price">0</field>
<field name="standard_price">0.286</field>
<field name="uom_id" ref="product.product_uom_km"/>
<field name="uom_po_id" ref="product.product_uom_km"/>
<field name="taxes_id" eval="False"/>
<field name="supplier_taxes_id" eval="False"/>
</record>
<record id="4cv_20000km+_private_car_expense" model="product.product">
<field name="name">4CV 20000km+ Private Car Expenses</field>
<field name="default_code">4CV/20000km+</field>
<field name="categ_id" ref="hr_expense.cat_expense"/>
<field name="sale_ok" eval="False"/>
<field name="purchase_ok" eval="False"/>
<field name="can_be_expensed" eval="False"/>
<field name="private_car_expense_ok" eval="True"/>
<field name="type">service</field>
<field name="list_price">0</field>
<field name="standard_price">0.332</field>
<field name="uom_id" ref="product.product_uom_km"/>
<field name="uom_po_id" ref="product.product_uom_km"/>
<field name="taxes_id" eval="False"/>
<field name="supplier_taxes_id" eval="False"/>
</record>
<record id="5cv_20000km+_private_car_expense" model="product.product">
<field name="name">5CV 20000km+ Private Car Expenses</field>
<field name="default_code">5CV/20000km+</field>
<field name="categ_id" ref="hr_expense.cat_expense"/>
<field name="sale_ok" eval="False"/>
<field name="purchase_ok" eval="False"/>
<field name="can_be_expensed" eval="False"/>
<field name="private_car_expense_ok" eval="True"/>
<field name="type">service</field>
<field name="list_price">0</field>
<field name="standard_price">0.364</field>
<field name="uom_id" ref="product.product_uom_km"/>
<field name="uom_po_id" ref="product.product_uom_km"/>
<field name="taxes_id" eval="False"/>
<field name="supplier_taxes_id" eval="False"/>
</record>
<record id="6cv_20000km+_private_car_expense" model="product.product">
<field name="name">6CV 20000km+ Private Car Expenses</field>
<field name="default_code">6CV/20000km+</field>
<field name="categ_id" ref="hr_expense.cat_expense"/>
<field name="sale_ok" eval="False"/>
<field name="purchase_ok" eval="False"/>
<field name="can_be_expensed" eval="False"/>
<field name="private_car_expense_ok" eval="True"/>
<field name="type">service</field>
<field name="list_price">0</field>
<field name="standard_price">0.382</field>
<field name="uom_id" ref="product.product_uom_km"/>
<field name="uom_po_id" ref="product.product_uom_km"/>
<field name="taxes_id" eval="False"/>
<field name="supplier_taxes_id" eval="False"/>
</record>
<record id="7cv+_20000km+_private_car_expense" model="product.product">
<field name="name">7CV+ 20000km+ Private Car Expenses</field>
<field name="default_code">7CV+/20000km+</field>
<field name="categ_id" ref="hr_expense.cat_expense"/>
<field name="sale_ok" eval="False"/>
<field name="purchase_ok" eval="False"/>
<field name="can_be_expensed" eval="False"/>
<field name="private_car_expense_ok" eval="True"/>
<field name="type">service</field>
<field name="list_price">0</field>
<field name="standard_price">0.401</field>
<field name="uom_id" ref="product.product_uom_km"/>
<field name="uom_po_id" ref="product.product_uom_km"/>
<field name="taxes_id" eval="False"/>
<field name="supplier_taxes_id" eval="False"/>
</record>
</odoo>

View File

@@ -7,24 +7,41 @@
<odoo noupdate="1"> <odoo noupdate="1">
<record id="demo_private_car_expense" model="product.product">
<field name="name">1-2CV 0-12000km Private Car Expenses</field>
<field name="default_code">1-2CV/0-12000km</field>
<field name="categ_id" ref="hr_expense.cat_expense"/>
<field name="sale_ok" eval="False"/>
<field name="purchase_ok" eval="False"/>
<field name="can_be_expensed" eval="False"/>
<field name="private_car_expense_ok" eval="True"/>
<field name="type">service</field>
<field name="list_price">0</field>
<field name="standard_price">0.42</field>
<field name="uom_id" ref="product.product_uom_km"/>
<field name="uom_po_id" ref="product.product_uom_km"/>
<field name="taxes_id" eval="False"/>
<field name="supplier_taxes_id" eval="False"/>
</record>
<record id="hr.employee_root" model="hr.employee"> <record id="hr.employee_root" model="hr.employee">
<field name="private_car_plate">OD 4212 OO</field> <field name="private_car_plate">OD 4212 OO</field>
<field name="private_car_product_id" ref="5cv_0-5000km_private_car_expense"/> <field name="private_car_product_id" ref="demo_private_car_expense"/>
</record> </record>
<record id="hr.employee_mit" model="hr.employee"> <record id="hr.employee_mit" model="hr.employee">
<field name="private_car_plate">OE 1234 EO</field> <field name="private_car_plate">OE 1234 EO</field>
<field name="private_car_product_id" ref="6cv_0-5000km_private_car_expense"/> <field name="private_car_product_id" ref="demo_private_car_expense"/>
</record> </record>
<record id="hr.employee_al" model="hr.employee"> <record id="hr.employee_al" model="hr.employee">
<field name="private_car_plate">BE 6543 AL</field> <field name="private_car_plate">BE 6543 AL</field>
<field name="private_car_product_id" ref="4cv_0-5000km_private_car_expense"/> <field name="private_car_product_id" ref="demo_private_car_expense"/>
</record> </record>
<record id="hr.employee_qdp" model="hr.employee"> <record id="hr.employee_qdp" model="hr.employee">
<field name="private_car_plate">BE 1235 QD</field> <field name="private_car_plate">BE 1235 QD</field>
<field name="private_car_product_id" ref="4cv_0-5000km_private_car_expense"/> <field name="private_car_product_id" ref="demo_private_car_expense"/>
</record> </record>
</odoo> </odoo>