brotherton-erpnext/erpnext/patches/v14_0/update_opportunity_currency_fields.py

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

50 lines
1.6 KiB
Python
Raw Normal View History

2022-08-25 22:35:08 +02:00
import click
import frappe
from frappe.utils import flt
import erpnext
from erpnext.setup.utils import get_exchange_rate
def execute():
frappe.reload_doc(
"accounts", "doctype", "currency_exchange_settings"
) # get_exchange_rate depends on Currency Exchange Settings
frappe.reload_doctype("Opportunity")
opportunities = frappe.db.get_list(
"Opportunity",
filters={"opportunity_amount": [">", 0]},
fields=["name", "company", "currency", "opportunity_amount"],
)
for opportunity in opportunities:
company_currency = erpnext.get_company_currency(opportunity.company)
2022-08-25 22:35:08 +02:00
if opportunity.currency is None or opportunity.currency == "":
opportunity.currency = company_currency
frappe.db.set_value(
"Opportunity",
opportunity.name,
{"currency": opportunity.currency},
update_modified=False,
)
click.secho(
2022-09-04 19:03:16 +05:30
f' Opportunity `{opportunity.name}` has no currency set. Setting it to company currency as default: `{opportunity.currency}`"\n',
fg="yellow",
)
# base total and total will be 0 only since item table did not have amount field earlier
if opportunity.currency != company_currency:
conversion_rate = get_exchange_rate(opportunity.currency, company_currency)
base_opportunity_amount = flt(conversion_rate) * flt(opportunity.opportunity_amount)
else:
conversion_rate = 1
2022-02-13 19:24:10 +05:30
base_opportunity_amount = flt(opportunity.opportunity_amount)
frappe.db.set_value(
"Opportunity",
opportunity.name,
2022-02-13 19:24:10 +05:30
{"conversion_rate": conversion_rate, "base_opportunity_amount": base_opportunity_amount},
update_modified=False,
)