UNPKG

ack-angular

Version:

Extra special directives, components, providers and pipes to aide in tackling everyday interface development needs in Angular2

194 lines 23.9 kB
//import { StateService,TransitionService,Transition } from "ui-router-ng2"; import { NavigationEnd } from '@angular/router'; import { Injectable } from '@angular/core'; import * as i0 from "@angular/core"; import * as i1 from "@angular/router"; /** A stateful connection to ui-router history - .stateChange() with arguments MUST be called at every state change - Has 99% accuracy of knowing if OS back or forward button has been used - Their is no web event for knowing if OS button is used. */ export class RouteWatchReporter { constructor(router, activatedRoute) { this.router = router; this.activatedRoute = activatedRoute; this.current = {}; this.$history = []; //$window : any this.historyPos = 0; this.isBackMode = false; this.isOsAction = false; this.isNextBackMode = false; this.isNextBackHistory = false; this.activatedRoute = activatedRoute; router.events.subscribe(event => { if (event.constructor == NavigationEnd) { //const params = {}//COMING REALLY SOON const current = this.getCurrent(); this.recordStateChange(current.config, current.params); } }); this.current = this.getCurrent(); } $window() { return window; } getCurrent() { return getCurrentByActive(this.activatedRoute); } getCurrentConfig() { let target = this.activatedRoute; while (target.firstChild) target = target.firstChild; return (target.routeConfig || target["config"] || target); } getCurrentParams() { let target = this.activatedRoute; while (target.firstChild) target = target.firstChild; return target.snapshot.params; } isTrapHistory(toState, toParams) { return this.isBackHistory(toState, toParams) && this.isForwardHistory(toState, toParams); } isBackHistory(toState, toParams) { const $history = this.$history; const isEven = $history.length > this.historyPos + 1; const isNameMatch = isEven && toState && toState.name == $history[this.historyPos + 1].name; return isNameMatch && this.isParamsMatch(toParams, $history[this.historyPos + 1].params); } isForwardHistory(toState, toParams) { const $history = this.$history; const isEven = !this.isNextBackMode && this.historyPos && $history.length > this.historyPos; const isNameMatch = isEven && toState && toState.name == $history[this.historyPos - 1].name; return isNameMatch && this.isParamsMatch(toParams, $history[this.historyPos - 1].params); } isParamsMatch(toParams, otherParams) { if (!toParams || !otherParams) { return false; } for (let x in toParams) { if (toParams[x] != otherParams[x]) { return false; } } return true; } recordStateChange(toState, toParams) { this.current = { params: toParams, config: toState }; let isForward = this.isForwardHistory(toState, toParams); let isBackHistory = this.isNextBackHistory || this.isBackHistory(toState, toParams); if (this.isOsAction && this.isTrapHistory(toState, toParams)) { if (this.isBackMode) { isForward = false; } else { isBackHistory = false; } } else { this.isBackMode = this.isNextBackMode || (this.isOsAction && isBackHistory); } const $history = this.$history; if (!toState) return; if (isForward) { --this.historyPos; } else if (this.isBackMode) { ++this.historyPos; } else { //const $state = this.$state() this.historyPos = 0; const hist = { name: toState.name, title: toState.title, data: toState.data, params: toParams }; if (!Object.keys(toParams).length) { delete hist.params; } $history.unshift(hist); } this.isNextBackHistory = false; } /** deprecated and most likely not working */ goBackTo(name, params) { this.isNextBackMode = true; this.isNextBackHistory = true; this.$state().go(name, params); } tryBack(name, params) { if (this.$history.length) { this.goHistoryBack(); } else { this.goBackTo(name, params); } } goHistoryBack() { this.isNextBackMode = true; this.isNextBackHistory = true; this.$window().history.back(); } watchDocument($document) { this.watchDocByCallbacks($document, this.getDocumentCallbacks()); } getDocumentCallbacks() { const isBackButton = () => { this.isOsAction = true; }; const isNotBackButton = () => { this.isOsAction = false; }; return { isBackButton: isBackButton, isNotBackButton: isNotBackButton }; } watchDocByCallbacks($document, callbacks) { $document.addEventListener('mouseout', callbacks.isBackButton); //$document.addEventListener('mouseover', callbacks.mouseover) $document.addEventListener('mousedown', callbacks.isNotBackButton); } unwatchDocByCallbacks($document, callbacks) { $document.removeEventListener('mouseout', callbacks.isBackButton); $document.removeEventListener('mouseover', callbacks.isNotBackButton); $document.removeEventListener('mousedown', callbacks.isNotBackButton); } } RouteWatchReporter.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: RouteWatchReporter, deps: [{ token: i1.Router }, { token: i1.ActivatedRoute }], target: i0.ɵɵFactoryTarget.Injectable }); RouteWatchReporter.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: RouteWatchReporter }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.4", ngImport: i0, type: RouteWatchReporter, decorators: [{ type: Injectable }], ctorParameters: function () { return [{ type: i1.Router }, { type: i1.ActivatedRoute }]; } }); export function getCurrentByActive(ActivatedRoute) { let parent = ActivatedRoute; let target = ActivatedRoute; while (target.firstChild) { parent = target; target = target.firstChild; } return { ...breakdownActivated(target), parent: breakdownActivated(parent), }; } export function getRouteByActive(ActivatedRoute) { let target = ActivatedRoute; while (target.firstChild) { target = target.firstChild; } return target; } function breakdownActivated(target) { const snapshot = target.snapshot || {}; return { ActivatedRoute: target, config: (target.routeConfig || target['config']), params: snapshot.params, }; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"RouteWatchReporter.js","sourceRoot":"","sources":["../../../../src/modules/router/RouteWatchReporter.ts"],"names":[],"mappings":"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","sourcesContent":["//import { StateService,TransitionService,Transition } from \"ui-router-ng2\";\nimport {\n  Route, Router, NavigationEnd,\n  ActivatedRoute, ActivatedRouteSnapshot, Data, Resolve, ResolveFn, Params\n} from '@angular/router';\nimport { Injectable, Type } from '@angular/core';\n\nexport interface RouteInsight {\n  config  : Route//|ActivatedRoute\n  ActivatedRoute?: ActivatedRoute\n}\n\nexport interface currentRoute extends RouteInsight {\n  ActivatedRoute : ActivatedRoute\n  params  : Record<string, string>\n  parent? : currentRoute//|ActivatedRoute\n}\n\ninterface History {\n  name: string\n  title?: string | Type<Resolve<string>> | ResolveFn<string>\n  params?: any\n  data?: Data\n}\n\n/** A stateful connection to ui-router history\n - .stateChange() with arguments MUST be called at every state change\n - Has 99% accuracy of knowing if OS back or forward button has been used\n   - Their is no web event for knowing if OS button is used.\n*/\n@Injectable() export class RouteWatchReporter{\n  current  : any = {}\n  $history : History[] = []\n  $state   : any\n  //$window  : any\n\n  historyPos : number = 0\n  isBackMode : boolean = false\n  isOsAction : boolean = false\n  isNextBackMode : boolean = false\n  isNextBackHistory : boolean = false\n\n  constructor(\n    public router: Router,\n    public activatedRoute:ActivatedRoute\n  ){\n    this.activatedRoute = activatedRoute\n\n    router.events.subscribe(event=>{\n      if(event.constructor==NavigationEnd){\n        //const params = {}//COMING REALLY SOON\n        const current = this.getCurrent()\n        this.recordStateChange(\n          current.config,\n          current.params\n         )\n      }\n    })\n\n    this.current = this.getCurrent()\n  }\n\n  $window(){\n    return window\n  }\n\n  getCurrent() : currentRoute{\n    return getCurrentByActive( this.activatedRoute )\n  }\n\n  getCurrentConfig():Route{\n    let target = this.activatedRoute\n    while(target.firstChild)target=target.firstChild\n    return <Route>(target.routeConfig || target[\"config\"] || target)\n  }\n\n  getCurrentParams(): Params | undefined {\n    let target = this.activatedRoute\n    while(target.firstChild)target=target.firstChild\n    return target.snapshot.params\n  }\n\n  isTrapHistory(toState: any, toParams: any): boolean{\n    return this.isBackHistory(toState, toParams) && this.isForwardHistory(toState, toParams)\n  }\n\n  isBackHistory(toState: any, toParams: any): boolean{\n    const $history = this.$history\n    const isEven = $history.length > this.historyPos+1\n    const isNameMatch = isEven && toState && toState.name==$history[this.historyPos+1].name\n    return isNameMatch && this.isParamsMatch(toParams, $history[this.historyPos+1].params)\n  }\n\n  isForwardHistory(toState: any, toParams: any): boolean{\n    const $history = this.$history\n    const isEven = !this.isNextBackMode && this.historyPos && $history.length>this.historyPos\n    const isNameMatch = isEven && toState && toState.name==$history[this.historyPos-1].name\n    return isNameMatch && this.isParamsMatch(toParams, $history[this.historyPos-1].params)\n  }\n\n  isParamsMatch(toParams: any, otherParams: any):boolean{\n    if( !toParams || !otherParams ){\n      return false\n    }\n\n    for(let x in toParams){\n      if(toParams[x]!=otherParams[x]){\n        return false\n      }\n    }\n\n    return true\n  }\n\n  recordStateChange(toState: Route, toParams: any){\n    this.current = { params:toParams, config:toState }\n    let isForward = this.isForwardHistory(toState, toParams)\n    let isBackHistory = this.isNextBackHistory || this.isBackHistory(toState, toParams)\n\n    if(this.isOsAction && this.isTrapHistory(toState, toParams)){\n      if(this.isBackMode){\n        isForward = false\n      }else{\n        isBackHistory = false\n      }\n    }else{\n      this.isBackMode = this.isNextBackMode || (this.isOsAction && isBackHistory)\n    }\n\n    const $history = this.$history\n\n    if(!toState)return\n\n    if(isForward){\n      --this.historyPos\n    }else if(this.isBackMode){\n      ++this.historyPos\n    }else{\n      //const $state = this.$state()\n      this.historyPos = 0\n      const hist: History = {\n        name: (toState as any).name,\n        title: toState.title,\n        data: toState.data,\n        params:toParams\n      }\n\n      if( !Object.keys(toParams).length ){\n        delete hist.params\n      }\n\n      $history.unshift(hist)\n    }\n\n    this.isNextBackHistory = false\n  }\n\n  /** deprecated and most likely not working */\n  goBackTo(name: any, params: any){\n    this.isNextBackMode = true\n    this.isNextBackHistory = true\n    this.$state().go(name, params)\n  }\n\n  tryBack(name: any, params: any){\n    if(this.$history.length){\n      this.goHistoryBack()\n    }else{\n      this.goBackTo(name, params)\n    }\n  }\n\n  goHistoryBack() {\n    this.isNextBackMode = true\n    this.isNextBackHistory = true\n    this.$window().history.back()\n  }\n\n  watchDocument($document: any){\n    this.watchDocByCallbacks($document, this.getDocumentCallbacks())\n  }\n\n  getDocumentCallbacks(){\n    const isBackButton = ()=>{\n      this.isOsAction = true\n    }\n\n    const isNotBackButton = ()=>{\n      this.isOsAction = false\n    }\n\n    return {\n      isBackButton    : isBackButton,\n      isNotBackButton : isNotBackButton\n    }\n  }\n\n  watchDocByCallbacks($document: any, callbacks: any){\n    $document.addEventListener('mouseout', callbacks.isBackButton)\n    //$document.addEventListener('mouseover', callbacks.mouseover)\n    $document.addEventListener('mousedown', callbacks.isNotBackButton)\n  }\n\n  unwatchDocByCallbacks($document: any, callbacks: any){\n    $document.removeEventListener('mouseout', callbacks.isBackButton)\n    $document.removeEventListener('mouseover', callbacks.isNotBackButton)\n    $document.removeEventListener('mousedown', callbacks.isNotBackButton)\n  }\n}\n\nexport function getCurrentByActive( ActivatedRoute:ActivatedRoute ): currentRoute {\n  let parent = ActivatedRoute\n  let target = ActivatedRoute\n  while(target.firstChild){\n    parent = target\n    target = target.firstChild\n  }\n\n  return {\n    ...breakdownActivated(target),\n    parent: breakdownActivated(parent),\n  }\n}\n\nexport function getRouteByActive( ActivatedRoute: ActivatedRoute ): ActivatedRoute {\n  let target = ActivatedRoute\n  while(target.firstChild){\n    target = target.firstChild\n  }\n\n  return target\n}\n\nfunction breakdownActivated(target: ActivatedRoute) {\n  const snapshot = target.snapshot || <ActivatedRouteSnapshot>{}\n  return {\n    ActivatedRoute: target,\n    config:<Route>(target.routeConfig || target['config']), //  || target\n    params: snapshot.params,\n  }\n}"]}