@libs-ui/components-inputs-color 0.2.355-8 → 0.2.356-0

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,135 @@
1
- # inputs-color
1
+ # @libs-ui/components-inputs-color
2
2
 
3
- This library was generated with [Nx](https://nx.dev).
3
+ > Component input chọn màu sắc (Color Picker) hỗ trợ độ mờ (opacity) và palette tùy chỉnh.
4
+
5
+ ## Giới thiệu
6
+
7
+ `LibsUiComponentsInputsColorComponent` là một standalone Angular component để chọn màu sắc. Nó tích hợp một bảng màu mặc định, khả năng lưu bảng màu tùy chỉnh và thanh trượt độ mờ trực quan.
8
+
9
+ ### Tính năng
10
+
11
+ - ✅ Chọn màu từ palette mặc định
12
+ - ✅ Lưu và quản lý palette tùy chỉnh (tối đa 8 màu)
13
+ - ✅ Điều chỉnh độ mờ (opacity) trực tiếp
14
+ - ✅ Tích hợp Popover thông minh
15
+ - ✅ Sử dụng Angular Signals cho hiệu năng cao
16
+ - ✅ Standalone Component, dễ dàng tích hợp
17
+
18
+ ## Khi nào sử dụng
19
+
20
+ - Khi cần cho phép người dùng chọn màu sắc trong các form cấu hình.
21
+ - Khi cần tích hợp tính năng quản lý màu cá nhân.
22
+ - Khi cần điều chỉnh cả màu sắc và độ trong suốt của phần tử.
23
+
24
+ ## Cài đặt
25
+
26
+ ```bash
27
+ # npm
28
+ npm install @libs-ui/components-inputs-color
29
+
30
+ # yarn
31
+ yarn add @libs-ui/components-inputs-color
32
+ ```
33
+
34
+ ## Import
35
+
36
+ ```typescript
37
+ import { LibsUiComponentsInputsColorComponent } from '@libs-ui/components-inputs-color';
38
+
39
+ @Component({
40
+ standalone: true,
41
+ imports: [LibsUiComponentsInputsColorComponent],
42
+ // ...
43
+ })
44
+ export class YourComponent {}
45
+ ```
46
+
47
+ ## Ví dụ
48
+
49
+ ### Cơ bản
50
+
51
+ ```html
52
+ <libs_ui-components-inputs-color [(data)]="colorData" />
53
+ ```
54
+
55
+ ### Với Custom Provider
56
+
57
+ ```html
58
+ <libs_ui-components-inputs-color
59
+ [(data)]="colorData"
60
+ [functionGetListColorDefault]="getColors"
61
+ [functionSetListColorCustom]="saveColors" />
62
+ ```
63
+
64
+ ## API
65
+
66
+ ### libs_ui-components-inputs-color
67
+
68
+ #### Inputs
69
+
70
+ | Property | Type | Default | Description |
71
+ | ------------------------------- | ------------------------------------------------- | ----------------------------- | ----------------------------------- |
72
+ | `[(data)]` | `model<IColorPickerData>` | `{ color: '', opacity: 100 }` | Dữ liệu màu sắc và độ mờ hiện tại |
73
+ | `[zIndex]` | `model<number>` | `1200` | Z-index cho popover bảng màu |
74
+ | `[customOptions]` | `input<IPickerCustomOptions>` | `undefined` | Cấu hình cho color picker bên trong |
75
+ | `[functionGetListColorDefault]` | `input<() => Promise<Array<string>>>` | `undefined` | Hàm lấy danh sách màu mặc định |
76
+ | `[functionGetListColorCustom]` | `input<() => Promise<Array<string>>>` | `undefined` | Hàm lấy danh sách màu tùy chỉnh |
77
+ | `[functionSetListColorCustom]` | `input<(colors: Array<string>) => Promise<void>>` | `undefined` | Hàm lưu danh sách màu tùy chỉnh |
78
+
79
+ #### Outputs
80
+
81
+ | Property | Type | Description |
82
+ | ------------------ | ------------------ | ------------------------------------ |
83
+ | `(outColorChange)` | `IColorPickerData` | Emit khi màu sắc hoặc độ mờ thay đổi |
84
+
85
+ ## Types & Interfaces
86
+
87
+ ```typescript
88
+ export interface IColorPickerData {
89
+ color: string;
90
+ opacity: number;
91
+ }
92
+
93
+ export interface IPickerCustomOptions {
94
+ slBarSize?: Array<number>;
95
+ hueBarSize?: Array<number>;
96
+ alphaBarSize?: Array<number>;
97
+ showHsl?: boolean;
98
+ showRgb?: boolean;
99
+ showHex?: boolean;
100
+ showAlpha?: boolean;
101
+ color?: string | Array<number>;
102
+ format?: 'rgb' | 'rgba' | 'hsl' | 'hsla' | 'hex' | 'color';
103
+ }
104
+ ```
105
+
106
+ ## Công nghệ
107
+
108
+ | Technology | Version | Purpose |
109
+ | --------------- | ------- | ---------------- |
110
+ | Angular | 18+ | Framework |
111
+ | Angular Signals | - | State management |
112
+ | TailwindCSS | 3.x | Styling |
113
+ | OnPush | - | Change Detection |
114
+
115
+ ## Demo
116
+
117
+ ```bash
118
+ npx nx serve core-ui
119
+ ```
120
+
121
+ Truy cập: `http://localhost:4500/inputs/color`
122
+
123
+ ## Unit Tests
124
+
125
+ ```bash
126
+ # Chạy tests
127
+ npx nx test components-inputs-color
128
+
129
+ # Coverage
130
+ npx nx test components-inputs-color --coverage
131
+ ```
132
+
133
+ ## License
134
+
135
+ MIT
@@ -1,13 +1,17 @@
1
+ import { LowerCasePipe } from '@angular/common';
1
2
  import { ChangeDetectionStrategy, Component, input, model, output, signal } from '@angular/core';
2
3
  import { LibsUiComponentsButtonsButtonComponent } from '@libs-ui/components-buttons-button';
4
+ import { LibsUiComponentsColorPickerComponent } from '@libs-ui/components-color-picker';
3
5
  import { LibsUiComponentsInputsValidComponent } from '@libs-ui/components-inputs-valid';
4
6
  import { LibsUiComponentsPopoverComponent } from '@libs-ui/components-popover';
5
7
  import { UtilsCache } from '@libs-ui/utils';
6
8
  import { TranslateModule } from '@ngx-translate/core';
7
- import { LibsUiComponentsColorPickerComponent } from '@libs-ui/components-color-picker';
8
- import { LowerCasePipe } from '@angular/common';
9
9
  import * as i0 from "@angular/core";
10
10
  import * as i1 from "@ngx-translate/core";
11
+ /**
12
+ * Component input chọn màu sắc (Color Picker) hỗ trợ độ mờ (opacity)
13
+ * Cung cấp bảng màu mặc định và cho phép người dùng lưu bảng màu tùy chỉnh
14
+ */
11
15
  export class LibsUiComponentsInputsColorComponent {
12
16
  // #region PROPERTY
13
17
  colorDefault = signal([]);
@@ -18,13 +22,20 @@ export class LibsUiComponentsInputsColorComponent {
18
22
  popoverFunctionControl = signal(undefined);
19
23
  popoverAddColorFunctionControl = signal(undefined);
20
24
  // #region INPUT
25
+ /** Dữ liệu màu sắc và độ mờ hiện tại */
21
26
  data = model({ color: '', opacity: 100 });
27
+ /** Z-index cho popover bảng màu */
22
28
  zIndex = model(1200);
29
+ /** Cấu hình tùy chỉnh cho color picker */
23
30
  customOptions = input();
31
+ /** Function lấy danh sách màu mặc định */
24
32
  functionGetListColorDefault = input();
33
+ /** Function lấy danh sách màu tùy chỉnh đã lưu */
25
34
  functionGetListColorCustom = input();
35
+ /** Function lưu danh sách màu tùy chỉnh mới */
26
36
  functionSetListColorCustom = input();
27
37
  // #region OUTPUT
38
+ /** Emit khi màu sắc hoặc độ mờ thay đổi */
28
39
  outColorChange = output();
29
40
  ngOnInit() {
30
41
  this.getListColorDefault();
@@ -126,4 +137,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
126
137
  type: Component,
127
138
  args: [{ selector: 'libs_ui-components-inputs-color', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [TranslateModule, LowerCasePipe, LibsUiComponentsPopoverComponent, LibsUiComponentsButtonsButtonComponent, LibsUiComponentsInputsValidComponent, LibsUiComponentsColorPickerComponent], template: "<div\n class=\"w-full flex justify-between rounded-[4px] h-[32px]\"\n [class.libs-ui-border-general]=\"!showPopup()\"\n [class.libs-ui-border-primary-focus-general]=\"showPopup()\">\n <div\n LibsUiComponentsPopoverDirective\n class=\"w-full flex\"\n [mode]=\"'click-toggle'\"\n [ignoreHiddenPopoverContentWhenMouseLeave]=\"true\"\n [config]=\"{\n template: element,\n whiteTheme: true,\n ignoreArrow: true,\n widthByParent: false,\n maxWidth: 500,\n maxHeight: 500,\n zIndex: zIndex(),\n classInclude: 'w-[334px]',\n direction: 'left',\n directionDistance: 4,\n position: {\n mode: 'start',\n distance: 0,\n },\n }\"\n [flagMouse]=\"flagMouse()\"\n (outEvent)=\"handlerPopoverEvent($event)\"\n (outFunctionsControl)=\"handlerFunctionControl($event)\">\n <div class=\"px-[16px] flex items-center\">\n <span\n class=\"w-[16px] h-[16px] rounded-[4px] libs-ui-border-general\"\n [style.background-color]=\"data().color\"></span>\n <span class=\"libs-ui-font-h5r ml-[8px]\">{{ data().color }}</span>\n </div>\n </div>\n <div class=\"w-[80px] shrink-0 libs-ui-border-left-general\">\n <libs_ui-components-inputs-valid\n [noBorder]=\"true\"\n [dataType]=\"'int'\"\n [minValueNumber]=\"0\"\n [maxValueNumber]=\"100\"\n [(item)]=\"data\"\n [fieldNameBind]=\"'opacity'\"\n [unitsRight]=\"[{ id: '%', label: '%' }]\"\n [keySelectedUnitRight]=\"'%'\"\n [classIncludeInput]=\"'text-center !p-0 !h-[28px] !min-h-[28px]'\"\n [configUnitRight]=\"{ classInclude: '!h-[30px]', fieldKey: 'id', fieldLabel: 'label' }\"\n (outValueChange)=\"handlerChangeOpacity()\" />\n </div>\n</div>\n\n<ng-template #element>\n <div class=\"p-[16px] w-full\">\n <div class=\"mb-[16px] grid gap-y-[4px] gap-x-[2px] grid-cols-8\">\n @for (color of colorDefault(); track $index; let i = $index) {\n <div class=\"py-[5px] px-[8px] relative\">\n @if ((color | lowercase) === (data().color | lowercase)) {\n <div class=\"w-[30px] h-[30px] rounded-[30px] top-0 left-[3px] absolute libs-ui-border-primary-general !border-2\"></div>\n }\n <div\n class=\"w-[20px] h-[20px] rounded-[20px] cursor-pointer\"\n [class.libs-ui-border-general]=\"(color | lowercase) === '#ffffff'\"\n [style.background-color]=\"color\"\n (click)=\"handlerSelectColor($event, color)\"></div>\n </div>\n }\n </div>\n <div class=\"flex items-center justify-between\">\n <span class=\"libs-ui-font-h5m color-[#6a7383]\">{{ 'i18n_color_custom' | translate }}</span>\n <libs_ui-components-buttons-button\n [type]=\"'button-link-primary'\"\n [classIconLeft]=\"'libs-ui-icon-add'\"\n [label]=\"'i18n_add_new'\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n template: colorPicker,\n whiteTheme: true,\n ignoreArrow: true,\n widthByParent: false,\n maxWidth: 500,\n maxHeight: 500,\n zIndex: zIndex() + 1,\n classInclude: 'w-[350px]',\n direction: 'left',\n directionDistance: -100,\n position: {\n mode: 'start',\n distance: -165,\n },\n },\n }\"\n [classInclude]=\"'py-[2px] px-[0]'\"\n (outPopoverEvent)=\"handlerPopoverAddColorEvent($event)\"\n (outFunctionsControl)=\"handlerAddColorFunctionControl($event)\" />\n </div>\n @if (colorCustom().length) {\n <div class=\"grid gap-y-[4px] gap-x-[2px] grid-cols-8\">\n @for (color of colorCustom(); track $index; let i = $index) {\n <div class=\"py-[5px] px-[8px] relative\">\n @if ((color | lowercase) === (data().color | lowercase)) {\n <div class=\"w-[30px] h-[30px] rounded-[30px] top-0 left-[3px] absolute libs-ui-border-primary-general !border-2\"></div>\n }\n <div\n class=\"w-[20px] h-[20px] rounded-[20px] cursor-pointer\"\n [class.libs-ui-border-general]=\"(color | lowercase) === '#ffffff'\"\n [style.background-color]=\"color\"\n (click)=\"handlerSelectColor($event, color)\"></div>\n </div>\n }\n </div>\n }\n </div>\n</ng-template>\n\n<ng-template #colorPicker>\n <div class=\"p-[16px] w-auto h-auto\">\n <libs_ui-components-color_picker\n [customOptions]=\"customOptions()\"\n (outColorChange)=\"handlerColorChange($event)\" />\n <div class=\"flex items-center justify-end pt-[16px]\">\n <libs_ui-components-buttons-button\n [label]=\"'i18n_cancel'\"\n [type]=\"'button-third'\"\n (outClick)=\"handlerAction($event, 'cancel')\" />\n <libs_ui-components-buttons-button\n [label]=\"'i18n_apply'\"\n [classInclude]=\"'ml-[16px]'\"\n (outClick)=\"handlerAction($event, 'apply')\" />\n </div>\n </div>\n</ng-template>\n" }]
128
139
  }] });
129
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inputs-color.component.js","sourceRoot":"","sources":["../../../../../../libs-ui/components/inputs/color/src/inputs-color.component.ts","../../../../../../libs-ui/components/inputs/color/src/inputs-color.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, input, model, OnDestroy, OnInit, output, signal } from '@angular/core';\nimport { LibsUiComponentsButtonsButtonComponent } from '@libs-ui/components-buttons-button';\nimport { LibsUiComponentsInputsValidComponent } from '@libs-ui/components-inputs-valid';\nimport { IFlagMouse, IPopoverFunctionControlEvent, LibsUiComponentsPopoverComponent, TYPE_POPOVER_EVENT } from '@libs-ui/components-popover';\nimport { UtilsCache } from '@libs-ui/utils';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { IColorPickerData } from './interfaces/color.interface';\nimport { IPickerCustomOptions, LibsUiComponentsColorPickerComponent } from '@libs-ui/components-color-picker';\nimport { LowerCasePipe } from '@angular/common';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-inputs-color',\n  templateUrl: './inputs-color.component.html',\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [TranslateModule, LowerCasePipe, LibsUiComponentsPopoverComponent, LibsUiComponentsButtonsButtonComponent, LibsUiComponentsInputsValidComponent, LibsUiComponentsColorPickerComponent],\n})\nexport class LibsUiComponentsInputsColorComponent implements OnInit, OnDestroy {\n  // #region PROPERTY\n  protected colorDefault = signal<Array<string>>([]);\n  protected showPopup = signal<boolean>(false);\n  protected colorCustom = signal<Array<string>>([]);\n  protected flagMouse = signal<IFlagMouse>({ isMouseEnter: false, isMouseEnterContent: false });\n\n  private colorAdd = signal<string | undefined>(undefined);\n  private popoverFunctionControl = signal<IPopoverFunctionControlEvent | undefined>(undefined);\n  private popoverAddColorFunctionControl = signal<IPopoverFunctionControlEvent | undefined>(undefined);\n\n  // #region INPUT\n  readonly data = model<IColorPickerData>({ color: '', opacity: 100 });\n  readonly zIndex = model<number>(1200);\n  readonly customOptions = input<IPickerCustomOptions>();\n  readonly functionGetListColorDefault = input<() => Promise<Array<string>>>();\n  readonly functionGetListColorCustom = input<() => Promise<Array<string>>>();\n  readonly functionSetListColorCustom = input<(colors: Array<string>) => Promise<void>>();\n\n  // #region OUTPUT\n  readonly outColorChange = output<IColorPickerData>();\n\n  ngOnInit() {\n    this.getListColorDefault();\n  }\n\n  /* FUNCTIONS */\n  private async getListColorDefault() {\n    const functionGetListColorDefault = this.functionGetListColorDefault();\n\n    if (functionGetListColorDefault) {\n      this.colorDefault.set(await functionGetListColorDefault());\n\n      return;\n    }\n    this.colorDefault.set((await UtilsCache.GetAsync('knfjsdfwenclsdnckjsdfsdfsdfshimdsjdfjksuwesfsdfsdf')) || []);\n  }\n\n  private async getListColorCustom() {\n    const functionGetListColorCustom = this.functionGetListColorCustom();\n\n    if (functionGetListColorCustom) {\n      this.colorCustom.set(await functionGetListColorCustom());\n\n      return;\n    }\n    this.colorCustom.set((await UtilsCache.GetAsync('knfjsdfwenclsdnckjsdfsdfsdfshimdsjdfjksudvsjahdvjasjdhwesfsdfsdf')) || []);\n  }\n\n  protected handlerPopoverEvent(type: TYPE_POPOVER_EVENT) {\n    if (type === 'show') {\n      this.showPopup.set(true);\n      this.getListColorCustom();\n\n      return;\n    }\n    if (type === 'remove') {\n      this.showPopup.set(false);\n    }\n  }\n\n  protected handlerSelectColor(event: Event, color: string) {\n    event.stopPropagation();\n    this.data.update((value) => ({ ...value, color }));\n    this.outColorChange.emit(this.data() as IColorPickerData);\n  }\n\n  protected handlerChangeOpacity() {\n    this.outColorChange.emit(this.data() as IColorPickerData);\n  }\n\n  protected handlerColorChange(event: string) {\n    this.colorAdd.set(event);\n  }\n\n  protected handlerPopoverAddColorEvent(type: TYPE_POPOVER_EVENT) {\n    if (type === 'show') {\n      this.flagMouse.set({ isMouseEnter: true, isMouseEnterContent: true });\n\n      return;\n    }\n    if (type === 'remove') {\n      setTimeout(() => {\n        this.flagMouse.set({ isMouseEnter: false, isMouseEnterContent: false });\n      }, 500);\n    }\n  }\n\n  protected handlerFunctionControl(event: IPopoverFunctionControlEvent) {\n    this.popoverFunctionControl.set(event);\n  }\n\n  protected handlerAddColorFunctionControl(event: IPopoverFunctionControlEvent) {\n    this.popoverAddColorFunctionControl.set(event);\n  }\n\n  protected handlerAction(event: Event, action: 'cancel' | 'apply') {\n    event.stopPropagation();\n    this.popoverAddColorFunctionControl()?.removePopoverOverlay();\n    if (action === 'cancel') {\n      return;\n    }\n    const colorAdd = this.colorAdd();\n\n    if (!colorAdd) {\n      return;\n    }\n    this.handlerSelectColor(event, colorAdd);\n    if (this.colorCustom().find((color) => color === colorAdd)) {\n      return;\n    }\n    this.colorCustom.update((value) => {\n      value.unshift(colorAdd);\n      if (value.length > 8) {\n        value.splice(8, value.length - 8);\n      }\n\n      return [...value];\n    });\n    this.setColorCustom();\n  }\n\n  private async setColorCustom() {\n    const functionSetListColorCustom = this.functionSetListColorCustom();\n\n    if (functionSetListColorCustom) {\n      await functionSetListColorCustom(this.colorCustom());\n\n      return;\n    }\n    UtilsCache.SetAsync('knfjsdfwenclsdnckjsdfsdfsdfshimdsjdfjksudvsjahdvjasjdhwesfsdfsdf', this.colorCustom(), UtilsCache.CACHE_EXPIRE_NONE);\n  }\n\n  ngOnDestroy() {\n    this.popoverFunctionControl()?.removePopoverOverlay();\n    this.popoverAddColorFunctionControl()?.removePopoverOverlay();\n  }\n}\n","<div\n  class=\"w-full flex justify-between rounded-[4px] h-[32px]\"\n  [class.libs-ui-border-general]=\"!showPopup()\"\n  [class.libs-ui-border-primary-focus-general]=\"showPopup()\">\n  <div\n    LibsUiComponentsPopoverDirective\n    class=\"w-full flex\"\n    [mode]=\"'click-toggle'\"\n    [ignoreHiddenPopoverContentWhenMouseLeave]=\"true\"\n    [config]=\"{\n      template: element,\n      whiteTheme: true,\n      ignoreArrow: true,\n      widthByParent: false,\n      maxWidth: 500,\n      maxHeight: 500,\n      zIndex: zIndex(),\n      classInclude: 'w-[334px]',\n      direction: 'left',\n      directionDistance: 4,\n      position: {\n        mode: 'start',\n        distance: 0,\n      },\n    }\"\n    [flagMouse]=\"flagMouse()\"\n    (outEvent)=\"handlerPopoverEvent($event)\"\n    (outFunctionsControl)=\"handlerFunctionControl($event)\">\n    <div class=\"px-[16px] flex items-center\">\n      <span\n        class=\"w-[16px] h-[16px] rounded-[4px] libs-ui-border-general\"\n        [style.background-color]=\"data().color\"></span>\n      <span class=\"libs-ui-font-h5r ml-[8px]\">{{ data().color }}</span>\n    </div>\n  </div>\n  <div class=\"w-[80px] shrink-0 libs-ui-border-left-general\">\n    <libs_ui-components-inputs-valid\n      [noBorder]=\"true\"\n      [dataType]=\"'int'\"\n      [minValueNumber]=\"0\"\n      [maxValueNumber]=\"100\"\n      [(item)]=\"data\"\n      [fieldNameBind]=\"'opacity'\"\n      [unitsRight]=\"[{ id: '%', label: '%' }]\"\n      [keySelectedUnitRight]=\"'%'\"\n      [classIncludeInput]=\"'text-center !p-0 !h-[28px] !min-h-[28px]'\"\n      [configUnitRight]=\"{ classInclude: '!h-[30px]', fieldKey: 'id', fieldLabel: 'label' }\"\n      (outValueChange)=\"handlerChangeOpacity()\" />\n  </div>\n</div>\n\n<ng-template #element>\n  <div class=\"p-[16px] w-full\">\n    <div class=\"mb-[16px] grid gap-y-[4px] gap-x-[2px] grid-cols-8\">\n      @for (color of colorDefault(); track $index; let i = $index) {\n        <div class=\"py-[5px] px-[8px] relative\">\n          @if ((color | lowercase) === (data().color | lowercase)) {\n            <div class=\"w-[30px] h-[30px] rounded-[30px] top-0 left-[3px] absolute libs-ui-border-primary-general !border-2\"></div>\n          }\n          <div\n            class=\"w-[20px] h-[20px] rounded-[20px] cursor-pointer\"\n            [class.libs-ui-border-general]=\"(color | lowercase) === '#ffffff'\"\n            [style.background-color]=\"color\"\n            (click)=\"handlerSelectColor($event, color)\"></div>\n        </div>\n      }\n    </div>\n    <div class=\"flex items-center justify-between\">\n      <span class=\"libs-ui-font-h5m color-[#6a7383]\">{{ 'i18n_color_custom' | translate }}</span>\n      <libs_ui-components-buttons-button\n        [type]=\"'button-link-primary'\"\n        [classIconLeft]=\"'libs-ui-icon-add'\"\n        [label]=\"'i18n_add_new'\"\n        [popover]=\"{\n          mode: 'click-toggle',\n          ignoreHiddenPopoverContentWhenMouseLeave: true,\n          config: {\n            template: colorPicker,\n            whiteTheme: true,\n            ignoreArrow: true,\n            widthByParent: false,\n            maxWidth: 500,\n            maxHeight: 500,\n            zIndex: zIndex() + 1,\n            classInclude: 'w-[350px]',\n            direction: 'left',\n            directionDistance: -100,\n            position: {\n              mode: 'start',\n              distance: -165,\n            },\n          },\n        }\"\n        [classInclude]=\"'py-[2px] px-[0]'\"\n        (outPopoverEvent)=\"handlerPopoverAddColorEvent($event)\"\n        (outFunctionsControl)=\"handlerAddColorFunctionControl($event)\" />\n    </div>\n    @if (colorCustom().length) {\n      <div class=\"grid gap-y-[4px] gap-x-[2px] grid-cols-8\">\n        @for (color of colorCustom(); track $index; let i = $index) {\n          <div class=\"py-[5px] px-[8px] relative\">\n            @if ((color | lowercase) === (data().color | lowercase)) {\n              <div class=\"w-[30px] h-[30px] rounded-[30px] top-0 left-[3px] absolute libs-ui-border-primary-general !border-2\"></div>\n            }\n            <div\n              class=\"w-[20px] h-[20px] rounded-[20px] cursor-pointer\"\n              [class.libs-ui-border-general]=\"(color | lowercase) === '#ffffff'\"\n              [style.background-color]=\"color\"\n              (click)=\"handlerSelectColor($event, color)\"></div>\n          </div>\n        }\n      </div>\n    }\n  </div>\n</ng-template>\n\n<ng-template #colorPicker>\n  <div class=\"p-[16px] w-auto h-auto\">\n    <libs_ui-components-color_picker\n      [customOptions]=\"customOptions()\"\n      (outColorChange)=\"handlerColorChange($event)\" />\n    <div class=\"flex items-center justify-end pt-[16px]\">\n      <libs_ui-components-buttons-button\n        [label]=\"'i18n_cancel'\"\n        [type]=\"'button-third'\"\n        (outClick)=\"handlerAction($event, 'cancel')\" />\n      <libs_ui-components-buttons-button\n        [label]=\"'i18n_apply'\"\n        [classInclude]=\"'ml-[16px]'\"\n        (outClick)=\"handlerAction($event, 'apply')\" />\n    </div>\n  </div>\n</ng-template>\n"]}
140
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"inputs-color.component.js","sourceRoot":"","sources":["../../../../../../libs-ui/components/inputs/color/src/inputs-color.component.ts","../../../../../../libs-ui/components/inputs/color/src/inputs-color.component.html"],"names":[],"mappings":"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","sourcesContent":["import { LowerCasePipe } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, input, model, OnDestroy, OnInit, output, signal } from '@angular/core';\nimport { LibsUiComponentsButtonsButtonComponent } from '@libs-ui/components-buttons-button';\nimport { IPickerCustomOptions, LibsUiComponentsColorPickerComponent } from '@libs-ui/components-color-picker';\nimport { LibsUiComponentsInputsValidComponent } from '@libs-ui/components-inputs-valid';\nimport { IFlagMouse, IPopoverFunctionControlEvent, LibsUiComponentsPopoverComponent, TYPE_POPOVER_EVENT } from '@libs-ui/components-popover';\nimport { UtilsCache } from '@libs-ui/utils';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { IColorPickerData } from './interfaces/color.interface';\n\n/**\n * Component input chọn màu sắc (Color Picker) hỗ trợ độ mờ (opacity)\n * Cung cấp bảng màu mặc định và cho phép người dùng lưu bảng màu tùy chỉnh\n */\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-inputs-color',\n  templateUrl: './inputs-color.component.html',\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [TranslateModule, LowerCasePipe, LibsUiComponentsPopoverComponent, LibsUiComponentsButtonsButtonComponent, LibsUiComponentsInputsValidComponent, LibsUiComponentsColorPickerComponent],\n})\nexport class LibsUiComponentsInputsColorComponent implements OnInit, OnDestroy {\n  // #region PROPERTY\n  protected colorDefault = signal<Array<string>>([]);\n  protected showPopup = signal<boolean>(false);\n  protected colorCustom = signal<Array<string>>([]);\n  protected flagMouse = signal<IFlagMouse>({ isMouseEnter: false, isMouseEnterContent: false });\n\n  private colorAdd = signal<string | undefined>(undefined);\n  private popoverFunctionControl = signal<IPopoverFunctionControlEvent | undefined>(undefined);\n  private popoverAddColorFunctionControl = signal<IPopoverFunctionControlEvent | undefined>(undefined);\n\n  // #region INPUT\n  /** Dữ liệu màu sắc và độ mờ hiện tại */\n  readonly data = model<IColorPickerData>({ color: '', opacity: 100 });\n\n  /** Z-index cho popover bảng màu */\n  readonly zIndex = model<number>(1200);\n\n  /** Cấu hình tùy chỉnh cho color picker */\n  readonly customOptions = input<IPickerCustomOptions>();\n\n  /** Function lấy danh sách màu mặc định */\n  readonly functionGetListColorDefault = input<() => Promise<Array<string>>>();\n\n  /** Function lấy danh sách màu tùy chỉnh đã lưu */\n  readonly functionGetListColorCustom = input<() => Promise<Array<string>>>();\n\n  /** Function lưu danh sách màu tùy chỉnh mới */\n  readonly functionSetListColorCustom = input<(colors: Array<string>) => Promise<void>>();\n\n  // #region OUTPUT\n  /** Emit khi màu sắc hoặc độ mờ thay đổi */\n  readonly outColorChange = output<IColorPickerData>();\n\n  ngOnInit() {\n    this.getListColorDefault();\n  }\n\n  /* FUNCTIONS */\n  private async getListColorDefault() {\n    const functionGetListColorDefault = this.functionGetListColorDefault();\n\n    if (functionGetListColorDefault) {\n      this.colorDefault.set(await functionGetListColorDefault());\n\n      return;\n    }\n    this.colorDefault.set((await UtilsCache.GetAsync('knfjsdfwenclsdnckjsdfsdfsdfshimdsjdfjksuwesfsdfsdf')) || []);\n  }\n\n  private async getListColorCustom() {\n    const functionGetListColorCustom = this.functionGetListColorCustom();\n\n    if (functionGetListColorCustom) {\n      this.colorCustom.set(await functionGetListColorCustom());\n\n      return;\n    }\n    this.colorCustom.set((await UtilsCache.GetAsync('knfjsdfwenclsdnckjsdfsdfsdfshimdsjdfjksudvsjahdvjasjdhwesfsdfsdf')) || []);\n  }\n\n  protected handlerPopoverEvent(type: TYPE_POPOVER_EVENT) {\n    if (type === 'show') {\n      this.showPopup.set(true);\n      this.getListColorCustom();\n\n      return;\n    }\n    if (type === 'remove') {\n      this.showPopup.set(false);\n    }\n  }\n\n  protected handlerSelectColor(event: Event, color: string) {\n    event.stopPropagation();\n    this.data.update((value) => ({ ...value, color }));\n    this.outColorChange.emit(this.data() as IColorPickerData);\n  }\n\n  protected handlerChangeOpacity() {\n    this.outColorChange.emit(this.data() as IColorPickerData);\n  }\n\n  protected handlerColorChange(event: string) {\n    this.colorAdd.set(event);\n  }\n\n  protected handlerPopoverAddColorEvent(type: TYPE_POPOVER_EVENT) {\n    if (type === 'show') {\n      this.flagMouse.set({ isMouseEnter: true, isMouseEnterContent: true });\n\n      return;\n    }\n    if (type === 'remove') {\n      setTimeout(() => {\n        this.flagMouse.set({ isMouseEnter: false, isMouseEnterContent: false });\n      }, 500);\n    }\n  }\n\n  protected handlerFunctionControl(event: IPopoverFunctionControlEvent) {\n    this.popoverFunctionControl.set(event);\n  }\n\n  protected handlerAddColorFunctionControl(event: IPopoverFunctionControlEvent) {\n    this.popoverAddColorFunctionControl.set(event);\n  }\n\n  protected handlerAction(event: Event, action: 'cancel' | 'apply') {\n    event.stopPropagation();\n    this.popoverAddColorFunctionControl()?.removePopoverOverlay();\n    if (action === 'cancel') {\n      return;\n    }\n    const colorAdd = this.colorAdd();\n\n    if (!colorAdd) {\n      return;\n    }\n    this.handlerSelectColor(event, colorAdd);\n    if (this.colorCustom().find((color) => color === colorAdd)) {\n      return;\n    }\n    this.colorCustom.update((value) => {\n      value.unshift(colorAdd);\n      if (value.length > 8) {\n        value.splice(8, value.length - 8);\n      }\n\n      return [...value];\n    });\n    this.setColorCustom();\n  }\n\n  private async setColorCustom() {\n    const functionSetListColorCustom = this.functionSetListColorCustom();\n\n    if (functionSetListColorCustom) {\n      await functionSetListColorCustom(this.colorCustom());\n\n      return;\n    }\n    UtilsCache.SetAsync('knfjsdfwenclsdnckjsdfsdfsdfshimdsjdfjksudvsjahdvjasjdhwesfsdfsdf', this.colorCustom(), UtilsCache.CACHE_EXPIRE_NONE);\n  }\n\n  ngOnDestroy() {\n    this.popoverFunctionControl()?.removePopoverOverlay();\n    this.popoverAddColorFunctionControl()?.removePopoverOverlay();\n  }\n}\n","<div\n  class=\"w-full flex justify-between rounded-[4px] h-[32px]\"\n  [class.libs-ui-border-general]=\"!showPopup()\"\n  [class.libs-ui-border-primary-focus-general]=\"showPopup()\">\n  <div\n    LibsUiComponentsPopoverDirective\n    class=\"w-full flex\"\n    [mode]=\"'click-toggle'\"\n    [ignoreHiddenPopoverContentWhenMouseLeave]=\"true\"\n    [config]=\"{\n      template: element,\n      whiteTheme: true,\n      ignoreArrow: true,\n      widthByParent: false,\n      maxWidth: 500,\n      maxHeight: 500,\n      zIndex: zIndex(),\n      classInclude: 'w-[334px]',\n      direction: 'left',\n      directionDistance: 4,\n      position: {\n        mode: 'start',\n        distance: 0,\n      },\n    }\"\n    [flagMouse]=\"flagMouse()\"\n    (outEvent)=\"handlerPopoverEvent($event)\"\n    (outFunctionsControl)=\"handlerFunctionControl($event)\">\n    <div class=\"px-[16px] flex items-center\">\n      <span\n        class=\"w-[16px] h-[16px] rounded-[4px] libs-ui-border-general\"\n        [style.background-color]=\"data().color\"></span>\n      <span class=\"libs-ui-font-h5r ml-[8px]\">{{ data().color }}</span>\n    </div>\n  </div>\n  <div class=\"w-[80px] shrink-0 libs-ui-border-left-general\">\n    <libs_ui-components-inputs-valid\n      [noBorder]=\"true\"\n      [dataType]=\"'int'\"\n      [minValueNumber]=\"0\"\n      [maxValueNumber]=\"100\"\n      [(item)]=\"data\"\n      [fieldNameBind]=\"'opacity'\"\n      [unitsRight]=\"[{ id: '%', label: '%' }]\"\n      [keySelectedUnitRight]=\"'%'\"\n      [classIncludeInput]=\"'text-center !p-0 !h-[28px] !min-h-[28px]'\"\n      [configUnitRight]=\"{ classInclude: '!h-[30px]', fieldKey: 'id', fieldLabel: 'label' }\"\n      (outValueChange)=\"handlerChangeOpacity()\" />\n  </div>\n</div>\n\n<ng-template #element>\n  <div class=\"p-[16px] w-full\">\n    <div class=\"mb-[16px] grid gap-y-[4px] gap-x-[2px] grid-cols-8\">\n      @for (color of colorDefault(); track $index; let i = $index) {\n        <div class=\"py-[5px] px-[8px] relative\">\n          @if ((color | lowercase) === (data().color | lowercase)) {\n            <div class=\"w-[30px] h-[30px] rounded-[30px] top-0 left-[3px] absolute libs-ui-border-primary-general !border-2\"></div>\n          }\n          <div\n            class=\"w-[20px] h-[20px] rounded-[20px] cursor-pointer\"\n            [class.libs-ui-border-general]=\"(color | lowercase) === '#ffffff'\"\n            [style.background-color]=\"color\"\n            (click)=\"handlerSelectColor($event, color)\"></div>\n        </div>\n      }\n    </div>\n    <div class=\"flex items-center justify-between\">\n      <span class=\"libs-ui-font-h5m color-[#6a7383]\">{{ 'i18n_color_custom' | translate }}</span>\n      <libs_ui-components-buttons-button\n        [type]=\"'button-link-primary'\"\n        [classIconLeft]=\"'libs-ui-icon-add'\"\n        [label]=\"'i18n_add_new'\"\n        [popover]=\"{\n          mode: 'click-toggle',\n          ignoreHiddenPopoverContentWhenMouseLeave: true,\n          config: {\n            template: colorPicker,\n            whiteTheme: true,\n            ignoreArrow: true,\n            widthByParent: false,\n            maxWidth: 500,\n            maxHeight: 500,\n            zIndex: zIndex() + 1,\n            classInclude: 'w-[350px]',\n            direction: 'left',\n            directionDistance: -100,\n            position: {\n              mode: 'start',\n              distance: -165,\n            },\n          },\n        }\"\n        [classInclude]=\"'py-[2px] px-[0]'\"\n        (outPopoverEvent)=\"handlerPopoverAddColorEvent($event)\"\n        (outFunctionsControl)=\"handlerAddColorFunctionControl($event)\" />\n    </div>\n    @if (colorCustom().length) {\n      <div class=\"grid gap-y-[4px] gap-x-[2px] grid-cols-8\">\n        @for (color of colorCustom(); track $index; let i = $index) {\n          <div class=\"py-[5px] px-[8px] relative\">\n            @if ((color | lowercase) === (data().color | lowercase)) {\n              <div class=\"w-[30px] h-[30px] rounded-[30px] top-0 left-[3px] absolute libs-ui-border-primary-general !border-2\"></div>\n            }\n            <div\n              class=\"w-[20px] h-[20px] rounded-[20px] cursor-pointer\"\n              [class.libs-ui-border-general]=\"(color | lowercase) === '#ffffff'\"\n              [style.background-color]=\"color\"\n              (click)=\"handlerSelectColor($event, color)\"></div>\n          </div>\n        }\n      </div>\n    }\n  </div>\n</ng-template>\n\n<ng-template #colorPicker>\n  <div class=\"p-[16px] w-auto h-auto\">\n    <libs_ui-components-color_picker\n      [customOptions]=\"customOptions()\"\n      (outColorChange)=\"handlerColorChange($event)\" />\n    <div class=\"flex items-center justify-end pt-[16px]\">\n      <libs_ui-components-buttons-button\n        [label]=\"'i18n_cancel'\"\n        [type]=\"'button-third'\"\n        (outClick)=\"handlerAction($event, 'cancel')\" />\n      <libs_ui-components-buttons-button\n        [label]=\"'i18n_apply'\"\n        [classInclude]=\"'ml-[16px]'\"\n        (outClick)=\"handlerAction($event, 'apply')\" />\n    </div>\n  </div>\n</ng-template>\n"]}
@@ -1,2 +1,2 @@
1
1
  export {};
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sb3IuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy11aS9jb21wb25lbnRzL2lucHV0cy9jb2xvci9zcmMvaW50ZXJmYWNlcy9jb2xvci5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgSUNvbG9yUGlja2VyRGF0YSB7XG4gIGNvbG9yOiBzdHJpbmc7XG4gIG9wYWNpdHk6IG51bWJlcjtcbn1cbiJdfQ==
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sb3IuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy11aS9jb21wb25lbnRzL2lucHV0cy9jb2xvci9zcmMvaW50ZXJmYWNlcy9jb2xvci5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8qKiBE4buvIGxp4buHdSBtw6B1IHPhuq9jIHRy4bqjIHbhu4EgdOG7qyBjb21wb25lbnQgKi9cbmV4cG9ydCBpbnRlcmZhY2UgSUNvbG9yUGlja2VyRGF0YSB7XG4gIC8qKiBNw6MgbcOgdSBoZXggKHZkOiAjZmZmZmZmKSAqL1xuICBjb2xvcjogc3RyaW5nO1xuICAvKiogxJDhu5kgbeG7nSB04burIDAgxJHhur9uIDEwMCAqL1xuICBvcGFjaXR5OiBudW1iZXI7XG59XG4iXX0=
@@ -1,14 +1,18 @@
1
+ import { LowerCasePipe } from '@angular/common';
1
2
  import * as i0 from '@angular/core';
2
3
  import { signal, model, input, output, ChangeDetectionStrategy, Component } from '@angular/core';
3
4
  import { LibsUiComponentsButtonsButtonComponent } from '@libs-ui/components-buttons-button';
5
+ import { LibsUiComponentsColorPickerComponent } from '@libs-ui/components-color-picker';
4
6
  import { LibsUiComponentsInputsValidComponent } from '@libs-ui/components-inputs-valid';
5
7
  import { LibsUiComponentsPopoverComponent } from '@libs-ui/components-popover';
6
8
  import { UtilsCache } from '@libs-ui/utils';
7
9
  import * as i1 from '@ngx-translate/core';
8
10
  import { TranslateModule } from '@ngx-translate/core';
9
- import { LibsUiComponentsColorPickerComponent } from '@libs-ui/components-color-picker';
10
- import { LowerCasePipe } from '@angular/common';
11
11
 
12
+ /**
13
+ * Component input chọn màu sắc (Color Picker) hỗ trợ độ mờ (opacity)
14
+ * Cung cấp bảng màu mặc định và cho phép người dùng lưu bảng màu tùy chỉnh
15
+ */
12
16
  class LibsUiComponentsInputsColorComponent {
13
17
  // #region PROPERTY
14
18
  colorDefault = signal([]);
@@ -19,13 +23,20 @@ class LibsUiComponentsInputsColorComponent {
19
23
  popoverFunctionControl = signal(undefined);
20
24
  popoverAddColorFunctionControl = signal(undefined);
21
25
  // #region INPUT
26
+ /** Dữ liệu màu sắc và độ mờ hiện tại */
22
27
  data = model({ color: '', opacity: 100 });
28
+ /** Z-index cho popover bảng màu */
23
29
  zIndex = model(1200);
30
+ /** Cấu hình tùy chỉnh cho color picker */
24
31
  customOptions = input();
32
+ /** Function lấy danh sách màu mặc định */
25
33
  functionGetListColorDefault = input();
34
+ /** Function lấy danh sách màu tùy chỉnh đã lưu */
26
35
  functionGetListColorCustom = input();
36
+ /** Function lưu danh sách màu tùy chỉnh mới */
27
37
  functionSetListColorCustom = input();
28
38
  // #region OUTPUT
39
+ /** Emit khi màu sắc hoặc độ mờ thay đổi */
29
40
  outColorChange = output();
30
41
  ngOnInit() {
31
42
  this.getListColorDefault();
@@ -1 +1 @@
1
- {"version":3,"file":"libs-ui-components-inputs-color.mjs","sources":["../../../../../../libs-ui/components/inputs/color/src/inputs-color.component.ts","../../../../../../libs-ui/components/inputs/color/src/inputs-color.component.html","../../../../../../libs-ui/components/inputs/color/src/libs-ui-components-inputs-color.ts"],"sourcesContent":["import { ChangeDetectionStrategy, Component, input, model, OnDestroy, OnInit, output, signal } from '@angular/core';\nimport { LibsUiComponentsButtonsButtonComponent } from '@libs-ui/components-buttons-button';\nimport { LibsUiComponentsInputsValidComponent } from '@libs-ui/components-inputs-valid';\nimport { IFlagMouse, IPopoverFunctionControlEvent, LibsUiComponentsPopoverComponent, TYPE_POPOVER_EVENT } from '@libs-ui/components-popover';\nimport { UtilsCache } from '@libs-ui/utils';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { IColorPickerData } from './interfaces/color.interface';\nimport { IPickerCustomOptions, LibsUiComponentsColorPickerComponent } from '@libs-ui/components-color-picker';\nimport { LowerCasePipe } from '@angular/common';\n\n@Component({\n // eslint-disable-next-line @angular-eslint/component-selector\n selector: 'libs_ui-components-inputs-color',\n templateUrl: './inputs-color.component.html',\n standalone: true,\n changeDetection: ChangeDetectionStrategy.OnPush,\n imports: [TranslateModule, LowerCasePipe, LibsUiComponentsPopoverComponent, LibsUiComponentsButtonsButtonComponent, LibsUiComponentsInputsValidComponent, LibsUiComponentsColorPickerComponent],\n})\nexport class LibsUiComponentsInputsColorComponent implements OnInit, OnDestroy {\n // #region PROPERTY\n protected colorDefault = signal<Array<string>>([]);\n protected showPopup = signal<boolean>(false);\n protected colorCustom = signal<Array<string>>([]);\n protected flagMouse = signal<IFlagMouse>({ isMouseEnter: false, isMouseEnterContent: false });\n\n private colorAdd = signal<string | undefined>(undefined);\n private popoverFunctionControl = signal<IPopoverFunctionControlEvent | undefined>(undefined);\n private popoverAddColorFunctionControl = signal<IPopoverFunctionControlEvent | undefined>(undefined);\n\n // #region INPUT\n readonly data = model<IColorPickerData>({ color: '', opacity: 100 });\n readonly zIndex = model<number>(1200);\n readonly customOptions = input<IPickerCustomOptions>();\n readonly functionGetListColorDefault = input<() => Promise<Array<string>>>();\n readonly functionGetListColorCustom = input<() => Promise<Array<string>>>();\n readonly functionSetListColorCustom = input<(colors: Array<string>) => Promise<void>>();\n\n // #region OUTPUT\n readonly outColorChange = output<IColorPickerData>();\n\n ngOnInit() {\n this.getListColorDefault();\n }\n\n /* FUNCTIONS */\n private async getListColorDefault() {\n const functionGetListColorDefault = this.functionGetListColorDefault();\n\n if (functionGetListColorDefault) {\n this.colorDefault.set(await functionGetListColorDefault());\n\n return;\n }\n this.colorDefault.set((await UtilsCache.GetAsync('knfjsdfwenclsdnckjsdfsdfsdfshimdsjdfjksuwesfsdfsdf')) || []);\n }\n\n private async getListColorCustom() {\n const functionGetListColorCustom = this.functionGetListColorCustom();\n\n if (functionGetListColorCustom) {\n this.colorCustom.set(await functionGetListColorCustom());\n\n return;\n }\n this.colorCustom.set((await UtilsCache.GetAsync('knfjsdfwenclsdnckjsdfsdfsdfshimdsjdfjksudvsjahdvjasjdhwesfsdfsdf')) || []);\n }\n\n protected handlerPopoverEvent(type: TYPE_POPOVER_EVENT) {\n if (type === 'show') {\n this.showPopup.set(true);\n this.getListColorCustom();\n\n return;\n }\n if (type === 'remove') {\n this.showPopup.set(false);\n }\n }\n\n protected handlerSelectColor(event: Event, color: string) {\n event.stopPropagation();\n this.data.update((value) => ({ ...value, color }));\n this.outColorChange.emit(this.data() as IColorPickerData);\n }\n\n protected handlerChangeOpacity() {\n this.outColorChange.emit(this.data() as IColorPickerData);\n }\n\n protected handlerColorChange(event: string) {\n this.colorAdd.set(event);\n }\n\n protected handlerPopoverAddColorEvent(type: TYPE_POPOVER_EVENT) {\n if (type === 'show') {\n this.flagMouse.set({ isMouseEnter: true, isMouseEnterContent: true });\n\n return;\n }\n if (type === 'remove') {\n setTimeout(() => {\n this.flagMouse.set({ isMouseEnter: false, isMouseEnterContent: false });\n }, 500);\n }\n }\n\n protected handlerFunctionControl(event: IPopoverFunctionControlEvent) {\n this.popoverFunctionControl.set(event);\n }\n\n protected handlerAddColorFunctionControl(event: IPopoverFunctionControlEvent) {\n this.popoverAddColorFunctionControl.set(event);\n }\n\n protected handlerAction(event: Event, action: 'cancel' | 'apply') {\n event.stopPropagation();\n this.popoverAddColorFunctionControl()?.removePopoverOverlay();\n if (action === 'cancel') {\n return;\n }\n const colorAdd = this.colorAdd();\n\n if (!colorAdd) {\n return;\n }\n this.handlerSelectColor(event, colorAdd);\n if (this.colorCustom().find((color) => color === colorAdd)) {\n return;\n }\n this.colorCustom.update((value) => {\n value.unshift(colorAdd);\n if (value.length > 8) {\n value.splice(8, value.length - 8);\n }\n\n return [...value];\n });\n this.setColorCustom();\n }\n\n private async setColorCustom() {\n const functionSetListColorCustom = this.functionSetListColorCustom();\n\n if (functionSetListColorCustom) {\n await functionSetListColorCustom(this.colorCustom());\n\n return;\n }\n UtilsCache.SetAsync('knfjsdfwenclsdnckjsdfsdfsdfshimdsjdfjksudvsjahdvjasjdhwesfsdfsdf', this.colorCustom(), UtilsCache.CACHE_EXPIRE_NONE);\n }\n\n ngOnDestroy() {\n this.popoverFunctionControl()?.removePopoverOverlay();\n this.popoverAddColorFunctionControl()?.removePopoverOverlay();\n }\n}\n","<div\n class=\"w-full flex justify-between rounded-[4px] h-[32px]\"\n [class.libs-ui-border-general]=\"!showPopup()\"\n [class.libs-ui-border-primary-focus-general]=\"showPopup()\">\n <div\n LibsUiComponentsPopoverDirective\n class=\"w-full flex\"\n [mode]=\"'click-toggle'\"\n [ignoreHiddenPopoverContentWhenMouseLeave]=\"true\"\n [config]=\"{\n template: element,\n whiteTheme: true,\n ignoreArrow: true,\n widthByParent: false,\n maxWidth: 500,\n maxHeight: 500,\n zIndex: zIndex(),\n classInclude: 'w-[334px]',\n direction: 'left',\n directionDistance: 4,\n position: {\n mode: 'start',\n distance: 0,\n },\n }\"\n [flagMouse]=\"flagMouse()\"\n (outEvent)=\"handlerPopoverEvent($event)\"\n (outFunctionsControl)=\"handlerFunctionControl($event)\">\n <div class=\"px-[16px] flex items-center\">\n <span\n class=\"w-[16px] h-[16px] rounded-[4px] libs-ui-border-general\"\n [style.background-color]=\"data().color\"></span>\n <span class=\"libs-ui-font-h5r ml-[8px]\">{{ data().color }}</span>\n </div>\n </div>\n <div class=\"w-[80px] shrink-0 libs-ui-border-left-general\">\n <libs_ui-components-inputs-valid\n [noBorder]=\"true\"\n [dataType]=\"'int'\"\n [minValueNumber]=\"0\"\n [maxValueNumber]=\"100\"\n [(item)]=\"data\"\n [fieldNameBind]=\"'opacity'\"\n [unitsRight]=\"[{ id: '%', label: '%' }]\"\n [keySelectedUnitRight]=\"'%'\"\n [classIncludeInput]=\"'text-center !p-0 !h-[28px] !min-h-[28px]'\"\n [configUnitRight]=\"{ classInclude: '!h-[30px]', fieldKey: 'id', fieldLabel: 'label' }\"\n (outValueChange)=\"handlerChangeOpacity()\" />\n </div>\n</div>\n\n<ng-template #element>\n <div class=\"p-[16px] w-full\">\n <div class=\"mb-[16px] grid gap-y-[4px] gap-x-[2px] grid-cols-8\">\n @for (color of colorDefault(); track $index; let i = $index) {\n <div class=\"py-[5px] px-[8px] relative\">\n @if ((color | lowercase) === (data().color | lowercase)) {\n <div class=\"w-[30px] h-[30px] rounded-[30px] top-0 left-[3px] absolute libs-ui-border-primary-general !border-2\"></div>\n }\n <div\n class=\"w-[20px] h-[20px] rounded-[20px] cursor-pointer\"\n [class.libs-ui-border-general]=\"(color | lowercase) === '#ffffff'\"\n [style.background-color]=\"color\"\n (click)=\"handlerSelectColor($event, color)\"></div>\n </div>\n }\n </div>\n <div class=\"flex items-center justify-between\">\n <span class=\"libs-ui-font-h5m color-[#6a7383]\">{{ 'i18n_color_custom' | translate }}</span>\n <libs_ui-components-buttons-button\n [type]=\"'button-link-primary'\"\n [classIconLeft]=\"'libs-ui-icon-add'\"\n [label]=\"'i18n_add_new'\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n template: colorPicker,\n whiteTheme: true,\n ignoreArrow: true,\n widthByParent: false,\n maxWidth: 500,\n maxHeight: 500,\n zIndex: zIndex() + 1,\n classInclude: 'w-[350px]',\n direction: 'left',\n directionDistance: -100,\n position: {\n mode: 'start',\n distance: -165,\n },\n },\n }\"\n [classInclude]=\"'py-[2px] px-[0]'\"\n (outPopoverEvent)=\"handlerPopoverAddColorEvent($event)\"\n (outFunctionsControl)=\"handlerAddColorFunctionControl($event)\" />\n </div>\n @if (colorCustom().length) {\n <div class=\"grid gap-y-[4px] gap-x-[2px] grid-cols-8\">\n @for (color of colorCustom(); track $index; let i = $index) {\n <div class=\"py-[5px] px-[8px] relative\">\n @if ((color | lowercase) === (data().color | lowercase)) {\n <div class=\"w-[30px] h-[30px] rounded-[30px] top-0 left-[3px] absolute libs-ui-border-primary-general !border-2\"></div>\n }\n <div\n class=\"w-[20px] h-[20px] rounded-[20px] cursor-pointer\"\n [class.libs-ui-border-general]=\"(color | lowercase) === '#ffffff'\"\n [style.background-color]=\"color\"\n (click)=\"handlerSelectColor($event, color)\"></div>\n </div>\n }\n </div>\n }\n </div>\n</ng-template>\n\n<ng-template #colorPicker>\n <div class=\"p-[16px] w-auto h-auto\">\n <libs_ui-components-color_picker\n [customOptions]=\"customOptions()\"\n (outColorChange)=\"handlerColorChange($event)\" />\n <div class=\"flex items-center justify-end pt-[16px]\">\n <libs_ui-components-buttons-button\n [label]=\"'i18n_cancel'\"\n [type]=\"'button-third'\"\n (outClick)=\"handlerAction($event, 'cancel')\" />\n <libs_ui-components-buttons-button\n [label]=\"'i18n_apply'\"\n [classInclude]=\"'ml-[16px]'\"\n (outClick)=\"handlerAction($event, 'apply')\" />\n </div>\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-inputs-color.mjs","sources":["../../../../../../libs-ui/components/inputs/color/src/inputs-color.component.ts","../../../../../../libs-ui/components/inputs/color/src/inputs-color.component.html","../../../../../../libs-ui/components/inputs/color/src/libs-ui-components-inputs-color.ts"],"sourcesContent":["import { LowerCasePipe } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, input, model, OnDestroy, OnInit, output, signal } from '@angular/core';\nimport { LibsUiComponentsButtonsButtonComponent } from '@libs-ui/components-buttons-button';\nimport { IPickerCustomOptions, LibsUiComponentsColorPickerComponent } from '@libs-ui/components-color-picker';\nimport { LibsUiComponentsInputsValidComponent } from '@libs-ui/components-inputs-valid';\nimport { IFlagMouse, IPopoverFunctionControlEvent, LibsUiComponentsPopoverComponent, TYPE_POPOVER_EVENT } from '@libs-ui/components-popover';\nimport { UtilsCache } from '@libs-ui/utils';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { IColorPickerData } from './interfaces/color.interface';\n\n/**\n * Component input chọn màu sắc (Color Picker) hỗ trợ độ mờ (opacity)\n * Cung cấp bảng màu mặc định và cho phép người dùng lưu bảng màu tùy chỉnh\n */\n@Component({\n // eslint-disable-next-line @angular-eslint/component-selector\n selector: 'libs_ui-components-inputs-color',\n templateUrl: './inputs-color.component.html',\n standalone: true,\n changeDetection: ChangeDetectionStrategy.OnPush,\n imports: [TranslateModule, LowerCasePipe, LibsUiComponentsPopoverComponent, LibsUiComponentsButtonsButtonComponent, LibsUiComponentsInputsValidComponent, LibsUiComponentsColorPickerComponent],\n})\nexport class LibsUiComponentsInputsColorComponent implements OnInit, OnDestroy {\n // #region PROPERTY\n protected colorDefault = signal<Array<string>>([]);\n protected showPopup = signal<boolean>(false);\n protected colorCustom = signal<Array<string>>([]);\n protected flagMouse = signal<IFlagMouse>({ isMouseEnter: false, isMouseEnterContent: false });\n\n private colorAdd = signal<string | undefined>(undefined);\n private popoverFunctionControl = signal<IPopoverFunctionControlEvent | undefined>(undefined);\n private popoverAddColorFunctionControl = signal<IPopoverFunctionControlEvent | undefined>(undefined);\n\n // #region INPUT\n /** Dữ liệu màu sắc và độ mờ hiện tại */\n readonly data = model<IColorPickerData>({ color: '', opacity: 100 });\n\n /** Z-index cho popover bảng màu */\n readonly zIndex = model<number>(1200);\n\n /** Cấu hình tùy chỉnh cho color picker */\n readonly customOptions = input<IPickerCustomOptions>();\n\n /** Function lấy danh sách màu mặc định */\n readonly functionGetListColorDefault = input<() => Promise<Array<string>>>();\n\n /** Function lấy danh sách màu tùy chỉnh đã lưu */\n readonly functionGetListColorCustom = input<() => Promise<Array<string>>>();\n\n /** Function lưu danh sách màu tùy chỉnh mới */\n readonly functionSetListColorCustom = input<(colors: Array<string>) => Promise<void>>();\n\n // #region OUTPUT\n /** Emit khi màu sắc hoặc độ mờ thay đổi */\n readonly outColorChange = output<IColorPickerData>();\n\n ngOnInit() {\n this.getListColorDefault();\n }\n\n /* FUNCTIONS */\n private async getListColorDefault() {\n const functionGetListColorDefault = this.functionGetListColorDefault();\n\n if (functionGetListColorDefault) {\n this.colorDefault.set(await functionGetListColorDefault());\n\n return;\n }\n this.colorDefault.set((await UtilsCache.GetAsync('knfjsdfwenclsdnckjsdfsdfsdfshimdsjdfjksuwesfsdfsdf')) || []);\n }\n\n private async getListColorCustom() {\n const functionGetListColorCustom = this.functionGetListColorCustom();\n\n if (functionGetListColorCustom) {\n this.colorCustom.set(await functionGetListColorCustom());\n\n return;\n }\n this.colorCustom.set((await UtilsCache.GetAsync('knfjsdfwenclsdnckjsdfsdfsdfshimdsjdfjksudvsjahdvjasjdhwesfsdfsdf')) || []);\n }\n\n protected handlerPopoverEvent(type: TYPE_POPOVER_EVENT) {\n if (type === 'show') {\n this.showPopup.set(true);\n this.getListColorCustom();\n\n return;\n }\n if (type === 'remove') {\n this.showPopup.set(false);\n }\n }\n\n protected handlerSelectColor(event: Event, color: string) {\n event.stopPropagation();\n this.data.update((value) => ({ ...value, color }));\n this.outColorChange.emit(this.data() as IColorPickerData);\n }\n\n protected handlerChangeOpacity() {\n this.outColorChange.emit(this.data() as IColorPickerData);\n }\n\n protected handlerColorChange(event: string) {\n this.colorAdd.set(event);\n }\n\n protected handlerPopoverAddColorEvent(type: TYPE_POPOVER_EVENT) {\n if (type === 'show') {\n this.flagMouse.set({ isMouseEnter: true, isMouseEnterContent: true });\n\n return;\n }\n if (type === 'remove') {\n setTimeout(() => {\n this.flagMouse.set({ isMouseEnter: false, isMouseEnterContent: false });\n }, 500);\n }\n }\n\n protected handlerFunctionControl(event: IPopoverFunctionControlEvent) {\n this.popoverFunctionControl.set(event);\n }\n\n protected handlerAddColorFunctionControl(event: IPopoverFunctionControlEvent) {\n this.popoverAddColorFunctionControl.set(event);\n }\n\n protected handlerAction(event: Event, action: 'cancel' | 'apply') {\n event.stopPropagation();\n this.popoverAddColorFunctionControl()?.removePopoverOverlay();\n if (action === 'cancel') {\n return;\n }\n const colorAdd = this.colorAdd();\n\n if (!colorAdd) {\n return;\n }\n this.handlerSelectColor(event, colorAdd);\n if (this.colorCustom().find((color) => color === colorAdd)) {\n return;\n }\n this.colorCustom.update((value) => {\n value.unshift(colorAdd);\n if (value.length > 8) {\n value.splice(8, value.length - 8);\n }\n\n return [...value];\n });\n this.setColorCustom();\n }\n\n private async setColorCustom() {\n const functionSetListColorCustom = this.functionSetListColorCustom();\n\n if (functionSetListColorCustom) {\n await functionSetListColorCustom(this.colorCustom());\n\n return;\n }\n UtilsCache.SetAsync('knfjsdfwenclsdnckjsdfsdfsdfshimdsjdfjksudvsjahdvjasjdhwesfsdfsdf', this.colorCustom(), UtilsCache.CACHE_EXPIRE_NONE);\n }\n\n ngOnDestroy() {\n this.popoverFunctionControl()?.removePopoverOverlay();\n this.popoverAddColorFunctionControl()?.removePopoverOverlay();\n }\n}\n","<div\n class=\"w-full flex justify-between rounded-[4px] h-[32px]\"\n [class.libs-ui-border-general]=\"!showPopup()\"\n [class.libs-ui-border-primary-focus-general]=\"showPopup()\">\n <div\n LibsUiComponentsPopoverDirective\n class=\"w-full flex\"\n [mode]=\"'click-toggle'\"\n [ignoreHiddenPopoverContentWhenMouseLeave]=\"true\"\n [config]=\"{\n template: element,\n whiteTheme: true,\n ignoreArrow: true,\n widthByParent: false,\n maxWidth: 500,\n maxHeight: 500,\n zIndex: zIndex(),\n classInclude: 'w-[334px]',\n direction: 'left',\n directionDistance: 4,\n position: {\n mode: 'start',\n distance: 0,\n },\n }\"\n [flagMouse]=\"flagMouse()\"\n (outEvent)=\"handlerPopoverEvent($event)\"\n (outFunctionsControl)=\"handlerFunctionControl($event)\">\n <div class=\"px-[16px] flex items-center\">\n <span\n class=\"w-[16px] h-[16px] rounded-[4px] libs-ui-border-general\"\n [style.background-color]=\"data().color\"></span>\n <span class=\"libs-ui-font-h5r ml-[8px]\">{{ data().color }}</span>\n </div>\n </div>\n <div class=\"w-[80px] shrink-0 libs-ui-border-left-general\">\n <libs_ui-components-inputs-valid\n [noBorder]=\"true\"\n [dataType]=\"'int'\"\n [minValueNumber]=\"0\"\n [maxValueNumber]=\"100\"\n [(item)]=\"data\"\n [fieldNameBind]=\"'opacity'\"\n [unitsRight]=\"[{ id: '%', label: '%' }]\"\n [keySelectedUnitRight]=\"'%'\"\n [classIncludeInput]=\"'text-center !p-0 !h-[28px] !min-h-[28px]'\"\n [configUnitRight]=\"{ classInclude: '!h-[30px]', fieldKey: 'id', fieldLabel: 'label' }\"\n (outValueChange)=\"handlerChangeOpacity()\" />\n </div>\n</div>\n\n<ng-template #element>\n <div class=\"p-[16px] w-full\">\n <div class=\"mb-[16px] grid gap-y-[4px] gap-x-[2px] grid-cols-8\">\n @for (color of colorDefault(); track $index; let i = $index) {\n <div class=\"py-[5px] px-[8px] relative\">\n @if ((color | lowercase) === (data().color | lowercase)) {\n <div class=\"w-[30px] h-[30px] rounded-[30px] top-0 left-[3px] absolute libs-ui-border-primary-general !border-2\"></div>\n }\n <div\n class=\"w-[20px] h-[20px] rounded-[20px] cursor-pointer\"\n [class.libs-ui-border-general]=\"(color | lowercase) === '#ffffff'\"\n [style.background-color]=\"color\"\n (click)=\"handlerSelectColor($event, color)\"></div>\n </div>\n }\n </div>\n <div class=\"flex items-center justify-between\">\n <span class=\"libs-ui-font-h5m color-[#6a7383]\">{{ 'i18n_color_custom' | translate }}</span>\n <libs_ui-components-buttons-button\n [type]=\"'button-link-primary'\"\n [classIconLeft]=\"'libs-ui-icon-add'\"\n [label]=\"'i18n_add_new'\"\n [popover]=\"{\n mode: 'click-toggle',\n ignoreHiddenPopoverContentWhenMouseLeave: true,\n config: {\n template: colorPicker,\n whiteTheme: true,\n ignoreArrow: true,\n widthByParent: false,\n maxWidth: 500,\n maxHeight: 500,\n zIndex: zIndex() + 1,\n classInclude: 'w-[350px]',\n direction: 'left',\n directionDistance: -100,\n position: {\n mode: 'start',\n distance: -165,\n },\n },\n }\"\n [classInclude]=\"'py-[2px] px-[0]'\"\n (outPopoverEvent)=\"handlerPopoverAddColorEvent($event)\"\n (outFunctionsControl)=\"handlerAddColorFunctionControl($event)\" />\n </div>\n @if (colorCustom().length) {\n <div class=\"grid gap-y-[4px] gap-x-[2px] grid-cols-8\">\n @for (color of colorCustom(); track $index; let i = $index) {\n <div class=\"py-[5px] px-[8px] relative\">\n @if ((color | lowercase) === (data().color | lowercase)) {\n <div class=\"w-[30px] h-[30px] rounded-[30px] top-0 left-[3px] absolute libs-ui-border-primary-general !border-2\"></div>\n }\n <div\n class=\"w-[20px] h-[20px] rounded-[20px] cursor-pointer\"\n [class.libs-ui-border-general]=\"(color | lowercase) === '#ffffff'\"\n [style.background-color]=\"color\"\n (click)=\"handlerSelectColor($event, color)\"></div>\n </div>\n }\n </div>\n }\n </div>\n</ng-template>\n\n<ng-template #colorPicker>\n <div class=\"p-[16px] w-auto h-auto\">\n <libs_ui-components-color_picker\n [customOptions]=\"customOptions()\"\n (outColorChange)=\"handlerColorChange($event)\" />\n <div class=\"flex items-center justify-end pt-[16px]\">\n <libs_ui-components-buttons-button\n [label]=\"'i18n_cancel'\"\n [type]=\"'button-third'\"\n (outClick)=\"handlerAction($event, 'cancel')\" />\n <libs_ui-components-buttons-button\n [label]=\"'i18n_apply'\"\n [classInclude]=\"'ml-[16px]'\"\n (outClick)=\"handlerAction($event, 'apply')\" />\n </div>\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,8 +1,12 @@
1
1
  import { OnDestroy, OnInit } from '@angular/core';
2
+ import { IPickerCustomOptions } from '@libs-ui/components-color-picker';
2
3
  import { IFlagMouse, IPopoverFunctionControlEvent, TYPE_POPOVER_EVENT } from '@libs-ui/components-popover';
3
4
  import { IColorPickerData } from './interfaces/color.interface';
4
- import { IPickerCustomOptions } from '@libs-ui/components-color-picker';
5
5
  import * as i0 from "@angular/core";
6
+ /**
7
+ * Component input chọn màu sắc (Color Picker) hỗ trợ độ mờ (opacity)
8
+ * Cung cấp bảng màu mặc định và cho phép người dùng lưu bảng màu tùy chỉnh
9
+ */
6
10
  export declare class LibsUiComponentsInputsColorComponent implements OnInit, OnDestroy {
7
11
  protected colorDefault: import("@angular/core").WritableSignal<string[]>;
8
12
  protected showPopup: import("@angular/core").WritableSignal<boolean>;
@@ -11,12 +15,19 @@ export declare class LibsUiComponentsInputsColorComponent implements OnInit, OnD
11
15
  private colorAdd;
12
16
  private popoverFunctionControl;
13
17
  private popoverAddColorFunctionControl;
18
+ /** Dữ liệu màu sắc và độ mờ hiện tại */
14
19
  readonly data: import("@angular/core").ModelSignal<IColorPickerData>;
20
+ /** Z-index cho popover bảng màu */
15
21
  readonly zIndex: import("@angular/core").ModelSignal<number>;
22
+ /** Cấu hình tùy chỉnh cho color picker */
16
23
  readonly customOptions: import("@angular/core").InputSignal<IPickerCustomOptions | undefined>;
24
+ /** Function lấy danh sách màu mặc định */
17
25
  readonly functionGetListColorDefault: import("@angular/core").InputSignal<(() => Promise<Array<string>>) | undefined>;
26
+ /** Function lấy danh sách màu tùy chỉnh đã lưu */
18
27
  readonly functionGetListColorCustom: import("@angular/core").InputSignal<(() => Promise<Array<string>>) | undefined>;
28
+ /** Function lưu danh sách màu tùy chỉnh mới */
19
29
  readonly functionSetListColorCustom: import("@angular/core").InputSignal<((colors: Array<string>) => Promise<void>) | undefined>;
30
+ /** Emit khi màu sắc hoặc độ mờ thay đổi */
20
31
  readonly outColorChange: import("@angular/core").OutputEmitterRef<IColorPickerData>;
21
32
  ngOnInit(): void;
22
33
  private getListColorDefault;
@@ -1,4 +1,7 @@
1
+ /** Dữ liệu màu sắc trả về từ component */
1
2
  export interface IColorPickerData {
3
+ /** Mã màu hex (vd: #ffffff) */
2
4
  color: string;
5
+ /** Độ mờ từ 0 đến 100 */
3
6
  opacity: number;
4
7
  }
package/package.json CHANGED
@@ -1,15 +1,15 @@
1
1
  {
2
2
  "name": "@libs-ui/components-inputs-color",
3
- "version": "0.2.355-8",
3
+ "version": "0.2.356-0",
4
4
  "peerDependencies": {
5
5
  "@angular/common": ">=18.0.0",
6
6
  "@angular/core": ">=18.0.0",
7
- "@libs-ui/components-buttons-button": "0.2.355-8",
8
- "@libs-ui/components-inputs-valid": "0.2.355-8",
9
- "@libs-ui/components-popover": "0.2.355-8",
10
- "@libs-ui/utils": "0.2.355-8",
7
+ "@libs-ui/components-buttons-button": "0.2.356-0",
8
+ "@libs-ui/components-inputs-valid": "0.2.356-0",
9
+ "@libs-ui/components-popover": "0.2.356-0",
10
+ "@libs-ui/utils": "0.2.356-0",
11
11
  "@ngx-translate/core": "^15.0.0",
12
- "@libs-ui/components-color-picker": "0.2.355-8"
12
+ "@libs-ui/components-color-picker": "0.2.356-0"
13
13
  },
14
14
  "sideEffects": false,
15
15
  "module": "fesm2022/libs-ui-components-inputs-color.mjs",