@covalent/guided-tour 4.0.0 → 4.1.1-beta.3

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/covalent-guided-tour.d.ts +2 -1
  3. package/esm2020/covalent-guided-tour.mjs +5 -0
  4. package/esm2020/lib/guided-tour.module.mjs +19 -0
  5. package/esm2020/lib/guided-tour.service.mjs +163 -0
  6. package/esm2020/lib/guided.tour.mjs +438 -0
  7. package/esm2020/public_api.mjs +4 -0
  8. package/fesm2015/{covalent-guided-tour.js → covalent-guided-tour.mjs} +180 -615
  9. package/fesm2015/covalent-guided-tour.mjs.map +1 -0
  10. package/fesm2020/covalent-guided-tour.mjs +619 -0
  11. package/fesm2020/covalent-guided-tour.mjs.map +1 -0
  12. package/lib/guided-tour.module.d.ts +7 -0
  13. package/{guided-tour.service.d.ts → lib/guided-tour.service.d.ts} +4 -1
  14. package/{guided.tour.d.ts → lib/guided.tour.d.ts} +3 -7
  15. package/package.json +26 -22
  16. package/public_api.d.ts +3 -0
  17. package/{_guided-tour.scss → styles/guided-tour.scss} +17 -2
  18. package/_guided-tour-theme.scss +0 -78
  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
@@ -1,312 +0,0 @@
1
- /**
2
- * @fileoverview added by tsickle
3
- * Generated from: guided-tour.service.ts
4
- * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
5
- */
6
- import { __awaiter } from "tslib";
7
- import { Injectable } from '@angular/core';
8
- import { HttpClient } from '@angular/common/http';
9
- import { Router, ActivatedRoute, NavigationStart, } from '@angular/router';
10
- import { tap, map, filter } from 'rxjs/operators';
11
- import { fromEvent } from 'rxjs';
12
- import { debounceTime } from 'rxjs/operators';
13
- import { CovalentGuidedTour } from './guided.tour';
14
- /**
15
- * @record
16
- */
17
- export function IGuidedTour() { }
18
- if (false) {
19
- /** @type {?} */
20
- IGuidedTour.prototype.steps;
21
- /** @type {?|undefined} */
22
- IGuidedTour.prototype.finishButtonText;
23
- }
24
- /**
25
- * @record
26
- */
27
- export function IGuidedTourStep() { }
28
- if (false) {
29
- /** @type {?|undefined} */
30
- IGuidedTourStep.prototype.routing;
31
- }
32
- /** @enum {string} */
33
- const TourEvents = {
34
- complete: "complete",
35
- cancel: "cancel",
36
- hide: "hide",
37
- show: "show",
38
- start: "start",
39
- active: "active",
40
- inactive: "inactive",
41
- };
42
- export { TourEvents };
43
- /**
44
- * @record
45
- */
46
- export function IGuidedTourEvent() { }
47
- if (false) {
48
- /** @type {?} */
49
- IGuidedTourEvent.prototype.step;
50
- /** @type {?} */
51
- IGuidedTourEvent.prototype.previous;
52
- /** @type {?} */
53
- IGuidedTourEvent.prototype.tour;
54
- }
55
- export class CovalentGuidedTourService extends CovalentGuidedTour {
56
- /**
57
- * @param {?} _router
58
- * @param {?} _route
59
- * @param {?} _httpClient
60
- */
61
- constructor(_router, _route, _httpClient) {
62
- super();
63
- this._router = _router;
64
- this._route = _route;
65
- this._httpClient = _httpClient;
66
- this._toursMap = new Map();
67
- this._tourStepURLs = new Map();
68
- _router.events
69
- .pipe(filter((/**
70
- * @param {?} event
71
- * @return {?}
72
- */
73
- (event) => event instanceof NavigationStart && event.navigationTrigger === 'popstate')))
74
- .subscribe((/**
75
- * @param {?} event
76
- * @return {?}
77
- */
78
- (event) => {
79
- if (this.shepherdTour.isActive) {
80
- this.shepherdTour.cancel();
81
- }
82
- }));
83
- }
84
- /**
85
- * @param {?} str
86
- * @return {?}
87
- */
88
- tourEvent$(str) {
89
- return fromEvent(this.shepherdTour, str);
90
- }
91
- /**
92
- * @param {?} tourName
93
- * @param {?} tour
94
- * @return {?}
95
- */
96
- registerTour(tourName, tour) {
97
- return __awaiter(this, void 0, void 0, function* () {
98
- /** @type {?} */
99
- const guidedTour = typeof tour === 'string' ? yield this._loadTour(tour) : tour;
100
- this._toursMap.set(tourName, guidedTour);
101
- });
102
- }
103
- /**
104
- * @param {?} tourName
105
- * @return {?}
106
- */
107
- startTour(tourName) {
108
- /** @type {?} */
109
- const guidedTour = this._getTour(tourName);
110
- this.finish();
111
- if (guidedTour && guidedTour.steps && guidedTour.steps.length) {
112
- // remove steps from tour since we need to preprocess them first
113
- this.newTour(Object.assign({}, guidedTour, { steps: undefined }));
114
- /** @type {?} */
115
- const tourInstance = this.shepherdTour.addSteps(this._configureRoutesForSteps(this._prepareTour(guidedTour.steps, guidedTour.finishButtonText)));
116
- // init route transition if step URL is different then the current location.
117
- this.tourEvent$(TourEvents.show).subscribe((/**
118
- * @param {?} tourEvent
119
- * @return {?}
120
- */
121
- (tourEvent) => {
122
- /** @type {?} */
123
- const currentURL = this._router.url.split(/[?#]/)[0];
124
- const { step: { id, options }, } = tourEvent;
125
- if (this._tourStepURLs.has(id)) {
126
- /** @type {?} */
127
- const stepRoute = this._tourStepURLs.get(id);
128
- if (stepRoute !== currentURL) {
129
- this._router.navigate([stepRoute]);
130
- }
131
- }
132
- else {
133
- if (options && options.routing) {
134
- this._tourStepURLs.set(id, options.routing.route);
135
- }
136
- else {
137
- this._tourStepURLs.set(id, currentURL);
138
- }
139
- }
140
- }));
141
- this.start();
142
- return tourInstance;
143
- }
144
- else {
145
- // tslint:disable-next-line:no-console
146
- console.warn(`Tour ${tourName} does not exist. Please try another tour.`);
147
- }
148
- }
149
- // Finds the right registered tour by using queryParams
150
- // finishes any other tour and starts the new one.
151
- /**
152
- * @param {?=} queryParam
153
- * @return {?}
154
- */
155
- initializeOnQueryParams(queryParam = 'tour') {
156
- return this._route.queryParamMap.pipe(debounceTime(100), tap((/**
157
- * @param {?} params
158
- * @return {?}
159
- */
160
- (params) => {
161
- /** @type {?} */
162
- const tourParam = params.get(queryParam);
163
- if (tourParam) {
164
- this.startTour(tourParam);
165
- // get current search parameters
166
- /** @type {?} */
167
- const searchParams = new URLSearchParams(window.location.search);
168
- // delete tour queryParam
169
- searchParams.delete(queryParam);
170
- // build new URL string without it
171
- /** @type {?} */
172
- let url = window.location.protocol + '//' + window.location.host + window.location.pathname;
173
- if (searchParams.toString()) {
174
- url += '?' + searchParams.toString();
175
- }
176
- // replace state in history without triggering a navigation
177
- window.history.replaceState({ path: url }, '', url);
178
- }
179
- })));
180
- }
181
- /**
182
- * @param {?} stepId
183
- * @param {?} isDisabled
184
- * @return {?}
185
- */
186
- setNextBtnDisability(stepId, isDisabled) {
187
- if (this.shepherdTour.getById(stepId)) {
188
- /** @type {?} */
189
- const stepOptions = ((/** @type {?} */ (this.shepherdTour.getById(stepId)))).options;
190
- stepOptions.buttons.forEach((/**
191
- * @param {?} button
192
- * @return {?}
193
- */
194
- (button) => {
195
- if (button.text === 'chevron_right') {
196
- button.disabled = isDisabled;
197
- }
198
- }));
199
- this.shepherdTour.getById(stepId).updateStepOptions(stepOptions);
200
- }
201
- }
202
- /**
203
- * @private
204
- * @param {?} tourUrl
205
- * @return {?}
206
- */
207
- _loadTour(tourUrl) {
208
- return __awaiter(this, void 0, void 0, function* () {
209
- /** @type {?} */
210
- const request = this._httpClient.get(tourUrl);
211
- try {
212
- return yield request
213
- .pipe(map((/**
214
- * @param {?} resultSet
215
- * @return {?}
216
- */
217
- (resultSet) => {
218
- return JSON.parse(JSON.stringify(resultSet));
219
- })))
220
- .toPromise();
221
- }
222
- catch (_a) {
223
- return undefined;
224
- }
225
- });
226
- }
227
- /**
228
- * @private
229
- * @param {?} key
230
- * @return {?}
231
- */
232
- _getTour(key) {
233
- return this._toursMap.get(key);
234
- }
235
- /**
236
- * @private
237
- * @param {?} routedSteps
238
- * @return {?}
239
- */
240
- _configureRoutesForSteps(routedSteps) {
241
- routedSteps.forEach((/**
242
- * @param {?} step
243
- * @return {?}
244
- */
245
- (step) => {
246
- if (step.routing) {
247
- /** @type {?} */
248
- const route = step.routing.route;
249
- // if there is a beforeShowPromise, then we save it and call it after the navigation
250
- if (step.beforeShowPromise) {
251
- /** @type {?} */
252
- const beforeShowPromise = step.beforeShowPromise;
253
- step.beforeShowPromise = (/**
254
- * @return {?}
255
- */
256
- () => {
257
- return this._router.navigate([route], step.routing.extras).then((/**
258
- * @return {?}
259
- */
260
- () => {
261
- return beforeShowPromise();
262
- }));
263
- });
264
- }
265
- else {
266
- step.beforeShowPromise = (/**
267
- * @return {?}
268
- */
269
- () => this._router.navigate([route]));
270
- }
271
- }
272
- }));
273
- return routedSteps;
274
- }
275
- }
276
- CovalentGuidedTourService.decorators = [
277
- { type: Injectable }
278
- ];
279
- /** @nocollapse */
280
- CovalentGuidedTourService.ctorParameters = () => [
281
- { type: Router },
282
- { type: ActivatedRoute },
283
- { type: HttpClient }
284
- ];
285
- if (false) {
286
- /**
287
- * @type {?}
288
- * @private
289
- */
290
- CovalentGuidedTourService.prototype._toursMap;
291
- /**
292
- * @type {?}
293
- * @private
294
- */
295
- CovalentGuidedTourService.prototype._tourStepURLs;
296
- /**
297
- * @type {?}
298
- * @private
299
- */
300
- CovalentGuidedTourService.prototype._router;
301
- /**
302
- * @type {?}
303
- * @private
304
- */
305
- CovalentGuidedTourService.prototype._route;
306
- /**
307
- * @type {?}
308
- * @private
309
- */
310
- CovalentGuidedTourService.prototype._httpClient;
311
- }
312
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"guided-tour.service.js","sourceRoot":"../../../../src/platform/guided-tour/","sources":["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"]}