223 lines
8.6 KiB
TypeScript
223 lines
8.6 KiB
TypeScript
///
|
|
/// Copyright © 2016-2022 The Thingsboard Authors
|
|
///
|
|
/// Licensed under the Apache License, Version 2.0 (the "License");
|
|
/// you may not use this file except in compliance with the License.
|
|
/// You may obtain a copy of the License at
|
|
///
|
|
/// http://www.apache.org/licenses/LICENSE-2.0
|
|
///
|
|
/// Unless required by applicable law or agreed to in writing, software
|
|
/// distributed under the License is distributed on an "AS IS" BASIS,
|
|
/// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
/// See the License for the specific language governing permissions and
|
|
/// limitations under the License.
|
|
///
|
|
|
|
import { Injectable } from '@angular/core';
|
|
import { Resolve, Router } from '@angular/router';
|
|
import {
|
|
checkBoxCell,
|
|
DateEntityTableColumn,
|
|
EntityTableColumn,
|
|
EntityTableConfig,
|
|
HeaderActionDescriptor
|
|
} from '@home/models/entity/entities-table-config.models';
|
|
import { TranslateService } from '@ngx-translate/core';
|
|
import { DatePipe } from '@angular/common';
|
|
import { EntityType, entityTypeResources, entityTypeTranslations } from '@shared/models/entity-type.models';
|
|
import { EntityAction } from '@home/models/entity/entity-component.models';
|
|
import { DialogService } from '@core/services/dialog.service';
|
|
import {
|
|
DeviceProfile,
|
|
deviceProfileTypeTranslationMap,
|
|
deviceTransportTypeTranslationMap
|
|
} from '@shared/models/device.models';
|
|
import { DeviceProfileService } from '@core/http/device-profile.service';
|
|
import { DeviceProfileComponent } from '@home/components/profile/device-profile.component';
|
|
import { DeviceProfileTabsComponent } from './device-profile-tabs.component';
|
|
import { MatDialog } from '@angular/material/dialog';
|
|
import {
|
|
AddDeviceProfileDialogComponent,
|
|
AddDeviceProfileDialogData
|
|
} from '@home/components/profile/add-device-profile-dialog.component';
|
|
import { ImportExportService } from '@home/components/import-export/import-export.service';
|
|
|
|
@Injectable()
|
|
export class DeviceProfilesTableConfigResolver implements Resolve<EntityTableConfig<DeviceProfile>> {
|
|
|
|
private readonly config: EntityTableConfig<DeviceProfile> = new EntityTableConfig<DeviceProfile>();
|
|
|
|
constructor(private deviceProfileService: DeviceProfileService,
|
|
private importExport: ImportExportService,
|
|
private translate: TranslateService,
|
|
private datePipe: DatePipe,
|
|
private dialogService: DialogService,
|
|
private router: Router,
|
|
private dialog: MatDialog) {
|
|
|
|
this.config.entityType = EntityType.DEVICE_PROFILE;
|
|
this.config.entityComponent = DeviceProfileComponent;
|
|
this.config.entityTabsComponent = DeviceProfileTabsComponent;
|
|
this.config.entityTranslations = entityTypeTranslations.get(EntityType.DEVICE_PROFILE);
|
|
this.config.entityResources = entityTypeResources.get(EntityType.DEVICE_PROFILE);
|
|
|
|
this.config.hideDetailsTabsOnEdit = false;
|
|
|
|
this.config.addDialogStyle = {width: '1000px'};
|
|
|
|
this.config.columns.push(
|
|
new DateEntityTableColumn<DeviceProfile>('createdTime', 'common.created-time', this.datePipe, '150px'),
|
|
new EntityTableColumn<DeviceProfile>('name', 'device-profile.name', '20%'),
|
|
new EntityTableColumn<DeviceProfile>('type', 'device-profile.type', '20%', (deviceProfile) => {
|
|
return this.translate.instant(deviceProfileTypeTranslationMap.get(deviceProfile.type));
|
|
}),
|
|
new EntityTableColumn<DeviceProfile>('transportType', 'device-profile.transport-type', '20%', (deviceProfile) => {
|
|
return this.translate.instant(deviceTransportTypeTranslationMap.get(deviceProfile.transportType));
|
|
}),
|
|
new EntityTableColumn<DeviceProfile>('description', 'device-profile.description', '40%'),
|
|
new EntityTableColumn<DeviceProfile>('isDefault', 'device-profile.default', '60px',
|
|
entity => {
|
|
return checkBoxCell(entity.default);
|
|
})
|
|
);
|
|
|
|
this.config.cellActionDescriptors.push(
|
|
{
|
|
name: this.translate.instant('device-profile.export'),
|
|
icon: 'file_download',
|
|
isEnabled: () => true,
|
|
onAction: ($event, entity) => this.exportDeviceProfile($event, entity)
|
|
},
|
|
{
|
|
name: this.translate.instant('device-profile.set-default'),
|
|
icon: 'flag',
|
|
isEnabled: (deviceProfile) => !deviceProfile.default,
|
|
onAction: ($event, entity) => this.setDefaultDeviceProfile($event, entity)
|
|
}
|
|
);
|
|
|
|
this.config.deleteEntityTitle = deviceProfile => this.translate.instant('device-profile.delete-device-profile-title',
|
|
{ deviceProfileName: deviceProfile.name });
|
|
this.config.deleteEntityContent = () => this.translate.instant('device-profile.delete-device-profile-text');
|
|
this.config.deleteEntitiesTitle = count => this.translate.instant('device-profile.delete-device-profiles-title', {count});
|
|
this.config.deleteEntitiesContent = () => this.translate.instant('device-profile.delete-device-profiles-text');
|
|
|
|
this.config.entitiesFetchFunction = pageLink => this.deviceProfileService.getDeviceProfiles(pageLink);
|
|
this.config.loadEntity = id => this.deviceProfileService.getDeviceProfile(id.id);
|
|
this.config.saveEntity = (deviceProfile, originDeviceProfile) =>
|
|
this.deviceProfileService.saveDeviceProfileAndConfirmOtaChange(originDeviceProfile, deviceProfile);
|
|
this.config.deleteEntity = id => this.deviceProfileService.deleteDeviceProfile(id.id);
|
|
this.config.onEntityAction = action => this.onDeviceProfileAction(action);
|
|
this.config.deleteEnabled = (deviceProfile) => deviceProfile && !deviceProfile.default;
|
|
this.config.entitySelectionEnabled = (deviceProfile) => deviceProfile && !deviceProfile.default;
|
|
this.config.addActionDescriptors = this.configureAddActions();
|
|
}
|
|
|
|
resolve(): EntityTableConfig<DeviceProfile> {
|
|
this.config.tableTitle = this.translate.instant('device-profile.device-profiles');
|
|
|
|
return this.config;
|
|
}
|
|
|
|
configureAddActions(): Array<HeaderActionDescriptor> {
|
|
const actions: Array<HeaderActionDescriptor> = [];
|
|
actions.push(
|
|
{
|
|
name: this.translate.instant('device-profile.create-device-profile'),
|
|
icon: 'insert_drive_file',
|
|
isEnabled: () => true,
|
|
onAction: () => this.addDeviceProfile()
|
|
},
|
|
{
|
|
name: this.translate.instant('device-profile.import'),
|
|
icon: 'file_upload',
|
|
isEnabled: () => true,
|
|
onAction: ($event) => this.importDeviceProfile($event)
|
|
}
|
|
);
|
|
return actions;
|
|
}
|
|
|
|
addDeviceProfile() {
|
|
this.dialog.open<AddDeviceProfileDialogComponent, AddDeviceProfileDialogData,
|
|
DeviceProfile>(AddDeviceProfileDialogComponent, {
|
|
disableClose: true,
|
|
panelClass: ['tb-dialog', 'tb-fullscreen-dialog'],
|
|
data: {
|
|
deviceProfileName: null,
|
|
transportType: null
|
|
}
|
|
}).afterClosed().subscribe(
|
|
(res) => {
|
|
if (res) {
|
|
this.config.updateData();
|
|
}
|
|
}
|
|
);
|
|
}
|
|
|
|
setDefaultDeviceProfile($event: Event, deviceProfile: DeviceProfile) {
|
|
if ($event) {
|
|
$event.stopPropagation();
|
|
}
|
|
this.dialogService.confirm(
|
|
this.translate.instant('device-profile.set-default-device-profile-title', {deviceProfileName: deviceProfile.name}),
|
|
this.translate.instant('device-profile.set-default-device-profile-text'),
|
|
this.translate.instant('action.no'),
|
|
this.translate.instant('action.yes'),
|
|
true
|
|
).subscribe((res) => {
|
|
if (res) {
|
|
this.deviceProfileService.setDefaultDeviceProfile(deviceProfile.id.id).subscribe(
|
|
() => {
|
|
this.config.updateData();
|
|
}
|
|
);
|
|
}
|
|
}
|
|
);
|
|
}
|
|
|
|
private openDeviceProfile($event: Event, deviceProfile: DeviceProfile) {
|
|
if ($event) {
|
|
$event.stopPropagation();
|
|
}
|
|
const url = this.router.createUrlTree(['deviceProfiles', deviceProfile.id.id]);
|
|
this.router.navigateByUrl(url);
|
|
}
|
|
|
|
importDeviceProfile($event: Event) {
|
|
this.importExport.importDeviceProfile().subscribe(
|
|
(deviceProfile) => {
|
|
if (deviceProfile) {
|
|
this.config.updateData();
|
|
}
|
|
}
|
|
);
|
|
}
|
|
|
|
exportDeviceProfile($event: Event, deviceProfile: DeviceProfile) {
|
|
if ($event) {
|
|
$event.stopPropagation();
|
|
}
|
|
this.importExport.exportDeviceProfile(deviceProfile.id.id);
|
|
}
|
|
|
|
onDeviceProfileAction(action: EntityAction<DeviceProfile>): boolean {
|
|
switch (action.action) {
|
|
case 'open':
|
|
this.openDeviceProfile(action.event, action.entity);
|
|
return true;
|
|
case 'setDefault':
|
|
this.setDefaultDeviceProfile(action.event, action.entity);
|
|
return true;
|
|
case 'export':
|
|
this.exportDeviceProfile(action.event, action.entity);
|
|
return true;
|
|
}
|
|
return false;
|
|
}
|
|
|
|
}
|