finished add default icon for scene

This commit is contained in:
faris Aljohari
2024-10-28 01:51:27 -05:00
parent 5539f5f52a
commit 86fb73ab8d
8 changed files with 70 additions and 4 deletions

View File

@ -0,0 +1,2 @@
export const defaultSceneIcon =
'';

View File

@ -0,0 +1,4 @@
export enum SceneIconType {
Default = 'default',
Other = 'other',
}

View File

@ -1,6 +1,7 @@
import { Column, Entity, ManyToOne, OneToMany } from 'typeorm'; import { Column, Entity, ManyToOne, OneToMany } from 'typeorm';
import { SceneDto, SceneIconDto } from '../dtos'; import { SceneDto, SceneIconDto } from '../dtos';
import { AbstractEntity } from '../../abstract/entities/abstract.entity'; import { AbstractEntity } from '../../abstract/entities/abstract.entity';
import { SceneIconType } from '@app/common/constants/secne-icon-type.enum';
// Define SceneIconEntity before SceneEntity // Define SceneIconEntity before SceneEntity
@Entity({ name: 'scene-icon' }) @Entity({ name: 'scene-icon' })
@ -11,6 +12,13 @@ export class SceneIconEntity extends AbstractEntity<SceneIconDto> {
}) })
public icon: string; public icon: string;
@Column({
type: 'enum',
enum: SceneIconType,
default: SceneIconType.Other,
})
iconType: SceneIconType;
@OneToMany( @OneToMany(
() => SceneEntity, () => SceneEntity,
(scenesIconEntity) => scenesIconEntity.sceneIcon, (scenesIconEntity) => scenesIconEntity.sceneIcon,

View File

@ -18,6 +18,8 @@ import { RegionSeeder } from './services/regions.seeder';
import { RegionRepository } from '../modules/region/repositories'; import { RegionRepository } from '../modules/region/repositories';
import { TimeZoneSeeder } from './services/timezone.seeder'; import { TimeZoneSeeder } from './services/timezone.seeder';
import { TimeZoneRepository } from '../modules/timezone/repositories'; import { TimeZoneRepository } from '../modules/timezone/repositories';
import { SceneIconSeeder } from './services/scene.icon.seeder';
import { SceneIconRepository } from '../modules/scene/repositories';
@Global() @Global()
@Module({ @Module({
providers: [ providers: [
@ -35,6 +37,8 @@ import { TimeZoneRepository } from '../modules/timezone/repositories';
RegionRepository, RegionRepository,
TimeZoneSeeder, TimeZoneSeeder,
TimeZoneRepository, TimeZoneRepository,
SceneIconSeeder,
SceneIconRepository,
], ],
exports: [SeederService], exports: [SeederService],
controllers: [], controllers: [],

View File

@ -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<void> {
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<void> {
try {
await this.sceneIconRepository.save({
icon: defaultSceneIcon,
iconType: SceneIconType.Default,
});
} catch (err) {
console.error('Error while creating default scene icon:', err);
throw err;
}
}
}

View File

@ -5,6 +5,7 @@ import { SpaceTypeSeeder } from './space.type.seeder';
import { SuperAdminSeeder } from './supper.admin.seeder'; import { SuperAdminSeeder } from './supper.admin.seeder';
import { RegionSeeder } from './regions.seeder'; import { RegionSeeder } from './regions.seeder';
import { TimeZoneSeeder } from './timezone.seeder'; import { TimeZoneSeeder } from './timezone.seeder';
import { SceneIconSeeder } from './scene.icon.seeder';
@Injectable() @Injectable()
export class SeederService { export class SeederService {
constructor( constructor(
@ -14,6 +15,7 @@ export class SeederService {
private readonly regionSeeder: RegionSeeder, private readonly regionSeeder: RegionSeeder,
private readonly timeZoneSeeder: TimeZoneSeeder, private readonly timeZoneSeeder: TimeZoneSeeder,
private readonly superAdminSeeder: SuperAdminSeeder, private readonly superAdminSeeder: SuperAdminSeeder,
private readonly sceneIconSeeder: SceneIconSeeder,
) {} ) {}
async seed() { async seed() {
@ -23,5 +25,6 @@ export class SeederService {
await this.regionSeeder.addRegionDataIfNotFound(); await this.regionSeeder.addRegionDataIfNotFound();
await this.timeZoneSeeder.addTimeZoneDataIfNotFound(); await this.timeZoneSeeder.addTimeZoneDataIfNotFound();
await this.superAdminSeeder.createSuperAdminIfNotFound(); await this.superAdminSeeder.createSuperAdminIfNotFound();
await this.sceneIconSeeder.createSceneDefaultIconIfNotFound();
} }
} }

View File

@ -74,10 +74,10 @@ export class AddSceneTapToRunDto {
public unitUuid: string; public unitUuid: string;
@ApiProperty({ @ApiProperty({
description: 'Icon UUID', description: 'Icon UUID',
required: true, required: false,
}) })
@IsString() @IsString()
@IsNotEmpty() @IsOptional()
public iconUuid: string; public iconUuid: string;
@ApiProperty({ @ApiProperty({
description: 'show in home page', description: 'show in home page',

View File

@ -28,6 +28,7 @@ import {
SceneIconRepository, SceneIconRepository,
SceneRepository, SceneRepository,
} from '@app/common/modules/scene/repositories'; } from '@app/common/modules/scene/repositories';
import { SceneIconType } from '@app/common/constants/secne-icon-type.enum';
@Injectable() @Injectable()
export class SceneService { export class SceneService {
@ -101,10 +102,16 @@ export class SceneService {
if (!response.success) { if (!response.success) {
throw new HttpException(response.msg, HttpStatus.BAD_REQUEST); throw new HttpException(response.msg, HttpStatus.BAD_REQUEST);
} else { } else {
const defaultSceneIcon = await this.sceneIconRepository.findOne({
where: { iconType: SceneIconType.Default },
});
await this.sceneRepository.save({ await this.sceneRepository.save({
sceneTuyaUuid: response.result.id, sceneTuyaUuid: response.result.id,
sceneIcon: { sceneIcon: {
uuid: addSceneTapToRunDto.iconUuid, uuid: addSceneTapToRunDto.iconUuid
? addSceneTapToRunDto.iconUuid
: defaultSceneIcon.uuid,
}, },
showInHomePage: addSceneTapToRunDto.showInHomePage, showInHomePage: addSceneTapToRunDto.showInHomePage,
unitUuid: unitUuid ? unitUuid : addSceneTapToRunDto.unitUuid, unitUuid: unitUuid ? unitUuid : addSceneTapToRunDto.unitUuid,
@ -174,7 +181,7 @@ export class SceneService {
// eslint-disable-next-line @typescript-eslint/no-unused-vars // eslint-disable-next-line @typescript-eslint/no-unused-vars
const { actions, ...rest } = sceneData; const { actions, ...rest } = sceneData;
return { return {
rest, ...rest,
}; };
}), }),
); );