Skip to content

Commit 73fe7c3

Browse files
authored
Merge branch 'code-differently:main' into Lesson_12
2 parents 811220e + 8d6467e commit 73fe7c3

File tree

4 files changed

+145
-2
lines changed

4 files changed

+145
-2
lines changed

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

Lines changed: 6 additions & 2 deletions
Original file line numberDiff line numberDiff line change
@@ -11,15 +11,16 @@ import { JamesCapparellLoader } from './james_capparell_loader.js';
1111
import { JosephCaballeroLoader } from './joseph_caballero_loader.js';
1212
import { KimberleeHaldaneLoader } from './kimberlee_haldane_loader.js';
1313
import { NileJacksonLoader } from './nile_jackson_loader.js';
14+
import { OyeyemiJimohLoader } from './oyeyemi_jimoh_loader.js';
1415
import { PabloLimonParedesLoader } from './pablo_limon_paredes_loader.js';
16+
import { ShawnDunsmoreLoader } from './shawn_dunsmore_loader.js';
1517
import { TommyTranLoader } from './tommy_tran_loader.js';
1618
import { XavierCruzLoader } from './xavier_cruz_loader.js';
19+
import { YafiahAbdullahLoader } from './yafiah_abdullah_loader.js';
1720
import { ZionBuchananLoader } from './zion_buchanan_loader.js';
1821

1922
export const Loaders = Symbol.for('Loaders');
2023

21-
// Add your quiz provider here.
22-
2324
const LOADER_PROVIDERS = [
2425
AmiyahJonesLoader,
2526
AngelicaCastilloLoader,
@@ -32,9 +33,12 @@ const LOADER_PROVIDERS = [
3233
JosephCaballeroLoader,
3334
KimberleeHaldaneLoader,
3435
NileJacksonLoader,
36+
OyeyemiJimohLoader,
3537
PabloLimonParedesLoader,
38+
ShawnDunsmoreLoader,
3639
TommyTranLoader,
3740
XavierCruzLoader,
41+
YafiahAbdullahLoader,
3842
ZionBuchananLoader,
3943
];
4044

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 OyeyemiJimohLoader implements Loader {
7+
getLoaderName(): string {
8+
return 'oyeyemijimoh';
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 mediaItems = [];
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+
mediaItems.push(new MediaItem(id, title, type, year, []));
30+
}
31+
return mediaItems;
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+
}
Lines changed: 47 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,47 @@
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 ShawnDunsmoreLoader implements Loader {
7+
getLoaderName(): string {
8+
return 'shawndunsmore';
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 mediaItems: MediaItem[] = [];
24+
const readable = fs
25+
.createReadStream('data/media_items.csv', 'utf-8')
26+
.pipe(csv());
27+
28+
for await (const row of readable) {
29+
const { id, title, type, year } = row;
30+
mediaItems.push(new MediaItem(id, title, type, year, []));
31+
}
32+
33+
return mediaItems;
34+
}
35+
36+
async loadCredits(): Promise<Credit[]> {
37+
const credits = [];
38+
const readable = fs
39+
.createReadStream('data/credits.csv', 'utf-8')
40+
.pipe(csv());
41+
for await (const row of readable) {
42+
const { media_item_id, role, name } = row;
43+
credits.push(new Credit(media_item_id, name, role));
44+
}
45+
return credits;
46+
}
47+
}
Lines changed: 47 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,47 @@
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 YafiahAbdullahLoader implements Loader {
7+
getLoaderName(): string {
8+
return 'yafiahabdullah';
9+
}
10+
11+
async loadData(): Promise<MediaItem[]> {
12+
const [credits, mediaItems] = await Promise.all([
13+
this.loadCredits(),
14+
this.loadMediaItems(),
15+
]);
16+
17+
console.log(
18+
`Loaded ${credits.length} credits and ${mediaItems.length} media items`,
19+
);
20+
21+
return [...mediaItems.values()];
22+
}
23+
24+
async loadMediaItems(): Promise<MediaItem[]> {
25+
const media = [];
26+
const readable = fs
27+
.createReadStream('data/media_items.csv', 'utf-8')
28+
.pipe(csv());
29+
for await (const row of readable) {
30+
const { id, type, title, year } = row;
31+
media.push(new MediaItem(id, title, type, year, []));
32+
}
33+
return media;
34+
}
35+
36+
async loadCredits(): Promise<Credit[]> {
37+
const credits = [];
38+
const readable = fs
39+
.createReadStream('data/credits.csv', 'utf-8')
40+
.pipe(csv());
41+
for await (const row of readable) {
42+
const { media_item_id, role, name } = row;
43+
credits.push(new Credit(media_item_id, name, role));
44+
}
45+
return credits;
46+
}
47+
}

0 commit comments

Comments
 (0)