2017-01-05 13:41:32 -05:00
|
|
|
<?php declare(strict_types=1);
|
|
|
|
/**
|
2017-02-15 16:13:32 -05:00
|
|
|
* Hummingbird Anime List Client
|
2017-01-05 13:41:32 -05:00
|
|
|
*
|
2018-08-22 13:48:27 -04:00
|
|
|
* An API client for Kitsu to manage anime and manga watch lists
|
2017-01-05 13:41:32 -05:00
|
|
|
*
|
2019-12-03 15:17:25 -05:00
|
|
|
* PHP version 7.2
|
2017-01-05 13:41:32 -05:00
|
|
|
*
|
2017-02-15 16:13:32 -05:00
|
|
|
* @package HummingbirdAnimeClient
|
2017-01-06 23:34:56 -05:00
|
|
|
* @author Timothy J. Warren <tim@timshomepage.net>
|
2019-12-06 09:16:35 -05:00
|
|
|
* @copyright 2015 - 2019 Timothy J. Warren
|
2017-01-06 23:34:56 -05:00
|
|
|
* @license http://www.opensource.org/licenses/mit-license.html MIT License
|
2019-12-06 09:16:35 -05:00
|
|
|
* @version 4.2
|
2017-03-07 20:53:58 -05:00
|
|
|
* @link https://git.timshomepage.net/timw4mail/HummingBirdAnimeClient
|
2017-01-11 10:34:24 -05:00
|
|
|
*/
|
|
|
|
|
|
|
|
namespace Aviat\AnimeClient\API\Kitsu\Transformer;
|
2017-01-05 13:41:32 -05:00
|
|
|
|
2017-01-12 15:41:20 -05:00
|
|
|
use Aviat\AnimeClient\API\{JsonAPI, Kitsu};
|
2018-11-08 11:36:42 -05:00
|
|
|
use Aviat\AnimeClient\Types\AnimePage;
|
2017-01-05 13:41:32 -05:00
|
|
|
use Aviat\Ion\Transformer\AbstractTransformer;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Transformer for anime description page
|
|
|
|
*/
|
2018-08-08 10:12:45 -04:00
|
|
|
final class AnimeTransformer extends AbstractTransformer {
|
2017-01-05 13:41:32 -05:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Convert raw api response to a more
|
|
|
|
* logical and workable structure
|
|
|
|
*
|
|
|
|
* @param array $item API library item
|
2018-11-08 11:36:42 -05:00
|
|
|
* @return AnimePage
|
2017-01-05 13:41:32 -05:00
|
|
|
*/
|
2018-11-08 11:36:42 -05:00
|
|
|
public function transform($item): AnimePage
|
2017-01-05 13:41:32 -05:00
|
|
|
{
|
2017-01-12 15:41:20 -05:00
|
|
|
$item['included'] = JsonAPI::organizeIncludes($item['included']);
|
2017-09-12 12:18:31 -04:00
|
|
|
$genres = $item['included']['categories'] ?? [];
|
|
|
|
$item['genres'] = array_column($genres, 'title') ?? [];
|
2017-01-05 13:41:32 -05:00
|
|
|
sort($item['genres']);
|
2017-04-13 11:15:16 -04:00
|
|
|
|
2018-08-10 20:10:19 -04:00
|
|
|
$title = $item['canonicalTitle'];
|
2018-11-01 22:15:20 -04:00
|
|
|
$titles = Kitsu::filterTitles($item);
|
2017-01-05 13:41:32 -05:00
|
|
|
|
2018-11-08 11:36:42 -05:00
|
|
|
$characters = [];
|
|
|
|
$staff = [];
|
|
|
|
|
|
|
|
if (array_key_exists('animeCharacters', $item['included']))
|
|
|
|
{
|
|
|
|
$animeCharacters = $item['included']['animeCharacters'];
|
|
|
|
|
|
|
|
foreach ($animeCharacters as $rel)
|
|
|
|
{
|
|
|
|
$charId = $rel['relationships']['character']['data']['id'];
|
|
|
|
$role = $rel['role'];
|
|
|
|
|
|
|
|
if (array_key_exists($charId, $item['included']['characters']))
|
|
|
|
{
|
|
|
|
$characters[$role][$charId] = $item['included']['characters'][$charId];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (array_key_exists('mediaStaff', $item['included']))
|
|
|
|
{
|
|
|
|
foreach ($item['included']['mediaStaff'] as $id => $staffing)
|
|
|
|
{
|
|
|
|
$personId = $staffing['relationships']['person']['data']['id'];
|
|
|
|
$personDetails = $item['included']['people'][$personId];
|
|
|
|
|
|
|
|
$role = $staffing['role'];
|
|
|
|
|
|
|
|
if ( ! array_key_exists($role, $staff))
|
|
|
|
{
|
|
|
|
$staff[$role] = [];
|
|
|
|
}
|
|
|
|
|
|
|
|
$staff[$role][$personId] = [
|
|
|
|
'id' => $personId,
|
|
|
|
'name' => $personDetails['name'] ?? '??',
|
|
|
|
'image' => $personDetails['image'],
|
|
|
|
];
|
|
|
|
|
|
|
|
usort($staff[$role], function ($a, $b) {
|
|
|
|
return $a['name'] <=> $b['name'];
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( ! empty($characters['main']))
|
|
|
|
{
|
2019-12-09 13:13:31 -05:00
|
|
|
uasort($characters['main'], static function ($a, $b) {
|
2018-11-08 11:36:42 -05:00
|
|
|
return $a['name'] <=> $b['name'];
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
if ( ! empty($characters['supporting']))
|
|
|
|
{
|
2019-12-09 13:13:31 -05:00
|
|
|
uasort($characters['supporting'], static function ($a, $b) {
|
2018-11-08 11:36:42 -05:00
|
|
|
return $a['name'] <=> $b['name'];
|
|
|
|
});
|
|
|
|
}
|
|
|
|
|
|
|
|
ksort($characters);
|
|
|
|
ksort($staff);
|
|
|
|
|
|
|
|
return new AnimePage([
|
2018-01-31 10:55:20 -05:00
|
|
|
'age_rating' => $item['ageRating'],
|
|
|
|
'age_rating_guide' => $item['ageRatingGuide'],
|
2018-11-08 11:36:42 -05:00
|
|
|
'characters' => $characters,
|
2017-01-05 13:41:32 -05:00
|
|
|
'cover_image' => $item['posterImage']['small'],
|
|
|
|
'episode_count' => $item['episodeCount'],
|
|
|
|
'episode_length' => $item['episodeLength'],
|
2018-01-31 10:55:20 -05:00
|
|
|
'genres' => $item['genres'],
|
|
|
|
'id' => $item['id'],
|
2018-10-29 09:39:56 -04:00
|
|
|
'included' => $item['included'],
|
2019-12-09 13:13:31 -05:00
|
|
|
'show_type' => (string)$this->string($item['showType'])->upperCaseFirst(),
|
2018-01-31 10:55:20 -05:00
|
|
|
'slug' => $item['slug'],
|
2018-11-08 11:36:42 -05:00
|
|
|
'staff' => $staff,
|
2018-01-31 10:55:20 -05:00
|
|
|
'status' => Kitsu::getAiringStatus($item['startDate'], $item['endDate']),
|
|
|
|
'streaming_links' => Kitsu::parseStreamingLinks($item['included']),
|
2017-01-05 13:41:32 -05:00
|
|
|
'synopsis' => $item['synopsis'],
|
2018-08-08 10:12:45 -04:00
|
|
|
'title' => $title,
|
2018-01-31 10:55:20 -05:00
|
|
|
'titles' => $titles,
|
|
|
|
'trailer_id' => $item['youtubeVideoId'],
|
2017-01-05 13:41:32 -05:00
|
|
|
'url' => "https://kitsu.io/anime/{$item['slug']}",
|
2018-08-08 10:12:45 -04:00
|
|
|
]);
|
2017-01-05 13:41:32 -05:00
|
|
|
}
|
2016-12-22 21:36:23 -05:00
|
|
|
}
|