feat: Reader beginning
This commit is contained in:
parent
e90c0a140e
commit
55945adc53
@@ -0,0 +1,57 @@
|
||||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace App\Domain\Reader\Application\Response;
|
||||
|
||||
final readonly class ChapterContextResponse
|
||||
{
|
||||
public function __construct(
|
||||
private string $id,
|
||||
private string $title,
|
||||
private float $number,
|
||||
private int $totalPages,
|
||||
private ?string $previousChapterId,
|
||||
private ?string $nextChapterId
|
||||
)
|
||||
{
|
||||
}
|
||||
|
||||
public function getId(): string
|
||||
{
|
||||
return $this->id;
|
||||
}
|
||||
|
||||
public function getTitle(): string
|
||||
{
|
||||
return $this->title;
|
||||
}
|
||||
|
||||
public function getNumber(): float
|
||||
{
|
||||
return $this->number;
|
||||
}
|
||||
|
||||
public function getTotalPages(): int
|
||||
{
|
||||
return $this->totalPages;
|
||||
}
|
||||
|
||||
public function getPreviousChapterId(): ?string
|
||||
{
|
||||
return $this->previousChapterId;
|
||||
}
|
||||
|
||||
public function getNextChapterId(): ?string
|
||||
{
|
||||
return $this->nextChapterId;
|
||||
}
|
||||
|
||||
public function getNavigation(): array
|
||||
{
|
||||
$navigation['previousChapter'] = $this->previousChapterId;
|
||||
$navigation['nextChapter'] = $this->nextChapterId;
|
||||
|
||||
return $navigation;
|
||||
}
|
||||
}
|
||||
@@ -0,0 +1,58 @@
|
||||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace App\Domain\Reader\Application\Response;
|
||||
|
||||
use App\Domain\Reader\Domain\Model\Page;
|
||||
|
||||
final class ChapterPagesResponse
|
||||
{
|
||||
/** @var array<PageResponse> */
|
||||
private array $pages;
|
||||
private int $totalItems;
|
||||
private int $currentPage;
|
||||
private int $itemsPerPage;
|
||||
|
||||
/**
|
||||
* @param array<Page> $pages
|
||||
*/
|
||||
public function __construct(array $pages, int $totalItems, int $currentPage, int $itemsPerPage)
|
||||
{
|
||||
$this->pages = array_map(
|
||||
static fn (Page $page) => new PageResponse($page),
|
||||
$pages
|
||||
);
|
||||
$this->totalItems = $totalItems;
|
||||
$this->currentPage = $currentPage;
|
||||
$this->itemsPerPage = $itemsPerPage;
|
||||
}
|
||||
|
||||
/**
|
||||
* @return array<PageResponse>
|
||||
*/
|
||||
public function getPages(): array
|
||||
{
|
||||
return $this->pages;
|
||||
}
|
||||
|
||||
public function getTotalItems(): int
|
||||
{
|
||||
return $this->totalItems;
|
||||
}
|
||||
|
||||
public function getCurrentPage(): int
|
||||
{
|
||||
return $this->currentPage;
|
||||
}
|
||||
|
||||
public function getItemsPerPage(): int
|
||||
{
|
||||
return $this->itemsPerPage;
|
||||
}
|
||||
|
||||
public function getTotalPages(): int
|
||||
{
|
||||
return (int) ceil($this->totalItems / $this->itemsPerPage);
|
||||
}
|
||||
}
|
||||
43
src/Domain/Reader/Application/Response/PageResponse.php
Normal file
43
src/Domain/Reader/Application/Response/PageResponse.php
Normal file
@@ -0,0 +1,43 @@
|
||||
<?php
|
||||
|
||||
declare(strict_types=1);
|
||||
|
||||
namespace App\Domain\Reader\Application\Response;
|
||||
|
||||
use App\Domain\Reader\Domain\Model\Page;
|
||||
|
||||
final class PageResponse
|
||||
{
|
||||
private string $id;
|
||||
private int $pageNumber;
|
||||
private string $url;
|
||||
private array $dimensions;
|
||||
|
||||
public function __construct(Page $page)
|
||||
{
|
||||
$this->id = $page->getId();
|
||||
$this->pageNumber = $page->getPageNumber()->getValue();
|
||||
$this->url = $page->getUrl();
|
||||
$this->dimensions = $page->getDimensions();
|
||||
}
|
||||
|
||||
public function getId(): string
|
||||
{
|
||||
return $this->id;
|
||||
}
|
||||
|
||||
public function getPageNumber(): int
|
||||
{
|
||||
return $this->pageNumber;
|
||||
}
|
||||
|
||||
public function getUrl(): string
|
||||
{
|
||||
return $this->url;
|
||||
}
|
||||
|
||||
public function getDimensions(): array
|
||||
{
|
||||
return $this->dimensions;
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user