. */ include_once __DIR__.'/../../core.php'; switch (filter('op')) { case 'update': $nome = filter('nome'); $nota = filter('nota'); $colore = filter('colore'); $id_original = filter('id_original') ?: null; if (isset($nome) && isset($nota) && isset($colore)) { $database->table('mg_categorie') ->where('id', '=', $id_record) ->update([ 'nome' => $nome, 'nota' => $nota, 'colore' => $colore, ]); flash()->info(tr('Salvataggio completato!')); } else { flash()->error(tr('Ci sono stati alcuni errori durante il salvataggio!')); } // Redirect alla categoria se si sta modificando una sottocategoria if ($id_original != null) { $database->commitTransaction(); redirect(base_path().'/editor.php?id_module='.$id_module.'&id_record='.($id_original ?: $id_record)); exit(); } break; case 'add': $nome = filter('nome'); $nota = filter('nota'); $colore = filter('colore'); $id_original = filter('id_original') ?: null; // Ricerca corrispondenze con stesso nome $corrispondenze = $database->table('mg_categorie') ->where('nome', '=', $nome); if (!empty($id_original)) { $corrispondenze = $corrispondenze->where('parent', '=', $id_original); } else { $corrispondenze = $corrispondenze->whereNull('parent'); } $corrispondenze = $corrispondenze->get(); // Eventuale creazione del nuovo record if ($corrispondenze->count() == 0) { $id_record = $database->table('mg_categorie') ->insertGetId([ 'nome' => $nome, 'nota' => $nota, 'colore' => $colore, 'parent' => $id_original, ]); flash()->info(tr('Aggiunta nuova tipologia di _TYPE_', [ '_TYPE_' => 'categoria', ])); } else { $id_record = $corrispondenze->first()->id; flash()->error(tr('Esiste giĆ  una categoria con lo stesso nome!')); } if (isAjaxRequest()) { echo json_encode(['id' => $id_record, 'text' => $nome]); } else { // Redirect alla categoria se si sta aggiungendo una sottocategoria $database->commitTransaction(); redirect(base_path().'/editor.php?id_module='.$id_module.'&id_record='.($id_original ?: $id_record)); exit(); } break; case 'delete': $id = filter('id'); if (empty($id)) { $id = $id_record; } if ($dbo->fetchNum('SELECT * FROM `mg_articoli` WHERE (`id_categoria`='.prepare($id).' OR `id_sottocategoria`='.prepare($id).' OR `id_sottocategoria` IN (SELECT id FROM `mg_categorie` WHERE `parent`='.prepare($id).')) AND `deleted_at` IS NULL') == 0) { $dbo->query('DELETE FROM `mg_categorie` WHERE `id`='.prepare($id)); flash()->info(tr('Tipologia di _TYPE_ eliminata con successo!', [ '_TYPE_' => 'categoria', ])); } else { flash()->error(tr('Esistono alcuni articoli collegati a questa categoria. Impossibile eliminarla.')); } break; }