2019-05-21 07:57:06 +05:30
|
|
|
class CallPopup {
|
2019-06-06 14:48:37 +05:30
|
|
|
constructor(call_log) {
|
2019-06-07 10:22:50 +05:30
|
|
|
this.caller_number = call_log.from;
|
2019-05-22 06:38:25 +05:30
|
|
|
this.call_log = call_log;
|
2019-06-17 08:46:38 +05:30
|
|
|
this.setup_listener();
|
2019-05-16 23:55:35 +05:30
|
|
|
this.make();
|
|
|
|
}
|
|
|
|
|
|
|
|
make() {
|
2021-02-08 20:13:23 +05:30
|
|
|
frappe.utils.play_sound('incoming-call');
|
2019-05-18 16:11:29 +05:30
|
|
|
this.dialog = new frappe.ui.Dialog({
|
|
|
|
'static': true,
|
2021-02-08 20:13:23 +05:30
|
|
|
'minimizable': true
|
|
|
|
});
|
|
|
|
this.dialog.get_close_btn().show();
|
|
|
|
this.setup_dialog();
|
|
|
|
this.set_call_status();
|
|
|
|
frappe.utils.bind_actions_with_object(this.dialog.$body, this);
|
|
|
|
this.dialog.$wrapper.addClass('call-popup');
|
|
|
|
this.dialog.get_close_btn().unbind('click').click(this.close_modal.bind(this));
|
|
|
|
this.dialog.show();
|
|
|
|
}
|
|
|
|
|
|
|
|
setup_dialog() {
|
|
|
|
this.setup_call_details();
|
|
|
|
this.dialog.$body.empty().append(this.caller_info);
|
|
|
|
}
|
|
|
|
|
|
|
|
set_indicator(color, blink=false) {
|
|
|
|
let classes = `indicator ${color} ${blink ? 'blink': ''}`;
|
|
|
|
this.dialog.header.find('.indicator').attr('class', classes);
|
|
|
|
}
|
|
|
|
|
|
|
|
set_call_status(call_status) {
|
|
|
|
let title = '';
|
|
|
|
call_status = call_status || this.call_log.status;
|
|
|
|
if (['Ringing'].includes(call_status) || !call_status) {
|
|
|
|
title = __('Incoming call from {0}', [this.get_caller_name() || this.caller_number]);
|
|
|
|
this.set_indicator('blue', true);
|
|
|
|
} else if (call_status === 'In Progress') {
|
|
|
|
title = __('Call Connected');
|
|
|
|
this.set_indicator('green');
|
|
|
|
} else if (['No Answer', 'Missed'].includes(call_status)) {
|
|
|
|
this.set_indicator('yellow');
|
|
|
|
title = __('Call Missed');
|
|
|
|
} else if (['Completed', 'Busy', 'Failed'].includes(call_status)) {
|
|
|
|
this.set_indicator('red');
|
|
|
|
title = __('Call Ended');
|
|
|
|
} else {
|
|
|
|
this.set_indicator('blue');
|
|
|
|
title = call_status;
|
|
|
|
}
|
|
|
|
this.dialog.set_title(title);
|
|
|
|
}
|
|
|
|
|
|
|
|
update_call_log(call_log, missed) {
|
|
|
|
this.call_log = call_log;
|
|
|
|
this.set_call_status(missed ? 'Missed': null);
|
|
|
|
}
|
|
|
|
|
|
|
|
close_modal() {
|
|
|
|
this.dialog.hide();
|
|
|
|
delete erpnext.call_popup;
|
|
|
|
}
|
|
|
|
|
|
|
|
call_ended(call_log, missed) {
|
|
|
|
frappe.utils.play_sound('call-disconnect');
|
|
|
|
this.update_call_log(call_log, missed);
|
|
|
|
setTimeout(() => {
|
|
|
|
if (!this.dialog.get_value('call_summary')) {
|
|
|
|
this.close_modal();
|
|
|
|
}
|
|
|
|
}, 60000);
|
|
|
|
this.clear_listeners();
|
|
|
|
}
|
|
|
|
|
|
|
|
get_caller_name() {
|
|
|
|
const contact_link = this.get_contact_link();
|
|
|
|
return contact_link.link_title || contact_link.link_name;
|
|
|
|
}
|
|
|
|
|
|
|
|
get_contact_link() {
|
|
|
|
let log = this.call_log;
|
|
|
|
let contact_link = log.links.find(d => d.link_doctype === 'Contact');
|
|
|
|
return contact_link || {};
|
|
|
|
}
|
|
|
|
|
|
|
|
setup_listener() {
|
|
|
|
frappe.realtime.on(`call_${this.call_log.id}_ended`, call_log => {
|
|
|
|
this.call_ended(call_log);
|
|
|
|
});
|
|
|
|
|
|
|
|
frappe.realtime.on(`call_${this.call_log.id}_missed`, call_log => {
|
|
|
|
this.call_ended(call_log, true);
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
clear_listeners() {
|
|
|
|
frappe.realtime.off(`call_${this.call_log.id}_ended`);
|
|
|
|
frappe.realtime.off(`call_${this.call_log.id}_missed`);
|
|
|
|
}
|
|
|
|
|
|
|
|
setup_call_details() {
|
|
|
|
this.caller_info = $(`<div></div>`);
|
|
|
|
this.call_details = new frappe.ui.FieldGroup({
|
|
|
|
fields: [{
|
2019-07-16 11:07:25 +05:30
|
|
|
'fieldname': 'name',
|
|
|
|
'label': 'Name',
|
|
|
|
'default': this.get_caller_name() || __('Unknown Caller'),
|
|
|
|
'fieldtype': 'Data',
|
|
|
|
'read_only': 1
|
|
|
|
}, {
|
|
|
|
'fieldtype': 'Button',
|
|
|
|
'label': __('Open Contact'),
|
2021-02-08 20:13:23 +05:30
|
|
|
'click': () => frappe.set_route('Form', 'Contact', this.get_contact_link().link_name),
|
|
|
|
'depends_on': () => this.get_caller_name()
|
2019-07-16 11:07:25 +05:30
|
|
|
}, {
|
|
|
|
'fieldtype': 'Button',
|
2021-02-08 20:13:23 +05:30
|
|
|
'label': __('Create New Contact'),
|
|
|
|
'click': this.create_new_contact.bind(this),
|
|
|
|
'depends_on': () => !this.get_caller_name()
|
2019-07-16 11:07:25 +05:30
|
|
|
}, {
|
|
|
|
'fieldtype': 'Button',
|
2021-02-08 20:13:23 +05:30
|
|
|
'label': __('Create New Customer'),
|
|
|
|
'click': this.create_new_customer.bind(this),
|
2019-07-16 11:07:25 +05:30
|
|
|
'depends_on': () => !this.get_caller_name()
|
|
|
|
}, {
|
|
|
|
'fieldtype': 'Button',
|
2019-09-12 22:04:49 +05:30
|
|
|
'label': __('Create New Lead'),
|
2019-07-16 11:07:25 +05:30
|
|
|
'click': () => frappe.new_doc('Lead', { 'mobile_no': this.caller_number }),
|
|
|
|
'depends_on': () => !this.get_caller_name()
|
|
|
|
}, {
|
|
|
|
'fieldtype': 'Column Break',
|
|
|
|
}, {
|
|
|
|
'fieldname': 'number',
|
|
|
|
'label': 'Phone Number',
|
|
|
|
'fieldtype': 'Data',
|
|
|
|
'default': this.caller_number,
|
|
|
|
'read_only': 1
|
2019-05-24 10:11:48 +05:30
|
|
|
}, {
|
2019-07-16 11:07:25 +05:30
|
|
|
'fieldtype': 'Section Break',
|
2021-02-08 20:13:23 +05:30
|
|
|
'hide_border': 1,
|
2019-05-16 23:55:35 +05:30
|
|
|
}, {
|
2019-05-18 16:11:29 +05:30
|
|
|
'fieldtype': 'Small Text',
|
2019-06-18 11:28:14 +05:30
|
|
|
'label': __('Call Summary'),
|
2019-05-24 10:11:48 +05:30
|
|
|
'fieldname': 'call_summary',
|
2019-05-18 16:11:29 +05:30
|
|
|
}, {
|
|
|
|
'fieldtype': 'Button',
|
2019-06-18 11:28:14 +05:30
|
|
|
'label': __('Save'),
|
2019-05-18 16:11:29 +05:30
|
|
|
'click': () => {
|
2021-02-08 20:13:23 +05:30
|
|
|
const call_summary = this.call_details.get_value('call_summary');
|
2019-06-11 08:03:55 +05:30
|
|
|
if (!call_summary) return;
|
2020-12-01 13:04:53 +05:30
|
|
|
frappe.xcall('erpnext.telephony.doctype.call_log.call_log.add_call_summary', {
|
2019-07-16 11:07:25 +05:30
|
|
|
'call_log': this.call_log.name,
|
2019-06-11 08:03:55 +05:30
|
|
|
'summary': call_summary,
|
2019-05-24 10:11:48 +05:30
|
|
|
}).then(() => {
|
2019-06-11 08:03:55 +05:30
|
|
|
this.close_modal();
|
|
|
|
frappe.show_alert({
|
2019-08-05 11:32:51 +05:30
|
|
|
message: `
|
|
|
|
${__('Call Summary Saved')}
|
2019-07-16 11:07:25 +05:30
|
|
|
<br>
|
|
|
|
<a
|
|
|
|
class="text-small text-muted"
|
2020-12-18 13:17:58 +05:30
|
|
|
href="/app/call-log/${this.call_log.name}">
|
2019-07-16 11:07:25 +05:30
|
|
|
${__('View call log')}
|
2019-08-05 11:32:51 +05:30
|
|
|
</a>
|
|
|
|
`,
|
2019-06-11 08:03:55 +05:30
|
|
|
indicator: 'green'
|
|
|
|
});
|
2019-05-24 10:11:48 +05:30
|
|
|
});
|
2019-05-18 16:11:29 +05:30
|
|
|
}
|
2019-05-27 10:38:43 +05:30
|
|
|
}],
|
2021-02-08 20:13:23 +05:30
|
|
|
body: this.caller_info
|
2019-05-16 23:55:35 +05:30
|
|
|
});
|
2021-02-08 20:13:23 +05:30
|
|
|
this.call_details.make();
|
2019-05-16 23:55:35 +05:30
|
|
|
}
|
|
|
|
|
2021-02-08 20:13:23 +05:30
|
|
|
is_known_caller() {
|
|
|
|
return Boolean(this.get_caller_name());
|
2019-05-16 23:55:35 +05:30
|
|
|
}
|
2019-05-21 07:57:06 +05:30
|
|
|
|
2021-02-08 20:13:23 +05:30
|
|
|
create_new_customer() {
|
|
|
|
// to avoid quick entry form
|
|
|
|
const new_customer = frappe.model.get_new_doc('Customer');
|
|
|
|
new_customer.mobile_no = this.caller_number;
|
|
|
|
frappe.set_route('Form', new_customer.doctype, new_customer.name);
|
2019-05-24 10:11:48 +05:30
|
|
|
}
|
2019-07-16 11:07:25 +05:30
|
|
|
|
2021-02-08 20:13:23 +05:30
|
|
|
create_new_contact() {
|
|
|
|
// TODO: fix new_doc, it should accept child table values
|
|
|
|
const new_contact = frappe.model.get_new_doc('Contact');
|
|
|
|
const phone_no = frappe.model.add_child(new_contact, 'Contact Phone', 'phone_nos');
|
|
|
|
phone_no.phone = this.caller_number;
|
|
|
|
phone_no.is_primary_mobile_no = 1;
|
|
|
|
frappe.set_route('Form', new_contact.doctype, new_contact.name);
|
2019-06-17 08:46:38 +05:30
|
|
|
}
|
2019-05-16 23:55:35 +05:30
|
|
|
}
|
|
|
|
|
2019-05-18 16:11:29 +05:30
|
|
|
$(document).on('app_ready', function () {
|
2019-06-06 14:48:37 +05:30
|
|
|
frappe.realtime.on('show_call_popup', call_log => {
|
2021-02-08 18:50:05 +05:30
|
|
|
let call_popup = erpnext.call_popup;
|
|
|
|
if (call_popup && call_log.name === call_popup.call_log.name) {
|
|
|
|
call_popup.update_call_log(call_log);
|
|
|
|
call_popup.dialog.show();
|
2021-02-09 12:17:29 +05:30
|
|
|
} else {
|
|
|
|
erpnext.call_popup = new CallPopup(call_log);
|
2019-05-21 07:57:06 +05:30
|
|
|
}
|
2019-05-16 23:55:35 +05:30
|
|
|
});
|
|
|
|
});
|
2021-02-08 20:13:23 +05:30
|
|
|
|
|
|
|
window.CallPopup = CallPopup;
|