ngx-joyride
Version:
[](https://badge.fury.io/js/ngx-joyride) [](https://travis-ci.org/tnicola/ngx-joyride) [ {
this.joyrideStepsContainer = joyrideStepsContainer;
this.viewContainerRef = viewContainerRef;
this.domService = domService;
this.router = router;
this.templateService = templateService;
this.platformId = platformId;
this.stepPosition = NO_POSITION;
this.prev = new EventEmitter();
this.next = new EventEmitter();
this.done = new EventEmitter();
this.subscriptions = [];
this.windowRef = this.domService.getNativeWindow();
this.step = new JoyrideStep();
}
ngAfterViewInit() {
if (!isPlatformBrowser(this.platformId))
return;
if (this.prevTemplate)
this.templateService.setPrevButton(this.prevTemplate);
if (this.nextTemplate)
this.templateService.setNextButton(this.nextTemplate);
if (this.doneTemplate)
this.templateService.setDoneButton(this.doneTemplate);
if (this.counterTemplate)
this.templateService.setCounter(this.counterTemplate);
this.step.position = this.stepPosition;
this.step.targetViewContainer = this.viewContainerRef;
this.setAsyncFields(this.step);
this.step.stepContent = this.stepContent;
this.step.stepContentParams = this.stepContentParams;
this.step.nextClicked = this.next;
this.step.prevCliked = this.prev;
this.step.tourDone = this.done;
if (!this.name)
throw new JoyrideError("All the steps should have the 'joyrideStep' property set with a custom name.");
this.step.name = this.name;
this.step.route = this.router.url.substr(0, 1) === '/' ? this.router.url.substr(1) : this.router.url;
this.step.transformCssStyle = this.windowRef.getComputedStyle(this.viewContainerRef.element.nativeElement).transform;
this.step.isElementOrAncestorFixed =
this.isElementFixed(this.viewContainerRef.element) ||
this.isAncestorsFixed(this.viewContainerRef.element.nativeElement.parentElement);
this.joyrideStepsContainer.addStep(this.step);
}
ngOnChanges(changes) {
if (changes['title'] || changes['text']) {
this.setAsyncFields(this.step);
}
}
isElementFixed(element) {
return this.windowRef.getComputedStyle(element.nativeElement).position === 'fixed';
}
setAsyncFields(step) {
if (this.title instanceof Observable) {
this.subscriptions.push(this.title.subscribe(title => {
step.title.next(title);
}));
}
else {
step.title.next(this.title);
}
if (this.text instanceof Observable) {
this.subscriptions.push(this.text.subscribe(text => {
step.text.next(text);
}));
}
else {
step.text.next(this.text);
}
}
isAncestorsFixed(nativeElement) {
if (!nativeElement || !nativeElement.parentElement)
return false;
let isElementFixed = this.windowRef.getComputedStyle(nativeElement.parentElement).position === 'fixed';
if (nativeElement.nodeName === 'BODY') {
return isElementFixed;
}
if (isElementFixed)
return true;
else
return this.isAncestorsFixed(nativeElement.parentElement);
}
ngOnDestroy() {
this.subscriptions.forEach(sub => {
sub.unsubscribe();
});
}
}
JoyrideDirective.decorators = [
{ type: Directive, args: [{
selector: 'joyrideStep, [joyrideStep]'
},] }
];
JoyrideDirective.ctorParameters = () => [
{ type: JoyrideStepsContainerService },
{ type: ViewContainerRef },
{ type: DomRefService },
{ type: Router },
{ type: TemplatesService },
{ type: Object, decorators: [{ type: Inject, args: [PLATFORM_ID,] }] }
];
JoyrideDirective.propDecorators = {
name: [{ type: Input, args: ['joyrideStep',] }],
nextStep: [{ type: Input }],
title: [{ type: Input }],
text: [{ type: Input }],
stepPosition: [{ type: Input }],
stepContent: [{ type: Input }],
stepContentParams: [{ type: Input }],
prevTemplate: [{ type: Input }],
nextTemplate: [{ type: Input }],
doneTemplate: [{ type: Input }],
counterTemplate: [{ type: Input }],
prev: [{ type: Output }],
next: [{ type: Output }],
done: [{ type: Output }]
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"joyride.directive.js","sourceRoot":"","sources":["../../../../../projects/ngx-joyride/src/lib/directives/joyride.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n    Directive,\r\n    ElementRef,\r\n    AfterViewInit,\r\n    Input,\r\n    ViewContainerRef,\r\n    TemplateRef,\r\n    Output,\r\n    EventEmitter,\r\n    Inject,\r\n    PLATFORM_ID,\r\n    OnChanges,\r\n    SimpleChanges,\r\n    OnDestroy\r\n} from '@angular/core';\r\nimport { JoyrideStep } from '../models/joyride-step.class';\r\nimport { JoyrideStepsContainerService } from '../services/joyride-steps-container.service';\r\nimport { JoyrideError } from '../models/joyride-error.class';\r\nimport { Router } from '@angular/router';\r\nimport { DomRefService } from '../services/dom.service';\r\nimport { isPlatformBrowser } from '@angular/common';\r\nimport { TemplatesService } from '../services/templates.service';\r\nimport { Observable, Subscription } from 'rxjs';\r\n\r\nexport const NO_POSITION = 'NO_POSITION';\r\n\r\n@Directive({\r\n    selector: 'joyrideStep, [joyrideStep]'\r\n})\r\nexport class JoyrideDirective implements AfterViewInit, OnChanges, OnDestroy {\r\n    @Input('joyrideStep')\r\n    name: string;\r\n\r\n    @Input()\r\n    nextStep?: string;\r\n\r\n    @Input()\r\n    title?: string | Observable<string>;\r\n\r\n    @Input()\r\n    text?: string | Observable<string>;\r\n\r\n    @Input()\r\n    stepPosition?: string = NO_POSITION;\r\n\r\n    @Input()\r\n    stepContent?: TemplateRef<any>;\r\n\r\n    @Input()\r\n    stepContentParams?: Object;\r\n\r\n    @Input()\r\n    prevTemplate?: TemplateRef<any>;\r\n\r\n    @Input()\r\n    nextTemplate?: TemplateRef<any>;\r\n\r\n    @Input()\r\n    doneTemplate?: TemplateRef<any>;\r\n\r\n    @Input()\r\n    counterTemplate?: TemplateRef<any>;\r\n\r\n    @Output()\r\n    prev?: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n    @Output()\r\n    next?: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n    @Output()\r\n    done?: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n    private windowRef: Window;\r\n    private step: JoyrideStep;\r\n    private subscriptions: Subscription[] = [];\r\n\r\n    constructor(\r\n        private readonly joyrideStepsContainer: JoyrideStepsContainerService,\r\n        private viewContainerRef: ViewContainerRef,\r\n        private readonly domService: DomRefService,\r\n        private readonly router: Router,\r\n        private readonly templateService: TemplatesService,\r\n        @Inject(PLATFORM_ID) private platformId: Object\r\n    ) {\r\n        this.windowRef = this.domService.getNativeWindow();\r\n        this.step = new JoyrideStep();\r\n    }\r\n\r\n    ngAfterViewInit() {\r\n        if (!isPlatformBrowser(this.platformId)) return;\r\n        if (this.prevTemplate) this.templateService.setPrevButton(this.prevTemplate);\r\n        if (this.nextTemplate) this.templateService.setNextButton(this.nextTemplate);\r\n        if (this.doneTemplate) this.templateService.setDoneButton(this.doneTemplate);\r\n        if (this.counterTemplate) this.templateService.setCounter(this.counterTemplate);\r\n        this.step.position = this.stepPosition;\r\n        this.step.targetViewContainer = this.viewContainerRef;\r\n        this.setAsyncFields(this.step);\r\n        this.step.stepContent = this.stepContent;\r\n        this.step.stepContentParams = this.stepContentParams;\r\n        this.step.nextClicked = this.next;\r\n        this.step.prevCliked = this.prev;\r\n        this.step.tourDone = this.done;\r\n        if (!this.name) throw new JoyrideError(\"All the steps should have the 'joyrideStep' property set with a custom name.\");\r\n        this.step.name = this.name;\r\n        this.step.route = this.router.url.substr(0, 1) === '/' ? this.router.url.substr(1) : this.router.url;\r\n        this.step.transformCssStyle = this.windowRef.getComputedStyle(this.viewContainerRef.element.nativeElement).transform;\r\n        this.step.isElementOrAncestorFixed =\r\n            this.isElementFixed(this.viewContainerRef.element) ||\r\n            this.isAncestorsFixed(this.viewContainerRef.element.nativeElement.parentElement);\r\n\r\n        this.joyrideStepsContainer.addStep(this.step);\r\n    }\r\n\r\n    ngOnChanges(changes: SimpleChanges) {\r\n        if (changes['title'] || changes['text']) {\r\n            this.setAsyncFields(this.step);\r\n        }\r\n    }\r\n\r\n    private isElementFixed(element: ElementRef) {\r\n        return this.windowRef.getComputedStyle(element.nativeElement).position === 'fixed';\r\n    }\r\n\r\n    private setAsyncFields(step: JoyrideStep) {\r\n        if (this.title instanceof Observable) {\r\n            this.subscriptions.push(\r\n                this.title.subscribe(title => {\r\n                    step.title.next(title);\r\n                })\r\n            );\r\n        } else {\r\n            step.title.next(this.title);\r\n        }\r\n        if (this.text instanceof Observable) {\r\n            this.subscriptions.push(\r\n                this.text.subscribe(text => {\r\n                    step.text.next(text);\r\n                })\r\n            );\r\n        } else {\r\n            step.text.next(this.text);\r\n        }\r\n    }\r\n\r\n    private isAncestorsFixed(nativeElement: any): boolean {\r\n        if (!nativeElement || !nativeElement.parentElement) return false;\r\n        let isElementFixed = this.windowRef.getComputedStyle(nativeElement.parentElement).position === 'fixed';\r\n        if (nativeElement.nodeName === 'BODY') {\r\n            return isElementFixed;\r\n        }\r\n        if (isElementFixed) return true;\r\n        else return this.isAncestorsFixed(nativeElement.parentElement);\r\n    }\r\n\r\n    ngOnDestroy(): void {\r\n        this.subscriptions.forEach(sub => {\r\n            sub.unsubscribe();\r\n        });\r\n    }\r\n}\r\n"]}