Spaces:
Sleeping
Sleeping
File size: 1,511 Bytes
73746a8 426f2a4 73746a8 f45e448 73746a8 426f2a4 73746a8 | 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 | import {
Entity,
Column,
PrimaryGeneratedColumn,
CreateDateColumn,
UpdateDateColumn,
OneToMany,
} from 'typeorm';
import { Order } from './order.entity';
import { UserCourse } from './user-course.entity';
import { Comment } from './comment.entity';
@Entity('courses')
export class Course {
@PrimaryGeneratedColumn()
id: number;
@Column({ type: 'varchar', length: 200 })
title: string;
@Column({ type: 'text', nullable: true })
description: string;
@Column({ type: 'varchar', length: 255, name: 'cover_image' })
coverImage: string;
@Column({ type: 'varchar', length: 500, name: 'drive_link' })
driveLink: string;
@Column({ type: 'decimal', precision: 10, scale: 2 })
price: number;
@Column({ type: 'varchar', length: 50, nullable: true })
category: string;
@Column({ type: 'int', default: 0, name: 'view_count' })
viewCount: number;
@Column({ type: 'int', default: 0, name: 'like_count' })
likeCount: number;
@Column({ type: 'int', default: 0, name: 'star_count' })
starCount: number;
@Column({ type: 'boolean', default: true, name: 'is_active' })
isActive: boolean;
@CreateDateColumn({ name: 'created_at' })
createdAt: Date;
@UpdateDateColumn({ name: 'updated_at' })
updatedAt: Date;
@OneToMany(() => Order, (order) => order.course)
orders: Order[];
@OneToMany(() => UserCourse, (userCourse) => userCourse.course)
userCourses: UserCourse[];
@OneToMany(() => Comment, (comment) => comment.course)
comments: Comment[];
}
|