summaryrefslogtreecommitdiffstats
path: root/portal-FE-common/src/app/pages/get-access
diff options
context:
space:
mode:
authorSunder Tattavarada <statta@research.att.com>2020-01-31 15:26:38 +0000
committerGerrit Code Review <gerrit@onap.org>2020-01-31 15:26:38 +0000
commite363b25a09970065499f91e9b54be0149517e737 (patch)
treeb66138e640294495c80b97d251af359559dd8cce /portal-FE-common/src/app/pages/get-access
parente0b464f75666b80976466437fa1057c3b4efd39f (diff)
parent46c63acfdb4bfa54c5f2a6eb42d80e5dd853488a (diff)
Merge "Angular upgrade - Dynamic widget,widget catalog"
Diffstat (limited to 'portal-FE-common/src/app/pages/get-access')
-rw-r--r--portal-FE-common/src/app/pages/get-access/get-access.component.html98
-rw-r--r--portal-FE-common/src/app/pages/get-access/get-access.component.scss0
-rw-r--r--portal-FE-common/src/app/pages/get-access/get-access.component.spec.ts25
-rw-r--r--portal-FE-common/src/app/pages/get-access/get-access.component.ts136
4 files changed, 259 insertions, 0 deletions
diff --git a/portal-FE-common/src/app/pages/get-access/get-access.component.html b/portal-FE-common/src/app/pages/get-access/get-access.component.html
new file mode 100644
index 00000000..8719ea41
--- /dev/null
+++ b/portal-FE-common/src/app/pages/get-access/get-access.component.html
@@ -0,0 +1,98 @@
+<!--
+ ============LICENSE_START==========================================
+ ONAP Portal
+ ===================================================================
+ Copyright (C) 2019 AT&T Intellectual Property. All rights reserved.
+ ===================================================================
+
+ Unless otherwise specified, all software contained herein is licensed
+ under the Apache License, Version 2.0 (the "License");
+ you may not use this software 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.
+
+ Unless otherwise specified, all documentation contained herein is licensed
+ under the Creative Commons License, Attribution 4.0 Intl. (the "License");
+ you may not use this documentation except in compliance with the License.
+ You may obtain a copy of the License at
+
+ https://creativecommons.org/licenses/by/4.0/
+
+ Unless required by applicable law or agreed to in writing, documentation
+ 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============================================
+
+
+ -->
+ <div class="container">
+ <div class="ecomp-main-view-title">
+ <h1 class="heading-page">Get Access</h1>
+ <br>
+ <span> Visit <a id="url-access" [href]="getAccessUrl" target="_new">{{getAccessName}}</a>
+ {{getAccessInfo}}
+ </span>
+ </div>
+ <mat-form-field>
+ <input matInput type="text" (keyup)="applyFilter($event.target.value)" placeholder="Search in entire table">
+ </mat-form-field>
+ <span class="ecomp-spinner" *ngIf="showSpinner"></span>
+ <table mat-table [dataSource]="getAccessDataSource">
+ <!-- Function Column -->
+ <ng-container matColumnDef="function">
+ <th id="col1" mat-header-cell *matHeaderCellDef> Function </th>
+ <td id="rowheader_t1_{{i}}-function" mat-cell *matCellDef="let element; let i = index;">
+ <div id="access-page-function" *ngIf="element.ecomp_function !== 'Onap Function Not Available'">
+ {{element.ecomp_function}}</div>
+ <div id="access-page-function" *ngIf="element.ecomp_function === 'Onap Function Not Available'">
+ {{element.ecomp_function}}</div>
+ </td>
+ </ng-container>
+
+ <!-- Application Name Column -->
+ <ng-container matColumnDef="applicationName">
+ <th id="col2" mat-header-cell *matHeaderCellDef> Application Name</th>
+ <td id="rowheader_t1_{{i}}-applicationName" mat-cell *matCellDef="let element; let i=index;"> {{element.app_name}}
+ </td>
+ </ng-container>
+
+ <!-- Role Name Column -->
+ <ng-container matColumnDef="roleName">
+ <th id="col3" mat-header-cell *matHeaderCellDef> Role Name </th>
+ <td id="rowheader_t1_{{i}}-roleName" mat-cell *matCellDef="let element; let i=index;"> {{element.role_name}}
+ </td>
+ </ng-container>
+
+ <!-- Current Role Column -->
+ <ng-container matColumnDef="currentRole">
+ <th id="col4" mat-header-cell *matHeaderCellDef> Current Role </th>
+ <td id="rowheader_t1_{{i}}-currentRole" mat-cell *matCellDef="let element; let i=index;">
+ <div id="access-page-currentRole" *ngIf="element.current_role === 'Y'">
+ <i class="icon ion-md-checkmark"></i>
+ </div>
+ </td>
+ </ng-container>
+
+ <!-- Request Status Column -->
+ <ng-container matColumnDef="requestStatus">
+ <th id="col4" mat-header-cell *matHeaderCellDef> Request Status </th>
+ <td id="rowheader_t1_{{i}}-requestStatus" mat-cell *matCellDef="let element; let i=index;">
+ <div id="access-page-RequestAccess" *ngIf="element.request_type !== null">{{element.request_type}}</div>
+ </td>
+ </ng-container>
+
+ <tr [hidden]="appTable.length === 0" mat-header-row *matHeaderRowDef="displayedColumns"></tr>
+ <tr mat-row *matRowDef="let row; columns: displayedColumns;" (click)="openExistingAdminModal(row)"></tr>
+ </table>
+ <mat-paginator [hidden]="appTable.length === 0" [pageSizeOptions]="[10, 20]" showFirstLastButtons></mat-paginator>
+ </div> \ No newline at end of file
diff --git a/portal-FE-common/src/app/pages/get-access/get-access.component.scss b/portal-FE-common/src/app/pages/get-access/get-access.component.scss
new file mode 100644
index 00000000..e69de29b
--- /dev/null
+++ b/portal-FE-common/src/app/pages/get-access/get-access.component.scss
diff --git a/portal-FE-common/src/app/pages/get-access/get-access.component.spec.ts b/portal-FE-common/src/app/pages/get-access/get-access.component.spec.ts
new file mode 100644
index 00000000..ae61740d
--- /dev/null
+++ b/portal-FE-common/src/app/pages/get-access/get-access.component.spec.ts
@@ -0,0 +1,25 @@
+import { async, ComponentFixture, TestBed } from '@angular/core/testing';
+
+import { GetAccessComponent } from './get-access.component';
+
+describe('GetAccessComponent', () => {
+ let component: GetAccessComponent;
+ let fixture: ComponentFixture<GetAccessComponent>;
+
+ beforeEach(async(() => {
+ TestBed.configureTestingModule({
+ declarations: [ GetAccessComponent ]
+ })
+ .compileComponents();
+ }));
+
+ beforeEach(() => {
+ fixture = TestBed.createComponent(GetAccessComponent);
+ component = fixture.componentInstance;
+ fixture.detectChanges();
+ });
+
+ it('should create', () => {
+ expect(component).toBeTruthy();
+ });
+});
diff --git a/portal-FE-common/src/app/pages/get-access/get-access.component.ts b/portal-FE-common/src/app/pages/get-access/get-access.component.ts
new file mode 100644
index 00000000..a7454894
--- /dev/null
+++ b/portal-FE-common/src/app/pages/get-access/get-access.component.ts
@@ -0,0 +1,136 @@
+/*-
+ * ============LICENSE_START==========================================
+ * ONAP Portal
+ * ===================================================================
+ * Copyright (C) 2019 AT&T Intellectual Property. All rights reserved.
+ * ===================================================================
+ *
+ * Unless otherwise specified, all software contained herein is licensed
+ * under the Apache License, Version 2.0 (the "License");
+ * you may not use this software 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.
+ *
+ * Unless otherwise specified, all documentation contained herein is licensed
+ * under the Creative Commons License, Attribution 4.0 Intl. (the "License");
+ * you may not use this documentation except in compliance with the License.
+ * You may obtain a copy of the License at
+ *
+ * https://creativecommons.org/licenses/by/4.0/
+ *
+ * Unless required by applicable law or agreed to in writing, documentation
+ * 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 { Component, OnInit, ViewChild } from '@angular/core';
+import { GetAccessService } from 'src/app/shared/services/get-access/get-access.service';
+import { MatTableDataSource, MatPaginator } from '@angular/material';
+import { environment } from '../../../environments/environment';
+
+@Component({
+ selector: 'app-get-access',
+ templateUrl: './get-access.component.html',
+ styleUrls: ['./get-access.component.scss']
+})
+export class GetAccessComponent implements OnInit {
+
+ isLoadingTable: boolean;
+ appTable: any[];
+ displayedColumns: string[] = ['function', 'applicationName', 'roleName', 'currentRole', 'requestStatus'];
+ getAccessDataSource = new MatTableDataSource(this.appTable);
+ @ViewChild(MatPaginator) paginator: MatPaginator;
+ showSpinner: boolean;
+ getAccessUrl = environment.getAccessUrl;
+ getAccessName = environment.getAccessName;
+ getAccessInfo = environment.getAccessInfo;
+
+ constructor(private getAccessService: GetAccessService) { }
+
+ ngOnInit() {
+ this.appTable = [];
+ this.getAccessAppsList();
+ }
+
+ applyFilter(filterValue: string) {
+ this.getAccessDataSource.filter = filterValue.trim().toLowerCase();
+ }
+
+ // Convert this code to typescript after mylogins feature is back again
+ // var resultAccessValue = null;
+
+ // $scope.openAppRoleModal = (itemData) => {
+ // if(resultAccessValue){
+ // let data = null;
+ // data = {
+ // dialogState: 2,
+ // selectedUser:{
+ // orgUserId: $scope.orgUserId,
+ // firstName: $scope.firstName,
+ // lastName: $scope.lastName,
+ // headerText: itemData.app_name,
+ // }
+ // }
+ // ngDialog.open({
+ // templateUrl: 'app/views/catalog/request-access-catalog-dialogs/request-access-catalog.modal.html',
+ // controller: 'ExternalRequestAccessCtrl',
+ // controllerAs: 'userInfo',
+ // data: data
+ // });
+ // }
+ // }
+
+ // userProfileService.getUserProfile().then(
+ // function(profile) {
+ // $scope.orgUserId = profile.orgUserId;
+ // $scope.firstName = profile.firstName;
+ // $scope.lastName = profile.lastName;
+ // });
+
+ getAccessAppsList() {
+ this.showSpinner = true;
+ this.getAccessService.getListOfApp().subscribe((_res: any) => {
+ var tableData = [];
+ // $log.info('GetAccessCtrl::updateAppsList: getting res');
+ var result = (typeof (_res) != "undefined" && _res != null) ? _res : null;
+ this.showSpinner = false;
+ // $log.info('GetAccessCtrl::updateAppsList: result',result);
+ // $log.info('GetAccessCtrl::updateAppsList: done');
+ var source = result;
+ // $log.info('GetAccessCtrl::updateAppsList source: ', source);
+ for (var i = 0; i < source.length; i++) {
+ var dataArr = source[i];
+ var checkEcompFuncAvail = 'Function Not Available';
+ var reqStatus = 'Pending';
+ dataArr.ecompFunction = (dataArr.ecompFunction === null) ? checkEcompFuncAvail : dataArr.ecompFunction;
+ dataArr.reqType = (dataArr.reqType === 'P') ? reqStatus : dataArr.reqType;
+ var dataTemp = {
+ ecomp_function: dataArr.ecompFunction,
+ app_name: dataArr.appName,
+ role_name: dataArr.roleName,
+ current_role: dataArr.roleActive,
+ request_type: dataArr.reqType
+ }
+ tableData.push(dataTemp);
+ }
+ this.appTable = tableData;
+ this.getAccessDataSource = new MatTableDataSource(this.appTable);
+ this.getAccessDataSource.paginator = this.paginator;
+ }, (_err) => {
+ this.isLoadingTable = false;
+ })
+ }
+}