UNPKG

ngx-joyride

Version:

[![npm version](https://badge.fury.io/js/ngx-joyride.svg)](https://badge.fury.io/js/ngx-joyride) [![Build Status](https://travis-ci.org/tnicola/ngx-joyride.svg?branch=master)](https://travis-ci.org/tnicola/ngx-joyride) [![codecov](https://codecov.io/gh/

187 lines 29.6 kB
import { Injectable, Inject, PLATFORM_ID } from '@angular/core'; import { DomRefService } from './dom.service'; import { isPlatformBrowser } from "@angular/common"; export class DocumentService { constructor(DOMService, platformId) { this.DOMService = DOMService; if (!isPlatformBrowser(platformId)) { return; } this.setDocumentHeight(); var doc = DOMService.getNativeDocument(); if (doc && !doc.elementsFromPoint) { // IE 11 - Edge browsers doc.elementsFromPoint = this.elementsFromPoint.bind(this); } } getElementFixedTop(elementRef) { return elementRef.nativeElement.getBoundingClientRect().top; } getElementFixedLeft(elementRef) { return elementRef.nativeElement.getBoundingClientRect().left; } getElementAbsoluteTop(elementRef) { const scrollOffsets = this.getScrollOffsets(); return (elementRef.nativeElement.getBoundingClientRect().top + scrollOffsets.y); } getElementAbsoluteLeft(elementRef) { const scrollOffsets = this.getScrollOffsets(); return (elementRef.nativeElement.getBoundingClientRect().left + scrollOffsets.x); } setDocumentHeight() { this.documentHeight = this.calculateDocumentHeight(); } getDocumentHeight() { return this.documentHeight; } isParentScrollable(elementRef) { return (this.getFirstScrollableParent(elementRef.nativeElement) !== this.DOMService.getNativeDocument().body); } isElementBeyondOthers(elementRef, isElementFixed, keywordToDiscard) { const x1 = isElementFixed ? this.getElementFixedLeft(elementRef) : this.getElementAbsoluteLeft(elementRef); const y1 = isElementFixed ? this.getElementFixedTop(elementRef) : this.getElementAbsoluteTop(elementRef); const x2 = x1 + elementRef.nativeElement.getBoundingClientRect().width - 1; const y2 = y1 + elementRef.nativeElement.getBoundingClientRect().height - 1; const elements1 = this.DOMService.getNativeDocument().elementsFromPoint(x1, y1); const elements2 = this.DOMService.getNativeDocument().elementsFromPoint(x2, y2); if (elements1.length === 0 && elements2.length === 0) return 1; if (this.getFirstElementWithoutKeyword(elements1, keywordToDiscard) !== elementRef.nativeElement || this.getFirstElementWithoutKeyword(elements2, keywordToDiscard) !== elementRef.nativeElement) { return 2; } return 3; } scrollIntoView(elementRef, isElementFixed) { const firstScrollableParent = this.getFirstScrollableParent(elementRef.nativeElement); const top = isElementFixed ? this.getElementFixedTop(elementRef) : this.getElementAbsoluteTop(elementRef); if (firstScrollableParent !== this.DOMService.getNativeDocument().body) { if (firstScrollableParent.scrollTo) { firstScrollableParent.scrollTo(0, top - 150); } else { // IE 11 - Edge browsers firstScrollableParent.scrollTop = top - 150; } } else { this.DOMService.getNativeWindow().scrollTo(0, top - 150); } } scrollToTheTop(elementRef) { const firstScrollableParent = this.getFirstScrollableParent(elementRef.nativeElement); if (firstScrollableParent !== this.DOMService.getNativeDocument().body) { if (firstScrollableParent.scrollTo) { firstScrollableParent.scrollTo(0, 0); } else { // IE 11 - Edge browsers firstScrollableParent.scrollTop = 0; } } else { this.DOMService.getNativeWindow().scrollTo(0, 0); } } scrollToTheBottom(elementRef) { const firstScrollableParent = this.getFirstScrollableParent(elementRef.nativeElement); if (firstScrollableParent !== this.DOMService.getNativeDocument().body) { if (firstScrollableParent.scrollTo) { firstScrollableParent.scrollTo(0, this.DOMService.getNativeDocument().body.scrollHeight); } else { // IE 11 - Edge browsers firstScrollableParent.scrollTop = firstScrollableParent.scrollHeight - firstScrollableParent.clientHeight; } } else { this.DOMService.getNativeWindow().scrollTo(0, this.DOMService.getNativeDocument().body.scrollHeight); } } getFirstScrollableParent(node) { const regex = /(auto|scroll|overlay)/; const style = (node, prop) => this.DOMService.getNativeWindow() .getComputedStyle(node, null) .getPropertyValue(prop); const scroll = (node) => regex.test(style(node, 'overflow') + style(node, 'overflow-y') + style(node, 'overflow-x')); const scrollparent = (node) => { return !node || node === this.DOMService.getNativeDocument().body ? this.DOMService.getNativeDocument().body : scroll(node) ? node : scrollparent(node.parentNode); }; return scrollparent(node); } calculateDocumentHeight() { const documentRef = this.DOMService.getNativeDocument(); return Math.max(documentRef.body.scrollHeight, documentRef.documentElement.scrollHeight, documentRef.body.offsetHeight, documentRef.documentElement.offsetHeight, documentRef.body.clientHeight, documentRef.documentElement.clientHeight); } getScrollOffsets() { const winReference = this.DOMService.getNativeWindow(); const docReference = this.DOMService.getNativeDocument(); // This works for all browsers except IE versions 8 and before if (winReference.pageXOffset != null) return { x: winReference.pageXOffset, y: winReference.pageYOffset }; // For IE (or any browser) in Standards mode if (docReference.compatMode == 'CSS1Compat') return { x: docReference.documentElement.scrollLeft, y: docReference.documentElement.scrollTop }; // For browsers in Quirks mode return { x: docReference.body.scrollLeft, y: docReference.body.scrollTop }; } elementsFromPoint(x, y) { var parents = []; var parent = void 0; do { const elem = this.DOMService.getNativeDocument().elementFromPoint(x, y); if (elem && parent !== elem) { parent = elem; parents.push(parent); parent.style.pointerEvents = 'none'; } else { parent = false; } } while (parent); parents.forEach(function (parent) { return (parent.style.pointerEvents = 'all'); }); return parents; } getFirstElementWithoutKeyword(elements, keyword) { while (elements[0] && elements[0].classList.toString().includes(keyword)) { elements.shift(); } return elements[0]; } } DocumentService.decorators = [ { type: Injectable } ]; DocumentService.ctorParameters = () => [ { type: DomRefService }, { type: Object, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] } ]; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"document.service.js","sourceRoot":"","sources":["../../../../../projects/ngx-joyride/src/lib/services/document.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, ElementRef, Inject, PLATFORM_ID } from '@angular/core';\r\nimport { DomRefService } from './dom.service';\r\nimport { isPlatformBrowser } from \"@angular/common\";\r\n\r\nexport interface IDocumentService {\r\n    getElementFixedTop(elementRef: ElementRef): number;\r\n\r\n    getElementFixedLeft(elementRef: ElementRef);\r\n\r\n    getElementAbsoluteTop(elementRef: ElementRef);\r\n\r\n    getElementAbsoluteLeft(elementRef: ElementRef);\r\n\r\n    setDocumentHeight();\r\n\r\n    getDocumentHeight(): number;\r\n    isParentScrollable(elementRef: ElementRef): boolean;\r\n    isElementBeyondOthers(\r\n        elementRef: ElementRef,\r\n        isElementFixed: boolean,\r\n        keywordToDiscard: string\r\n    ): number;\r\n    scrollToTheTop(elementRef: ElementRef): void;\r\n    scrollToTheBottom(elementRef: ElementRef): void;\r\n}\r\n\r\n@Injectable()\r\nexport class DocumentService implements IDocumentService {\r\n    private documentHeight: number;\r\n\r\n    constructor(private readonly DOMService: DomRefService, @Inject(PLATFORM_ID) platformId: Object) {\r\n        if (!isPlatformBrowser(platformId)) {\r\n            return;\r\n        }\r\n        this.setDocumentHeight();\r\n        var doc = DOMService.getNativeDocument();\r\n        if (doc && !doc.elementsFromPoint) {\r\n            // IE 11 - Edge browsers\r\n            doc.elementsFromPoint = this.elementsFromPoint.bind(this);\r\n        }\r\n    }\r\n\r\n    getElementFixedTop(elementRef: ElementRef) {\r\n        return elementRef.nativeElement.getBoundingClientRect().top;\r\n    }\r\n\r\n    getElementFixedLeft(elementRef: ElementRef) {\r\n        return elementRef.nativeElement.getBoundingClientRect().left;\r\n    }\r\n\r\n    getElementAbsoluteTop(elementRef: ElementRef) {\r\n        const scrollOffsets = this.getScrollOffsets();\r\n        return (\r\n            elementRef.nativeElement.getBoundingClientRect().top +\r\n            scrollOffsets.y\r\n        );\r\n    }\r\n\r\n    getElementAbsoluteLeft(elementRef: ElementRef) {\r\n        const scrollOffsets = this.getScrollOffsets();\r\n        return (\r\n            elementRef.nativeElement.getBoundingClientRect().left +\r\n            scrollOffsets.x\r\n        );\r\n    }\r\n\r\n    setDocumentHeight() {\r\n        this.documentHeight = this.calculateDocumentHeight();\r\n    }\r\n\r\n    getDocumentHeight() {\r\n        return this.documentHeight;\r\n    }\r\n\r\n    isParentScrollable(elementRef: ElementRef): boolean {\r\n        return (\r\n            this.getFirstScrollableParent(elementRef.nativeElement) !==\r\n            this.DOMService.getNativeDocument().body\r\n        );\r\n    }\r\n\r\n    isElementBeyondOthers(\r\n        elementRef: ElementRef,\r\n        isElementFixed: boolean,\r\n        keywordToDiscard: string\r\n    ) {\r\n        const x1 = isElementFixed\r\n            ? this.getElementFixedLeft(elementRef)\r\n            : this.getElementAbsoluteLeft(elementRef);\r\n        const y1 = isElementFixed\r\n            ? this.getElementFixedTop(elementRef)\r\n            : this.getElementAbsoluteTop(elementRef);\r\n        const x2 =\r\n            x1 + elementRef.nativeElement.getBoundingClientRect().width - 1;\r\n        const y2 =\r\n            y1 + elementRef.nativeElement.getBoundingClientRect().height - 1;\r\n\r\n        const elements1 = this.DOMService.getNativeDocument().elementsFromPoint(\r\n            x1,\r\n            y1\r\n        );\r\n        const elements2 = this.DOMService.getNativeDocument().elementsFromPoint(\r\n            x2,\r\n            y2\r\n        );\r\n\r\n        if (elements1.length === 0 && elements2.length === 0) return 1;\r\n        if (\r\n            this.getFirstElementWithoutKeyword(elements1, keywordToDiscard) !==\r\n                elementRef.nativeElement ||\r\n            this.getFirstElementWithoutKeyword(elements2, keywordToDiscard) !==\r\n                elementRef.nativeElement\r\n        ) {\r\n            return 2;\r\n        }\r\n        return 3;\r\n    }\r\n\r\n    scrollIntoView(elementRef: ElementRef, isElementFixed: boolean): void {\r\n        const firstScrollableParent = this.getFirstScrollableParent(\r\n            elementRef.nativeElement\r\n        );\r\n        const top = isElementFixed\r\n            ? this.getElementFixedTop(elementRef)\r\n            : this.getElementAbsoluteTop(elementRef);\r\n        if (\r\n            firstScrollableParent !== this.DOMService.getNativeDocument().body\r\n        ) {\r\n            if (firstScrollableParent.scrollTo) {\r\n                firstScrollableParent.scrollTo(0, top - 150);\r\n            } else {\r\n                // IE 11 - Edge browsers\r\n                firstScrollableParent.scrollTop = top - 150;\r\n            }\r\n        } else {\r\n            this.DOMService.getNativeWindow().scrollTo(0, top - 150);\r\n        }\r\n    }\r\n\r\n    scrollToTheTop(elementRef: ElementRef): void {\r\n        const firstScrollableParent = this.getFirstScrollableParent(\r\n            elementRef.nativeElement\r\n        );\r\n        if (\r\n            firstScrollableParent !== this.DOMService.getNativeDocument().body\r\n        ) {\r\n            if (firstScrollableParent.scrollTo) {\r\n                firstScrollableParent.scrollTo(0, 0);\r\n            } else {\r\n                // IE 11 - Edge browsers\r\n                firstScrollableParent.scrollTop = 0;\r\n            }\r\n        } else {\r\n            this.DOMService.getNativeWindow().scrollTo(0, 0);\r\n        }\r\n    }\r\n\r\n    scrollToTheBottom(elementRef: ElementRef): void {\r\n        const firstScrollableParent = this.getFirstScrollableParent(\r\n            elementRef.nativeElement\r\n        );\r\n        if (\r\n            firstScrollableParent !== this.DOMService.getNativeDocument().body\r\n        ) {\r\n            if (firstScrollableParent.scrollTo) {\r\n                firstScrollableParent.scrollTo(\r\n                    0,\r\n                    this.DOMService.getNativeDocument().body.scrollHeight\r\n                );\r\n            } else {\r\n                // IE 11 - Edge browsers\r\n                firstScrollableParent.scrollTop =\r\n                    firstScrollableParent.scrollHeight -\r\n                    firstScrollableParent.clientHeight;\r\n            }\r\n        } else {\r\n            this.DOMService.getNativeWindow().scrollTo(\r\n                0,\r\n                this.DOMService.getNativeDocument().body.scrollHeight\r\n            );\r\n        }\r\n    }\r\n\r\n    private getFirstScrollableParent(node: any) {\r\n        const regex = /(auto|scroll|overlay)/;\r\n\r\n        const style = (node: any, prop: any) =>\r\n            this.DOMService.getNativeWindow()\r\n                .getComputedStyle(node, null)\r\n                .getPropertyValue(prop);\r\n\r\n        const scroll = (node: any) =>\r\n            regex.test(\r\n                style(node, 'overflow') +\r\n                    style(node, 'overflow-y') +\r\n                    style(node, 'overflow-x')\r\n            );\r\n\r\n        const scrollparent = (node: any): any => {\r\n            return !node || node === this.DOMService.getNativeDocument().body\r\n                ? this.DOMService.getNativeDocument().body\r\n                : scroll(node)\r\n                ? node\r\n                : scrollparent(node.parentNode);\r\n        };\r\n\r\n        return scrollparent(node);\r\n    }\r\n\r\n    private calculateDocumentHeight() {\r\n        const documentRef = this.DOMService.getNativeDocument();\r\n        return Math.max(\r\n            documentRef.body.scrollHeight,\r\n            documentRef.documentElement.scrollHeight,\r\n            documentRef.body.offsetHeight,\r\n            documentRef.documentElement.offsetHeight,\r\n            documentRef.body.clientHeight,\r\n            documentRef.documentElement.clientHeight\r\n        );\r\n    }\r\n\r\n    private getScrollOffsets() {\r\n        const winReference = this.DOMService.getNativeWindow();\r\n        const docReference = this.DOMService.getNativeDocument();\r\n\r\n        // This works for all browsers except IE versions 8 and before\r\n        if (winReference.pageXOffset != null)\r\n            return { x: winReference.pageXOffset, y: winReference.pageYOffset };\r\n\r\n        // For IE (or any browser) in Standards mode\r\n        if (docReference.compatMode == 'CSS1Compat')\r\n            return {\r\n                x: docReference.documentElement.scrollLeft,\r\n                y: docReference.documentElement.scrollTop\r\n            };\r\n\r\n        // For browsers in Quirks mode\r\n        return {\r\n            x: docReference.body.scrollLeft,\r\n            y: docReference.body.scrollTop\r\n        };\r\n    }\r\n\r\n    private elementsFromPoint(x, y) {\r\n        var parents = [];\r\n        var parent = void 0;\r\n        do {\r\n            const elem = this.DOMService.getNativeDocument().elementFromPoint(\r\n                x,\r\n                y\r\n            );\r\n            if (elem && parent !== elem) {\r\n                parent = elem;\r\n                parents.push(parent);\r\n                parent.style.pointerEvents = 'none';\r\n            } else {\r\n                parent = false;\r\n            }\r\n        } while (parent);\r\n        parents.forEach(function(parent) {\r\n            return (parent.style.pointerEvents = 'all');\r\n        });\r\n        return parents;\r\n    }\r\n\r\n    private getFirstElementWithoutKeyword(\r\n        elements: Element[],\r\n        keyword: string\r\n    ): Element {\r\n        while (\r\n            elements[0] &&\r\n            elements[0].classList.toString().includes(keyword)\r\n        ) {\r\n            elements.shift();\r\n        }\r\n        return elements[0];\r\n    }\r\n}\r\n"]}