@tilde-nlp/ngx-common 6.1.84 → 6.1.86

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,7 +33,7 @@ export class NewFeatureDialogWrapperComponent {
33
33
  if (!targetElement) {
34
34
  return;
35
35
  }
36
- if (ResolutionHelper.isMobileRes()) {
36
+ if (ResolutionHelper.isMobileRes() && this.mobileScreenCustomPosition?.autoScroll) {
37
37
  targetElement.scrollIntoView({ behavior: 'smooth', block: 'center' });
38
38
  }
39
39
  setTimeout(() => {
@@ -47,11 +47,11 @@ export class NewFeatureDialogWrapperComponent {
47
47
  featureLocalStorageKey: this.featureLocalStorageKey,
48
48
  },
49
49
  position: {
50
- left: `${ResolutionHelper.isMobileRes() ? '10' : updatedRects.left - this.maxWidth}px`,
51
- top: `${ResolutionHelper.isMobileRes() ? '70%' : updatedRects.top + 45 + 'px'}`,
50
+ left: `${ResolutionHelper.isMobileRes() && this.mobileScreenCustomPosition?.left ? this.mobileScreenCustomPosition.left : (updatedRects.left - this.maxWidth) + 'px'}`,
51
+ top: `${ResolutionHelper.isMobileRes() && this.mobileScreenCustomPosition?.top ? this.mobileScreenCustomPosition?.top : (updatedRects.top + 45) + 'px'}`,
52
+ right: `${ResolutionHelper.isMobileRes() && this.mobileScreenCustomPosition?.right ? this.mobileScreenCustomPosition?.right : 'auto'}`
52
53
  },
53
- maxWidth: `${ResolutionHelper.isMobileRes() ? 'calc(100%) - 15px' : this.maxWidth + 'px'}`,
54
- panelClass: 'new-feature-dialog'
54
+ maxWidth: `${this.maxWidth}px`
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() ? 500 : 0);
62
+ }, ResolutionHelper.isMobileRes() && this.mobileScreenCustomPosition?.autoScroll ? 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", 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", mobileScreenCustomPosition: "mobileScreenCustomPosition" }, 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,
@@ -99,6 +99,8 @@ export class NewFeatureDialogWrapperComponent {
99
99
  type: Input
100
100
  }], maxWidth: [{
101
101
  type: Input
102
+ }], mobileScreenCustomPosition: [{
103
+ type: Input
102
104
  }] }); })();
103
105
  (() => { (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 }); })();
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"]}
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() featureLocalStorageKey!: string;\r\n\t@Input() timeout = 0;\r\n\t@Input() maxWidth = 320;\r\n\t@Input() mobileScreenCustomPosition?: { autoScroll: boolean, left: string, top: string, right: string };\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.mobileScreenCustomPosition?.autoScroll) {\r\n\t\t\ttargetElement!.scrollIntoView({ behavior: 'smooth', block: 'center'});\r\n\t\t}\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() && this.mobileScreenCustomPosition?.left ? this.mobileScreenCustomPosition.left : (updatedRects.left - this.maxWidth) + 'px'}`,\r\n\t\t\t\t\ttop: `${ResolutionHelper.isMobileRes() && this.mobileScreenCustomPosition?.top ? this.mobileScreenCustomPosition?.top : (updatedRects.top + 45) + 'px'}`,\r\n\t\t\t\t\tright: `${ResolutionHelper.isMobileRes() && this.mobileScreenCustomPosition?.right ? this.mobileScreenCustomPosition?.right : 'auto'}`\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.mobileScreenCustomPosition?.autoScroll ? 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"]}
@@ -8329,7 +8329,7 @@ class NewFeatureDialogWrapperComponent {
8329
8329
  if (!targetElement) {
8330
8330
  return;
8331
8331
  }
8332
- if (ResolutionHelper.isMobileRes()) {
8332
+ if (ResolutionHelper.isMobileRes() && this.mobileScreenCustomPosition?.autoScroll) {
8333
8333
  targetElement.scrollIntoView({ behavior: 'smooth', block: 'center' });
8334
8334
  }
8335
8335
  setTimeout(() => {
@@ -8343,11 +8343,11 @@ class NewFeatureDialogWrapperComponent {
8343
8343
  featureLocalStorageKey: this.featureLocalStorageKey,
8344
8344
  },
8345
8345
  position: {
8346
- left: `${ResolutionHelper.isMobileRes() ? '10' : updatedRects.left - this.maxWidth}px`,
8347
- top: `${ResolutionHelper.isMobileRes() ? '70%' : updatedRects.top + 45 + 'px'}`,
8346
+ left: `${ResolutionHelper.isMobileRes() && this.mobileScreenCustomPosition?.left ? this.mobileScreenCustomPosition.left : (updatedRects.left - this.maxWidth) + 'px'}`,
8347
+ top: `${ResolutionHelper.isMobileRes() && this.mobileScreenCustomPosition?.top ? this.mobileScreenCustomPosition?.top : (updatedRects.top + 45) + 'px'}`,
8348
+ right: `${ResolutionHelper.isMobileRes() && this.mobileScreenCustomPosition?.right ? this.mobileScreenCustomPosition?.right : 'auto'}`
8348
8349
  },
8349
- maxWidth: `${ResolutionHelper.isMobileRes() ? 'calc(100%) - 15px' : this.maxWidth + 'px'}`,
8350
- panelClass: 'new-feature-dialog'
8350
+ maxWidth: `${this.maxWidth}px`
8351
8351
  });
8352
8352
  this.dialogRef.afterClosed().subscribe(() => {
8353
8353
  this.setFeatureSeen();
@@ -8355,7 +8355,7 @@ class NewFeatureDialogWrapperComponent {
8355
8355
  this.#featureService.showNextFeature();
8356
8356
  });
8357
8357
  // Wait until the element is visible in the viewport.
8358
- }, ResolutionHelper.isMobileRes() ? 500 : 0);
8358
+ }, ResolutionHelper.isMobileRes() && this.mobileScreenCustomPosition?.autoScroll ? 500 : 0);
8359
8359
  }
8360
8360
  setFeatureStatus() {
8361
8361
  this.isFeatureSeen = !!this.featureLocalStorageKey && !!localStorage.getItem(this.featureLocalStorageKey);
@@ -8371,7 +8371,7 @@ class NewFeatureDialogWrapperComponent {
8371
8371
  }
8372
8372
  }
8373
8373
  static { this.ɵfac = function NewFeatureDialogWrapperComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || NewFeatureDialogWrapperComponent)(); }; }
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 }); }
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", mobileScreenCustomPosition: "mobileScreenCustomPosition" }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 0, vars: 0, template: function NewFeatureDialogWrapperComponent_Template(rf, ctx) { }, dependencies: [CommonModule, MatDialogModule], encapsulation: 2 }); }
8375
8375
  }
8376
8376
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(NewFeatureDialogWrapperComponent, [{
8377
8377
  type: Component,
@@ -8395,6 +8395,8 @@ class NewFeatureDialogWrapperComponent {
8395
8395
  type: Input
8396
8396
  }], maxWidth: [{
8397
8397
  type: Input
8398
+ }], mobileScreenCustomPosition: [{
8399
+ type: Input
8398
8400
  }] }); })();
8399
8401
  (() => { (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 }); })();
8400
8402