From 40a3b85fad990c641ec61aac5705180140a03ce7 Mon Sep 17 00:00:00 2001 From: Logan Van Hook <55011072+lgv-0@users.noreply.github.com> Date: Mon, 20 Apr 2020 16:29:56 -0400 Subject: [PATCH] Entities Seeding (#106) * Update entities for voting and statistics * Initialize migrations, setup seeding (Canon & Cohort) * Add default parent account * Seed 4 default children * Add vote counter to child * Add comments * Remove unused imports * Setup story seeding * Illustration seeding, fix null contraints * Add readability seeds to avoid py crash * Warning comment, possibly #96? --- src/database/entity/Child.ts | 32 ++-- src/database/entity/Cohort.ts | 5 +- src/database/entity/Illustrations.ts | 9 +- src/database/entity/Matches.ts | 2 +- src/database/entity/Stories.ts | 9 +- .../migration/1587051617754-MainMigration.ts | 116 +++++++++++++++ src/database/seeds/seeds.ts | 137 ++++++++++++++++++ 7 files changed, 279 insertions(+), 31 deletions(-) create mode 100644 src/database/migration/1587051617754-MainMigration.ts create mode 100644 src/database/seeds/seeds.ts diff --git a/src/database/entity/Child.ts b/src/database/entity/Child.ts index 5a854e6a..ac17d0a8 100644 --- a/src/database/entity/Child.ts +++ b/src/database/entity/Child.ts @@ -30,28 +30,28 @@ class Child { @Column((type) => Progress) progress: Progress; - @ManyToOne( - (type) => Parent, - (parent) => parent.children - ) + @Column({ nullable: true }) + total_points: number; + + @Column({ nullable: true }) + wins: number; + + @Column({ nullable: true }) + losses: number; + + @Column({ nullable: true }) + votes: number; + + @ManyToOne((type) => Parent, (parent) => parent.children) parent: Parent; - @ManyToOne( - (type) => Cohort, - (cohort) => cohort.children - ) + @ManyToOne((type) => Cohort, (cohort) => cohort.children) cohort: Cohort; - @OneToMany( - (type) => Illustrations, - (illustrations) => illustrations.child - ) + @OneToMany((type) => Illustrations, (illustrations) => illustrations.child) illustrations: Illustrations[]; - @OneToMany( - (type) => Stories, - (stories) => stories.child - ) + @OneToMany((type) => Stories, (stories) => stories.child) stories: Stories[]; } diff --git a/src/database/entity/Cohort.ts b/src/database/entity/Cohort.ts index 902a8bb7..1f189b70 100644 --- a/src/database/entity/Cohort.ts +++ b/src/database/entity/Cohort.ts @@ -20,10 +20,7 @@ class Cohort { @Column((type) => DueDates) dueDates: DueDates; - @OneToMany( - (type) => Child, - (child) => child.cohort - ) + @OneToMany((type) => Child, (child) => child.cohort) children: Child[]; } diff --git a/src/database/entity/Illustrations.ts b/src/database/entity/Illustrations.ts index 417382b4..e31ab2c6 100644 --- a/src/database/entity/Illustrations.ts +++ b/src/database/entity/Illustrations.ts @@ -9,11 +9,7 @@ class Illustrations { @Column() childId: number; - @ManyToOne( - (type) => Child, - (child) => child.illustrations, - { onDelete: 'CASCADE' } - ) + @ManyToOne((type) => Child, (child) => child.illustrations, { onDelete: 'CASCADE' }) @JoinColumn() child: Child; @@ -25,6 +21,9 @@ class Illustrations { @Column({ nullable: true }) points: number; + + @Column({ nullable: true }) + votes: number; } export { Illustrations }; diff --git a/src/database/entity/Matches.ts b/src/database/entity/Matches.ts index 5be8f3e2..7fef6aeb 100644 --- a/src/database/entity/Matches.ts +++ b/src/database/entity/Matches.ts @@ -1,4 +1,4 @@ -import { Column, PrimaryGeneratedColumn, OneToMany, ManyToOne, Entity } from 'typeorm'; +import { Column, PrimaryGeneratedColumn, Entity } from 'typeorm'; @Entity() class Matches { diff --git a/src/database/entity/Stories.ts b/src/database/entity/Stories.ts index de377c03..6de24655 100644 --- a/src/database/entity/Stories.ts +++ b/src/database/entity/Stories.ts @@ -10,11 +10,7 @@ class Stories { @Column() childId: number; - @ManyToOne( - (type) => Child, - (child) => child.stories, - { onDelete: 'CASCADE' } - ) + @ManyToOne((type) => Child, (child) => child.stories, { onDelete: 'CASCADE' }) @JoinColumn() child: Child; @@ -30,6 +26,9 @@ class Stories { @Column({ nullable: true }) points: number; + @Column({ nullable: true }) + votes: number; + @Column({ type: 'double precision', nullable: true }) flesch_reading_ease: number; diff --git a/src/database/migration/1587051617754-MainMigration.ts b/src/database/migration/1587051617754-MainMigration.ts new file mode 100644 index 00000000..59780951 --- /dev/null +++ b/src/database/migration/1587051617754-MainMigration.ts @@ -0,0 +1,116 @@ +import { MigrationInterface, QueryRunner } from 'typeorm'; +import { Cohort, Canon, Parent, Child, Stories, Illustrations } from '../../database/entity'; +import { + CohortSeed, + CanonSeed, + ParentSeed, + ChildSeed, + StorySeed, + IllustrationSeed, +} from '../seeds/seeds'; +import Stripe from 'stripe'; + +export class MainMigration1587051617754 implements MigrationInterface { + name = 'MainMigration1587051617754'; + + public async up(queryRunner: QueryRunner): Promise { + /* Basic query structure copied from generating a new migration (migration:generate) */ + await queryRunner.query( + `CREATE TABLE "admin" ("id" SERIAL NOT NULL, "email" character varying NOT NULL, "password" character varying NOT NULL, "temptoken" character varying, "role" character varying NOT NULL, CONSTRAINT "UQ_de87485f6489f5d0995f5841952" UNIQUE ("email"), CONSTRAINT "PK_e032310bcef831fb83101899b10" PRIMARY KEY ("id"))`, + undefined + ); + await queryRunner.query( + `CREATE TABLE "canon" ("week" integer NOT NULL, "base64" character varying NOT NULL, "altbase64" character varying, CONSTRAINT "PK_8c1bfa026b3b545879ae7437a05" PRIMARY KEY ("week"))`, + undefined + ); + await queryRunner.query( + `CREATE TABLE "parent" ("id" SERIAL NOT NULL, "name" character varying, "email" character varying NOT NULL, "password" character varying NOT NULL, "stripeID" character varying, CONSTRAINT "UQ_9158391af7b8ca4911efaad8a73" UNIQUE ("email"), CONSTRAINT "PK_bf93c41ee1ae1649869ebd05617" PRIMARY KEY ("id"))`, + undefined + ); + await queryRunner.query( + `CREATE TABLE "cohort" ("id" SERIAL NOT NULL, "name" character varying NOT NULL, "week" integer NOT NULL, "activity" character varying NOT NULL, "dueDatesReading" TIMESTAMP NOT NULL, "dueDatesWriting" TIMESTAMP NOT NULL, "dueDatesDrawing" TIMESTAMP NOT NULL, "dueDatesTeamreview" TIMESTAMP, "dueDatesRandomreview" TIMESTAMP, "dueDatesResults" TIMESTAMP, CONSTRAINT "PK_4fb3cca38dc4b461110344e5f9b" PRIMARY KEY ("id"))`, + undefined + ); + await queryRunner.query( + `CREATE TABLE "illustrations" ("id" SERIAL NOT NULL, "childId" integer NOT NULL, "week" integer NOT NULL, "illustration" character varying, "points" integer, "votes" integer, CONSTRAINT "PK_ec4a601172b41459d76aeb1f02f" PRIMARY KEY ("id"))`, + undefined + ); + await queryRunner.query( + `CREATE TABLE "stories" ("id" SERIAL NOT NULL, "childId" integer NOT NULL, "week" integer NOT NULL, "storyText" character varying, "points" integer, "votes" integer, "flesch_reading_ease" double precision, "smog_index" double precision, "flesch_kincaid_grade" double precision, "coleman_liau_index" double precision, "automated_readability_index" double precision, "dale_chall_readability_score" double precision, "difficult_words" double precision, "linsear_write_formula" double precision, "gunning_fog" double precision, "consolidated_score" character varying, "doc_length" integer, "quote_count" integer, "storyPage1" character varying, "storyPage2" character varying, "storyPage3" character varying, "storyPage4" character varying, "storyPage5" character varying, "transcribedTextT_page1" character varying, "transcribedTextT_page2" character varying, "transcribedTextT_page3" character varying, "transcribedTextT_page4" character varying, "transcribedTextT_page5" character varying, CONSTRAINT "PK_bb6f880b260ed96c452b32a39f0" PRIMARY KEY ("id"))`, + undefined + ); + await queryRunner.query( + `CREATE TABLE "child" ("id" SERIAL NOT NULL, "username" character varying NOT NULL, "grade" integer NOT NULL, "subscription" boolean NOT NULL DEFAULT false, "avatar" character varying, "total_points" integer, "wins" integer, "losses" integer, "votes" integer, "parentId" integer, "cohortId" integer, "preferencesDyslexia" boolean NOT NULL DEFAULT false, "progressReading" boolean NOT NULL DEFAULT false, "progressWriting" boolean NOT NULL DEFAULT false, "progressDrawing" boolean NOT NULL DEFAULT false, "progressTeamreview" boolean NOT NULL DEFAULT false, "progressRandomreview" boolean NOT NULL DEFAULT false, CONSTRAINT "PK_4609b9b323ca37c6bc435ec4b6b" PRIMARY KEY ("id"))`, + undefined + ); + await queryRunner.query( + `CREATE TABLE "matches" ("id" SERIAL NOT NULL, "team1_child1_id" integer, "team1_child2_id" integer, "team2_child1_id" integer, "team2_child2_id" integer, "week" integer, CONSTRAINT "PK_8a22c7b2e0828988d51256117f4" PRIMARY KEY ("id"))`, + undefined + ); + await queryRunner.query( + `ALTER TABLE "illustrations" ADD CONSTRAINT "FK_2675728b1c00556cd980c77b849" FOREIGN KEY ("childId") REFERENCES "child"("id") ON DELETE CASCADE ON UPDATE NO ACTION`, + undefined + ); + await queryRunner.query( + `ALTER TABLE "stories" ADD CONSTRAINT "FK_71d050c35abe5d607bb746503af" FOREIGN KEY ("childId") REFERENCES "child"("id") ON DELETE CASCADE ON UPDATE NO ACTION`, + undefined + ); + await queryRunner.query( + `ALTER TABLE "child" ADD CONSTRAINT "FK_8a2f35051e01ce9c6656af13c7c" FOREIGN KEY ("parentId") REFERENCES "parent"("id") ON DELETE NO ACTION ON UPDATE NO ACTION`, + undefined + ); + await queryRunner.query( + `ALTER TABLE "child" ADD CONSTRAINT "FK_faecc77a0cf169a4c97f0a8d812" FOREIGN KEY ("cohortId") REFERENCES "cohort"("id") ON DELETE NO ACTION ON UPDATE NO ACTION`, + undefined + ); + /******************/ + + /* SEEDING - Need to use queryRunner's Manager to get the proper connection info */ + await queryRunner.manager.getRepository(Cohort).save(CohortSeed); + await queryRunner.manager.getRepository(Canon).save(CanonSeed); + + //Should match auth exactly + let { id: stripeID } = await new Stripe('sk_test_v666XmnGJcP1Oz3GBg2iFmvd004Q3qp4jZ', { + apiVersion: '2019-12-03', + typescript: true, + }).customers.create({ + email: ParentSeed.email, + }); + ParentSeed.stripeID = stripeID; + await queryRunner.manager.getRepository(Parent).save(ParentSeed); + + await queryRunner.manager.getRepository(Child).save(ChildSeed); + + await queryRunner.manager.getRepository(Stories).save(StorySeed); + + await queryRunner.manager.getRepository(Illustrations).save(IllustrationSeed); + /******************/ + } + + public async down(queryRunner: QueryRunner): Promise { + await queryRunner.query( + `ALTER TABLE "child" DROP CONSTRAINT "FK_faecc77a0cf169a4c97f0a8d812"`, + undefined + ); + await queryRunner.query( + `ALTER TABLE "child" DROP CONSTRAINT "FK_8a2f35051e01ce9c6656af13c7c"`, + undefined + ); + await queryRunner.query( + `ALTER TABLE "stories" DROP CONSTRAINT "FK_71d050c35abe5d607bb746503af"`, + undefined + ); + await queryRunner.query( + `ALTER TABLE "illustrations" DROP CONSTRAINT "FK_2675728b1c00556cd980c77b849"`, + undefined + ); + await queryRunner.query(`DROP TABLE "matches"`, undefined); + await queryRunner.query(`DROP TABLE "child"`, undefined); + await queryRunner.query(`DROP TABLE "stories"`, undefined); + await queryRunner.query(`DROP TABLE "illustrations"`, undefined); + await queryRunner.query(`DROP TABLE "cohort"`, undefined); + await queryRunner.query(`DROP TABLE "parent"`, undefined); + await queryRunner.query(`DROP TABLE "canon"`, undefined); + await queryRunner.query(`DROP TABLE "admin"`, undefined); + } +} diff --git a/src/database/seeds/seeds.ts b/src/database/seeds/seeds.ts new file mode 100644 index 00000000..6757e524 --- /dev/null +++ b/src/database/seeds/seeds.ts @@ -0,0 +1,137 @@ +import { Cohort, Canon, Parent, Child, Stories, Illustrations } from '../entity'; +import { DueDates } from '../entity/DueDates'; +import { hashSync } from 'bcryptjs'; +import { Preferences } from '../entity/Preferences'; +import { Pages, Transcribed_Pages } from '../entity/Pages'; +import { Progress } from '../entity/Progress'; + +/* Non-Nullable vars and columns with no default function MUST be defined */ + +let c1 = new Cohort(); +c1.name = 'Main'; +c1.week = 1; +c1.activity = 'reading'; +c1.dueDates = new DueDates(); +c1.dueDates.reading = new Date(); +c1.dueDates.writing = new Date(); +c1.dueDates.drawing = new Date(); + +export const CohortSeed = [c1]; + +let CanonStory = new Canon(); +CanonStory.week = 1; +CanonStory.base64 = //Non-Dyslexic PDF story for reading portion + 'JVBERi0xLjMNCiXi48/TDQoNCjEgMCBvYmoNCjw8DQovVHlwZSAvQ2F0YWxvZw0KL091dGxpbmVzIDIgMCBSDQovUGFnZXMgMyAwIFINCj4+DQplbmRvYmoNCg0KMiAwIG9iag0KPDwNCi9UeXBlIC9PdXRsaW5lcw0KL0NvdW50IDANCj4+DQplbmRvYmoNCg0KMyAwIG9iag0KPDwNCi9UeXBlIC9QYWdlcw0KL0NvdW50IDINCi9LaWRzIFsgNCAwIFIgNiAwIFIgXSANCj4+DQplbmRvYmoNCg0KNCAwIG9iag0KPDwNCi9UeXBlIC9QYWdlDQovUGFyZW50IDMgMCBSDQovUmVzb3VyY2VzIDw8DQovRm9udCA8PA0KL0YxIDkgMCBSIA0KPj4NCi9Qcm9jU2V0IDggMCBSDQo+Pg0KL01lZGlhQm94IFswIDAgNjEyLjAwMDAgNzkyLjAwMDBdDQovQ29udGVudHMgNSAwIFINCj4+DQplbmRvYmoNCg0KNSAwIG9iag0KPDwgL0xlbmd0aCAxMDc0ID4+DQpzdHJlYW0NCjIgSg0KQlQNCjAgMCAwIHJnDQovRjEgMDAyNyBUZg0KNTcuMzc1MCA3MjIuMjgwMCBUZA0KKCBBIFNpbXBsZSBQREYgRmlsZSApIFRqDQpFVA0KQlQNCi9GMSAwMDEwIFRmDQo2OS4yNTAwIDY4OC42MDgwIFRkDQooIFRoaXMgaXMgYSBzbWFsbCBkZW1vbnN0cmF0aW9uIC5wZGYgZmlsZSAtICkgVGoNCkVUDQpCVA0KL0YxIDAwMTAgVGYNCjY5LjI1MDAgNjY0LjcwNDAgVGQNCigganVzdCBmb3IgdXNlIGluIHRoZSBWaXJ0dWFsIE1lY2hhbmljcyB0dXRvcmlhbHMuIE1vcmUgdGV4dC4gQW5kIG1vcmUgKSBUag0KRVQNCkJUDQovRjEgMDAxMCBUZg0KNjkuMjUwMCA2NTIuNzUyMCBUZA0KKCB0ZXh0LiBBbmQgbW9yZSB0ZXh0LiBBbmQgbW9yZSB0ZXh0LiBBbmQgbW9yZSB0ZXh0LiApIFRqDQpFVA0KQlQNCi9GMSAwMDEwIFRmDQo2OS4yNTAwIDYyOC44NDgwIFRkDQooIEFuZCBtb3JlIHRleHQuIEFuZCBtb3JlIHRleHQuIEFuZCBtb3JlIHRleHQuIEFuZCBtb3JlIHRleHQuIEFuZCBtb3JlICkgVGoNCkVUDQpCVA0KL0YxIDAwMTAgVGYNCjY5LjI1MDAgNjE2Ljg5NjAgVGQNCiggdGV4dC4gQW5kIG1vcmUgdGV4dC4gQm9yaW5nLCB6enp6ei4gQW5kIG1vcmUgdGV4dC4gQW5kIG1vcmUgdGV4dC4gQW5kICkgVGoNCkVUDQpCVA0KL0YxIDAwMTAgVGYNCjY5LjI1MDAgNjA0Ljk0NDAgVGQNCiggbW9yZSB0ZXh0LiBBbmQgbW9yZSB0ZXh0LiBBbmQgbW9yZSB0ZXh0LiBBbmQgbW9yZSB0ZXh0LiBBbmQgbW9yZSB0ZXh0LiApIFRqDQpFVA0KQlQNCi9GMSAwMDEwIFRmDQo2OS4yNTAwIDU5Mi45OTIwIFRkDQooIEFuZCBtb3JlIHRleHQuIEFuZCBtb3JlIHRleHQuICkgVGoNCkVUDQpCVA0KL0YxIDAwMTAgVGYNCjY5LjI1MDAgNTY5LjA4ODAgVGQNCiggQW5kIG1vcmUgdGV4dC4gQW5kIG1vcmUgdGV4dC4gQW5kIG1vcmUgdGV4dC4gQW5kIG1vcmUgdGV4dC4gQW5kIG1vcmUgKSBUag0KRVQNCkJUDQovRjEgMDAxMCBUZg0KNjkuMjUwMCA1NTcuMTM2MCBUZA0KKCB0ZXh0LiBBbmQgbW9yZSB0ZXh0LiBBbmQgbW9yZSB0ZXh0LiBFdmVuIG1vcmUuIENvbnRpbnVlZCBvbiBwYWdlIDIgLi4uKSBUag0KRVQNCmVuZHN0cmVhbQ0KZW5kb2JqDQoNCjYgMCBvYmoNCjw8DQovVHlwZSAvUGFnZQ0KL1BhcmVudCAzIDAgUg0KL1Jlc291cmNlcyA8PA0KL0ZvbnQgPDwNCi9GMSA5IDAgUiANCj4+DQovUHJvY1NldCA4IDAgUg0KPj4NCi9NZWRpYUJveCBbMCAwIDYxMi4wMDAwIDc5Mi4wMDAwXQ0KL0NvbnRlbnRzIDcgMCBSDQo+Pg0KZW5kb2JqDQoNCjcgMCBvYmoNCjw8IC9MZW5ndGggNjc2ID4+DQpzdHJlYW0NCjIgSg0KQlQNCjAgMCAwIHJnDQovRjEgMDAyNyBUZg0KNTcuMzc1MCA3MjIuMjgwMCBUZA0KKCBTaW1wbGUgUERGIEZpbGUgMiApIFRqDQpFVA0KQlQNCi9GMSAwMDEwIFRmDQo2OS4yNTAwIDY4OC42MDgwIFRkDQooIC4uLmNvbnRpbnVlZCBmcm9tIHBhZ2UgMS4gWWV0IG1vcmUgdGV4dC4gQW5kIG1vcmUgdGV4dC4gQW5kIG1vcmUgdGV4dC4gKSBUag0KRVQNCkJUDQovRjEgMDAxMCBUZg0KNjkuMjUwMCA2NzYuNjU2MCBUZA0KKCBBbmQgbW9yZSB0ZXh0LiBBbmQgbW9yZSB0ZXh0LiBBbmQgbW9yZSB0ZXh0LiBBbmQgbW9yZSB0ZXh0LiBBbmQgbW9yZSApIFRqDQpFVA0KQlQNCi9GMSAwMDEwIFRmDQo2OS4yNTAwIDY2NC43MDQwIFRkDQooIHRleHQuIE9oLCBob3cgYm9yaW5nIHR5cGluZyB0aGlzIHN0dWZmLiBCdXQgbm90IGFzIGJvcmluZyBhcyB3YXRjaGluZyApIFRqDQpFVA0KQlQNCi9GMSAwMDEwIFRmDQo2OS4yNTAwIDY1Mi43NTIwIFRkDQooIHBhaW50IGRyeS4gQW5kIG1vcmUgdGV4dC4gQW5kIG1vcmUgdGV4dC4gQW5kIG1vcmUgdGV4dC4gQW5kIG1vcmUgdGV4dC4gKSBUag0KRVQNCkJUDQovRjEgMDAxMCBUZg0KNjkuMjUwMCA2NDAuODAwMCBUZA0KKCBCb3JpbmcuICBNb3JlLCBhIGxpdHRsZSBtb3JlIHRleHQuIFRoZSBlbmQsIGFuZCBqdXN0IGFzIHdlbGwuICkgVGoNCkVUDQplbmRzdHJlYW0NCmVuZG9iag0KDQo4IDAgb2JqDQpbL1BERiAvVGV4dF0NCmVuZG9iag0KDQo5IDAgb2JqDQo8PA0KL1R5cGUgL0ZvbnQNCi9TdWJ0eXBlIC9UeXBlMQ0KL05hbWUgL0YxDQovQmFzZUZvbnQgL0hlbHZldGljYQ0KL0VuY29kaW5nIC9XaW5BbnNpRW5jb2RpbmcNCj4+DQplbmRvYmoNCg0KMTAgMCBvYmoNCjw8DQovQ3JlYXRvciAoUmF2ZSBcKGh0dHA6Ly93d3cubmV2cm9uYS5jb20vcmF2ZVwpKQ0KL1Byb2R1Y2VyIChOZXZyb25hIERlc2lnbnMpDQovQ3JlYXRpb25EYXRlIChEOjIwMDYwMzAxMDcyODI2KQ0KPj4NCmVuZG9iag0KDQp4cmVmDQowIDExDQowMDAwMDAwMDAwIDY1NTM1IGYNCjAwMDAwMDAwMTkgMDAwMDAgbg0KMDAwMDAwMDA5MyAwMDAwMCBuDQowMDAwMDAwMTQ3IDAwMDAwIG4NCjAwMDAwMDAyMjIgMDAwMDAgbg0KMDAwMDAwMDM5MCAwMDAwMCBuDQowMDAwMDAxNTIyIDAwMDAwIG4NCjAwMDAwMDE2OTAgMDAwMDAgbg0KMDAwMDAwMjQyMyAwMDAwMCBuDQowMDAwMDAyNDU2IDAwMDAwIG4NCjAwMDAwMDI1NzQgMDAwMDAgbg0KDQp0cmFpbGVyDQo8PA0KL1NpemUgMTENCi9Sb290IDEgMCBSDQovSW5mbyAxMCAwIFINCj4+DQoNCnN0YXJ0eHJlZg0KMjcxNA0KJSVFT0YNCg=='; + +export const CanonSeed = [CanonStory]; + +let ParentDefault = new Parent(); +ParentDefault.email = 'test@test.com'; +ParentDefault.name = 'TestFirst TestLast'; +ParentDefault.password = hashSync('testpass', parseInt(process.env.SALT || '3', 10)); + +export const ParentSeed = ParentDefault; + +function MakeChild(name, grade, points, wins, losses, dyslexia, progress) { + let Temp = new Child(); + + Temp.username = name; + Temp.subscription = true; //Bypassing add-a-card + Temp.cohort = c1; //Tying the new child to the new cohort + Temp.parent = ParentDefault; //Tying the new child to the new parent + Temp.preferences = new Preferences(); + Temp.preferences.dyslexia = dyslexia; + Temp.grade = grade; + Temp.total_points = points; + Temp.wins = wins; + Temp.losses = losses; + Temp.votes = 0; + + Temp.progress = new Progress(); + progress.forEach((name) => { + Temp.progress[name] = true; + }); + + return Temp; +} + +//Need these exported to tie with stories +let Child3 = MakeChild('Child3', 5, 0, 0, 0, false, [ + 'reading', + 'writing', + 'drawing', + 'teamReview', + ]), + Child4 = MakeChild('Child4', 6, 0, 0, 0, false, [ + 'reading', + 'writing', + 'drawing', + 'teamReview', + ]); + +export const ChildSeed = [ + MakeChild('Child1', 4, 0, 0, 0, false, []), + MakeChild('Child2', 5, 0, 0, 0, false, ['reading']), + Child3, + Child4, +]; + +let child_story_1 = + ''; + +let child_story_2 = + ''; + +function MakeStory(child, page, transcribe) { + let Temp = new Stories(); + + Temp.child = child; + Temp.story = new Pages(); + Temp.story.page1 = page; + Temp.transcribed_text = new Transcribed_Pages(); + Temp.transcribed_text.t_page1 = transcribe; + + //Currently py scripts will crash without this + Temp.flesch_reading_ease = 36.96; + Temp.smog_index = 0; + Temp.flesch_kincaid_grade = 10.3; + Temp.coleman_liau_index = 11.86; + Temp.automated_readability_index = 8.2; + Temp.dale_chall_readability_score = 9.35; + Temp.difficult_words = 3; + Temp.linsear_write_formula = 4.5; + Temp.gunning_fog = 8.04; + Temp.consolidated_score = '4th and 5th grade'; + Temp.doc_length = 57; + Temp.quote_count = 0; + + Temp.week = 1; + + return Temp; +} + +export const StorySeed = [ + MakeStory(Child3, child_story_1, 'Small legendary pokemon personality test'), + MakeStory(Child4, child_story_2, 'Which NARUTO character are you!?'), +]; + +let child_illustration_1 = + ''; + +let child_illustration_2 = + ''; + +function MakeIllustration(child, illustration) { + let Temp = new Illustrations(); + + Temp.child = child; + Temp.illustration = illustration; + Temp.week = 1; + + return Temp; +} + +export const IllustrationSeed = [ + MakeIllustration(Child3, child_illustration_1), + MakeIllustration(Child4, child_illustration_2), +];