@libs-ui/components-avatar 0.2.28 → 0.2.30-6.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
CHANGED
|
@@ -1,3 +1,263 @@
|
|
|
1
|
-
#
|
|
1
|
+
# Avatar
|
|
2
2
|
|
|
3
|
-
|
|
3
|
+
## Giới thiệu
|
|
4
|
+
|
|
5
|
+
`avatar` là một component Avatar linh hoạt dùng cho ứng dụng Angular. Component này cho phép hiển thị avatar người dùng với nhiều tùy chọn khác nhau như hình ảnh, chữ cái đầu, màu sắc tự động, và hỗ trợ fallback khi ảnh bị lỗi.
|
|
6
|
+
|
|
7
|
+
## Tính năng
|
|
8
|
+
|
|
9
|
+
- Hiển thị hình ảnh avatar người dùng
|
|
10
|
+
- Tự động hiển thị chữ cái đầu khi không có ảnh
|
|
11
|
+
- Tạo màu nền tự động dựa trên ID
|
|
12
|
+
- Hỗ trợ nhiều kích thước khác nhau (16px, 24px, 32px, 40px, 48px, 64px)
|
|
13
|
+
- Hỗ trợ hình dạng khác nhau (tròn, vuông)
|
|
14
|
+
- Xử lý lỗi hình ảnh với nhiều tùy chọn fallback
|
|
15
|
+
- Hỗ trợ tùy chỉnh class CSS
|
|
16
|
+
|
|
17
|
+
## Cài đặt
|
|
18
|
+
|
|
19
|
+
### Yêu cầu
|
|
20
|
+
|
|
21
|
+
- Angular 18.0.0 trở lên
|
|
22
|
+
- Tailwind CSS 3.3.0 trở lên
|
|
23
|
+
|
|
24
|
+
### Hướng dẫn
|
|
25
|
+
|
|
26
|
+
Để cài đặt component `avatar`, sử dụng npm hoặc yarn:
|
|
27
|
+
|
|
28
|
+
```bash
|
|
29
|
+
npm install @libs-ui/components-avatar
|
|
30
|
+
```
|
|
31
|
+
|
|
32
|
+
hoặc
|
|
33
|
+
|
|
34
|
+
```bash
|
|
35
|
+
yarn add @libs-ui/components-avatar
|
|
36
|
+
```
|
|
37
|
+
|
|
38
|
+
## Sử dụng
|
|
39
|
+
|
|
40
|
+
### Import component
|
|
41
|
+
|
|
42
|
+
```typescript
|
|
43
|
+
// example.component.ts
|
|
44
|
+
import { Component } from '@angular/core';
|
|
45
|
+
import { LibsUiComponentsAvatarComponent } from '@libs-ui/components-avatar';
|
|
46
|
+
|
|
47
|
+
@Component({
|
|
48
|
+
selector: 'app-example',
|
|
49
|
+
standalone: true,
|
|
50
|
+
imports: [LibsUiComponentsAvatarComponent],
|
|
51
|
+
template: `
|
|
52
|
+
<libs_ui-components-avatar
|
|
53
|
+
[linkAvatar]="'https://example.com/avatar.jpg'"
|
|
54
|
+
[textAvatar]="'Nguyễn Văn A'"
|
|
55
|
+
[idGenColor]="'user-123'"
|
|
56
|
+
[size]="40">
|
|
57
|
+
</libs_ui-components-avatar>
|
|
58
|
+
`
|
|
59
|
+
})
|
|
60
|
+
export class ExampleComponent {
|
|
61
|
+
// Component logic
|
|
62
|
+
}
|
|
63
|
+
```
|
|
64
|
+
|
|
65
|
+
#### Cách 2: Sử dụng file HTML riêng biệt
|
|
66
|
+
|
|
67
|
+
```typescript
|
|
68
|
+
// example.component.ts
|
|
69
|
+
import { Component } from '@angular/core';
|
|
70
|
+
import { LibsUiComponentsAvatarComponent } from '@libs-ui/components-avatar';
|
|
71
|
+
|
|
72
|
+
@Component({
|
|
73
|
+
selector: 'app-example',
|
|
74
|
+
standalone: true,
|
|
75
|
+
imports: [LibsUiComponentsAvatarComponent],
|
|
76
|
+
templateUrl: './example.component.html'
|
|
77
|
+
})
|
|
78
|
+
export class ExampleComponent {
|
|
79
|
+
// Component logic
|
|
80
|
+
}
|
|
81
|
+
```
|
|
82
|
+
|
|
83
|
+
```html
|
|
84
|
+
<!-- example.component.html -->
|
|
85
|
+
<libs_ui-components-avatar
|
|
86
|
+
[linkAvatar]="'https://example.com/avatar.jpg'"
|
|
87
|
+
[linkAvatarError]="'https://example.com/default-avatar.jpg'"
|
|
88
|
+
[textAvatar]="'Nguyễn Văn A'"
|
|
89
|
+
[idGenColor]="'user-123'"
|
|
90
|
+
[size]="40"
|
|
91
|
+
[typeShape]="'circle'">
|
|
92
|
+
</libs_ui-components-avatar>
|
|
93
|
+
```
|
|
94
|
+
|
|
95
|
+
## Công nghệ sử dụng
|
|
96
|
+
|
|
97
|
+
- **Angular 18**: Sử dụng các tính năng mới nhất của Angular 18 như control flow (@if, @for), standalone components, và signals
|
|
98
|
+
- **Tailwind CSS**: Component được xây dựng với Tailwind CSS 3.3+ để quản lý style
|
|
99
|
+
|
|
100
|
+
## API Reference
|
|
101
|
+
|
|
102
|
+
### Inputs
|
|
103
|
+
|
|
104
|
+
| Tên | Kiểu dữ liệu | Mặc định | Mô tả |
|
|
105
|
+
|--------------------|-----------------------------|----------|----------------------------------------------------------------------|
|
|
106
|
+
| linkAvatar | `string` | - | Đường dẫn của hình ảnh avatar |
|
|
107
|
+
| linkAvatarError | `string` | - | Đường dẫn của hình ảnh thay thế khi avatar chính bị lỗi |
|
|
108
|
+
| textAvatar | `string` | - | Văn bản hiển thị khi không có hình ảnh (thường là chữ cái đầu của tên) |
|
|
109
|
+
| idGenColor | `string` | - | ID dùng để tạo màu nền tự động khi sử dụng văn bản |
|
|
110
|
+
| size | `16 \| 24 \| 32 \| 40 \| 48 \| 64` | `32` | Kích thước của avatar (tính bằng pixel) |
|
|
111
|
+
| typeShape | `'circle' \| 'rectangle'` | `'circle'`| Hình dạng của avatar (tròn hoặc vuông) |
|
|
112
|
+
| classInclude | `string` | `'mr-[8px]'` | CSS class bổ sung cho container chính |
|
|
113
|
+
| classImageInclude | `string` | `''` | CSS class bổ sung cho thẻ img |
|
|
114
|
+
| getLastTextAfterSpace | `boolean` | `false` | Nếu true, chỉ lấy chữ cái đầu tiên của từ cuối cùng trong textAvatar |
|
|
115
|
+
| clickPreviewImage | `boolean` | `false` | Cho phép click vào avatar để mở xem ảnh preview |
|
|
116
|
+
|
|
117
|
+
### Outputs
|
|
118
|
+
|
|
119
|
+
| Tên | Kiểu dữ liệu | Mô tả |
|
|
120
|
+
|-----|--------------|-------|
|
|
121
|
+
| outAvatarError | `void` | Sự kiện được kích hoạt khi linkAvatar bị lỗi và không có linkAvatarError |
|
|
122
|
+
|
|
123
|
+
### Interfaces
|
|
124
|
+
|
|
125
|
+
#### IAvatarConfig
|
|
126
|
+
```typescript
|
|
127
|
+
export interface IAvatarConfig {
|
|
128
|
+
classImageInclude?: string;
|
|
129
|
+
classInclude?: string;
|
|
130
|
+
size?: TYPE_SIZE_AVATAR_CONFIG;
|
|
131
|
+
linkAvatar?: string;
|
|
132
|
+
linkAvatarError?: string;
|
|
133
|
+
idGenColor?: string;
|
|
134
|
+
textAvatar?: string;
|
|
135
|
+
typeShape?: TYPE_SHAPE_AVATAR;
|
|
136
|
+
getLastTextAfterSpace?: boolean;
|
|
137
|
+
}
|
|
138
|
+
|
|
139
|
+
export type TYPE_SIZE_AVATAR_CONFIG = 16 | 24 | 32 | 40 | 48 | 64;
|
|
140
|
+
export type TYPE_SHAPE_AVATAR = 'circle' | 'rectangle';
|
|
141
|
+
```
|
|
142
|
+
|
|
143
|
+
## Ví dụ
|
|
144
|
+
|
|
145
|
+
### Avatar với ảnh và fallback
|
|
146
|
+
|
|
147
|
+
**TypeScript (user-avatar.component.ts):**
|
|
148
|
+
```typescript
|
|
149
|
+
import { Component } from '@angular/core';
|
|
150
|
+
import { LibsUiComponentsAvatarComponent } from '@libs-ui/components-avatar';
|
|
151
|
+
|
|
152
|
+
@Component({
|
|
153
|
+
selector: 'app-user-avatar',
|
|
154
|
+
standalone: true,
|
|
155
|
+
imports: [LibsUiComponentsAvatarComponent],
|
|
156
|
+
templateUrl: './user-avatar.component.html'
|
|
157
|
+
})
|
|
158
|
+
export class UserAvatarComponent {
|
|
159
|
+
user = {
|
|
160
|
+
id: 'user-123',
|
|
161
|
+
name: 'Nguyễn Văn A',
|
|
162
|
+
avatar: 'https://example.com/avatar.jpg'
|
|
163
|
+
};
|
|
164
|
+
|
|
165
|
+
handleAvatarError() {
|
|
166
|
+
console.log('Không thể tải được hình ảnh avatar');
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
```
|
|
170
|
+
|
|
171
|
+
**HTML (user-avatar.component.html):**
|
|
172
|
+
```html
|
|
173
|
+
<libs_ui-components-avatar
|
|
174
|
+
[linkAvatar]="user.avatar"
|
|
175
|
+
[textAvatar]="user.name"
|
|
176
|
+
[idGenColor]="user.id"
|
|
177
|
+
[size]="40"
|
|
178
|
+
(outAvatarError)="handleAvatarError()">
|
|
179
|
+
</libs_ui-components-avatar>
|
|
180
|
+
```
|
|
181
|
+
|
|
182
|
+
### Nhóm Avatars với kích thước và hình dạng khác nhau
|
|
183
|
+
|
|
184
|
+
**TypeScript (avatar-group.component.ts):**
|
|
185
|
+
```typescript
|
|
186
|
+
import { Component } from '@angular/core';
|
|
187
|
+
import { LibsUiComponentsAvatarComponent } from '@libs-ui/components-avatar';
|
|
188
|
+
|
|
189
|
+
@Component({
|
|
190
|
+
selector: 'app-avatar-group',
|
|
191
|
+
standalone: true,
|
|
192
|
+
imports: [LibsUiComponentsAvatarComponent],
|
|
193
|
+
templateUrl: './avatar-group.component.html'
|
|
194
|
+
})
|
|
195
|
+
export class AvatarGroupComponent {
|
|
196
|
+
users = [
|
|
197
|
+
{
|
|
198
|
+
id: 'user-1',
|
|
199
|
+
name: 'Nguyễn Văn A',
|
|
200
|
+
avatar: 'https://example.com/avatar1.jpg',
|
|
201
|
+
size: 64
|
|
202
|
+
},
|
|
203
|
+
{
|
|
204
|
+
id: 'user-2',
|
|
205
|
+
name: 'Trần Thị B',
|
|
206
|
+
avatar: 'https://example.com/avatar2.jpg',
|
|
207
|
+
size: 48
|
|
208
|
+
},
|
|
209
|
+
{
|
|
210
|
+
id: 'user-3',
|
|
211
|
+
name: 'Lê Văn C',
|
|
212
|
+
avatar: 'https://example.com/avatar3.jpg',
|
|
213
|
+
size: 32
|
|
214
|
+
},
|
|
215
|
+
{
|
|
216
|
+
id: 'user-4',
|
|
217
|
+
name: 'Phạm Thị D',
|
|
218
|
+
avatar: null,
|
|
219
|
+
size: 24
|
|
220
|
+
}
|
|
221
|
+
];
|
|
222
|
+
}
|
|
223
|
+
```
|
|
224
|
+
|
|
225
|
+
**HTML (avatar-group.component.html):**
|
|
226
|
+
```html
|
|
227
|
+
<div class="flex items-center space-x-2">
|
|
228
|
+
@for (user of users; track user.id) {
|
|
229
|
+
<libs_ui-components-avatar
|
|
230
|
+
[linkAvatar]="user.avatar"
|
|
231
|
+
[textAvatar]="user.name"
|
|
232
|
+
[idGenColor]="user.id"
|
|
233
|
+
[size]="user.size"
|
|
234
|
+
[typeShape]="user.id === 'user-4' ? 'rectangle' : 'circle'">
|
|
235
|
+
</libs_ui-components-avatar>
|
|
236
|
+
}
|
|
237
|
+
</div>
|
|
238
|
+
```
|
|
239
|
+
|
|
240
|
+
## Demo
|
|
241
|
+
|
|
242
|
+
Để xem các ví dụ tương tác về component Avatar, bạn có thể sử dụng `LibsUiComponentsAvatarDemoComponent` trong ứng dụng của mình:
|
|
243
|
+
|
|
244
|
+
```typescript
|
|
245
|
+
import { Component } from '@angular/core';
|
|
246
|
+
import { LibsUiComponentsAvatarDemoComponent } from '@libs-ui/components-avatar';
|
|
247
|
+
|
|
248
|
+
@Component({
|
|
249
|
+
selector: 'app-avatar-demo',
|
|
250
|
+
standalone: true,
|
|
251
|
+
imports: [LibsUiComponentsAvatarDemoComponent],
|
|
252
|
+
template: `
|
|
253
|
+
<lib-avatar-demo></lib-avatar-demo>
|
|
254
|
+
`
|
|
255
|
+
})
|
|
256
|
+
export class AvatarDemoComponent {}
|
|
257
|
+
```
|
|
258
|
+
|
|
259
|
+
Hoặc thêm trực tiếp trong template HTML:
|
|
260
|
+
|
|
261
|
+
```html
|
|
262
|
+
<lib-avatar-demo></lib-avatar-demo>
|
|
263
|
+
```
|
package/avatar.component.d.ts
CHANGED
|
@@ -1,24 +1,34 @@
|
|
|
1
|
+
import { OnDestroy } from '@angular/core';
|
|
1
2
|
import { TYPE_SHAPE_AVATAR, TYPE_SIZE_AVATAR_CONFIG } from './interfaces/avatar.interface';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
|
-
export declare class LibsUiComponentsAvatarComponent {
|
|
4
|
-
protected readonly getLastTextAfterSpace: import("@angular/core").WritableSignal<boolean>;
|
|
4
|
+
export declare class LibsUiComponentsAvatarComponent implements OnDestroy {
|
|
5
5
|
protected isErrorLinkAvatar: import("@angular/core").WritableSignal<boolean>;
|
|
6
6
|
protected isErrorLinkAvatarError: import("@angular/core").WritableSignal<boolean>;
|
|
7
7
|
protected isShowIcon: import("@angular/core").WritableSignal<boolean>;
|
|
8
8
|
protected color: import("@angular/core").Signal<string>;
|
|
9
9
|
protected fontSize: import("@angular/core").Signal<6 | 4 | 3 | 1>;
|
|
10
|
+
private galleryViewerComponent?;
|
|
10
11
|
readonly typeShape: import("@angular/core").InputSignalWithTransform<TYPE_SHAPE_AVATAR | undefined, TYPE_SHAPE_AVATAR | undefined>;
|
|
11
12
|
readonly classInclude: import("@angular/core").InputSignalWithTransform<string | undefined, string | undefined>;
|
|
12
13
|
readonly size: import("@angular/core").InputSignalWithTransform<TYPE_SIZE_AVATAR_CONFIG | undefined, TYPE_SIZE_AVATAR_CONFIG | undefined>;
|
|
13
14
|
readonly linkAvatar: import("@angular/core").InputSignal<string | undefined>;
|
|
14
15
|
readonly linkAvatarError: import("@angular/core").InputSignal<string | undefined>;
|
|
16
|
+
readonly classImageInclude: import("@angular/core").InputSignalWithTransform<string | undefined, string | undefined>;
|
|
17
|
+
readonly zIndexPreviewImage: import("@angular/core").InputSignal<number | undefined>;
|
|
18
|
+
readonly clickPreviewImage: import("@angular/core").InputSignal<boolean | undefined>;
|
|
15
19
|
readonly idGenColor: import("@angular/core").InputSignal<string | undefined>;
|
|
20
|
+
readonly getLastTextAfterSpace: import("@angular/core").InputSignal<boolean | undefined>;
|
|
16
21
|
readonly textAvatar: import("@angular/core").InputSignalWithTransform<string | undefined, string | undefined>;
|
|
17
|
-
readonly
|
|
22
|
+
readonly textAvatarClassInclude: import("@angular/core").InputSignalWithTransform<string, string | undefined>;
|
|
23
|
+
readonly containertextAvatarClassInclude: import("@angular/core").InputSignalWithTransform<string, string | undefined>;
|
|
18
24
|
readonly outAvatarError: import("@angular/core").OutputEmitterRef<void>;
|
|
25
|
+
readonly outEventPreviewImage: import("@angular/core").OutputEmitterRef<"open" | "remove">;
|
|
26
|
+
private dynamicComponentService;
|
|
19
27
|
constructor();
|
|
20
28
|
protected handlerImageError(e: ErrorEvent): Promise<void>;
|
|
29
|
+
protected handlerClickImage(): void;
|
|
21
30
|
private fontSizeComputed;
|
|
31
|
+
ngOnDestroy(): void;
|
|
22
32
|
static ɵfac: i0.ɵɵFactoryDeclaration<LibsUiComponentsAvatarComponent, never>;
|
|
23
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<LibsUiComponentsAvatarComponent, "libs_ui-components-avatar", never, { "typeShape": { "alias": "typeShape"; "required": false; "isSignal": true; }; "classInclude": { "alias": "classInclude"; "required": false; "isSignal": true; }; "size": { "alias": "size"; "required": false; "isSignal": true; }; "linkAvatar": { "alias": "linkAvatar"; "required": false; "isSignal": true; }; "linkAvatarError": { "alias": "linkAvatarError"; "required": false; "isSignal": true; }; "idGenColor": { "alias": "idGenColor"; "required": false; "isSignal": true; }; "textAvatar": { "alias": "textAvatar"; "required": false; "isSignal": true; }; "
|
|
33
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<LibsUiComponentsAvatarComponent, "libs_ui-components-avatar", never, { "typeShape": { "alias": "typeShape"; "required": false; "isSignal": true; }; "classInclude": { "alias": "classInclude"; "required": false; "isSignal": true; }; "size": { "alias": "size"; "required": false; "isSignal": true; }; "linkAvatar": { "alias": "linkAvatar"; "required": false; "isSignal": true; }; "linkAvatarError": { "alias": "linkAvatarError"; "required": false; "isSignal": true; }; "classImageInclude": { "alias": "classImageInclude"; "required": false; "isSignal": true; }; "zIndexPreviewImage": { "alias": "zIndexPreviewImage"; "required": false; "isSignal": true; }; "clickPreviewImage": { "alias": "clickPreviewImage"; "required": false; "isSignal": true; }; "idGenColor": { "alias": "idGenColor"; "required": false; "isSignal": true; }; "getLastTextAfterSpace": { "alias": "getLastTextAfterSpace"; "required": false; "isSignal": true; }; "textAvatar": { "alias": "textAvatar"; "required": false; "isSignal": true; }; "textAvatarClassInclude": { "alias": "textAvatarClassInclude"; "required": false; "isSignal": true; }; "containertextAvatarClassInclude": { "alias": "containertextAvatarClassInclude"; "required": false; "isSignal": true; }; }, { "outAvatarError": "outAvatarError"; "outEventPreviewImage": "outEventPreviewImage"; }, never, never, true, never>;
|
|
24
34
|
}
|
|
@@ -1,33 +1,45 @@
|
|
|
1
|
-
import { Component, computed, effect, input, output, signal, untracked } from '@angular/core';
|
|
1
|
+
import { Component, computed, effect, inject, input, output, signal, untracked } from '@angular/core';
|
|
2
|
+
import { LibsUiComponentsGalleryViewerComponent } from '@libs-ui/components-gallery';
|
|
3
|
+
import { LibsUiDynamicComponentService } from '@libs-ui/services-dynamic-component';
|
|
2
4
|
import { deleteUnicode, getColorById } from '@libs-ui/utils';
|
|
3
5
|
import * as i0 from "@angular/core";
|
|
4
6
|
export class LibsUiComponentsAvatarComponent {
|
|
5
|
-
|
|
6
|
-
getLastTextAfterSpace = signal(false);
|
|
7
|
+
// #region PROPERTY
|
|
7
8
|
isErrorLinkAvatar = signal(false);
|
|
8
9
|
isErrorLinkAvatarError = signal(false);
|
|
9
10
|
isShowIcon = signal(false);
|
|
10
11
|
color = computed(() => getColorById(this.idGenColor() || ''));
|
|
11
12
|
fontSize = computed(this.fontSizeComputed.bind(this));
|
|
12
|
-
|
|
13
|
-
|
|
13
|
+
galleryViewerComponent;
|
|
14
|
+
// #region INPUT
|
|
15
|
+
typeShape = input('circle', { transform: (value) => value ?? 'circle' });
|
|
14
16
|
classInclude = input('mr-[8px]', { transform: (value) => value ?? 'mr-[8px]' });
|
|
15
|
-
size = input(32, { transform: value => value ?? 32 });
|
|
17
|
+
size = input(32, { transform: (value) => value ?? 32 });
|
|
16
18
|
linkAvatar = input();
|
|
17
19
|
linkAvatarError = input();
|
|
20
|
+
classImageInclude = input('', { transform: (value) => value ?? '' });
|
|
21
|
+
zIndexPreviewImage = input();
|
|
22
|
+
clickPreviewImage = input();
|
|
18
23
|
idGenColor = input();
|
|
24
|
+
getLastTextAfterSpace = input(); // Lấy text cuối cùng sau khi cắt khoảng trắng. Lưu ý truyền biến này trước khi truyền biến textAvatar
|
|
19
25
|
textAvatar = input('', {
|
|
20
26
|
transform: (value) => {
|
|
21
|
-
value = deleteUnicode(value || '')
|
|
27
|
+
value = deleteUnicode(value || '')
|
|
28
|
+
.replace(/[^a-zA-Z0-9\s]/g, '')
|
|
29
|
+
.trim();
|
|
22
30
|
if (this.getLastTextAfterSpace()) {
|
|
23
31
|
value = value.split(' ').pop() || '';
|
|
24
32
|
}
|
|
25
33
|
return value[0] || '—';
|
|
26
|
-
}
|
|
34
|
+
},
|
|
27
35
|
});
|
|
28
|
-
|
|
29
|
-
|
|
36
|
+
textAvatarClassInclude = input('', { transform: (value) => value ?? '' });
|
|
37
|
+
containertextAvatarClassInclude = input('', { transform: (value) => value ?? '' });
|
|
38
|
+
// #region OUTPUT
|
|
30
39
|
outAvatarError = output();
|
|
40
|
+
outEventPreviewImage = output();
|
|
41
|
+
// #region INJECT
|
|
42
|
+
dynamicComponentService = inject(LibsUiDynamicComponentService);
|
|
31
43
|
constructor() {
|
|
32
44
|
effect(() => {
|
|
33
45
|
this.linkAvatar();
|
|
@@ -41,6 +53,7 @@ export class LibsUiComponentsAvatarComponent {
|
|
|
41
53
|
/* FUNCTIONS */
|
|
42
54
|
async handlerImageError(e) {
|
|
43
55
|
if (!this.linkAvatarError()?.trim() && this.idGenColor() && this.textAvatar()) {
|
|
56
|
+
this.outAvatarError.emit();
|
|
44
57
|
this.isShowIcon.set(true);
|
|
45
58
|
return;
|
|
46
59
|
}
|
|
@@ -60,6 +73,23 @@ export class LibsUiComponentsAvatarComponent {
|
|
|
60
73
|
}
|
|
61
74
|
e.target.src = this.linkAvatarError();
|
|
62
75
|
}
|
|
76
|
+
handlerClickImage() {
|
|
77
|
+
if (this.galleryViewerComponent || !this.clickPreviewImage()) {
|
|
78
|
+
return;
|
|
79
|
+
}
|
|
80
|
+
this.outEventPreviewImage.emit('open');
|
|
81
|
+
this.galleryViewerComponent = this.dynamicComponentService.resolveComponentFactory(LibsUiComponentsGalleryViewerComponent);
|
|
82
|
+
this.galleryViewerComponent.setInput('images', [{ imageSrc: this.linkAvatar() }]);
|
|
83
|
+
this.galleryViewerComponent.setInput('fieldDisplaySrcImage', 'imageSrc');
|
|
84
|
+
this.galleryViewerComponent.setInput('singleImage', true);
|
|
85
|
+
this.galleryViewerComponent.setInput('zIndex', this.zIndexPreviewImage());
|
|
86
|
+
this.galleryViewerComponent.instance.outClose.subscribe(() => {
|
|
87
|
+
this.dynamicComponentService.remove(this.galleryViewerComponent);
|
|
88
|
+
this.galleryViewerComponent = undefined;
|
|
89
|
+
this.outEventPreviewImage.emit('remove');
|
|
90
|
+
});
|
|
91
|
+
this.dynamicComponentService.addToBody(this.galleryViewerComponent);
|
|
92
|
+
}
|
|
63
93
|
/* COMPUTED PROPERTIES FUNCTION */
|
|
64
94
|
fontSizeComputed() {
|
|
65
95
|
if (this.size() === 16 || this.size() === 24) {
|
|
@@ -76,11 +106,15 @@ export class LibsUiComponentsAvatarComponent {
|
|
|
76
106
|
}
|
|
77
107
|
return 4;
|
|
78
108
|
}
|
|
109
|
+
ngOnDestroy() {
|
|
110
|
+
this.dynamicComponentService.remove(this.galleryViewerComponent);
|
|
111
|
+
this.galleryViewerComponent = undefined;
|
|
112
|
+
}
|
|
79
113
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsAvatarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
80
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LibsUiComponentsAvatarComponent, isStandalone: true, selector: "libs_ui-components-avatar", inputs: { typeShape: { classPropertyName: "typeShape", publicName: "typeShape", isSignal: true, isRequired: false, transformFunction: null }, classInclude: { classPropertyName: "classInclude", publicName: "classInclude", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, linkAvatar: { classPropertyName: "linkAvatar", publicName: "linkAvatar", isSignal: true, isRequired: false, transformFunction: null }, linkAvatarError: { classPropertyName: "linkAvatarError", publicName: "linkAvatarError", isSignal: true, isRequired: false, transformFunction: null }, idGenColor: { classPropertyName: "idGenColor", publicName: "idGenColor", isSignal: true, isRequired: false, transformFunction: null }, textAvatar: { classPropertyName: "textAvatar", publicName: "textAvatar", isSignal: true, isRequired: false, transformFunction: null },
|
|
114
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LibsUiComponentsAvatarComponent, isStandalone: true, selector: "libs_ui-components-avatar", inputs: { typeShape: { classPropertyName: "typeShape", publicName: "typeShape", isSignal: true, isRequired: false, transformFunction: null }, classInclude: { classPropertyName: "classInclude", publicName: "classInclude", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, linkAvatar: { classPropertyName: "linkAvatar", publicName: "linkAvatar", isSignal: true, isRequired: false, transformFunction: null }, linkAvatarError: { classPropertyName: "linkAvatarError", publicName: "linkAvatarError", isSignal: true, isRequired: false, transformFunction: null }, classImageInclude: { classPropertyName: "classImageInclude", publicName: "classImageInclude", isSignal: true, isRequired: false, transformFunction: null }, zIndexPreviewImage: { classPropertyName: "zIndexPreviewImage", publicName: "zIndexPreviewImage", isSignal: true, isRequired: false, transformFunction: null }, clickPreviewImage: { classPropertyName: "clickPreviewImage", publicName: "clickPreviewImage", isSignal: true, isRequired: false, transformFunction: null }, idGenColor: { classPropertyName: "idGenColor", publicName: "idGenColor", isSignal: true, isRequired: false, transformFunction: null }, getLastTextAfterSpace: { classPropertyName: "getLastTextAfterSpace", publicName: "getLastTextAfterSpace", isSignal: true, isRequired: false, transformFunction: null }, textAvatar: { classPropertyName: "textAvatar", publicName: "textAvatar", isSignal: true, isRequired: false, transformFunction: null }, textAvatarClassInclude: { classPropertyName: "textAvatarClassInclude", publicName: "textAvatarClassInclude", isSignal: true, isRequired: false, transformFunction: null }, containertextAvatarClassInclude: { classPropertyName: "containertextAvatarClassInclude", publicName: "containertextAvatarClassInclude", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { outAvatarError: "outAvatarError", outEventPreviewImage: "outEventPreviewImage" }, ngImport: i0, template: "<div class=\"libs_ui-component-avatar {{ classInclude() }}\"\n [class.libs_ui-component-avatar-rectangle]=\"typeShape() === 'rectangle'\"\n [style.width.px]='size()'\n [style.height.px]='size()'>\n @if (!isShowIcon()) {\n <img [class]=\"classImageInclude() + (clickPreviewImage() ? ' cursor-pointer' : 'cursor-default')\"\n [src]='linkAvatar()'\n (error)=\"handlerImageError($event)\"\n (click)=\"handlerClickImage()\" />\n } @else {\n <div class='libs_ui-component-avatar-icon {{ containertextAvatarClassInclude() }}'\n [style.background]='color()'>\n <div class=\"uppercase text-[#ffffff] libs-ui-font-h{{ fontSize() }}s {{ textAvatarClassInclude() }}\"\n [innerHTML]=\"textAvatar()\">\n </div>\n </div>\n }\n</div>\n", styles: [".libs_ui-component-avatar{position:relative;border-radius:50%;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#fff;transition:width .4s,height .4s}.libs_ui-component-avatar-icon,.libs_ui-component-avatar img{border:1px solid #f8f9fa;display:flex;align-items:center;justify-content:center;border-radius:50%;width:100%;height:100%}.libs_ui-component-avatar-icon{width:100%;height:100%}.libs_ui-component-avatar-rectangle{border-radius:4px}.libs_ui-component-avatar-rectangle-icon,.libs_ui-component-avatar-rectangle img{border:none;border-radius:4px;margin:auto}\n"] });
|
|
81
115
|
}
|
|
82
116
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsAvatarComponent, decorators: [{
|
|
83
117
|
type: Component,
|
|
84
|
-
args: [{ selector: 'libs_ui-components-avatar', standalone: true, template: "
|
|
118
|
+
args: [{ selector: 'libs_ui-components-avatar', standalone: true, template: "<div class=\"libs_ui-component-avatar {{ classInclude() }}\"\n [class.libs_ui-component-avatar-rectangle]=\"typeShape() === 'rectangle'\"\n [style.width.px]='size()'\n [style.height.px]='size()'>\n @if (!isShowIcon()) {\n <img [class]=\"classImageInclude() + (clickPreviewImage() ? ' cursor-pointer' : 'cursor-default')\"\n [src]='linkAvatar()'\n (error)=\"handlerImageError($event)\"\n (click)=\"handlerClickImage()\" />\n } @else {\n <div class='libs_ui-component-avatar-icon {{ containertextAvatarClassInclude() }}'\n [style.background]='color()'>\n <div class=\"uppercase text-[#ffffff] libs-ui-font-h{{ fontSize() }}s {{ textAvatarClassInclude() }}\"\n [innerHTML]=\"textAvatar()\">\n </div>\n </div>\n }\n</div>\n", styles: [".libs_ui-component-avatar{position:relative;border-radius:50%;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#fff;transition:width .4s,height .4s}.libs_ui-component-avatar-icon,.libs_ui-component-avatar img{border:1px solid #f8f9fa;display:flex;align-items:center;justify-content:center;border-radius:50%;width:100%;height:100%}.libs_ui-component-avatar-icon{width:100%;height:100%}.libs_ui-component-avatar-rectangle{border-radius:4px}.libs_ui-component-avatar-rectangle-icon,.libs_ui-component-avatar-rectangle img{border:none;border-radius:4px;margin:auto}\n"] }]
|
|
85
119
|
}], ctorParameters: () => [] });
|
|
86
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"avatar.component.js","sourceRoot":"","sources":["../../../../../libs-ui/components/avatar/src/avatar.component.ts","../../../../../libs-ui/components/avatar/src/avatar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, computed, effect, input, output, signal, untracked } from '@angular/core';\nimport { IEvent } from '@libs-ui/interfaces-types';\nimport { deleteUnicode, getColorById } from '@libs-ui/utils';\nimport { TYPE_SHAPE_AVATAR, TYPE_SIZE_AVATAR_CONFIG } from './interfaces/avatar.interface';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-avatar',\n  templateUrl: './avatar.component.html',\n  standalone: true,\n  styleUrls: ['./avatar.component.scss']\n})\nexport class LibsUiComponentsAvatarComponent {\n  /* PROPERTY */\n  protected readonly getLastTextAfterSpace = signal<boolean>(false);\n  protected isErrorLinkAvatar = signal<boolean>(false);\n  protected isErrorLinkAvatarError = signal<boolean>(false);\n  protected isShowIcon = signal<boolean>(false);\n  protected color = computed(() => getColorById(this.idGenColor() || ''));\n  protected fontSize = computed(this.fontSizeComputed.bind(this));\n\n  /* INPUT */\n  readonly typeShape = input<TYPE_SHAPE_AVATAR | undefined, TYPE_SHAPE_AVATAR | undefined>('circle', { transform: value => value ?? 'circle' });\n  readonly classInclude = input<string | undefined, string | undefined>('mr-[8px]', { transform: (value) => value ?? 'mr-[8px]' });\n  readonly size = input<TYPE_SIZE_AVATAR_CONFIG | undefined, TYPE_SIZE_AVATAR_CONFIG | undefined>(32, { transform: value => value ?? 32 });\n  readonly linkAvatar = input<string>();\n  readonly linkAvatarError = input<string>();\n  readonly idGenColor = input<string>();\n  readonly textAvatar = input<string | undefined, string | undefined>('', {\n    transform: (value) => {\n      value = deleteUnicode(value || '').replace(/[^a-zA-Z0-9\\s]/g, '').trim();\n\n      if (this.getLastTextAfterSpace()) {\n        value = value.split(' ').pop() || '';\n      }\n\n      return value[0] || '&mdash;';\n    }\n  });\n  readonly classImageInclude = input<string | undefined, string | undefined>('', { transform: (value) => value ?? '' });\n\n  /* OUTPUT */\n  readonly outAvatarError = output<void>();\n\n  constructor() {\n    effect(() => {\n      this.linkAvatar();\n      untracked(() => {\n        this.isShowIcon.set(false);\n        this.isErrorLinkAvatar.set(false);\n        this.isErrorLinkAvatarError.set(false);\n      })\n    });\n  }\n\n  /* FUNCTIONS */\n  protected async handlerImageError(e: ErrorEvent) {\n    if (!this.linkAvatarError()?.trim() && this.idGenColor() && this.textAvatar()) {\n      this.isShowIcon.set(true);\n\n      return;\n    }\n    if (this.isErrorLinkAvatar()) {\n      this.isErrorLinkAvatarError.set(true)\n    }\n    this.isErrorLinkAvatar.set(true);\n\n    if (this.isErrorLinkAvatarError() && this.idGenColor() && this.textAvatar()) {\n      this.isShowIcon.set(true)\n    }\n\n\n    if (this.isErrorLinkAvatarError()) {\n      return;\n    }\n    if (!this.linkAvatarError()) {\n      this.outAvatarError.emit();\n\n      return;\n    }\n    (e as IEvent).target.src = this.linkAvatarError();\n  }\n\n  /* COMPUTED PROPERTIES FUNCTION */\n  private fontSizeComputed() {\n    if (this.size() === 16 || this.size() === 24) {\n      return 6;\n    }\n\n    if (this.size() === 32) {\n      return 4;\n    }\n\n    if (this.size() === 40) {\n      return 3;\n    }\n\n    if (this.size() === 64) {\n      return 1;\n    }\n    return 4;\n  }\n}","@if (linkAvatar() || isShowIcon()) {\n  <div class=\"libs_ui-component-avatar {{ classInclude() }}\"\n    [class.libs_ui-component-avatar-rectangle]=\"typeShape() === 'rectangle'\"\n    [style.width.px]='size()'\n    [style.height.px]='size()'>\n    @if (linkAvatar() && !isShowIcon()) {\n      <img [class]=\"classImageInclude()\"\n        [src]='linkAvatar()'\n        (error)=\"handlerImageError($event)\" />\n    }\n    @if (isShowIcon()) {\n      <div class='libs_ui-component-avatar-icon'\n        [style.background]='color()'>\n        <div class=\"uppercase text-[#ffffff] libs-ui-font-h{{ fontSize() }}s\"\n          [innerHTML]=\"textAvatar()\">\n        </div>\n      </div>\n    }\n  </div>\n}\n"]}
|
|
120
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"avatar.component.js","sourceRoot":"","sources":["../../../../../libs-ui/components/avatar/src/avatar.component.ts","../../../../../libs-ui/components/avatar/src/avatar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ComponentRef, computed, effect, inject, input, OnDestroy, output, signal, untracked } from '@angular/core';\nimport { LibsUiComponentsGalleryViewerComponent } from '@libs-ui/components-gallery';\nimport { IEvent } from '@libs-ui/interfaces-types';\nimport { LibsUiDynamicComponentService } from '@libs-ui/services-dynamic-component';\nimport { deleteUnicode, getColorById } from '@libs-ui/utils';\nimport { TYPE_SHAPE_AVATAR, TYPE_SIZE_AVATAR_CONFIG } from './interfaces/avatar.interface';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-avatar',\n  templateUrl: './avatar.component.html',\n  standalone: true,\n  styleUrls: ['./avatar.component.scss'],\n})\nexport class LibsUiComponentsAvatarComponent implements OnDestroy {\n  // #region PROPERTY\n  protected isErrorLinkAvatar = signal<boolean>(false);\n  protected isErrorLinkAvatarError = signal<boolean>(false);\n  protected isShowIcon = signal<boolean>(false);\n  protected color = computed(() => getColorById(this.idGenColor() || ''));\n  protected fontSize = computed(this.fontSizeComputed.bind(this));\n\n  private galleryViewerComponent?: ComponentRef<LibsUiComponentsGalleryViewerComponent>;\n\n  // #region INPUT\n  readonly typeShape = input<TYPE_SHAPE_AVATAR | undefined, TYPE_SHAPE_AVATAR | undefined>('circle', { transform: (value) => value ?? 'circle' });\n  readonly classInclude = input<string | undefined, string | undefined>('mr-[8px]', { transform: (value) => value ?? 'mr-[8px]' });\n  readonly size = input<TYPE_SIZE_AVATAR_CONFIG | undefined, TYPE_SIZE_AVATAR_CONFIG | undefined>(32, { transform: (value) => value ?? 32 });\n  readonly linkAvatar = input<string>();\n  readonly linkAvatarError = input<string>();\n  readonly classImageInclude = input<string | undefined, string | undefined>('', { transform: (value) => value ?? '' });\n  readonly zIndexPreviewImage = input<number>();\n  readonly clickPreviewImage = input<boolean>();\n  readonly idGenColor = input<string>();\n  readonly getLastTextAfterSpace = input<boolean>(); // Lấy text cuối cùng sau khi cắt khoảng trắng. Lưu ý truyền biến này trước khi truyền biến textAvatar\n  readonly textAvatar = input<string | undefined, string | undefined>('', {\n    transform: (value) => {\n      value = deleteUnicode(value || '')\n        .replace(/[^a-zA-Z0-9\\s]/g, '')\n        .trim();\n\n      if (this.getLastTextAfterSpace()) {\n        value = value.split(' ').pop() || '';\n      }\n\n      return value[0] || '&mdash;';\n    },\n  });\n  readonly textAvatarClassInclude = input<string, string | undefined>('', { transform: (value) => value ?? '' });\n  readonly containertextAvatarClassInclude = input<string, string | undefined>('', { transform: (value) => value ?? '' });\n\n  // #region OUTPUT\n  readonly outAvatarError = output<void>();\n  readonly outEventPreviewImage = output<'open' | 'remove'>();\n\n  // #region INJECT\n  private dynamicComponentService = inject(LibsUiDynamicComponentService);\n\n  constructor() {\n    effect(() => {\n      this.linkAvatar();\n      untracked(() => {\n        this.isShowIcon.set(false);\n        this.isErrorLinkAvatar.set(false);\n        this.isErrorLinkAvatarError.set(false);\n      });\n    });\n  }\n\n  /* FUNCTIONS */\n  protected async handlerImageError(e: ErrorEvent) {\n    if (!this.linkAvatarError()?.trim() && this.idGenColor() && this.textAvatar()) {\n      this.outAvatarError.emit();\n      this.isShowIcon.set(true);\n\n      return;\n    }\n    if (this.isErrorLinkAvatar()) {\n      this.isErrorLinkAvatarError.set(true);\n    }\n    this.isErrorLinkAvatar.set(true);\n\n    if (this.isErrorLinkAvatarError() && this.idGenColor() && this.textAvatar()) {\n      this.isShowIcon.set(true);\n    }\n\n    if (this.isErrorLinkAvatarError()) {\n      return;\n    }\n    if (!this.linkAvatarError()) {\n      this.outAvatarError.emit();\n\n      return;\n    }\n    (e as IEvent).target.src = this.linkAvatarError();\n  }\n\n  protected handlerClickImage() {\n    if (this.galleryViewerComponent || !this.clickPreviewImage()) {\n      return;\n    }\n    this.outEventPreviewImage.emit('open');\n    this.galleryViewerComponent = this.dynamicComponentService.resolveComponentFactory(LibsUiComponentsGalleryViewerComponent);\n    this.galleryViewerComponent.setInput('images', [{ imageSrc: this.linkAvatar() }]);\n    this.galleryViewerComponent.setInput('fieldDisplaySrcImage', 'imageSrc');\n    this.galleryViewerComponent.setInput('singleImage', true);\n    this.galleryViewerComponent.setInput('zIndex', this.zIndexPreviewImage());\n    this.galleryViewerComponent.instance.outClose.subscribe(() => {\n      this.dynamicComponentService.remove(this.galleryViewerComponent);\n      this.galleryViewerComponent = undefined;\n      this.outEventPreviewImage.emit('remove');\n    });\n\n    this.dynamicComponentService.addToBody(this.galleryViewerComponent);\n  }\n\n  /* COMPUTED PROPERTIES FUNCTION */\n  private fontSizeComputed() {\n    if (this.size() === 16 || this.size() === 24) {\n      return 6;\n    }\n\n    if (this.size() === 32) {\n      return 4;\n    }\n\n    if (this.size() === 40) {\n      return 3;\n    }\n\n    if (this.size() === 64) {\n      return 1;\n    }\n    return 4;\n  }\n\n  ngOnDestroy(): void {\n    this.dynamicComponentService.remove(this.galleryViewerComponent);\n    this.galleryViewerComponent = undefined;\n  }\n}\n","<div class=\"libs_ui-component-avatar {{ classInclude() }}\"\n  [class.libs_ui-component-avatar-rectangle]=\"typeShape() === 'rectangle'\"\n  [style.width.px]='size()'\n  [style.height.px]='size()'>\n  @if (!isShowIcon()) {\n    <img [class]=\"classImageInclude() + (clickPreviewImage() ? ' cursor-pointer' : 'cursor-default')\"\n      [src]='linkAvatar()'\n      (error)=\"handlerImageError($event)\"\n      (click)=\"handlerClickImage()\" />\n  } @else {\n    <div class='libs_ui-component-avatar-icon {{ containertextAvatarClassInclude() }}'\n      [style.background]='color()'>\n      <div class=\"uppercase text-[#ffffff] libs-ui-font-h{{ fontSize() }}s {{ textAvatarClassInclude() }}\"\n        [innerHTML]=\"textAvatar()\">\n      </div>\n    </div>\n  }\n</div>\n"]}
|
|
@@ -1,34 +1,46 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import { signal, computed, input, output, effect, untracked, Component } from '@angular/core';
|
|
2
|
+
import { signal, computed, input, output, inject, effect, untracked, Component } from '@angular/core';
|
|
3
|
+
import { LibsUiComponentsGalleryViewerComponent } from '@libs-ui/components-gallery';
|
|
4
|
+
import { LibsUiDynamicComponentService } from '@libs-ui/services-dynamic-component';
|
|
3
5
|
import { getColorById, deleteUnicode } from '@libs-ui/utils';
|
|
4
6
|
|
|
5
7
|
class LibsUiComponentsAvatarComponent {
|
|
6
|
-
|
|
7
|
-
getLastTextAfterSpace = signal(false);
|
|
8
|
+
// #region PROPERTY
|
|
8
9
|
isErrorLinkAvatar = signal(false);
|
|
9
10
|
isErrorLinkAvatarError = signal(false);
|
|
10
11
|
isShowIcon = signal(false);
|
|
11
12
|
color = computed(() => getColorById(this.idGenColor() || ''));
|
|
12
13
|
fontSize = computed(this.fontSizeComputed.bind(this));
|
|
13
|
-
|
|
14
|
-
|
|
14
|
+
galleryViewerComponent;
|
|
15
|
+
// #region INPUT
|
|
16
|
+
typeShape = input('circle', { transform: (value) => value ?? 'circle' });
|
|
15
17
|
classInclude = input('mr-[8px]', { transform: (value) => value ?? 'mr-[8px]' });
|
|
16
|
-
size = input(32, { transform: value => value ?? 32 });
|
|
18
|
+
size = input(32, { transform: (value) => value ?? 32 });
|
|
17
19
|
linkAvatar = input();
|
|
18
20
|
linkAvatarError = input();
|
|
21
|
+
classImageInclude = input('', { transform: (value) => value ?? '' });
|
|
22
|
+
zIndexPreviewImage = input();
|
|
23
|
+
clickPreviewImage = input();
|
|
19
24
|
idGenColor = input();
|
|
25
|
+
getLastTextAfterSpace = input(); // Lấy text cuối cùng sau khi cắt khoảng trắng. Lưu ý truyền biến này trước khi truyền biến textAvatar
|
|
20
26
|
textAvatar = input('', {
|
|
21
27
|
transform: (value) => {
|
|
22
|
-
value = deleteUnicode(value || '')
|
|
28
|
+
value = deleteUnicode(value || '')
|
|
29
|
+
.replace(/[^a-zA-Z0-9\s]/g, '')
|
|
30
|
+
.trim();
|
|
23
31
|
if (this.getLastTextAfterSpace()) {
|
|
24
32
|
value = value.split(' ').pop() || '';
|
|
25
33
|
}
|
|
26
34
|
return value[0] || '—';
|
|
27
|
-
}
|
|
35
|
+
},
|
|
28
36
|
});
|
|
29
|
-
|
|
30
|
-
|
|
37
|
+
textAvatarClassInclude = input('', { transform: (value) => value ?? '' });
|
|
38
|
+
containertextAvatarClassInclude = input('', { transform: (value) => value ?? '' });
|
|
39
|
+
// #region OUTPUT
|
|
31
40
|
outAvatarError = output();
|
|
41
|
+
outEventPreviewImage = output();
|
|
42
|
+
// #region INJECT
|
|
43
|
+
dynamicComponentService = inject(LibsUiDynamicComponentService);
|
|
32
44
|
constructor() {
|
|
33
45
|
effect(() => {
|
|
34
46
|
this.linkAvatar();
|
|
@@ -42,6 +54,7 @@ class LibsUiComponentsAvatarComponent {
|
|
|
42
54
|
/* FUNCTIONS */
|
|
43
55
|
async handlerImageError(e) {
|
|
44
56
|
if (!this.linkAvatarError()?.trim() && this.idGenColor() && this.textAvatar()) {
|
|
57
|
+
this.outAvatarError.emit();
|
|
45
58
|
this.isShowIcon.set(true);
|
|
46
59
|
return;
|
|
47
60
|
}
|
|
@@ -61,6 +74,23 @@ class LibsUiComponentsAvatarComponent {
|
|
|
61
74
|
}
|
|
62
75
|
e.target.src = this.linkAvatarError();
|
|
63
76
|
}
|
|
77
|
+
handlerClickImage() {
|
|
78
|
+
if (this.galleryViewerComponent || !this.clickPreviewImage()) {
|
|
79
|
+
return;
|
|
80
|
+
}
|
|
81
|
+
this.outEventPreviewImage.emit('open');
|
|
82
|
+
this.galleryViewerComponent = this.dynamicComponentService.resolveComponentFactory(LibsUiComponentsGalleryViewerComponent);
|
|
83
|
+
this.galleryViewerComponent.setInput('images', [{ imageSrc: this.linkAvatar() }]);
|
|
84
|
+
this.galleryViewerComponent.setInput('fieldDisplaySrcImage', 'imageSrc');
|
|
85
|
+
this.galleryViewerComponent.setInput('singleImage', true);
|
|
86
|
+
this.galleryViewerComponent.setInput('zIndex', this.zIndexPreviewImage());
|
|
87
|
+
this.galleryViewerComponent.instance.outClose.subscribe(() => {
|
|
88
|
+
this.dynamicComponentService.remove(this.galleryViewerComponent);
|
|
89
|
+
this.galleryViewerComponent = undefined;
|
|
90
|
+
this.outEventPreviewImage.emit('remove');
|
|
91
|
+
});
|
|
92
|
+
this.dynamicComponentService.addToBody(this.galleryViewerComponent);
|
|
93
|
+
}
|
|
64
94
|
/* COMPUTED PROPERTIES FUNCTION */
|
|
65
95
|
fontSizeComputed() {
|
|
66
96
|
if (this.size() === 16 || this.size() === 24) {
|
|
@@ -77,12 +107,16 @@ class LibsUiComponentsAvatarComponent {
|
|
|
77
107
|
}
|
|
78
108
|
return 4;
|
|
79
109
|
}
|
|
110
|
+
ngOnDestroy() {
|
|
111
|
+
this.dynamicComponentService.remove(this.galleryViewerComponent);
|
|
112
|
+
this.galleryViewerComponent = undefined;
|
|
113
|
+
}
|
|
80
114
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsAvatarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
81
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LibsUiComponentsAvatarComponent, isStandalone: true, selector: "libs_ui-components-avatar", inputs: { typeShape: { classPropertyName: "typeShape", publicName: "typeShape", isSignal: true, isRequired: false, transformFunction: null }, classInclude: { classPropertyName: "classInclude", publicName: "classInclude", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, linkAvatar: { classPropertyName: "linkAvatar", publicName: "linkAvatar", isSignal: true, isRequired: false, transformFunction: null }, linkAvatarError: { classPropertyName: "linkAvatarError", publicName: "linkAvatarError", isSignal: true, isRequired: false, transformFunction: null }, idGenColor: { classPropertyName: "idGenColor", publicName: "idGenColor", isSignal: true, isRequired: false, transformFunction: null }, textAvatar: { classPropertyName: "textAvatar", publicName: "textAvatar", isSignal: true, isRequired: false, transformFunction: null },
|
|
115
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LibsUiComponentsAvatarComponent, isStandalone: true, selector: "libs_ui-components-avatar", inputs: { typeShape: { classPropertyName: "typeShape", publicName: "typeShape", isSignal: true, isRequired: false, transformFunction: null }, classInclude: { classPropertyName: "classInclude", publicName: "classInclude", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, linkAvatar: { classPropertyName: "linkAvatar", publicName: "linkAvatar", isSignal: true, isRequired: false, transformFunction: null }, linkAvatarError: { classPropertyName: "linkAvatarError", publicName: "linkAvatarError", isSignal: true, isRequired: false, transformFunction: null }, classImageInclude: { classPropertyName: "classImageInclude", publicName: "classImageInclude", isSignal: true, isRequired: false, transformFunction: null }, zIndexPreviewImage: { classPropertyName: "zIndexPreviewImage", publicName: "zIndexPreviewImage", isSignal: true, isRequired: false, transformFunction: null }, clickPreviewImage: { classPropertyName: "clickPreviewImage", publicName: "clickPreviewImage", isSignal: true, isRequired: false, transformFunction: null }, idGenColor: { classPropertyName: "idGenColor", publicName: "idGenColor", isSignal: true, isRequired: false, transformFunction: null }, getLastTextAfterSpace: { classPropertyName: "getLastTextAfterSpace", publicName: "getLastTextAfterSpace", isSignal: true, isRequired: false, transformFunction: null }, textAvatar: { classPropertyName: "textAvatar", publicName: "textAvatar", isSignal: true, isRequired: false, transformFunction: null }, textAvatarClassInclude: { classPropertyName: "textAvatarClassInclude", publicName: "textAvatarClassInclude", isSignal: true, isRequired: false, transformFunction: null }, containertextAvatarClassInclude: { classPropertyName: "containertextAvatarClassInclude", publicName: "containertextAvatarClassInclude", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { outAvatarError: "outAvatarError", outEventPreviewImage: "outEventPreviewImage" }, ngImport: i0, template: "<div class=\"libs_ui-component-avatar {{ classInclude() }}\"\n [class.libs_ui-component-avatar-rectangle]=\"typeShape() === 'rectangle'\"\n [style.width.px]='size()'\n [style.height.px]='size()'>\n @if (!isShowIcon()) {\n <img [class]=\"classImageInclude() + (clickPreviewImage() ? ' cursor-pointer' : 'cursor-default')\"\n [src]='linkAvatar()'\n (error)=\"handlerImageError($event)\"\n (click)=\"handlerClickImage()\" />\n } @else {\n <div class='libs_ui-component-avatar-icon {{ containertextAvatarClassInclude() }}'\n [style.background]='color()'>\n <div class=\"uppercase text-[#ffffff] libs-ui-font-h{{ fontSize() }}s {{ textAvatarClassInclude() }}\"\n [innerHTML]=\"textAvatar()\">\n </div>\n </div>\n }\n</div>\n", styles: [".libs_ui-component-avatar{position:relative;border-radius:50%;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#fff;transition:width .4s,height .4s}.libs_ui-component-avatar-icon,.libs_ui-component-avatar img{border:1px solid #f8f9fa;display:flex;align-items:center;justify-content:center;border-radius:50%;width:100%;height:100%}.libs_ui-component-avatar-icon{width:100%;height:100%}.libs_ui-component-avatar-rectangle{border-radius:4px}.libs_ui-component-avatar-rectangle-icon,.libs_ui-component-avatar-rectangle img{border:none;border-radius:4px;margin:auto}\n"] });
|
|
82
116
|
}
|
|
83
117
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsAvatarComponent, decorators: [{
|
|
84
118
|
type: Component,
|
|
85
|
-
args: [{ selector: 'libs_ui-components-avatar', standalone: true, template: "
|
|
119
|
+
args: [{ selector: 'libs_ui-components-avatar', standalone: true, template: "<div class=\"libs_ui-component-avatar {{ classInclude() }}\"\n [class.libs_ui-component-avatar-rectangle]=\"typeShape() === 'rectangle'\"\n [style.width.px]='size()'\n [style.height.px]='size()'>\n @if (!isShowIcon()) {\n <img [class]=\"classImageInclude() + (clickPreviewImage() ? ' cursor-pointer' : 'cursor-default')\"\n [src]='linkAvatar()'\n (error)=\"handlerImageError($event)\"\n (click)=\"handlerClickImage()\" />\n } @else {\n <div class='libs_ui-component-avatar-icon {{ containertextAvatarClassInclude() }}'\n [style.background]='color()'>\n <div class=\"uppercase text-[#ffffff] libs-ui-font-h{{ fontSize() }}s {{ textAvatarClassInclude() }}\"\n [innerHTML]=\"textAvatar()\">\n </div>\n </div>\n }\n</div>\n", styles: [".libs_ui-component-avatar{position:relative;border-radius:50%;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#fff;transition:width .4s,height .4s}.libs_ui-component-avatar-icon,.libs_ui-component-avatar img{border:1px solid #f8f9fa;display:flex;align-items:center;justify-content:center;border-radius:50%;width:100%;height:100%}.libs_ui-component-avatar-icon{width:100%;height:100%}.libs_ui-component-avatar-rectangle{border-radius:4px}.libs_ui-component-avatar-rectangle-icon,.libs_ui-component-avatar-rectangle img{border:none;border-radius:4px;margin:auto}\n"] }]
|
|
86
120
|
}], ctorParameters: () => [] });
|
|
87
121
|
|
|
88
122
|
/**
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"libs-ui-components-avatar.mjs","sources":["../../../../../libs-ui/components/avatar/src/avatar.component.ts","../../../../../libs-ui/components/avatar/src/avatar.component.html","../../../../../libs-ui/components/avatar/src/libs-ui-components-avatar.ts"],"sourcesContent":["import { Component, computed, effect, input, output, signal, untracked } from '@angular/core';\nimport { IEvent } from '@libs-ui/interfaces-types';\nimport { deleteUnicode, getColorById } from '@libs-ui/utils';\nimport { TYPE_SHAPE_AVATAR, TYPE_SIZE_AVATAR_CONFIG } from './interfaces/avatar.interface';\n\n@Component({\n // eslint-disable-next-line @angular-eslint/component-selector\n selector: 'libs_ui-components-avatar',\n templateUrl: './avatar.component.html',\n standalone: true,\n styleUrls: ['./avatar.component.scss']\n})\nexport class LibsUiComponentsAvatarComponent {\n /* PROPERTY */\n protected readonly getLastTextAfterSpace = signal<boolean>(false);\n protected isErrorLinkAvatar = signal<boolean>(false);\n protected isErrorLinkAvatarError = signal<boolean>(false);\n protected isShowIcon = signal<boolean>(false);\n protected color = computed(() => getColorById(this.idGenColor() || ''));\n protected fontSize = computed(this.fontSizeComputed.bind(this));\n\n /* INPUT */\n readonly typeShape = input<TYPE_SHAPE_AVATAR | undefined, TYPE_SHAPE_AVATAR | undefined>('circle', { transform: value => value ?? 'circle' });\n readonly classInclude = input<string | undefined, string | undefined>('mr-[8px]', { transform: (value) => value ?? 'mr-[8px]' });\n readonly size = input<TYPE_SIZE_AVATAR_CONFIG | undefined, TYPE_SIZE_AVATAR_CONFIG | undefined>(32, { transform: value => value ?? 32 });\n readonly linkAvatar = input<string>();\n readonly linkAvatarError = input<string>();\n readonly idGenColor = input<string>();\n readonly textAvatar = input<string | undefined, string | undefined>('', {\n transform: (value) => {\n value = deleteUnicode(value || '').replace(/[^a-zA-Z0-9\\s]/g, '').trim();\n\n if (this.getLastTextAfterSpace()) {\n value = value.split(' ').pop() || '';\n }\n\n return value[0] || '—';\n }\n });\n readonly classImageInclude = input<string | undefined, string | undefined>('', { transform: (value) => value ?? '' });\n\n /* OUTPUT */\n readonly outAvatarError = output<void>();\n\n constructor() {\n effect(() => {\n this.linkAvatar();\n untracked(() => {\n this.isShowIcon.set(false);\n this.isErrorLinkAvatar.set(false);\n this.isErrorLinkAvatarError.set(false);\n })\n });\n }\n\n /* FUNCTIONS */\n protected async handlerImageError(e: ErrorEvent) {\n if (!this.linkAvatarError()?.trim() && this.idGenColor() && this.textAvatar()) {\n this.isShowIcon.set(true);\n\n return;\n }\n if (this.isErrorLinkAvatar()) {\n this.isErrorLinkAvatarError.set(true)\n }\n this.isErrorLinkAvatar.set(true);\n\n if (this.isErrorLinkAvatarError() && this.idGenColor() && this.textAvatar()) {\n this.isShowIcon.set(true)\n }\n\n\n if (this.isErrorLinkAvatarError()) {\n return;\n }\n if (!this.linkAvatarError()) {\n this.outAvatarError.emit();\n\n return;\n }\n (e as IEvent).target.src = this.linkAvatarError();\n }\n\n /* COMPUTED PROPERTIES FUNCTION */\n private fontSizeComputed() {\n if (this.size() === 16 || this.size() === 24) {\n return 6;\n }\n\n if (this.size() === 32) {\n return 4;\n }\n\n if (this.size() === 40) {\n return 3;\n }\n\n if (this.size() === 64) {\n return 1;\n }\n return 4;\n }\n}","@if (linkAvatar() || isShowIcon()) {\n <div class=\"libs_ui-component-avatar {{ classInclude() }}\"\n [class.libs_ui-component-avatar-rectangle]=\"typeShape() === 'rectangle'\"\n [style.width.px]='size()'\n [style.height.px]='size()'>\n @if (linkAvatar() && !isShowIcon()) {\n <img [class]=\"classImageInclude()\"\n [src]='linkAvatar()'\n (error)=\"handlerImageError($event)\" />\n }\n @if (isShowIcon()) {\n <div class='libs_ui-component-avatar-icon'\n [style.background]='color()'>\n <div class=\"uppercase text-[#ffffff] libs-ui-font-h{{ fontSize() }}s\"\n [innerHTML]=\"textAvatar()\">\n </div>\n </div>\n }\n </div>\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-avatar.mjs","sources":["../../../../../libs-ui/components/avatar/src/avatar.component.ts","../../../../../libs-ui/components/avatar/src/avatar.component.html","../../../../../libs-ui/components/avatar/src/libs-ui-components-avatar.ts"],"sourcesContent":["import { Component, ComponentRef, computed, effect, inject, input, OnDestroy, output, signal, untracked } from '@angular/core';\nimport { LibsUiComponentsGalleryViewerComponent } from '@libs-ui/components-gallery';\nimport { IEvent } from '@libs-ui/interfaces-types';\nimport { LibsUiDynamicComponentService } from '@libs-ui/services-dynamic-component';\nimport { deleteUnicode, getColorById } from '@libs-ui/utils';\nimport { TYPE_SHAPE_AVATAR, TYPE_SIZE_AVATAR_CONFIG } from './interfaces/avatar.interface';\n\n@Component({\n // eslint-disable-next-line @angular-eslint/component-selector\n selector: 'libs_ui-components-avatar',\n templateUrl: './avatar.component.html',\n standalone: true,\n styleUrls: ['./avatar.component.scss'],\n})\nexport class LibsUiComponentsAvatarComponent implements OnDestroy {\n // #region PROPERTY\n protected isErrorLinkAvatar = signal<boolean>(false);\n protected isErrorLinkAvatarError = signal<boolean>(false);\n protected isShowIcon = signal<boolean>(false);\n protected color = computed(() => getColorById(this.idGenColor() || ''));\n protected fontSize = computed(this.fontSizeComputed.bind(this));\n\n private galleryViewerComponent?: ComponentRef<LibsUiComponentsGalleryViewerComponent>;\n\n // #region INPUT\n readonly typeShape = input<TYPE_SHAPE_AVATAR | undefined, TYPE_SHAPE_AVATAR | undefined>('circle', { transform: (value) => value ?? 'circle' });\n readonly classInclude = input<string | undefined, string | undefined>('mr-[8px]', { transform: (value) => value ?? 'mr-[8px]' });\n readonly size = input<TYPE_SIZE_AVATAR_CONFIG | undefined, TYPE_SIZE_AVATAR_CONFIG | undefined>(32, { transform: (value) => value ?? 32 });\n readonly linkAvatar = input<string>();\n readonly linkAvatarError = input<string>();\n readonly classImageInclude = input<string | undefined, string | undefined>('', { transform: (value) => value ?? '' });\n readonly zIndexPreviewImage = input<number>();\n readonly clickPreviewImage = input<boolean>();\n readonly idGenColor = input<string>();\n readonly getLastTextAfterSpace = input<boolean>(); // Lấy text cuối cùng sau khi cắt khoảng trắng. Lưu ý truyền biến này trước khi truyền biến textAvatar\n readonly textAvatar = input<string | undefined, string | undefined>('', {\n transform: (value) => {\n value = deleteUnicode(value || '')\n .replace(/[^a-zA-Z0-9\\s]/g, '')\n .trim();\n\n if (this.getLastTextAfterSpace()) {\n value = value.split(' ').pop() || '';\n }\n\n return value[0] || '—';\n },\n });\n readonly textAvatarClassInclude = input<string, string | undefined>('', { transform: (value) => value ?? '' });\n readonly containertextAvatarClassInclude = input<string, string | undefined>('', { transform: (value) => value ?? '' });\n\n // #region OUTPUT\n readonly outAvatarError = output<void>();\n readonly outEventPreviewImage = output<'open' | 'remove'>();\n\n // #region INJECT\n private dynamicComponentService = inject(LibsUiDynamicComponentService);\n\n constructor() {\n effect(() => {\n this.linkAvatar();\n untracked(() => {\n this.isShowIcon.set(false);\n this.isErrorLinkAvatar.set(false);\n this.isErrorLinkAvatarError.set(false);\n });\n });\n }\n\n /* FUNCTIONS */\n protected async handlerImageError(e: ErrorEvent) {\n if (!this.linkAvatarError()?.trim() && this.idGenColor() && this.textAvatar()) {\n this.outAvatarError.emit();\n this.isShowIcon.set(true);\n\n return;\n }\n if (this.isErrorLinkAvatar()) {\n this.isErrorLinkAvatarError.set(true);\n }\n this.isErrorLinkAvatar.set(true);\n\n if (this.isErrorLinkAvatarError() && this.idGenColor() && this.textAvatar()) {\n this.isShowIcon.set(true);\n }\n\n if (this.isErrorLinkAvatarError()) {\n return;\n }\n if (!this.linkAvatarError()) {\n this.outAvatarError.emit();\n\n return;\n }\n (e as IEvent).target.src = this.linkAvatarError();\n }\n\n protected handlerClickImage() {\n if (this.galleryViewerComponent || !this.clickPreviewImage()) {\n return;\n }\n this.outEventPreviewImage.emit('open');\n this.galleryViewerComponent = this.dynamicComponentService.resolveComponentFactory(LibsUiComponentsGalleryViewerComponent);\n this.galleryViewerComponent.setInput('images', [{ imageSrc: this.linkAvatar() }]);\n this.galleryViewerComponent.setInput('fieldDisplaySrcImage', 'imageSrc');\n this.galleryViewerComponent.setInput('singleImage', true);\n this.galleryViewerComponent.setInput('zIndex', this.zIndexPreviewImage());\n this.galleryViewerComponent.instance.outClose.subscribe(() => {\n this.dynamicComponentService.remove(this.galleryViewerComponent);\n this.galleryViewerComponent = undefined;\n this.outEventPreviewImage.emit('remove');\n });\n\n this.dynamicComponentService.addToBody(this.galleryViewerComponent);\n }\n\n /* COMPUTED PROPERTIES FUNCTION */\n private fontSizeComputed() {\n if (this.size() === 16 || this.size() === 24) {\n return 6;\n }\n\n if (this.size() === 32) {\n return 4;\n }\n\n if (this.size() === 40) {\n return 3;\n }\n\n if (this.size() === 64) {\n return 1;\n }\n return 4;\n }\n\n ngOnDestroy(): void {\n this.dynamicComponentService.remove(this.galleryViewerComponent);\n this.galleryViewerComponent = undefined;\n }\n}\n","<div class=\"libs_ui-component-avatar {{ classInclude() }}\"\n [class.libs_ui-component-avatar-rectangle]=\"typeShape() === 'rectangle'\"\n [style.width.px]='size()'\n [style.height.px]='size()'>\n @if (!isShowIcon()) {\n <img [class]=\"classImageInclude() + (clickPreviewImage() ? ' cursor-pointer' : 'cursor-default')\"\n [src]='linkAvatar()'\n (error)=\"handlerImageError($event)\"\n (click)=\"handlerClickImage()\" />\n } @else {\n <div class='libs_ui-component-avatar-icon {{ containertextAvatarClassInclude() }}'\n [style.background]='color()'>\n <div class=\"uppercase text-[#ffffff] libs-ui-font-h{{ fontSize() }}s {{ textAvatarClassInclude() }}\"\n [innerHTML]=\"textAvatar()\">\n </div>\n </div>\n }\n</div>\n","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,9 +1,10 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@libs-ui/components-avatar",
|
|
3
|
-
"version": "0.2.
|
|
3
|
+
"version": "0.2.306.1",
|
|
4
4
|
"peerDependencies": {
|
|
5
|
-
"@angular/
|
|
6
|
-
"@
|
|
5
|
+
"@angular/core": ">=18.0.0",
|
|
6
|
+
"@libs-ui/interfaces-types": "0.2.306.1",
|
|
7
|
+
"@libs-ui/utils": "0.2.306.1"
|
|
7
8
|
},
|
|
8
9
|
"sideEffects": false,
|
|
9
10
|
"module": "fesm2022/libs-ui-components-avatar.mjs",
|