mirror of
https://github.com/devcode-it/openstamanager.git
synced 2025-01-28 14:39:28 +01:00
459f75cab8
Aggiunto supporto al logo stampe caricabile come allegato. Miglioramento della gestione dei dati di input. Completata gestione AJAX degli allegati.
158 lines
5.2 KiB
PHP
158 lines
5.2 KiB
PHP
<?php
|
|
|
|
include_once __DIR__.'/../../core.php';
|
|
|
|
$id = post('id');
|
|
|
|
switch (post('op')) {
|
|
case 'upload':
|
|
include $docroot.'/modules/aggiornamenti/upload_modules.php';
|
|
|
|
break;
|
|
|
|
case 'uninstall':
|
|
if (!empty($id)) {
|
|
// Leggo l'id del modulo
|
|
$rs = $dbo->fetchArray('SELECT id, name, directory FROM zz_modules WHERE id='.prepare($id).' AND `default`=0');
|
|
$modulo = $rs[0]['title'];
|
|
$module_dir = $rs[0]['directory'];
|
|
|
|
if (count($rs) == 1) {
|
|
// Elimino il modulo dal menu
|
|
$dbo->query('DELETE FROM zz_modules WHERE id='.prepare($id).' OR parent='.prepare($id));
|
|
|
|
$uninstall_script = $docroot.'/modules/'.$module_dir.'/update/uninstall.php';
|
|
|
|
if (file_exists($uninstall_script)) {
|
|
include_once $uninstall_script;
|
|
}
|
|
|
|
delete($docroot.'/modules/'.$module_dir.'/');
|
|
|
|
$_SESSION['infos'][] = tr('Modulo _MODULE_ disinstallato!', [
|
|
'_MODULE_' => '"'.$modulo.'"',
|
|
]);
|
|
}
|
|
}
|
|
|
|
break;
|
|
|
|
case 'disable':
|
|
$dbo->query('UPDATE `zz_modules` SET `enabled` = 0 WHERE (`id` = '.prepare($id).' OR `parent` = '.prepare($id).') AND `id` != '.prepare(Modules::get('Aggiornamenti')['id']));
|
|
|
|
$_SESSION['infos'][] = tr('Modulo _MODULE_ disabilitato!', [
|
|
'_MODULE_' => '"'.Modules::get($id)['title'].'"',
|
|
]);
|
|
|
|
break;
|
|
|
|
case 'enable':
|
|
$dbo->query('UPDATE `zz_modules` SET `enabled` = 1 WHERE `id` = '.prepare($id).' OR `parent` = '.prepare($id));
|
|
|
|
$_SESSION['infos'][] = tr('Modulo _MODULE_ abilitato!', [
|
|
'_MODULE_' => '"'.Modules::get($id)['title'].'"',
|
|
]);
|
|
|
|
break;
|
|
|
|
case 'disable_widget':
|
|
$dbo->query('UPDATE zz_widgets SET enabled = 0 WHERE id = '.prepare($id));
|
|
|
|
$rs = $dbo->fetchArray('SELECT id, name FROM zz_widgets WHERE id='.prepare($id));
|
|
$widget = $rs[0]['name'];
|
|
|
|
$_SESSION['infos'][] = tr('Widget _WIDGET_ disabilitato!', [
|
|
'_WIDGET_' => '"'.$widget.'"',
|
|
]);
|
|
|
|
break;
|
|
|
|
case 'enable_widget':
|
|
$dbo->query('UPDATE zz_widgets SET enabled=1 WHERE id='.prepare($id));
|
|
|
|
$rs = $dbo->fetchArray('SELECT id, name FROM zz_widgets WHERE id='.prepare($id));
|
|
$widget = $rs[0]['name'];
|
|
|
|
$_SESSION['infos'][] = tr('Widget _WIDGET_ abilitato!', [
|
|
'_WIDGET_' => '"'.$widget.'"',
|
|
]);
|
|
|
|
break;
|
|
|
|
case 'change_position_widget_top':
|
|
$dbo->query("UPDATE zz_widgets SET location='controller_top' WHERE id=".prepare($id));
|
|
|
|
$rs = $dbo->fetchArray('SELECT id, name FROM zz_widgets WHERE id='.prepare($id));
|
|
$widget = $rs[0]['name'];
|
|
|
|
$_SESSION['infos'][] = tr('Posizione del widget _WIDGET_ aggiornata!', [
|
|
'_WIDGET_' => '"'.$widget.'"',
|
|
]);
|
|
|
|
break;
|
|
|
|
case 'change_position_widget_right':
|
|
$dbo->query("UPDATE zz_widgets SET location='controller_right' WHERE id=".prepare($id));
|
|
|
|
$rs = $dbo->fetchArray('SELECT id, name FROM zz_widgets WHERE id='.prepare($id));
|
|
$widget = $rs[0]['name'];
|
|
|
|
$_SESSION['infos'][] = tr('Posizione del widget _WIDGET_ aggiornata!', [
|
|
'_WIDGET_' => '"'.$widget.'"',
|
|
]);
|
|
|
|
break;
|
|
|
|
// Ordinamento moduli di primo livello
|
|
case 'sortmodules':
|
|
$rs = $dbo->fetchArray('SELECT id FROM zz_modules WHERE enabled = 1 AND parent IS NULL ORDER BY `order` ASC');
|
|
|
|
if ($_POST['ids'] != implode(',', array_column($rs, 'id'))) {
|
|
$ids = explode(',', $_POST['ids']);
|
|
|
|
for ($i = 0; $i < count($ids); ++$i) {
|
|
$dbo->query('UPDATE zz_modules SET `order`='.prepare($i).' WHERE id='.prepare($ids[$i]));
|
|
}
|
|
|
|
$_SESSION['infos'][] = tr('Posizione voci di menù aggiornate!');
|
|
}
|
|
|
|
break;
|
|
|
|
case 'sortwidget':
|
|
$id_module = post('id_module');
|
|
$id_record = post('id_record');
|
|
$location = post('location');
|
|
|
|
$location = empty($id_record) ? 'controller_'.$location : 'editor_'.$location;
|
|
|
|
$rs = $dbo->fetchArray("SELECT CONCAT('widget_', id) AS id FROM zz_widgets WHERE enabled = 1 AND location = ".prepare($location).' AND id_module = '.prepare($id_module).' ORDER BY `order` ASC');
|
|
|
|
if ($_POST['ids'] != implode(',', array_column($rs, 'id'))) {
|
|
$ids = explode(',', $_POST['ids']);
|
|
|
|
for ($i = 0; $i < count($ids); ++$i) {
|
|
$id = explode('_', $ids[$i]);
|
|
$dbo->query('UPDATE zz_widgets SET `order`='.prepare($i).' WHERE id='.prepare($id[1]));
|
|
}
|
|
|
|
$_SESSION['infos'][] = tr('Posizioni widgets aggiornate!');
|
|
}
|
|
break;
|
|
|
|
case 'updatewidget':
|
|
$id_module = post('id_module');
|
|
$id_record = post('id_record');
|
|
$location = post('location');
|
|
$class = post('class');
|
|
$id = explode('_', post('id'));
|
|
|
|
$location = empty($id_record) ? 'controller_'.$location : 'editor_'.$location;
|
|
|
|
if (!empty($class)) {
|
|
$dbo->query('UPDATE zz_widgets SET class='.prepare($class).' WHERE id='.prepare($id[1]));
|
|
}
|
|
|
|
break;
|
|
}
|