310 lines
8.3 KiB
PHP
310 lines
8.3 KiB
PHP
<?php
|
|
|
|
/**
|
|
* Classe per la gestione delle funzioni AJAX richiamabili del progetto.
|
|
*
|
|
* @since 2.4
|
|
*/
|
|
class AJAX
|
|
{
|
|
/**
|
|
* Controlla se è in corso una richiesta AJAX generata dal progetto.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public static function isAjaxRequest()
|
|
{
|
|
return \Whoops\Util\Misc::isAjaxRequest() && filter('ajax') !== null;
|
|
}
|
|
|
|
/**
|
|
* Individua le opzioni di selezione a partire dalla risorsa richiesta.
|
|
*
|
|
* @param string $resource
|
|
* @param array $elements
|
|
* @param mixed $search
|
|
* @param int $page
|
|
* @param int $length
|
|
*
|
|
* @return array
|
|
*/
|
|
public static function select($resource, $elements = [], $search = null, $page = 0, $length = 100)
|
|
{
|
|
if (!isset($elements)) {
|
|
$elements = [];
|
|
}
|
|
$elements = (!is_array($elements)) ? explode(',', $elements) : $elements;
|
|
|
|
$files = self::find('ajax/select.php', false);
|
|
|
|
// File di gestione predefinita
|
|
array_unshift($files, DOCROOT.'/ajax_select.php');
|
|
|
|
foreach ($files as $file) {
|
|
$results = self::getSelectResults($file, $resource, $elements, [
|
|
'offset' => $page * $length,
|
|
'length' => $length,
|
|
], $search);
|
|
|
|
if (isset($results)) {
|
|
break;
|
|
}
|
|
}
|
|
|
|
$total = $results['recordsFiltered'] ?: count($results);
|
|
$list = $results['results'] ? $results['results'] : $results;
|
|
|
|
return [
|
|
'results' => $list,
|
|
'recordsFiltered' => $total,
|
|
];
|
|
}
|
|
|
|
/**
|
|
* Completa la query SQL a partire da parametri definiti e ne restituisce i risultati.
|
|
*
|
|
* @param string $query
|
|
* @param array $where
|
|
* @param array $filter
|
|
* @param array $search
|
|
* @param array $limit
|
|
* @param array $custom
|
|
*
|
|
* @return array
|
|
*/
|
|
public static function selectResults($query, $where, $filter = [], $search = [], $limit = [], $custom = [])
|
|
{
|
|
if (str_contains($query, '|filter|')) {
|
|
$query = str_replace('|filter|', !empty($filter) ? 'WHERE '.implode(' OR ', $filter) : '', $query);
|
|
} elseif (!empty($filter)) {
|
|
$where[] = '('.implode(' OR ', $filter).')';
|
|
}
|
|
|
|
if (!empty($search)) {
|
|
$where[] = '('.implode(' OR ', $search).')';
|
|
}
|
|
|
|
$query = str_replace('|where|', !empty($where) ? 'WHERE '.implode(' AND ', $where) : '', $query);
|
|
$query .= ' LIMIT '.$limit['offset'].', '.$limit['length'];
|
|
|
|
$data = \Util\Query::executeAndCount($query);
|
|
$rows = $data['results'];
|
|
|
|
$results = [];
|
|
foreach ($rows as $row) {
|
|
$result = [];
|
|
foreach ($custom as $key => $value) {
|
|
$result[$key] = $row[$value];
|
|
}
|
|
|
|
$results[] = $result;
|
|
}
|
|
|
|
return [
|
|
'results' => $results,
|
|
'recordsFiltered' => $data['count'],
|
|
];
|
|
}
|
|
|
|
/**
|
|
* Effettua la ricerca di un termine all'intero delle risorse disponibili.
|
|
*
|
|
* @param string $term
|
|
*
|
|
* @return array
|
|
*/
|
|
public static function search($term)
|
|
{
|
|
if (strlen($term) < 2) {
|
|
return;
|
|
}
|
|
|
|
$files = self::find('ajax/search.php');
|
|
|
|
// File di gestione predefinita
|
|
array_unshift($files, DOCROOT.'/ajax_search.php');
|
|
|
|
$results = [];
|
|
foreach ($files as $file) {
|
|
$module_results = self::getSearchResults($file, $term);
|
|
|
|
$results = array_merge($results, $module_results);
|
|
}
|
|
|
|
return $results;
|
|
}
|
|
|
|
/**
|
|
* Completa il codice HTML per la risorsa richiesta.
|
|
*
|
|
* @param string $resource
|
|
*
|
|
* @return string
|
|
*/
|
|
public static function complete($resource)
|
|
{
|
|
$files = self::find('ajax/complete.php');
|
|
|
|
// File di gestione predefinita
|
|
array_unshift($files, DOCROOT.'/ajax_complete.php');
|
|
|
|
foreach ($files as $file) {
|
|
$result = self::getCompleteResults($file, $resource);
|
|
if (!empty($result)) {
|
|
break;
|
|
}
|
|
}
|
|
|
|
return $result;
|
|
}
|
|
|
|
/**
|
|
* Individua i file per cui l'utente possiede i permessi di accesso.
|
|
*
|
|
* @param string $file
|
|
* @param bool $permissions
|
|
*
|
|
* @return array
|
|
*/
|
|
public static function find($file, $permissions = true)
|
|
{
|
|
$dirname = substr($file, 0, strrpos($file, '/') + 1);
|
|
|
|
// Individuazione delle cartelle accessibili
|
|
if (!empty($permissions)) {
|
|
$modules = Modules::getAvailableModules();
|
|
} else {
|
|
$modules = Models\Module::withoutGlobalScope('enabled')->get();
|
|
}
|
|
|
|
$modules = $modules->toArray();
|
|
|
|
$dirs = array_unique(array_column($modules, 'directory'));
|
|
$pieces = array_chunk($dirs, 5);
|
|
|
|
// Individuazione dei file esistenti
|
|
$list = [];
|
|
foreach ($pieces as $piece) {
|
|
// File nativi
|
|
$files = glob(DOCROOT.'/modules/{'.implode(',', $piece).'}/'.$file, GLOB_BRACE);
|
|
|
|
// File personalizzati
|
|
$custom_files = glob(DOCROOT.'/modules/{'.implode(',', $piece).'}/custom/'.$file, GLOB_BRACE);
|
|
|
|
// Pulizia dei file nativi che sono stati personalizzati
|
|
foreach ($custom_files as $key => $value) {
|
|
$index = array_search(str_replace('custom/'.$dirname, $dirname, $value), $files);
|
|
if ($index !== false) {
|
|
unset($files[$index]);
|
|
}
|
|
}
|
|
|
|
$list = array_merge($list, $files, $custom_files);
|
|
}
|
|
|
|
asort($list);
|
|
|
|
return $list;
|
|
}
|
|
|
|
/**
|
|
* Ottiene i risultati del select all'interno di un file specifico (modulo).
|
|
*
|
|
* @param string $file
|
|
* @param string $resource
|
|
* @param array $elements
|
|
* @param array $limit
|
|
* @param mixed $search
|
|
*
|
|
* @return array|null
|
|
*/
|
|
protected static function getSelectResults($file, $resource, $elements = [], $limit = [], $search = null)
|
|
{
|
|
$superselect = self::getSelectInfo();
|
|
|
|
$where = [];
|
|
$filter = [];
|
|
$search_fields = [];
|
|
|
|
$custom = [
|
|
'id' => 'id',
|
|
'text' => 'descrizione',
|
|
];
|
|
|
|
// Database
|
|
$dbo = $database = database();
|
|
|
|
require $file;
|
|
|
|
if (!isset($results) && !empty($query)) {
|
|
$results = self::selectResults($query, $where, $filter, $search_fields, $limit, $custom);
|
|
}
|
|
|
|
return isset($results) ? $results : null;
|
|
}
|
|
|
|
/**
|
|
* Restituisce le informazioni aggiuntive per i select.
|
|
*/
|
|
protected static function getSelectInfo()
|
|
{
|
|
return !empty($_SESSION['superselect']) ? $_SESSION['superselect'] : [];
|
|
}
|
|
|
|
/**
|
|
* Ottiene i risultati della ricerca all'interno di un file specifico (modulo).
|
|
*
|
|
* @param string $file
|
|
* @param string $term
|
|
*
|
|
* @return array
|
|
*/
|
|
protected static function getSearchResults($file, $term)
|
|
{
|
|
// Database
|
|
$dbo = $database = database();
|
|
|
|
// Ricerca anagrafiche per ragione sociale per potere mostrare gli interventi, fatture,
|
|
// ordini, ecc della persona ricercata
|
|
$idanagrafiche = ['-1'];
|
|
$ragioni_sociali = ['-1'];
|
|
$rs = $dbo->fetchArray('SELECT idanagrafica, ragione_sociale FROM an_anagrafiche WHERE ragione_sociale LIKE "%'.$term.'%"');
|
|
|
|
for ($a = 0; $a < sizeof($rs); ++$a) {
|
|
$idanagrafiche[] = $rs[$a]['idanagrafica'];
|
|
$ragioni_sociali[$rs[$a]['idanagrafica']] = $rs[$a]['ragione_sociale'];
|
|
}
|
|
|
|
$results = [];
|
|
|
|
require $file;
|
|
|
|
$results = (array) $results;
|
|
foreach ($results as $key => $value) {
|
|
$results[$key]['value'] = $key;
|
|
}
|
|
|
|
return $results;
|
|
}
|
|
|
|
/**
|
|
* Ottiene i risultati della richiesta di completamento all'interno di un file specifico (modulo).
|
|
*
|
|
* @param string $file
|
|
* @param string $resource
|
|
*
|
|
* @return string
|
|
*/
|
|
protected static function getCompleteResults($file, $resource)
|
|
{
|
|
// Database
|
|
$dbo = $database = database();
|
|
|
|
ob_start();
|
|
require $file;
|
|
$result = ob_get_clean();
|
|
|
|
return $result;
|
|
}
|
|
}
|