Fixed the cirvular import BS

ref #11
This commit is contained in:
Nicolai Ort 2020-12-02 17:40:03 +01:00
parent 5bf978d32d
commit ac0ce799f9
8 changed files with 92 additions and 16 deletions

View File

@ -13,5 +13,5 @@ export class Donor extends Participant {
*/
@Column()
@IsBoolean()
receiptNeeded = false;
receiptNeeded: boolean;
}

View File

@ -1,12 +1,86 @@
import { Entity, OneToMany } from "typeorm";
import { Participant } from "./Participant";
import { PrimaryGeneratedColumn, Column, OneToMany, ManyToOne, Entity } from "typeorm";
import {
IsEmail,
IsInt,
IsNotEmpty,
IsOptional,
IsPhoneNumber,
IsString,
} from "class-validator";
import { Address } from "./Address";
import { Donation } from "./Donation";
import { RunnerGroup } from "./RunnerGroup";
/**
* Defines a group's contact.
*/
@Entity()
export class GroupContact extends Participant{
export class GroupContact {
/**
* Autogenerated unique id (primary key).
*/
@PrimaryGeneratedColumn()
@IsOptional()
@IsInt()
id: number;
/**
* The contact's first name.
*/
@Column()
@IsNotEmpty()
@IsString()
firstname: string;
/**
* The contact's middle name.
* Optional
*/
@Column()
@IsOptional()
@IsString()
middlename?: string;
/**
* The contact's last name.
*/
@Column()
@IsOptional()
@IsString()
lastname: string;
/**
* The contact's address.
* Optional
*/
@IsOptional()
@ManyToOne(() => Address, address => address.participants)
address?: Address;
/**
* The contact's phone number.
* Optional
*/
@Column()
@IsOptional()
@IsPhoneNumber("DE")
phone?: string;
/**
* The contact's email address.
* Optional
*/
@Column()
@IsOptional()
@IsEmail()
email?: string;
/**
* Used to link the contact as the donor of a donation.
*/
@OneToMany(() => Donation, donation => donation.donor)
donations: Donation[];
/**
* Used to link runners to donations.
*/

View File

@ -45,7 +45,7 @@ export class RunnerCard {
*/
@Column()
@IsBoolean()
enabled = true;
enabled: boolean;
/**
* Used to link cards to a track scans.

View File

@ -43,10 +43,4 @@ export abstract class RunnerGroup {
*/
@OneToMany(() => Runner, runner => runner.group)
runners: Runner[];
/**
* Used to link teams to runner groups.
*/
@OneToMany(() => RunnerTeam, team => team.parentGroup)
teams: RunnerTeam[];
}

View File

@ -1,7 +1,8 @@
import { Entity, Column, ManyToOne } from "typeorm";
import { Entity, Column, ManyToOne, OneToMany } from "typeorm";
import { IsOptional,} from "class-validator";
import { RunnerGroup } from "./RunnerGroup";
import { Address } from "./Address";
import { RunnerTeam } from "./RunnerTeam";
/**
* Defines a runner organisation (business or school for example).
@ -16,4 +17,10 @@ export class RunnerOrganisation extends RunnerGroup {
@IsOptional()
@ManyToOne(() => Address, address => address.groups)
address?: Address;
/**
* Used to link teams to runner groups.
*/
@OneToMany(() => RunnerTeam, team => team.parentGroup)
teams: RunnerTeam[];
}

View File

@ -1,6 +1,7 @@
import { Entity, Column, ManyToOne } from "typeorm";
import { IsNotEmpty } from "class-validator";
import { RunnerGroup } from "./RunnerGroup";
import { RunnerOrganisation } from "./RunnerOrganisation";
/**
* Defines a runner team (class or deparment for example).
@ -13,6 +14,6 @@ export class RunnerTeam extends RunnerGroup {
* Optional
*/
@IsNotEmpty()
@ManyToOne(() => RunnerGroup, group => group.teams)
parentGroup?: RunnerGroup;
@ManyToOne(() => RunnerOrganisation, org => org.teams)
parentGroup?: RunnerOrganisation;
}

View File

@ -40,5 +40,5 @@ export abstract class Scan {
*/
@Column()
@IsBoolean()
valid = true;
valid: boolean;
}

View File

@ -50,7 +50,7 @@ export class ScanStation {
*/
@Column()
@IsBoolean()
enabled = true;
enabled: boolean;
/**
* Used to link track scans to a scan station.