From 3bda43c72f2ebd66484426da0b154d14f5468661 Mon Sep 17 00:00:00 2001 From: Serreau Jovann Date: Thu, 2 Apr 2026 22:26:15 +0200 Subject: [PATCH] feat: ajout entities Devis, Advert et Order liees a OrderNumber MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Relations: - Devis → OrderNumber (OneToOne): chaque devis a un numero unique - Devis → Advert (OneToMany): un devis peut generer plusieurs factures pro forma - Advert → OrderNumber (OneToOne): chaque facture pro forma a un numero unique - Advert → Devis (ManyToOne, nullable): un advert peut exister sans devis - Advert → Order (OneToMany): un advert peut generer plusieurs factures - Order → OrderNumber (OneToOne): chaque facture a un numero unique - Order → Advert (ManyToOne, nullable): une facture peut exister sans advert Chaine: Devis → Advert → Order Si un advert genere plusieurs factures, le champ splitIndex (smallint) ajoute un suffixe -X au numero (ex: 04/2026-00001-1, 04/2026-00001-2). La methode getInvoiceNumber() retourne le numero complet avec suffixe. src/Entity/Devis.php: id, orderNumber (OneToOne), createdAt, adverts (OneToMany) src/Entity/Advert.php: id, orderNumber (OneToOne), devis (ManyToOne nullable), createdAt, orders (OneToMany) src/Entity/Order.php: id, orderNumber (OneToOne), advert (ManyToOne nullable), splitIndex (smallint default 0), createdAt, getInvoiceNumber() Table nommee `order` (mot reserve SQL, echappee avec backticks) src/Repository/DevisRepository.php, AdvertRepository.php, OrderRepository.php migrations/Version20260402202554.php: tables devis, advert, `order` avec foreign keys vers order_number et relations entre elles Co-Authored-By: Claude Opus 4.6 (1M context) --- migrations/Version20260402202554.php | 50 ++++++++++++++++ src/Entity/Advert.php | 70 +++++++++++++++++++++++ src/Entity/Devis.php | 56 ++++++++++++++++++ src/Entity/Order.php | 85 ++++++++++++++++++++++++++++ src/Repository/AdvertRepository.php | 18 ++++++ src/Repository/DevisRepository.php | 18 ++++++ src/Repository/OrderRepository.php | 18 ++++++ 7 files changed, 315 insertions(+) create mode 100644 migrations/Version20260402202554.php create mode 100644 src/Entity/Advert.php create mode 100644 src/Entity/Devis.php create mode 100644 src/Entity/Order.php create mode 100644 src/Repository/AdvertRepository.php create mode 100644 src/Repository/DevisRepository.php create mode 100644 src/Repository/OrderRepository.php diff --git a/migrations/Version20260402202554.php b/migrations/Version20260402202554.php new file mode 100644 index 0000000..e02ab7a --- /dev/null +++ b/migrations/Version20260402202554.php @@ -0,0 +1,50 @@ +addSql('CREATE TABLE advert (id INT GENERATED BY DEFAULT AS IDENTITY NOT NULL, created_at TIMESTAMP(0) WITHOUT TIME ZONE NOT NULL, order_number_id INT NOT NULL, devis_id INT DEFAULT NULL, PRIMARY KEY (id))'); + $this->addSql('CREATE UNIQUE INDEX UNIQ_54F1F40B8C26A5E8 ON advert (order_number_id)'); + $this->addSql('CREATE INDEX IDX_54F1F40B41DEFADA ON advert (devis_id)'); + $this->addSql('CREATE TABLE devis (id INT GENERATED BY DEFAULT AS IDENTITY NOT NULL, created_at TIMESTAMP(0) WITHOUT TIME ZONE NOT NULL, order_number_id INT NOT NULL, PRIMARY KEY (id))'); + $this->addSql('CREATE UNIQUE INDEX UNIQ_8B27C52B8C26A5E8 ON devis (order_number_id)'); + $this->addSql('CREATE TABLE "order" (id INT GENERATED BY DEFAULT AS IDENTITY NOT NULL, split_index SMALLINT DEFAULT 0 NOT NULL, created_at TIMESTAMP(0) WITHOUT TIME ZONE NOT NULL, order_number_id INT NOT NULL, advert_id INT DEFAULT NULL, PRIMARY KEY (id))'); + $this->addSql('CREATE UNIQUE INDEX UNIQ_F52993988C26A5E8 ON "order" (order_number_id)'); + $this->addSql('CREATE INDEX IDX_F5299398D07ECCB6 ON "order" (advert_id)'); + $this->addSql('ALTER TABLE advert ADD CONSTRAINT FK_54F1F40B8C26A5E8 FOREIGN KEY (order_number_id) REFERENCES order_number (id) NOT DEFERRABLE'); + $this->addSql('ALTER TABLE advert ADD CONSTRAINT FK_54F1F40B41DEFADA FOREIGN KEY (devis_id) REFERENCES devis (id) NOT DEFERRABLE'); + $this->addSql('ALTER TABLE devis ADD CONSTRAINT FK_8B27C52B8C26A5E8 FOREIGN KEY (order_number_id) REFERENCES order_number (id) NOT DEFERRABLE'); + $this->addSql('ALTER TABLE "order" ADD CONSTRAINT FK_F52993988C26A5E8 FOREIGN KEY (order_number_id) REFERENCES order_number (id) NOT DEFERRABLE'); + $this->addSql('ALTER TABLE "order" ADD CONSTRAINT FK_F5299398D07ECCB6 FOREIGN KEY (advert_id) REFERENCES advert (id) NOT DEFERRABLE'); + } + + public function down(Schema $schema): void + { + // this down() migration is auto-generated, please modify it to your needs + $this->addSql('ALTER TABLE advert DROP CONSTRAINT FK_54F1F40B8C26A5E8'); + $this->addSql('ALTER TABLE advert DROP CONSTRAINT FK_54F1F40B41DEFADA'); + $this->addSql('ALTER TABLE devis DROP CONSTRAINT FK_8B27C52B8C26A5E8'); + $this->addSql('ALTER TABLE "order" DROP CONSTRAINT FK_F52993988C26A5E8'); + $this->addSql('ALTER TABLE "order" DROP CONSTRAINT FK_F5299398D07ECCB6'); + $this->addSql('DROP TABLE advert'); + $this->addSql('DROP TABLE devis'); + $this->addSql('DROP TABLE "order"'); + } +} diff --git a/src/Entity/Advert.php b/src/Entity/Advert.php new file mode 100644 index 0000000..201a107 --- /dev/null +++ b/src/Entity/Advert.php @@ -0,0 +1,70 @@ + */ + #[ORM\OneToMany(targetEntity: Order::class, mappedBy: 'advert')] + private Collection $orders; + + public function __construct(OrderNumber $orderNumber) + { + $this->orderNumber = $orderNumber; + $this->createdAt = new \DateTimeImmutable(); + $this->orders = new ArrayCollection(); + } + + public function getId(): ?int + { + return $this->id; + } + + public function getOrderNumber(): OrderNumber + { + return $this->orderNumber; + } + + public function getDevis(): ?Devis + { + return $this->devis; + } + + public function setDevis(?Devis $devis): void + { + $this->devis = $devis; + } + + public function getCreatedAt(): \DateTimeImmutable + { + return $this->createdAt; + } + + /** @return Collection */ + public function getOrders(): Collection + { + return $this->orders; + } +} diff --git a/src/Entity/Devis.php b/src/Entity/Devis.php new file mode 100644 index 0000000..e53b003 --- /dev/null +++ b/src/Entity/Devis.php @@ -0,0 +1,56 @@ + */ + #[ORM\OneToMany(targetEntity: Advert::class, mappedBy: 'devis')] + private Collection $adverts; + + public function __construct(OrderNumber $orderNumber) + { + $this->orderNumber = $orderNumber; + $this->createdAt = new \DateTimeImmutable(); + $this->adverts = new ArrayCollection(); + } + + public function getId(): ?int + { + return $this->id; + } + + public function getOrderNumber(): OrderNumber + { + return $this->orderNumber; + } + + public function getCreatedAt(): \DateTimeImmutable + { + return $this->createdAt; + } + + /** @return Collection */ + public function getAdverts(): Collection + { + return $this->adverts; + } +} diff --git a/src/Entity/Order.php b/src/Entity/Order.php new file mode 100644 index 0000000..96d0ef5 --- /dev/null +++ b/src/Entity/Order.php @@ -0,0 +1,85 @@ + 0])] + private int $splitIndex = 0; + + #[ORM\Column] + private \DateTimeImmutable $createdAt; + + public function __construct(OrderNumber $orderNumber) + { + $this->orderNumber = $orderNumber; + $this->createdAt = new \DateTimeImmutable(); + } + + public function getId(): ?int + { + return $this->id; + } + + public function getOrderNumber(): OrderNumber + { + return $this->orderNumber; + } + + public function getAdvert(): ?Advert + { + return $this->advert; + } + + public function setAdvert(?Advert $advert): void + { + $this->advert = $advert; + } + + public function getSplitIndex(): int + { + return $this->splitIndex; + } + + public function setSplitIndex(int $splitIndex): void + { + $this->splitIndex = $splitIndex; + } + + /** + * Retourne le numero de facture complet. + * Si splitIndex > 0, ajoute le suffixe -X (ex: 04/2026-00001-2). + */ + public function getInvoiceNumber(): string + { + $num = $this->orderNumber->getNumOrder(); + + return $this->splitIndex > 0 ? $num.'-'.$this->splitIndex : $num; + } + + public function getCreatedAt(): \DateTimeImmutable + { + return $this->createdAt; + } +} diff --git a/src/Repository/AdvertRepository.php b/src/Repository/AdvertRepository.php new file mode 100644 index 0000000..5d08193 --- /dev/null +++ b/src/Repository/AdvertRepository.php @@ -0,0 +1,18 @@ + + */ +class AdvertRepository extends ServiceEntityRepository +{ + public function __construct(ManagerRegistry $registry) + { + parent::__construct($registry, Advert::class); + } +} diff --git a/src/Repository/DevisRepository.php b/src/Repository/DevisRepository.php new file mode 100644 index 0000000..9677a6b --- /dev/null +++ b/src/Repository/DevisRepository.php @@ -0,0 +1,18 @@ + + */ +class DevisRepository extends ServiceEntityRepository +{ + public function __construct(ManagerRegistry $registry) + { + parent::__construct($registry, Devis::class); + } +} diff --git a/src/Repository/OrderRepository.php b/src/Repository/OrderRepository.php new file mode 100644 index 0000000..22af896 --- /dev/null +++ b/src/Repository/OrderRepository.php @@ -0,0 +1,18 @@ + + */ +class OrderRepository extends ServiceEntityRepository +{ + public function __construct(ManagerRegistry $registry) + { + parent::__construct($registry, Order::class); + } +}