UNPKG

ng-zorro-antd

Version:

An enterprise-class UI components based on Ant Design and Angular

116 lines (110 loc) 4.51 kB
import { ɵɵdefineInjectable, Injectable, ɵɵinject, NgModule } from '@angular/core'; import { coerceElement } from '@angular/cdk/coercion'; import ResizeObserver from 'resize-observer-polyfill'; import { Observable, Subject } from 'rxjs'; /** * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE */ /** * Factory that creates a new ResizeObserver and allows us to stub it out in unit tests. */ class NzResizeObserverFactory { create(callback) { return typeof ResizeObserver === 'undefined' ? null : new ResizeObserver(callback); } } NzResizeObserverFactory.ɵprov = ɵɵdefineInjectable({ factory: function NzResizeObserverFactory_Factory() { return new NzResizeObserverFactory(); }, token: NzResizeObserverFactory, providedIn: "root" }); NzResizeObserverFactory.decorators = [ { type: Injectable, args: [{ providedIn: 'root' },] } ]; /** An injectable service that allows watching elements for changes to their content. */ class NzResizeObserver { constructor(nzResizeObserverFactory) { this.nzResizeObserverFactory = nzResizeObserverFactory; /** Keeps track of the existing ResizeObservers so they can be reused. */ this.observedElements = new Map(); } ngOnDestroy() { this.observedElements.forEach((_, element) => this.cleanupObserver(element)); } observe(elementOrRef) { const element = coerceElement(elementOrRef); return new Observable((observer) => { const stream = this.observeElement(element); const subscription = stream.subscribe(observer); return () => { subscription.unsubscribe(); this.unobserveElement(element); }; }); } /** * Observes the given element by using the existing ResizeObserver if available, or creating a * new one if not. */ observeElement(element) { if (!this.observedElements.has(element)) { const stream = new Subject(); const observer = this.nzResizeObserverFactory.create(mutations => stream.next(mutations)); if (observer) { observer.observe(element); } this.observedElements.set(element, { observer, stream, count: 1 }); } else { this.observedElements.get(element).count++; } return this.observedElements.get(element).stream; } /** * Un-observes the given element and cleans up the underlying ResizeObserver if nobody else is * observing this element. */ unobserveElement(element) { if (this.observedElements.has(element)) { this.observedElements.get(element).count--; if (!this.observedElements.get(element).count) { this.cleanupObserver(element); } } } /** Clean up the underlying ResizeObserver for the specified element. */ cleanupObserver(element) { if (this.observedElements.has(element)) { const { observer, stream } = this.observedElements.get(element); if (observer) { observer.disconnect(); } stream.complete(); this.observedElements.delete(element); } } } NzResizeObserver.ɵprov = ɵɵdefineInjectable({ factory: function NzResizeObserver_Factory() { return new NzResizeObserver(ɵɵinject(NzResizeObserverFactory)); }, token: NzResizeObserver, providedIn: "root" }); NzResizeObserver.decorators = [ { type: Injectable, args: [{ providedIn: 'root' },] } ]; NzResizeObserver.ctorParameters = () => [ { type: NzResizeObserverFactory } ]; /** * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE */ class NzResizeObserversModule { } NzResizeObserversModule.decorators = [ { type: NgModule, args: [{ providers: [NzResizeObserverFactory] },] } ]; /** * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE */ /** * Generated bundle index. Do not edit. */ export { NzResizeObserver, NzResizeObserversModule, NzResizeObserverFactory as ɵNzResizeObserverFactory }; //# sourceMappingURL=ng-zorro-antd-core-resize-observers.js.map