@libs-ui/components-minimap 0.1.1-1

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 ADDED
@@ -0,0 +1,244 @@
1
+ # @libs-ui/components-minimap
2
+
3
+ Directive tạo minimap (bản đồ thu nhỏ) để điều hướng nhanh trong nội dung có thể cuộn lớn. Giúp người dùng dễ dàng xem tổng quan và di chuyển đến vị trí mong muốn trong một vùng nội dung lớn.
4
+
5
+ ## ✨ Tính năng
6
+
7
+ • **Minimap tự động**: Tạo bản đồ thu nhỏ của element có thể cuộn
8
+ • **Navigation tương tác**: Click và kéo thả để di chuyển viewport
9
+ • **Tùy chỉnh style**: Cấu hình màu sắc, kích thước, vị trí minimap
10
+ • **Responsive**: Tự động cập nhật khi nội dung thay đổi
11
+ • **Performance tối ưu**: Sử dụng signal và RxJS cho hiệu suất cao
12
+ • **Hỗ trợ scale**: Làm việc với element có transform scale
13
+ • **Control functions**: API để show/hide/toggle minimap từ code
14
+
15
+ ## 📦 Cài đặt
16
+
17
+ ```bash
18
+ npm install @libs-ui/components-minimap
19
+ ```
20
+
21
+ <button onclick="navigator.clipboard.writeText('npm install @libs-ui/components-minimap')" class="copy-btn">📋 Sao chép</button>
22
+
23
+ ```bash
24
+ yarn add @libs-ui/components-minimap
25
+ ```
26
+
27
+ <button onclick="navigator.clipboard.writeText('yarn add @libs-ui/components-minimap')" class="copy-btn">📋 Sao chép</button>
28
+
29
+ ## 🚀 Sử dụng
30
+
31
+ ### Ví dụ cơ bản (Inline Template)
32
+
33
+ ```typescript
34
+ import { Component } from '@angular/core';
35
+ import { LibsUiComponentsMinimapDirective } from '@libs-ui/components-minimap';
36
+
37
+ @Component({
38
+ selector: 'app-example',
39
+ standalone: true,
40
+ imports: [LibsUiComponentsMinimapDirective],
41
+ template: `
42
+ <div
43
+ LibsUiComponentsMinimapDirective
44
+ class="scrollable-content"
45
+ style="width: 500px; height: 300px; overflow: auto;">
46
+ <!-- Nội dung lớn cần minimap -->
47
+ <div style="width: 1500px; height: 1000px; background: linear-gradient(45deg, #ff6b6b, #4ecdc4);">
48
+ <h2>Nội dung rất lớn</h2>
49
+ <p>Cuộn để xem minimap hoạt động...</p>
50
+ </div>
51
+ </div>
52
+ `,
53
+ })
54
+ export class ExampleComponent {}
55
+ ```
56
+
57
+ ### Ví dụ với file HTML riêng
58
+
59
+ **Component:**
60
+
61
+ ```typescript
62
+ import { Component } from '@angular/core';
63
+ import { LibsUiComponentsMinimapDirective, IMiniMapFunctionControl, IMiniMapStyleConfig } from '@libs-ui/components-minimap';
64
+
65
+ @Component({
66
+ selector: 'app-minimap-demo',
67
+ standalone: true,
68
+ imports: [LibsUiComponentsMinimapDirective],
69
+ templateUrl: './minimap-demo.component.html',
70
+ styleUrls: ['./minimap-demo.component.scss'],
71
+ })
72
+ export class MinimapDemoComponent {
73
+ // Cấu hình style cho minimap container
74
+ minimapStyle: IMiniMapStyleConfig = {
75
+ width: 250,
76
+ height: 150,
77
+ top: 20,
78
+ right: 20,
79
+ background: '#f8f9fa',
80
+ border: '2px solid #007bff',
81
+ borderRadius: 8,
82
+ zIndex: 1500,
83
+ };
84
+
85
+ // Cấu hình style cho viewport rectangle
86
+ viewportStyle: IMiniMapStyleConfig = {
87
+ border: '2px solid #ff6b6b',
88
+ background: 'rgba(255, 107, 107, 0.1)',
89
+ borderRadius: 4,
90
+ };
91
+
92
+ minimapControls: IMiniMapFunctionControl | null = null;
93
+
94
+ // Nhận function controls từ directive
95
+ onMinimapReady(controls: IMiniMapFunctionControl) {
96
+ this.minimapControls = controls;
97
+ }
98
+
99
+ // Các method điều khiển minimap
100
+ showMinimap() {
101
+ this.minimapControls?.show();
102
+ }
103
+
104
+ hideMinimap() {
105
+ this.minimapControls?.hidden();
106
+ }
107
+
108
+ toggleMinimap() {
109
+ this.minimapControls?.toggle();
110
+ }
111
+ }
112
+ ```
113
+
114
+ **Template (minimap-demo.component.html):**
115
+
116
+ ```html
117
+ <div class="demo-container">
118
+ <!-- Control buttons -->
119
+ <div class="controls mb-3">
120
+ <button
121
+ (click)="showMinimap()"
122
+ class="btn btn-success me-2">
123
+ Hiện Minimap
124
+ </button>
125
+ <button
126
+ (click)="hideMinimap()"
127
+ class="btn btn-warning me-2">
128
+ Ẩn Minimap
129
+ </button>
130
+ <button
131
+ (click)="toggleMinimap()"
132
+ class="btn btn-info">
133
+ Toggle Minimap
134
+ </button>
135
+ </div>
136
+
137
+ <!-- Scrollable content với minimap -->
138
+ <div
139
+ LibsUiComponentsMinimapDirective
140
+ [styleImageElement]="minimapStyle"
141
+ [styleRectangleElement]="viewportStyle"
142
+ [timerStartDrawMinimap]="500"
143
+ (outFunctionControls)="onMinimapReady($event)"
144
+ class="scrollable-area"
145
+ style="width: 600px; height: 400px; overflow: auto; border: 1px solid #ddd;">
146
+ <!-- Large content -->
147
+ <div
148
+ class="large-content"
149
+ style="width: 1200px; height: 800px; padding: 20px;">
150
+ <h1>Nội dung lớn với Minimap</h1>
151
+
152
+ <div
153
+ class="mo-minimap-flag-element-scale"
154
+ style="transform: scale(1.2);">
155
+ <!-- Element có scale để test tính năng scale detection -->
156
+ <div class="grid-content">
157
+ <!-- Tạo grid content để dễ nhận biết vị trí -->
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;
166
+ margin: 2px; display: flex; align-items: center;
167
+ justify-content: center; background: #f0f0f0;">
168
+ {{row}}-{{col}}
169
+ </div>
170
+ </div>
171
+ </div>
172
+ </div>
173
+ </div>
174
+ </div>
175
+ </div>
176
+ ```
177
+
178
+ ## 🛠️ Công nghệ sử dụng
179
+
180
+ - **Angular 18+**: Framework chính
181
+ - **RxJS**: Quản lý events và reactive programming
182
+ - **TypeScript**: Ngôn ngữ phát triển
183
+ - **Signals**: Quản lý state hiện đại của Angular
184
+
185
+ ## 📖 API Reference
186
+
187
+ ### Inputs
188
+
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 |
196
+
197
+ ### Outputs
198
+
199
+ | Tên | Kiểu | Mô tả |
200
+ | --------------------- | ------------------------- | ------------------------------------------------ |
201
+ | `outFunctionControls` | `IMiniMapFunctionControl` | Emit object chứa các function để control minimap |
202
+
203
+ ### Interfaces
204
+
205
+ #### `IMiniMapStyleConfig`
206
+
207
+ ```typescript
208
+ interface IMiniMapStyleConfig {
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
221
+ }
222
+ ```
223
+
224
+ Cấu hình style cho minimap container hoặc viewport rectangle. Tất cả thuộc tính đều optional.
225
+
226
+ #### `IMiniMapFunctionControl`
227
+
228
+ ```typescript
229
+ interface IMiniMapFunctionControl {
230
+ show: () => void; // Hiển thị minimap
231
+ hidden: () => void; // Ẩn minimap
232
+ toggle: () => void; // Toggle hiển thị/ẩn minimap
233
+ }
234
+ ```
235
+
236
+ Object chứa các function để điều khiển minimap từ code. Nhận được qua output `outFunctionControls`.
237
+
238
+ ## 💡 Lưu ý
239
+
240
+ - Directive tự động tạo minimap container và thêm vào `document.body`
241
+ - Sử dụng class `mo-minimap-flag-element-scale` để đánh dấu element có scale transform
242
+ - Minimap tự động cập nhật khi nội dung hoặc kích thước thay đổi
243
+ - Viewport rectangle có thể click và kéo thả để điều hướng
244
+ - Memory được quản lý tự động, tự cleanup khi component destroy
@@ -0,0 +1,3 @@
1
+ export * from './minimap.directive';
2
+ export * from './minimap.interface';
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvbWluaW1hcC9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyxxQkFBcUIsQ0FBQztBQUNwQyxjQUFjLHFCQUFxQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9taW5pbWFwLmRpcmVjdGl2ZSc7XG5leHBvcnQgKiBmcm9tICcuL21pbmltYXAuaW50ZXJmYWNlJztcbiJdfQ==
@@ -0,0 +1,5 @@
1
+ /**
2
+ * Generated bundle index. Do not edit.
3
+ */
4
+ export * from './index';
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGlicy11aS1jb21wb25lbnRzLW1pbmltYXAuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvbWluaW1hcC9zcmMvbGlicy11aS1jb21wb25lbnRzLW1pbmltYXAudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLFNBQVMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9pbmRleCc7XG4iXX0=
@@ -0,0 +1,240 @@
1
+ import { Directive, ElementRef, inject, input, output, signal } from '@angular/core';
2
+ import { getDragEventByElement, setStylesElement } from '@libs-ui/utils';
3
+ import { fromEvent, Subject, takeUntil, tap, timer } from 'rxjs';
4
+ import * as i0 from "@angular/core";
5
+ export class LibsUiComponentsMinimapDirective {
6
+ // #region PROPERTY
7
+ isShow = signal(false);
8
+ containerElement = document.createElement('DIV');
9
+ imgElement = document.createElement('DIV');
10
+ viewPortElement = document.createElement('DIV');
11
+ onDestroy = new Subject();
12
+ // #endregion
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 });
16
+ elementScroll = input();
17
+ styleRectangleElement = input();
18
+ styleImageElement = input();
19
+ // #endregion
20
+ // #region OUTPUT
21
+ outFunctionControls = output();
22
+ // #endregion
23
+ // #region INJECT
24
+ elementRef = inject(ElementRef);
25
+ // #endregion
26
+ ngAfterViewInit() {
27
+ const config = { attributes: true, childList: true, subtree: true };
28
+ const observer = new MutationObserver(this.updateMiniMap.bind(this));
29
+ observer.observe(this.Element, config);
30
+ this.onDestroy.subscribe(() => {
31
+ this.containerElement?.remove();
32
+ observer.disconnect();
33
+ });
34
+ timer(this.timerStartDrawMinimap())
35
+ .pipe(tap(() => {
36
+ this.imgElementInitStyleAndAddToBody();
37
+ this.viewPortElementInitStyleAndAddToImgElement();
38
+ const rectImage = this.imgElement.getBoundingClientRect();
39
+ this.setPositionRectangle(rectImage, { clientX: rectImage.x, clientY: rectImage.y });
40
+ this.updateMiniMap();
41
+ this.outFunctionControls.emit(this.FunctionsControl);
42
+ this.initEvent();
43
+ }), takeUntil(this.onDestroy))
44
+ .subscribe();
45
+ }
46
+ // #region FUNCTIONS
47
+ get FunctionsControl() {
48
+ return {
49
+ show: this.show.bind(this),
50
+ hidden: this.hidden.bind(this),
51
+ toggle: this.toggle.bind(this),
52
+ };
53
+ }
54
+ imgElementInitStyleAndAddToBody() {
55
+ const rectElement = this.Element.getBoundingClientRect();
56
+ this.containerElement.classList.add('fixed', 'flex', 'invisible', 'libs-ui-directive-minimap-container', 'select-none');
57
+ this.imgElement.classList.add('relative', 'w-full', 'h-full', 'overflow-hidden');
58
+ setStylesElement(this.containerElement, {
59
+ zIndex: `${this.styleImageElement()?.zIndex ?? '1300'}`,
60
+ background: `${this.styleImageElement()?.background ?? 'white'}`,
61
+ border: `${this.styleImageElement()?.border ?? '1px solid #E6E7EA'}`,
62
+ borderRadius: `${this.styleImageElement()?.borderRadius ?? '4px'}`,
63
+ width: `${this.styleImageElement()?.width ?? '198'}px`,
64
+ height: `${this.styleImageElement()?.height ?? '108'}px`,
65
+ });
66
+ this.styleRectTopBottomElement(rectElement);
67
+ this.styleRectLeftRightElement(rectElement);
68
+ this.containerElement.append(this.imgElement);
69
+ document.body.appendChild(this.containerElement);
70
+ }
71
+ viewPortElementInitStyleAndAddToImgElement() {
72
+ this.viewPortElement.classList.add('fixed', 'libs-ui-border-primary-general', 'invisible', 'libs-ui-directive-minimap-rectangle');
73
+ setStylesElement(this.viewPortElement, {
74
+ zIndex: `${this.styleRectangleElement()?.zIndex ?? '1301'}`,
75
+ background: `${this.styleRectangleElement()?.background ?? 'transparent'}`,
76
+ border: `${this.styleRectangleElement()?.border ?? 'none'}`,
77
+ borderRadius: `${this.styleRectangleElement()?.borderRadius ?? '0'}`,
78
+ cursor: 'grab',
79
+ });
80
+ this.containerElement.appendChild(this.viewPortElement);
81
+ }
82
+ styleRectTopBottomElement(rectElement) {
83
+ if (this.styleImageElement()?.bottom) {
84
+ this.containerElement.style.bottom = `${this.styleImageElement()?.bottom}px`;
85
+ return;
86
+ }
87
+ this.containerElement.style.top = `${this.styleImageElement()?.top ?? rectElement.top}px`;
88
+ }
89
+ styleRectLeftRightElement(rectElement) {
90
+ if (this.styleImageElement()?.right) {
91
+ this.containerElement.style.right = `${this.styleImageElement()?.right}px`;
92
+ return;
93
+ }
94
+ this.containerElement.style.left = `${this.styleImageElement()?.left ?? rectElement.left}px`;
95
+ }
96
+ initEvent() {
97
+ let preEvent;
98
+ const handlerScrollElement = (event) => {
99
+ const rectViewPort = this.viewPortElement.getBoundingClientRect();
100
+ const rectImage = this.imgElement.getBoundingClientRect();
101
+ const { ratioX, ratioY } = this.getRatio();
102
+ if (event.type === 'scroll') {
103
+ event = {
104
+ clientX: this.Element.scrollLeft * ratioX + rectImage.left + rectViewPort.width / 2,
105
+ clientY: this.Element.scrollTop * ratioY + rectImage.top + rectViewPort.height / 2,
106
+ };
107
+ this.setPositionRectangle(rectImage, event);
108
+ return;
109
+ }
110
+ if (event.type === 'mousedown') {
111
+ preEvent = event;
112
+ return;
113
+ }
114
+ if (!preEvent) {
115
+ return;
116
+ }
117
+ const distanceX = (event.clientX - preEvent.clientX) / ratioX;
118
+ const distanceY = (event.clientY - preEvent.clientY) / ratioY;
119
+ preEvent = event;
120
+ this.Element.scroll({
121
+ left: this.Element.scrollLeft + distanceX,
122
+ top: this.Element.scrollTop + distanceY,
123
+ });
124
+ };
125
+ getDragEventByElement({ elementMouseDown: this.viewPortElement, elementMouseMove: this.viewPortElement, isStartWithMouseDownEvent: true, onDestroy: this.onDestroy }).subscribe(handlerScrollElement);
126
+ fromEvent(this.Element, 'scroll')
127
+ .pipe(tap((event) => event.stopPropagation()), takeUntil(this.onDestroy))
128
+ .subscribe((event) => handlerScrollElement(event));
129
+ fromEvent(window, 'resize')
130
+ .pipe(tap((event) => event.stopPropagation()), takeUntil(this.onDestroy))
131
+ .subscribe(this.updateMiniMap.bind(this));
132
+ }
133
+ getRatio() {
134
+ const rectContainer = this.containerElement.getBoundingClientRect();
135
+ const ratioX = rectContainer.width / this.Element.scrollWidth;
136
+ const ratioY = rectContainer.height / this.Element.scrollHeight;
137
+ return { ratioX: ratioX, ratioY: ratioY };
138
+ }
139
+ getScaleElement() {
140
+ let { scaleX, scaleY } = { scaleX: 1, scaleY: 1 };
141
+ const elementScale = this.Element.getElementsByClassName(this.classNameFlagElementScale())?.[0];
142
+ if (elementScale && getComputedStyle(elementScale).transform) {
143
+ const matrix = getComputedStyle(this.Element.getElementsByClassName(this.classNameFlagElementScale())[0]).transform;
144
+ const matrixArray = matrix.replace('matrix(', '').split(',');
145
+ console.log('matrixArray', matrixArray);
146
+ scaleX = parseFloat(matrixArray[0]); // convert from string to number
147
+ scaleY = parseFloat(matrixArray[3]);
148
+ }
149
+ return { scaleX, scaleY, elementScale };
150
+ }
151
+ reverseMultiplication(avg1, avg2) {
152
+ if (avg2 <= 1) {
153
+ return avg1 * avg2;
154
+ }
155
+ return avg1 / avg2;
156
+ }
157
+ setPositionRectangle(rectImage, mousePosition) {
158
+ const { ratioX, ratioY } = this.getRatio();
159
+ const { scaleX, scaleY } = this.getScaleElement();
160
+ const width = this.Element.clientWidth * this.reverseMultiplication(ratioX, scaleX);
161
+ const height = this.Element.clientHeight * this.reverseMultiplication(ratioY, scaleY);
162
+ let leftSvg = mousePosition.clientX - width / 2;
163
+ let topSvg = mousePosition.clientY - height / 2;
164
+ if (leftSvg < rectImage.left) {
165
+ leftSvg = rectImage.left;
166
+ }
167
+ if (leftSvg + width >= rectImage.left + rectImage.width) {
168
+ leftSvg = rectImage.left + rectImage.width - width;
169
+ }
170
+ if (topSvg < rectImage.top) {
171
+ topSvg = rectImage.top;
172
+ }
173
+ if (topSvg + height >= rectImage.top + rectImage.height) {
174
+ topSvg = rectImage.top + rectImage.height - height;
175
+ }
176
+ this.viewPortElement.style.left = `${leftSvg}px`;
177
+ this.viewPortElement.style.top = `${topSvg}px`;
178
+ this.viewPortElement.style.width = `${width}px`;
179
+ this.viewPortElement.style.height = `${Math.round(height)}px`;
180
+ }
181
+ updateMiniMap() {
182
+ this.imgElement.firstElementChild?.remove();
183
+ let { ratioX, ratioY } = this.getRatio();
184
+ const nodeClone = this.Element.cloneNode(true);
185
+ nodeClone.style.width = `${this.Element.scrollWidth}px`;
186
+ nodeClone.style.height = `${this.Element.scrollHeight}px`;
187
+ const { scaleX, scaleY } = this.getScaleElement();
188
+ ratioX = this.reverseMultiplication(ratioX, scaleX);
189
+ ratioY = this.reverseMultiplication(ratioY, scaleY);
190
+ nodeClone.style.transform = `scale(${ratioX},${ratioY})`;
191
+ nodeClone.classList.add('overflow-unset', 'select-none', 'pointer-events-none');
192
+ this.imgElement.append(nodeClone);
193
+ const translateX = (nodeClone.getBoundingClientRect().left - this.imgElement.getBoundingClientRect().left) / ratioX;
194
+ const translateY = (nodeClone.getBoundingClientRect().top - this.imgElement.getBoundingClientRect().top) / ratioY;
195
+ const viewPortElement = this.viewPortElement.getBoundingClientRect();
196
+ const rectImage = this.imgElement.getBoundingClientRect();
197
+ const event = {
198
+ clientX: this.Element.scrollLeft * ratioX + rectImage.left + viewPortElement.width / 2,
199
+ clientY: this.Element.scrollTop * ratioY + rectImage.top + viewPortElement.height / 2,
200
+ };
201
+ nodeClone.style.transform = `scale(${ratioX},${ratioY}) translate(-${translateX}px,-${translateY}px)`;
202
+ this.setPositionRectangle(rectImage, event);
203
+ }
204
+ toggle() {
205
+ if (this.isShow()) {
206
+ this.hidden();
207
+ return;
208
+ }
209
+ this.show();
210
+ }
211
+ hidden() {
212
+ this.isShow.set(false);
213
+ this.containerElement?.classList.add('invisible');
214
+ this.viewPortElement.classList.add('invisible');
215
+ }
216
+ show() {
217
+ this.isShow.set(true);
218
+ this.containerElement?.classList.remove('invisible');
219
+ this.viewPortElement.classList.remove('invisible');
220
+ }
221
+ get Element() {
222
+ return this.elementScroll() || this.elementRef.nativeElement;
223
+ }
224
+ // #endregion
225
+ ngOnDestroy() {
226
+ this.onDestroy.next();
227
+ this.onDestroy.complete();
228
+ }
229
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiComponentsMinimapDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
230
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.14", type: LibsUiComponentsMinimapDirective, isStandalone: true, selector: "[LibsUiComponentsMinimapDirective]", inputs: { classNameFlagElementScale: { classPropertyName: "classNameFlagElementScale", publicName: "classNameFlagElementScale", isSignal: true, isRequired: false, transformFunction: null }, timerStartDrawMinimap: { classPropertyName: "timerStartDrawMinimap", publicName: "timerStartDrawMinimap", isSignal: true, isRequired: false, transformFunction: null }, elementScroll: { classPropertyName: "elementScroll", publicName: "elementScroll", isSignal: true, isRequired: false, transformFunction: null }, styleRectangleElement: { classPropertyName: "styleRectangleElement", publicName: "styleRectangleElement", isSignal: true, isRequired: false, transformFunction: null }, styleImageElement: { classPropertyName: "styleImageElement", publicName: "styleImageElement", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { outFunctionControls: "outFunctionControls" }, ngImport: i0 });
231
+ }
232
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiComponentsMinimapDirective, decorators: [{
233
+ type: Directive,
234
+ args: [{
235
+ // eslint-disable-next-line @angular-eslint/directive-selector
236
+ selector: '[LibsUiComponentsMinimapDirective]',
237
+ standalone: true,
238
+ }]
239
+ }] });
240
+ //# 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, 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  // #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(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    });\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    });\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"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWluaW1hcC5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvbWluaW1hcC9zcmMvbWluaW1hcC5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgSU1pbmlNYXBTdHlsZUNvbmZpZyB7XG4gIHg/OiBudW1iZXI7XG4gIHk/OiBudW1iZXI7XG4gIHdpZHRoPzogbnVtYmVyO1xuICBoZWlnaHQ/OiBudW1iZXI7XG4gIHpJbmRleD86IG51bWJlcjtcbiAgYm9yZGVyPzogc3RyaW5nO1xuICBib3JkZXJSYWRpdXM/OiBudW1iZXI7XG4gIGJhY2tncm91bmQ/OiBzdHJpbmc7XG4gIHRvcD86IG51bWJlcjtcbiAgbGVmdD86IG51bWJlcjtcbiAgYm90dG9tPzogbnVtYmVyO1xuICByaWdodD86IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJTWluaU1hcEZ1bmN0aW9uQ29udHJvbCB7XG4gIHNob3c6ICgpID0+IHZvaWQ7XG4gIGhpZGRlbjogKCkgPT4gdm9pZDtcbiAgdG9nZ2xlOiAoKSA9PiB2b2lkO1xufVxuIl19
@@ -0,0 +1,247 @@
1
+ import * as i0 from '@angular/core';
2
+ import { signal, input, output, inject, ElementRef, Directive } from '@angular/core';
3
+ import { setStylesElement, getDragEventByElement } from '@libs-ui/utils';
4
+ import { Subject, timer, tap, takeUntil, fromEvent } from 'rxjs';
5
+
6
+ class LibsUiComponentsMinimapDirective {
7
+ // #region PROPERTY
8
+ isShow = signal(false);
9
+ containerElement = document.createElement('DIV');
10
+ imgElement = document.createElement('DIV');
11
+ viewPortElement = document.createElement('DIV');
12
+ onDestroy = new Subject();
13
+ // #endregion
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 });
17
+ elementScroll = input();
18
+ styleRectangleElement = input();
19
+ styleImageElement = input();
20
+ // #endregion
21
+ // #region OUTPUT
22
+ outFunctionControls = output();
23
+ // #endregion
24
+ // #region INJECT
25
+ elementRef = inject(ElementRef);
26
+ // #endregion
27
+ ngAfterViewInit() {
28
+ const config = { attributes: true, childList: true, subtree: true };
29
+ const observer = new MutationObserver(this.updateMiniMap.bind(this));
30
+ observer.observe(this.Element, config);
31
+ this.onDestroy.subscribe(() => {
32
+ this.containerElement?.remove();
33
+ observer.disconnect();
34
+ });
35
+ timer(this.timerStartDrawMinimap())
36
+ .pipe(tap(() => {
37
+ this.imgElementInitStyleAndAddToBody();
38
+ this.viewPortElementInitStyleAndAddToImgElement();
39
+ const rectImage = this.imgElement.getBoundingClientRect();
40
+ this.setPositionRectangle(rectImage, { clientX: rectImage.x, clientY: rectImage.y });
41
+ this.updateMiniMap();
42
+ this.outFunctionControls.emit(this.FunctionsControl);
43
+ this.initEvent();
44
+ }), takeUntil(this.onDestroy))
45
+ .subscribe();
46
+ }
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
+ }
55
+ imgElementInitStyleAndAddToBody() {
56
+ const rectElement = this.Element.getBoundingClientRect();
57
+ this.containerElement.classList.add('fixed', 'flex', 'invisible', 'libs-ui-directive-minimap-container', 'select-none');
58
+ this.imgElement.classList.add('relative', 'w-full', 'h-full', 'overflow-hidden');
59
+ setStylesElement(this.containerElement, {
60
+ zIndex: `${this.styleImageElement()?.zIndex ?? '1300'}`,
61
+ background: `${this.styleImageElement()?.background ?? 'white'}`,
62
+ border: `${this.styleImageElement()?.border ?? '1px solid #E6E7EA'}`,
63
+ borderRadius: `${this.styleImageElement()?.borderRadius ?? '4px'}`,
64
+ width: `${this.styleImageElement()?.width ?? '198'}px`,
65
+ height: `${this.styleImageElement()?.height ?? '108'}px`,
66
+ });
67
+ this.styleRectTopBottomElement(rectElement);
68
+ this.styleRectLeftRightElement(rectElement);
69
+ this.containerElement.append(this.imgElement);
70
+ document.body.appendChild(this.containerElement);
71
+ }
72
+ viewPortElementInitStyleAndAddToImgElement() {
73
+ this.viewPortElement.classList.add('fixed', 'libs-ui-border-primary-general', 'invisible', 'libs-ui-directive-minimap-rectangle');
74
+ setStylesElement(this.viewPortElement, {
75
+ zIndex: `${this.styleRectangleElement()?.zIndex ?? '1301'}`,
76
+ background: `${this.styleRectangleElement()?.background ?? 'transparent'}`,
77
+ border: `${this.styleRectangleElement()?.border ?? 'none'}`,
78
+ borderRadius: `${this.styleRectangleElement()?.borderRadius ?? '0'}`,
79
+ cursor: 'grab',
80
+ });
81
+ this.containerElement.appendChild(this.viewPortElement);
82
+ }
83
+ styleRectTopBottomElement(rectElement) {
84
+ if (this.styleImageElement()?.bottom) {
85
+ this.containerElement.style.bottom = `${this.styleImageElement()?.bottom}px`;
86
+ return;
87
+ }
88
+ this.containerElement.style.top = `${this.styleImageElement()?.top ?? rectElement.top}px`;
89
+ }
90
+ styleRectLeftRightElement(rectElement) {
91
+ if (this.styleImageElement()?.right) {
92
+ this.containerElement.style.right = `${this.styleImageElement()?.right}px`;
93
+ return;
94
+ }
95
+ this.containerElement.style.left = `${this.styleImageElement()?.left ?? rectElement.left}px`;
96
+ }
97
+ initEvent() {
98
+ let preEvent;
99
+ const handlerScrollElement = (event) => {
100
+ const rectViewPort = this.viewPortElement.getBoundingClientRect();
101
+ const rectImage = this.imgElement.getBoundingClientRect();
102
+ const { ratioX, ratioY } = this.getRatio();
103
+ if (event.type === 'scroll') {
104
+ event = {
105
+ clientX: this.Element.scrollLeft * ratioX + rectImage.left + rectViewPort.width / 2,
106
+ clientY: this.Element.scrollTop * ratioY + rectImage.top + rectViewPort.height / 2,
107
+ };
108
+ this.setPositionRectangle(rectImage, event);
109
+ return;
110
+ }
111
+ if (event.type === 'mousedown') {
112
+ preEvent = event;
113
+ return;
114
+ }
115
+ if (!preEvent) {
116
+ return;
117
+ }
118
+ const distanceX = (event.clientX - preEvent.clientX) / ratioX;
119
+ const distanceY = (event.clientY - preEvent.clientY) / ratioY;
120
+ preEvent = event;
121
+ this.Element.scroll({
122
+ left: this.Element.scrollLeft + distanceX,
123
+ top: this.Element.scrollTop + distanceY,
124
+ });
125
+ };
126
+ getDragEventByElement({ elementMouseDown: this.viewPortElement, elementMouseMove: this.viewPortElement, isStartWithMouseDownEvent: true, onDestroy: this.onDestroy }).subscribe(handlerScrollElement);
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));
133
+ }
134
+ getRatio() {
135
+ const rectContainer = this.containerElement.getBoundingClientRect();
136
+ const ratioX = rectContainer.width / this.Element.scrollWidth;
137
+ const ratioY = rectContainer.height / this.Element.scrollHeight;
138
+ return { ratioX: ratioX, ratioY: ratioY };
139
+ }
140
+ getScaleElement() {
141
+ let { scaleX, scaleY } = { scaleX: 1, scaleY: 1 };
142
+ const elementScale = this.Element.getElementsByClassName(this.classNameFlagElementScale())?.[0];
143
+ if (elementScale && getComputedStyle(elementScale).transform) {
144
+ const matrix = getComputedStyle(this.Element.getElementsByClassName(this.classNameFlagElementScale())[0]).transform;
145
+ const matrixArray = matrix.replace('matrix(', '').split(',');
146
+ console.log('matrixArray', matrixArray);
147
+ scaleX = parseFloat(matrixArray[0]); // convert from string to number
148
+ scaleY = parseFloat(matrixArray[3]);
149
+ }
150
+ return { scaleX, scaleY, elementScale };
151
+ }
152
+ reverseMultiplication(avg1, avg2) {
153
+ if (avg2 <= 1) {
154
+ return avg1 * avg2;
155
+ }
156
+ return avg1 / avg2;
157
+ }
158
+ setPositionRectangle(rectImage, mousePosition) {
159
+ const { ratioX, ratioY } = this.getRatio();
160
+ const { scaleX, scaleY } = this.getScaleElement();
161
+ const width = this.Element.clientWidth * this.reverseMultiplication(ratioX, scaleX);
162
+ const height = this.Element.clientHeight * this.reverseMultiplication(ratioY, scaleY);
163
+ let leftSvg = mousePosition.clientX - width / 2;
164
+ let topSvg = mousePosition.clientY - height / 2;
165
+ if (leftSvg < rectImage.left) {
166
+ leftSvg = rectImage.left;
167
+ }
168
+ if (leftSvg + width >= rectImage.left + rectImage.width) {
169
+ leftSvg = rectImage.left + rectImage.width - width;
170
+ }
171
+ if (topSvg < rectImage.top) {
172
+ topSvg = rectImage.top;
173
+ }
174
+ if (topSvg + height >= rectImage.top + rectImage.height) {
175
+ topSvg = rectImage.top + rectImage.height - height;
176
+ }
177
+ this.viewPortElement.style.left = `${leftSvg}px`;
178
+ this.viewPortElement.style.top = `${topSvg}px`;
179
+ this.viewPortElement.style.width = `${width}px`;
180
+ this.viewPortElement.style.height = `${Math.round(height)}px`;
181
+ }
182
+ updateMiniMap() {
183
+ this.imgElement.firstElementChild?.remove();
184
+ let { ratioX, ratioY } = this.getRatio();
185
+ const nodeClone = this.Element.cloneNode(true);
186
+ nodeClone.style.width = `${this.Element.scrollWidth}px`;
187
+ nodeClone.style.height = `${this.Element.scrollHeight}px`;
188
+ const { scaleX, scaleY } = this.getScaleElement();
189
+ ratioX = this.reverseMultiplication(ratioX, scaleX);
190
+ ratioY = this.reverseMultiplication(ratioY, scaleY);
191
+ nodeClone.style.transform = `scale(${ratioX},${ratioY})`;
192
+ nodeClone.classList.add('overflow-unset', 'select-none', 'pointer-events-none');
193
+ this.imgElement.append(nodeClone);
194
+ const translateX = (nodeClone.getBoundingClientRect().left - this.imgElement.getBoundingClientRect().left) / ratioX;
195
+ const translateY = (nodeClone.getBoundingClientRect().top - this.imgElement.getBoundingClientRect().top) / ratioY;
196
+ const viewPortElement = this.viewPortElement.getBoundingClientRect();
197
+ const rectImage = this.imgElement.getBoundingClientRect();
198
+ const event = {
199
+ clientX: this.Element.scrollLeft * ratioX + rectImage.left + viewPortElement.width / 2,
200
+ clientY: this.Element.scrollTop * ratioY + rectImage.top + viewPortElement.height / 2,
201
+ };
202
+ nodeClone.style.transform = `scale(${ratioX},${ratioY}) translate(-${translateX}px,-${translateY}px)`;
203
+ this.setPositionRectangle(rectImage, event);
204
+ }
205
+ toggle() {
206
+ if (this.isShow()) {
207
+ this.hidden();
208
+ return;
209
+ }
210
+ this.show();
211
+ }
212
+ hidden() {
213
+ this.isShow.set(false);
214
+ this.containerElement?.classList.add('invisible');
215
+ this.viewPortElement.classList.add('invisible');
216
+ }
217
+ show() {
218
+ this.isShow.set(true);
219
+ this.containerElement?.classList.remove('invisible');
220
+ this.viewPortElement.classList.remove('invisible');
221
+ }
222
+ get Element() {
223
+ return this.elementScroll() || this.elementRef.nativeElement;
224
+ }
225
+ // #endregion
226
+ ngOnDestroy() {
227
+ this.onDestroy.next();
228
+ this.onDestroy.complete();
229
+ }
230
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiComponentsMinimapDirective, deps: [], target: i0.ɵɵFactoryTarget.Directive });
231
+ static ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "17.1.0", version: "18.2.14", type: LibsUiComponentsMinimapDirective, isStandalone: true, selector: "[LibsUiComponentsMinimapDirective]", inputs: { classNameFlagElementScale: { classPropertyName: "classNameFlagElementScale", publicName: "classNameFlagElementScale", isSignal: true, isRequired: false, transformFunction: null }, timerStartDrawMinimap: { classPropertyName: "timerStartDrawMinimap", publicName: "timerStartDrawMinimap", isSignal: true, isRequired: false, transformFunction: null }, elementScroll: { classPropertyName: "elementScroll", publicName: "elementScroll", isSignal: true, isRequired: false, transformFunction: null }, styleRectangleElement: { classPropertyName: "styleRectangleElement", publicName: "styleRectangleElement", isSignal: true, isRequired: false, transformFunction: null }, styleImageElement: { classPropertyName: "styleImageElement", publicName: "styleImageElement", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { outFunctionControls: "outFunctionControls" }, ngImport: i0 });
232
+ }
233
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiComponentsMinimapDirective, decorators: [{
234
+ type: Directive,
235
+ args: [{
236
+ // eslint-disable-next-line @angular-eslint/directive-selector
237
+ selector: '[LibsUiComponentsMinimapDirective]',
238
+ standalone: true,
239
+ }]
240
+ }] });
241
+
242
+ /**
243
+ * Generated bundle index. Do not edit.
244
+ */
245
+
246
+ export { LibsUiComponentsMinimapDirective };
247
+ //# sourceMappingURL=libs-ui-components-minimap.mjs.map
@@ -0,0 +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, 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 // #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(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 });\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 });\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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"}
package/index.d.ts ADDED
@@ -0,0 +1,2 @@
1
+ export * from './minimap.directive';
2
+ export * from './minimap.interface';
@@ -0,0 +1,36 @@
1
+ import { AfterViewInit, OnDestroy } from '@angular/core';
2
+ import { IMiniMapFunctionControl, IMiniMapStyleConfig } from './minimap.interface';
3
+ import * as i0 from "@angular/core";
4
+ export declare class LibsUiComponentsMinimapDirective implements AfterViewInit, OnDestroy {
5
+ private isShow;
6
+ private containerElement;
7
+ private imgElement;
8
+ private viewPortElement;
9
+ private onDestroy;
10
+ readonly classNameFlagElementScale: import("@angular/core").InputSignalWithTransform<string, string | undefined>;
11
+ readonly timerStartDrawMinimap: import("@angular/core").InputSignalWithTransform<number, number | undefined>;
12
+ readonly elementScroll: import("@angular/core").InputSignal<HTMLElement | undefined>;
13
+ readonly styleRectangleElement: import("@angular/core").InputSignal<IMiniMapStyleConfig | undefined>;
14
+ readonly styleImageElement: import("@angular/core").InputSignal<IMiniMapStyleConfig | undefined>;
15
+ readonly outFunctionControls: import("@angular/core").OutputEmitterRef<IMiniMapFunctionControl>;
16
+ private elementRef;
17
+ ngAfterViewInit(): void;
18
+ get FunctionsControl(): IMiniMapFunctionControl;
19
+ private imgElementInitStyleAndAddToBody;
20
+ private viewPortElementInitStyleAndAddToImgElement;
21
+ private styleRectTopBottomElement;
22
+ private styleRectLeftRightElement;
23
+ private initEvent;
24
+ private getRatio;
25
+ private getScaleElement;
26
+ private reverseMultiplication;
27
+ private setPositionRectangle;
28
+ private updateMiniMap;
29
+ private toggle;
30
+ private hidden;
31
+ private show;
32
+ private get Element();
33
+ ngOnDestroy(): void;
34
+ static ɵfac: i0.ɵɵFactoryDeclaration<LibsUiComponentsMinimapDirective, never>;
35
+ static ɵdir: i0.ɵɵDirectiveDeclaration<LibsUiComponentsMinimapDirective, "[LibsUiComponentsMinimapDirective]", never, { "classNameFlagElementScale": { "alias": "classNameFlagElementScale"; "required": false; "isSignal": true; }; "timerStartDrawMinimap": { "alias": "timerStartDrawMinimap"; "required": false; "isSignal": true; }; "elementScroll": { "alias": "elementScroll"; "required": false; "isSignal": true; }; "styleRectangleElement": { "alias": "styleRectangleElement"; "required": false; "isSignal": true; }; "styleImageElement": { "alias": "styleImageElement"; "required": false; "isSignal": true; }; }, { "outFunctionControls": "outFunctionControls"; }, never, never, true, never>;
36
+ }
@@ -0,0 +1,19 @@
1
+ export interface IMiniMapStyleConfig {
2
+ x?: number;
3
+ y?: number;
4
+ width?: number;
5
+ height?: number;
6
+ zIndex?: number;
7
+ border?: string;
8
+ borderRadius?: number;
9
+ background?: string;
10
+ top?: number;
11
+ left?: number;
12
+ bottom?: number;
13
+ right?: number;
14
+ }
15
+ export interface IMiniMapFunctionControl {
16
+ show: () => void;
17
+ hidden: () => void;
18
+ toggle: () => void;
19
+ }
package/package.json ADDED
@@ -0,0 +1,27 @@
1
+ {
2
+ "name": "@libs-ui/components-minimap",
3
+ "version": "0.1.1-1",
4
+ "peerDependencies": {
5
+ "@angular/core": ">=18.0.0",
6
+ "@libs-ui/interfaces-types": "0.1.1-1",
7
+ "@libs-ui/utils": "0.1.1-1",
8
+ "rxjs": "~7.8.0"
9
+ },
10
+ "sideEffects": false,
11
+ "module": "fesm2022/libs-ui-components-minimap.mjs",
12
+ "typings": "index.d.ts",
13
+ "exports": {
14
+ "./package.json": {
15
+ "default": "./package.json"
16
+ },
17
+ ".": {
18
+ "types": "./index.d.ts",
19
+ "esm2022": "./esm2022/libs-ui-components-minimap.mjs",
20
+ "esm": "./esm2022/libs-ui-components-minimap.mjs",
21
+ "default": "./fesm2022/libs-ui-components-minimap.mjs"
22
+ }
23
+ },
24
+ "dependencies": {
25
+ "tslib": "^2.3.0"
26
+ }
27
+ }