- Dodati operacije na pozicijo dela projekta

- Dodatna tabela z operacijami in stanjem (končano/nekončano)
  - šifrant operacij - možnost določevanje privzetih operacij

- Opombe na pozicij dela projekta

- Pogled kooperacij na poziciji dela projekta
  - Izpisano številka kooperacije in kooperant
This commit is contained in:
2026-02-28 09:37:13 +01:00
parent 7d64e423c3
commit 9d0fb30bf0
15 changed files with 3774 additions and 56 deletions

File diff suppressed because it is too large Load Diff

View File

@@ -0,0 +1,140 @@
using Microsoft.EntityFrameworkCore.Metadata;
using Microsoft.EntityFrameworkCore.Migrations;
#nullable disable
namespace EveryThing.Migrations
{
public partial class _17 : Migration
{
protected override void Up(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropForeignKey(
name: "FK_Invoices_Projects_ProjectIdProject",
table: "Invoices");
migrationBuilder.DropIndex(
name: "IX_Invoices_ProjectIdProject",
table: "Invoices");
migrationBuilder.DropColumn(
name: "ProjectIdProject",
table: "Invoices");
migrationBuilder.AddColumn<string>(
name: "Note",
table: "ProjectPartItems",
type: "longtext",
nullable: true)
.Annotation("MySql:CharSet", "utf8mb4");
migrationBuilder.CreateTable(
name: "CodeTableOperations",
columns: table => new
{
Id = table.Column<int>(type: "int", nullable: false)
.Annotation("MySql:ValueGenerationStrategy", MySqlValueGenerationStrategy.IdentityColumn),
Title = table.Column<string>(type: "longtext", nullable: false)
.Annotation("MySql:CharSet", "utf8mb4"),
Default = table.Column<bool>(type: "tinyint(1)", nullable: false)
},
constraints: table =>
{
table.PrimaryKey("PK_CodeTableOperations", x => x.Id);
})
.Annotation("MySql:CharSet", "utf8mb4");
migrationBuilder.CreateTable(
name: "ProjectPartItemOperations",
columns: table => new
{
Id = table.Column<int>(type: "int", nullable: false)
.Annotation("MySql:ValueGenerationStrategy", MySqlValueGenerationStrategy.IdentityColumn),
IdProjectPartItemFk = table.Column<int>(type: "int", nullable: false),
IdCodeTableOperationFk = table.Column<int>(type: "int", nullable: false),
Finished = table.Column<bool>(type: "tinyint(1)", nullable: false),
Order = table.Column<short>(type: "smallint", nullable: false)
},
constraints: table =>
{
table.PrimaryKey("PK_ProjectPartItemOperations", x => x.Id);
table.ForeignKey(
name: "FK_ProjectPartItemOperations_CodeTableOperations_IdCodeTableOpe~",
column: x => x.IdCodeTableOperationFk,
principalTable: "CodeTableOperations",
principalColumn: "Id",
onDelete: ReferentialAction.Restrict);
table.ForeignKey(
name: "FK_ProjectPartItemOperations_ProjectPartItems_IdProjectPartItem~",
column: x => x.IdProjectPartItemFk,
principalTable: "ProjectPartItems",
principalColumn: "IdProjectPartItem",
onDelete: ReferentialAction.Restrict);
})
.Annotation("MySql:CharSet", "utf8mb4");
migrationBuilder.CreateIndex(
name: "IX_Invoices_IdProjectFk",
table: "Invoices",
column: "IdProjectFk");
migrationBuilder.CreateIndex(
name: "IX_ProjectPartItemOperations_IdCodeTableOperationFk",
table: "ProjectPartItemOperations",
column: "IdCodeTableOperationFk");
migrationBuilder.CreateIndex(
name: "IX_ProjectPartItemOperations_IdProjectPartItemFk",
table: "ProjectPartItemOperations",
column: "IdProjectPartItemFk");
migrationBuilder.AddForeignKey(
name: "FK_Invoices_Projects_IdProjectFk",
table: "Invoices",
column: "IdProjectFk",
principalTable: "Projects",
principalColumn: "IdProject",
onDelete: ReferentialAction.Restrict);
}
protected override void Down(MigrationBuilder migrationBuilder)
{
migrationBuilder.DropForeignKey(
name: "FK_Invoices_Projects_IdProjectFk",
table: "Invoices");
migrationBuilder.DropTable(
name: "ProjectPartItemOperations");
migrationBuilder.DropTable(
name: "CodeTableOperations");
migrationBuilder.DropIndex(
name: "IX_Invoices_IdProjectFk",
table: "Invoices");
migrationBuilder.DropColumn(
name: "Note",
table: "ProjectPartItems");
migrationBuilder.AddColumn<int>(
name: "ProjectIdProject",
table: "Invoices",
type: "int",
nullable: true);
migrationBuilder.CreateIndex(
name: "IX_Invoices_ProjectIdProject",
table: "Invoices",
column: "ProjectIdProject");
migrationBuilder.AddForeignKey(
name: "FK_Invoices_Projects_ProjectIdProject",
table: "Invoices",
column: "ProjectIdProject",
principalTable: "Projects",
principalColumn: "IdProject",
onDelete: ReferentialAction.Restrict);
}
}
}

View File

@@ -318,6 +318,24 @@ namespace EveryThing.Migrations
b.ToTable("CodeTableJobs");
});
modelBuilder.Entity("EveryThing.Models.CodeTable.CodeTableOperation", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
b.Property<bool>("Default")
.HasColumnType("tinyint(1)");
b.Property<string>("Title")
.IsRequired()
.HasColumnType("longtext");
b.HasKey("Id");
b.ToTable("CodeTableOperations");
});
modelBuilder.Entity("EveryThing.Models.CodeTable.CodeTablePartner", b =>
{
b.Property<int>("IdPartner")
@@ -713,9 +731,6 @@ namespace EveryThing.Migrations
b.Property<string>("PreText")
.HasColumnType("longtext");
b.Property<int?>("ProjectIdProject")
.HasColumnType("int");
b.Property<int>("State")
.HasColumnType("int");
@@ -728,7 +743,7 @@ namespace EveryThing.Migrations
b.HasIndex("IdPartnerFk");
b.HasIndex("ProjectIdProject");
b.HasIndex("IdProjectFk");
b.ToTable("Invoices");
});
@@ -900,6 +915,9 @@ namespace EveryThing.Migrations
b.Property<float>("MaterialPrice")
.HasColumnType("float");
b.Property<string>("Note")
.HasColumnType("longtext");
b.Property<float>("NumberOfItems")
.HasColumnType("float");
@@ -937,6 +955,33 @@ namespace EveryThing.Migrations
b.ToTable("ProjectPartItems");
});
modelBuilder.Entity("EveryThing.Models.Project.ProjectPartItemOperation", b =>
{
b.Property<int>("Id")
.ValueGeneratedOnAdd()
.HasColumnType("int");
b.Property<bool>("Finished")
.HasColumnType("tinyint(1)");
b.Property<int>("IdCodeTableOperationFk")
.HasColumnType("int");
b.Property<int>("IdProjectPartItemFk")
.HasColumnType("int");
b.Property<short>("Order")
.HasColumnType("smallint");
b.HasKey("Id");
b.HasIndex("IdCodeTableOperationFk");
b.HasIndex("IdProjectPartItemFk");
b.ToTable("ProjectPartItemOperations");
});
modelBuilder.Entity("EveryThing.Models.Transport.TransportLoadingOrder", b =>
{
b.Property<int>("IdTransportLoadingOrder")
@@ -1823,7 +1868,7 @@ namespace EveryThing.Migrations
b.HasOne("EveryThing.Models.Project.Project", "Project")
.WithMany("Invoices")
.HasForeignKey("ProjectIdProject")
.HasForeignKey("IdProjectFk")
.OnDelete(DeleteBehavior.Restrict);
b.Navigation("Company");
@@ -1925,6 +1970,25 @@ namespace EveryThing.Migrations
b.Navigation("ProjectPart");
});
modelBuilder.Entity("EveryThing.Models.Project.ProjectPartItemOperation", b =>
{
b.HasOne("EveryThing.Models.CodeTable.CodeTableOperation", "Operation")
.WithMany("ProjectPartItemOperation")
.HasForeignKey("IdCodeTableOperationFk")
.OnDelete(DeleteBehavior.Restrict)
.IsRequired();
b.HasOne("EveryThing.Models.Project.ProjectPartItem", "ProjectPartItem")
.WithMany("ProjectPartItemOperation")
.HasForeignKey("IdProjectPartItemFk")
.OnDelete(DeleteBehavior.Restrict)
.IsRequired();
b.Navigation("Operation");
b.Navigation("ProjectPartItem");
});
modelBuilder.Entity("EveryThing.Models.Transport.TransportLoadingOrder", b =>
{
b.HasOne("EveryThing.Models.CodeTable.CodeTableCompany", "Company")
@@ -2354,6 +2418,11 @@ namespace EveryThing.Migrations
b.Navigation("JobEmployee");
});
modelBuilder.Entity("EveryThing.Models.CodeTable.CodeTableOperation", b =>
{
b.Navigation("ProjectPartItemOperation");
});
modelBuilder.Entity("EveryThing.Models.CodeTable.CodeTablePartner", b =>
{
b.Navigation("Invoice");
@@ -2394,6 +2463,8 @@ namespace EveryThing.Migrations
modelBuilder.Entity("EveryThing.Models.Project.ProjectPartItem", b =>
{
b.Navigation("InvoiceItem");
b.Navigation("ProjectPartItemOperation");
});
modelBuilder.Entity("EveryThing.Models.Transport.TransportLoadingOrder", b =>