thingsboard/ui-ngx/src/app/modules/home/components/rule-node/action/delete-attributes-config.component.ts

89 lines
3.3 KiB
TypeScript
Raw Normal View History

2025-01-07 19:07:33 +02: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.
///
import { Component, ViewChild } from '@angular/core';
import { UntypedFormBuilder, UntypedFormGroup, Validators } from '@angular/forms';
import { MatChipGrid, MatChipInputEvent } from '@angular/material/chips';
import { COMMA, ENTER, SEMICOLON } from '@angular/cdk/keycodes';
import { RuleNodeConfiguration, RuleNodeConfigurationComponent } from '@app/shared/models/rule-node.models';
import { AttributeScope, telemetryTypeTranslations } from '@shared/models/telemetry/telemetry.models';
@Component({
selector: 'tb-action-node-delete-attributes-config',
templateUrl: './delete-attributes-config.component.html',
styleUrls: []
})
export class DeleteAttributesConfigComponent extends RuleNodeConfigurationComponent {
@ViewChild('attributeChipList') attributeChipList: MatChipGrid;
deleteAttributesConfigForm: UntypedFormGroup;
attributeScopeMap = AttributeScope;
attributeScopes = Object.keys(AttributeScope);
telemetryTypeTranslationsMap = telemetryTypeTranslations;
separatorKeysCodes = [ENTER, COMMA, SEMICOLON];
constructor(private fb: UntypedFormBuilder) {
super();
}
protected configForm(): UntypedFormGroup {
return this.deleteAttributesConfigForm;
}
protected onConfigurationSet(configuration: RuleNodeConfiguration) {
this.deleteAttributesConfigForm = this.fb.group({
scope: [configuration ? configuration.scope : null, [Validators.required]],
keys: [configuration ? configuration.keys : null, [Validators.required]],
sendAttributesDeletedNotification: [configuration ? configuration.sendAttributesDeletedNotification : false, []],
notifyDevice: [configuration ? configuration.notifyDevice : false, []]
});
this.deleteAttributesConfigForm.get('scope').valueChanges.subscribe((value) => {
if (value !== AttributeScope.SHARED_SCOPE) {
this.deleteAttributesConfigForm.get('notifyDevice').patchValue(false, {emitEvent: false});
}
});
}
removeKey(key: string): void {
const keys: string[] = this.deleteAttributesConfigForm.get('keys').value;
const index = keys.indexOf(key);
if (index >= 0) {
keys.splice(index, 1);
this.deleteAttributesConfigForm.get('keys').patchValue(keys, {emitEvent: true});
}
}
addKey(event: MatChipInputEvent): void {
const input = event.input;
let value = event.value;
if ((value || '').trim()) {
value = value.trim();
let keys: string[] = this.deleteAttributesConfigForm.get('keys').value;
if (!keys || keys.indexOf(value) === -1) {
if (!keys) {
keys = [];
}
keys.push(value);
this.deleteAttributesConfigForm.get('keys').patchValue(keys, {emitEvent: true});
}
}
if (input) {
input.value = '';
}
}
}