$(document).ready(function () { var date = new Date(); var d = date.getDate(); var m = date.getMonth(); var y = date.getFullYear(); var clickedEvent; var dayNamesShort = ['Sonntag', 'Montag', 'Dienstag', 'Mittwoch', 'Donnerstag', 'Freitag', 'Samstag']; var dayNames = ['Sonntag', 'Montag', 'Dienstag', 'Mittwoch', 'Donnerstag', 'Freitag', 'Samstag']; var monthNames = ['Januar', 'Februar', 'März', 'April', 'Mai', 'Juni', 'Juli', 'August', 'September', 'Oktober', 'November', 'Dezember']; var monthNamesShort = ['Januar', 'Februar', 'März', 'April', 'Mai', 'Juni', 'Juli', 'August', 'September', 'Oktober', 'November', 'Dezember']; var today = 'Heute'; var month = 'Monat'; var week = 'Woche'; var day = 'Tag'; if ($('#calendar').length === 0) { return; } $("input#ansprechpartner").autocomplete({ source: "index.php?module=ajax&action=filter&filtername=ansprechpartneradresse&adresse="+0, }); $("input#adresse").autocomplete({ source: "index.php?module=ajax&action=filter&filtername=adresse", select: function( event, ui ) { if(ui.item){ $("input#ansprechpartner").autocomplete({ source: "index.php?module=ajax&action=filter&filtername=ansprechpartneradresse&adresse="+ui.item.value, }); } } }); var $calendarattributes = $('#calendarattributes'); if ($calendarattributes.length !== 0) { try{ var calendarattributes = JSON.parse($calendarattributes.html()); dayNamesShort = calendarattributes.dayNames; dayNames = calendarattributes.dayNames; monthNames = calendarattributes.monthNames; monthNamesShort = calendarattributes.monthNames; today = calendarattributes.today; month = calendarattributes.month; week = calendarattributes.week; day = calendarattributes.day; }catch(e){ //Nichts tun; Fallback wird verwendet } } $('#calendar').fullCalendar({ theme: true, header: { left: 'tasks', center: 'prev,title,next', right: 'today,month,agendaWeek,agendaDay' }, allDayText: 'Ganztägig', firstDay: 1, dayNamesShort: dayNamesShort, dayNames: dayNames, monthNames: monthNames, monthNamesShort: monthNamesShort, timeFormat: 'H:mm', buttonText: { prev: "", next: "", prevYear: "«", nextYear: "»", today: today, month: month, week: week, day: day }, axisFormat: 'HH:mm', columnFormat: { month: 'ddd', week: 'ddd d.M', day: 'dddd d.M' }, weekNumbers: true, weekNumberTitle: 'W', selectable: true, loading: function (isLoading, view) { //var myView = $.cookie('currentView'); //var myViewDate = $.cookie('currentViewDate'); var myView = Nocie.Get('currentView'); var myViewDate = Nocie.Get('currentViewDate'); // In Monatsansicht zum aktuellen Tag scrollen // (isLoading ist false wenn der AJAX-Request da ist) if (isLoading === false && view.name === 'month') { var autoscroll = parseInt($('#calendar').data('autoscroll')); if (autoscroll === 1) { setTimeout(function () { // Timeout $('.fc-today').attr('id', 'scrollTo'); // Set an ID for the current day.. $('html, body').animate({ scrollTop: $('#scrollTo').offset().top - 104 // Scroll to this ID }, 1000); }, 200); } } if (isLoading && myView != null) { $('#calendar').fullCalendar('changeView', myView); if (myViewDate != null) { var mydate = Date.parse(myViewDate); var year = $.format.date(mydate, 'yyyy'); var month = $.format.date(mydate, 'M') - 1; var day = (myView === 'month') ? 15 : $.format.date(mydate, 'd'); $('#calendar').fullCalendar('gotoDate', year, month, day); Nocie.Remove('currentViewDate'); Nocie.Remove('currentView'); } } }, select: function (start, end, allDay) { var myView = $('#calendar').fullCalendar('getView'); Nocie.Set('currentViewDate', myView.start); Nocie.Set('currentView', myView.name); // Neuen Event anlegen $("#TerminDialog").SetFormData(-1, start, end, allDay); $("#TerminDialog").dialog("open"); AllDay($('#allday')); }, eventDrop: function (event, dayDelta, minuteDelta, allDay, revertFunc) // eventDrop: function(event, element) { var task = ''; if (event.task != undefined) task = '&task=' + event.task; if (event.id > -1) { $.get('./index.php?module=kalender&action=update&id=' + event.id + '&start=' + $.fullCalendar.formatDate(event.start, 'yyyy-MM-dd HH:mm:ss') + '&end=' + $.fullCalendar.formatDate(event.end, 'yyyy-MM-dd HH:mm:ss') + '&allDay=' + event.allDay + task, function () { $('#calendar').fullCalendar('updateEvent', event); }); } else { alert("Eintrag kann nicht verschoben werden"); revertFunc(); } }, eventResize: function (event, dayDelta, minuteDelta, revertFunc, jsEvent, ui, view) { //eventResize: function(event, element) { if (event.id > -1) { $.get('./index.php?module=kalender&action=update&id=' + event.id + '&start=' + $.fullCalendar.formatDate(event.start, 'yyyy-MM-dd HH:mm:ss') + '&end=' + $.fullCalendar.formatDate(event.end, 'yyyy-MM-dd HH:mm:ss'), function () { $('#calendar').fullCalendar('updateEvent', event); }); } else { alert("Eintrag kann nicht verlängert werden"); revertFunc(); } }, eventClick: function (calEvent, jsEvent, view) { clickedEvent = calEvent; var myView = $('#calendar').fullCalendar('getView'); //$.cookie("currentView",myView.name); //$.cookie("currentViewDate", myView.visStart); Nocie.Set('currentView', myView.name); Nocie.Set('currentViewDate', calEvent.start); if ($("#TerminDialog").SetFormData(calEvent.id, calEvent.start, calEvent.end, calEvent.allDay, calEvent.task)) { console.log('open soon'); $("#TerminDialog").dialog("open"); AllDay($('#allday')); } }, editable: true, events: "./index.php?module=kalender&action=data" }); $(document).on('click', '#allday', function (e) { AllDay(this); }); $.fn.SetFormData = function (id, start, end, allDay, task) { if (id == -2) { AufgabenEdit(task); //window.open('index.php?module=aufgaben&action=edit&id=' + task + '&back=kalender#tabs-3', '_blank'); return false; } else if (id == -3) { // mindesthaltbarkeit //alert("Eintrag kann nicht editiert werden"); window.open('index.php?module=artikel&action=mindesthaltbarkeitsdatum&id=' + task, '_blank'); return false; } else if (id == -4) { // geburstag window.open('index.php?module=adresse&action=brief&id=' + task, '_blank'); return false; } else if (id == -5) { // Projekt //heute mal wieder rein 4.08.18 BS window.open('index.php?module=projekt&action=dashboard&id=' + task, '_blank'); return false; } else if (id == -6) { // Serviceauftrag window.open('index.php?module=serviceauftrag&action=edit&id=' + task, '_blank'); return false; } else if (id == -7) { // Urlaub Mitarbeiterzeiterfassung return false; } else if (id > -1) { var formdata = null; // Edit $.ajax({ url: './index.php?module=kalender&action=eventdata&id=' + id, success: function (data) { EditMode(data); }, error: function (request, statusCode, error) { $("#submitError").html("Keine Event-Daten gefunden"); } }); } else { // Neuen Event anlegen console.log('new'); // Zuletzt angeklickten Event vergessen clickedEvent = null; var defaultColor = $('#calendar').data('default-color'); if (typeof defaultColor === 'undefined' || defaultColor === '') { defaultColor = '#0B8092'; } // New $("#mode").val("new"); $("#datum").val($.format.date(start, "dd.MM.yyyy")); $("#datum_bis").val($.format.date(end, "dd.MM.yyyy")); $('#googleStatus').html(''); // Buttons $(":button:contains('Kopieren')").prop("disabled", true).addClass('ui-state-disabled'); $(":button:contains('Löschen')").prop("disabled", true).addClass('ui-state-disabled'); $(":button:has('Einladung')").prop("disabled", true).addClass('ui-state-disabled'); $("input[name=public]").prop('checked', 'checked'); $("input[name=erinnerung]").prop('checked', 'checked'); $("input[name=allday]").prop('checked', 'checked'); $("#personen option").prop('selected', false); $("#gruppenkalender option").prop('selected', false); $("#color").val(defaultColor).change(); // Ganztags if (allDay) { $("#allday").attr('checked', true); $("#von").attr('disabled', true); $("#bis").attr('disabled', true); } else { $("#allday").attr('checked', false); $("#von").attr('disabled', false); $("#bis").attr('disabled', false); } // Von & Bis $("#von").val($.format.date(start, "HH:mm")); $("#bis").val($.format.date(end, "HH:mm")); // Haken bei Ganztags entfernen, wenn Uhrzeit eingetragen wird $("#von,#bis").on('keyup', function () { var $allday = $('#allday'); if ($allday.prop('checked')) { $allday.prop('checked', false); } }); } return true; }; var EditMode = function (data) { $("#mode").val("edit"); $("#eventid").val(data.id); $("#titel").val(data.titel); $("#ort").val(data.ort); $("#adresse").val(data.adresse); $("#ansprechpartner").val(data.ansprechpartner); $("#adresseintern").val(data.adresseintern); $("#projekt").val(data.projekt); $("#beschreibung").val(data.beschreibung); $("#datum").val($.format.date(data.von, "dd.MM.yyyy")); $("#datum_bis").val($.format.date(data.bis, "dd.MM.yyyy")); // Buttons $(":button:contains('Kopieren')").prop("disabled", false).removeClass('ui-state-disabled'); $(":button:contains('Löschen')").prop("disabled", false).removeClass('ui-state-disabled'); $(":button:has('Einladung')").prop("disabled", false).removeClass('ui-state-disabled'); $('#googleStatus').html(''); if(data.googleEventLink !== '' && data.googleEventEdit === false) { $('#googleStatus').append('Dieser Google Termin kann nur vom Besitzer bearbeitet werden.
'); $(":button:contains('Löschen')").prop("disabled", true).addClass('ui-state-disabled'); $(":button:contains('Speichern')").prop("disabled", true).addClass('ui-state-disabled'); $(":button:contains('Einladung')").prop("disabled", true).addClass('ui-state-disabled'); $(":button:contains('Kopieren')").prop("disabled", true).addClass('ui-state-disabled'); } // Cannot edit an Event if it's a Google Event of another user if(data.googleEventLink !== '') { $('#googleStatus').append('In Google Kalender öffnen'); } // Ganztags if (data.allDay) { $("#allday").prop('checked', true); $("#von").prop('disabled', true); $("#bis").prop('disabled', true); } else { $("#allday").prop('checked', false); $("#von").prop('disabled', false); $("#bis").prop('disabled', false); } // Öffentlich if (data.public) $("#public").prop('checked', true); else $("#public").prop('checked', false); // Erinnerung if (data.erinnerung) $("#erinnerung").prop('checked', true); else $("#erinnerung").prop('checked', false); // Von & Bis $("#von").val($.format.date(data.von, "HH:mm")); $("#bis").val($.format.date(data.bis, "HH:mm")); // Color //$("#colors option[value='"+data.color+"']").prop('selected','selected'); //if($("#colors option[value='"+data.color+"']").prop('selected')=='selected') // $("#colors").css("background-color", data.color); $("#color").val(data.color); $("#color").change(); // Personen $('#personen option').removeAttr('selected'); if (data.personen != null && data.personen !== undefined) { jQuery.each(data.personen, function (k, v) { $("#personen option[value='" + v.userid + "']").prop('selected', 'selected'); }); } // Gruppenkalender $('#gruppenkalender option').removeAttr('selected'); if (data.gruppenkalender != null && data.gruppenkalender !== undefined) { jQuery.each(data.gruppenkalender, function (k, v) { $("#gruppenkalender option[value='" + v.kalendergruppe + "']").prop('selected', 'selected'); }); } $("input#ansprechpartner").autocomplete({ source: "index.php?module=ajax&action=filter&filtername=ansprechpartneradresse&adresse="+data.adressid, }); }; // Standard-Verhalten der Multiple-Selectbox ändern: // - Beim Klick auf einen Eintrag wird nur der angeklickte Eintrag ausgewählt; bzw. abgewählt (wenn vorher aktiv). // - Das Halten der Strg-Taste zum Entfernen einer Auswahl ist dadurch nicht mehr notwendig. $('#personen option, #gruppenkalender option').on('mousedown', function (e) { e.preventDefault(); $(e.target).prop('selected', function (i, value) { return !value; }); }); $('#TerminForm').submit(function (e) { var mode = $('#mode').val(); e.preventDefault(); var formData = $(this).serialize(); $.ajax({ url: 'index.php?module=kalender&action=list&ajax=true', method: 'post', data: formData, dataType: 'json', success: function (eventData) { // Event wurde gelöscht > Event aus Kalender entfernen if (mode === 'delete' && typeof eventData.deletedEventId !== 'undefined') { $('#calendar').fullCalendar('removeEvents', eventData.deletedEventId); $('#TerminDialog').dialog('close'); return; } // Termin wurde kopiert if (mode === 'copy' && clickedEvent !== null) { $('#calendar').fullCalendar('refetchEvents'); $('#TerminDialog').dialog('close'); return; } // Neuer Termin wurde angelegt if (mode === 'new' && clickedEvent === null) { $('#calendar').fullCalendar('refetchEvents'); $('#TerminDialog').dialog('close'); return; } // Termin wurde bearbeitet > Originalen Event aktualisieren if (mode === 'edit' && clickedEvent !== null) { clickedEvent = updateExistingEvent(clickedEvent, eventData); $('#calendar').fullCalendar('updateEvent', clickedEvent); } } }); }); $("#TerminDialog").dialog({ autoOpen: false, height: 600, width: 1000, modal: true, buttons: { "Speichern": function () { var errMsg = ''; if ($("#datum").val() == "") errMsg = "Geben Sie bitte ein gültiges Datum ein (dd.mm.jjjj)"; if ($("#von").val() == "") $("#von").val("00:00"); if ($("#von").val().includes(':') == false) $("#von").val($("#von").val()+":00"); if ($("#bis").val() == "") $("#bis").val("23:59"); if ($("#bis").val().includes(':') == false) $("#bis").val($("#bis").val()+":00"); if ($("#titel").val() == "") errMsg = "Geben Sie bitte einen Titel ein"; if (errMsg != "") $("#submitError").html(errMsg); else { $('#TerminForm').submit(); $(this).dialog("close"); } }, "Kopieren": function () { $("#mode").val("copy"); $('#TerminForm').submit(); }, "Löschen": function () { if (confirm("Soll der Termin wirklich gelöscht werden?")) { $("#mode").val("delete"); $('#TerminForm').submit(); } }, "Einladung": function () { var errMsg = ''; if ($("#datum").val() == "") errMsg = "Geben Sie bitte ein gültiges Datum ein (dd.mm.jjjj)" if ($("#titel").val() == "") errMsg = "Geben Sie bitte einen Titel ein"; if (errMsg != "") $("#submitError").html(errMsg); else { $('#noRedirect').val('1'); // $('#TerminForm').submit(); $.ajax({ url: 'index.php?module=kalender&action=list', method: 'post', data: $('#TerminForm').serialize(), dataType: 'json', success: function (datatermin) { $("#einladungeventid").val(datatermin.eventid); $("#TerminDialog").dialog("close"); $("#TerminDialogEinladung").dialog("open"); // betreff und text holen und ansprechpartner list $.ajax({ url: 'index.php?module=kalender&action=eventdata&cmd=getEinladung&id=' + $("#einladungeventid").val(), method: 'post', dataType: 'json', success: function (data) { if (data.status == 1) { $('#noRedirect').val('0'); $('#TerminDialogEinladung').find('#einladungbetreff').val(data.betreff); $('#TerminDialogEinladung').find('#einladungtext').val(data.text); $('#TerminDialogEinladung').find('#einladungcc').val(data.einladungcc); } else { alert(data.statusText); } } }); } }); } }, // "Einladung": function () { // var errMsg = ''; // if ($("#datum").val() == "") errMsg = "Geben Sie bitte ein gültiges Datum ein (dd.mm.jjjj)" // if ($("#titel").val() == "") errMsg = "Geben Sie bitte einen Titel ein"; // // if (errMsg != "") // $("#submitError").html(errMsg); // else { // $("#TerminDialogEinladung").dialog("open"); // // betreff und text holen und ansprechpartner list // // $.ajax({ // url: 'index.php?module=kalender&action=einladung&cmd=get&id=' + $("#eventid").val(), // method: 'post', // dataType: 'json', // success: function (data) { // if (data.status == 1) { // $('#TerminDialogEinladung').find('#einladungbetreff').val(data.betreff); // $('#TerminDialogEinladung').find('#einladungtext').val(data.text); // $('#TerminDialogEinladung').find('#einladungcc').val(data.einladungcc); // } else { // alert(data.statusText); // } // } // }); // // } // // }, "Abbrechen": function () { $(this).dialog("close"); } }, close: function () { $("#submitError").html(""); $("#titel").val(""); $("#ort").val(""); $("#adresse").val(""); $("#ansprechpartner").val(""); $("#adresseintern").val(""); $("#projekt").val(""); $("#beschreibung").val(""); $("#datum").val(""); $("#datum_bis").val(""); $("#von").val(""); $("#bis").val(""); $("#public").attr('checked', false); $("#erinnerung").attr('checked', false); //$("#colors option[value='']").attr('selected','selected'); //$("#colors").css('background-color','#FFFFFF'); $("#color").val(""); $("#color").change(); //$('#personen option').removeAttr('selected'); $("#eventid").val(""); $("#mode").val(""); $("input#ansprechpartner").autocomplete({ source: "index.php?module=ajax&action=filter&filtername=ansprechpartneradresse&adresse="+0, }); } }); $("#TerminDialogEinladung").dialog({ modal: true, bgiframe: true, closeOnEscape: false, minWidth: 900, minHeight: 350, autoOpen: false, buttons: { ABBRECHEN: function () { $(this).dialog('close'); }, "Einladung SENDEN": function () { $.ajax({ url: 'index.php?module=kalender&action=eventdata&cmd=sendEinladung&id=' + $("#eventid").val(), data: { //Alle Felder die fürs editieren vorhanden sind id: $('#einladungeventid').val(), betreff: $('#einladungbetreff').val(), text: $('#einladungtext').val(), emailcc: $('#einladungcc').val() }, method: 'post', dataType: 'json', beforeSend: function () { App.loading.open(); }, success: function (data) { App.loading.close(); if (data.status == 1) { /* $('#editKontorahmen').find('#editid').val(''); $('#editKontorahmen').find('#editkonto').val(''); $('#editKontorahmen').find('#editbeschriftung').val(''); $('#editKontorahmen').find('#editart').val(''); $('#editKontorahmen').find('#editbemerkung').val(''); $('#editKontorahmen').find('#editnichtsichtbar').val(''); */ // alert(data.statusText); $("#TerminDialogEinladung").dialog('close'); } else { alert(data.statusText); $('#calendar').fullCalendar('refetchEvents'); } } }); //alert($("#einladungeventid").val()); /* $.ajax({ url: 'index.php?module=kalender&action=einladung&id='+$("#eventid").val(), data: { //Alle Felder die fürs editieren vorhanden sind //id: $('#editid').val(), id: $('#').val(), betreff: $('#einladungbetreff').val(), text: $('#einladungtext').val(), betreff: $('#einladungcc').val() }, success: function(data) { }, error: function (request, statusCode, error) { }); */ } } }); $("#TerminDialogEinladung").dialog({ close: function (event, ui) { } }); }); function AllDay(el) { if (el.checked) { $("#von").attr('disabled', true); $("#bis").attr('disabled', true); } else { $("#von").attr('disabled', false); $("#bis").attr('disabled', false); } } function getDialogButton(jqUIdialog, button_names) { if (typeof button_names == 'string') button_names = [button_names]; var buttons = jqUIdialog.parent().find('.ui-dialog-buttonpane button'); for (var i = 0; i < buttons.length; i++) { var jButton = $(buttons[i]); for (var j = 0; j < button_names.length; j++) if (jButton.text() == button_names[j]) return jButton; } return null; } /** * Aktualisiert ein vorhandenes Event-Objekt * * @param {Event} event https://fullcalendar.io/docs/v1/event-object * @param {Array} data * * @return {Event} */ var updateExistingEvent = function(event, data) { event.title = data.title; event.beschreibung = data.beschreibung; event.color = data.color; event.farbe = data.color; event.projekt = data.projekt; event.adresse = data.adresse; event.ansprechpartner = data.ansprechpartner; event.adresseintern = data.adresseintern; event.allDay = (data.allDay === '1'); event.public = (data.public === '1'); event.erinnerung = (data.erinnerung === '1'); event.start = new Date(data.start); event.end = new Date(data.end); return event; }; /** * Erzeugt ein neues Event-Objekt * * @param {Array} data * * @return {Event} https://fullcalendar.io/docs/v1/event-object */ var createNewEvent = function (data) { return { id: data.id, title: data.title, color: data.color, projekt: data.projekt, adresse: data.adresse, ansprechpartner: data.ansprechpartner, adresseintern: data.adresseintern, allDay: (data.allDay === '1'), public: (data.public === '1'), erinnerung: (data.erinnerung === '1'), start: new Date(data.start), end: new Date(data.end) }; };