mirror of
https://github.com/SyncrowIOT/backend.git
synced 2025-11-26 20:14:54 +00:00
finished add default icon for scene
This commit is contained in:
2
libs/common/src/constants/default.scene.icon.ts
Normal file
2
libs/common/src/constants/default.scene.icon.ts
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
export const defaultSceneIcon =
|
||||||
|
'';
|
||||||
4
libs/common/src/constants/secne-icon-type.enum.ts
Normal file
4
libs/common/src/constants/secne-icon-type.enum.ts
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
export enum SceneIconType {
|
||||||
|
Default = 'default',
|
||||||
|
Other = 'other',
|
||||||
|
}
|
||||||
@ -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,
|
||||||
|
|||||||
@ -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: [],
|
||||||
|
|||||||
38
libs/common/src/seed/services/scene.icon.seeder.ts
Normal file
38
libs/common/src/seed/services/scene.icon.seeder.ts
Normal 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;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -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();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -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',
|
||||||
|
|||||||
@ -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,
|
||||||
};
|
};
|
||||||
}),
|
}),
|
||||||
);
|
);
|
||||||
|
|||||||
Reference in New Issue
Block a user