node-csfd-api 3.0.0-next.2 → 3.0.0-next.21

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (67) hide show
  1. package/README.md +103 -45
  2. package/fetchers/fetch.polyfill.d.ts +1 -0
  3. package/fetchers/fetch.polyfill.js +9 -0
  4. package/{cjs/fetchers → fetchers}/index.js +5 -14
  5. package/helpers/cinema.helper.d.ts +19 -0
  6. package/helpers/cinema.helper.js +105 -0
  7. package/{cjs/helpers → helpers}/creator.helper.js +12 -11
  8. package/{types/helpers → helpers}/global.helper.d.ts +10 -0
  9. package/{cjs/helpers → helpers}/global.helper.js +9 -5
  10. package/{cjs/helpers → helpers}/movie.helper.js +9 -4
  11. package/{types/helpers → helpers}/search.helper.d.ts +1 -1
  12. package/{cjs/helpers → helpers}/search.helper.js +5 -3
  13. package/{cjs/helpers → helpers}/user-ratings.helper.js +2 -1
  14. package/{types/index.d.ts → index.d.ts} +5 -1
  15. package/index.js +39 -0
  16. package/interfaces/cinema.interface.d.ts +23 -0
  17. package/interfaces/user-ratings.interface.js +2 -0
  18. package/package.json +21 -14
  19. package/services/cinema.service.d.ts +6 -0
  20. package/services/cinema.service.js +34 -0
  21. package/services/creator.service.js +32 -0
  22. package/{cjs/services → services}/movie.service.js +10 -21
  23. package/{cjs/services → services}/search.service.js +29 -20
  24. package/{cjs/services → services}/user-ratings.service.js +25 -36
  25. package/{types/vars.d.ts → vars.d.ts} +2 -0
  26. package/{cjs/vars.js → vars.js} +5 -1
  27. package/cjs/index.js +0 -50
  28. package/cjs/services/creator.service.js +0 -43
  29. package/esm/fetchers/index.js +0 -32
  30. package/esm/helpers/creator.helper.js +0 -73
  31. package/esm/helpers/global.helper.js +0 -56
  32. package/esm/helpers/movie.helper.js +0 -223
  33. package/esm/helpers/search-user.helper.js +0 -15
  34. package/esm/helpers/search.helper.js +0 -49
  35. package/esm/helpers/user-ratings.helper.js +0 -47
  36. package/esm/index.js +0 -46
  37. package/esm/interfaces/creator.interface.js +0 -1
  38. package/esm/interfaces/global.js +0 -1
  39. package/esm/interfaces/movie.interface.js +0 -1
  40. package/esm/interfaces/search.interface.js +0 -1
  41. package/esm/interfaces/user-ratings.interface.js +0 -1
  42. package/esm/services/creator.service.js +0 -39
  43. package/esm/services/movie.service.js +0 -65
  44. package/esm/services/search.service.js +0 -67
  45. package/esm/services/user-ratings.service.js +0 -91
  46. package/esm/vars.js +0 -4
  47. package/types/index.ts +0 -22
  48. /package/{types/fetchers → fetchers}/index.d.ts +0 -0
  49. /package/{types/helpers → helpers}/creator.helper.d.ts +0 -0
  50. /package/{types/helpers → helpers}/movie.helper.d.ts +0 -0
  51. /package/{types/helpers → helpers}/search-user.helper.d.ts +0 -0
  52. /package/{cjs/helpers → helpers}/search-user.helper.js +0 -0
  53. /package/{types/helpers → helpers}/user-ratings.helper.d.ts +0 -0
  54. /package/{cjs/interfaces/creator.interface.js → interfaces/cinema.interface.js} +0 -0
  55. /package/{types/interfaces → interfaces}/creator.interface.d.ts +0 -0
  56. /package/{cjs/interfaces/global.js → interfaces/creator.interface.js} +0 -0
  57. /package/{types/interfaces → interfaces}/global.d.ts +0 -0
  58. /package/{cjs/interfaces/movie.interface.js → interfaces/global.js} +0 -0
  59. /package/{types/interfaces → interfaces}/movie.interface.d.ts +0 -0
  60. /package/{cjs/interfaces/search.interface.js → interfaces/movie.interface.js} +0 -0
  61. /package/{types/interfaces → interfaces}/search.interface.d.ts +0 -0
  62. /package/{cjs/interfaces/user-ratings.interface.js → interfaces/search.interface.js} +0 -0
  63. /package/{types/interfaces → interfaces}/user-ratings.interface.d.ts +0 -0
  64. /package/{types/services → services}/creator.service.d.ts +0 -0
  65. /package/{types/services → services}/movie.service.d.ts +0 -0
  66. /package/{types/services → services}/search.service.d.ts +0 -0
  67. /package/{types/services → services}/user-ratings.service.d.ts +0 -0
package/index.js ADDED
@@ -0,0 +1,39 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.csfd = exports.Csfd = void 0;
4
+ const cinema_service_1 = require("./services/cinema.service");
5
+ const creator_service_1 = require("./services/creator.service");
6
+ const movie_service_1 = require("./services/movie.service");
7
+ const search_service_1 = require("./services/search.service");
8
+ const user_ratings_service_1 = require("./services/user-ratings.service");
9
+ class Csfd {
10
+ constructor(userRatingsService, movieService, creatorService, searchService, cinemaService) {
11
+ this.userRatingsService = userRatingsService;
12
+ this.movieService = movieService;
13
+ this.creatorService = creatorService;
14
+ this.searchService = searchService;
15
+ this.cinemaService = cinemaService;
16
+ }
17
+ async userRatings(user, config) {
18
+ return this.userRatingsService.userRatings(user, config);
19
+ }
20
+ async movie(movie) {
21
+ return this.movieService.movie(+movie);
22
+ }
23
+ async creator(creator) {
24
+ return this.creatorService.creator(+creator);
25
+ }
26
+ async search(text) {
27
+ return this.searchService.search(text);
28
+ }
29
+ async cinema(district, period) {
30
+ return this.cinemaService.cinemas(+district, period);
31
+ }
32
+ }
33
+ exports.Csfd = Csfd;
34
+ const movieScraper = new movie_service_1.MovieScraper();
35
+ const userRatingsScraper = new user_ratings_service_1.UserRatingsScraper();
36
+ const cinemaScraper = new cinema_service_1.CinemaScraper();
37
+ const creatorScraper = new creator_service_1.CreatorScraper();
38
+ const searchScraper = new search_service_1.SearchScraper();
39
+ exports.csfd = new Csfd(userRatingsScraper, movieScraper, creatorScraper, searchScraper, cinemaScraper);
@@ -0,0 +1,23 @@
1
+ import { CSFDMovieListItem } from './movie.interface';
2
+ export interface CSFDCinema {
3
+ id: number;
4
+ name: string;
5
+ city: string;
6
+ url: string;
7
+ coords: {
8
+ lat: number;
9
+ lng: number;
10
+ };
11
+ region?: string;
12
+ screenings: CSFDCinemaGroupedFilmsByDate[];
13
+ }
14
+ export interface CSFDCinemaGroupedFilmsByDate {
15
+ date: string;
16
+ films: CSFDCinemaMovie[];
17
+ }
18
+ export interface CSFDCinemaMovie extends CSFDMovieListItem {
19
+ meta: CSFDCinemaMeta[];
20
+ showTimes: string[];
21
+ }
22
+ export type CSFDCinemaMeta = 'dubbing' | '3D' | 'subtitles' | string;
23
+ export type CSFDCinemaPeriod = 'today' | 'weekend' | 'week' | 'tomorrow' | 'month';
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
package/package.json CHANGED
@@ -1,21 +1,20 @@
1
1
  {
2
2
  "name": "node-csfd-api",
3
- "version": "3.0.0-next.2",
3
+ "version": "3.0.0-next.21",
4
4
  "description": "ČSFD API in JavaScript. Amazing NPM library for scrapping csfd.cz :)",
5
- "main": "./cjs/index.js",
5
+ "main": "./index.js",
6
6
  "author": "BART! <bart@bartweb.cz>",
7
7
  "scripts": {
8
8
  "start": "tsc -w",
9
9
  "prebuild": "rimraf dist",
10
- "build": "tsc && tsc -p tsconfig-cjs.json && yarn barrels",
11
- "barrels": "barrelsby --delete -c barrels.json",
12
- "postbuild": "npm-prepare-dist -s postinstall -s prepare && yarn fix-paths",
10
+ "build": "tsc",
11
+ "postbuild": "npm-prepare-dist -s postinstall -s prepare",
13
12
  "tsc": "tsc",
14
- "demo": "ts-node demo",
13
+ "demo": "tsx demo",
15
14
  "lint": "eslint ./src/**/**/* --fix",
16
- "test": "jest",
17
- "fix-paths": "yarn json -I -f ./dist/package.json -e \"this.module='./esm/index.js';this.main='./cjs/index.js';this.types='./types/index.d.ts'\"",
18
- "publish:next": "yarn && yarn build && yarn test --coverage true && npm publish --folder dist --tag beta",
15
+ "test": "vitest",
16
+ "test:coverage": "yarn test run --coverage",
17
+ "publish:next": "yarn && yarn build && yarn test:coverage && cd dist && npm publish --tag next",
19
18
  "postversion": "git push && git push --follow-tags",
20
19
  "release:beta": "npm version preminor --preid=beta -m \"chore(update): prelease %s β\"",
21
20
  "prerelease:beta": "npm version prerelease --preid=beta -m \"chore(update): prelease %s β\"",
@@ -23,8 +22,13 @@
23
22
  "release:minor": "git checkout master && npm version minor -m \"chore(update): release %s 🚀\"",
24
23
  "release:major": "git checkout master && npm version major -m \"chore(update): major release %s 💥\""
25
24
  },
25
+ "publishConfig": {
26
+ "access": "public",
27
+ "registry": "https://registry.npmjs.org"
28
+ },
26
29
  "dependencies": {
27
- "node-html-parser": "^6.1.4"
30
+ "cross-fetch": "^4.1.0",
31
+ "node-html-parser": "^7.0.1"
28
32
  },
29
33
  "repository": {
30
34
  "url": "git+https://github.com/bartholomej/node-csfd-api.git",
@@ -48,9 +52,12 @@
48
52
  "api"
49
53
  ],
50
54
  "engines": {
51
- "node": ">= 12"
55
+ "node": ">= 18"
52
56
  },
53
57
  "license": "MIT",
54
- "module": "./esm/index.js",
55
- "types": "./types/index.d.ts"
56
- }
58
+ "lint-staged": {
59
+ "*.ts": "eslint --cache --fix"
60
+ },
61
+ "module": "./index.js",
62
+ "types": "./index.d.ts"
63
+ }
@@ -0,0 +1,6 @@
1
+ import { CSFDCinema, CSFDCinemaPeriod } from '../interfaces/cinema.interface';
2
+ export declare class CinemaScraper {
3
+ private cinema;
4
+ cinemas(district?: number, period?: CSFDCinemaPeriod): Promise<CSFDCinema[]>;
5
+ private buildCinemas;
6
+ }
@@ -0,0 +1,34 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CinemaScraper = void 0;
4
+ const node_html_parser_1 = require("node-html-parser");
5
+ const fetchers_1 = require("../fetchers");
6
+ const vars_1 = require("../vars");
7
+ const cinema_helper_1 = require("./../helpers/cinema.helper");
8
+ class CinemaScraper {
9
+ async cinemas(district = 1, period = 'today') {
10
+ const url = (0, vars_1.cinemasUrl)(district, period);
11
+ const response = await (0, fetchers_1.fetchPage)(url);
12
+ const cinemasHtml = (0, node_html_parser_1.parse)(response);
13
+ const contentNode = cinemasHtml.querySelectorAll('#snippet--cinemas section.box');
14
+ this.buildCinemas(contentNode);
15
+ return this.cinema;
16
+ }
17
+ buildCinemas(contentNode) {
18
+ const cinemas = [];
19
+ contentNode.map((x) => {
20
+ var _a, _b;
21
+ const cinema = {
22
+ id: (0, cinema_helper_1.getCinemaId)(x),
23
+ name: (_a = (0, cinema_helper_1.parseCinema)(x)) === null || _a === void 0 ? void 0 : _a.name,
24
+ city: (_b = (0, cinema_helper_1.parseCinema)(x)) === null || _b === void 0 ? void 0 : _b.city,
25
+ url: (0, cinema_helper_1.getCinemaUrl)(x),
26
+ coords: (0, cinema_helper_1.getCoords)(x),
27
+ screenings: (0, cinema_helper_1.getGroupedFilmsByDate)(x)
28
+ };
29
+ cinemas.push(cinema);
30
+ });
31
+ this.cinema = cinemas;
32
+ }
33
+ }
34
+ exports.CinemaScraper = CinemaScraper;
@@ -0,0 +1,32 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.CreatorScraper = void 0;
4
+ const node_html_parser_1 = require("node-html-parser");
5
+ const fetchers_1 = require("../fetchers");
6
+ const creator_helper_1 = require("../helpers/creator.helper");
7
+ const vars_1 = require("../vars");
8
+ class CreatorScraper {
9
+ async creator(creatorId) {
10
+ const url = (0, vars_1.creatorUrl)(+creatorId);
11
+ const response = await (0, fetchers_1.fetchPage)(url);
12
+ const creatorHtml = (0, node_html_parser_1.parse)(response);
13
+ const asideNode = creatorHtml.querySelector('.creator-about');
14
+ const filmsNode = creatorHtml.querySelector('.creator-filmography');
15
+ this.buildCreator(+creatorId, asideNode, filmsNode);
16
+ return this.person;
17
+ }
18
+ buildCreator(id, asideEl, filmsNode) {
19
+ var _a, _b, _c;
20
+ this.person = {
21
+ id,
22
+ name: (0, creator_helper_1.getName)(asideEl),
23
+ birthday: (_a = (0, creator_helper_1.getBirthdayInfo)(asideEl)) === null || _a === void 0 ? void 0 : _a.birthday,
24
+ birthplace: (_b = (0, creator_helper_1.getBirthdayInfo)(asideEl)) === null || _b === void 0 ? void 0 : _b.birthPlace,
25
+ photo: (0, creator_helper_1.getPhoto)(asideEl),
26
+ age: ((_c = (0, creator_helper_1.getBirthdayInfo)(asideEl)) === null || _c === void 0 ? void 0 : _c.age) || null,
27
+ bio: (0, creator_helper_1.getBio)(asideEl),
28
+ films: (0, creator_helper_1.getFilms)(filmsNode)
29
+ };
30
+ }
31
+ }
32
+ exports.CreatorScraper = CreatorScraper;
@@ -1,13 +1,4 @@
1
1
  "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
2
  Object.defineProperty(exports, "__esModule", { value: true });
12
3
  exports.MovieScraper = void 0;
13
4
  const node_html_parser_1 = require("node-html-parser");
@@ -15,18 +6,16 @@ const fetchers_1 = require("../fetchers");
15
6
  const movie_helper_1 = require("../helpers/movie.helper");
16
7
  const vars_1 = require("../vars");
17
8
  class MovieScraper {
18
- movie(movieId) {
19
- return __awaiter(this, void 0, void 0, function* () {
20
- const url = (0, vars_1.movieUrl)(+movieId);
21
- const response = yield (0, fetchers_1.fetchPage)(url);
22
- const movieHtml = (0, node_html_parser_1.parse)(response);
23
- const pageClasses = movieHtml.querySelector('.page-content').classNames.split(' ');
24
- const asideNode = movieHtml.querySelector('.aside-movie-profile');
25
- const movieNode = movieHtml.querySelector('.main-movie-profile');
26
- const jsonLd = movieHtml.querySelector('script[type="application/ld+json"]').innerText;
27
- this.buildMovie(+movieId, movieNode, asideNode, pageClasses, jsonLd);
28
- return this.film;
29
- });
9
+ async movie(movieId) {
10
+ const url = (0, vars_1.movieUrl)(+movieId);
11
+ const response = await (0, fetchers_1.fetchPage)(url);
12
+ const movieHtml = (0, node_html_parser_1.parse)(response);
13
+ const pageClasses = movieHtml.querySelector('.page-content').classNames.split(' ');
14
+ const asideNode = movieHtml.querySelector('.aside-movie-profile');
15
+ const movieNode = movieHtml.querySelector('.main-movie-profile');
16
+ const jsonLd = movieHtml.querySelector('script[type="application/ld+json"]').innerText;
17
+ this.buildMovie(+movieId, movieNode, asideNode, pageClasses, jsonLd);
18
+ return this.film;
30
19
  }
31
20
  buildMovie(movieId, el, asideEl, pageClasses, jsonLd) {
32
21
  this.film = {
@@ -1,13 +1,4 @@
1
1
  "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
2
  Object.defineProperty(exports, "__esModule", { value: true });
12
3
  exports.SearchScraper = void 0;
13
4
  const node_html_parser_1 = require("node-html-parser");
@@ -17,19 +8,19 @@ const search_user_helper_1 = require("../helpers/search-user.helper");
17
8
  const search_helper_1 = require("../helpers/search.helper");
18
9
  const vars_1 = require("../vars");
19
10
  class SearchScraper {
20
- search(text) {
21
- return __awaiter(this, void 0, void 0, function* () {
22
- const url = (0, vars_1.searchUrl)(text);
23
- const response = yield (0, fetchers_1.fetchPage)(url);
24
- const html = (0, node_html_parser_1.parse)(response);
25
- const moviesNode = html.querySelectorAll('.main-movies article');
26
- const usersNode = html.querySelectorAll('.main-users article');
27
- return this.parseSearch(moviesNode, usersNode);
28
- });
11
+ async search(text) {
12
+ const url = (0, vars_1.searchUrl)(text);
13
+ const response = await (0, fetchers_1.fetchPage)(url);
14
+ const html = (0, node_html_parser_1.parse)(response);
15
+ const moviesNode = html.querySelectorAll('.main-movies article');
16
+ const usersNode = html.querySelectorAll('.main-users article');
17
+ const tvSeriesNode = html.querySelectorAll('.main-series article');
18
+ return this.parseSearch(moviesNode, usersNode, tvSeriesNode);
29
19
  }
30
- parseSearch(moviesNode, usersNode) {
20
+ parseSearch(moviesNode, usersNode, tvSeriesNode) {
31
21
  const movies = [];
32
22
  const users = [];
23
+ const tvSeries = [];
33
24
  moviesNode.map((m) => {
34
25
  const url = (0, search_helper_1.getUrl)(m);
35
26
  const movie = {
@@ -59,10 +50,28 @@ class SearchScraper {
59
50
  };
60
51
  users.push(user);
61
52
  });
53
+ tvSeriesNode.map((m) => {
54
+ const url = (0, search_helper_1.getUrl)(m);
55
+ const user = {
56
+ id: (0, global_helper_1.parseIdFromUrl)(url),
57
+ title: (0, search_helper_1.getTitle)(m),
58
+ year: (0, search_helper_1.getYear)(m),
59
+ url: `https://www.csfd.cz${url}`,
60
+ type: (0, search_helper_1.getType)(m),
61
+ colorRating: (0, search_helper_1.getColorRating)(m),
62
+ poster: (0, search_helper_1.getPoster)(m),
63
+ origins: (0, search_helper_1.getOrigins)(m),
64
+ creators: {
65
+ directors: (0, search_helper_1.parsePeople)(m, 'directors'),
66
+ actors: (0, search_helper_1.parsePeople)(m, 'actors')
67
+ }
68
+ };
69
+ tvSeries.push(user);
70
+ });
62
71
  const search = {
63
72
  movies: movies,
64
73
  users: users,
65
- tvSeries: [],
74
+ tvSeries: tvSeries,
66
75
  creators: []
67
76
  };
68
77
  return search;
@@ -1,13 +1,4 @@
1
1
  "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
2
  Object.defineProperty(exports, "__esModule", { value: true });
12
3
  exports.UserRatingsScraper = void 0;
13
4
  const node_html_parser_1 = require("node-html-parser");
@@ -18,36 +9,34 @@ class UserRatingsScraper {
18
9
  constructor() {
19
10
  this.films = [];
20
11
  }
21
- userRatings(user, config) {
22
- return __awaiter(this, void 0, void 0, function* () {
23
- let allMovies = [];
24
- const url = (0, vars_1.userRatingsUrl)(user);
25
- const response = yield (0, fetchers_1.fetchPage)(url);
26
- const items = (0, node_html_parser_1.parse)(response);
27
- const movies = items.querySelectorAll('.box-user-rating .table-container tbody tr');
28
- // Get number of pages
29
- const pagesNode = items.querySelector('.pagination');
30
- const pages = +(pagesNode === null || pagesNode === void 0 ? void 0 : pagesNode.childNodes[pagesNode.childNodes.length - 4].rawText) || 1;
31
- allMovies = this.getPage(config, movies);
32
- if (config === null || config === void 0 ? void 0 : config.allPages) {
33
- console.log('User', user, url);
34
- console.log('Fetching all pages', pages);
35
- for (let i = 2; i <= pages; i++) {
36
- console.log('Fetching page', i, 'out of', pages, '...');
37
- const url = (0, vars_1.userRatingsUrl)(user, i);
38
- const response = yield (0, fetchers_1.fetchPage)(url);
39
- const items = (0, node_html_parser_1.parse)(response);
40
- const movies = items.querySelectorAll('.box-user-rating .table-container tbody tr');
41
- allMovies = [...this.getPage(config, movies)];
42
- // Sleep
43
- if (config.allPagesDelay) {
44
- yield (0, user_ratings_helper_1.sleep)(config.allPagesDelay);
45
- }
12
+ async userRatings(user, config) {
13
+ let allMovies = [];
14
+ const url = (0, vars_1.userRatingsUrl)(user);
15
+ const response = await (0, fetchers_1.fetchPage)(url);
16
+ const items = (0, node_html_parser_1.parse)(response);
17
+ const movies = items.querySelectorAll('.box-user-rating .table-container tbody tr');
18
+ // Get number of pages
19
+ const pagesNode = items.querySelector('.pagination');
20
+ const pages = +(pagesNode === null || pagesNode === void 0 ? void 0 : pagesNode.childNodes[pagesNode.childNodes.length - 4].rawText) || 1;
21
+ allMovies = this.getPage(config, movies);
22
+ if (config === null || config === void 0 ? void 0 : config.allPages) {
23
+ console.log('User', user, url);
24
+ console.log('Fetching all pages', pages);
25
+ for (let i = 2; i <= pages; i++) {
26
+ console.log('Fetching page', i, 'out of', pages, '...');
27
+ const url = (0, vars_1.userRatingsUrl)(user, i);
28
+ const response = await (0, fetchers_1.fetchPage)(url);
29
+ const items = (0, node_html_parser_1.parse)(response);
30
+ const movies = items.querySelectorAll('.box-user-rating .table-container tbody tr');
31
+ allMovies = [...this.getPage(config, movies)];
32
+ // Sleep
33
+ if (config.allPagesDelay) {
34
+ await (0, user_ratings_helper_1.sleep)(config.allPagesDelay);
46
35
  }
47
- return allMovies;
48
36
  }
49
37
  return allMovies;
50
- });
38
+ }
39
+ return allMovies;
51
40
  }
52
41
  getPage(config, movies) {
53
42
  var _a, _b, _c, _d;
@@ -1,4 +1,6 @@
1
+ import { CSFDCinemaPeriod } from 'interfaces/cinema.interface';
1
2
  export declare const userRatingsUrl: (user: string | number, page?: number) => string;
2
3
  export declare const movieUrl: (movie: number) => string;
3
4
  export declare const creatorUrl: (creator: number | string) => string;
5
+ export declare const cinemasUrl: (district: number | string, period: CSFDCinemaPeriod) => string;
4
6
  export declare const searchUrl: (text: string) => string;
@@ -1,11 +1,15 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.searchUrl = exports.creatorUrl = exports.movieUrl = exports.userRatingsUrl = void 0;
3
+ exports.searchUrl = exports.cinemasUrl = exports.creatorUrl = exports.movieUrl = exports.userRatingsUrl = void 0;
4
4
  const userRatingsUrl = (user, page) => `https://www.csfd.cz/uzivatel/${encodeURIComponent(user)}/hodnoceni/${page ? '?page=' + page : ''}`;
5
5
  exports.userRatingsUrl = userRatingsUrl;
6
6
  const movieUrl = (movie) => `https://www.csfd.cz/film/${encodeURIComponent(movie)}/prehled/`;
7
7
  exports.movieUrl = movieUrl;
8
8
  const creatorUrl = (creator) => `https://www.csfd.cz/tvurce/${encodeURIComponent(creator)}`;
9
9
  exports.creatorUrl = creatorUrl;
10
+ const cinemasUrl = (district, period) => {
11
+ return `https://www.csfd.cz/kino/?period=${period}&district=${district}`;
12
+ };
13
+ exports.cinemasUrl = cinemasUrl;
10
14
  const searchUrl = (text) => `https://www.csfd.cz/hledat/?q=${encodeURIComponent(text)}`;
11
15
  exports.searchUrl = searchUrl;
package/cjs/index.js DELETED
@@ -1,50 +0,0 @@
1
- "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.csfd = exports.Csfd = void 0;
13
- const creator_service_1 = require("./services/creator.service");
14
- const movie_service_1 = require("./services/movie.service");
15
- const search_service_1 = require("./services/search.service");
16
- const user_ratings_service_1 = require("./services/user-ratings.service");
17
- class Csfd {
18
- constructor(userRatingsService, movieService, creatorService, searchService) {
19
- this.userRatingsService = userRatingsService;
20
- this.movieService = movieService;
21
- this.creatorService = creatorService;
22
- this.searchService = searchService;
23
- }
24
- userRatings(user, config) {
25
- return __awaiter(this, void 0, void 0, function* () {
26
- return this.userRatingsService.userRatings(user, config);
27
- });
28
- }
29
- movie(movie) {
30
- return __awaiter(this, void 0, void 0, function* () {
31
- return this.movieService.movie(+movie);
32
- });
33
- }
34
- creator(creator) {
35
- return __awaiter(this, void 0, void 0, function* () {
36
- return this.creatorService.creator(+creator);
37
- });
38
- }
39
- search(text) {
40
- return __awaiter(this, void 0, void 0, function* () {
41
- return this.searchService.search(text);
42
- });
43
- }
44
- }
45
- exports.Csfd = Csfd;
46
- const movieScraper = new movie_service_1.MovieScraper();
47
- const userRatingsScraper = new user_ratings_service_1.UserRatingsScraper();
48
- const creatorScraper = new creator_service_1.CreatorScraper();
49
- const searchScraper = new search_service_1.SearchScraper();
50
- exports.csfd = new Csfd(userRatingsScraper, movieScraper, creatorScraper, searchScraper);
@@ -1,43 +0,0 @@
1
- "use strict";
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- Object.defineProperty(exports, "__esModule", { value: true });
12
- exports.CreatorScraper = void 0;
13
- const node_html_parser_1 = require("node-html-parser");
14
- const fetchers_1 = require("../fetchers");
15
- const creator_helper_1 = require("../helpers/creator.helper");
16
- const vars_1 = require("../vars");
17
- class CreatorScraper {
18
- creator(creatorId) {
19
- return __awaiter(this, void 0, void 0, function* () {
20
- const url = (0, vars_1.creatorUrl)(+creatorId);
21
- const response = yield (0, fetchers_1.fetchPage)(url);
22
- const creatorHtml = (0, node_html_parser_1.parse)(response);
23
- const asideNode = creatorHtml.querySelector('.creator-about');
24
- const filmsNode = creatorHtml.querySelector('.creator-filmography');
25
- this.buildCreator(+creatorId, asideNode, filmsNode);
26
- return this.person;
27
- });
28
- }
29
- buildCreator(id, asideEl, filmsNode) {
30
- var _a, _b, _c;
31
- this.person = {
32
- id,
33
- name: (0, creator_helper_1.getName)(asideEl),
34
- birthday: (_a = (0, creator_helper_1.getBirthdayInfo)(asideEl)) === null || _a === void 0 ? void 0 : _a.birthday,
35
- birthplace: (_b = (0, creator_helper_1.getBirthdayInfo)(asideEl)) === null || _b === void 0 ? void 0 : _b.birthPlace,
36
- photo: (0, creator_helper_1.getPhoto)(asideEl),
37
- age: ((_c = (0, creator_helper_1.getBirthdayInfo)(asideEl)) === null || _c === void 0 ? void 0 : _c.age) || null,
38
- bio: (0, creator_helper_1.getBio)(asideEl),
39
- films: (0, creator_helper_1.getFilms)(filmsNode)
40
- };
41
- }
42
- }
43
- exports.CreatorScraper = CreatorScraper;
@@ -1,32 +0,0 @@
1
- // import fetch from 'cross-fetch';
2
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
3
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
4
- return new (P || (P = Promise))(function (resolve, reject) {
5
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
6
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
7
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
8
- step((generator = generator.apply(thisArg, _arguments || [])).next());
9
- });
10
- };
11
- const USER_AGENTS = [
12
- 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/87.0.4280.88 Safari/537.36',
13
- 'Mozilla/5.0 (iPhone; CPU iPhone OS 14_3 like Mac OS X) AppleWebKit/605.1.15 (KHTML, like Gecko) CriOS/87.0.4280.77 Mobile/15E148 Safari/604.1',
14
- 'Mozilla/5.0 (Linux; Android 10; SM-A205U) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/87.0.4280.101 Mobile Safari/537.36',
15
- 'Mozilla/5.0 (Linux; Android 10) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/87.0.4280.101 Mobile Safari/537.36'
16
- ];
17
- const headers = {
18
- 'User-Agent': USER_AGENTS[Math.floor(Math.random() * USER_AGENTS.length)]
19
- };
20
- export const fetchPage = (url) => __awaiter(void 0, void 0, void 0, function* () {
21
- try {
22
- const response = yield fetch(url, { headers });
23
- if (response.status >= 400 && response.status < 600) {
24
- throw new Error(`node-csfd-api: Bad response ${response.status} for url: ${url}`);
25
- }
26
- return yield response.text();
27
- }
28
- catch (e) {
29
- console.error(e);
30
- return 'Error';
31
- }
32
- });
@@ -1,73 +0,0 @@
1
- import { addProtocol, parseColor, parseIdFromUrl } from './global.helper';
2
- export const getColorRating = (el) => {
3
- return parseColor(el === null || el === void 0 ? void 0 : el.classNames.split(' ').pop());
4
- };
5
- export const getId = (url) => {
6
- if (url) {
7
- return parseIdFromUrl(url);
8
- }
9
- return null;
10
- };
11
- export const getName = (el) => {
12
- return el.querySelector('h1').innerText.trim();
13
- };
14
- export const getBirthdayInfo = (el) => {
15
- const text = el.querySelector('h1 + p').innerHTML.trim();
16
- const parts = text.split('\n');
17
- let birthday;
18
- let age;
19
- let birthPlace;
20
- if (parts.length) {
21
- const birthdayRow = parts.find((x) => x.includes('nar.'));
22
- const ageRow = parts.find((x) => x.includes('let)'));
23
- const birthPlaceRow = parts.find((x) => x.includes('<br>')); // Ugly but there is no other way to detect
24
- birthday = birthdayRow ? parseBirthday(birthdayRow) : '';
25
- age = ageRow ? +parseAge(ageRow) : null;
26
- birthPlace = birthPlaceRow ? parseBirthPlace(birthPlaceRow) : '';
27
- }
28
- return { birthday, age, birthPlace };
29
- };
30
- export const getBio = (el) => {
31
- return el.querySelector('.article-content p').text.trim().split('\n')[0].trim();
32
- };
33
- export const getPhoto = (el) => {
34
- const image = el.querySelector('img').attributes.src;
35
- return addProtocol(image);
36
- };
37
- export const parseBirthday = (text) => {
38
- return text.replace(/nar./g, '').trim();
39
- };
40
- export const parseAge = (text) => {
41
- return text.trim().replace(/\(/g, '').replace(/let\)/g, '').trim();
42
- };
43
- export const parseBirthPlace = (text) => {
44
- return text.trim().replace(/<br>/g, '').trim();
45
- };
46
- export const getFilms = (el) => {
47
- var _a;
48
- const filmNodes = (_a = el.querySelectorAll('.box')[0]) === null || _a === void 0 ? void 0 : _a.querySelectorAll('table tr');
49
- let yearCache;
50
- const films = filmNodes.map((filmNode) => {
51
- var _a, _b, _c;
52
- const id = getId((_a = filmNode.querySelector('td.name .film-title-name')) === null || _a === void 0 ? void 0 : _a.attributes.href);
53
- const title = (_b = filmNode.querySelector('.name')) === null || _b === void 0 ? void 0 : _b.text.trim();
54
- const year = +((_c = filmNode.querySelector('.year')) === null || _c === void 0 ? void 0 : _c.text.trim());
55
- const colorRating = getColorRating(filmNode.querySelector('.name .icon'));
56
- // Cache year from previous film because there is a gap between movies with same year
57
- if (year) {
58
- yearCache = +year;
59
- }
60
- if (id && title) {
61
- return {
62
- id,
63
- title,
64
- year: year || yearCache,
65
- colorRating
66
- };
67
- }
68
- return {};
69
- });
70
- // Remove empty objects
71
- const filmsUnique = films.filter((value) => Object.keys(value).length !== 0);
72
- return filmsUnique;
73
- };