@libs-ui/components-minimap 0.2.304 → 0.2.306-10

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.
package/README.md CHANGED
@@ -39,18 +39,17 @@ import { LibsUiComponentsMinimapDirective } from '@libs-ui/components-minimap';
39
39
  standalone: true,
40
40
  imports: [LibsUiComponentsMinimapDirective],
41
41
  template: `
42
- <div
42
+ <div
43
43
  LibsUiComponentsMinimapDirective
44
44
  class="scrollable-content"
45
45
  style="width: 500px; height: 300px; overflow: auto;">
46
-
47
46
  <!-- Nội dung lớn cần minimap -->
48
47
  <div style="width: 1500px; height: 1000px; background: linear-gradient(45deg, #ff6b6b, #4ecdc4);">
49
48
  <h2>Nội dung rất lớn</h2>
50
49
  <p>Cuộn để xem minimap hoạt động...</p>
51
50
  </div>
52
51
  </div>
53
- `
52
+ `,
54
53
  })
55
54
  export class ExampleComponent {}
56
55
  ```
@@ -58,6 +57,7 @@ export class ExampleComponent {}
58
57
  ### Ví dụ với file HTML riêng
59
58
 
60
59
  **Component:**
60
+
61
61
  ```typescript
62
62
  import { Component } from '@angular/core';
63
63
  import { LibsUiComponentsMinimapDirective, IMiniMapFunctionControl, IMiniMapStyleConfig } from '@libs-ui/components-minimap';
@@ -67,10 +67,9 @@ import { LibsUiComponentsMinimapDirective, IMiniMapFunctionControl, IMiniMapStyl
67
67
  standalone: true,
68
68
  imports: [LibsUiComponentsMinimapDirective],
69
69
  templateUrl: './minimap-demo.component.html',
70
- styleUrls: ['./minimap-demo.component.scss']
70
+ styleUrls: ['./minimap-demo.component.scss'],
71
71
  })
72
72
  export class MinimapDemoComponent {
73
-
74
73
  // Cấu hình style cho minimap container
75
74
  minimapStyle: IMiniMapStyleConfig = {
76
75
  width: 250,
@@ -80,14 +79,14 @@ export class MinimapDemoComponent {
80
79
  background: '#f8f9fa',
81
80
  border: '2px solid #007bff',
82
81
  borderRadius: 8,
83
- zIndex: 1500
82
+ zIndex: 1500,
84
83
  };
85
84
 
86
85
  // Cấu hình style cho viewport rectangle
87
86
  viewportStyle: IMiniMapStyleConfig = {
88
87
  border: '2px solid #ff6b6b',
89
88
  background: 'rgba(255, 107, 107, 0.1)',
90
- borderRadius: 4
89
+ borderRadius: 4,
91
90
  };
92
91
 
93
92
  minimapControls: IMiniMapFunctionControl | null = null;
@@ -113,24 +112,30 @@ export class MinimapDemoComponent {
113
112
  ```
114
113
 
115
114
  **Template (minimap-demo.component.html):**
115
+
116
116
  ```html
117
117
  <div class="demo-container">
118
-
119
118
  <!-- Control buttons -->
120
119
  <div class="controls mb-3">
121
- <button (click)="showMinimap()" class="btn btn-success me-2">
120
+ <button
121
+ (click)="showMinimap()"
122
+ class="btn btn-success me-2">
122
123
  Hiện Minimap
123
124
  </button>
124
- <button (click)="hideMinimap()" class="btn btn-warning me-2">
125
+ <button
126
+ (click)="hideMinimap()"
127
+ class="btn btn-warning me-2">
125
128
  Ẩn Minimap
126
129
  </button>
127
- <button (click)="toggleMinimap()" class="btn btn-info">
130
+ <button
131
+ (click)="toggleMinimap()"
132
+ class="btn btn-info">
128
133
  Toggle Minimap
129
134
  </button>
130
135
  </div>
131
136
 
132
137
  <!-- Scrollable content với minimap -->
133
- <div
138
+ <div
134
139
  LibsUiComponentsMinimapDirective
135
140
  [styleImageElement]="minimapStyle"
136
141
  [styleRectangleElement]="viewportStyle"
@@ -138,21 +143,26 @@ export class MinimapDemoComponent {
138
143
  (outFunctionControls)="onMinimapReady($event)"
139
144
  class="scrollable-area"
140
145
  style="width: 600px; height: 400px; overflow: auto; border: 1px solid #ddd;">
141
-
142
146
  <!-- Large content -->
143
- <div class="large-content" style="width: 1200px; height: 800px; padding: 20px;">
147
+ <div
148
+ class="large-content"
149
+ style="width: 1200px; height: 800px; padding: 20px;">
144
150
  <h1>Nội dung lớn với Minimap</h1>
145
-
146
- <div class="mo-minimap-flag-element-scale" style="transform: scale(1.2);">
151
+
152
+ <div
153
+ class="mo-minimap-flag-element-scale"
154
+ style="transform: scale(1.2);">
147
155
  <!-- Element có scale để test tính năng scale detection -->
148
156
  <div class="grid-content">
149
157
  <!-- Tạo grid content để dễ nhận biết vị trí -->
150
- <div *ngFor="let row of [1,2,3,4,5,6,7,8,9,10]"
151
- class="row"
152
- style="display: flex; margin: 10px 0;">
153
- <div *ngFor="let col of [1,2,3,4,5,6,7,8,9,10]"
154
- class="cell"
155
- style="width: 80px; height: 60px; border: 1px solid #ccc;
158
+ <div
159
+ *ngFor="let row of [1,2,3,4,5,6,7,8,9,10]"
160
+ class="row"
161
+ style="display: flex; margin: 10px 0;">
162
+ <div
163
+ *ngFor="let col of [1,2,3,4,5,6,7,8,9,10]"
164
+ class="cell"
165
+ style="width: 80px; height: 60px; border: 1px solid #ccc;
156
166
  margin: 2px; display: flex; align-items: center;
157
167
  justify-content: center; background: #f0f0f0;">
158
168
  {{row}}-{{col}}
@@ -176,18 +186,18 @@ export class MinimapDemoComponent {
176
186
 
177
187
  ### Inputs
178
188
 
179
- | Tên | Kiểu | Mặc định | Mô tả |
180
- |-----|------|----------|-------|
181
- | `classNameFlagElementScale` | `string` | `'mo-minimap-flag-element-scale'` | Class name của element có scale transform để directive detect |
182
- | `timerStartDrawMinimap` | `number` | `250` | Thời gian delay (ms) trước khi bắt đầu vẽ minimap |
183
- | `elementScroll` | `HTMLElement` | `undefined` | Element cuộn tùy chỉnh (mặc định dùng host element) |
184
- | `styleRectangleElement` | `IMiniMapStyleConfig` | `undefined` | Cấu hình style cho viewport rectangle |
185
- | `styleImageElement` | `IMiniMapStyleConfig` | `undefined` | Cấu hình style cho minimap container |
189
+ | Tên | Kiểu | Mặc định | Mô tả |
190
+ | --------------------------- | --------------------- | --------------------------------- | ------------------------------------------------------------- |
191
+ | `classNameFlagElementScale` | `string` | `'mo-minimap-flag-element-scale'` | Class name của element có scale transform để directive detect |
192
+ | `timerStartDrawMinimap` | `number` | `250` | Thời gian delay (ms) trước khi bắt đầu vẽ minimap |
193
+ | `elementScroll` | `HTMLElement` | `undefined` | Element cuộn tùy chỉnh (mặc định dùng host element) |
194
+ | `styleRectangleElement` | `IMiniMapStyleConfig` | `undefined` | Cấu hình style cho viewport rectangle |
195
+ | `styleImageElement` | `IMiniMapStyleConfig` | `undefined` | Cấu hình style cho minimap container |
186
196
 
187
197
  ### Outputs
188
198
 
189
- | Tên | Kiểu | Mô tả |
190
- |-----|------|-------|
199
+ | Tên | Kiểu | Mô tả |
200
+ | --------------------- | ------------------------- | ------------------------------------------------ |
191
201
  | `outFunctionControls` | `IMiniMapFunctionControl` | Emit object chứa các function để control minimap |
192
202
 
193
203
  ### Interfaces
@@ -196,18 +206,18 @@ export class MinimapDemoComponent {
196
206
 
197
207
  ```typescript
198
208
  interface IMiniMapStyleConfig {
199
- x?: number; // Vị trí x (không sử dụng)
200
- y?: number; // Vị trí y (không sử dụng)
201
- width?: number; // Chiều rộng minimap (px)
202
- height?: number; // Chiều cao minimap (px)
203
- zIndex?: number; // Z-index layer
204
- border?: string; // CSS border
205
- borderRadius?: number; // CSS border-radius (px)
206
- background?: string; // CSS background
207
- top?: number; // Vị trí top (px)
208
- left?: number; // Vị trí left (px)
209
- bottom?: number; // Vị trí bottom (px) - ưu tiên hơn top
210
- right?: number; // Vị trí right (px) - ưu tiên hơn left
209
+ x?: number; // Vị trí x (không sử dụng)
210
+ y?: number; // Vị trí y (không sử dụng)
211
+ width?: number; // Chiều rộng minimap (px)
212
+ height?: number; // Chiều cao minimap (px)
213
+ zIndex?: number; // Z-index layer
214
+ border?: string; // CSS border
215
+ borderRadius?: number; // CSS border-radius (px)
216
+ background?: string; // CSS background
217
+ top?: number; // Vị trí top (px)
218
+ left?: number; // Vị trí left (px)
219
+ bottom?: number; // Vị trí bottom (px) - ưu tiên hơn top
220
+ right?: number; // Vị trí right (px) - ưu tiên hơn left
211
221
  }
212
222
  ```
213
223
 
@@ -217,9 +227,9 @@ Cấu hình style cho minimap container hoặc viewport rectangle. Tất cả th
217
227
 
218
228
  ```typescript
219
229
  interface IMiniMapFunctionControl {
220
- show: () => void; // Hiển thị minimap
221
- hidden: () => void; // Ẩn minimap
222
- toggle: () => void; // Toggle hiển thị/ẩn minimap
230
+ show: () => void; // Hiển thị minimap
231
+ hidden: () => void; // Ẩn minimap
232
+ toggle: () => void; // Toggle hiển thị/ẩn minimap
223
233
  }
224
234
  ```
225
235
 
package/esm2022/index.mjs CHANGED
@@ -1,3 +1,3 @@
1
1
  export * from './minimap.directive';
2
2
  export * from './minimap.interface';
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvbWluaW1hcC9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLHFCQUFxQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9taW5pbWFwLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL21pbmltYXAuaW50ZXJmYWNlJzsiXX0=
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvbWluaW1hcC9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLHFCQUFxQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9taW5pbWFwLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL21pbmltYXAuaW50ZXJmYWNlJztcbiJdfQ==
@@ -11,8 +11,8 @@ export class LibsUiComponentsMinimapDirective {
11
11
  onDestroy = new Subject();
12
12
  // #endregion
13
13
  // #region INPUT
14
- classNameFlagElementScale = input('libs-ui-minimap-flag-element-scale', { transform: val => val ?? 'libs-ui-minimap-flag-element-scale' });
15
- timerStartDrawMinimap = input(250, { transform: val => val ?? 250 });
14
+ classNameFlagElementScale = input('libs-ui-minimap-flag-element-scale', { transform: (val) => val ?? 'libs-ui-minimap-flag-element-scale' });
15
+ timerStartDrawMinimap = input(250, { transform: (val) => val ?? 250 });
16
16
  elementScroll = input();
17
17
  styleRectangleElement = input();
18
18
  styleImageElement = input();
@@ -32,21 +32,26 @@ export class LibsUiComponentsMinimapDirective {
32
32
  this.containerElement?.remove();
33
33
  observer.disconnect();
34
34
  });
35
- timer(this.timerStartDrawMinimap()).pipe(tap(() => {
35
+ timer(this.timerStartDrawMinimap())
36
+ .pipe(tap(() => {
36
37
  this.imgElementInitStyleAndAddToBody();
37
38
  this.viewPortElementInitStyleAndAddToImgElement();
38
39
  const rectImage = this.imgElement.getBoundingClientRect();
39
40
  this.setPositionRectangle(rectImage, { clientX: rectImage.x, clientY: rectImage.y });
40
41
  this.updateMiniMap();
41
- this.outFunctionControls.emit({
42
- show: this.show.bind(this),
43
- hidden: this.hidden.bind(this),
44
- toggle: this.toggle.bind(this)
45
- });
42
+ this.outFunctionControls.emit(this.FunctionsControl);
46
43
  this.initEvent();
47
- }), takeUntil(this.onDestroy)).subscribe();
44
+ }), takeUntil(this.onDestroy))
45
+ .subscribe();
48
46
  }
49
47
  // #region FUNCTIONS
48
+ get FunctionsControl() {
49
+ return {
50
+ show: this.show.bind(this),
51
+ hidden: this.hidden.bind(this),
52
+ toggle: this.toggle.bind(this),
53
+ };
54
+ }
50
55
  imgElementInitStyleAndAddToBody() {
51
56
  const rectElement = this.Element.getBoundingClientRect();
52
57
  this.containerElement.classList.add('fixed', 'flex', 'invisible', 'libs-ui-directive-minimap-container', 'select-none');
@@ -57,7 +62,7 @@ export class LibsUiComponentsMinimapDirective {
57
62
  border: `${this.styleImageElement()?.border ?? '1px solid #E6E7EA'}`,
58
63
  borderRadius: `${this.styleImageElement()?.borderRadius ?? '4px'}`,
59
64
  width: `${this.styleImageElement()?.width ?? '198'}px`,
60
- height: `${this.styleImageElement()?.height ?? '108'}px`
65
+ height: `${this.styleImageElement()?.height ?? '108'}px`,
61
66
  }, this.renderer2);
62
67
  this.styleRectTopBottomElement(rectElement);
63
68
  this.styleRectLeftRightElement(rectElement);
@@ -71,7 +76,7 @@ export class LibsUiComponentsMinimapDirective {
71
76
  background: `${this.styleRectangleElement()?.background ?? 'transparent'}`,
72
77
  border: `${this.styleRectangleElement()?.border ?? 'none'}`,
73
78
  borderRadius: `${this.styleRectangleElement()?.borderRadius ?? '0'}`,
74
- cursor: 'grab'
79
+ cursor: 'grab',
75
80
  }, this.renderer2);
76
81
  this.containerElement.appendChild(this.viewPortElement);
77
82
  }
@@ -98,7 +103,7 @@ export class LibsUiComponentsMinimapDirective {
98
103
  if (event.type === 'scroll') {
99
104
  event = {
100
105
  clientX: this.Element.scrollLeft * ratioX + rectImage.left + rectViewPort.width / 2,
101
- clientY: this.Element.scrollTop * ratioY + rectImage.top + rectViewPort.height / 2
106
+ clientY: this.Element.scrollTop * ratioY + rectImage.top + rectViewPort.height / 2,
102
107
  };
103
108
  this.setPositionRectangle(rectImage, event);
104
109
  return;
@@ -115,12 +120,16 @@ export class LibsUiComponentsMinimapDirective {
115
120
  preEvent = event;
116
121
  this.Element.scroll({
117
122
  left: this.Element.scrollLeft + distanceX,
118
- top: this.Element.scrollTop + distanceY
123
+ top: this.Element.scrollTop + distanceY,
119
124
  });
120
125
  };
121
126
  getDragEventByElement({ elementMouseDown: this.viewPortElement, elementMouseMove: this.viewPortElement, isStartWithMouseDownEvent: true, onDestroy: this.onDestroy }).subscribe(handlerScrollElement);
122
- fromEvent(this.Element, 'scroll').pipe(tap(event => event.stopPropagation()), takeUntil(this.onDestroy)).subscribe((event) => handlerScrollElement(event));
123
- fromEvent(window, 'resize').pipe(tap(event => event.stopPropagation()), takeUntil(this.onDestroy)).subscribe(this.updateMiniMap.bind(this));
127
+ fromEvent(this.Element, 'scroll')
128
+ .pipe(tap((event) => event.stopPropagation()), takeUntil(this.onDestroy))
129
+ .subscribe((event) => handlerScrollElement(event));
130
+ fromEvent(window, 'resize')
131
+ .pipe(tap((event) => event.stopPropagation()), takeUntil(this.onDestroy))
132
+ .subscribe(this.updateMiniMap.bind(this));
124
133
  }
125
134
  getRatio() {
126
135
  const rectContainer = this.containerElement.getBoundingClientRect();
@@ -133,7 +142,7 @@ export class LibsUiComponentsMinimapDirective {
133
142
  const elementScale = this.Element.getElementsByClassName(this.classNameFlagElementScale())?.[0];
134
143
  if (elementScale && getComputedStyle(elementScale).transform) {
135
144
  const matrix = getComputedStyle(this.Element.getElementsByClassName(this.classNameFlagElementScale())[0]).transform;
136
- const matrixArray = matrix.replace("matrix(", "").split(",");
145
+ const matrixArray = matrix.replace('matrix(', '').split(',');
137
146
  console.log('matrixArray', matrixArray);
138
147
  scaleX = parseFloat(matrixArray[0]); // convert from string to number
139
148
  scaleY = parseFloat(matrixArray[3]);
@@ -188,7 +197,7 @@ export class LibsUiComponentsMinimapDirective {
188
197
  const rectImage = this.imgElement.getBoundingClientRect();
189
198
  const event = {
190
199
  clientX: this.Element.scrollLeft * ratioX + rectImage.left + viewPortElement.width / 2,
191
- clientY: this.Element.scrollTop * ratioY + rectImage.top + viewPortElement.height / 2
200
+ clientY: this.Element.scrollTop * ratioY + rectImage.top + viewPortElement.height / 2,
192
201
  };
193
202
  nodeClone.style.transform = `scale(${ratioX},${ratioY}) translate(-${translateX}px,-${translateY}px)`;
194
203
  this.setPositionRectangle(rectImage, event);
@@ -225,8 +234,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
225
234
  type: Directive,
226
235
  args: [{
227
236
  // eslint-disable-next-line @angular-eslint/directive-selector
228
- selector: "[LibsUiComponentsMinimapDirective]",
237
+ selector: '[LibsUiComponentsMinimapDirective]',
229
238
  standalone: true,
230
239
  }]
231
240
  }] });
232
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"minimap.directive.js","sourceRoot":"","sources":["../../../../../libs-ui/components/minimap/src/minimap.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Directive, ElementRef, inject, input, OnDestroy, output, Renderer2, signal } from '@angular/core';\nimport { IBoundingClientRect } from '@libs-ui/interfaces-types';\nimport { getDragEventByElement, setStylesElement } from '@libs-ui/utils';\nimport { fromEvent, Subject, takeUntil, tap, timer } from 'rxjs';\nimport { IMiniMapFunctionControl, IMiniMapStyleConfig } from './minimap.interface';\n@Directive({\n  // eslint-disable-next-line @angular-eslint/directive-selector\n  selector: \"[LibsUiComponentsMinimapDirective]\",\n  standalone: true,\n})\nexport class LibsUiComponentsMinimapDirective implements AfterViewInit, OnDestroy {\n  // #region PROPERTY\n  private isShow = signal<boolean>(false);\n  private containerElement: HTMLElement = document.createElement('DIV');\n  private imgElement: HTMLElement = document.createElement('DIV');\n  private viewPortElement = document.createElement('DIV');\n  private onDestroy = new Subject<void>();\n  // #endregion\n\n  // #region INPUT\n  readonly classNameFlagElementScale = input<string, string | undefined>('libs-ui-minimap-flag-element-scale', { transform: val => val ?? 'libs-ui-minimap-flag-element-scale' });\n  readonly timerStartDrawMinimap = input<number, number | undefined>(250, { transform: val => val ?? 250 });\n  readonly elementScroll = input<HTMLElement>();\n  readonly styleRectangleElement = input<IMiniMapStyleConfig>();\n  readonly styleImageElement = input<IMiniMapStyleConfig>();\n  // #endregion\n\n  // #region OUTPUT\n  readonly outFunctionControls = output<IMiniMapFunctionControl>();\n  // #endregion\n\n  // #region INJECT\n  private elementRef = inject(ElementRef);\n  private renderer2 = inject(Renderer2);\n  // #endregion\n\n  ngAfterViewInit(): void {\n    const config = { attributes: true, childList: true, subtree: true };\n    const observer = new MutationObserver(this.updateMiniMap.bind(this));\n\n    observer.observe(this.Element, config);\n    this.onDestroy.subscribe(() => {\n      this.containerElement?.remove();\n      observer.disconnect();\n    });\n\n    timer(this.timerStartDrawMinimap()).pipe(tap(() => {\n      this.imgElementInitStyleAndAddToBody();\n      this.viewPortElementInitStyleAndAddToImgElement();\n\n      const rectImage = this.imgElement.getBoundingClientRect();\n\n      this.setPositionRectangle(rectImage, { clientX: rectImage.x, clientY: rectImage.y });\n      this.updateMiniMap();\n      this.outFunctionControls.emit({\n        show: this.show.bind(this),\n        hidden: this.hidden.bind(this),\n        toggle: this.toggle.bind(this)\n      });\n      this.initEvent();\n    }),\n      takeUntil(this.onDestroy)).subscribe();\n  }\n\n  // #region FUNCTIONS\n  private imgElementInitStyleAndAddToBody() {\n    const rectElement = this.Element.getBoundingClientRect();\n\n    this.containerElement.classList.add('fixed', 'flex', 'invisible', 'libs-ui-directive-minimap-container','select-none');\n    this.imgElement.classList.add('relative', 'w-full', 'h-full', 'overflow-hidden');\n    setStylesElement(this.containerElement, {\n      zIndex: `${this.styleImageElement()?.zIndex ?? '1300'}`,\n      background: `${this.styleImageElement()?.background ?? 'white'}`,\n      border: `${this.styleImageElement()?.border ?? '1px solid #E6E7EA'}`,\n      borderRadius: `${this.styleImageElement()?.borderRadius ?? '4px'}`,\n      width: `${this.styleImageElement()?.width ?? '198'}px`,\n      height: `${this.styleImageElement()?.height ?? '108'}px`\n    }, this.renderer2);\n    this.styleRectTopBottomElement(rectElement);\n    this.styleRectLeftRightElement(rectElement);\n    this.containerElement.append(this.imgElement);\n    document.body.appendChild(this.containerElement);\n  }\n\n  private viewPortElementInitStyleAndAddToImgElement() {\n    this.viewPortElement.classList.add('fixed', 'libs-ui-border-primary-general', 'invisible', 'libs-ui-directive-minimap-rectangle');\n    setStylesElement(this.viewPortElement as unknown as HTMLElement, {\n      zIndex: `${this.styleRectangleElement()?.zIndex ?? '1301'}`,\n      background: `${this.styleRectangleElement()?.background ?? 'transparent'}`,\n      border: `${this.styleRectangleElement()?.border ?? 'none'}`,\n      borderRadius: `${this.styleRectangleElement()?.borderRadius ?? '0'}`,\n      cursor: 'grab'\n    }, this.renderer2);\n    this.containerElement.appendChild(this.viewPortElement);\n  }\n\n  private styleRectTopBottomElement(rectElement: DOMRect) {\n    if (this.styleImageElement()?.bottom) {\n      this.containerElement.style.bottom = `${this.styleImageElement()?.bottom}px`;\n\n      return;\n    }\n    this.containerElement.style.top = `${this.styleImageElement()?.top ?? rectElement.top}px`;\n  }\n  private styleRectLeftRightElement(rectElement: DOMRect) {\n    if (this.styleImageElement()?.right) {\n      this.containerElement.style.right = `${this.styleImageElement()?.right}px`;\n\n      return;\n    }\n    this.containerElement.style.left = `${this.styleImageElement()?.left ?? rectElement.left}px`;\n  }\n\n  private initEvent() {\n    let preEvent: MouseEvent;\n    const handlerScrollElement = (event: MouseEvent) => {\n      const rectViewPort = this.viewPortElement.getBoundingClientRect();\n      const rectImage = this.imgElement.getBoundingClientRect();\n      const { ratioX, ratioY } = this.getRatio();\n\n      if (event.type === 'scroll') {\n        event = {\n          clientX: this.Element.scrollLeft * ratioX + rectImage.left + rectViewPort.width / 2,\n          clientY: this.Element.scrollTop * ratioY + rectImage.top + rectViewPort.height / 2\n        } as MouseEvent;\n        this.setPositionRectangle(rectImage, event);\n\n        return;\n      }\n      if (event.type === 'mousedown') {\n        preEvent = event;\n\n        return;\n      }\n      if (!preEvent) {\n        return;\n      }\n\n      const distanceX = (event.clientX - preEvent.clientX) / ratioX;\n      const distanceY = (event.clientY - preEvent.clientY) / ratioY;\n\n      preEvent = event;\n      this.Element.scroll({\n        left: this.Element.scrollLeft + distanceX,\n        top: this.Element.scrollTop + distanceY\n      });\n    };\n\n    getDragEventByElement({ elementMouseDown: this.viewPortElement, elementMouseMove: this.viewPortElement,isStartWithMouseDownEvent:true, onDestroy: this.onDestroy }).subscribe(handlerScrollElement);\n    fromEvent<Event>(this.Element, 'scroll').pipe(tap(event => event.stopPropagation()), takeUntil(this.onDestroy)).subscribe((event) => handlerScrollElement(event as MouseEvent));\n    fromEvent<Event>(window, 'resize').pipe(tap(event => event.stopPropagation()), takeUntil(this.onDestroy)).subscribe(this.updateMiniMap.bind(this));\n  }\n\n  private getRatio() {\n    const rectContainer = this.containerElement.getBoundingClientRect();\n    const ratioX = rectContainer.width / this.Element.scrollWidth;\n    const ratioY = rectContainer.height / this.Element.scrollHeight;\n\n    return { ratioX: ratioX, ratioY: ratioY };\n  }\n  private getScaleElement() {\n    let { scaleX, scaleY } = { scaleX: 1, scaleY: 1 };\n    const elementScale = this.Element.getElementsByClassName(this.classNameFlagElementScale())?.[0] as HTMLElement;\n\n    if (elementScale && getComputedStyle(elementScale).transform) {\n      const matrix = getComputedStyle(this.Element.getElementsByClassName(this.classNameFlagElementScale())[0]).transform;\n      const matrixArray = matrix.replace(\"matrix(\", \"\").split(\",\");\n      console.log('matrixArray',matrixArray);\n\n      scaleX = parseFloat(matrixArray[0]); // convert from string to number\n      scaleY = parseFloat(matrixArray[3]);\n    }\n\n    return { scaleX, scaleY, elementScale };\n  }\n\n  private reverseMultiplication(avg1: number, avg2: number) {\n    if (avg2 <= 1) {\n      return avg1 * avg2;\n    }\n\n    return avg1 / avg2;\n  }\n\n  private setPositionRectangle(rectImage: IBoundingClientRect, mousePosition: { clientX: number, clientY: number }) {\n    const { ratioX, ratioY } = this.getRatio();\n    const { scaleX, scaleY } = this.getScaleElement();\n\n    const width = this.Element.clientWidth * this.reverseMultiplication(ratioX, scaleX);\n    const height = this.Element.clientHeight * this.reverseMultiplication(ratioY, scaleY);\n    let leftSvg = mousePosition.clientX - width / 2;\n    let topSvg = mousePosition.clientY - height / 2;\n\n    if (leftSvg < rectImage.left) {\n      leftSvg = rectImage.left;\n    }\n    if (leftSvg + width >= rectImage.left + rectImage.width) {\n      leftSvg = rectImage.left + rectImage.width - width;\n    }\n    if (topSvg < rectImage.top) {\n      topSvg = rectImage.top;\n    }\n    if (topSvg + height >= rectImage.top + rectImage.height) {\n      topSvg = rectImage.top + rectImage.height - height;\n    }\n    this.viewPortElement.style.left = `${leftSvg}px`;\n    this.viewPortElement.style.top = `${topSvg}px`;\n    this.viewPortElement.style.width = `${width}px`;\n    this.viewPortElement.style.height = `${Math.round(height)}px`;\n  }\n\n  private updateMiniMap() {\n    this.imgElement.firstElementChild?.remove();\n    let { ratioX, ratioY } = this.getRatio();\n    const nodeClone = this.Element.cloneNode(true) as HTMLElement;\n    nodeClone.style.width = `${this.Element.scrollWidth}px`;\n    nodeClone.style.height = `${this.Element.scrollHeight}px`;\n    const { scaleX, scaleY } = this.getScaleElement();\n\n    ratioX = this.reverseMultiplication(ratioX, scaleX);\n    ratioY = this.reverseMultiplication(ratioY, scaleY);\n    nodeClone.style.transform = `scale(${ratioX},${ratioY})`;\n    nodeClone.classList.add('overflow-unset','select-none','pointer-events-none');\n    this.imgElement.append(nodeClone);\n\n    const translateX = (nodeClone.getBoundingClientRect().left - this.imgElement.getBoundingClientRect().left) / ratioX;\n    const translateY = (nodeClone.getBoundingClientRect().top - this.imgElement.getBoundingClientRect().top) / ratioY;\n    const viewPortElement = this.viewPortElement.getBoundingClientRect();\n    const rectImage = this.imgElement.getBoundingClientRect();\n    const event = {\n      clientX: this.Element.scrollLeft * ratioX + rectImage.left + viewPortElement.width / 2,\n      clientY: this.Element.scrollTop * ratioY + rectImage.top + viewPortElement.height / 2\n    } as MouseEvent;\n\n    nodeClone.style.transform = `scale(${ratioX},${ratioY}) translate(-${translateX}px,-${translateY}px)`;\n    this.setPositionRectangle(rectImage, event);\n  }\n\n  private toggle() {\n    if (this.isShow()) {\n      this.hidden();\n\n      return;\n    }\n\n    this.show();\n  }\n\n  private hidden() {\n    this.isShow.set(false);\n    this.containerElement?.classList.add('invisible');\n    this.viewPortElement.classList.add('invisible');\n  }\n\n  private show() {\n    this.isShow.set(true);\n    this.containerElement?.classList.remove('invisible');\n    this.viewPortElement.classList.remove('invisible');\n  }\n\n  private get Element(): HTMLElement {\n    return this.elementScroll() || this.elementRef.nativeElement;\n  }\n\n  // #endregion\n  ngOnDestroy(): void {\n    this.onDestroy.next();\n    this.onDestroy.complete();\n  }\n}"]}
241
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"minimap.directive.js","sourceRoot":"","sources":["../../../../../libs-ui/components/minimap/src/minimap.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Directive, ElementRef, inject, input, OnDestroy, output, Renderer2, signal } from '@angular/core';\nimport { IBoundingClientRect } from '@libs-ui/interfaces-types';\nimport { getDragEventByElement, setStylesElement } from '@libs-ui/utils';\nimport { fromEvent, Subject, takeUntil, tap, timer } from 'rxjs';\nimport { IMiniMapFunctionControl, IMiniMapStyleConfig } from './minimap.interface';\n@Directive({\n  // eslint-disable-next-line @angular-eslint/directive-selector\n  selector: '[LibsUiComponentsMinimapDirective]',\n  standalone: true,\n})\nexport class LibsUiComponentsMinimapDirective implements AfterViewInit, OnDestroy {\n  // #region PROPERTY\n  private isShow = signal<boolean>(false);\n  private containerElement: HTMLElement = document.createElement('DIV');\n  private imgElement: HTMLElement = document.createElement('DIV');\n  private viewPortElement = document.createElement('DIV');\n  private onDestroy = new Subject<void>();\n  // #endregion\n\n  // #region INPUT\n  readonly classNameFlagElementScale = input<string, string | undefined>('libs-ui-minimap-flag-element-scale', { transform: (val) => val ?? 'libs-ui-minimap-flag-element-scale' });\n  readonly timerStartDrawMinimap = input<number, number | undefined>(250, { transform: (val) => val ?? 250 });\n  readonly elementScroll = input<HTMLElement>();\n  readonly styleRectangleElement = input<IMiniMapStyleConfig>();\n  readonly styleImageElement = input<IMiniMapStyleConfig>();\n  // #endregion\n\n  // #region OUTPUT\n  readonly outFunctionControls = output<IMiniMapFunctionControl>();\n  // #endregion\n\n  // #region INJECT\n  private elementRef = inject(ElementRef);\n  private renderer2 = inject(Renderer2);\n  // #endregion\n\n  ngAfterViewInit(): void {\n    const config = { attributes: true, childList: true, subtree: true };\n    const observer = new MutationObserver(this.updateMiniMap.bind(this));\n\n    observer.observe(this.Element, config);\n    this.onDestroy.subscribe(() => {\n      this.containerElement?.remove();\n      observer.disconnect();\n    });\n\n    timer(this.timerStartDrawMinimap())\n      .pipe(\n        tap(() => {\n          this.imgElementInitStyleAndAddToBody();\n          this.viewPortElementInitStyleAndAddToImgElement();\n\n          const rectImage = this.imgElement.getBoundingClientRect();\n\n          this.setPositionRectangle(rectImage, { clientX: rectImage.x, clientY: rectImage.y });\n          this.updateMiniMap();\n          this.outFunctionControls.emit(this.FunctionsControl);\n          this.initEvent();\n        }),\n        takeUntil(this.onDestroy)\n      )\n      .subscribe();\n  }\n\n  // #region FUNCTIONS\n  public get FunctionsControl(): IMiniMapFunctionControl {\n    return {\n      show: this.show.bind(this),\n      hidden: this.hidden.bind(this),\n      toggle: this.toggle.bind(this),\n    };\n  }\n\n  private imgElementInitStyleAndAddToBody() {\n    const rectElement = this.Element.getBoundingClientRect();\n\n    this.containerElement.classList.add('fixed', 'flex', 'invisible', 'libs-ui-directive-minimap-container', 'select-none');\n    this.imgElement.classList.add('relative', 'w-full', 'h-full', 'overflow-hidden');\n    setStylesElement(\n      this.containerElement,\n      {\n        zIndex: `${this.styleImageElement()?.zIndex ?? '1300'}`,\n        background: `${this.styleImageElement()?.background ?? 'white'}`,\n        border: `${this.styleImageElement()?.border ?? '1px solid #E6E7EA'}`,\n        borderRadius: `${this.styleImageElement()?.borderRadius ?? '4px'}`,\n        width: `${this.styleImageElement()?.width ?? '198'}px`,\n        height: `${this.styleImageElement()?.height ?? '108'}px`,\n      },\n      this.renderer2\n    );\n    this.styleRectTopBottomElement(rectElement);\n    this.styleRectLeftRightElement(rectElement);\n    this.containerElement.append(this.imgElement);\n    document.body.appendChild(this.containerElement);\n  }\n\n  private viewPortElementInitStyleAndAddToImgElement() {\n    this.viewPortElement.classList.add('fixed', 'libs-ui-border-primary-general', 'invisible', 'libs-ui-directive-minimap-rectangle');\n    setStylesElement(\n      this.viewPortElement as unknown as HTMLElement,\n      {\n        zIndex: `${this.styleRectangleElement()?.zIndex ?? '1301'}`,\n        background: `${this.styleRectangleElement()?.background ?? 'transparent'}`,\n        border: `${this.styleRectangleElement()?.border ?? 'none'}`,\n        borderRadius: `${this.styleRectangleElement()?.borderRadius ?? '0'}`,\n        cursor: 'grab',\n      },\n      this.renderer2\n    );\n    this.containerElement.appendChild(this.viewPortElement);\n  }\n\n  private styleRectTopBottomElement(rectElement: DOMRect) {\n    if (this.styleImageElement()?.bottom) {\n      this.containerElement.style.bottom = `${this.styleImageElement()?.bottom}px`;\n\n      return;\n    }\n    this.containerElement.style.top = `${this.styleImageElement()?.top ?? rectElement.top}px`;\n  }\n  private styleRectLeftRightElement(rectElement: DOMRect) {\n    if (this.styleImageElement()?.right) {\n      this.containerElement.style.right = `${this.styleImageElement()?.right}px`;\n\n      return;\n    }\n    this.containerElement.style.left = `${this.styleImageElement()?.left ?? rectElement.left}px`;\n  }\n\n  private initEvent() {\n    let preEvent: MouseEvent;\n    const handlerScrollElement = (event: MouseEvent) => {\n      const rectViewPort = this.viewPortElement.getBoundingClientRect();\n      const rectImage = this.imgElement.getBoundingClientRect();\n      const { ratioX, ratioY } = this.getRatio();\n\n      if (event.type === 'scroll') {\n        event = {\n          clientX: this.Element.scrollLeft * ratioX + rectImage.left + rectViewPort.width / 2,\n          clientY: this.Element.scrollTop * ratioY + rectImage.top + rectViewPort.height / 2,\n        } as MouseEvent;\n        this.setPositionRectangle(rectImage, event);\n\n        return;\n      }\n      if (event.type === 'mousedown') {\n        preEvent = event;\n\n        return;\n      }\n      if (!preEvent) {\n        return;\n      }\n\n      const distanceX = (event.clientX - preEvent.clientX) / ratioX;\n      const distanceY = (event.clientY - preEvent.clientY) / ratioY;\n\n      preEvent = event;\n      this.Element.scroll({\n        left: this.Element.scrollLeft + distanceX,\n        top: this.Element.scrollTop + distanceY,\n      });\n    };\n\n    getDragEventByElement({ elementMouseDown: this.viewPortElement, elementMouseMove: this.viewPortElement, isStartWithMouseDownEvent: true, onDestroy: this.onDestroy }).subscribe(handlerScrollElement);\n    fromEvent<Event>(this.Element, 'scroll')\n      .pipe(\n        tap((event) => event.stopPropagation()),\n        takeUntil(this.onDestroy)\n      )\n      .subscribe((event) => handlerScrollElement(event as MouseEvent));\n    fromEvent<Event>(window, 'resize')\n      .pipe(\n        tap((event) => event.stopPropagation()),\n        takeUntil(this.onDestroy)\n      )\n      .subscribe(this.updateMiniMap.bind(this));\n  }\n\n  private getRatio() {\n    const rectContainer = this.containerElement.getBoundingClientRect();\n    const ratioX = rectContainer.width / this.Element.scrollWidth;\n    const ratioY = rectContainer.height / this.Element.scrollHeight;\n\n    return { ratioX: ratioX, ratioY: ratioY };\n  }\n  private getScaleElement() {\n    let { scaleX, scaleY } = { scaleX: 1, scaleY: 1 };\n    const elementScale = this.Element.getElementsByClassName(this.classNameFlagElementScale())?.[0] as HTMLElement;\n\n    if (elementScale && getComputedStyle(elementScale).transform) {\n      const matrix = getComputedStyle(this.Element.getElementsByClassName(this.classNameFlagElementScale())[0]).transform;\n      const matrixArray = matrix.replace('matrix(', '').split(',');\n      console.log('matrixArray', matrixArray);\n\n      scaleX = parseFloat(matrixArray[0]); // convert from string to number\n      scaleY = parseFloat(matrixArray[3]);\n    }\n\n    return { scaleX, scaleY, elementScale };\n  }\n\n  private reverseMultiplication(avg1: number, avg2: number) {\n    if (avg2 <= 1) {\n      return avg1 * avg2;\n    }\n\n    return avg1 / avg2;\n  }\n\n  private setPositionRectangle(rectImage: IBoundingClientRect, mousePosition: { clientX: number; clientY: number }) {\n    const { ratioX, ratioY } = this.getRatio();\n    const { scaleX, scaleY } = this.getScaleElement();\n\n    const width = this.Element.clientWidth * this.reverseMultiplication(ratioX, scaleX);\n    const height = this.Element.clientHeight * this.reverseMultiplication(ratioY, scaleY);\n    let leftSvg = mousePosition.clientX - width / 2;\n    let topSvg = mousePosition.clientY - height / 2;\n\n    if (leftSvg < rectImage.left) {\n      leftSvg = rectImage.left;\n    }\n    if (leftSvg + width >= rectImage.left + rectImage.width) {\n      leftSvg = rectImage.left + rectImage.width - width;\n    }\n    if (topSvg < rectImage.top) {\n      topSvg = rectImage.top;\n    }\n    if (topSvg + height >= rectImage.top + rectImage.height) {\n      topSvg = rectImage.top + rectImage.height - height;\n    }\n    this.viewPortElement.style.left = `${leftSvg}px`;\n    this.viewPortElement.style.top = `${topSvg}px`;\n    this.viewPortElement.style.width = `${width}px`;\n    this.viewPortElement.style.height = `${Math.round(height)}px`;\n  }\n\n  private updateMiniMap() {\n    this.imgElement.firstElementChild?.remove();\n    let { ratioX, ratioY } = this.getRatio();\n    const nodeClone = this.Element.cloneNode(true) as HTMLElement;\n    nodeClone.style.width = `${this.Element.scrollWidth}px`;\n    nodeClone.style.height = `${this.Element.scrollHeight}px`;\n    const { scaleX, scaleY } = this.getScaleElement();\n\n    ratioX = this.reverseMultiplication(ratioX, scaleX);\n    ratioY = this.reverseMultiplication(ratioY, scaleY);\n    nodeClone.style.transform = `scale(${ratioX},${ratioY})`;\n    nodeClone.classList.add('overflow-unset', 'select-none', 'pointer-events-none');\n    this.imgElement.append(nodeClone);\n\n    const translateX = (nodeClone.getBoundingClientRect().left - this.imgElement.getBoundingClientRect().left) / ratioX;\n    const translateY = (nodeClone.getBoundingClientRect().top - this.imgElement.getBoundingClientRect().top) / ratioY;\n    const viewPortElement = this.viewPortElement.getBoundingClientRect();\n    const rectImage = this.imgElement.getBoundingClientRect();\n    const event = {\n      clientX: this.Element.scrollLeft * ratioX + rectImage.left + viewPortElement.width / 2,\n      clientY: this.Element.scrollTop * ratioY + rectImage.top + viewPortElement.height / 2,\n    } as MouseEvent;\n\n    nodeClone.style.transform = `scale(${ratioX},${ratioY}) translate(-${translateX}px,-${translateY}px)`;\n    this.setPositionRectangle(rectImage, event);\n  }\n\n  private toggle() {\n    if (this.isShow()) {\n      this.hidden();\n\n      return;\n    }\n\n    this.show();\n  }\n\n  private hidden() {\n    this.isShow.set(false);\n    this.containerElement?.classList.add('invisible');\n    this.viewPortElement.classList.add('invisible');\n  }\n\n  private show() {\n    this.isShow.set(true);\n    this.containerElement?.classList.remove('invisible');\n    this.viewPortElement.classList.remove('invisible');\n  }\n\n  private get Element(): HTMLElement {\n    return this.elementScroll() || this.elementRef.nativeElement;\n  }\n\n  // #endregion\n  ngOnDestroy(): void {\n    this.onDestroy.next();\n    this.onDestroy.complete();\n  }\n}\n"]}
@@ -12,8 +12,8 @@ class LibsUiComponentsMinimapDirective {
12
12
  onDestroy = new Subject();
13
13
  // #endregion
14
14
  // #region INPUT
15
- classNameFlagElementScale = input('libs-ui-minimap-flag-element-scale', { transform: val => val ?? 'libs-ui-minimap-flag-element-scale' });
16
- timerStartDrawMinimap = input(250, { transform: val => val ?? 250 });
15
+ classNameFlagElementScale = input('libs-ui-minimap-flag-element-scale', { transform: (val) => val ?? 'libs-ui-minimap-flag-element-scale' });
16
+ timerStartDrawMinimap = input(250, { transform: (val) => val ?? 250 });
17
17
  elementScroll = input();
18
18
  styleRectangleElement = input();
19
19
  styleImageElement = input();
@@ -33,21 +33,26 @@ class LibsUiComponentsMinimapDirective {
33
33
  this.containerElement?.remove();
34
34
  observer.disconnect();
35
35
  });
36
- timer(this.timerStartDrawMinimap()).pipe(tap(() => {
36
+ timer(this.timerStartDrawMinimap())
37
+ .pipe(tap(() => {
37
38
  this.imgElementInitStyleAndAddToBody();
38
39
  this.viewPortElementInitStyleAndAddToImgElement();
39
40
  const rectImage = this.imgElement.getBoundingClientRect();
40
41
  this.setPositionRectangle(rectImage, { clientX: rectImage.x, clientY: rectImage.y });
41
42
  this.updateMiniMap();
42
- this.outFunctionControls.emit({
43
- show: this.show.bind(this),
44
- hidden: this.hidden.bind(this),
45
- toggle: this.toggle.bind(this)
46
- });
43
+ this.outFunctionControls.emit(this.FunctionsControl);
47
44
  this.initEvent();
48
- }), takeUntil(this.onDestroy)).subscribe();
45
+ }), takeUntil(this.onDestroy))
46
+ .subscribe();
49
47
  }
50
48
  // #region FUNCTIONS
49
+ get FunctionsControl() {
50
+ return {
51
+ show: this.show.bind(this),
52
+ hidden: this.hidden.bind(this),
53
+ toggle: this.toggle.bind(this),
54
+ };
55
+ }
51
56
  imgElementInitStyleAndAddToBody() {
52
57
  const rectElement = this.Element.getBoundingClientRect();
53
58
  this.containerElement.classList.add('fixed', 'flex', 'invisible', 'libs-ui-directive-minimap-container', 'select-none');
@@ -58,7 +63,7 @@ class LibsUiComponentsMinimapDirective {
58
63
  border: `${this.styleImageElement()?.border ?? '1px solid #E6E7EA'}`,
59
64
  borderRadius: `${this.styleImageElement()?.borderRadius ?? '4px'}`,
60
65
  width: `${this.styleImageElement()?.width ?? '198'}px`,
61
- height: `${this.styleImageElement()?.height ?? '108'}px`
66
+ height: `${this.styleImageElement()?.height ?? '108'}px`,
62
67
  }, this.renderer2);
63
68
  this.styleRectTopBottomElement(rectElement);
64
69
  this.styleRectLeftRightElement(rectElement);
@@ -72,7 +77,7 @@ class LibsUiComponentsMinimapDirective {
72
77
  background: `${this.styleRectangleElement()?.background ?? 'transparent'}`,
73
78
  border: `${this.styleRectangleElement()?.border ?? 'none'}`,
74
79
  borderRadius: `${this.styleRectangleElement()?.borderRadius ?? '0'}`,
75
- cursor: 'grab'
80
+ cursor: 'grab',
76
81
  }, this.renderer2);
77
82
  this.containerElement.appendChild(this.viewPortElement);
78
83
  }
@@ -99,7 +104,7 @@ class LibsUiComponentsMinimapDirective {
99
104
  if (event.type === 'scroll') {
100
105
  event = {
101
106
  clientX: this.Element.scrollLeft * ratioX + rectImage.left + rectViewPort.width / 2,
102
- clientY: this.Element.scrollTop * ratioY + rectImage.top + rectViewPort.height / 2
107
+ clientY: this.Element.scrollTop * ratioY + rectImage.top + rectViewPort.height / 2,
103
108
  };
104
109
  this.setPositionRectangle(rectImage, event);
105
110
  return;
@@ -116,12 +121,16 @@ class LibsUiComponentsMinimapDirective {
116
121
  preEvent = event;
117
122
  this.Element.scroll({
118
123
  left: this.Element.scrollLeft + distanceX,
119
- top: this.Element.scrollTop + distanceY
124
+ top: this.Element.scrollTop + distanceY,
120
125
  });
121
126
  };
122
127
  getDragEventByElement({ elementMouseDown: this.viewPortElement, elementMouseMove: this.viewPortElement, isStartWithMouseDownEvent: true, onDestroy: this.onDestroy }).subscribe(handlerScrollElement);
123
- fromEvent(this.Element, 'scroll').pipe(tap(event => event.stopPropagation()), takeUntil(this.onDestroy)).subscribe((event) => handlerScrollElement(event));
124
- fromEvent(window, 'resize').pipe(tap(event => event.stopPropagation()), takeUntil(this.onDestroy)).subscribe(this.updateMiniMap.bind(this));
128
+ fromEvent(this.Element, 'scroll')
129
+ .pipe(tap((event) => event.stopPropagation()), takeUntil(this.onDestroy))
130
+ .subscribe((event) => handlerScrollElement(event));
131
+ fromEvent(window, 'resize')
132
+ .pipe(tap((event) => event.stopPropagation()), takeUntil(this.onDestroy))
133
+ .subscribe(this.updateMiniMap.bind(this));
125
134
  }
126
135
  getRatio() {
127
136
  const rectContainer = this.containerElement.getBoundingClientRect();
@@ -134,7 +143,7 @@ class LibsUiComponentsMinimapDirective {
134
143
  const elementScale = this.Element.getElementsByClassName(this.classNameFlagElementScale())?.[0];
135
144
  if (elementScale && getComputedStyle(elementScale).transform) {
136
145
  const matrix = getComputedStyle(this.Element.getElementsByClassName(this.classNameFlagElementScale())[0]).transform;
137
- const matrixArray = matrix.replace("matrix(", "").split(",");
146
+ const matrixArray = matrix.replace('matrix(', '').split(',');
138
147
  console.log('matrixArray', matrixArray);
139
148
  scaleX = parseFloat(matrixArray[0]); // convert from string to number
140
149
  scaleY = parseFloat(matrixArray[3]);
@@ -189,7 +198,7 @@ class LibsUiComponentsMinimapDirective {
189
198
  const rectImage = this.imgElement.getBoundingClientRect();
190
199
  const event = {
191
200
  clientX: this.Element.scrollLeft * ratioX + rectImage.left + viewPortElement.width / 2,
192
- clientY: this.Element.scrollTop * ratioY + rectImage.top + viewPortElement.height / 2
201
+ clientY: this.Element.scrollTop * ratioY + rectImage.top + viewPortElement.height / 2,
193
202
  };
194
203
  nodeClone.style.transform = `scale(${ratioX},${ratioY}) translate(-${translateX}px,-${translateY}px)`;
195
204
  this.setPositionRectangle(rectImage, event);
@@ -226,7 +235,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
226
235
  type: Directive,
227
236
  args: [{
228
237
  // eslint-disable-next-line @angular-eslint/directive-selector
229
- selector: "[LibsUiComponentsMinimapDirective]",
238
+ selector: '[LibsUiComponentsMinimapDirective]',
230
239
  standalone: true,
231
240
  }]
232
241
  }] });
@@ -1 +1 @@
1
- {"version":3,"file":"libs-ui-components-minimap.mjs","sources":["../../../../../libs-ui/components/minimap/src/minimap.directive.ts","../../../../../libs-ui/components/minimap/src/libs-ui-components-minimap.ts"],"sourcesContent":["import { AfterViewInit, Directive, ElementRef, inject, input, OnDestroy, output, Renderer2, signal } from '@angular/core';\nimport { IBoundingClientRect } from '@libs-ui/interfaces-types';\nimport { getDragEventByElement, setStylesElement } from '@libs-ui/utils';\nimport { fromEvent, Subject, takeUntil, tap, timer } from 'rxjs';\nimport { IMiniMapFunctionControl, IMiniMapStyleConfig } from './minimap.interface';\n@Directive({\n // eslint-disable-next-line @angular-eslint/directive-selector\n selector: \"[LibsUiComponentsMinimapDirective]\",\n standalone: true,\n})\nexport class LibsUiComponentsMinimapDirective implements AfterViewInit, OnDestroy {\n // #region PROPERTY\n private isShow = signal<boolean>(false);\n private containerElement: HTMLElement = document.createElement('DIV');\n private imgElement: HTMLElement = document.createElement('DIV');\n private viewPortElement = document.createElement('DIV');\n private onDestroy = new Subject<void>();\n // #endregion\n\n // #region INPUT\n readonly classNameFlagElementScale = input<string, string | undefined>('libs-ui-minimap-flag-element-scale', { transform: val => val ?? 'libs-ui-minimap-flag-element-scale' });\n readonly timerStartDrawMinimap = input<number, number | undefined>(250, { transform: val => val ?? 250 });\n readonly elementScroll = input<HTMLElement>();\n readonly styleRectangleElement = input<IMiniMapStyleConfig>();\n readonly styleImageElement = input<IMiniMapStyleConfig>();\n // #endregion\n\n // #region OUTPUT\n readonly outFunctionControls = output<IMiniMapFunctionControl>();\n // #endregion\n\n // #region INJECT\n private elementRef = inject(ElementRef);\n private renderer2 = inject(Renderer2);\n // #endregion\n\n ngAfterViewInit(): void {\n const config = { attributes: true, childList: true, subtree: true };\n const observer = new MutationObserver(this.updateMiniMap.bind(this));\n\n observer.observe(this.Element, config);\n this.onDestroy.subscribe(() => {\n this.containerElement?.remove();\n observer.disconnect();\n });\n\n timer(this.timerStartDrawMinimap()).pipe(tap(() => {\n this.imgElementInitStyleAndAddToBody();\n this.viewPortElementInitStyleAndAddToImgElement();\n\n const rectImage = this.imgElement.getBoundingClientRect();\n\n this.setPositionRectangle(rectImage, { clientX: rectImage.x, clientY: rectImage.y });\n this.updateMiniMap();\n this.outFunctionControls.emit({\n show: this.show.bind(this),\n hidden: this.hidden.bind(this),\n toggle: this.toggle.bind(this)\n });\n this.initEvent();\n }),\n takeUntil(this.onDestroy)).subscribe();\n }\n\n // #region FUNCTIONS\n private imgElementInitStyleAndAddToBody() {\n const rectElement = this.Element.getBoundingClientRect();\n\n this.containerElement.classList.add('fixed', 'flex', 'invisible', 'libs-ui-directive-minimap-container','select-none');\n this.imgElement.classList.add('relative', 'w-full', 'h-full', 'overflow-hidden');\n setStylesElement(this.containerElement, {\n zIndex: `${this.styleImageElement()?.zIndex ?? '1300'}`,\n background: `${this.styleImageElement()?.background ?? 'white'}`,\n border: `${this.styleImageElement()?.border ?? '1px solid #E6E7EA'}`,\n borderRadius: `${this.styleImageElement()?.borderRadius ?? '4px'}`,\n width: `${this.styleImageElement()?.width ?? '198'}px`,\n height: `${this.styleImageElement()?.height ?? '108'}px`\n }, this.renderer2);\n this.styleRectTopBottomElement(rectElement);\n this.styleRectLeftRightElement(rectElement);\n this.containerElement.append(this.imgElement);\n document.body.appendChild(this.containerElement);\n }\n\n private viewPortElementInitStyleAndAddToImgElement() {\n this.viewPortElement.classList.add('fixed', 'libs-ui-border-primary-general', 'invisible', 'libs-ui-directive-minimap-rectangle');\n setStylesElement(this.viewPortElement as unknown as HTMLElement, {\n zIndex: `${this.styleRectangleElement()?.zIndex ?? '1301'}`,\n background: `${this.styleRectangleElement()?.background ?? 'transparent'}`,\n border: `${this.styleRectangleElement()?.border ?? 'none'}`,\n borderRadius: `${this.styleRectangleElement()?.borderRadius ?? '0'}`,\n cursor: 'grab'\n }, this.renderer2);\n this.containerElement.appendChild(this.viewPortElement);\n }\n\n private styleRectTopBottomElement(rectElement: DOMRect) {\n if (this.styleImageElement()?.bottom) {\n this.containerElement.style.bottom = `${this.styleImageElement()?.bottom}px`;\n\n return;\n }\n this.containerElement.style.top = `${this.styleImageElement()?.top ?? rectElement.top}px`;\n }\n private styleRectLeftRightElement(rectElement: DOMRect) {\n if (this.styleImageElement()?.right) {\n this.containerElement.style.right = `${this.styleImageElement()?.right}px`;\n\n return;\n }\n this.containerElement.style.left = `${this.styleImageElement()?.left ?? rectElement.left}px`;\n }\n\n private initEvent() {\n let preEvent: MouseEvent;\n const handlerScrollElement = (event: MouseEvent) => {\n const rectViewPort = this.viewPortElement.getBoundingClientRect();\n const rectImage = this.imgElement.getBoundingClientRect();\n const { ratioX, ratioY } = this.getRatio();\n\n if (event.type === 'scroll') {\n event = {\n clientX: this.Element.scrollLeft * ratioX + rectImage.left + rectViewPort.width / 2,\n clientY: this.Element.scrollTop * ratioY + rectImage.top + rectViewPort.height / 2\n } as MouseEvent;\n this.setPositionRectangle(rectImage, event);\n\n return;\n }\n if (event.type === 'mousedown') {\n preEvent = event;\n\n return;\n }\n if (!preEvent) {\n return;\n }\n\n const distanceX = (event.clientX - preEvent.clientX) / ratioX;\n const distanceY = (event.clientY - preEvent.clientY) / ratioY;\n\n preEvent = event;\n this.Element.scroll({\n left: this.Element.scrollLeft + distanceX,\n top: this.Element.scrollTop + distanceY\n });\n };\n\n getDragEventByElement({ elementMouseDown: this.viewPortElement, elementMouseMove: this.viewPortElement,isStartWithMouseDownEvent:true, onDestroy: this.onDestroy }).subscribe(handlerScrollElement);\n fromEvent<Event>(this.Element, 'scroll').pipe(tap(event => event.stopPropagation()), takeUntil(this.onDestroy)).subscribe((event) => handlerScrollElement(event as MouseEvent));\n fromEvent<Event>(window, 'resize').pipe(tap(event => event.stopPropagation()), takeUntil(this.onDestroy)).subscribe(this.updateMiniMap.bind(this));\n }\n\n private getRatio() {\n const rectContainer = this.containerElement.getBoundingClientRect();\n const ratioX = rectContainer.width / this.Element.scrollWidth;\n const ratioY = rectContainer.height / this.Element.scrollHeight;\n\n return { ratioX: ratioX, ratioY: ratioY };\n }\n private getScaleElement() {\n let { scaleX, scaleY } = { scaleX: 1, scaleY: 1 };\n const elementScale = this.Element.getElementsByClassName(this.classNameFlagElementScale())?.[0] as HTMLElement;\n\n if (elementScale && getComputedStyle(elementScale).transform) {\n const matrix = getComputedStyle(this.Element.getElementsByClassName(this.classNameFlagElementScale())[0]).transform;\n const matrixArray = matrix.replace(\"matrix(\", \"\").split(\",\");\n console.log('matrixArray',matrixArray);\n\n scaleX = parseFloat(matrixArray[0]); // convert from string to number\n scaleY = parseFloat(matrixArray[3]);\n }\n\n return { scaleX, scaleY, elementScale };\n }\n\n private reverseMultiplication(avg1: number, avg2: number) {\n if (avg2 <= 1) {\n return avg1 * avg2;\n }\n\n return avg1 / avg2;\n }\n\n private setPositionRectangle(rectImage: IBoundingClientRect, mousePosition: { clientX: number, clientY: number }) {\n const { ratioX, ratioY } = this.getRatio();\n const { scaleX, scaleY } = this.getScaleElement();\n\n const width = this.Element.clientWidth * this.reverseMultiplication(ratioX, scaleX);\n const height = this.Element.clientHeight * this.reverseMultiplication(ratioY, scaleY);\n let leftSvg = mousePosition.clientX - width / 2;\n let topSvg = mousePosition.clientY - height / 2;\n\n if (leftSvg < rectImage.left) {\n leftSvg = rectImage.left;\n }\n if (leftSvg + width >= rectImage.left + rectImage.width) {\n leftSvg = rectImage.left + rectImage.width - width;\n }\n if (topSvg < rectImage.top) {\n topSvg = rectImage.top;\n }\n if (topSvg + height >= rectImage.top + rectImage.height) {\n topSvg = rectImage.top + rectImage.height - height;\n }\n this.viewPortElement.style.left = `${leftSvg}px`;\n this.viewPortElement.style.top = `${topSvg}px`;\n this.viewPortElement.style.width = `${width}px`;\n this.viewPortElement.style.height = `${Math.round(height)}px`;\n }\n\n private updateMiniMap() {\n this.imgElement.firstElementChild?.remove();\n let { ratioX, ratioY } = this.getRatio();\n const nodeClone = this.Element.cloneNode(true) as HTMLElement;\n nodeClone.style.width = `${this.Element.scrollWidth}px`;\n nodeClone.style.height = `${this.Element.scrollHeight}px`;\n const { scaleX, scaleY } = this.getScaleElement();\n\n ratioX = this.reverseMultiplication(ratioX, scaleX);\n ratioY = this.reverseMultiplication(ratioY, scaleY);\n nodeClone.style.transform = `scale(${ratioX},${ratioY})`;\n nodeClone.classList.add('overflow-unset','select-none','pointer-events-none');\n this.imgElement.append(nodeClone);\n\n const translateX = (nodeClone.getBoundingClientRect().left - this.imgElement.getBoundingClientRect().left) / ratioX;\n const translateY = (nodeClone.getBoundingClientRect().top - this.imgElement.getBoundingClientRect().top) / ratioY;\n const viewPortElement = this.viewPortElement.getBoundingClientRect();\n const rectImage = this.imgElement.getBoundingClientRect();\n const event = {\n clientX: this.Element.scrollLeft * ratioX + rectImage.left + viewPortElement.width / 2,\n clientY: this.Element.scrollTop * ratioY + rectImage.top + viewPortElement.height / 2\n } as MouseEvent;\n\n nodeClone.style.transform = `scale(${ratioX},${ratioY}) translate(-${translateX}px,-${translateY}px)`;\n this.setPositionRectangle(rectImage, event);\n }\n\n private toggle() {\n if (this.isShow()) {\n this.hidden();\n\n return;\n }\n\n this.show();\n }\n\n private hidden() {\n this.isShow.set(false);\n this.containerElement?.classList.add('invisible');\n this.viewPortElement.classList.add('invisible');\n }\n\n private show() {\n this.isShow.set(true);\n this.containerElement?.classList.remove('invisible');\n this.viewPortElement.classList.remove('invisible');\n }\n\n private get Element(): HTMLElement {\n return this.elementScroll() || this.elementRef.nativeElement;\n }\n\n // #endregion\n ngOnDestroy(): void {\n this.onDestroy.next();\n this.onDestroy.complete();\n }\n}","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"libs-ui-components-minimap.mjs","sources":["../../../../../libs-ui/components/minimap/src/minimap.directive.ts","../../../../../libs-ui/components/minimap/src/libs-ui-components-minimap.ts"],"sourcesContent":["import { AfterViewInit, Directive, ElementRef, inject, input, OnDestroy, output, Renderer2, signal } from '@angular/core';\nimport { IBoundingClientRect } from '@libs-ui/interfaces-types';\nimport { getDragEventByElement, setStylesElement } from '@libs-ui/utils';\nimport { fromEvent, Subject, takeUntil, tap, timer } from 'rxjs';\nimport { IMiniMapFunctionControl, IMiniMapStyleConfig } from './minimap.interface';\n@Directive({\n // eslint-disable-next-line @angular-eslint/directive-selector\n selector: '[LibsUiComponentsMinimapDirective]',\n standalone: true,\n})\nexport class LibsUiComponentsMinimapDirective implements AfterViewInit, OnDestroy {\n // #region PROPERTY\n private isShow = signal<boolean>(false);\n private containerElement: HTMLElement = document.createElement('DIV');\n private imgElement: HTMLElement = document.createElement('DIV');\n private viewPortElement = document.createElement('DIV');\n private onDestroy = new Subject<void>();\n // #endregion\n\n // #region INPUT\n readonly classNameFlagElementScale = input<string, string | undefined>('libs-ui-minimap-flag-element-scale', { transform: (val) => val ?? 'libs-ui-minimap-flag-element-scale' });\n readonly timerStartDrawMinimap = input<number, number | undefined>(250, { transform: (val) => val ?? 250 });\n readonly elementScroll = input<HTMLElement>();\n readonly styleRectangleElement = input<IMiniMapStyleConfig>();\n readonly styleImageElement = input<IMiniMapStyleConfig>();\n // #endregion\n\n // #region OUTPUT\n readonly outFunctionControls = output<IMiniMapFunctionControl>();\n // #endregion\n\n // #region INJECT\n private elementRef = inject(ElementRef);\n private renderer2 = inject(Renderer2);\n // #endregion\n\n ngAfterViewInit(): void {\n const config = { attributes: true, childList: true, subtree: true };\n const observer = new MutationObserver(this.updateMiniMap.bind(this));\n\n observer.observe(this.Element, config);\n this.onDestroy.subscribe(() => {\n this.containerElement?.remove();\n observer.disconnect();\n });\n\n timer(this.timerStartDrawMinimap())\n .pipe(\n tap(() => {\n this.imgElementInitStyleAndAddToBody();\n this.viewPortElementInitStyleAndAddToImgElement();\n\n const rectImage = this.imgElement.getBoundingClientRect();\n\n this.setPositionRectangle(rectImage, { clientX: rectImage.x, clientY: rectImage.y });\n this.updateMiniMap();\n this.outFunctionControls.emit(this.FunctionsControl);\n this.initEvent();\n }),\n takeUntil(this.onDestroy)\n )\n .subscribe();\n }\n\n // #region FUNCTIONS\n public get FunctionsControl(): IMiniMapFunctionControl {\n return {\n show: this.show.bind(this),\n hidden: this.hidden.bind(this),\n toggle: this.toggle.bind(this),\n };\n }\n\n private imgElementInitStyleAndAddToBody() {\n const rectElement = this.Element.getBoundingClientRect();\n\n this.containerElement.classList.add('fixed', 'flex', 'invisible', 'libs-ui-directive-minimap-container', 'select-none');\n this.imgElement.classList.add('relative', 'w-full', 'h-full', 'overflow-hidden');\n setStylesElement(\n this.containerElement,\n {\n zIndex: `${this.styleImageElement()?.zIndex ?? '1300'}`,\n background: `${this.styleImageElement()?.background ?? 'white'}`,\n border: `${this.styleImageElement()?.border ?? '1px solid #E6E7EA'}`,\n borderRadius: `${this.styleImageElement()?.borderRadius ?? '4px'}`,\n width: `${this.styleImageElement()?.width ?? '198'}px`,\n height: `${this.styleImageElement()?.height ?? '108'}px`,\n },\n this.renderer2\n );\n this.styleRectTopBottomElement(rectElement);\n this.styleRectLeftRightElement(rectElement);\n this.containerElement.append(this.imgElement);\n document.body.appendChild(this.containerElement);\n }\n\n private viewPortElementInitStyleAndAddToImgElement() {\n this.viewPortElement.classList.add('fixed', 'libs-ui-border-primary-general', 'invisible', 'libs-ui-directive-minimap-rectangle');\n setStylesElement(\n this.viewPortElement as unknown as HTMLElement,\n {\n zIndex: `${this.styleRectangleElement()?.zIndex ?? '1301'}`,\n background: `${this.styleRectangleElement()?.background ?? 'transparent'}`,\n border: `${this.styleRectangleElement()?.border ?? 'none'}`,\n borderRadius: `${this.styleRectangleElement()?.borderRadius ?? '0'}`,\n cursor: 'grab',\n },\n this.renderer2\n );\n this.containerElement.appendChild(this.viewPortElement);\n }\n\n private styleRectTopBottomElement(rectElement: DOMRect) {\n if (this.styleImageElement()?.bottom) {\n this.containerElement.style.bottom = `${this.styleImageElement()?.bottom}px`;\n\n return;\n }\n this.containerElement.style.top = `${this.styleImageElement()?.top ?? rectElement.top}px`;\n }\n private styleRectLeftRightElement(rectElement: DOMRect) {\n if (this.styleImageElement()?.right) {\n this.containerElement.style.right = `${this.styleImageElement()?.right}px`;\n\n return;\n }\n this.containerElement.style.left = `${this.styleImageElement()?.left ?? rectElement.left}px`;\n }\n\n private initEvent() {\n let preEvent: MouseEvent;\n const handlerScrollElement = (event: MouseEvent) => {\n const rectViewPort = this.viewPortElement.getBoundingClientRect();\n const rectImage = this.imgElement.getBoundingClientRect();\n const { ratioX, ratioY } = this.getRatio();\n\n if (event.type === 'scroll') {\n event = {\n clientX: this.Element.scrollLeft * ratioX + rectImage.left + rectViewPort.width / 2,\n clientY: this.Element.scrollTop * ratioY + rectImage.top + rectViewPort.height / 2,\n } as MouseEvent;\n this.setPositionRectangle(rectImage, event);\n\n return;\n }\n if (event.type === 'mousedown') {\n preEvent = event;\n\n return;\n }\n if (!preEvent) {\n return;\n }\n\n const distanceX = (event.clientX - preEvent.clientX) / ratioX;\n const distanceY = (event.clientY - preEvent.clientY) / ratioY;\n\n preEvent = event;\n this.Element.scroll({\n left: this.Element.scrollLeft + distanceX,\n top: this.Element.scrollTop + distanceY,\n });\n };\n\n getDragEventByElement({ elementMouseDown: this.viewPortElement, elementMouseMove: this.viewPortElement, isStartWithMouseDownEvent: true, onDestroy: this.onDestroy }).subscribe(handlerScrollElement);\n fromEvent<Event>(this.Element, 'scroll')\n .pipe(\n tap((event) => event.stopPropagation()),\n takeUntil(this.onDestroy)\n )\n .subscribe((event) => handlerScrollElement(event as MouseEvent));\n fromEvent<Event>(window, 'resize')\n .pipe(\n tap((event) => event.stopPropagation()),\n takeUntil(this.onDestroy)\n )\n .subscribe(this.updateMiniMap.bind(this));\n }\n\n private getRatio() {\n const rectContainer = this.containerElement.getBoundingClientRect();\n const ratioX = rectContainer.width / this.Element.scrollWidth;\n const ratioY = rectContainer.height / this.Element.scrollHeight;\n\n return { ratioX: ratioX, ratioY: ratioY };\n }\n private getScaleElement() {\n let { scaleX, scaleY } = { scaleX: 1, scaleY: 1 };\n const elementScale = this.Element.getElementsByClassName(this.classNameFlagElementScale())?.[0] as HTMLElement;\n\n if (elementScale && getComputedStyle(elementScale).transform) {\n const matrix = getComputedStyle(this.Element.getElementsByClassName(this.classNameFlagElementScale())[0]).transform;\n const matrixArray = matrix.replace('matrix(', '').split(',');\n console.log('matrixArray', matrixArray);\n\n scaleX = parseFloat(matrixArray[0]); // convert from string to number\n scaleY = parseFloat(matrixArray[3]);\n }\n\n return { scaleX, scaleY, elementScale };\n }\n\n private reverseMultiplication(avg1: number, avg2: number) {\n if (avg2 <= 1) {\n return avg1 * avg2;\n }\n\n return avg1 / avg2;\n }\n\n private setPositionRectangle(rectImage: IBoundingClientRect, mousePosition: { clientX: number; clientY: number }) {\n const { ratioX, ratioY } = this.getRatio();\n const { scaleX, scaleY } = this.getScaleElement();\n\n const width = this.Element.clientWidth * this.reverseMultiplication(ratioX, scaleX);\n const height = this.Element.clientHeight * this.reverseMultiplication(ratioY, scaleY);\n let leftSvg = mousePosition.clientX - width / 2;\n let topSvg = mousePosition.clientY - height / 2;\n\n if (leftSvg < rectImage.left) {\n leftSvg = rectImage.left;\n }\n if (leftSvg + width >= rectImage.left + rectImage.width) {\n leftSvg = rectImage.left + rectImage.width - width;\n }\n if (topSvg < rectImage.top) {\n topSvg = rectImage.top;\n }\n if (topSvg + height >= rectImage.top + rectImage.height) {\n topSvg = rectImage.top + rectImage.height - height;\n }\n this.viewPortElement.style.left = `${leftSvg}px`;\n this.viewPortElement.style.top = `${topSvg}px`;\n this.viewPortElement.style.width = `${width}px`;\n this.viewPortElement.style.height = `${Math.round(height)}px`;\n }\n\n private updateMiniMap() {\n this.imgElement.firstElementChild?.remove();\n let { ratioX, ratioY } = this.getRatio();\n const nodeClone = this.Element.cloneNode(true) as HTMLElement;\n nodeClone.style.width = `${this.Element.scrollWidth}px`;\n nodeClone.style.height = `${this.Element.scrollHeight}px`;\n const { scaleX, scaleY } = this.getScaleElement();\n\n ratioX = this.reverseMultiplication(ratioX, scaleX);\n ratioY = this.reverseMultiplication(ratioY, scaleY);\n nodeClone.style.transform = `scale(${ratioX},${ratioY})`;\n nodeClone.classList.add('overflow-unset', 'select-none', 'pointer-events-none');\n this.imgElement.append(nodeClone);\n\n const translateX = (nodeClone.getBoundingClientRect().left - this.imgElement.getBoundingClientRect().left) / ratioX;\n const translateY = (nodeClone.getBoundingClientRect().top - this.imgElement.getBoundingClientRect().top) / ratioY;\n const viewPortElement = this.viewPortElement.getBoundingClientRect();\n const rectImage = this.imgElement.getBoundingClientRect();\n const event = {\n clientX: this.Element.scrollLeft * ratioX + rectImage.left + viewPortElement.width / 2,\n clientY: this.Element.scrollTop * ratioY + rectImage.top + viewPortElement.height / 2,\n } as MouseEvent;\n\n nodeClone.style.transform = `scale(${ratioX},${ratioY}) translate(-${translateX}px,-${translateY}px)`;\n this.setPositionRectangle(rectImage, event);\n }\n\n private toggle() {\n if (this.isShow()) {\n this.hidden();\n\n return;\n }\n\n this.show();\n }\n\n private hidden() {\n this.isShow.set(false);\n this.containerElement?.classList.add('invisible');\n this.viewPortElement.classList.add('invisible');\n }\n\n private show() {\n this.isShow.set(true);\n this.containerElement?.classList.remove('invisible');\n this.viewPortElement.classList.remove('invisible');\n }\n\n private get Element(): HTMLElement {\n return this.elementScroll() || this.elementRef.nativeElement;\n }\n\n // #endregion\n ngOnDestroy(): void {\n this.onDestroy.next();\n this.onDestroy.complete();\n }\n}\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
@@ -16,6 +16,7 @@ export declare class LibsUiComponentsMinimapDirective implements AfterViewInit,
16
16
  private elementRef;
17
17
  private renderer2;
18
18
  ngAfterViewInit(): void;
19
+ get FunctionsControl(): IMiniMapFunctionControl;
19
20
  private imgElementInitStyleAndAddToBody;
20
21
  private viewPortElementInitStyleAndAddToImgElement;
21
22
  private styleRectTopBottomElement;
package/package.json CHANGED
@@ -1,10 +1,10 @@
1
1
  {
2
2
  "name": "@libs-ui/components-minimap",
3
- "version": "0.2.304",
3
+ "version": "0.2.306-10",
4
4
  "peerDependencies": {
5
5
  "@angular/core": ">=18.0.0",
6
- "@libs-ui/interfaces-types": "0.2.304",
7
- "@libs-ui/utils": "0.2.304",
6
+ "@libs-ui/interfaces-types": "0.2.306-10",
7
+ "@libs-ui/utils": "0.2.306-10",
8
8
  "rxjs": "~7.8.0"
9
9
  },
10
10
  "sideEffects": false,