From 07756cdeb407f59f34101cef3fb49df5da2c927a Mon Sep 17 00:00:00 2001 From: Oleksandr Zhyian Date: Fri, 12 Jul 2024 16:15:41 +0300 Subject: [PATCH] feat: include slugs in admission requirements data and allow the use of custom admission requirements --- .../AdmissionRequirementTranslated.php | 16 +++++++-- .../Filter/AdmissionRequirementTypeFilter.php | 21 +++--------- src/Domain/AdmissionRequirement.php | 34 +++++++++++++++++-- ...rdPressDatabaseDegreeProgramRepository.php | 1 + tests/resources/fixtures/degree_program.json | 18 ++++++---- .../unit/Domain/AdmissionRequirementsTest.php | 4 +++ 6 files changed, 66 insertions(+), 28 deletions(-) diff --git a/src/Application/AdmissionRequirementTranslated.php b/src/Application/AdmissionRequirementTranslated.php index b7bf64e..dee351f 100644 --- a/src/Application/AdmissionRequirementTranslated.php +++ b/src/Application/AdmissionRequirementTranslated.php @@ -11,6 +11,7 @@ * name: string, * link_text: string, * link_url: string, + * slug: string * } * @psalm-type AdmissionRequirementTranslatedType = AdmissionRequirementTranslated * & array{parent: AdmissionRequirementTranslated|null} @@ -20,15 +21,17 @@ final class AdmissionRequirementTranslated private function __construct( private Link $current, private ?AdmissionRequirementTranslated $parent, + private string $slug ) { } public static function new( Link $current, ?AdmissionRequirementTranslated $parent, + string $slug = '' ): self { - return new self($current, $parent); + return new self($current, $parent, $slug); } public static function fromAdmissionRequirement( @@ -41,6 +44,7 @@ public static function fromAdmissionRequirement( $admissionRequirement->parent() ? self::fromAdmissionRequirement($admissionRequirement->parent(), $languageCode) : null, + $admissionRequirement->slug() ); } @@ -57,10 +61,12 @@ public static function fromArray(array $data): self /** @var AdmissionRequirementTranslatedType|null $parentData */ $parentData = $data[AdmissionRequirement::PARENT]; + $slug = $data[AdmissionRequirement::SLUG] ?? ''; return new self( Link::fromArray($currentData), - $parentData ? self::fromArray($parentData) : null + $parentData ? self::fromArray($parentData) : null, + $slug ); } @@ -73,6 +79,7 @@ public function asArray(): array $parentData = $this->parent?->asArray(); $currentData = $this->current->asArray(); $currentData[AdmissionRequirement::PARENT] = $parentData; + $currentData[AdmissionRequirement::SLUG] = $this->slug; return $currentData; } @@ -82,6 +89,11 @@ public function name(): string return $this->current->name(); } + public function slug(): string + { + return $this->slug; + } + public function linkText(): string { return $this->current->linkText(); diff --git a/src/Application/Filter/AdmissionRequirementTypeFilter.php b/src/Application/Filter/AdmissionRequirementTypeFilter.php index 295282e..47036f4 100644 --- a/src/Application/Filter/AdmissionRequirementTypeFilter.php +++ b/src/Application/Filter/AdmissionRequirementTypeFilter.php @@ -4,25 +4,18 @@ namespace Fau\DegreeProgram\Common\Application\Filter; -/** - * @psalm-type AdmissionRequirementType = 'frei' | 'eingeschraenkt' | 'frei-mit-einschraenkung' - */ final class AdmissionRequirementTypeFilter implements Filter { public const FREE = 'frei'; - public const FREE_WITH_RESTRICTION = 'frei-mit-einschraenkung'; public const RESTRICTED = 'eingeschraenkt'; public const KEY = 'admission-requirement'; /** - * @var array + * @var array */ private array $types; - /** - * @psalm-param AdmissionRequirementType $types - */ private function __construct( string ...$types ) { @@ -35,9 +28,6 @@ public function id(): string return self::KEY; } - /** - * @psalm-return array - */ public function value(): array { return array_unique($this->types); @@ -56,7 +46,7 @@ public static function empty(): static } /** - * @psalm-return ?array + * @return array|null */ private static function sanitize(mixed $value): ?array { @@ -68,12 +58,9 @@ private static function sanitize(mixed $value): ?array return null; } - /** @psalm-var array $value */ - $value = array_filter( + return array_filter( $value, - static fn ($item) => in_array($item, [self::FREE, self::FREE_WITH_RESTRICTION, self::RESTRICTED], true), + 'is_string', ); - - return $value; } } diff --git a/src/Domain/AdmissionRequirement.php b/src/Domain/AdmissionRequirement.php index 23e7a8c..fe84c9e 100644 --- a/src/Domain/AdmissionRequirement.php +++ b/src/Domain/AdmissionRequirement.php @@ -12,6 +12,7 @@ * name: MultilingualStringType, * link_text: MultilingualStringType, * link_url: MultilingualStringType, + * slug: string * } * * @psalm-type AdmissionRequirementType = AdmissionRequirement & array{ @@ -22,6 +23,7 @@ final class AdmissionRequirement { public const ID = 'id'; public const NAME = 'name'; + public const SLUG = 'slug'; public const LINK_TEXT = 'link_text'; public const LINK_URL = 'link_url'; @@ -33,6 +35,7 @@ final class AdmissionRequirement 'required' => [ AdmissionRequirement::ID, AdmissionRequirement::NAME, + AdmissionRequirement::SLUG, AdmissionRequirement::LINK_TEXT, AdmissionRequirement::LINK_URL, AdmissionRequirement::PARENT, @@ -43,6 +46,10 @@ final class AdmissionRequirement 'minLength' => 1, ], AdmissionRequirement::NAME => MultilingualString::SCHEMA, + AdmissionRequirement::SLUG => [ + 'type' => 'string', + 'minLength' => 1, + ], AdmissionRequirement::LINK_TEXT => MultilingualString::SCHEMA, AdmissionRequirement::LINK_URL => MultilingualString::SCHEMA, AdmissionRequirement::PARENT => [ @@ -51,6 +58,7 @@ final class AdmissionRequirement 'required' => [ AdmissionRequirement::ID, AdmissionRequirement::NAME, + AdmissionRequirement::SLUG, ], 'properties' => [ AdmissionRequirement::ID => [ @@ -58,6 +66,10 @@ final class AdmissionRequirement 'minLength' => 1, ], AdmissionRequirement::NAME => MultilingualString::SCHEMA, + AdmissionRequirement::SLUG => [ + 'type' => 'string', + 'minLength' => 1, + ], ], ], ], @@ -69,6 +81,7 @@ final class AdmissionRequirement 'required' => [ AdmissionRequirement::ID, AdmissionRequirement::NAME, + AdmissionRequirement::SLUG, AdmissionRequirement::LINK_TEXT, AdmissionRequirement::LINK_URL, ], @@ -78,6 +91,10 @@ final class AdmissionRequirement 'maxLength' => 0, ], AdmissionRequirement::NAME => MultilingualString::SCHEMA, + AdmissionRequirement::SLUG => [ + 'type' => 'string', + 'maxLength' => 0, + ], AdmissionRequirement::LINK_TEXT => MultilingualString::SCHEMA, AdmissionRequirement::LINK_URL => MultilingualString::SCHEMA, AdmissionRequirement::PARENT => [ @@ -89,22 +106,25 @@ final class AdmissionRequirement private function __construct( private MultilingualLink $current, private ?AdmissionRequirement $parent, + private string $slug ) { } public static function new( MultilingualLink $current, ?AdmissionRequirement $parent, + string $slug = '' ): self { - return new self($current, $parent); + return new self($current, $parent, $slug); } public static function empty(): self { return new self( MultilingualLink::empty(), - null + null, + '' ); } @@ -122,10 +142,12 @@ public static function fromArray(array $data): self /** @var AdmissionRequirementType|null $parentData */ $parentData = $data[self::PARENT] ?? null; + $slug = $data[self::SLUG] ?? ''; return new self( MultilingualLink::fromArray($currentData), - $parentData ? self::fromArray($parentData) : null + $parentData ? self::fromArray($parentData) : null, + $slug ); } @@ -138,6 +160,7 @@ public function asArray(): array $parentData = $this->parent?->asArray(); $currentData = $this->current->asArray(); $currentData[self::PARENT] = $parentData; + $currentData[self::SLUG] = $this->slug; return $currentData; } @@ -152,6 +175,11 @@ public function name(): MultilingualString return $this->current->name(); } + public function slug(): string + { + return $this->slug; + } + public function linkText(): MultilingualString { return $this->current->linkText(); diff --git a/src/Infrastructure/Repository/WordPressDatabaseDegreeProgramRepository.php b/src/Infrastructure/Repository/WordPressDatabaseDegreeProgramRepository.php index bd3f746..4bd3cc8 100644 --- a/src/Infrastructure/Repository/WordPressDatabaseDegreeProgramRepository.php +++ b/src/Infrastructure/Repository/WordPressDatabaseDegreeProgramRepository.php @@ -307,6 +307,7 @@ private function admissionRequirement(?WP_Term $term): AdmissionRequirement return AdmissionRequirement::new( $this->bilingualLinkFromTerm($term), $parent instanceof WP_Term ? $this->admissionRequirement($parent) : null, + $term->slug ); } diff --git a/tests/resources/fixtures/degree_program.json b/tests/resources/fixtures/degree_program.json index a92f942..0c8ce1a 100644 --- a/tests/resources/fixtures/degree_program.json +++ b/tests/resources/fixtures/degree_program.json @@ -262,8 +262,10 @@ "de": "", "en": "" }, - "parent": null - } + "parent": null, + "slug": "frei" + }, + "slug": "admission_bachelor" }, "teaching_degree_higher_semester": { "id": "term:24", @@ -299,8 +301,10 @@ "de": "", "en": "" }, - "parent": null - } + "parent": null, + "slug": "frei" + }, + "slug": "admission_higher_semester" }, "master": { "id": "term:19", @@ -336,8 +340,10 @@ "de": "", "en": "" }, - "parent": null - } + "parent": null, + "slug": "nich_frei" + }, + "slug": "admission_master" } }, "content_related_master_requirements": { diff --git a/tests/unit/Domain/AdmissionRequirementsTest.php b/tests/unit/Domain/AdmissionRequirementsTest.php index ee25e17..38e425e 100644 --- a/tests/unit/Domain/AdmissionRequirementsTest.php +++ b/tests/unit/Domain/AdmissionRequirementsTest.php @@ -30,6 +30,7 @@ public function testFromArray(): void 'en' => 'Link URL Bachelor EN', ], 'parent' => null, + 'slug' => 'name_bachelor', ], 'teaching_degree_higher_semester' => [ 'id' => 'term:6', @@ -66,7 +67,9 @@ public function testFromArray(): void 'en' => '', ], 'parent' => null, + 'slug' => 'frei', ], + 'slug' => 'name_higher_semester', ], 'master' => [ 'id' => 'term:7', @@ -86,6 +89,7 @@ public function testFromArray(): void 'en' => 'Link URL Master EN', ], 'parent' => null, + 'slug' => 'name_master', ], ];