diff options
-rw-r--r-- | modules-available/locationinfo/api.inc.php | 86 | ||||
-rw-r--r-- | modules-available/locationinfo/install.inc.php | 18 | ||||
-rw-r--r-- | modules-available/locationinfo/lang/de/module.json | 5 | ||||
-rw-r--r-- | modules-available/locationinfo/lang/de/template-tags.json | 28 | ||||
-rw-r--r-- | modules-available/locationinfo/lang/en/module.json | 5 | ||||
-rw-r--r-- | modules-available/locationinfo/lang/en/template-tags.json | 28 | ||||
-rw-r--r-- | modules-available/locationinfo/lang/pt/template-tags.json | 3 | ||||
-rw-r--r-- | modules-available/locationinfo/page.inc.php | 97 | ||||
-rw-r--r-- | modules-available/locationinfo/style.css | 47 | ||||
-rw-r--r-- | modules-available/locationinfo/templates/_page.html | 4 | ||||
-rw-r--r-- | modules-available/locationinfo/templates/location-info.html | 203 | ||||
-rw-r--r-- | modules-available/locationinfo/templates/pcsubtable.html | 22 |
12 files changed, 520 insertions, 26 deletions
diff --git a/modules-available/locationinfo/api.inc.php b/modules-available/locationinfo/api.inc.php index 0d84ebce..be202546 100644 --- a/modules-available/locationinfo/api.inc.php +++ b/modules-available/locationinfo/api.inc.php @@ -1,7 +1,83 @@ <?php -echo json_encode(array( - 'key' => 'value', - 'number' => 123, - 'list' => array(1,2,3,4,5,6,'foo') -)); +HandleParameters(); + +function HandleParameters() { + $getAction = $_GET['action']; + + if ($getAction == "roominfo") { + $getRoomID = $_GET['id']; + $getCoords = $_GET['coords']; + + if (empty($getCoords)) { + $getCoords = '0'; + } + getRoomInfoJson($getRoomID, $getCoords); + } +} + +function getRoomInfoJson($locationID, $coords) { + $error = false; + + $dbquery = Database::simpleQuery("SELECT hidden FROM `locationinfo` WHERE locationid = $locationID"); + + while($roominfo=$dbquery->fetch(PDO::FETCH_ASSOC)) { + $hidden = $roominfo['hidden']; + if ($hidden === '0') { + $error = false; + } else { + $error = true; + } + } + $pcs = getPcInfos($locationID, $coords); + + if (empty($pcs)) { + $error = true; + } + + if ($error === false) { + echo $pcs; + } else { + echo "ERROR"; + } +} + +function getPcInfos($locationID, $coords) { + + $dbquery; + + if ($coords === '1') { + $dbquery = Database::simpleQuery("SELECT machineuuid, position, logintime FROM `machine` WHERE locationid = $locationID"); + } else { + $dbquery = Database::simpleQuery("SELECT machineuuid, logintime FROM `machine` WHERE locationid = $locationID"); + } + + $pcs = array(); + + while($pc=$dbquery->fetch(PDO::FETCH_ASSOC)) { + + $computer = array(); + + $computer['id'] = $pc['machineuuid']; + + if ($coords === '1') { + $position = json_decode($pc['position'], true); + $computer['x'] = $position['gridRow']; + $computer['y'] = $position['gridCol']; + } + + $computer['inUse'] = 0; + + if ($pc['logintime'] > 0) { + $computer['inUse'] = 1; + } + + $pcs[] = $computer; + } + + $str = json_encode($pcs, true); + + return $str; +} + +?> diff --git a/modules-available/locationinfo/install.inc.php b/modules-available/locationinfo/install.inc.php new file mode 100644 index 00000000..807e2826 --- /dev/null +++ b/modules-available/locationinfo/install.inc.php @@ -0,0 +1,18 @@ +<?php + +$res = array(); + +$res[] = tableCreate('locationinfo', ' + `locationid` INT(11) NOT NULL, + `hidden` BOOLEAN NOT NULL DEFAULT 0, + `computers` BLOB DEFAULT NULL, + PRIMARY KEY (`locationid`) +'); + +// Create response for browser + +if (in_array(UPDATE_DONE, $res)) { + finalResponse(UPDATE_DONE, 'Tables created successfully'); +} + +finalResponse(UPDATE_NOOP, 'Everything already up to date'); diff --git a/modules-available/locationinfo/lang/de/module.json b/modules-available/locationinfo/lang/de/module.json index 166909c3..2fd14353 100644 --- a/modules-available/locationinfo/lang/de/module.json +++ b/modules-available/locationinfo/lang/de/module.json @@ -1,4 +1,3 @@ { - "module_name": "Mein erstes Modul", - "page_title": "Mein erster Seitentitel" -}
\ No newline at end of file + "module_name": "Infoscreen" +} diff --git a/modules-available/locationinfo/lang/de/template-tags.json b/modules-available/locationinfo/lang/de/template-tags.json index ce98ce38..843beb5a 100644 --- a/modules-available/locationinfo/lang/de/template-tags.json +++ b/modules-available/locationinfo/lang/de/template-tags.json @@ -1,3 +1,27 @@ { - "lang_hello": "Hallo" -}
\ No newline at end of file + "lang_mainHeader": "Infoscreen", + + "lang_locationName": "Name", + "lang_locationID": "ID", + "lang_locationIsHidden": "Versteckt", + "lang_locationInUse": "In Benutzung / Gesamt", + "lang_locationSettings": "Einstellungen", + + + "lang_pcID": "ID", + "lang_pcX": "X", + "lang_pcY": "Y", + "lang_pcInUse": "In Benutzung", + + "lang_day": "Tag", + "lang_openingTime": "Öffnungszeit", + "lang_closingTime": "Schließungszeit", + + "lang_shortMonday": "Mo", + "lang_shortTuesday": "Di", + "lang_shortWednesday": "Mi", + "lang_shortThursday": "Do", + "lang_shortFriday": "Fr", + "lang_shortSaturday": "Sa", + "lang_shortSunday": "So" +} diff --git a/modules-available/locationinfo/lang/en/module.json b/modules-available/locationinfo/lang/en/module.json index b2bcbb0c..2fd14353 100644 --- a/modules-available/locationinfo/lang/en/module.json +++ b/modules-available/locationinfo/lang/en/module.json @@ -1,4 +1,3 @@ { - "module_name": "My first module", - "page_title": "My first page title" -}
\ No newline at end of file + "module_name": "Infoscreen" +} diff --git a/modules-available/locationinfo/lang/en/template-tags.json b/modules-available/locationinfo/lang/en/template-tags.json index c30739e5..4c4d1d38 100644 --- a/modules-available/locationinfo/lang/en/template-tags.json +++ b/modules-available/locationinfo/lang/en/template-tags.json @@ -1,3 +1,27 @@ { - "lang_hello": "Hello" -}
\ No newline at end of file + "lang_mainHeader": "Infoscreen", + + "lang_locationName": "Name", + "lang_locationID": "ID", + "lang_locationIsHidden": "Hidden", + "lang_locationInUse": "In use / total", + "lang_locationSettings": "Settings", + + + "lang_pcID": "ID", + "lang_pcX": "X", + "lang_pcY": "Y", + "lang_pcInUse": "In Use", + + "lang_day": "Day", + "lang_openingTime": "Opening time", + "lang_closingTime": "Closing time", + + "lang_shortMonday": "Mon", + "lang_shortTuesday": "Tue", + "lang_shortWednesday": "Wed", + "lang_shortThursday": "Thu", + "lang_shortFriday": "Fri", + "lang_shortSaturday": "Sat", + "lang_shortSunday": "Sun" +} diff --git a/modules-available/locationinfo/lang/pt/template-tags.json b/modules-available/locationinfo/lang/pt/template-tags.json deleted file mode 100644 index e7981844..00000000 --- a/modules-available/locationinfo/lang/pt/template-tags.json +++ /dev/null @@ -1,3 +0,0 @@ -{ - "lang_hello": "Olá" -}
\ No newline at end of file diff --git a/modules-available/locationinfo/page.inc.php b/modules-available/locationinfo/page.inc.php index ff73107a..f6b4b661 100644 --- a/modules-available/locationinfo/page.inc.php +++ b/modules-available/locationinfo/page.inc.php @@ -3,13 +3,14 @@ class Page_LocationInfo extends Page { + private $action; + /** * Called before any page rendering happens - early hook to check parameters etc. */ protected function doPreprocess() { User::load(); - if (!User::isLoggedIn()) { Message::addError('main.no-permission'); Util::redirect('?do=Main'); // does not return @@ -21,9 +22,97 @@ class Page_LocationInfo extends Page */ protected function doRender() { - Render::addTemplate('_page', array( - 'foo' => 'bar', - 'now' => date('d.m.Y H:i:s') + $getAction = Request::get('action'); + if (empty($getAction)) { + Util::redirect('?do=locationinfo&action=infoscreen'); + } + + if ($getAction === 'infoscreen') { + $this->getInfoScreenTable(); + } + + if($getAction == 'updateroomdb') { + $this->updateInfoscreenDb(); + Util::redirect('?do=locationinfo&action=infoscreen'); + } + + if ($getAction === 'hide') { + $roomId = Request::get('id'); + $hiddenValue = Request::get('value'); + $this->toggleHidden($roomId, $hiddenValue); + Util::redirect('?do=locationinfo&action=infoscreen'); + } + } + + protected function toggleHidden($id, $val) { + Database::exec("UPDATE `locationinfo` SET hidden = $val WHERE locationid = $id"); + } + + protected function getInfoScreenTable() { + + $dbquery = Database::simpleQuery("SELECT * FROM `locationinfo`"); + + $pcs = array(); + while($roominfo=$dbquery->fetch(PDO::FETCH_ASSOC)) { + $data = array(); + $data['locationid'] = $roominfo['locationid']; + $data['hidden'] = $roominfo['hidden']; + + $inUseCounter = 0; + $totalPcCounter = 0; + $data['computers'] = json_decode($roominfo['computers'], true); + + foreach ($data['computers'] as $value) { + if ($value['inUse'] == 1) { + $inUseCounter++; + } + $totalPcCounter++; + } + $data['inUse'] = $inUseCounter; + $data['totalPcs'] = $totalPcCounter; + $pcs[] = $data; + } + + Render::addTemplate('location-info', array( + 'list' => array_values($pcs), + )); + } + + protected function updateInfoscreenDb() { + $dbquery = Database::simpleQuery("SELECT DISTINCT locationid FROM `machine` WHERE locationid IS NOT NULL"); + while($roominfo=$dbquery->fetch(PDO::FETCH_ASSOC)) { + $this->updatePcInfos($roominfo['locationid']); + } + } + + /** + * AJAX + */ + protected function doAjax() + { + User::load(); + if (!User::isLoggedIn()) { + die('Unauthorized'); + } + $action = Request::any('action'); + if ($action === 'pcsubtable') { + $id = Request::any('id'); + $this->ajaxShowLocation($id); + + } + } + + private function ajaxShowLocation($id) + { + $dbquery = Database::simpleQuery("SELECT * FROM `locationinfo` WHERE locationid = $id"); + + $data = array(); + while($roominfo=$dbquery->fetch(PDO::FETCH_ASSOC)) { + $data = json_decode($roominfo['computers'], true); + } + + echo Render::parse('pcsubtable', array( + 'list' => array_values($data), )); } diff --git a/modules-available/locationinfo/style.css b/modules-available/locationinfo/style.css new file mode 100644 index 00000000..2169efa2 --- /dev/null +++ b/modules-available/locationinfo/style.css @@ -0,0 +1,47 @@ +/* The Modal (background) */ +.modal { + display: none; /* Hidden by default */ + position: fixed; /* Stay in place */ + z-index: 1; /* Sit on top */ + left: 0; + top: 0; + width: 100%; /* Full width */ + height: 100%; /* Full height */ + overflow: auto; /* Enable scroll if needed */ + background-color: rgb(0,0,0); /* Fallback color */ + background-color: rgba(0,0,0,0.4); /* Black w/ opacity */ +} + +/* Modal Content/Box */ +.modal-content { + background-color: #fefefe; + margin: 15% auto; /* 15% from the top and centered */ + padding: 20px; + border: 1px solid #888; + width: 40%; /* Could be more or less, depending on screen size */ +} + +/* The Close Button */ +.close { + color: #aaa; + float: right; + font-size: 28px; + font-weight: bold; +} + +.close:hover, +.close:focus { + color: black; + text-decoration: none; + cursor: pointer; +} + +.tablerow:hover { + background-color: #F2F2F2; +} + +.divider{ + width:50px; + height:auto; + display:inline-block; +} diff --git a/modules-available/locationinfo/templates/_page.html b/modules-available/locationinfo/templates/_page.html deleted file mode 100644 index dfc941ae..00000000 --- a/modules-available/locationinfo/templates/_page.html +++ /dev/null @@ -1,4 +0,0 @@ -<div style="border:5px solid red"> - <h1>{{lang_hello}}, {{foo}}</h1> - ** {{now}} ** -</div>
\ No newline at end of file diff --git a/modules-available/locationinfo/templates/location-info.html b/modules-available/locationinfo/templates/location-info.html new file mode 100644 index 00000000..9e4e886d --- /dev/null +++ b/modules-available/locationinfo/templates/location-info.html @@ -0,0 +1,203 @@ +<div> +<h1>{{lang_mainHeader}}</h1> + +<!-- The Modal --> +<div id="popup" class="modal"> + <!-- Modal content --> + <div class="modal-content"> + <span class="close" onclick="closePopup()">x</span> + <label id=1></label> + <br> + + <!-- vvvv TEST STUFF vvvv--> + <table class="table table-condensed locations" style="margin-bottom:0px"> + <tr> + <th>{{lang_day}}</th> + <th>{{lang_openingTime}}</th> + <th>{{lang_closingTime}}</th> + </tr> + + <tr> + <td>Monday</td> + <td>08:00</td> + <td>16:00</td> + </tr> + + <tr> + <td>MO, DI, MI, DO, FR, SA</td> + <td>08:00</td> + <td>21:00</td> + </tr> + + <tr> + <td>SO</td> + <td>10:00</td> + <td>12:00</td> + </tr> + + <tr> + <td>MON, TUE, WED, THU, FRI, SAT, SUN</td> + <td>10:00</td> + <td>12:00</td> + </tr> + + <tr> + <td> + <label><input type="checkbox" value="Monday">{{lang_shortMonday}}</label> + <label><input type="checkbox" value="Tuesday">{{lang_shortTuesday}}</label> + <label><input type="checkbox" value="Wednesday">{{lang_shortWednesday}}</label> + <label><input type="checkbox" value="Thursday">{{lang_shortThursday}}</label> + <label><input type="checkbox" value="Friday">{{lang_shortFriday}}</label> + <label><input type="checkbox" value="Saturday">{{lang_shortSaturday}}</label> + <label><input type="checkbox" value="Sunday">{{lang_shortSunday}}</label> + </td> + <td> + <label><input type="text" onkeypress="return isNumber(event)" style="width:35px;"> :</label> + <input type="text" onkeypress="return isNumber(event)" style="width:35px;"> + </td> + <td> + <label><input type="text" onkeypress="return isNumber(event)" style="width:35px;"> :</label> + <input type="text" onkeypress="return isNumber(event)" style="width:35px;"> + </td> + </tr> + </table> + + <!-- ^^^^ TEST STUFF ^^^^--> + + <button class="btn btn-success btn-sm">Add</button> + <button class="btn btn-sm btn-danger">Delete</button> + + + <br><br> + <button class="btn btn-primary">Save</button> + <div class="divider"></div> + <button class="btn btn-sm btn-danger" onclick="closePopup()">Cancel</button> + </div> + +</div> +<script> + +// Get the modal +var modal = document.getElementById('popup'); + +// Get the button that opens the modal +var btn = document.getElementById("myBtn"); + +// Get the <span> element that closes the modal +var span = document.getElementsByClassName("close")[0]; + +// When the user clicks on the button, open the modal +function openPopup(locID) { + modal.style.display = "block"; + + $('#1').text('Location ID: ' + locID); +} + +// When the user clicks on <span> (x), close the modal +function closePopup() { + modal.style.display = "none"; +} + +// When the user clicks anywhere outside of the modal, close it +window.onclick = function(event) { + if (event.target == modal) { + modal.style.display = "none"; + } +} +</script> + +<table class="table table-condensed locations" style="margin-bottom:0px"> + + <tr> + <th>{{lang_locationID}}</th> + <th>{{lang_locationInUse}}</th> + <th width=50>{{lang_locationIsHidden}}</th> + <th width=50>{{lang_locationSettings}}</th> + </tr> + +{{#list}} + <tr class="tablerow" onclick="slxOpenLocationInfo(this, {{locationid}})"> + <td> + <div style="display:inline-block;width:{{depth}}em"></div> + <a href="#" >{{locationid}}<b class="caret"></b></a> + </td> + <td>{{inUse}} / {{totalPcs}}</td> + <!-- <td>{{hidden}}</td> --> + <!-- <td><form><input type="checkbox" id={{locationid}} value={{hidden}}></form></td> --> + <td id={{locationid}} onclick="event.cancelBubble = true;" align="center"></td> + <script> + var cbh = document.getElementById('{{locationid}}'); + var cb = document.createElement('input'); + cb.type = 'checkbox'; + + cbh.appendChild(cb); + cb.id = 'cb' + {{locationid}}; + cb.value = {{hidden}}; + if ({{hidden}} == 1) { + cb.checked = true; + } + cb.addEventListener("click", function() { cbClick(this, {{locationid}}); }); + </script> + + <td><button onclick="event.cancelBubble = true; openPopup({{locationid}})">{{lang_locationSettings}}</button></td> + + </tr> +{{/list}} + +</table> + +<script type="text/javascript"><!-- + +function isNumber(evt) { + evt = (evt) ? evt : window.event; + var charCode = (evt.which) ? evt.which : evt.keyCode; + if (charCode > 31 && (charCode < 48 || charCode > 57)) { + return false; + } + return true; +} + +var x = false; + +var lastPcSubTable = false; + +function cbClick(cb, locID) { + // TODO TOGGLE CB and set db Value + //alert("TODO set db value and toggle cb: " + locID); + var value; + + if (cb.checked == true) { + value = 1; + } else { + value = 0; + } + window.location.href = "?do=locationinfo&action=hide&id=" + locID + "&value=" + value; +} + +function slxOpenLocationInfo(e, locationId) { + if (lastPcSubTable !== false) { + lastPcSubTable.hide(); + $(lastPcSubTable).prev().removeClass('active slx-bold'); + } + + var existing = $('#subtable' + locationId); + if (existing.length > 0) { + if (existing.is(lastPcSubTable)) { + lastPcSubTable = false; + } else { + existing.show(); + $(e).closest('tr').addClass('active slx-bold'); + lastPcSubTable = existing; + } + return; + } + + var td = $('<td>').attr('colspan', '2').css('padding', '0px 0px 12px'); + var tr = $('<tr>').attr('id', 'subtable' + locationId); + tr.append(td); + $(e).closest('tr').addClass('active slx-bold').after(tr); + td.load("?do=locationinfo&action=pcsubtable&id=" + locationId); + lastPcSubTable = tr; +} + // --> +</script> diff --git a/modules-available/locationinfo/templates/pcsubtable.html b/modules-available/locationinfo/templates/pcsubtable.html new file mode 100644 index 00000000..0359813b --- /dev/null +++ b/modules-available/locationinfo/templates/pcsubtable.html @@ -0,0 +1,22 @@ +<div> +<br> +<table style="margin-bottom:0px"> + <tr> + <th width=120>{{lang_pcID}}</th> + <th width=50>{{lang_pcX}}</th> + <th width=50>{{lang_pcY}}</th> + <th width=20>{{lang_pcInUse}}</th> + </tr> + +{{#list}} + <tr class="tablerow"> + <td>{{id}}</td> + <td>{{x}}</td> + <td>{{y}}</td> + <td align="center">{{inUse}}</td> + </tr> +{{/list}} + +</table> +<br> +</div> |