tango-app-ui-analyse-traffic 3.8.0-alpha.25 → 3.8.0-alpha.26

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.
@@ -5,7 +5,8 @@ export class MagnifierDirective {
5
5
  renderer;
6
6
  lens;
7
7
  zoom = 2; // Zoom factor
8
- lensSize = 300; // Lens width/height in px
8
+ lensWidth = 300; // lens width
9
+ lensHeight = 700; // lens height (taller)
9
10
  constructor(el, renderer) {
10
11
  this.el = el;
11
12
  this.renderer = renderer;
@@ -16,8 +17,8 @@ export class MagnifierDirective {
16
17
  createLens() {
17
18
  this.lens = this.renderer.createElement('div');
18
19
  this.renderer.setStyle(this.lens, 'position', 'absolute');
19
- this.renderer.setStyle(this.lens, 'width', `${this.lensSize}px`);
20
- this.renderer.setStyle(this.lens, 'height', `${this.lensSize}px`);
20
+ this.renderer.setStyle(this.lens, 'width', `${this.lensWidth}px`);
21
+ this.renderer.setStyle(this.lens, 'height', `${this.lensHeight}px`);
21
22
  this.renderer.setStyle(this.lens, 'border', '2px solid red');
22
23
  this.renderer.setStyle(this.lens, 'background-color', 'rgba(255,255,255,0.5)');
23
24
  this.renderer.setStyle(this.lens, 'pointer-events', 'none');
@@ -33,16 +34,16 @@ export class MagnifierDirective {
33
34
  const scrollY = window.pageYOffset;
34
35
  const x = e.pageX - rect.left - scrollX;
35
36
  const y = e.pageY - rect.top - scrollY;
36
- const lensX = e.pageX - this.lensSize / 2;
37
- const lensY = e.pageY - this.lensSize / 2;
37
+ const lensX = e.pageX - this.lensWidth / 2;
38
+ const lensY = e.pageY - this.lensHeight / 2;
38
39
  // Move lens
39
40
  this.renderer.setStyle(this.lens, 'left', `${lensX}px`);
40
41
  this.renderer.setStyle(this.lens, 'top', `${lensY}px`);
41
42
  // Set background image and zoom
42
43
  this.renderer.setStyle(this.lens, 'backgroundImage', `url(${image.src})`);
43
44
  this.renderer.setStyle(this.lens, 'backgroundSize', `${image.width * this.zoom}px ${image.height * this.zoom}px`);
44
- const bgX = x * this.zoom - this.lensSize / 2;
45
- const bgY = y * this.zoom - this.lensSize / 2;
45
+ const bgX = x * this.zoom - this.lensWidth / 2;
46
+ const bgY = y * this.zoom - this.lensHeight / 2;
46
47
  this.renderer.setStyle(this.lens, 'backgroundPosition', `-${bgX}px -${bgY}px`);
47
48
  this.renderer.setStyle(this.lens, 'visibility', 'visible');
48
49
  }
@@ -71,4 +72,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
71
72
  type: HostListener,
72
73
  args: ['mouseleave']
73
74
  }] } });
74
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"magnifier.directive.js","sourceRoot":"","sources":["../../../../../projects/tango-analyse-traffic/src/lib/directive/magnifier.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, HostListener, Renderer2, OnInit, OnDestroy } from '@angular/core';\r\n\r\n@Directive({\r\n  selector: '[appMagnifier]',\r\n})\r\nexport class MagnifierDirective implements OnInit, OnDestroy {\r\n  private lens: HTMLElement | null;\r\n  private zoom = 2;        // Zoom factor\r\n  private lensSize = 300;  // Lens width/height in px\r\n\r\n  constructor(private el: ElementRef, private renderer: Renderer2) {}\r\n\r\n  ngOnInit() {\r\n    this.createLens();\r\n  }\r\n\r\n  private createLens() {\r\n    this.lens = this.renderer.createElement('div');\r\n\r\n    this.renderer.setStyle(this.lens, 'position', 'absolute');\r\n    this.renderer.setStyle(this.lens, 'width', `${this.lensSize}px`);\r\n    this.renderer.setStyle(this.lens, 'height', `${this.lensSize}px`);\r\n    this.renderer.setStyle(this.lens, 'border', '2px solid red');\r\n    this.renderer.setStyle(this.lens, 'background-color', 'rgba(255,255,255,0.5)');\r\n    this.renderer.setStyle(this.lens, 'pointer-events', 'none');\r\n    this.renderer.setStyle(this.lens, 'z-index', '9999');\r\n    this.renderer.setStyle(this.lens, 'transition', 'all 0.1s ease');\r\n    this.renderer.setStyle(this.lens, 'visibility', 'hidden');\r\n\r\n    this.renderer.appendChild(document.body, this.lens);\r\n  }\r\n\r\n  @HostListener('mousemove', ['$event'])\r\n  onMouseMove(e: MouseEvent): void {\r\n    const image = this.el.nativeElement;\r\n    const rect = image.getBoundingClientRect();\r\n\r\n    const scrollX = window.pageXOffset;\r\n    const scrollY = window.pageYOffset;\r\n\r\n    const x = e.pageX - rect.left - scrollX;\r\n    const y = e.pageY - rect.top - scrollY;\r\n\r\n    const lensX = e.pageX - this.lensSize / 2;\r\n    const lensY = e.pageY - this.lensSize / 2;\r\n\r\n    // Move lens\r\n    this.renderer.setStyle(this.lens, 'left', `${lensX}px`);\r\n    this.renderer.setStyle(this.lens, 'top', `${lensY}px`);\r\n\r\n    // Set background image and zoom\r\n    this.renderer.setStyle(this.lens, 'backgroundImage', `url(${image.src})`);\r\n    this.renderer.setStyle(\r\n      this.lens,\r\n      'backgroundSize',\r\n      `${image.width * this.zoom}px ${image.height * this.zoom}px`\r\n    );\r\n\r\n    const bgX = x * this.zoom - this.lensSize / 2;\r\n    const bgY = y * this.zoom - this.lensSize / 2;\r\n\r\n    this.renderer.setStyle(this.lens, 'backgroundPosition', `-${bgX}px -${bgY}px`);\r\n    this.renderer.setStyle(this.lens, 'visibility', 'visible');\r\n  }\r\n\r\n  @HostListener('mouseleave')\r\n  onMouseLeave() {\r\n    this.renderer.setStyle(this.lens, 'visibility', 'hidden');\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    // Cleanup lens element\r\n    if (this.lens && this.lens.parentNode) {\r\n      this.renderer.removeChild(document.body, this.lens);\r\n      this.lens = null;\r\n    }\r\n  }\r\n}\r\n"]}
75
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"magnifier.directive.js","sourceRoot":"","sources":["../../../../../projects/tango-analyse-traffic/src/lib/directive/magnifier.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directive, ElementRef, HostListener, Renderer2, OnInit, OnDestroy } from '@angular/core';\r\n\r\n@Directive({\r\n  selector: '[appMagnifier]',\r\n})\r\nexport class MagnifierDirective implements OnInit, OnDestroy {\r\n  private lens: HTMLElement | null;\r\n  private zoom = 2;        // Zoom factor\r\n  private lensWidth = 300;   // lens width\r\n  private lensHeight = 700;  // lens height (taller)\r\n\r\n  constructor(private el: ElementRef, private renderer: Renderer2) {}\r\n\r\n  ngOnInit() {\r\n    this.createLens();\r\n  }\r\n\r\n  private createLens() {\r\n    this.lens = this.renderer.createElement('div');\r\n\r\n    this.renderer.setStyle(this.lens, 'position', 'absolute');\r\n    this.renderer.setStyle(this.lens, 'width', `${this.lensWidth}px`);\r\n    this.renderer.setStyle(this.lens, 'height', `${this.lensHeight}px`);\r\n    this.renderer.setStyle(this.lens, 'border', '2px solid red');\r\n    this.renderer.setStyle(this.lens, 'background-color', 'rgba(255,255,255,0.5)');\r\n    this.renderer.setStyle(this.lens, 'pointer-events', 'none');\r\n    this.renderer.setStyle(this.lens, 'z-index', '9999');\r\n    this.renderer.setStyle(this.lens, 'transition', 'all 0.1s ease');\r\n    this.renderer.setStyle(this.lens, 'visibility', 'hidden');\r\n\r\n    this.renderer.appendChild(document.body, this.lens);\r\n  }\r\n\r\n  @HostListener('mousemove', ['$event'])\r\n  onMouseMove(e: MouseEvent): void {\r\n    const image = this.el.nativeElement;\r\n    const rect = image.getBoundingClientRect();\r\n\r\n    const scrollX = window.pageXOffset;\r\n    const scrollY = window.pageYOffset;\r\n\r\n    const x = e.pageX - rect.left - scrollX;\r\n    const y = e.pageY - rect.top - scrollY;\r\n\r\n    const lensX = e.pageX - this.lensWidth / 2;\r\n    const lensY = e.pageY - this.lensHeight / 2;\r\n\r\n    // Move lens\r\n    this.renderer.setStyle(this.lens, 'left', `${lensX}px`);\r\n    this.renderer.setStyle(this.lens, 'top', `${lensY}px`);\r\n\r\n    // Set background image and zoom\r\n    this.renderer.setStyle(this.lens, 'backgroundImage', `url(${image.src})`);\r\n    this.renderer.setStyle(\r\n      this.lens,\r\n      'backgroundSize',\r\n      `${image.width * this.zoom}px ${image.height * this.zoom}px`\r\n    );\r\n\r\n    const bgX = x * this.zoom - this.lensWidth / 2;\r\n    const bgY = y * this.zoom - this.lensHeight / 2;\r\n\r\n    this.renderer.setStyle(this.lens, 'backgroundPosition', `-${bgX}px -${bgY}px`);\r\n    this.renderer.setStyle(this.lens, 'visibility', 'visible');\r\n  }\r\n\r\n  @HostListener('mouseleave')\r\n  onMouseLeave() {\r\n    this.renderer.setStyle(this.lens, 'visibility', 'hidden');\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    // Cleanup lens element\r\n    if (this.lens && this.lens.parentNode) {\r\n      this.renderer.removeChild(document.body, this.lens);\r\n      this.lens = null;\r\n    }\r\n  }\r\n}\r\n"]}
@@ -753,7 +753,8 @@ class MagnifierDirective {
753
753
  renderer;
754
754
  lens;
755
755
  zoom = 2; // Zoom factor
756
- lensSize = 300; // Lens width/height in px
756
+ lensWidth = 300; // lens width
757
+ lensHeight = 700; // lens height (taller)
757
758
  constructor(el, renderer) {
758
759
  this.el = el;
759
760
  this.renderer = renderer;
@@ -764,8 +765,8 @@ class MagnifierDirective {
764
765
  createLens() {
765
766
  this.lens = this.renderer.createElement('div');
766
767
  this.renderer.setStyle(this.lens, 'position', 'absolute');
767
- this.renderer.setStyle(this.lens, 'width', `${this.lensSize}px`);
768
- this.renderer.setStyle(this.lens, 'height', `${this.lensSize}px`);
768
+ this.renderer.setStyle(this.lens, 'width', `${this.lensWidth}px`);
769
+ this.renderer.setStyle(this.lens, 'height', `${this.lensHeight}px`);
769
770
  this.renderer.setStyle(this.lens, 'border', '2px solid red');
770
771
  this.renderer.setStyle(this.lens, 'background-color', 'rgba(255,255,255,0.5)');
771
772
  this.renderer.setStyle(this.lens, 'pointer-events', 'none');
@@ -781,16 +782,16 @@ class MagnifierDirective {
781
782
  const scrollY = window.pageYOffset;
782
783
  const x = e.pageX - rect.left - scrollX;
783
784
  const y = e.pageY - rect.top - scrollY;
784
- const lensX = e.pageX - this.lensSize / 2;
785
- const lensY = e.pageY - this.lensSize / 2;
785
+ const lensX = e.pageX - this.lensWidth / 2;
786
+ const lensY = e.pageY - this.lensHeight / 2;
786
787
  // Move lens
787
788
  this.renderer.setStyle(this.lens, 'left', `${lensX}px`);
788
789
  this.renderer.setStyle(this.lens, 'top', `${lensY}px`);
789
790
  // Set background image and zoom
790
791
  this.renderer.setStyle(this.lens, 'backgroundImage', `url(${image.src})`);
791
792
  this.renderer.setStyle(this.lens, 'backgroundSize', `${image.width * this.zoom}px ${image.height * this.zoom}px`);
792
- const bgX = x * this.zoom - this.lensSize / 2;
793
- const bgY = y * this.zoom - this.lensSize / 2;
793
+ const bgX = x * this.zoom - this.lensWidth / 2;
794
+ const bgY = y * this.zoom - this.lensHeight / 2;
794
795
  this.renderer.setStyle(this.lens, 'backgroundPosition', `-${bgX}px -${bgY}px`);
795
796
  this.renderer.setStyle(this.lens, 'visibility', 'visible');
796
797
  }