@energycap/components 0.43.11 → 0.44.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.
@@ -62,21 +62,20 @@ import * as i59 from "./controls/item-picker/item-picker.component";
62
62
  import * as i60 from "./controls/help-popover/help-popover.component";
63
63
  import * as i61 from "./controls/link-button/link-button.component";
64
64
  import * as i62 from "./display/tooltip/tooltip.component";
65
- import * as i63 from "./display/tour/tour.component";
66
- import * as i64 from "./controls/button/copy-table-button.directive";
67
- import * as i65 from "./display/tooltip-directive/tooltip.directive";
68
- import * as i66 from "./controls/calendar/calendar.component";
69
- import * as i67 from "./controls/calendar/calendar-item.component";
70
- import * as i68 from "./controls/date-input/date-input.component";
71
- import * as i69 from "./shared/directives/keyboard-nav-container/keyboard-nav-container.directive";
72
- import * as i70 from "./shared/display/pipes/date-display-2.pipe";
73
- import * as i71 from "@angular/common";
74
- import * as i72 from "@angular/forms";
75
- import * as i73 from "@angular/router";
76
- import * as i74 from "@ngx-translate/core";
77
- import * as i75 from "@angular/cdk/a11y";
78
- import * as i76 from "@angular/cdk/overlay";
79
- import * as i77 from "@angular/cdk/scrolling";
65
+ import * as i63 from "./controls/button/copy-table-button.directive";
66
+ import * as i64 from "./display/tooltip-directive/tooltip.directive";
67
+ import * as i65 from "./controls/calendar/calendar.component";
68
+ import * as i66 from "./controls/calendar/calendar-item.component";
69
+ import * as i67 from "./controls/date-input/date-input.component";
70
+ import * as i68 from "./shared/directives/keyboard-nav-container/keyboard-nav-container.directive";
71
+ import * as i69 from "./shared/display/pipes/date-display-2.pipe";
72
+ import * as i70 from "@angular/common";
73
+ import * as i71 from "@angular/forms";
74
+ import * as i72 from "@angular/router";
75
+ import * as i73 from "@ngx-translate/core";
76
+ import * as i74 from "@angular/cdk/a11y";
77
+ import * as i75 from "@angular/cdk/overlay";
78
+ import * as i76 from "@angular/cdk/scrolling";
80
79
  export type ComponentsModuleConfig = {
81
80
  tracker: Provider;
82
81
  };
@@ -88,6 +87,6 @@ export declare class ComponentsModule {
88
87
  */
89
88
  static forRoot(config: ComponentsModuleConfig): ModuleWithProviders<ComponentsModule>;
90
89
  static ɵfac: i0.ɵɵFactoryDeclaration<ComponentsModule, never>;
91
- static ɵmod: i0.ɵɵNgModuleDeclaration<ComponentsModule, [typeof i1.ButtonComponent, typeof i2.TabsComponent, typeof i3.TextboxComponent, typeof i4.NavItemActiveDirective, typeof i5.SpinnerComponent, typeof i6.ViewOverlayComponent, typeof i7.BannerComponent, typeof i8.ResizableTableDirective, typeof i2.TabsComponent, typeof i9.TableComponent, typeof i10.SearchableTableComponent, typeof i11.ComboboxComponent, typeof i12.MenuComponent, typeof i13.PopupContainerDirective, typeof i14.DropdownComponent, typeof i15.ConfirmComponent, typeof i16.DialogComponent, typeof i17.DateDisplayPipe, typeof i18.TimeDisplayPipe, typeof i19.MockDateDisplayPipe, typeof i20.RadioButtonComponent, typeof i21.CheckboxComponent, typeof i22.NumericboxComponent, typeof i23.AvatarComponent, typeof i24.AppBarComponent, typeof i25.SplashComponent, typeof i26.IfViewportWidthDirective, typeof i27.ClickAreaForDirective, typeof i28.CollapsibleToggleComponent, typeof i29.TableMasterRowComponent, typeof i30.TableMasterHeaderRowComponent, typeof i31.TableDetailRowComponent, typeof i32.TableLockedColumnComponent, typeof i33.TableSelectableRowComponent, typeof i34.PopoverComponent, typeof i35.TablePaginationComponent, typeof i36.RowCountPipe, typeof i37.CopyButtonDirective, typeof i35.TablePaginationComponent, typeof i38.TagsComponent, typeof i39.FormControlComponent, typeof i40.SelectComponent, typeof i41.ItemDisplayComponent, typeof i33.TableSelectableRowComponent, typeof i42.ResizableColumnComponent, typeof i43.DialogGroupComponent, typeof i44.FileUploadComponent, typeof i45.FormGroupComponent, typeof i46.JsonDisplayComponent, typeof i47.ToastComponent, typeof i48.ToasterComponent, typeof i49.PageViewComponent, typeof i50.PageTitleComponent, typeof i51.WizardProgressComponent, typeof i52.WizardButtonsComponent, typeof i53.HierarchyTreeComponent, typeof i54.TreeComponent, typeof i55.RelativeDatePipe, typeof i56.ResizableComponent, typeof i57.HighlightTextPipe, typeof i58.FormControlLabelComponent, typeof i59.ItemPickerComponent, typeof i60.HelpPopoverComponent, typeof i61.LinkButtonComponent, typeof i62.TooltipComponent, typeof i63.TourComponent, typeof i64.CopyTableButtonDirective, typeof i65.TooltipDirective, typeof i66.CalendarComponent, typeof i67.CalendarItemComponent, typeof i68.DateInputComponent, typeof i69.KeyboardNavContainerDirective, typeof i70.DateDisplayPipe2], [typeof i71.CommonModule, typeof i72.FormsModule, typeof i72.ReactiveFormsModule, typeof i73.RouterModule, typeof i74.TranslateModule, typeof i75.A11yModule, typeof i76.OverlayModule, typeof i77.ScrollingModule], [typeof i1.ButtonComponent, typeof i2.TabsComponent, typeof i3.TextboxComponent, typeof i4.NavItemActiveDirective, typeof i5.SpinnerComponent, typeof i6.ViewOverlayComponent, typeof i7.BannerComponent, typeof i2.TabsComponent, typeof i9.TableComponent, typeof i10.SearchableTableComponent, typeof i11.ComboboxComponent, typeof i12.MenuComponent, typeof i13.PopupContainerDirective, typeof i14.DropdownComponent, typeof i15.ConfirmComponent, typeof i16.DialogComponent, typeof i17.DateDisplayPipe, typeof i18.TimeDisplayPipe, typeof i20.RadioButtonComponent, typeof i21.CheckboxComponent, typeof i22.NumericboxComponent, typeof i23.AvatarComponent, typeof i24.AppBarComponent, typeof i25.SplashComponent, typeof i26.IfViewportWidthDirective, typeof i27.ClickAreaForDirective, typeof i28.CollapsibleToggleComponent, typeof i29.TableMasterRowComponent, typeof i30.TableMasterHeaderRowComponent, typeof i32.TableLockedColumnComponent, typeof i33.TableSelectableRowComponent, typeof i34.PopoverComponent, typeof i37.CopyButtonDirective, typeof i35.TablePaginationComponent, typeof i38.TagsComponent, typeof i39.FormControlComponent, typeof i40.SelectComponent, typeof i41.ItemDisplayComponent, typeof i42.ResizableColumnComponent, typeof i43.DialogGroupComponent, typeof i44.FileUploadComponent, typeof i45.FormGroupComponent, typeof i46.JsonDisplayComponent, typeof i47.ToastComponent, typeof i48.ToasterComponent, typeof i49.PageViewComponent, typeof i50.PageTitleComponent, typeof i51.WizardProgressComponent, typeof i52.WizardButtonsComponent, typeof i53.HierarchyTreeComponent, typeof i54.TreeComponent, typeof i55.RelativeDatePipe, typeof i56.ResizableComponent, typeof i57.HighlightTextPipe, typeof i58.FormControlLabelComponent, typeof i59.ItemPickerComponent, typeof i60.HelpPopoverComponent, typeof i61.LinkButtonComponent, typeof i62.TooltipComponent, typeof i63.TourComponent, typeof i64.CopyTableButtonDirective, typeof i65.TooltipDirective, typeof i66.CalendarComponent, typeof i68.DateInputComponent, typeof i69.KeyboardNavContainerDirective, typeof i70.DateDisplayPipe2]>;
90
+ static ɵmod: i0.ɵɵNgModuleDeclaration<ComponentsModule, [typeof i1.ButtonComponent, typeof i2.TabsComponent, typeof i3.TextboxComponent, typeof i4.NavItemActiveDirective, typeof i5.SpinnerComponent, typeof i6.ViewOverlayComponent, typeof i7.BannerComponent, typeof i8.ResizableTableDirective, typeof i2.TabsComponent, typeof i9.TableComponent, typeof i10.SearchableTableComponent, typeof i11.ComboboxComponent, typeof i12.MenuComponent, typeof i13.PopupContainerDirective, typeof i14.DropdownComponent, typeof i15.ConfirmComponent, typeof i16.DialogComponent, typeof i17.DateDisplayPipe, typeof i18.TimeDisplayPipe, typeof i19.MockDateDisplayPipe, typeof i20.RadioButtonComponent, typeof i21.CheckboxComponent, typeof i22.NumericboxComponent, typeof i23.AvatarComponent, typeof i24.AppBarComponent, typeof i25.SplashComponent, typeof i26.IfViewportWidthDirective, typeof i27.ClickAreaForDirective, typeof i28.CollapsibleToggleComponent, typeof i29.TableMasterRowComponent, typeof i30.TableMasterHeaderRowComponent, typeof i31.TableDetailRowComponent, typeof i32.TableLockedColumnComponent, typeof i33.TableSelectableRowComponent, typeof i34.PopoverComponent, typeof i35.TablePaginationComponent, typeof i36.RowCountPipe, typeof i37.CopyButtonDirective, typeof i35.TablePaginationComponent, typeof i38.TagsComponent, typeof i39.FormControlComponent, typeof i40.SelectComponent, typeof i41.ItemDisplayComponent, typeof i33.TableSelectableRowComponent, typeof i42.ResizableColumnComponent, typeof i43.DialogGroupComponent, typeof i44.FileUploadComponent, typeof i45.FormGroupComponent, typeof i46.JsonDisplayComponent, typeof i47.ToastComponent, typeof i48.ToasterComponent, typeof i49.PageViewComponent, typeof i50.PageTitleComponent, typeof i51.WizardProgressComponent, typeof i52.WizardButtonsComponent, typeof i53.HierarchyTreeComponent, typeof i54.TreeComponent, typeof i55.RelativeDatePipe, typeof i56.ResizableComponent, typeof i57.HighlightTextPipe, typeof i58.FormControlLabelComponent, typeof i59.ItemPickerComponent, typeof i60.HelpPopoverComponent, typeof i61.LinkButtonComponent, typeof i62.TooltipComponent, typeof i63.CopyTableButtonDirective, typeof i64.TooltipDirective, typeof i65.CalendarComponent, typeof i66.CalendarItemComponent, typeof i67.DateInputComponent, typeof i68.KeyboardNavContainerDirective, typeof i69.DateDisplayPipe2], [typeof i70.CommonModule, typeof i71.FormsModule, typeof i71.ReactiveFormsModule, typeof i72.RouterModule, typeof i73.TranslateModule, typeof i74.A11yModule, typeof i75.OverlayModule, typeof i76.ScrollingModule], [typeof i1.ButtonComponent, typeof i2.TabsComponent, typeof i3.TextboxComponent, typeof i4.NavItemActiveDirective, typeof i5.SpinnerComponent, typeof i6.ViewOverlayComponent, typeof i7.BannerComponent, typeof i2.TabsComponent, typeof i9.TableComponent, typeof i10.SearchableTableComponent, typeof i11.ComboboxComponent, typeof i12.MenuComponent, typeof i13.PopupContainerDirective, typeof i14.DropdownComponent, typeof i15.ConfirmComponent, typeof i16.DialogComponent, typeof i17.DateDisplayPipe, typeof i18.TimeDisplayPipe, typeof i20.RadioButtonComponent, typeof i21.CheckboxComponent, typeof i22.NumericboxComponent, typeof i23.AvatarComponent, typeof i24.AppBarComponent, typeof i25.SplashComponent, typeof i26.IfViewportWidthDirective, typeof i27.ClickAreaForDirective, typeof i28.CollapsibleToggleComponent, typeof i29.TableMasterRowComponent, typeof i30.TableMasterHeaderRowComponent, typeof i32.TableLockedColumnComponent, typeof i33.TableSelectableRowComponent, typeof i34.PopoverComponent, typeof i37.CopyButtonDirective, typeof i35.TablePaginationComponent, typeof i38.TagsComponent, typeof i39.FormControlComponent, typeof i40.SelectComponent, typeof i41.ItemDisplayComponent, typeof i42.ResizableColumnComponent, typeof i43.DialogGroupComponent, typeof i44.FileUploadComponent, typeof i45.FormGroupComponent, typeof i46.JsonDisplayComponent, typeof i47.ToastComponent, typeof i48.ToasterComponent, typeof i49.PageViewComponent, typeof i50.PageTitleComponent, typeof i51.WizardProgressComponent, typeof i52.WizardButtonsComponent, typeof i53.HierarchyTreeComponent, typeof i54.TreeComponent, typeof i55.RelativeDatePipe, typeof i56.ResizableComponent, typeof i57.HighlightTextPipe, typeof i58.FormControlLabelComponent, typeof i59.ItemPickerComponent, typeof i60.HelpPopoverComponent, typeof i61.LinkButtonComponent, typeof i62.TooltipComponent, typeof i63.CopyTableButtonDirective, typeof i64.TooltipDirective, typeof i65.CalendarComponent, typeof i67.DateInputComponent, typeof i68.KeyboardNavContainerDirective, typeof i69.DateDisplayPipe2]>;
92
91
  static ɵinj: i0.ɵɵInjectorDeclaration<ComponentsModule>;
93
92
  }
@@ -27,7 +27,7 @@ export interface TooltipOptions {
27
27
  */
28
28
  customContent?: TemplateRef<any>;
29
29
  /**
30
- * When true a close button appears in the top right corner to hide the tooltip. Useful when tooltips are used in a tour. An event will emitted when the tooltip is hidden.
30
+ * When true a close button appears in the top right corner to hide the tooltip. An event will emitted when the tooltip is hidden.
31
31
  */
32
32
  dismissible?: boolean;
33
33
  /**
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@energycap/components",
3
- "version": "0.43.11",
3
+ "version": "0.44.0",
4
4
  "schematics": "./schematics/collection.json",
5
5
  "dependencies": {
6
6
  "tslib": "^2.0.0"
package/public-api.d.ts CHANGED
@@ -78,9 +78,6 @@ export * from './lib/display/toast/toaster/toaster.component';
78
78
  export * from './lib/display/tooltip-directive/tooltip.directive';
79
79
  export * from './lib/display/tooltip/tooltip.component';
80
80
  export * from './lib/display/tooltip/tooltip.service';
81
- export * from './lib/display/tour/tour-types';
82
- export * from './lib/display/tour/tour.component';
83
- export * from './lib/display/tour/tour.service';
84
81
  export * from './lib/display/tree/tree.component';
85
82
  export * from './lib/display/view-overlay/view-overlay.component';
86
83
  export * from './lib/shared/directives/click-area-for/click-area-for.directive';
@@ -138,8 +138,6 @@
138
138
 
139
139
  // TODO: where is this used and what would the new value be
140
140
  --ec-color-accrual: #{$ec-color-accrual};
141
-
142
- --ec-color-tour-title: var(--ec-color-primary-light);
143
141
 
144
142
  --ec-background-color: rgb(255, 255, 255);
145
143
  --ec-background-color-overlay: rgba(255, 255, 255, .7);
@@ -148,7 +146,6 @@
148
146
  --ec-background-color-dark: rgb(26, 26, 35);
149
147
  --ec-background-color-dialog: rgba(26, 26, 35, .5);
150
148
  --ec-background-color-dialog-stacked: rgba(26, 26, 35, .25);
151
- --ec-background-color-tour: var(--ec-color-gray-8);
152
149
  --ec-background-splash: radial-gradient(104.77% 95.14% at 90.16% 85.25%, rgba(113,235,111,0.60) 0%, rgba(255, 255, 255, 0) 100%),
153
150
  radial-gradient(156.88% 63.71% at 8.4% 78.12%, rgba(219, 141, 255, 0.60) 0%, rgba(255, 255, 255, 0) 100%),
154
151
  radial-gradient(265.09% 182.17% at 24.49% 5.63%, rgba(0, 87, 255, 0.60) 0%, rgba(255, 255, 255, 0) 100%), #FFF;
@@ -1,34 +0,0 @@
1
- export class Tour {
2
- constructor() {
3
- /** Unique identifier for the tour */
4
- this.id = '';
5
- /** List of tour steps to present to the user */
6
- this.steps = [];
7
- }
8
- }
9
- export class TourStep {
10
- constructor() {
11
- /** Unique identifier for the tour step */
12
- this.id = '';
13
- /** HTML formatted text that contains the primary content of the tour step */
14
- this.text = '';
15
- }
16
- }
17
- export class TourAnchor {
18
- constructor() {
19
- /**
20
- * Selector to attach the tooltip to. If defined but does not exist in the
21
- * DOM skip this step because it is probably hidden to the user because of
22
- * permissions.
23
- */
24
- this.selector = '';
25
- }
26
- }
27
- export class TourEvent {
28
- constructor(tours, tourAction = 'start', isAutoStart = false) {
29
- this.tours = tours;
30
- this.tourAction = tourAction;
31
- this.isAutoStart = isAutoStart;
32
- }
33
- }
34
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG91ci10eXBlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NvbXBvbmVudHMvc3JjL2xpYi9kaXNwbGF5L3RvdXIvdG91ci10eXBlcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFPQSxNQUFNLE9BQU8sSUFBSTtJQUFqQjtRQUNFLHFDQUFxQztRQUNyQyxPQUFFLEdBQVcsRUFBRSxDQUFDO1FBQ2hCLGdEQUFnRDtRQUNoRCxVQUFLLEdBQWUsRUFBRSxDQUFDO0lBT3pCLENBQUM7Q0FBQTtBQVdELE1BQU0sT0FBTyxRQUFRO0lBQXJCO1FBQ0UsMENBQTBDO1FBQzFDLE9BQUUsR0FBVyxFQUFFLENBQUM7UUFRaEIsNkVBQTZFO1FBQzdFLFNBQUksR0FBVyxFQUFFLENBQUM7SUFjcEIsQ0FBQztDQUFBO0FBRUQsTUFBTSxPQUFPLFVBQVU7SUFBdkI7UUFlRTs7OztXQUlHO1FBQ0gsYUFBUSxHQUFXLEVBQUUsQ0FBQztJQUl4QixDQUFDO0NBQUE7QUFFRCxNQUFNLE9BQU8sU0FBUztJQUNwQixZQUNTLEtBQWEsRUFDYixhQUF5QyxPQUFPLEVBQ2hELGNBQXVCLEtBQUs7UUFGNUIsVUFBSyxHQUFMLEtBQUssQ0FBUTtRQUNiLGVBQVUsR0FBVixVQUFVLENBQXNDO1FBQ2hELGdCQUFXLEdBQVgsV0FBVyxDQUFpQjtJQUNqQyxDQUFDO0NBQ04iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUZW1wbGF0ZVJlZiwgVHlwZSB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IERpYWxvZ0NvbnRlbnQgfSBmcm9tIFwiLi4vZGlhbG9nL2RpYWxvZy1jb250ZW50XCI7XHJcbmltcG9ydCB7IERpYWxvZ09wdGlvbnMsIERpYWxvZ1NpemUgfSBmcm9tIFwiLi4vZGlhbG9nL2RpYWxvZy10eXBlc1wiO1xyXG5pbXBvcnQgeyBUb29sdGlwUG9zaXRpb24gfSBmcm9tIFwiLi4vdG9vbHRpcC90b29sdGlwLmNvbXBvbmVudFwiO1xyXG5cclxuZXhwb3J0IHR5cGUgVG91ckNhY2hlRW50cnkgPSB7IGNvbXBsZXRlZDogYm9vbGVhbiB9O1xyXG5cclxuZXhwb3J0IGNsYXNzIFRvdXI8VCA9IGFueT4ge1xyXG4gIC8qKiBVbmlxdWUgaWRlbnRpZmllciBmb3IgdGhlIHRvdXIgKi9cclxuICBpZDogc3RyaW5nID0gJyc7XHJcbiAgLyoqIExpc3Qgb2YgdG91ciBzdGVwcyB0byBwcmVzZW50IHRvIHRoZSB1c2VyICovXHJcbiAgc3RlcHM6IFRvdXJTdGVwW10gPSBbXTtcclxuXHJcbiAgLyoqIEZpbmFsIHN0ZXAgdG8gYmUgcHJlc2VudGVkIHRvIHRoZSB1c2VyIGlmIGRlZmluZWQgKi9cclxuICBleGl0U3RlcD86IFRvdXJTdGVwO1xyXG5cclxuICAvKiogRGlhbG9nIHRvIHByZXNlbnQgdG8gdGhlIHVzZXIgYmVmb3JlIHRoZSB0b3VyIGJlZ2lucyAqL1xyXG4gIGludHJvRGlhbG9nPzogVG91ckludHJvRGlhbG9nPFQ+XHJcbn1cclxuXHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFRvdXJJbnRyb0RpYWxvZzxUPiB7XHJcbiAgY29udGVudD86IFR5cGU8RGlhbG9nQ29udGVudDxUPj4gfCBUZW1wbGF0ZVJlZjxhbnk+O1xyXG4gIGNvbnRleHQ/OiBUO1xyXG4gIG9wdGlvbnM/OiBEaWFsb2dPcHRpb25zO1xyXG4gIHNpemU/OiBEaWFsb2dTaXplO1xyXG59XHJcblxyXG5cclxuZXhwb3J0IGNsYXNzIFRvdXJTdGVwIHtcclxuICAvKiogVW5pcXVlIGlkZW50aWZpZXIgZm9yIHRoZSB0b3VyIHN0ZXAgKi9cclxuICBpZDogc3RyaW5nID0gJyc7XHJcblxyXG4gIC8qKiBPcHRpb25hbCB0b3VyIHN0ZXAgdGl0bGUgZGlzcGxheWVkIGF0IHRvcCBvZiB0b29sdGlwICovXHJcbiAgdGl0bGU/OiBzdHJpbmc7XHJcblxyXG4gIC8qKiBPcHRpb25hbCBtZWRpYSB0byBkaXNwbGF5IGJlbG93IHRpdGxlIGFuZCBhYm92ZSB0b3VyIHRleHQuIENhbiBiZSBhIGpwZywgcG5nLCBvciBnaWYgKi9cclxuICBtZWRpYT86IHN0cmluZztcclxuXHJcbiAgLyoqIEhUTUwgZm9ybWF0dGVkIHRleHQgdGhhdCBjb250YWlucyB0aGUgcHJpbWFyeSBjb250ZW50IG9mIHRoZSB0b3VyIHN0ZXAgKi9cclxuICB0ZXh0OiBzdHJpbmcgPSAnJztcclxuXHJcbiAgLyoqIFRoZSBlbGVtZW50IHRvIGF0dGFjaCB0aGUgdG91ciBzdGVwIHRvLiBJZiB1bmRlZmluZWQsIHN0ZXAgd2lsbCBhcHBlYXIgY2VudGVyZWQgb24gc2NyZWVuICovXHJcbiAgYW5jaG9yPzogVG91ckFuY2hvcjtcclxuXHJcbiAgaGVscExpbms/OiBzdHJpbmc7XHJcblxyXG4gIC8qKiBBbGxvd3MgdGhlIHN0ZXAgdG8gaGF2ZSBhIGZpeGVkIHdpZHRoIGRlZmluZWQgZm9yIHRoZSB0b29sdGlwLiBJZiBub3QgZGVmaW5lZCB0aGUgd2lkdGggd2lsbCBiZSBkZWZhdWx0ZWQgdG8gNDAwLiBJZiB5b3Ugd291bGQgbGlrZSBcclxuICAgKiAgYXV0byB3aWR0aCBkZWZpbmUgYXMgJ2F1dG8nLlxyXG4gICAqL1xyXG4gIHdpZHRoPzogbnVtYmVyIHwgJ2F1dG8nO1xyXG5cclxuICAvKiogQWxsb3dzIHRoZSBzdGVwIHRvIGhhdmUgYSBtYXggd2lkdGggZGVmaW5lZCBmb3IgdGhlIHRvb2x0aXAgKi9cclxuICBtYXhXaWR0aD86IG51bWJlcjtcclxufVxyXG5cclxuZXhwb3J0IGNsYXNzIFRvdXJBbmNob3Ige1xyXG4gIC8qKlxyXG4gICAqIE9wdGlvbmFsIGNzcyBzZWxlY3RvciBvZiBhbiBlbGVtZW50IHRvIGNsaWNrIGluIG9yZGVyIHRvIG9wZW4gYSBtZW51IG9yIFxyXG4gICAqIG92ZXJsYXkuIFNob3VsZCBub3QgY2F1c2UgYSBuYXZpZ2F0aW9uLiBJZiBkZWZpbmVkIGJ1dCBkb2VzIG5vdCBleGlzdCBpbiBcclxuICAgKiB0aGUgRE9NLCBza2lwIHRoaXMgc3RlcCBiZWNhdXNlIGl0IGlzIHByb2JhYmx5IGhpZGRlbiB0byB0aGUgdXNlciBiZWNhdXNlIG9mIHBlcm1pc3Npb25zIFxyXG4gICAqL1xyXG4gIGNsaWNrQmVmb3JlPzogc3RyaW5nO1xyXG5cclxuICAvKiogXHJcbiAgICogQ1NTIHNlbGVjdG9yIG9mIGVsZW1lbnQgdG8gY2xpY2sgaW4gb3JkZXIgdG8gY2xvc2UgYSBtZW51IG9yIG92ZXJsYXkgXHJcbiAgICogYmVmb3JlIGNvbnRpbnVpbmcgdG8gdGhlIG5leHQgc3RlcC4gSWdub3JlZCBpZiBjbGlja0JlZm9yZSBpcyB1bmRlZmluZWQuIFxyXG4gICAqIFNob3VsZCBub3QgY2F1c2UgYSBuYXZpZ2F0aW9uIFxyXG4gICAqL1xyXG4gIGNsaWNrQWZ0ZXI/OiBzdHJpbmc7XHJcblxyXG4gIC8qKiBcclxuICAgKiBTZWxlY3RvciB0byBhdHRhY2ggdGhlIHRvb2x0aXAgdG8uIElmIGRlZmluZWQgYnV0IGRvZXMgbm90IGV4aXN0IGluIHRoZSAgXHJcbiAgICogRE9NIHNraXAgdGhpcyBzdGVwIGJlY2F1c2UgaXQgaXMgcHJvYmFibHkgaGlkZGVuIHRvIHRoZSB1c2VyIGJlY2F1c2Ugb2YgIFxyXG4gICAqIHBlcm1pc3Npb25zLlxyXG4gICAqL1xyXG4gIHNlbGVjdG9yOiBzdHJpbmcgPSAnJztcclxuXHJcbiAgLyoqIFBvc2l0aW9uIG9mIHRoZSB0b29sdGlwIHJlbGF0aXZlIHRvIHRoZSBhbmNob3IuIGh0dHBzOi8vZW5lcmd5Y2FwLWNvbXBvbmVudHMubmV0bGlmeS5hcHAvdG9vbHRpcCNwb3NpdGlvbiAqL1xyXG4gIHBvc2l0aW9uPzogVG9vbHRpcFBvc2l0aW9uXHJcbn1cclxuXHJcbmV4cG9ydCBjbGFzcyBUb3VyRXZlbnQge1xyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcHVibGljIHRvdXJzOiBUb3VyW10sXHJcbiAgICBwdWJsaWMgdG91ckFjdGlvbjogJ3N0YXJ0JyB8ICdlbmQnIHwgJ2FwcGVuZCcgPSAnc3RhcnQnLFxyXG4gICAgcHVibGljIGlzQXV0b1N0YXJ0OiBib29sZWFuID0gZmFsc2UsXHJcbiAgKSB7IH1cclxufSJdfQ==
@@ -1,398 +0,0 @@
1
- import { DOCUMENT } from '@angular/common';
2
- import { Component, Inject, ViewChild } from '@angular/core';
3
- import { Subject, lastValueFrom } from 'rxjs';
4
- import { takeUntil } from 'rxjs/operators';
5
- import * as i0 from "@angular/core";
6
- import * as i1 from "./tour.service";
7
- import * as i2 from "./../tooltip/tooltip.service";
8
- import * as i3 from "../../core/telemetry.service";
9
- import * as i4 from "../../core/cache.service";
10
- import * as i5 from "../dialog/dialog.service";
11
- import * as i6 from "@ngx-translate/core";
12
- import * as i7 from "@angular/common";
13
- import * as i8 from "../../controls/link-button/link-button.component";
14
- export class TourComponent {
15
- constructor(tourService, tooltipService, telemetryService, cacheService, dialogService, translateService, document) {
16
- this.tourService = tourService;
17
- this.tooltipService = tooltipService;
18
- this.telemetryService = telemetryService;
19
- this.cacheService = cacheService;
20
- this.dialogService = dialogService;
21
- this.translateService = translateService;
22
- this.document = document;
23
- /** Used to tell the UI that the step being shown is an exit step. This will change the
24
- * link text and the action when clicked
25
- */
26
- this.showDoneButton = false;
27
- /** Array of tours provided when the start tour event was detected */
28
- this.tours = [];
29
- // Couple indexes for the current tour/step stored for easier reference when knowing if we are at the end of the steps/tours
30
- this.currentStepIndex = -1;
31
- this.currentTourIndex = -1;
32
- /** Used to know if the restore step should be triggered when the tour is dismissed */
33
- this.isAutoStart = false;
34
- this.destroyed = new Subject();
35
- }
36
- ngOnInit() {
37
- this.tourService.events.pipe(takeUntil(this.destroyed)).subscribe(async (event) => {
38
- if (event.tourAction === 'start') {
39
- await this.setupTourComponent(event);
40
- }
41
- else if (event.tourAction === 'end') {
42
- if (this.currentTour) {
43
- this.writeCompletionKeyForAllTours();
44
- await this.endTour();
45
- }
46
- }
47
- else if (event.tourAction === 'append') {
48
- let visibleTours = event.tours;
49
- // If this was triggered via auto start then we need to remove any tours that have been completed
50
- if (event.isAutoStart) {
51
- visibleTours = this.removeCompletedTours(visibleTours);
52
- }
53
- // If there is already a current tour, then we need to append the new tours to the current tour
54
- if (this.currentTour) {
55
- this.tours = this.tours.concat(visibleTours);
56
- }
57
- else {
58
- // There is not a current tour, so treat this as a start event
59
- await this.setupTourComponent(event);
60
- }
61
- }
62
- });
63
- }
64
- ngOnDestroy() {
65
- this.destroyed.next();
66
- this.destroyed.unsubscribe();
67
- }
68
- /**
69
- * Called when a restore step has been completed
70
- */
71
- async done() {
72
- this.writeCompletionKey(this.currentTour);
73
- await this.endTour();
74
- }
75
- /**
76
- * Called when a tour begins and when the user clicks next on the current tour step. It will handle any after click actions and then
77
- * find the next step and present it to the user and transition to a restore step or new tour if needed.
78
- */
79
- async showNextStep() {
80
- // Before moving to the next step, make sure the current step does not have a click after defined. This could be hiding a menu
81
- // that was opened for the soon to be previous step.
82
- await this.waitForTimeout(this.handleClickAfter.bind(this));
83
- // Remove any previous tooltips
84
- this.removeTooltip();
85
- // Get our next step index to display to the user
86
- this.currentStepIndex = this.getNextAvailableStepIndex();
87
- if (this.currentStepIndex === -1) {
88
- // No more steps found, we either need to check for the exit step if this is the last tour
89
- // in the tours array or advance to the next tour
90
- if (this.currentTourIndex === this.tours.length - 1) {
91
- await this.handleExitStep();
92
- }
93
- else {
94
- // Write the completion key for the current tour before we move to the next
95
- this.writeCompletionKey(this.currentTour);
96
- this.currentTourIndex++;
97
- await this.showNextTour();
98
- }
99
- }
100
- else {
101
- this.currentTourStep = this.currentTour?.steps[this.currentStepIndex];
102
- // Now that we have our current step index, take care of any click before elements before showing the
103
- // tooltip. This could be opening a menu to get the tooltip element visible.
104
- await this.waitForTimeout(this.handleClickBefore.bind(this));
105
- // Click befores are done, now let's show the tooltip defined in the tour step
106
- await this.waitForTimeout(this.showStepTooltip.bind(this));
107
- }
108
- }
109
- async setupTourComponent(event) {
110
- // End any tours that may have been in progress if the user kicks off a new one
111
- if (this.currentTour) {
112
- this.writeCompletionKeyForAllTours();
113
- await this.endTour();
114
- }
115
- this.isAutoStart = event.isAutoStart;
116
- if (event.isAutoStart) {
117
- this.tours = this.removeCompletedTours(event.tours);
118
- }
119
- else {
120
- this.tours = event.tours;
121
- }
122
- if (this.tours.length) {
123
- this.showDoneButton = false;
124
- this.currentTourStep = undefined;
125
- this.currentStepIndex = -1;
126
- // Prime the index for the first tour
127
- this.currentTourIndex = 0;
128
- await this.showNextTour();
129
- }
130
- }
131
- /**
132
- * Shows a tour and emits an event that it was started
133
- * @param tour
134
- */
135
- async showNextTour() {
136
- // Track a tour started event if the consumer of the library has telemetry configured
137
- this.telemetryService.trackEvent('TourStarted', { tourId: this.currentTour.id });
138
- let continueTour = true;
139
- if (this.isAutoStart && this.currentTourIndex === 0 && this.currentTour?.introDialog) {
140
- let result = await lastValueFrom(this.dialogService.openDialog(this.currentTour.introDialog.content, this.currentTour.introDialog.size ?? 'small', this.currentTour.introDialog.context ?? undefined, this.currentTour.introDialog.options ?? undefined));
141
- if (!result.save) {
142
- continueTour = false;
143
- this.writeCompletionKeyForAllTours();
144
- // Advance to the last tour if there are multiple for its exit step
145
- this.currentTourIndex = this.tours.length - 1;
146
- await this.handleExitStep();
147
- }
148
- }
149
- if (continueTour) {
150
- this.showNextStep();
151
- }
152
- }
153
- async endTour() {
154
- // Handle any click afters for the active step shown before shutting it down
155
- await this.waitForTimeout(this.handleClickAfter.bind(this));
156
- this.currentTourStep = undefined;
157
- this.tours = [];
158
- this.removeTooltip();
159
- }
160
- /**
161
- * Displays a tooltip for the current tour step
162
- */
163
- async showStepTooltip() {
164
- // Track an event if the consumer of the library has telemetry configured
165
- this.telemetryService.trackEvent('TourStepChange', { tourId: this.currentTour.id, tourStepId: this.currentTourStep.id });
166
- const tooltipElement = this.document.querySelector(this.currentTourStep.anchor.selector);
167
- if (tooltipElement) {
168
- // Default width if none provided
169
- let stepWidth = 432;
170
- // Check the current tour step width and decide if it needs to change from the default value
171
- // based on whether the step defined it or not
172
- if (this.currentTourStep?.width !== undefined) {
173
- if (typeof this.currentTourStep.width === 'number') {
174
- stepWidth = this.currentTourStep.width;
175
- }
176
- else if (this.currentTourStep.width === 'auto') {
177
- stepWidth = undefined;
178
- }
179
- }
180
- const options = {
181
- id: `${this.currentTour?.id}_${this.currentTourStep.id}`,
182
- text: this.translateService.instant(this.currentTourStep.text),
183
- title: this.currentTourStep.title ? this.translateService.instant(this.currentTourStep.title) : undefined,
184
- customContent: this.custom,
185
- dismissible: true,
186
- maxWidth: this.currentTourStep?.maxWidth,
187
- width: stepWidth,
188
- backgroundColor: 'var(--ec-background-color-tour)',
189
- titleColor: 'var(--ec-color-tour-title)'
190
- };
191
- this.tooltip = this.tooltipService.show(tooltipElement, this.currentTourStep.anchor?.position, options);
192
- await this.waitForTimeout(this.focusOnNextOrDoneButton.bind(this));
193
- this.subscribeToTooltipOnHide();
194
- }
195
- }
196
- /**
197
- * Subscribes to the tooltips onHide event emitter and reacts if the user dismisses the tooltip
198
- */
199
- async subscribeToTooltipOnHide() {
200
- let tooltipSubscription = this.tooltip?.onHide.pipe(takeUntil(this.destroyed)).subscribe(async () => {
201
- tooltipSubscription?.unsubscribe();
202
- this.writeCompletionKeyForAllTours();
203
- // If this is dismissed during an auto start tour then handle the exit step
204
- // Check that the done button is shown as well, if the done is shown then we're in the exit step
205
- // and dismissing should just end the tour
206
- if (this.isAutoStart && !this.showDoneButton) {
207
- // Advance to the last tour if there are multiple for its exit step
208
- this.currentTourIndex = this.tours.length - 1;
209
- await this.handleExitStep();
210
- }
211
- else {
212
- await this.endTour();
213
- }
214
- });
215
- }
216
- /**
217
- * Loops through the current tour steps starting after the current step index. It will try to find a visible
218
- * selector and if so return the index.
219
- * @returns
220
- */
221
- getNextAvailableStepIndex() {
222
- let nextStepIndex = -1;
223
- // Look through the steps starting with the current index and find the next that is avaiable
224
- // for the user.
225
- for (let i = this.currentStepIndex + 1; i < this.currentTour.steps.length; i++) {
226
- if (this.currentTour?.steps[i].anchor && this.stepElementFound(this.currentTour.steps[i].anchor)) {
227
- return i;
228
- }
229
- }
230
- return nextStepIndex;
231
- }
232
- /**
233
- * Try to find the tour step element to know if it is visible for the user. Check for the clickBefore first if defined
234
- * @param anchor
235
- * @returns
236
- */
237
- stepElementFound(anchor) {
238
- if (anchor.clickBefore) {
239
- return this.document.querySelector(anchor.clickBefore) !== null;
240
- }
241
- else {
242
- return this.document.querySelector(anchor.selector) !== null;
243
- }
244
- }
245
- /**
246
- * Some tour steps may have a click after defined. If so call the click method on the html element
247
- */
248
- handleClickAfter() {
249
- let selector = this.currentTourStep?.anchor?.clickAfter;
250
- if (selector) {
251
- this.clickElementIfFound(selector);
252
- }
253
- }
254
- /**
255
- * Some tour steps may have a click before defined. If so call the click method on the html element
256
- */
257
- handleClickBefore() {
258
- if (this.currentTourStep?.anchor?.clickBefore) {
259
- this.clickElementIfFound(this.currentTourStep.anchor?.clickBefore);
260
- }
261
- }
262
- /**
263
- * Checks for an exit step on the current tour and if found displays the step
264
- */
265
- async handleExitStep() {
266
- if (this.currentTour?.exitStep) {
267
- this.removeTooltip();
268
- this.showDoneButton = true;
269
- this.currentTourStep = this.currentTour?.exitStep;
270
- await this.waitForTimeout(this.handleClickBefore.bind(this));
271
- await this.waitForTimeout(this.showStepTooltip.bind(this));
272
- }
273
- }
274
- /**
275
- * Try to find the element with the selector provided and if so click it. This is how tour steps will open/close menus to
276
- * give a tour to the user
277
- * @param selector
278
- */
279
- clickElementIfFound(selector) {
280
- if (selector !== undefined) {
281
- const element = this.document.querySelector(selector);
282
- if (element) {
283
- element.click();
284
- }
285
- }
286
- }
287
- /**
288
- * When auto starting tours we will want to remove any that have the local storage key written as completed so
289
- * they are not presented to the user again.
290
- * @param tours
291
- * @returns
292
- */
293
- removeCompletedTours(tours) {
294
- return tours.filter(tour => {
295
- let cacheValue = this.cacheService.getItem(this.makeCacheKey(tour));
296
- if (cacheValue) {
297
- return !cacheValue.completed;
298
- }
299
- else {
300
- return true;
301
- }
302
- });
303
- }
304
- /**
305
- * Writes a key to local storage so the tour will not be shown again automatically
306
- */
307
- writeCompletionKey(tour) {
308
- if (tour) {
309
- this.cacheService.setItem(this.makeCacheKey(tour), { completed: true });
310
- }
311
- }
312
- /**
313
- * When dismissing a tour or one being dismissed via a navigation event, etc we will want to mark
314
- * every tour in the array as completed so it doesn't resurface unless the user requests the tour.
315
- * This function will loop over all and write the local storage key
316
- */
317
- writeCompletionKeyForAllTours() {
318
- this.tours.forEach(tour => {
319
- this.writeCompletionKey(tour);
320
- });
321
- }
322
- /**
323
- * Cache key used to set/get the completion status of a tour
324
- * @param tour
325
- * @returns
326
- */
327
- makeCacheKey(tour) {
328
- return this.tourService.getCacheKey(tour);
329
- }
330
- /**
331
- * Removes a tooltip from the view, used when switching tour steps and closing a tour
332
- */
333
- removeTooltip() {
334
- this.tooltip?.overlayRef?.dispose();
335
- }
336
- /**
337
- * Returns the tour based on the current index
338
- */
339
- get currentTour() {
340
- if (this.currentTourIndex > -1 && this.currentTourIndex < this.tours.length) {
341
- return this.tours[this.currentTourIndex];
342
- }
343
- else {
344
- return undefined;
345
- }
346
- }
347
- /**
348
- * The click before/after and show tooltip functions need to be wrapped in setTimeout for the UI
349
- * to operate correctly but setTimeout is an action we cannot await so we're wrapping it in a promise to return
350
- * so the function calls can await the action
351
- * @param fn
352
- * @returns
353
- */
354
- waitForTimeout(fn) {
355
- return new Promise(resolve => {
356
- setTimeout(() => {
357
- fn();
358
- resolve();
359
- });
360
- });
361
- }
362
- /**
363
- * Find the "next" or "done" button and focus on it.
364
- *
365
- * They are mutually exclusive, so if we cannot find the next button
366
- * we look for the done button.
367
- */
368
- focusOnNextOrDoneButton() {
369
- if (!this.focusOnElement(`#${this.currentTourStep.id}_nextButton`)) {
370
- this.focusOnElement(`#${this.currentTourStep.id}_doneButton`);
371
- }
372
- }
373
- /**
374
- * Find an element with given selector and focus on it.
375
- * Return false if element not found.
376
- */
377
- focusOnElement(selector) {
378
- const element = this.document.querySelector(selector);
379
- if (element) {
380
- element.focus();
381
- return true;
382
- }
383
- return false;
384
- }
385
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TourComponent, deps: [{ token: i1.TourService }, { token: i2.TooltipService }, { token: i3.TelemetryService }, { token: i4.CacheService }, { token: i5.DialogService }, { token: i6.TranslateService }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Component }); }
386
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: TourComponent, selector: "ec-tour", viewQueries: [{ propertyName: "custom", first: true, predicate: ["tourTooltip"], descendants: true }], ngImport: i0, template: "<ng-template #tourTooltip>\r\n <div *ngIf=\"currentTourStep?.media\"\r\n class=\"mb-3\">\r\n <img id=\"{{currentTourStep?.id + '_media'}}\"\r\n style=\"max-width: 100%;\"\r\n src=\"{{currentTourStep?.media}}\">\r\n </div>\r\n <div class=\"font-color-primary-light px-3 mb-3\"\r\n [innerHtml]=\"currentTourStep?.text | translate\">\r\n </div>\r\n <a *ngIf=\"currentTourStep?.helpLink\" id=\"{{currentTourStep?.id + '_helpLink'}}\" class=\"d-block mb-3 px-3\" target=\"_blank\" href=\"{{currentTourStep?.helpLink}}\" translate>LearnMore_SC</a>\r\n <footer class=\"px-3 mt-3 d-flex\">\r\n <button id=\"{{currentTourStep?.id + '_nextButton'}}\" *ngIf=\"!showDoneButton\" class=\"ml-auto tourAction\" ecLinkButton (click)=\"showNextStep()\" translate>Next_TC</button>\r\n <button id=\"{{currentTourStep?.id + '_doneButton'}}\" *ngIf=\"showDoneButton\" class=\"ml-auto tourAction\" ecLinkButton (click)=\"done()\" translate>Done_TC</button>\r\n </footer>\r\n</ng-template>", styles: [".tourAction{color:var(--ec-tour-action-color, var(--ec-color-brand-green))!important}\n"], dependencies: [{ kind: "directive", type: i7.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i6.TranslateDirective, selector: "[translate],[ngx-translate]", inputs: ["translate", "translateParams"] }, { kind: "component", type: i8.LinkButtonComponent, selector: "button[ecLinkButton]" }, { kind: "pipe", type: i6.TranslatePipe, name: "translate" }] }); }
387
- }
388
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: TourComponent, decorators: [{
389
- type: Component,
390
- args: [{ selector: 'ec-tour', template: "<ng-template #tourTooltip>\r\n <div *ngIf=\"currentTourStep?.media\"\r\n class=\"mb-3\">\r\n <img id=\"{{currentTourStep?.id + '_media'}}\"\r\n style=\"max-width: 100%;\"\r\n src=\"{{currentTourStep?.media}}\">\r\n </div>\r\n <div class=\"font-color-primary-light px-3 mb-3\"\r\n [innerHtml]=\"currentTourStep?.text | translate\">\r\n </div>\r\n <a *ngIf=\"currentTourStep?.helpLink\" id=\"{{currentTourStep?.id + '_helpLink'}}\" class=\"d-block mb-3 px-3\" target=\"_blank\" href=\"{{currentTourStep?.helpLink}}\" translate>LearnMore_SC</a>\r\n <footer class=\"px-3 mt-3 d-flex\">\r\n <button id=\"{{currentTourStep?.id + '_nextButton'}}\" *ngIf=\"!showDoneButton\" class=\"ml-auto tourAction\" ecLinkButton (click)=\"showNextStep()\" translate>Next_TC</button>\r\n <button id=\"{{currentTourStep?.id + '_doneButton'}}\" *ngIf=\"showDoneButton\" class=\"ml-auto tourAction\" ecLinkButton (click)=\"done()\" translate>Done_TC</button>\r\n </footer>\r\n</ng-template>", styles: [".tourAction{color:var(--ec-tour-action-color, var(--ec-color-brand-green))!important}\n"] }]
391
- }], ctorParameters: () => [{ type: i1.TourService }, { type: i2.TooltipService }, { type: i3.TelemetryService }, { type: i4.CacheService }, { type: i5.DialogService }, { type: i6.TranslateService }, { type: Document, decorators: [{
392
- type: Inject,
393
- args: [DOCUMENT]
394
- }] }], propDecorators: { custom: [{
395
- type: ViewChild,
396
- args: ['tourTooltip']
397
- }] } });
398
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tour.component.js","sourceRoot":"","sources":["../../../../../../projects/components/src/lib/display/tour/tour.component.ts","../../../../../../projects/components/src/lib/display/tour/tour.component.html"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\r\nimport { Component, Inject, OnInit, TemplateRef, ViewChild } from '@angular/core';\r\nimport { TranslateService } from '@ngx-translate/core';\r\nimport { Subject, lastValueFrom } from 'rxjs';\r\nimport { takeUntil } from 'rxjs/operators';\r\n\r\nimport { CacheService } from '../../core/cache.service';\r\nimport { TelemetryService } from '../../core/telemetry.service';\r\nimport { DialogService } from '../dialog/dialog.service';\r\nimport { TooltipComponent, TooltipOptions } from './../tooltip/tooltip.component';\r\nimport { TooltipService } from './../tooltip/tooltip.service';\r\nimport { Tour, TourAnchor, TourCacheEntry, TourEvent, TourStep } from './tour-types';\r\nimport { TourService } from './tour.service';\r\n\r\n@Component({\r\n  selector: 'ec-tour',\r\n  templateUrl: './tour.component.html',\r\n  styleUrls: ['./tour.component.scss']\r\n})\r\nexport class TourComponent implements OnInit {\r\n  /** Current tour step being shown to the user. The custom content in the template is bound to properties on this and therefor needs to be\r\n  *  its own property. The exitStep is a tour step and this will hold that step at the end of the tour.\r\n  */\r\n  public currentTourStep?: TourStep;\r\n\r\n  /** Used to tell the UI that the step being shown is an exit step. This will change the\r\n   *  link text and the action when clicked\r\n   */\r\n  public showDoneButton: boolean = false;\r\n\r\n  /** Reference to the tooltip used for the tour steps */\r\n  public tooltip?: TooltipComponent;\r\n\r\n  /** Array of tours provided when the start tour event was detected */\r\n  private tours: Tour[] = [];\r\n\r\n  // Couple indexes for the current tour/step stored for easier reference when knowing if we are at the end of the steps/tours\r\n  private currentStepIndex: number = -1;\r\n  private currentTourIndex: number = -1;\r\n\r\n  /** Used to know if the restore step should be triggered when the tour is dismissed */\r\n  private isAutoStart: boolean = false;\r\n\r\n  private destroyed = new Subject<void>();\r\n\r\n  @ViewChild('tourTooltip') public custom!: TemplateRef<any>;\r\n\r\n  constructor(\r\n    private tourService: TourService,\r\n    private tooltipService: TooltipService,\r\n    private telemetryService: TelemetryService,\r\n    private cacheService: CacheService,\r\n    private dialogService: DialogService,\r\n    private translateService: TranslateService,\r\n    @Inject(DOCUMENT) private document: Document,\r\n  ) { }\r\n\r\n  ngOnInit(): void {\r\n    this.tourService.events.pipe(\r\n      takeUntil(this.destroyed)\r\n    ).subscribe(async event => {\r\n      if (event.tourAction === 'start') {\r\n        await this.setupTourComponent(event);\r\n      } else if (event.tourAction === 'end') {\r\n        if (this.currentTour) {\r\n          this.writeCompletionKeyForAllTours();\r\n          await this.endTour();\r\n        }\r\n      } else if (event.tourAction === 'append') {\r\n        let visibleTours: Tour[] = event.tours;\r\n        \r\n        // If this was triggered via auto start then we need to remove any tours that have been completed\r\n        if (event.isAutoStart) {\r\n          visibleTours = this.removeCompletedTours(visibleTours);\r\n        }\r\n\r\n        // If there is already a current tour, then we need to append the new tours to the current tour\r\n        if (this.currentTour) {\r\n          this.tours = this.tours.concat(visibleTours);\r\n        } else {\r\n          // There is not a current tour, so treat this as a start event\r\n          await this.setupTourComponent(event);\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.destroyed.next();\r\n    this.destroyed.unsubscribe();\r\n  }\r\n\r\n  /**\r\n   * Called when a restore step has been completed\r\n   */\r\n  public async done(): Promise<void> {\r\n    this.writeCompletionKey(this.currentTour);\r\n    await this.endTour();\r\n  }\r\n\r\n  /**\r\n   * Called when a tour begins and when the user clicks next on the current tour step. It will handle any after click actions and then\r\n   * find the next step and present it to the user and transition to a restore step or new tour if needed.\r\n   */\r\n  public async showNextStep(): Promise<void> {\r\n    // Before moving to the next step, make sure the current step does not have a click after defined. This could be hiding a menu\r\n    // that was opened for the soon to be previous step.\r\n    await this.waitForTimeout(this.handleClickAfter.bind(this));\r\n\r\n    // Remove any previous tooltips\r\n    this.removeTooltip();\r\n\r\n    // Get our next step index to display to the user\r\n    this.currentStepIndex = this.getNextAvailableStepIndex();\r\n\r\n    if (this.currentStepIndex === -1) {\r\n      // No more steps found, we either need to check for the exit step if this is the last tour\r\n      // in the tours array or advance to the next tour\r\n      if (this.currentTourIndex === this.tours.length - 1) {\r\n        await this.handleExitStep();\r\n      } else {\r\n        // Write the completion key for the current tour before we move to the next\r\n        this.writeCompletionKey(this.currentTour);\r\n\r\n        this.currentTourIndex++;\r\n        await this.showNextTour();\r\n      }\r\n    } else {\r\n      this.currentTourStep = this.currentTour?.steps[this.currentStepIndex];\r\n\r\n      // Now that we have our current step index, take care of any click before elements before showing the\r\n      // tooltip. This could be opening a menu to get the tooltip element visible.\r\n      await this.waitForTimeout(this.handleClickBefore.bind(this));\r\n\r\n      // Click befores are done, now let's show the tooltip defined in the tour step\r\n      await this.waitForTimeout(this.showStepTooltip.bind(this));\r\n    }\r\n  }\r\n\r\n  private async setupTourComponent(event: TourEvent): Promise<void> {\r\n    // End any tours that may have been in progress if the user kicks off a new one\r\n    if (this.currentTour) {\r\n      this.writeCompletionKeyForAllTours();\r\n      await this.endTour();\r\n    }\r\n\r\n    this.isAutoStart = event.isAutoStart;\r\n\r\n    if (event.isAutoStart) {\r\n      this.tours = this.removeCompletedTours(event.tours);\r\n    } else {\r\n      this.tours = event.tours;\r\n    }\r\n\r\n    if (this.tours.length) {\r\n      this.showDoneButton = false;\r\n\r\n      this.currentTourStep = undefined;\r\n      this.currentStepIndex = -1;\r\n\r\n      // Prime the index for the first tour\r\n      this.currentTourIndex = 0;\r\n\r\n      await this.showNextTour();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Shows a tour and emits an event that it was started\r\n   * @param tour\r\n   */\r\n  private async showNextTour(): Promise<void> {\r\n    // Track a tour started event if the consumer of the library has telemetry configured\r\n    this.telemetryService.trackEvent('TourStarted', { tourId: this.currentTour!.id });\r\n\r\n    let continueTour: boolean = true;\r\n\r\n    if (this.isAutoStart && this.currentTourIndex === 0 && this.currentTour?.introDialog) {\r\n      let result = await lastValueFrom(this.dialogService.openDialog(this.currentTour.introDialog.content!, this.currentTour.introDialog.size ?? 'small', this.currentTour.introDialog.context ?? undefined, this.currentTour.introDialog.options ?? undefined));\r\n      if (!result.save) {\r\n        continueTour = false;\r\n\r\n        this.writeCompletionKeyForAllTours();\r\n        // Advance to the last tour if there are multiple for its exit step\r\n        this.currentTourIndex = this.tours.length - 1;\r\n        await this.handleExitStep();\r\n      }\r\n    }\r\n\r\n    if (continueTour) {\r\n      this.showNextStep();\r\n    }\r\n  }\r\n\r\n  private async endTour(): Promise<void> {\r\n    // Handle any click afters for the active step shown before shutting it down\r\n    await this.waitForTimeout(this.handleClickAfter.bind(this));\r\n\r\n    this.currentTourStep = undefined;\r\n    this.tours = [];\r\n\r\n    this.removeTooltip();\r\n  }\r\n\r\n  /**\r\n   * Displays a tooltip for the current tour step\r\n   */\r\n  private async showStepTooltip() {\r\n    // Track an event if the consumer of the library has telemetry configured\r\n    this.telemetryService.trackEvent('TourStepChange', { tourId: this.currentTour!.id, tourStepId: this.currentTourStep!.id });\r\n\r\n    const tooltipElement = this.document.querySelector(this.currentTourStep!.anchor!.selector);\r\n\r\n    if (tooltipElement) {\r\n      // Default width if none provided\r\n      let stepWidth: number | undefined = 432;\r\n\r\n      // Check the current tour step width and decide if it needs to change from the default value\r\n      // based on whether the step defined it or not\r\n      if (this.currentTourStep?.width !== undefined) {\r\n        if (typeof this.currentTourStep.width === 'number') {\r\n          stepWidth = this.currentTourStep.width;\r\n        } else if (this.currentTourStep.width === 'auto') {\r\n          stepWidth = undefined;\r\n        }\r\n      }\r\n\r\n      const options: TooltipOptions = {\r\n        id: `${this.currentTour?.id}_${this.currentTourStep!.id}`,\r\n        text: this.translateService.instant(this.currentTourStep!.text),\r\n        title: this.currentTourStep!.title ? this.translateService.instant(this.currentTourStep!.title) : undefined,\r\n        customContent: this.custom,\r\n        dismissible: true,\r\n        maxWidth: this.currentTourStep?.maxWidth,\r\n        width: stepWidth,\r\n        backgroundColor: 'var(--ec-background-color-tour)',\r\n        titleColor: 'var(--ec-color-tour-title)'\r\n      };\r\n\r\n      this.tooltip = this.tooltipService.show(tooltipElement as HTMLElement, this.currentTourStep!.anchor?.position, options);\r\n      await this.waitForTimeout(this.focusOnNextOrDoneButton.bind(this));\r\n      this.subscribeToTooltipOnHide();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Subscribes to the tooltips onHide event emitter and reacts if the user dismisses the tooltip\r\n   */\r\n  private async subscribeToTooltipOnHide(): Promise<void> {\r\n    let tooltipSubscription = this.tooltip?.onHide.pipe(\r\n      takeUntil(this.destroyed)\r\n    ).subscribe(async () => {\r\n      tooltipSubscription?.unsubscribe();\r\n\r\n      this.writeCompletionKeyForAllTours();\r\n      // If this is dismissed during an auto start tour then handle the exit step\r\n      // Check that the done button is shown as well, if the done is shown then we're in the exit step\r\n      // and dismissing should just end the tour\r\n      if (this.isAutoStart && !this.showDoneButton) {\r\n        // Advance to the last tour if there are multiple for its exit step\r\n        this.currentTourIndex = this.tours.length - 1;\r\n\r\n        await this.handleExitStep();\r\n      } else {\r\n        await this.endTour();\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Loops through the current tour steps starting after the current step index. It will try to find a visible\r\n   * selector and if so return the index.\r\n   * @returns\r\n   */\r\n  private getNextAvailableStepIndex(): number {\r\n    let nextStepIndex: number = -1;\r\n\r\n    // Look through the steps starting with the current index and find the next that is avaiable\r\n    // for the user.\r\n    for (let i: number = this.currentStepIndex + 1; i < this.currentTour!.steps.length; i++) {\r\n      if (this.currentTour?.steps[i].anchor && this.stepElementFound(this.currentTour!.steps[i].anchor!)) {\r\n        return i;\r\n      }\r\n    }\r\n\r\n    return nextStepIndex;\r\n  }\r\n\r\n  /**\r\n   * Try to find the tour step element to know if it is visible for the user. Check for the clickBefore first if defined\r\n   * @param anchor\r\n   * @returns\r\n   */\r\n  private stepElementFound(anchor: TourAnchor): boolean {\r\n    if (anchor.clickBefore) {\r\n      return this.document.querySelector(anchor.clickBefore) !== null;\r\n    } else {\r\n      return this.document.querySelector(anchor.selector) !== null;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Some tour steps may have a click after defined. If so call the click method on the html element\r\n   */\r\n  private handleClickAfter(): void {\r\n    let selector = this.currentTourStep?.anchor?.clickAfter;\r\n    if (selector) {\r\n      this.clickElementIfFound(selector);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Some tour steps may have a click before defined. If so call the click method on the html element\r\n   */\r\n  private handleClickBefore(): void {\r\n    if (this.currentTourStep?.anchor?.clickBefore) {\r\n      this.clickElementIfFound(this.currentTourStep.anchor?.clickBefore);\r\n    }\r\n  }\r\n\r\n  /**\r\n  * Checks for an exit step on the current tour and if found displays the step\r\n  */\r\n  private async handleExitStep(): Promise<void> {\r\n    if (this.currentTour?.exitStep) {\r\n      this.removeTooltip();\r\n\r\n      this.showDoneButton = true;\r\n      this.currentTourStep = this.currentTour?.exitStep;\r\n\r\n      await this.waitForTimeout(this.handleClickBefore.bind(this));\r\n      await this.waitForTimeout(this.showStepTooltip.bind(this));\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Try to find the element with the selector provided and if so click it. This is how tour steps will open/close menus to\r\n   * give a tour to the user\r\n   * @param selector\r\n   */\r\n  private clickElementIfFound(selector: string | undefined): void {\r\n    if (selector !== undefined) {\r\n      const element = this.document.querySelector(selector);\r\n      if (element) {\r\n        (element as HTMLElement).click();\r\n      }\r\n    }\r\n  }\r\n\r\n  /**\r\n   * When auto starting tours we will want to remove any that have the local storage key written as completed so\r\n   * they are not presented to the user again.\r\n   * @param tours\r\n   * @returns\r\n   */\r\n  private removeCompletedTours(tours: Tour[]): Tour[] {\r\n    return tours.filter(tour => {\r\n      let cacheValue = this.cacheService.getItem<TourCacheEntry>(this.makeCacheKey(tour));\r\n      if (cacheValue) {\r\n        return !cacheValue.completed;\r\n      } else {\r\n        return true;\r\n      }\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Writes a key to local storage so the tour will not be shown again automatically\r\n   */\r\n  private writeCompletionKey(tour: Tour | undefined): void {\r\n    if (tour) {\r\n      this.cacheService.setItem(this.makeCacheKey(tour), <TourCacheEntry>{ completed: true });\r\n    }\r\n  }\r\n\r\n  /**\r\n   * When dismissing a tour or one being dismissed via a navigation event, etc we will want to mark\r\n   * every tour in the array as completed so it doesn't resurface unless the user requests the tour.\r\n   * This function will loop over all and write the local storage key\r\n   */\r\n  private writeCompletionKeyForAllTours(): void {\r\n    this.tours.forEach(tour => {\r\n      this.writeCompletionKey(tour);\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Cache key used to set/get the completion status of a tour\r\n   * @param tour\r\n   * @returns\r\n   */\r\n  private makeCacheKey(tour: Tour): string {\r\n    return this.tourService.getCacheKey(tour);\r\n  }\r\n\r\n  /**\r\n   * Removes a tooltip from the view, used when switching tour steps and closing a tour\r\n   */\r\n  private removeTooltip(): void {\r\n    this.tooltip?.overlayRef?.dispose();\r\n  }\r\n\r\n  /**\r\n   * Returns the tour based on the current index\r\n   */\r\n  private get currentTour(): Tour | undefined {\r\n    if (this.currentTourIndex > -1 && this.currentTourIndex < this.tours.length) {\r\n      return this.tours[this.currentTourIndex];\r\n    } else {\r\n      return undefined;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * The click before/after and show tooltip functions need to be wrapped in setTimeout for the UI\r\n   * to operate correctly but setTimeout is an action we cannot await so we're wrapping it in a promise to return\r\n   * so the function calls can await the action\r\n   * @param fn\r\n   * @returns\r\n   */\r\n  private waitForTimeout(fn: () => void) {\r\n    return new Promise<void>(resolve => {\r\n      setTimeout(() => {\r\n        fn();\r\n        resolve();\r\n      });\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Find the \"next\" or \"done\" button and focus on it.\r\n   *\r\n   * They are mutually exclusive, so if we cannot find the next button\r\n   * we look for the done button.\r\n   */\r\n  private focusOnNextOrDoneButton(): void {\r\n    if (!this.focusOnElement(`#${this.currentTourStep!.id}_nextButton`)) {\r\n      this.focusOnElement(`#${this.currentTourStep!.id}_doneButton`)\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Find an element with given selector and focus on it.\r\n   * Return false if element not found.\r\n   */\r\n  private focusOnElement(selector: string): boolean {\r\n    const element = this.document.querySelector(selector);\r\n    if (element) {\r\n      (element as HTMLElement).focus();\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n}\r\n","<ng-template #tourTooltip>\r\n    <div *ngIf=\"currentTourStep?.media\"\r\n         class=\"mb-3\">\r\n        <img id=\"{{currentTourStep?.id + '_media'}}\"\r\n             style=\"max-width: 100%;\"\r\n             src=\"{{currentTourStep?.media}}\">\r\n    </div>\r\n    <div class=\"font-color-primary-light px-3 mb-3\"\r\n         [innerHtml]=\"currentTourStep?.text | translate\">\r\n    </div>\r\n    <a *ngIf=\"currentTourStep?.helpLink\" id=\"{{currentTourStep?.id + '_helpLink'}}\" class=\"d-block mb-3 px-3\" target=\"_blank\" href=\"{{currentTourStep?.helpLink}}\" translate>LearnMore_SC</a>\r\n    <footer class=\"px-3 mt-3 d-flex\">\r\n        <button id=\"{{currentTourStep?.id + '_nextButton'}}\" *ngIf=\"!showDoneButton\" class=\"ml-auto tourAction\" ecLinkButton (click)=\"showNextStep()\" translate>Next_TC</button>\r\n        <button id=\"{{currentTourStep?.id + '_doneButton'}}\" *ngIf=\"showDoneButton\" class=\"ml-auto tourAction\" ecLinkButton (click)=\"done()\" translate>Done_TC</button>\r\n    </footer>\r\n</ng-template>"]}