Code for send email via erpnext

hello community . I want to add a button to send emails to users . I know there is an option for this in all doctypes but I want to send a custom email. how to achieve this ? thank you .

@bahaou Hey Baha, this solution requires a custom app because you have to patch the CommunicationComposer prototype.

  • Use the built in Email Template doctype
  • Decide how you want to map the email template to the doctype so that the communication composer can load it. This really depends on your use case, but it could be per-user/per-doctype (most complex) to per-doctype. If you want to go with per-doctype, add a custom field on the Email Template doctype for mapping.
// include this in a file that is  in build.json and included in the app via hooks.py
frappe.views.CommunicationComposer = frappe.views.CommunicationComposer.extend({
	set_email_template: function(val) {
		this.dialog.fields_dict.content.set_value("");
                // frappe.call or frappe.db.get_value for your API that gets the correct template
		this.dialog.fields_dict.email_template.set_value(val);
	},
// you may need to do more based on your use case, this is just to get you started
}

Good luck!

1 Like

I want to expand on this topic, as I just got my custom CommunicationComposer class working using the code below. Maybe it helps somebody in the future! Thanks to @tmatteson for guiding me in the right direction.

This approach allows you to modify the core email popup with custom field properties or new fields.

In your custom app, place the following code:

hooks.py:

app_include_js = [
    "/assets/appname/js/pages/communication-composer.js" # Extend core email functionality
	]

communication-composer.js:

class CustomCommunicationComposer extends frappe.views.CommunicationComposer {
    get_fields() {
        console.debug("Running custom get_fields()");

        // First run parent function get_fields()
        const fields = super.get_fields();

        // Change result field list
        // Example: Add a custom field
        fields.push({
            fieldname: "custom_field",
            fieldtype: "Data",
            label: "Custom Field"
        });

        return fields;
    }
}

// Make sure that the new custom class is used
frappe.views.CommunicationComposer = CustomCommunicationComposer;
1 Like