@libs-ui/components-minimap 0.2.355-13 → 0.2.355-15

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.
Files changed (2) hide show
  1. package/README.md +136 -0
  2. package/package.json +3 -3
package/README.md ADDED
@@ -0,0 +1,136 @@
1
+ # @libs-ui/components-minimap
2
+
3
+ > Thêm bản đồ thu nhỏ (Minimap) cho các vùng chứa có nội dung lớn hoặc cuộn.
4
+
5
+ ## Giới thiệu
6
+
7
+ `LibsUiComponentsMinimapDirective` là một standalone directive giúp tạo ra một trải nghiệm chuyển hướng trực quan cho người dùng trong các bảng vẽ (canvas), sơ đồ hoặc các vùng nội dung rộng lớn. Nó tự động theo dõi thay đổi trong DOM và đồng bộ hóa vị trí cuộn giữa nội dung chính và bản đồ thu nhỏ.
8
+
9
+ ### Tính năng
10
+
11
+ - ✅ **Standalone Directive**: Dễ dàng tích hợp vào bất kỳ phần tử nào có thuộc tính cuộn.
12
+ - ✅ **Đồng bộ hai chiều**: Cuộn nội dung chính cập nhật Minimap, kéo viewport trên Minimap cập nhật nội dung chính.
13
+ - ✅ **Theo dõi thay đổi**: Sử dụng `MutationObserver` để tự động cập nhật hình ảnh trên Minimap khi nội dung thay đổi.
14
+ - ✅ **Tùy biến cao**: Cho phép cấu hình vị trí, kích thước, màu sắc và z-index của cả Minimap và Viewport.
15
+ - ✅ **Hỗ trợ Scale**: Khả năng nhận diện tỷ lệ phóng to/thu nhỏ của nội dung để hiển thị chính xác.
16
+
17
+ ## Khi nào sử dụng
18
+
19
+ - Khi có các vùng chứa nội dung lớn vượt quá kích thước màn hình (sơ đồ, bản đồ văn phòng, editor đồ họa).
20
+ - Khi người dùng cần cái nhìn tổng quan về cấu trúc nội dung và khả năng di chuyển nhanh chóng đến các vùng cụ thể.
21
+ - Thay thế hoặc hỗ trợ cho thanh cuộn truyền thống trên các giao diện phức tạp.
22
+
23
+ ## Cài đặt
24
+
25
+ ```bash
26
+ # npm
27
+ npm install @libs-ui/components-minimap
28
+
29
+ # yarn
30
+ yarn add @libs-ui/components-minimap
31
+ ```
32
+
33
+ ## Import
34
+
35
+ ```typescript
36
+ import { LibsUiComponentsMinimapDirective } from '@libs-ui/components-minimap';
37
+
38
+ @Component({
39
+ standalone: true,
40
+ imports: [LibsUiComponentsMinimapDirective],
41
+ // ...
42
+ })
43
+ export class YourComponent {}
44
+ ```
45
+
46
+ ## Ví dụ
47
+
48
+ ### Cơ bản
49
+
50
+ ```html
51
+ <div
52
+ class="w-full h-[500px] overflow-auto"
53
+ LibsUiComponentsMinimapDirective>
54
+ <!-- Nội dung lớn ở đây -->
55
+ <div class="w-[2000px] h-[2000px]">...</div>
56
+ </div>
57
+ ```
58
+
59
+ ### Với cấu hình Styles và Controls
60
+
61
+ ```html
62
+ <div
63
+ class="scroll-container"
64
+ LibsUiComponentsMinimapDirective
65
+ [styleImageElement]="{ bottom: 20, right: 20, width: 200, height: 120 }"
66
+ [styleRectangleElement]="{ border: '2px solid #3b82f6' }"
67
+ (outFunctionControls)="controls = $event">
68
+ ...
69
+ </div>
70
+
71
+ <button (click)="controls.toggle()">Bật/Tắt Minimap</button>
72
+ ```
73
+
74
+ ## API
75
+
76
+ ### [LibsUiComponentsMinimapDirective]
77
+
78
+ #### Inputs
79
+
80
+ | Property | Type | Default | Description |
81
+ | ----------------------------- | --------------------- | -------------------------------------- | ---------------------------------------------------- |
82
+ | `[elementScroll]` | `HTMLElement` | `Host Element` | Phần tử đích để theo dõi cuộn (nếu khác host). |
83
+ | `[styleImageElement]` | `IMiniMapStyleConfig` | `undefined` | Cấu hình phong cách và vị trí cho khung Minimap. |
84
+ | `[styleRectangleElement]` | `IMiniMapStyleConfig` | `undefined` | Cấu hình cho khung Viewport trên Minimap. |
85
+ | `[timerStartDrawMinimap]` | `number` | `250` | Thời gian chờ (ms) trước khi bắt đầu vẽ Minimap. |
86
+ | `[classNameFlagElementScale]` | `string` | `'libs-ui-minimap-flag-element-scale'` | Class name để xác định phần tử chứa scale transform. |
87
+
88
+ #### Outputs
89
+
90
+ | Property | Type | Description |
91
+ | ----------------------- | --------------------------------------- | ---------------------------------------------------- |
92
+ | `(outFunctionControls)` | `EventEmitter<IMiniMapFunctionControl>` | Phát ra bộ điều khiển để điều khiển Minimap từ code. |
93
+
94
+ #### Methods (via Controls)
95
+
96
+ | Method | Parameters | Description |
97
+ | ---------- | ---------- | ------------------------------- |
98
+ | `show()` | `-` | Hiển thị Minimap. |
99
+ | `hidden()` | `-` | Ẩn Minimap. |
100
+ | `toggle()` | `-` | Chuyển đổi trạng thái hiển thị. |
101
+
102
+ ## Types & Interfaces
103
+
104
+ ```typescript
105
+ export interface IMiniMapStyleConfig {
106
+ zIndex?: number;
107
+ border?: string;
108
+ borderRadius?: number;
109
+ background?: string;
110
+ top?: number;
111
+ left?: number;
112
+ bottom?: number;
113
+ right?: number;
114
+ width?: number;
115
+ height?: number;
116
+ }
117
+
118
+ export interface IMiniMapFunctionControl {
119
+ show: () => void;
120
+ hidden: () => void;
121
+ toggle: () => void;
122
+ }
123
+ ```
124
+
125
+ ## Công nghệ
126
+
127
+ | Technology | Purpose |
128
+ | ---------------- | ------------------------- |
129
+ | Angular 18+ | Framework chính |
130
+ | Angular Signals | Quản lý trạng thái nội bộ |
131
+ | MutationObserver | Theo dõi thay đổi DOM |
132
+ | DOM Cloning | Tạo hình ảnh thu nhỏ |
133
+
134
+ ## License
135
+
136
+ MIT
package/package.json CHANGED
@@ -1,10 +1,10 @@
1
1
  {
2
2
  "name": "@libs-ui/components-minimap",
3
- "version": "0.2.355-13",
3
+ "version": "0.2.355-15",
4
4
  "peerDependencies": {
5
5
  "@angular/core": ">=18.0.0",
6
- "@libs-ui/interfaces-types": "0.2.355-13",
7
- "@libs-ui/utils": "0.2.355-13",
6
+ "@libs-ui/interfaces-types": "0.2.355-15",
7
+ "@libs-ui/utils": "0.2.355-15",
8
8
  "rxjs": "~7.8.0"
9
9
  },
10
10
  "sideEffects": false,