diff --git a/erpnext/setup/doctype/email_digest/email_digest.json b/erpnext/setup/doctype/email_digest/email_digest.json index da95b259e2..125aca17c7 100644 --- a/erpnext/setup/doctype/email_digest/email_digest.json +++ b/erpnext/setup/doctype/email_digest/email_digest.json @@ -1,5 +1,7 @@ { "allow_copy": 0, + "allow_events_in_timeline": 0, + "allow_guest_to_view": 0, "allow_import": 0, "allow_rename": 0, "autoname": "Prompt", @@ -13,6 +15,8 @@ "editable_grid": 0, "fields": [ { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -23,6 +27,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "Email Digest Settings", @@ -37,9 +42,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -50,6 +58,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "length": 0, @@ -63,9 +72,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -76,6 +88,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 1, "in_standard_filter": 0, "label": "Enabled", @@ -90,9 +103,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -103,6 +119,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 1, "in_standard_filter": 1, "label": "For Company", @@ -118,9 +135,12 @@ "reqd": 1, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -131,6 +151,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 1, "in_standard_filter": 1, "label": "How frequently?", @@ -146,9 +167,12 @@ "reqd": 1, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -160,6 +184,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "Next email will be sent on:", @@ -174,9 +199,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -187,6 +215,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "length": 0, @@ -200,9 +229,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -214,6 +246,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "Recipients", @@ -229,9 +262,12 @@ "reqd": 1, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -242,6 +278,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "Add/Remove Recipients", @@ -256,9 +293,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -269,6 +309,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "Accounts", @@ -283,9 +324,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -296,6 +340,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "Profit & Loss", @@ -310,9 +355,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -324,6 +372,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "New Income", @@ -338,9 +387,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -352,6 +404,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "New Expenses", @@ -366,9 +419,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -379,6 +435,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "Annual Income", @@ -393,9 +450,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -406,6 +466,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "Annual Expenses", @@ -421,9 +482,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -435,6 +499,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "Balance Sheet", @@ -449,9 +514,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -463,6 +531,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "Bank Balance", @@ -477,9 +546,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -490,9 +562,10 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, - "label": "Credit Balance", + "label": "Bank Credit Balance", "length": 0, "no_copy": 0, "permlevel": 0, @@ -505,9 +578,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -519,6 +595,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "Receivables", @@ -533,9 +610,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -547,6 +627,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "Payables", @@ -561,9 +642,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -574,8 +658,9 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, - "in_standard_filter": 0, + "in_standard_filter": 0, "label": "Work in Progress", "length": 0, "no_copy": 0, @@ -589,9 +674,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -602,8 +690,9 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, - "in_standard_filter": 0, + "in_standard_filter": 0, "label": "Sales Orders to Bill", "length": 0, "no_copy": 0, @@ -617,9 +706,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -630,8 +722,9 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, - "in_standard_filter": 0, + "in_standard_filter": 0, "label": "Purchase Orders to Bill", "length": 0, "no_copy": 0, @@ -645,9 +738,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -658,6 +754,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "Operations", @@ -673,9 +770,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -686,6 +786,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "length": 0, @@ -700,9 +801,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -713,6 +817,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "New Sales Orders", @@ -728,9 +833,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -741,8 +849,9 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, - "in_standard_filter": 0, + "in_standard_filter": 0, "label": "New Purchase Orders", "length": 0, "no_copy": 0, @@ -756,9 +865,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -769,8 +881,9 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, - "in_standard_filter": 0, + "in_standard_filter": 0, "label": "Sales Orders to Deliver", "length": 0, "no_copy": 0, @@ -784,9 +897,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -797,8 +913,9 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, - "in_standard_filter": 0, + "in_standard_filter": 0, "label": "Purchase Orders to Receive", "length": 0, "no_copy": 0, @@ -812,9 +929,76 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 - }, + }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, + "allow_on_submit": 0, + "bold": 0, + "collapsible": 0, + "columns": 0, + "fieldname": "sales_invoice", + "fieldtype": "Check", + "hidden": 0, + "ignore_user_permissions": 0, + "ignore_xss_filter": 0, + "in_filter": 0, + "in_global_search": 0, + "in_list_view": 0, + "in_standard_filter": 0, + "label": "New Sales Invoice", + "length": 0, + "no_copy": 0, + "permlevel": 0, + "precision": "", + "print_hide": 0, + "print_hide_if_no_value": 0, + "read_only": 0, + "remember_last_selected_value": 0, + "report_hide": 0, + "reqd": 0, + "search_index": 0, + "set_only_once": 0, + "translatable": 0, + "unique": 0 + }, + { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, + "allow_on_submit": 0, + "bold": 0, + "collapsible": 0, + "columns": 0, + "fieldname": "purchase_invoice", + "fieldtype": "Check", + "hidden": 0, + "ignore_user_permissions": 0, + "ignore_xss_filter": 0, + "in_filter": 0, + "in_global_search": 0, + "in_list_view": 0, + "in_standard_filter": 0, + "label": "New Purchase Invoice", + "length": 0, + "no_copy": 0, + "permlevel": 0, + "precision": "", + "print_hide": 0, + "print_hide_if_no_value": 0, + "read_only": 0, + "remember_last_selected_value": 0, + "report_hide": 0, + "reqd": 0, + "search_index": 0, + "set_only_once": 0, + "translatable": 0, + "unique": 0 + }, + { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -825,6 +1009,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "", @@ -840,9 +1025,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -853,6 +1041,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "New Quotations", @@ -868,9 +1057,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -881,8 +1073,9 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, - "in_standard_filter": 0, + "in_standard_filter": 0, "label": "Open Quotations", "length": 0, "no_copy": 0, @@ -896,9 +1089,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -909,6 +1105,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "Open Issues", @@ -924,9 +1121,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -937,6 +1137,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "Open Projects", @@ -952,9 +1153,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 - }, + }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -965,8 +1169,9 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, - "in_standard_filter": 0, + "in_standard_filter": 0, "label": "Purchase Orders Items Overdue", "length": 0, "no_copy": 0, @@ -980,9 +1185,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -993,6 +1201,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "Other", @@ -1008,9 +1217,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -1021,6 +1233,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "Tools", @@ -1036,9 +1249,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -1049,6 +1265,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "Upcoming Calendar Events", @@ -1064,9 +1281,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -1077,6 +1297,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "Open To Do", @@ -1092,9 +1313,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -1105,6 +1329,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "Open Notifications", @@ -1120,9 +1345,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -1133,6 +1361,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": " ", @@ -1148,9 +1377,12 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 }, { + "allow_bulk_edit": 0, + "allow_in_quick_entry": 0, "allow_on_submit": 0, "bold": 0, "collapsible": 0, @@ -1161,6 +1393,7 @@ "ignore_user_permissions": 0, "ignore_xss_filter": 0, "in_filter": 0, + "in_global_search": 0, "in_list_view": 0, "in_standard_filter": 0, "label": "Add Quote", @@ -1176,22 +1409,23 @@ "reqd": 0, "search_index": 0, "set_only_once": 0, + "translatable": 0, "unique": 0 } ], + "has_web_view": 0, "hide_heading": 0, "hide_toolbar": 0, "icon": "fa fa-envelope", "idx": 1, "image_view": 0, "in_create": 0, - "is_submittable": 0, "issingle": 0, "istable": 0, "max_attachments": 0, "menu_index": 0, - "modified": "2018-09-16 22:00:00.000000", + "modified": "2019-01-16 09:52:15.149908", "modified_by": "Administrator", "module": "Setup", "name": "Email Digest", @@ -1199,7 +1433,6 @@ "permissions": [ { "amend": 0, - "apply_user_permissions": 0, "cancel": 0, "create": 1, "delete": 1, @@ -1207,7 +1440,6 @@ "export": 0, "if_owner": 0, "import": 0, - "is_custom": 0, "permlevel": 0, "print": 1, "read": 1, @@ -1220,7 +1452,6 @@ }, { "amend": 0, - "apply_user_permissions": 0, "cancel": 0, "create": 0, "delete": 0, @@ -1228,7 +1459,6 @@ "export": 0, "if_owner": 0, "import": 0, - "is_custom": 0, "permlevel": 1, "print": 0, "read": 1, @@ -1243,7 +1473,10 @@ "quick_entry": 0, "read_only": 0, "read_only_onload": 0, + "show_name_in_global_search": 0, "sort_field": "modified", "sort_order": "DESC", - "track_seen": 0 + "track_changes": 0, + "track_seen": 0, + "track_views": 0 } \ No newline at end of file diff --git a/erpnext/setup/doctype/email_digest/email_digest.py b/erpnext/setup/doctype/email_digest/email_digest.py index 36b5bb9a84..a1aa134982 100644 --- a/erpnext/setup/doctype/email_digest/email_digest.py +++ b/erpnext/setup/doctype/email_digest/email_digest.py @@ -5,7 +5,7 @@ from __future__ import unicode_literals import frappe from frappe import _ from frappe.utils import fmt_money, formatdate, format_time, now_datetime, \ - get_url_to_form, get_url_to_list, flt, getdate, get_link_to_report + get_url_to_form, get_url_to_list, flt, get_link_to_report from datetime import timedelta from dateutil.relativedelta import relativedelta from frappe.core.doctype.user.user import STANDARD_USERS @@ -239,7 +239,9 @@ class EmailDigest(Document): for key in ("income", "expenses_booked", "income_year_to_date", "expense_year_to_date", "bank_balance", "credit_balance", "invoiced_amount", "payables", "sales_orders_to_bill", "purchase_orders_to_bill", "sales_order", "purchase_order", - "sales_orders_to_deliver", "purchase_orders_to_receive", "new_quotations", "pending_quotations"): + "sales_orders_to_deliver", "purchase_orders_to_receive", "sales_invoice", "purchase_invoice", + "new_quotations", "pending_quotations"): + if self.get(key): cache_key = "email_digest:card:{0}:{1}:{2}:{3}".format(self.company, self.frequency, key, self.from_date) card = cache.get(cache_key) @@ -288,7 +290,17 @@ class EmailDigest(Document): """Get income for given period""" income, past_income, count = self.get_period_amounts(self.get_roots("income"),'income') - label = get_link_to_report("Sales Register",self.meta.get_label("income"),filters={"company":self.company}) + income_account = frappe.db.get_all('Account', + fields=["name"], + filters={"root_type":"Income", "parent_account":''}) + + label = get_link_to_report("General Ledger",self.meta.get_label("income"), + filters={"company": self.company, + "from_date": self.future_from_date, + "to_date": self.future_to_date, + "account": income_account[0].name + } + ) return { "label": label, "value": income, @@ -316,12 +328,14 @@ class EmailDigest(Document): if fieldname == 'income': filters = { "root_type": "Income", + "report_date":self.future_to_date, } label = get_link_to_report('Account Balance', label=self.meta.get_label(root_type + "_year_to_date"), filters=filters) elif fieldname == 'expenses_booked': filters = { "root_type": "Expense", + "report_date":self.future_to_date, } label = get_link_to_report('Account Balance', label=self.meta.get_label(root_type + "_year_to_date"), filters=filters) @@ -348,8 +362,17 @@ class EmailDigest(Document): def get_expenses_booked(self): expenses, past_expenses, count = self.get_period_amounts(self.get_roots("expense"), 'expenses_booked') - label = get_link_to_report("Purchase Register",self.meta.get_label("expenses_booked"), - filters={"company": self.company}) + expense_account = frappe.db.get_all('Account', + fields=["name"], + filters={"root_type":"Expense", "parent_account":''}) + + label = get_link_to_report("General Ledger",self.meta.get_label("expenses_booked"), + filters={"company":self.company, + "from_date":self.future_from_date, + "to_date":self.future_to_date, + "account": expense_account[0].name + } + ) return { "label": label, "value": expenses, @@ -376,8 +399,18 @@ class EmailDigest(Document): where (transaction_date <= %(to_date)s) and billing_status != "Fully Billed" and status not in ('Closed','Cancelled', 'Completed') """, {"to_date": self.future_to_date})[0] + label = get_link_to_report('Sales Order', label=self.meta.get_label("sales_orders_to_bill"), + report_type="Report Builder", + doctype="Sales Order", + filters = { + "status": [['!=', "Closed"], ['!=', "Cancelled"], ['!=', "Completed"]], + "billing_status": [['!=', "Fully Billed"]], + "transaction_date": [['<=', self.future_to_date]] + } + ) + return { - "label": self.meta.get_label("sales_orders_to_bill"), + "label": label, "value": value, "count": count } @@ -390,8 +423,15 @@ class EmailDigest(Document): where (transaction_date <= %(to_date)s) and delivery_status != "Fully Delivered" and status not in ('Closed','Cancelled', 'Completed') """, {"to_date": self.future_to_date})[0] - label = get_link_to_report("Pending Sales Order", label=self.meta.get_label("sales_orders_to_deliver"), - report_type="Report Builder", doctype="Sales Order") + label = get_link_to_report('Sales Order', label=self.meta.get_label("sales_orders_to_deliver"), + report_type="Report Builder", + doctype="Sales Order", + filters = { + "status": [['!=', "Closed"], ['!=', "Cancelled"], ['!=', "Completed"]], + "delivery_status": [['!=', "Fully Delivered"]], + "transaction_date": [['<=', self.future_to_date]] + } + ) return { "label": label, @@ -407,8 +447,15 @@ class EmailDigest(Document): where (transaction_date <= %(to_date)s) and per_received < 100 and status not in ('Closed','Cancelled', 'Completed') """, {"to_date": self.future_to_date})[0] - label = get_link_to_report("Pending Purchase Order", label=self.meta.get_label("purchase_orders_to_receive"), - report_type="Report Builder", doctype="Purchase Order") + label = get_link_to_report('Purchase Order', label=self.meta.get_label("purchase_orders_to_receive"), + report_type="Report Builder", + doctype="Purchase Order", + filters = { + "status": [['!=', "Closed"], ['!=', "Cancelled"], ['!=', "Completed"]], + "per_received": [['<', 100]], + "transaction_date": [['<=', self.future_to_date]] + } + ) return { "label": label, @@ -424,8 +471,18 @@ class EmailDigest(Document): where (transaction_date <= %(to_date)s) and per_billed < 100 and status not in ('Closed','Cancelled', 'Completed') """, {"to_date": self.future_to_date})[0] + label = get_link_to_report('Purchase Order', label=self.meta.get_label("purchase_orders_to_bill"), + report_type="Report Builder", + doctype="Purchase Order", + filters = { + "status": [['!=', "Closed"], ['!=', "Cancelled"], ['!=', "Completed"]], + "per_received": [['<', 100]], + "transaction_date": [['<=', self.future_to_date]] + } + ) + return { - "label": self.meta.get_label("purchase_orders_to_bill"), + "label": label, "value": value, "count": count } @@ -453,11 +510,15 @@ class EmailDigest(Document): if fieldname == "bank_balance": filters = { "root_type": "Asset", + "account_type": "Bank", + "date": self.future_to_date } label = get_link_to_report('Account Balance', label=self.meta.get_label(fieldname), filters=filters) else: filters = { "root_type": "Liability", + "account_type": "Bank", + "to_date": self.future_to_date } label = get_link_to_report('Account Balance', label=self.meta.get_label(fieldname), filters=filters) @@ -468,9 +529,11 @@ class EmailDigest(Document): } else: if account_type == 'Payable': - label = get_link_to_report('Accounts Payable', label=self.meta.get_label(fieldname)) + label = get_link_to_report('Accounts Payable', label=self.meta.get_label(fieldname), + filters={"report_date": self.future_to_date} ) elif account_type == 'Receivable': - label = get_link_to_report('Accounts Receivable', label=self.meta.get_label(fieldname)) + label = get_link_to_report('Accounts Receivable', label=self.meta.get_label(fieldname), + filters={"report_date": self.future_to_date}) else: label = self.meta.get_label(fieldname) @@ -509,6 +572,14 @@ class EmailDigest(Document): return self.get_summary_of_pending("Sales Order","pending_sales_orders","per_delivered") + def get_sales_invoice(self): + + return self.get_summary_of_doc("Sales Invoice","sales_invoice") + + def get_purchase_invoice(self): + + return self.get_summary_of_doc("Purchase Invoice","purchase_invoice") + def get_new_quotations(self): return self.get_summary_of_doc("Quotation","new_quotations") @@ -546,8 +617,16 @@ class EmailDigest(Document): and company = %(company)s and status not in ('Ordered','Cancelled', 'Lost') """,{"to_date": self.past_to_date, "company": self.company})[0][0] - label = get_link_to_report("Pending Quotation", label=self.meta.get_label(fieldname), - report_type="Report Builder", doctype="Quotation") + label = get_link_to_report('Quotation', label=self.meta.get_label(fieldname), + report_type="Report Builder", + doctype="Quotation", + filters = { + "status": [['!=', "Ordered"], ['!=', "Cancelled"], ['!=', "Lost"]], + "per_received": [['<', 100]], + "transaction_date": [['<=', self.future_to_date]], + "company": self.company + } + ) return { "label": label, @@ -558,14 +637,20 @@ class EmailDigest(Document): def get_summary_of_doc(self, doc_type, fieldname): + date_field = 'posting_date' if doc_type in ['Sales Invoice', 'Purchase Invoice'] \ + else 'transaction_date' + value = self.get_total_on(doc_type, self.future_from_date, self.future_to_date)[0] count = self.get_total_on(doc_type, self.future_from_date, self.future_to_date)[1] last_value =self.get_total_on(doc_type, self.past_from_date, self.past_to_date)[0] filters = { - "transaction_date": getdate() + date_field: [['>=', self.future_from_date], ['<=', self.future_to_date]], + "status": [['!=','Cancelled']], + "company": self.company } + label = get_link_to_report(doc_type,label=self.meta.get_label(fieldname), report_type="Report Builder", filters=filters, doctype=doc_type) @@ -578,9 +663,12 @@ class EmailDigest(Document): def get_total_on(self, doc_type, from_date, to_date): + date_field = 'posting_date' if doc_type in ['Sales Invoice', 'Purchase Invoice'] \ + else 'transaction_date' + return frappe.db.sql("""select ifnull(sum(grand_total),0), count(*) from `tab{0}` - where (transaction_date between %(from_date)s and %(to_date)s) and company=%(company)s - and status not in ('Cancelled')""".format(doc_type), + where ({1} between %(from_date)s and %(to_date)s) and company=%(company)s + and status not in ('Cancelled')""".format(doc_type, date_field), {"from_date": from_date, "to_date": to_date, "company": self.company})[0] def get_from_to_date(self):