From 792331b5c75580583b8772b44e868e5ec9d57d81 Mon Sep 17 00:00:00 2001 From: Gianmarco Date: Tue, 3 Feb 2026 11:40:19 +0100 Subject: [PATCH 1/3] Lista commesse --- TecniStamp/TecniStamp.Domain/Cliente.cs | 4 +- ...03103529_Rimossi campi cliente.Designer.cs | 825 ++++++++++++++++++ .../20260203103529_Rimossi campi cliente.cs | 58 ++ .../TecniStampDbContextModelSnapshot.cs | 9 - .../Components/Layout/MainLayout.razor | 12 +- .../Components/Pages/Anagrafiche/Ruoli.razor | 24 +- .../Pages/Anagrafiche/Ruoli_Edit.razor | 125 ++- .../Components/Pages/Commesse/Commesse.razor | 6 +- .../Components/Widget/Breadcrumb.razor | 2 +- .../Components/Widget/Breadcrumb.razor.css | 15 + .../Model/Commesse/ClienteViewModel.cs | 6 +- TecniStamp/TecniStamp/Model/RuoloViewModel.cs | 5 + 12 files changed, 986 insertions(+), 105 deletions(-) create mode 100644 TecniStamp/TecniStamp.Infrastructure/Migrations/20260203103529_Rimossi campi cliente.Designer.cs create mode 100644 TecniStamp/TecniStamp.Infrastructure/Migrations/20260203103529_Rimossi campi cliente.cs create mode 100644 TecniStamp/TecniStamp/Components/Widget/Breadcrumb.razor.css diff --git a/TecniStamp/TecniStamp.Domain/Cliente.cs b/TecniStamp/TecniStamp.Domain/Cliente.cs index 9fcad04..4eae546 100644 --- a/TecniStamp/TecniStamp.Domain/Cliente.cs +++ b/TecniStamp/TecniStamp.Domain/Cliente.cs @@ -7,16 +7,14 @@ public class Cliente : EntitaBase { public string RagioneSociale { get; set; } public string PartitaIva { get; set; } - public string Paese { get; set; } public string Telefono { get; set; } public string Email { get; set; } - public string Indirizzo { get; set; } public string CAP { get; set; } public string Citta { get; set; } public string NumeroCivico { get; set; } public string Via { get; set; } public string Provincia { get; set; } - public string Note { get; set; } + public string? Note { get; set; } [ForeignKey(nameof(Comune))] public Guid? ComuneId { get; set; } diff --git a/TecniStamp/TecniStamp.Infrastructure/Migrations/20260203103529_Rimossi campi cliente.Designer.cs b/TecniStamp/TecniStamp.Infrastructure/Migrations/20260203103529_Rimossi campi cliente.Designer.cs new file mode 100644 index 0000000..633ca7e --- /dev/null +++ b/TecniStamp/TecniStamp.Infrastructure/Migrations/20260203103529_Rimossi campi cliente.Designer.cs @@ -0,0 +1,825 @@ +// +using System; +using Microsoft.EntityFrameworkCore; +using Microsoft.EntityFrameworkCore.Infrastructure; +using Microsoft.EntityFrameworkCore.Metadata; +using Microsoft.EntityFrameworkCore.Migrations; +using Microsoft.EntityFrameworkCore.Storage.ValueConversion; +using TecniStamp.Infrastructure.DAL.Context; + +#nullable disable + +namespace TecniStamp.Infrastructure.Migrations +{ + [DbContext(typeof(TecniStampDbContext))] + [Migration("20260203103529_Rimossi campi cliente")] + partial class Rimossicampicliente + { + /// + protected override void BuildTargetModel(ModelBuilder modelBuilder) + { +#pragma warning disable 612, 618 + modelBuilder + .HasAnnotation("ProductVersion", "9.0.11") + .HasAnnotation("Relational:MaxIdentifierLength", 128); + + SqlServerModelBuilderExtensions.UseIdentityColumns(modelBuilder); + + modelBuilder.Entity("TecniStamp.Domain.Cliente", b => + { + b.Property("Id") + .ValueGeneratedOnAdd() + .HasColumnType("uniqueidentifier"); + + b.Property("CAP") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("Citta") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("ComuneId") + .HasColumnType("uniqueidentifier"); + + b.Property("DataCreazione") + .HasColumnType("datetime2"); + + b.Property("DataModifica") + .HasColumnType("datetime2"); + + b.Property("Eliminato") + .HasColumnType("bit"); + + b.Property("Email") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("IdUtenteCreazione") + .HasColumnType("uniqueidentifier"); + + b.Property("IdUtenteModifica") + .HasColumnType("uniqueidentifier"); + + b.Property("Note") + .HasColumnType("nvarchar(max)"); + + b.Property("NumeroCivico") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("PartitaIva") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("Provincia") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("RagioneSociale") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("Telefono") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("Via") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.HasKey("Id"); + + b.HasIndex("ComuneId"); + + b.HasIndex("IdUtenteCreazione"); + + b.HasIndex("IdUtenteModifica"); + + b.ToTable("Cliente"); + }); + + modelBuilder.Entity("TecniStamp.Domain.Commessa", b => + { + b.Property("Id") + .ValueGeneratedOnAdd() + .HasColumnType("uniqueidentifier"); + + b.Property("AnnoCommessa") + .HasColumnType("int"); + + b.Property("ClienteId") + .HasColumnType("uniqueidentifier"); + + b.Property("CodiceCommessa") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("DataConsegna") + .HasColumnType("datetime2"); + + b.Property("DataConsegnaPrevista") + .HasColumnType("datetime2"); + + b.Property("DataCreazione") + .HasColumnType("datetime2"); + + b.Property("DataModifica") + .HasColumnType("datetime2"); + + b.Property("DataOrdine") + .HasColumnType("datetime2"); + + b.Property("Eliminato") + .HasColumnType("bit"); + + b.Property("IdUtenteCreazione") + .HasColumnType("uniqueidentifier"); + + b.Property("IdUtenteModifica") + .HasColumnType("uniqueidentifier"); + + b.Property("OrdineNr") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("OreTotali") + .HasColumnType("decimal(18,2)"); + + b.Property("RiferimentoCliente") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("Stato") + .HasColumnType("int"); + + b.HasKey("Id"); + + b.HasIndex("ClienteId"); + + b.HasIndex("IdUtenteCreazione"); + + b.HasIndex("IdUtenteModifica"); + + b.ToTable("Commessa"); + }); + + modelBuilder.Entity("TecniStamp.Domain.ComuneIstat", b => + { + b.Property("Id") + .ValueGeneratedOnAdd() + .HasColumnType("uniqueidentifier"); + + b.Property("CodFisco") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("Comune") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("DataCreazione") + .HasColumnType("datetime2"); + + b.Property("DataModifica") + .HasColumnType("datetime2"); + + b.Property("Eliminato") + .HasColumnType("bit"); + + b.Property("IdUtenteCreazione") + .HasColumnType("uniqueidentifier"); + + b.Property("IdUtenteModifica") + .HasColumnType("uniqueidentifier"); + + b.Property("Istat") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("Prefisso") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("Provincia") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("ProvinciaIstatId") + .HasColumnType("uniqueidentifier"); + + b.Property("Regione") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.HasKey("Id"); + + b.HasIndex("IdUtenteCreazione"); + + b.HasIndex("IdUtenteModifica"); + + b.HasIndex("ProvinciaIstatId"); + + b.ToTable("ComuneIstat"); + }); + + modelBuilder.Entity("TecniStamp.Domain.Feature", b => + { + b.Property("Id") + .ValueGeneratedOnAdd() + .HasColumnType("uniqueidentifier"); + + b.Property("DataCreazione") + .HasColumnType("datetime2"); + + b.Property("DataModifica") + .HasColumnType("datetime2"); + + b.Property("Descrizione") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("Eliminato") + .HasColumnType("bit"); + + b.Property("IdUtenteCreazione") + .HasColumnType("uniqueidentifier"); + + b.Property("IdUtenteModifica") + .HasColumnType("uniqueidentifier"); + + b.Property("Nome") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("Ordinamento") + .HasColumnType("int"); + + b.Property("SezioneId") + .HasColumnType("uniqueidentifier"); + + b.Property("Type") + .HasColumnType("int"); + + b.HasKey("Id"); + + b.HasIndex("IdUtenteCreazione"); + + b.HasIndex("IdUtenteModifica"); + + b.HasIndex("SezioneId"); + + b.ToTable("Feature"); + }); + + modelBuilder.Entity("TecniStamp.Domain.Lavorazione", b => + { + b.Property("Id") + .ValueGeneratedOnAdd() + .HasColumnType("uniqueidentifier"); + + b.Property("ChiaveEsterna") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("Codice") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("CodiceColore") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("CostoOrario") + .HasColumnType("real"); + + b.Property("DataCreazione") + .HasColumnType("datetime2"); + + b.Property("DataModifica") + .HasColumnType("datetime2"); + + b.Property("Descrizione") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("Eliminato") + .HasColumnType("bit"); + + b.Property("IdUtenteCreazione") + .HasColumnType("uniqueidentifier"); + + b.Property("IdUtenteModifica") + .HasColumnType("uniqueidentifier"); + + b.Property("Sovrapponibile") + .HasColumnType("bit"); + + b.HasKey("Id"); + + b.HasIndex("IdUtenteCreazione"); + + b.HasIndex("IdUtenteModifica"); + + b.ToTable("Lavorazione"); + }); + + modelBuilder.Entity("TecniStamp.Domain.Macchinario", b => + { + b.Property("Id") + .ValueGeneratedOnAdd() + .HasColumnType("uniqueidentifier"); + + b.Property("CodiceEsterno") + .HasColumnType("nvarchar(max)"); + + b.Property("ConfigurazioneJSON") + .HasColumnType("nvarchar(max)"); + + b.Property("ConfigurazionePercorso") + .HasColumnType("nvarchar(max)"); + + b.Property("DataCreazione") + .HasColumnType("datetime2"); + + b.Property("DataModifica") + .HasColumnType("datetime2"); + + b.Property("Descrizione") + .HasColumnType("nvarchar(max)"); + + b.Property("Eliminato") + .HasColumnType("bit"); + + b.Property("IdUtenteCreazione") + .HasColumnType("uniqueidentifier"); + + b.Property("IdUtenteModifica") + .HasColumnType("uniqueidentifier"); + + b.Property("Interscambio") + .HasColumnType("bit"); + + b.Property("Nome") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.HasKey("Id"); + + b.HasIndex("IdUtenteCreazione"); + + b.HasIndex("IdUtenteModifica"); + + b.ToTable("Macchinario"); + }); + + modelBuilder.Entity("TecniStamp.Domain.Permission", b => + { + b.Property("Id") + .ValueGeneratedOnAdd() + .HasColumnType("uniqueidentifier"); + + b.Property("DataCreazione") + .HasColumnType("datetime2"); + + b.Property("DataModifica") + .HasColumnType("datetime2"); + + b.Property("Eliminato") + .HasColumnType("bit"); + + b.Property("IdFeature") + .HasColumnType("uniqueidentifier"); + + b.Property("IdUtenteCreazione") + .HasColumnType("uniqueidentifier"); + + b.Property("IdUtenteModifica") + .HasColumnType("uniqueidentifier"); + + b.Property("RuoloId") + .HasColumnType("uniqueidentifier"); + + b.HasKey("Id"); + + b.HasIndex("IdFeature"); + + b.HasIndex("IdUtenteCreazione"); + + b.HasIndex("IdUtenteModifica"); + + b.HasIndex("RuoloId"); + + b.ToTable("Permission"); + }); + + modelBuilder.Entity("TecniStamp.Domain.ProvinciaIstat", b => + { + b.Property("Id") + .ValueGeneratedOnAdd() + .HasColumnType("uniqueidentifier"); + + b.Property("DataCreazione") + .HasColumnType("datetime2"); + + b.Property("DataModifica") + .HasColumnType("datetime2"); + + b.Property("Eliminato") + .HasColumnType("bit"); + + b.Property("IdUtenteCreazione") + .HasColumnType("uniqueidentifier"); + + b.Property("IdUtenteModifica") + .HasColumnType("uniqueidentifier"); + + b.Property("Provincia") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("Sigla") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.HasKey("Id"); + + b.HasIndex("IdUtenteCreazione"); + + b.HasIndex("IdUtenteModifica"); + + b.ToTable("ProvinciaIstat"); + }); + + modelBuilder.Entity("TecniStamp.Domain.Ruolo", b => + { + b.Property("Id") + .ValueGeneratedOnAdd() + .HasColumnType("uniqueidentifier"); + + b.Property("DataCreazione") + .HasColumnType("datetime2"); + + b.Property("DataModifica") + .HasColumnType("datetime2"); + + b.Property("Eliminato") + .HasColumnType("bit"); + + b.Property("IdUtenteCreazione") + .HasColumnType("uniqueidentifier"); + + b.Property("IdUtenteModifica") + .HasColumnType("uniqueidentifier"); + + b.Property("Nome") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.HasKey("Id"); + + b.HasIndex("IdUtenteCreazione"); + + b.HasIndex("IdUtenteModifica"); + + b.ToTable("Ruolo"); + }); + + modelBuilder.Entity("TecniStamp.Domain.Sezione", b => + { + b.Property("Id") + .ValueGeneratedOnAdd() + .HasColumnType("uniqueidentifier"); + + b.Property("Blank") + .HasColumnType("bit"); + + b.Property("DataCreazione") + .HasColumnType("datetime2"); + + b.Property("DataModifica") + .HasColumnType("datetime2"); + + b.Property("Eliminato") + .HasColumnType("bit"); + + b.Property("Icona") + .HasColumnType("nvarchar(max)"); + + b.Property("IdUtenteCreazione") + .HasColumnType("uniqueidentifier"); + + b.Property("IdUtenteModifica") + .HasColumnType("uniqueidentifier"); + + b.Property("Nome") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("Ordinamento") + .HasColumnType("int"); + + b.Property("ParentId") + .HasColumnType("uniqueidentifier"); + + b.Property("Url") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.HasKey("Id"); + + b.HasIndex("IdUtenteCreazione"); + + b.HasIndex("IdUtenteModifica"); + + b.HasIndex("ParentId"); + + b.ToTable("Sezione"); + }); + + modelBuilder.Entity("TecniStamp.Domain.Utente", b => + { + b.Property("Id") + .ValueGeneratedOnAdd() + .HasColumnType("uniqueidentifier"); + + b.Property("Cognome") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("Costo") + .HasColumnType("decimal(18,2)"); + + b.Property("DataCreazione") + .HasColumnType("datetime2"); + + b.Property("DataModifica") + .HasColumnType("datetime2"); + + b.Property("Eliminato") + .HasColumnType("bit"); + + b.Property("Email") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("IdUtenteCreazione") + .HasColumnType("uniqueidentifier"); + + b.Property("IdUtenteModifica") + .HasColumnType("uniqueidentifier"); + + b.Property("Nome") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("Password") + .IsRequired() + .HasColumnType("nvarchar(max)"); + + b.Property("RuoloId") + .HasColumnType("uniqueidentifier"); + + b.HasKey("Id"); + + b.HasIndex("IdUtenteCreazione"); + + b.HasIndex("IdUtenteModifica"); + + b.HasIndex("RuoloId"); + + b.ToTable("Utente"); + }); + + modelBuilder.Entity("TecniStamp.Domain.Cliente", b => + { + b.HasOne("TecniStamp.Domain.ComuneIstat", "Comune") + .WithMany() + .HasForeignKey("ComuneId"); + + b.HasOne("TecniStamp.Domain.Utente", "UtenteCreazione") + .WithMany() + .HasForeignKey("IdUtenteCreazione"); + + b.HasOne("TecniStamp.Domain.Utente", "UtenteModifica") + .WithMany() + .HasForeignKey("IdUtenteModifica"); + + b.Navigation("Comune"); + + b.Navigation("UtenteCreazione"); + + b.Navigation("UtenteModifica"); + }); + + modelBuilder.Entity("TecniStamp.Domain.Commessa", b => + { + b.HasOne("TecniStamp.Domain.Cliente", "Cliente") + .WithMany() + .HasForeignKey("ClienteId"); + + b.HasOne("TecniStamp.Domain.Utente", "UtenteCreazione") + .WithMany() + .HasForeignKey("IdUtenteCreazione"); + + b.HasOne("TecniStamp.Domain.Utente", "UtenteModifica") + .WithMany() + .HasForeignKey("IdUtenteModifica"); + + b.Navigation("Cliente"); + + b.Navigation("UtenteCreazione"); + + b.Navigation("UtenteModifica"); + }); + + modelBuilder.Entity("TecniStamp.Domain.ComuneIstat", b => + { + b.HasOne("TecniStamp.Domain.Utente", "UtenteCreazione") + .WithMany() + .HasForeignKey("IdUtenteCreazione"); + + b.HasOne("TecniStamp.Domain.Utente", "UtenteModifica") + .WithMany() + .HasForeignKey("IdUtenteModifica"); + + b.HasOne("TecniStamp.Domain.ProvinciaIstat", "ProvinciaIstat") + .WithMany() + .HasForeignKey("ProvinciaIstatId"); + + b.Navigation("ProvinciaIstat"); + + b.Navigation("UtenteCreazione"); + + b.Navigation("UtenteModifica"); + }); + + modelBuilder.Entity("TecniStamp.Domain.Feature", b => + { + b.HasOne("TecniStamp.Domain.Utente", "UtenteCreazione") + .WithMany() + .HasForeignKey("IdUtenteCreazione"); + + b.HasOne("TecniStamp.Domain.Utente", "UtenteModifica") + .WithMany() + .HasForeignKey("IdUtenteModifica"); + + b.HasOne("TecniStamp.Domain.Sezione", "Sezione") + .WithMany("Features") + .HasForeignKey("SezioneId") + .OnDelete(DeleteBehavior.Cascade) + .IsRequired(); + + b.Navigation("Sezione"); + + b.Navigation("UtenteCreazione"); + + b.Navigation("UtenteModifica"); + }); + + modelBuilder.Entity("TecniStamp.Domain.Lavorazione", b => + { + b.HasOne("TecniStamp.Domain.Utente", "UtenteCreazione") + .WithMany() + .HasForeignKey("IdUtenteCreazione"); + + b.HasOne("TecniStamp.Domain.Utente", "UtenteModifica") + .WithMany() + .HasForeignKey("IdUtenteModifica"); + + b.Navigation("UtenteCreazione"); + + b.Navigation("UtenteModifica"); + }); + + modelBuilder.Entity("TecniStamp.Domain.Macchinario", b => + { + b.HasOne("TecniStamp.Domain.Utente", "UtenteCreazione") + .WithMany() + .HasForeignKey("IdUtenteCreazione"); + + b.HasOne("TecniStamp.Domain.Utente", "UtenteModifica") + .WithMany() + .HasForeignKey("IdUtenteModifica"); + + b.Navigation("UtenteCreazione"); + + b.Navigation("UtenteModifica"); + }); + + modelBuilder.Entity("TecniStamp.Domain.Permission", b => + { + b.HasOne("TecniStamp.Domain.Feature", "Feature") + .WithMany() + .HasForeignKey("IdFeature") + .OnDelete(DeleteBehavior.Cascade) + .IsRequired(); + + b.HasOne("TecniStamp.Domain.Utente", "UtenteCreazione") + .WithMany() + .HasForeignKey("IdUtenteCreazione"); + + b.HasOne("TecniStamp.Domain.Utente", "UtenteModifica") + .WithMany() + .HasForeignKey("IdUtenteModifica"); + + b.HasOne("TecniStamp.Domain.Ruolo", "Ruolo") + .WithMany("Permessi") + .HasForeignKey("RuoloId"); + + b.Navigation("Feature"); + + b.Navigation("Ruolo"); + + b.Navigation("UtenteCreazione"); + + b.Navigation("UtenteModifica"); + }); + + modelBuilder.Entity("TecniStamp.Domain.ProvinciaIstat", b => + { + b.HasOne("TecniStamp.Domain.Utente", "UtenteCreazione") + .WithMany() + .HasForeignKey("IdUtenteCreazione"); + + b.HasOne("TecniStamp.Domain.Utente", "UtenteModifica") + .WithMany() + .HasForeignKey("IdUtenteModifica"); + + b.Navigation("UtenteCreazione"); + + b.Navigation("UtenteModifica"); + }); + + modelBuilder.Entity("TecniStamp.Domain.Ruolo", b => + { + b.HasOne("TecniStamp.Domain.Utente", "UtenteCreazione") + .WithMany() + .HasForeignKey("IdUtenteCreazione"); + + b.HasOne("TecniStamp.Domain.Utente", "UtenteModifica") + .WithMany() + .HasForeignKey("IdUtenteModifica"); + + b.Navigation("UtenteCreazione"); + + b.Navigation("UtenteModifica"); + }); + + modelBuilder.Entity("TecniStamp.Domain.Sezione", b => + { + b.HasOne("TecniStamp.Domain.Utente", "UtenteCreazione") + .WithMany() + .HasForeignKey("IdUtenteCreazione"); + + b.HasOne("TecniStamp.Domain.Utente", "UtenteModifica") + .WithMany() + .HasForeignKey("IdUtenteModifica"); + + b.HasOne("TecniStamp.Domain.Sezione", "Parent") + .WithMany() + .HasForeignKey("ParentId"); + + b.Navigation("Parent"); + + b.Navigation("UtenteCreazione"); + + b.Navigation("UtenteModifica"); + }); + + modelBuilder.Entity("TecniStamp.Domain.Utente", b => + { + b.HasOne("TecniStamp.Domain.Utente", "UtenteCreazione") + .WithMany() + .HasForeignKey("IdUtenteCreazione"); + + b.HasOne("TecniStamp.Domain.Utente", "UtenteModifica") + .WithMany() + .HasForeignKey("IdUtenteModifica"); + + b.HasOne("TecniStamp.Domain.Ruolo", "Ruolo") + .WithMany("Utenti") + .HasForeignKey("RuoloId"); + + b.Navigation("Ruolo"); + + b.Navigation("UtenteCreazione"); + + b.Navigation("UtenteModifica"); + }); + + modelBuilder.Entity("TecniStamp.Domain.Ruolo", b => + { + b.Navigation("Permessi"); + + b.Navigation("Utenti"); + }); + + modelBuilder.Entity("TecniStamp.Domain.Sezione", b => + { + b.Navigation("Features"); + }); +#pragma warning restore 612, 618 + } + } +} diff --git a/TecniStamp/TecniStamp.Infrastructure/Migrations/20260203103529_Rimossi campi cliente.cs b/TecniStamp/TecniStamp.Infrastructure/Migrations/20260203103529_Rimossi campi cliente.cs new file mode 100644 index 0000000..428c10f --- /dev/null +++ b/TecniStamp/TecniStamp.Infrastructure/Migrations/20260203103529_Rimossi campi cliente.cs @@ -0,0 +1,58 @@ +using Microsoft.EntityFrameworkCore.Migrations; + +#nullable disable + +namespace TecniStamp.Infrastructure.Migrations +{ + /// + public partial class Rimossicampicliente : Migration + { + /// + protected override void Up(MigrationBuilder migrationBuilder) + { + migrationBuilder.DropColumn( + name: "Indirizzo", + table: "Cliente"); + + migrationBuilder.DropColumn( + name: "Paese", + table: "Cliente"); + + migrationBuilder.AlterColumn( + name: "Note", + table: "Cliente", + type: "nvarchar(max)", + nullable: true, + oldClrType: typeof(string), + oldType: "nvarchar(max)"); + } + + /// + protected override void Down(MigrationBuilder migrationBuilder) + { + migrationBuilder.AlterColumn( + name: "Note", + table: "Cliente", + type: "nvarchar(max)", + nullable: false, + defaultValue: "", + oldClrType: typeof(string), + oldType: "nvarchar(max)", + oldNullable: true); + + migrationBuilder.AddColumn( + name: "Indirizzo", + table: "Cliente", + type: "nvarchar(max)", + nullable: false, + defaultValue: ""); + + migrationBuilder.AddColumn( + name: "Paese", + table: "Cliente", + type: "nvarchar(max)", + nullable: false, + defaultValue: ""); + } + } +} diff --git a/TecniStamp/TecniStamp.Infrastructure/Migrations/TecniStampDbContextModelSnapshot.cs b/TecniStamp/TecniStamp.Infrastructure/Migrations/TecniStampDbContextModelSnapshot.cs index 2a4bb0d..0f5402b 100644 --- a/TecniStamp/TecniStamp.Infrastructure/Migrations/TecniStampDbContextModelSnapshot.cs +++ b/TecniStamp/TecniStamp.Infrastructure/Migrations/TecniStampDbContextModelSnapshot.cs @@ -58,22 +58,13 @@ namespace TecniStamp.Infrastructure.Migrations b.Property("IdUtenteModifica") .HasColumnType("uniqueidentifier"); - b.Property("Indirizzo") - .IsRequired() - .HasColumnType("nvarchar(max)"); - b.Property("Note") - .IsRequired() .HasColumnType("nvarchar(max)"); b.Property("NumeroCivico") .IsRequired() .HasColumnType("nvarchar(max)"); - b.Property("Paese") - .IsRequired() - .HasColumnType("nvarchar(max)"); - b.Property("PartitaIva") .IsRequired() .HasColumnType("nvarchar(max)"); diff --git a/TecniStamp/TecniStamp/Components/Layout/MainLayout.razor b/TecniStamp/TecniStamp/Components/Layout/MainLayout.razor index f1ef179..119d4e8 100644 --- a/TecniStamp/TecniStamp/Components/Layout/MainLayout.razor +++ b/TecniStamp/TecniStamp/Components/Layout/MainLayout.razor @@ -4,15 +4,15 @@ -
- -
+ +
diff --git a/TecniStamp/TecniStamp/Components/Pages/Anagrafiche/Ruoli.razor b/TecniStamp/TecniStamp/Components/Pages/Anagrafiche/Ruoli.razor index 119c5c7..fdc5562 100644 --- a/TecniStamp/TecniStamp/Components/Pages/Anagrafiche/Ruoli.razor +++ b/TecniStamp/TecniStamp/Components/Pages/Anagrafiche/Ruoli.razor @@ -1,23 +1,22 @@ @page "/anagrafiche/ruoli" @using Microsoft.EntityFrameworkCore @using TecniStamp.Model +@using TecniStamp.Model.Common +@using TecniStamp.Utils @rendermode InteractiveServer -Ruoli -
- -
-
+Commesse + + +
+
+
-
- -

Ruoli

-
@@ -44,11 +43,12 @@
-
+ @code { List ruoli; RadzenDataGrid ruoliGrid; + public List BreadcrumbList { get; set; } = new(); /// /// Carica la lista dei ruoli non eliminati, ordinandoli per nome. @@ -62,6 +62,8 @@ includi: x => x.Include(y => y.UtenteCreazione), ordinamento: x => x.OrderBy(y => y.Nome))) .Select(x => (RuoloViewModel)x).ToList(); + + BreadcrumbList = await BreadcrumbUtils.BuildBreadcrumbByFeature(_managerService, "Ruoli_Insert"); } /// diff --git a/TecniStamp/TecniStamp/Components/Pages/Anagrafiche/Ruoli_Edit.razor b/TecniStamp/TecniStamp/Components/Pages/Anagrafiche/Ruoli_Edit.razor index c365bdb..9d83ed8 100644 --- a/TecniStamp/TecniStamp/Components/Pages/Anagrafiche/Ruoli_Edit.razor +++ b/TecniStamp/TecniStamp/Components/Pages/Anagrafiche/Ruoli_Edit.razor @@ -3,94 +3,82 @@ @using Microsoft.EntityFrameworkCore @using TecniStamp.Domain @using TecniStamp.Model +@using TecniStamp.Model.Common @using TecniStamp.Utils @rendermode InteractiveServer @inject AuthenticationStateProvider auth @pageTitle + -
- - - - -
-
- +
+
+
-
-
-
-
- - +
+
+
+ + -
-
-
- Descrizione - - -
-
- -
-
- -
-
- -
+
+
+
+ Descrizione + +
- + +
+
+ +
+
+ +
+
+
+ +
+ +
+
+
+ + + + + + + + + + + + +
- -
-
- - - - - - - - - - - - -
-
-
-
- +
@code { [Parameter] public Guid? RuoloId { get; set; } + public List BreadcrumbList { get; set; } = new(); public RuoloViewModel Model { get; set; } = new(); private List permessi { get; set; } = new(); @@ -113,6 +101,9 @@ permessi = []; foreach (var section in sections) permessi.AddRange(section.Features.Where(x => !x.Eliminato).Select(x => new PermissionRowViewModel(section, x, permissions)).ToList()); + + BreadcrumbList = await BreadcrumbUtils.BuildBreadcrumbByFeature(_managerService, "Ruoli_Insert", "Modifica", "/Anagrafiche/Ruoli"); + } /// diff --git a/TecniStamp/TecniStamp/Components/Pages/Commesse/Commesse.razor b/TecniStamp/TecniStamp/Components/Pages/Commesse/Commesse.razor index 6c6b06e..28adadc 100644 --- a/TecniStamp/TecniStamp/Components/Pages/Commesse/Commesse.razor +++ b/TecniStamp/TecniStamp/Components/Pages/Commesse/Commesse.razor @@ -29,9 +29,9 @@ - - - + + + diff --git a/TecniStamp/TecniStamp/Components/Widget/Breadcrumb.razor b/TecniStamp/TecniStamp/Components/Widget/Breadcrumb.razor index fed5bee..afc68c0 100644 --- a/TecniStamp/TecniStamp/Components/Widget/Breadcrumb.razor +++ b/TecniStamp/TecniStamp/Components/Widget/Breadcrumb.razor @@ -1,5 +1,5 @@ @using TecniStamp.Model.Common -
+
@@ -56,7 +73,8 @@ CommesseList = (await _managerService.CommessaService.RicercaQueryable( x => x.Eliminato == false, - includi:x => x.Include(y => y.Cliente).ThenInclude(z => z.Comune).ThenInclude(w => w.ProvinciaIstat))) + includi:x => x.Include(y => y.Cliente).ThenInclude(z => z.Comune).ThenInclude(w => w.ProvinciaIstat) + .Include(x => x.Posizioni))) .Select(x => (CommessaViewModel)x).ToList(); } } \ No newline at end of file diff --git a/TecniStamp/TecniStamp/Model/Commesse/CommessaPosizioneViewModel.cs b/TecniStamp/TecniStamp/Model/Commesse/CommessaPosizioneViewModel.cs new file mode 100644 index 0000000..e7e13d6 --- /dev/null +++ b/TecniStamp/TecniStamp/Model/Commesse/CommessaPosizioneViewModel.cs @@ -0,0 +1,35 @@ +using TecniStamp.Domain; + +namespace TecniStamp.Model.Commesse; + +public class CommessaPosizioneViewModel : BaseViewModel +{ + public int Posizione { get; set; } + public string NumeroDisegno { get; set; } + public string NumeroArticolo { get; set; } + public string NumeroFabb { get; set; } + public string Descrizione { get; set; } + public string Categoria { get; set; } + public DateTime DataConsegna { get; set; } + public DateTime DataTerminePrevisto { get; set; } + + public override void Validate(){} + + public static implicit operator CommessaPosizioneViewModel(CommessaPosizione model) + { + return model == null + ? null + : new CommessaPosizioneViewModel() + { + Descrizione = model.Descrizione, + NumeroArticolo = model.NumeroArticolo, + NumeroDisegno = model.NumeroDisegno, + NumeroFabb = model.NumeroFabb, + Categoria = model.Categoria, + DataConsegna = model.DataConsegna, + DataTerminePrevisto = model.DataTerminePrevisto, + Id = model.Id, + Posizione = model.Posizione + }; + } +} \ No newline at end of file diff --git a/TecniStamp/TecniStamp/Model/Commesse/CommessaViewModel.cs b/TecniStamp/TecniStamp/Model/Commesse/CommessaViewModel.cs index fb8074f..2c5c0a0 100644 --- a/TecniStamp/TecniStamp/Model/Commesse/CommessaViewModel.cs +++ b/TecniStamp/TecniStamp/Model/Commesse/CommessaViewModel.cs @@ -15,6 +15,7 @@ public class CommessaViewModel : BaseViewModel public DateTime DataConsegnaPrevista { get; set; } public DateTime DataConsegna { get; set; } public CommessaStato Stato { get; set; } + public List Posizioni { get; set; } public string RagioneSocialeCliente => Cliente?.RagioneSociale ?? string.Empty; @@ -40,7 +41,8 @@ public class CommessaViewModel : BaseViewModel DataOrdine = model.DataOrdine, DataConsegnaPrevista = model.DataConsegnaPrevista, DataConsegna = model.DataConsegna, - Id = model.Id + Id = model.Id, + Posizioni = model.Posizioni.Select(p => (CommessaPosizioneViewModel)p).ToList() }; } } \ No newline at end of file From 5b1fc5f66e7e7464ab3c28ec04480d616328b47a Mon Sep 17 00:00:00 2001 From: Gianmarco Date: Tue, 3 Feb 2026 14:04:46 +0100 Subject: [PATCH 3/3] Commessa Edit --- .../Components/Pages/Commesse/Commesse.razor | 34 ++++++++++++ .../Pages/Commesse/Commesse_Edit.razor | 55 +++++++++++++++++++ .../Commesse/Commesse_Edit_InfoGenerali.razor | 6 ++ .../Pages/Commesse/Commesse_Edit_OE.razor | 6 ++ .../TecniStamp/Components/_Imports.razor | 1 + .../TecniStamp/Utils/MembershipUtils.cs | 13 +++++ 6 files changed, 115 insertions(+) create mode 100644 TecniStamp/TecniStamp/Components/Pages/Commesse/Commesse_Edit.razor create mode 100644 TecniStamp/TecniStamp/Components/Pages/Commesse/Commesse_Edit_InfoGenerali.razor create mode 100644 TecniStamp/TecniStamp/Components/Pages/Commesse/Commesse_Edit_OE.razor diff --git a/TecniStamp/TecniStamp/Components/Pages/Commesse/Commesse.razor b/TecniStamp/TecniStamp/Components/Pages/Commesse/Commesse.razor index ae01a79..d41cfc0 100644 --- a/TecniStamp/TecniStamp/Components/Pages/Commesse/Commesse.razor +++ b/TecniStamp/TecniStamp/Components/Pages/Commesse/Commesse.razor @@ -50,6 +50,13 @@ + + + +
@@ -65,6 +72,9 @@ public List CommesseList { get; set; } = new(); RadzenDataGrid commesseGrid; + private bool canEdit = false; + private bool canDelete = false; + protected override async Task OnInitializedAsync() { await base.OnInitializedAsync(); @@ -76,5 +86,29 @@ includi:x => x.Include(y => y.Cliente).ThenInclude(z => z.Comune).ThenInclude(w => w.ProvinciaIstat) .Include(x => x.Posizioni))) .Select(x => (CommessaViewModel)x).ToList(); + canEdit = await MembershipUtils.CheckPermission(_auth, _managerService, "Commesse_Edit"); + canDelete = await MembershipUtils.CheckPermission(_auth, _managerService, "Commesse_Delete"); } + + private async Task EditRow(CommessaViewModel commessa) + { + _navManager.NavigateTo($"/commesse/modifica/{commessa.Id}"); + } + + private async Task DeleteRow(CommessaViewModel commessa) + { + var ok = await _dialogService.Confirm($"Vuoi davvero eliminare la commessa {commessa.CodiceCommessa}?", "Conferma eliminazione", new ConfirmOptions { OkButtonText = "Sì", CancelButtonText = "No", Width = "400px" }); + + if (ok == true) + { + await _managerService.CommessaService.Elimina(commessa.Id, await MembershipUtils.GetUserId(_auth)); + CommesseList = (await _managerService.CommessaService.RicercaQueryable( + x => x.Eliminato == false, + includi:x => x.Include(y => y.Cliente).ThenInclude(z => z.Comune).ThenInclude(w => w.ProvinciaIstat) + .Include(x => x.Posizioni))) + .Select(x => (CommessaViewModel)x).ToList(); + } + } + +void ShowTooltip(ElementReference elementReference, TooltipOptions options = null) => _tooltipService.Open(elementReference, options.Text, options); } \ No newline at end of file diff --git a/TecniStamp/TecniStamp/Components/Pages/Commesse/Commesse_Edit.razor b/TecniStamp/TecniStamp/Components/Pages/Commesse/Commesse_Edit.razor new file mode 100644 index 0000000..0edd4c6 --- /dev/null +++ b/TecniStamp/TecniStamp/Components/Pages/Commesse/Commesse_Edit.razor @@ -0,0 +1,55 @@ +@page "/commesse/modifica" +@page "/commesse/modifica/{CommessaId:guid}" + +@rendermode InteractiveServer + +@using Microsoft.EntityFrameworkCore +@using TecniStamp.Model.Commesse +@using TecniStamp.Model.Common +@using TecniStamp.Utils + +Commesse + + +
+
+
+
+
+ + + + + + + + + + + +
+
+
+
+
+ +@code { + [Parameter] public Guid? CommessaId { get; set; } + + public List BreadcrumbList { get; set; } = new(); + + public CommessaViewModel Model { get; set; } = new(); + + protected override async Task OnInitializedAsync() + { + await base.OnInitializedAsync(); + + Model = CommessaId.GetValueOrDefault() == Guid.Empty + ? new CommessaViewModel() + : await _managerService.CommessaService.RicercaPer(x => x.Id == CommessaId, + includi:x => x.Include(y => y.Cliente).Include(y => y.Posizioni)); + + BreadcrumbList = await BreadcrumbUtils.BuildBreadcrumbByFeature(_managerService, "Commesse_Info", "Modifica", "/commesse"); + } + +} \ No newline at end of file diff --git a/TecniStamp/TecniStamp/Components/Pages/Commesse/Commesse_Edit_InfoGenerali.razor b/TecniStamp/TecniStamp/Components/Pages/Commesse/Commesse_Edit_InfoGenerali.razor new file mode 100644 index 0000000..56ca312 --- /dev/null +++ b/TecniStamp/TecniStamp/Components/Pages/Commesse/Commesse_Edit_InfoGenerali.razor @@ -0,0 +1,6 @@ +@using TecniStamp.Model.Commesse +

@Model.CodiceCommessa

+ +@code { + [Parameter] public CommessaViewModel Model { get; set; } = new(); +} \ No newline at end of file diff --git a/TecniStamp/TecniStamp/Components/Pages/Commesse/Commesse_Edit_OE.razor b/TecniStamp/TecniStamp/Components/Pages/Commesse/Commesse_Edit_OE.razor new file mode 100644 index 0000000..512b43a --- /dev/null +++ b/TecniStamp/TecniStamp/Components/Pages/Commesse/Commesse_Edit_OE.razor @@ -0,0 +1,6 @@ +@using TecniStamp.Model.Commesse +

Commesse_Edit_OE

+ +@code { + [Parameter] public CommessaViewModel Model { get; set; } = new(); +} \ No newline at end of file diff --git a/TecniStamp/TecniStamp/Components/_Imports.razor b/TecniStamp/TecniStamp/Components/_Imports.razor index c064d65..ac8a8a8 100644 --- a/TecniStamp/TecniStamp/Components/_Imports.razor +++ b/TecniStamp/TecniStamp/Components/_Imports.razor @@ -18,5 +18,6 @@ @inject IManagerService _managerService @inject DialogService _dialogService +@inject TooltipService _tooltipService @inject NavigationManager _navManager @inject AuthenticationStateProvider _auth \ No newline at end of file diff --git a/TecniStamp/TecniStamp/Utils/MembershipUtils.cs b/TecniStamp/TecniStamp/Utils/MembershipUtils.cs index 8491cba..dbdc289 100644 --- a/TecniStamp/TecniStamp/Utils/MembershipUtils.cs +++ b/TecniStamp/TecniStamp/Utils/MembershipUtils.cs @@ -1,4 +1,5 @@ using Microsoft.AspNetCore.Components.Authorization; +using TecniStamp.Service.Interfaces; namespace TecniStamp.Utils; @@ -19,4 +20,16 @@ public static class MembershipUtils return Guid.Parse(idClaim ?? Guid.Empty.ToString()); } + + public static async Task CheckPermission(AuthenticationStateProvider auth, IManagerService managerService, string featureName) + { + var state = await auth.GetAuthenticationStateAsync(); + var idClaim = state.User.FindFirst("RoleId")?.Value; + + var parsed = Guid.Parse(idClaim ?? Guid.Empty.ToString()); + + var perm = await managerService.RuoloService.RicercaPer(x => + x.Id == parsed && x.Permessi.Any(y => y.Feature.Nome == featureName && y.Eliminato == false) && x.Eliminato == false); + return perm != null; + } }