import {
JoinColumn,
ManyToOne,
Entity,
PrimaryColumn,
Index,
Column,
} from "typeorm";
import { User } from "./user.js";
import { id } from "../id.js";
@Entity()
export class DriveFolder {
@PrimaryColumn(id())
public id: string;
@Index()
@Column('timestamp with time zone', {
comment: 'The created date of the DriveFolder.',
})
public createdAt: Date;
@Column('varchar', {
length: 128,
comment: 'The name of the DriveFolder.',
public name: string;
@Column({
...id(),
nullable: true,
comment: 'The owner ID.',
public userId: User["id"] | null;
@ManyToOne(type => User, {
onDelete: 'CASCADE',
@JoinColumn()
public user: User | null;
comment: 'The parent folder ID. If null, it means the DriveFolder is located in root.',
public parentId: DriveFolder["id"] | null;
@ManyToOne(type => DriveFolder, {
onDelete: 'SET NULL',
public parent: DriveFolder | null;
}