Skip to content

Commit 3419598

Browse files
authored
Merge branch 'main' into feat/lesson10
2 parents bcb4104 + d537950 commit 3419598

File tree

3 files changed

+98
-1
lines changed

3 files changed

+98
-1
lines changed
Lines changed: 45 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,45 @@
1+
import csv from 'csv-parser';
2+
import fs from 'fs';
3+
import { Credit, MediaItem } from '../models/index.js';
4+
import { Loader } from './loader.js';
5+
6+
export class AngelicaCastilloLoader implements Loader {
7+
getLoaderName(): string {
8+
return 'angelicacastillo';
9+
}
10+
11+
async loadData(): Promise<MediaItem[]> {
12+
const credits = await this.loadCredits();
13+
const mediaItems = await this.loadMediaItems();
14+
15+
console.log(
16+
`Loaded ${credits.length} credits and ${mediaItems.length} media items`,
17+
);
18+
19+
return [...mediaItems.values()];
20+
}
21+
22+
async loadMediaItems(): Promise<MediaItem[]> {
23+
const media = [];
24+
const readable = fs
25+
.createReadStream('data/media_items.csv', 'utf-8')
26+
.pipe(csv());
27+
for await (const row of readable) {
28+
const { id, type, title, year } = row;
29+
media.push(new MediaItem(id, title, type, year, []));
30+
}
31+
return media;
32+
}
33+
34+
async loadCredits(): Promise<Credit[]> {
35+
const credits = [];
36+
const readable = fs
37+
.createReadStream('data/credits.csv', 'utf-8')
38+
.pipe(csv());
39+
for await (const row of readable) {
40+
const { media_item_id, role, name } = row;
41+
credits.push(new Credit(media_item_id, name, role));
42+
}
43+
return credits;
44+
}
45+
}

lesson_10/libraries/src/loaders/loaders.module.ts

Lines changed: 9 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1,12 +1,20 @@
11
import { Module } from '@nestjs/common';
2+
import { AngelicaCastilloLoader } from './angelica_castillo_loader.js';
23
import { AnthonyMaysLoader } from './anthony_mays_loader.js';
34
import { JamesCapparellLoader } from './james_capparell_loader.js';
5+
import { NileJacksonLoader } from './nile_jackson_loader.js';
46
import { XavierCruzLoader } from './xavier_cruz_loader.js';
57

68
export const Loaders = Symbol.for('Loaders');
79

810
// Add your quiz provider here.
9-
const LOADER_PROVIDERS = [AnthonyMaysLoader, JamesCapparellLoader, XavierCruzLoader];
11+
const LOADER_PROVIDERS = [
12+
AnthonyMaysLoader,
13+
AngelicaCastilloLoader,
14+
JamesCapparellLoader,
15+
NileJacksonLoader,
16+
XavierCruzLoader,
17+
];
1018

1119
@Module({
1220
providers: [
Lines changed: 44 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,44 @@
1+
import csv from 'csv-parser';
2+
import fs from 'fs';
3+
import { Credit, MediaItem } from '../models/index.js';
4+
import { Loader } from './loader.js';
5+
6+
export class NileJacksonLoader implements Loader {
7+
getLoaderName(): string {
8+
return 'nilejackson';
9+
}
10+
11+
async loadData(): Promise<MediaItem[]> {
12+
const credits = await this.loadCredits();
13+
const mediaItems = await this.loadMediaItems();
14+
15+
console.log(
16+
`Loaded ${credits.length} credits and ${mediaItems.length} media items`,
17+
);
18+
19+
return [...mediaItems.values()];
20+
}
21+
async loadMediaItems(): Promise<MediaItem[]> {
22+
const mediaItems = [];
23+
const readable = fs
24+
.createReadStream('data/media_items.csv', 'utf-8')
25+
.pipe(csv());
26+
for await (const row of readable) {
27+
const { id, title, type, year } = row;
28+
mediaItems.push(new MediaItem(id, title, type, year, []));
29+
}
30+
return mediaItems;
31+
}
32+
33+
async loadCredits(): Promise<Credit[]> {
34+
const credits = [];
35+
const readable = fs
36+
.createReadStream('data/credits.csv', 'utf-8')
37+
.pipe(csv());
38+
for await (const row of readable) {
39+
const { media_item_id, role, name } = row;
40+
credits.push(new Credit(media_item_id, name, role));
41+
}
42+
return credits;
43+
}
44+
}

0 commit comments

Comments
 (0)