Get character details page from GraphQL, still need to do castings section, see #27
Some checks failed
timw4mail/HummingBirdAnimeClient/pipeline/head There was a failure building this commit

This commit is contained in:
Timothy Warren 2020-08-17 14:01:55 -04:00
parent 4d4b7126e2
commit 1725a106fa
4 changed files with 128 additions and 20 deletions

View File

@ -42,15 +42,15 @@ use Aviat\AnimeClient\API\Kitsu;
<?php foreach ($data['media']['anime'] as $id => $anime): ?>
<article class="media">
<?php
$link = $url->generate('anime.details', ['id' => $anime['attributes']['slug']]);
$titles = Kitsu::filterTitles($anime['attributes']);
$link = $url->generate('anime.details', ['id' => $anime['slug']]);
$titles = Kitsu::getTitles($anime['titles']);
?>
<a href="<?= $link ?>">
<?= $helper->picture("images/anime/{$id}.webp") ?>
<?= $helper->picture("images/anime/{$anime['id']}.webp") ?>
</a>
<div class="name">
<a href="<?= $link ?>">
<?= array_shift($titles) ?>
<?= $anime['titles']['canonical'] ?>
<?php foreach ($titles as $title): ?>
<br />
<small><?= $title ?></small>
@ -70,15 +70,15 @@ use Aviat\AnimeClient\API\Kitsu;
<?php foreach ($data['media']['manga'] as $id => $manga): ?>
<article class="media">
<?php
$link = $url->generate('manga.details', ['id' => $manga['attributes']['slug']]);
$titles = Kitsu::filterTitles($manga['attributes']);
$link = $url->generate('manga.details', ['id' => $manga['slug']]);
$titles = Kitsu::getTitles($manga['titles']);
?>
<a href="<?= $link ?>">
<?= $helper->picture("images/manga/{$id}.webp") ?>
<?= $helper->picture("images/manga/{$manga['id']}.webp") ?>
</a>
<div class="name">
<a href="<?= $link ?>">
<?= array_shift($titles) ?>
<?= $manga['titles']['canonical'] ?>
<?php foreach ($titles as $title): ?>
<br />
<small><?= $title ?></small>

View File

@ -190,17 +190,8 @@ final class Model {
*/
public function getCharacter(string $slug): array
{
return $this->requestBuilder->getRequest('characters', [
'query' => [
'filter' => [
'slug' => $slug,
],
'fields' => [ // For some characters, these filters cause issues...so leave them out
// 'anime' => 'canonicalTitle,abbreviatedTitles,titles,slug,posterImage',
// 'manga' => 'canonicalTitle,abbreviatedTitles,titles,slug,posterImage'
],
'include' => 'castings.person,castings.media'
]
return $this->requestBuilder->runQuery('CharacterDetails', [
'slug' => $slug
]);
}

View File

@ -6,10 +6,11 @@ query ($slug: String!) {
url
}
}
description
names {
alternatives
canonical
#canonicalLocale
canonicalLocale
localized
},
primaryMedia {
@ -23,6 +24,63 @@ query ($slug: String!) {
}
type
},
media {
nodes {
media {
id
slug
titles {
alternatives
canonical
canonicalLocale
localized
}
posterImage {
original {
height
name
url
width
}
views {
height
name
url
width
}
}
type
}
voices {
nodes {
id
licensor {
name
}
locale
person {
id
slug
name
names {
alternatives
canonical
canonicalLocale
localized
}
image {
original {
height
width
url
name
}
}
}
}
}
}
}
slug
}
}

View File

@ -31,6 +31,65 @@ final class CharacterTransformer extends AbstractTransformer {
* @return Character
*/
public function transform($characterData): Character
{
$data = $characterData['data']['findCharacterBySlug'] ?? [];
$castings = [];
$media = [
'anime' => [],
'manga' => [],
];
$names = array_unique(
array_merge(
[$data['names']['canonical']],
array_values($data['names']['localized'])
)
);
$name = array_shift($names);
if (isset($data['media']['nodes']))
{
[$media, $castings] = $this->organizeMediaAndVoices($data['media']['nodes']);
}
return Character::from([
'castings' => $castings,
'description' => $data['description']['en'],
'id' => $data['id'],
'media' => $media,
'name' => $name,
'names' => $names,
'otherNames' => $data['names']['alternatives'],
]);
}
protected function organizeMediaAndVoices (array $data): array
{
if (empty($data))
{
return [[], []];
}
$rawMedia = array_column($data, 'media');
$rawAnime = array_filter($rawMedia, fn ($item) => $item['type'] === 'Anime');
$rawManga = array_filter($rawMedia, fn ($item) => $item['type'] === 'Manga');
uasort($rawAnime, fn ($a, $b) => $a['titles']['canonical'] <=> $b['titles']['canonical']);
uasort($rawManga, fn ($a, $b) => $a['titles']['canonical'] <=> $b['titles']['canonical']);
$media = [
'anime' => $rawAnime,
'manga' => $rawManga,
];
return [$media, []];
}
/**
* @param array $characterData
* @return Character
*/
public function oldTransform($characterData): Character
{
$data = JsonAPI::organizeData($characterData);
$attributes = $data[0]['attributes'];