| /* |
| * Licensed to the Apache Software Foundation (ASF) under one |
| * or more contributor license agreements. See the NOTICE file |
| * distributed with this work for additional information |
| * regarding copyright ownership. The ASF licenses this file |
| * to you 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, OnInit, Inject } from '@angular/core'; |
| import { FormGroup, FormBuilder, Validators } from '@angular/forms'; |
| import { MatDialogRef, MAT_DIALOG_DATA, MatDialog } from '@angular/material'; |
| import { ToastrService } from 'ngx-toastr'; |
| |
| import { EndpointService } from '../../../core/services'; |
| import { NotificationDialogComponent } from '../../../shared/modal-dialog/notification-dialog'; |
| import { PATTERNS } from '../../../core/util'; |
| |
| export interface Endpoint { |
| name: string; |
| url: string; |
| account: string; |
| } |
| |
| @Component({ |
| selector: 'endpoints', |
| templateUrl: './endpoints.component.html', |
| styleUrls: ['./endpoints.component.scss'] |
| }) |
| export class EndpointsComponent implements OnInit { |
| public createEndpointForm: FormGroup; |
| endpoints: Endpoint[] = []; |
| displayedColumns: string[] = ['name', 'url', 'account', 'endpoint_tag', 'actions']; |
| |
| constructor( |
| @Inject(MAT_DIALOG_DATA) public data: any, |
| public toastr: ToastrService, |
| public dialogRef: MatDialogRef<EndpointsComponent>, |
| public dialog: MatDialog, |
| private endpointService: EndpointService, |
| private _fb: FormBuilder |
| ) { } |
| |
| ngOnInit() { |
| this.initFormModel(); |
| this.getEndpointList(); |
| } |
| |
| public assignChanges(data) { |
| this.endpointService.createEndpoint(data).subscribe(() => { |
| this.toastr.success('Endpoint created successfully!', 'Success!'); |
| this.dialogRef.close(true); |
| }, error => this.toastr.error(error.message || 'Endpoint creation failed!', 'Oops!')); |
| } |
| |
| public deleteEndpoint(data) { |
| this.dialog.open(NotificationDialogComponent, { data: { type: 'confirmation', item: data }, panelClass: 'modal-sm' }) |
| .afterClosed().subscribe(result => { |
| result && this.endpointService.deleteEndpoint(data.name).subscribe(() => { |
| this.toastr.success('Endpoint successfully deleted!', 'Success!'); |
| this.getEndpointList(); |
| }, error => this.toastr.error(error.message || 'Endpoint creation failed!', 'Oops!')); |
| }); |
| } |
| |
| private initFormModel(): void { |
| this.createEndpointForm = this._fb.group({ |
| name: ['', Validators.compose([Validators.required, Validators.pattern(PATTERNS.namePattern)])], |
| url: ['', Validators.compose([Validators.required, Validators.pattern(PATTERNS.url)])], |
| account: ['', Validators.compose([Validators.required, Validators.pattern(PATTERNS.namePattern)])], |
| endpoint_tag: ['', Validators.compose([Validators.required, Validators.pattern(PATTERNS.namePattern)])] |
| }); |
| } |
| |
| private getEndpointList() { |
| this.endpointService.getEndpointsData().subscribe((endpoints: any) => this.endpoints = endpoints); |
| } |
| } |