30 lines
1.2 KiB
Python
30 lines
1.2 KiB
Python
from odoo import api, fields, models
|
|
|
|
|
|
class ResCurrencyRate(models.Model):
|
|
_inherit = "res.currency.rate"
|
|
|
|
@api.model
|
|
def _get_rate_for_spreadsheet(self, currency_from_code, currency_to_code, date=None):
|
|
if not currency_from_code or not currency_to_code:
|
|
return False
|
|
Currency = self.env["res.currency"].with_context({"active_test": False})
|
|
currency_from = Currency.search([("name", "=", currency_from_code)])
|
|
currency_to = Currency.search([("name", "=", currency_to_code)])
|
|
if not currency_from or not currency_to:
|
|
return False
|
|
company = self.env.company
|
|
date = fields.Date.from_string(date) if date else fields.Date.context_today(self)
|
|
return Currency._get_conversion_rate(currency_from, currency_to, company, date)
|
|
|
|
@api.model
|
|
def get_rates_for_spreadsheet(self, requests):
|
|
result = []
|
|
for request in requests:
|
|
record = request.copy()
|
|
record.update({
|
|
"rate": self._get_rate_for_spreadsheet(request["from"], request["to"], request.get("date")),
|
|
})
|
|
result.append(record)
|
|
return result
|