fix: update standard dropdown items from hooks while install and after migrate
This commit is contained in:
parent
8e703dd723
commit
6cc22d8795
@ -3,6 +3,7 @@
|
|||||||
|
|
||||||
import frappe
|
import frappe
|
||||||
from frappe.model.document import Document
|
from frappe.model.document import Document
|
||||||
|
|
||||||
from crm.install import after_install
|
from crm.install import after_install
|
||||||
|
|
||||||
|
|
||||||
@ -10,3 +11,28 @@ class FCRMSettings(Document):
|
|||||||
@frappe.whitelist()
|
@frappe.whitelist()
|
||||||
def restore_defaults(self, force=False):
|
def restore_defaults(self, force=False):
|
||||||
after_install(force)
|
after_install(force)
|
||||||
|
|
||||||
|
|
||||||
|
def after_migrate():
|
||||||
|
sync_table("dropdown_items", "standard_dropdown_items")
|
||||||
|
|
||||||
|
|
||||||
|
def sync_table(key, hook):
|
||||||
|
crm_settings = FCRMSettings("FCRM Settings")
|
||||||
|
existing_items = {d.name1: d for d in crm_settings.get(key)}
|
||||||
|
new_standard_items = {}
|
||||||
|
|
||||||
|
# add new items
|
||||||
|
count = 0 # maintain count because list may come from seperate apps
|
||||||
|
for item in frappe.get_hooks(hook):
|
||||||
|
if item.get("name1") not in existing_items:
|
||||||
|
crm_settings.append(key, item, count)
|
||||||
|
new_standard_items[item.get("name1")] = True
|
||||||
|
count += 1
|
||||||
|
|
||||||
|
# remove unused items
|
||||||
|
items = crm_settings.get(key)
|
||||||
|
items = [item for item in items if not (item.is_standard and (item.name1 not in new_standard_items))]
|
||||||
|
crm_settings.set(key, items)
|
||||||
|
|
||||||
|
crm_settings.save()
|
||||||
|
|||||||
64
crm/hooks.py
64
crm/hooks.py
@ -155,11 +155,13 @@ doc_events = {
|
|||||||
"on_update": ["crm.api.whatsapp.on_update"],
|
"on_update": ["crm.api.whatsapp.on_update"],
|
||||||
},
|
},
|
||||||
"CRM Deal": {
|
"CRM Deal": {
|
||||||
"on_update": ["crm.fcrm.doctype.erpnext_crm_settings.erpnext_crm_settings.create_customer_in_erpnext"],
|
"on_update": [
|
||||||
|
"crm.fcrm.doctype.erpnext_crm_settings.erpnext_crm_settings.create_customer_in_erpnext"
|
||||||
|
],
|
||||||
},
|
},
|
||||||
"User": {
|
"User": {
|
||||||
"before_validate": ["crm.api.demo.validate_user"],
|
"before_validate": ["crm.api.demo.validate_user"],
|
||||||
}
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
# Scheduled Tasks
|
# Scheduled Tasks
|
||||||
@ -251,3 +253,61 @@ doc_events = {
|
|||||||
# auth_hooks = [
|
# auth_hooks = [
|
||||||
# "crm.auth.validate"
|
# "crm.auth.validate"
|
||||||
# ]
|
# ]
|
||||||
|
|
||||||
|
after_migrate = ["crm.fcrm.doctype.fcrm_settings.fcrm_settings.after_migrate"]
|
||||||
|
|
||||||
|
standard_dropdown_items = [
|
||||||
|
{
|
||||||
|
"name1": "app_selector",
|
||||||
|
"label": "Apps",
|
||||||
|
"type": "Route",
|
||||||
|
"route": "#",
|
||||||
|
"is_standard": 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name1": "support_link",
|
||||||
|
"label": "Support",
|
||||||
|
"type": "Route",
|
||||||
|
"icon": "life-buoy",
|
||||||
|
"route": "https://t.me/frappecrm",
|
||||||
|
"is_standard": 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name1": "docs_link",
|
||||||
|
"label": "Docs",
|
||||||
|
"type": "Route",
|
||||||
|
"icon": "book-open",
|
||||||
|
"route": "https://docs.frappe.io/crm",
|
||||||
|
"is_standard": 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name1": "toggle_theme",
|
||||||
|
"label": "Toggle theme",
|
||||||
|
"type": "Route",
|
||||||
|
"icon": "moon",
|
||||||
|
"route": "#",
|
||||||
|
"is_standard": 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name1": "settings",
|
||||||
|
"label": "Settings",
|
||||||
|
"type": "Route",
|
||||||
|
"icon": "settings",
|
||||||
|
"route": "#",
|
||||||
|
"is_standard": 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name1": "separator",
|
||||||
|
"label": "",
|
||||||
|
"type": "Separator",
|
||||||
|
"is_standard": 1,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"name1": "logout",
|
||||||
|
"label": "Log out",
|
||||||
|
"type": "Route",
|
||||||
|
"icon": "log-out",
|
||||||
|
"route": "#",
|
||||||
|
"is_standard": 1,
|
||||||
|
},
|
||||||
|
]
|
||||||
|
|||||||
@ -18,6 +18,7 @@ def after_install(force=False):
|
|||||||
add_email_template_custom_fields()
|
add_email_template_custom_fields()
|
||||||
add_default_industries()
|
add_default_industries()
|
||||||
add_default_lead_sources()
|
add_default_lead_sources()
|
||||||
|
add_standard_dropdown_items()
|
||||||
frappe.db.commit()
|
frappe.db.commit()
|
||||||
|
|
||||||
|
|
||||||
@ -333,3 +334,18 @@ def add_default_lead_sources():
|
|||||||
doc = frappe.new_doc("CRM Lead Source")
|
doc = frappe.new_doc("CRM Lead Source")
|
||||||
doc.source_name = source
|
doc.source_name = source
|
||||||
doc.insert()
|
doc.insert()
|
||||||
|
|
||||||
|
|
||||||
|
def add_standard_dropdown_items():
|
||||||
|
crm_settings = frappe.get_single("FCRM Settings")
|
||||||
|
|
||||||
|
# don't add dropdown items if they're already present
|
||||||
|
if crm_settings.dropdown_items:
|
||||||
|
return
|
||||||
|
|
||||||
|
crm_settings.dropdown_items = []
|
||||||
|
|
||||||
|
for item in frappe.get_hooks("standard_dropdown_items"):
|
||||||
|
crm_settings.append("dropdown_items", item)
|
||||||
|
|
||||||
|
crm_settings.save()
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user