2026-01-28 10:42:06 +08:00
|
|
|
import {
|
|
|
|
|
Entity,
|
|
|
|
|
PrimaryGeneratedColumn,
|
|
|
|
|
Column,
|
|
|
|
|
CreateDateColumn,
|
|
|
|
|
ManyToOne,
|
|
|
|
|
JoinColumn,
|
|
|
|
|
Unique,
|
2026-01-28 13:03:28 +08:00
|
|
|
} from "typeorm";
|
|
|
|
|
import { GroupMemberRole } from "../common/enums";
|
|
|
|
|
import { User } from "./user.entity";
|
|
|
|
|
import { Group } from "./group.entity";
|
2026-01-28 10:42:06 +08:00
|
|
|
|
2026-01-28 13:03:28 +08:00
|
|
|
@Entity("group_members")
|
|
|
|
|
@Unique(["groupId", "userId"])
|
2026-01-28 10:42:06 +08:00
|
|
|
export class GroupMember {
|
2026-01-28 13:03:28 +08:00
|
|
|
@PrimaryGeneratedColumn("uuid")
|
2026-01-28 10:42:06 +08:00
|
|
|
id: string;
|
|
|
|
|
|
|
|
|
|
@Column()
|
|
|
|
|
groupId: string;
|
|
|
|
|
|
2026-01-28 13:03:28 +08:00
|
|
|
@ManyToOne(() => Group, (group) => group.members, { onDelete: "CASCADE" })
|
|
|
|
|
@JoinColumn({ name: "groupId" })
|
2026-01-28 10:42:06 +08:00
|
|
|
group: Group;
|
|
|
|
|
|
|
|
|
|
@Column()
|
|
|
|
|
userId: string;
|
|
|
|
|
|
2026-01-28 13:03:28 +08:00
|
|
|
@ManyToOne(() => User, (user) => user.groupMembers, { onDelete: "CASCADE" })
|
|
|
|
|
@JoinColumn({ name: "userId" })
|
2026-01-28 10:42:06 +08:00
|
|
|
user: User;
|
|
|
|
|
|
|
|
|
|
@Column({
|
2026-01-28 13:03:28 +08:00
|
|
|
type: "enum",
|
2026-01-28 10:42:06 +08:00
|
|
|
enum: GroupMemberRole,
|
|
|
|
|
default: GroupMemberRole.MEMBER,
|
|
|
|
|
})
|
|
|
|
|
role: GroupMemberRole;
|
|
|
|
|
|
2026-01-28 13:03:28 +08:00
|
|
|
@Column({ type: "varchar", nullable: true, length: 50, comment: "组内昵称" })
|
2026-01-28 10:42:06 +08:00
|
|
|
nickname: string;
|
|
|
|
|
|
|
|
|
|
@Column({ default: true })
|
|
|
|
|
isActive: boolean;
|
|
|
|
|
|
|
|
|
|
@CreateDateColumn()
|
|
|
|
|
joinedAt: Date;
|
|
|
|
|
}
|