123456789101112131415161718192021222324252627282930 |
- 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
|