@raphy/ngx-equalizer
Version:
A library to equalize height and width of elements with Angular4+
293 lines (282 loc) • 19.4 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
*/
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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"}