Project

General

Profile

1
import { Component, OnInit } from '@angular/core';
2
import { ActivatedRoute } from '@angular/router';
3
import { AuthenticationService } from '../../../services/authentication.service';
4
import { UsagestatsService } from '../../../services/usagestats.service';
5
import { ReportResponse } from '../../../domain/usageStatsClasses';
6
import { FormBuilder, FormGroup } from '@angular/forms';
7

    
8
@Component({
9
  selector: 'metrics-usagestats-report-results',
10
  templateUrl: 'metrics-usagestats-report-results.component.html',
11
  styleUrls: ['metrics-usagestats-report-results.component.css']
12
})
13
export class MetricsUsagestatsReportResultsComponent implements OnInit {
14

    
15
  loadingMessage: string;
16
  errorMessage: string;
17
  infoMessage: string;
18

    
19
  repoResponse: ReportResponse;
20
  coveredPeriod: string;
21
  params: URLSearchParams;
22
  page: number;
23
  pageSize: number;
24
  totalPages: number;
25
  selectedItemIndex: number;
26

    
27
  pageSizeSelect: FormGroup;
28
  chosenReport: string;
29

    
30
  constructor(private route: ActivatedRoute,
31
              private authService: AuthenticationService,
32
              private usageService: UsagestatsService,
33
              private fb: FormBuilder) {}
34

    
35
  ngOnInit() {
36
    this.page = 0;
37
    this.pageSize = 10;
38
    this.readParams();
39
    this.pageSizeSelect = this.fb.group({selectPageSize: ['']});
40
    let body = document.getElementsByTagName('body')[0];
41
    body.classList.remove("top_bar_active");   //remove the class
42
    body.classList.remove("page_heading_active");
43
    body.classList.remove("landing");
44
    body.classList.add("dashboard");
45
  }
46

    
47
  readParams() {
48
    this.params = new URLSearchParams();
49

    
50
    this.route.queryParams.subscribe( qparams => {
51
      this.params.append('Report', qparams['report']);
52
      this.params.append('Release', '4');
53
      this.params.append('RequestorID', this.authService.getUserEmail());
54
      this.params.append('BeginDate', qparams['beginDate']);
55
      this.params.append('EndDate', qparams['endDate']);
56
      this.params.append('RepositoryIdentifier', qparams['repoId']);
57
      this.params.append('ItemIdentifier', qparams['itemIdentifier']);
58
      this.params.append('ItemDataType', qparams['itemIdentifier']);
59
      this.params.append('Granularity', qparams['granularity']);
60
    });
61

    
62
    this.chosenReport = this.params.get('Report');
63
    this.getReportResponse();
64
  }
65

    
66
  getReportResponse() {
67
    this.errorMessage = '';
68
    this.loadingMessage = 'Loading results...';
69
    this.infoMessage = '';
70
    this.selectedItemIndex = null;
71
    this.repoResponse = null;
72

    
73
    this.usageService.getReportResponse(this.page.toString(), this.pageSize.toString(), this.params).subscribe(
74
      responseWrapper => {
75
        this.repoResponse = responseWrapper.ReportResponse;
76
      },
77
      error => {
78
        this.errorMessage = 'Failed to load the report results!';
79
        this.loadingMessage = '';
80
      },
81
      () => {
82
        this.errorMessage = '';
83
        this.loadingMessage = '';
84

    
85
        this.pageSizeSelect.get('selectPageSize').setValue(this.pageSize);
86
        this.pageSizeSelect.get('selectPageSize').updateValueAndValidity();
87

    
88
        this.totalPages = Math.ceil(
89
          +this.repoResponse.ReportDefinition.Filters
90
                  .ReportAttribute.filter(x => x['Name'] === 'ReportItemCount')[0].Value / this.pageSize);
91
        if ( this.totalPages === 0 ) {
92
          this.infoMessage = 'No results were found';
93
        }
94

    
95
        if (this.repoResponse.ReportDefinition && this.repoResponse.ReportDefinition.Filters &&
96
            this.repoResponse.ReportDefinition.Filters.ReportAttribute) {
97

    
98
          if (this.repoResponse.Report && this.repoResponse.ReportDefinition.Filters.UsageDateRange &&
99
            this.repoResponse.ReportDefinition.Filters.UsageDateRange.Begin &&
100
            this.repoResponse.ReportDefinition.Filters.UsageDateRange.End) {
101
            this.coveredPeriod = this.repoResponse.ReportDefinition.Filters.UsageDateRange.Begin + ' to ';
102
            this.coveredPeriod = this.coveredPeriod + this.repoResponse.ReportDefinition.Filters.UsageDateRange.End;
103
          } else {
104
            const defaultDatePeriod = this.repoResponse.Exception.filter(x => x['Message'] === 'Unspecified Date Arguments');
105

    
106
            this.coveredPeriod = defaultDatePeriod[0].Data.split(':')[1].trim() + ' to ';
107
            this.coveredPeriod = this.coveredPeriod + defaultDatePeriod[1].Data.split(':')[1].trim() + ' (default)';
108
          }
109

    
110
        } else {
111
          this.repoResponse = null;
112
        }
113
      }
114
    );
115

    
116
  }
117

    
118

    
119
  getPageSize() {
120
    this.pageSize = +(this.pageSizeSelect.get('selectPageSize').value);
121
    this.page = 0;
122
    this.getReportResponse();
123
  }
124

    
125
  goToNextPage() {
126
    if ( (this.page + 1) < this.totalPages) {
127
      this.page++;
128
      console.log(`Get me page ${this.page}!`);
129
      this.getReportResponse();
130
    }
131
  }
132

    
133
  goToPreviousPage() {
134
    if (this.page > 0) {
135
      this.page--;
136
      console.log(`Get me page ${this.page}!`);
137
      this.getReportResponse();
138
    }
139
  }
140

    
141
  displayItemPerformance(i: number) {
142
    if (this.selectedItemIndex === i) {
143
      this.selectedItemIndex = null;
144
    } else {
145
      this.selectedItemIndex = i;
146
    }
147
  }
148

    
149
  transformItem(itemIdentifiers: any[]) {
150
    let field: string;
151
    if (this.chosenReport === 'RR1') {
152
      field = 'URL';
153
    } else {
154
      field = 'URLs';
155
    }
156
    const i = itemIdentifiers.findIndex(x => x['Type'] === field);
157
    if ( i > -1 ) {
158
      const urls = itemIdentifiers[i]['Value'];
159
      return urls.split(';');
160
    }
161
    return '';
162
  }
163

    
164
}
(9-9/15)