2024-08-13 13:08:21 +03:00
|
|
|
///
|
|
|
|
|
/// Copyright © 2016-2024 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.
|
|
|
|
|
///
|
|
|
|
|
|
2024-10-22 15:35:32 +03:00
|
|
|
import { Component, Input, OnChanges, SimpleChanges } from '@angular/core';
|
2024-08-13 13:08:21 +03:00
|
|
|
import { BaseData } from '@shared/models/base-data';
|
|
|
|
|
import { EntityId } from '@shared/models/id/entity-id';
|
|
|
|
|
import { baseDetailsPageByEntityType, EntityType } from '@app/shared/public-api';
|
2024-11-01 11:53:26 +02:00
|
|
|
import { isEqual, isObject } from '@core/utils';
|
2024-08-13 13:08:21 +03:00
|
|
|
|
|
|
|
|
@Component({
|
|
|
|
|
selector: 'tb-entity-chips',
|
|
|
|
|
templateUrl: './entity-chips.component.html',
|
|
|
|
|
styleUrls: ['./entity-chips.component.scss']
|
|
|
|
|
})
|
2024-10-22 15:35:32 +03:00
|
|
|
export class EntityChipsComponent implements OnChanges {
|
2024-08-13 13:08:21 +03:00
|
|
|
|
|
|
|
|
@Input()
|
2024-10-22 15:35:32 +03:00
|
|
|
entity: BaseData<EntityId>;
|
2024-08-13 13:08:21 +03:00
|
|
|
|
2024-10-22 15:35:32 +03:00
|
|
|
@Input()
|
|
|
|
|
key: string;
|
2024-08-13 13:08:21 +03:00
|
|
|
|
|
|
|
|
entityDetailsPrefixUrl: string;
|
|
|
|
|
|
2024-10-22 15:35:32 +03:00
|
|
|
subEntities: Array<BaseData<EntityId>> = [];
|
2024-08-13 13:08:21 +03:00
|
|
|
|
2024-10-22 15:35:32 +03:00
|
|
|
ngOnChanges(changes: SimpleChanges) {
|
|
|
|
|
for (const propName of Object.keys(changes)) {
|
|
|
|
|
const change = changes[propName];
|
|
|
|
|
if (propName === 'entity' && change.currentValue !== change.previousValue) {
|
|
|
|
|
this.update();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2024-08-13 13:08:21 +03:00
|
|
|
|
2024-10-22 15:35:32 +03:00
|
|
|
private update(): void {
|
|
|
|
|
if (this.entity && this.entity.id && this.key) {
|
|
|
|
|
let entitiesList = this.entity?.[this.key];
|
|
|
|
|
if (isObject(entitiesList) && !Array.isArray(entitiesList)) {
|
|
|
|
|
entitiesList = [entitiesList];
|
|
|
|
|
}
|
|
|
|
|
if (Array.isArray(entitiesList)) {
|
2024-11-01 11:53:26 +02:00
|
|
|
if (entitiesList.length) {
|
|
|
|
|
this.entityDetailsPrefixUrl = baseDetailsPageByEntityType.get(entitiesList[0].id.entityType as EntityType);
|
2024-10-22 15:35:32 +03:00
|
|
|
}
|
2024-11-01 11:53:26 +02:00
|
|
|
} else {
|
|
|
|
|
entitiesList = [];
|
|
|
|
|
}
|
|
|
|
|
if (!isEqual(entitiesList, this.subEntities)) {
|
|
|
|
|
this.subEntities = entitiesList;
|
2024-08-13 13:08:21 +03:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|