20 changed files with 347 additions and 66 deletions
@ -0,0 +1,21 @@ |
|||
/** |
|||
* 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. |
|||
*/ |
|||
:host { |
|||
.export-result-message { |
|||
padding: 48px 8px 8px; |
|||
text-align: center; |
|||
} |
|||
} |
|||
@ -0,0 +1,49 @@ |
|||
<!-- |
|||
|
|||
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. |
|||
|
|||
--> |
|||
<section style="min-width: 400px;"> |
|||
<mat-toolbar> |
|||
<h2>{{ 'version-control.restore-entity-from-version' | translate: {versionName} }}</h2> |
|||
<span fxFlex></span> |
|||
</mat-toolbar> |
|||
<mat-progress-bar color="warn" style="z-index: 10; width: 100%; margin-bottom: -4px;" mode="indeterminate" |
|||
*ngIf="isLoading$ | async"> |
|||
</mat-progress-bar> |
|||
<form [formGroup]="restoreFormGroup" style="padding-top: 16px;"> |
|||
<fieldset [disabled]="isLoading$ | async"> |
|||
<div fxFlex fxLayout="column"> |
|||
<mat-checkbox formControlName="loadRelations" style="margin-bottom: 16px;"> |
|||
{{ 'version-control.load-entity-relations' | translate }} |
|||
</mat-checkbox> |
|||
</div> |
|||
</fieldset> |
|||
</form> |
|||
<div fxLayoutAlign="end center" fxLayoutGap="8px"> |
|||
<button mat-button color="primary" |
|||
type="button" |
|||
[disabled]="(isLoading$ | async)" |
|||
(click)="cancel()" cdkFocusInitial> |
|||
{{ 'action.cancel' | translate }} |
|||
</button> |
|||
<button mat-raised-button color="primary" |
|||
type="button" |
|||
(click)="restore()" |
|||
[disabled]="(isLoading$ | async) || restoreFormGroup.invalid"> |
|||
{{ 'action.restore' | translate }} |
|||
</button> |
|||
</div> |
|||
</section> |
|||
@ -0,0 +1,86 @@ |
|||
///
|
|||
/// 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 { Component, Input, OnInit } from '@angular/core'; |
|||
import { PageComponent } from '@shared/components/page.component'; |
|||
import { FormBuilder, FormGroup } from '@angular/forms'; |
|||
import { SingleEntityVersionLoadRequest, VersionLoadRequestType, VersionLoadResult } from '@shared/models/vc.models'; |
|||
import { Store } from '@ngrx/store'; |
|||
import { AppState } from '@core/core.state'; |
|||
import { EntitiesVersionControlService } from '@core/http/entities-version-control.service'; |
|||
import { EntityId } from '@shared/models/id/entity-id'; |
|||
import { TranslateService } from '@ngx-translate/core'; |
|||
|
|||
@Component({ |
|||
selector: 'tb-entity-version-restore', |
|||
templateUrl: './entity-version-restore.component.html', |
|||
styleUrls: [] |
|||
}) |
|||
export class EntityVersionRestoreComponent extends PageComponent implements OnInit { |
|||
|
|||
@Input() |
|||
branch: string; |
|||
|
|||
@Input() |
|||
versionName: string; |
|||
|
|||
@Input() |
|||
versionId: string; |
|||
|
|||
@Input() |
|||
externalEntityId: EntityId; |
|||
|
|||
@Input() |
|||
onClose: (result: Array<VersionLoadResult> | null) => void; |
|||
|
|||
restoreFormGroup: FormGroup; |
|||
|
|||
constructor(protected store: Store<AppState>, |
|||
private entitiesVersionControlService: EntitiesVersionControlService, |
|||
private translate: TranslateService, |
|||
private fb: FormBuilder) { |
|||
super(store); |
|||
} |
|||
|
|||
ngOnInit(): void { |
|||
this.restoreFormGroup = this.fb.group({ |
|||
loadRelations: [false, []] |
|||
}); |
|||
} |
|||
|
|||
cancel(): void { |
|||
if (this.onClose) { |
|||
this.onClose(null); |
|||
} |
|||
} |
|||
|
|||
restore(): void { |
|||
const request: SingleEntityVersionLoadRequest = { |
|||
branch: this.branch, |
|||
versionId: this.versionId, |
|||
externalEntityId: this.externalEntityId, |
|||
config: { |
|||
loadRelations: this.restoreFormGroup.get('loadRelations').value |
|||
}, |
|||
type: VersionLoadRequestType.SINGLE_ENTITY |
|||
}; |
|||
this.entitiesVersionControlService.loadEntitiesVersion(request).subscribe((result) => { |
|||
if (this.onClose) { |
|||
this.onClose(result); |
|||
} |
|||
}); |
|||
} |
|||
} |
|||
Loading…
Reference in new issue