diff --git a/libs/common/src/modules/space/dtos/index.ts b/libs/common/src/modules/space/dtos/index.ts new file mode 100644 index 0000000..9144208 --- /dev/null +++ b/libs/common/src/modules/space/dtos/index.ts @@ -0,0 +1 @@ +export * from './space.dto'; diff --git a/libs/common/src/modules/space/dtos/space.dto.ts b/libs/common/src/modules/space/dtos/space.dto.ts new file mode 100644 index 0000000..cc5ad83 --- /dev/null +++ b/libs/common/src/modules/space/dtos/space.dto.ts @@ -0,0 +1,19 @@ +import { IsNotEmpty, IsString } from 'class-validator'; + +export class SpaceDto { + @IsString() + @IsNotEmpty() + public uuid: string; + + @IsString() + @IsNotEmpty() + public parentUuid: string; + + @IsString() + @IsNotEmpty() + public spaceName: string; + + @IsString() + @IsNotEmpty() + public spaceTypeUuid: string; +} diff --git a/libs/common/src/modules/space/entities/index.ts b/libs/common/src/modules/space/entities/index.ts new file mode 100644 index 0000000..bce8032 --- /dev/null +++ b/libs/common/src/modules/space/entities/index.ts @@ -0,0 +1 @@ +export * from './space.entity'; diff --git a/libs/common/src/modules/space/entities/space.entity.ts b/libs/common/src/modules/space/entities/space.entity.ts new file mode 100644 index 0000000..f546b62 --- /dev/null +++ b/libs/common/src/modules/space/entities/space.entity.ts @@ -0,0 +1,36 @@ +import { Column, Entity, ManyToOne, OneToMany } from 'typeorm'; +import { SpaceDto } from '../dtos'; +import { AbstractEntity } from '../../abstract/entities/abstract.entity'; +import { SpaceTypeEntity } from '../../space-type/entities'; + +@Entity({ name: 'space' }) +export class SpaceEntity extends AbstractEntity { + @Column({ + type: 'uuid', + default: () => 'gen_random_uuid()', // Use gen_random_uuid() for default value + nullable: false, + }) + public uuid: string; + + @Column({ + nullable: false, + }) + parentUuid: string; + + @Column({ + nullable: false, + }) + public spaceName: string; + @ManyToOne(() => SpaceEntity, (space) => space.children, { nullable: true }) + parent: SpaceEntity; + + @OneToMany(() => SpaceEntity, (space) => space.parent) + children: SpaceEntity[]; + @ManyToOne(() => SpaceTypeEntity, (spaceType) => spaceType.spaces) + spaceType: SpaceTypeEntity; + + constructor(partial: Partial) { + super(); + Object.assign(this, partial); + } +} diff --git a/libs/common/src/modules/space/repositories/index.ts b/libs/common/src/modules/space/repositories/index.ts new file mode 100644 index 0000000..1e390d3 --- /dev/null +++ b/libs/common/src/modules/space/repositories/index.ts @@ -0,0 +1 @@ +export * from './space.repository'; diff --git a/libs/common/src/modules/space/repositories/space.repository.ts b/libs/common/src/modules/space/repositories/space.repository.ts new file mode 100644 index 0000000..c939761 --- /dev/null +++ b/libs/common/src/modules/space/repositories/space.repository.ts @@ -0,0 +1,10 @@ +import { DataSource, Repository } from 'typeorm'; +import { Injectable } from '@nestjs/common'; +import { SpaceEntity } from '../entities/space.entity'; + +@Injectable() +export class SpaceRepository extends Repository { + constructor(private dataSource: DataSource) { + super(SpaceEntity, dataSource.createEntityManager()); + } +} diff --git a/libs/common/src/modules/space/space.repository.module.ts b/libs/common/src/modules/space/space.repository.module.ts new file mode 100644 index 0000000..58a8ad0 --- /dev/null +++ b/libs/common/src/modules/space/space.repository.module.ts @@ -0,0 +1,11 @@ +import { Module } from '@nestjs/common'; +import { TypeOrmModule } from '@nestjs/typeorm'; +import { SpaceEntity } from './entities/space.entity'; + +@Module({ + providers: [], + exports: [], + controllers: [], + imports: [TypeOrmModule.forFeature([SpaceEntity])], +}) +export class SpaceRepositoryModule {}