Widget:Hotspots: Unterschied zwischen den Versionen

Aus Freifunk Dresden - Anwender-Wiki
Zur Navigation springen Zur Suche springen
Zeile 34: Zeile 34:
 
</style>
 
</style>
  
 
<div id="dialog" title="Basic dialog">
 
  <p>This is the default dialog which is useful for displaying information. The dialog window can be moved, resized and closed with the 'x' icon.</p>
 
</div>
 
  
 
<div>
 
<div>
Zeile 271: Zeile 267:
 
     my.query('#hotspots tbody').on('click', 'a.stats', function () {
 
     my.query('#hotspots tbody').on('click', 'a.stats', function () {
 
         var id = this.attributes['data'].nodeValue;
 
         var id = this.attributes['data'].nodeValue;
         //alert( 'You clicked: ' + id );
+
 
         my.query( "#dialog" ).dialog({
+
         //create  <div>
 +
        var popup = '<div id="statdialog" title="Statistik Knoten: '+ id +'">'
 +
                  + '<img src="https://stats.freifunk-dresden.de/summary/clients/6hour">'
 +
                  + '</div>';
 +
        my.query('body').append(popup);
 +
 
 +
        //show popup
 +
         my.query( '#statdialog' ).dialog({
 
           resizable: false,
 
           resizable: false,
 
           height: "auto",
 
           height: "auto",
 
           width: 400,
 
           width: 400,
 
           modal: true,
 
           modal: true,
 +
          close: function( event, ui ) {
 +
                    my.query( '#statdialog' ).remove();  //remove div
 +
                  }
 
         });
 
         });
 +
       
 +
       
 +
 
     } );
 
     } );
  
 
  } );
 
  } );
 
</script>
 
</script>

Version vom 8. Oktober 2018, 17:47 Uhr

<script type="text/javascript" src="https://api.freifunk-dresden.de/freifunk-dresden-hotspots.json.js"></script>

<script type="text/javascript" src="/hotspots/jquery/jquery.js"></script> <script type="text/javascript" src="/hotspots/jquery/jquery-ui.min.js"></script> <link rel="stylesheet" type="text/css" href="/hotspots/jquery/jquery-ui.min.css"/>

<link rel="stylesheet" type="text/css" href="/hotspots/datatables/datatables.min.css"/> <script type="text/javascript" src="/hotspots/datatables/datatables.min.js"></script>

<style> .stats {

  background-image:url('');
   background-size: 30px;
   background-repeat: no-repeat;
   background-position: center;
   display: block;
   width: 30px;
   height: 30px;
   text-decoration: none;
   cursor: pointer;
   overflow: hidden;
   text-indent: 100%;
   white-space:nowrap;

} </style>


Spalten anzeigen:

<a class="toggle-vis" data-column="1">IP-Adresse</a>,
<a class="toggle-vis" data-column="3">Registriert</a>,
<a class="toggle-vis" data-column="6">Stats</a>,
<a class="toggle-vis" data-column="9">SSID</a>,
<a class="toggle-vis" data-column="10">Gateway</a>,
<a class="toggle-vis" data-column="11">Model</a>
<thead> </thead> <tfoot> </tfoot>
Node IP Ok
GW
Tage
Registriert Name Map Stat Firmware AU SSID Gateway
aktuell/bevorzugt.
Model Ort Kommentar


<script type="text/javascript">

function getIp(node) {

var _middle = Math.floor((node / 255)) % 256;
var _minor  = (node % 255) + 1;
return '10.200.' + _middle.toString() + '.' + _minor.toString();

}

/* https://api.jquery.com/jquery.noconflict/

If for some reason two versions of jQuery are loaded (which is not recommended), calling $.noConflict(true) from the second version will return the globally scoped jQuery variables to those of the first version. Some times it could be issue with older version (or not stable) of JQuery files.

Solution: move new jQuery completely in new object and use this.

  • /

var my = {}; my.query = jQuery.noConflict( true );

// use new way to call function when DOM is ready. old way was $(document).ready(handler) my.query(function() {

 // remember Table, to later access it via event function when a link is clicked with
 // specific class name to make columns visible
 var myTable = my.query('#hotspots').DataTable( {

"processing": true,

//"pageLength" : 25, //"lengthMenu": [[ 25, 50, 100, 200, -1 ], [25,50,100,200,"All"]], paging: false,

"order" : 0,'asc',

// extensions "fixedHeader": true, //"responsive": true,

// define nowrap for specific columns "columnDefs": [ { className: "dt-nowrap", "targets": [0,1,2,3,4,5,6,7,8,9,10,11,12,13 ] }, // default: visible { visible: false, "targets": [ 1,3,6, 9,10,11 ] }

],

       "data": dataSet,
       // https://datatables.net/reference/option/rowCallback

"rowCallback": function( row, data ) {

if ( data.id < 1000 ) { row.style.backgroundColor= (row.className=="odd") ? "#bbddbb" : "#cceecc"; //row.firstChild.style.backgroundColor = row.style.backgroundColor; }

if ( data.id > 1000 && data.id < 51000 ) { row.style.backgroundColor= (row.className=="odd") ? "#ddddee" : "#eeeeff"; //row.firstChild.style.backgroundColor = row.style.backgroundColor; }

if ( data.status.offline_since > 2 ) { //row.style.backgroundColor= (row.className=="odd") ? "#cccccc" : "#dddddd"; row.style.backgroundColor= "#cccccc"; //row.firstChild.style.backgroundColor = row.style.backgroundColor; } },

       // see: https://datatables.net/manual/data/orthogonal-data
       "columns": [

{ "data": "id", "render" : function (data, type, row) { // If display or filter data is requested, format the date if ( type === 'display' || type === 'filter' ) { return '<a href="http://' + data + '.freifunk-dresden.de/">' + data + '</a>'; } //else return id that is used when sorting this column return data; } }, { "data": "id", //use "id" as input data for renderer "render" : function (data, type, row) { // If display or filter data is requested, format the date if ( type === 'display' || type === 'filter' ) { var ip = getIp(data); return '<a href="http://' + ip + '/">' + ip + '</a>'; } //else return id that is used when sorting this column return data; } }, { "data": "status", "render" : function (data, type, row) { if ( type === 'display' || type === 'filter' ) { var img_o = data.online ? 'yes.png' : 'no.png'; var img_g = data.gateway ? 'yes.png' : 'no.png'; return 'Ja' + 'Ja' + '[' + data.offline_since + ']'; } return data.offline_since; } }, { "data": "status.registered", "render" : function (data, type, row) { if ( type === 'display' || type === 'filter' ) { var t = new Date(data*1000); var day = ( '0' + t.getDate() ).slice(-2); var month = ( '0' + t.getMonth() ).slice(-2); var h = ( '0' + t.getHours() ).slice(-2); var m = ( '0' + t.getMinutes() ).slice(-2); return day + '.' + month + '.' + t.getFullYear() + ' ' + h + ':' + m; } return data; } }, { "data": "name", "render" : function (data, type, row) { return data.substring(0,15); } }, { "data": "position", "render" : function (data, type, row) { if ( type === 'display' || type === 'filter' ) { return '<a href="http://maps.google.de/maps?f=q&hl=de&q='

                                     + data.lat.toString() + ','
                                     + data.lon.toString() + '&ie=UTF8&z=15&iwloc=addr&om=1">Map</a>'; 

} return 0; } }, { "data": "id", "render" : function (data, type, row) { // If display or filter data is requested, format the date if ( type === 'display' || type === 'filter' ) { return '<a class="stats" data="' + data + '"></a>'

                                           + ' <a target="_blank" href="https://stats.freifunk-dresden.de/' + data + '/clients/6hour">C</a>'
                                           + '/' + '<a target="_blank" href="https://stats.freifunk-dresden.de/' + data + '/wifi/6hour">W</a>'
                                           + '/' + '<a target="_blank" href="https://stats.freifunk-dresden.de/' + data + '/backbone/6hour">B</a>'
                                           + '/' + '<a target="_blank" href="https://stats.freifunk-dresden.de/' + data + '/ovpn/6hour">O</a>'

} //else return id that is used when sorting this column return data; } },

{ "data": "firmware" }, { "data": "status.autoupdate", "render" : function (data, type, row) { if ( type === 'display' || type === 'filter' ) { var img_o = data ? 'yes.png' : 'no.png'; return 'Ja'; } return data; } }, { "data": "status.ssid"}, { "data": "status", "render" : function (data, type, row) { if ( type === 'display' || type === 'filter' ) { return data.selected_gateway + '(' + data.preferred_gateway + ')'; } return data.selected_gateway; } }, { "data": "model", "render" : function (data, type, row) { return data.substring(0,25); } }, { "data": "location", "render" : function (data, type, row) { return data.substring(0,25); } }, { "data": "note", "render" : function (data, type, row) { return data.substring(0,40); } },

       ]
   } );
   //function that is called each time a link with class "toggle-vis" is clicked.
   //Then corresponding column visibility toggles
   my.query('a.toggle-vis').on( 'click', function (e) {
       e.preventDefault();

       // Get the column API object
       var column = myTable.column( $(this).attr('data-column') );

       // Toggle the visibility
       column.visible( ! column.visible() );
   } );
   //register event handler
   my.query('#hotspots tbody').on('click', 'a.stats', function () {
       var id = this.attributes['data'].nodeValue;

//create

var popup = '
'
                 + ''
+ '
';
       my.query('body').append(popup);
       //show popup
       my.query( '#statdialog' ).dialog({
          resizable: false,
          height: "auto",
          width: 400,
          modal: true,
          close: function( event, ui ) {
                   my.query( '#statdialog' ).remove();  //remove div
                 }
       });
       
       
   } );
} );

</script>