@covalent/guided-tour 3.1.2 → 4.0.0-beta.2

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.
@@ -1,5 +1,4 @@
1
1
  @import './guided-tour.scss';
2
- @import '~@angular/material/button/button-base';
3
2
 
4
3
  @mixin covalent-guided-tour-theme($theme, $config: null) {
5
4
  @include td-guided-tour-typography($config);
@@ -14,9 +13,11 @@
14
13
  .shepherd-title {
15
14
  @include mat-typography-level-to-styles($config, subheading-2);
16
15
  }
16
+
17
17
  .shepherd-text {
18
18
  @include mat-typography-level-to-styles($config, body-1);
19
19
  }
20
+
20
21
  .shepherd-progress {
21
22
  @include mat-typography-level-to-styles($config, body-1);
22
23
  }
@@ -41,6 +42,7 @@
41
42
  .shepherd-cancel-icon span::after {
42
43
  color: mat-color($accent, darker-contrast);
43
44
  }
45
+
44
46
  .shepherd-button:not(:disabled),
45
47
  .shepherd-button.shepherd-button-secondary:not(:disabled),
46
48
  .shepherd-cancel-icon {
@@ -61,8 +63,6 @@
61
63
  // Bringing in mat-icon button styles
62
64
  // Class can't be passed so we must include mat button styles here
63
65
  .shepherd-cancel-icon {
64
- @include mat-button-base;
65
-
66
66
  min-width: 0;
67
67
  margin: 0;
68
68
  padding: 0;
@@ -72,6 +72,7 @@
72
72
  line-height: $mat-icon-button-size;
73
73
  border-radius: $mat-icon-button-border-radius;
74
74
  }
75
+
75
76
  .shepherd-void-button {
76
77
  display: none;
77
78
  }
package/_guided-tour.scss CHANGED
@@ -5,12 +5,14 @@ $mat-icon-font: 'Material Icons', sans-serif;
5
5
  @include mat-elevation-transition;
6
6
  @include mat-elevation(4);
7
7
  }
8
+
8
9
  .shepherd-element:hover {
9
10
  .shepherd-content,
10
11
  .shepherd-arrow::before {
11
12
  @include mat-elevation(8);
12
13
  }
13
14
  }
15
+
14
16
  .shepherd-arrow::after {
15
17
  content: '';
16
18
  position: absolute;
@@ -39,6 +41,7 @@ $mat-icon-font: 'Material Icons', sans-serif;
39
41
  .shepherd-element[data-popper-placement^='top'] > .shepherd-arrow::after {
40
42
  bottom: 8px;
41
43
  }
44
+
42
45
  .shepherd-element[data-popper-placement^='bottom'] > .shepherd-arrow::after {
43
46
  top: 8px;
44
47
  }
@@ -49,9 +52,11 @@ $mat-icon-font: 'Material Icons', sans-serif;
49
52
  height: 48px;
50
53
  bottom: -16px;
51
54
  }
55
+
52
56
  .shepherd-element[data-popper-placement^='left'] > .shepherd-arrow::after {
53
57
  right: 8px;
54
58
  }
59
+
55
60
  .shepherd-element[data-popper-placement^='right'] > .shepherd-arrow::after {
56
61
  left: 8px;
57
62
  }
@@ -62,6 +67,7 @@ $mat-icon-font: 'Material Icons', sans-serif;
62
67
  cursor: pointer;
63
68
  margin-right: 0.5rem;
64
69
  padding: 0.5rem 1.5rem;
70
+
65
71
  &.material-icons {
66
72
  font-family: $mat-icon-font;
67
73
  font-size: 24px;
@@ -114,11 +120,14 @@ $mat-icon-font: 'Material Icons', sans-serif;
114
120
  background: none;
115
121
  font-size: 1.6em;
116
122
  font-family: $mat-icon-font;
123
+ position: relative;
124
+ border-width: 0;
117
125
  // Work around for having material icon as close button
118
126
  // Shepherd uses a span with 'x' string as content and aria-label hidden,
119
127
  // hence, doing this won't affect accessibility.
120
128
  span {
121
129
  color: transparent;
130
+
122
131
  &::after {
123
132
  content: 'close';
124
133
  font-size: 20px;
@@ -157,7 +166,7 @@ $mat-icon-font: 'Material Icons', sans-serif;
157
166
 
158
167
  .shepherd-element {
159
168
  border-radius: 5px;
160
- box-shadow: 0 1px 4px rgba(0, 0, 0, 0.2);
169
+ box-shadow: 0 1px 4px rgba(0, 0, 0, 20%);
161
170
  max-width: 400px;
162
171
  min-width: 400px;
163
172
  min-height: 100px;
@@ -198,21 +207,26 @@ $mat-icon-font: 'Material Icons', sans-serif;
198
207
  .shepherd-element[data-popper-placement^='top'] > .shepherd-arrow {
199
208
  bottom: -8px;
200
209
  }
210
+
201
211
  .shepherd-element[data-popper-placement^='bottom'] > .shepherd-arrow {
202
212
  top: -8px;
203
213
  }
214
+
204
215
  .shepherd-element[data-popper-placement^='left'] > .shepherd-arrow {
205
216
  right: -8px;
206
217
  }
218
+
207
219
  .shepherd-element[data-popper-placement^='right'] > .shepherd-arrow {
208
220
  left: -8px;
209
221
  }
222
+
210
223
  .shepherd-target-click-disabled.shepherd-enabled.shepherd-target,
211
224
  .shepherd-target-click-disabled.shepherd-enabled.shepherd-target * {
212
225
  pointer-events: none;
213
226
  }
227
+
214
228
  .shepherd-modal-overlay-container {
215
- -ms-filter: progid:dximagetransform.microsoft.gradient.alpha(Opacity=50);
229
+ filter: progid:dximagetransform.microsoft.gradient.alpha(Opacity=50);
216
230
  filter: alpha(opacity=50);
217
231
  height: 0;
218
232
  left: 0;
@@ -231,6 +245,7 @@ $mat-icon-font: 'Material Icons', sans-serif;
231
245
  opacity: 0.5;
232
246
  transition: all 0.3s ease-out, height 0s 0s, opacity 0.3s 0s;
233
247
  }
248
+
234
249
  .shepherd-modal-overlay-container.shepherd-modal-is-visible path {
235
250
  pointer-events: all;
236
251
  }
@@ -1,4 +1,5 @@
1
1
  /**
2
2
  * Generated bundle index. Do not edit.
3
3
  */
4
+ /// <amd-module name="@covalent/guided-tour" />
4
5
  export * from './index';
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './index';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY292YWxlbnQtZ3VpZGVkLXRvdXIuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvcGxhdGZvcm0vZ3VpZGVkLXRvdXIvY292YWxlbnQtZ3VpZGVkLXRvdXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0=
@@ -0,0 +1,20 @@
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
+ /** @nocollapse */ /** @nocollapse */ CovalentGuidedTourModule.ɵfac = function CovalentGuidedTourModule_Factory(t) { return new (t || CovalentGuidedTourModule)(); };
8
+ /** @nocollapse */ /** @nocollapse */ CovalentGuidedTourModule.ɵmod = /** @pureOrBreakMyCode */ i0.ɵɵdefineNgModule({ type: CovalentGuidedTourModule });
9
+ /** @nocollapse */ /** @nocollapse */ CovalentGuidedTourModule.ɵinj = /** @pureOrBreakMyCode */ i0.ɵɵdefineInjector({ providers: [CovalentGuidedTourService], imports: [[CommonModule]] });
10
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(CovalentGuidedTourModule, [{
11
+ type: NgModule,
12
+ args: [{
13
+ imports: [CommonModule],
14
+ providers: [CovalentGuidedTourService],
15
+ declarations: [],
16
+ exports: [],
17
+ }]
18
+ }], null, null); })();
19
+ (function () { (typeof ngJitMode === "undefined" || ngJitMode) && i0.ɵɵsetNgModuleScope(CovalentGuidedTourModule, { imports: [CommonModule] }); })();
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3VpZGVkLXRvdXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3BsYXRmb3JtL2d1aWRlZC10b3VyL2d1aWRlZC10b3VyLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQzs7QUFRbEUsTUFBTSxPQUFPLHdCQUF3Qjs7c0lBQXhCLHdCQUF3Qjs0SEFBeEIsd0JBQXdCO2lJQUp4QixDQUFDLHlCQUF5QixDQUFDLFlBRDdCLENBQUMsWUFBWSxDQUFDO3VGQUtaLHdCQUF3QjtjQU5wQyxRQUFRO2VBQUM7Z0JBQ1IsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO2dCQUN2QixTQUFTLEVBQUUsQ0FBQyx5QkFBeUIsQ0FBQztnQkFDdEMsWUFBWSxFQUFFLEVBQUU7Z0JBQ2hCLE9BQU8sRUFBRSxFQUFFO2FBQ1o7O3dGQUNZLHdCQUF3QixjQUx6QixZQUFZIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDb3ZhbGVudEd1aWRlZFRvdXJTZXJ2aWNlIH0gZnJvbSAnLi9ndWlkZWQtdG91ci5zZXJ2aWNlJztcblxuQE5nTW9kdWxlKHtcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIHByb3ZpZGVyczogW0NvdmFsZW50R3VpZGVkVG91clNlcnZpY2VdLFxuICBkZWNsYXJhdGlvbnM6IFtdLFxuICBleHBvcnRzOiBbXSxcbn0pXG5leHBvcnQgY2xhc3MgQ292YWxlbnRHdWlkZWRUb3VyTW9kdWxlIHt9XG4iXX0=
@@ -0,0 +1,155 @@
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 && event.navigationTrigger === 'popstate'))
34
+ .subscribe((event) => {
35
+ if (this.shepherdTour.isActive) {
36
+ this.shepherdTour.cancel();
37
+ }
38
+ });
39
+ }
40
+ tourEvent$(str) {
41
+ return fromEvent(this.shepherdTour, str);
42
+ }
43
+ async registerTour(tourName, tour) {
44
+ const guidedTour = typeof tour === 'string' ? await this._loadTour(tour) : tour;
45
+ this._toursMap.set(tourName, guidedTour);
46
+ }
47
+ startTour(tourName) {
48
+ const guidedTour = this._getTour(tourName);
49
+ this.finish();
50
+ if (guidedTour && guidedTour.steps && guidedTour.steps.length) {
51
+ // remove steps from tour since we need to preprocess them first
52
+ this.newTour(Object.assign({}, guidedTour, { steps: undefined }));
53
+ const tourInstance = this.shepherdTour.addSteps(this._configureRoutesForSteps(this._prepareTour(guidedTour.steps, guidedTour.finishButtonText)));
54
+ // init route transition if step URL is different then the current location.
55
+ this.tourEvent$(TourEvents.show).subscribe((tourEvent) => {
56
+ const currentURL = this._router.url.split(/[?#]/)[0];
57
+ const { step: { id, options }, } = tourEvent;
58
+ if (this._tourStepURLs.has(id)) {
59
+ const stepRoute = this._tourStepURLs.get(id);
60
+ if (stepRoute !== currentURL) {
61
+ this._router.navigate([stepRoute]);
62
+ }
63
+ }
64
+ else {
65
+ if (options && options.routing) {
66
+ this._tourStepURLs.set(id, options.routing.route);
67
+ }
68
+ else {
69
+ this._tourStepURLs.set(id, currentURL);
70
+ }
71
+ }
72
+ });
73
+ this.start();
74
+ return tourInstance;
75
+ }
76
+ else {
77
+ // tslint:disable-next-line:no-console
78
+ console.warn(`Tour ${tourName} does not exist. Please try another tour.`);
79
+ }
80
+ }
81
+ // Finds the right registered tour by using queryParams
82
+ // finishes any other tour and starts the new one.
83
+ initializeOnQueryParams(queryParam = 'tour') {
84
+ return this._route.queryParamMap.pipe(debounceTime(100), tap((params) => {
85
+ const tourParam = params.get(queryParam);
86
+ if (tourParam) {
87
+ this.startTour(tourParam);
88
+ // get current search parameters
89
+ const searchParams = new URLSearchParams(window.location.search);
90
+ // delete tour queryParam
91
+ searchParams.delete(queryParam);
92
+ // build new URL string without it
93
+ let url = window.location.protocol + '//' + window.location.host + window.location.pathname;
94
+ if (searchParams.toString()) {
95
+ url += '?' + searchParams.toString();
96
+ }
97
+ // replace state in history without triggering a navigation
98
+ window.history.replaceState({ path: url }, '', url);
99
+ }
100
+ }));
101
+ }
102
+ setNextBtnDisability(stepId, isDisabled) {
103
+ if (this.shepherdTour.getById(stepId)) {
104
+ const stepOptions = this.shepherdTour.getById(stepId).options;
105
+ stepOptions.buttons.forEach((button) => {
106
+ if (button.text === 'chevron_right') {
107
+ button.disabled = isDisabled;
108
+ }
109
+ });
110
+ this.shepherdTour.getById(stepId).updateStepOptions(stepOptions);
111
+ }
112
+ }
113
+ async _loadTour(tourUrl) {
114
+ const request = this._httpClient.get(tourUrl);
115
+ try {
116
+ return await request
117
+ .pipe(map((resultSet) => {
118
+ return JSON.parse(JSON.stringify(resultSet));
119
+ }))
120
+ .toPromise();
121
+ }
122
+ catch {
123
+ return undefined;
124
+ }
125
+ }
126
+ _getTour(key) {
127
+ return this._toursMap.get(key);
128
+ }
129
+ _configureRoutesForSteps(routedSteps) {
130
+ routedSteps.forEach((step) => {
131
+ if (step.routing) {
132
+ const route = step.routing.route;
133
+ // if there is a beforeShowPromise, then we save it and call it after the navigation
134
+ if (step.beforeShowPromise) {
135
+ const beforeShowPromise = step.beforeShowPromise;
136
+ step.beforeShowPromise = () => {
137
+ return this._router.navigate([route], step.routing.extras).then(() => {
138
+ return beforeShowPromise();
139
+ });
140
+ };
141
+ }
142
+ else {
143
+ step.beforeShowPromise = () => this._router.navigate([route]);
144
+ }
145
+ }
146
+ });
147
+ return routedSteps;
148
+ }
149
+ }
150
+ /** @nocollapse */ /** @nocollapse */ CovalentGuidedTourService.ɵfac = function CovalentGuidedTourService_Factory(t) { return new (t || CovalentGuidedTourService)(i0.ɵɵinject(i1.Router), i0.ɵɵinject(i1.ActivatedRoute), i0.ɵɵinject(i2.HttpClient)); };
151
+ /** @nocollapse */ /** @nocollapse */ CovalentGuidedTourService.ɵprov = /** @pureOrBreakMyCode */ i0.ɵɵdefineInjectable({ token: CovalentGuidedTourService, factory: CovalentGuidedTourService.ɵfac });
152
+ (function () { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(CovalentGuidedTourService, [{
153
+ type: Injectable
154
+ }], function () { return [{ type: i1.Router }, { type: i1.ActivatedRoute }, { type: i2.HttpClient }]; }, null); })();
155
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"guided-tour.service.js","sourceRoot":"","sources":["../../../../src/platform/guided-tour/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 { CovalentGuidedTour, ITourStep, ITourOptions, TourStepButton } 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(private _router: Router, private _route: ActivatedRoute, private _httpClient: HttpClient) {\n    super();\n    _router.events\n      .pipe(\n        filter((event: NavigationEvent) => event instanceof NavigationStart && event.navigationTrigger === 'popstate'),\n      )\n      .subscribe((event: NavigationEvent) => {\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(tourName: string, tour: IGuidedTour | string): Promise<void> {\n    const guidedTour: IGuidedTour = typeof tour === 'string' ? await this._loadTour(tour) : tour;\n    this._toursMap.set(tourName, guidedTour);\n  }\n\n  startTour(tourName: string): Shepherd.Tour {\n    const guidedTour: IGuidedTour = 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(this._prepareTour(guidedTour.steps, guidedTour.finishButtonText)),\n      );\n      // init route transition if step URL is different then the current location.\n      this.tourEvent$(TourEvents.show).subscribe((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: string = 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      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    }\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: string = params.get(queryParam);\n        if (tourParam) {\n          this.startTour(tourParam);\n          // get current search parameters\n          const searchParams: URLSearchParams = new URLSearchParams(window.location.search);\n          // delete tour queryParam\n          searchParams.delete(queryParam);\n          // build new URL string without it\n          let url: string = window.location.protocol + '//' + window.location.host + 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).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 {\n    return this._toursMap.get(key);\n  }\n\n  private _configureRoutesForSteps(routedSteps: IGuidedTourStep[]): 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.navigate([route], step.routing.extras).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"]}