diff --git a/libs/common/src/constants/default.scene.icon.ts b/libs/common/src/constants/default.scene.icon.ts new file mode 100644 index 0000000..637ca8c --- /dev/null +++ b/libs/common/src/constants/default.scene.icon.ts @@ -0,0 +1,2 @@ +export const defaultSceneIcon = + ''; diff --git a/libs/common/src/constants/secne-icon-type.enum.ts b/libs/common/src/constants/secne-icon-type.enum.ts new file mode 100644 index 0000000..1cbb693 --- /dev/null +++ b/libs/common/src/constants/secne-icon-type.enum.ts @@ -0,0 +1,4 @@ +export enum SceneIconType { + Default = 'default', + Other = 'other', +} diff --git a/libs/common/src/modules/scene/entities/scene.entity.ts b/libs/common/src/modules/scene/entities/scene.entity.ts index d94d172..2ade9ad 100644 --- a/libs/common/src/modules/scene/entities/scene.entity.ts +++ b/libs/common/src/modules/scene/entities/scene.entity.ts @@ -1,6 +1,7 @@ import { Column, Entity, ManyToOne, OneToMany } from 'typeorm'; import { SceneDto, SceneIconDto } from '../dtos'; import { AbstractEntity } from '../../abstract/entities/abstract.entity'; +import { SceneIconType } from '@app/common/constants/secne-icon-type.enum'; // Define SceneIconEntity before SceneEntity @Entity({ name: 'scene-icon' }) @@ -11,6 +12,13 @@ export class SceneIconEntity extends AbstractEntity { }) public icon: string; + @Column({ + type: 'enum', + enum: SceneIconType, + default: SceneIconType.Other, + }) + iconType: SceneIconType; + @OneToMany( () => SceneEntity, (scenesIconEntity) => scenesIconEntity.sceneIcon, diff --git a/libs/common/src/seed/seeder.module.ts b/libs/common/src/seed/seeder.module.ts index f63c05d..0c89c5c 100644 --- a/libs/common/src/seed/seeder.module.ts +++ b/libs/common/src/seed/seeder.module.ts @@ -18,6 +18,8 @@ import { RegionSeeder } from './services/regions.seeder'; import { RegionRepository } from '../modules/region/repositories'; import { TimeZoneSeeder } from './services/timezone.seeder'; import { TimeZoneRepository } from '../modules/timezone/repositories'; +import { SceneIconSeeder } from './services/scene.icon.seeder'; +import { SceneIconRepository } from '../modules/scene/repositories'; @Global() @Module({ providers: [ @@ -35,6 +37,8 @@ import { TimeZoneRepository } from '../modules/timezone/repositories'; RegionRepository, TimeZoneSeeder, TimeZoneRepository, + SceneIconSeeder, + SceneIconRepository, ], exports: [SeederService], controllers: [], diff --git a/libs/common/src/seed/services/scene.icon.seeder.ts b/libs/common/src/seed/services/scene.icon.seeder.ts new file mode 100644 index 0000000..3f363ce --- /dev/null +++ b/libs/common/src/seed/services/scene.icon.seeder.ts @@ -0,0 +1,38 @@ +import { Injectable } from '@nestjs/common'; +import { SceneIconRepository } from '@app/common/modules/scene/repositories'; +import { SceneIconType } from '@app/common/constants/secne-icon-type.enum'; +import { defaultSceneIcon } from '@app/common/constants/default.scene.icon'; + +@Injectable() +export class SceneIconSeeder { + constructor(private readonly sceneIconRepository: SceneIconRepository) {} + + async createSceneDefaultIconIfNotFound(): Promise { + try { + const defaultSceneIconData = await this.sceneIconRepository.find({ + where: { iconType: SceneIconType.Default }, + }); + + if (defaultSceneIconData.length <= 0) { + console.log('Creating default scene icon...'); + + await this.createDefaultSceneIcon(); + } + } catch (err) { + console.error('Error while checking default scene icon:', err); + throw err; + } + } + + private async createDefaultSceneIcon(): Promise { + try { + await this.sceneIconRepository.save({ + icon: defaultSceneIcon, + iconType: SceneIconType.Default, + }); + } catch (err) { + console.error('Error while creating default scene icon:', err); + throw err; + } + } +} diff --git a/libs/common/src/seed/services/seeder.service.ts b/libs/common/src/seed/services/seeder.service.ts index 47d899d..e627e44 100644 --- a/libs/common/src/seed/services/seeder.service.ts +++ b/libs/common/src/seed/services/seeder.service.ts @@ -5,6 +5,7 @@ import { SpaceTypeSeeder } from './space.type.seeder'; import { SuperAdminSeeder } from './supper.admin.seeder'; import { RegionSeeder } from './regions.seeder'; import { TimeZoneSeeder } from './timezone.seeder'; +import { SceneIconSeeder } from './scene.icon.seeder'; @Injectable() export class SeederService { constructor( @@ -14,6 +15,7 @@ export class SeederService { private readonly regionSeeder: RegionSeeder, private readonly timeZoneSeeder: TimeZoneSeeder, private readonly superAdminSeeder: SuperAdminSeeder, + private readonly sceneIconSeeder: SceneIconSeeder, ) {} async seed() { @@ -23,5 +25,6 @@ export class SeederService { await this.regionSeeder.addRegionDataIfNotFound(); await this.timeZoneSeeder.addTimeZoneDataIfNotFound(); await this.superAdminSeeder.createSuperAdminIfNotFound(); + await this.sceneIconSeeder.createSceneDefaultIconIfNotFound(); } } diff --git a/src/scene/dtos/scene.dto.ts b/src/scene/dtos/scene.dto.ts index 62690bd..24334e9 100644 --- a/src/scene/dtos/scene.dto.ts +++ b/src/scene/dtos/scene.dto.ts @@ -74,10 +74,10 @@ export class AddSceneTapToRunDto { public unitUuid: string; @ApiProperty({ description: 'Icon UUID', - required: true, + required: false, }) @IsString() - @IsNotEmpty() + @IsOptional() public iconUuid: string; @ApiProperty({ description: 'show in home page', diff --git a/src/scene/services/scene.service.ts b/src/scene/services/scene.service.ts index ea2237a..3278970 100644 --- a/src/scene/services/scene.service.ts +++ b/src/scene/services/scene.service.ts @@ -28,6 +28,7 @@ import { SceneIconRepository, SceneRepository, } from '@app/common/modules/scene/repositories'; +import { SceneIconType } from '@app/common/constants/secne-icon-type.enum'; @Injectable() export class SceneService { @@ -101,10 +102,16 @@ export class SceneService { if (!response.success) { throw new HttpException(response.msg, HttpStatus.BAD_REQUEST); } else { + const defaultSceneIcon = await this.sceneIconRepository.findOne({ + where: { iconType: SceneIconType.Default }, + }); + await this.sceneRepository.save({ sceneTuyaUuid: response.result.id, sceneIcon: { - uuid: addSceneTapToRunDto.iconUuid, + uuid: addSceneTapToRunDto.iconUuid + ? addSceneTapToRunDto.iconUuid + : defaultSceneIcon.uuid, }, showInHomePage: addSceneTapToRunDto.showInHomePage, unitUuid: unitUuid ? unitUuid : addSceneTapToRunDto.unitUuid,