UNPKG

@pshurygin/ngx-quicklink

Version:
89 lines 11.4 kB
import * as tslib_1 from "tslib"; import { Injectable, InjectionToken, NgZone } from '@angular/core'; import { RouterPreloader } from '@angular/router'; import { PrefetchRegistry } from './prefetch-registry.service'; const ɵ0 = function (cb) { const start = Date.now(); return setTimeout(function () { cb({ didTimeout: false, timeRemaining: function () { return Math.max(0, 50 - (Date.now() - start)); } }); }, 1); }, ɵ1 = () => { }; const requestIdleCallback = typeof window !== 'undefined' ? window.requestIdleCallback || ɵ0 : ɵ1; const observerSupported = () => typeof window !== 'undefined' ? !!window.IntersectionObserver : false; const ɵ2 = observerSupported; export const LinkHandler = new InjectionToken('LinkHandler'); let ObservableLinkHandler = class ObservableLinkHandler { constructor(loader, queue, ngZone) { this.loader = loader; this.queue = queue; this.ngZone = ngZone; this.elementLink = new Map(); this.observer = observerSupported() ? new IntersectionObserver(entries => { entries.forEach(entry => { if (entry.isIntersecting) { const link = entry.target; const routerLink = this.elementLink.get(link); if (!routerLink || !routerLink.urlTree) return; this.queue.add(routerLink.urlTree); this.observer.unobserve(link); requestIdleCallback(() => { this.loader.preload().subscribe(() => void 0); this.queue.remove(routerLink.urlTree); }); } }); }) : null; } register(el) { this.elementLink.set(el.element, el); this.ngZone.runOutsideAngular(() => { this.observer.observe(el.element); }); } // First call to unregister will not hit this. unregister(el) { if (this.elementLink.has(el.element)) { this.observer.unobserve(el.element); this.elementLink.delete(el.element); } } supported() { return observerSupported(); } }; ObservableLinkHandler = tslib_1.__decorate([ Injectable(), tslib_1.__metadata("design:paramtypes", [RouterPreloader, PrefetchRegistry, NgZone]) ], ObservableLinkHandler); export { ObservableLinkHandler }; let PreloadLinkHandler = class PreloadLinkHandler { constructor(loader, queue) { this.loader = loader; this.queue = queue; } register(el) { this.queue.add(el.urlTree); requestIdleCallback(() => this.loader.preload().subscribe(() => void 0)); } unregister(_) { } supported() { return true; } }; PreloadLinkHandler = tslib_1.__decorate([ Injectable(), tslib_1.__metadata("design:paramtypes", [RouterPreloader, PrefetchRegistry]) ], PreloadLinkHandler); export { PreloadLinkHandler }; export { ɵ0, ɵ1, ɵ2 }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"link-handler.service.js","sourceRoot":"ng://@pshurygin/ngx-quicklink/","sources":["src/link-handler.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, InjectionToken, NgZone } from '@angular/core';\nimport { LinkDirective } from './link.directive';\nimport { RouterPreloader } from '@angular/router';\nimport { LinkHandlerStrategy } from './link-handler-strategy';\nimport { PrefetchRegistry } from './prefetch-registry.service';\n\ntype RequestIdleCallbackHandle = any;\ntype RequestIdleCallbackOptions = {\n  timeout: number;\n};\ntype RequestIdleCallbackDeadline = {\n  readonly didTimeout: boolean;\n  timeRemaining: (() => number);\n};\n\ntype RequestIdleCallback = ((\n  callback: ((deadline: RequestIdleCallbackDeadline) => void),\n  opts?: RequestIdleCallbackOptions\n) => RequestIdleCallbackHandle);\n\nconst requestIdleCallback: RequestIdleCallback =\n  typeof window !== 'undefined'\n    ? (window as any).requestIdleCallback ||\n      function(cb: Function) {\n        const start = Date.now();\n        return setTimeout(function() {\n          cb({\n            didTimeout: false,\n            timeRemaining: function() {\n              return Math.max(0, 50 - (Date.now() - start));\n            }\n          });\n        }, 1);\n      }\n    : () => {};\n\nconst observerSupported = () =>\n  typeof window !== 'undefined' ? !!(window as any).IntersectionObserver : false;\n\nexport const LinkHandler = new InjectionToken('LinkHandler');\n\n@Injectable()\nexport class ObservableLinkHandler implements LinkHandlerStrategy {\n  private elementLink = new Map<Element, LinkDirective>();\n  private observer: IntersectionObserver | null = observerSupported()\n    ? new IntersectionObserver(entries => {\n        entries.forEach(entry => {\n          if (entry.isIntersecting) {\n            const link = entry.target as HTMLAnchorElement;\n\n            const routerLink = this.elementLink.get(link);\n            if ( !routerLink || !routerLink.urlTree ) return;\n\n            this.queue.add(routerLink.urlTree);\n            this.observer.unobserve(link);\n            requestIdleCallback(() => {\n              this.loader.preload().subscribe(() => void 0);\n              this.queue.remove(routerLink.urlTree);\n            });\n          }\n        });\n      })\n    : null;\n\n  constructor(private loader: RouterPreloader, private queue: PrefetchRegistry, private ngZone: NgZone) {}\n\n  register(el: LinkDirective) {\n    this.elementLink.set(el.element, el);\n    this.ngZone.runOutsideAngular(() => {\n      this.observer.observe(el.element);\n    });\n  }\n\n  // First call to unregister will not hit this.\n  unregister(el: LinkDirective) {\n    if (this.elementLink.has(el.element)) {\n      this.observer.unobserve(el.element);\n      this.elementLink.delete(el.element);\n    }\n  }\n\n  supported() {\n    return observerSupported();\n  }\n}\n\n@Injectable()\nexport class PreloadLinkHandler implements LinkHandlerStrategy {\n  constructor(private loader: RouterPreloader, private queue: PrefetchRegistry) {}\n\n  register(el: LinkDirective) {\n    this.queue.add(el.urlTree);\n    requestIdleCallback(() => this.loader.preload().subscribe(() => void 0));\n  }\n\n  unregister(_: LinkDirective) {}\n\n  supported() {\n    return true;\n  }\n}\n"]}