You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
55 lines
1.5 KiB
55 lines
1.5 KiB
import React from 'react';
|
|
import { defineMessages, useIntl } from 'react-intl';
|
|
import useSWR from 'swr';
|
|
import type { GenreSliderItem } from '../../../../server/interfaces/api/discoverInterfaces';
|
|
import Error from '../../../pages/_error';
|
|
import Header from '../../Common/Header';
|
|
import LoadingSpinner from '../../Common/LoadingSpinner';
|
|
import PageTitle from '../../Common/PageTitle';
|
|
import GenreCard from '../../GenreCard';
|
|
import { genreColorMap } from '../constants';
|
|
|
|
const messages = defineMessages({
|
|
seriesgenres: 'Series Genres',
|
|
});
|
|
|
|
const TvGenreList = () => {
|
|
const intl = useIntl();
|
|
const { data, error } = useSWR<GenreSliderItem[]>(
|
|
`/api/v1/discover/genreslider/tv`
|
|
);
|
|
|
|
if (!data && !error) {
|
|
return <LoadingSpinner />;
|
|
}
|
|
|
|
if (!data) {
|
|
return <Error statusCode={404} />;
|
|
}
|
|
|
|
return (
|
|
<>
|
|
<PageTitle title={intl.formatMessage(messages.seriesgenres)} />
|
|
<div className="mt-1 mb-5">
|
|
<Header>{intl.formatMessage(messages.seriesgenres)}</Header>
|
|
</div>
|
|
<ul className="cards-horizontal">
|
|
{data.map((genre, index) => (
|
|
<li key={`genre-${genre.id}-${index}`}>
|
|
<GenreCard
|
|
name={genre.name}
|
|
image={`https://image.tmdb.org/t/p/w1280_filter(duotone,${
|
|
genreColorMap[genre.id] ?? genreColorMap[0]
|
|
})${genre.backdrops[4]}`}
|
|
url={`/discover/tv/genre/${genre.id}`}
|
|
canExpand
|
|
/>
|
|
</li>
|
|
))}
|
|
</ul>
|
|
</>
|
|
);
|
|
};
|
|
|
|
export default TvGenreList;
|