@tilde-nlp/ngx-common 6.1.83 → 6.1.84

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.
@@ -33,9 +33,8 @@ export class NewFeatureDialogWrapperComponent {
33
33
  if (!targetElement) {
34
34
  return;
35
35
  }
36
- if (ResolutionHelper.isMobileRes() && this.featureContainerClassName) {
37
- const containerElement = document.querySelector(`.${this.featureContainerClassName}`);
38
- containerElement.scrollIntoView({ behavior: 'smooth', block: 'start' });
36
+ if (ResolutionHelper.isMobileRes()) {
37
+ targetElement.scrollIntoView({ behavior: 'smooth', block: 'center' });
39
38
  }
40
39
  setTimeout(() => {
41
40
  this.featureActive.set(true);
@@ -48,10 +47,11 @@ export class NewFeatureDialogWrapperComponent {
48
47
  featureLocalStorageKey: this.featureLocalStorageKey,
49
48
  },
50
49
  position: {
51
- left: `${updatedRects.left - this.maxWidth}px`,
52
- top: `${updatedRects.top + 45}px`,
50
+ left: `${ResolutionHelper.isMobileRes() ? '10' : updatedRects.left - this.maxWidth}px`,
51
+ top: `${ResolutionHelper.isMobileRes() ? '70%' : updatedRects.top + 45 + 'px'}`,
53
52
  },
54
- maxWidth: `${this.maxWidth}px`,
53
+ maxWidth: `${ResolutionHelper.isMobileRes() ? 'calc(100%) - 15px' : this.maxWidth + 'px'}`,
54
+ panelClass: 'new-feature-dialog'
55
55
  });
56
56
  this.dialogRef.afterClosed().subscribe(() => {
57
57
  this.setFeatureSeen();
@@ -59,7 +59,7 @@ export class NewFeatureDialogWrapperComponent {
59
59
  this.#featureService.showNextFeature();
60
60
  });
61
61
  // Wait until the element is visible in the viewport.
62
- }, ResolutionHelper.isMobileRes() && this.featureContainerClassName ? 500 : 0);
62
+ }, ResolutionHelper.isMobileRes() ? 500 : 0);
63
63
  }
64
64
  setFeatureStatus() {
65
65
  this.isFeatureSeen = !!this.featureLocalStorageKey && !!localStorage.getItem(this.featureLocalStorageKey);
@@ -75,7 +75,7 @@ export class NewFeatureDialogWrapperComponent {
75
75
  }
76
76
  }
77
77
  static { this.ɵfac = function NewFeatureDialogWrapperComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || NewFeatureDialogWrapperComponent)(); }; }
78
- static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: NewFeatureDialogWrapperComponent, selectors: [["lib-new-feature-dialog-wrapper"]], inputs: { titleLocalizationKey: "titleLocalizationKey", descriptionLocalizationKey: "descriptionLocalizationKey", closeLocalizationKey: "closeLocalizationKey", featureClassName: "featureClassName", featureContainerClassName: "featureContainerClassName", featureLocalStorageKey: "featureLocalStorageKey", timeout: "timeout", maxWidth: "maxWidth" }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 0, vars: 0, template: function NewFeatureDialogWrapperComponent_Template(rf, ctx) { }, dependencies: [CommonModule, MatDialogModule], encapsulation: 2 }); }
78
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: NewFeatureDialogWrapperComponent, selectors: [["lib-new-feature-dialog-wrapper"]], inputs: { titleLocalizationKey: "titleLocalizationKey", descriptionLocalizationKey: "descriptionLocalizationKey", closeLocalizationKey: "closeLocalizationKey", featureClassName: "featureClassName", featureLocalStorageKey: "featureLocalStorageKey", timeout: "timeout", maxWidth: "maxWidth" }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 0, vars: 0, template: function NewFeatureDialogWrapperComponent_Template(rf, ctx) { }, dependencies: [CommonModule, MatDialogModule], encapsulation: 2 }); }
79
79
  }
80
80
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(NewFeatureDialogWrapperComponent, [{
81
81
  type: Component,
@@ -93,8 +93,6 @@ export class NewFeatureDialogWrapperComponent {
93
93
  type: Input
94
94
  }], featureClassName: [{
95
95
  type: Input
96
- }], featureContainerClassName: [{
97
- type: Input
98
96
  }], featureLocalStorageKey: [{
99
97
  type: Input
100
98
  }], timeout: [{
@@ -103,4 +101,4 @@ export class NewFeatureDialogWrapperComponent {
103
101
  type: Input
104
102
  }] }); })();
105
103
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(NewFeatureDialogWrapperComponent, { className: "NewFeatureDialogWrapperComponent", filePath: "lib\\new-feature-dialog\\new-feature-dialog-wrapper\\new-feature-dialog-wrapper.component.ts", lineNumber: 15 }); })();
106
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"new-feature-dialog-wrapper.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-common/src/lib/new-feature-dialog/new-feature-dialog-wrapper/new-feature-dialog-wrapper.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject, Input, OnDestroy, OnInit, signal } from '@angular/core';\r\nimport { MatDialog, MatDialogModule, MatDialogRef } from '@angular/material/dialog';\r\nimport { CommonModule } from '@angular/common';\r\nimport { NewFeatureDialogComponent } from '../new-feature-dialog.component';\r\nimport { ResolutionHelper } from '../../helpers';\r\nimport { NewFeatureDialogService } from './new-feature-dialog.service';\r\nimport { Subject } from 'rxjs';\r\n\r\n@Component({\r\n\tselector: 'lib-new-feature-dialog-wrapper',\r\n\tstandalone: true,\r\n\timports: [CommonModule, MatDialogModule, NewFeatureDialogComponent],\r\n\ttemplate: '',\r\n})\r\nexport class NewFeatureDialogWrapperComponent implements OnInit, OnDestroy {\r\n\t@Input() titleLocalizationKey!: string;\r\n\t@Input() descriptionLocalizationKey!: string;\r\n\t@Input() closeLocalizationKey!: string;\r\n\t@Input() featureClassName!: string;\r\n\t@Input() featureContainerClassName!: string;\r\n\t@Input() featureLocalStorageKey!: string;\r\n\t@Input() timeout = 0;\r\n\t@Input() maxWidth = 320;\r\n\r\n\treadonly #dialog = inject(MatDialog);\r\n\treadonly #featureService = inject(NewFeatureDialogService);\r\n\treadonly #destroy = new Subject();\r\n\r\n\tdialogRef: MatDialogRef<NewFeatureDialogComponent> | undefined;\r\n\tfeatureActive = signal(false);\r\n\tisFeatureSeen = false;\r\n\r\n\tngOnInit(): void {\r\n\t\tsetTimeout(() => {\r\n\t\t\tthis.setFeatureStatus();\r\n\t\t}, this.timeout);\r\n\t}\r\n\r\n\tngOnDestroy(): void {\r\n\t\tthis.#destroy.next(null);\r\n\t\tthis.#destroy.complete();\r\n\t}\r\n\r\n\tshowFeatureDialog(): void {\r\n\t\tconst targetElement = document.querySelector(`.${this.featureClassName}`);\r\n\t\tif (!targetElement) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tif (ResolutionHelper.isMobileRes() && this.featureContainerClassName) {\r\n\t\t\tconst containerElement = document.querySelector(`.${this.featureContainerClassName}`);\r\n\t\t\tcontainerElement!.scrollIntoView({ behavior: 'smooth', block: 'start'});\r\n\t\t}\r\n\r\n\t\tsetTimeout(() => {\r\n\t\t\tthis.featureActive.set(true);\r\n\t\t\tconst updatedRects = targetElement.getBoundingClientRect();\r\n\t\t\tthis.dialogRef = this.#dialog.open(NewFeatureDialogComponent, {\r\n\t\t\t\tdata: {\r\n\t\t\t\t\ttitle: this.titleLocalizationKey,\r\n\t\t\t\t\tdescription: this.descriptionLocalizationKey,\r\n\t\t\t\t\tclose: this.closeLocalizationKey,\r\n\t\t\t\t\tfeatureLocalStorageKey: this.featureLocalStorageKey,\r\n\t\t\t\t},\r\n\t\t\t\tposition: {\r\n\t\t\t\t\tleft: `${updatedRects.left - this.maxWidth}px`,\r\n\t\t\t\t\ttop: `${updatedRects.top + 45}px`,\r\n\t\t\t\t},\r\n\t\t\t\tmaxWidth: `${this.maxWidth}px`,\r\n\t\t\t});\r\n\r\n\t\t\tthis.dialogRef.afterClosed().subscribe(() => {\r\n\t\t\t\tthis.setFeatureSeen();\r\n\t\t\t\tthis.#featureService.current.set(undefined);\r\n\t\t\t\tthis.#featureService.showNextFeature();\r\n\t\t\t});\r\n\t\t\t// Wait until the element is visible in the viewport.\r\n\t\t}, ResolutionHelper.isMobileRes() && this.featureContainerClassName ? 500 : 0);\r\n\t}\r\n\r\n\tprivate setFeatureStatus(): void {\r\n\t\tthis.isFeatureSeen = !!this.featureLocalStorageKey && !!localStorage.getItem(this.featureLocalStorageKey);\r\n\r\n\t\tif (!this.isFeatureSeen) {\r\n\t\t\tthis.#featureService.requestOpenFeature(this);\r\n\t\t}\r\n\t}\r\n\r\n\tprivate setFeatureSeen(): void {\r\n\t\tthis.featureActive.set(false);\r\n\t\tthis.isFeatureSeen = true;\r\n\t\tif (this.featureLocalStorageKey) {\r\n\t\t\tlocalStorage.setItem(this.featureLocalStorageKey, 'true');\r\n\t\t}\r\n\t}\r\n}\r\n"]}
104
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"new-feature-dialog-wrapper.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-common/src/lib/new-feature-dialog/new-feature-dialog-wrapper/new-feature-dialog-wrapper.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, inject, Input, OnDestroy, OnInit, signal } from '@angular/core';\r\nimport { MatDialog, MatDialogModule, MatDialogRef } from '@angular/material/dialog';\r\nimport { CommonModule } from '@angular/common';\r\nimport { NewFeatureDialogComponent } from '../new-feature-dialog.component';\r\nimport { ResolutionHelper } from '../../helpers';\r\nimport { NewFeatureDialogService } from './new-feature-dialog.service';\r\nimport { Subject } from 'rxjs';\r\n\r\n@Component({\r\n\tselector: 'lib-new-feature-dialog-wrapper',\r\n\tstandalone: true,\r\n\timports: [CommonModule, MatDialogModule, NewFeatureDialogComponent],\r\n\ttemplate: '',\r\n})\r\nexport class NewFeatureDialogWrapperComponent implements OnInit, OnDestroy {\r\n\t@Input() titleLocalizationKey!: string;\r\n\t@Input() descriptionLocalizationKey!: string;\r\n\t@Input() closeLocalizationKey!: string;\r\n\t@Input() featureClassName!: string;\r\n\t@Input() featureLocalStorageKey!: string;\r\n\t@Input() timeout = 0;\r\n\t@Input() maxWidth = 320;\r\n\r\n\treadonly #dialog = inject(MatDialog);\r\n\treadonly #featureService = inject(NewFeatureDialogService);\r\n\treadonly #destroy = new Subject();\r\n\r\n\tdialogRef: MatDialogRef<NewFeatureDialogComponent> | undefined;\r\n\tfeatureActive = signal(false);\r\n\tisFeatureSeen = false;\r\n\r\n\tngOnInit(): void {\r\n\t\tsetTimeout(() => {\r\n\t\t\tthis.setFeatureStatus();\r\n\t\t}, this.timeout);\r\n\t}\r\n\r\n\tngOnDestroy(): void {\r\n\t\tthis.#destroy.next(null);\r\n\t\tthis.#destroy.complete();\r\n\t}\r\n\r\n\tshowFeatureDialog(): void {\r\n\t\tconst targetElement = document.querySelector(`.${this.featureClassName}`);\r\n\t\tif (!targetElement) {\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tif (ResolutionHelper.isMobileRes()) {\r\n\t\t\ttargetElement!.scrollIntoView({ behavior: 'smooth', block: 'center'});\r\n\t\t}\r\n\r\n\t\tsetTimeout(() => {\r\n\t\t\tthis.featureActive.set(true);\r\n\t\t\tconst updatedRects = targetElement.getBoundingClientRect();\r\n\t\t\tthis.dialogRef = this.#dialog.open(NewFeatureDialogComponent, {\r\n\t\t\t\tdata: {\r\n\t\t\t\t\ttitle: this.titleLocalizationKey,\r\n\t\t\t\t\tdescription: this.descriptionLocalizationKey,\r\n\t\t\t\t\tclose: this.closeLocalizationKey,\r\n\t\t\t\t\tfeatureLocalStorageKey: this.featureLocalStorageKey,\r\n\t\t\t\t},\r\n\t\t\t\tposition: {\r\n\t\t\t\t\tleft: `${ResolutionHelper.isMobileRes() ? '10' : updatedRects.left - this.maxWidth}px`,\r\n\t\t\t\t\ttop: `${ResolutionHelper.isMobileRes() ? '70%' : updatedRects.top + 45+'px'}`,\r\n\t\t\t\t},\r\n\t\t\t\tmaxWidth: `${ResolutionHelper.isMobileRes() ? 'calc(100%) - 15px' : this.maxWidth+'px'}`,\r\n\t\t\t\tpanelClass: 'new-feature-dialog'\r\n\t\t\t});\r\n\r\n\t\t\tthis.dialogRef.afterClosed().subscribe(() => {\r\n\t\t\t\tthis.setFeatureSeen();\r\n\t\t\t\tthis.#featureService.current.set(undefined);\r\n\t\t\t\tthis.#featureService.showNextFeature();\r\n\t\t\t});\r\n\t\t\t// Wait until the element is visible in the viewport.\r\n\t\t}, ResolutionHelper.isMobileRes() ? 500 : 0);\r\n\t}\r\n\r\n\tprivate setFeatureStatus(): void {\r\n\t\tthis.isFeatureSeen = !!this.featureLocalStorageKey && !!localStorage.getItem(this.featureLocalStorageKey);\r\n\r\n\t\tif (!this.isFeatureSeen) {\r\n\t\t\tthis.#featureService.requestOpenFeature(this);\r\n\t\t}\r\n\t}\r\n\r\n\tprivate setFeatureSeen(): void {\r\n\t\tthis.featureActive.set(false);\r\n\t\tthis.isFeatureSeen = true;\r\n\t\tif (this.featureLocalStorageKey) {\r\n\t\t\tlocalStorage.setItem(this.featureLocalStorageKey, 'true');\r\n\t\t}\r\n\t}\r\n}\r\n"]}
@@ -29,11 +29,9 @@ export class PlausibleHelper {
29
29
  static customEvent(id, properties) {
30
30
  const windowObj = window;
31
31
  if (!windowObj?.plausible) {
32
- console.log('STOPPING EVENT', windowObj);
33
32
  return;
34
33
  }
35
- console.log('SUCCESS EVENT', id, properties);
36
34
  windowObj.plausible(id, { props: properties });
37
35
  }
38
36
  }
39
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGxhdXNpYmxlLmhlbHBlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1jb21tb24vc3JjL2xpYi9wbGF1c2libGUvcGxhdXNpYmxlLmhlbHBlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSx1REFBdUQ7QUFDdkQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUV6QyxNQUFNLE9BQU8sZUFBZTtJQUN4Qjs7OztPQUlHO0lBQ0gsTUFBTSxDQUFDLFlBQVksQ0FBQyxNQUFjO1FBQzlCLE1BQU0sVUFBVSxHQUFHLElBQUksVUFBVSxFQUFFLENBQUM7UUFDcEMsTUFBTSxTQUFTLEdBQVEsVUFBVSxDQUFDLE1BQU0sQ0FBQztRQUN6QyxJQUFJLENBQUMsU0FBUyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDeEIsT0FBTztRQUNYLENBQUM7UUFFRCxNQUFNLFlBQVksR0FBRyxzQ0FBc0MsQ0FBQztRQUM1RCxNQUFNLE1BQU0sR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQ2hELE1BQU0sQ0FBQyxHQUFHLEdBQUcsWUFBWSxDQUFDO1FBQzFCLE1BQU0sQ0FBQyxZQUFZLENBQUMsYUFBYSxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQzNDLFFBQVEsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBRTdCLDhIQUE4SDtRQUM5SCxTQUFTLENBQUMsU0FBUyxHQUFHLFNBQVMsQ0FBQyxTQUFTLElBQUksQ0FBQyxDQUFDLEdBQUcsTUFBVyxFQUFFLEVBQUUsR0FBRyxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQSxDQUFDLENBQUMsQ0FBQyxDQUFBO0lBQzdJLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNILE1BQU0sQ0FBQyxXQUFXLENBQUMsRUFBVSxFQUFFLFVBQWdCO1FBQzNDLE1BQU0sU0FBUyxHQUFRLE1BQU0sQ0FBQztRQUM5QixJQUFJLENBQUMsU0FBUyxFQUFFLFNBQVMsRUFBRSxDQUFDO1lBQ3hCLE9BQU8sQ0FBQyxHQUFHLENBQUMsZ0JBQWdCLEVBQUUsU0FBUyxDQUFDLENBQUM7WUFDekMsT0FBTztRQUNYLENBQUM7UUFDRCxPQUFPLENBQUMsR0FBRyxDQUFDLGVBQWUsRUFBRSxFQUFFLEVBQUUsVUFBVSxDQUFDLENBQUM7UUFDN0MsU0FBUyxDQUFDLFNBQVMsQ0FBQyxFQUFFLEVBQUUsRUFBRSxLQUFLLEVBQUUsVUFBVSxFQUFFLENBQUMsQ0FBQztJQUNuRCxDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55ICovXHJcbmltcG9ydCB7IERPTVNlcnZpY2UgfSBmcm9tIFwiLi4vc2VydmljZXNcIjtcclxuXHJcbmV4cG9ydCBjbGFzcyBQbGF1c2libGVIZWxwZXIge1xyXG4gICAgLyoqXHJcbiAgICAgKiBBZGRzIHBsYXVzaWJsZSBmb3Igc2VsZWN0ZWQgZG9tYWluIGFuZCBhZGRzIGFkZGl0aW9uYWwgc2NyaXB0IGZvciBjdXN0b20gZXZlbnQgKGdvYWwpIHRyaWdnZXJpbmdcclxuICAgICAqIEBwYXJhbSBkb21haW4gZG9tYWluIHRoYXQgaXMgcmVnaXN0ZXJlZCBpbiB5b3VyIHBsYXVzaWJsZSBhY2NvdW50XHJcbiAgICAgKiBAcmV0dXJuc1xyXG4gICAgICovXHJcbiAgICBzdGF0aWMgYWRkUGxhdXNpYmxlKGRvbWFpbjogc3RyaW5nKSB7XHJcbiAgICAgICAgY29uc3QgZG9tU2VydmljZSA9IG5ldyBET01TZXJ2aWNlKCk7XHJcbiAgICAgICAgY29uc3Qgd2luZG93T2JqOiBhbnkgPSBkb21TZXJ2aWNlLndpbmRvdztcclxuICAgICAgICBpZiAoIXdpbmRvd09iaiB8fCAhZG9tYWluKSB7XHJcbiAgICAgICAgICAgIHJldHVybjtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIGNvbnN0IHBsYXVzaWJsZVNyYyA9IFwiaHR0cHM6Ly9wbGF1c2libGUuaW8vanMvcGxhdXNpYmxlLmpzXCI7XHJcbiAgICAgICAgY29uc3Qgc2NyaXB0ID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudChcInNjcmlwdFwiKTtcclxuICAgICAgICBzY3JpcHQuc3JjID0gcGxhdXNpYmxlU3JjO1xyXG4gICAgICAgIHNjcmlwdC5zZXRBdHRyaWJ1dGUoXCJkYXRhLWRvbWFpblwiLCBkb21haW4pO1xyXG4gICAgICAgIGRvY3VtZW50LmhlYWQuYXBwZW5kKHNjcmlwdCk7XHJcblxyXG4gICAgICAgIC8vIEFkZCBwbGF1c2libGUgY3VzdG9tIGV2ZW50IGZ1bmN0aW9uYWxpdHkgaHR0cHM6Ly9wbGF1c2libGUuaW8vZG9jcy9jdXN0b20tZXZlbnQtZ29hbHMjY29kZS1leGFtcGxlLWZvci10cmFja2luZy1saW5rLWNsaWNrc1xyXG4gICAgICAgIHdpbmRvd09iai5wbGF1c2libGUgPSB3aW5kb3dPYmoucGxhdXNpYmxlIHx8ICgoLi4ucGFyYW1zOiBhbnkpID0+IHsgKHdpbmRvd09iai5wbGF1c2libGUucSA9IHdpbmRvd09iai5wbGF1c2libGUucSB8fCBbXSkucHVzaChwYXJhbXMpIH0pXHJcbiAgICB9XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBFbWl0cyBjdXN0b20gcGxhdXNpYmxlIGV2ZW50XHJcbiAgICAgKiBAcGFyYW0gaWQgcGxhdXNpYmxlIGV2ZW50IGlkIHRoYXQgc2hvdWxkIGJlIHRoZSBzYW1lIGFzIHJlZ2lzdGVyZWQgaW4gcGxhdXNpYmxlXHJcbiAgICAgKiBAcGFyYW0gcHJvcGVydGllcyBhbiBvYmplY3Qgd2l0aCBjdXN0b20gcHJvcGVydGllcyBmb3IgdGhlIGV2ZW50XHJcbiAgICAgKiBAcmV0dXJuc1xyXG4gICAgICovXHJcbiAgICBzdGF0aWMgY3VzdG9tRXZlbnQoaWQ6IHN0cmluZywgcHJvcGVydGllcz86IGFueSkge1xyXG4gICAgICAgIGNvbnN0IHdpbmRvd09iajogYW55ID0gd2luZG93O1xyXG4gICAgICAgIGlmICghd2luZG93T2JqPy5wbGF1c2libGUpIHtcclxuICAgICAgICAgICAgY29uc29sZS5sb2coJ1NUT1BQSU5HIEVWRU5UJywgd2luZG93T2JqKTtcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIH1cclxuICAgICAgICBjb25zb2xlLmxvZygnU1VDQ0VTUyBFVkVOVCcsIGlkLCBwcm9wZXJ0aWVzKTtcclxuICAgICAgICB3aW5kb3dPYmoucGxhdXNpYmxlKGlkLCB7IHByb3BzOiBwcm9wZXJ0aWVzIH0pO1xyXG4gICAgfVxyXG59XHJcbiJdfQ==
37
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGxhdXNpYmxlLmhlbHBlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1jb21tb24vc3JjL2xpYi9wbGF1c2libGUvcGxhdXNpYmxlLmhlbHBlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSx1REFBdUQ7QUFDdkQsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUV6QyxNQUFNLE9BQU8sZUFBZTtJQUN4Qjs7OztPQUlHO0lBQ0gsTUFBTSxDQUFDLFlBQVksQ0FBQyxNQUFjO1FBQzlCLE1BQU0sVUFBVSxHQUFHLElBQUksVUFBVSxFQUFFLENBQUM7UUFDcEMsTUFBTSxTQUFTLEdBQVEsVUFBVSxDQUFDLE1BQU0sQ0FBQztRQUN6QyxJQUFJLENBQUMsU0FBUyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDeEIsT0FBTztRQUNYLENBQUM7UUFFRCxNQUFNLFlBQVksR0FBRyxzQ0FBc0MsQ0FBQztRQUM1RCxNQUFNLE1BQU0sR0FBRyxRQUFRLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1FBQ2hELE1BQU0sQ0FBQyxHQUFHLEdBQUcsWUFBWSxDQUFDO1FBQzFCLE1BQU0sQ0FBQyxZQUFZLENBQUMsYUFBYSxFQUFFLE1BQU0sQ0FBQyxDQUFDO1FBQzNDLFFBQVEsQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBRTdCLDhIQUE4SDtRQUM5SCxTQUFTLENBQUMsU0FBUyxHQUFHLFNBQVMsQ0FBQyxTQUFTLElBQUksQ0FBQyxDQUFDLEdBQUcsTUFBVyxFQUFFLEVBQUUsR0FBRyxDQUFDLFNBQVMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxHQUFHLFNBQVMsQ0FBQyxTQUFTLENBQUMsQ0FBQyxJQUFJLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQSxDQUFDLENBQUMsQ0FBQyxDQUFBO0lBQzdJLENBQUM7SUFFRDs7Ozs7T0FLRztJQUNILE1BQU0sQ0FBQyxXQUFXLENBQUMsRUFBVSxFQUFFLFVBQWdCO1FBQzNDLE1BQU0sU0FBUyxHQUFRLE1BQU0sQ0FBQztRQUM5QixJQUFJLENBQUMsU0FBUyxFQUFFLFNBQVMsRUFBRSxDQUFDO1lBQ3hCLE9BQU87UUFDWCxDQUFDO1FBQ0QsU0FBUyxDQUFDLFNBQVMsQ0FBQyxFQUFFLEVBQUUsRUFBRSxLQUFLLEVBQUUsVUFBVSxFQUFFLENBQUMsQ0FBQztJQUNuRCxDQUFDO0NBQ0oiLCJzb3VyY2VzQ29udGVudCI6WyIvKiBlc2xpbnQtZGlzYWJsZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55ICovXHJcbmltcG9ydCB7IERPTVNlcnZpY2UgfSBmcm9tIFwiLi4vc2VydmljZXNcIjtcclxuXHJcbmV4cG9ydCBjbGFzcyBQbGF1c2libGVIZWxwZXIge1xyXG4gICAgLyoqXHJcbiAgICAgKiBBZGRzIHBsYXVzaWJsZSBmb3Igc2VsZWN0ZWQgZG9tYWluIGFuZCBhZGRzIGFkZGl0aW9uYWwgc2NyaXB0IGZvciBjdXN0b20gZXZlbnQgKGdvYWwpIHRyaWdnZXJpbmdcclxuICAgICAqIEBwYXJhbSBkb21haW4gZG9tYWluIHRoYXQgaXMgcmVnaXN0ZXJlZCBpbiB5b3VyIHBsYXVzaWJsZSBhY2NvdW50XHJcbiAgICAgKiBAcmV0dXJuc1xyXG4gICAgICovXHJcbiAgICBzdGF0aWMgYWRkUGxhdXNpYmxlKGRvbWFpbjogc3RyaW5nKSB7XHJcbiAgICAgICAgY29uc3QgZG9tU2VydmljZSA9IG5ldyBET01TZXJ2aWNlKCk7XHJcbiAgICAgICAgY29uc3Qgd2luZG93T2JqOiBhbnkgPSBkb21TZXJ2aWNlLndpbmRvdztcclxuICAgICAgICBpZiAoIXdpbmRvd09iaiB8fCAhZG9tYWluKSB7XHJcbiAgICAgICAgICAgIHJldHVybjtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIGNvbnN0IHBsYXVzaWJsZVNyYyA9IFwiaHR0cHM6Ly9wbGF1c2libGUuaW8vanMvcGxhdXNpYmxlLmpzXCI7XHJcbiAgICAgICAgY29uc3Qgc2NyaXB0ID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudChcInNjcmlwdFwiKTtcclxuICAgICAgICBzY3JpcHQuc3JjID0gcGxhdXNpYmxlU3JjO1xyXG4gICAgICAgIHNjcmlwdC5zZXRBdHRyaWJ1dGUoXCJkYXRhLWRvbWFpblwiLCBkb21haW4pO1xyXG4gICAgICAgIGRvY3VtZW50LmhlYWQuYXBwZW5kKHNjcmlwdCk7XHJcblxyXG4gICAgICAgIC8vIEFkZCBwbGF1c2libGUgY3VzdG9tIGV2ZW50IGZ1bmN0aW9uYWxpdHkgaHR0cHM6Ly9wbGF1c2libGUuaW8vZG9jcy9jdXN0b20tZXZlbnQtZ29hbHMjY29kZS1leGFtcGxlLWZvci10cmFja2luZy1saW5rLWNsaWNrc1xyXG4gICAgICAgIHdpbmRvd09iai5wbGF1c2libGUgPSB3aW5kb3dPYmoucGxhdXNpYmxlIHx8ICgoLi4ucGFyYW1zOiBhbnkpID0+IHsgKHdpbmRvd09iai5wbGF1c2libGUucSA9IHdpbmRvd09iai5wbGF1c2libGUucSB8fCBbXSkucHVzaChwYXJhbXMpIH0pXHJcbiAgICB9XHJcblxyXG4gICAgLyoqXHJcbiAgICAgKiBFbWl0cyBjdXN0b20gcGxhdXNpYmxlIGV2ZW50XHJcbiAgICAgKiBAcGFyYW0gaWQgcGxhdXNpYmxlIGV2ZW50IGlkIHRoYXQgc2hvdWxkIGJlIHRoZSBzYW1lIGFzIHJlZ2lzdGVyZWQgaW4gcGxhdXNpYmxlXHJcbiAgICAgKiBAcGFyYW0gcHJvcGVydGllcyBhbiBvYmplY3Qgd2l0aCBjdXN0b20gcHJvcGVydGllcyBmb3IgdGhlIGV2ZW50XHJcbiAgICAgKiBAcmV0dXJuc1xyXG4gICAgICovXHJcbiAgICBzdGF0aWMgY3VzdG9tRXZlbnQoaWQ6IHN0cmluZywgcHJvcGVydGllcz86IGFueSkge1xyXG4gICAgICAgIGNvbnN0IHdpbmRvd09iajogYW55ID0gd2luZG93O1xyXG4gICAgICAgIGlmICghd2luZG93T2JqPy5wbGF1c2libGUpIHtcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIH1cclxuICAgICAgICB3aW5kb3dPYmoucGxhdXNpYmxlKGlkLCB7IHByb3BzOiBwcm9wZXJ0aWVzIH0pO1xyXG4gICAgfVxyXG59XHJcbiJdfQ==
@@ -1890,10 +1890,8 @@ class PlausibleHelper {
1890
1890
  static customEvent(id, properties) {
1891
1891
  const windowObj = window;
1892
1892
  if (!windowObj?.plausible) {
1893
- console.log('STOPPING EVENT', windowObj);
1894
1893
  return;
1895
1894
  }
1896
- console.log('SUCCESS EVENT', id, properties);
1897
1895
  windowObj.plausible(id, { props: properties });
1898
1896
  }
1899
1897
  }
@@ -8331,9 +8329,8 @@ class NewFeatureDialogWrapperComponent {
8331
8329
  if (!targetElement) {
8332
8330
  return;
8333
8331
  }
8334
- if (ResolutionHelper.isMobileRes() && this.featureContainerClassName) {
8335
- const containerElement = document.querySelector(`.${this.featureContainerClassName}`);
8336
- containerElement.scrollIntoView({ behavior: 'smooth', block: 'start' });
8332
+ if (ResolutionHelper.isMobileRes()) {
8333
+ targetElement.scrollIntoView({ behavior: 'smooth', block: 'center' });
8337
8334
  }
8338
8335
  setTimeout(() => {
8339
8336
  this.featureActive.set(true);
@@ -8346,10 +8343,11 @@ class NewFeatureDialogWrapperComponent {
8346
8343
  featureLocalStorageKey: this.featureLocalStorageKey,
8347
8344
  },
8348
8345
  position: {
8349
- left: `${updatedRects.left - this.maxWidth}px`,
8350
- top: `${updatedRects.top + 45}px`,
8346
+ left: `${ResolutionHelper.isMobileRes() ? '10' : updatedRects.left - this.maxWidth}px`,
8347
+ top: `${ResolutionHelper.isMobileRes() ? '70%' : updatedRects.top + 45 + 'px'}`,
8351
8348
  },
8352
- maxWidth: `${this.maxWidth}px`,
8349
+ maxWidth: `${ResolutionHelper.isMobileRes() ? 'calc(100%) - 15px' : this.maxWidth + 'px'}`,
8350
+ panelClass: 'new-feature-dialog'
8353
8351
  });
8354
8352
  this.dialogRef.afterClosed().subscribe(() => {
8355
8353
  this.setFeatureSeen();
@@ -8357,7 +8355,7 @@ class NewFeatureDialogWrapperComponent {
8357
8355
  this.#featureService.showNextFeature();
8358
8356
  });
8359
8357
  // Wait until the element is visible in the viewport.
8360
- }, ResolutionHelper.isMobileRes() && this.featureContainerClassName ? 500 : 0);
8358
+ }, ResolutionHelper.isMobileRes() ? 500 : 0);
8361
8359
  }
8362
8360
  setFeatureStatus() {
8363
8361
  this.isFeatureSeen = !!this.featureLocalStorageKey && !!localStorage.getItem(this.featureLocalStorageKey);
@@ -8373,7 +8371,7 @@ class NewFeatureDialogWrapperComponent {
8373
8371
  }
8374
8372
  }
8375
8373
  static { this.ɵfac = function NewFeatureDialogWrapperComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || NewFeatureDialogWrapperComponent)(); }; }
8376
- static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: NewFeatureDialogWrapperComponent, selectors: [["lib-new-feature-dialog-wrapper"]], inputs: { titleLocalizationKey: "titleLocalizationKey", descriptionLocalizationKey: "descriptionLocalizationKey", closeLocalizationKey: "closeLocalizationKey", featureClassName: "featureClassName", featureContainerClassName: "featureContainerClassName", featureLocalStorageKey: "featureLocalStorageKey", timeout: "timeout", maxWidth: "maxWidth" }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 0, vars: 0, template: function NewFeatureDialogWrapperComponent_Template(rf, ctx) { }, dependencies: [CommonModule, MatDialogModule], encapsulation: 2 }); }
8374
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: NewFeatureDialogWrapperComponent, selectors: [["lib-new-feature-dialog-wrapper"]], inputs: { titleLocalizationKey: "titleLocalizationKey", descriptionLocalizationKey: "descriptionLocalizationKey", closeLocalizationKey: "closeLocalizationKey", featureClassName: "featureClassName", featureLocalStorageKey: "featureLocalStorageKey", timeout: "timeout", maxWidth: "maxWidth" }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 0, vars: 0, template: function NewFeatureDialogWrapperComponent_Template(rf, ctx) { }, dependencies: [CommonModule, MatDialogModule], encapsulation: 2 }); }
8377
8375
  }
8378
8376
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(NewFeatureDialogWrapperComponent, [{
8379
8377
  type: Component,
@@ -8391,8 +8389,6 @@ class NewFeatureDialogWrapperComponent {
8391
8389
  type: Input
8392
8390
  }], featureClassName: [{
8393
8391
  type: Input
8394
- }], featureContainerClassName: [{
8395
- type: Input
8396
8392
  }], featureLocalStorageKey: [{
8397
8393
  type: Input
8398
8394
  }], timeout: [{