Перейти к содержимому
Odoo Меню
  • Войти
  • Попробовать бесплатно
  • Модули
    Финансы
    • Бухгалтерия
    • Выставление счетов
    • Расходы
    • Таблицы
    • Документооборот
    • Подпись
    Продажи
    • CRM
    • Продажи
    • POS Магазин
    • POS Ресторан
    • Подписки
    • Аренда
    Вебсайты
    • Конструктор вебсайтов
    • eCommerce
    • Блог
    • Форум
    • Онлайн-чат
    • Электронное обучение
    Логистика
    • Склад
    • Производство
    • PLM
    • Закупки
    • Обслуживание
    • Качество
    Отдел кадров
    • Сотрудники
    • Подбор персонала
    • Отпуска
    • Оценка персонала
    • Реферальная программа
    • Автопарк
    Маркетинг
    • SMM
    • E-mail рассылки
    • СМС рассылки
    • Мероприятия
    • Автоматизация маркетинга
    • Опросы
    Услуги
    • Проекты
    • Табели
    • Выездной сервис
    • Поддержка
    • Планирование
    • Встречи
    Продуктивность
    • Обсуждения
    • Согласование
    • IoT
    • VoIP-телефония
    • Knowledge
    • WhatsApp
    Сторонние приложения Модуль Студия Odoo Платформа Odoo Cloud
  • Индустрии
    Розничная торговля
    • Книжный магазин
    • Магазин одежды
    • Мебельный магазин
    • Продуктовый магазин
    • Строительный магазин
    • Магазин игрушек
    Гостинично-ресторанный бизнес
    • Бар и паб
    • Ресторан
    • Фастфуд
    • Гостевой дом
    • Дистрибьютор напитков
    • Отель
    Недвижимость
    • Агентство недвижимости
    • Архитектурное бюро
    • Строительство
    • Управление недвижимостью
    • Ландшафтный дизайн
    • Товарищество собственников жилья
    Консалтинг
    • Бухгалтерская фирма
    • Партнер Odoo
    • Маркетинговое агентство
    • Юридическая фирма
    • Подбор персонала
    • Аудиторское бюро
    Производство
    • Текстиль
    • Металл
    • Мебель
    • Продукты питания
    • Пивоварня
    • Корпоративные сувениры
    Здоровье и фитнес
    • Спортивный комплекс
    • Магазин оптики
    • Фитнес-клуб
    • Велнес-центр
    • Аптека
    • Салон красоты
    Услуги
    • Специалист по бытовым услугам
    • Продажа и обслуживание IT-оборудования
    • Солнечные энергосистемы
    • Производство обуви
    • Клининг
    • Системы ОВКВ
    Прочее
    • Некоммерческая организация
    • Консалтинг в сфере устойчивого развития
    • Аренда рекламных щитов
    • Бизнес по фотосъемке
    • Прокат велосипедов
    • Реселлер программного обеспечения
    Все индустрии
  • Community
    Обучение
    • Видео уроки
    • Документация
    • Сертификация
    • Тренинг
    • Блог
    • Подкаст
    Образование и развитие
    • Образовательная программа
    • Деловая игра Scale Up!
    • Экскурсия в офис Odoo
    ПО
    • Скачать
    • Сравнить версии
    • Релизы
    Сотрудничество
    • Github
    • Форум
    • Мероприятия
    • Перевод
    • Стать партнером
    • Услуги для партнеров
    • Зарегистрировать бухгалтерскую фирму
    Услуги
    • Найти партнера
    • Найти бухгалтера
    • Встреча с экспертом
    • Услуги по внедрению
    • Отзывы клиентов
    • Поддержка
    • Обновления
    Github Youtube Twitter Linkedin Instagram Facebook Spotify
    +1 (650) 691-3277
    Заказать демонстрацию
  • Цены
  • Поддержка

Odoo is the world's easiest all-in-one management software.
It includes hundreds of business apps:

  • CRM
  • e-Commerce
  • Бухгалтерия
  • Склад
  • PoS
  • Проекты
  • MRP
All apps
Чтобы взаимодействовать с сообществом, необходимо зарегистрироваться.
Все посты Люди Значки
Теги (Смотреть все)
odoo accounting v14 pos v15
Об этом форуме
Чтобы взаимодействовать с сообществом, необходимо зарегистрироваться.
Все посты Люди Значки
Теги (Смотреть все)
odoo accounting v14 pos v15
Об этом форуме
Помощь

Auto set invoice "Recipient Bank" by currency with automated action

Подписаться

Получайте уведомления о появлении активности в этом посте

Этот вопрос был отмечен
configurationcurrencyAutomatedActionsKeepItSimpleodoo16features
5 Ответы
5973 Представления
Аватар
Ricardo Gross

Having different bank accounts in different currencies, is it possible to configure Odoo so that when creating customer invoice and selecting, for example the Euro currency, automatically my Euro bank account will be set in the Recipient Bank?


Odoo simply takes the first company account from the top which causes errors, an Automatic Action to take the first account in the currency/journal currrency selected in invoice could be a solution.


1
Аватар
Отменить
Аватар
Patrick Mathers
Лучший ответ

This worked for me:


Model: Journal Entry

Trigger: On Creation & Update

Action to do: Execute Python Code

Python Code:

for record in records:
  if record.move_type == 'out_invoice':
    currency = record.currency_id
    bank_account = record.env['res.partner.bank'].search([('currency_id', '=', currency.id)], limit=1)
    if bank_account:
        record.write({'partner_bank_id': bank_account.id})

Update: You can set currency.id as a trigger field, although this was not necessary in my case as all fields are monitored if empty.

2
Аватар
Отменить
Ricardo Gross
Автор

thanks Patrick, but maybe missing trigger fields or something else?

Michael Hofer

Thanks, this did help - I have just extended it slightly in my answer.

Ricardo Gross
Автор

for v18 it also works by setting the trigger "on save” and adding Apply on “status = Draft"

Аватар
Michael Hofer
Лучший ответ

It's really surprising that there is no easier way to solve this. I had the same issue and found this thread, but the examples were not fully working for me. They did select a bank account, but not necessarily one which is linked to the own company.


This seems to work (tested in Odoo 17, but should work in Odoo 16 too):


for record in records:
if record.move_type == 'out_invoice':
  currency = record.currency_id
bank_account = record.env['res.partner.bank'].search(['&', ('currency_id', '=', currency.id), ('partner_id', '=', record.env.company.partner_id.id)], limit=1)
    if bank_account:
        record.write({'partner_bank_id': bank_account.id})



I have set the trigger on "currency" too, but it is not necessary. Hope it helps!

1
Аватар
Отменить
Admin

Hi Michael,
Thank you for your answer. I use Odoo 17 and have been trying to setting the Automation Rules there to automatically change the Recipient bank when changing the currency of the invoice. I assume that in Odoo 17 you need to define 2 Rules since you can only choose one Trigger? One trigger would be "after last update" and one "after creation". Do I need to set a Domain (if yes, which)? Do i need to set parameters for "apply on" (if yes, which)? I used your code above but it gives me an error message. (IndentationError : unindent does not match any outer indentation level at line 16
bank_account = record.env['res.partner.bank'].search(['&', ('currency_id', '=', currency.id), ('partner_id', '=', record.env.company.partner_id.id)], limit=1))
Thank you for your help!

Аватар
constanceseverino
Лучший ответ

I think you can reference this post. It can help.

0
Аватар
Отменить
constanceseverino

https://www.odoo.com/ko_KR/forum/doummal-1/multi-currency-on-invoice-cannot-update-on-report-214088

constanceseverino

or this link https://www.odoo.com/ko_KR/forum/doummal-1/displaying-currency-in-invoice-with-3-letter-currency-code-213421 https://bloxdio2.com

Аватар
Kris Kormany
Лучший ответ

I would need exactly that, but the provided code does not work in Odoo 16. @Ricardo: Were you able to solve this?

0
Аватар
Отменить
Ricardo Gross
Автор

unfortunately not yet

Аватар
Savya Sachin
Лучший ответ

Hi,

Yes, for this you can create an automatic action that triggers when a new invoice is created or updated. The automatic action should set the recipient bank account based on the currency selected in the invoice.

for move in records:
if move.type == 'out_invoice':
currency = move.currency_id
bank_account = self.env['res.partner.bank'].search([('currency_id', '=', currency.id)], limit=1)
if bank_account:
move.write({'partner_bank_id': bank_account.id})


Once the automatic action is created, it will be triggered when a new invoice is created or updated. It will set the recipient bank account based on the currency selected in the invoice.

Note that this solution assumes that you have created separate bank accounts for each currency. If you have not done so already, you will need to create a separate bank account for each currency in your chart of accounts.


Regards

0
Аватар
Отменить
Ricardo Gross
Автор

thanks for your solution.
But either I'm doing something wrong or the automated action code is not correct, as when I test and change the invoice currency, the recipient bank remains always the same. Have you tested your solution in v16?

Не оставайтесь в стороне – присоединяйтесь к обсуждению!

Создайте аккаунт сегодня, чтобы получить доступ к эксклюзивным функциям и стать частью нашего замечательного сообщества!

Регистрация
Похожие посты Ответы Просмотры Активность
Unable users to timesheet hours on closed (folded) projects and/or tasks
timesheets folded AutomatedActions KeepItSimple odoo16features
Аватар
Аватар
1
февр. 24
3391
Is there a way for changes to confirmed SO's to update the PO? (Inter-Company Transactions)
syncronisation intercompany AutomatedActions KeepItSimple odoo16features
Аватар
0
февр. 23
2976
Odoo16: where is Automated Actions in Technical menu Решено
AutomatedActions odoo16features
Аватар
Аватар
Аватар
Аватар
3
окт. 23
4285
Currency issue in Vendor Bill Решено
currency odoo16features
Аватар
Аватар
1
окт. 23
2713
EE16 - exchange rate not being applied to journal entries
accounting currency odoo16features
Аватар
Аватар
Аватар
2
июл. 24
3507
Сообщество
  • Видео уроки
  • Документация
  • Форум
Открытый исходный код
  • Скачать
  • Github
  • Runbot
  • Перевод
Услуги
  • Хостинг Odoo.sh
  • Поддержка
  • Обновление
  • Индивидуальные решения по доработке
  • Образование
  • Найти бухгалтера
  • Найти партнера
  • Стать партнером
О нас
  • Наша компания
  • Активы бренда
  • Cвяжитесь с нами
  • Вакансии
  • Мероприятия
  • Подкаст
  • Блог
  • Клиенты
  • Правовые документы • Конфиденциальность
  • Безопасность
الْعَرَبيّة Català 简体中文 繁體中文 (台灣) Čeština Dansk Nederlands English Suomi Français Deutsch हिंदी Bahasa Indonesia Italiano 日本語 한국어 (KR) Lietuvių kalba Język polski Português (BR) română русский язык Slovenský jazyk slovenščina Español (América Latina) Español ภาษาไทย Türkçe українська Tiếng Việt

Odoo – это набор бизнес-модулей с открытым исходным кодом, который закроет все потребности вашей компании: CRM, E-commerce, Бухгалтерия, Склад, POS, управление проектами и др.

Odoo сочетает в себе простоту использования и полную интеграцию всех бизнес-процессов в одной системе.

Website made with

Odoo Experience on YouTube

1. Use the live chat to ask your questions.
2. The operator answers within a few minutes.

Live support on Youtube
Watch now