@rfprodz/client-guided-tour 1.0.0

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 (30) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +117 -0
  3. package/esm2022/index.mjs +5 -0
  4. package/esm2022/lib/components/guided-tour/guided-tour.component.mjs +29 -0
  5. package/esm2022/lib/components/guided-tour/guided-tour.directive.mjs +183 -0
  6. package/esm2022/lib/components/guided-tour/guided-tour.interface.mjs +16 -0
  7. package/esm2022/lib/components/guided-tour-example/guided-tour-example.component.mjs +57 -0
  8. package/esm2022/lib/components/index.mjs +3 -0
  9. package/esm2022/lib/guided-tour-example-routing.module.mjs +24 -0
  10. package/esm2022/lib/guided-tour-example.module.mjs +21 -0
  11. package/esm2022/lib/guided-tour.module.mjs +25 -0
  12. package/esm2022/lib/providers/overlay.provider.mjs +12 -0
  13. package/esm2022/lib/services/guided-tour/guided-tour.service.mjs +52 -0
  14. package/esm2022/lib/services/index.mjs +2 -0
  15. package/esm2022/rfprodz-client-guided-tour.mjs +5 -0
  16. package/fesm2022/rfprodz-client-guided-tour.mjs +387 -0
  17. package/fesm2022/rfprodz-client-guided-tour.mjs.map +1 -0
  18. package/index.d.ts +4 -0
  19. package/lib/components/guided-tour/guided-tour.component.d.ts +15 -0
  20. package/lib/components/guided-tour/guided-tour.directive.d.ts +45 -0
  21. package/lib/components/guided-tour/guided-tour.interface.d.ts +14 -0
  22. package/lib/components/guided-tour-example/guided-tour-example.component.d.ts +20 -0
  23. package/lib/components/index.d.ts +2 -0
  24. package/lib/guided-tour-example-routing.module.d.ts +7 -0
  25. package/lib/guided-tour-example.module.d.ts +12 -0
  26. package/lib/guided-tour.module.d.ts +13 -0
  27. package/lib/providers/overlay.provider.d.ts +6 -0
  28. package/lib/services/guided-tour/guided-tour.service.d.ts +23 -0
  29. package/lib/services/index.d.ts +1 -0
  30. package/package.json +45 -0
package/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ The MIT License (MIT)
2
+
3
+ Copyright (c) 2023 rfprod.
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in
13
+ all copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
21
+ THE SOFTWARE.
package/README.md ADDED
@@ -0,0 +1,117 @@
1
+ # Guided Tour Module for Angular
2
+
3
+ Guided tour feature for Angular clients.
4
+
5
+ ## Description
6
+
7
+ TBD
8
+
9
+ ## Usage
10
+
11
+ ### Within the development workspace
12
+
13
+ Import the module
14
+
15
+ ```typescript
16
+ ...
17
+ import { AppGuidedTourModule } from '@app/client-guided-tour';
18
+
19
+ @NgModule({
20
+ imports: [
21
+ ...
22
+ AppGuidedTourModule,
23
+ ...
24
+ ],
25
+ ...
26
+ })
27
+ export class AppModule {}
28
+ ```
29
+
30
+ ### As an external package
31
+
32
+ Install the package
33
+
34
+ ```bash
35
+ yarn add @rfprodz/client-guided-tour @angular/cdk @angular/common @angular/core @angular/material
36
+ ```
37
+
38
+ Import the module
39
+
40
+ ```typescript
41
+ ...
42
+ import { AppGuidedTourModule } from '@rfprodz/client-guided-tour';
43
+
44
+ @NgModule({
45
+ imports: [
46
+ ...
47
+ AppGuidedTourModule,
48
+ ...
49
+ ],
50
+ ...
51
+ })
52
+ export class AppModule {}
53
+ ```
54
+
55
+ Use in components
56
+
57
+ ```html
58
+ ...
59
+ <p>... Some content ...</p>
60
+
61
+ <div [appGuidedTour]="config.at(0)" [highlightElement]="false">first item to explain</div>
62
+
63
+ <p>... Some content ...</p>
64
+
65
+ <div [appGuidedTour]="config.at(1)" [highlightElement]="true">second item to explain</div>
66
+ ...
67
+ ```
68
+
69
+ ```typescript
70
+ @Component({
71
+ ...
72
+ providers: [AppGuidedTourService], // <-- declare a service
73
+ ...
74
+ })
75
+ export class GuidedComponent implements AfterViewInit {
76
+ /** Locate steps. */
77
+ @ViewChildren(AppGuidedTourDirective) public steps!: QueryList<AppGuidedTourDirective>;
78
+
79
+ /** Configure the tour. */
80
+ public tourConig$ = signal<IGuidedTourData[]>([
81
+ {
82
+ index: 0,
83
+ title: 'first',
84
+ subtitle: 'First step',
85
+ description: 'The first step. Highlighting disabled.',
86
+ first: true,
87
+ last: false,
88
+ },
89
+ {
90
+ index: 1,
91
+ title: 'second',
92
+ subtitle: 'Second step',
93
+ description: 'The second step. Highlighting enabled.',
94
+ first: false,
95
+ last: true,
96
+ },
97
+ ]);
98
+
99
+ constructor(public readonly tour: AppGuidedTourService) {}
100
+
101
+ public ngAfterViewInit(): void {
102
+ this.tour.configuration = this.steps; // <-- add steps to the service
103
+ }
104
+ }
105
+ ```
106
+
107
+ ## Developer commands reference
108
+
109
+ ```bash
110
+ npx nx run tools:help --search client-guided-tour:
111
+ ```
112
+
113
+ ## References
114
+
115
+ - [Nx](https://nx.dev)
116
+ - [Angular](https://angular.io)
117
+ - [Angular Material](https://material.angular.io)
@@ -0,0 +1,5 @@
1
+ export * from './lib/components';
2
+ export * from './lib/guided-tour.module';
3
+ export * from './lib/guided-tour-example.module';
4
+ export * from './lib/services';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9saWJzL2NsaWVudC1ndWlkZWQtdG91ci9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxrQkFBa0IsQ0FBQztBQUNqQyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsa0NBQWtDLENBQUM7QUFDakQsY0FBYyxnQkFBZ0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vbGliL2NvbXBvbmVudHMnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZ3VpZGVkLXRvdXIubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2d1aWRlZC10b3VyLWV4YW1wbGUubW9kdWxlJztcbmV4cG9ydCAqIGZyb20gJy4vbGliL3NlcnZpY2VzJztcbiJdfQ==
@@ -0,0 +1,29 @@
1
+ import { ChangeDetectionStrategy, Component, Inject } from '@angular/core';
2
+ import { AppGuidedTourService } from '../../services/guided-tour/guided-tour.service';
3
+ import { GUIDED_TOUR_DATA } from './guided-tour.interface';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "../../services/guided-tour/guided-tour.service";
6
+ import * as i2 from "@angular/material/button";
7
+ import * as i3 from "@angular/material/icon";
8
+ import * as i4 from "@angular/material/card";
9
+ /** Guided tour component. */
10
+ export class AppGuidedTourComponent {
11
+ /**
12
+ * @param tour Guided tour service.
13
+ * @param data Guided tour step data.
14
+ */
15
+ constructor(tour, data) {
16
+ this.tour = tour;
17
+ this.data = data;
18
+ }
19
+ /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: AppGuidedTourComponent, deps: [{ token: i1.AppGuidedTourService }, { token: GUIDED_TOUR_DATA }], target: i0.ɵɵFactoryTarget.Component }); }
20
+ /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.7", type: AppGuidedTourComponent, selector: "app-guided-tour", ngImport: i0, template: "<mat-card>\n <mat-card-header>\n <mat-card-title>{{ data.title }}</mat-card-title>\n <mat-card-subtitle>{{ data.subtitle }}</mat-card-subtitle>\n </mat-card-header>\n\n <mat-card-content>\n <p>{{ data.description }}</p>\n </mat-card-content>\n\n <mat-card-actions class=\"actions\">\n <button mat-button [disabled]=\"data.first\" (click)=\"tour.previous()\" color=\"primary\">\n <mat-icon>chevron_left</mat-icon>\n Previous\n </button>\n\n <button mat-button (click)=\"tour.end()\" color=\"warn\">\n <mat-icon>close</mat-icon>\n End\n </button>\n\n <button mat-button [disabled]=\"data.last\" (click)=\"tour.next()\" color=\"primary\">\n Next\n <mat-icon>chevron_right</mat-icon>\n </button>\n </mat-card-actions>\n</mat-card>\n", styles: [":host{display:block}.actions>*:not(:first-child):not(:last-child){margin:0 6px}\n"], dependencies: [{ kind: "component", type: i2.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "component", type: i3.MatIcon, selector: "mat-icon", inputs: ["color", "inline", "svgIcon", "fontSet", "fontIcon"], exportAs: ["matIcon"] }, { kind: "component", type: i4.MatCard, selector: "mat-card", inputs: ["appearance"], exportAs: ["matCard"] }, { kind: "directive", type: i4.MatCardActions, selector: "mat-card-actions", inputs: ["align"], exportAs: ["matCardActions"] }, { kind: "directive", type: i4.MatCardContent, selector: "mat-card-content" }, { kind: "component", type: i4.MatCardHeader, selector: "mat-card-header" }, { kind: "directive", type: i4.MatCardSubtitle, selector: "mat-card-subtitle, [mat-card-subtitle], [matCardSubtitle]" }, { kind: "directive", type: i4.MatCardTitle, selector: "mat-card-title, [mat-card-title], [matCardTitle]" }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
21
+ }
22
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: AppGuidedTourComponent, decorators: [{
23
+ type: Component,
24
+ args: [{ selector: 'app-guided-tour', changeDetection: ChangeDetectionStrategy.OnPush, template: "<mat-card>\n <mat-card-header>\n <mat-card-title>{{ data.title }}</mat-card-title>\n <mat-card-subtitle>{{ data.subtitle }}</mat-card-subtitle>\n </mat-card-header>\n\n <mat-card-content>\n <p>{{ data.description }}</p>\n </mat-card-content>\n\n <mat-card-actions class=\"actions\">\n <button mat-button [disabled]=\"data.first\" (click)=\"tour.previous()\" color=\"primary\">\n <mat-icon>chevron_left</mat-icon>\n Previous\n </button>\n\n <button mat-button (click)=\"tour.end()\" color=\"warn\">\n <mat-icon>close</mat-icon>\n End\n </button>\n\n <button mat-button [disabled]=\"data.last\" (click)=\"tour.next()\" color=\"primary\">\n Next\n <mat-icon>chevron_right</mat-icon>\n </button>\n </mat-card-actions>\n</mat-card>\n", styles: [":host{display:block}.actions>*:not(:first-child):not(:last-child){margin:0 6px}\n"] }]
25
+ }], ctorParameters: () => [{ type: i1.AppGuidedTourService }, { type: undefined, decorators: [{
26
+ type: Inject,
27
+ args: [GUIDED_TOUR_DATA]
28
+ }] }] });
29
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3VpZGVkLXRvdXIuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jbGllbnQtZ3VpZGVkLXRvdXIvc3JjL2xpYi9jb21wb25lbnRzL2d1aWRlZC10b3VyL2d1aWRlZC10b3VyLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY2xpZW50LWd1aWRlZC10b3VyL3NyYy9saWIvY29tcG9uZW50cy9ndWlkZWQtdG91ci9ndWlkZWQtdG91ci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUUzRSxPQUFPLEVBQUUsb0JBQW9CLEVBQUUsTUFBTSxnREFBZ0QsQ0FBQztBQUN0RixPQUFPLEVBQUUsZ0JBQWdCLEVBQW1CLE1BQU0seUJBQXlCLENBQUM7Ozs7OztBQUU1RSw2QkFBNkI7QUFPN0IsTUFBTSxPQUFPLHNCQUFzQjtJQUNqQzs7O09BR0c7SUFDSCxZQUNrQixJQUEwQixFQUNBLElBQXFCO1FBRC9DLFNBQUksR0FBSixJQUFJLENBQXNCO1FBQ0EsU0FBSSxHQUFKLElBQUksQ0FBaUI7SUFDOUQsQ0FBQztpSUFSTyxzQkFBc0Isc0RBT3ZCLGdCQUFnQjtxSEFQZixzQkFBc0IsdURDWm5DLHl4QkEyQkE7OzJGRGZhLHNCQUFzQjtrQkFObEMsU0FBUzsrQkFDRSxpQkFBaUIsbUJBR1YsdUJBQXVCLENBQUMsTUFBTTs7MEJBUzVDLE1BQU07MkJBQUMsZ0JBQWdCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmltcG9ydCB7IEFwcEd1aWRlZFRvdXJTZXJ2aWNlIH0gZnJvbSAnLi4vLi4vc2VydmljZXMvZ3VpZGVkLXRvdXIvZ3VpZGVkLXRvdXIuc2VydmljZSc7XG5pbXBvcnQgeyBHVUlERURfVE9VUl9EQVRBLCBJR3VpZGVkVG91ckRhdGEgfSBmcm9tICcuL2d1aWRlZC10b3VyLmludGVyZmFjZSc7XG5cbi8qKiBHdWlkZWQgdG91ciBjb21wb25lbnQuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdhcHAtZ3VpZGVkLXRvdXInLFxuICB0ZW1wbGF0ZVVybDogJy4vZ3VpZGVkLXRvdXIuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9ndWlkZWQtdG91ci5jb21wb25lbnQuc2NzcyddLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgQXBwR3VpZGVkVG91ckNvbXBvbmVudCB7XG4gIC8qKlxuICAgKiBAcGFyYW0gdG91ciAgR3VpZGVkIHRvdXIgc2VydmljZS5cbiAgICogQHBhcmFtIGRhdGEgR3VpZGVkIHRvdXIgc3RlcCBkYXRhLlxuICAgKi9cbiAgY29uc3RydWN0b3IoXG4gICAgcHVibGljIHJlYWRvbmx5IHRvdXI6IEFwcEd1aWRlZFRvdXJTZXJ2aWNlLFxuICAgIEBJbmplY3QoR1VJREVEX1RPVVJfREFUQSkgcHVibGljIHJlYWRvbmx5IGRhdGE6IElHdWlkZWRUb3VyRGF0YSxcbiAgKSB7fVxufVxuIiwiPG1hdC1jYXJkPlxuICA8bWF0LWNhcmQtaGVhZGVyPlxuICAgIDxtYXQtY2FyZC10aXRsZT57eyBkYXRhLnRpdGxlIH19PC9tYXQtY2FyZC10aXRsZT5cbiAgICA8bWF0LWNhcmQtc3VidGl0bGU+e3sgZGF0YS5zdWJ0aXRsZSB9fTwvbWF0LWNhcmQtc3VidGl0bGU+XG4gIDwvbWF0LWNhcmQtaGVhZGVyPlxuXG4gIDxtYXQtY2FyZC1jb250ZW50PlxuICAgIDxwPnt7IGRhdGEuZGVzY3JpcHRpb24gfX08L3A+XG4gIDwvbWF0LWNhcmQtY29udGVudD5cblxuICA8bWF0LWNhcmQtYWN0aW9ucyBjbGFzcz1cImFjdGlvbnNcIj5cbiAgICA8YnV0dG9uIG1hdC1idXR0b24gW2Rpc2FibGVkXT1cImRhdGEuZmlyc3RcIiAoY2xpY2spPVwidG91ci5wcmV2aW91cygpXCIgY29sb3I9XCJwcmltYXJ5XCI+XG4gICAgICA8bWF0LWljb24+Y2hldnJvbl9sZWZ0PC9tYXQtaWNvbj5cbiAgICAgIFByZXZpb3VzXG4gICAgPC9idXR0b24+XG5cbiAgICA8YnV0dG9uIG1hdC1idXR0b24gKGNsaWNrKT1cInRvdXIuZW5kKClcIiBjb2xvcj1cIndhcm5cIj5cbiAgICAgIDxtYXQtaWNvbj5jbG9zZTwvbWF0LWljb24+XG4gICAgICBFbmRcbiAgICA8L2J1dHRvbj5cblxuICAgIDxidXR0b24gbWF0LWJ1dHRvbiBbZGlzYWJsZWRdPVwiZGF0YS5sYXN0XCIgKGNsaWNrKT1cInRvdXIubmV4dCgpXCIgY29sb3I9XCJwcmltYXJ5XCI+XG4gICAgICBOZXh0XG4gICAgICA8bWF0LWljb24+Y2hldnJvbl9yaWdodDwvbWF0LWljb24+XG4gICAgPC9idXR0b24+XG4gIDwvbWF0LWNhcmQtYWN0aW9ucz5cbjwvbWF0LWNhcmQ+XG4iXX0=
@@ -0,0 +1,183 @@
1
+ import { Overlay, OverlayConfig } from '@angular/cdk/overlay';
2
+ import { ComponentPortal } from '@angular/cdk/portal';
3
+ import { Directive, ElementRef, Injector, Input, ViewContainerRef } from '@angular/core';
4
+ import { OVERLAY_REFERENCE } from '../../providers/overlay.provider';
5
+ import { AppGuidedTourService } from '../../services/guided-tour/guided-tour.service';
6
+ import { AppGuidedTourComponent } from './guided-tour.component';
7
+ import { GUIDED_TOUR_DATA } from './guided-tour.interface';
8
+ import * as i0 from "@angular/core";
9
+ import * as i1 from "@angular/cdk/overlay";
10
+ import * as i2 from "../../services/guided-tour/guided-tour.service";
11
+ /** Guided tour directive. */
12
+ export class AppGuidedTourDirective {
13
+ /**
14
+ * @param el A wrapper around a native element inside of a View.
15
+ * @param overlay Service to create Overlays.
16
+ * @param overlayConfig Initial configuration used when creating an overlay.
17
+ * @param viewContainerRef Represents a container where one or more views can be attached to a component.
18
+ * @param tour Guided tour service.
19
+ */
20
+ constructor(el, overlay, overlayConfig, viewContainerRef, tour) {
21
+ this.el = el;
22
+ this.overlay = overlay;
23
+ this.overlayConfig = overlayConfig;
24
+ this.viewContainerRef = viewContainerRef;
25
+ this.tour = tour;
26
+ /** Guided tour step configuration. */
27
+ this.appGuidedTour = void 0;
28
+ this.highlightElement = false;
29
+ /** Connected positions configuration. */
30
+ this.flexibleConnectedPositions = [
31
+ // below origin
32
+ {
33
+ originX: 'center',
34
+ originY: 'bottom',
35
+ overlayX: 'center',
36
+ overlayY: 'top',
37
+ },
38
+ {
39
+ originX: 'center',
40
+ originY: 'bottom',
41
+ overlayX: 'end',
42
+ overlayY: 'top',
43
+ },
44
+ {
45
+ originX: 'center',
46
+ originY: 'bottom',
47
+ overlayX: 'start',
48
+ overlayY: 'top',
49
+ },
50
+ // above origin
51
+ {
52
+ originX: 'center',
53
+ originY: 'top',
54
+ overlayX: 'center',
55
+ overlayY: 'bottom',
56
+ },
57
+ {
58
+ originX: 'center',
59
+ originY: 'top',
60
+ overlayX: 'end',
61
+ overlayY: 'bottom',
62
+ },
63
+ {
64
+ originX: 'center',
65
+ originY: 'top',
66
+ overlayX: 'start',
67
+ overlayY: 'bottom',
68
+ },
69
+ ];
70
+ /** Scroll strategy. */
71
+ this.scrollStrategy = 'reposition';
72
+ /** Overlay reference. */
73
+ this.overlayRef = null;
74
+ }
75
+ /** Overlay configurator. */
76
+ configureOverlay() {
77
+ const positionHost = this.nativeElement;
78
+ if (typeof positionHost !== 'undefined') {
79
+ this.overlayConfig.hasBackdrop = false;
80
+ this.overlayConfig.panelClass = '';
81
+ this.overlayConfig.minHeight = void 0;
82
+ this.overlayConfig.minWidth = void 0;
83
+ this.overlayConfig.maxHeight = void 0;
84
+ this.overlayConfig.maxWidth = void 0;
85
+ this.overlayConfig.height = void 0;
86
+ this.overlayConfig.width = void 0;
87
+ switch (this.scrollStrategy) {
88
+ case 'block':
89
+ this.overlayConfig.scrollStrategy = this.overlay.scrollStrategies.block();
90
+ break;
91
+ case 'close':
92
+ this.overlayConfig.scrollStrategy = this.overlay.scrollStrategies.close();
93
+ break;
94
+ case 'noop':
95
+ this.overlayConfig.scrollStrategy = this.overlay.scrollStrategies.noop();
96
+ break;
97
+ case 'reposition':
98
+ default:
99
+ this.overlayConfig.scrollStrategy = this.overlay.scrollStrategies.reposition();
100
+ break;
101
+ }
102
+ this.overlayConfig.positionStrategy = this.overlay
103
+ .position()
104
+ .flexibleConnectedTo(positionHost)
105
+ .setOrigin(positionHost)
106
+ .withPositions(this.flexibleConnectedPositions);
107
+ }
108
+ }
109
+ /** Overlay creator. */
110
+ createOverlay() {
111
+ if (this.overlayRef === null) {
112
+ this.configureOverlay();
113
+ this.overlayRef = this.overlay.create(this.overlayConfig);
114
+ }
115
+ return this.overlayRef;
116
+ }
117
+ /** Disposes an overlay. */
118
+ dispose() {
119
+ if (this.overlayRef !== null) {
120
+ void this.overlayRef?.detach();
121
+ void this.overlayRef?.dispose();
122
+ this.overlayRef = null;
123
+ this.decorateNativeEl(true);
124
+ }
125
+ }
126
+ /** Displays an overlay. */
127
+ display() {
128
+ if (typeof this.appGuidedTour !== 'undefined' && !this.overlayRef?.hasAttached) {
129
+ const overlayRef = this.createOverlay();
130
+ const context = Injector.create({
131
+ providers: [
132
+ {
133
+ provide: OVERLAY_REFERENCE,
134
+ useValue: overlayRef,
135
+ },
136
+ {
137
+ provide: GUIDED_TOUR_DATA,
138
+ useValue: { ...this.appGuidedTour },
139
+ },
140
+ {
141
+ provide: AppGuidedTourService,
142
+ useValue: this.tour,
143
+ },
144
+ ],
145
+ });
146
+ const portal = new ComponentPortal(AppGuidedTourComponent, this.viewContainerRef, context);
147
+ void this.overlayRef?.attach(portal);
148
+ this.decorateNativeEl();
149
+ }
150
+ }
151
+ decorateNativeEl(reset) {
152
+ if (typeof this.nativeElement !== 'undefined' && this.highlightElement) {
153
+ if (reset === true) {
154
+ this.nativeElement.style.border = 'unset';
155
+ return;
156
+ }
157
+ this.nativeElement.style.border = '1px dotted black';
158
+ }
159
+ }
160
+ ngAfterContentInit() {
161
+ this.nativeElement = this.el.nativeElement;
162
+ }
163
+ ngOnDestroy() {
164
+ this.dispose();
165
+ }
166
+ /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: AppGuidedTourDirective, deps: [{ token: i0.ElementRef }, { token: i1.Overlay }, { token: i1.OverlayConfig }, { token: i0.ViewContainerRef }, { token: i2.AppGuidedTourService }], target: i0.ɵɵFactoryTarget.Directive }); }
167
+ /** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "17.0.7", type: AppGuidedTourDirective, selector: "[appGuidedTour]", inputs: { appGuidedTour: "appGuidedTour", highlightElement: "highlightElement", flexibleConnectedPositions: "flexibleConnectedPositions", scrollStrategy: "scrollStrategy" }, ngImport: i0 }); }
168
+ }
169
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: AppGuidedTourDirective, decorators: [{
170
+ type: Directive,
171
+ args: [{
172
+ selector: '[appGuidedTour]',
173
+ }]
174
+ }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.Overlay }, { type: i1.OverlayConfig }, { type: i0.ViewContainerRef }, { type: i2.AppGuidedTourService }], propDecorators: { appGuidedTour: [{
175
+ type: Input
176
+ }], highlightElement: [{
177
+ type: Input
178
+ }], flexibleConnectedPositions: [{
179
+ type: Input
180
+ }], scrollStrategy: [{
181
+ type: Input
182
+ }] } });
183
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"guided-tour.directive.js","sourceRoot":"","sources":["../../../../../../../libs/client-guided-tour/src/lib/components/guided-tour/guided-tour.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { ConnectedPosition, Overlay, OverlayConfig, OverlayRef } from '@angular/cdk/overlay';\nimport { ComponentPortal } from '@angular/cdk/portal';\nimport { AfterContentInit, Directive, ElementRef, Injector, Input, OnDestroy, ViewContainerRef } from '@angular/core';\n\nimport { OVERLAY_REFERENCE } from '../../providers/overlay.provider';\nimport { AppGuidedTourService } from '../../services/guided-tour/guided-tour.service';\nimport { AppGuidedTourComponent } from './guided-tour.component';\nimport { GUIDED_TOUR_DATA, IGuidedTourData } from './guided-tour.interface';\n\n/** Guided tour directive. */\n@Directive({\n  selector: '[appGuidedTour]',\n})\nexport class AppGuidedTourDirective implements AfterContentInit, OnDestroy {\n  /** Guided tour step configuration. */\n  @Input() public appGuidedTour: IGuidedTourData | undefined = void 0;\n\n  @Input() public highlightElement = false;\n\n  /** Connected positions configuration. */\n  @Input() public flexibleConnectedPositions: ConnectedPosition[] = [\n    // below origin\n    {\n      originX: 'center',\n      originY: 'bottom',\n      overlayX: 'center',\n      overlayY: 'top',\n    },\n    {\n      originX: 'center',\n      originY: 'bottom',\n      overlayX: 'end',\n      overlayY: 'top',\n    },\n    {\n      originX: 'center',\n      originY: 'bottom',\n      overlayX: 'start',\n      overlayY: 'top',\n    },\n    // above origin\n    {\n      originX: 'center',\n      originY: 'top',\n      overlayX: 'center',\n      overlayY: 'bottom',\n    },\n    {\n      originX: 'center',\n      originY: 'top',\n      overlayX: 'end',\n      overlayY: 'bottom',\n    },\n    {\n      originX: 'center',\n      originY: 'top',\n      overlayX: 'start',\n      overlayY: 'bottom',\n    },\n  ];\n\n  /** Scroll strategy. */\n  @Input() public scrollStrategy: 'block' | 'close' | 'noop' | 'reposition' = 'reposition';\n\n  /** Native element ref. */\n  private nativeElement?: HTMLElement;\n\n  /** Overlay reference. */\n  private overlayRef: OverlayRef | null = null;\n\n  /**\n   * @param el A wrapper around a native element inside of a View.\n   * @param overlay Service to create Overlays.\n   * @param overlayConfig Initial configuration used when creating an overlay.\n   * @param viewContainerRef Represents a container where one or more views can be attached to a component.\n   * @param tour Guided tour service.\n   */\n  constructor(\n    private readonly el: ElementRef,\n    private readonly overlay: Overlay,\n    private readonly overlayConfig: OverlayConfig,\n    private readonly viewContainerRef: ViewContainerRef,\n    private readonly tour: AppGuidedTourService,\n  ) {}\n\n  /** Overlay configurator. */\n  private configureOverlay(): void {\n    const positionHost = this.nativeElement;\n    if (typeof positionHost !== 'undefined') {\n      this.overlayConfig.hasBackdrop = false;\n      this.overlayConfig.panelClass = '';\n      this.overlayConfig.minHeight = void 0;\n      this.overlayConfig.minWidth = void 0;\n      this.overlayConfig.maxHeight = void 0;\n      this.overlayConfig.maxWidth = void 0;\n      this.overlayConfig.height = void 0;\n      this.overlayConfig.width = void 0;\n      switch (this.scrollStrategy) {\n        case 'block':\n          this.overlayConfig.scrollStrategy = this.overlay.scrollStrategies.block();\n          break;\n        case 'close':\n          this.overlayConfig.scrollStrategy = this.overlay.scrollStrategies.close();\n          break;\n        case 'noop':\n          this.overlayConfig.scrollStrategy = this.overlay.scrollStrategies.noop();\n          break;\n        case 'reposition':\n        default:\n          this.overlayConfig.scrollStrategy = this.overlay.scrollStrategies.reposition();\n          break;\n      }\n      this.overlayConfig.positionStrategy = this.overlay\n        .position()\n        .flexibleConnectedTo(positionHost)\n        .setOrigin(positionHost)\n        .withPositions(this.flexibleConnectedPositions);\n    }\n  }\n\n  /** Overlay creator. */\n  private createOverlay(): OverlayRef | null {\n    if (this.overlayRef === null) {\n      this.configureOverlay();\n      this.overlayRef = this.overlay.create(this.overlayConfig);\n    }\n    return this.overlayRef;\n  }\n\n  /** Disposes an overlay. */\n  public dispose(): void {\n    if (this.overlayRef !== null) {\n      void this.overlayRef?.detach();\n      void this.overlayRef?.dispose();\n      this.overlayRef = null;\n      this.decorateNativeEl(true);\n    }\n  }\n\n  /** Displays an overlay. */\n  public display(): void {\n    if (typeof this.appGuidedTour !== 'undefined' && !this.overlayRef?.hasAttached) {\n      const overlayRef = this.createOverlay();\n      const context = Injector.create({\n        providers: [\n          {\n            provide: OVERLAY_REFERENCE,\n            useValue: overlayRef,\n          },\n          {\n            provide: GUIDED_TOUR_DATA,\n            useValue: { ...this.appGuidedTour },\n          },\n          {\n            provide: AppGuidedTourService,\n            useValue: this.tour,\n          },\n        ],\n      });\n      const portal = new ComponentPortal(AppGuidedTourComponent, this.viewContainerRef, context);\n      void this.overlayRef?.attach(portal);\n      this.decorateNativeEl();\n    }\n  }\n\n  private decorateNativeEl(reset?: boolean) {\n    if (typeof this.nativeElement !== 'undefined' && this.highlightElement) {\n      if (reset === true) {\n        this.nativeElement.style.border = 'unset';\n        return;\n      }\n      this.nativeElement.style.border = '1px dotted black';\n    }\n  }\n\n  public ngAfterContentInit(): void {\n    this.nativeElement = this.el.nativeElement;\n  }\n\n  public ngOnDestroy(): void {\n    this.dispose();\n  }\n}\n"]}
@@ -0,0 +1,16 @@
1
+ import { InjectionToken } from '@angular/core';
2
+ /** Guided tour step data injection token. */
3
+ export const GUIDED_TOUR_DATA = new InjectionToken('GUIDED_TOUR_DATA');
4
+ /** Guided tour step data provider. */
5
+ export const guidedTourDataProvider = {
6
+ provide: GUIDED_TOUR_DATA,
7
+ useValue: {
8
+ index: 0,
9
+ title: '',
10
+ subtitle: '',
11
+ description: '',
12
+ first: true,
13
+ last: true,
14
+ },
15
+ };
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3VpZGVkLXRvdXIuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy9jbGllbnQtZ3VpZGVkLXRvdXIvc3JjL2xpYi9jb21wb25lbnRzL2d1aWRlZC10b3VyL2d1aWRlZC10b3VyLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFZLE1BQU0sZUFBZSxDQUFDO0FBWXpELDZDQUE2QztBQUM3QyxNQUFNLENBQUMsTUFBTSxnQkFBZ0IsR0FBRyxJQUFJLGNBQWMsQ0FBa0Isa0JBQWtCLENBQUMsQ0FBQztBQUV4RixzQ0FBc0M7QUFDdEMsTUFBTSxDQUFDLE1BQU0sc0JBQXNCLEdBQWE7SUFDOUMsT0FBTyxFQUFFLGdCQUFnQjtJQUN6QixRQUFRLEVBQW1CO1FBQ3pCLEtBQUssRUFBRSxDQUFDO1FBQ1IsS0FBSyxFQUFFLEVBQUU7UUFDVCxRQUFRLEVBQUUsRUFBRTtRQUNaLFdBQVcsRUFBRSxFQUFFO1FBQ2YsS0FBSyxFQUFFLElBQUk7UUFDWCxJQUFJLEVBQUUsSUFBSTtLQUNYO0NBQ0YsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGlvblRva2VuLCBQcm92aWRlciB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG4vKiogR3VpZGVkIHRvdXIgc3RlcCBkYXRhLiAqL1xuZXhwb3J0IGludGVyZmFjZSBJR3VpZGVkVG91ckRhdGEge1xuICBpbmRleDogbnVtYmVyO1xuICB0aXRsZTogc3RyaW5nO1xuICBzdWJ0aXRsZTogc3RyaW5nO1xuICBkZXNjcmlwdGlvbjogc3RyaW5nO1xuICBmaXJzdDogYm9vbGVhbjtcbiAgbGFzdDogYm9vbGVhbjtcbn1cblxuLyoqIEd1aWRlZCB0b3VyIHN0ZXAgZGF0YSBpbmplY3Rpb24gdG9rZW4uICovXG5leHBvcnQgY29uc3QgR1VJREVEX1RPVVJfREFUQSA9IG5ldyBJbmplY3Rpb25Ub2tlbjxJR3VpZGVkVG91ckRhdGE+KCdHVUlERURfVE9VUl9EQVRBJyk7XG5cbi8qKiBHdWlkZWQgdG91ciBzdGVwIGRhdGEgcHJvdmlkZXIuICovXG5leHBvcnQgY29uc3QgZ3VpZGVkVG91ckRhdGFQcm92aWRlcjogUHJvdmlkZXIgPSB7XG4gIHByb3ZpZGU6IEdVSURFRF9UT1VSX0RBVEEsXG4gIHVzZVZhbHVlOiA8SUd1aWRlZFRvdXJEYXRhPntcbiAgICBpbmRleDogMCxcbiAgICB0aXRsZTogJycsXG4gICAgc3VidGl0bGU6ICcnLFxuICAgIGRlc2NyaXB0aW9uOiAnJyxcbiAgICBmaXJzdDogdHJ1ZSxcbiAgICBsYXN0OiB0cnVlLFxuICB9LFxufTtcbiJdfQ==
@@ -0,0 +1,57 @@
1
+ import { ChangeDetectionStrategy, Component, QueryList, signal, ViewChildren } from '@angular/core';
2
+ import { AppGuidedTourService } from '../../services/guided-tour/guided-tour.service';
3
+ import { AppGuidedTourDirective } from '../guided-tour/guided-tour.directive';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "../../services/guided-tour/guided-tour.service";
6
+ import * as i2 from "@angular/common";
7
+ import * as i3 from "@angular/material/button";
8
+ import * as i4 from "../guided-tour/guided-tour.directive";
9
+ /** An example of a guided tour. */
10
+ export class AppGuidedTourExampleComponent {
11
+ /**
12
+ * @param tour Guided tour service.
13
+ */
14
+ constructor(tour) {
15
+ this.tour = tour;
16
+ /** Example tour configuration. */
17
+ this.tourConig$ = signal([
18
+ {
19
+ index: 0,
20
+ title: 'first',
21
+ subtitle: 'First step',
22
+ description: 'The first step. Highlighting disabled.',
23
+ first: true,
24
+ last: false,
25
+ },
26
+ {
27
+ index: 1,
28
+ title: 'second',
29
+ subtitle: 'Second step',
30
+ description: 'The second step. Highlighting enabled.',
31
+ first: false,
32
+ last: false,
33
+ },
34
+ {
35
+ index: 2,
36
+ title: 'third',
37
+ subtitle: 'Third step',
38
+ description: 'The final step. Highlighting enabled.',
39
+ first: false,
40
+ last: true,
41
+ },
42
+ ]);
43
+ }
44
+ ngAfterViewInit() {
45
+ this.tour.configuration = this.steps;
46
+ }
47
+ /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: AppGuidedTourExampleComponent, deps: [{ token: i1.AppGuidedTourService }], target: i0.ɵɵFactoryTarget.Component }); }
48
+ /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.0.7", type: AppGuidedTourExampleComponent, selector: "app-guided-tour-example", providers: [AppGuidedTourService], viewQueries: [{ propertyName: "steps", predicate: AppGuidedTourDirective, descendants: true }], ngImport: i0, template: "<p>... Some content ...</p>\n\n<ng-container *ngIf=\"tourConig$() as config\">\n <div [appGuidedTour]=\"config.at(1)\" [highlightElement]=\"true\">second item to explain</div>\n\n <p>... Some content ...</p>\n\n <div [appGuidedTour]=\"config.at(2)\" [highlightElement]=\"true\">third item to explain</div>\n\n <p>... Some content ...</p>\n\n <div [appGuidedTour]=\"config.at(0)\">first item to explain</div>\n</ng-container>\n\n<p>... Some content ...</p>\n\n@if (!tour.active) {\n <button mat-raised-button color=\"accent\" (click)=\"tour.next()\">Start tour</button>\n} @else {\n <button mat-raised-button color=\"warn\" (click)=\"tour.end()\">End tour</button>\n}\n", styles: [":host{display:block;padding:16px}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.MatButton, selector: " button[mat-button], button[mat-raised-button], button[mat-flat-button], button[mat-stroked-button] ", exportAs: ["matButton"] }, { kind: "directive", type: i4.AppGuidedTourDirective, selector: "[appGuidedTour]", inputs: ["appGuidedTour", "highlightElement", "flexibleConnectedPositions", "scrollStrategy"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
49
+ }
50
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: AppGuidedTourExampleComponent, decorators: [{
51
+ type: Component,
52
+ args: [{ selector: 'app-guided-tour-example', providers: [AppGuidedTourService], changeDetection: ChangeDetectionStrategy.OnPush, template: "<p>... Some content ...</p>\n\n<ng-container *ngIf=\"tourConig$() as config\">\n <div [appGuidedTour]=\"config.at(1)\" [highlightElement]=\"true\">second item to explain</div>\n\n <p>... Some content ...</p>\n\n <div [appGuidedTour]=\"config.at(2)\" [highlightElement]=\"true\">third item to explain</div>\n\n <p>... Some content ...</p>\n\n <div [appGuidedTour]=\"config.at(0)\">first item to explain</div>\n</ng-container>\n\n<p>... Some content ...</p>\n\n@if (!tour.active) {\n <button mat-raised-button color=\"accent\" (click)=\"tour.next()\">Start tour</button>\n} @else {\n <button mat-raised-button color=\"warn\" (click)=\"tour.end()\">End tour</button>\n}\n", styles: [":host{display:block;padding:16px}\n"] }]
53
+ }], ctorParameters: () => [{ type: i1.AppGuidedTourService }], propDecorators: { steps: [{
54
+ type: ViewChildren,
55
+ args: [AppGuidedTourDirective]
56
+ }] } });
57
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3VpZGVkLXRvdXItZXhhbXBsZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NsaWVudC1ndWlkZWQtdG91ci9zcmMvbGliL2NvbXBvbmVudHMvZ3VpZGVkLXRvdXItZXhhbXBsZS9ndWlkZWQtdG91ci1leGFtcGxlLmNvbXBvbmVudC50cyIsIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY2xpZW50LWd1aWRlZC10b3VyL3NyYy9saWIvY29tcG9uZW50cy9ndWlkZWQtdG91ci1leGFtcGxlL2d1aWRlZC10b3VyLWV4YW1wbGUuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFpQix1QkFBdUIsRUFBRSxTQUFTLEVBQUUsU0FBUyxFQUFFLE1BQU0sRUFBRSxZQUFZLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFbkgsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sZ0RBQWdELENBQUM7QUFDdEYsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sc0NBQXNDLENBQUM7Ozs7OztBQUc5RSxtQ0FBbUM7QUFRbkMsTUFBTSxPQUFPLDZCQUE2QjtJQWdDeEM7O09BRUc7SUFDSCxZQUE0QixJQUEwQjtRQUExQixTQUFJLEdBQUosSUFBSSxDQUFzQjtRQS9CdEQsa0NBQWtDO1FBQzNCLGVBQVUsR0FBRyxNQUFNLENBQW9CO1lBQzVDO2dCQUNFLEtBQUssRUFBRSxDQUFDO2dCQUNSLEtBQUssRUFBRSxPQUFPO2dCQUNkLFFBQVEsRUFBRSxZQUFZO2dCQUN0QixXQUFXLEVBQUUsd0NBQXdDO2dCQUNyRCxLQUFLLEVBQUUsSUFBSTtnQkFDWCxJQUFJLEVBQUUsS0FBSzthQUNaO1lBQ0Q7Z0JBQ0UsS0FBSyxFQUFFLENBQUM7Z0JBQ1IsS0FBSyxFQUFFLFFBQVE7Z0JBQ2YsUUFBUSxFQUFFLGFBQWE7Z0JBQ3ZCLFdBQVcsRUFBRSx3Q0FBd0M7Z0JBQ3JELEtBQUssRUFBRSxLQUFLO2dCQUNaLElBQUksRUFBRSxLQUFLO2FBQ1o7WUFDRDtnQkFDRSxLQUFLLEVBQUUsQ0FBQztnQkFDUixLQUFLLEVBQUUsT0FBTztnQkFDZCxRQUFRLEVBQUUsWUFBWTtnQkFDdEIsV0FBVyxFQUFFLHVDQUF1QztnQkFDcEQsS0FBSyxFQUFFLEtBQUs7Z0JBQ1osSUFBSSxFQUFFLElBQUk7YUFDWDtTQUNGLENBQUMsQ0FBQztJQUtzRCxDQUFDO0lBRW5ELGVBQWU7UUFDcEIsSUFBSSxDQUFDLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQztJQUN2QyxDQUFDO2lJQXZDVSw2QkFBNkI7cUhBQTdCLDZCQUE2QixrREFIN0IsQ0FBQyxvQkFBb0IsQ0FBQyxvREFLbkIsc0JBQXNCLGdEQ2hCdEMscXFCQXFCQTs7MkZEUGEsNkJBQTZCO2tCQVB6QyxTQUFTOytCQUNFLHlCQUF5QixhQUd4QixDQUFDLG9CQUFvQixDQUFDLG1CQUNoQix1QkFBdUIsQ0FBQyxNQUFNO3lGQUlGLEtBQUs7c0JBQWpELFlBQVk7dUJBQUMsc0JBQXNCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQWZ0ZXJWaWV3SW5pdCwgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgUXVlcnlMaXN0LCBzaWduYWwsIFZpZXdDaGlsZHJlbiB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5pbXBvcnQgeyBBcHBHdWlkZWRUb3VyU2VydmljZSB9IGZyb20gJy4uLy4uL3NlcnZpY2VzL2d1aWRlZC10b3VyL2d1aWRlZC10b3VyLnNlcnZpY2UnO1xuaW1wb3J0IHsgQXBwR3VpZGVkVG91ckRpcmVjdGl2ZSB9IGZyb20gJy4uL2d1aWRlZC10b3VyL2d1aWRlZC10b3VyLmRpcmVjdGl2ZSc7XG5pbXBvcnQgeyBJR3VpZGVkVG91ckRhdGEgfSBmcm9tICcuLi9ndWlkZWQtdG91ci9ndWlkZWQtdG91ci5pbnRlcmZhY2UnO1xuXG4vKiogQW4gZXhhbXBsZSBvZiBhIGd1aWRlZCB0b3VyLiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXBwLWd1aWRlZC10b3VyLWV4YW1wbGUnLFxuICB0ZW1wbGF0ZVVybDogJy4vZ3VpZGVkLXRvdXItZXhhbXBsZS5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2d1aWRlZC10b3VyLWV4YW1wbGUuY29tcG9uZW50LnNjc3MnXSxcbiAgcHJvdmlkZXJzOiBbQXBwR3VpZGVkVG91clNlcnZpY2VdLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbn0pXG5leHBvcnQgY2xhc3MgQXBwR3VpZGVkVG91ckV4YW1wbGVDb21wb25lbnQgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0IHtcbiAgLyoqIFRvdXIgc3RlcHMuICovXG4gIEBWaWV3Q2hpbGRyZW4oQXBwR3VpZGVkVG91ckRpcmVjdGl2ZSkgcHVibGljIHN0ZXBzITogUXVlcnlMaXN0PEFwcEd1aWRlZFRvdXJEaXJlY3RpdmU+O1xuXG4gIC8qKiBFeGFtcGxlIHRvdXIgY29uZmlndXJhdGlvbi4gKi9cbiAgcHVibGljIHRvdXJDb25pZyQgPSBzaWduYWw8SUd1aWRlZFRvdXJEYXRhW10+KFtcbiAgICB7XG4gICAgICBpbmRleDogMCxcbiAgICAgIHRpdGxlOiAnZmlyc3QnLFxuICAgICAgc3VidGl0bGU6ICdGaXJzdCBzdGVwJyxcbiAgICAgIGRlc2NyaXB0aW9uOiAnVGhlIGZpcnN0IHN0ZXAuIEhpZ2hsaWdodGluZyBkaXNhYmxlZC4nLFxuICAgICAgZmlyc3Q6IHRydWUsXG4gICAgICBsYXN0OiBmYWxzZSxcbiAgICB9LFxuICAgIHtcbiAgICAgIGluZGV4OiAxLFxuICAgICAgdGl0bGU6ICdzZWNvbmQnLFxuICAgICAgc3VidGl0bGU6ICdTZWNvbmQgc3RlcCcsXG4gICAgICBkZXNjcmlwdGlvbjogJ1RoZSBzZWNvbmQgc3RlcC4gSGlnaGxpZ2h0aW5nIGVuYWJsZWQuJyxcbiAgICAgIGZpcnN0OiBmYWxzZSxcbiAgICAgIGxhc3Q6IGZhbHNlLFxuICAgIH0sXG4gICAge1xuICAgICAgaW5kZXg6IDIsXG4gICAgICB0aXRsZTogJ3RoaXJkJyxcbiAgICAgIHN1YnRpdGxlOiAnVGhpcmQgc3RlcCcsXG4gICAgICBkZXNjcmlwdGlvbjogJ1RoZSBmaW5hbCBzdGVwLiBIaWdobGlnaHRpbmcgZW5hYmxlZC4nLFxuICAgICAgZmlyc3Q6IGZhbHNlLFxuICAgICAgbGFzdDogdHJ1ZSxcbiAgICB9LFxuICBdKTtcblxuICAvKipcbiAgICogQHBhcmFtIHRvdXIgR3VpZGVkIHRvdXIgc2VydmljZS5cbiAgICovXG4gIGNvbnN0cnVjdG9yKHB1YmxpYyByZWFkb25seSB0b3VyOiBBcHBHdWlkZWRUb3VyU2VydmljZSkge31cblxuICBwdWJsaWMgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xuICAgIHRoaXMudG91ci5jb25maWd1cmF0aW9uID0gdGhpcy5zdGVwcztcbiAgfVxufVxuIiwiPHA+Li4uIFNvbWUgY29udGVudCAuLi48L3A+XG5cbjxuZy1jb250YWluZXIgKm5nSWY9XCJ0b3VyQ29uaWckKCkgYXMgY29uZmlnXCI+XG4gIDxkaXYgW2FwcEd1aWRlZFRvdXJdPVwiY29uZmlnLmF0KDEpXCIgW2hpZ2hsaWdodEVsZW1lbnRdPVwidHJ1ZVwiPnNlY29uZCBpdGVtIHRvIGV4cGxhaW48L2Rpdj5cblxuICA8cD4uLi4gU29tZSBjb250ZW50IC4uLjwvcD5cblxuICA8ZGl2IFthcHBHdWlkZWRUb3VyXT1cImNvbmZpZy5hdCgyKVwiIFtoaWdobGlnaHRFbGVtZW50XT1cInRydWVcIj50aGlyZCBpdGVtIHRvIGV4cGxhaW48L2Rpdj5cblxuICA8cD4uLi4gU29tZSBjb250ZW50IC4uLjwvcD5cblxuICA8ZGl2IFthcHBHdWlkZWRUb3VyXT1cImNvbmZpZy5hdCgwKVwiPmZpcnN0IGl0ZW0gdG8gZXhwbGFpbjwvZGl2PlxuPC9uZy1jb250YWluZXI+XG5cbjxwPi4uLiBTb21lIGNvbnRlbnQgLi4uPC9wPlxuXG5AaWYgKCF0b3VyLmFjdGl2ZSkge1xuICA8YnV0dG9uIG1hdC1yYWlzZWQtYnV0dG9uIGNvbG9yPVwiYWNjZW50XCIgKGNsaWNrKT1cInRvdXIubmV4dCgpXCI+U3RhcnQgdG91cjwvYnV0dG9uPlxufSBAZWxzZSB7XG4gIDxidXR0b24gbWF0LXJhaXNlZC1idXR0b24gY29sb3I9XCJ3YXJuXCIgKGNsaWNrKT1cInRvdXIuZW5kKClcIj5FbmQgdG91cjwvYnV0dG9uPlxufVxuIl19
@@ -0,0 +1,3 @@
1
+ export * from './guided-tour/guided-tour.directive';
2
+ export * from './guided-tour/guided-tour.interface';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzL2NsaWVudC1ndWlkZWQtdG91ci9zcmMvbGliL2NvbXBvbmVudHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxxQ0FBcUMsQ0FBQztBQUNwRCxjQUFjLHFDQUFxQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9ndWlkZWQtdG91ci9ndWlkZWQtdG91ci5kaXJlY3RpdmUnO1xuZXhwb3J0ICogZnJvbSAnLi9ndWlkZWQtdG91ci9ndWlkZWQtdG91ci5pbnRlcmZhY2UnO1xuIl19
@@ -0,0 +1,24 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { RouterModule } from '@angular/router';
3
+ import { AppGuidedTourExampleComponent } from './components/guided-tour-example/guided-tour-example.component';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/router";
6
+ const routes = [
7
+ {
8
+ path: '',
9
+ component: AppGuidedTourExampleComponent,
10
+ },
11
+ ];
12
+ export class AppGuidedTourExampleRoutingModule {
13
+ /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: AppGuidedTourExampleRoutingModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
14
+ /** @nocollapse */ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.0.7", ngImport: i0, type: AppGuidedTourExampleRoutingModule, imports: [i1.RouterModule], exports: [RouterModule] }); }
15
+ /** @nocollapse */ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: AppGuidedTourExampleRoutingModule, imports: [RouterModule.forChild(routes), RouterModule] }); }
16
+ }
17
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: AppGuidedTourExampleRoutingModule, decorators: [{
18
+ type: NgModule,
19
+ args: [{
20
+ imports: [RouterModule.forChild(routes)],
21
+ exports: [RouterModule],
22
+ }]
23
+ }] });
24
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3VpZGVkLXRvdXItZXhhbXBsZS1yb3V0aW5nLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYnMvY2xpZW50LWd1aWRlZC10b3VyL3NyYy9saWIvZ3VpZGVkLXRvdXItZXhhbXBsZS1yb3V0aW5nLm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBUyxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUV0RCxPQUFPLEVBQUUsNkJBQTZCLEVBQUUsTUFBTSxnRUFBZ0UsQ0FBQzs7O0FBRS9HLE1BQU0sTUFBTSxHQUFZO0lBQ3RCO1FBQ0UsSUFBSSxFQUFFLEVBQUU7UUFDUixTQUFTLEVBQUUsNkJBQTZCO0tBQ3pDO0NBQ0YsQ0FBQztBQU1GLE1BQU0sT0FBTyxpQ0FBaUM7aUlBQWpDLGlDQUFpQztrSUFBakMsaUNBQWlDLHdDQUZsQyxZQUFZO2tJQUVYLGlDQUFpQyxZQUhsQyxZQUFZLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxFQUM3QixZQUFZOzsyRkFFWCxpQ0FBaUM7a0JBSjdDLFFBQVE7bUJBQUM7b0JBQ1IsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsQ0FBQztvQkFDeEMsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO2lCQUN4QiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE5nTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBSb3V0ZSwgUm91dGVyTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcblxuaW1wb3J0IHsgQXBwR3VpZGVkVG91ckV4YW1wbGVDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvZ3VpZGVkLXRvdXItZXhhbXBsZS9ndWlkZWQtdG91ci1leGFtcGxlLmNvbXBvbmVudCc7XG5cbmNvbnN0IHJvdXRlczogUm91dGVbXSA9IFtcbiAge1xuICAgIHBhdGg6ICcnLFxuICAgIGNvbXBvbmVudDogQXBwR3VpZGVkVG91ckV4YW1wbGVDb21wb25lbnQsXG4gIH0sXG5dO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbUm91dGVyTW9kdWxlLmZvckNoaWxkKHJvdXRlcyldLFxuICBleHBvcnRzOiBbUm91dGVyTW9kdWxlXSxcbn0pXG5leHBvcnQgY2xhc3MgQXBwR3VpZGVkVG91ckV4YW1wbGVSb3V0aW5nTW9kdWxlIHt9XG4iXX0=
@@ -0,0 +1,21 @@
1
+ import { CommonModule } from '@angular/common';
2
+ import { NgModule } from '@angular/core';
3
+ import { MatButtonModule } from '@angular/material/button';
4
+ import { MatIconModule } from '@angular/material/icon';
5
+ import { AppGuidedTourExampleComponent } from './components/guided-tour-example/guided-tour-example.component';
6
+ import { AppGuidedTourModule } from './guided-tour.module';
7
+ import { AppGuidedTourExampleRoutingModule } from './guided-tour-example-routing.module';
8
+ import * as i0 from "@angular/core";
9
+ export class AppGuidedTourExampleModule {
10
+ /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: AppGuidedTourExampleModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
11
+ /** @nocollapse */ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.0.7", ngImport: i0, type: AppGuidedTourExampleModule, declarations: [AppGuidedTourExampleComponent], imports: [CommonModule, MatButtonModule, MatIconModule, AppGuidedTourModule, AppGuidedTourExampleRoutingModule] }); }
12
+ /** @nocollapse */ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: AppGuidedTourExampleModule, imports: [CommonModule, MatButtonModule, MatIconModule, AppGuidedTourModule, AppGuidedTourExampleRoutingModule] }); }
13
+ }
14
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: AppGuidedTourExampleModule, decorators: [{
15
+ type: NgModule,
16
+ args: [{
17
+ imports: [CommonModule, MatButtonModule, MatIconModule, AppGuidedTourModule, AppGuidedTourExampleRoutingModule],
18
+ declarations: [AppGuidedTourExampleComponent],
19
+ }]
20
+ }] });
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3VpZGVkLXRvdXItZXhhbXBsZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzL2NsaWVudC1ndWlkZWQtdG91ci9zcmMvbGliL2d1aWRlZC10b3VyLWV4YW1wbGUubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFFdkQsT0FBTyxFQUFFLDZCQUE2QixFQUFFLE1BQU0sZ0VBQWdFLENBQUM7QUFDL0csT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGlDQUFpQyxFQUFFLE1BQU0sc0NBQXNDLENBQUM7O0FBTXpGLE1BQU0sT0FBTywwQkFBMEI7aUlBQTFCLDBCQUEwQjtrSUFBMUIsMEJBQTBCLGlCQUZ0Qiw2QkFBNkIsYUFEbEMsWUFBWSxFQUFFLGVBQWUsRUFBRSxhQUFhLEVBQUUsbUJBQW1CLEVBQUUsaUNBQWlDO2tJQUduRywwQkFBMEIsWUFIM0IsWUFBWSxFQUFFLGVBQWUsRUFBRSxhQUFhLEVBQUUsbUJBQW1CLEVBQUUsaUNBQWlDOzsyRkFHbkcsMEJBQTBCO2tCQUp0QyxRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxlQUFlLEVBQUUsYUFBYSxFQUFFLG1CQUFtQixFQUFFLGlDQUFpQyxDQUFDO29CQUMvRyxZQUFZLEVBQUUsQ0FBQyw2QkFBNkIsQ0FBQztpQkFDOUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5cbmltcG9ydCB7IEFwcEd1aWRlZFRvdXJFeGFtcGxlQ29tcG9uZW50IH0gZnJvbSAnLi9jb21wb25lbnRzL2d1aWRlZC10b3VyLWV4YW1wbGUvZ3VpZGVkLXRvdXItZXhhbXBsZS5jb21wb25lbnQnO1xuaW1wb3J0IHsgQXBwR3VpZGVkVG91ck1vZHVsZSB9IGZyb20gJy4vZ3VpZGVkLXRvdXIubW9kdWxlJztcbmltcG9ydCB7IEFwcEd1aWRlZFRvdXJFeGFtcGxlUm91dGluZ01vZHVsZSB9IGZyb20gJy4vZ3VpZGVkLXRvdXItZXhhbXBsZS1yb3V0aW5nLm1vZHVsZSc7XG5cbkBOZ01vZHVsZSh7XG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGUsIE1hdEJ1dHRvbk1vZHVsZSwgTWF0SWNvbk1vZHVsZSwgQXBwR3VpZGVkVG91ck1vZHVsZSwgQXBwR3VpZGVkVG91ckV4YW1wbGVSb3V0aW5nTW9kdWxlXSxcbiAgZGVjbGFyYXRpb25zOiBbQXBwR3VpZGVkVG91ckV4YW1wbGVDb21wb25lbnRdLFxufSlcbmV4cG9ydCBjbGFzcyBBcHBHdWlkZWRUb3VyRXhhbXBsZU1vZHVsZSB7fVxuIl19
@@ -0,0 +1,25 @@
1
+ import { OverlayModule } from '@angular/cdk/overlay';
2
+ import { CommonModule } from '@angular/common';
3
+ import { NgModule } from '@angular/core';
4
+ import { MatButtonModule } from '@angular/material/button';
5
+ import { MatCardModule } from '@angular/material/card';
6
+ import { MatIconModule } from '@angular/material/icon';
7
+ import { AppGuidedTourComponent } from './components/guided-tour/guided-tour.component';
8
+ import { AppGuidedTourDirective } from './components/guided-tour/guided-tour.directive';
9
+ import { overlayProvider } from './providers/overlay.provider';
10
+ import * as i0 from "@angular/core";
11
+ export class AppGuidedTourModule {
12
+ /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: AppGuidedTourModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
13
+ /** @nocollapse */ static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.0.7", ngImport: i0, type: AppGuidedTourModule, declarations: [AppGuidedTourComponent, AppGuidedTourDirective], imports: [CommonModule, OverlayModule, MatButtonModule, MatIconModule, MatCardModule], exports: [AppGuidedTourDirective] }); }
14
+ /** @nocollapse */ static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: AppGuidedTourModule, providers: [overlayProvider], imports: [CommonModule, OverlayModule, MatButtonModule, MatIconModule, MatCardModule] }); }
15
+ }
16
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: AppGuidedTourModule, decorators: [{
17
+ type: NgModule,
18
+ args: [{
19
+ imports: [CommonModule, OverlayModule, MatButtonModule, MatIconModule, MatCardModule],
20
+ declarations: [AppGuidedTourComponent, AppGuidedTourDirective],
21
+ providers: [overlayProvider],
22
+ exports: [AppGuidedTourDirective],
23
+ }]
24
+ }] });
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3VpZGVkLXRvdXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vbGlicy9jbGllbnQtZ3VpZGVkLXRvdXIvc3JjL2xpYi9ndWlkZWQtdG91ci5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBRXZELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLGdEQUFnRCxDQUFDO0FBQ3hGLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLGdEQUFnRCxDQUFDO0FBQ3hGLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSw4QkFBOEIsQ0FBQzs7QUFRL0QsTUFBTSxPQUFPLG1CQUFtQjtpSUFBbkIsbUJBQW1CO2tJQUFuQixtQkFBbUIsaUJBSmYsc0JBQXNCLEVBQUUsc0JBQXNCLGFBRG5ELFlBQVksRUFBRSxhQUFhLEVBQUUsZUFBZSxFQUFFLGFBQWEsRUFBRSxhQUFhLGFBRzFFLHNCQUFzQjtrSUFFckIsbUJBQW1CLGFBSG5CLENBQUMsZUFBZSxDQUFDLFlBRmxCLFlBQVksRUFBRSxhQUFhLEVBQUUsZUFBZSxFQUFFLGFBQWEsRUFBRSxhQUFhOzsyRkFLekUsbUJBQW1CO2tCQU4vQixRQUFRO21CQUFDO29CQUNSLE9BQU8sRUFBRSxDQUFDLFlBQVksRUFBRSxhQUFhLEVBQUUsZUFBZSxFQUFFLGFBQWEsRUFBRSxhQUFhLENBQUM7b0JBQ3JGLFlBQVksRUFBRSxDQUFDLHNCQUFzQixFQUFFLHNCQUFzQixDQUFDO29CQUM5RCxTQUFTLEVBQUUsQ0FBQyxlQUFlLENBQUM7b0JBQzVCLE9BQU8sRUFBRSxDQUFDLHNCQUFzQixDQUFDO2lCQUNsQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IE92ZXJsYXlNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvb3ZlcmxheSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XG5pbXBvcnQgeyBNYXRDYXJkTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvY2FyZCc7XG5pbXBvcnQgeyBNYXRJY29uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvaWNvbic7XG5cbmltcG9ydCB7IEFwcEd1aWRlZFRvdXJDb21wb25lbnQgfSBmcm9tICcuL2NvbXBvbmVudHMvZ3VpZGVkLXRvdXIvZ3VpZGVkLXRvdXIuY29tcG9uZW50JztcbmltcG9ydCB7IEFwcEd1aWRlZFRvdXJEaXJlY3RpdmUgfSBmcm9tICcuL2NvbXBvbmVudHMvZ3VpZGVkLXRvdXIvZ3VpZGVkLXRvdXIuZGlyZWN0aXZlJztcbmltcG9ydCB7IG92ZXJsYXlQcm92aWRlciB9IGZyb20gJy4vcHJvdmlkZXJzL292ZXJsYXkucHJvdmlkZXInO1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCBPdmVybGF5TW9kdWxlLCBNYXRCdXR0b25Nb2R1bGUsIE1hdEljb25Nb2R1bGUsIE1hdENhcmRNb2R1bGVdLFxuICBkZWNsYXJhdGlvbnM6IFtBcHBHdWlkZWRUb3VyQ29tcG9uZW50LCBBcHBHdWlkZWRUb3VyRGlyZWN0aXZlXSxcbiAgcHJvdmlkZXJzOiBbb3ZlcmxheVByb3ZpZGVyXSxcbiAgZXhwb3J0czogW0FwcEd1aWRlZFRvdXJEaXJlY3RpdmVdLFxufSlcbmV4cG9ydCBjbGFzcyBBcHBHdWlkZWRUb3VyTW9kdWxlIHt9XG4iXX0=
@@ -0,0 +1,12 @@
1
+ import { OverlayConfig } from '@angular/cdk/overlay';
2
+ import { InjectionToken } from '@angular/core';
3
+ /** The overlay reference injection token. */
4
+ export const OVERLAY_REFERENCE = new InjectionToken('OverlayReference');
5
+ /** Overlay config provider. */
6
+ export const overlayProvider = {
7
+ provide: OverlayConfig,
8
+ useFactory: () => new OverlayConfig({
9
+ direction: 'ltr',
10
+ }),
11
+ };
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3ZlcmxheS5wcm92aWRlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY2xpZW50LWd1aWRlZC10b3VyL3NyYy9saWIvcHJvdmlkZXJzL292ZXJsYXkucHJvdmlkZXIudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGFBQWEsRUFBYyxNQUFNLHNCQUFzQixDQUFDO0FBQ2pFLE9BQU8sRUFBRSxjQUFjLEVBQVksTUFBTSxlQUFlLENBQUM7QUFFekQsNkNBQTZDO0FBQzdDLE1BQU0sQ0FBQyxNQUFNLGlCQUFpQixHQUFHLElBQUksY0FBYyxDQUFhLGtCQUFrQixDQUFDLENBQUM7QUFFcEYsK0JBQStCO0FBQy9CLE1BQU0sQ0FBQyxNQUFNLGVBQWUsR0FBYTtJQUN2QyxPQUFPLEVBQUUsYUFBYTtJQUN0QixVQUFVLEVBQUUsR0FBRyxFQUFFLENBQ2YsSUFBSSxhQUFhLENBQUM7UUFDaEIsU0FBUyxFQUFFLEtBQUs7S0FDakIsQ0FBQztDQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPdmVybGF5Q29uZmlnLCBPdmVybGF5UmVmIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xuaW1wb3J0IHsgSW5qZWN0aW9uVG9rZW4sIFByb3ZpZGVyIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbi8qKiBUaGUgb3ZlcmxheSByZWZlcmVuY2UgaW5qZWN0aW9uIHRva2VuLiAqL1xuZXhwb3J0IGNvbnN0IE9WRVJMQVlfUkVGRVJFTkNFID0gbmV3IEluamVjdGlvblRva2VuPE92ZXJsYXlSZWY+KCdPdmVybGF5UmVmZXJlbmNlJyk7XG5cbi8qKiBPdmVybGF5IGNvbmZpZyBwcm92aWRlci4gKi9cbmV4cG9ydCBjb25zdCBvdmVybGF5UHJvdmlkZXI6IFByb3ZpZGVyID0ge1xuICBwcm92aWRlOiBPdmVybGF5Q29uZmlnLFxuICB1c2VGYWN0b3J5OiAoKSA9PlxuICAgIG5ldyBPdmVybGF5Q29uZmlnKHtcbiAgICAgIGRpcmVjdGlvbjogJ2x0cicsXG4gICAgfSksXG59O1xuIl19