openstamanager/modules/tipi_anagrafiche/actions.php

74 lines
2.5 KiB
PHP
Executable File

<?php
/*
* OpenSTAManager: il software gestionale open source per l'assistenza tecnica e la fatturazione
* Copyright (C) DevCode s.r.l.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <https://www.gnu.org/licenses/>.
*/
include_once __DIR__.'/../../core.php';
use Modules\Anagrafiche\Tipo;
switch (post('op')) {
case 'update':
$id_tipo = post('id_record');
$descrizione = post('descrizione');
$block = ['Cliente', 'Tecnico', 'Azienda', 'Fornitore'];
// Nome accettato
if (!in_array($descrizione, $block)) {
$tipo->setTranslation('title', $descrizione);
if (Models\Locale::getDefault()->id == Models\Locale::getPredefined()->id) {
$tipo->name = $descrizione;
}
$tipo->save();
flash()->info(tr('Informazioni salvate correttamente!'));
} else {
// Nome non consentito
flash()->error(tr('Nome non consentito!'));
}
break;
case 'add':
$descrizione = post('descrizione');
if (!empty($descrizione)) {
// Verifico che il nome non sia duplicato
$tipo = Tipo::find((new Tipo())->getByField('title', $descrizione));
if ($tipo) {
flash()->error(tr('Nome già esistente!'));
} else {
$tipo = Tipo::build($descrizione);
if (Models\Locale::getDefault()->id == Models\Locale::getPredefined()->id) {
$tipo->name = $descrizione;
}
$id_record = $dbo->lastInsertedID();
$tipo->setTranslation('title', $descrizione);
$tipo->save();
flash()->info(tr('Nuovo tipo di anagrafica aggiunto!'));
}
}
break;
case 'delete':
$query = 'DELETE FROM `an_tipianagrafiche` WHERE `id`='.prepare($id_record);
$dbo->query($query);
flash()->info(tr('Tipo di anagrafica eliminato!'));
break;
}