You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
70 lines
1.4 KiB
70 lines
1.4 KiB
import {
|
|
Column,
|
|
CreateDateColumn,
|
|
Entity,
|
|
ManyToOne,
|
|
OneToMany,
|
|
PrimaryGeneratedColumn,
|
|
UpdateDateColumn,
|
|
} from 'typeorm';
|
|
import type { IssueType } from '../constants/issue';
|
|
import { IssueStatus } from '../constants/issue';
|
|
import IssueComment from './IssueComment';
|
|
import Media from './Media';
|
|
import { User } from './User';
|
|
|
|
@Entity()
|
|
class Issue {
|
|
@PrimaryGeneratedColumn()
|
|
public id: number;
|
|
|
|
@Column({ type: 'int' })
|
|
public issueType: IssueType;
|
|
|
|
@Column({ type: 'int', default: IssueStatus.OPEN })
|
|
public status: IssueStatus;
|
|
|
|
@Column({ type: 'int', default: 0 })
|
|
public problemSeason: number;
|
|
|
|
@Column({ type: 'int', default: 0 })
|
|
public problemEpisode: number;
|
|
|
|
@ManyToOne(() => Media, (media) => media.issues, {
|
|
eager: true,
|
|
onDelete: 'CASCADE',
|
|
})
|
|
public media: Media;
|
|
|
|
@ManyToOne(() => User, (user) => user.createdIssues, {
|
|
eager: true,
|
|
onDelete: 'CASCADE',
|
|
})
|
|
public createdBy: User;
|
|
|
|
@ManyToOne(() => User, {
|
|
eager: true,
|
|
onDelete: 'CASCADE',
|
|
nullable: true,
|
|
})
|
|
public modifiedBy?: User;
|
|
|
|
@OneToMany(() => IssueComment, (comment) => comment.issue, {
|
|
cascade: true,
|
|
eager: true,
|
|
})
|
|
public comments: IssueComment[];
|
|
|
|
@CreateDateColumn()
|
|
public createdAt: Date;
|
|
|
|
@UpdateDateColumn()
|
|
public updatedAt: Date;
|
|
|
|
constructor(init?: Partial<Issue>) {
|
|
Object.assign(this, init);
|
|
}
|
|
}
|
|
|
|
export default Issue;
|