ngx-joyride
Version:
[](https://badge.fury.io/js/ngx-joyride) [](https://travis-ci.org/tnicola/ngx-joyride) [ {
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"]}