2015-03-03 14:55:30 +05:30
|
|
|
# Copyright (c) 2015, Frappe Technologies Pvt. Ltd. and Contributors
|
2013-09-10 13:46:15 +05:30
|
|
|
# License: GNU General Public License v3. See license.txt
|
|
|
|
|
2014-10-21 16:16:30 +05:30
|
|
|
|
2019-01-23 00:28:37 +05:30
|
|
|
import frappe
|
|
|
|
|
2013-09-11 18:58:20 +05:30
|
|
|
|
2014-02-14 15:47:51 +05:30
|
|
|
@frappe.whitelist(allow_guest=True)
|
2013-09-11 18:58:20 +05:30
|
|
|
def send_message(subject="Website Query", message="", sender="", status="Open"):
|
2017-11-16 17:03:52 +05:30
|
|
|
from frappe.www.contact import send_message as website_send_message
|
2022-03-28 18:52:46 +05:30
|
|
|
|
2017-11-16 17:03:52 +05:30
|
|
|
lead = customer = None
|
2017-02-20 10:25:25 +05:30
|
|
|
|
2017-11-16 17:03:52 +05:30
|
|
|
website_send_message(subject, message, sender)
|
2017-02-20 10:25:25 +05:30
|
|
|
|
2017-11-16 17:03:52 +05:30
|
|
|
customer = frappe.db.sql(
|
|
|
|
"""select distinct dl.link_name from `tabDynamic Link` dl
|
|
|
|
left join `tabContact` c on dl.parent=c.name where dl.link_doctype='Customer'
|
2019-01-29 10:52:37 +05:30
|
|
|
and c.email_id = %s""",
|
|
|
|
sender,
|
|
|
|
)
|
2017-02-20 10:25:25 +05:30
|
|
|
|
2017-11-16 17:03:52 +05:30
|
|
|
if not customer:
|
2017-06-01 15:38:04 +02:00
|
|
|
lead = frappe.db.get_value("Lead", dict(email_id=sender))
|
|
|
|
if not lead:
|
|
|
|
new_lead = frappe.get_doc(
|
|
|
|
dict(doctype="Lead", email_id=sender, lead_name=sender.split("@")[0].title())
|
|
|
|
).insert(ignore_permissions=True)
|
2022-03-28 18:52:46 +05:30
|
|
|
|
2017-11-16 17:03:52 +05:30
|
|
|
opportunity = frappe.get_doc(
|
|
|
|
dict(
|
|
|
|
doctype="Opportunity",
|
2019-07-03 10:34:31 +05:30
|
|
|
opportunity_from="Customer" if customer else "Lead",
|
2017-11-16 17:03:52 +05:30
|
|
|
status="Open",
|
|
|
|
title=subject,
|
|
|
|
contact_email=sender,
|
2022-03-28 18:52:46 +05:30
|
|
|
)
|
2017-11-16 17:03:52 +05:30
|
|
|
)
|
|
|
|
|
|
|
|
if customer:
|
2019-07-03 10:34:31 +05:30
|
|
|
opportunity.party_name = customer[0][0]
|
2017-11-16 17:03:52 +05:30
|
|
|
elif lead:
|
2019-07-03 10:34:31 +05:30
|
|
|
opportunity.party_name = lead
|
2017-11-16 17:03:52 +05:30
|
|
|
else:
|
2019-07-03 10:34:31 +05:30
|
|
|
opportunity.party_name = new_lead.name
|
2017-11-16 17:03:52 +05:30
|
|
|
|
|
|
|
opportunity.insert(ignore_permissions=True)
|
|
|
|
|
|
|
|
comm = frappe.get_doc(
|
|
|
|
{
|
|
|
|
"doctype": "Communication",
|
|
|
|
"subject": subject,
|
|
|
|
"content": message,
|
|
|
|
"sender": sender,
|
|
|
|
"sent_or_received": "Received",
|
|
|
|
"reference_doctype": "Opportunity",
|
|
|
|
"reference_name": opportunity.name,
|
|
|
|
}
|
|
|
|
)
|
|
|
|
comm.insert(ignore_permissions=True)
|
|
|
|
|
|
|
|
return "okay"
|