| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455 |
- import { Entity, PrimaryGeneratedColumn, Column, CreateDateColumn, UpdateDateColumn, ManyToOne, JoinColumn, ObjectLiteral } from 'typeorm';
- import { UserEntity } from '../users/user.entity';
- export enum IdType {
- ID_CARD = '身份证',
- HONG_KONG_MACAO_PASS = '港澳通行证',
- TAIWAN_PASS = '台湾通行证',
- PASSPORT = '护照',
- OTHER = '其他证件'
- }
- @Entity('passengers')
- export class Passenger implements ObjectLiteral {
- @PrimaryGeneratedColumn()
- id!: number;
- @Column({ name: 'user_id', type: 'integer', comment: '用户ID' })
- userId!: number;
- @ManyToOne(() => UserEntity, (user) => user.id)
- @JoinColumn({ name: 'user_id' })
- user!: UserEntity;
- @Column({ type: 'varchar', length: 50, comment: '乘客姓名' })
- name!: string;
- @Column({
- type: 'enum',
- enum: IdType,
- default: IdType.ID_CARD,
- comment: '证件类型'
- })
- idType!: IdType;
- @Column({ name: 'id_number', type: 'varchar', length: 30, comment: '证件号码' })
- idNumber!: string;
- @Column({ type: 'varchar', length: 20, comment: '手机号' })
- phone!: string;
- @Column({ name: 'is_default', type: 'boolean', default: false, comment: '是否默认乘客' })
- isDefault!: boolean;
- @CreateDateColumn({ name: 'created_at', comment: '创建时间' })
- createdAt!: Date;
- @UpdateDateColumn({ name: 'updated_at', comment: '更新时间' })
- updatedAt!: Date;
- @Column({ name: 'created_by', type: 'integer', nullable: true, comment: '创建人ID' })
- createdBy?: number;
- @Column({ name: 'updated_by', type: 'integer', nullable: true, comment: '更新人ID' })
- updatedBy?: number;
- }
|