UNPKG

@raphy/ngx-equalizer

Version:

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

304 lines (291 loc) 21.6 kB
(function (global, factory) { typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports, require('@angular/core'), require('@angular/common')) : typeof define === 'function' && define.amd ? define('@raphy/ngx-equalizer', ['exports', '@angular/core', '@angular/common'], factory) : (factory((global.raphy = global.raphy || {}, global.raphy['ngx-equalizer'] = {}),global.ng.core,global.ng.common)); }(this, (function (exports,core,common) { 'use strict'; /** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ var EqualizerService = (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: core.Injectable }, ]; return EqualizerService; }()); /** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ /** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ var EqualizerWatcherDirective = (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: core.Directive, args: [{ selector: '[equalizerWatcher]' },] }, ]; /** @nocollapse */ EqualizerWatcherDirective.ctorParameters = function () { return [ { type: core.ElementRef } ]; }; EqualizerWatcherDirective.propDecorators = { _id: [{ type: core.Input, args: ['equalizerWatcher',] }] }; return EqualizerWatcherDirective; }()); /** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ var EqualizerDirective = (function () { function EqualizerDirective(_elementRef, _renderer, _equalizerService) { this._elementRef = _elementRef; this._renderer = _renderer; this._equalizerService = _equalizerService; this._params = 'height'; this._watchers = new core.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: core.Directive, args: [{ selector: '[equalizer]', exportAs: 'equalizer' },] }, ]; /** @nocollapse */ EqualizerDirective.ctorParameters = function () { return [ { type: core.ElementRef }, { type: core.Renderer2 }, { type: EqualizerService } ]; }; EqualizerDirective.propDecorators = { _params: [{ type: core.Input, args: ['equalizer',] }], _id: [{ type: core.Input, args: ['equalizerId',] }], _watchers: [{ type: core.ContentChildren, args: [EqualizerWatcherDirective, { read: EqualizerWatcherDirective },] }], _onResize: [{ type: core.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 = (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: core.NgModule, args: [{ imports: [ common.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 */ exports.EqualizerDirective = EqualizerDirective; exports.EqualizerWatcherDirective = EqualizerWatcherDirective; exports.EqualizerService = EqualizerService; exports.EqualizerModule = EqualizerModule; exports.ɵa = EqualizerDirective; exports.ɵb = EqualizerWatcherDirective; exports.ɵc = EqualizerService; Object.defineProperty(exports, '__esModule', { value: true }); }))); //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"raphy-ngx-equalizer.umd.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":["Injectable","Directive","ElementRef","Input","QueryList","Renderer2","ContentChildren","HostListener","NgModule","CommonModule"],"mappings":"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"}