UNPKG

@raphy/ngx-equalizer

Version:

A library to equalize height and width of elements with Angular4+

293 lines (282 loc) 19.4 kB
import { Injectable, Directive, ElementRef, Input, ContentChildren, HostListener, QueryList, Renderer2, NgModule } from '@angular/core'; import { CommonModule } from '@angular/common'; /** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ var EqualizerService = /** @class */ (function () { function EqualizerService() { } /** * @param {?} renderer * @param {?} elementRefs * @param {?=} params * @return {?} */ EqualizerService.prototype.equalize = /** * @param {?} renderer * @param {?} elementRefs * @param {?=} params * @return {?} */ function (renderer, elementRefs, params) { if (params === void 0) { params = { property: 'height', reset: true }; } var /** @type {?} */ maxValue = 0; elementRefs.map(function (elementRef) { if (params.reset) { renderer.setStyle(elementRef.nativeElement, params.property, 'initial'); } var /** @type {?} */ value = elementRef.nativeElement['offset' + params.property[0].toUpperCase() + params.property.slice(1)]; maxValue = value > maxValue ? value : maxValue; }); elementRefs.map(function (elementRef) { renderer.setStyle(elementRef.nativeElement, params.property, maxValue + 'px'); }); }; EqualizerService.decorators = [ { type: Injectable }, ]; return EqualizerService; }()); /** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ /** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ var EqualizerWatcherDirective = /** @class */ (function () { function EqualizerWatcherDirective(_elementRef) { this._elementRef = _elementRef; } Object.defineProperty(EqualizerWatcherDirective.prototype, "elementRef", { get: /** * @return {?} */ function () { return this._elementRef; }, enumerable: true, configurable: true }); Object.defineProperty(EqualizerWatcherDirective.prototype, "id", { get: /** * @return {?} */ function () { return this._id; }, set: /** * @param {?} value * @return {?} */ function (value) { this._id = value; }, enumerable: true, configurable: true }); EqualizerWatcherDirective.decorators = [ { type: Directive, args: [{ selector: '[equalizerWatcher]' },] }, ]; /** @nocollapse */ EqualizerWatcherDirective.ctorParameters = function () { return [ { type: ElementRef } ]; }; EqualizerWatcherDirective.propDecorators = { _id: [{ type: Input, args: ['equalizerWatcher',] }] }; return EqualizerWatcherDirective; }()); /** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ var EqualizerDirective = /** @class */ (function () { function EqualizerDirective(_elementRef, _renderer, _equalizerService) { this._elementRef = _elementRef; this._renderer = _renderer; this._equalizerService = _equalizerService; this._params = 'height'; this._watchers = new QueryList(); } Object.defineProperty(EqualizerDirective.prototype, "params", { get: /** * @return {?} */ function () { return this._params; }, set: /** * @param {?} value * @return {?} */ function (value) { this._params = value; this.equalize(); }, enumerable: true, configurable: true }); Object.defineProperty(EqualizerDirective.prototype, "elementRef", { get: /** * @return {?} */ function () { return this._elementRef; }, enumerable: true, configurable: true }); Object.defineProperty(EqualizerDirective.prototype, "id", { get: /** * @return {?} */ function () { return this._id; }, set: /** * @param {?} value * @return {?} */ function (value) { this._id = value; }, enumerable: true, configurable: true }); /** * @return {?} */ EqualizerDirective.prototype.ngAfterViewChecked = /** * @return {?} */ function () { this.equalize(); }; /** * @return {?} */ EqualizerDirective.prototype._onResize = /** * @return {?} */ function () { this.equalize(); }; /** * @return {?} */ EqualizerDirective.prototype.equalize = /** * @return {?} */ function () { var _this = this; if (!this._params) { this._params = 'height'; } var /** @type {?} */ params = Object.assign({ property: 'height', reset: true }, typeof this._params === 'string' ? { property: this._params } : this._params); var /** @type {?} */ watchers = this._watchers.filter(function (watcher) { console.log('ID matching', watcher.id, _this.id); if (watcher.id || _this.id) { return watcher.id === _this.id; } return watcher.elementRef.nativeElement !== _this._elementRef.nativeElement; }).map(function (watcher) { return watcher.elementRef; }); this._equalizerService.equalize(this._renderer, watchers, params); }; EqualizerDirective.decorators = [ { type: Directive, args: [{ selector: '[equalizer]', exportAs: 'equalizer' },] }, ]; /** @nocollapse */ EqualizerDirective.ctorParameters = function () { return [ { type: ElementRef }, { type: Renderer2 }, { type: EqualizerService } ]; }; EqualizerDirective.propDecorators = { _params: [{ type: Input, args: ['equalizer',] }], _id: [{ type: Input, args: ['equalizerId',] }], _watchers: [{ type: ContentChildren, args: [EqualizerWatcherDirective, { read: EqualizerWatcherDirective },] }], _onResize: [{ type: HostListener, args: ['window:resize',] }] }; return EqualizerDirective; }()); /** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ /** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ var EqualizerModule = /** @class */ (function () { function EqualizerModule() { } /** * @return {?} */ EqualizerModule.forRoot = /** * @return {?} */ function () { return { ngModule: EqualizerModule, providers: [ EqualizerService, ] }; }; /** * @return {?} */ EqualizerModule.forChild = /** * @return {?} */ function () { return { ngModule: EqualizerModule, providers: [ EqualizerService ] }; }; EqualizerModule.decorators = [ { type: NgModule, args: [{ imports: [ CommonModule, ], exports: [ EqualizerDirective, EqualizerWatcherDirective, ], declarations: [ EqualizerDirective, EqualizerWatcherDirective, ], providers: [ EqualizerService, ], },] }, ]; return EqualizerModule; }()); /** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ /** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ /** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ export { EqualizerDirective, EqualizerWatcherDirective, EqualizerService, EqualizerModule, EqualizerDirective as ɵa, EqualizerWatcherDirective as ɵb, EqualizerService as ɵc }; //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"raphy-ngx-equalizer.js.map","sources":["ng://@raphy/ngx-equalizer/lib/services/equalizer.service.ts","ng://@raphy/ngx-equalizer/lib/directives/equalizer-watcher.directive.ts","ng://@raphy/ngx-equalizer/lib/directives/equalizer.directive.ts","ng://@raphy/ngx-equalizer/lib/equalizer.module.ts"],"sourcesContent":["import { ElementRef, Injectable, Renderer2 } from '@angular/core';\n\nimport { EqualizeParams } from '../equalize-params';\n\n@Injectable()\nexport class EqualizerService {\n    public equalize(\n        renderer: Renderer2,\n        elementRefs: ElementRef[],\n        params: EqualizeParams = {property: 'height', reset: true}\n    ) {\n\n        let maxValue: number = 0;\n\n        elementRefs.map(\n            (elementRef: ElementRef) => {\n                if (params.reset) {\n                    renderer.setStyle(elementRef.nativeElement, params.property, 'initial');\n                }\n\n                const value: number = elementRef.nativeElement['offset' + params.property[0].toUpperCase() + params.property.slice(1)];\n                maxValue = value > maxValue ? value : maxValue;\n            }\n        );\n\n        elementRefs.map(\n            (elementRef: ElementRef) => {\n                renderer.setStyle(elementRef.nativeElement, params.property, maxValue + 'px');\n            }\n        );\n    }\n}\n","import { Directive, ElementRef, Input } from '@angular/core';\n\n@Directive({\n    selector: '[equalizerWatcher]'\n})\nexport class EqualizerWatcherDirective {\n    @Input('equalizerWatcher')\n    private _id: string | number;\n\n    get elementRef(): ElementRef {\n        return this._elementRef;\n    }\n\n    get id(): string | number {\n        return this._id;\n    }\n\n    set id(value: string | number) {\n        this._id = value;\n    }\n\n    constructor(\n        private _elementRef: ElementRef\n    ) {\n    }\n}\n","import { AfterViewChecked, ContentChildren, Directive, ElementRef, HostListener, Input, QueryList, Renderer2 } from '@angular/core';\n\nimport { EqualizeParams } from '../equalize-params';\nimport { EqualizerService } from '../services/index';\nimport { EqualizerWatcherDirective } from './equalizer-watcher.directive';\n\n\n@Directive({\n    selector: '[equalizer]',\n    exportAs: 'equalizer'\n})\nexport class EqualizerDirective implements AfterViewChecked {\n    @Input('equalizer')\n    private _params: 'height' | 'width' | EqualizeParams = 'height';\n\n    @Input('equalizerId')\n    private _id: string | number;\n\n    @ContentChildren(EqualizerWatcherDirective, {read: EqualizerWatcherDirective})\n    private _watchers: QueryList<EqualizerWatcherDirective> = new QueryList<EqualizerWatcherDirective>();\n\n    get params() {\n        return this._params;\n    }\n\n    set params(value) {\n        this._params = value;\n\n        this.equalize();\n    }\n\n    get elementRef(): ElementRef {\n        return this._elementRef;\n    }\n\n    get id(): string | number {\n        return this._id;\n    }\n\n    set id(value: string | number) {\n        this._id = value;\n    }\n\n    constructor(\n        private _elementRef: ElementRef,\n        private _renderer: Renderer2,\n        private _equalizerService: EqualizerService\n    ) {\n    }\n\n    public ngAfterViewChecked(): void {\n        this.equalize();\n    }\n\n    @HostListener('window:resize')\n    private _onResize(): void {\n        this.equalize();\n    }\n\n    public equalize() {\n        if (!this._params) {\n            this._params = 'height';\n        }\n\n        const params: EqualizeParams = Object.assign({property: 'height', reset: true}, typeof this._params === 'string' ? {property: this._params} : this._params);\n        const watchers: ElementRef[] = this._watchers.filter((watcher) => {\n            console.log('ID matching', watcher.id, this.id);\n            if (watcher.id || this.id) {\n                return watcher.id === this.id;\n            }\n\n            return watcher.elementRef.nativeElement !== this._elementRef.nativeElement;\n        }).map((watcher) => watcher.elementRef);\n\n        this._equalizerService.equalize(\n            this._renderer,\n            watchers,\n            params\n        );\n    }\n}\n","import { CommonModule } from '@angular/common';\nimport { ModuleWithProviders, NgModule } from '@angular/core';\n\nimport { EqualizerDirective, EqualizerWatcherDirective } from './directives';\nimport { EqualizerService } from './services';\n\n@NgModule({\n    imports: [\n        CommonModule,\n    ],\n    exports: [\n        EqualizerDirective,\n        EqualizerWatcherDirective,\n    ],\n    declarations: [\n        EqualizerDirective,\n        EqualizerWatcherDirective,\n    ],\n    providers: [\n        EqualizerService,\n    ],\n})\nexport class EqualizerModule {\n    public static forRoot(): ModuleWithProviders {\n        return {\n            ngModule: EqualizerModule,\n            providers: [\n                EqualizerService,\n            ]\n        };\n    }\n\n    public static forChild(): ModuleWithProviders {\n        return {\n            ngModule: EqualizerModule,\n            providers: [\n                EqualizerService\n            ]\n        };\n    }\n}\n"],"names":[],"mappings":"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"}