Odoo has special support for monetary values related to a currency. Let's see how to use it in a Model.
We will reuse the my_module
addon module from Chapter 3, Creating Odoo Modules.
The monetary field needs a complementary currency field to store the currency for the amounts.
The my_module
already has a models/library_book.py
defining a basic Model. We will edit this to add the needed fields:
class LibraryBook(models.Model): # ... currency_id = fields.Many2one( 'res.currency', string='Currency')
class LibraryBook(models.Model): # ... retail_price = fields.Monetary( 'Retail Price', # optional: currency_field='currency_id', )
Now, upgrade the addon module, and the new fields should be available in the Model. They won't be visible in views until they are added to them, but we can confirm their addition by inspecting the Model fields in Settings | Technical | Database Structure | Models.
Monetary fields are similar to Float fields, but Odoo is able to represent them correctly in the user interface since it knows what their currency is through a second field for that purpose.
This currency field is expected to be named currency_id
, but we can use whatever field name we like as long as it is indicated using the currency_field
optional parameter. You might like to know that the decimal precision for the amount is taken from the currency definition (the decimal_precision
field of the res.currency
model).
3.144.41.229