Conversione dei widget in HTMLBuilder
This commit is contained in:
parent
40f8bbee2f
commit
7538e132c1
|
@ -25,14 +25,8 @@ $module_dir = $module['directory'];
|
|||
|
||||
include $docroot.'/actions.php';
|
||||
|
||||
/*
|
||||
* Widget top
|
||||
*/
|
||||
|
||||
//se non sono mobile nascondo i widget controller_top
|
||||
if (!isMobile()) {
|
||||
echo Widgets::addModuleWidgets($id_module, 'controller_top');
|
||||
}
|
||||
// Widget in alto
|
||||
echo '{( "name": "widgets", "id_module": "'.$id_module.'", "position": "top", "place": "controller" )}';
|
||||
|
||||
// Lettura eventuali plugins modulo da inserire come tab
|
||||
echo '
|
||||
|
@ -88,31 +82,12 @@ foreach ($plugins as $plugin) {
|
|||
|
||||
echo '
|
||||
</div>
|
||||
</div>
|
||||
</div>';
|
||||
</div>';
|
||||
|
||||
redirectOperation($id_module, $id_record);
|
||||
|
||||
/*
|
||||
* Widget laterali.
|
||||
*/
|
||||
// Controllo se ho widget per il lato destro dello schermo, altrimenti non creo la colonna di destra
|
||||
|
||||
//se sono mobile pesco anche i widget di controller_top
|
||||
if (isMobile()) {
|
||||
$extra_where = " OR location = 'controller_top'";
|
||||
} else {
|
||||
$extra_where = '';
|
||||
}
|
||||
|
||||
$result_widgets = $dbo->fetchArray('SELECT `id`, `location`, `class` FROM `zz_widgets` WHERE `id_module`='.prepare($id_module)." AND (`location`='controller_right' ".$extra_where.' ) AND `enabled`=1 ORDER BY `order` ASC');
|
||||
if (count($result_widgets) > 0) {
|
||||
echo '
|
||||
<div class="col-md-12">';
|
||||
echo Widgets::addModuleWidgets($id_module, 'controller_right');
|
||||
echo '
|
||||
</div>';
|
||||
}
|
||||
// Widget in basso
|
||||
echo '{( "name": "widgets", "id_module": "'.$id_module.'", "position": "right", "place": "controller" )}';
|
||||
|
||||
if (file_exists($docroot.'/include/custom/bottom.php')) {
|
||||
include $docroot.'/include/custom/bottom.php';
|
||||
|
|
19
editor.php
19
editor.php
|
@ -26,6 +26,9 @@ $module_dir = $module['directory'];
|
|||
// Inclusione elementi fondamentali del modulo
|
||||
include $docroot.'/actions.php';
|
||||
|
||||
// Widget in alto
|
||||
echo '{( "name": "widgets", "id_module": "'.$id_module.'", "id_record": "'.$id_record.'", "position": "top", "place": "editor" )}';
|
||||
|
||||
$advanced_sessions = get_var('Attiva notifica di presenza utenti sul record');
|
||||
if ($advanced_sessions) {
|
||||
$dbo->query('DELETE FROM zz_semaphores WHERE id_utente='.prepare($_SESSION['id_utente']).' AND posizione='.prepare($id_module.', '.$id_record));
|
||||
|
@ -215,25 +218,17 @@ if (empty($records)) {
|
|||
|
||||
redirectOperation($id_module, $id_record);
|
||||
|
||||
// Widget in basso
|
||||
echo '{( "name": "widgets", "id_module": "'.$id_module.'", "id_record": "'.$id_record.'", "position": "right", "place": "editor" )}';
|
||||
|
||||
echo '
|
||||
<hr>
|
||||
<a href="'.ROOTDIR.'/controller.php?id_module='.$id_module.'">
|
||||
<i class="fa fa-chevron-left"></i> '.tr('Indietro').'
|
||||
</a>';
|
||||
|
||||
/*
|
||||
* Widget laterali
|
||||
*/
|
||||
echo '
|
||||
</div>
|
||||
<div class="col-md-12">';
|
||||
echo Widgets::addModuleWidgets($id_module, 'editor_right');
|
||||
echo '
|
||||
</div>';
|
||||
|
||||
?>
|
||||
<script>
|
||||
<?php
|
||||
<script>';
|
||||
|
||||
// Se l'utente ha i permessi in sola lettura per il modulo, converto tutti i campi di testo in span
|
||||
if ($module['permessi'] == 'r') {
|
||||
|
|
|
@ -268,7 +268,7 @@ $(document).ready(function () {
|
|||
|
||||
$('.widget').mouseover(function (e) {
|
||||
e.preventDefault();
|
||||
start_widgets($("#widget-controller_top, #widget-controller_right"));
|
||||
start_widgets($("#widget-top, #widget-right"));
|
||||
});
|
||||
|
||||
$('#supersearch').keyup(function () {
|
||||
|
@ -1001,7 +1001,7 @@ function start_inputmask(element) {
|
|||
$(element+'.email-mask').inputmask('Regex', {
|
||||
regex: "^[a-zA-Z0-9_!#$%&'*+/=?`{|}~^-]+(?:\\.[a-zA-Z0-9_!#$%&'*+/=?`{|}~^-]+)*@[a-zA-Z0-9-]+(?:\\.[a-zA-Z0-9-]+)*$",
|
||||
});
|
||||
|
||||
|
||||
$(element+'.alphanumeric-mask').inputmask('Regex', {
|
||||
regex: "[A-Za-z0-9]{10}",
|
||||
});
|
||||
|
|
|
@ -238,7 +238,7 @@ class App
|
|||
$fields[] = trim($view['name']);
|
||||
|
||||
$search_inside[] = !empty($view['search_inside']) ? $view['search_inside'] : $view['name'];
|
||||
$order_by[] = !empty($view['order_by']) ? $view['order_by'] : $view['name'];
|
||||
$order_by[] = !empty($view['order_by']) ? $view['order_by'] : '`'.$view['name'].'`';
|
||||
$search[] = $view['search'];
|
||||
$slow[] = $view['slow'];
|
||||
$format[] = $view['format'];
|
||||
|
|
|
@ -77,6 +77,7 @@ class HTMLBuilder
|
|||
'button' => 'HTMLBuilder\Manager\ButtonManager',
|
||||
'csrf' => 'HTMLBuilder\Manager\CSRFManager',
|
||||
'custom_fields' => 'HTMLBuilder\Manager\FieldManager',
|
||||
'widgets' => 'HTMLBuilder\Manager\WidgetManager',
|
||||
],
|
||||
'instances' => [],
|
||||
];
|
||||
|
|
|
@ -0,0 +1,243 @@
|
|||
<?php
|
||||
|
||||
namespace HTMLBuilder\Manager;
|
||||
|
||||
/**
|
||||
* @since 2.4
|
||||
*/
|
||||
class WidgetManager implements ManagerInterface
|
||||
{
|
||||
public function manage($options)
|
||||
{
|
||||
$result = '';
|
||||
|
||||
if (isset($options['id'])) {
|
||||
$result = $this->widget($options);
|
||||
} else {
|
||||
$result = $this->group($options);
|
||||
}
|
||||
|
||||
return $result;
|
||||
}
|
||||
|
||||
protected function widget($options)
|
||||
{
|
||||
$database = \Database::getConnection();
|
||||
|
||||
// Widget richiesto
|
||||
$widget = $database->fetchArray('SELECT * FROM zz_widgets WHERE id = '.prepare($options['id']))[0];
|
||||
|
||||
$result = ' ';
|
||||
|
||||
// Generazione del widget in base al tipo
|
||||
switch ($widget['type']) {
|
||||
// Stampa
|
||||
case 'print':
|
||||
$result = $this->print($widget);
|
||||
|
||||
break;
|
||||
|
||||
// Statistiche
|
||||
case 'stats':
|
||||
$result = $this->stats($widget);
|
||||
|
||||
break;
|
||||
|
||||
// Chart (codice PHP)
|
||||
case 'chart':
|
||||
$result = $this->chart($widget);
|
||||
|
||||
break;
|
||||
|
||||
// Personalizzato (codice PHP e icona)
|
||||
case 'custom':
|
||||
$result = $this->custom($widget);
|
||||
|
||||
break;
|
||||
}
|
||||
|
||||
return $result;
|
||||
}
|
||||
|
||||
protected function print($widget)
|
||||
{
|
||||
return $this->stats($widget);
|
||||
}
|
||||
|
||||
protected function stats($widget)
|
||||
{
|
||||
// Indivduazione della query relativa
|
||||
$query = $widget['query'];
|
||||
|
||||
$additionals = \Modules::getAdditionalsQuery($widget['id_module']);
|
||||
if (!empty($additionals)) {
|
||||
$query = str_replace('1=1', '1=1 '.$additionals, $query);
|
||||
}
|
||||
|
||||
$query = \App::replacePlaceholder($query);
|
||||
|
||||
// Individuazione del risultato della query
|
||||
$database = \Database::getConnection();
|
||||
$value = null;
|
||||
if (!empty($query)) {
|
||||
$value = $database->fetchArray($query)[0]['dato'];
|
||||
}
|
||||
|
||||
// Generazione del codice HTML
|
||||
$result .= '
|
||||
<button type="button" class="close" onclick="if(confirm(\'Disabilitare questo widget?\')) { $.post( \''.ROOTDIR.'/modules/aggiornamenti/actions.php?id_module='.$widget['id_module'].'\', { op: \'disable_widget\', id: \''.$widget['id'].'\' }, function(response){ location.reload(); }); };" >
|
||||
<span aria-hidden="true">×</span><span class="sr-only">'.tr('Chiudi').'</span>
|
||||
</button>';
|
||||
|
||||
if (!empty($widget['more_link'])) {
|
||||
$result .= '
|
||||
<a class="clickable" ';
|
||||
|
||||
// Link diretto
|
||||
if ($widget['more_link_type'] == 'link') {
|
||||
$result .= 'href="'.$widget['more_link'].'"';
|
||||
}
|
||||
|
||||
// Modal
|
||||
elseif ($widget['more_link_type'] == 'popup') {
|
||||
$result .= 'data-href="'.$widget['more_link'].'" data-toggle="modal" data-title="'.$widget['text'].'" data-target="#bs-popup"';
|
||||
}
|
||||
|
||||
// Codice JavaScript
|
||||
elseif ($widget['more_link_type'] == 'javascript') {
|
||||
$link = $widget['more_link'];
|
||||
|
||||
$link = \App::replacePlaceholder($link);
|
||||
|
||||
$result .= 'onclick="'.$link.'"';
|
||||
}
|
||||
|
||||
$result .= '>';
|
||||
}
|
||||
|
||||
$result .= '
|
||||
<div class="info-box">
|
||||
<span class="info-box-icon" style="background-color:'.$widget['bgcolor'].'">
|
||||
<i class="'.$widget['icon'].'"></i>
|
||||
</span>
|
||||
|
||||
<div class="info-box-content">
|
||||
<span class="info-box-text'.(!empty($widget['help']) ? ' tip' : '').'"'.(!empty($widget['help']) ? ' title="'.prepareToField($widget['help']).'" data-position="bottom"' : '').'>
|
||||
'.$widget['text'].'
|
||||
|
||||
'.(!empty($widget['help']) ? '<i class="fa fa-question-circle-o"></i>' : '').'
|
||||
</span>
|
||||
<span class="info-box-number">'.$value.'</span>
|
||||
</div>
|
||||
</div>';
|
||||
|
||||
if (!empty($widget['more_link'])) {
|
||||
$result .= '
|
||||
</a>';
|
||||
|
||||
$result .= '
|
||||
</li>';
|
||||
}
|
||||
|
||||
return $result;
|
||||
}
|
||||
|
||||
protected function chart($widget)
|
||||
{
|
||||
return $this->custom($widget);
|
||||
}
|
||||
|
||||
protected function custom($widget)
|
||||
{
|
||||
$result .= '
|
||||
|
||||
<li class="'.$widget['class'].'" id="'.$widget['id'].'">
|
||||
<!-- small box -->
|
||||
<div class="small-box bg-'.$widget['bgcolor'].'">
|
||||
<div class="inner">';
|
||||
|
||||
// Codice specifico
|
||||
include_once $widget['php_include'];
|
||||
|
||||
$result .= '
|
||||
</div>';
|
||||
|
||||
// Icona
|
||||
if (!empty($widget['icon'])) {
|
||||
$result .= '
|
||||
<div class="icon">
|
||||
<i class="'.$widget['icon'].'"></i>
|
||||
</div>';
|
||||
}
|
||||
|
||||
$result .= '
|
||||
</div>
|
||||
</li>';
|
||||
|
||||
return $result;
|
||||
}
|
||||
|
||||
protected function group($options)
|
||||
{
|
||||
$query = 'SELECT id FROM zz_widgets WHERE id_module = '.prepare($options['id_module']).' AND (|position|) AND enabled = 1 ORDER BY `order` ASC';
|
||||
|
||||
// Mobile (tutti i widget a destra)
|
||||
if (isMobile()) {
|
||||
if ($options['position'] == 'right') {
|
||||
$position = "location = '".$options['place']."_right' OR location = '".$options['place']."_top'";
|
||||
} elseif ($options['position'] == 'top') {
|
||||
$position = '1=0';
|
||||
}
|
||||
}
|
||||
|
||||
// Widget a destra
|
||||
elseif ($options['position'] == 'right') {
|
||||
$position = "location = '".$options['place']."_right'";
|
||||
}
|
||||
|
||||
// Widget in alto
|
||||
elseif ($options['position'] == 'top') {
|
||||
$position = "location = '".$options['place']."_top'";
|
||||
}
|
||||
|
||||
$query = str_replace('|position|', $position, $query);
|
||||
|
||||
// Indivduazione dei widget interessati
|
||||
$database = \Database::getConnection();
|
||||
$widgets = $database->fetchArray($query);
|
||||
|
||||
$result = ' ';
|
||||
|
||||
// Generazione del codice HTML
|
||||
if (!empty($widgets)) {
|
||||
$row_max = count($widgets);
|
||||
if ($row_max > 4) {
|
||||
$row_max = 4;
|
||||
} elseif ($row_max < 2) {
|
||||
$row_max = 2;
|
||||
}
|
||||
|
||||
$result = '
|
||||
<ul class="row widget" id="widget-'.$options['position'].'" data-class="">';
|
||||
|
||||
// Aggiungo ad uno ad uno tutti i widget
|
||||
foreach ($widgets as $widget) {
|
||||
$result .= '
|
||||
<li class="col-sm-6 col-md-4 col-lg-'.intval(12 / $row_max).' li-widget" id="widget_'.$widget['id'].'">';
|
||||
|
||||
$info = array_merge($options, [
|
||||
'id' => $widget['id'],
|
||||
]);
|
||||
$result .= $this->widget($info);
|
||||
|
||||
$result .= '
|
||||
</li>';
|
||||
}
|
||||
|
||||
$result .= '
|
||||
</ul>';
|
||||
}
|
||||
|
||||
return $result;
|
||||
}
|
||||
}
|
|
@ -1,7 +1,7 @@
|
|||
<?php
|
||||
|
||||
/**
|
||||
* Classe per gestire le email (framework open-source PHPMailer) in base alle impostazioni.
|
||||
* Classe per gestire le email in base alle impostazioni, basata sul framework open-source PHPMailer.
|
||||
*
|
||||
* @since 2.3
|
||||
*/
|
||||
|
|
182
src/Widgets.php
182
src/Widgets.php
|
@ -1,182 +0,0 @@
|
|||
<?php
|
||||
|
||||
/**
|
||||
* Classe per la gestione dei widgets del progetto.
|
||||
*
|
||||
* @since 2.0
|
||||
*/
|
||||
class Widgets
|
||||
{
|
||||
/** @var array Elenco delle strutture HTML dei widget */
|
||||
public static $widgets = [];
|
||||
|
||||
/**
|
||||
* Prende da database tutti i widget associati al modulo passato come parametro e li aggiunge alla pagina.
|
||||
*
|
||||
* @param string $id_module Modulo a cui aggiungere i widget
|
||||
* @param string $location Posizione all'interno del modulo
|
||||
*/
|
||||
public static function addModuleWidgets($id_module, $location)
|
||||
{
|
||||
if (empty(self::$widgets[$id_module][$location])) {
|
||||
$dbo = Database::getConnection();
|
||||
|
||||
//se sono mobile mostro su controller_right anche quello che è su controller_top
|
||||
if ((isMobile()) && ($location == 'controller_right')) {
|
||||
$extra_where = " OR location = 'controller_top' ";
|
||||
} else {
|
||||
$extra_where = '';
|
||||
}
|
||||
|
||||
// ottengo da db gli id dei widget associati al modulo
|
||||
$results = $dbo->fetchArray('SELECT id, location, class FROM zz_widgets WHERE id_module='.prepare($id_module).' AND ( location='.prepare($location).' '.$extra_where.' ) AND enabled=1 ORDER BY `order` ASC');
|
||||
|
||||
$result = '';
|
||||
|
||||
if (!empty($results)) {
|
||||
$cont = count($results);
|
||||
if ($cont > 4 || $cont < 2) {
|
||||
$cont = 4;
|
||||
}
|
||||
|
||||
// Aggiungo la riga per bootstrap
|
||||
$result = '
|
||||
<ul class="row widget" id="widget-'.$location.'" data-class="'.$results[0]['class'].'">';
|
||||
|
||||
// Aggiungo ad uno ad uno tutti i widget
|
||||
foreach ($results as $widget) {
|
||||
$result .= self::createWidget($widget['id'], $widget['class'], $cont);
|
||||
}
|
||||
|
||||
$result .= '
|
||||
</ul>';
|
||||
}
|
||||
|
||||
self::$widgets[$id_module][$location] = $result;
|
||||
}
|
||||
|
||||
return self::$widgets[$id_module][$location];
|
||||
}
|
||||
|
||||
/**
|
||||
* A seconda del tipo di widget inserisce il codice HTML per la sua creazione nella pagina.
|
||||
* Ottiene i dati per la creazione del widget dalla tabella, in maniera da crearli in maniera dinamica a seconda dei campi.
|
||||
*
|
||||
* @param int $id_widget Identificativo numerico del widget
|
||||
* @param string $class
|
||||
* @param int $totalNumber
|
||||
*
|
||||
* @return string
|
||||
*/
|
||||
protected static function createWidget($id_widget, $class, $totalNumber = 4)
|
||||
{
|
||||
global $rootdir;
|
||||
|
||||
$dbo = Database::getConnection();
|
||||
|
||||
// ottengo i dati del widget passato come parametro da database
|
||||
$results = $dbo->fetchArray("SELECT *, (SELECT name FROM zz_modules WHERE id = zz_widgets.id_module) AS 'module_name' FROM zz_widgets WHERE id=".prepare($id_widget));
|
||||
$module_name = $results[0]['module_name'];
|
||||
|
||||
$result = '';
|
||||
// a seconda del tipo inserisco il widget in maniera differente
|
||||
switch ($results[0]['type']) {
|
||||
// widget di tipo statistiche
|
||||
case 'print':
|
||||
case 'stats':
|
||||
$query = $results[0]['query'];
|
||||
|
||||
$additionals = Modules::getAdditionalsQuery($module_name);
|
||||
if (!empty($additionals)) {
|
||||
$query = str_replace('1=1', '1=1 '.$additionals, $query);
|
||||
}
|
||||
$query = str_replace('|period_start|', $_SESSION['period_start'], $query);
|
||||
$query = str_replace('|period_end|', $_SESSION['period_end'], $query);
|
||||
|
||||
$query = App::replacePlaceholder($query);
|
||||
|
||||
$dato = '';
|
||||
if ($query != '') {
|
||||
$dato = $dbo->fetchArray($query);
|
||||
$dato = $dato[0]['dato'];
|
||||
}
|
||||
|
||||
// inserisco il widget
|
||||
$result .= '
|
||||
<li class="col-sm-6 col-md-4 col-lg-'.intval(12 / $totalNumber).' li-widget" id="widget_'.$results[0]['id'].'">
|
||||
<button type="button" class="close" onclick="if(confirm(\'Disabilitare questo widget?\')) { $.post( \''.$rootdir.'/modules/aggiornamenti/actions.php?id_module='.$results[0]['id_module'].'\', { op: \'disable_widget\', id: \''.$results[0]['id'].'\' }, function(response){ location.href = \''.$rootdir.'/controller.php?id_module='.$results[0]['id_module'].'\'; }); };" ><span aria-hidden="true">×</span><span class="sr-only">'.tr('Chiudi').'</span></button>';
|
||||
if (!empty($results[0]['more_link'])) {
|
||||
$result .= '
|
||||
<a class="clickable" ';
|
||||
if ($results[0]['more_link_type'] == 'link') {
|
||||
$result .= 'href="'.$results[0]['more_link'].'"';
|
||||
} elseif ($results[0]['more_link_type'] == 'popup') {
|
||||
$result .= 'data-href="'.$results[0]['more_link'].'" data-toggle="modal" data-title="'.$results[0]['text'].'" data-target="#bs-popup"';
|
||||
} elseif ($results[0]['more_link_type'] == 'javascript') {
|
||||
$link = $results[0]['more_link'];
|
||||
$link = str_replace('|period_start|', $_SESSION['period_start'], $link);
|
||||
$link = str_replace('|period_end|', $_SESSION['period_end'], $link);
|
||||
$result .= 'onclick="'.$link.'"';
|
||||
}
|
||||
$result .= '>';
|
||||
}
|
||||
|
||||
$result .= '
|
||||
<div class="info-box">
|
||||
<span class="info-box-icon" style="background-color:'.$results[0]['bgcolor'].'">
|
||||
<i class="'.$results[0]['icon'].'"></i>
|
||||
</span>
|
||||
<div class="info-box-content">
|
||||
<span class="info-box-text'.(!empty($results[0]['help']) ? ' tip' : '').'"'.(!empty($results[0]['help']) ? ' title="'.prepareToField($results[0]['help']).'" data-position="bottom"' : '').'>
|
||||
'.$results[0]['text'].'
|
||||
'.(!empty($results[0]['help']) ? '<i class="fa fa-question-circle-o"></i>' : '').'
|
||||
</span>
|
||||
<span class="info-box-number">'.$dato.'</span>
|
||||
</div>
|
||||
</div>';
|
||||
|
||||
if (!empty($results[0]['more_link'])) {
|
||||
$result .= '
|
||||
</a>';
|
||||
|
||||
$result .= '
|
||||
</li>';
|
||||
}
|
||||
|
||||
break;
|
||||
|
||||
// widget di tipo chart: importa la pagina php specificata nel campo php_include della tabella, non ha l'icona
|
||||
case 'chart':
|
||||
$result .= '
|
||||
<li class="'.$class.'" id="'.$results[0]['id'].'">
|
||||
<!-- small box -->
|
||||
<div class="small-box bg-'.$results[0]['bgcolor'].'">
|
||||
<div class="inner">';
|
||||
include_once $results[0]['php_include'];
|
||||
$result .= '
|
||||
</div>
|
||||
</div>
|
||||
</li>';
|
||||
break;
|
||||
|
||||
// widget custom con codice php e icona
|
||||
case 'custom':
|
||||
$result .= '
|
||||
<li class="'.$class.'" id="'.$results[0]['id'].'">
|
||||
<!-- small box -->
|
||||
<div class="small-box bg-'.$results[0]['bgcolor'].'">
|
||||
<div class="inner">';
|
||||
include_once $results[0]['php_include'];
|
||||
$result .= '
|
||||
</div>
|
||||
<div class="icon">
|
||||
<i class="'.$results[0]['icon'].'"></i>
|
||||
</div>
|
||||
</div>
|
||||
</li>';
|
||||
break;
|
||||
}
|
||||
|
||||
return $result;
|
||||
}
|
||||
}
|
|
@ -39,6 +39,7 @@ $files = [
|
|||
'lib/modulebuilder.php',
|
||||
'lib/permissions_check.php',
|
||||
'lib/user_check.php',
|
||||
'src/Widgets.php',
|
||||
'templates/fatture_accompagnatorie/fattura_body.html',
|
||||
'templates/fatture_accompagnatorie/fattura.html',
|
||||
'templates/fatture_accompagnatorie/pdfgen.fatture_accompagnatorie.php',
|
||||
|
|
Loading…
Reference in New Issue