@covalent/guided-tour 4.0.0 → 4.1.0-develop.5

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (33) hide show
  1. package/README.md +32 -15
  2. package/_guided-tour-theme.scss +6 -6
  3. package/covalent-guided-tour.d.ts +2 -1
  4. package/esm2020/covalent-guided-tour.mjs +5 -0
  5. package/esm2020/lib/guided-tour.module.mjs +19 -0
  6. package/esm2020/lib/guided-tour.service.mjs +163 -0
  7. package/esm2020/lib/guided.tour.mjs +438 -0
  8. package/esm2020/public_api.mjs +4 -0
  9. package/fesm2015/{covalent-guided-tour.js → covalent-guided-tour.mjs} +180 -615
  10. package/fesm2015/covalent-guided-tour.mjs.map +1 -0
  11. package/fesm2020/covalent-guided-tour.mjs +619 -0
  12. package/fesm2020/covalent-guided-tour.mjs.map +1 -0
  13. package/lib/guided-tour.module.d.ts +7 -0
  14. package/{guided-tour.service.d.ts → lib/guided-tour.service.d.ts} +4 -1
  15. package/{guided.tour.d.ts → lib/guided.tour.d.ts} +3 -7
  16. package/package.json +25 -21
  17. package/public_api.d.ts +3 -0
  18. package/{_guided-tour.scss → styles/guided-tour.scss} +17 -2
  19. package/bundles/covalent-guided-tour.umd.js +0 -1369
  20. package/bundles/covalent-guided-tour.umd.js.map +0 -1
  21. package/bundles/covalent-guided-tour.umd.min.js +0 -16
  22. package/bundles/covalent-guided-tour.umd.min.js.map +0 -1
  23. package/covalent-guided-tour.metadata.json +0 -1
  24. package/esm2015/covalent-guided-tour.js +0 -10
  25. package/esm2015/guided-tour.module.js +0 -19
  26. package/esm2015/guided-tour.service.js +0 -312
  27. package/esm2015/guided.tour.js +0 -722
  28. package/esm2015/index.js +0 -7
  29. package/esm2015/public-api.js +0 -9
  30. package/fesm2015/covalent-guided-tour.js.map +0 -1
  31. package/guided-tour.module.d.ts +0 -2
  32. package/index.d.ts +0 -1
  33. package/public-api.d.ts +0 -3
package/README.md CHANGED
@@ -6,15 +6,15 @@ A wrapper around [Shepherd](https://shepherdjs.dev) with extra functionality. Ma
6
6
 
7
7
  #### Methods
8
8
 
9
- + registerTour(tourName: string, tour: IGuidedTour | string): Promise<void>
10
- + Create a tour
11
- + startTour(tourName: string): Shepherd.Tour
12
- + Start a certain tour
13
- + initializeOnQueryParams(queryParam: string = 'tour'): Observable<ParamMap>
14
- + Listen to query params to launch a tour
15
- + tourEvent$(str: TourEvents): Observable<IGuidedTourEvent>
16
- + Observable of tour events
17
-
9
+ - registerTour(tourName: string, tour: IGuidedTour | string): Promise<void>
10
+ - Create a tour
11
+ - startTour(tourName: string): Shepherd.Tour
12
+ - Start a certain tour
13
+ - initializeOnQueryParams(queryParam: string = 'tour'): Observable<ParamMap>
14
+ - Listen to query params to launch a tour
15
+ - tourEvent$(str: TourEvents): Observable<IGuidedTourEvent>
16
+ - Observable of tour events
17
+
18
18
  ```ts
19
19
  // for reference
20
20
  export type TourStep = Shepherd.Step.StepOptions;
@@ -105,6 +105,7 @@ import { CovalentGuidedTourModule } from '@covalent/guided-tour';
105
105
  ```
106
106
 
107
107
  ## Usage
108
+
108
109
  ```ts
109
110
  import { CovalentGuidedTourService } from '@covalent/guided-tour';
110
111
 
@@ -139,16 +140,32 @@ const basicDemoTour: IGuidedTour = {
139
140
  };
140
141
  this._guidedTourService.registerTour('basicDemoTour', basicDemoTour);
141
142
  this._guidedTourService.startTour('basicDemoTour');
142
- this._guidedTourService.tourEvent$(TourEvents.show)
143
- .subscribe((event: IGuidedTourEvent) => { /* event object contains current step, previous step and tour objects */});
143
+ this._guidedTourService
144
+ .tourEvent$(TourEvents.show)
145
+ .subscribe((event: IGuidedTourEvent) => {
146
+ /* event object contains current step, previous step and tour objects */
147
+ });
144
148
  ```
145
149
 
146
150
  ```html
147
151
  <div id="basic-demo">
148
- <button mat-raised-button color="accent" (click)="startTour()">Start tour</button>
149
- <meter id="fuel" min="0" max="100" low="33" high="66" optimum="50" value="50"></meter>
150
- <progress id="oxygen" max="100" value="70"> 70% </progress>
152
+ <button mat-raised-button color="accent" (click)="startTour()">
153
+ Start tour
154
+ </button>
155
+ <meter
156
+ id="fuel"
157
+ min="0"
158
+ max="100"
159
+ low="33"
160
+ high="66"
161
+ optimum="50"
162
+ value="50"
163
+ ></meter>
164
+ <progress id="oxygen" max="100" value="70">70%</progress>
151
165
  <marquee id="status">All systems are running smoothly</marquee>
152
166
  </div>
153
-
154
167
  ```
168
+
169
+ ## Running unit tests
170
+
171
+ Run `nx test angular-guided-tour` to execute the unit tests.
@@ -1,6 +1,3 @@
1
- @import './guided-tour.scss';
2
- @import '~@angular/material/button/button-base';
3
-
4
1
  @mixin covalent-guided-tour-theme($theme, $config: null) {
5
2
  @include td-guided-tour-typography($config);
6
3
  @include td-guided-tour-theme($theme);
@@ -14,9 +11,11 @@
14
11
  .shepherd-title {
15
12
  @include mat-typography-level-to-styles($config, subheading-2);
16
13
  }
14
+
17
15
  .shepherd-text {
18
16
  @include mat-typography-level-to-styles($config, body-1);
19
17
  }
18
+
20
19
  .shepherd-progress {
21
20
  @include mat-typography-level-to-styles($config, body-1);
22
21
  }
@@ -41,6 +40,7 @@
41
40
  .shepherd-cancel-icon span::after {
42
41
  color: mat-color($accent, darker-contrast);
43
42
  }
43
+
44
44
  .shepherd-button:not(:disabled),
45
45
  .shepherd-button.shepherd-button-secondary:not(:disabled),
46
46
  .shepherd-cancel-icon {
@@ -54,15 +54,14 @@
54
54
  .shepherd-arrow::before,
55
55
  .shepherd-arrow::after,
56
56
  .shepherd-content,
57
- .shepherd-element.shepherd-has-title[data-popper-placement^='bottom'] > .shepherd-arrow::before {
57
+ .shepherd-element.shepherd-has-title[data-popper-placement^='bottom']
58
+ > .shepherd-arrow::before {
58
59
  background: mat-color($accent, darker);
59
60
  }
60
61
 
61
62
  // Bringing in mat-icon button styles
62
63
  // Class can't be passed so we must include mat button styles here
63
64
  .shepherd-cancel-icon {
64
- @include mat-button-base;
65
-
66
65
  min-width: 0;
67
66
  margin: 0;
68
67
  padding: 0;
@@ -72,6 +71,7 @@
72
71
  line-height: $mat-icon-button-size;
73
72
  border-radius: $mat-icon-button-border-radius;
74
73
  }
74
+
75
75
  .shepherd-void-button {
76
76
  display: none;
77
77
  }
@@ -1,4 +1,5 @@
1
1
  /**
2
2
  * Generated bundle index. Do not edit.
3
3
  */
4
- export * from './index';
4
+ /// <amd-module name="@covalent/guided-tour" />
5
+ export * from './public_api';
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './public_api';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY292YWxlbnQtZ3VpZGVkLXRvdXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL2FuZ3VsYXItZ3VpZGVkLXRvdXIvc3JjL2NvdmFsZW50LWd1aWRlZC10b3VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOztHQUVHO0FBRUgsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEdlbmVyYXRlZCBidW5kbGUgaW5kZXguIERvIG5vdCBlZGl0LlxuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vcHVibGljX2FwaSc7XG4iXX0=
@@ -0,0 +1,19 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { CovalentGuidedTourService } from './guided-tour.service';
4
+ import * as i0 from "@angular/core";
5
+ export class CovalentGuidedTourModule {
6
+ }
7
+ CovalentGuidedTourModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: CovalentGuidedTourModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
8
+ CovalentGuidedTourModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: CovalentGuidedTourModule, imports: [CommonModule] });
9
+ CovalentGuidedTourModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: CovalentGuidedTourModule, providers: [CovalentGuidedTourService], imports: [[CommonModule]] });
10
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: CovalentGuidedTourModule, decorators: [{
11
+ type: NgModule,
12
+ args: [{
13
+ imports: [CommonModule],
14
+ providers: [CovalentGuidedTourService],
15
+ declarations: [],
16
+ exports: [],
17
+ }]
18
+ }] });
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3VpZGVkLXRvdXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9hbmd1bGFyLWd1aWRlZC10b3VyL3NyYy9saWIvZ3VpZGVkLXRvdXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDOztBQVFsRSxNQUFNLE9BQU8sd0JBQXdCOztxSEFBeEIsd0JBQXdCO3NIQUF4Qix3QkFBd0IsWUFMekIsWUFBWTtzSEFLWCx3QkFBd0IsYUFKeEIsQ0FBQyx5QkFBeUIsQ0FBQyxZQUQ3QixDQUFDLFlBQVksQ0FBQzsyRkFLWix3QkFBd0I7a0JBTnBDLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixTQUFTLEVBQUUsQ0FBQyx5QkFBeUIsQ0FBQztvQkFDdEMsWUFBWSxFQUFFLEVBQUU7b0JBQ2hCLE9BQU8sRUFBRSxFQUFFO2lCQUNaIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb3ZhbGVudEd1aWRlZFRvdXJTZXJ2aWNlIH0gZnJvbSAnLi9ndWlkZWQtdG91ci5zZXJ2aWNlJztcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIHByb3ZpZGVyczogW0NvdmFsZW50R3VpZGVkVG91clNlcnZpY2VdLFxuICBkZWNsYXJhdGlvbnM6IFtdLFxuICBleHBvcnRzOiBbXSxcbn0pXG5leHBvcnQgY2xhc3MgQ292YWxlbnRHdWlkZWRUb3VyTW9kdWxlIHt9XG4iXX0=
@@ -0,0 +1,163 @@
1
+ import { Injectable } from '@angular/core';
2
+ import { HttpClient } from '@angular/common/http';
3
+ import { Router, ActivatedRoute, NavigationStart, } from '@angular/router';
4
+ import { tap, map, filter } from 'rxjs/operators';
5
+ import { fromEvent } from 'rxjs';
6
+ import { debounceTime } from 'rxjs/operators';
7
+ import { CovalentGuidedTour, } from './guided.tour';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "@angular/router";
10
+ import * as i2 from "@angular/common/http";
11
+ /**
12
+ * Router enabled Shepherd tour
13
+ */
14
+ export var TourEvents;
15
+ (function (TourEvents) {
16
+ TourEvents["complete"] = "complete";
17
+ TourEvents["cancel"] = "cancel";
18
+ TourEvents["hide"] = "hide";
19
+ TourEvents["show"] = "show";
20
+ TourEvents["start"] = "start";
21
+ TourEvents["active"] = "active";
22
+ TourEvents["inactive"] = "inactive";
23
+ })(TourEvents || (TourEvents = {}));
24
+ export class CovalentGuidedTourService extends CovalentGuidedTour {
25
+ constructor(_router, _route, _httpClient) {
26
+ super();
27
+ this._router = _router;
28
+ this._route = _route;
29
+ this._httpClient = _httpClient;
30
+ this._toursMap = new Map();
31
+ this._tourStepURLs = new Map();
32
+ _router.events
33
+ .pipe(filter((event) => event instanceof NavigationStart &&
34
+ event.navigationTrigger === 'popstate'))
35
+ .subscribe(() => {
36
+ if (this.shepherdTour.isActive()) {
37
+ this.shepherdTour.cancel();
38
+ }
39
+ });
40
+ }
41
+ tourEvent$(str) {
42
+ return fromEvent(this.shepherdTour, str);
43
+ }
44
+ async registerTour(tourName, tour) {
45
+ const guidedTour = typeof tour === 'string' ? await this._loadTour(tour) : tour;
46
+ this._toursMap.set(tourName, guidedTour);
47
+ }
48
+ startTour(tourName) {
49
+ const guidedTour = this._getTour(tourName);
50
+ this.finish();
51
+ if (guidedTour && guidedTour.steps && guidedTour.steps.length) {
52
+ // remove steps from tour since we need to preprocess them first
53
+ this.newTour(Object.assign({}, guidedTour, { steps: undefined }));
54
+ const tourInstance = this.shepherdTour.addSteps(this._configureRoutesForSteps(this._prepareTour(guidedTour.steps, guidedTour.finishButtonText)));
55
+ // init route transition if step URL is different then the current location.
56
+ this.tourEvent$(TourEvents.show).subscribe((tourEvent) => {
57
+ const currentURL = this._router.url.split(/[?#]/)[0];
58
+ const { step: { id, options }, } = tourEvent;
59
+ if (this._tourStepURLs.has(id)) {
60
+ const stepRoute = this._tourStepURLs.get(id);
61
+ if (stepRoute !== currentURL) {
62
+ this._router.navigate([stepRoute]);
63
+ }
64
+ }
65
+ else {
66
+ if (options && options.routing) {
67
+ this._tourStepURLs.set(id, options.routing.route);
68
+ }
69
+ else {
70
+ this._tourStepURLs.set(id, currentURL);
71
+ }
72
+ }
73
+ });
74
+ this.start();
75
+ return tourInstance;
76
+ }
77
+ else {
78
+ // tslint:disable-next-line:no-console
79
+ console.warn(`Tour ${tourName} does not exist. Please try another tour.`);
80
+ return undefined;
81
+ }
82
+ }
83
+ // Finds the right registered tour by using queryParams
84
+ // finishes any other tour and starts the new one.
85
+ initializeOnQueryParams(queryParam = 'tour') {
86
+ return this._route.queryParamMap.pipe(debounceTime(100), tap((params) => {
87
+ const tourParam = params.get(queryParam);
88
+ if (tourParam) {
89
+ this.startTour(tourParam);
90
+ // get current search parameters
91
+ const searchParams = new URLSearchParams(window.location.search);
92
+ // delete tour queryParam
93
+ searchParams.delete(queryParam);
94
+ // build new URL string without it
95
+ let url = window.location.protocol +
96
+ '//' +
97
+ window.location.host +
98
+ window.location.pathname;
99
+ if (searchParams.toString()) {
100
+ url += '?' + searchParams.toString();
101
+ }
102
+ // replace state in history without triggering a navigation
103
+ window.history.replaceState({ path: url }, '', url);
104
+ }
105
+ }));
106
+ }
107
+ setNextBtnDisability(stepId, isDisabled) {
108
+ if (this.shepherdTour.getById(stepId)) {
109
+ const stepOptions = this.shepherdTour.getById(stepId)
110
+ .options;
111
+ stepOptions.buttons?.forEach((button) => {
112
+ if (button.text === 'chevron_right') {
113
+ button.disabled = isDisabled;
114
+ }
115
+ });
116
+ this.shepherdTour.getById(stepId)?.updateStepOptions(stepOptions);
117
+ }
118
+ }
119
+ async _loadTour(tourUrl) {
120
+ const request = this._httpClient.get(tourUrl);
121
+ try {
122
+ return await request
123
+ .pipe(map((resultSet) => {
124
+ return JSON.parse(JSON.stringify(resultSet));
125
+ }))
126
+ .toPromise();
127
+ }
128
+ catch {
129
+ return undefined;
130
+ }
131
+ }
132
+ _getTour(key) {
133
+ return this._toursMap.get(key);
134
+ }
135
+ _configureRoutesForSteps(routedSteps) {
136
+ routedSteps.forEach((step) => {
137
+ if (step.routing) {
138
+ const route = step.routing.route;
139
+ // if there is a beforeShowPromise, then we save it and call it after the navigation
140
+ if (step.beforeShowPromise) {
141
+ const beforeShowPromise = step.beforeShowPromise;
142
+ step.beforeShowPromise = () => {
143
+ return this._router
144
+ .navigate([route], step.routing?.extras)
145
+ .then(() => {
146
+ return beforeShowPromise();
147
+ });
148
+ };
149
+ }
150
+ else {
151
+ step.beforeShowPromise = () => this._router.navigate([route]);
152
+ }
153
+ }
154
+ });
155
+ return routedSteps;
156
+ }
157
+ }
158
+ CovalentGuidedTourService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: CovalentGuidedTourService, deps: [{ token: i1.Router }, { token: i1.ActivatedRoute }, { token: i2.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
159
+ CovalentGuidedTourService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: CovalentGuidedTourService });
160
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.2", ngImport: i0, type: CovalentGuidedTourService, decorators: [{
161
+ type: Injectable
162
+ }], ctorParameters: function () { return [{ type: i1.Router }, { type: i1.ActivatedRoute }, { type: i2.HttpClient }]; } });
163
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"guided-tour.service.js","sourceRoot":"","sources":["../../../../../libs/angular-guided-tour/src/lib/guided-tour.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\nimport { HttpClient } from '@angular/common/http';\nimport {\n  Router,\n  ActivatedRoute,\n  ParamMap,\n  NavigationExtras,\n  NavigationStart,\n  Event as NavigationEvent,\n} from '@angular/router';\nimport Shepherd from 'shepherd.js';\nimport { tap, map, filter } from 'rxjs/operators';\nimport { Observable, fromEvent } from 'rxjs';\nimport { debounceTime } from 'rxjs/operators';\nimport {\n  CovalentGuidedTour,\n  ITourStep,\n  ITourOptions,\n  TourStepButton,\n} from './guided.tour';\n\nexport interface IGuidedTour extends ITourOptions {\n  steps: IGuidedTourStep[];\n  finishButtonText?: string;\n}\n\nexport interface IGuidedTourStep extends ITourStep {\n  routing?: {\n    route: string;\n    extras?: NavigationExtras;\n  };\n}\n\n/**\n *  Router enabled Shepherd tour\n */\nexport enum TourEvents {\n  complete = 'complete',\n  cancel = 'cancel',\n  hide = 'hide',\n  show = 'show',\n  start = 'start',\n  active = 'active',\n  inactive = 'inactive',\n}\n\nexport interface IGuidedTourEvent {\n  step: any;\n  previous: any;\n  tour: any;\n}\n\n@Injectable()\nexport class CovalentGuidedTourService extends CovalentGuidedTour {\n  private _toursMap: Map<string, IGuidedTour> = new Map<string, IGuidedTour>();\n  private _tourStepURLs: Map<string, string> = new Map<string, string>();\n  constructor(\n    private _router: Router,\n    private _route: ActivatedRoute,\n    private _httpClient: HttpClient\n  ) {\n    super();\n    _router.events\n      .pipe(\n        filter(\n          (event: NavigationEvent) =>\n            event instanceof NavigationStart &&\n            event.navigationTrigger === 'popstate'\n        )\n      )\n      .subscribe(() => {\n        if (this.shepherdTour.isActive()) {\n          this.shepherdTour.cancel();\n        }\n      });\n  }\n\n  tourEvent$(str: TourEvents): Observable<IGuidedTourEvent> {\n    return fromEvent(this.shepherdTour, str);\n  }\n\n  async registerTour(\n    tourName: string,\n    tour: IGuidedTour | string\n  ): Promise<void> {\n    const guidedTour: IGuidedTour =\n      typeof tour === 'string' ? await this._loadTour(tour) : tour;\n    this._toursMap.set(tourName, guidedTour);\n  }\n\n  startTour(tourName: string): Shepherd.Tour | undefined {\n    const guidedTour = this._getTour(tourName);\n    this.finish();\n    if (guidedTour && guidedTour.steps && guidedTour.steps.length) {\n      // remove steps from tour since we need to preprocess them first\n      this.newTour(Object.assign({}, guidedTour, { steps: undefined }));\n      const tourInstance: Shepherd.Tour = this.shepherdTour.addSteps(\n        this._configureRoutesForSteps(\n          this._prepareTour(guidedTour.steps, guidedTour.finishButtonText)\n        )\n      );\n      // init route transition if step URL is different then the current location.\n      this.tourEvent$(TourEvents.show).subscribe(\n        (tourEvent: IGuidedTourEvent) => {\n          const currentURL: string = this._router.url.split(/[?#]/)[0];\n          const {\n            step: { id, options },\n          } = tourEvent;\n          if (this._tourStepURLs.has(id)) {\n            const stepRoute = this._tourStepURLs.get(id);\n            if (stepRoute !== currentURL) {\n              this._router.navigate([stepRoute]);\n            }\n          } else {\n            if (options && options.routing) {\n              this._tourStepURLs.set(id, options.routing.route);\n            } else {\n              this._tourStepURLs.set(id, currentURL);\n            }\n          }\n        }\n      );\n      this.start();\n      return tourInstance;\n    } else {\n      // tslint:disable-next-line:no-console\n      console.warn(`Tour ${tourName} does not exist. Please try another tour.`);\n      return undefined;\n    }\n  }\n\n  // Finds the right registered tour by using queryParams\n  // finishes any other tour and starts the new one.\n  initializeOnQueryParams(queryParam: string = 'tour'): Observable<ParamMap> {\n    return this._route.queryParamMap.pipe(\n      debounceTime(100),\n      tap((params: ParamMap) => {\n        const tourParam = params.get(queryParam);\n        if (tourParam) {\n          this.startTour(tourParam);\n          // get current search parameters\n          const searchParams: URLSearchParams = new URLSearchParams(\n            window.location.search\n          );\n          // delete tour queryParam\n          searchParams.delete(queryParam);\n          // build new URL string without it\n          let url: string =\n            window.location.protocol +\n            '//' +\n            window.location.host +\n            window.location.pathname;\n          if (searchParams.toString()) {\n            url += '?' + searchParams.toString();\n          }\n          // replace state in history without triggering a navigation\n          window.history.replaceState({ path: url }, '', url);\n        }\n      })\n    );\n  }\n\n  setNextBtnDisability(stepId: string, isDisabled: boolean): void {\n    if (this.shepherdTour.getById(stepId)) {\n      const stepOptions: ITourStep = (this.shepherdTour.getById(stepId) as any)\n        .options;\n      stepOptions.buttons?.forEach((button: TourStepButton) => {\n        if (button.text === 'chevron_right') {\n          button.disabled = isDisabled;\n        }\n      });\n      this.shepherdTour.getById(stepId)?.updateStepOptions(stepOptions);\n    }\n  }\n\n  private async _loadTour(tourUrl: string): Promise<any> {\n    const request: Observable<object> = this._httpClient.get(tourUrl);\n    try {\n      return await request\n        .pipe(\n          map((resultSet: any) => {\n            return JSON.parse(JSON.stringify(resultSet));\n          })\n        )\n        .toPromise();\n    } catch {\n      return undefined;\n    }\n  }\n\n  private _getTour(key: string): IGuidedTour | undefined {\n    return this._toursMap.get(key);\n  }\n\n  private _configureRoutesForSteps(\n    routedSteps: IGuidedTourStep[]\n  ): IGuidedTourStep[] {\n    routedSteps.forEach((step: IGuidedTourStep) => {\n      if (step.routing) {\n        const route: string = step.routing.route;\n        // if there is a beforeShowPromise, then we save it and call it after the navigation\n        if (step.beforeShowPromise) {\n          const beforeShowPromise: () => Promise<void> = step.beforeShowPromise;\n          step.beforeShowPromise = () => {\n            return this._router\n              .navigate([route], step.routing?.extras)\n              .then(() => {\n                return beforeShowPromise();\n              });\n          };\n        } else {\n          step.beforeShowPromise = () => this._router.navigate([route]);\n        }\n      }\n    });\n\n    return routedSteps;\n  }\n}\n"]}