UNPKG

slider-carousel

Version:

Angular component of the carousel, using the slider as a transition. This is a simple, clean and light alternative. It also does not need dependencies.

106 lines 13.5 kB
import { Injectable, ComponentFactoryResolver, ApplicationRef, Injector, EmbeddedViewRef, ComponentRef } from '@angular/core'; import { Observable } from 'rxjs'; import { SliderCarouselPreviewComponent } from './slider-carousel-preview/slider-carousel-preview.component'; export class Helper { constructor(componentFactoryResolver, appRef, injector) { this.componentFactoryResolver = componentFactoryResolver; this.appRef = appRef; this.injector = injector; } openPreview(data = {}) { let onCloseSubscribe; let object; object = { onClose: new Observable((subscribe) => onCloseSubscribe = subscribe), instance: null }; let componenRef = this.createComponent(SliderCarouselPreviewComponent, data, (data) => { onCloseSubscribe.next(data); }); object.instance = componenRef.instance; return object; } createComponent(component, data, onClose) { const componentRef = this.componentFactoryResolver .resolveComponentFactory(component) .create(this.injector); if (!data) data = {}; data.close = (data) => { this.appRef.detachView(componentRef.hostView); componentRef.destroy(); if (onClose) onClose(data); }; Object.assign(componentRef.instance, { modalRef: data }); this.appRef.attachView(componentRef.hostView); const domElem = componentRef.hostView.rootNodes[0]; document.body.appendChild(domElem); return componentRef; } smoothScroll(element, scroll, duration = 400, direction = 'top') { let start = direction === 'top' ? element.scrollTop : element.scrollLeft; if (scroll < 0) scroll = 0; let distance = (scroll - start) - 77; let startTime = new Date().getTime(); if (!duration) duration = 400; let easeInOutQuart = (time, from, distance, duration) => { if ((time /= duration / 2) < 1) return distance / 2 * time * time * time * time + from; return -distance / 2 * ((time -= 2) * time * time * time - 2) + from; }; let timer = setInterval(() => { const time = new Date().getTime() - startTime, newScroll = easeInOutQuart(time, start, distance, duration); if (time >= duration) { clearInterval(timer); timer = null; } if (element.scrollTo) { if (direction === 'top') element.scrollTo(element.scrollLeft, newScroll); else element.scrollTo(newScroll, element.scrollTop); } else { if (direction === 'top') element.scrollTop = newScroll; else element.scrollLeft = newScroll; } }, 1000 / 60); return timer; } elementIsChild(element, parentElment) { try { while (element && element.tagName.toUpperCase() !== 'BODY') { if (element === parentElment) { return true; } element = element.parentNode; } return false; } catch (_a) { return false; } } isMobileDevice() { return (typeof window.orientation !== "undefined") || (navigator.userAgent.indexOf('IEMobile') !== -1); } } Helper.ctorParameters = () => [ { type: ComponentFactoryResolver }, { type: ApplicationRef }, { type: Injector } ]; Helper.decorators = [ { type: Injectable } ]; Helper.ctorParameters = () => [ { type: ComponentFactoryResolver }, { type: ApplicationRef }, { type: Injector } ]; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"helper.js","sourceRoot":"ng://slider-carousel/","sources":["helper.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, ComponentFactoryResolver, ApplicationRef, Injector, EmbeddedViewRef, ComponentRef } from '@angular/core';\nimport { Observable, Subscriber } from 'rxjs';\nimport { SliderCarouselPreviewComponent } from './slider-carousel-preview/slider-carousel-preview.component';\n\n@Injectable()\nexport class Helper {\n\n    constructor(\n        private componentFactoryResolver: ComponentFactoryResolver,\n        private appRef: ApplicationRef,\n        private injector: Injector\n    ) {\n\n    }\n\t\n\tpublic openPreview(data: { [key: string]: any } = {}) {\n        let onCloseSubscribe: Subscriber<any>;\n\t\tlet object: {\n            onClose: Observable<any>,\n            instance: SliderCarouselPreviewComponent\n        };\n\n        object = {\n            onClose: new Observable((subscribe) => onCloseSubscribe = subscribe),\n            instance: null\n        };\n\n        let componenRef = this.createComponent(SliderCarouselPreviewComponent, data, (data) => {\n            onCloseSubscribe.next(data);\n        });\n        object.instance = (componenRef as ComponentRef<SliderCarouselPreviewComponent>).instance;\n\n        return object;\n    }\n    \n    public createComponent(component: any, data, onClose: (data) => void) {\n        const componentRef = this.componentFactoryResolver\n            .resolveComponentFactory(component)\n            .create(this.injector);\n\n        if (!data) data = {};\n\n        data.close = (data) => {\n            this.appRef.detachView(componentRef.hostView);\n            componentRef.destroy();\n            if (onClose) onClose(data);\n        };\n        \n        Object.assign(componentRef.instance, { modalRef: data });\n\n        this.appRef.attachView(componentRef.hostView);\n        \n        const domElem = (componentRef.hostView as EmbeddedViewRef<any>).rootNodes[0] as HTMLElement;\n        \n        document.body.appendChild(domElem);\n\n        return componentRef;\n    }\n\n    public smoothScroll(element: HTMLElement, scroll: number, duration: number = 400, direction: string = 'top') {\n\t\tlet start = direction === 'top' ? element.scrollTop : element.scrollLeft;\n\n\t\tif (scroll < 0) scroll = 0;\n\n\t\tlet distance = (scroll - start) - 77;\n\n\t\tlet startTime = new Date().getTime();\n\n\t\tif (!duration) duration = 400;\n\n\t\tlet easeInOutQuart = (time, from, distance, duration) => {\n\t\t\tif ((time /= duration / 2) < 1)\n\t\t\t\treturn distance / 2 * time * time * time * time + from;\n\t\t\treturn -distance / 2 * ((time -= 2) * time * time * time - 2) + from;\n\t\t};\n\n\t\tlet timer = setInterval(() => {\n\t\t\tconst time = new Date().getTime() - startTime,\n\t\t\tnewScroll = easeInOutQuart(time, start, distance, duration);\n\n\t\t\tif (time >= duration) {\n\t\t\t\tclearInterval(timer);\n\t\t\t\ttimer = null;\n\t\t\t}\n\n\t\t\tif (element.scrollTo) {\n\t\t\t\tif (direction === 'top')\n\t\t\t\t\telement.scrollTo(element.scrollLeft, newScroll);\n\t\t\t\telse\n\t\t\t\t\telement.scrollTo(newScroll, element.scrollTop);\n\t\t\t}\n\t\t\telse {\n\t\t\t\tif (direction === 'top')\n\t\t\t\t\telement.scrollTop = newScroll;\n\t\t\t\telse\n\t\t\t\t\telement.scrollLeft = newScroll;\n\t\t\t}\n\t\t}, 1000 / 60);\n\n\t\treturn timer;\n    }\n    \n\tpublic elementIsChild(element, parentElment): boolean{\n\t\ttry {\n\t\t\twhile (element && element.tagName.toUpperCase() !== 'BODY') {\n\t\t\t\tif (element === parentElment) {\n\t\t\t\t\treturn true;\n\t\t\t\t}\n\t\t\t\telement = element.parentNode;\n\t\t\t}\n\t\t\treturn false;\n\t\t}\n\t\tcatch {\n\t\t\treturn false;\n\t\t}\n\t}\n\n    public isMobileDevice() {\n        return (typeof window.orientation !== \"undefined\") || (navigator.userAgent.indexOf('IEMobile') !== -1);\n    }\n}"]}