7 changed files with 179 additions and 34 deletions
@ -0,0 +1,26 @@ |
|||||
|
<!-- |
||||
|
|
||||
|
Copyright © 2016-2020 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. |
||||
|
|
||||
|
--> |
||||
|
<button mat-raised-button |
||||
|
ngxClipboard |
||||
|
[cbContent]="credential" |
||||
|
(cbOnSuccess)="onCopyCredential()" |
||||
|
[fxHide]="hideButton" |
||||
|
[disabled]="disabled || loading"> |
||||
|
<mat-icon svgIcon="mdi:clipboard-arrow-left"></mat-icon> |
||||
|
<span>{{ buttonLabel }}</span> |
||||
|
</button> |
||||
@ -0,0 +1,128 @@ |
|||||
|
///
|
||||
|
/// Copyright © 2016-2020 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, Input, OnDestroy, OnInit } from '@angular/core'; |
||||
|
import { EntityId } from '@shared/models/id/entity-id'; |
||||
|
import { DeviceService } from '@core/http/device.service'; |
||||
|
import { DeviceCredentials, DeviceCredentialsType } from '@shared/models/device.models'; |
||||
|
import { isDefinedAndNotNull, isEqual } from '@core/utils'; |
||||
|
import { BehaviorSubject, Subject } from 'rxjs'; |
||||
|
import { distinctUntilChanged, filter, mergeMap, tap } from 'rxjs/operators'; |
||||
|
import { EntityType } from '@shared/models/entity-type.models'; |
||||
|
import { ActionNotificationShow } from '@core/notification/notification.actions'; |
||||
|
import { Store } from '@ngrx/store'; |
||||
|
import { AppState } from '@core/core.state'; |
||||
|
import { TranslateService } from '@ngx-translate/core'; |
||||
|
|
||||
|
@Component({ |
||||
|
selector: 'tb-copy-device-credentials', |
||||
|
templateUrl: './copy-device-credentials.component.html', |
||||
|
styleUrls: [] |
||||
|
}) |
||||
|
export class CopyDeviceCredentialsComponent implements OnDestroy { |
||||
|
|
||||
|
private deviceId$ = new BehaviorSubject<EntityId>(null); |
||||
|
|
||||
|
private credentials$ = new Subject<DeviceCredentials>(); |
||||
|
|
||||
|
private tooltipMessage: string; |
||||
|
|
||||
|
public hideButton = true; |
||||
|
|
||||
|
public credential: string; |
||||
|
|
||||
|
public loading = false; |
||||
|
|
||||
|
public buttonLabel: string; |
||||
|
|
||||
|
@Input() |
||||
|
set deviceId(deviceId: EntityId) { |
||||
|
this.deviceId$.next(deviceId); |
||||
|
} |
||||
|
|
||||
|
@Input() disabled: boolean; |
||||
|
|
||||
|
@Input() |
||||
|
set credentials(credential: DeviceCredentials) { |
||||
|
this.credentials$.next(credential); |
||||
|
} |
||||
|
|
||||
|
constructor(private store: Store<AppState>, |
||||
|
private translate: TranslateService, |
||||
|
private deviceService: DeviceService |
||||
|
) { |
||||
|
this.deviceId$.pipe( |
||||
|
filter(device => isDefinedAndNotNull(device) && device.entityType === EntityType.DEVICE), |
||||
|
distinctUntilChanged((prev, curr) => prev.id === curr.id), |
||||
|
tap(() => this.loading = true), |
||||
|
mergeMap(device => this.deviceService.getDeviceCredentials(device.id)) |
||||
|
).subscribe(deviceCredentials => { |
||||
|
this.processingValue(deviceCredentials); |
||||
|
this.loading = false; |
||||
|
}); |
||||
|
|
||||
|
this.credentials$.pipe( |
||||
|
filter(credential => isDefinedAndNotNull(credential)), |
||||
|
distinctUntilChanged((prev, curr) => isEqual(prev, curr)) |
||||
|
).subscribe(deviceCredentials => { |
||||
|
console.warn(deviceCredentials); |
||||
|
this.processingValue(deviceCredentials); |
||||
|
}); |
||||
|
} |
||||
|
|
||||
|
ngOnDestroy(): void { |
||||
|
this.deviceId$.unsubscribe(); |
||||
|
this.credentials$.unsubscribe(); |
||||
|
} |
||||
|
|
||||
|
private processingValue(credential: DeviceCredentials): void { |
||||
|
switch (credential.credentialsType) { |
||||
|
case DeviceCredentialsType.ACCESS_TOKEN: |
||||
|
this.hideButton = false; |
||||
|
this.credential = credential.credentialsId; |
||||
|
this.buttonLabel = this.translate.instant('device.copyAccessToken'); |
||||
|
this.tooltipMessage = this.translate.instant('device.accessTokenCopiedMessage'); |
||||
|
break; |
||||
|
case DeviceCredentialsType.MQTT_BASIC: |
||||
|
this.hideButton = false; |
||||
|
this.credential = this.convertObjectToString(JSON.parse(credential.credentialsValue)); |
||||
|
this.buttonLabel = this.translate.instant('device.copy-mqtt-authentication'); |
||||
|
this.tooltipMessage = this.translate.instant('device.mqtt-authentication-copied-message'); |
||||
|
break; |
||||
|
default: |
||||
|
this.hideButton = true; |
||||
|
this.credential = null; |
||||
|
this.buttonLabel = ''; |
||||
|
this.tooltipMessage = ''; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
private convertObjectToString(obj: object): string { |
||||
|
Object.keys(obj).forEach(k => (!obj[k] && obj[k] !== undefined) && delete obj[k]); |
||||
|
return JSON.stringify(obj).replace(/"([^"]+)":/g, '$1:'); |
||||
|
} |
||||
|
|
||||
|
onCopyCredential() { |
||||
|
this.store.dispatch(new ActionNotificationShow( |
||||
|
{ |
||||
|
message: this.tooltipMessage, |
||||
|
type: 'success', |
||||
|
duration: 750, |
||||
|
verticalPosition: 'bottom', |
||||
|
horizontalPosition: 'right' |
||||
|
})); |
||||
|
} |
||||
|
} |
||||
Loading…
Reference in new issue