@raphy/ngx-equalizer
Version:
A library to equalize height and width of elements with Angular4+
250 lines (239 loc) • 17.3 kB
JavaScript
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
*/
class EqualizerService {
/**
* @param {?} renderer
* @param {?} elementRefs
* @param {?=} params
* @return {?}
*/
equalize(renderer, elementRefs, params = { property: 'height', reset: true }) {
let /** @type {?} */ maxValue = 0;
elementRefs.map((elementRef) => {
if (params.reset) {
renderer.setStyle(elementRef.nativeElement, params.property, 'initial');
}
const /** @type {?} */ value = elementRef.nativeElement['offset' + params.property[0].toUpperCase() + params.property.slice(1)];
maxValue = value > maxValue ? value : maxValue;
});
elementRefs.map((elementRef) => {
renderer.setStyle(elementRef.nativeElement, params.property, maxValue + 'px');
});
}
}
EqualizerService.decorators = [
{ type: Injectable },
];
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
class EqualizerWatcherDirective {
/**
* @param {?} _elementRef
*/
constructor(_elementRef) {
this._elementRef = _elementRef;
}
/**
* @return {?}
*/
get elementRef() {
return this._elementRef;
}
/**
* @return {?}
*/
get id() {
return this._id;
}
/**
* @param {?} value
* @return {?}
*/
set id(value) {
this._id = value;
}
}
EqualizerWatcherDirective.decorators = [
{ type: Directive, args: [{
selector: '[equalizerWatcher]'
},] },
];
/** @nocollapse */
EqualizerWatcherDirective.ctorParameters = () => [
{ type: ElementRef }
];
EqualizerWatcherDirective.propDecorators = {
_id: [{ type: Input, args: ['equalizerWatcher',] }]
};
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
class EqualizerDirective {
/**
* @param {?} _elementRef
* @param {?} _renderer
* @param {?} _equalizerService
*/
constructor(_elementRef, _renderer, _equalizerService) {
this._elementRef = _elementRef;
this._renderer = _renderer;
this._equalizerService = _equalizerService;
this._params = 'height';
this._watchers = new QueryList();
}
/**
* @return {?}
*/
get params() {
return this._params;
}
/**
* @param {?} value
* @return {?}
*/
set params(value) {
this._params = value;
this.equalize();
}
/**
* @return {?}
*/
get elementRef() {
return this._elementRef;
}
/**
* @return {?}
*/
get id() {
return this._id;
}
/**
* @param {?} value
* @return {?}
*/
set id(value) {
this._id = value;
}
/**
* @return {?}
*/
ngAfterViewChecked() {
this.equalize();
}
/**
* @return {?}
*/
_onResize() {
this.equalize();
}
/**
* @return {?}
*/
equalize() {
if (!this._params) {
this._params = 'height';
}
const /** @type {?} */ params = Object.assign({ property: 'height', reset: true }, typeof this._params === 'string' ? { property: this._params } : this._params);
const /** @type {?} */ watchers = this._watchers.filter((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((watcher) => watcher.elementRef);
this._equalizerService.equalize(this._renderer, watchers, params);
}
}
EqualizerDirective.decorators = [
{ type: Directive, args: [{
selector: '[equalizer]',
exportAs: 'equalizer'
},] },
];
/** @nocollapse */
EqualizerDirective.ctorParameters = () => [
{ 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',] }]
};
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
class EqualizerModule {
/**
* @return {?}
*/
static forRoot() {
return {
ngModule: EqualizerModule,
providers: [
EqualizerService,
]
};
}
/**
* @return {?}
*/
static forChild() {
return {
ngModule: EqualizerModule,
providers: [
EqualizerService
]
};
}
}
EqualizerModule.decorators = [
{ type: NgModule, args: [{
imports: [
CommonModule,
],
exports: [
EqualizerDirective,
EqualizerWatcherDirective,
],
declarations: [
EqualizerDirective,
EqualizerWatcherDirective,
],
providers: [
EqualizerService,
],
},] },
];
/**
* @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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"}