@raphy/ngx-equalizer
Version:
A library to equalize height and width of elements with Angular4+
304 lines (291 loc) • 21.6 kB
JavaScript
(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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"}