Squashed commit of the following:
commit5d38a76997Merge:7cccdb9f160e23Author: Blake <blakejoy@users.noreply.github.com> Date: Sat Apr 15 11:44:39 2023 -0400 Merge pull request #22 from blakejoy/feat/add_linting feat - add linting and prettier commitf160e2362cAuthor: Blake Joynes <blakejoynes@gmail.com> Date: Sat Apr 15 11:44:00 2023 -0400 add pre commit hook commit0fd8317884Merge:bc91674d1e87baAuthor: Blake Joynes <blakejoynes@gmail.com> Date: Sat Apr 15 11:41:28 2023 -0400 add husky commitbc91674c4bAuthor: Blake Joynes <blakejoynes@gmail.com> Date: Sat Apr 15 11:39:24 2023 -0400 add husky commitd1e87ba7beAuthor: Blake <blakejoy@users.noreply.github.com> Date: Fri Apr 14 08:48:33 2023 -0400 Update .prettierrc commitd064d4d86fAuthor: Blake Joynes <blakejoynes@gmail.com> Date: Fri Apr 14 03:09:39 2023 -0400 turn off linebreak rules commit06155bd323Author: Blake Joynes <blakejoynes@gmail.com> Date: Thu Apr 13 21:58:41 2023 -0400 add linting and prettier
This commit is contained in:
41
.eslintrc.js
41
.eslintrc.js
@@ -2,42 +2,21 @@ module.exports = {
|
||||
env: {
|
||||
browser: false,
|
||||
es2021: true,
|
||||
node: true,
|
||||
},
|
||||
extends: [
|
||||
'plugin:@typescript-eslint/recommended',
|
||||
"eslint:recommended",
|
||||
"plugin:@typescript-eslint/eslint-recommended",
|
||||
"plugin:@typescript-eslint/recommended",
|
||||
"prettier",
|
||||
],
|
||||
parser: '@typescript-eslint/parser',
|
||||
parser: "@typescript-eslint/parser",
|
||||
parserOptions: {
|
||||
ecmaVersion: 12,
|
||||
sourceType: 'module',
|
||||
sourceType: "module",
|
||||
},
|
||||
plugins: [
|
||||
'@typescript-eslint',
|
||||
],
|
||||
rules: {
|
||||
'@typescript-eslint/no-var-requires': 'off',
|
||||
'@typescript-eslint/no-explicit-any': 'off',
|
||||
'@typescript-eslint/interface-name-prefix': 'off',
|
||||
'@typescript-eslint/no-non-null-assertion': 'off',
|
||||
'@typescript-eslint/no-use-before-define': 'off',
|
||||
'@typescript-eslint/no-empty-interface': 'off',
|
||||
'@typescript-eslint/explicit-function-return-type': ['warn', { allowExpressions: true }],
|
||||
indent: 'off',
|
||||
'@typescript-eslint/indent': ['error', 2],
|
||||
'no-trailing-spaces': 'error',
|
||||
quotes: ['error', 'single', { allowTemplateLiterals: true }],
|
||||
semi: ['error', 'always'],
|
||||
'spaced-comment': ['error', 'always'],
|
||||
'no-irregular-whitespace': ['error', { 'skipComments': true }],
|
||||
'space-infix-ops': 'error',
|
||||
'array-bracket-spacing': 'error',
|
||||
'object-curly-spacing': ['error', 'always'],
|
||||
'space-before-function-paren': ['error', {
|
||||
named: 'never',
|
||||
anonymous: 'never',
|
||||
asyncArrow: 'always',
|
||||
}],
|
||||
'comma-dangle': ['warn', 'always-multiline'],
|
||||
'no-multiple-empty-lines': 'error',
|
||||
rules:{
|
||||
'linebreak-style': ['off', 'unix'],
|
||||
},
|
||||
plugins: ["@typescript-eslint"],
|
||||
};
|
||||
|
||||
4
.husky/pre-commit
Executable file
4
.husky/pre-commit
Executable file
@@ -0,0 +1,4 @@
|
||||
#!/usr/bin/env sh
|
||||
. "$(dirname -- "$0")/_/husky.sh"
|
||||
|
||||
npm run lint
|
||||
3
.prettierignore
Normal file
3
.prettierignore
Normal file
@@ -0,0 +1,3 @@
|
||||
dist
|
||||
node_modules
|
||||
.github
|
||||
12
.prettierrc
Normal file
12
.prettierrc
Normal file
@@ -0,0 +1,12 @@
|
||||
{
|
||||
"printWidth": 80,
|
||||
"tabWidth": 2,
|
||||
"useTabs": false,
|
||||
"semi": true,
|
||||
"singleQuote": true,
|
||||
"trailingComma": "es5",
|
||||
"bracketSpacing": true,
|
||||
"arrowParens": "always",
|
||||
"proseWrap": "never",
|
||||
"htmlWhitespaceSensitivity": "strict"
|
||||
}
|
||||
3928
package-lock.json
generated
3928
package-lock.json
generated
File diff suppressed because it is too large
Load Diff
23
package.json
23
package.json
@@ -8,7 +8,8 @@
|
||||
"compile": "rm -rf dist && tsc -d && npm run copy-types",
|
||||
"lint": "eslint --ext .ts src/",
|
||||
"lint:fix": "eslint --ext .ts src/ --fix",
|
||||
"prepublish": "tsc",
|
||||
"format": "npx prettier --write src",
|
||||
"pre-commit": "npm run lint",
|
||||
"copy-types": "mkdir dist/types && cp src/types/*.d.ts dist/types"
|
||||
},
|
||||
"bugs": {
|
||||
@@ -31,14 +32,17 @@
|
||||
"devDependencies": {
|
||||
"@types/node": "^15.3.0",
|
||||
"@types/node-fetch": "^2.5.10",
|
||||
"@typescript-eslint/eslint-plugin": "^4.23.0",
|
||||
"@typescript-eslint/parser": "^4.23.0",
|
||||
"@typescript-eslint/eslint-plugin": "^5.58.0",
|
||||
"@typescript-eslint/parser": "^5.58.0",
|
||||
"dotenv": "^9.0.2",
|
||||
"eslint": "^7.26.0",
|
||||
"eslint-config-airbnb-base": "^14.2.1",
|
||||
"eslint-plugin-import": "^2.23.1",
|
||||
"eslint": "^8.38.0",
|
||||
"eslint-config-airbnb-typescript": "^17.0.0",
|
||||
"eslint-config-prettier": "^8.8.0",
|
||||
"eslint-plugin-prettier": "^4.2.1",
|
||||
"husky": "^8.0.3",
|
||||
"prettier": "^2.8.7",
|
||||
"ts-node": "^9.1.1",
|
||||
"typescript": "^4.2.4"
|
||||
"typescript": "^4.9.5"
|
||||
},
|
||||
"dependencies": {
|
||||
"cross-fetch": "^3.1.4"
|
||||
@@ -48,6 +52,11 @@
|
||||
"yarn": "1.19.2",
|
||||
"npm": "7.12.1"
|
||||
},
|
||||
"husky": {
|
||||
"hooks": {
|
||||
"pre-commit": "npm run pre-commit"
|
||||
}
|
||||
},
|
||||
"files": [
|
||||
"dist"
|
||||
]
|
||||
|
||||
@@ -17,6 +17,6 @@ export default class Api {
|
||||
'Content-Type': 'application/json;charset=utf-8',
|
||||
},
|
||||
});
|
||||
return await response.json() as T;
|
||||
return (await response.json()) as T;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
import { BaseEndpoint } from './base';
|
||||
import { BaseEndpoint } from './base';
|
||||
import { Certifications } from '../types/certification';
|
||||
|
||||
export class CertificationEndpoint extends BaseEndpoint {
|
||||
|
||||
@@ -1,7 +1,6 @@
|
||||
import { BaseEndpoint } from './base';
|
||||
import { ChangeOptions, Changes } from '../types/changes';
|
||||
|
||||
|
||||
export class ChangeEndpoint extends BaseEndpoint {
|
||||
constructor(protected readonly accessToken: string) {
|
||||
super(accessToken);
|
||||
|
||||
@@ -1,5 +1,10 @@
|
||||
import { DetailedCollection, ImageCollection, LanguageOption, Translations } from '../types';
|
||||
import { BaseEndpoint } from './base';
|
||||
import {
|
||||
DetailedCollection,
|
||||
ImageCollection,
|
||||
LanguageOption,
|
||||
Translations,
|
||||
} from '../types';
|
||||
import { BaseEndpoint } from './base';
|
||||
|
||||
const BASE_COLLECTION = '/collection';
|
||||
|
||||
@@ -19,4 +24,4 @@ export class CollectionsEndpoint extends BaseEndpoint {
|
||||
async translations(id: number, options? : LanguageOption): Promise<Translations> {
|
||||
return await this.api.get<Translations>(`${BASE_COLLECTION}/${id}/translations`, options);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -9,5 +9,4 @@ export class ConfigurationEndpoint extends BaseEndpoint {
|
||||
async getCurrent(): Promise<Configuration> {
|
||||
return await this.api.get<Configuration>(`/configuration`);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -1,7 +1,6 @@
|
||||
import { BaseEndpoint } from './base';
|
||||
import { CreditResponse } from '../types/credits';
|
||||
|
||||
|
||||
export class CreditsEndpoint extends BaseEndpoint {
|
||||
constructor(protected readonly accessToken: string) {
|
||||
super(accessToken);
|
||||
@@ -10,5 +9,4 @@ export class CreditsEndpoint extends BaseEndpoint {
|
||||
async getById(id: string): Promise<CreditResponse> {
|
||||
return await this.api.get<CreditResponse>(`/credit/${id}`);
|
||||
}
|
||||
|
||||
}
|
||||
|
||||
@@ -25,7 +25,7 @@ interface DiscoverQueryOptions {
|
||||
with_companies?: string;
|
||||
}
|
||||
|
||||
interface MovieQueryOptions extends DiscoverQueryOptions{
|
||||
interface MovieQueryOptions extends DiscoverQueryOptions {
|
||||
region?: string;
|
||||
certification_country?: string;
|
||||
certification?: string;
|
||||
@@ -45,7 +45,7 @@ interface MovieQueryOptions extends DiscoverQueryOptions{
|
||||
with_people?: string;
|
||||
}
|
||||
|
||||
interface TvShowQueryOptions extends DiscoverQueryOptions{
|
||||
interface TvShowQueryOptions extends DiscoverQueryOptions {
|
||||
'air_date.gte'?: string;
|
||||
'air_date.lte'?: string;
|
||||
'first_air_date.gte'?: string;
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
import { BaseEndpoint } from './base';
|
||||
import { BaseEndpoint } from './base';
|
||||
|
||||
export interface Genres {
|
||||
genres: Array<{id: number, name: string}>
|
||||
genres: Array<{ id: number; name: string }>;
|
||||
}
|
||||
|
||||
export class GenreEndpoint extends BaseEndpoint {
|
||||
|
||||
@@ -1,5 +1,3 @@
|
||||
|
||||
|
||||
export * from './account';
|
||||
export * from './certification';
|
||||
export * from './changes';
|
||||
@@ -16,4 +14,3 @@ export * from './trending';
|
||||
export * from './find';
|
||||
export * from './keywords';
|
||||
export * from './collections';
|
||||
|
||||
|
||||
@@ -8,7 +8,7 @@ export class KeywordsEndpoint extends BaseEndpoint {
|
||||
super(accessToken);
|
||||
}
|
||||
|
||||
async details(keywordId : number): Promise<Keyword> {
|
||||
async details(keywordId: number): Promise<Keyword> {
|
||||
return await this.api.get<Keyword>(`${BASE_Keyword}/${keywordId}`);
|
||||
}
|
||||
|
||||
|
||||
@@ -19,7 +19,8 @@ import {
|
||||
ReleaseDates,
|
||||
Reviews,
|
||||
SimilarMovies,
|
||||
TopRatedMovies, Translations,
|
||||
TopRatedMovies,
|
||||
Translations,
|
||||
UpcomingMovies,
|
||||
Videos,
|
||||
WatchProviders,
|
||||
@@ -27,36 +28,38 @@ import {
|
||||
|
||||
const BASE_MOVIE = '/movie';
|
||||
|
||||
export class MoviesEndpoint extends BaseEndpoint{
|
||||
export class MoviesEndpoint extends BaseEndpoint {
|
||||
constructor(protected readonly accessToken: string) {
|
||||
super(accessToken);
|
||||
}
|
||||
|
||||
async details(id: number): Promise<MovieDetails>{
|
||||
async details(id: number): Promise<MovieDetails> {
|
||||
return await this.api.get<MovieDetails>(`${BASE_MOVIE}/${id}`);
|
||||
}
|
||||
|
||||
async alternativeTitles(id: number): Promise<AlternativeTitles>{
|
||||
return await this.api.get<AlternativeTitles>(`${BASE_MOVIE}/${id}/alternative_titles`);
|
||||
async alternativeTitles(id: number): Promise<AlternativeTitles> {
|
||||
return await this.api.get<AlternativeTitles>(
|
||||
`${BASE_MOVIE}/${id}/alternative_titles`
|
||||
);
|
||||
}
|
||||
|
||||
async changes(id: number, options?: ChangeOptions): Promise<MovieChanges>{
|
||||
return await this.api.get<MovieChanges>(`${BASE_MOVIE}/${id}/changes`, options);
|
||||
}
|
||||
|
||||
async credits(id: number): Promise<Credits>{
|
||||
async credits(id: number): Promise<Credits> {
|
||||
return await this.api.get<Credits>(`${BASE_MOVIE}/${id}/credits`);
|
||||
}
|
||||
|
||||
async externalIds(id: number): Promise<ExternalIds>{
|
||||
async externalIds(id: number): Promise<ExternalIds> {
|
||||
return await this.api.get<ExternalIds>(`${BASE_MOVIE}/${id}/external_ids`);
|
||||
}
|
||||
|
||||
async images(id: number): Promise<Images>{
|
||||
async images(id: number): Promise<Images> {
|
||||
return await this.api.get<Images>(`${BASE_MOVIE}/${id}/images`);
|
||||
}
|
||||
|
||||
async keywords(id: number): Promise<Keywords>{
|
||||
async keywords(id: number): Promise<Keywords> {
|
||||
return await this.api.get<Keywords>(`${BASE_MOVIE}/${id}/keywords`);
|
||||
}
|
||||
|
||||
@@ -68,8 +71,10 @@ export class MoviesEndpoint extends BaseEndpoint{
|
||||
return await this.api.get<Recommendations>(`${BASE_MOVIE}/${id}/recommendations`, options);
|
||||
}
|
||||
|
||||
async releaseDates(id: number): Promise<ReleaseDates>{
|
||||
return await this.api.get<ReleaseDates>(`${BASE_MOVIE}/${id}/release_dates`);
|
||||
async releaseDates(id: number): Promise<ReleaseDates> {
|
||||
return await this.api.get<ReleaseDates>(
|
||||
`${BASE_MOVIE}/${id}/release_dates`
|
||||
);
|
||||
}
|
||||
|
||||
async reviews(id: number, options?: PageOption): Promise<Reviews>{
|
||||
@@ -80,11 +85,11 @@ export class MoviesEndpoint extends BaseEndpoint{
|
||||
return await this.api.get<SimilarMovies>(`${BASE_MOVIE}/${id}/similar`, options);
|
||||
}
|
||||
|
||||
async translations(id: number): Promise<Translations>{
|
||||
async translations(id: number): Promise<Translations> {
|
||||
return await this.api.get<Translations>(`${BASE_MOVIE}/${id}/translations`);
|
||||
}
|
||||
|
||||
async videos(id: number): Promise<Videos>{
|
||||
async videos(id: number): Promise<Videos> {
|
||||
return await this.api.get<Videos>(`${BASE_MOVIE}/${id}/videos`);
|
||||
}
|
||||
|
||||
@@ -92,11 +97,13 @@ export class MoviesEndpoint extends BaseEndpoint{
|
||||
* Powered by JustWatch
|
||||
* @param id
|
||||
*/
|
||||
async watchProviders(id: number): Promise<WatchProviders>{
|
||||
return await this.api.get<WatchProviders>(`${BASE_MOVIE}/${id}/watch/providers`);
|
||||
async watchProviders(id: number): Promise<WatchProviders> {
|
||||
return await this.api.get<WatchProviders>(
|
||||
`${BASE_MOVIE}/${id}/watch/providers`
|
||||
);
|
||||
}
|
||||
|
||||
async latest(): Promise<LatestMovie>{
|
||||
async latest(): Promise<LatestMovie> {
|
||||
return await this.api.get<LatestMovie>(`${BASE_MOVIE}/latest`);
|
||||
}
|
||||
|
||||
@@ -116,5 +123,3 @@ export class MoviesEndpoint extends BaseEndpoint{
|
||||
return await this.api.get<UpcomingMovies>(`${BASE_MOVIE}/upcoming`, options);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
@@ -30,34 +30,44 @@ export class PeopleEndpoint extends BaseEndpoint {
|
||||
}
|
||||
|
||||
async movieCredits(id: number): Promise<PersonMovieCredit> {
|
||||
return await this.api.get<PersonMovieCredit>(`${BASE_PERSON}/${id}/movie_credits`);
|
||||
return await this.api.get<PersonMovieCredit>(
|
||||
`${BASE_PERSON}/${id}/movie_credits`
|
||||
);
|
||||
}
|
||||
|
||||
async tvShowCredits(id: number): Promise<PersonTvShowCredit> {
|
||||
return await this.api.get<PersonTvShowCredit>(`${BASE_PERSON}/${id}/tv_credits`);
|
||||
return await this.api.get<PersonTvShowCredit>(
|
||||
`${BASE_PERSON}/${id}/tv_credits`
|
||||
);
|
||||
}
|
||||
|
||||
async combinedCredits(id: number) : Promise<PersonCombinedCredits> {
|
||||
return await this.api.get<PersonCombinedCredits>(`${BASE_PERSON}/${id}/combined_credits`);
|
||||
async combinedCredits(id: number): Promise<PersonCombinedCredits> {
|
||||
return await this.api.get<PersonCombinedCredits>(
|
||||
`${BASE_PERSON}/${id}/combined_credits`
|
||||
);
|
||||
}
|
||||
|
||||
async externalId(id: number): Promise<ExternalIds>{
|
||||
async externalId(id: number): Promise<ExternalIds> {
|
||||
return await this.api.get<ExternalIds>(`${BASE_PERSON}/${id}/external_ids`);
|
||||
}
|
||||
|
||||
async images(id: number): Promise<{id: number, profiles: Image[]}>{
|
||||
return await this.api.get<{id: number, profiles: Image[]}>(`${BASE_PERSON}/${id}/images`);
|
||||
async images(id: number): Promise<{ id: number; profiles: Image[] }> {
|
||||
return await this.api.get<{ id: number; profiles: Image[] }>(
|
||||
`${BASE_PERSON}/${id}/images`
|
||||
);
|
||||
}
|
||||
|
||||
async taggedImages(id: number, options?: PageOption): Promise<TaggedImages>{
|
||||
return await this.api.get<TaggedImages>(`${BASE_PERSON}/${id}/tagged_images`, options);
|
||||
}
|
||||
|
||||
async translation(id: number) : Promise<PeopleTranslations>{
|
||||
return await this.api.get<PeopleTranslations>(`${BASE_PERSON}/${id}/translations`);
|
||||
async translation(id: number): Promise<PeopleTranslations> {
|
||||
return await this.api.get<PeopleTranslations>(
|
||||
`${BASE_PERSON}/${id}/translations`
|
||||
);
|
||||
}
|
||||
|
||||
async latest(): Promise<PersonDetail>{
|
||||
async latest(): Promise<PersonDetail> {
|
||||
return await this.api.get<PersonDetail>(`${BASE_PERSON}/latest`);
|
||||
}
|
||||
|
||||
|
||||
@@ -15,12 +15,12 @@ export interface MovieSearchOptions extends SearchOptions {
|
||||
primary_release_year?: number;
|
||||
}
|
||||
|
||||
export interface TvSearchOptions extends SearchOptions{
|
||||
export interface TvSearchOptions extends SearchOptions {
|
||||
include_adult?: boolean;
|
||||
first_air_date_year?: number;
|
||||
}
|
||||
|
||||
export interface PeopleSearchOptions extends SearchOptions{
|
||||
export interface PeopleSearchOptions extends SearchOptions {
|
||||
include_adult?: boolean;
|
||||
}
|
||||
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
import { MediaType, TimeWindow, TrendingResults } from '../types';
|
||||
import { MediaType, TimeWindow, TrendingResults } from '../types';
|
||||
import { BaseEndpoint } from './base';
|
||||
|
||||
export class TrendingEndpoint extends BaseEndpoint {
|
||||
@@ -6,9 +6,12 @@ export class TrendingEndpoint extends BaseEndpoint {
|
||||
super(accessToken);
|
||||
}
|
||||
|
||||
async trending<T extends MediaType>(mediaType : T, timeWindow: TimeWindow): Promise<TrendingResults<T>> {
|
||||
return await this.api.get<TrendingResults<T>>(`/trending/${mediaType}/${timeWindow}`);
|
||||
async trending<T extends MediaType>(
|
||||
mediaType: T,
|
||||
timeWindow: TimeWindow
|
||||
): Promise<TrendingResults<T>> {
|
||||
return await this.api.get<TrendingResults<T>>(
|
||||
`/trending/${mediaType}/${timeWindow}`
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
|
||||
@@ -30,48 +30,54 @@ import {
|
||||
|
||||
const BASE_TV = '/tv';
|
||||
|
||||
export class TvShowsEndpoint extends BaseEndpoint{
|
||||
export class TvShowsEndpoint extends BaseEndpoint {
|
||||
constructor(protected readonly accessToken: string) {
|
||||
super(accessToken);
|
||||
}
|
||||
|
||||
async details(id: number): Promise<TvShowDetails>{
|
||||
async details(id: number): Promise<TvShowDetails> {
|
||||
return await this.api.get<TvShowDetails>(`${BASE_TV}/${id}`);
|
||||
}
|
||||
|
||||
async alternativeTitles(id: number): Promise<AlternativeTitles>{
|
||||
return await this.api.get<AlternativeTitles>(`${BASE_TV}/${id}/alternative_titles`);
|
||||
async alternativeTitles(id: number): Promise<AlternativeTitles> {
|
||||
return await this.api.get<AlternativeTitles>(
|
||||
`${BASE_TV}/${id}/alternative_titles`
|
||||
);
|
||||
}
|
||||
|
||||
async changes(id: number, options?: ChangeOptions): Promise<TvShowChanges>{
|
||||
return await this.api.get<TvShowChanges>(`${BASE_TV}/${id}/changes`, options);
|
||||
}
|
||||
|
||||
async contentRatings(id: number): Promise<ContentRatings>{
|
||||
return await this.api.get<ContentRatings>(`${BASE_TV}/${id}/content_ratings`);
|
||||
async contentRatings(id: number): Promise<ContentRatings> {
|
||||
return await this.api.get<ContentRatings>(
|
||||
`${BASE_TV}/${id}/content_ratings`
|
||||
);
|
||||
}
|
||||
|
||||
async credits(id: number): Promise<Credits>{
|
||||
async credits(id: number): Promise<Credits> {
|
||||
return await this.api.get<Credits>(`${BASE_TV}/${id}/credits`);
|
||||
}
|
||||
|
||||
async season(tvId: number, seasonNumber: number): Promise<SeasonDetails>{
|
||||
return await this.api.get<SeasonDetails>(`${BASE_TV}/${tvId}/season/${seasonNumber}`);
|
||||
async season(tvId: number, seasonNumber: number): Promise<SeasonDetails> {
|
||||
return await this.api.get<SeasonDetails>(
|
||||
`${BASE_TV}/${tvId}/season/${seasonNumber}`
|
||||
);
|
||||
}
|
||||
|
||||
async episodeGroups(id: number): Promise<EpisodeGroups>{
|
||||
async episodeGroups(id: number): Promise<EpisodeGroups> {
|
||||
return await this.api.get<EpisodeGroups>(`${BASE_TV}/${id}/episode_groups`);
|
||||
}
|
||||
|
||||
async externalIds(id: number): Promise<ExternalIds>{
|
||||
async externalIds(id: number): Promise<ExternalIds> {
|
||||
return await this.api.get<ExternalIds>(`${BASE_TV}/${id}/external_ids`);
|
||||
}
|
||||
|
||||
async images(id: number): Promise<Images>{
|
||||
async images(id: number): Promise<Images> {
|
||||
return await this.api.get<Images>(`${BASE_TV}/${id}/images`);
|
||||
}
|
||||
|
||||
async keywords(id: number): Promise<Keywords>{
|
||||
async keywords(id: number): Promise<Keywords> {
|
||||
return await this.api.get<Keywords>(`${BASE_TV}/${id}/keywords`);
|
||||
}
|
||||
|
||||
@@ -83,35 +89,39 @@ export class TvShowsEndpoint extends BaseEndpoint{
|
||||
return await this.api.get<Reviews>(`${BASE_TV}/${id}/reviews`, options);
|
||||
}
|
||||
|
||||
async screenedTheatrically(id: number): Promise<ScreenedTheatrically>{
|
||||
return await this.api.get<ScreenedTheatrically>(`${BASE_TV}/${id}/screened_theatrically`);
|
||||
async screenedTheatrically(id: number): Promise<ScreenedTheatrically> {
|
||||
return await this.api.get<ScreenedTheatrically>(
|
||||
`${BASE_TV}/${id}/screened_theatrically`
|
||||
);
|
||||
}
|
||||
|
||||
async similar(id: number, options?: PageOption): Promise<SimilarTvShows>{
|
||||
return await this.api.get<SimilarTvShows>(`${BASE_TV}/${id}/similar`, options);
|
||||
}
|
||||
|
||||
async translations(id: number): Promise<Translations>{
|
||||
async translations(id: number): Promise<Translations> {
|
||||
return await this.api.get<Translations>(`${BASE_TV}/${id}/translations`);
|
||||
}
|
||||
|
||||
async videos(id: number): Promise<Videos>{
|
||||
async videos(id: number): Promise<Videos> {
|
||||
return await this.api.get<Videos>(`${BASE_TV}/${id}/videos`);
|
||||
}
|
||||
|
||||
/**
|
||||
* Powered by JustWatch
|
||||
* @param id
|
||||
*/
|
||||
async watchProviders(id: number): Promise<WatchProviders>{
|
||||
return await this.api.get<WatchProviders>(`${BASE_TV}/${id}/watch/providers`);
|
||||
* Powered by JustWatch
|
||||
* @param id
|
||||
*/
|
||||
async watchProviders(id: number): Promise<WatchProviders> {
|
||||
return await this.api.get<WatchProviders>(
|
||||
`${BASE_TV}/${id}/watch/providers`
|
||||
);
|
||||
}
|
||||
|
||||
async latest(): Promise<LatestTvShows>{
|
||||
async latest(): Promise<LatestTvShows> {
|
||||
return await this.api.get<LatestTvShows>(`${BASE_TV}/latest`);
|
||||
}
|
||||
|
||||
async onTheAir(): Promise<OnTheAir>{
|
||||
async onTheAir(): Promise<OnTheAir> {
|
||||
return await this.api.get<OnTheAir>(`${BASE_TV}/on_the_air`);
|
||||
}
|
||||
|
||||
|
||||
22
src/tmdb.ts
22
src/tmdb.ts
@@ -44,47 +44,47 @@ export default class TMDB {
|
||||
return new CreditsEndpoint(this.accessToken);
|
||||
}
|
||||
|
||||
get search(): SearchEndpoint{
|
||||
get search(): SearchEndpoint {
|
||||
return new SearchEndpoint(this.accessToken);
|
||||
}
|
||||
|
||||
get genres(): GenreEndpoint{
|
||||
get genres(): GenreEndpoint {
|
||||
return new GenreEndpoint(this.accessToken);
|
||||
}
|
||||
|
||||
get movies(): MoviesEndpoint{
|
||||
get movies(): MoviesEndpoint {
|
||||
return new MoviesEndpoint(this.accessToken);
|
||||
}
|
||||
|
||||
get tvShows(): TvShowsEndpoint{
|
||||
get tvShows(): TvShowsEndpoint {
|
||||
return new TvShowsEndpoint(this.accessToken);
|
||||
}
|
||||
|
||||
get discover(): DiscoverEndpoint{
|
||||
get discover(): DiscoverEndpoint {
|
||||
return new DiscoverEndpoint(this.accessToken);
|
||||
}
|
||||
|
||||
get people(): PeopleEndpoint{
|
||||
get people(): PeopleEndpoint {
|
||||
return new PeopleEndpoint(this.accessToken);
|
||||
}
|
||||
|
||||
get review(): ReviewEndpoint{
|
||||
get review(): ReviewEndpoint {
|
||||
return new ReviewEndpoint(this.accessToken);
|
||||
}
|
||||
|
||||
get trending(): TrendingEndpoint{
|
||||
get trending(): TrendingEndpoint {
|
||||
return new TrendingEndpoint(this.accessToken);
|
||||
}
|
||||
|
||||
get find() : FindEndpoint{
|
||||
get find(): FindEndpoint {
|
||||
return new FindEndpoint(this.accessToken);
|
||||
}
|
||||
|
||||
get keywords() : KeywordsEndpoint{
|
||||
get keywords(): KeywordsEndpoint {
|
||||
return new KeywordsEndpoint(this.accessToken);
|
||||
}
|
||||
|
||||
get collections() : CollectionsEndpoint{
|
||||
get collections(): CollectionsEndpoint {
|
||||
return new CollectionsEndpoint(this.accessToken);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -6,14 +6,14 @@ export interface Certification {
|
||||
|
||||
export interface Certifications {
|
||||
certifications: {
|
||||
US: Certification[],
|
||||
CA: Certification[],
|
||||
DE: Certification[],
|
||||
GB: Certification[],
|
||||
AU: Certification[],
|
||||
BR: Certification[],
|
||||
FR: Certification[],
|
||||
NZ: Certification[],
|
||||
IN: Certification[],
|
||||
}
|
||||
US: Certification[];
|
||||
CA: Certification[];
|
||||
DE: Certification[];
|
||||
GB: Certification[];
|
||||
AU: Certification[];
|
||||
BR: Certification[];
|
||||
FR: Certification[];
|
||||
NZ: Certification[];
|
||||
IN: Certification[];
|
||||
};
|
||||
}
|
||||
|
||||
@@ -3,7 +3,7 @@ export interface Change {
|
||||
adult: boolean | undefined;
|
||||
}
|
||||
|
||||
export interface Changes{
|
||||
export interface Changes {
|
||||
results: Change[];
|
||||
page: number;
|
||||
total_pages: number;
|
||||
|
||||
@@ -12,5 +12,5 @@ export interface Collection {
|
||||
}
|
||||
|
||||
export interface DetailedCollection extends Collection {
|
||||
parts: Movie[]
|
||||
parts: Movie[];
|
||||
}
|
||||
|
||||
@@ -1,4 +1,3 @@
|
||||
|
||||
export interface Images {
|
||||
base_url: string;
|
||||
secure_base_url: string;
|
||||
@@ -14,47 +13,45 @@ export interface Configuration {
|
||||
change_keys: ChangeKeys[];
|
||||
}
|
||||
|
||||
|
||||
export const enum BackdropSizes {
|
||||
W300 = 'w300',
|
||||
W780 = 'w780',
|
||||
W1280 = 'w1280',
|
||||
ORIGINAL = 'original'
|
||||
ORIGINAL = 'original',
|
||||
}
|
||||
|
||||
export const enum LogoSizes {
|
||||
W45= 'w45',
|
||||
W92= 'w92',
|
||||
W154= 'w154',
|
||||
W185= 'w185',
|
||||
W45 = 'w45',
|
||||
W92 = 'w92',
|
||||
W154 = 'w154',
|
||||
W185 = 'w185',
|
||||
W300 = 'w300',
|
||||
W500 = 'w500',
|
||||
ORIGINAL = 'original'
|
||||
ORIGINAL = 'original',
|
||||
}
|
||||
|
||||
export const enum PosterSizes {
|
||||
W92= 'w92',
|
||||
W154= 'w154',
|
||||
W185='w185',
|
||||
W92 = 'w92',
|
||||
W154 = 'w154',
|
||||
W185 = 'w185',
|
||||
W300 = 'w300',
|
||||
W500 = 'w500',
|
||||
W780 = 'w780',
|
||||
ORIGINAL = 'original'
|
||||
ORIGINAL = 'original',
|
||||
}
|
||||
|
||||
export const enum ProfileSizes {
|
||||
W45 = 'w45',
|
||||
W185 = 'w185',
|
||||
W632 = 'w632',
|
||||
ORIGINAL = 'original'
|
||||
ORIGINAL = 'original',
|
||||
}
|
||||
|
||||
|
||||
export const enum StillSizes {
|
||||
W92= 'w92',
|
||||
W92 = 'w92',
|
||||
W185 = 'w185',
|
||||
W300 = 'w300',
|
||||
ORIGINAL = 'original'
|
||||
ORIGINAL = 'original',
|
||||
}
|
||||
|
||||
export const enum ChangeKeys {
|
||||
@@ -110,5 +107,5 @@ export const enum ChangeKeys {
|
||||
TVRAGE_ID = 'tvrage_id',
|
||||
TYPE = 'type',
|
||||
VIDEO = 'video',
|
||||
VIDEOS = 'videos'
|
||||
VIDEOS = 'videos',
|
||||
}
|
||||
|
||||
@@ -6,10 +6,9 @@ export interface CreditSeason {
|
||||
season_number?: number;
|
||||
}
|
||||
|
||||
|
||||
export interface Media{
|
||||
export interface Media {
|
||||
i?: number;
|
||||
name?:string;
|
||||
name?: string;
|
||||
first_air_date?: string;
|
||||
vote_count?: number;
|
||||
overview?: string;
|
||||
@@ -87,8 +86,6 @@ export interface ImageCollection {
|
||||
backdrops: Image[];
|
||||
posters: Image[];
|
||||
}
|
||||
|
||||
|
||||
export interface Video {
|
||||
id: string;
|
||||
iso_639_1: string;
|
||||
@@ -103,4 +100,4 @@ export interface Video {
|
||||
export interface Videos {
|
||||
id: number;
|
||||
results: Video[];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,29 +1,29 @@
|
||||
import { Movie, TV } from '.';
|
||||
|
||||
export type SortOption =
|
||||
| 'popularity.asc'
|
||||
| 'popularity.desc'
|
||||
| 'release_date.asc'
|
||||
| 'release_date.desc'
|
||||
| 'revenue.asc'
|
||||
| 'revenue.desc'
|
||||
| 'primary_release_date.asc'
|
||||
| 'primary_release_date.desc'
|
||||
| 'original_title.asc'
|
||||
| 'original_title.desc'
|
||||
| 'vote_average.asc'
|
||||
| 'vote_average.desc'
|
||||
| 'vote_count.asc'
|
||||
| 'vote_count.desc';
|
||||
| 'popularity.asc'
|
||||
| 'popularity.desc'
|
||||
| 'release_date.asc'
|
||||
| 'release_date.desc'
|
||||
| 'revenue.asc'
|
||||
| 'revenue.desc'
|
||||
| 'primary_release_date.asc'
|
||||
| 'primary_release_date.desc'
|
||||
| 'original_title.asc'
|
||||
| 'original_title.desc'
|
||||
| 'vote_average.asc'
|
||||
| 'vote_average.desc'
|
||||
| 'vote_count.asc'
|
||||
| 'vote_count.desc';
|
||||
|
||||
export interface MovieDiscoverResult{
|
||||
export interface MovieDiscoverResult {
|
||||
page: number;
|
||||
results: Movie[];
|
||||
total_results: number;
|
||||
total_pages: number;
|
||||
}
|
||||
|
||||
export interface TvShowDiscoverResult{
|
||||
export interface TvShowDiscoverResult {
|
||||
page: number;
|
||||
results: TV[];
|
||||
total_results: number;
|
||||
|
||||
@@ -1,8 +1,8 @@
|
||||
export * from './options';
|
||||
export * from './certification';
|
||||
export * from './credits';
|
||||
export * from './credits';
|
||||
export * from './configuration';
|
||||
export * from './changes';
|
||||
export * from './changes';
|
||||
export * from './movies';
|
||||
export * from './search';
|
||||
export * from './tv-shows';
|
||||
@@ -77,7 +77,7 @@ export interface Company {
|
||||
|
||||
export interface TV {
|
||||
id: number;
|
||||
name:string;
|
||||
name: string;
|
||||
first_air_date: string;
|
||||
backdrop_path: string;
|
||||
genre_ids: number[];
|
||||
@@ -122,7 +122,7 @@ export interface SpokenLanguage {
|
||||
name: string;
|
||||
}
|
||||
|
||||
export interface ContentRatings{
|
||||
export interface ContentRatings {
|
||||
results: ContentRatingsResult[];
|
||||
id: number;
|
||||
}
|
||||
@@ -132,7 +132,6 @@ export interface ContentRatingsResult {
|
||||
rating: string;
|
||||
}
|
||||
|
||||
|
||||
export interface Recommendation {
|
||||
adult: boolean;
|
||||
backdrop_path?: any;
|
||||
@@ -150,7 +149,6 @@ export interface Recommendation {
|
||||
vote_count: number;
|
||||
}
|
||||
|
||||
|
||||
export interface Recommendations {
|
||||
page: number;
|
||||
results: Recommendation[];
|
||||
@@ -176,7 +174,6 @@ export interface Reviews {
|
||||
total_results: number;
|
||||
}
|
||||
|
||||
|
||||
export interface TranslationData {
|
||||
title: string;
|
||||
overview: string;
|
||||
@@ -196,7 +193,7 @@ export interface Translations {
|
||||
translations: Translation[];
|
||||
}
|
||||
|
||||
export interface Image{
|
||||
export interface Image {
|
||||
aspect_ratio: number;
|
||||
file_path: string;
|
||||
height: number;
|
||||
@@ -204,4 +201,4 @@ export interface Image{
|
||||
vote_average: number;
|
||||
vote_count: number;
|
||||
width: number;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -5,14 +5,14 @@ export interface KeywordsOptions {
|
||||
language?: string;
|
||||
}
|
||||
|
||||
export interface BelongingMovies{
|
||||
export interface BelongingMovies {
|
||||
page: number;
|
||||
results: Movie[];
|
||||
total_results: number;
|
||||
total_pages: number;
|
||||
}
|
||||
|
||||
export interface Keyword{
|
||||
export interface Keyword {
|
||||
id: number;
|
||||
name: string;
|
||||
}
|
||||
@@ -20,4 +20,4 @@ export interface Keyword{
|
||||
export interface Keywords {
|
||||
id: number;
|
||||
keywords: Keyword[];
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,4 +1,10 @@
|
||||
import { Genre, Movie, ProductionCompany, ProductionCountry, SpokenLanguage } from './';
|
||||
import {
|
||||
Genre,
|
||||
Movie,
|
||||
ProductionCompany,
|
||||
ProductionCountry,
|
||||
SpokenLanguage,
|
||||
} from './';
|
||||
|
||||
export interface MovieDetails {
|
||||
adult: boolean;
|
||||
@@ -34,7 +40,7 @@ export enum ReleaseDateType {
|
||||
'Theatrical',
|
||||
'Digital',
|
||||
'Physical',
|
||||
'TV'
|
||||
'TV',
|
||||
}
|
||||
|
||||
export interface ReleaseDate {
|
||||
@@ -55,7 +61,6 @@ export interface ReleaseDates {
|
||||
results: ReleaseDateResult[];
|
||||
}
|
||||
|
||||
|
||||
export interface SimilarMovies {
|
||||
page: number;
|
||||
results: Movie[];
|
||||
@@ -82,7 +87,6 @@ export interface MovieLists {
|
||||
total_results: number;
|
||||
}
|
||||
|
||||
|
||||
export interface MovieChangeItem {
|
||||
id: string;
|
||||
action: string;
|
||||
@@ -129,7 +133,6 @@ export interface LatestMovie {
|
||||
vote_count: number;
|
||||
}
|
||||
|
||||
|
||||
export interface Dates {
|
||||
maximum: string;
|
||||
minimum: string;
|
||||
|
||||
@@ -1,8 +1,8 @@
|
||||
import { Review } from './';
|
||||
|
||||
export interface ReviewDetails extends Review{
|
||||
export interface ReviewDetails extends Review {
|
||||
iso_639_1: string;
|
||||
media_id: number;
|
||||
media_title: number;
|
||||
media_type: number;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -4,5 +4,3 @@ export interface Search<T> {
|
||||
total_pages: number;
|
||||
total_results: number;
|
||||
}
|
||||
|
||||
|
||||
|
||||
@@ -6,14 +6,14 @@ export type TimeWindow = 'day' | 'week';
|
||||
type TrendingResult<T extends MediaType> = T extends 'tv'
|
||||
? TV
|
||||
: T extends 'movie'
|
||||
? Movie
|
||||
: T extends 'person'
|
||||
? Person
|
||||
: TV | Movie | Person;
|
||||
? Movie
|
||||
: T extends 'person'
|
||||
? Person
|
||||
: TV | Movie | Person;
|
||||
|
||||
export interface TrendingResults<T extends MediaType> {
|
||||
page: number;
|
||||
results: (TrendingResult<T> & {media_type: MediaType})[];
|
||||
results: (TrendingResult<T> & { media_type: MediaType })[];
|
||||
total_pages: number;
|
||||
total_results: number;
|
||||
}
|
||||
}
|
||||
|
||||
@@ -1,4 +1,10 @@
|
||||
import { Genre, ProductionCompany, ProductionCountry, SpokenLanguage, Crew } from './';
|
||||
import {
|
||||
Genre,
|
||||
ProductionCompany,
|
||||
ProductionCountry,
|
||||
SpokenLanguage,
|
||||
Crew,
|
||||
} from './';
|
||||
|
||||
export interface CreatedBy {
|
||||
id: number;
|
||||
@@ -73,45 +79,44 @@ export interface TvShowDetails {
|
||||
}
|
||||
|
||||
export interface GuestStar {
|
||||
credit_id: string
|
||||
order: number
|
||||
character: string
|
||||
adult: boolean
|
||||
gender: number | null
|
||||
id: number
|
||||
known_for_department: string
|
||||
name: string
|
||||
original_name: string
|
||||
popularity: number
|
||||
profile_path: string | null
|
||||
|
||||
credit_id: string;
|
||||
order: number;
|
||||
character: string;
|
||||
adult: boolean;
|
||||
gender: number | null;
|
||||
id: number;
|
||||
known_for_department: string;
|
||||
name: string;
|
||||
original_name: string;
|
||||
popularity: number;
|
||||
profile_path: string | null;
|
||||
}
|
||||
|
||||
export interface Episode {
|
||||
air_date: string
|
||||
episode_number: number
|
||||
crew: Crew[]
|
||||
guest_stars: GuestStar[]
|
||||
id: number
|
||||
name: string
|
||||
overview: string
|
||||
production_code: string
|
||||
season_number: number
|
||||
still_path: string
|
||||
vote_average: number
|
||||
vote_count: number
|
||||
air_date: string;
|
||||
episode_number: number;
|
||||
crew: Crew[];
|
||||
guest_stars: GuestStar[];
|
||||
id: number;
|
||||
name: string;
|
||||
overview: string;
|
||||
production_code: string;
|
||||
season_number: number;
|
||||
still_path: string;
|
||||
vote_average: number;
|
||||
vote_count: number;
|
||||
show_id: number;
|
||||
runtime: number;
|
||||
}
|
||||
|
||||
export interface SeasonDetails {
|
||||
air_date: string
|
||||
episodes: Episode[]
|
||||
name: string
|
||||
overview: string
|
||||
id: number
|
||||
poster_path: string | null
|
||||
season_number: number
|
||||
air_date: string;
|
||||
episodes: Episode[];
|
||||
name: string;
|
||||
overview: string;
|
||||
id: number;
|
||||
poster_path: string | null;
|
||||
season_number: number;
|
||||
}
|
||||
|
||||
export interface TvShowItem {
|
||||
@@ -165,7 +170,6 @@ export interface ScreenedTheatrically {
|
||||
results: ScreenedTheatricallyResult[];
|
||||
}
|
||||
|
||||
|
||||
export interface SimilarTvShow {
|
||||
backdrop_path: string;
|
||||
first_air_date: string;
|
||||
@@ -218,7 +222,6 @@ export interface LatestTvShows {
|
||||
vote_count: number;
|
||||
}
|
||||
|
||||
|
||||
export interface OnTheAirResult {
|
||||
poster_path: string;
|
||||
popularity: number;
|
||||
@@ -242,7 +245,6 @@ export interface OnTheAir {
|
||||
total_pages: number;
|
||||
}
|
||||
|
||||
|
||||
export interface AiringTodayResult {
|
||||
poster_path: string;
|
||||
popularity: number;
|
||||
@@ -266,7 +268,6 @@ export interface TvShowsAiringToday {
|
||||
total_pages: number;
|
||||
}
|
||||
|
||||
|
||||
export interface PopularTvShowResult {
|
||||
poster_path: string;
|
||||
popularity: number;
|
||||
@@ -290,7 +291,6 @@ export interface PopularTvShows {
|
||||
total_pages: number;
|
||||
}
|
||||
|
||||
|
||||
export interface TopRatedTvShowResult {
|
||||
poster_path: string;
|
||||
popularity: number;
|
||||
@@ -313,5 +313,3 @@ export interface TopRatedTvShows {
|
||||
total_results: number;
|
||||
total_pages: number;
|
||||
}
|
||||
|
||||
|
||||
|
||||
@@ -1,4 +1,3 @@
|
||||
|
||||
export interface Flatrate {
|
||||
display_priority: number;
|
||||
logo_path: string;
|
||||
@@ -20,7 +19,6 @@ export interface Buy {
|
||||
provider_name: string;
|
||||
}
|
||||
|
||||
|
||||
export interface WatchLocale {
|
||||
AR: {
|
||||
link: string;
|
||||
@@ -298,5 +296,3 @@ export interface WatchProviders {
|
||||
id: number;
|
||||
results: WatchLocale;
|
||||
}
|
||||
|
||||
|
||||
|
||||
@@ -8,7 +8,12 @@
|
||||
* @param {string} imagePath raw image path
|
||||
* @param {boolean} svg get svg version if true
|
||||
*/
|
||||
export const getFullImagePath = (baseUrl: string, fileSize: string, imagePath: string, svg = false): string => {
|
||||
export const getFullImagePath = (
|
||||
baseUrl: string,
|
||||
fileSize: string,
|
||||
imagePath: string,
|
||||
svg = false
|
||||
): string => {
|
||||
const imagePathArr = imagePath.split('.');
|
||||
const imageFormat = svg ? 'svg' : imagePathArr[1];
|
||||
|
||||
|
||||
Reference in New Issue
Block a user