blob: 5b5cc00ed5cda209d8afe0aec66cb4baefe7b5a0 [file] [log] [blame]
/*-
* ========================LICENSE_START=================================
* O-RAN-SC
* %%
* Copyright (C) 2019 Nordix Foundation
* %%
* 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.
* ========================LICENSE_END===================================
*/
import { animate, state, style, transition, trigger } from '@angular/animations';
import { AfterViewInit, Component, Inject, OnInit, ViewChild } from '@angular/core';
import { MatDialogConfig, MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';
import { MatMenuTrigger } from '@angular/material/menu';
import { JsonPointer } from 'angular6-json-schema-form';
import * as uuid from 'uuid';
import { PolicyInstance, PolicyType } from '../interfaces/policy.types';
import { PolicyService } from '../services/policy/policy.service';
import { ErrorDialogService } from '../services/ui/error-dialog.service';
import { NotificationService } from './../services/ui/notification.service';
import { UiService } from '../services/ui/ui.service';
@Component({
selector: 'rd-policy-instance-dialog',
templateUrl: './policy-instance-dialog.component.html',
styleUrls: ['./policy-instance-dialog.component.scss'],
animations: [
trigger('expandSection', [
state('in', style({ height: '*' })),
transition(':enter', [
style({ height: 0 }), animate(100),
]),
transition(':leave', [
style({ height: '*' }),
animate(100, style({ height: 0 })),
]),
]),
],
})
export class PolicyInstanceDialogComponent implements OnInit, AfterViewInit {
formActive = false;
isVisible = {
form: true,
json: false,
schema: false
};
jsonFormStatusMessage = 'Loading form...';
jsonSchemaObject: any = {};
jsonObject: any = {};
jsonFormOptions: any = {
addSubmit: false, // Add a submit button if layout does not have one
debug: false, // Don't show inline debugging information
loadExternalAssets: true, // Load external css and JavaScript for frameworks
returnEmptyFields: false, // Don't return values for empty input fields
setSchemaDefaults: true, // Always use schema defaults for empty fields
defautWidgetOptions: { feedback: true }, // Show inline feedback icons
};
liveFormData: any = {};
formValidationErrors: any;
formIsValid = false;
@ViewChild(MatMenuTrigger, { static: true }) menuTrigger: MatMenuTrigger;
public policyInstanceId: string;
public policyTypeName: string;
darkMode: boolean;
constructor(
private dataService: PolicyService,
private errorService: ErrorDialogService,
private notificationService: NotificationService,
@Inject(MAT_DIALOG_DATA) private data,
private dialogRef: MatDialogRef<PolicyInstanceDialogComponent>,
private ui: UiService) {
this.formActive = false;
this.policyInstanceId = data.instanceId;
this.policyTypeName = data.name;
this.jsonSchemaObject = data.createSchema;
this.jsonObject = this.parseJson(data.instanceJson);
}
ngOnInit() {
this.jsonFormStatusMessage = 'Init';
this.formActive = true;
this.ui.darkModeState.subscribe((isDark) => {
this.darkMode = isDark;
});
}
ngAfterViewInit() {
}
onSubmit() {
if (this.policyInstanceId == null) {
this.policyInstanceId = uuid.v4();
}
const policyJson: string = this.prettyLiveFormData;
const self: PolicyInstanceDialogComponent = this;
this.dataService.putPolicy(this.policyTypeName, this.policyInstanceId, policyJson).subscribe(
{
next(value) {
self.notificationService.success('Policy ' + self.policyTypeName + ':' + self.policyInstanceId + ' submitted');
},
error(error) {
self.errorService.displayError('updatePolicy failed: ' + error.message);
},
complete() { }
});
}
onClose() {
this.dialogRef.close();
}
public onChanges(formData: any) {
this.liveFormData = formData;
}
get prettyLiveFormData() {
return JSON.stringify(this.liveFormData, null, 2);
}
get schemaAsString() {
return JSON.stringify(this.jsonSchemaObject, null, 2);
}
get jsonAsString() {
return JSON.stringify(this.jsonObject, null, 2);
}
isValid(isValid: boolean): void {
this.formIsValid = isValid;
}
validationErrors(validationErrors: any): void {
this.formValidationErrors = validationErrors;
}
get prettyValidationErrors() {
if (!this.formValidationErrors) { return null; }
const errorArray = [];
for (const error of this.formValidationErrors) {
const message = error.message;
const dataPathArray = JsonPointer.parse(error.dataPath);
if (dataPathArray.length) {
let field = dataPathArray[0];
for (let i = 1; i < dataPathArray.length; i++) {
const key = dataPathArray[i];
field += /^\d+$/.test(key) ? `[${key}]` : `.${key}`;
}
errorArray.push(`${field}: ${message}`);
} else {
errorArray.push(message);
}
}
return errorArray.join('<br>');
}
private parseJson(str: string): string {
try {
if (str != null) {
return JSON.parse(str);
}
} catch (jsonError) {
this.jsonFormStatusMessage =
'Invalid JSON\n' +
'parser returned:\n\n' + jsonError;
}
return null;
}
public toggleVisible(item: string) {
this.isVisible[item] = !this.isVisible[item];
}
}
export function getPolicyDialogProperties(policyType: PolicyType, instance: PolicyInstance, darkMode: boolean): MatDialogConfig {
const createSchema = policyType.schemaObject;
const instanceId = instance ? instance.id : null;
const instanceJson = instance ? instance.json : null;
const name = policyType.name;
return {
maxWidth: '1200px',
maxHeight: '900px',
width: '900px',
role: 'dialog',
disableClose: false,
panelClass: darkMode ? 'dark-theme' : '',
data: {
createSchema,
instanceId,
instanceJson,
name
}
};
}