/** * @license e-Calendar v0.9.3 * (c) 2014-2016 - Jhonis de Souza * License: GNU */ (function ($) { var eCalendar = function (options, object) { // Initializing global variables var adDay = new Date().getDate(); var adMonth = new Date().getMonth(); var adYear = new Date().getFullYear(); var dDay = adDay; var dMonth = adMonth; var dYear = adYear; var instance = object; var settings = $.extend({}, $.fn.eCalendar.defaults, options); function lpad(value, length, pad) { if (typeof pad == 'undefined') { pad = '0'; } var p; for (var i = 0; i < length; i++) { p += pad; } return (p + value).slice(-length); } var mouseOver = function () { $(this).addClass('c-nav-btn-over'); }; var mouseLeave = function () { $(this).removeClass('c-nav-btn-over'); }; var mouseOverEvent = function () { var d = $(this).attr('data-event-day'); $('div.c-event-item[data-event-day="' + d + '"]').addClass('c-event-over'); }; var mouseLeaveEvent = function () { $(this).removeClass('c-event-over') var d = $(this).attr('data-event-day'); $('div.c-event-item[data-event-day="' + d + '"]').removeClass('c-event-over'); $("#id").css("display",""); }; var mouseOverItem = function () { $(this).addClass('c-event-over'); var d = $(this).attr('data-event-day'); $('div.c-event[data-event-day="' + d + '"]').addClass('c-event-over'); }; var mouseLeaveItem = function () { $(this).removeClass('c-event-over') var d = $(this).attr('data-event-day'); $('div.c-event[data-event-day="' + d + '"]').removeClass('c-event-over'); }; var nextMonth = function () { if (dMonth < 11) { dMonth++; } else { dMonth = 0; dYear++; } print(); }; var previousMonth = function () { if (dMonth > 0) { dMonth--; } else { dMonth = 11; dYear--; } print(); }; function loadEvents() { if (typeof settings.url != 'undefined' && settings.url != '') { $.ajax({url: settings.url, async: false, success: function (result) { settings.events = result; } }); } } function print() { loadEvents(); var dWeekDayOfMonthStart = new Date(dYear, dMonth, 1).getDay() - settings.firstDayOfWeek; if (dWeekDayOfMonthStart < 0) { dWeekDayOfMonthStart = 6 - ((dWeekDayOfMonthStart + 1) * -1); } var dLastDayOfMonth = new Date(dYear, dMonth + 1, 0).getDate(); var dLastDayOfPreviousMonth = new Date(dYear, dMonth + 1, 0).getDate() - dWeekDayOfMonthStart + 1; var cBody = $('
').addClass('c-grid'); var cEvents = $('
').addClass('c-event-grid'); cEvents.hide(); var cEventsBody = $('
').addClass('c-event-body'); cEvents.append($('
').addClass('c-event-title c-pad-top').html(settings.eventTitle)); cEvents.append(cEventsBody); var cNext = $('
').addClass('c-next c-grid-title c-pad-top'); var cMonth = $('
').addClass('c-month c-grid-title c-pad-top'); var cPrevious = $('
').addClass('c-previous c-grid-title c-pad-top'); cPrevious.html(settings.textArrows.previous); cMonth.html(settings.months[dMonth] + ' ' + dYear); cNext.html(settings.textArrows.next); cPrevious.on('mouseover', mouseOver).on('mouseleave', mouseLeave).on('click', previousMonth); cNext.on('mouseover', mouseOver).on('mouseleave', mouseLeave).on('click', nextMonth); cBody.append(cPrevious); cBody.append(cMonth); cBody.append(cNext); var dayOfWeek = settings.firstDayOfWeek; for (var i = 0; i < 7; i++) { if (dayOfWeek > 6) { dayOfWeek = 0; } var cWeekDay = $('
').addClass('c-week-day c-pad-top'); cWeekDay.html(settings.weekDays[dayOfWeek]); cBody.append(cWeekDay); dayOfWeek++; } var day = 1; var dayOfNextMonth = 1; for (var i = 0; i < 42; i++) { var cDay = $('
'); if (i < dWeekDayOfMonthStart) { cDay.addClass('c-day-previous-month c-pad-top'); cDay.html(dLastDayOfPreviousMonth++); } else if (day <= dLastDayOfMonth) { cDay.addClass('c-day c-pad-top'); if (day == dDay && adMonth == dMonth && adYear == dYear) { cDay.addClass('c-today'); } for (var j = 0; j < settings.events.length; j++) { var d = settings.events[j].datetime; if (d.getDate() == day && d.getMonth() == dMonth && d.getFullYear() == dYear) { cDay.addClass('c-event').attr('data-event-day', d.getDate()); cEvents.show(); cDay.on('mouseover', mouseOverEvent).on('mouseleave', mouseLeaveEvent); } } cDay.html(day++); } else { cDay.addClass('c-day-next-month c-pad-top'); cDay.html(dayOfNextMonth++); } cBody.append(cDay); } var eventList = $('
').addClass('c-event-list'); for (var i = 0; i < settings.events.length; i++) { var d = settings.events[i].datetime; if (d.getMonth() == dMonth && d.getFullYear() == dYear) { var date = lpad(d.getDate(), 2) + '/' + lpad(d.getMonth() + 1, 2) + ' ' + lpad(d.getHours(), 2) + ':' + lpad(d.getMinutes(), 2); var item = $('
').addClass('c-event-item'); var title = $('
').addClass('title').html(date + ' ' + settings.events[i].title + '
'); var description = $('
').addClass('description').html(settings.events[i].description + '
'); item.attr('data-event-day', d.getDate()); item.on('mouseover', mouseOverItem).on('mouseleave', mouseLeaveItem); item.append(title).append(description); // Add the url to the description if is set if( settings.events[i].url !== undefined ) { /** * If the setting url_blank is set and is true, the target of the url * will be "_blank" */ type_url = settings.events[i].url_blank !== undefined && settings.events[i].url_blank === true ? '_blank':''; description.wrap( '' ); } eventList.append(item); } } $(instance).addClass('calendar'); cEventsBody.append(eventList); $(instance).html(cBody).append(cEvents); } return print(); } $.fn.eCalendar = function (oInit) { return this.each(function () { return eCalendar(oInit, $(this)); }); }; // plugin defaults $.fn.eCalendar.defaults = { weekDays: ['Dom', 'Lun', 'Mar', 'Mer', 'Gio', 'Ven', 'Sab'], months: ['Gennaio', 'Febbraio', 'Marzo', 'Aprile', 'Maggio', 'Giugno', 'Luglio', 'Agosto', 'Settembre', 'Ottobre', 'Novembre', 'Dicembre'], textArrows: {previous: '<', next: '>'}, eventTitle: 'Eventi & Calendario', url: '', events: [ { title: 'Assemblea per il bilancio', description: 'Assemblea per il bilancio', datetime: new Date(2020, 7, 01, 10) }, { title: 'Evento fine anno', description: 'Evento fine anno', datetime: new Date(2020, 0, 07, 09) }, ], firstDayOfWeek: 0 }; }(jQuery));