Added new componetnts inside page modules
[portal.git] / portal-FE-common / src / app / pages / notification-history / notification-history.component.ts
1 /*-
2  * ============LICENSE_START==========================================
3  * ONAP Portal
4  * ===================================================================
5  * Copyright (C) 2019 AT&T Intellectual Property. All rights reserved.
6  * ===================================================================
7  *
8  * Unless otherwise specified, all software contained herein is licensed
9  * under the Apache License, Version 2.0 (the "License");
10  * you may not use this software except in compliance with the License.
11  * You may obtain a copy of the License at
12  *
13  *             http://www.apache.org/licenses/LICENSE-2.0
14  *
15  * Unless required by applicable law or agreed to in writing, software
16  * distributed under the License is distributed on an "AS IS" BASIS,
17  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
18  * See the License for the specific language governing permissions and
19  * limitations under the License.
20  *
21  * Unless otherwise specified, all documentation contained herein is licensed
22  * under the Creative Commons License, Attribution 4.0 Intl. (the "License");
23  * you may not use this documentation except in compliance with the License.
24  * You may obtain a copy of the License at
25  *
26  *             https://creativecommons.org/licenses/by/4.0/
27  *
28  * Unless required by applicable law or agreed to in writing, documentation
29  * distributed under the License is distributed on an "AS IS" BASIS,
30  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
31  * See the License for the specific language governing permissions and
32  * limitations under the License.
33  *
34  * ============LICENSE_END============================================
35  *
36  * 
37  */
38
39 import { Component, OnInit, ViewChild } from '@angular/core';
40 import { MatTableDataSource } from '@angular/material';
41 import { MatSort, MatPaginator } from '@angular/material';
42 import { NotificationService } from '../../shared/services/index';
43
44 @Component({
45   selector: 'app-notification-history',
46   templateUrl: './notification-history.component.html',
47   styleUrls: ['./notification-history.component.scss']
48 })
49 export class NotificationHistoryComponent implements OnInit {
50
51   result: any;
52   notificationHistory: any= [];
53   displayedColumns: string[] = ['messageSource', 'message', 'startDateLocalTime','endDateLocalTime', 'priority', 'createdBy', 'createdTime'];
54   notificationsDataSource = new MatTableDataSource(this.notificationHistory);
55   @ViewChild(MatSort) sort: MatSort;
56   @ViewChild(MatPaginator) paginator: MatPaginator;
57
58   constructor(public notificationService: NotificationService) { }
59
60   ngOnInit() {
61     this.getNotificationHistory();
62   }
63
64   getNotificationHistory(){
65     //console.log("getNotificationHistory called");
66     this.notificationService.getNotificationHistory()
67     .subscribe(_data => {
68         this.result = _data;
69         if (this.result == null || this.result == 'undefined') {
70           console.log('NotificationService::getNotificationHistory Failed: Result or result.data is null');
71         }else {
72           //console.log('Notification Data ::',this.result);
73           this.notificationHistory = this.result;
74           this.populateTableData(this.notificationHistory);
75         }
76     }, error =>{
77       console.log(error);
78     });
79   }
80
81   populateTableData(notificationHistory: Array<Object>){
82     this.notificationsDataSource = new MatTableDataSource(notificationHistory);
83     this.notificationsDataSource.sort = this.sort;
84     this.notificationsDataSource.paginator = this.paginator;
85   }
86
87   applyFilter(filterValue: string) {
88     this.notificationsDataSource.filter = filterValue.trim().toLowerCase();
89   }
90
91 }