air-lib
Version:
This is Air's angular component library
184 lines • 15.3 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { PagingService } from './../../services/paging.service';
import { Component } from '@angular/core';
import { Router } from '@angular/router';
import { HttpService } from '../../services/http.service';
import { PagingEvent } from '../../entities/paging-event';
export class BaseMasterComponent {
/**
* @param {?} router
* @param {?} httpService
*/
constructor(router, httpService) {
this.router = router;
this.httpService = httpService;
}
/**
* @return {?}
*/
ngOnInit() {
this.setData();
}
/**
* @protected
* @return {?}
*/
setData() {
/** @type {?} */
const self = this;
self.httpService.get(self.apiCall.url)
.subscribe((data) => {
/** @type {?} */
const body = (/** @type {?} */ (data.body));
/** @type {?} */
const hash = data.headers.get(BaseMasterComponent.CACHED_HEADER);
if (hash === null) {
return;
}
/** @type {?} */
const pageNo = this.getPageNo(self.apiCall.url);
/** @type {?} */
const itemsOnPage = this.getPageEntries(self.apiCall.url);
this.setHash(hash, pageNo, itemsOnPage);
this.initialize(body);
return body;
}, err => { throw Error(err); });
}
/**
* @param {?} url
* @return {?}
*/
getPageNo(url) {
/** @type {?} */
let result = -1;
/** @type {?} */
const regexp = /page=[0-9]+/gm;
/** @type {?} */
const matches = url.match(regexp);
if (matches && matches.length > 0) {
result = +matches[0].replace('page=', '');
}
if (result === -1) {
return 1;
}
return result;
}
/**
* @param {?} url
* @return {?}
*/
getPageEntries(url) {
/** @type {?} */
let result = -1;
/** @type {?} */
const regexp = /pageentries=[0-9]+/gm;
/** @type {?} */
const matches = url.match(regexp);
if (matches && matches.length > 0) {
result = +matches[0].replace('pageentries=', '');
}
if (result === -1) {
return 50;
}
return result;
}
/**
* @protected
* @param {?} response
* @return {?}
*/
initialize(response) { }
/**
* @param {?} data
* @param {?} apiCall
* @return {?}
*/
parseHttpHeader(data, apiCall) {
this.apiCall = apiCall;
/** @type {?} */
const hash = data.headers.get(BaseMasterComponent.CACHED_HEADER);
/** @type {?} */
const pageNo = this.getPageNo(apiCall.url);
/** @type {?} */
const itemsOnPage = this.getPageEntries(apiCall.url);
if (hash !== null) {
this.setHash(hash, pageNo, itemsOnPage);
}
}
/**
* @protected
* @param {?} id
* @param {?} hash
* @param {?} i
* @param {?} apiCall
* @param {?} total
* @param {?=} itemsOnPage
* @return {?}
*/
openDetails(id, hash, i, apiCall, total, itemsOnPage = 50) {
/** @type {?} */
const pagingEvent = new PagingEvent(hash);
pagingEvent.startIndex = 0;
/** @type {?} */
const index = (this.getPageNo(apiCall.url) - 1) * itemsOnPage + i;
pagingEvent.currentIndex = index;
pagingEvent.total = total;
pagingEvent.itemsOnPage = itemsOnPage;
pagingEvent.backUrl = encodeURIComponent(this.router.url);
pagingEvent.detailsUrl = this.detailsUrl;
pagingEvent.currentId = id;
pagingEvent.targetUrl = PagingService.buildRedirectUrl(pagingEvent);
pagingEvent.apiCall = apiCall;
PagingService.saveToLocalStorage(pagingEvent);
this.router.navigateByUrl(pagingEvent.targetUrl);
}
/**
* @param {?} hashFromHeader
* @param {?} currentPage
* @param {?} itemsOnPage
* @return {?}
*/
setHash(hashFromHeader, currentPage, itemsOnPage) {
this.hash = hashFromHeader;
PagingService.fireHashChangedEvent(hashFromHeader, this.context, currentPage, itemsOnPage);
}
}
BaseMasterComponent.CACHED_HEADER = 'SearchResultsHash';
BaseMasterComponent.decorators = [
{ type: Component, args: [{
template: '',
providers: [PagingService]
}] }
];
BaseMasterComponent.ctorParameters = () => [
{ type: Router },
{ type: HttpService }
];
if (false) {
/** @type {?} */
BaseMasterComponent.CACHED_HEADER;
/** @type {?} */
BaseMasterComponent.prototype.apiCall;
/** @type {?} */
BaseMasterComponent.prototype.detailsUrl;
/** @type {?} */
BaseMasterComponent.prototype.hash;
/** @type {?} */
BaseMasterComponent.prototype.data;
/** @type {?} */
BaseMasterComponent.prototype.context;
/**
* @type {?}
* @protected
*/
BaseMasterComponent.prototype.router;
/**
* @type {?}
* @protected
*/
BaseMasterComponent.prototype.httpService;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-master.component.js","sourceRoot":"ng://air-lib/","sources":["lib/components/base-master/base-master.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { ApiCallInfo } from './../../entities/api-call-info';\r\nimport { PagingService } from './../../services/paging.service';\r\nimport { Component, OnInit } from '@angular/core';\r\nimport { HttpResponse } from '@angular/common/http';\r\nimport { Router } from '@angular/router';\r\nimport { HttpService } from '../../services/http.service';\r\nimport { PagingEvent } from '../../entities/paging-event';\r\n\r\n@Component({\r\n  template: '',\r\n  providers: [PagingService]\r\n})\r\n\r\nexport class BaseMasterComponent implements OnInit {\r\n\r\n  public static CACHED_HEADER = 'SearchResultsHash';\r\n  public apiCall: ApiCallInfo;\r\n  public detailsUrl: string;\r\n  public hash: string;\r\n  public data: any;\r\n  public context: string;\r\n  \r\n  constructor(protected router: Router, protected httpService: HttpService) {\r\n  \r\n  }\r\n\r\n  ngOnInit() {\r\n    this.setData();\r\n  }\r\n\r\n  protected setData() {\r\n    const self = this;\r\n\r\n    self.httpService.get(self.apiCall.url)\r\n      .subscribe(\r\n        (data: HttpResponse<Object>) => {\r\n\r\n          const body = data.body as any;\r\n          const hash = data.headers.get(BaseMasterComponent.CACHED_HEADER);\r\n          if (hash === null) {\r\n            return;\r\n          }\r\n          const pageNo = this.getPageNo(self.apiCall.url);\r\n          const itemsOnPage = this.getPageEntries(self.apiCall.url);\r\n          this.setHash(hash, pageNo, itemsOnPage);\r\n\r\n          this.initialize(body);\r\n          return body;\r\n        },\r\n        err => { throw Error(err); }\r\n      );\r\n  }\r\n\r\n  public getPageNo(url: string): number {\r\n    let result = -1;\r\n    const regexp = /page=[0-9]+/gm;\r\n    const matches = url.match(regexp);\r\n    if (matches && matches.length > 0) {\r\n      result = +matches[0].replace('page=', '');\r\n    }\r\n    if (result === -1) {\r\n      return 1;\r\n    }\r\n    return result;\r\n  }\r\n\r\n  public getPageEntries(url: string): number {\r\n    let result = -1;\r\n    const regexp = /pageentries=[0-9]+/gm;\r\n    const matches = url.match(regexp);\r\n    if (matches && matches.length > 0) {\r\n      result = +matches[0].replace('pageentries=', '');\r\n    }\r\n    if (result === -1) {\r\n      return 50;\r\n    }\r\n    return result;\r\n  }\r\n\r\n  protected initialize(response: any) { }\r\n\r\n  public parseHttpHeader(data: HttpResponse<Object>, apiCall: ApiCallInfo) {\r\n    this.apiCall = apiCall;\r\n    const hash = data.headers.get(BaseMasterComponent.CACHED_HEADER);\r\n    const pageNo = this.getPageNo(apiCall.url);\r\n    const itemsOnPage = this.getPageEntries(apiCall.url);\r\n    if (hash !== null) {\r\n      this.setHash(hash, pageNo, itemsOnPage);\r\n    }\r\n  }\r\n\r\n  protected openDetails(id: string, hash: string, i: number, apiCall: ApiCallInfo, total: number, itemsOnPage: number = 50) {\r\n\r\n    const pagingEvent = new PagingEvent(hash);\r\n    \r\n    pagingEvent.startIndex = 0;\r\n    const index = (this.getPageNo(apiCall.url) - 1) * itemsOnPage + i;\r\n    pagingEvent.currentIndex = index;\r\n    pagingEvent.total = total;\r\n    pagingEvent.itemsOnPage = itemsOnPage;\r\n    pagingEvent.backUrl = encodeURIComponent(this.router.url);\r\n    pagingEvent.detailsUrl = this.detailsUrl;\r\n    pagingEvent.currentId = id;\r\n    pagingEvent.targetUrl = PagingService.buildRedirectUrl(pagingEvent);\r\n    pagingEvent.apiCall = apiCall;\r\n    PagingService.saveToLocalStorage(pagingEvent);\r\n\r\n    this.router.navigateByUrl(pagingEvent.targetUrl);\r\n\r\n  }\r\n\r\n  public setHash(hashFromHeader: string, currentPage: number, itemsOnPage: number) {\r\n    this.hash = hashFromHeader;\r\n    PagingService.fireHashChangedEvent(hashFromHeader, this.context, currentPage, itemsOnPage);\r\n  }\r\n}\r\n"]}