Achtung AddressModel Anpassungen

Features:
•	Termin Typen wurden erweitert
o	IBN ESTMK (Kundensuche alles außer Xinon)
o	IBN Snopp (Kundensuche alles außer Xinon)
o	Störungen (Ticketsuche)
	Derzeit werden Ticket Informationen wie bei IBN (Betreff und Ort eingesetzt, wenn leer) bzw. die Beschreibung erhält den Ticket Link und das Subjekt des Tickets (Ticket Link derzeit nur im Outlook Anklickbar (offene Punkte Hyperlinks))
•	Symbole der Termin Typen angepasst
•	Für Outlook werden für die verschiedenen Termintypen derzeit die Standard Kategorien in Deutsch hergenommen (Anfrage zwecks zentraler Kategorien läuft)
o	Gelbe Kategorie … IBN Xinon
o	Grüne Kategorie … IBN ESTMK
o	Lila Kategorie … IBN Snopp
o	Rote Kategorie … Störung

•	Filter wurden eingebaut
o	Es kann nun explizit nach Termintypen gefiltert werden
o	Es können auch Termintypen in Kombination gefiltert werden
•	Vorlagen können nun selbst erstellt und bearbeitet werden
o	Dynamische Felder
	Datum [&&date&&] … Startdatum des Termins
	Start [&&start&&] … Startuhrzeit des Termins
	Ende [&&end&&] … Enduhrzeit des Termins
	dyn. VM/NM [&&vmnm&&] … dynamisch vormittags oder nachmittags je nach Startzeit > 12:00 = nachmittags
o	Vorlagen sind jeweils für jeden IBN Termin Typ zu erstellen
o	Es darf nur 1ne Reminder Vorlage per Termintyp geben
Bugfix:
•	Mehrfachanzeigebug vom gleichen Termin, wenn der Termin mehrfach in kurzer Zeit verschoben oder vergrößert/verkleinert wurde.
•	Tolltipps verschwinden jetzt nicht, wenn man direkt darauf fährt.
This commit is contained in:
Daniel Spitzer
2025-01-27 09:15:15 +01:00
parent 8896bd27b6
commit 6917b1dce6
10 changed files with 408 additions and 85 deletions

View File

@@ -77,8 +77,27 @@ endforeach;
<div class="card-body mb-3 "> <div class="card-body mb-3 ">
<div class="row "> <div class="row ">
<div class="col-12"> <div class="col-12">
<div class="float-left"> <div class="float-left mb-2">
<h4 class="header-title">Kalender</h4> <h4 class="header-title d-inline-block mr-1">Filter:</h4>
<div class="d-inline-block">
<button title="Xinon Inbetriebnahmen"
class="btn btn-light btn-light-search top-search-filter" data-ctype="2"><img
class="logo-top-search" src='/img/xinon-logo.png'></button>
<button title="ESTMK Inbetriebnahmen"
class="btn btn-light btn-light-search top-search-filter" data-ctype="3"><img
class="logo-top-search"
src='/img/estmk_logo.png'>
</button>
<button title="SNOPP Inbetriebnahmen"
class="btn btn-light btn-light-search top-search-filter" data-ctype="4"><img
class="logo-top-search"
src='/img/snop-logo.png'>
</button>
<button title="Störungen" data-ctype="5"
class="btn btn-light btn-light-search top-search-filter"><i
class="fa-duotone fa-solid fa-triangle-exclamation fa-calendar-alert fa-calendar-alert-search"></i>
</button>
</div>
</div> </div>
<?php if (!$rights) : ?> <?php if (!$rights) : ?>
<div class="alert alert-danger" role="alert"> <div class="alert alert-danger" role="alert">
@@ -86,7 +105,6 @@ endforeach;
</div> </div>
<?php die(); endif; ?> <?php die(); endif; ?>
<div class="d-inline-block w-50 search-div" style="margin-top: -7px;"> <div class="d-inline-block w-50 search-div" style="margin-top: -7px;">
<select id="jumpevent" class="jumpevent"></select> <select id="jumpevent" class="jumpevent"></select>
</div> </div>
@@ -96,13 +114,13 @@ endforeach;
</div> </div>
</div> </div>
<div clas="row"> <div clas="row">
</div> </div>
<div class="row "> <div class="row ">
<div id="calendar-side-div" class="col-12 col-lg-2"> <div id="calendar-side-div" class="col-12 col-lg-2">
<div class="calendar-side-borders-main"> <div class="calendar-side-borders-main">
<h3 class="no-movable" data-calendarid="<?= $Calendar[0]->go_calendar_id ?>" data-id="<?= $Calendar[0]->id ?>" id="calendar-id">Kalender <h3 class="no-movable" data-calendarid="<?= $Calendar[0]->go_calendar_id ?>"
data-id="<?= $Calendar[0]->id ?>" id="calendar-id">Kalender
<div class="add-cal-group-div"><i title="Kalendergruppe hinzufügen" <div class="add-cal-group-div"><i title="Kalendergruppe hinzufügen"
class="fa-duotone fa-solid fa-rectangle-history-circle-plus"></i> class="fa-duotone fa-solid fa-rectangle-history-circle-plus"></i>
</div> </div>
@@ -159,52 +177,11 @@ endforeach;
<?= ($CalendarAll[$calendar['calendar_id']]->user->name) ?: $specialCalendars[$calendar['calendar_id']] ?> <?= ($CalendarAll[$calendar['calendar_id']]->user->name) ?: $specialCalendars[$calendar['calendar_id']] ?>
</label> </label>
</div> </div>
<?php endforeach; <?php endforeach; ?>
// foreach ($Rights as $key => $calendar):
?>
<!---->
<!-- <div class="form-check text-left ml-2"-->
<!-- data-origin="-->
<?php //= $calendar['origin']
?><!--">-->
<!-- <input data-calendar_id="-->
<?php //= $calendar['calendar_id']
?><!--"-->
<!-- class="form-check-input calendar-check"-->
<!-- name="form-check-input" type="checkbox"-->
<!-- --><?php //= ($calendar['checked']) ? 'checked="checked"' : ''
?>
<!-- value="2">-->
<!-- <input-->
<!-- data-calendar_id="-->
<?php //= $calendar['calendar_id']
?><!--"-->
<!-- type="color"-->
<!-- class="form-control-color color-input"-->
<!-- value="-->
<?php //= $Calendar_colors[$key]['bgcolor']
?><!--"-->
<!-- title="Hintergrundfarbe">-->
<!-- <input data-calendar_id="-->
<?php //= $calendar['calendar_id']
?><!--"-->
<!-- type="color"-->
<!-- class="form-control-color color-text-input"-->
<!-- value="-->
<?php //= ($Calendar_colors[$key]['txtcolor']) ? $Calendar_colors[$key]['txtcolor'] : '#000000'
?><!--"-->
<!-- title="Textfarbe">-->
<!-- <label class="calendar-side-label" style="margin-top:2px;">-->
<!-- --><?php //= ($CalendarAll[$key]->user->name) ?: $specialCalendars[$calendar['calendar_id']]
?>
<!-- </label>-->
<!-- </div>-->
<!-- --><?php //endforeach;
?>
</div> </div>
</div> </div>
<?php endforeach; <?php endforeach;
// var_dump($Rights); // var_dump($Rights);
?> ?>
</div> </div>
<?php else : ?> <?php else : ?>
@@ -393,7 +370,10 @@ endforeach;
<span title="Erinnerung" class="input-group-text spanwidht">Typ</span> <span title="Erinnerung" class="input-group-text spanwidht">Typ</span>
<select class="form-control form-select" aria-label="Default select" id="type"> <select class="form-control form-select" aria-label="Default select" id="type">
<option value="1">Termin</option> <option value="1">Termin</option>
<option value="2">IBN</option> <option value="2">IBN Xinon</option>
<option value="3">IBN ESTMK</option>
<option value="4">IBN SNOPP</option>
<option value="5">Störung</option>
</select> </select>
</div> </div>
</div> </div>
@@ -565,7 +545,8 @@ endforeach;
</div> </div>
<div class="d-inline-block ml-2"> <div class="d-inline-block ml-2">
<div class="dropdown"> <div class="dropdown">
<button style="padding: 1px 8px;" id="preview-button" class="btn btn-info dropdown-toggle" <button style="padding: 1px 8px;" id="preview-button"
class="btn btn-info dropdown-toggle"
type="button" data-toggle="dropdown" aria-expanded="false"> type="button" data-toggle="dropdown" aria-expanded="false">
Vorlagen Vorlagen
</button> </button>
@@ -589,6 +570,7 @@ endforeach;
</div> </div>
</div> </div>
</div> </div>
<div class="customer-div customer-info-div"> <div class="customer-div customer-info-div">
<div class="row mt-2 justify-content-center"> <div class="row mt-2 justify-content-center">
<div class="col-10"> <div class="col-10">
@@ -606,6 +588,19 @@ endforeach;
</div> </div>
</div> </div>
</div> </div>
<div class="ticket-div">
<div class="row mt-2 justify-content-center">
<div class="col-2">
<label for="location" class="col-form-label fw-medium">Ticket</label>
</div>
<div class="col-8">
<div id="relContainer3" style="position:relative">
<select id="ticket" class="jumpevent"></select>
</div>
</div>
</div>
</div>
<div id="documents" class="row mt-2 mb-2 justify-content-center"> <div id="documents" class="row mt-2 mb-2 justify-content-center">
<div class="col-10" id="attachments" data-newkey=""> <div class="col-10" id="attachments" data-newkey="">
<label class="col-form-label fw-medium">Anlagen</label> <label class="col-form-label fw-medium">Anlagen</label>
@@ -660,6 +655,7 @@ endforeach;
let requestEventAttachmentTmpDeleteUrl = "<?= self::getUrl("Calendar", "api", ['do' => 'deleteCalendarEventAttachmentTmp']) ?>"; let requestEventAttachmentTmpDeleteUrl = "<?= self::getUrl("Calendar", "api", ['do' => 'deleteCalendarEventAttachmentTmp']) ?>";
let requestEventAttachmentUploadUrl = "<?= self::getUrl("Calendar", "api", ['do' => 'uploadCalendarEventAttachment']) ?>"; let requestEventAttachmentUploadUrl = "<?= self::getUrl("Calendar", "api", ['do' => 'uploadCalendarEventAttachment']) ?>";
let requestAddressUrl = "<?= self::getUrl("Calendar", "api", ['do' => 'getAddress']) ?>"; let requestAddressUrl = "<?= self::getUrl("Calendar", "api", ['do' => 'getAddress']) ?>";
let requestTicketUrl = "<?= self::getUrl("Calendar", "api", ['do' => 'getTicket']) ?>";
let requestInsertUrl = "<?= self::getUrl("Calendar", "api", ['do' => 'insertCalendarEvent']) ?>"; let requestInsertUrl = "<?= self::getUrl("Calendar", "api", ['do' => 'insertCalendarEvent']) ?>";
let requestUpdateUrl = "<?= self::getUrl("Calendar", "api", ['do' => 'updateCalendarEvent']) ?>"; let requestUpdateUrl = "<?= self::getUrl("Calendar", "api", ['do' => 'updateCalendarEvent']) ?>";
let requestUpdateStateUrl = "<?= self::getUrl("Calendar", "api", ['do' => 'updateCalendarEventState']) ?>"; let requestUpdateStateUrl = "<?= self::getUrl("Calendar", "api", ['do' => 'updateCalendarEventState']) ?>";

View File

@@ -493,11 +493,19 @@ class AddressModel {
if (array_key_exists("Controller!", $filter)) { if (array_key_exists("Controller!", $filter)) {
$termstring = trim($filter['search_term!']); $termstring = trim($filter['search_term!']);
$xinon= $filter['xinon'];
$termExplode = explode(" ", $termstring); $termExplode = explode(" ", $termstring);
if ($xinon == 1) {
foreach ($termExplode as $term) { foreach ($termExplode as $term) {
$wherestring .= " AND (`customer_number` LIKE '%" . $term . "%' OR `company` LIKE '%" . $term . "%' OR `firstname` LIKE '%" . $term . "%' OR `lastname` LIKE '%" . $term . "%' OR `street` LIKE '%" . $term . "%' OR `zip` LIKE '%" . $term . "%' OR `city` LIKE '%" . $term . "%') "; $wherestring .= " AND (`customer_number` LIKE '%" . $term . "%' OR `company` LIKE '%" . $term . "%' OR `firstname` LIKE '%" . $term . "%' OR `lastname` LIKE '%" . $term . "%' OR `street` LIKE '%" . $term . "%' OR `zip` LIKE '%" . $term . "%' OR `city` LIKE '%" . $term . "%') ";
} }
$where .= " AND customer_number > 0 $wherestring"; $where .= " AND customer_number > 0 $wherestring";
} else {
foreach ($termExplode as $term) {
$wherestring .= " AND (`company` LIKE '%" . $term . "%' OR `firstname` LIKE '%" . $term . "%' OR `lastname` LIKE '%" . $term . "%' OR `street` LIKE '%" . $term . "%' OR `zip` LIKE '%" . $term . "%' OR `city` LIKE '%" . $term . "%') ";
}
$where .= " AND customer_number is NULL $wherestring";
}
} }
// var_dump($filter, $where);exit; // var_dump($filter, $where);exit;

View File

@@ -85,7 +85,10 @@ class CalendarController extends mfBaseController
case "getAddress": case "getAddress":
$r = $this->request; $r = $this->request;
$this->getAddress($r); $this->getAddress($r);
die();
case "getTicket";
$r = $this->request;
$this->getTicket($r);
die(); die();
case "insertCalendarEvent": case "insertCalendarEvent":
$r = $this->request; $r = $this->request;
@@ -247,7 +250,8 @@ class CalendarController extends mfBaseController
private function getAddress($r) private function getAddress($r)
{ {
$address = AddressModel::search(array("Controller!" => 'Calendar', "search_term!" => $r->term), array('count' => '20')); $xinon = $r->xinon;
$address = AddressModel::search(array("Controller!" => 'Calendar', "search_term!" => $r->term, "xinon" => $xinon), array('count' => '20'));
$mobiles = CalendarModel::$austrian_mobile_prefixes; $mobiles = CalendarModel::$austrian_mobile_prefixes;
$prefixes = array('0043', '43 ', '43', '0'); $prefixes = array('0043', '43 ', '43', '0');
foreach ($address as $key => $value) { foreach ($address as $key => $value) {
@@ -323,6 +327,32 @@ class CalendarController extends mfBaseController
echo trim($json); echo trim($json);
die(); die();
} }
private function getTicket($r)
{
$project = new XinonProject();
$data=$project->searchSupportTickets($r->term);
foreach ($data as $key => $value) {
$rows[] = array(
'id' => $value['id'],
'text' => 'Ticket: '.$value['id']." ".$value['subject'],
'subject' => $value['subject'],
'mail' => $value['customField5'],
'mobilenumber' => $value['customField4'],
'location' => $value['customField3'],
'name' => $value['customField2']
);
}
$json['incomplete_results'] = false;
$json['total_count'] = count($rows);
$json['items'] = $rows;
$json = json_encode($json);
echo trim($json);
die();
}
protected function indexAction() protected function indexAction()
{ {

View File

@@ -42,7 +42,12 @@ class CalendarModel
'#dbbeb3', '#e9aebc', '#b5cae7', '#dec2d4', '#aebbd5', '#dbbeb3', '#e9aebc', '#b5cae7', '#dec2d4', '#aebbd5',
'#e2baaf', '#b6ebd5', '#a9c4bb', '#d7d2c5', '#d7e3d4' '#e2baaf', '#b6ebd5', '#a9c4bb', '#d7d2c5', '#d7e3d4'
]; ];
public static $eventCategories = array(
2 => 'Gelbe Kategorie', //Xinon IBN
3 => 'Grüne Kategorie', //ESTMK IBN
4 => 'Lila Kategorie', //Snopp IBN
5 => 'Rote Kategorie', //Störung
);
public static $specialCalendarColors = array(997 => '#bd0000', 998 => '#8000A3', 999 => '#08769b'); public static $specialCalendarColors = array(997 => '#bd0000', 998 => '#8000A3', 999 => '#08769b');
public static function convertToSummertime($timestamp) public static function convertToSummertime($timestamp)
@@ -174,10 +179,16 @@ class CalendarModel
$where = ""; $where = "";
} }
$visibleCalendars = $r->visibleCalendars; $visibleCalendars = $r->visibleCalendars;
$visibleCalendarTypes = $r->visibleCalendarTypes;
if ($visibleCalendars) { if ($visibleCalendars) {
$where .= " AND calendar_id IN (" . implode(",", $visibleCalendars) . ")"; $where .= " AND calendar_id IN (" . implode(",", $visibleCalendars) . ")";
$whereTimeRecording = " AND `Calendar`.`go_calendar_id` IN (" . implode(",", $visibleCalendars) . ")"; $whereTimeRecording = " AND `Calendar`.`go_calendar_id` IN (" . implode(",", $visibleCalendars) . ")";
} }
if ($visibleCalendarTypes) {
$where .= " AND event_type IN (" . implode(",", $visibleCalendarTypes) . ")";
}
$sql = "SELECT `cal_events`.id,`cal_events`.categories, uuid, calendar_id, `cal_events`.user_id, start_time, end_time, timezone, all_day_event, `cal_events`.name,`cal_calendars`.name calendar_name, description, location, repeat_end_time, reminder, ctime,cname, mtime,mname, muser_id, busy, status, resource_event_id, private, rrule, `cal_events`.background, `cal_events`.files_folder_id, read_only, category_id, exception_for_event_id, recurrence_id, is_organizer,event_type,busy,recurrence,rrule_events FROM cal_events INNER JOIN `cal_calendars` ON (`cal_calendars`.`id`=`cal_events`.`calendar_id`) WHERE 1=1 $where "; $sql = "SELECT `cal_events`.id,`cal_events`.categories, uuid, calendar_id, `cal_events`.user_id, start_time, end_time, timezone, all_day_event, `cal_events`.name,`cal_calendars`.name calendar_name, description, location, repeat_end_time, reminder, ctime,cname, mtime,mname, muser_id, busy, status, resource_event_id, private, rrule, `cal_events`.background, `cal_events`.files_folder_id, read_only, category_id, exception_for_event_id, recurrence_id, is_organizer,event_type,busy,recurrence,rrule_events FROM cal_events INNER JOIN `cal_calendars` ON (`cal_calendars`.`id`=`cal_events`.`calendar_id`) WHERE 1=1 $where ";
$res = $dbcal->query($sql); $res = $dbcal->query($sql);
@@ -407,11 +418,10 @@ WHERE `TimerecordingCategory`.`hourday`!='1' AND `TimerecordingCategory`.`hourda
$sql = "SELECT `id`,`name`,`customer_info_send`,`start_time`,`end_time`,`event_type` FROM `cal_events` WHERE `customer_info_reminder`= 1 AND `customer_info_send` IS NOT NULL AND `event_type` > 1 AND `start_time` BETWEEN $timecalcstart AND $timecalcend"; $sql = "SELECT `id`,`name`,`customer_info_send`,`start_time`,`end_time`,`event_type` FROM `cal_events` WHERE `customer_info_reminder`= 1 AND `customer_info_send` IS NOT NULL AND `event_type` > 1 AND `start_time` BETWEEN $timecalcstart AND $timecalcend";
$res = $dbcal->query($sql); $res = $dbcal->query($sql);
while ($data = $dbcal->fetch_array($res)) while ($data = $dbcal->fetch_array($res)) {
{
$rows[] = array( $rows[] = array(
'id' => $data['id'], 'id' => $data['id'],
'name' => $data['name'], 'name' => $data['name'],
'customer_info_send' => $data['customer_info_send'], 'customer_info_send' => $data['customer_info_send'],
'start_time' => $data['start_time'], 'start_time' => $data['start_time'],
'end_time' => $data['end_time'], 'end_time' => $data['end_time'],
@@ -608,13 +618,15 @@ WHERE `TimerecordingCategory`.`hourday`!='1' AND `TimerecordingCategory`.`hourda
header('Content-Type: application/json'); header('Content-Type: application/json');
$db = self::dbKalender(); $db = self::dbKalender();
$sql = "SELECT `cal_events`.id,microsoft_id,uuid,ms_user_id FROM `cal_events` INNER JOIN `cal_calendars` ON (`cal_calendars`.`id`=`cal_events`.`calendar_id`) WHERE `cal_events`.id = '" . $id . "' LIMIT 1"; $sql = "SELECT `cal_events`.id,microsoft_id,uuid,ms_user_id,categories FROM `cal_events` INNER JOIN `cal_calendars` ON (`cal_calendars`.`id`=`cal_events`.`calendar_id`) WHERE `cal_events`.id = '" . $id . "' LIMIT 1";
$res = $db->query($sql); $res = $db->query($sql);
if ($db->num_rows($res)) { if ($db->num_rows($res)) {
$result = $db->fetch_object($res); $result = $db->fetch_object($res);
$microsoft_id = $result->microsoft_id; $microsoft_id = $result->microsoft_id;
$cal_events_id = $result->uuid; $cal_events_id = $result->uuid;
$microsoft_user_id = $result->ms_user_id; $microsoft_user_id = $result->ms_user_id;
$categories = json_decode($result->categories, true);
} }
$updateArray['start_time'] = $start; $updateArray['start_time'] = $start;
@@ -643,13 +655,31 @@ WHERE `TimerecordingCategory`.`hourday`!='1' AND `TimerecordingCategory`.`hourda
else else
$updateArray['reminder'] = $reminder; $updateArray['reminder'] = $reminder;
} }
if ($type) if ($type) {
$updateArray['event_type'] = $type; $updateArray['event_type'] = $type;
$calEventCategories = self::$eventCategories;
foreach ($calEventCategories as $key => $value) {
$arraykey = array_search($value, $categories);
if (!empty($arraykey || $arraykey === 0)) {
unset($categories[$arraykey]);
}
}
if ($type > 1) {
$categories[] = $calEventCategories[$type];
$categories = array_values($categories);
}
if ($categories) {
$updateArray['categories'] = json_encode($categories);
} else
$updateArray['categories'] = NULL;
}
if (isset($busy)) if (isset($busy))
$updateArray['busy'] = $busy; $updateArray['busy'] = $busy;
if ($type == 2) { if ($type == 2 || $type == 3 || $type == 4) {
if ($r->customer) if ($r->customer)
$updateArray['customer'] = $r->customer; $updateArray['customer'] = $r->customer;
else else
@@ -815,7 +845,15 @@ WHERE `TimerecordingCategory`.`hourday`!='1' AND `TimerecordingCategory`.`hourda
if ($reminder == 'NULL') { if ($reminder == 'NULL') {
$reminder = NULL; $reminder = NULL;
} }
if ($type == 2) { $calEventCategories = self::$eventCategories;
if ($type > 1) {
$categories[] = $calEventCategories[$type];
}
if ($categories) {
$categories = json_encode($categories);
} else
$categories = NULL;
if ($type == 2 || $type == 3 || $type == 4) {
$customer = $r->customer; $customer = $r->customer;
$customer_info_type = $r->customer_info_type; $customer_info_type = $r->customer_info_type;
$customer_info_text = $r->customer_info_text; $customer_info_text = $r->customer_info_text;
@@ -836,7 +874,7 @@ WHERE `TimerecordingCategory`.`hourday`!='1' AND `TimerecordingCategory`.`hourda
$customer_info_send = NULL; $customer_info_send = NULL;
} }
$dataarray = array("start_time" => $start, 'end_time' => $end, 'name' => $title, 'description' => $description, 'location' => $location, 'calendar_id' => $user_id, 'uuid' => "a5eb79b3-fca7-5378-a09e-" . rand(100000000000, 999999999999), 'user_id' => 1, 'timezone' => 'Europe/Amsterdam', 'all_day_event' => 0, 'repeat_end_time' => 0, 'reminder' => $reminder, 'ctime' => time(), 'cname' => $me->name, 'mtime' => time(), 'mname' => $me->name, 'user_id' => 1, 'busy' => $busy, 'status' => 'CONFIRMED', 'resource_event_id' => 0, 'private' => $privateflag, 'rrule' => '', 'background' => 'EBF1E2', 'files_folder_id' => 0, 'read_only' => 0, 'exception_for_event_id' => 0, 'recurrence_id' => 0, 'is_organizer' => 1, 'event_type' => $type, 'customer' => $customer, 'customer_info' => $customer_info, 'customer_info_send' => $customer_info_send, 'customer_info_reminder' => $customer_info_reminder_check); $dataarray = array("start_time" => $start, 'end_time' => $end, 'name' => $title, 'description' => $description, 'location' => $location, 'calendar_id' => $user_id, 'uuid' => "a5eb79b3-fca7-5378-a09e-" . rand(100000000000, 999999999999), 'user_id' => 1, 'timezone' => 'Europe/Amsterdam', 'all_day_event' => 0, 'repeat_end_time' => 0, 'reminder' => $reminder, 'ctime' => time(), 'cname' => $me->name, 'mtime' => time(), 'mname' => $me->name, 'user_id' => 1, 'busy' => $busy, 'status' => 'CONFIRMED', 'resource_event_id' => 0, 'private' => $privateflag, 'rrule' => '', 'background' => 'EBF1E2', 'files_folder_id' => 0, 'read_only' => 0,'categories'=>$categories, 'exception_for_event_id' => 0, 'recurrence_id' => 0, 'is_organizer' => 1, 'event_type' => $type, 'customer' => $customer, 'customer_info' => $customer_info, 'customer_info_send' => $customer_info_send, 'customer_info_reminder' => $customer_info_reminder_check);
$db->insert("cal_events", $dataarray); $db->insert("cal_events", $dataarray);
$event_id = $dataarray['uuid']; $event_id = $dataarray['uuid'];

View File

@@ -9,7 +9,7 @@ class CalendarTemplateModel
public static $calendarTemplateEventTypes=array( public static $calendarTemplateEventTypes=array(
"1"=>"Termin", "1"=>"Termin",
"2"=>"IBN", "2"=>"IBN Xinon",
"3"=>"IBN E-Stmk", "3"=>"IBN E-Stmk",
"4"=>"IBN Snopp", "4"=>"IBN Snopp",
"5"=>"Störungen" "5"=>"Störungen"

View File

@@ -11,7 +11,7 @@
.fc-timegrid-event-short .fc-event-main-frame { .fc-timegrid-event-short .fc-event-main-frame {
flex-direction: row; flex-direction: row;
overflow: hidden; overflow: hidden;
margin-left: 10px; margin-left: 13px;
} }
.fc-toolbar { .fc-toolbar {
@@ -121,7 +121,7 @@
.tooltip[x-placement^="right"], .tooltip[x-placement^="right"],
.popper[x-placement^="right"] { .popper[x-placement^="right"] {
margin-left: 5px; margin-left: 0px;
} }
.popper[x-placement^="right"] .popper__arrow, .popper[x-placement^="right"] .popper__arrow,
@@ -130,7 +130,7 @@
border-left-color: transparent; border-left-color: transparent;
border-top-color: transparent; border-top-color: transparent;
border-bottom-color: transparent; border-bottom-color: transparent;
left: -5px; left: 0px;
top: calc(50% - 5px); top: calc(50% - 5px);
margin-left: 0; margin-left: 0;
margin-right: 0; margin-right: 0;
@@ -333,8 +333,10 @@ thead .fc-day-today .fc-scrollgrid-sync-inner .fc-col-header-cell-cushion {
.fc-event-type { .fc-event-type {
position: absolute; position: absolute;
top: 0; top: 1px;
left: -4px; left: -4px;
opacity: 0.8;
filter: drop-shadow(1px 1px 1px #000);
} }
.fc-event-recurrence { .fc-event-recurrence {
@@ -673,4 +675,43 @@ thead .fc-day-today .fc-scrollgrid-sync-inner .fc-col-header-cell-cushion {
} }
.cursor-alias{ .cursor-alias{
cursor: alias; cursor: alias;
}
.fa-calendar-alert
{
font-size: 15px;
vertical-align: top;
margin-top: -1px;
}
.fa-calendar-alert:after {
color: #ff0000;
opacity: 0.7;
}
.fa-calendar-alert:before {
color: #fff;
}
.fa-calendar-alert-search
{
font-size: 22px;
}
.logo-top-search
{
height: 20px;
vertical-align: top;
cursor: pointer;
}
.btn-light-search
{
border-color: #e5e5e5;
padding: 3px 6px;
}
.top-search-filter
{
filter:grayscale(100%);
}
.fc-event-time {
z-index: 100;
} }

BIN
public/img/estmk_logo.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.2 KiB

BIN
public/img/snop-logo.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 2.3 KiB

BIN
public/img/xinon-logo.png Normal file

Binary file not shown.

After

Width:  |  Height:  |  Size: 12 KiB

View File

@@ -399,7 +399,9 @@ document.addEventListener('DOMContentLoaded', function () {
isOrganizer = data.data.isorganizer.isorganizer; isOrganizer = data.data.isorganizer.isorganizer;
if (data.data.type.type == "1") { if (data.data.type.type == "1") {
$('.customer-div').hide(); $('.customer-div').hide();
} else if (data.data.type.type == "2") { $('.ticket-div').hide();
} else if (data.data.type.type == "2" || data.data.type.type == "3" || data.data.type.type == "4") {
$('.ticket-div').hide();
$('.customer-div').show(); $('.customer-div').show();
if (data.data.customer.customer) { if (data.data.customer.customer) {
$('#customer').html('<option>' + data.data.customer.customer + '</option>'); $('#customer').html('<option>' + data.data.customer.customer + '</option>');
@@ -467,6 +469,32 @@ document.addEventListener('DOMContentLoaded', function () {
html: true html: true
}); });
} }
} else if (data.data.type.type == "5") {
$('.ticket-div').show();
$('.customer-div').hide();
if (data.data.customer.customer) {
$('#customer').html('<option>' + data.data.customer.customer + '</option>');
} else {
$('#customer').html('<option></option>');
}
$('#ticket').select2({
placeholder: "Ticket",
minimumInputLength: 3,
dropdownParent: jQuery('#relContainer3'),
// dropdownParent: $('#EventModal'),
language: "de",
ajax: {
url: requestTicketUrl,
dataType: 'json',
delay: 250,
processResults: function (data) {
// Transforms the top-level key of the response object from 'items' to 'results'
return {
results: data.items
};
}
}
})
} }
if (isOrganizer == "1") { if (isOrganizer == "1") {
$('.event-organizer-div').hide(); $('.event-organizer-div').hide();
@@ -649,7 +677,23 @@ document.addEventListener('DOMContentLoaded', function () {
if (info.event.extendedProps['event_type'] == '2') { if (info.event.extendedProps['event_type'] == '2') {
info.el.querySelector(".fc-event-title").insertAdjacentHTML("afterend", "<div class=\"fc-event-type\"><i class=\"fa-light fa-user-helmet-safety\"></i></div>"); // info.el.querySelector(".fc-event-title").insertAdjacentHTML("afterend", "<div class=\"fc-event-type\"><i class=\"fa-light fa-user-helmet-safety\"></i></div>");
info.el.querySelector(".fc-event-title").insertAdjacentHTML("afterend", "<div class=\"fc-event-type\"><img style='height: 13px;vertical-align: top;' src='/img/xinon-logo.png'></div>");
}
if (info.event.extendedProps['event_type'] == '3') {
// info.el.querySelector(".fc-event-title").insertAdjacentHTML("afterend", "<div class=\"fc-event-type\"><i class=\"fa-light fa-user-helmet-safety\"></i></div>");
info.el.querySelector(".fc-event-title").insertAdjacentHTML("afterend", "<div class=\"fc-event-type\"><img style='height: 13px;vertical-align: top;' src='/img/estmk_logo.png'></div>");
}
if (info.event.extendedProps['event_type'] == '4') {
// info.el.querySelector(".fc-event-title").insertAdjacentHTML("afterend", "<div class=\"fc-event-type\"><i class=\"fa-light fa-user-helmet-safety\"></i></div>");
info.el.querySelector(".fc-event-title").insertAdjacentHTML("afterend", "<div class=\"fc-event-type\"><img style='height: 13px;vertical-align: top;' src='/img/snop-logo.png'></div>");
}
if (info.event.extendedProps['event_type'] == '5') {
// info.el.querySelector(".fc-event-title").insertAdjacentHTML("afterend", "<div class=\"fc-event-type\"><i class=\"fa-light fa-user-helmet-safety\"></i></div>");
info.el.querySelector(".fc-event-title").insertAdjacentHTML("afterend", "<div class=\"fc-event-type\"><i class=\"fa-duotone fa-solid fa-triangle-exclamation fa-calendar-alert\"></i></div>");
} }
if (info.event.extendedProps['privateflag'] == 1) { if (info.event.extendedProps['privateflag'] == 1) {
info.el.querySelector(".fc-event-title").insertAdjacentHTML("afterend", "<div class=\"fc-event-private\"><i class=\"fa-regular fa-event-lock fa-lock\"></i></div>"); info.el.querySelector(".fc-event-title").insertAdjacentHTML("afterend", "<div class=\"fc-event-private\"><i class=\"fa-regular fa-event-lock fa-lock\"></i></div>");
@@ -686,7 +730,7 @@ document.addEventListener('DOMContentLoaded', function () {
} }
}, },
eventResize: function (info) { eventResize: function (info) {
info.event.remove();
let start = info.event.start.getTime(); let start = info.event.start.getTime();
const offsetstart = getOffset(start); const offsetstart = getOffset(start);
start = (start / 1000 + offsetstart) * 1000; start = (start / 1000 + offsetstart) * 1000;
@@ -715,7 +759,7 @@ document.addEventListener('DOMContentLoaded', function () {
}, },
eventDrop: function (info) { eventDrop: function (info) {
// sleep(2000).then(() => { info.event.remove();
let start = info.event.start.getTime(); let start = info.event.start.getTime();
const offsetstart = getOffset(start); const offsetstart = getOffset(start);
start = (start / 1000 + offsetstart) * 1000; start = (start / 1000 + offsetstart) * 1000;
@@ -826,19 +870,31 @@ if (typeof (EventSource) !== 'undefined') {
source.addEventListener('message', function (e) { source.addEventListener('message', function (e) {
// document.getElementById('result').innerHTML += e.data + '<br>'; // document.getElementById('result').innerHTML += e.data + '<br>';
let checkbox = $(".form-check-input"); let checkbox = $(".form-check-input");
let calendarFilter = $('.btn-light-search');
let visibleCalendars = []; let visibleCalendars = [];
let visibleCalendarTypes = [];
let mycalendar_id = $('#calendar-id').data('calendarid'); let mycalendar_id = $('#calendar-id').data('calendarid');
visibleCalendars.push(0); visibleCalendars.push(0);
checkbox.each(function () { checkbox.each(function () {
if ($(this).prop('checked')) { if ($(this).prop('checked')) {
visibleCalendars.push($(this).data('calendar_id')); visibleCalendars.push(parseInt($(this).data('calendar_id')));
}
});
calendarFilter.each(function () {
if (!$(this).hasClass('top-search-filter')) {
visibleCalendarTypes.push(parseInt($(this).data('ctype')));
} }
}); });
jsondata = JSON.parse(e.data); jsondata = JSON.parse(e.data);
jsondata.forEach(function (event) { jsondata.forEach(function (event) {
if (!visibleCalendars.includes(event.calendar_id)) { if (!visibleCalendars.includes(parseInt(event.calendar_id))) {
return; return;
} }
if (visibleCalendarTypes.length > 0 && !visibleCalendarTypes.includes(parseInt(event.event_type))) {
return;
}
let cevent = calendar.getEventById(event.cal_events_id); let cevent = calendar.getEventById(event.cal_events_id);
let rights = false; let rights = false;
let movable = false; let movable = false;
@@ -875,6 +931,7 @@ if (typeof (EventSource) !== 'undefined') {
if (event.change_type == '2' && cevent) { if (event.change_type == '2' && cevent) {
if (cevent) { if (cevent) {
if (event.calendar_id == event.calendar_id) { if (event.calendar_id == event.calendar_id) {
// console.log(jsondata);
cevent.remove(); cevent.remove();
calendar.addEvent({ calendar.addEvent({
id: event.cal_events_id, id: event.cal_events_id,
@@ -904,6 +961,40 @@ if (typeof (EventSource) !== 'undefined') {
cname: event.cname, cname: event.cname,
busy: event.busy busy: event.busy
}); });
// cevent.setProp('title', event.name);
// console.log(event.start_time);
// console.log(event.end_time);
// console.log(event.name);
// cevent.setDates(event.start_time, event.end_time);
//
// // Farben und Klassennamen
// cevent.setProp('backgroundColor', event.bgColor);
// cevent.setProp('textColor', event.txtColor);
// cevent.setProp('classNames', [
// 'cal-class-group-' + event.calendar_id,
// 'cal-class-id-' + event.cal_events_id,
// cursorclass
// ]);
// cevent.setExtendedProp('description', event.description);
// cevent.setExtendedProp('calendar_id', event.calendar_id_check);
// cevent.setExtendedProp('location', event.location);
// cevent.setExtendedProp('event_type', event.event_type);
// cevent.setExtendedProp('attachment', event.attachment);
// cevent.setExtendedProp('attachments', event.attachments);
// cevent.setExtendedProp('privateflag', event.privateflag);
// cevent.setExtendedProp('rruleflag', event.rruleflag);
// cevent.setExtendedProp('rrule', event.rrule);
// cevent.setExtendedProp('duration', event.duration);
// cevent.setExtendedProp('resourceId', event.calendar_id);
// cevent.setExtendedProp('calendar_name', event.calendar_name);
// cevent.setExtendedProp('clickable', event.rights);
// cevent.setExtendedProp('mtime', event.mtime);
// cevent.setExtendedProp('mname', event.mname);
// cevent.setExtendedProp('ctime', event.ctime);
// cevent.setExtendedProp('cname', event.cname);
// cevent.setExtendedProp('busy', event.busy);
// cevent.setProp('editable', movable);
} else { } else {
cevent.remove(); cevent.remove();
calendar.addEvent({ calendar.addEvent({
@@ -1011,16 +1102,16 @@ $(document).ready(function () {
}); });
$(document).on('show.bs.dropdown', '.dropdown', function () { $(document).on('show.bs.dropdown', '.dropdown', function () {
let previewMenue=''; let previewMenue = '';
$.getJSON(requestgetpreviewtUrl, { $.getJSON(requestgetpreviewtUrl, {
event_type: $('#type').val() event_type: $('#type').val()
}, function (data) { }, function (data) {
}).done(function (data) { }).done(function (data) {
; ;
let counter =1; let counter = 1;
$.each(data.data, function(index, item) { $.each(data.data, function (index, item) {
previewMenue += '<li><a class="dropdown-item text-template" data-text="' + item.data.text + '">' + item.data.name + '</a></li>'; previewMenue += '<li><a class="dropdown-item text-template" data-text="' + item.data.text + '">' + item.data.name + '</a></li>';
counter++; counter++;
}); });
@@ -1067,9 +1158,11 @@ $(document).ready(function () {
$('#customer-info-check-info').empty(); $('#customer-info-check-info').empty();
$('#customer-info-type').val('1'); $('#customer-info-type').val('1');
$('#customer').val(''); $('#customer').val('');
$('#ticket').val('');
$('.event-organizer-div').hide(); $('.event-organizer-div').hide();
$('#calendar-attendees').val('').trigger('change'); $('#calendar-attendees').val('').trigger('change');
$('.customer-div').hide(); $('.customer-div').hide();
$('.ticket-div').hide();
$('.calendar-users-all').hide(); $('.calendar-users-all').hide();
$('#EventModalLabel span').text('Termin erstellen'); $('#EventModalLabel span').text('Termin erstellen');
$('#EventModalLabel .fa-calendar-symbol').addClass('fa-calendar-circle-plus'); $('#EventModalLabel .fa-calendar-symbol').addClass('fa-calendar-circle-plus');
@@ -1152,7 +1245,7 @@ $(document).ready(function () {
if ($('#customer-info-check').is(':checked')) { if ($('#customer-info-check').is(':checked')) {
customer_info_check = 1; customer_info_check = 1;
} }
if (type == '2') { if (type == '2' || type == '3' || type == '4') {
customer_info_text = $('#customer-info-text').val(); customer_info_text = $('#customer-info-text').val();
customer_info_type = $('#customer-info-type').val(); customer_info_type = $('#customer-info-type').val();
customer_info_type_text = $('#customer-info-type-text').val(); customer_info_type_text = $('#customer-info-type-text').val();
@@ -1247,7 +1340,7 @@ $(document).ready(function () {
if ($('#customer-info-check').is(':checked')) { if ($('#customer-info-check').is(':checked')) {
customer_info_check = 1; customer_info_check = 1;
} }
if (type == '2') { if (type == '2' || type == '3' || type == '4') {
customer_info_text = $('#customer-info-text').val(); customer_info_text = $('#customer-info-text').val();
customer_info_type = $('#customer-info-type').val(); customer_info_type = $('#customer-info-type').val();
customer_info_type_text = $('#customer-info-type-text').val(); customer_info_type_text = $('#customer-info-type-text').val();
@@ -1259,7 +1352,8 @@ $(document).ready(function () {
} }
let id = $(this).data('id'); let id = $(this).data('id');
const cevent = calendar.getEventById(id);
cevent.remove();
$('#calendar-users > option:selected').each(function () { $('#calendar-users > option:selected').each(function () {
users.push($(this).val()); users.push($(this).val());
}); });
@@ -1392,6 +1486,17 @@ $(document).ready(function () {
} }
}) })
}); });
$('body').on('click', '.btn-light-search', function (event, init = 0) {
if ($(this).hasClass('top-search-filter')) {
$(this).removeClass('top-search-filter');
} else {
$(this).addClass('top-search-filter');
}
refreshCalendarEvents();
});
$('body').on('change', '.calendar-check', function (event, init = 0) { $('body').on('change', '.calendar-check', function (event, init = 0) {
if ($(this).prop('checked')) { if ($(this).prop('checked')) {
@@ -1514,10 +1619,12 @@ $(document).ready(function () {
}) })
$('body').on('change', '#type', function () { $('body').on('change', '#type', function () {
$('#customer').val('');
if ($(this).val() == "1") { if ($(this).val() == "1") {
$('.customer-div').hide(); $('.customer-div').hide();
} else if ($(this).val() == "2") { } else if ($(this).val() == "2") {
$('.customer-div').show(); $('.customer-div').show();
$('.ticket-div').hide();
$('#customer').select2({ $('#customer').select2({
placeholder: "Kunden Suche", placeholder: "Kunden Suche",
minimumInputLength: 3, minimumInputLength: 3,
@@ -1528,6 +1635,12 @@ $(document).ready(function () {
url: requestAddressUrl, url: requestAddressUrl,
dataType: 'json', dataType: 'json',
delay: 250, delay: 250,
data: function (params) {
return {
term: params.term,
xinon: 1,
};
},
processResults: function (data) { processResults: function (data) {
// Transforms the top-level key of the response object from 'items' to 'results' // Transforms the top-level key of the response object from 'items' to 'results'
return { return {
@@ -1536,6 +1649,84 @@ $(document).ready(function () {
} }
} }
}); });
} else if ($(this).val() == "3") {
$('.customer-div').show();
$('.ticket-div').hide();
$('#customer').select2({
placeholder: "Kunden Suche",
minimumInputLength: 3,
// dropdownParent: $('#EventModal'),
dropdownParent: jQuery('#relContainer2'),
language: "de",
ajax: {
url: requestAddressUrl,
dataType: 'json',
delay: 250,
data: function (params) {
return {
term: params.term,
xinon: 0,
};
},
processResults: function (data) {
// Transforms the top-level key of the response object from 'items' to 'results'
return {
results: data.items
};
}
}
});
} else if ($(this).val() == "4") {
$('.customer-div').show();
$('.ticket-div').hide();
$('#customer').select2({
placeholder: "Kunden Suche",
minimumInputLength: 3,
// dropdownParent: $('#EventModal'),
dropdownParent: jQuery('#relContainer2'),
language: "de",
ajax: {
url: requestAddressUrl,
dataType: 'json',
delay: 250,
data: function (params) {
return {
term: params.term,
xinon: 0,
};
},
processResults: function (data) {
// Transforms the top-level key of the response object from 'items' to 'results'
return {
results: data.items
};
}
}
});
}
else if ($(this).val() == "5") {
$('.customer-div').hide();
$('.ticket-div').show();
$('#ticket').select2({
placeholder: "Ticket",
minimumInputLength: 3,
dropdownParent: jQuery('#relContainer3'),
// dropdownParent: $('#EventModal'),
language: "de",
ajax: {
url: requestTicketUrl,
dataType: 'json',
delay: 250,
processResults: function (data) {
// Transforms the top-level key of the response object from 'items' to 'results'
return {
results: data.items
};
}
}
})
} }
}); });
@@ -1608,7 +1799,6 @@ $(document).ready(function () {
text = text.replace(/\[&&end&&\]/g, endtime); text = text.replace(/\[&&end&&\]/g, endtime);
$('#customer-info-text').val(text); $('#customer-info-text').val(text);
}); });
@@ -1636,6 +1826,18 @@ $(document).ready(function () {
} }
});
$('body').on('change', '#ticket', function () {
if ($('#name').val() == "") {
$('#name').val('Störung: ' + $("#ticket").select2('data')[0].name);
}
if ($('#location').val() == "") {
$('#location').val($("#ticket").select2('data')[0].location);
}
$('#description').val('<a href="https://project.xinon.at/projects/storungen-and-support/work_packages/' + $("#ticket").select2('data')[0].id + '/activity" target="_blank">Ticket Nr.: ' + $("#ticket").select2('data')[0].id + '</a>\n' + $("#ticket").select2('data')[0].subject);
}); });
$("body").on("click", "#customer-info-check", function () { $("body").on("click", "#customer-info-check", function () {
@@ -1906,7 +2108,9 @@ $(document).ready(function () {
function refreshCalendarEvents() { function refreshCalendarEvents() {
calendar.removeAllEvents(); calendar.removeAllEvents();
let checkbox = $(".calendar-check"); let checkbox = $(".calendar-check");
let calendarFilter = $('.btn-light-search');
let visibleCalendars = []; let visibleCalendars = [];
let visibleCalendarTypes = [];
let mycalendar_id = $('#calendar-id').data('calendarid'); let mycalendar_id = $('#calendar-id').data('calendarid');
visibleCalendars.push(0); visibleCalendars.push(0);
checkbox.each(function () { checkbox.each(function () {
@@ -1914,9 +2118,17 @@ $(document).ready(function () {
visibleCalendars.push($(this).data('calendar_id')); visibleCalendars.push($(this).data('calendar_id'));
} }
}); });
calendarFilter.each(function () {
if (!$(this).hasClass('top-search-filter')) {
visibleCalendarTypes.push($(this).data('ctype'));
}
});
$.post(requestUrl, {visibleCalendars: visibleCalendars}, function (data) { $.post(requestUrl, {
visibleCalendars: visibleCalendars,
visibleCalendarTypes: visibleCalendarTypes
}, function (data) {
}, 'json').done(function (json) { }, 'json').done(function (json) {
if (json.success == true) { if (json.success == true) {
@@ -2131,6 +2343,4 @@ $(document).ready(function () {
}); });
} }
});
})
;