ngx-joyride
Version:
[](https://badge.fury.io/js/ngx-joyride) [](https://travis-ci.org/tnicola/ngx-joyride) [ {
this.documentService = documentService;
this.optionsService = optionsService;
this.rendererFactory = rendererFactory;
this.lastXScroll = 0;
this.lastYScroll = 0;
this.setRenderer();
}
setRenderer() {
this.renderer = this.rendererFactory.createRenderer(null, null);
}
draw(step) {
this.elementRef = step.targetViewContainer;
this.targetAbsoluteTop = this.getTargetTotalTop(step);
this.targetAbsoluteLeft = this.getTargetTotalLeft(step);
this.currentBackdropContainer = this.renderer.createElement('div');
this.renderer.addClass(this.currentBackdropContainer, 'backdrop-container');
this.renderer.setStyle(this.currentBackdropContainer, 'position', 'fixed');
this.renderer.setStyle(this.currentBackdropContainer, 'top', '0px');
this.renderer.setStyle(this.currentBackdropContainer, 'left', '0px');
this.renderer.setStyle(this.currentBackdropContainer, 'width', '100%');
this.renderer.setStyle(this.currentBackdropContainer, 'height', '100%');
this.renderer.setStyle(this.currentBackdropContainer, 'z-index', '1000');
this.renderer.setAttribute(this.currentBackdropContainer, 'id', 'backdrop-' + step.name);
this.backdropContent = this.renderer.createElement('div');
this.renderer.addClass(this.backdropContent, 'backdrop-content');
this.renderer.setStyle(this.backdropContent, 'position', 'relative');
this.renderer.setStyle(this.backdropContent, 'height', '100%');
this.renderer.setStyle(this.backdropContent, 'display', 'flex');
this.renderer.setStyle(this.backdropContent, 'flex-direction', 'column');
this.renderer.appendChild(this.currentBackdropContainer, this.backdropContent);
this.backdropTop = this.renderer.createElement('div');
this.renderer.addClass(this.backdropTop, 'joyride-backdrop');
this.renderer.addClass(this.backdropTop, 'backdrop-top');
this.renderer.setStyle(this.backdropTop, 'width', '100%');
this.renderer.setStyle(this.backdropTop, 'height', this.targetAbsoluteTop - this.lastYScroll + 'px');
this.renderer.setStyle(this.backdropTop, 'flex-shrink', '0');
this.renderer.setStyle(this.backdropTop, 'background-color', `rgba(${this.optionsService.getBackdropColor()}, 0.7)`);
this.renderer.appendChild(this.backdropContent, this.backdropTop);
this.backdropMiddleContainer = this.renderer.createElement('div');
this.renderer.addClass(this.backdropMiddleContainer, 'backdrop-middle-container');
this.renderer.setStyle(this.backdropMiddleContainer, 'height', this.elementRef.element.nativeElement.offsetHeight + 'px');
this.renderer.setStyle(this.backdropMiddleContainer, 'width', '100%');
this.renderer.setStyle(this.backdropMiddleContainer, 'flex-shrink', '0');
this.renderer.appendChild(this.backdropContent, this.backdropMiddleContainer);
this.backdropMiddleContent = this.renderer.createElement('div');
this.renderer.addClass(this.backdropMiddleContent, 'backdrop-middle-content');
this.renderer.setStyle(this.backdropMiddleContent, 'display', 'flex');
this.renderer.setStyle(this.backdropMiddleContent, 'width', '100%');
this.renderer.setStyle(this.backdropMiddleContent, 'height', '100%');
this.renderer.appendChild(this.backdropMiddleContainer, this.backdropMiddleContent);
this.leftBackdrop = this.renderer.createElement('div');
this.renderer.addClass(this.leftBackdrop, 'joyride-backdrop');
this.renderer.addClass(this.leftBackdrop, 'backdrop-left');
this.renderer.setStyle(this.leftBackdrop, 'flex-shrink', '0');
this.renderer.setStyle(this.leftBackdrop, 'width', this.targetAbsoluteLeft - this.lastXScroll + 'px');
this.renderer.setStyle(this.leftBackdrop, 'background-color', `rgba(${this.optionsService.getBackdropColor()}, 0.7)`);
this.renderer.appendChild(this.backdropMiddleContent, this.leftBackdrop);
this.targetBackdrop = this.renderer.createElement('div');
this.renderer.addClass(this.targetBackdrop, 'backdrop-target');
this.renderer.setStyle(this.targetBackdrop, 'flex-shrink', '0');
this.renderer.setStyle(this.targetBackdrop, 'width', this.elementRef.element.nativeElement.offsetWidth + 'px');
this.renderer.appendChild(this.backdropMiddleContent, this.targetBackdrop);
this.rightBackdrop = this.renderer.createElement('div');
this.renderer.addClass(this.rightBackdrop, 'joyride-backdrop');
this.renderer.addClass(this.rightBackdrop, 'backdrop-right');
this.renderer.setStyle(this.rightBackdrop, 'width', '100%');
this.renderer.setStyle(this.rightBackdrop, 'background-color', `rgba(${this.optionsService.getBackdropColor()}, 0.7)`);
this.renderer.appendChild(this.backdropMiddleContent, this.rightBackdrop);
this.backdropBottom = this.renderer.createElement('div');
this.renderer.addClass(this.backdropBottom, 'joyride-backdrop');
this.renderer.addClass(this.backdropBottom, 'backdrop-bottom');
this.renderer.setStyle(this.backdropBottom, 'width', '100%');
this.renderer.setStyle(this.backdropBottom, 'height', '100%');
this.renderer.setStyle(this.backdropBottom, 'background-color', `rgba(${this.optionsService.getBackdropColor()}, 0.7)`);
this.renderer.appendChild(this.backdropContent, this.backdropBottom);
this.removeLastBackdrop();
this.drawCurrentBackdrop();
this.lastBackdropContainer = this.currentBackdropContainer;
}
remove() {
this.removeLastBackdrop();
}
redrawTarget(step) {
this.targetAbsoluteLeft = this.getTargetTotalLeft(step);
this.targetAbsoluteTop = this.getTargetTotalTop(step);
this.handleVerticalScroll(step);
this.handleHorizontalScroll(step);
}
getTargetTotalTop(step) {
let targetVC = step.targetViewContainer;
return step.isElementOrAncestorFixed
? this.documentService.getElementFixedTop(targetVC.element)
: this.documentService.getElementAbsoluteTop(targetVC.element);
}
getTargetTotalLeft(step) {
let targetVC = step.targetViewContainer;
return step.isElementOrAncestorFixed
? this.documentService.getElementFixedLeft(targetVC.element)
: this.documentService.getElementAbsoluteLeft(targetVC.element);
}
redraw(step, scroll) {
if (this.lastYScroll !== scroll.scrollY) {
this.lastYScroll = scroll.scrollY;
if (this.elementRef) {
this.handleVerticalScroll(step);
}
}
if (this.lastXScroll !== scroll.scrollX) {
this.lastXScroll = scroll.scrollX;
if (this.elementRef) {
this.handleHorizontalScroll(step);
}
}
}
handleHorizontalScroll(step) {
let newBackdropLeftWidth = step.isElementOrAncestorFixed ? this.targetAbsoluteLeft : this.targetAbsoluteLeft - this.lastXScroll;
if (newBackdropLeftWidth >= 0) {
this.renderer.setStyle(this.leftBackdrop, 'width', newBackdropLeftWidth + 'px');
this.renderer.setStyle(this.targetBackdrop, 'width', this.elementRef.element.nativeElement.offsetWidth + 'px');
}
else {
this.handleTargetPartialWidth(newBackdropLeftWidth);
}
}
handleTargetPartialWidth(newBackdropLeftWidth) {
this.renderer.setStyle(this.leftBackdrop, 'width', 0 + 'px');
let visibleTargetWidth = this.elementRef.element.nativeElement.offsetWidth + newBackdropLeftWidth;
if (visibleTargetWidth >= 0) {
this.renderer.setStyle(this.targetBackdrop, 'width', visibleTargetWidth + 'px');
}
else {
this.renderer.setStyle(this.targetBackdrop, 'width', 0 + 'px');
}
}
handleVerticalScroll(step) {
let newBackdropTopHeight = step.isElementOrAncestorFixed ? this.targetAbsoluteTop : this.targetAbsoluteTop - this.lastYScroll;
if (newBackdropTopHeight >= 0) {
this.renderer.setStyle(this.backdropTop, 'height', newBackdropTopHeight + 'px');
this.renderer.setStyle(this.backdropMiddleContainer, 'height', this.elementRef.element.nativeElement.offsetHeight + 'px');
}
else {
this.handleTargetPartialHeight(newBackdropTopHeight);
}
}
handleTargetPartialHeight(newBackdropTopHeight) {
this.renderer.setStyle(this.backdropTop, 'height', 0 + 'px');
let visibleTargetHeight = this.elementRef.element.nativeElement.offsetHeight + newBackdropTopHeight;
if (visibleTargetHeight >= 0) {
this.renderer.setStyle(this.backdropMiddleContainer, 'height', visibleTargetHeight + 'px');
}
else {
this.renderer.setStyle(this.backdropMiddleContainer, 'height', 0 + 'px');
}
}
removeLastBackdrop() {
if (this.lastBackdropContainer) {
this.renderer.removeChild(document.body, this.lastBackdropContainer);
this.lastBackdropContainer = undefined;
}
}
drawCurrentBackdrop() {
this.renderer.appendChild(document.body, this.currentBackdropContainer);
}
}
JoyrideBackdropService.decorators = [
{ type: Injectable }
];
JoyrideBackdropService.ctorParameters = () => [
{ type: DocumentService },
{ type: JoyrideOptionsService },
{ type: RendererFactory2 }
];
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"joyride-backdrop.service.js","sourceRoot":"","sources":["../../../../../projects/ngx-joyride/src/lib/services/joyride-backdrop.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Renderer2, RendererFactory2, ViewContainerRef } from '@angular/core';\r\nimport { DocumentService } from './document.service';\r\nimport { Scroll } from './event-listener.service';\r\nimport { JoyrideOptionsService } from './joyride-options.service';\r\nimport { JoyrideStep } from '../models/joyride-step.class';\r\n\r\n@Injectable()\r\nexport class JoyrideBackdropService {\r\n    private renderer: Renderer2;\r\n    private currentBackdropContainer: any;\r\n    private lastBackdropContainer: any;\r\n    private backdropContent: any;\r\n    private backdropTop: any;\r\n    private backdropBottom: any;\r\n    private backdropMiddleContainer: any;\r\n    private backdropMiddleContent: any;\r\n    private leftBackdrop: any;\r\n    private targetBackdrop: any;\r\n    private rightBackdrop: any;\r\n    private elementRef: ViewContainerRef;\r\n    private targetAbsoluteTop: number;\r\n    private targetAbsoluteLeft: number;\r\n    private lastXScroll: number = 0;\r\n    private lastYScroll: number = 0;\r\n\r\n    constructor(\r\n        private readonly documentService: DocumentService,\r\n        private readonly optionsService: JoyrideOptionsService,\r\n        private readonly rendererFactory: RendererFactory2\r\n    ) {\r\n        this.setRenderer();\r\n    }\r\n\r\n    private setRenderer() {\r\n        this.renderer = this.rendererFactory.createRenderer(null, null);\r\n    }\r\n\r\n    draw(step: JoyrideStep) {\r\n        this.elementRef = step.targetViewContainer;\r\n        this.targetAbsoluteTop = this.getTargetTotalTop(step);\r\n        this.targetAbsoluteLeft = this.getTargetTotalLeft(step);\r\n\r\n        this.currentBackdropContainer = this.renderer.createElement('div');\r\n        this.renderer.addClass(this.currentBackdropContainer, 'backdrop-container');\r\n        this.renderer.setStyle(this.currentBackdropContainer, 'position', 'fixed');\r\n        this.renderer.setStyle(this.currentBackdropContainer, 'top', '0px');\r\n        this.renderer.setStyle(this.currentBackdropContainer, 'left', '0px');\r\n        this.renderer.setStyle(this.currentBackdropContainer, 'width', '100%');\r\n        this.renderer.setStyle(this.currentBackdropContainer, 'height', '100%');\r\n        this.renderer.setStyle(this.currentBackdropContainer, 'z-index', '1000');\r\n        this.renderer.setAttribute(this.currentBackdropContainer, 'id', 'backdrop-' + step.name);\r\n\r\n        this.backdropContent = this.renderer.createElement('div');\r\n        this.renderer.addClass(this.backdropContent, 'backdrop-content');\r\n        this.renderer.setStyle(this.backdropContent, 'position', 'relative');\r\n        this.renderer.setStyle(this.backdropContent, 'height', '100%');\r\n        this.renderer.setStyle(this.backdropContent, 'display', 'flex');\r\n        this.renderer.setStyle(this.backdropContent, 'flex-direction', 'column');\r\n        this.renderer.appendChild(this.currentBackdropContainer, this.backdropContent);\r\n\r\n        this.backdropTop = this.renderer.createElement('div');\r\n        this.renderer.addClass(this.backdropTop, 'joyride-backdrop');\r\n        this.renderer.addClass(this.backdropTop, 'backdrop-top');\r\n        this.renderer.setStyle(this.backdropTop, 'width', '100%');\r\n        this.renderer.setStyle(this.backdropTop, 'height', this.targetAbsoluteTop - this.lastYScroll + 'px');\r\n        this.renderer.setStyle(this.backdropTop, 'flex-shrink', '0');\r\n        this.renderer.setStyle(this.backdropTop, 'background-color', `rgba(${this.optionsService.getBackdropColor()}, 0.7)`);\r\n        this.renderer.appendChild(this.backdropContent, this.backdropTop);\r\n\r\n        this.backdropMiddleContainer = this.renderer.createElement('div');\r\n        this.renderer.addClass(this.backdropMiddleContainer, 'backdrop-middle-container');\r\n        this.renderer.setStyle(this.backdropMiddleContainer, 'height', this.elementRef.element.nativeElement.offsetHeight + 'px');\r\n        this.renderer.setStyle(this.backdropMiddleContainer, 'width', '100%');\r\n        this.renderer.setStyle(this.backdropMiddleContainer, 'flex-shrink', '0');\r\n        this.renderer.appendChild(this.backdropContent, this.backdropMiddleContainer);\r\n\r\n        this.backdropMiddleContent = this.renderer.createElement('div');\r\n        this.renderer.addClass(this.backdropMiddleContent, 'backdrop-middle-content');\r\n        this.renderer.setStyle(this.backdropMiddleContent, 'display', 'flex');\r\n        this.renderer.setStyle(this.backdropMiddleContent, 'width', '100%');\r\n        this.renderer.setStyle(this.backdropMiddleContent, 'height', '100%');\r\n        this.renderer.appendChild(this.backdropMiddleContainer, this.backdropMiddleContent);\r\n\r\n        this.leftBackdrop = this.renderer.createElement('div');\r\n        this.renderer.addClass(this.leftBackdrop, 'joyride-backdrop');\r\n        this.renderer.addClass(this.leftBackdrop, 'backdrop-left');\r\n        this.renderer.setStyle(this.leftBackdrop, 'flex-shrink', '0');\r\n        this.renderer.setStyle(this.leftBackdrop, 'width', this.targetAbsoluteLeft - this.lastXScroll + 'px');\r\n        this.renderer.setStyle(this.leftBackdrop, 'background-color', `rgba(${this.optionsService.getBackdropColor()}, 0.7)`);\r\n        this.renderer.appendChild(this.backdropMiddleContent, this.leftBackdrop);\r\n\r\n        this.targetBackdrop = this.renderer.createElement('div');\r\n        this.renderer.addClass(this.targetBackdrop, 'backdrop-target');\r\n        this.renderer.setStyle(this.targetBackdrop, 'flex-shrink', '0');\r\n        this.renderer.setStyle(this.targetBackdrop, 'width', this.elementRef.element.nativeElement.offsetWidth + 'px');\r\n        this.renderer.appendChild(this.backdropMiddleContent, this.targetBackdrop);\r\n\r\n        this.rightBackdrop = this.renderer.createElement('div');\r\n        this.renderer.addClass(this.rightBackdrop, 'joyride-backdrop');\r\n        this.renderer.addClass(this.rightBackdrop, 'backdrop-right');\r\n        this.renderer.setStyle(this.rightBackdrop, 'width', '100%');\r\n        this.renderer.setStyle(this.rightBackdrop, 'background-color', `rgba(${this.optionsService.getBackdropColor()}, 0.7)`);\r\n        this.renderer.appendChild(this.backdropMiddleContent, this.rightBackdrop);\r\n\r\n        this.backdropBottom = this.renderer.createElement('div');\r\n        this.renderer.addClass(this.backdropBottom, 'joyride-backdrop');\r\n        this.renderer.addClass(this.backdropBottom, 'backdrop-bottom');\r\n        this.renderer.setStyle(this.backdropBottom, 'width', '100%');\r\n        this.renderer.setStyle(this.backdropBottom, 'height', '100%');\r\n        this.renderer.setStyle(this.backdropBottom, 'background-color', `rgba(${this.optionsService.getBackdropColor()}, 0.7)`);\r\n        this.renderer.appendChild(this.backdropContent, this.backdropBottom);\r\n\r\n        this.removeLastBackdrop();\r\n        this.drawCurrentBackdrop();\r\n        this.lastBackdropContainer = this.currentBackdropContainer;\r\n    }\r\n\r\n    remove() {\r\n        this.removeLastBackdrop();\r\n    }\r\n\r\n    redrawTarget(step: JoyrideStep) {\r\n        this.targetAbsoluteLeft = this.getTargetTotalLeft(step);\r\n        this.targetAbsoluteTop = this.getTargetTotalTop(step);\r\n        this.handleVerticalScroll(step);\r\n        this.handleHorizontalScroll(step);\r\n    }\r\n\r\n    private getTargetTotalTop(step: JoyrideStep) {\r\n        let targetVC = step.targetViewContainer;\r\n        return step.isElementOrAncestorFixed\r\n            ? this.documentService.getElementFixedTop(targetVC.element)\r\n            : this.documentService.getElementAbsoluteTop(targetVC.element);\r\n    }\r\n\r\n    private getTargetTotalLeft(step: JoyrideStep) {\r\n        let targetVC = step.targetViewContainer;\r\n\r\n        return step.isElementOrAncestorFixed\r\n            ? this.documentService.getElementFixedLeft(targetVC.element)\r\n            : this.documentService.getElementAbsoluteLeft(targetVC.element);\r\n    }\r\n    redraw(step: JoyrideStep, scroll: Scroll) {\r\n        if (this.lastYScroll !== scroll.scrollY) {\r\n            this.lastYScroll = scroll.scrollY;\r\n            if (this.elementRef) {\r\n                this.handleVerticalScroll(step);\r\n            }\r\n        }\r\n        if (this.lastXScroll !== scroll.scrollX) {\r\n            this.lastXScroll = scroll.scrollX;\r\n            if (this.elementRef) {\r\n                this.handleHorizontalScroll(step);\r\n            }\r\n        }\r\n    }\r\n\r\n    private handleHorizontalScroll(step: JoyrideStep) {\r\n        let newBackdropLeftWidth = step.isElementOrAncestorFixed ? this.targetAbsoluteLeft : this.targetAbsoluteLeft - this.lastXScroll;\r\n\r\n        if (newBackdropLeftWidth >= 0) {\r\n            this.renderer.setStyle(this.leftBackdrop, 'width', newBackdropLeftWidth + 'px');\r\n            this.renderer.setStyle(this.targetBackdrop, 'width', this.elementRef.element.nativeElement.offsetWidth + 'px');\r\n        } else {\r\n            this.handleTargetPartialWidth(newBackdropLeftWidth);\r\n        }\r\n    }\r\n\r\n    private handleTargetPartialWidth(newBackdropLeftWidth: number) {\r\n        this.renderer.setStyle(this.leftBackdrop, 'width', 0 + 'px');\r\n        let visibleTargetWidth = this.elementRef.element.nativeElement.offsetWidth + newBackdropLeftWidth;\r\n        if (visibleTargetWidth >= 0) {\r\n            this.renderer.setStyle(this.targetBackdrop, 'width', visibleTargetWidth + 'px');\r\n        } else {\r\n            this.renderer.setStyle(this.targetBackdrop, 'width', 0 + 'px');\r\n        }\r\n    }\r\n\r\n    private handleVerticalScroll(step: JoyrideStep) {\r\n        let newBackdropTopHeight = step.isElementOrAncestorFixed ? this.targetAbsoluteTop : this.targetAbsoluteTop - this.lastYScroll;\r\n\r\n        if (newBackdropTopHeight >= 0) {\r\n            this.renderer.setStyle(this.backdropTop, 'height', newBackdropTopHeight + 'px');\r\n            this.renderer.setStyle(this.backdropMiddleContainer, 'height', this.elementRef.element.nativeElement.offsetHeight + 'px');\r\n        } else {\r\n            this.handleTargetPartialHeight(newBackdropTopHeight);\r\n        }\r\n    }\r\n\r\n    private handleTargetPartialHeight(newBackdropTopHeight: number) {\r\n        this.renderer.setStyle(this.backdropTop, 'height', 0 + 'px');\r\n        let visibleTargetHeight = this.elementRef.element.nativeElement.offsetHeight + newBackdropTopHeight;\r\n        if (visibleTargetHeight >= 0) {\r\n            this.renderer.setStyle(this.backdropMiddleContainer, 'height', visibleTargetHeight + 'px');\r\n        } else {\r\n            this.renderer.setStyle(this.backdropMiddleContainer, 'height', 0 + 'px');\r\n        }\r\n    }\r\n\r\n    private removeLastBackdrop() {\r\n        if (this.lastBackdropContainer) {\r\n            this.renderer.removeChild(document.body, this.lastBackdropContainer);\r\n            this.lastBackdropContainer = undefined;\r\n        }\r\n    }\r\n\r\n    private drawCurrentBackdrop() {\r\n        this.renderer.appendChild(document.body, this.currentBackdropContainer);\r\n    }\r\n}\r\n"]}