@libs-ui/components-buttons-dropdown 0.2.278 → 0.2.280
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 +159 -2
- package/dropdown.interface.d.ts +20 -7
- package/esm2022/dropdown.component.mjs +2 -2
- package/esm2022/dropdown.interface.mjs +1 -1
- package/fesm2022/libs-ui-components-buttons-dropdown.mjs +1 -1
- package/fesm2022/libs-ui-components-buttons-dropdown.mjs.map +1 -1
- package/package.json +5 -5
package/README.md
CHANGED
|
@@ -1,3 +1,160 @@
|
|
|
1
|
-
#
|
|
1
|
+
# Button Dropdown
|
|
2
2
|
|
|
3
|
-
|
|
3
|
+
## Giới thiệu
|
|
4
|
+
|
|
5
|
+
`@libs-ui/components-buttons-dropdown` là một component Dropdown Button dùng cho Angular, cho phép hiển thị danh sách các tùy chọn khi nhấn vào button, hỗ trợ custom templates, binding lựa chọn và nhiều tùy chỉnh linh hoạt.
|
|
6
|
+
|
|
7
|
+
## Tính năng
|
|
8
|
+
|
|
9
|
+
- Hiển thị danh sách items dưới dạng popover khi click (hoặc hover)
|
|
10
|
+
- Hỗ trợ custom label và key cho items
|
|
11
|
+
- Two-way binding giá trị chọn (`keySelected`)
|
|
12
|
+
- Tuỳ chọn auto apply (`applyNow`) hoặc yêu cầu click nút Áp dụng
|
|
13
|
+
- Hỗ trợ vô hiệu hóa và tuỳ chỉnh kích thước, kiểu button
|
|
14
|
+
- Cấu hình popover (kích thước, vị trí, z-index, direction)
|
|
15
|
+
- Hỗ trợ custom CSS classes cho container và items
|
|
16
|
+
|
|
17
|
+
## Cài đặt
|
|
18
|
+
|
|
19
|
+
```bash
|
|
20
|
+
npm install @libs-ui/components-buttons-dropdown
|
|
21
|
+
```
|
|
22
|
+
|
|
23
|
+
hoặc
|
|
24
|
+
|
|
25
|
+
```bash
|
|
26
|
+
yarn add @libs-ui/components-buttons-dropdown
|
|
27
|
+
```
|
|
28
|
+
|
|
29
|
+
## Sử dụng
|
|
30
|
+
|
|
31
|
+
### Inline Template
|
|
32
|
+
|
|
33
|
+
```typescript
|
|
34
|
+
import { Component } from '@angular/core';
|
|
35
|
+
import { LibsUiComponentsButtonsDropdownComponent } from '@libs-ui/components-buttons-dropdown';
|
|
36
|
+
|
|
37
|
+
@Component({
|
|
38
|
+
selector: 'app-example',
|
|
39
|
+
standalone: true,
|
|
40
|
+
imports: [LibsUiComponentsButtonsDropdownComponent],
|
|
41
|
+
template: `
|
|
42
|
+
<libs_ui-components-buttons-dropdown
|
|
43
|
+
[label]="'Chọn mục'"
|
|
44
|
+
[items]="items"
|
|
45
|
+
[(keySelected)]="selectedKey"
|
|
46
|
+
(outSelectItem)="onSelect($event)">
|
|
47
|
+
</libs_ui-components-buttons-dropdown>
|
|
48
|
+
`
|
|
49
|
+
})
|
|
50
|
+
export class ExampleComponent {
|
|
51
|
+
items = [
|
|
52
|
+
{ id: '1', label: 'Option 1' },
|
|
53
|
+
{ id: '2', label: 'Option 2' },
|
|
54
|
+
{ id: '3', label: 'Option 3' }
|
|
55
|
+
];
|
|
56
|
+
selectedKey = '1';
|
|
57
|
+
onSelect(item: any) {
|
|
58
|
+
console.log('Selected:', item);
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
```
|
|
62
|
+
|
|
63
|
+
### File HTML riêng
|
|
64
|
+
|
|
65
|
+
```typescript
|
|
66
|
+
import { Component } from '@angular/core';
|
|
67
|
+
import { LibsUiComponentsButtonsDropdownComponent } from '@libs-ui/components-buttons-dropdown';
|
|
68
|
+
|
|
69
|
+
@Component({
|
|
70
|
+
selector: 'app-example',
|
|
71
|
+
standalone: true,
|
|
72
|
+
imports: [LibsUiComponentsButtonsDropdownComponent],
|
|
73
|
+
templateUrl: './example.component.html'
|
|
74
|
+
})
|
|
75
|
+
export class ExampleComponent {
|
|
76
|
+
items = [ /* ... */ ];
|
|
77
|
+
selectedKey = '';
|
|
78
|
+
onSelect(item: any) { }
|
|
79
|
+
}
|
|
80
|
+
```
|
|
81
|
+
|
|
82
|
+
```html
|
|
83
|
+
<libs_ui-components-buttons-dropdown
|
|
84
|
+
[label]="'Chọn mục'"
|
|
85
|
+
[items]="items"
|
|
86
|
+
[(keySelected)]="selectedKey"
|
|
87
|
+
(outSelectItem)="onSelect($event)">
|
|
88
|
+
</libs_ui-components-buttons-dropdown>
|
|
89
|
+
```
|
|
90
|
+
|
|
91
|
+
## API Reference
|
|
92
|
+
|
|
93
|
+
### Inputs
|
|
94
|
+
|
|
95
|
+
| Tên | Kiểu | Mặc định | Mô tả |
|
|
96
|
+
|---------------------------------|--------------------------------|--------------------------|------------------------------------------------------------|
|
|
97
|
+
| label | `string` | `''` | Text hiển thị trên nút (ví dụ: "Chọn mục"). |
|
|
98
|
+
| items | `Array<any>` | required | Danh sách các mục sẽ hiển thị trong menu. |
|
|
99
|
+
| fieldDisplay | `string` | `label` | Trường của mục để hiển thị nội dung. |
|
|
100
|
+
| keyField | `string` | `id` | Trường của mục dùng làm giá trị key. |
|
|
101
|
+
| keySelected | `string` | undefined | Giá trị key đang được chọn (hỗ trợ two-way binding). |
|
|
102
|
+
| applyNow | `boolean` | `false` | Nếu true: chọn xong tự emit sự kiện; false: cần bấm nút Áp dụng. |
|
|
103
|
+
| showBorderBottom | `boolean` | `false` | Hiện đường kẻ dưới menu khi mở. |
|
|
104
|
+
| disable | `boolean` | `false` | Khóa dropdown, không cho chọn mục. |
|
|
105
|
+
| sizeButton | `TYPE_SIZE_BUTTON` | `medium` | Kích thước nút (.small/.medium/.large). |
|
|
106
|
+
| typeButton | `TYPE_BUTTON` | `button-primary` | Kiểu style của nút (primary, secondary,...). |
|
|
107
|
+
| classLabel | `string` | `''` | Class CSS thêm cho nhãn (text). |
|
|
108
|
+
| classInclude | `string` | `''` | Class CSS thêm cho phần container chính. |
|
|
109
|
+
| classIncludeContainer | `string` | undefined | Class CSS thêm cho phần container nội dung. |
|
|
110
|
+
| fieldClass | `string` | `class` | Trường trong mục chứa class CSS khi cần. |
|
|
111
|
+
| classIconLeft | `string` | `''` | Class CSS thêm cho icon bên trái. |
|
|
112
|
+
| classIconRight | `string` | `libs-ui-icon-move-right rotate-[90deg]` | Class CSS thêm cho icon bên phải. |
|
|
113
|
+
| iconOnlyType | `boolean` | `false` | Chỉ hiện icon, không hiển thị nhãn. |
|
|
114
|
+
| popupConfig | `IPopupConfigButtonDropdown` | default cấu hình popover | Cấu hình chi tiết cho popover (vị trí, kích thước). |
|
|
115
|
+
| ignoreHiddenPopoverContentWhenMouseLeave | `boolean` | `true` | Giữ popover mở khi chuột rời khỏi nội dung. |
|
|
116
|
+
| modePopover | `TYPE_POPOVER_MODE` | `click-toggle` | Cách hiển thị popover (click, hover,...). |
|
|
117
|
+
|
|
118
|
+
### Outputs
|
|
119
|
+
|
|
120
|
+
| Tên | Kiểu | Mô tả |
|
|
121
|
+
|----------------------|-------------------------------|-----------------------------------------------------------|
|
|
122
|
+
| outSelectItem | `(item: any) => void` | Trả về mục (item) bạn vừa chọn. |
|
|
123
|
+
| outHover | `(isHover: boolean) => void` | Phát ra khi rê chuột lên/xuống trên một mục. |
|
|
124
|
+
| outApply | `(item: any) => void` | Phát ra khi bạn bấm nút Áp dụng (với applyNow=false). |
|
|
125
|
+
| outPopoverEvent | `(event: TYPE_POPOVER_EVENT) => void` | Phát ra các sự kiện của popover (show, hide, click, ...). |
|
|
126
|
+
| outFunctionsControl | `(control: IPopoverFunctionControlEvent) => void` | Cung cấp control API để điều khiển popover. |
|
|
127
|
+
| outIconEvent | `(event: MouseEvent) => void` | Phát ra khi bạn nhấn vào icon. |
|
|
128
|
+
|
|
129
|
+
### Interfaces
|
|
130
|
+
```typescript
|
|
131
|
+
export interface IButtonDropdown extends IButton {
|
|
132
|
+
items: any[];
|
|
133
|
+
fieldDisplay?: string;
|
|
134
|
+
keyField?: string;
|
|
135
|
+
keySelected?: string;
|
|
136
|
+
applyNow?: boolean;
|
|
137
|
+
showBorderBottom?: boolean;
|
|
138
|
+
popupConfig?: IPopupConfigButtonDropdown;
|
|
139
|
+
ignoreHiddenPopoverContentWhenMouseLeave?: boolean;
|
|
140
|
+
modePopover?: TYPE_POPOVER_MODE;
|
|
141
|
+
}
|
|
142
|
+
|
|
143
|
+
export interface IPopupConfigButtonDropdown {
|
|
144
|
+
width?: number;
|
|
145
|
+
maxWidth?: number;
|
|
146
|
+
maxHeight?: number;
|
|
147
|
+
zIndex?: number;
|
|
148
|
+
direction?: TYPE_POPOVER_DIRECTION;
|
|
149
|
+
timeDestroy?: number;
|
|
150
|
+
widthByParent?: boolean;
|
|
151
|
+
position?: {
|
|
152
|
+
mode: 'start' | 'center' | 'end';
|
|
153
|
+
distance: number;
|
|
154
|
+
};
|
|
155
|
+
classInclude?: string;
|
|
156
|
+
}
|
|
157
|
+
|
|
158
|
+
export type TYPE_POPOVER_DIRECTION = 'top' | 'right' | 'bottom' | 'left';
|
|
159
|
+
export type TYPE_POPOVER_MODE = 'hover' | 'click' | 'click-toggle' | 'click_open_and_click_panel_content_hidden';
|
|
160
|
+
```
|
package/dropdown.interface.d.ts
CHANGED
|
@@ -1,16 +1,29 @@
|
|
|
1
1
|
import { IButton } from "@libs-ui/components-buttons-button";
|
|
2
|
-
import { TYPE_POPOVER_DIRECTION } from "@libs-ui/components-popover";
|
|
3
|
-
|
|
2
|
+
import { TYPE_POPOVER_DIRECTION, TYPE_POPOVER_MODE } from "@libs-ui/components-popover";
|
|
3
|
+
/**
|
|
4
|
+
* Interface for Dropdown Button component inputs.
|
|
5
|
+
*/
|
|
4
6
|
export interface IButtonDropdown extends IButton {
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
7
|
+
/** Danh sách các mục sẽ hiển thị trong menu. */
|
|
8
|
+
items: any[];
|
|
9
|
+
/** Tên trường dùng để hiển thị nội dung của mỗi mục. */
|
|
10
|
+
fieldDisplay?: string;
|
|
11
|
+
/** Tên trường dùng làm giá trị key của mỗi mục. */
|
|
12
|
+
keyField?: string;
|
|
13
|
+
/** Giá trị key đang được chọn (hỗ trợ two-way binding). */
|
|
8
14
|
keySelected?: string;
|
|
15
|
+
/** Nếu true: chọn xong tự emit sự kiện; false: cần bấm nút Áp dụng. */
|
|
9
16
|
applyNow?: boolean;
|
|
17
|
+
/** Hiển thị đường kẻ dưới menu khi mở. */
|
|
18
|
+
showBorderBottom?: boolean;
|
|
19
|
+
/** Cấu hình chi tiết cho popover (vị trí, kích thước). */
|
|
10
20
|
popupConfig?: IPopupConfigButtonDropdown;
|
|
11
|
-
|
|
12
|
-
|
|
21
|
+
/** Giữ popover mở khi chuột rời khỏi nội dung. */
|
|
22
|
+
ignoreHiddenPopoverContentWhenMouseLeave?: boolean;
|
|
23
|
+
/** Cách hiển thị popover (click, hover,...). */
|
|
24
|
+
modePopover?: TYPE_POPOVER_MODE;
|
|
13
25
|
}
|
|
26
|
+
/** Configuration options for Dropdown popover. */
|
|
14
27
|
export interface IPopupConfigButtonDropdown {
|
|
15
28
|
width?: number;
|
|
16
29
|
maxWidth?: number;
|
|
@@ -16,7 +16,7 @@ export class LibsUiComponentsButtonsDropdownComponent {
|
|
|
16
16
|
fieldClassIconLeft = input('classIconLeft'); // iconclass item of items
|
|
17
17
|
items = input.required({ transform: data => data.map(item => ({ ...item, [this.fieldDisplay()]: escapeHtml(item[this.fieldDisplay()]) })) }); // requried
|
|
18
18
|
fieldDisplay = input('label', { transform: value => value ?? 'label' });
|
|
19
|
-
keyField = input('key', { transform: value => value ?? '
|
|
19
|
+
keyField = input('key', { transform: value => value ?? 'key' });
|
|
20
20
|
keySelected = model();
|
|
21
21
|
applyNow = input(false); // if not applyNow: keyField is requried
|
|
22
22
|
showBorderBottom = input(false);
|
|
@@ -88,4 +88,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
|
|
|
88
88
|
LibsUiComponentsPopoverComponent
|
|
89
89
|
], changeDetection: ChangeDetectionStrategy.OnPush, template: "<div #buttonDropdownEl\n class=\"libs-ui-buttons-dropdown flex {{ classIncludeContainer() || '' }}\"\n [class.libs-ui-buttons-dropdown-un-apply-now]=\"!applyNow()\"\n [class.libs-ui-buttons-dropdown-apply-now-button-primary]=\"applyNow() && typeButton() === 'button-primary'\"\n [class.libs-ui-buttons-dropdown-apply-now-button-secondary]=\"applyNow() && typeButton() === 'button-secondary'\">\n <libs_ui-components-buttons-button [disable]=\"disable()\"\n [iconOnlyType]=\"iconOnlyType()\"\n [classIconLeft]=\"classIconLeft()\"\n [classIconRight]=\"!applyNow() ? '' : classIconRight()\"\n [type]=\"typeButton()\"\n [classLabel]=\"classLabel()\"\n [classInclude]=\"classInclude()\"\n [sizeButton]=\"sizeButton()\"\n [popover]=\"{\n elementRefCustom: buttonDropdownEl,\n mode: modePopover(),\n ignoreShowPopover: !applyNow(),\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n animationConfig: {\n time: .5\n },\n template: templateContentEl,\n whiteTheme: true,\n ignoreArrow: true,\n width: popupConfig().width,\n widthByParent: popupConfig().widthByParent ?? false,\n maxWidth: popupConfig().maxWidth,\n maxHeight: popupConfig().maxHeight,\n zIndex: popupConfig().zIndex,\n classInclude: 'rounded-[4px] ' + popupConfig().classInclude,\n direction: popupConfig().direction,\n timerDestroy: popupConfig().timeDestroy,\n directionDistance: 2,\n position: {\n mode: popupConfig().position?.mode || 'start',\n distance: popupConfig().position?.distance ?? 0\n }\n }\n }\"\n [label]=\"labelDisplay()\"\n (outFunctionsControl)=\"handlerPopoverControlEvent($event)\"\n (outPopoverEvent)=\"handlerPopoverEvent($event)\"\n (outClick)=\"handlerApply()\" />\n @if (!applyNow()) {\n <div class=\"h-full w-[1px] bg-white\"></div>\n <libs_ui-components-buttons-button [type]=\"typeButton()\"\n [disable]=\"disable()\"\n [sizeButton]=\"sizeButton()\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: ignoreHiddenPopoverContentWhenMouseLeave(),\n config:{\n animationConfig: {\n time:.5\n },\n template: templateContentEl,\n whiteTheme: true,\n ignoreArrow: true,\n width: popupConfig().width,\n maxWidth: popupConfig().maxWidth,\n widthByParent: popupConfig().widthByParent ?? false,\n maxHeight: popupConfig().maxHeight,\n zIndex: popupConfig().zIndex,\n direction: popupConfig().direction,\n classInclude: popupConfig().classInclude,\n directionDistance:2,\n position: {\n mode: 'start',\n distance: 0\n }\n }\n }\"\n [iconOnlyType]=\"true\"\n [classIconRight]=\"classIconRight()\"\n [classInclude]=\"classInclude() || '!py-[9px]'\"\n (outFunctionsControl)=\"handlerPopoverControlEvent($event)\"\n (outPopoverEvent)=\"handlerPopoverEvent($event)\" />\n }\n</div>\n<ng-template #templateContentEl>\n <div>\n @if (items() && items().length) {\n <div class=\"m-0 p-0\">\n @for (item of items(); track item) {\n <div class=\"{{ item.classRow || '' }}\">\n <div LibsUiComponentsPopoverDirective\n [config]=\"{content: item.popoverContent, zIndex: popupConfig().zIndex, directionDistance: -2}\"\n [ignoreShowPopover]=\"!item.showPopover\"\n [ignoreStopPropagationEvent]=\"true\"\n class=\"libs-ui-bg-list-hover relative cursor-pointer py-[7px] {{ item.classInclude || '' }} {{ showBorderBottom() ? 'libs-ui-border-bottom-general' : '' }}\"\n [class.flex]=\"!item.ignoreFlex\"\n [class.px-[16px]]=\"applyNow()\"\n [class.pl-[16px]]=\"!applyNow()\"\n [class.pr-[40px]]=\"!applyNow()\"\n [class.libs-ui-disable]=\"item.disable\"\n [class.pointer-events-none]=\"item.disable\"\n (click)=\"handlerSelectItem($event,item)\">\n @if (item[fieldClassIconLeft()]) {\n <i [class]=\"item[fieldClassIconLeft()]\"></i>\n }\n <span [class]=\"item[fieldClass()] ?? 'libs-ui-font-h5r'\"\n [innerHtml]=\"item[fieldDisplay()] | translate\">\n </span>\n @if (item.buttonTemplateConfig) {\n <libs_ui-components-buttons-button [classIconLeft]=\"item.buttonTemplateConfig.iconLeft\"\n [classIconRight]=\"item.buttonTemplateConfig.icon\"\n [label]=\"item.buttonTemplateConfig.label\"\n [classLabel]=\"item.buttonTemplateConfig.label\"\n (outClick)=\"handlerClickButtonTemplate($event, item, items())\"\n [type]=\"item.buttonTemplateConfig.type\" />\n }\n <ng-container *ngTemplateOutlet=\"item?.subTemplate || null;context:{item:item}\"></ng-container>\n @if (item[keyField()] === keySelected() && !applyNow()) {\n <i class=\"libs-ui-icon-check absolute right-[16px] top-[8px]\"></i>\n }\n </div>\n </div>\n }\n </div>\n } @else {\n <div class=\"p-[20px]\"\n [innerHtml]=\"'i18n_no_data' | translate\"></div>\n }\n </div>\n</ng-template>\n", styles: [":host ::ng-deep .libs-ui-buttons-dropdown{max-width:max-content}:host ::ng-deep .libs-ui-buttons-dropdown .libs-ui-button{border-radius:0!important;height:100%}:host ::ng-deep .libs-ui-buttons-dropdown>:first-child libs_ui-components-popover .libs-ui-button{border-top-left-radius:4px!important;border-bottom-left-radius:4px!important;padding-right:8px}:host ::ng-deep .libs-ui-buttons-dropdown>:last-child libs_ui-components-popover .libs-ui-button{border-top-right-radius:4px!important;border-bottom-right-radius:4px!important;padding-left:0}:host ::ng-deep .libs-ui-buttons-dropdown:hover>:first-child .libs-ui-button-primary{background:var(--libs-ui-color-light-1, #4E8CF7)!important}:host ::ng-deep .libs-ui-buttons-dropdown:hover>:last-child .libs-ui-button-primary{background:var(--libs-ui-color-light-1, #4E8CF7)!important}:host ::ng-deep .libs-ui-buttons-dropdown.libs-ui-buttons-dropdown-un-apply-now>:first-child libs_ui-components-popover .libs-ui-button{padding-right:12px}:host ::ng-deep .libs-ui-buttons-dropdown.libs-ui-buttons-dropdown-un-apply-now>:last-child libs_ui-components-popover .libs-ui-button{border-left:1px solid transparent!important;padding:4px 12px}:host ::ng-deep .libs-ui-buttons-dropdown.libs-ui-buttons-dropdown-apply-now-button-primary>:first-child libs_ui-components-popover .libs-ui-button{border-right:1px solid transparent}:host ::ng-deep .libs-ui-buttons-dropdown.libs-ui-buttons-dropdown-apply-now-button-primary>:last-child libs_ui-components-popover .libs-ui-button{border-left:1px solid transparent}:host ::ng-deep .libs-ui-buttons-dropdown.libs-ui-buttons-dropdown-apply-now-button-secondary>:first-child libs_ui-components-popover .libs-ui-button{border-right:none!important}:host ::ng-deep .libs-ui-buttons-dropdown.libs-ui-buttons-dropdown-apply-now-button-secondary>:last-child libs_ui-components-popover .libs-ui-button{border-left:none!important}:host ::ng-deep .libs-ui-buttons-dropdown.libs-ui-buttons-dropdown-apply-now-button-secondary:hover *>[class^=libs-ui-icon]:before{color:var(--libs-ui-color-light-1, #4E8CF7)}:host ::ng-deep .libs-ui-buttons-dropdown.libs-ui-buttons-dropdown-apply-now-button-secondary:hover .libs-ui-button{color:var(--libs-ui-color-light-1, #4E8CF7);background:var(--mo-button-other-color-background-hover, #E9F1FE)!important}\n"] }]
|
|
90
90
|
}] });
|
|
91
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../libs-ui/components/buttons/dropdown/src/dropdown.component.ts","../../../../../../libs-ui/components/buttons/dropdown/src/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { NgTemplateOutlet } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, computed, input, model, output } from '@angular/core';\nimport { LibsUiComponentsButtonsButtonComponent, TYPE_BUTTON, TYPE_SIZE_BUTTON } from '@libs-ui/components-buttons-button';\nimport { IPopoverFunctionControlEvent, LibsUiComponentsPopoverComponent, TYPE_POPOVER_EVENT, TYPE_POPOVER_MODE } from '@libs-ui/components-popover';\nimport { escapeHtml } from '@libs-ui/utils';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { IPopupConfigButtonDropdown } from './dropdown.interface';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-buttons-dropdown',\n  templateUrl: './dropdown.component.html',\n  styleUrl: './dropdown.component.scss',\n  standalone: true,\n  imports: [\n    TranslateModule, NgTemplateOutlet,\n    LibsUiComponentsButtonsButtonComponent,\n    LibsUiComponentsPopoverComponent\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class LibsUiComponentsButtonsDropdownComponent {\n\n  // #region PROPERTY\n  protected labelDisplay = computed(this.labelComputed.bind(this))\n\n  // #region INPUT\n  readonly label = input<string>();\n  readonly fieldClass = input<string>('class'); // change color label item of items\n  readonly fieldClassIconLeft = input<string>('classIconLeft'); // iconclass item of items\n  readonly items = input.required<Array<any>, Array<any>>({ transform: data => data.map(item => ({ ...item, [this.fieldDisplay()]: escapeHtml(item[this.fieldDisplay()]) })) }); // requried\n  readonly fieldDisplay = input<string, string | undefined>('label', { transform: value => value ?? 'label' });\n  readonly keyField = input<string, string | undefined>('key', { transform: value => value ?? 'id' });\n  readonly keySelected = model<string>();\n  readonly applyNow = input<boolean>(false); // if not applyNow: keyField is requried\n  readonly showBorderBottom = input<boolean>(false);\n  readonly disable = input<boolean>(false);\n  readonly sizeButton = input<TYPE_SIZE_BUTTON>('medium');\n  readonly classLabel = input<string>('');\n  readonly iconOnlyType = input<boolean>(false);\n  readonly classIconRight = input<string>('libs-ui-icon-move-right rotate-[90deg]');\n  readonly classIconLeft = input<string>('');\n  readonly typeButton = input<TYPE_BUTTON>('button-primary');\n  readonly popupConfig = input<IPopupConfigButtonDropdown>({ width: 205, maxWidth: 250, maxHeight: 140, zIndex: 1200, direction: 'top' });\n  readonly ignoreHiddenPopoverContentWhenMouseLeave = input<boolean>(true);\n  readonly classInclude = input<string>('');\n  readonly modePopover = input<TYPE_POPOVER_MODE>('click-toggle');\n  readonly classIncludeContainer = input<string>();\n\n  // #region OUTPUT\n  readonly outSelectItem = output<any>();\n  readonly outHover = output<boolean>();\n  readonly outApply = output<any>(); // sử dụng cho bấm button left chế độ applyNow = false;\n  readonly outPopoverEvent = output<TYPE_POPOVER_EVENT>();\n  readonly outFunctionsControl = output<IPopoverFunctionControlEvent>();\n  readonly outIconEvent = output<MouseEvent>();\n\n  /* FUNCTIONS */\n  protected async handlerApply() {\n    if (!this.applyNow()) {\n      this.outApply.emit(this.items().find(item => item[this.keyField()] === this.keySelected()));\n    }\n  }\n\n  protected async handlerSelectItem(event: Event, data: any) {\n    event.stopPropagation();\n    if (data.subTemplate) {\n      return;\n    }\n    if (!this.applyNow()) {\n      this.keySelected.set(data[this.keyField()]);\n    }\n    this.outSelectItem.emit(data);\n    this.outHover.emit(false);\n  }\n\n  protected async handlerPopoverEvent(event: TYPE_POPOVER_EVENT) {\n    this.outPopoverEvent.emit(event);\n  }\n\n  protected async handlerPopoverControlEvent(control: IPopoverFunctionControlEvent) {\n    this.outFunctionsControl.emit(control);\n  }\n\n  protected async handlerClickButtonTemplate(event: Event, data: any, items: Array<any>) {\n    event.stopPropagation();\n    data.buttonTemplateConfig.action(data, items);\n  }\n\n  private labelComputed() {\n    if (!this.keySelected() || !this.items() || !this.items().length || !this.keyField() || this.applyNow()) {\n      return this.label();\n    }\n    for (const item of this.items()) {\n      if (item[this.keyField()] === this.keySelected()) {\n        return item[this.fieldDisplay()];\n      }\n    }\n\n    return this.label();\n  }\n\n}","<div #buttonDropdownEl\n  class=\"libs-ui-buttons-dropdown flex {{ classIncludeContainer() || '' }}\"\n  [class.libs-ui-buttons-dropdown-un-apply-now]=\"!applyNow()\"\n  [class.libs-ui-buttons-dropdown-apply-now-button-primary]=\"applyNow() && typeButton() === 'button-primary'\"\n  [class.libs-ui-buttons-dropdown-apply-now-button-secondary]=\"applyNow() && typeButton() === 'button-secondary'\">\n  <libs_ui-components-buttons-button [disable]=\"disable()\"\n    [iconOnlyType]=\"iconOnlyType()\"\n    [classIconLeft]=\"classIconLeft()\"\n    [classIconRight]=\"!applyNow() ? '' : classIconRight()\"\n    [type]=\"typeButton()\"\n    [classLabel]=\"classLabel()\"\n    [classInclude]=\"classInclude()\"\n    [sizeButton]=\"sizeButton()\"\n    [popover]=\"{\n      elementRefCustom: buttonDropdownEl,\n      mode: modePopover(),\n      ignoreShowPopover: !applyNow(),\n      ignoreHiddenPopoverContentWhenMouseLeave: true,\n      config: {\n        animationConfig: {\n          time: .5\n        },\n        template: templateContentEl,\n        whiteTheme: true,\n        ignoreArrow: true,\n        width: popupConfig().width,\n        widthByParent: popupConfig().widthByParent ?? false,\n        maxWidth: popupConfig().maxWidth,\n        maxHeight: popupConfig().maxHeight,\n        zIndex: popupConfig().zIndex,\n        classInclude: 'rounded-[4px] ' + popupConfig().classInclude,\n        direction: popupConfig().direction,\n        timerDestroy: popupConfig().timeDestroy,\n        directionDistance: 2,\n        position: {\n          mode: popupConfig().position?.mode || 'start',\n          distance: popupConfig().position?.distance ?? 0\n        }\n      }\n    }\"\n    [label]=\"labelDisplay()\"\n    (outFunctionsControl)=\"handlerPopoverControlEvent($event)\"\n    (outPopoverEvent)=\"handlerPopoverEvent($event)\"\n    (outClick)=\"handlerApply()\" />\n  @if (!applyNow()) {\n    <div class=\"h-full w-[1px] bg-white\"></div>\n    <libs_ui-components-buttons-button [type]=\"typeButton()\"\n      [disable]=\"disable()\"\n      [sizeButton]=\"sizeButton()\"\n      [popover]=\"{\n        mode: 'click-toggle',\n        ignoreHiddenPopoverContentWhenMouseLeave: ignoreHiddenPopoverContentWhenMouseLeave(),\n        config:{\n          animationConfig: {\n            time:.5\n          },\n          template: templateContentEl,\n          whiteTheme: true,\n          ignoreArrow: true,\n          width: popupConfig().width,\n          maxWidth: popupConfig().maxWidth,\n          widthByParent: popupConfig().widthByParent ?? false,\n          maxHeight: popupConfig().maxHeight,\n          zIndex: popupConfig().zIndex,\n          direction: popupConfig().direction,\n          classInclude: popupConfig().classInclude,\n          directionDistance:2,\n          position: {\n            mode: 'start',\n            distance: 0\n          }\n        }\n      }\"\n      [iconOnlyType]=\"true\"\n      [classIconRight]=\"classIconRight()\"\n      [classInclude]=\"classInclude() || '!py-[9px]'\"\n      (outFunctionsControl)=\"handlerPopoverControlEvent($event)\"\n      (outPopoverEvent)=\"handlerPopoverEvent($event)\" />\n  }\n</div>\n<ng-template #templateContentEl>\n  <div>\n    @if (items() && items().length) {\n      <div class=\"m-0 p-0\">\n        @for (item of items(); track item) {\n          <div class=\"{{ item.classRow || '' }}\">\n            <div LibsUiComponentsPopoverDirective\n              [config]=\"{content: item.popoverContent, zIndex: popupConfig().zIndex, directionDistance: -2}\"\n              [ignoreShowPopover]=\"!item.showPopover\"\n              [ignoreStopPropagationEvent]=\"true\"\n              class=\"libs-ui-bg-list-hover relative cursor-pointer py-[7px] {{ item.classInclude || '' }}  {{ showBorderBottom() ? 'libs-ui-border-bottom-general' : '' }}\"\n              [class.flex]=\"!item.ignoreFlex\"\n              [class.px-[16px]]=\"applyNow()\"\n              [class.pl-[16px]]=\"!applyNow()\"\n              [class.pr-[40px]]=\"!applyNow()\"\n              [class.libs-ui-disable]=\"item.disable\"\n              [class.pointer-events-none]=\"item.disable\"\n              (click)=\"handlerSelectItem($event,item)\">\n              @if (item[fieldClassIconLeft()]) {\n                <i [class]=\"item[fieldClassIconLeft()]\"></i>\n              }\n              <span [class]=\"item[fieldClass()] ?? 'libs-ui-font-h5r'\"\n                [innerHtml]=\"item[fieldDisplay()] | translate\">\n              </span>\n              @if (item.buttonTemplateConfig) {\n                <libs_ui-components-buttons-button [classIconLeft]=\"item.buttonTemplateConfig.iconLeft\"\n                  [classIconRight]=\"item.buttonTemplateConfig.icon\"\n                  [label]=\"item.buttonTemplateConfig.label\"\n                  [classLabel]=\"item.buttonTemplateConfig.label\"\n                  (outClick)=\"handlerClickButtonTemplate($event, item, items())\"\n                  [type]=\"item.buttonTemplateConfig.type\" />\n              }\n              <ng-container *ngTemplateOutlet=\"item?.subTemplate || null;context:{item:item}\"></ng-container>\n              @if (item[keyField()] === keySelected() && !applyNow()) {\n                <i class=\"libs-ui-icon-check absolute right-[16px] top-[8px]\"></i>\n              }\n            </div>\n          </div>\n        }\n      </div>\n    } @else {\n      <div class=\"p-[20px]\"\n        [innerHtml]=\"'i18n_no_data' | translate\"></div>\n    }\n  </div>\n</ng-template>\n"]}
|
|
91
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../libs-ui/components/buttons/dropdown/src/dropdown.component.ts","../../../../../../libs-ui/components/buttons/dropdown/src/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { NgTemplateOutlet } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, computed, input, model, output } from '@angular/core';\nimport { LibsUiComponentsButtonsButtonComponent, TYPE_BUTTON, TYPE_SIZE_BUTTON } from '@libs-ui/components-buttons-button';\nimport { IPopoverFunctionControlEvent, LibsUiComponentsPopoverComponent, TYPE_POPOVER_EVENT, TYPE_POPOVER_MODE } from '@libs-ui/components-popover';\nimport { escapeHtml } from '@libs-ui/utils';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { IPopupConfigButtonDropdown } from './dropdown.interface';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-buttons-dropdown',\n  templateUrl: './dropdown.component.html',\n  styleUrl: './dropdown.component.scss',\n  standalone: true,\n  imports: [\n    TranslateModule, NgTemplateOutlet,\n    LibsUiComponentsButtonsButtonComponent,\n    LibsUiComponentsPopoverComponent\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class LibsUiComponentsButtonsDropdownComponent {\n\n  // #region PROPERTY\n  protected labelDisplay = computed(this.labelComputed.bind(this))\n\n  // #region INPUT\n  readonly label = input<string>();\n  readonly fieldClass = input<string>('class'); // change color label item of items\n  readonly fieldClassIconLeft = input<string>('classIconLeft'); // iconclass item of items\n  readonly items = input.required<Array<any>, Array<any>>({ transform: data => data.map(item => ({ ...item, [this.fieldDisplay()]: escapeHtml(item[this.fieldDisplay()]) })) }); // requried\n  readonly fieldDisplay = input<string, string | undefined>('label', { transform: value => value ?? 'label' });\n  readonly keyField = input<string, string | undefined>('key', { transform: value => value ?? 'key' });\n  readonly keySelected = model<string>();\n  readonly applyNow = input<boolean>(false); // if not applyNow: keyField is requried\n  readonly showBorderBottom = input<boolean>(false);\n  readonly disable = input<boolean>(false);\n  readonly sizeButton = input<TYPE_SIZE_BUTTON>('medium');\n  readonly classLabel = input<string>('');\n  readonly iconOnlyType = input<boolean>(false);\n  readonly classIconRight = input<string>('libs-ui-icon-move-right rotate-[90deg]');\n  readonly classIconLeft = input<string>('');\n  readonly typeButton = input<TYPE_BUTTON>('button-primary');\n  readonly popupConfig = input<IPopupConfigButtonDropdown>({ width: 205, maxWidth: 250, maxHeight: 140, zIndex: 1200, direction: 'top' });\n  readonly ignoreHiddenPopoverContentWhenMouseLeave = input<boolean>(true);\n  readonly classInclude = input<string>('');\n  readonly modePopover = input<TYPE_POPOVER_MODE>('click-toggle');\n  readonly classIncludeContainer = input<string>();\n\n  // #region OUTPUT\n  readonly outSelectItem = output<any>();\n  readonly outHover = output<boolean>();\n  readonly outApply = output<any>(); // sử dụng cho bấm button left chế độ applyNow = false;\n  readonly outPopoverEvent = output<TYPE_POPOVER_EVENT>();\n  readonly outFunctionsControl = output<IPopoverFunctionControlEvent>();\n  readonly outIconEvent = output<MouseEvent>();\n\n  /* FUNCTIONS */\n  protected async handlerApply() {\n    if (!this.applyNow()) {\n      this.outApply.emit(this.items().find(item => item[this.keyField()] === this.keySelected()));\n    }\n  }\n\n  protected async handlerSelectItem(event: Event, data: any) {\n    event.stopPropagation();\n    if (data.subTemplate) {\n      return;\n    }\n    if (!this.applyNow()) {\n      this.keySelected.set(data[this.keyField()]);\n    }\n    this.outSelectItem.emit(data);\n    this.outHover.emit(false);\n  }\n\n  protected async handlerPopoverEvent(event: TYPE_POPOVER_EVENT) {\n    this.outPopoverEvent.emit(event);\n  }\n\n  protected async handlerPopoverControlEvent(control: IPopoverFunctionControlEvent) {\n    this.outFunctionsControl.emit(control);\n  }\n\n  protected async handlerClickButtonTemplate(event: Event, data: any, items: Array<any>) {\n    event.stopPropagation();\n    data.buttonTemplateConfig.action(data, items);\n  }\n\n  private labelComputed() {\n    if (!this.keySelected() || !this.items() || !this.items().length || !this.keyField() || this.applyNow()) {\n      return this.label();\n    }\n    for (const item of this.items()) {\n      if (item[this.keyField()] === this.keySelected()) {\n        return item[this.fieldDisplay()];\n      }\n    }\n\n    return this.label();\n  }\n\n}","<div #buttonDropdownEl\n  class=\"libs-ui-buttons-dropdown flex {{ classIncludeContainer() || '' }}\"\n  [class.libs-ui-buttons-dropdown-un-apply-now]=\"!applyNow()\"\n  [class.libs-ui-buttons-dropdown-apply-now-button-primary]=\"applyNow() && typeButton() === 'button-primary'\"\n  [class.libs-ui-buttons-dropdown-apply-now-button-secondary]=\"applyNow() && typeButton() === 'button-secondary'\">\n  <libs_ui-components-buttons-button [disable]=\"disable()\"\n    [iconOnlyType]=\"iconOnlyType()\"\n    [classIconLeft]=\"classIconLeft()\"\n    [classIconRight]=\"!applyNow() ? '' : classIconRight()\"\n    [type]=\"typeButton()\"\n    [classLabel]=\"classLabel()\"\n    [classInclude]=\"classInclude()\"\n    [sizeButton]=\"sizeButton()\"\n    [popover]=\"{\n      elementRefCustom: buttonDropdownEl,\n      mode: modePopover(),\n      ignoreShowPopover: !applyNow(),\n      ignoreHiddenPopoverContentWhenMouseLeave: true,\n      config: {\n        animationConfig: {\n          time: .5\n        },\n        template: templateContentEl,\n        whiteTheme: true,\n        ignoreArrow: true,\n        width: popupConfig().width,\n        widthByParent: popupConfig().widthByParent ?? false,\n        maxWidth: popupConfig().maxWidth,\n        maxHeight: popupConfig().maxHeight,\n        zIndex: popupConfig().zIndex,\n        classInclude: 'rounded-[4px] ' + popupConfig().classInclude,\n        direction: popupConfig().direction,\n        timerDestroy: popupConfig().timeDestroy,\n        directionDistance: 2,\n        position: {\n          mode: popupConfig().position?.mode || 'start',\n          distance: popupConfig().position?.distance ?? 0\n        }\n      }\n    }\"\n    [label]=\"labelDisplay()\"\n    (outFunctionsControl)=\"handlerPopoverControlEvent($event)\"\n    (outPopoverEvent)=\"handlerPopoverEvent($event)\"\n    (outClick)=\"handlerApply()\" />\n  @if (!applyNow()) {\n    <div class=\"h-full w-[1px] bg-white\"></div>\n    <libs_ui-components-buttons-button [type]=\"typeButton()\"\n      [disable]=\"disable()\"\n      [sizeButton]=\"sizeButton()\"\n      [popover]=\"{\n        mode: 'click-toggle',\n        ignoreHiddenPopoverContentWhenMouseLeave: ignoreHiddenPopoverContentWhenMouseLeave(),\n        config:{\n          animationConfig: {\n            time:.5\n          },\n          template: templateContentEl,\n          whiteTheme: true,\n          ignoreArrow: true,\n          width: popupConfig().width,\n          maxWidth: popupConfig().maxWidth,\n          widthByParent: popupConfig().widthByParent ?? false,\n          maxHeight: popupConfig().maxHeight,\n          zIndex: popupConfig().zIndex,\n          direction: popupConfig().direction,\n          classInclude: popupConfig().classInclude,\n          directionDistance:2,\n          position: {\n            mode: 'start',\n            distance: 0\n          }\n        }\n      }\"\n      [iconOnlyType]=\"true\"\n      [classIconRight]=\"classIconRight()\"\n      [classInclude]=\"classInclude() || '!py-[9px]'\"\n      (outFunctionsControl)=\"handlerPopoverControlEvent($event)\"\n      (outPopoverEvent)=\"handlerPopoverEvent($event)\" />\n  }\n</div>\n<ng-template #templateContentEl>\n  <div>\n    @if (items() && items().length) {\n      <div class=\"m-0 p-0\">\n        @for (item of items(); track item) {\n          <div class=\"{{ item.classRow || '' }}\">\n            <div LibsUiComponentsPopoverDirective\n              [config]=\"{content: item.popoverContent, zIndex: popupConfig().zIndex, directionDistance: -2}\"\n              [ignoreShowPopover]=\"!item.showPopover\"\n              [ignoreStopPropagationEvent]=\"true\"\n              class=\"libs-ui-bg-list-hover relative cursor-pointer py-[7px] {{ item.classInclude || '' }}  {{ showBorderBottom() ? 'libs-ui-border-bottom-general' : '' }}\"\n              [class.flex]=\"!item.ignoreFlex\"\n              [class.px-[16px]]=\"applyNow()\"\n              [class.pl-[16px]]=\"!applyNow()\"\n              [class.pr-[40px]]=\"!applyNow()\"\n              [class.libs-ui-disable]=\"item.disable\"\n              [class.pointer-events-none]=\"item.disable\"\n              (click)=\"handlerSelectItem($event,item)\">\n              @if (item[fieldClassIconLeft()]) {\n                <i [class]=\"item[fieldClassIconLeft()]\"></i>\n              }\n              <span [class]=\"item[fieldClass()] ?? 'libs-ui-font-h5r'\"\n                [innerHtml]=\"item[fieldDisplay()] | translate\">\n              </span>\n              @if (item.buttonTemplateConfig) {\n                <libs_ui-components-buttons-button [classIconLeft]=\"item.buttonTemplateConfig.iconLeft\"\n                  [classIconRight]=\"item.buttonTemplateConfig.icon\"\n                  [label]=\"item.buttonTemplateConfig.label\"\n                  [classLabel]=\"item.buttonTemplateConfig.label\"\n                  (outClick)=\"handlerClickButtonTemplate($event, item, items())\"\n                  [type]=\"item.buttonTemplateConfig.type\" />\n              }\n              <ng-container *ngTemplateOutlet=\"item?.subTemplate || null;context:{item:item}\"></ng-container>\n              @if (item[keyField()] === keySelected() && !applyNow()) {\n                <i class=\"libs-ui-icon-check absolute right-[16px] top-[8px]\"></i>\n              }\n            </div>\n          </div>\n        }\n      </div>\n    } @else {\n      <div class=\"p-[20px]\"\n        [innerHtml]=\"'i18n_no_data' | translate\"></div>\n    }\n  </div>\n</ng-template>\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZHJvcGRvd24uaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy11aS9jb21wb25lbnRzL2J1dHRvbnMvZHJvcGRvd24vc3JjL2Ryb3Bkb3duLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueSAqL1xuaW1wb3J0IHsgSUJ1dHRvbiB9IGZyb20gXCJAbGlicy11aS9jb21wb25lbnRzLWJ1dHRvbnMtYnV0dG9uXCI7XG5pbXBvcnQgeyBUWVBFX1BPUE9WRVJfRElSRUNUSU9OLCBUWVBFX1BPUE9WRVJfTU9ERSB9IGZyb20gXCJAbGlicy11aS9jb21wb25lbnRzLXBvcG92ZXJcIjtcblxuLyoqXG4gKiBJbnRlcmZhY2UgZm9yIERyb3Bkb3duIEJ1dHRvbiBjb21wb25lbnQgaW5wdXRzLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIElCdXR0b25Ecm9wZG93biBleHRlbmRzIElCdXR0b24ge1xuICAvKiogRGFuaCBzw6FjaCBjw6FjIG3hu6VjIHPhur0gaGnhu4NuIHRo4buLIHRyb25nIG1lbnUuICovXG4gIGl0ZW1zOiBhbnlbXTtcbiAgLyoqIFTDqm4gdHLGsOG7nW5nIGTDuW5nIMSR4buDIGhp4buDbiB0aOG7iyBu4buZaSBkdW5nIGPhu6dhIG3hu5dpIG3hu6VjLiAqL1xuICBmaWVsZERpc3BsYXk/OiBzdHJpbmc7XG4gIC8qKiBUw6puIHRyxrDhu51uZyBkw7luZyBsw6BtIGdpw6EgdHLhu4sga2V5IGPhu6dhIG3hu5dpIG3hu6VjLiAqL1xuICBrZXlGaWVsZD86IHN0cmluZztcbiAgLyoqIEdpw6EgdHLhu4sga2V5IMSRYW5nIMSRxrDhu6NjIGNo4buNbiAoaOG7lyB0cuG7oyB0d28td2F5IGJpbmRpbmcpLiAqL1xuICBrZXlTZWxlY3RlZD86IHN0cmluZztcbiAgLyoqIE7hur91IHRydWU6IGNo4buNbiB4b25nIHThu7EgZW1pdCBz4buxIGtp4buHbjsgZmFsc2U6IGPhuqduIGLhuqVtIG7DunQgw4FwIGThu6VuZy4gKi9cbiAgYXBwbHlOb3c/OiBib29sZWFuO1xuICAvKiogSGnhu4NuIHRo4buLIMSRxrDhu51uZyBr4bq7IGTGsOG7m2kgbWVudSBraGkgbeG7ny4gKi9cbiAgc2hvd0JvcmRlckJvdHRvbT86IGJvb2xlYW47XG4gIC8qKiBD4bqldSBow6xuaCBjaGkgdGnhur90IGNobyBwb3BvdmVyICh24buLIHRyw60sIGvDrWNoIHRoxrDhu5tjKS4gKi9cbiAgcG9wdXBDb25maWc/OiBJUG9wdXBDb25maWdCdXR0b25Ecm9wZG93bjtcbiAgLyoqIEdp4buvIHBvcG92ZXIgbeG7nyBraGkgY2h14buZdCBy4budaSBraOG7j2kgbuG7mWkgZHVuZy4gKi9cbiAgaWdub3JlSGlkZGVuUG9wb3ZlckNvbnRlbnRXaGVuTW91c2VMZWF2ZT86IGJvb2xlYW47XG4gIC8qKiBDw6FjaCBoaeG7g24gdGjhu4sgcG9wb3ZlciAoY2xpY2ssIGhvdmVyLC4uLikuICovXG4gIG1vZGVQb3BvdmVyPzogVFlQRV9QT1BPVkVSX01PREU7XG59XG5cbi8qKiBDb25maWd1cmF0aW9uIG9wdGlvbnMgZm9yIERyb3Bkb3duIHBvcG92ZXIuICovXG5leHBvcnQgaW50ZXJmYWNlIElQb3B1cENvbmZpZ0J1dHRvbkRyb3Bkb3duIHtcbiAgd2lkdGg/OiBudW1iZXI7XG4gIG1heFdpZHRoPzogbnVtYmVyO1xuICBtYXhIZWlnaHQ/OiBudW1iZXI7XG4gIHpJbmRleD86IG51bWJlcjtcbiAgZGlyZWN0aW9uPzogVFlQRV9QT1BPVkVSX0RJUkVDVElPTjtcbiAgdGltZURlc3Ryb3k/OiBudW1iZXI7XG4gIHdpZHRoQnlQYXJlbnQ/OiBib29sZWFuO1xuICBwb3NpdGlvbj86IHtcbiAgICBtb2RlOiAnc3RhcnQnIHwgJ2NlbnRlcicgfCAnZW5kJztcbiAgICBkaXN0YW5jZTogbnVtYmVyO1xuICB9O1xuICBjbGFzc0luY2x1ZGU/OiBzdHJpbmc7XG59Il19
|
|
@@ -17,7 +17,7 @@ class LibsUiComponentsButtonsDropdownComponent {
|
|
|
17
17
|
fieldClassIconLeft = input('classIconLeft'); // iconclass item of items
|
|
18
18
|
items = input.required({ transform: data => data.map(item => ({ ...item, [this.fieldDisplay()]: escapeHtml(item[this.fieldDisplay()]) })) }); // requried
|
|
19
19
|
fieldDisplay = input('label', { transform: value => value ?? 'label' });
|
|
20
|
-
keyField = input('key', { transform: value => value ?? '
|
|
20
|
+
keyField = input('key', { transform: value => value ?? 'key' });
|
|
21
21
|
keySelected = model();
|
|
22
22
|
applyNow = input(false); // if not applyNow: keyField is requried
|
|
23
23
|
showBorderBottom = input(false);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"libs-ui-components-buttons-dropdown.mjs","sources":["../../../../../../libs-ui/components/buttons/dropdown/src/dropdown.component.ts","../../../../../../libs-ui/components/buttons/dropdown/src/dropdown.component.html","../../../../../../libs-ui/components/buttons/dropdown/src/libs-ui-components-buttons-dropdown.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { NgTemplateOutlet } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, computed, input, model, output } from '@angular/core';\nimport { LibsUiComponentsButtonsButtonComponent, TYPE_BUTTON, TYPE_SIZE_BUTTON } from '@libs-ui/components-buttons-button';\nimport { IPopoverFunctionControlEvent, LibsUiComponentsPopoverComponent, TYPE_POPOVER_EVENT, TYPE_POPOVER_MODE } from '@libs-ui/components-popover';\nimport { escapeHtml } from '@libs-ui/utils';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { IPopupConfigButtonDropdown } from './dropdown.interface';\n\n@Component({\n // eslint-disable-next-line @angular-eslint/component-selector\n selector: 'libs_ui-components-buttons-dropdown',\n templateUrl: './dropdown.component.html',\n styleUrl: './dropdown.component.scss',\n standalone: true,\n imports: [\n TranslateModule, NgTemplateOutlet,\n LibsUiComponentsButtonsButtonComponent,\n LibsUiComponentsPopoverComponent\n ],\n changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class LibsUiComponentsButtonsDropdownComponent {\n\n // #region PROPERTY\n protected labelDisplay = computed(this.labelComputed.bind(this))\n\n // #region INPUT\n readonly label = input<string>();\n readonly fieldClass = input<string>('class'); // change color label item of items\n readonly fieldClassIconLeft = input<string>('classIconLeft'); // iconclass item of items\n readonly items = input.required<Array<any>, Array<any>>({ transform: data => data.map(item => ({ ...item, [this.fieldDisplay()]: escapeHtml(item[this.fieldDisplay()]) })) }); // requried\n readonly fieldDisplay = input<string, string | undefined>('label', { transform: value => value ?? 'label' });\n readonly keyField = input<string, string | undefined>('key', { transform: value => value ?? 'id' });\n readonly keySelected = model<string>();\n readonly applyNow = input<boolean>(false); // if not applyNow: keyField is requried\n readonly showBorderBottom = input<boolean>(false);\n readonly disable = input<boolean>(false);\n readonly sizeButton = input<TYPE_SIZE_BUTTON>('medium');\n readonly classLabel = input<string>('');\n readonly iconOnlyType = input<boolean>(false);\n readonly classIconRight = input<string>('libs-ui-icon-move-right rotate-[90deg]');\n readonly classIconLeft = input<string>('');\n readonly typeButton = input<TYPE_BUTTON>('button-primary');\n readonly popupConfig = input<IPopupConfigButtonDropdown>({ width: 205, maxWidth: 250, maxHeight: 140, zIndex: 1200, direction: 'top' });\n readonly ignoreHiddenPopoverContentWhenMouseLeave = input<boolean>(true);\n readonly classInclude = input<string>('');\n readonly modePopover = input<TYPE_POPOVER_MODE>('click-toggle');\n readonly classIncludeContainer = input<string>();\n\n // #region OUTPUT\n readonly outSelectItem = output<any>();\n readonly outHover = output<boolean>();\n readonly outApply = output<any>(); // sử dụng cho bấm button left chế độ applyNow = false;\n readonly outPopoverEvent = output<TYPE_POPOVER_EVENT>();\n readonly outFunctionsControl = output<IPopoverFunctionControlEvent>();\n readonly outIconEvent = output<MouseEvent>();\n\n /* FUNCTIONS */\n protected async handlerApply() {\n if (!this.applyNow()) {\n this.outApply.emit(this.items().find(item => item[this.keyField()] === this.keySelected()));\n }\n }\n\n protected async handlerSelectItem(event: Event, data: any) {\n event.stopPropagation();\n if (data.subTemplate) {\n return;\n }\n if (!this.applyNow()) {\n this.keySelected.set(data[this.keyField()]);\n }\n this.outSelectItem.emit(data);\n this.outHover.emit(false);\n }\n\n protected async handlerPopoverEvent(event: TYPE_POPOVER_EVENT) {\n this.outPopoverEvent.emit(event);\n }\n\n protected async handlerPopoverControlEvent(control: IPopoverFunctionControlEvent) {\n this.outFunctionsControl.emit(control);\n }\n\n protected async handlerClickButtonTemplate(event: Event, data: any, items: Array<any>) {\n event.stopPropagation();\n data.buttonTemplateConfig.action(data, items);\n }\n\n private labelComputed() {\n if (!this.keySelected() || !this.items() || !this.items().length || !this.keyField() || this.applyNow()) {\n return this.label();\n }\n for (const item of this.items()) {\n if (item[this.keyField()] === this.keySelected()) {\n return item[this.fieldDisplay()];\n }\n }\n\n return this.label();\n }\n\n}","<div #buttonDropdownEl\n class=\"libs-ui-buttons-dropdown flex {{ classIncludeContainer() || '' }}\"\n [class.libs-ui-buttons-dropdown-un-apply-now]=\"!applyNow()\"\n [class.libs-ui-buttons-dropdown-apply-now-button-primary]=\"applyNow() && typeButton() === 'button-primary'\"\n [class.libs-ui-buttons-dropdown-apply-now-button-secondary]=\"applyNow() && typeButton() === 'button-secondary'\">\n <libs_ui-components-buttons-button [disable]=\"disable()\"\n [iconOnlyType]=\"iconOnlyType()\"\n [classIconLeft]=\"classIconLeft()\"\n [classIconRight]=\"!applyNow() ? '' : classIconRight()\"\n [type]=\"typeButton()\"\n [classLabel]=\"classLabel()\"\n [classInclude]=\"classInclude()\"\n [sizeButton]=\"sizeButton()\"\n [popover]=\"{\n elementRefCustom: buttonDropdownEl,\n mode: modePopover(),\n ignoreShowPopover: !applyNow(),\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n animationConfig: {\n time: .5\n },\n template: templateContentEl,\n whiteTheme: true,\n ignoreArrow: true,\n width: popupConfig().width,\n widthByParent: popupConfig().widthByParent ?? false,\n maxWidth: popupConfig().maxWidth,\n maxHeight: popupConfig().maxHeight,\n zIndex: popupConfig().zIndex,\n classInclude: 'rounded-[4px] ' + popupConfig().classInclude,\n direction: popupConfig().direction,\n timerDestroy: popupConfig().timeDestroy,\n directionDistance: 2,\n position: {\n mode: popupConfig().position?.mode || 'start',\n distance: popupConfig().position?.distance ?? 0\n }\n }\n }\"\n [label]=\"labelDisplay()\"\n (outFunctionsControl)=\"handlerPopoverControlEvent($event)\"\n (outPopoverEvent)=\"handlerPopoverEvent($event)\"\n (outClick)=\"handlerApply()\" />\n @if (!applyNow()) {\n <div class=\"h-full w-[1px] bg-white\"></div>\n <libs_ui-components-buttons-button [type]=\"typeButton()\"\n [disable]=\"disable()\"\n [sizeButton]=\"sizeButton()\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: ignoreHiddenPopoverContentWhenMouseLeave(),\n config:{\n animationConfig: {\n time:.5\n },\n template: templateContentEl,\n whiteTheme: true,\n ignoreArrow: true,\n width: popupConfig().width,\n maxWidth: popupConfig().maxWidth,\n widthByParent: popupConfig().widthByParent ?? false,\n maxHeight: popupConfig().maxHeight,\n zIndex: popupConfig().zIndex,\n direction: popupConfig().direction,\n classInclude: popupConfig().classInclude,\n directionDistance:2,\n position: {\n mode: 'start',\n distance: 0\n }\n }\n }\"\n [iconOnlyType]=\"true\"\n [classIconRight]=\"classIconRight()\"\n [classInclude]=\"classInclude() || '!py-[9px]'\"\n (outFunctionsControl)=\"handlerPopoverControlEvent($event)\"\n (outPopoverEvent)=\"handlerPopoverEvent($event)\" />\n }\n</div>\n<ng-template #templateContentEl>\n <div>\n @if (items() && items().length) {\n <div class=\"m-0 p-0\">\n @for (item of items(); track item) {\n <div class=\"{{ item.classRow || '' }}\">\n <div LibsUiComponentsPopoverDirective\n [config]=\"{content: item.popoverContent, zIndex: popupConfig().zIndex, directionDistance: -2}\"\n [ignoreShowPopover]=\"!item.showPopover\"\n [ignoreStopPropagationEvent]=\"true\"\n class=\"libs-ui-bg-list-hover relative cursor-pointer py-[7px] {{ item.classInclude || '' }} {{ showBorderBottom() ? 'libs-ui-border-bottom-general' : '' }}\"\n [class.flex]=\"!item.ignoreFlex\"\n [class.px-[16px]]=\"applyNow()\"\n [class.pl-[16px]]=\"!applyNow()\"\n [class.pr-[40px]]=\"!applyNow()\"\n [class.libs-ui-disable]=\"item.disable\"\n [class.pointer-events-none]=\"item.disable\"\n (click)=\"handlerSelectItem($event,item)\">\n @if (item[fieldClassIconLeft()]) {\n <i [class]=\"item[fieldClassIconLeft()]\"></i>\n }\n <span [class]=\"item[fieldClass()] ?? 'libs-ui-font-h5r'\"\n [innerHtml]=\"item[fieldDisplay()] | translate\">\n </span>\n @if (item.buttonTemplateConfig) {\n <libs_ui-components-buttons-button [classIconLeft]=\"item.buttonTemplateConfig.iconLeft\"\n [classIconRight]=\"item.buttonTemplateConfig.icon\"\n [label]=\"item.buttonTemplateConfig.label\"\n [classLabel]=\"item.buttonTemplateConfig.label\"\n (outClick)=\"handlerClickButtonTemplate($event, item, items())\"\n [type]=\"item.buttonTemplateConfig.type\" />\n }\n <ng-container *ngTemplateOutlet=\"item?.subTemplate || null;context:{item:item}\"></ng-container>\n @if (item[keyField()] === keySelected() && !applyNow()) {\n <i class=\"libs-ui-icon-check absolute right-[16px] top-[8px]\"></i>\n }\n </div>\n </div>\n }\n </div>\n } @else {\n <div class=\"p-[20px]\"\n [innerHtml]=\"'i18n_no_data' | translate\"></div>\n }\n </div>\n</ng-template>\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-buttons-dropdown.mjs","sources":["../../../../../../libs-ui/components/buttons/dropdown/src/dropdown.component.ts","../../../../../../libs-ui/components/buttons/dropdown/src/dropdown.component.html","../../../../../../libs-ui/components/buttons/dropdown/src/libs-ui-components-buttons-dropdown.ts"],"sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { NgTemplateOutlet } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, computed, input, model, output } from '@angular/core';\nimport { LibsUiComponentsButtonsButtonComponent, TYPE_BUTTON, TYPE_SIZE_BUTTON } from '@libs-ui/components-buttons-button';\nimport { IPopoverFunctionControlEvent, LibsUiComponentsPopoverComponent, TYPE_POPOVER_EVENT, TYPE_POPOVER_MODE } from '@libs-ui/components-popover';\nimport { escapeHtml } from '@libs-ui/utils';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { IPopupConfigButtonDropdown } from './dropdown.interface';\n\n@Component({\n // eslint-disable-next-line @angular-eslint/component-selector\n selector: 'libs_ui-components-buttons-dropdown',\n templateUrl: './dropdown.component.html',\n styleUrl: './dropdown.component.scss',\n standalone: true,\n imports: [\n TranslateModule, NgTemplateOutlet,\n LibsUiComponentsButtonsButtonComponent,\n LibsUiComponentsPopoverComponent\n ],\n changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class LibsUiComponentsButtonsDropdownComponent {\n\n // #region PROPERTY\n protected labelDisplay = computed(this.labelComputed.bind(this))\n\n // #region INPUT\n readonly label = input<string>();\n readonly fieldClass = input<string>('class'); // change color label item of items\n readonly fieldClassIconLeft = input<string>('classIconLeft'); // iconclass item of items\n readonly items = input.required<Array<any>, Array<any>>({ transform: data => data.map(item => ({ ...item, [this.fieldDisplay()]: escapeHtml(item[this.fieldDisplay()]) })) }); // requried\n readonly fieldDisplay = input<string, string | undefined>('label', { transform: value => value ?? 'label' });\n readonly keyField = input<string, string | undefined>('key', { transform: value => value ?? 'key' });\n readonly keySelected = model<string>();\n readonly applyNow = input<boolean>(false); // if not applyNow: keyField is requried\n readonly showBorderBottom = input<boolean>(false);\n readonly disable = input<boolean>(false);\n readonly sizeButton = input<TYPE_SIZE_BUTTON>('medium');\n readonly classLabel = input<string>('');\n readonly iconOnlyType = input<boolean>(false);\n readonly classIconRight = input<string>('libs-ui-icon-move-right rotate-[90deg]');\n readonly classIconLeft = input<string>('');\n readonly typeButton = input<TYPE_BUTTON>('button-primary');\n readonly popupConfig = input<IPopupConfigButtonDropdown>({ width: 205, maxWidth: 250, maxHeight: 140, zIndex: 1200, direction: 'top' });\n readonly ignoreHiddenPopoverContentWhenMouseLeave = input<boolean>(true);\n readonly classInclude = input<string>('');\n readonly modePopover = input<TYPE_POPOVER_MODE>('click-toggle');\n readonly classIncludeContainer = input<string>();\n\n // #region OUTPUT\n readonly outSelectItem = output<any>();\n readonly outHover = output<boolean>();\n readonly outApply = output<any>(); // sử dụng cho bấm button left chế độ applyNow = false;\n readonly outPopoverEvent = output<TYPE_POPOVER_EVENT>();\n readonly outFunctionsControl = output<IPopoverFunctionControlEvent>();\n readonly outIconEvent = output<MouseEvent>();\n\n /* FUNCTIONS */\n protected async handlerApply() {\n if (!this.applyNow()) {\n this.outApply.emit(this.items().find(item => item[this.keyField()] === this.keySelected()));\n }\n }\n\n protected async handlerSelectItem(event: Event, data: any) {\n event.stopPropagation();\n if (data.subTemplate) {\n return;\n }\n if (!this.applyNow()) {\n this.keySelected.set(data[this.keyField()]);\n }\n this.outSelectItem.emit(data);\n this.outHover.emit(false);\n }\n\n protected async handlerPopoverEvent(event: TYPE_POPOVER_EVENT) {\n this.outPopoverEvent.emit(event);\n }\n\n protected async handlerPopoverControlEvent(control: IPopoverFunctionControlEvent) {\n this.outFunctionsControl.emit(control);\n }\n\n protected async handlerClickButtonTemplate(event: Event, data: any, items: Array<any>) {\n event.stopPropagation();\n data.buttonTemplateConfig.action(data, items);\n }\n\n private labelComputed() {\n if (!this.keySelected() || !this.items() || !this.items().length || !this.keyField() || this.applyNow()) {\n return this.label();\n }\n for (const item of this.items()) {\n if (item[this.keyField()] === this.keySelected()) {\n return item[this.fieldDisplay()];\n }\n }\n\n return this.label();\n }\n\n}","<div #buttonDropdownEl\n class=\"libs-ui-buttons-dropdown flex {{ classIncludeContainer() || '' }}\"\n [class.libs-ui-buttons-dropdown-un-apply-now]=\"!applyNow()\"\n [class.libs-ui-buttons-dropdown-apply-now-button-primary]=\"applyNow() && typeButton() === 'button-primary'\"\n [class.libs-ui-buttons-dropdown-apply-now-button-secondary]=\"applyNow() && typeButton() === 'button-secondary'\">\n <libs_ui-components-buttons-button [disable]=\"disable()\"\n [iconOnlyType]=\"iconOnlyType()\"\n [classIconLeft]=\"classIconLeft()\"\n [classIconRight]=\"!applyNow() ? '' : classIconRight()\"\n [type]=\"typeButton()\"\n [classLabel]=\"classLabel()\"\n [classInclude]=\"classInclude()\"\n [sizeButton]=\"sizeButton()\"\n [popover]=\"{\n elementRefCustom: buttonDropdownEl,\n mode: modePopover(),\n ignoreShowPopover: !applyNow(),\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n animationConfig: {\n time: .5\n },\n template: templateContentEl,\n whiteTheme: true,\n ignoreArrow: true,\n width: popupConfig().width,\n widthByParent: popupConfig().widthByParent ?? false,\n maxWidth: popupConfig().maxWidth,\n maxHeight: popupConfig().maxHeight,\n zIndex: popupConfig().zIndex,\n classInclude: 'rounded-[4px] ' + popupConfig().classInclude,\n direction: popupConfig().direction,\n timerDestroy: popupConfig().timeDestroy,\n directionDistance: 2,\n position: {\n mode: popupConfig().position?.mode || 'start',\n distance: popupConfig().position?.distance ?? 0\n }\n }\n }\"\n [label]=\"labelDisplay()\"\n (outFunctionsControl)=\"handlerPopoverControlEvent($event)\"\n (outPopoverEvent)=\"handlerPopoverEvent($event)\"\n (outClick)=\"handlerApply()\" />\n @if (!applyNow()) {\n <div class=\"h-full w-[1px] bg-white\"></div>\n <libs_ui-components-buttons-button [type]=\"typeButton()\"\n [disable]=\"disable()\"\n [sizeButton]=\"sizeButton()\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: ignoreHiddenPopoverContentWhenMouseLeave(),\n config:{\n animationConfig: {\n time:.5\n },\n template: templateContentEl,\n whiteTheme: true,\n ignoreArrow: true,\n width: popupConfig().width,\n maxWidth: popupConfig().maxWidth,\n widthByParent: popupConfig().widthByParent ?? false,\n maxHeight: popupConfig().maxHeight,\n zIndex: popupConfig().zIndex,\n direction: popupConfig().direction,\n classInclude: popupConfig().classInclude,\n directionDistance:2,\n position: {\n mode: 'start',\n distance: 0\n }\n }\n }\"\n [iconOnlyType]=\"true\"\n [classIconRight]=\"classIconRight()\"\n [classInclude]=\"classInclude() || '!py-[9px]'\"\n (outFunctionsControl)=\"handlerPopoverControlEvent($event)\"\n (outPopoverEvent)=\"handlerPopoverEvent($event)\" />\n }\n</div>\n<ng-template #templateContentEl>\n <div>\n @if (items() && items().length) {\n <div class=\"m-0 p-0\">\n @for (item of items(); track item) {\n <div class=\"{{ item.classRow || '' }}\">\n <div LibsUiComponentsPopoverDirective\n [config]=\"{content: item.popoverContent, zIndex: popupConfig().zIndex, directionDistance: -2}\"\n [ignoreShowPopover]=\"!item.showPopover\"\n [ignoreStopPropagationEvent]=\"true\"\n class=\"libs-ui-bg-list-hover relative cursor-pointer py-[7px] {{ item.classInclude || '' }} {{ showBorderBottom() ? 'libs-ui-border-bottom-general' : '' }}\"\n [class.flex]=\"!item.ignoreFlex\"\n [class.px-[16px]]=\"applyNow()\"\n [class.pl-[16px]]=\"!applyNow()\"\n [class.pr-[40px]]=\"!applyNow()\"\n [class.libs-ui-disable]=\"item.disable\"\n [class.pointer-events-none]=\"item.disable\"\n (click)=\"handlerSelectItem($event,item)\">\n @if (item[fieldClassIconLeft()]) {\n <i [class]=\"item[fieldClassIconLeft()]\"></i>\n }\n <span [class]=\"item[fieldClass()] ?? 'libs-ui-font-h5r'\"\n [innerHtml]=\"item[fieldDisplay()] | translate\">\n </span>\n @if (item.buttonTemplateConfig) {\n <libs_ui-components-buttons-button [classIconLeft]=\"item.buttonTemplateConfig.iconLeft\"\n [classIconRight]=\"item.buttonTemplateConfig.icon\"\n [label]=\"item.buttonTemplateConfig.label\"\n [classLabel]=\"item.buttonTemplateConfig.label\"\n (outClick)=\"handlerClickButtonTemplate($event, item, items())\"\n [type]=\"item.buttonTemplateConfig.type\" />\n }\n <ng-container *ngTemplateOutlet=\"item?.subTemplate || null;context:{item:item}\"></ng-container>\n @if (item[keyField()] === keySelected() && !applyNow()) {\n <i class=\"libs-ui-icon-check absolute right-[16px] top-[8px]\"></i>\n }\n </div>\n </div>\n }\n </div>\n } @else {\n <div class=\"p-[20px]\"\n [innerHtml]=\"'i18n_no_data' | translate\"></div>\n }\n </div>\n</ng-template>\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,14 +1,14 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@libs-ui/components-buttons-dropdown",
|
|
3
|
-
"version": "0.2.
|
|
3
|
+
"version": "0.2.280",
|
|
4
4
|
"peerDependencies": {
|
|
5
5
|
"@angular/common": "^18.2.0",
|
|
6
6
|
"@angular/core": "^18.2.0",
|
|
7
|
-
"@libs-ui/components-buttons-button": "^0.2.
|
|
8
|
-
"@libs-ui/components-popover": "^0.2.
|
|
9
|
-
"@libs-ui/utils": "^0.2.
|
|
7
|
+
"@libs-ui/components-buttons-button": "^0.2.280",
|
|
8
|
+
"@libs-ui/components-popover": "^0.2.280",
|
|
9
|
+
"@libs-ui/utils": "^0.2.280",
|
|
10
10
|
"@ngx-translate/core": "^15.0.0",
|
|
11
|
-
"@libs-ui/interfaces-types": "^0.2.
|
|
11
|
+
"@libs-ui/interfaces-types": "^0.2.280"
|
|
12
12
|
},
|
|
13
13
|
"sideEffects": false,
|
|
14
14
|
"module": "fesm2022/libs-ui-components-buttons-dropdown.mjs",
|