9 Commits

Author SHA1 Message Date
Blake
6e111921b5 Create npm-publish.yml 2023-04-15 14:51:27 -04:00
Blake
c95a66baae Merge pull request #23 from Der-Penz/refactor/parsing-options-superclass
Refactor/ moved parsing of parameters into superclass
2023-04-15 14:47:56 -04:00
DerPenz
f3f4868ef8 version: 0.2.0 2023-04-15 20:22:45 +02:00
DerPenz
6bcddc62f1 Merge branch 'master' into refactor/parsing-options-superclass 2023-04-15 18:38:17 +02:00
DerPenz
2b26b7b848 run npm format 2023-04-15 18:32:53 +02:00
DerPenz
6c361002bf Squashed commit of the following:
commit 5d38a76997
Merge: 7cccdb9 f160e23
Author: 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

commit f160e2362c
Author: Blake Joynes <blakejoynes@gmail.com>
Date:   Sat Apr 15 11:44:00 2023 -0400

    add pre commit hook

commit 0fd8317884
Merge: bc91674 d1e87ba
Author: Blake Joynes <blakejoynes@gmail.com>
Date:   Sat Apr 15 11:41:28 2023 -0400

    add husky

commit bc91674c4b
Author: Blake Joynes <blakejoynes@gmail.com>
Date:   Sat Apr 15 11:39:24 2023 -0400

    add husky

commit d1e87ba7be
Author: Blake <blakejoy@users.noreply.github.com>
Date:   Fri Apr 14 08:48:33 2023 -0400

    Update .prettierrc

commit d064d4d86f
Author: Blake Joynes <blakejoynes@gmail.com>
Date:   Fri Apr 14 03:09:39 2023 -0400

    turn off linebreak rules

commit 06155bd323
Author: Blake Joynes <blakejoynes@gmail.com>
Date:   Thu Apr 13 21:58:41 2023 -0400

    add linting and prettier
2023-04-15 18:32:06 +02:00
Blake
6fd471b921 Merge pull request #24 from blakejoy/update_any_types
fix warnings for any type
2023-04-15 12:20:25 -04:00
DerPenz
562864a70f removed unused parameter parsing 2023-04-14 16:01:35 +02:00
DerPenz
1200064194 moved option parsing in superclass 'get' method 2023-04-14 15:54:27 +02:00
13 changed files with 96 additions and 89 deletions

33
.github/workflows/npm-publish.yml vendored Normal file
View File

@@ -0,0 +1,33 @@
# This workflow will run tests using node and then publish a package to GitHub Packages when a release is created
# For more information see: https://docs.github.com/en/actions/publishing-packages/publishing-nodejs-packages
name: Node.js Package
on:
release:
types: [created]
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/setup-node@v3
with:
node-version: 16
- run: npm ci
- run: npm test
publish-npm:
needs: build
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- uses: actions/setup-node@v3
with:
node-version: 16
registry-url: https://registry.npmjs.org/
- run: npm ci
- run: npm publish
env:
NODE_AUTH_TOKEN: ${{secrets.npm_token}}

View File

@@ -1,6 +1,6 @@
{
"name": "tmdb-ts",
"version": "0.1.9",
"version": "0.2.0",
"description": "TMDB v3 library wrapper",
"main": "dist/index.js",
"types": "dist/index.d.ts",

View File

@@ -1,4 +1,5 @@
import fetch from 'cross-fetch';
import { parseOptions } from './utils';
const BASE_URL_V3 = 'https://api.themoviedb.org/3';
@@ -7,8 +8,9 @@ export default class Api {
this.accessToken = accessToken;
}
async get<T>(path: string): Promise<T> {
const response = await fetch(`${BASE_URL_V3}${path}`, {
async get<T>(path: string, options?: Record<string, any>): Promise<T> {
const params = parseOptions(options);
const response = await fetch(`${BASE_URL_V3}${path}?${params}`, {
method: 'GET',
headers: {
Authorization: `Bearer ${this.accessToken}`,

View File

@@ -1,6 +1,5 @@
import { BaseEndpoint } from './base';
import { ChangeOptions, Changes } from '../types/changes';
import { parseOptions } from '../utils';
export class ChangeEndpoint extends BaseEndpoint {
constructor(protected readonly accessToken: string) {
@@ -8,17 +7,14 @@ export class ChangeEndpoint extends BaseEndpoint {
}
async movies(options?: ChangeOptions): Promise<Changes> {
const params = parseOptions(options);
return await this.api.get<Changes>(`/movie/changes?${params}`);
return await this.api.get<Changes>(`/movie/changes`, options);
}
async tvShows(options?: ChangeOptions): Promise<Changes> {
const params = parseOptions(options);
return await this.api.get<Changes>(`/tv/changes?${params}`);
return await this.api.get<Changes>(`/tv/changes`, options);
}
async person(options?: ChangeOptions): Promise<Changes> {
const params = parseOptions(options);
return await this.api.get<Changes>(`/person/changes${params}`);
return await this.api.get<Changes>(`/person/change`, options);
}
}

View File

@@ -4,7 +4,6 @@ import {
LanguageOption,
Translations,
} from '../types';
import { parseOptions } from '../utils';
import { BaseEndpoint } from './base';
const BASE_COLLECTION = '/collection';
@@ -18,16 +17,16 @@ export class CollectionsEndpoint extends BaseEndpoint {
id: number,
options?: LanguageOption
): Promise<DetailedCollection> {
const params = parseOptions(options);
return await this.api.get<DetailedCollection>(
`${BASE_COLLECTION}/${id}?${params}`
`${BASE_COLLECTION}/${id}`,
options
);
}
async images(id: number, options?: LanguageOption): Promise<ImageCollection> {
const params = parseOptions(options);
return await this.api.get<ImageCollection>(
`${BASE_COLLECTION}/${id}/images?${params}`
`${BASE_COLLECTION}/${id}/images`,
options
);
}
@@ -35,9 +34,9 @@ export class CollectionsEndpoint extends BaseEndpoint {
id: number,
options?: LanguageOption
): Promise<Translations> {
const params = parseOptions(options);
return await this.api.get<Translations>(
`${BASE_COLLECTION}/${id}/translations?${params}`
`${BASE_COLLECTION}/${id}/translations`,
options
);
}
}

View File

@@ -3,7 +3,6 @@ import {
SortOption,
TvShowDiscoverResult,
} from '../types';
import { parseOptions } from '../utils';
import { BaseEndpoint } from './base';
const BASE_DISCOVER = '/discover';
@@ -70,16 +69,16 @@ export class DiscoverEndpoint extends BaseEndpoint {
}
async movie(options?: MovieQueryOptions): Promise<MovieDiscoverResult> {
const params = parseOptions(options);
return await this.api.get<MovieDiscoverResult>(
`${BASE_DISCOVER}/movie?${params}`
`${BASE_DISCOVER}/movie`,
options
);
}
async tvShow(options?: TvShowQueryOptions): Promise<TvShowDiscoverResult> {
const params = parseOptions(options);
return await this.api.get<TvShowDiscoverResult>(
`${BASE_DISCOVER}/tv?${params}`
`${BASE_DISCOVER}/tv`,
options
);
}
}

View File

@@ -1,6 +1,5 @@
import { BaseEndpoint } from './base';
import { ExternalIdOptions, FindResult } from '../types';
import { parseOptions } from '../utils';
export class FindEndpoint extends BaseEndpoint {
constructor(accessToken: string) {
@@ -11,7 +10,6 @@ export class FindEndpoint extends BaseEndpoint {
externalId: string,
options: ExternalIdOptions
): Promise<FindResult> {
const params = parseOptions(options);
return await this.api.get<FindResult>(`/find/${externalId}?${params}`);
return await this.api.get<FindResult>(`/find/${externalId}`, options);
}
}

View File

@@ -1,6 +1,5 @@
import { BaseEndpoint } from './base';
import { BelongingMovies, Keyword, KeywordsOptions } from '../types';
import { parseOptions } from '../utils';
const BASE_Keyword = '/keyword';
@@ -17,9 +16,9 @@ export class KeywordsEndpoint extends BaseEndpoint {
keywordId: number,
options?: KeywordsOptions
): Promise<BelongingMovies> {
const params = parseOptions(options);
return await this.api.get<BelongingMovies>(
`${BASE_Keyword}/${keywordId}/movies?${params}`
`${BASE_Keyword}/${keywordId}/movies`,
options
);
}
}

View File

@@ -25,7 +25,6 @@ import {
Videos,
WatchProviders,
} from '../types';
import { parseOptions } from '../utils';
const BASE_MOVIE = '/movie';
@@ -45,9 +44,9 @@ export class MoviesEndpoint extends BaseEndpoint {
}
async changes(id: number, options?: ChangeOptions): Promise<MovieChanges> {
const params = parseOptions(options);
return await this.api.get<MovieChanges>(
`${BASE_MOVIE}/${id}/changes?${params}`
`${BASE_MOVIE}/${id}/changes`,
options
);
}
@@ -71,19 +70,16 @@ export class MoviesEndpoint extends BaseEndpoint {
id: number,
options?: LanguageOption | PageOption
): Promise<MovieLists> {
const params = parseOptions(options);
return await this.api.get<MovieLists>(
`${BASE_MOVIE}/${id}/lists?${params}`
);
return await this.api.get<MovieLists>(`${BASE_MOVIE}/${id}/lists`, options);
}
async recommendations(
id: number,
options?: PageOption
): Promise<Recommendations> {
const params = parseOptions(options);
return await this.api.get<Recommendations>(
`${BASE_MOVIE}/${id}/recommendations?${params}`
`${BASE_MOVIE}/${id}/recommendations`,
options
);
}
@@ -94,14 +90,13 @@ export class MoviesEndpoint extends BaseEndpoint {
}
async reviews(id: number, options?: PageOption): Promise<Reviews> {
const params = parseOptions(options);
return await this.api.get<Reviews>(`${BASE_MOVIE}/${id}/reviews?${params}`);
return await this.api.get<Reviews>(`${BASE_MOVIE}/${id}/reviews`, options);
}
async similar(id: number, options?: PageOption): Promise<SimilarMovies> {
const params = parseOptions(options);
return await this.api.get<SimilarMovies>(
`${BASE_MOVIE}/${id}/similar?${params}`
`${BASE_MOVIE}/${id}/similar`,
options
);
}
@@ -130,32 +125,31 @@ export class MoviesEndpoint extends BaseEndpoint {
async nowPlaying(
options?: PageOption & LanguageOption & RegionOption
): Promise<MoviesPlayingNow> {
const params = parseOptions(options);
return await this.api.get<MoviesPlayingNow>(
`${BASE_MOVIE}/now_playing?${params}`
`${BASE_MOVIE}/now_playing`,
options
);
}
async popular(options?: PageOption): Promise<PopularMovies> {
const params = parseOptions(options);
return await this.api.get<PopularMovies>(`${BASE_MOVIE}/popular?${params}`);
return await this.api.get<PopularMovies>(`${BASE_MOVIE}/popular`, options);
}
async topRated(
options?: PageOption & LanguageOption & RegionOption
): Promise<TopRatedMovies> {
const params = parseOptions(options);
return await this.api.get<TopRatedMovies>(
`${BASE_MOVIE}/top_rated?${params}`
`${BASE_MOVIE}/top_rated`,
options
);
}
async upcoming(
options?: PageOption & LanguageOption & RegionOption
): Promise<UpcomingMovies> {
const params = parseOptions(options);
return await this.api.get<UpcomingMovies>(
`${BASE_MOVIE}/upcoming?${params}`
`${BASE_MOVIE}/upcoming`,
options
);
}
}

View File

@@ -12,7 +12,6 @@ import {
PopularPersons,
TaggedImages,
} from '../types';
import { parseOptions } from '../utils';
import { BaseEndpoint } from './base';
const BASE_PERSON = '/person';
@@ -27,9 +26,9 @@ export class PeopleEndpoint extends BaseEndpoint {
}
async changes(id: number, options?: ChangeOptions): Promise<PersonChanges> {
const params = parseOptions(options);
return await this.api.get<PersonChanges>(
`${BASE_PERSON}/${id}/changes?${params}`
`${BASE_PERSON}/${id}/changes`,
options
);
}
@@ -62,9 +61,9 @@ export class PeopleEndpoint extends BaseEndpoint {
}
async taggedImages(id: number, options?: PageOption): Promise<TaggedImages> {
const params = parseOptions(options);
return await this.api.get<TaggedImages>(
`${BASE_PERSON}/${id}/tagged_images?${params}`
`${BASE_PERSON}/${id}/tagged_images`,
options
);
}
@@ -79,9 +78,9 @@ export class PeopleEndpoint extends BaseEndpoint {
}
async popular(options?: PageOption): Promise<PopularPersons> {
const params = parseOptions(options);
return await this.api.get<PopularPersons>(
`${BASE_PERSON}/popular?${params}`
`${BASE_PERSON}/popular`,
options
);
}
}

View File

@@ -1,7 +1,6 @@
import { BaseEndpoint } from './base';
import { Search } from '../types/search';
import { Collection, Company, Movie, Person, TV } from '../types';
import { parseOptions } from '../utils';
const BASE_SEARCH = '/search';
@@ -31,44 +30,39 @@ export class SearchEndpoint extends BaseEndpoint {
}
async companies(options: SearchOptions): Promise<Search<Company>> {
const params = parseOptions(options);
return await this.api.get<Search<Company>>(
`${BASE_SEARCH}/company?${params}`
`${BASE_SEARCH}/company`,
options
);
}
async collections(options: SearchOptions): Promise<Search<Collection>> {
const params = parseOptions(options);
return await this.api.get<Search<Collection>>(
`${BASE_SEARCH}/collection?${params}`
`${BASE_SEARCH}/collection`,
options
);
}
async keywords(
options: SearchOptions
): Promise<Search<{ id: string; name: string }>> {
const params = parseOptions(options);
return await this.api.get<Search<{ id: string; name: string }>>(
`${BASE_SEARCH}/keyword?${params}`
`${BASE_SEARCH}/keyword`,
options
);
}
async movies(options: MovieSearchOptions): Promise<Search<Movie>> {
const params = parseOptions(options);
return await this.api.get<Search<Movie>>(`${BASE_SEARCH}/movie?${params}`);
return await this.api.get<Search<Movie>>(`${BASE_SEARCH}/movie`, options);
}
async people(options: PeopleSearchOptions): Promise<Search<Person>> {
const params = parseOptions(options);
return await this.api.get<Search<Person>>(
`${BASE_SEARCH}/person?${params}`
);
return await this.api.get<Search<Person>>(`${BASE_SEARCH}/person`, options);
}
// TODO: Multi search
async tvShows(options: TvSearchOptions): Promise<Search<TV>> {
const params = parseOptions(options);
return await this.api.get<Search<TV>>(`${BASE_SEARCH}/tv?${params}`);
return await this.api.get<Search<TV>>(`${BASE_SEARCH}/tv`, options);
}
}

View File

@@ -27,7 +27,6 @@ import {
Videos,
WatchProviders,
} from '../types';
import { parseOptions } from '../utils';
const BASE_TV = '/tv';
@@ -47,9 +46,9 @@ export class TvShowsEndpoint extends BaseEndpoint {
}
async changes(id: number, options?: ChangeOptions): Promise<TvShowChanges> {
const params = parseOptions(options);
return await this.api.get<TvShowChanges>(
`${BASE_TV}/${id}/changes?${params}`
`${BASE_TV}/${id}/changes`,
options
);
}
@@ -89,15 +88,14 @@ export class TvShowsEndpoint extends BaseEndpoint {
id: number,
options?: PageOption
): Promise<Recommendations> {
const params = parseOptions(options);
return await this.api.get<Recommendations>(
`${BASE_TV}/${id}/recommendations?${params}`
`${BASE_TV}/${id}/recommendations`,
options
);
}
async reviews(id: number, options?: PageOption): Promise<Reviews> {
const params = parseOptions(options);
return await this.api.get<Reviews>(`${BASE_TV}/${id}/reviews?${params}`);
return await this.api.get<Reviews>(`${BASE_TV}/${id}/reviews`, options);
}
async screenedTheatrically(id: number): Promise<ScreenedTheatrically> {
@@ -107,9 +105,9 @@ export class TvShowsEndpoint extends BaseEndpoint {
}
async similar(id: number, options?: PageOption): Promise<SimilarTvShows> {
const params = parseOptions(options);
return await this.api.get<SimilarTvShows>(
`${BASE_TV}/${id}/similar?${params}`
`${BASE_TV}/${id}/similar`,
options
);
}
@@ -142,25 +140,21 @@ export class TvShowsEndpoint extends BaseEndpoint {
async airingToday(
options?: PageOption & LanguageOption & RegionOption
): Promise<TvShowsAiringToday> {
const params = parseOptions(options);
return await this.api.get<TvShowsAiringToday>(
`${BASE_TV}/airing_today?${params}`
`${BASE_TV}/airing_today`,
options
);
}
async popular(
options?: PageOption & LanguageOption & RegionOption
): Promise<PopularTvShows> {
const params = parseOptions(options);
return await this.api.get<PopularTvShows>(`${BASE_TV}/popular?${params}`);
return await this.api.get<PopularTvShows>(`${BASE_TV}/popular`, options);
}
async topRated(
options?: PageOption & LanguageOption & RegionOption
): Promise<TopRatedTvShows> {
const params = parseOptions(options);
return await this.api.get<TopRatedTvShows>(
`${BASE_TV}/top_rated?${params}`
);
return await this.api.get<TopRatedTvShows>(`${BASE_TV}/top_rated`, options);
}
}

View File

@@ -1,4 +1,4 @@
export function parseOptions(options?: Record<string, any>): string {
/* eslint-disable @typescript-eslint/no-explicit-any */
export function parseOptions(options?: { [s: string]: any }): string {
return options ? new URLSearchParams(Object.entries(options)).toString() : '';
}