%PDF- %PDF-
Mini Shell

Mini Shell

Direktori : /var/www/projetos/suporte.iigd.com.br/js/
Upload File :
Create Path :
Current File : /var/www/projetos/suporte.iigd.com.br/js/reservations.js

/**
 * ---------------------------------------------------------------------
 *
 * GLPI - Gestionnaire Libre de Parc Informatique
 *
 * http://glpi-project.org
 *
 * @copyright 2015-2024 Teclib' and contributors.
 * @copyright 2003-2014 by the INDEPNET Development Team.
 * @licence   https://www.gnu.org/licenses/gpl-3.0.html
 *
 * ---------------------------------------------------------------------
 *
 * LICENSE
 *
 * This file is part of GLPI.
 *
 * This program is free software: you can redistribute it and/or modify
 * it under the terms of the GNU General Public License as published by
 * the Free Software Foundation, either version 3 of the License, or
 * (at your option) any later version.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 * GNU General Public License for more details.
 *
 * You should have received a copy of the GNU General Public License
 * along with this program.  If not, see <https://www.gnu.org/licenses/>.
 *
 * ---------------------------------------------------------------------
 */

/* global FullCalendar, FullCalendarLocales */
/* global glpi_ajax_dialog */

var Reservations = function() {
    this.is_all      = true;
    this.id          = 0;
    this.rand        = '';
    this.dom_id      = '';
    this.calendar    = null;
    this.license_key = null;
    this.currentv    = null;
    this.defaultDate = null;
    this.can_reserve = true;
    this.now         = null;

    var my = this;

    my.init = function(config) {
        my.id           = config.id || 0;
        my.is_all       = config.is_all || true;
        my.rand         = config.rand || true;
        my.is_tab       = config.is_tab || false;
        my.license_key  = config.license_key || '';
        my.dom_id       = "reservations_planning_"+my.rand;
        my.currentv     = config.currentv || 'dayGridMonth';
        my.defaultDate  = config.defaultDate || new Date();
        my.defaultPDate = new Date(my.defaultDate);
        if (config.can_reserve != undefined) {
            my.can_reserve = config.can_reserve;
        }
        my.now          = config.now || null;
    };

    my.displayPlanning = function() {
        my.calendar = new FullCalendar.Calendar(document.getElementById(my.dom_id), {
            schedulerLicenseKey: my.license_key,
            timeZone: 'UTC',
            nowIndicator: true,
            now: my.now,// as we set the calendar as UTC, we need to reprecise the current datetime
            theme: true,
            editable: true,
            defaultDate: my.defaultDate,
            minTime:     CFG_GLPI.planning_begin,
            maxTime:     CFG_GLPI.planning_end,
            weekNumbers: true,
            defaultView:  localStorage.getItem("fcDefaultViewReservation") !== null
                ? localStorage.getItem("fcDefaultViewReservation")
                : my.currentv,
            height: function() {
                var _newheight = $(window).height() - 272;
                if ($('#debugajax').length > 0) {
                    _newheight -= $('#debugajax').height();
                }

                if (my.is_tab) {
                    // TODO .glpi_tabs not exists anymore
                    _newheight = $('.glpi_tabs ').height() - 150;
                }

                //minimal size
                var _minheight = 300;
                if (_newheight < _minheight) {
                    _newheight = _minheight;
                }

                return _newheight;
            },
            resourceAreaWidth: '15%',
            plugins: ['dayGrid', 'interaction', 'list', 'timeGrid', 'resourceTimeline'],
            header: {
                left:   'prev,next,today',
                center: 'title',
                right:  'dayGridMonth, timeGridWeek, timeGridDay, listFull, resourceWeek'
            },

            views: {
                listFull: {
                    type: 'list',
                    titleFormat: function() {
                        return '';
                    },
                    visibleRange: function(currentDate) {
                        var current_year = currentDate.getFullYear();
                        var offset = 1;
                        if (my.id > 0) {
                            offset = 10;
                        }
                        return {
                            start: (new Date(currentDate.getTime())).setFullYear(current_year - offset),
                            end: (new Date(currentDate.getTime())).setFullYear(current_year + offset)
                        };
                    }
                },
                resourceWeek: {
                    type: 'resourceTimeline',
                    buttonText: __('Timeline Week'),
                    duration: { weeks: 1 },
                    groupByDateAndResource: true,
                    slotLabelFormat: [
                        { week: 'short' },
                        { weekday: 'short', day: 'numeric', month: 'numeric', omitCommas: true },
                        function(date) {
                            return date.date.hour;
                        }
                    ]
                },
            },

            events: {
                url:  CFG_GLPI.root_doc+"/ajax/reservations.php",
                type: 'GET',
                extraParams: {
                    'action': 'get_events',
                    'reservationitems_id': my.id,
                },
                success: function() {

                },
                failure: function(error) {
                    console.error('there was an error while fetching events!', error);
                }
            },

            resources: {
                url:  CFG_GLPI.root_doc+"/ajax/reservations.php",
                method: 'GET',
                extraParams: {
                    'action': 'get_resources',
                }
            },

            eventRender: function(info) {
                var event    = info.event;
                var extProps = event.extendedProps;
                var element  = $(info.el);
                var view     = info.view;

                // add icon if exists
                if ("icon" in extProps && !my.is_tab) {
                    var icon_alt = "";
                    if ("icon_alt" in extProps) {
                        icon_alt = extProps.icon_alt;
                    }

                    element.find(".fc-title, .fc-list-item-title")
                        .append("&nbsp;<i class='"+extProps.icon+"' title='"+icon_alt+"'></i>");
                }

                // detect ideal position
                var qtip_position = {
                    target: 'mouse',
                    adjust: {
                        mouse: false
                    },
                    viewport: $(window)
                };
                if (view.type.indexOf('list') >= 0) {
                    // on central, we want the tooltip on the anchor
                    // because the event is 100% width and so tooltip will be too much on the right.
                    qtip_position.target= element.find('a');
                }

                element.qtip({
                    position: qtip_position,
                    content: extProps.comment,
                    style: {
                        classes: 'qtip-shadow qtip-bootstrap'
                    },
                    show: {
                        solo: true,
                        delay: 100
                    },
                    hide: {
                        fixed: true,
                        delay: 100
                    }
                });
            },

            dayRender: function (info) {
                if (my.dateAreSameDay(info.date, my.defaultPDate)) {
                    $(info.el).addClass('defaultDate');
                }
            },

            viewSkeletonRender: function (info) {
                var view = info.view;

                // when the view changes, we update our localStorage value with the new view name
                localStorage.setItem("fcDefaultViewReservation", view.type);
            },

            eventResize: function(info) {
                my.editEvent(info);
            },

            eventDrop: function(info) {
                my.editEvent(info);
            },

            // ADD EVENTS
            selectable: my.can_reserve,
            select: function(info) {
                if (my.can_reserve) {
                    glpi_ajax_dialog({
                        title: __("Add reservation"),
                        url: CFG_GLPI.root_doc+"/ajax/reservations.php",
                        params: {
                            action: 'add_reservation_fromselect',
                            id:     my.id,
                            start:  info.start.toISOString(),
                            end:    info.end.toISOString(),
                        },
                        dialogclass: 'modal-lg',
                    });
                }

                my.calendar.unselect();
            },

            eventClick: function(info) {
                var event    = info.event;
                var ajaxurl  = event.extendedProps.ajaxurl;
                var editable = event.extendedProps._editable;

                info.jsEvent.preventDefault(); // don't let the browser navigate

                if (!editable || !ajaxurl) {
                    return;
                }

                glpi_ajax_dialog({
                    title: __("Edit reservation"),
                    url: ajaxurl+"&ajax=true",
                    dialogclass: 'modal-lg',
                });
            }
        });

        my.calendar.render();

        // load language
        var loadedLocales = Object.keys(FullCalendarLocales);
        if (loadedLocales.length === 1) {
            my.calendar.setOption('locale', loadedLocales[0]);
        }
    };

    // send an ajax request to update a reservation
    my.editEvent = function(info) {
        var event      = info.event;
        var revertFunc = info.revert;

        var start      = event.start;
        var end        = event.end;

        $.ajax({
            url: CFG_GLPI.root_doc+"/ajax/reservations.php",
            type: 'POST',
            data: {
                action:        'update_event',
                start:         start.toISOString(),
                end:           end.toISOString(),
                id:            event.id,
            },
            success: function(html) {
                if (!html) {
                    revertFunc();
                }
            },
            error: function() {
                revertFunc();
            }
        });
    };

    my.dateAreSameDay = function(date1, date2) {
        return date1.getFullYear() === date2.getFullYear()
          && date1.getMonth() === date2.getMonth()
          && date1.getDate() === date2.getDate();
    };
};

Zerion Mini Shell 1.0