Merge branch 'master' of https://github.com/fusionpbx/fusionpbx
This commit is contained in:
commit
20aafafea8
|
|
@ -49,94 +49,85 @@ else {
|
||||||
require_once "resources/header.php";
|
require_once "resources/header.php";
|
||||||
|
|
||||||
if (is_array($_REQUEST) && !empty($_REQUEST['src']) && !empty($_REQUEST['dest'])) {
|
if (is_array($_REQUEST) && !empty($_REQUEST['src']) && !empty($_REQUEST['dest'])) {
|
||||||
//get the http variables and set them as variables
|
//retrieve submitted variables
|
||||||
$src = check_str($_REQUEST['src']);
|
$src = check_str($_REQUEST['src']);
|
||||||
$dest = check_str($_REQUEST['dest']);
|
|
||||||
$ringback = check_str($_REQUEST['ringback']);
|
|
||||||
$src = str_replace(array('.', '(', ')', '-', ' '), '', $src);
|
|
||||||
if (strpbrk($dest, '@') != FALSE) {
|
|
||||||
$dest = str_replace(array('(', ')', ' '), '', $dest); //don't strip periods or dashes in sip-uri calls
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
$dest = str_replace(array('.', '(', ')', '-', ' '), '', $dest); //strip the periods for phone numbers.
|
|
||||||
}
|
|
||||||
$src_cid_name = check_str($_REQUEST['src_cid_name']);
|
$src_cid_name = check_str($_REQUEST['src_cid_name']);
|
||||||
$src_cid_number = check_str($_REQUEST['src_cid_number']);
|
$src_cid_number = check_str($_REQUEST['src_cid_number']);
|
||||||
|
|
||||||
|
$dest = check_str($_REQUEST['dest']);
|
||||||
$dest_cid_name = check_str($_REQUEST['dest_cid_name']);
|
$dest_cid_name = check_str($_REQUEST['dest_cid_name']);
|
||||||
$dest_cid_number = check_str($_REQUEST['dest_cid_number']);
|
$dest_cid_number = check_str($_REQUEST['dest_cid_number']);
|
||||||
|
|
||||||
$auto_answer = check_str($_REQUEST['auto_answer']); //true,false
|
$auto_answer = check_str($_REQUEST['auto_answer']); //true,false
|
||||||
$rec = check_str($_REQUEST['rec']); //true,false
|
$rec = check_str($_REQUEST['rec']); //true,false
|
||||||
if ($auto_answer == "true") {
|
$ringback = check_str($_REQUEST['ringback']);
|
||||||
$sip_auto_answer = "sip_auto_answer=true,";
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
$sip_auto_answer = '';
|
|
||||||
}
|
|
||||||
if (strlen($cid_number) == 0) { $cid_number = $src;}
|
|
||||||
$context = $_SESSION['context'];
|
$context = $_SESSION['context'];
|
||||||
|
|
||||||
//workaround for TBDialout on Thunderbird
|
//clean up variable values
|
||||||
//seems it can only handle the first %NUM%
|
$src = str_replace(array('.','(',')','-',' '), '', $src);
|
||||||
if ($dest == "%NUM%"){
|
$dest = (strpbrk($dest, '@') != FALSE) ? str_replace(array('(',')',' '), '', $dest) : str_replace(array('.','(',')','-',' '), '', $dest); //don't strip periods or dashes in sip-uri calls, only phone numbers
|
||||||
//echo "Thunderbird fix, dest now = $src_cid_number <br>";
|
|
||||||
$dest = $src_cid_number;
|
//adjust variable values
|
||||||
}
|
$sip_auto_answer = ($auto_answer == "true") ? ",sip_auto_answer=true" : null;
|
||||||
|
|
||||||
|
//mozilla thunderbird TBDialout workaround (seems it can only handle the first %NUM%)
|
||||||
|
$dest = ($dest == "%NUM%") ? $src_cid_number : $dest;
|
||||||
|
|
||||||
//translate ringback
|
//translate ringback
|
||||||
switch ($ringback) {
|
switch ($ringback) {
|
||||||
|
case "music": $ringback_value = "\'local_stream://moh\'"; break;
|
||||||
|
case "uk-ring": $ringback_value = "\'%(400,200,400,450);%(400,2200,400,450)\'"; break;
|
||||||
|
case "fr-ring": $ringback_value = "\'%(1500,3500,440.0,0.0)\'"; break;
|
||||||
|
case "pt-ring": $ringback_value = "\'%(1000,5000,400.0,0.0)\'"; break;
|
||||||
|
case "rs-ring": $ringback_value = "\'%(1000,4000,425.0,0.0)\'"; break;
|
||||||
|
case "it-ring": $ringback_value = "\'%(1000,4000,425.0,0.0)\'"; break;
|
||||||
case "us-ring":
|
case "us-ring":
|
||||||
$ringback_value = "\'%(2000,4000,440.0,480.0)\'";
|
|
||||||
break;
|
|
||||||
case "uk-ring":
|
|
||||||
$ringback_value = "\'%(400,200,400,450);%(400,2200,400,450)\'";
|
|
||||||
break;
|
|
||||||
case "fr-ring":
|
|
||||||
$ringback_value = "\'%(1500,3500,440.0,0.0)\'";
|
|
||||||
break;
|
|
||||||
case "pt-ring":
|
|
||||||
$ringback_value = "\'%(1000,5000,400.0,0.0)\'";
|
|
||||||
break;
|
|
||||||
case "rs-ring":
|
|
||||||
$ringback_value = "\'%(1000,4000,425.0,0.0)\'";
|
|
||||||
break;
|
|
||||||
case "it-ring":
|
|
||||||
$ringback_value = "\'%(1000,4000,425.0,0.0)\'";
|
|
||||||
break;
|
|
||||||
case "music":
|
|
||||||
$ringback_value = "\'local_stream://moh\'";
|
|
||||||
break;
|
|
||||||
default:
|
default:
|
||||||
$ringback = 'us-ring';
|
$ringback = 'us-ring';
|
||||||
$ringback_value = "\'%(2000,4000,440.0,480.0)\'";
|
$ringback_value = "\'%(2000,4000,440.0,480.0)\'";
|
||||||
}
|
}
|
||||||
|
|
||||||
//source should see the destination caller id
|
//determine call direction
|
||||||
if (strlen($src) < 7) {
|
$dir = (strlen($dest) < 7) ? 'local' : 'outbound';
|
||||||
$source = "{click_to_call=true,".$sip_auto_answer."origination_caller_id_name='$src_cid_name',origination_caller_id_number=$src_cid_number,instant_ringback=true,ringback=$ringback_value,presence_id=$src@".$_SESSION['domains'][$domain_uuid]['domain_name'].",call_direction=outbound,domain_uuid=".$domain_uuid.",domain_name=".$_SESSION['domains'][$domain_uuid]['domain_name']."}user/$src@".$_SESSION['domains'][$domain_uuid]['domain_name'];
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
$bridge_array = outbound_route_to_bridge ($_SESSION['domain_uuid'], $src);
|
|
||||||
$source = "{click_to_call=true,origination_caller_id_name='$src_cid_name',origination_caller_id_number=$src_cid_number,instant_ringback=true,ringback=$ringback_value,presence_id=$src@".$_SESSION['domains'][$domain_uuid]['domain_name'].",call_direction=outbound}".$bridge_array[0];
|
|
||||||
}
|
|
||||||
|
|
||||||
//destination needs to see the source caller id
|
//define a leg - set source to display the defined caller id name and number
|
||||||
if (strlen($dest) < 7) {
|
$source_common = "{".
|
||||||
if (strpbrk($dest, '@') != FALSE) {
|
"click_to_call=true".
|
||||||
//echo "Found an @ 2<br><br>";
|
",origination_caller_id_name='".$src_cid_name."'".
|
||||||
$switch_cmd = "api originate $source &bridge({origination_caller_id_name='$dest_cid_name',origination_caller_id_number=$dest_cid_number,call_direction=outbound}sofia/external/$dest)";
|
",origination_caller_id_number=".$src_cid_number.
|
||||||
echo "$switch_cmd";
|
",instant_ringback=true".
|
||||||
}
|
",ringback=".$ringback_value.
|
||||||
else {
|
",presence_id=".$src."@".$_SESSION['domains'][$domain_uuid]['domain_name'].
|
||||||
$switch_cmd = "api originate $source &transfer('".$dest." XML ".$context."')";
|
",call_direction=".$dir;
|
||||||
}
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
if (strlen($src) < 7) {
|
if (strlen($src) < 7) {
|
||||||
if (strlen($dest_cid_number) == 0) {
|
//source is a local extension
|
||||||
//get the caller id from the extension caller id comes from the extension (the source number)
|
$source = $source_common.$sip_auto_answer.
|
||||||
$sql = "select * from v_extensions ";
|
",domain_uuid=".$domain_uuid.
|
||||||
$sql .= "where domain_uuid = '".$_SESSION['domain_uuid']."' ";
|
",domain_name=".$_SESSION['domains'][$domain_uuid]['domain_name']."}user/".$src."@".$_SESSION['domains'][$domain_uuid]['domain_name'];
|
||||||
$sql .= "and extension = '$src' ";
|
}
|
||||||
|
else {
|
||||||
|
//source is an external number
|
||||||
|
$bridge_array = outbound_route_to_bridge($_SESSION['domain_uuid'], $src);
|
||||||
|
$source = $source_common."}".$bridge_array[0];
|
||||||
|
}
|
||||||
|
unset($source_common);
|
||||||
|
|
||||||
|
//define b leg - set destination to display the defined caller id name and number
|
||||||
|
$destination_common = " &bridge({origination_caller_id_name='".$dest_cid_name."',origination_caller_id_number=".$dest_cid_number;
|
||||||
|
if (strlen($dest) < 7) {
|
||||||
|
//destination is a local extension
|
||||||
|
if (strpbrk($dest, '@') != FALSE) { //sip-uri
|
||||||
|
$switch_cmd = $destination_common.",call_direction=outbound}sofia/external/".$dest.")";
|
||||||
|
}
|
||||||
|
else { //not sip-uri
|
||||||
|
$switch_cmd = " &transfer('".$dest." XML ".$context."')";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
//local extension (source) > external number (destination)
|
||||||
|
if (strlen($src) < 7 && strlen($dest_cid_number) == 0) {
|
||||||
|
//retrieve outbound caller id from the (source) extension
|
||||||
|
$sql = "select outbound_caller_id_name, outbound_caller_id_number from v_extensions where domain_uuid = '".$_SESSION['domain_uuid']."' and extension = '".$src."' ";
|
||||||
$prep_statement = $db->prepare(check_sql($sql));
|
$prep_statement = $db->prepare(check_sql($sql));
|
||||||
$prep_statement->execute();
|
$prep_statement->execute();
|
||||||
$result = $prep_statement->fetchAll(PDO::FETCH_NAMED);
|
$result = $prep_statement->fetchAll(PDO::FETCH_NAMED);
|
||||||
|
|
@ -147,52 +138,29 @@ if (is_array($_REQUEST) && !empty($_REQUEST['src']) && !empty($_REQUEST['dest'])
|
||||||
}
|
}
|
||||||
unset ($prep_statement);
|
unset ($prep_statement);
|
||||||
}
|
}
|
||||||
}
|
|
||||||
$bridge_array = outbound_route_to_bridge ($_SESSION['domain_uuid'], $dest);
|
|
||||||
$destination = "{origination_caller_id_name='$dest_cid_name',origination_caller_id_number=$dest_cid_number}".$bridge_array[0];
|
|
||||||
if (permission_exists('click_to_call_call')) {
|
if (permission_exists('click_to_call_call')) {
|
||||||
if (strpbrk($dest, '@') != FALSE) {
|
if (strpbrk($dest, '@') != FALSE) { //sip-uri
|
||||||
//call a sip uri
|
$switch_cmd = $destination_common.",call_direction=outbound}sofia/external/".$dest.")";
|
||||||
//echo "Found an @ 4, do nothing for now<br><br>";
|
|
||||||
$switch_cmd = "api originate $source &bridge({origination_caller_id_name='$dest_cid_name',origination_caller_id_number=$dest_cid_number,call_direction=outbound}sofia/external/$dest)";
|
|
||||||
//echo "<br>SWITCH-CMD: $switch_cmd<br>";
|
|
||||||
}
|
}
|
||||||
else {
|
else { //not sip-uri
|
||||||
//regular call
|
$bridge_array = outbound_route_to_bridge($_SESSION['domain_uuid'], $dest);
|
||||||
$switch_cmd = "api originate $source &bridge($destination)";
|
//$switch_cmd = $destination_common."}".$bridge_array[0].")"; // wouldn't set cdr destination correctly, so below used instead
|
||||||
|
$switch_cmd = " &transfer('".$dest." XML ".$context."')";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
unset($destination_common);
|
||||||
//display the last command
|
|
||||||
echo "<div align='center'>\n";
|
|
||||||
echo "<table width='40%'>\n";
|
|
||||||
echo "<tr>\n";
|
|
||||||
echo "<th align='left'>Message</th>\n";
|
|
||||||
echo "</tr>\n";
|
|
||||||
echo "<tr>\n";
|
|
||||||
echo "<td class='row_style1'><strong>$switch_cmd $src has called $dest</strong></td>\n";
|
|
||||||
echo "</tr>\n";
|
|
||||||
echo "</table>\n";
|
|
||||||
echo "</div>\n";
|
|
||||||
|
|
||||||
//create the even socket connection and send the event socket command
|
//create the even socket connection and send the event socket command
|
||||||
$fp = event_socket_create($_SESSION['event_socket_ip_address'], $_SESSION['event_socket_port'], $_SESSION['event_socket_password']);
|
$fp = event_socket_create($_SESSION['event_socket_ip_address'], $_SESSION['event_socket_port'], $_SESSION['event_socket_password']);
|
||||||
if (!$fp) {
|
if (!$fp) {
|
||||||
//show the error message
|
//error message
|
||||||
$msg = "<div align='center'>Connection to Event Socket failed.<br /></div>";
|
echo "<div align='center'><strong>Connection to Event Socket failed.</strong></div>";
|
||||||
echo "<div align='center'>\n";
|
|
||||||
echo "<table width='40%'>\n";
|
|
||||||
echo "<tr>\n";
|
|
||||||
echo " <th align='left'>Message</th>\n";
|
|
||||||
echo "</tr>\n";
|
|
||||||
echo "<tr>\n";
|
|
||||||
echo " <td class='row_style1'><strong>$msg</strong></td>\n";
|
|
||||||
echo "</tr>\n";
|
|
||||||
echo "</table>\n";
|
|
||||||
echo "</div>\n";
|
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
|
//display the last command
|
||||||
|
$switch_cmd = "api originate ".$source.$switch_cmd;
|
||||||
|
echo "<div align='center'>".$switch_cmd."<br /><br /><strong>".$src." has called ".$dest."</strong></div>\n";
|
||||||
//show the command result
|
//show the command result
|
||||||
$result = trim(event_socket_request($fp, $switch_cmd));
|
$result = trim(event_socket_request($fp, $switch_cmd));
|
||||||
if (substr($result, 0,3) == "+OK") {
|
if (substr($result, 0,3) == "+OK") {
|
||||||
|
|
@ -205,12 +173,7 @@ if (is_array($_REQUEST) && !empty($_REQUEST['src']) && !empty($_REQUEST['dest'])
|
||||||
$result2 = trim(event_socket_request($fp, $switch_cmd));
|
$result2 = trim(event_socket_request($fp, $switch_cmd));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
echo "<div align='center'>\n";
|
echo "<div align='center'><br />".$result."<br /><br /></div>\n";
|
||||||
echo "<br />\n";
|
|
||||||
echo $result;
|
|
||||||
echo "<br />\n";
|
|
||||||
echo "<br />\n";
|
|
||||||
echo "</div>\n";
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -361,6 +361,15 @@
|
||||||
)
|
)
|
||||||
and bridge_uuid is null
|
and bridge_uuid is null
|
||||||
and destination_number in ('".implode("','",$assigned_extensions)."')
|
and destination_number in ('".implode("','",$assigned_extensions)."')
|
||||||
|
and (";
|
||||||
|
$x = 0;
|
||||||
|
foreach ($assigned_extensions as $assigned_extension_uuid => $assigned_extension) {
|
||||||
|
$sql .= "extension_uuid = '".$assigned_extension_uuid."' ";
|
||||||
|
$sql .= "or destination_number = '".$assigned_extension."' ";
|
||||||
|
if (++$x < sizeof($assigned_extensions)) { $sql .= "or "; }
|
||||||
|
}
|
||||||
|
$sql .= "
|
||||||
|
)
|
||||||
order by
|
order by
|
||||||
start_epoch desc
|
start_epoch desc
|
||||||
limit ".$missed_limit."
|
limit ".$missed_limit."
|
||||||
|
|
@ -396,9 +405,22 @@
|
||||||
$tmp_month = date("M", strtotime($row['start_stamp']));
|
$tmp_month = date("M", strtotime($row['start_stamp']));
|
||||||
$tmp_day = date("d", strtotime($row['start_stamp']));
|
$tmp_day = date("d", strtotime($row['start_stamp']));
|
||||||
$tmp_start_epoch = (defined('TIME_24HR') && TIME_24HR == 1) ? date("j/n H:i", $row['start_epoch']) : date("j/n h:ia", $row['start_epoch']);
|
$tmp_start_epoch = (defined('TIME_24HR') && TIME_24HR == 1) ? date("j/n H:i", $row['start_epoch']) : date("j/n h:ia", $row['start_epoch']);
|
||||||
|
//set click-to-call variables
|
||||||
$tr_link = "onclick=\"send_cmd('".PROJECT_PATH."/app/click_to_call/click_to_call.php?src_cid_name=".urlencode($row['caller_id_name'])."&src_cid_number=".urlencode($row['caller_id_number'])."&dest_cid_name=".urlencode($_SESSION['user']['extension'][0]['outbound_caller_id_name'])."&dest_cid_number=".urlencode($_SESSION['user']['extension'][0]['outbound_caller_id_number'])."&src=".urlencode($_SESSION['user']['extension'][0]['user'])."&dest=".urlencode($row['caller_id_number'])."&rec=false&ringback=us-ring&auto_answer=true');\"";
|
if (permission_exists('click_to_call_call')) {
|
||||||
$hud[$n]['html'] .= "<tr ".$tr_link." style='cursor: pointer;'>\n";
|
$tr_link = "onclick=\"send_cmd('".PROJECT_PATH."/app/click_to_call/click_to_call.php".
|
||||||
|
"?src_cid_name=".urlencode($row['caller_id_name']).
|
||||||
|
"&src_cid_number=".urlencode($row['caller_id_number']).
|
||||||
|
"&dest_cid_name=".urlencode($_SESSION['user']['extension'][0]['outbound_caller_id_name']).
|
||||||
|
"&dest_cid_number=".urlencode($_SESSION['user']['extension'][0]['outbound_caller_id_number']).
|
||||||
|
"&src=".urlencode($_SESSION['user']['extension'][0]['user']).
|
||||||
|
"&dest=".urlencode($row['caller_id_number']).
|
||||||
|
"&rec=false".
|
||||||
|
"&ringback=us-ring".
|
||||||
|
"&auto_answer=true".
|
||||||
|
"');\" ".
|
||||||
|
"style='cursor: pointer;'";
|
||||||
|
}
|
||||||
|
$hud[$n]['html'] .= "<tr ".$tr_link.">\n";
|
||||||
$hud[$n]['html'] .= "<td valign='top' class='".$row_style[$c]."' style='cursor: help;'>\n";
|
$hud[$n]['html'] .= "<td valign='top' class='".$row_style[$c]."' style='cursor: help;'>\n";
|
||||||
if ($theme_cdr_images_exist) {
|
if ($theme_cdr_images_exist) {
|
||||||
$call_result = ($row['answer_stamp'] != '') ? 'voicemail' : 'cancelled';
|
$call_result = ($row['answer_stamp'] != '') ? 'voicemail' : 'cancelled';
|
||||||
|
|
@ -447,10 +469,11 @@
|
||||||
domain_uuid = '".$_SESSION['domain_uuid']."'
|
domain_uuid = '".$_SESSION['domain_uuid']."'
|
||||||
and (";
|
and (";
|
||||||
$x = 0;
|
$x = 0;
|
||||||
foreach ($assigned_extensions as $assigned_extension) {
|
foreach ($assigned_extensions as $assigned_extension_uuid => $assigned_extension) {
|
||||||
$sql .= "caller_id_number like '".$assigned_extension."' ";
|
$sql .= "extension_uuid = '".$assigned_extension_uuid."' ";
|
||||||
$sql .= "or destination_number like '".$assigned_extension."' ";
|
$sql .= "or caller_id_number = '".$assigned_extension."' ";
|
||||||
$sql .= "or destination_number like '*99".$assigned_extension."' ";
|
$sql .= "or destination_number = '".$assigned_extension."' ";
|
||||||
|
$sql .= "or destination_number = '*99".$assigned_extension."' ";
|
||||||
if (++$x < sizeof($assigned_extensions)) { $sql .= "or "; }
|
if (++$x < sizeof($assigned_extensions)) { $sql .= "or "; }
|
||||||
}
|
}
|
||||||
$sql .= "
|
$sql .= "
|
||||||
|
|
@ -499,17 +522,32 @@
|
||||||
$tmp_start_epoch = (defined('TIME_24HR') && TIME_24HR == 1) ? date("j/n H:i", $row['start_epoch']) : date("j/n h:ia", $row['start_epoch']);
|
$tmp_start_epoch = (defined('TIME_24HR') && TIME_24HR == 1) ? date("j/n H:i", $row['start_epoch']) : date("j/n h:ia", $row['start_epoch']);
|
||||||
|
|
||||||
//determine name
|
//determine name
|
||||||
$cdr_name = ($row['direction'] == 'inbound' || ($row['direction'] == 'local' && in_array($row['destination_number'], $assigned_extensions))) ? $row['caller_id_name'] : " ";
|
$cdr_name = ($row['direction'] == 'inbound' || ($row['direction'] == 'local' && in_array($row['destination_number'], $assigned_extensions))) ? $row['caller_id_name'] : $row['destination_number'];
|
||||||
//determine number to display/click-to-call
|
//determine number to display
|
||||||
if ($row['direction'] == 'inbound' || ($row['direction'] == 'local' && in_array($row['destination_number'], $assigned_extensions))) {
|
if ($row['direction'] == 'inbound' || ($row['direction'] == 'local' && in_array($row['destination_number'], $assigned_extensions))) {
|
||||||
$cdr_number = (is_numeric($row['caller_id_number'])) ? format_phone($row['caller_id_number']) : $row['caller_id_number'];
|
$cdr_number = (is_numeric($row['caller_id_number'])) ? format_phone($row['caller_id_number']) : $row['caller_id_number'];
|
||||||
|
$dest = $row['caller_id_number'];
|
||||||
}
|
}
|
||||||
else if ($row['direction'] == 'outbound' || ($row['direction'] == 'local' && in_array($row['caller_id_number'], $assigned_extensions))) {
|
else if ($row['direction'] == 'outbound' || ($row['direction'] == 'local' && in_array($row['caller_id_number'], $assigned_extensions))) {
|
||||||
$cdr_number = (is_numeric($row['destination_number'])) ? format_phone($row['destination_number']) : $row['destination_number'];
|
$cdr_number = (is_numeric($row['destination_number'])) ? format_phone($row['destination_number']) : $row['destination_number'];
|
||||||
|
$dest = $row['destination_number'];
|
||||||
}
|
}
|
||||||
|
//set click-to-call variables
|
||||||
$tr_link = "onclick=\"send_cmd('".PROJECT_PATH."/app/click_to_call/click_to_call.php?src_cid_name=".urlencode($cdr_name)."&src_cid_number=".urlencode($cdr_number)."&dest_cid_name=".urlencode($_SESSION['user']['extension'][0]['outbound_caller_id_name'])."&dest_cid_number=".urlencode($_SESSION['user']['extension'][0]['outbound_caller_id_number'])."&src=".urlencode($_SESSION['user']['extension'][0]['user'])."&dest=".urlencode($cdr_number)."&rec=false&ringback=us-ring&auto_answer=true');\"";
|
if (permission_exists('click_to_call_call')) {
|
||||||
$hud[$n]['html'] .= "<tr ".$tr_link." style='cursor: pointer;'>\n";
|
$tr_link = "onclick=\"send_cmd('".PROJECT_PATH."/app/click_to_call/click_to_call.php".
|
||||||
|
"?src_cid_name=".urlencode($cdr_name).
|
||||||
|
"&src_cid_number=".urlencode($cdr_number).
|
||||||
|
"&dest_cid_name=".urlencode($_SESSION['user']['extension'][0]['outbound_caller_id_name']).
|
||||||
|
"&dest_cid_number=".urlencode($_SESSION['user']['extension'][0]['outbound_caller_id_number']).
|
||||||
|
"&src=".urlencode($_SESSION['user']['extension'][0]['user']).
|
||||||
|
"&dest=".urlencode($dest).
|
||||||
|
"&rec=false".
|
||||||
|
"&ringback=us-ring".
|
||||||
|
"&auto_answer=true".
|
||||||
|
"');\" ".
|
||||||
|
"style='cursor: pointer;'";
|
||||||
|
}
|
||||||
|
$hud[$n]['html'] .= "<tr ".$tr_link.">\n";
|
||||||
//determine call result and appropriate icon
|
//determine call result and appropriate icon
|
||||||
$hud[$n]['html'] .= "<td valign='top' class='".$row_style[$c]."' style='cursor: help;'>\n";
|
$hud[$n]['html'] .= "<td valign='top' class='".$row_style[$c]."' style='cursor: help;'>\n";
|
||||||
if ($theme_cdr_images_exist) {
|
if ($theme_cdr_images_exist) {
|
||||||
|
|
@ -896,7 +934,7 @@
|
||||||
if ((in_array('missed', $selected_blocks) || in_array('recent', $selected_blocks)) && permission_exists('xml_cdr_view')) {
|
if ((in_array('missed', $selected_blocks) || in_array('recent', $selected_blocks)) && permission_exists('xml_cdr_view')) {
|
||||||
echo "<script type=\"text/javascript\">\n";
|
echo "<script type=\"text/javascript\">\n";
|
||||||
echo " function send_cmd(url) {\n";
|
echo " function send_cmd(url) {\n";
|
||||||
echo " /*\n";
|
//echo " alert(url);\n";
|
||||||
echo " if (window.XMLHttpRequest) { // code for IE7+, Firefox, Chrome, Opera, Safari\n";
|
echo " if (window.XMLHttpRequest) { // code for IE7+, Firefox, Chrome, Opera, Safari\n";
|
||||||
echo " xmlhttp=new XMLHttpRequest();\n";
|
echo " xmlhttp=new XMLHttpRequest();\n";
|
||||||
echo " }\n";
|
echo " }\n";
|
||||||
|
|
@ -906,7 +944,6 @@
|
||||||
echo " xmlhttp.open(\"GET\",url,true);\n";
|
echo " xmlhttp.open(\"GET\",url,true);\n";
|
||||||
echo " xmlhttp.send(null);\n";
|
echo " xmlhttp.send(null);\n";
|
||||||
echo " document.getElementById('cmd_reponse').innerHTML=xmlhttp.responseText;\n";
|
echo " document.getElementById('cmd_reponse').innerHTML=xmlhttp.responseText;\n";
|
||||||
echo " */\n";
|
|
||||||
echo " }\n";
|
echo " }\n";
|
||||||
echo "</script>\n";
|
echo "</script>\n";
|
||||||
}
|
}
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue