gest366/lib/widgets.class.php

150 lines
5.2 KiB
PHP

<?php
/**
*
* Classe Widgets
*
* @version : 0.2
* La classe viene inclusa per poter creare il codice dei widgets
* Per poterla utilizzare è necessario che precedentemente sia stata inclusa la classe per la manipolazione del database
*
*/
class Widgets {
/**
* Funzione createWidget
* $id_widget: l'id numerico del widget da creare ed inserire nella pagina
* Sa seconda del tipo di widget inserisce il codice HTML per la sua creazione nella pagina.
* Ottiene i dati per la creazione
* del widget da tabella, in maniera da crearli in maniera dinamica a seconda dei campi
*/
function createWidget($id_widget, $class, $totalNumber = 6) {
global $dbo;
global $rootdir;
// se ho passato il parametro allora
if (isset($id_widget)) {
// ottengo i dati del widget passato come parametro da database
$rs_w = $dbo->fetchArray("SELECT * FROM zz_widget_modules WHERE id=" . prepare($id_widget));
// a seconda del tipo inserisco il widget in maniera differente
switch ($rs_w[0]['type']) {
// widget di tipo statistiche
case "print" :
case "stats" :
$query = $rs_w[0]['query'];
$query = str_replace("|period_start|", $_SESSION['period_start'], $query);
$query = str_replace("|period_end|", $_SESSION['period_end'], $query);
$dato = "";
if($query != "") $dato = $dbo->fetchArray($query)[0]['dato'];
// inserisco il widget
echo '
<li class="col-xs-12 col-sm-6 col-md-4 col-lg-' . intval(12/$totalNumber) . ' li-widget" id="widget_' . $rs_w[0]['id'] . '">
<button type="button" class="close" onclick="if(confirm(\'Disabilitare questo widget?\')) { $.post( \'' . $rootdir . '/modules/aggiornamenti/actions.php?id_module=' . $rs_w[0]['id_module'] . '\', { op: \'disable_widget\', id: \'' . $rs_w[0]['id'] . '\' }, function(response){ location.href = \'' . $rootdir . '/controller.php?id_module=' . $rs_w[0]['id_module'] . '\'; }); };" ><span aria-hidden="true">&times;</span><span class="sr-only">' . _("Chiudi") . '</span></button>
<a class="clickable" ';
if ($rs_w[0]['more_link'] != '') {
if ($rs_w[0]['more_link_type'] == 'link') {
echo 'href="' . $rs_w[0]['more_link'] . '"';
}
else if ($rs_w[0]['more_link_type'] == 'popup') {
echo 'data-href="' . $rs_w[0]['more_link'] . '" data-toggle="modal" data-title="' . $rs_w[0]['text'] . '" data-target="#bs-popup"';
}
else if ($rs_w[0]['more_link_type'] == 'javascript') {
$link = $rs_w[0]['more_link'];
$link = str_replace("|period_start|", $_SESSION['period_start'], $link);
$link = str_replace("|period_end|", $_SESSION['period_end'], $link);
echo 'onclick="' . $link . '"';
}
}
echo '>
<div class="info-box">
<span class="info-box-icon" style="background-color:' . $rs_w[0]['bgcolor'] . '">
<i class="' . $rs_w[0]['icon'] . '"></i>
</span>
<div class="info-box-content">
<span class="info-box-text">' . $rs_w[0]['text'] . '</span>
<span class="info-box-number">' . $dato . '</span>
</div>
</div>
</a>
</li>';
break;
// widget di tipo chart: importa la pagina php specificata nel campo php_include della tabella, non ha l'icona
case "chart" :
echo '
<li class="' . $class . '" id="' . $rs_w[0]['id'] . '">
<!-- small box -->
<div class="small-box bg-' . $rs_w[0]['bgcolor'] . '">
<div class="inner">';
include_once ($rs_w[0]['php_include']);
echo '
</div>
</div>
</li>';
break;
// widget custom con codice php e icona
case "custom" :
echo '
<li class="' . $class . '" id="' . $rs_w[0]['id'] . '">
<!-- small box -->
<div class="small-box bg-' . $rs_w[0]['bgcolor'] . '">
<div class="inner">';
include_once ($rs_w[0]['php_include']);
echo '
</div>
<div class="icon">
<i class="' . $rs_w[0]['icon'] . '"></i>
</div>
</div>
</li>';
break;
}
}
}
/**
* Funzione addModuleWidgets
* $id_modulo: modulo in cui ci si trova
* $location: location all'interno del modulo, per esempio controller oppure inserimento/modifica
* Prende da database tutti i widget associati al modulo passato come parametro e li aggiunge con createWidget
* alla pagina
*/
function addModuleWidgets($id_module, $location) {
global $dbo;
if (isset($id_module)) {
// ottengo da db gli id dei widget associati al modulo
$rs_w = $dbo->fetchArray("SELECT id, location, class FROM zz_widget_modules WHERE id_module=\"" . $id_module . "\" AND location=\"" . $location . "\" AND enabled=1 ORDER BY `order` ASC");
$cont = count($rs_w);
if($cont!=0){
if($cont > 6) $cont = 6;
if($cont <= 2) $cont = 4;
// aggiungo la riga per bootstrap
echo '
<ul class="row widget" id="widget-' . $location . '" data-class="' . $rs_w[0]['class'] . '">';
// aggiungo ad uno ad uno tutti i widget
for($i = 0; $i < sizeof($rs_w); $i ++) {
$this->createWidget($rs_w[$i]['id'], $rs_w[$i]['class'], $cont);
}
echo '
</ul>
<script>
equalHeight("#widget-' . $location . ' .li-widget .box");
</script>';
}
}
}
}
?>