diff options
-rw-r--r-- | modules-available/locationinfo/api.inc.php | 12 | ||||
-rwxr-xr-x | modules-available/locationinfo/frontend/doorsign.html | 180 |
2 files changed, 102 insertions, 90 deletions
diff --git a/modules-available/locationinfo/api.inc.php b/modules-available/locationinfo/api.inc.php index 760a9be7..ebea0ccb 100644 --- a/modules-available/locationinfo/api.inc.php +++ b/modules-available/locationinfo/api.inc.php @@ -231,10 +231,15 @@ function getConfig($paneluuid) $config = LocationInfo::defaultPanelConfig($panel['paneltype']); $locations = Location::getLocationsAssoc(); + $overrides = false; - if (!empty($panel['config'])) { - $json = json_decode($panel['config'], true); + if (!empty($panel['panelconfig'])) { + $json = json_decode($panel['panelconfig'], true); if (is_array($json)) { + if (isset($json['overrides']) && is_array($json['overrides'])) { + $overrides = $json['overrides']; + } + unset($json['overrides']); $config = $json + $config; } } @@ -245,6 +250,9 @@ function getConfig($paneluuid) 'id' => $lid, 'name' => isset($locations[$lid]) ? $locations[$lid]['locationname'] : 'noname00.pas', ); + if (isset($overrides[$lid]) && is_array($overrides[$lid])) { + $config['locations'][$lid]['overrides'] = $overrides[$lid]; + } } appendMachineData($config['locations'], $lids, true); $locChange = appendOpeningTimes($config['locations'], $lids); diff --git a/modules-available/locationinfo/frontend/doorsign.html b/modules-available/locationinfo/frontend/doorsign.html index a39b982a..baee4dca 100755 --- a/modules-available/locationinfo/frontend/doorsign.html +++ b/modules-available/locationinfo/frontend/doorsign.html @@ -153,7 +153,6 @@ optional: padding: 0; box-sizing: border-box; background: linear-gradient(#cccccc, white); - } .free-busy-busy { @@ -238,6 +237,10 @@ optional: border-radius: 0; } + .wc-scrollable-grid { + transition: height 500ms; + } + .wc-scrollable-grid .wc-day-column-first { border-style: solid; @@ -247,7 +250,6 @@ optional: border-color: grey; } - </style> <script type='text/javascript' src='../../../script/jquery.js'></script> @@ -372,9 +374,9 @@ optional: addRoom(fetchedRooms[i]); } + panelUuid = uuid; initRooms(); // TODO: Check for changed config using get=timestamp and reload whole page on change - panelUuid = uuid; }, error: function () { fatalError('Could not fetch panel config'); @@ -478,7 +480,7 @@ optional: var width = "100%"; var height = "100%"; var top, left; - hasMode4 = (globalConfig.mode === 4); + hasMode4 = false; if (roomIds.length === 2 || roomIds.length === 4) { width = "50%"; } @@ -499,16 +501,14 @@ optional: left = ((t % 2) * 50) + '%'; } - var $loc = $("<div>").prop('id', "location_" + rid).addClass('location-container'); + var $loc = $("<div>").addClass('location-container'); $loc.css({top: top, left: left, width: width, height: height}); $("body").append($loc); - room.$.container = $loc; + room.$.container = $loc; room.$.locationName = $('<div>').addClass('col').addClass('header-font'); - room.$.currentEvent = $("<span>").addClass('nowrap'); room.$.currentRemain = $("<span>").addClass('nowrap').addClass('timer'); - room.$.seatsCounter = $('<span>').addClass('seats-counter'); room.$.seatsBackground = $('<div>').addClass('col col-square').append(room.$.seatsCounter); @@ -516,31 +516,24 @@ optional: $header.append(room.$.locationName); $header.append($('<div>').addClass('col header-font center').append(room.$.currentEvent).append(' ').append(room.$.currentRemain)); $header.append(room.$.seatsBackground); - - $loc.append($header); room.$.header = $header; + $loc.append($header); if (room.name !== null) { room.$.locationName.text(room.name); } - if (room.config.mode === 1) { - setUpCalendar(room.config.scale + "%", room.config.daystoshow, rooms[rid]); - initRoomLayout(rooms[rid]); - - } else if (room.config.mode === 2) { - setUpCalendar("100%", room.config.daystoshow, rooms[rid]); - - } else if (room.config.mode === 3) { - initRoomLayout(rooms[rid]); - - } else if (room.config.mode === 4) { - setUpCalendar("100%", room.config.daystoshow, rooms[rid]); - initRoomLayout(rooms[rid]); + if (room.config.mode !== 3) { + setUpCalendar(room); + } + if (room.config.mode !== 2) { + initRoomLayout(room); + } + if (room.config.mode === 4) { hasMode4 = true; } - SetOpeningTimes(rooms[rid]); - UpdateRoomHeader(rooms[rid]); + SetOpeningTimes(room); + UpdateRoomHeader(room); (function (room) { setTimeout(function () { @@ -553,41 +546,30 @@ optional: generateProgressBar(); } - setInterval(mainUpdateLoop, 1000); + mainUpdateLoop(); + setInterval(mainUpdateLoop, 10000); + setInterval(updateHeaders, globalConfig.eco ? 10000 : 1000); } - var timeSteps = 10; var lastDate = false; /** - * Main Update loop, this loop runs every 1 seconds and calls all - * function which should be called periodically + * Main Update loop, this loop runs every 10 seconds */ function mainUpdateLoop() { var date = MyDate(); var now = date.getTime(); - // check every 10 sec if rooms need new calendar data or room data - // groups request - - if (timeSteps > 9) { - timeSteps = 0; - if (lastCalendarUpdate + globalConfig.calupdate < now) { - lastCalendarUpdate = now; - queryCalendars(); - } - if (lastRoomUpdate + globalConfig.roomupdate < now) { - lastRoomUpdate = now; - queryRooms(); - } + if (lastCalendarUpdate + globalConfig.calupdate < now) { + lastCalendarUpdate = now; + queryCalendars(); } - - for (var property in rooms) { - if (rooms[property].state.end) { - // Updating All room Headers - UpdateRoomHeader(rooms[property]); - } + if (lastRoomUpdate + globalConfig.roomupdate < now) { + lastRoomUpdate = now; + queryRooms(); } + $('.calendar').weekCalendar("scrollToHour"); + // reload site at midnight var today = date.getDate(); if (lastDate !== false) { @@ -597,7 +579,19 @@ optional: } else { lastDate = today; } - timeSteps++; + } + + /** + * Update all location headers. + * Runs ever second (normal) or every 10 seconds (eco) + */ + function updateHeaders() { + for (var property in rooms) { + if (rooms[property].state.end) { + // Updating All room Headers + UpdateRoomHeader(rooms[property]); + } + } } @@ -658,17 +652,17 @@ optional: /** * inilizes the Calendar for an room - * @param percent Percentages of how mucht width the Calendar div should get (only used in mode 1) - * @param daysToShow How many days the calendar should show * @param room Room Object */ - function setUpCalendar(percent, daysToShow, room) { - generateCalendarDiv(percent, room); + function setUpCalendar(room) { + var daysToShow = room.config.daystoshow; + generateCalendarDiv(room); room.$.calendar.weekCalendar({ timeslotsPerHour: 1, timeslotHeight: 30, daysToShow: daysToShow, height: function () { + if (room.config.mode === 1 && room.config.vertical && (!room.timetable || !room.timetable.length)) return 20; var height = $(window).height(); if (roomIds.length === 4) { height /= 2; @@ -713,13 +707,16 @@ optional: * @param room Room Object */ - function generateCalendarDiv(width, room) { - var $cal = $('<div>').prop('id', 'calendar_' + room.id).addClass('calendar'); - if (room.config.vertical && room.config.mode === 1) { - width = 100 + "%"; + function generateCalendarDiv(room) { + var width = 100; + if (room.config.mode === 1 && !room.config.vertical) { + width = room.config.scale; + } + var $cal = $('<div>').addClass('calendar'); + if (room.config.mode === 1 && room.config.vertical) { $cal.css('float', "none"); } - $cal.width(width); + $cal.width(width + '%'); room.$.container.append($cal); room.$.calendar = $cal; } @@ -785,12 +782,12 @@ optional: close = 24; } room.openTimes = close - opening; + scaleCalendar(room); room.$.calendar.weekCalendar("option", "businessHours", { start: opening, end: close, limitDisplay: true }); - scaleCalendar(room); } /** @@ -879,8 +876,12 @@ optional: var cal = room.$.calendar; cal.weekCalendar('option', 'data', {events: json}); cal.weekCalendar("refresh"); - cal.weekCalendar("option", "defaultFreeBusy", {free: false}); + cal.weekCalendar("option", "defaultFreeBusy", {free: !room.openingTimesCalendar}); cal.weekCalendar("updateFreeBusy", room.openingTimesCalendar); + cal.weekCalendar("resizeCalendar"); + setTimeout(function() { + scaleRoom(room); + }, 550); } room.state = null; UpdateRoomHeader(room); @@ -955,12 +956,12 @@ optional: $cal.weekCalendar("option", "data", {events: room.timetable}); $cal.weekCalendar('refresh'); } + $cal.weekCalendar("option", "defaultFreeBusy", {free: !room.openingTimesCalendar}); if (room.openingTimesCalendar) { $cal.weekCalendar("updateFreeBusy", room.openingTimesCalendar); } $cal.weekCalendar("resizeCalendar"); - $cal.weekCalendar("scrollToHour"); - + $cal.weekCalendar("option", "hourLine", true); } /** @@ -969,7 +970,7 @@ optional: * @param {Date} a * @param {Date} b * @param room Room Object - * @returns time string + * @returns {string} printable time */ function GetTimeDiferenceAsString(a, b, room) { if (!a || !b) { @@ -990,10 +991,10 @@ optional: minutes = "0" + minutes; } if (days !== 0) { - // dont show? + // don't show? return ""; } - if (room.config.eco) { + if (globalConfig.eco) { return hours + ":" + minutes; } return hours + ":" + minutes + ":" + seconds; @@ -1002,12 +1003,13 @@ optional: /** * returns next closing time of a given room * @param room - * @returns Date Object of next closing + * @returns {Date} Object of next closing */ function GetNextClosing(room) { + if (!room.openingTimes || room.openingTimes.length === 0) return null; var now = MyDate(); var day = now.getDay(); - var bestdate = false; + var bestdate = null; for (var a = 0; a < 7; a++) { var tmp = room.openingTimes[(day + a) % 7]; if (!tmp) continue; @@ -1034,10 +1036,10 @@ optional: * checks if a room is on a given date/time open * @param date Date Object * @param room Room object - * @returns bool for open or not + * @returns {Boolean} for open or not */ function IsOpen(date, room) { - if (!room.openingTimes) return false; + if (!room.openingTimes || room.openingTimes.length === 0) return true; var tmp = room.openingTimes[date.getDay()]; if (!tmp) return false; var openDate = new Date(date.getTime()); @@ -1056,15 +1058,15 @@ optional: /** - * Retruns next Opening + * Returns next Opening * @param room Room Object - * @returns bestdate Date Object of next opening + * @returns {Date} Object of next opening */ function GetNextOpening(room) { if (!room.openingTimes) return null; var now = MyDate(); var day = now.getDay(); - var bestdate = false; + var bestdate = null; for (var dow = 0; dow < 7; dow++) { var tmp = room.openingTimes[(day + dow) % 7]; if (!tmp) continue; @@ -1087,7 +1089,7 @@ optional: /** - * Sets the free PCs number in the right corner and updates the sqare color acordingly + * Sets the free PCs number in the right corner and updates the square color accordingly * @param room Room * @param seats Number of free PC's in the room */ @@ -1198,7 +1200,7 @@ optional: /** * returns next event from a given json of events * @param calEvents Json which contains the calendar data. - * @returns event next Carlendar Event + * @returns event next Calendar Event */ function getNextEvent(calEvents) { if (!calEvents) return null; @@ -1227,6 +1229,7 @@ optional: /** * Skip to next upcoming day matching the given day of week. + * @return {Date} */ function getNextDayOfWeek(date, dayOfWeek) { var resultDate = new Date(date.getTime()); @@ -1238,8 +1241,8 @@ optional: */ - var picSizeX = 3.8; - var picSizeY = 3; + const picSizeX = 3.8; + const picSizeY = 3; /** * Generates the RoomLayout Div @@ -1316,19 +1319,12 @@ optional: * @param room Room Object */ function generateOffsetAndScale(room) { + var clientHeight; - var clientHeight = $(window).height(); - if (roomIds.length === 4) { - clientHeight /= 2; - } - - clientHeight -= room.$.header.height() - 5; - - if (roomIds.length > 1) { - clientHeight -= 5; - } if (room.config.vertical && room.config.mode === 1) { - clientHeight *= (1 - (room.config.scale / 100)); + clientHeight = room.$.container.height() - (room.$.calendar.position().top + room.$.calendar.height()); + } else { + clientHeight = room.$.container.height() - (room.$.header.height() + 5); } var clientWidth = room.$.layout.width(); @@ -1641,7 +1637,7 @@ optional: */ function generateProgressBar() { if ($pbar) return; - $pbar = $('<div id="progressBar" class="progressbar">'); + $pbar = $('<div class="progressbar">'); $('body').append($pbar); SetProgressBarSpeed(); } @@ -1665,6 +1661,14 @@ optional: }, interval); } + /** + * Convert passed argument to integer if possible, return NaN otherwise. + * The difference to parseInt() is that leading zeros are ignored and not + * interpreted as octal representation. + * + * @param str string or already a number + * @return {number} str converted to number, or NaN + */ function toInt(str) { var t = typeof str; if (t === 'number') return str | 0; |