netgescon-master/database/migrations/2025_07_05_120000_create_documenti_table.php
Pikappa2 cb49fbfe70 Implementato dark mode completo e salvataggio impostazioni utente
- Aggiunto dark mode completo alla sidebar con classi Tailwind
- Implementato sistema di salvataggio permanente delle impostazioni utente
- Creata tabella user_settings per gestire preferenze personalizzate
- Aggiunto model UserSetting con metodi helper get/set
- Esteso controller impostazioni per supportare salvataggio e temi predefiniti
- Applicato stesso tema anche al pannello amministratore
- Aggiornate route per gestione temi in admin e superadmin
- Integrato sistema impostazioni nel layout principale con variabili CSS
- Aggiornato AppServiceProvider con helper userSetting()
- Dark mode applicato a: sidebar, modali, footer, bottoni, hover states
- Temi predefiniti: Default, Dark, Ocean con preview tempo reale
- Compatibilità completa tra pannello admin e superadmin
2025-07-05 19:22:51 +02:00

38 lines
1.7 KiB
PHP

<?php
use Illuminate\Database\Migrations\Migration;
use Illuminate\Database\Schema\Blueprint;
use Illuminate\Support\Facades\Schema;
return new class extends Migration {
public function up(): void
{
Schema::create('documenti', function (Blueprint $table) {
$table->id();
$table->string('protocollo')->nullable()->unique(); // es. 2025-0001
$table->date('data_protocollo')->nullable();
$table->string('tipo_documento')->nullable(); // Fattura, Contratto, Verbale, ecc.
$table->unsignedBigInteger('stabile_id')->nullable();
$table->unsignedBigInteger('fornitore_id')->nullable();
$table->unsignedBigInteger('esercizio_contabile_id')->nullable();
$table->text('descrizione')->nullable();
$table->decimal('importo', 12, 2)->nullable();
$table->date('data_documento')->nullable();
$table->string('nome_file');
$table->string('path_file');
$table->text('testo_estratto_ocr')->nullable();
// Polimorfismo
$table->unsignedBigInteger('documentable_id')->nullable()->index();
$table->string('documentable_type')->nullable()->index();
$table->timestamps();
// FK opzionali
$table->foreign('stabile_id')->references('id')->on('stabili')->onDelete('set null');
$table->foreign('fornitore_id')->references('id')->on('fornitori')->onDelete('set null');
// $table->foreign('esercizio_contabile_id')->references('id')->on('esercizi_contabili')->onDelete('set null'); // FK disabilitata: tabella non ancora presente
});
}
public function down(): void
{
Schema::dropIfExists('documenti');
}
};