mirror of
https://github.com/itflow-org/itflow
synced 2026-03-22 13:35:37 +00:00
Allow entering multiple ticket watchers at once
This commit is contained in:
@@ -21,7 +21,7 @@
|
|||||||
<span class="input-group-text"><i class="fa fa-fw fa-envelope"></i></span>
|
<span class="input-group-text"><i class="fa fa-fw fa-envelope"></i></span>
|
||||||
</div>
|
</div>
|
||||||
<select class="form-control select2" data-tags="true" name="watcher_email">
|
<select class="form-control select2" data-tags="true" name="watcher_email">
|
||||||
<option value="">- Select a contact or enter an email -</option>
|
<option value="">- Select a contact or enter an email(s) -</option>
|
||||||
<?php
|
<?php
|
||||||
|
|
||||||
$sql_client_contacts_select = mysqli_query($mysqli, "SELECT contact_id, contact_name, contact_email FROM contacts WHERE contact_client_id = $client_id AND contact_email <> '' ORDER BY contact_name ASC");
|
$sql_client_contacts_select = mysqli_query($mysqli, "SELECT contact_id, contact_name, contact_email FROM contacts WHERE contact_client_id = $client_id AND contact_email <> '' ORDER BY contact_name ASC");
|
||||||
|
|||||||
@@ -423,66 +423,73 @@ if (isset($_POST['add_ticket_watcher'])) {
|
|||||||
$ticket_id = intval($_POST['ticket_id']);
|
$ticket_id = intval($_POST['ticket_id']);
|
||||||
$client_id = intval($_POST['client_id']);
|
$client_id = intval($_POST['client_id']);
|
||||||
$ticket_number = sanitizeInput($_POST['ticket_number']);
|
$ticket_number = sanitizeInput($_POST['ticket_number']);
|
||||||
$watcher_email = sanitizeInput($_POST['watcher_email']);
|
$watcher_emails = preg_split("/,| |;/", $_POST['watcher_email']); // Split on comma, semicolon or space, we sanitize later
|
||||||
$notify = intval($_POST['watcher_notify']);
|
$notify = intval($_POST['watcher_notify']);
|
||||||
|
|
||||||
mysqli_query($mysqli, "INSERT INTO ticket_watchers SET watcher_email = '$watcher_email', watcher_ticket_id = $ticket_id");
|
// Process each watcher in list
|
||||||
|
foreach ($watcher_emails as $watcher_email) {
|
||||||
|
|
||||||
// Notify watcher
|
|
||||||
if ($notify && !empty($config_smtp_host)) {
|
|
||||||
|
|
||||||
// Get contact/ticket details
|
|
||||||
$sql = mysqli_query($mysqli, "SELECT ticket_prefix, ticket_number, ticket_category, ticket_subject, ticket_details, ticket_priority, ticket_status_name, ticket_url_key, ticket_created_by, ticket_assigned_to, ticket_client_id FROM tickets
|
|
||||||
LEFT JOIN clients ON ticket_client_id = client_id
|
|
||||||
LEFT JOIN contacts ON ticket_contact_id = contact_id
|
|
||||||
LEFT JOIN ticket_statuses ON ticket_status = ticket_status_id
|
|
||||||
WHERE ticket_id = $ticket_id
|
|
||||||
AND ticket_closed_at IS NULL");
|
|
||||||
$row = mysqli_fetch_array($sql);
|
|
||||||
|
|
||||||
$ticket_prefix = sanitizeInput($row['ticket_prefix']);
|
|
||||||
$ticket_number = intval($row['ticket_number']);
|
|
||||||
$ticket_category = sanitizeInput($row['ticket_category']);
|
|
||||||
$ticket_subject = sanitizeInput($row['ticket_subject']);
|
|
||||||
$ticket_details = mysqli_escape_string($mysqli, $row['ticket_details']);
|
|
||||||
$ticket_priority = sanitizeInput($row['ticket_priority']);
|
|
||||||
$ticket_status = sanitizeInput($row['ticket_status_name']);
|
|
||||||
$url_key = sanitizeInput($row['ticket_url_key']);
|
|
||||||
$client_id = intval($row['ticket_client_id']);
|
|
||||||
$ticket_created_by = intval($row['ticket_created_by']);
|
|
||||||
$ticket_assigned_to = intval($row['ticket_assigned_to']);
|
|
||||||
|
|
||||||
// Get Company Phone Number
|
|
||||||
$sql = mysqli_query($mysqli, "SELECT company_name, company_phone, company_phone_country_code FROM companies WHERE company_id = 1");
|
|
||||||
$row = mysqli_fetch_array($sql);
|
|
||||||
$company_name = sanitizeInput($row['company_name']);
|
|
||||||
$company_phone = sanitizeInput(formatPhoneNumber($row['company_phone'], $row['company_phone_country_code']));
|
|
||||||
|
|
||||||
// Email content
|
|
||||||
$data = []; // Queue array
|
|
||||||
|
|
||||||
$subject = "Ticket Notification - [$ticket_prefix$ticket_number] - $ticket_subject";
|
|
||||||
$body = "<i style=\'color: #808080\'>##- Please type your reply above this line -##</i><br><br>Hello,<br><br>You have been added as a collaborator on this ticket regarding \"$ticket_subject\".<br><br>--------------------------------<br>$ticket_details--------------------------------<br><br>Ticket: $ticket_prefix$ticket_number<br>Subject: $ticket_subject<br>Status: $ticket_status<br>Guest link: https://$config_base_url/guest/guest_view_ticket.php?ticket_id=$ticket_id&url_key=$url_key<br><br>--<br>$company_name - Support<br>$config_ticket_from_email<br>$company_phone";
|
|
||||||
|
|
||||||
// Only add watcher to email queue if email is valid
|
|
||||||
if (filter_var($watcher_email, FILTER_VALIDATE_EMAIL)) {
|
if (filter_var($watcher_email, FILTER_VALIDATE_EMAIL)) {
|
||||||
$data[] = [
|
|
||||||
'from' => $config_ticket_from_email,
|
$watcher_email = sanitizeInput($watcher_email);
|
||||||
'from_name' => $config_ticket_from_name,
|
|
||||||
'recipient' => $watcher_email,
|
mysqli_query($mysqli, "INSERT INTO ticket_watchers SET watcher_email = '$watcher_email', watcher_ticket_id = $ticket_id");
|
||||||
'recipient_name' => $watcher_email,
|
|
||||||
'subject' => $subject,
|
// Notify watcher
|
||||||
'body' => $body
|
if ($notify && !empty($config_smtp_host)) {
|
||||||
];
|
|
||||||
|
// Get contact/ticket details
|
||||||
|
$sql = mysqli_query($mysqli, "SELECT ticket_prefix, ticket_number, ticket_category, ticket_subject, ticket_details, ticket_priority, ticket_status_name, ticket_url_key, ticket_created_by, ticket_assigned_to, ticket_client_id FROM tickets
|
||||||
|
LEFT JOIN clients ON ticket_client_id = client_id
|
||||||
|
LEFT JOIN contacts ON ticket_contact_id = contact_id
|
||||||
|
LEFT JOIN ticket_statuses ON ticket_status = ticket_status_id
|
||||||
|
WHERE ticket_id = $ticket_id
|
||||||
|
AND ticket_closed_at IS NULL");
|
||||||
|
$row = mysqli_fetch_array($sql);
|
||||||
|
|
||||||
|
$ticket_prefix = sanitizeInput($row['ticket_prefix']);
|
||||||
|
$ticket_number = intval($row['ticket_number']);
|
||||||
|
$ticket_category = sanitizeInput($row['ticket_category']);
|
||||||
|
$ticket_subject = sanitizeInput($row['ticket_subject']);
|
||||||
|
$ticket_details = mysqli_escape_string($mysqli, $row['ticket_details']);
|
||||||
|
$ticket_priority = sanitizeInput($row['ticket_priority']);
|
||||||
|
$ticket_status = sanitizeInput($row['ticket_status_name']);
|
||||||
|
$url_key = sanitizeInput($row['ticket_url_key']);
|
||||||
|
$client_id = intval($row['ticket_client_id']);
|
||||||
|
$ticket_created_by = intval($row['ticket_created_by']);
|
||||||
|
$ticket_assigned_to = intval($row['ticket_assigned_to']);
|
||||||
|
|
||||||
|
// Get Company Phone Number
|
||||||
|
$sql = mysqli_query($mysqli, "SELECT company_name, company_phone, company_phone_country_code FROM companies WHERE company_id = 1");
|
||||||
|
$row = mysqli_fetch_array($sql);
|
||||||
|
$company_name = sanitizeInput($row['company_name']);
|
||||||
|
$company_phone = sanitizeInput(formatPhoneNumber($row['company_phone'], $row['company_phone_country_code']));
|
||||||
|
|
||||||
|
// Email content
|
||||||
|
$data = []; // Queue array
|
||||||
|
|
||||||
|
$subject = "Ticket Notification - [$ticket_prefix$ticket_number] - $ticket_subject";
|
||||||
|
$body = "<i style=\'color: #808080\'>##- Please type your reply above this line -##</i><br><br>Hello,<br><br>You have been added as a collaborator on this ticket regarding \"$ticket_subject\".<br><br>--------------------------------<br>$ticket_details--------------------------------<br><br>Ticket: $ticket_prefix$ticket_number<br>Subject: $ticket_subject<br>Status: $ticket_status<br>Guest link: https://$config_base_url/guest/guest_view_ticket.php?ticket_id=$ticket_id&url_key=$url_key<br><br>--<br>$company_name - Support<br>$config_ticket_from_email<br>$company_phone";
|
||||||
|
|
||||||
|
$data[] = [
|
||||||
|
'from' => $config_ticket_from_email,
|
||||||
|
'from_name' => $config_ticket_from_name,
|
||||||
|
'recipient' => $watcher_email,
|
||||||
|
'recipient_name' => $watcher_email,
|
||||||
|
'subject' => $subject,
|
||||||
|
'body' => $body
|
||||||
|
];
|
||||||
|
|
||||||
|
addToMailQueue($data);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Logging
|
||||||
|
logAction("Ticket", "Edit", "$session_name added $watcher_email as a watcher for ticket $config_ticket_prefix$ticket_number", $client_id, $ticket_id);
|
||||||
}
|
}
|
||||||
|
|
||||||
addToMailQueue($data);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Logging
|
$_SESSION['alert_message'] = "Added watcher(s)";
|
||||||
logAction("Ticket", "Edit", "$session_name added $watcher_email as a watcher for ticket $ticket_prefix$ticket_number", $client_id, $ticket_id);
|
|
||||||
|
|
||||||
$_SESSION['alert_message'] = "Added <strong>$watcher_email</strong> as a watcher";
|
|
||||||
|
|
||||||
header("Location: " . $_SERVER["HTTP_REFERER"]);
|
header("Location: " . $_SERVER["HTTP_REFERER"]);
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user