UNPKG

@offensichtbar-codestock/ngx-flex-masonry-grid

Version:

Angular Module for displaying items in a flex-based masonry layout without any third party dependencies

143 lines 18.4 kB
import { Component, ElementRef, HostBinding, Inject, HostListener } from '@angular/core'; import { AnimationBuilder, useAnimation } from '@angular/animations'; import { NgxFlexMasonryGridService } from "./ngx-flex-masonry-grid.service"; import { CIRCULAR_IMPORT_PARENT } from './circular-imports'; import NgxFMG_ANIMATION from './animations'; export class NgxFlexMasonryGridItemComponent { constructor(element, builder, service, parent) { this.element = element; this.builder = builder; this.service = service; this.parent = parent; this.heightprops = 'max-content'; this._translateY = 0; this._isready = false; this._remove = false; } get getLeaveDrawer() { return this._remove; } animationIsDone() { if (this._remove) this.service.removeItem(this); } get height() { return this.element.nativeElement.offsetHeight; } get isready() { return this._isready; } set isready(ready) { this._isready = ready; } get width() { const marginLeft = window .getComputedStyle(this.element.nativeElement, null) .getPropertyValue('margin-left') .match(/\d+/); const marginRight = window .getComputedStyle(this.element.nativeElement, null) .getPropertyValue('margin-right') .match(/\d+/); return this.element.nativeElement.offsetWidth + (parseInt(marginLeft[0]) + parseInt(marginRight[0])); } set translateY(value) { if (this._isready) { this.upDatePosition(value); } else { this.element.nativeElement.style.transform = `translateY(-${value}px)`; } this._translateY = value; } get translateY() { return this._translateY; } ngOnInit() { } upDatePosition(to) { const params = { animatePosY: `-${to}px` }; const metadata = useAnimation(NgxFMG_ANIMATION.UPDATE_POSITION, { params: params }); const player = this.builder.build(metadata).create(this.element.nativeElement); player.play(); } playAnimation() { const metadata = NgxFMG_ANIMATION.FADE_IN; this.element.nativeElement.style.visibility = 'visible'; const player = this.builder.build(metadata).create(this.element.nativeElement); player.play(); } ngAfterViewInit() { this.translateY = 0; this.startLoading(); } startLoading() { const images = this.element.nativeElement.querySelectorAll('img'); this.images = new Set(images); let loaded = []; if (images.length == 0) { setTimeout(() => { this.service.observeimage([...loaded, { item: this, height: this.element.nativeElement.offsetHeight }]); }); return; } Array.from(this.images).forEach((image) => { this.loadImage(image.src).then(props => { var _a; loaded = this.checkActionLoaded(loaded, images, props); (_a = this.images) === null || _a === void 0 ? void 0 : _a.delete(image); }).catch((error) => { var _a; loaded = this.checkActionLoaded(loaded, images); (_a = this.images) === null || _a === void 0 ? void 0 : _a.delete(image); }); }); } checkActionLoaded(loaded, images, props) { loaded = [...loaded, (props) ? props : { item: this, height: this.element.nativeElement.offsetHeight }]; if (loaded.length === images.length) { this.service.observeimage(loaded); } return loaded; } loadImage(src) { return new Promise((resolve, reject) => { let img = new Image(); img.onload = () => resolve({ item: this, height: this.element.nativeElement.offsetHeight }); img.onerror = reject; img.src = src; }); } ngOnDestroy() { this._remove = true; } } NgxFlexMasonryGridItemComponent.decorators = [ { type: Component, args: [{ selector: 'osb-ngx-flexmasonry-grid-item', template: '<ng-content></ng-content> ', animations: [ NgxFMG_ANIMATION.TRIGGER_FADE_OUT ] },] } ]; NgxFlexMasonryGridItemComponent.ctorParameters = () => [ { type: ElementRef }, { type: AnimationBuilder }, { type: NgxFlexMasonryGridService }, { type: undefined, decorators: [{ type: Inject, args: [CIRCULAR_IMPORT_PARENT,] }] } ]; NgxFlexMasonryGridItemComponent.propDecorators = { heightprops: [{ type: HostBinding, args: ['style.height',] }], getLeaveDrawer: [{ type: HostBinding, args: ['@TRIGGER_FADE_OUT',] }], animationIsDone: [{ type: HostListener, args: ['@TRIGGER_FADE_OUT.done',] }] }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-flex-masonry-grid-item.component.js","sourceRoot":"","sources":["../../../../projects/ngx-flex-masonry-grid/src/lib/ngx-flex-masonry-grid-item.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {Component, OnInit, OnDestroy, AfterViewInit, ElementRef, HostBinding, Inject, HostListener} from '@angular/core';\nimport { NgxFlexMasonryGridLoadingParams } from './ngx-flex-masonry-grid-options';\nimport { AnimationBuilder,useAnimation } from '@angular/animations';\nimport { NgxFlexMasonryGridService } from \"./ngx-flex-masonry-grid.service\";\nimport { CircularImportsParent, CIRCULAR_IMPORT_PARENT } from './circular-imports';\nimport NgxFMG_ANIMATION from './animations';\n\n@Component({ \n    selector: 'osb-ngx-flexmasonry-grid-item',\n    template: '<ng-content></ng-content> ', \n    animations: [\n        NgxFMG_ANIMATION.TRIGGER_FADE_OUT\n    ]\n    \n}) \n\nexport class NgxFlexMasonryGridItemComponent implements OnInit, OnDestroy, AfterViewInit  {\n\n    \n    @HostBinding('style.height') heightprops =  'max-content'; \n\n    @HostBinding('@TRIGGER_FADE_OUT') get getLeaveDrawer(): boolean {\n        return this._remove;\n    }\n\n    @HostListener('@TRIGGER_FADE_OUT.done') animationIsDone() {\n        if(this._remove)\n            this.service.removeItem(this);\n    }\n \n   \n    public images?: Set<HTMLImageElement>;\n    private _translateY: number =0;\n    private _isready: boolean = false;\n    private _remove: boolean = false;\n    public get height(): number {\n        return this.element.nativeElement.offsetHeight;\n    }\n\n    public get isready():boolean {\n        return this._isready;\n    }\n\n\n    public set isready(ready:boolean) {\n        this._isready = ready;\n    }\n\n    public get width():number {\n        const  marginLeft:any = window\n            .getComputedStyle(this.element.nativeElement,null)\n            .getPropertyValue('margin-left')\n            .match(/\\d+/);\n    \n        const marginRight:any = window\n            .getComputedStyle(this.element.nativeElement,null)\n            .getPropertyValue('margin-right')\n            .match(/\\d+/);\n\n        return this.element.nativeElement.offsetWidth + (parseInt(marginLeft[0]) + parseInt(marginRight[0]));\n    }\n\n    public set translateY(value:number) {\n        if(this._isready) {\n            this.upDatePosition(value);\n        } else {\n            this.element.nativeElement.style.transform = `translateY(-${value}px)`;\n           \n        }\n        this._translateY = value;\n    }\n\n    public get translateY():number {\n        return this._translateY;\n    }\n\n    constructor(\n        private element: ElementRef, \n        private builder: AnimationBuilder,   \n        public service: NgxFlexMasonryGridService,\n        @Inject(CIRCULAR_IMPORT_PARENT) private parent: CircularImportsParent\n    ) { }\n\n    ngOnInit() {}\n\n    upDatePosition(to:number) {\n      \n        const params = {animatePosY: `-${to}px`};\n        const metadata = useAnimation(NgxFMG_ANIMATION.UPDATE_POSITION, {params: params});\n\n        const player = this.builder.build(metadata).create(this.element.nativeElement);\n \n\n        player.play();           \n            \n    }\n\n    playAnimation() {\n        \n        const metadata = NgxFMG_ANIMATION.FADE_IN;\n        this.element.nativeElement.style.visibility = 'visible';\n\n        const player = this.builder.build(metadata).create(this.element.nativeElement);\n        player.play();       \n    }\n\n    ngAfterViewInit() {\n        this.translateY = 0;\n        this.startLoading();\n    }\n\n    startLoading() {\n        const images = this.element.nativeElement.querySelectorAll('img');     \n        this.images = new Set(images);    \n        let loaded:Array<NgxFlexMasonryGridLoadingParams> = [];\n\n        if( images.length == 0) {\n           setTimeout(() =>{\n                this.service.observeimage([...loaded, {\n                    item: this,\n                    height: this.element.nativeElement.offsetHeight\n                }]);\n            });\n            \n            return;\n        }\n\n        Array.from(this.images).forEach((image: HTMLImageElement) => {\n            \n            this.loadImage(image.src).then(props => {\n                loaded = this.checkActionLoaded(loaded, images, props)\n                this.images?.delete(image);\n            }).catch((error) => {                    \n                loaded = this.checkActionLoaded(loaded, images)\n                this.images?.delete(image);\n            })\n        });\n    }\n\n    checkActionLoaded(loaded: Array<NgxFlexMasonryGridLoadingParams>, images: Array<HTMLImageElement>, props?:NgxFlexMasonryGridLoadingParams) {\n        loaded = [...loaded, (props) ? props : {\n            item: this,\n            height: this.element.nativeElement.offsetHeight\n        }];\n\n        if(loaded.length === images.length) {                       \n            this.service.observeimage(loaded);\n        } \n\n        return loaded;\n    }\n\n    loadImage(src: string): Promise<NgxFlexMasonryGridLoadingParams> {\n\n        return  new Promise((resolve, reject) => {\n            let img = new Image()\n            img.onload = () => resolve({\n                item: this,\n                height: this.element.nativeElement.offsetHeight\n            })\n            img.onerror = reject\n            img.src = src\n        })\n       \n    }\n\n    ngOnDestroy() {\n        this._remove = true;\n       \n    }\n}\n"]}