UNPKG

air-lib

Version:

This is Air's angular component library

184 lines 15.3 kB
/** * @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"]}