feat: ajout de la fonctionnalité d'édition des mangas, incluant la création d'un modal d'édition, la mise à jour de l'API pour gérer les modifications, et l'intégration de la logique de gestion des erreurs. Tests ajoutés pour valider le bon fonctionnement de l'édition.

This commit is contained in:
ext.jeremy.guillot@maxicoffee.domains
2025-06-30 20:00:09 +02:00
parent 896c57ac34
commit 9255509042
20 changed files with 1185 additions and 11 deletions

View File

@@ -0,0 +1,18 @@
<?php
namespace App\Domain\Manga\Application\Command;
readonly class EditManga
{
public function __construct(
public string $id,
public ?string $title = null,
public ?string $description = null,
public ?string $author = null,
public ?int $publicationYear = null,
public ?array $genres = null,
public ?string $status = null,
public ?float $rating = null,
public ?array $alternativeSlugs = null
) {}
}

View File

@@ -36,7 +36,9 @@ readonly class CreateMangaHandler
$command->status,
$command->externalId ? new ExternalId($command->externalId) : null,
$command->imageUrl,
$command->rating
$command->rating,
null, // imageUrls
[], // alternativeSlugs
);
if (!is_null($command->imageUrl)) {
@@ -55,4 +57,4 @@ readonly class CreateMangaHandler
$this->messageBus->dispatch(new MangaCreated($command->externalId));
}
}
}
}

View File

@@ -0,0 +1,59 @@
<?php
namespace App\Domain\Manga\Application\CommandHandler;
use App\Domain\Manga\Application\Command\EditManga;
use App\Domain\Manga\Domain\Contract\Repository\MangaRepositoryInterface;
use App\Domain\Manga\Domain\Exception\MangaNotFoundException;
use App\Domain\Manga\Domain\Model\ValueObject\MangaTitle;
readonly class EditMangaHandler
{
public function __construct(
private MangaRepositoryInterface $mangaRepository
) {}
public function handle(EditManga $command): void
{
$manga = $this->mangaRepository->findById($command->id);
if (!$manga) {
throw new MangaNotFoundException($command->id);
}
// Update only provided fields (partial update)
if ($command->title !== null) {
$manga->updateTitle(new MangaTitle($command->title));
}
if ($command->description !== null) {
$manga->updateDescription($command->description);
}
if ($command->author !== null) {
$manga->updateAuthor($command->author);
}
if ($command->publicationYear !== null) {
$manga->updatePublicationYear($command->publicationYear);
}
if ($command->genres !== null) {
$manga->updateGenres($command->genres);
}
if ($command->status !== null) {
$manga->updateStatus($command->status);
}
if ($command->rating !== null) {
$manga->setRating($command->rating);
}
if ($command->alternativeSlugs !== null) {
$manga->updateAlternativeSlugs($command->alternativeSlugs);
}
$this->mangaRepository->save($manga);
}
}

View File

@@ -25,6 +25,7 @@ readonly class GetMangaByIdHandler
id: $manga->getId()->getValue(),
title: $manga->getTitle()->getValue(),
slug: $manga->getSlug()->getValue(),
alternativeSlugs: $manga->getAlternativeSlugs(),
description: $manga->getDescription(),
author: $manga->getAuthor(),
publicationYear: $manga->getPublicationYear(),
@@ -32,7 +33,7 @@ readonly class GetMangaByIdHandler
status: $manga->getStatus(),
externalId: $manga->getExternalId()?->getValue(),
imageUrl: $manga->getImageUrl(),
thumbnailUrl: $manga->getImageUrls()->getThumbnail(),
thumbnailUrl: $manga->getImageUrls()?->getThumbnail(),
rating: $manga->getRating()
);
}

View File

@@ -8,6 +8,7 @@ readonly class MangaResponse
public string $id,
public string $title,
public string $slug,
public array $alternativeSlugs,
public string $description,
public string $author,
public int $publicationYear,