@acorex/components 18.16.0-next.5 → 18.16.0-next.7

Sign up to get free protection for your applications and to get access to all the features.
Files changed (40) hide show
  1. package/color-palette/lib/color-palette-input.component.d.ts +6 -1
  2. package/color-palette/lib/color-palette-picker.component.d.ts +6 -2
  3. package/data-pager/lib/data-pager.component.d.ts +1 -2
  4. package/esm2022/action-sheet/lib/action-sheet.component.mjs +2 -2
  5. package/esm2022/color-palette/lib/color-palette-input.component.mjs +2 -1
  6. package/esm2022/color-palette/lib/color-palette-picker.component.mjs +66 -40
  7. package/esm2022/data-pager/lib/data-pager-numeric-selector.component.mjs +15 -11
  8. package/esm2022/data-pager/lib/data-pager-pagesize-dropdown.component.mjs +3 -3
  9. package/esm2022/data-pager/lib/data-pager.component.mjs +6 -7
  10. package/esm2022/data-table/lib/data-table/data-table.component.mjs +1 -1
  11. package/esm2022/image-editor/lib/image-editor-container/image-editor-container.component.mjs +5 -4
  12. package/esm2022/image-editor/lib/image-editor-toolbar/image-editor-toolbar.component.mjs +2 -2
  13. package/esm2022/image-editor/lib/image-editor-tools/image-editor-color-picker/image-editor-color-picker.component.mjs +3 -3
  14. package/esm2022/image-editor/lib/image-editor-view/image-editor-view.component.mjs +59 -16
  15. package/esm2022/image-editor/lib/image-editor.service.mjs +1 -1
  16. package/esm2022/media-viewer/lib/media-viewer-container/media-viewer-container.component.mjs +7 -3
  17. package/esm2022/media-viewer/lib/media-viewer-slider/media-viewer-slider.component.mjs +2 -2
  18. package/esm2022/step-wizard/lib/step-wizard.component.mjs +20 -3
  19. package/esm2022/tabs/lib/tabs.component.mjs +2 -2
  20. package/fesm2022/acorex-components-action-sheet.mjs +2 -2
  21. package/fesm2022/acorex-components-action-sheet.mjs.map +1 -1
  22. package/fesm2022/acorex-components-color-palette.mjs +65 -38
  23. package/fesm2022/acorex-components-color-palette.mjs.map +1 -1
  24. package/fesm2022/acorex-components-data-pager.mjs +21 -18
  25. package/fesm2022/acorex-components-data-pager.mjs.map +1 -1
  26. package/fesm2022/acorex-components-data-table.mjs +1 -1
  27. package/fesm2022/acorex-components-data-table.mjs.map +1 -1
  28. package/fesm2022/acorex-components-image-editor.mjs +64 -22
  29. package/fesm2022/acorex-components-image-editor.mjs.map +1 -1
  30. package/fesm2022/acorex-components-media-viewer.mjs +8 -4
  31. package/fesm2022/acorex-components-media-viewer.mjs.map +1 -1
  32. package/fesm2022/acorex-components-step-wizard.mjs +18 -1
  33. package/fesm2022/acorex-components-step-wizard.mjs.map +1 -1
  34. package/fesm2022/acorex-components-tabs.mjs +1 -1
  35. package/fesm2022/acorex-components-tabs.mjs.map +1 -1
  36. package/image-editor/lib/image-editor-container/image-editor-container.component.d.ts +2 -0
  37. package/image-editor/lib/image-editor-view/image-editor-view.component.d.ts +16 -3
  38. package/image-editor/lib/image-editor.service.d.ts +2 -2
  39. package/package.json +1 -1
  40. package/step-wizard/lib/step-wizard.component.d.ts +2 -1
@@ -13,7 +13,12 @@ export declare class AXColorPaletteInputComponent extends MXBaseComponent implem
13
13
  _parent: AXColorPaletteParentComponent;
14
14
  private _unsubscriber;
15
15
  isValid: boolean;
16
- _rgba: any;
16
+ _rgba: {
17
+ r: number;
18
+ g: number;
19
+ b: number;
20
+ a: number;
21
+ };
17
22
  _hex: string;
18
23
  /**
19
24
  * @ignore
@@ -16,6 +16,8 @@ export declare class AXColorPalettePickerComponent extends MXBaseComponent {
16
16
  b: number;
17
17
  a: number;
18
18
  };
19
+ private circle;
20
+ private changingColor;
19
21
  /**
20
22
  * @ignore
21
23
  */
@@ -66,11 +68,9 @@ export declare class AXColorPalettePickerComponent extends MXBaseComponent {
66
68
  /**
67
69
  * @ignore
68
70
  */
69
- protected _handleSurfaceClick(e: MouseEvent): void;
70
71
  /**
71
72
  * @ignore
72
73
  */
73
- protected _handleDrag(): void;
74
74
  /**
75
75
  * @ignore
76
76
  */
@@ -86,6 +86,10 @@ export declare class AXColorPalettePickerComponent extends MXBaseComponent {
86
86
  * @ignore
87
87
  */
88
88
  private get __hostClass();
89
+ protected handleMove(event: MouseEvent): void;
90
+ protected handleDown(event: MouseEvent): void;
91
+ protected handleUp(): void;
92
+ private placePointer;
89
93
  static ɵfac: i0.ɵɵFactoryDeclaration<AXColorPalettePickerComponent, never>;
90
94
  static ɵcmp: i0.ɵɵComponentDeclaration<AXColorPalettePickerComponent, "ax-color-palette-picker", never, {}, {}, never, never, false, never>;
91
95
  }
@@ -10,7 +10,6 @@ export type AXDataPagerMode = 'full' | 'compact' | 'custom';
10
10
  */
11
11
  export declare class AXDataPagerComponent extends MXValueComponent<number> {
12
12
  private _parent;
13
- classes: import("@angular/core").InputSignal<string>;
14
13
  /**
15
14
  * @ignore
16
15
  */
@@ -148,5 +147,5 @@ export declare class AXDataPagerComponent extends MXValueComponent<number> {
148
147
  goToPage(page: number): void;
149
148
  get __hostClass(): string;
150
149
  static ɵfac: i0.ɵɵFactoryDeclaration<AXDataPagerComponent, [{ optional: true; }]>;
151
- static ɵcmp: i0.ɵɵComponentDeclaration<AXDataPagerComponent, "ax-data-pager", never, { "value": { "alias": "value"; "required": false; }; "name": { "alias": "name"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "readonly": { "alias": "readonly"; "required": false; }; "classes": { "alias": "class"; "required": false; "isSignal": true; }; "isLoading": { "alias": "isLoading"; "required": false; }; "size": { "alias": "size"; "required": false; }; "total": { "alias": "total"; "required": false; }; "displayMode": { "alias": "displayMode"; "required": false; }; }, { "valueChange": "valueChange"; "onValueChanged": "onValueChanged"; "disabledChange": "disabledChange"; "readonlyChange": "readonlyChange"; "displayModeChange": "displayModeChange"; "onChanged": "onChanged"; }, never, ["ax-prefix", "ax-suffix"], false, never>;
150
+ static ɵcmp: i0.ɵɵComponentDeclaration<AXDataPagerComponent, "ax-data-pager", never, { "value": { "alias": "value"; "required": false; }; "name": { "alias": "name"; "required": false; }; "disabled": { "alias": "disabled"; "required": false; }; "readonly": { "alias": "readonly"; "required": false; }; "isLoading": { "alias": "isLoading"; "required": false; }; "size": { "alias": "size"; "required": false; }; "total": { "alias": "total"; "required": false; }; "displayMode": { "alias": "displayMode"; "required": false; }; }, { "valueChange": "valueChange"; "onValueChanged": "onValueChanged"; "disabledChange": "disabledChange"; "readonlyChange": "readonlyChange"; "displayModeChange": "displayModeChange"; "onChanged": "onChanged"; }, never, ["ax-prefix", "ax-suffix"], false, never>;
152
151
  }
@@ -85,7 +85,7 @@ export class AXActionSheetComponent extends MXBaseComponent {
85
85
  provide: AXFocusableComponent,
86
86
  useExisting: AXActionSheetComponent,
87
87
  },
88
- ], usesInheritance: true, ngImport: i0, template: "@if (data.header) {\n <ax-header>\n <ax-prefix>\n <ax-title>{{ data.title | translate | async }}</ax-title>\n\n @if (data.subTitle) {\n <ax-sub-title>\n {{ data.subTitle }}\n </ax-sub-title>\n }\n </ax-prefix>\n @if (data.closeButton) {\n <ax-suffix>\n <ax-close-button></ax-close-button>\n </ax-suffix>\n }\n </ax-header>\n}\n\n@if (this.data.content) {\n <div class=\"ax-custom-template-container\">\n <ng-template [cdkPortalOutlet]=\"_selectedPortal\" (attached)=\"handleAttched($event)\"></ng-template>\n </div>\n}\n\n<div class=\"ax-action-list ax-action-list-vertical\">\n @for (item of data.items; let i = $index; track i) {\n @if (item.group?.title) {\n <ax-title>{{ item.group?.title }}</ax-title>\n }\n <div\n class=\"ax-action-item ax-el-interactive ax-el-{{ item.color }}-blank\"\n [class.ax-state-disabled]=\"item.disabled\"\n [tabindex]=\"i\"\n (click)=\"onItemClick(item)\"\n >\n <div class=\"ax-action-item-prefix\">\n @if (item.icon) {\n <span class=\"ax-item-icon\" [class]=\"item.icon\"></span>\n }\n <ax-text>{{ item.text | translate | async }}</ax-text>\n </div>\n <div class=\"ax-action-item-suffix\"></div>\n </div>\n @if (item.break) {\n <ax-divider></ax-divider>\n }\n }\n</div>\n", styles: ["ax-action-sheet{display:block;width:100vw}@media (min-width: 768px){ax-action-sheet{width:70vw}}@media (min-width: 1024px){ax-action-sheet{width:50vw}}ax-action-sheet .ax-custom-template-container{overflow-y:auto;max-height:80vh}ax-action-sheet ax-header{padding:1rem;border-bottom-width:1px;font-size:1rem;line-height:1.5rem;font-weight:500}@media (min-width: 768px){ax-action-sheet ax-header{font-size:1.125rem;line-height:1.75rem}}ax-action-sheet ax-header ax-prefix,ax-action-sheet ax-header ax-suffix{display:flex;flex-direction:column;justify-content:flex-start}ax-action-sheet ax-header ax-prefix{align-items:flex-start}ax-action-sheet ax-header ax-prefix ax-title{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1}ax-action-sheet ax-header ax-suffix{align-items:flex-end;max-width:fit-content}ax-action-sheet .ax-action-list{overflow-y:auto;max-height:80vh}ax-action-sheet .ax-action-list ax-title{font-size:.875rem}ax-action-sheet .ax-action-list .ax-action-item{min-height:3.5rem!important;font-size:1rem!important}ax-action-sheet .ax-action-list .ax-action-item .ax-item-icon{margin-inline-end:.75rem!important;font-size:1.5rem!important;line-height:2rem!important}\n"], dependencies: [{ kind: "directive", type: i2.CdkPortalOutlet, selector: "[cdkPortalOutlet]", inputs: ["cdkPortalOutlet"], outputs: ["attached"], exportAs: ["cdkPortalOutlet"] }, { kind: "component", type: i3.AXDecoratorCloseButtonComponent, selector: "ax-close-button", inputs: ["icon"] }, { kind: "component", type: i3.AXDecoratorGenericComponent, selector: "ax-footer, ax-header, ax-content, ax-divider, ax-form-hint, ax-prefix, ax-suffix, ax-text, ax-title, ax-sub-title, ax-placeholder, ax-overlay" }, { kind: "pipe", type: i4.AXTranslatorPipe, name: "translate" }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
88
+ ], usesInheritance: true, ngImport: i0, template: "@if (data.header) {\n <ax-header>\n <ax-prefix>\n <ax-title>{{ data.title | translate | async }}</ax-title>\n\n @if (data.subTitle) {\n <ax-sub-title>\n {{ data.subTitle }}\n </ax-sub-title>\n }\n </ax-prefix>\n @if (data.closeButton) {\n <ax-suffix>\n <ax-close-button></ax-close-button>\n </ax-suffix>\n }\n </ax-header>\n}\n\n@if (this.data.content) {\n <div class=\"ax-custom-template-container\">\n <ng-template [cdkPortalOutlet]=\"_selectedPortal\" (attached)=\"handleAttched($event)\"></ng-template>\n </div>\n}\n\n<div class=\"ax-action-list ax-action-list-vertical\">\n @for (item of data.items; let i = $index; track i) {\n @if (item.group?.title) {\n <ax-title>{{ item.group?.title }}</ax-title>\n }\n <div\n class=\"ax-action-item ax-el-interactive ax-el-{{ item.color }}-blank\"\n [class.ax-state-disabled]=\"item.disabled\"\n [tabindex]=\"i\"\n (click)=\"onItemClick(item)\"\n >\n <div class=\"ax-action-item-prefix\">\n @if (item.icon) {\n <span class=\"ax-item-icon\" [class]=\"item.icon\"></span>\n }\n <ax-text>{{ item.text | translate | async }}</ax-text>\n </div>\n <div class=\"ax-action-item-suffix\"></div>\n </div>\n @if (item.break) {\n <ax-divider></ax-divider>\n }\n }\n</div>\n", styles: ["ax-action-sheet{display:block;width:100vw}@media (min-width: 768px){ax-action-sheet{width:70vw}}@media (min-width: 1024px){ax-action-sheet{width:50vw}}ax-action-sheet .ax-custom-template-container{overflow-y:auto;max-height:100vh}ax-action-sheet ax-header{padding:1rem;border-bottom-width:1px;font-size:1rem;line-height:1.5rem;font-weight:500}@media (min-width: 768px){ax-action-sheet ax-header{font-size:1.125rem;line-height:1.75rem}}ax-action-sheet ax-header ax-prefix,ax-action-sheet ax-header ax-suffix{display:flex;flex-direction:column;justify-content:flex-start}ax-action-sheet ax-header ax-prefix{align-items:flex-start}ax-action-sheet ax-header ax-prefix ax-title{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1}ax-action-sheet ax-header ax-suffix{align-items:flex-end;max-width:fit-content}ax-action-sheet .ax-action-list{overflow-y:auto;max-height:100vh}ax-action-sheet .ax-action-list ax-title{font-size:.875rem}ax-action-sheet .ax-action-list .ax-action-item{min-height:3.5rem!important;font-size:1rem!important}ax-action-sheet .ax-action-list .ax-action-item .ax-item-icon{margin-inline-end:.75rem!important;font-size:1.5rem!important;line-height:2rem!important}\n"], dependencies: [{ kind: "directive", type: i2.CdkPortalOutlet, selector: "[cdkPortalOutlet]", inputs: ["cdkPortalOutlet"], outputs: ["attached"], exportAs: ["cdkPortalOutlet"] }, { kind: "component", type: i3.AXDecoratorCloseButtonComponent, selector: "ax-close-button", inputs: ["icon"] }, { kind: "component", type: i3.AXDecoratorGenericComponent, selector: "ax-footer, ax-header, ax-content, ax-divider, ax-form-hint, ax-prefix, ax-suffix, ax-text, ax-title, ax-sub-title, ax-placeholder, ax-overlay" }, { kind: "pipe", type: i4.AXTranslatorPipe, name: "translate" }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
89
89
  }
90
90
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXActionSheetComponent, decorators: [{
91
91
  type: Component,
@@ -98,7 +98,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
98
98
  provide: AXFocusableComponent,
99
99
  useExisting: AXActionSheetComponent,
100
100
  },
101
- ], template: "@if (data.header) {\n <ax-header>\n <ax-prefix>\n <ax-title>{{ data.title | translate | async }}</ax-title>\n\n @if (data.subTitle) {\n <ax-sub-title>\n {{ data.subTitle }}\n </ax-sub-title>\n }\n </ax-prefix>\n @if (data.closeButton) {\n <ax-suffix>\n <ax-close-button></ax-close-button>\n </ax-suffix>\n }\n </ax-header>\n}\n\n@if (this.data.content) {\n <div class=\"ax-custom-template-container\">\n <ng-template [cdkPortalOutlet]=\"_selectedPortal\" (attached)=\"handleAttched($event)\"></ng-template>\n </div>\n}\n\n<div class=\"ax-action-list ax-action-list-vertical\">\n @for (item of data.items; let i = $index; track i) {\n @if (item.group?.title) {\n <ax-title>{{ item.group?.title }}</ax-title>\n }\n <div\n class=\"ax-action-item ax-el-interactive ax-el-{{ item.color }}-blank\"\n [class.ax-state-disabled]=\"item.disabled\"\n [tabindex]=\"i\"\n (click)=\"onItemClick(item)\"\n >\n <div class=\"ax-action-item-prefix\">\n @if (item.icon) {\n <span class=\"ax-item-icon\" [class]=\"item.icon\"></span>\n }\n <ax-text>{{ item.text | translate | async }}</ax-text>\n </div>\n <div class=\"ax-action-item-suffix\"></div>\n </div>\n @if (item.break) {\n <ax-divider></ax-divider>\n }\n }\n</div>\n", styles: ["ax-action-sheet{display:block;width:100vw}@media (min-width: 768px){ax-action-sheet{width:70vw}}@media (min-width: 1024px){ax-action-sheet{width:50vw}}ax-action-sheet .ax-custom-template-container{overflow-y:auto;max-height:80vh}ax-action-sheet ax-header{padding:1rem;border-bottom-width:1px;font-size:1rem;line-height:1.5rem;font-weight:500}@media (min-width: 768px){ax-action-sheet ax-header{font-size:1.125rem;line-height:1.75rem}}ax-action-sheet ax-header ax-prefix,ax-action-sheet ax-header ax-suffix{display:flex;flex-direction:column;justify-content:flex-start}ax-action-sheet ax-header ax-prefix{align-items:flex-start}ax-action-sheet ax-header ax-prefix ax-title{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1}ax-action-sheet ax-header ax-suffix{align-items:flex-end;max-width:fit-content}ax-action-sheet .ax-action-list{overflow-y:auto;max-height:80vh}ax-action-sheet .ax-action-list ax-title{font-size:.875rem}ax-action-sheet .ax-action-list .ax-action-item{min-height:3.5rem!important;font-size:1rem!important}ax-action-sheet .ax-action-list .ax-action-item .ax-item-icon{margin-inline-end:.75rem!important;font-size:1.5rem!important;line-height:2rem!important}\n"] }]
101
+ ], template: "@if (data.header) {\n <ax-header>\n <ax-prefix>\n <ax-title>{{ data.title | translate | async }}</ax-title>\n\n @if (data.subTitle) {\n <ax-sub-title>\n {{ data.subTitle }}\n </ax-sub-title>\n }\n </ax-prefix>\n @if (data.closeButton) {\n <ax-suffix>\n <ax-close-button></ax-close-button>\n </ax-suffix>\n }\n </ax-header>\n}\n\n@if (this.data.content) {\n <div class=\"ax-custom-template-container\">\n <ng-template [cdkPortalOutlet]=\"_selectedPortal\" (attached)=\"handleAttched($event)\"></ng-template>\n </div>\n}\n\n<div class=\"ax-action-list ax-action-list-vertical\">\n @for (item of data.items; let i = $index; track i) {\n @if (item.group?.title) {\n <ax-title>{{ item.group?.title }}</ax-title>\n }\n <div\n class=\"ax-action-item ax-el-interactive ax-el-{{ item.color }}-blank\"\n [class.ax-state-disabled]=\"item.disabled\"\n [tabindex]=\"i\"\n (click)=\"onItemClick(item)\"\n >\n <div class=\"ax-action-item-prefix\">\n @if (item.icon) {\n <span class=\"ax-item-icon\" [class]=\"item.icon\"></span>\n }\n <ax-text>{{ item.text | translate | async }}</ax-text>\n </div>\n <div class=\"ax-action-item-suffix\"></div>\n </div>\n @if (item.break) {\n <ax-divider></ax-divider>\n }\n }\n</div>\n", styles: ["ax-action-sheet{display:block;width:100vw}@media (min-width: 768px){ax-action-sheet{width:70vw}}@media (min-width: 1024px){ax-action-sheet{width:50vw}}ax-action-sheet .ax-custom-template-container{overflow-y:auto;max-height:100vh}ax-action-sheet ax-header{padding:1rem;border-bottom-width:1px;font-size:1rem;line-height:1.5rem;font-weight:500}@media (min-width: 768px){ax-action-sheet ax-header{font-size:1.125rem;line-height:1.75rem}}ax-action-sheet ax-header ax-prefix,ax-action-sheet ax-header ax-suffix{display:flex;flex-direction:column;justify-content:flex-start}ax-action-sheet ax-header ax-prefix{align-items:flex-start}ax-action-sheet ax-header ax-prefix ax-title{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:1}ax-action-sheet ax-header ax-suffix{align-items:flex-end;max-width:fit-content}ax-action-sheet .ax-action-list{overflow-y:auto;max-height:100vh}ax-action-sheet .ax-action-list ax-title{font-size:.875rem}ax-action-sheet .ax-action-list .ax-action-item{min-height:3.5rem!important;font-size:1rem!important}ax-action-sheet .ax-action-list .ax-action-item .ax-item-icon{margin-inline-end:.75rem!important;font-size:1.5rem!important;line-height:2rem!important}\n"] }]
102
102
  }], ctorParameters: () => [{ type: undefined, decorators: [{
103
103
  type: Inject,
104
104
  args: [DIALOG_DATA]
@@ -94,6 +94,7 @@ export class AXColorPaletteInputComponent extends MXBaseComponent {
94
94
  break;
95
95
  default:
96
96
  this._colorMode = 'rgba';
97
+ this.applyParent(true);
97
98
  break;
98
99
  }
99
100
  }
@@ -153,4 +154,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
153
154
  type: HostBinding,
154
155
  args: ['class']
155
156
  }] } });
156
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-palette-input.component.js","sourceRoot":"","sources":["../../../../../../libs/components/color-palette/src/lib/color-palette-input.component.ts","../../../../../../libs/components/color-palette/src/lib/color-palette-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXValueChangedEvent, MXBaseComponent } from '@acorex/components/common';\nimport { AXMaskOptions } from '@acorex/components/text-box';\nimport { AXColorUtil, AXUnsubscriber } from '@acorex/core/utils';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  HostBinding,\n  Inject,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { AXColorPaletteChildComponent, AXColorPaletteParentComponent } from './color-palette.class';\n\n/**\n * Component for selecting colors from a palette.\n *\n * @category Components\n */\n@Component({\n  selector: 'ax-color-palette-input',\n  templateUrl: './color-palette-input.component.html',\n  styles: `\n    .ax-bold {\n      font-weight: bold;\n    }\n  `,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: AXColorPaletteChildComponent,\n      useExisting: AXColorPaletteInputComponent,\n    },\n    AXUnsubscriber,\n  ],\n})\nexport class AXColorPaletteInputComponent extends MXBaseComponent implements AfterViewInit {\n  isValid = true;\n\n  _rgba: any = {\n    r: 0,\n    g: 0,\n    b: 0,\n    a: 0,\n  };\n\n  _hex = '';\n\n  /**\n   *  @ignore\n   */\n  protected _colorMode: 'hex' | 'rgba' = 'hex';\n\n  /**\n   *  @ignore\n   */\n  protected _hexMaskOptions: AXMaskOptions = {\n    mask: /^#[0-9a-f]{0,6}[0-9a-f]{0,2}$/i,\n    prepare: (str, m, a) => {\n      return m.typedValue?.startsWith('#') || str == '#' ? str.trim() : '#' + str.trim();\n    },\n  };\n\n  /**\n   *  @ignore\n   */\n  constructor(\n    @Inject(AXColorPaletteParentComponent)\n    public _parent: AXColorPaletteParentComponent,\n    private _unsubscriber: AXUnsubscriber,\n  ) {\n    super();\n    _parent.onValueChanged.pipe(_unsubscriber.takeUntilDestroy).subscribe((e) => {\n      this.applyParent(e.isUserInteraction);\n    });\n    _parent.onOptionChanged.pipe(_unsubscriber.takeUntilDestroy).subscribe((e) => {\n      this.cdr.markForCheck();\n    });\n  }\n\n  /**\n   *  @ignore\n   */\n  private applyParent(u: boolean = false) {\n    const value = this._parent.value;\n    if (!value) {\n      this._hex = '';\n      this._rgba = {\n        r: null,\n        g: null,\n        b: null,\n        a: null,\n      };\n    } else {\n      if (this._colorMode == 'rgba') {\n        Object.assign(this._rgba, AXColorUtil.to(value, 'rgba'));\n      }\n      if (this._colorMode == 'hex') {\n        this._hex = AXColorUtil.toString(value, 'hex');\n      }\n      if (!u && this._rgba.a != 1) {\n        this._colorMode = 'rgba';\n      }\n    }\n    this.checkValid();\n    this.cdr.detectChanges();\n  }\n\n  /**\n   *  @ignore\n   */\n  ngAfterViewInit() {\n    this.applyParent();\n  }\n\n  /**\n   *  @ignore\n   */\n  _handleChangeInputMode() {\n    switch (this._colorMode) {\n      case 'rgba':\n        this._colorMode = 'hex';\n        this.applyParent(true);\n        break;\n      default:\n        this._colorMode = 'rgba';\n        break;\n    }\n  }\n\n  /**\n   *  @ignore\n   */\n  _handleRGBAValueChanged(e: AXValueChangedEvent<number>) {\n    if (e.isUserInteraction) {\n      this._rgba[e.name] = e.value;\n      const { r, g, b, a } = this._rgba;\n      const _color = `rgba(${r},${g},${b},${a})`;\n      this._parent.commitValue(AXColorUtil.toString(_color, 'rgba'), e.isUserInteraction);\n    }\n  }\n\n  /**\n   *  @ignore\n   */\n  protected _handleHEXAValueChanged(e: AXValueChangedEvent<string>) {\n    if (e.isUserInteraction && e.value?.trim() != this._hex?.trim()) {\n      this._parent.commitValue(e.value, e.isUserInteraction);\n    }\n  }\n\n  /**\n   *  @ignore\n   */\n  private checkValid() {\n    this.isValid = AXColorUtil.isValid(this._hex);\n  }\n\n  /**\n   *  @ignore\n   */\n  @HostBinding('class')\n  private get __hostClass(): string {\n    return `ax-color-palette-input`;\n  }\n}\n","<div class=\"palette-inputs\">\n  @switch (_colorMode) {\n    @case ('hex') {\n      <div>\n        <ax-text-box\n          class=\"ax-sm\"\n          [ngModel]=\"_hex\"\n          [disabled]=\"_parent.disabled\"\n          [readonly]=\"_parent.readonly\"\n          [state]=\"isValid ? 'clear' : 'error'\"\n          (onValueChanged)=\"_handleHEXAValueChanged($event)\"\n          [mask-options]=\"_hexMaskOptions\"\n        >\n        </ax-text-box>\n        <label>HEX</label>\n      </div>\n    }\n    @case ('rgba') {\n      <div>\n        <ax-number-box\n          class=\"ax-sm\"\n          name=\"r\"\n          [minValue]=\"0\"\n          [maxValue]=\"255\"\n          [ngModel]=\"_rgba.r\"\n          [showSpinButtons]=\"false\"\n          [disabled]=\"_parent.disabled\"\n          [readonly]=\"_parent.readonly\"\n          (onValueChanged)=\"_handleRGBAValueChanged($event)\"\n        >\n        </ax-number-box>\n        <label>R</label>\n      </div>\n      <div>\n        <ax-number-box\n          class=\"ax-sm\"\n          name=\"g\"\n          [minValue]=\"0\"\n          [maxValue]=\"255\"\n          [ngModel]=\"_rgba.g\"\n          [showSpinButtons]=\"false\"\n          [disabled]=\"_parent.disabled\"\n          [readonly]=\"_parent.readonly\"\n          (onValueChanged)=\"_handleRGBAValueChanged($event)\"\n        >\n        </ax-number-box>\n        <label>G</label>\n      </div>\n      <div>\n        <ax-number-box\n          class=\"ax-sm\"\n          name=\"b\"\n          [minValue]=\"0\"\n          [maxValue]=\"255\"\n          [ngModel]=\"_rgba.b\"\n          [showSpinButtons]=\"false\"\n          [disabled]=\"_parent.disabled\"\n          [readonly]=\"_parent.readonly\"\n          (onValueChanged)=\"_handleRGBAValueChanged($event)\"\n        >\n        </ax-number-box>\n        <label>B</label>\n      </div>\n      <div>\n        <ax-number-box\n          class=\"ax-sm\"\n          name=\"a\"\n          [minValue]=\"0\"\n          [maxValue]=\"1\"\n          [ngModel]=\"_rgba.a\"\n          [decimals]=\"2\"\n          [step]=\"0.1\"\n          [disabled]=\"_parent.disabled\"\n          [readonly]=\"_parent.readonly\"\n          [showSpinButtons]=\"false\"\n          (onValueChanged)=\"_handleRGBAValueChanged($event)\"\n        >\n        </ax-number-box>\n        <label>A</label>\n      </div>\n    }\n  }\n</div>\n<button\n  type=\"button\"\n  class=\"ax-general-button ax-button-rounded ax-button-icon ax-sm\"\n  (click)=\"_handleChangeInputMode()\"\n  [disabled]=\"_parent.disabled\"\n>\n  <span class=\"ax-icon ax-icon-unfold-more ax-bold\"></span>\n</button>\n"]}
157
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-palette-input.component.js","sourceRoot":"","sources":["../../../../../../libs/components/color-palette/src/lib/color-palette-input.component.ts","../../../../../../libs/components/color-palette/src/lib/color-palette-input.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXValueChangedEvent, MXBaseComponent } from '@acorex/components/common';\nimport { AXMaskOptions } from '@acorex/components/text-box';\nimport { AXColorUtil, AXUnsubscriber } from '@acorex/core/utils';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  HostBinding,\n  Inject,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { AXColorPaletteChildComponent, AXColorPaletteParentComponent } from './color-palette.class';\n\n/**\n * Component for selecting colors from a palette.\n *\n * @category Components\n */\n@Component({\n  selector: 'ax-color-palette-input',\n  templateUrl: './color-palette-input.component.html',\n  styles: `\n    .ax-bold {\n      font-weight: bold;\n    }\n  `,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: AXColorPaletteChildComponent,\n      useExisting: AXColorPaletteInputComponent,\n    },\n    AXUnsubscriber,\n  ],\n})\nexport class AXColorPaletteInputComponent extends MXBaseComponent implements AfterViewInit {\n  isValid = true;\n\n  _rgba: { r: number; g: number; b: number; a: number } = {\n    r: 0,\n    g: 0,\n    b: 0,\n    a: 0,\n  };\n\n  _hex = '';\n\n  /**\n   *  @ignore\n   */\n  protected _colorMode: 'hex' | 'rgba' = 'hex';\n\n  /**\n   *  @ignore\n   */\n  protected _hexMaskOptions: AXMaskOptions = {\n    mask: /^#[0-9a-f]{0,6}[0-9a-f]{0,2}$/i,\n    prepare: (str: any, m: any, a: any) => {\n      return m.typedValue?.startsWith('#') || str == '#' ? str.trim() : '#' + str.trim();\n    },\n  };\n\n  /**\n   *  @ignore\n   */\n  constructor(\n    @Inject(AXColorPaletteParentComponent)\n    public _parent: AXColorPaletteParentComponent,\n    private _unsubscriber: AXUnsubscriber,\n  ) {\n    super();\n    _parent.onValueChanged.pipe(_unsubscriber.takeUntilDestroy).subscribe((e) => {\n      this.applyParent(e.isUserInteraction);\n    });\n    _parent.onOptionChanged.pipe(_unsubscriber.takeUntilDestroy).subscribe((e) => {\n      this.cdr.markForCheck();\n    });\n  }\n\n  /**\n   *  @ignore\n   */\n  private applyParent(u = false) {\n    const value = this._parent.value;\n    if (!value) {\n      this._hex = '';\n      this._rgba = {\n        r: null,\n        g: null,\n        b: null,\n        a: null,\n      };\n    } else {\n      if (this._colorMode == 'rgba') {\n        Object.assign(this._rgba, AXColorUtil.to(value, 'rgba'));\n      }\n      if (this._colorMode == 'hex') {\n        this._hex = AXColorUtil.toString(value, 'hex');\n      }\n      if (!u && this._rgba.a != 1) {\n        this._colorMode = 'rgba';\n      }\n    }\n    this.checkValid();\n    this.cdr.detectChanges();\n  }\n\n  /**\n   *  @ignore\n   */\n  ngAfterViewInit() {\n    this.applyParent();\n  }\n\n  /**\n   *  @ignore\n   */\n  _handleChangeInputMode() {\n    switch (this._colorMode) {\n      case 'rgba':\n        this._colorMode = 'hex';\n        this.applyParent(true);\n        break;\n      default:\n        this._colorMode = 'rgba';\n        this.applyParent(true);\n        break;\n    }\n  }\n\n  /**\n   *  @ignore\n   */\n  _handleRGBAValueChanged(e: AXValueChangedEvent<number>) {\n    if (e.isUserInteraction) {\n      this._rgba[e.name] = e.value;\n      const { r, g, b, a } = this._rgba;\n      const _color = `rgba(${r},${g},${b},${a})`;\n      this._parent.commitValue(AXColorUtil.toString(_color, 'rgba'), e.isUserInteraction);\n    }\n  }\n\n  /**\n   *  @ignore\n   */\n  protected _handleHEXAValueChanged(e: AXValueChangedEvent<string>) {\n    if (e.isUserInteraction && e.value?.trim() != this._hex?.trim()) {\n      this._parent.commitValue(e.value, e.isUserInteraction);\n    }\n  }\n\n  /**\n   *  @ignore\n   */\n  private checkValid() {\n    this.isValid = AXColorUtil.isValid(this._hex);\n  }\n\n  /**\n   *  @ignore\n   */\n  @HostBinding('class')\n  private get __hostClass(): string {\n    return `ax-color-palette-input`;\n  }\n}\n","<div class=\"palette-inputs\">\n  @switch (_colorMode) {\n    @case ('hex') {\n      <div>\n        <ax-text-box\n          class=\"ax-sm\"\n          [ngModel]=\"_hex\"\n          [disabled]=\"_parent.disabled\"\n          [readonly]=\"_parent.readonly\"\n          [state]=\"isValid ? 'clear' : 'error'\"\n          (onValueChanged)=\"_handleHEXAValueChanged($event)\"\n          [mask-options]=\"_hexMaskOptions\"\n        >\n        </ax-text-box>\n        <label>HEX</label>\n      </div>\n    }\n    @case ('rgba') {\n      <div>\n        <ax-number-box\n          class=\"ax-sm\"\n          name=\"r\"\n          [minValue]=\"0\"\n          [maxValue]=\"255\"\n          [ngModel]=\"_rgba.r\"\n          [showSpinButtons]=\"false\"\n          [disabled]=\"_parent.disabled\"\n          [readonly]=\"_parent.readonly\"\n          (onValueChanged)=\"_handleRGBAValueChanged($event)\"\n        >\n        </ax-number-box>\n        <label>R</label>\n      </div>\n      <div>\n        <ax-number-box\n          class=\"ax-sm\"\n          name=\"g\"\n          [minValue]=\"0\"\n          [maxValue]=\"255\"\n          [ngModel]=\"_rgba.g\"\n          [showSpinButtons]=\"false\"\n          [disabled]=\"_parent.disabled\"\n          [readonly]=\"_parent.readonly\"\n          (onValueChanged)=\"_handleRGBAValueChanged($event)\"\n        >\n        </ax-number-box>\n        <label>G</label>\n      </div>\n      <div>\n        <ax-number-box\n          class=\"ax-sm\"\n          name=\"b\"\n          [minValue]=\"0\"\n          [maxValue]=\"255\"\n          [ngModel]=\"_rgba.b\"\n          [showSpinButtons]=\"false\"\n          [disabled]=\"_parent.disabled\"\n          [readonly]=\"_parent.readonly\"\n          (onValueChanged)=\"_handleRGBAValueChanged($event)\"\n        >\n        </ax-number-box>\n        <label>B</label>\n      </div>\n      <div>\n        <ax-number-box\n          class=\"ax-sm\"\n          name=\"a\"\n          [minValue]=\"0\"\n          [maxValue]=\"1\"\n          [ngModel]=\"_rgba.a\"\n          [decimals]=\"2\"\n          [step]=\"0.1\"\n          [disabled]=\"_parent.disabled\"\n          [readonly]=\"_parent.readonly\"\n          [showSpinButtons]=\"false\"\n          (onValueChanged)=\"_handleRGBAValueChanged($event)\"\n        >\n        </ax-number-box>\n        <label>A</label>\n      </div>\n    }\n  }\n</div>\n<button\n  type=\"button\"\n  class=\"ax-general-button ax-button-rounded ax-button-icon ax-sm\"\n  (click)=\"_handleChangeInputMode()\"\n  [disabled]=\"_parent.disabled\"\n>\n  <span class=\"ax-icon ax-icon-unfold-more ax-bold\"></span>\n</button>\n"]}
@@ -1,14 +1,13 @@
1
1
  import { MXBaseComponent } from '@acorex/components/common';
2
2
  import { isBrowser } from '@acorex/core/platform';
3
3
  import { AXColorUtil, AXUnsubscriber } from '@acorex/core/utils';
4
- import { ChangeDetectionStrategy, Component, HostBinding, Inject, ViewEncapsulation } from '@angular/core';
4
+ import { ChangeDetectionStrategy, Component, HostBinding, Inject, signal, viewChild, ViewEncapsulation, } from '@angular/core';
5
5
  import { AXColorPaletteChildComponent, AXColorPaletteParentComponent } from './color-palette.class';
6
6
  import * as i0 from "@angular/core";
7
7
  import * as i1 from "@acorex/core/utils";
8
8
  import * as i2 from "@angular/forms";
9
9
  import * as i3 from "@acorex/components/range-slider";
10
- import * as i4 from "@angular/cdk/drag-drop";
11
- import * as i5 from "./color-palette.class";
10
+ import * as i4 from "./color-palette.class";
12
11
  /**
13
12
  * Component for picking colors from a color palette.
14
13
  *
@@ -28,6 +27,8 @@ export class AXColorPalettePickerComponent extends MXBaseComponent {
28
27
  b: 0,
29
28
  a: 0,
30
29
  };
30
+ this.circle = viewChild('circle');
31
+ this.changingColor = signal(false);
31
32
  /**
32
33
  * @ignore
33
34
  */
@@ -123,41 +124,41 @@ export class AXColorPalettePickerComponent extends MXBaseComponent {
123
124
  /**
124
125
  * @ignore
125
126
  */
126
- _handleSurfaceClick(e) {
127
- if (this._parent.disabled || this._parent.readonly) {
128
- e.preventDefault();
129
- e.stopPropagation();
130
- return;
131
- }
132
- const surface = this.getHostElement().querySelector('.ax-color-box-overlay');
133
- const pointer = this.getHostElement().querySelector('.ax-color-box-pointer');
134
- let x = e.offsetX;
135
- let y = e.offsetY;
136
- this.setColorByXY(x, y);
137
- }
127
+ // protected _handleSurfaceClick(e: MouseEvent) {
128
+ // if (this._parent.disabled || this._parent.readonly) {
129
+ // e.preventDefault();
130
+ // e.stopPropagation();
131
+ // return;
132
+ // }
133
+ // const surface = this.getHostElement().querySelector<HTMLDivElement>('.ax-color-box-overlay');
134
+ // const pointer = this.getHostElement().querySelector<HTMLDivElement>('.ax-color-box-pointer');
135
+ // const x = e.offsetX;
136
+ // const y = e.offsetY;
137
+ // this.setColorByXY(x, y);
138
+ // }
138
139
  /**
139
140
  * @ignore
140
141
  */
141
- _handleDrag() {
142
- if (this._parent.disabled || this._parent.readonly) {
143
- return;
144
- }
145
- const surface = this.getHostElement().querySelector('.ax-color-box-overlay');
146
- const sb = surface.getBoundingClientRect();
147
- const pointer = this.getHostElement().querySelector('.ax-color-box-pointer');
148
- const pb = pointer.getBoundingClientRect();
149
- const w = pb.width / 2;
150
- let x = pb.left - sb.left + w;
151
- let y = pb.top - sb.top + w;
152
- //
153
- x = x < 0 ? 0 : x;
154
- x = x > sb.width ? sb.width : x;
155
- //
156
- y = y < 0 ? 0 : y;
157
- y = y > sb.height ? sb.height : y;
158
- //
159
- this.setColorByXY(x, y);
160
- }
142
+ // protected _handleDrag() {
143
+ // if (this._parent.disabled || this._parent.readonly) {
144
+ // return;
145
+ // }
146
+ // const surface = this.getHostElement().querySelector<HTMLDivElement>('.ax-color-box-overlay');
147
+ // const sb = surface.getBoundingClientRect();
148
+ // const pointer = this.getHostElement().querySelector<HTMLDivElement>('.ax-color-box-pointer');
149
+ // const pb = pointer.getBoundingClientRect();
150
+ // const w = pb.width / 2;
151
+ // let x = pb.left - sb.left + w;
152
+ // let y = pb.top - sb.top + w;
153
+ // //
154
+ // x = x < 0 ? 0 : x;
155
+ // x = x > sb.width ? sb.width : x;
156
+ // //
157
+ // y = y < 0 ? 0 : y;
158
+ // y = y > sb.height ? sb.height : y;
159
+ // //
160
+ // this.setColorByXY(x, y);
161
+ // }
161
162
  /**
162
163
  * @ignore
163
164
  */
@@ -223,14 +224,39 @@ export class AXColorPalettePickerComponent extends MXBaseComponent {
223
224
  get __hostClass() {
224
225
  return `ax-color-palette-picker`;
225
226
  }
227
+ handleMove(event) {
228
+ if (!this.changingColor())
229
+ return;
230
+ this.placePointer(event);
231
+ }
232
+ handleDown(event) {
233
+ if (this._parent.disabled || this._parent.readonly)
234
+ return;
235
+ this.placePointer(event);
236
+ this.changingColor.set(true);
237
+ }
238
+ handleUp() {
239
+ this.changingColor.set(false);
240
+ }
241
+ placePointer(event) {
242
+ const circleElement = this.circle().nativeElement;
243
+ const parentStats = circleElement.parentElement.getBoundingClientRect();
244
+ const circleHeight = circleElement.offsetHeight / 2;
245
+ const circleWidth = circleElement.offsetWidth / 2;
246
+ const top = event.clientY - parentStats.top - circleHeight;
247
+ const left = event.clientX - parentStats.left - circleWidth;
248
+ circleElement.style.top = `${Math.max(0 - circleHeight, Math.min(top, parentStats.height - circleHeight))}px`;
249
+ circleElement.style.left = `${Math.max(0 - circleWidth, Math.min(left, parentStats.width - circleWidth))}px`;
250
+ this.setColorByXY(event.clientX - parentStats.left, event.clientY - parentStats.top);
251
+ }
226
252
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXColorPalettePickerComponent, deps: [{ token: AXColorPaletteParentComponent }, { token: i1.AXUnsubscriber }], target: i0.ɵɵFactoryTarget.Component }); }
227
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.0", type: AXColorPalettePickerComponent, selector: "ax-color-palette-picker", host: { properties: { "class": "this.__hostClass" } }, providers: [
253
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.2.0", version: "18.2.0", type: AXColorPalettePickerComponent, selector: "ax-color-palette-picker", host: { properties: { "class": "this.__hostClass" } }, providers: [
228
254
  {
229
255
  provide: AXColorPaletteChildComponent,
230
256
  useExisting: AXColorPalettePickerComponent,
231
257
  },
232
258
  AXUnsubscriber,
233
- ], usesInheritance: true, ngImport: i0, template: "<div class=\"ax-color-box-overlay-trans\">\n <div class=\"ax-color-box-overlay\" [style.background-color]=\"_bgColor\">\n <div class=\"ax-color-box-overlay-g1\"></div>\n <div class=\"ax-color-box-overlay-g2\" (click)=\"_handleSurfaceClick($event)\"></div>\n <div\n class=\"ax-color-box-pointer\"\n cdkDrag\n cdkDragBoundary=\".ax-color-box-overlay\"\n [cdkDragFreeDragPosition]=\"dragPosition\"\n (cdkDragEnded)=\"_handleDrag()\"\n [cdkDragDisabled]=\"_parent.disabled || _parent.readonly\"\n ></div>\n </div>\n</div>\n\n<ax-range-slider\n class=\"ax-color-box-gradient\"\n [min]=\"0\"\n [max]=\"100\"\n [mode]=\"'single'\"\n [ngModel]=\"_gradient\"\n [disabled]=\"_parent.disabled\"\n [readonly]=\"_parent.readonly\"\n (ngModelChange)=\"_handleGradientChanged($event)\"\n>\n</ax-range-slider>\n<ax-range-slider\n class=\"ax-color-box-transparent\"\n [min]=\"0\"\n [max]=\"1\"\n [hasStep]=\"false\"\n [ngModel]=\"_rgba.a\"\n [disabled]=\"_parent.disabled\"\n [readonly]=\"_parent.readonly\"\n (ngModelChange)=\"_handleAlphaChanged($event)\"\n>\n</ax-range-slider>\n", dependencies: [{ kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.AXRangeSliderComponent, selector: "ax-range-slider", inputs: ["disabled", "readonly", "orientation", "color", "values", "mode", "min", "max", "step", "snap", "tooltipMode", "snapMode", "hasStep", "hasSnap", "hasLable", "hasTooltip"], outputs: ["valuesChange"] }, { kind: "directive", type: i4.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer", "cdkDragScale"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
259
+ ], viewQueries: [{ propertyName: "circle", first: true, predicate: ["circle"], descendants: true, isSignal: true }], usesInheritance: true, ngImport: i0, template: "<div class=\"ax-color-box-overlay-trans\">\n <div\n class=\"ax-color-box-overlay\"\n [style.background-color]=\"_bgColor\"\n (mousemove)=\"handleMove($event)\"\n (mousedown)=\"handleDown($event)\"\n (mouseup)=\"handleUp()\"\n (mouseleave)=\"handleUp()\"\n >\n <div class=\"ax-color-box-overlay-g1\"></div>\n <div class=\"ax-color-box-overlay-g2\"></div>\n <div #circle class=\"ax-color-box-pointer\"></div>\n </div>\n</div>\n\n<ax-range-slider\n class=\"ax-color-box-gradient\"\n [min]=\"0\"\n [max]=\"100\"\n [mode]=\"'single'\"\n [ngModel]=\"_gradient\"\n [disabled]=\"_parent.disabled\"\n [readonly]=\"_parent.readonly\"\n (ngModelChange)=\"_handleGradientChanged($event)\"\n>\n</ax-range-slider>\n<ax-range-slider\n class=\"ax-color-box-transparent\"\n [min]=\"0\"\n [max]=\"1\"\n [hasStep]=\"false\"\n [ngModel]=\"_rgba.a\"\n [disabled]=\"_parent.disabled\"\n [readonly]=\"_parent.readonly\"\n (ngModelChange)=\"_handleAlphaChanged($event)\"\n>\n</ax-range-slider>\n", dependencies: [{ kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.AXRangeSliderComponent, selector: "ax-range-slider", inputs: ["disabled", "readonly", "orientation", "color", "values", "mode", "min", "max", "step", "snap", "tooltipMode", "snapMode", "hasStep", "hasSnap", "hasLable", "hasTooltip"], outputs: ["valuesChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
234
260
  }
235
261
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXColorPalettePickerComponent, decorators: [{
236
262
  type: Component,
@@ -240,12 +266,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
240
266
  useExisting: AXColorPalettePickerComponent,
241
267
  },
242
268
  AXUnsubscriber,
243
- ], template: "<div class=\"ax-color-box-overlay-trans\">\n <div class=\"ax-color-box-overlay\" [style.background-color]=\"_bgColor\">\n <div class=\"ax-color-box-overlay-g1\"></div>\n <div class=\"ax-color-box-overlay-g2\" (click)=\"_handleSurfaceClick($event)\"></div>\n <div\n class=\"ax-color-box-pointer\"\n cdkDrag\n cdkDragBoundary=\".ax-color-box-overlay\"\n [cdkDragFreeDragPosition]=\"dragPosition\"\n (cdkDragEnded)=\"_handleDrag()\"\n [cdkDragDisabled]=\"_parent.disabled || _parent.readonly\"\n ></div>\n </div>\n</div>\n\n<ax-range-slider\n class=\"ax-color-box-gradient\"\n [min]=\"0\"\n [max]=\"100\"\n [mode]=\"'single'\"\n [ngModel]=\"_gradient\"\n [disabled]=\"_parent.disabled\"\n [readonly]=\"_parent.readonly\"\n (ngModelChange)=\"_handleGradientChanged($event)\"\n>\n</ax-range-slider>\n<ax-range-slider\n class=\"ax-color-box-transparent\"\n [min]=\"0\"\n [max]=\"1\"\n [hasStep]=\"false\"\n [ngModel]=\"_rgba.a\"\n [disabled]=\"_parent.disabled\"\n [readonly]=\"_parent.readonly\"\n (ngModelChange)=\"_handleAlphaChanged($event)\"\n>\n</ax-range-slider>\n" }]
244
- }], ctorParameters: () => [{ type: i5.AXColorPaletteParentComponent, decorators: [{
269
+ ], template: "<div class=\"ax-color-box-overlay-trans\">\n <div\n class=\"ax-color-box-overlay\"\n [style.background-color]=\"_bgColor\"\n (mousemove)=\"handleMove($event)\"\n (mousedown)=\"handleDown($event)\"\n (mouseup)=\"handleUp()\"\n (mouseleave)=\"handleUp()\"\n >\n <div class=\"ax-color-box-overlay-g1\"></div>\n <div class=\"ax-color-box-overlay-g2\"></div>\n <div #circle class=\"ax-color-box-pointer\"></div>\n </div>\n</div>\n\n<ax-range-slider\n class=\"ax-color-box-gradient\"\n [min]=\"0\"\n [max]=\"100\"\n [mode]=\"'single'\"\n [ngModel]=\"_gradient\"\n [disabled]=\"_parent.disabled\"\n [readonly]=\"_parent.readonly\"\n (ngModelChange)=\"_handleGradientChanged($event)\"\n>\n</ax-range-slider>\n<ax-range-slider\n class=\"ax-color-box-transparent\"\n [min]=\"0\"\n [max]=\"1\"\n [hasStep]=\"false\"\n [ngModel]=\"_rgba.a\"\n [disabled]=\"_parent.disabled\"\n [readonly]=\"_parent.readonly\"\n (ngModelChange)=\"_handleAlphaChanged($event)\"\n>\n</ax-range-slider>\n" }]
270
+ }], ctorParameters: () => [{ type: i4.AXColorPaletteParentComponent, decorators: [{
245
271
  type: Inject,
246
272
  args: [AXColorPaletteParentComponent]
247
273
  }] }, { type: i1.AXUnsubscriber }], propDecorators: { __hostClass: [{
248
274
  type: HostBinding,
249
275
  args: ['class']
250
276
  }] } });
251
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-palette-picker.component.js","sourceRoot":"","sources":["../../../../../../libs/components/color-palette/src/lib/color-palette-picker.component.ts","../../../../../../libs/components/color-palette/src/lib/color-palette-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { MXBaseComponent } from '@acorex/components/common';\nimport { isBrowser } from '@acorex/core/platform';\nimport { AXColorUtil, AXUnsubscriber } from '@acorex/core/utils';\nimport { ChangeDetectionStrategy, Component, HostBinding, Inject, ViewEncapsulation } from '@angular/core';\nimport { AXColorPaletteChildComponent, AXColorPaletteParentComponent } from './color-palette.class';\n\n/**\n * Component for picking colors from a color palette.\n *\n * @category Components\n */\n@Component({\n  selector: 'ax-color-palette-picker',\n  templateUrl: './color-palette-picker.component.html',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: AXColorPaletteChildComponent,\n      useExisting: AXColorPalettePickerComponent,\n    },\n    AXUnsubscriber,\n  ],\n})\nexport class AXColorPalettePickerComponent extends MXBaseComponent {\n  _rgba: { r: number; g: number; b: number; a: number } = {\n    r: 0,\n    g: 0,\n    b: 0,\n    a: 0,\n  };\n\n  /**\n   *  @ignore\n   */\n  protected _gradient: number = 0;\n\n  /**\n   *  @ignore\n   */\n  protected _bgColor: string = '#F00';\n\n  /**\n   *  @ignore\n   */\n  private readonly _gradientColors: any[] = [\n    { color: 'rgb(255, 0, 0)', pos: 0 },\n    { color: 'rgb(255, 255, 0)', pos: 0.17 },\n    { color: 'rgb(0, 255, 0)', pos: 0.33 },\n    { color: 'rgb(0, 255, 255)', pos: 0.5 },\n    { color: 'rgb(0, 0, 255)', pos: 0.67 },\n    { color: 'rgb(255, 0, 255)', pos: 0.83 },\n    { color: 'rgb(255, 0, 0)', pos: 1 },\n  ];\n\n  /**\n   *  @ignore\n   */\n  private readonly _gradients = AXColorUtil.gradient(this._gradientColors);\n\n  /**\n   *  @ignore\n   */\n  private readonly _colors = this._gradients.rgb(100);\n\n  /**\n   *  @ignore\n   */\n  protected dragPosition = { x: 0, y: 0 };\n\n  /**\n   *  @ignore\n   */\n  constructor(\n    @Inject(AXColorPaletteParentComponent)\n    public _parent: AXColorPaletteParentComponent,\n    private _unsubscriber: AXUnsubscriber,\n  ) {\n    super();\n    _parent.onValueChanged.pipe(_unsubscriber.takeUntilDestroy).subscribe((e) => {\n      this._handleParentColorChanged();\n    });\n    _parent.onOptionChanged.pipe(_unsubscriber.takeUntilDestroy).subscribe((e) => {\n      this.cdr.markForCheck();\n    });\n  }\n\n  /**\n   *  @ignore\n   */\n  private setHSV() {\n    const hsv = AXColorUtil.to(this._rgba, 'hsva') as any;\n    const sortedH = this._colors.map((c) => c.toHsv().h);\n    this._gradient = sortedH.findIndex((c) => {\n      return Math.round(c) >= Math.round(hsv.h);\n    });\n    this._bgColor = AXColorUtil.toString({ h: hsv.h, s: 1, v: 1, a: this._rgba.a }, 'rgba');\n    this.setPointerByPercent(hsv.s * 100, hsv.v * 100);\n  }\n\n  /**\n   *  @ignore\n   */\n  private _handleParentColorChanged() {\n    const color = this._parent.value;\n    if (!color) {\n      this._rgba = {\n        r: 0,\n        g: 0,\n        b: 0,\n        a: 0,\n      };\n    } else {\n      if (!AXColorUtil.equal(color, this._rgba)) {\n        Object.assign(this._rgba, AXColorUtil.to(color, 'rgba'));\n      }\n    }\n    this.setHSV();\n    this.cdr.detectChanges();\n  }\n\n  /**\n   *  @ignore\n   */\n  protected _handleAlphaChanged(e: any) {\n    if (e != this._rgba.a) {\n      const { r, g, b } = this._rgba;\n      const _color = `rgba(${r},${g},${b},${e})`;\n      this._parent.commitValue(AXColorUtil.toString(_color, 'rgba'), true);\n    }\n  }\n\n  /**\n   *  @ignore\n   */\n  protected _handleGradientChanged(e: any) {\n    if (e != this._gradient) {\n      const { s, v } = AXColorUtil.to(this._rgba, 'hsva') as any;\n      const { h } = this._colors[e as number].toHsv();\n      this._parent.commitValue(AXColorUtil.toString({ h, s, v, a: this._rgba.a }, 'rgba'), true);\n    }\n  }\n\n  /**\n   *  @ignore\n   */\n  protected _handleSurfaceClick(e: MouseEvent) {\n    if (this._parent.disabled || this._parent.readonly) {\n      e.preventDefault();\n      e.stopPropagation();\n      return;\n    }\n    const surface = this.getHostElement().querySelector<HTMLDivElement>('.ax-color-box-overlay');\n    const pointer = this.getHostElement().querySelector<HTMLDivElement>('.ax-color-box-pointer');\n    let x = e.offsetX;\n    let y = e.offsetY;\n    this.setColorByXY(x, y);\n  }\n\n  /**\n   *  @ignore\n   */\n  protected _handleDrag() {\n    if (this._parent.disabled || this._parent.readonly) {\n      return;\n    }\n    const surface = this.getHostElement().querySelector<HTMLDivElement>('.ax-color-box-overlay');\n    const sb = surface.getBoundingClientRect();\n    const pointer = this.getHostElement().querySelector<HTMLDivElement>('.ax-color-box-pointer');\n    const pb = pointer.getBoundingClientRect();\n    const w = pb.width / 2;\n    let x = pb.left - sb.left + w;\n    let y = pb.top - sb.top + w;\n    //\n    x = x < 0 ? 0 : x;\n    x = x > sb.width ? sb.width : x;\n    //\n    y = y < 0 ? 0 : y;\n    y = y > sb.height ? sb.height : y;\n    //\n    this.setColorByXY(x, y);\n  }\n\n  /**\n   *  @ignore\n   */\n  // protected _handleDragMove(event: any) {\n  //   if (this._parent.disabled || this._parent.readonly) {\n  //     return;\n  //   }\n\n  //   const surface = this.getHostElement().querySelector<HTMLDivElement>('.ax-color-box-overlay');\n  //   const sb = surface.getBoundingClientRect();\n\n  //   // Get the position of the drag event relative to the surface\n  //   const dragPosition = event.pointerPosition;\n\n  //   // Calculate x and y offsets relative to the surface\n  //   let x = dragPosition.x - sb.left; // Pointer x position\n  //   let y = dragPosition.y - sb.top; // Pointer y position\n\n  //   // Clamp values to be within bounds\n  //   // Adjust the clamping logic to prevent overshooting by taking the pointer size into account\n  //   const pointerWidth = 20; // Assuming a pointer width of 20px, adjust as necessary\n  //   const pointerHeight = 20; // Assuming a pointer height of 20px, adjust as necessary\n\n  //   x = Math.max(0 + pointerWidth / 2, Math.min(x, sb.width - pointerWidth / 2)); // Center the pointer\n  //   y = Math.max(0 + pointerHeight / 2, Math.min(y, sb.height - pointerHeight / 2)); // Center the pointer\n\n  //   // Call the method to set the color based on the new x and y\n  //   this.setColorByXY(x, y);\n  // }\n\n  /**\n   *  @ignore\n   */\n  private setColorByXY(x: number, y: number) {\n    const surface = this.getHostElement().querySelector<HTMLDivElement>('.ax-color-box-overlay');\n    const sb = surface.getBoundingClientRect();\n    //\n    const { h, a } = AXColorUtil.to(this._bgColor, 'hsva') as any;\n    const hsva = {\n      h,\n      s: x / sb.width,\n      v: (sb.height - y) / sb.height,\n      a,\n    };\n    this._parent.commitValue(AXColorUtil.toString(hsva, 'rgba'), true);\n  }\n\n  /**\n   *  @ignore\n   */\n  private setPointerByPercent(x: number, y: number) {\n    if (isBrowser()) {\n      const surface = this.getHostElement().querySelector<HTMLDivElement>('.ax-color-box-overlay');\n      if (!surface) return;\n      const sb = surface?.getBoundingClientRect();\n      const pointer = this.getHostElement().querySelector<HTMLDivElement>('.ax-color-box-pointer');\n      const pb = pointer?.getBoundingClientRect();\n      const w = pb.width / 2;\n      const width = sb.width; //+ pb.width\n      const height = sb.height; // + pb.width\n      this.dragPosition = {\n        x: (x * width) / 100 - w,\n        y: height - (y * height) / 100 - w,\n      };\n    }\n  }\n\n  /**\n   *  @ignore\n   */\n  @HostBinding('class')\n  private get __hostClass(): string {\n    return `ax-color-palette-picker`;\n  }\n}\n","<div class=\"ax-color-box-overlay-trans\">\n  <div class=\"ax-color-box-overlay\" [style.background-color]=\"_bgColor\">\n    <div class=\"ax-color-box-overlay-g1\"></div>\n    <div class=\"ax-color-box-overlay-g2\" (click)=\"_handleSurfaceClick($event)\"></div>\n    <div\n      class=\"ax-color-box-pointer\"\n      cdkDrag\n      cdkDragBoundary=\".ax-color-box-overlay\"\n      [cdkDragFreeDragPosition]=\"dragPosition\"\n      (cdkDragEnded)=\"_handleDrag()\"\n      [cdkDragDisabled]=\"_parent.disabled || _parent.readonly\"\n    ></div>\n  </div>\n</div>\n\n<ax-range-slider\n  class=\"ax-color-box-gradient\"\n  [min]=\"0\"\n  [max]=\"100\"\n  [mode]=\"'single'\"\n  [ngModel]=\"_gradient\"\n  [disabled]=\"_parent.disabled\"\n  [readonly]=\"_parent.readonly\"\n  (ngModelChange)=\"_handleGradientChanged($event)\"\n>\n</ax-range-slider>\n<ax-range-slider\n  class=\"ax-color-box-transparent\"\n  [min]=\"0\"\n  [max]=\"1\"\n  [hasStep]=\"false\"\n  [ngModel]=\"_rgba.a\"\n  [disabled]=\"_parent.disabled\"\n  [readonly]=\"_parent.readonly\"\n  (ngModelChange)=\"_handleAlphaChanged($event)\"\n>\n</ax-range-slider>\n"]}
277
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-palette-picker.component.js","sourceRoot":"","sources":["../../../../../../libs/components/color-palette/src/lib/color-palette-picker.component.ts","../../../../../../libs/components/color-palette/src/lib/color-palette-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { MXBaseComponent } from '@acorex/components/common';\nimport { isBrowser } from '@acorex/core/platform';\nimport { AXColorUtil, AXUnsubscriber } from '@acorex/core/utils';\nimport {\n  ChangeDetectionStrategy,\n  Component,\n  ElementRef,\n  HostBinding,\n  Inject,\n  signal,\n  viewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { AXColorPaletteChildComponent, AXColorPaletteParentComponent } from './color-palette.class';\n\n/**\n * Component for picking colors from a color palette.\n *\n * @category Components\n */\n@Component({\n  selector: 'ax-color-palette-picker',\n  templateUrl: './color-palette-picker.component.html',\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  providers: [\n    {\n      provide: AXColorPaletteChildComponent,\n      useExisting: AXColorPalettePickerComponent,\n    },\n    AXUnsubscriber,\n  ],\n})\nexport class AXColorPalettePickerComponent extends MXBaseComponent {\n  _rgba: { r: number; g: number; b: number; a: number } = {\n    r: 0,\n    g: 0,\n    b: 0,\n    a: 0,\n  };\n\n  private circle = viewChild<ElementRef<HTMLDivElement>>('circle');\n\n  private changingColor = signal(false);\n\n  /**\n   *  @ignore\n   */\n  protected _gradient = 0;\n\n  /**\n   *  @ignore\n   */\n  protected _bgColor = '#F00';\n\n  /**\n   *  @ignore\n   */\n  private readonly _gradientColors: any[] = [\n    { color: 'rgb(255, 0, 0)', pos: 0 },\n    { color: 'rgb(255, 255, 0)', pos: 0.17 },\n    { color: 'rgb(0, 255, 0)', pos: 0.33 },\n    { color: 'rgb(0, 255, 255)', pos: 0.5 },\n    { color: 'rgb(0, 0, 255)', pos: 0.67 },\n    { color: 'rgb(255, 0, 255)', pos: 0.83 },\n    { color: 'rgb(255, 0, 0)', pos: 1 },\n  ];\n\n  /**\n   *  @ignore\n   */\n  private readonly _gradients = AXColorUtil.gradient(this._gradientColors);\n\n  /**\n   *  @ignore\n   */\n  private readonly _colors = this._gradients.rgb(100);\n\n  /**\n   *  @ignore\n   */\n  protected dragPosition = { x: 0, y: 0 };\n\n  /**\n   *  @ignore\n   */\n  constructor(\n    @Inject(AXColorPaletteParentComponent)\n    public _parent: AXColorPaletteParentComponent,\n    private _unsubscriber: AXUnsubscriber,\n  ) {\n    super();\n    _parent.onValueChanged.pipe(_unsubscriber.takeUntilDestroy).subscribe((e) => {\n      this._handleParentColorChanged();\n    });\n    _parent.onOptionChanged.pipe(_unsubscriber.takeUntilDestroy).subscribe((e) => {\n      this.cdr.markForCheck();\n    });\n  }\n\n  /**\n   *  @ignore\n   */\n  private setHSV() {\n    const hsv = AXColorUtil.to(this._rgba, 'hsva') as any;\n    const sortedH = this._colors.map((c) => c.toHsv().h);\n    this._gradient = sortedH.findIndex((c) => {\n      return Math.round(c) >= Math.round(hsv.h);\n    });\n    this._bgColor = AXColorUtil.toString({ h: hsv.h, s: 1, v: 1, a: this._rgba.a }, 'rgba');\n    this.setPointerByPercent(hsv.s * 100, hsv.v * 100);\n  }\n\n  /**\n   *  @ignore\n   */\n  private _handleParentColorChanged() {\n    const color = this._parent.value;\n    if (!color) {\n      this._rgba = {\n        r: 0,\n        g: 0,\n        b: 0,\n        a: 0,\n      };\n    } else {\n      if (!AXColorUtil.equal(color, this._rgba)) {\n        Object.assign(this._rgba, AXColorUtil.to(color, 'rgba'));\n      }\n    }\n    this.setHSV();\n    this.cdr.detectChanges();\n  }\n\n  /**\n   *  @ignore\n   */\n  protected _handleAlphaChanged(e: any) {\n    if (e != this._rgba.a) {\n      const { r, g, b } = this._rgba;\n      const _color = `rgba(${r},${g},${b},${e})`;\n      this._parent.commitValue(AXColorUtil.toString(_color, 'rgba'), true);\n    }\n  }\n\n  /**\n   *  @ignore\n   */\n  protected _handleGradientChanged(e: any) {\n    if (e != this._gradient) {\n      const { s, v } = AXColorUtil.to(this._rgba, 'hsva') as any;\n      const { h } = this._colors[e as number].toHsv();\n      this._parent.commitValue(AXColorUtil.toString({ h, s, v, a: this._rgba.a }, 'rgba'), true);\n    }\n  }\n\n  /**\n   *  @ignore\n   */\n  // protected _handleSurfaceClick(e: MouseEvent) {\n  //   if (this._parent.disabled || this._parent.readonly) {\n  //     e.preventDefault();\n  //     e.stopPropagation();\n  //     return;\n  //   }\n  //   const surface = this.getHostElement().querySelector<HTMLDivElement>('.ax-color-box-overlay');\n  //   const pointer = this.getHostElement().querySelector<HTMLDivElement>('.ax-color-box-pointer');\n  //   const x = e.offsetX;\n  //   const y = e.offsetY;\n  //   this.setColorByXY(x, y);\n  // }\n\n  /**\n   *  @ignore\n   */\n  // protected _handleDrag() {\n  //   if (this._parent.disabled || this._parent.readonly) {\n  //     return;\n  //   }\n  //   const surface = this.getHostElement().querySelector<HTMLDivElement>('.ax-color-box-overlay');\n  //   const sb = surface.getBoundingClientRect();\n  //   const pointer = this.getHostElement().querySelector<HTMLDivElement>('.ax-color-box-pointer');\n  //   const pb = pointer.getBoundingClientRect();\n  //   const w = pb.width / 2;\n  //   let x = pb.left - sb.left + w;\n  //   let y = pb.top - sb.top + w;\n  //   //\n  //   x = x < 0 ? 0 : x;\n  //   x = x > sb.width ? sb.width : x;\n  //   //\n  //   y = y < 0 ? 0 : y;\n  //   y = y > sb.height ? sb.height : y;\n  //   //\n  //   this.setColorByXY(x, y);\n  // }\n\n  /**\n   *  @ignore\n   */\n  // protected _handleDragMove(event: any) {\n  //   if (this._parent.disabled || this._parent.readonly) {\n  //     return;\n  //   }\n\n  //   const surface = this.getHostElement().querySelector<HTMLDivElement>('.ax-color-box-overlay');\n  //   const sb = surface.getBoundingClientRect();\n\n  //   // Get the position of the drag event relative to the surface\n  //   const dragPosition = event.pointerPosition;\n\n  //   // Calculate x and y offsets relative to the surface\n  //   let x = dragPosition.x - sb.left; // Pointer x position\n  //   let y = dragPosition.y - sb.top; // Pointer y position\n\n  //   // Clamp values to be within bounds\n  //   // Adjust the clamping logic to prevent overshooting by taking the pointer size into account\n  //   const pointerWidth = 20; // Assuming a pointer width of 20px, adjust as necessary\n  //   const pointerHeight = 20; // Assuming a pointer height of 20px, adjust as necessary\n\n  //   x = Math.max(0 + pointerWidth / 2, Math.min(x, sb.width - pointerWidth / 2)); // Center the pointer\n  //   y = Math.max(0 + pointerHeight / 2, Math.min(y, sb.height - pointerHeight / 2)); // Center the pointer\n\n  //   // Call the method to set the color based on the new x and y\n  //   this.setColorByXY(x, y);\n  // }\n\n  /**\n   *  @ignore\n   */\n  private setColorByXY(x: number, y: number) {\n    const surface = this.getHostElement().querySelector<HTMLDivElement>('.ax-color-box-overlay');\n    const sb = surface.getBoundingClientRect();\n    //\n    const { h, a } = AXColorUtil.to(this._bgColor, 'hsva') as any;\n    const hsva = {\n      h,\n      s: x / sb.width,\n      v: (sb.height - y) / sb.height,\n      a,\n    };\n    this._parent.commitValue(AXColorUtil.toString(hsva, 'rgba'), true);\n  }\n\n  /**\n   *  @ignore\n   */\n  private setPointerByPercent(x: number, y: number) {\n    if (isBrowser()) {\n      const surface = this.getHostElement().querySelector<HTMLDivElement>('.ax-color-box-overlay');\n      if (!surface) return;\n      const sb = surface?.getBoundingClientRect();\n      const pointer = this.getHostElement().querySelector<HTMLDivElement>('.ax-color-box-pointer');\n      const pb = pointer?.getBoundingClientRect();\n      const w = pb.width / 2;\n      const width = sb.width; //+ pb.width\n      const height = sb.height; // + pb.width\n      this.dragPosition = {\n        x: (x * width) / 100 - w,\n        y: height - (y * height) / 100 - w,\n      };\n    }\n  }\n\n  /**\n   *  @ignore\n   */\n  @HostBinding('class')\n  private get __hostClass(): string {\n    return `ax-color-palette-picker`;\n  }\n\n  protected handleMove(event: MouseEvent) {\n    if (!this.changingColor()) return;\n    this.placePointer(event);\n  }\n\n  protected handleDown(event: MouseEvent) {\n    if (this._parent.disabled || this._parent.readonly) return;\n    this.placePointer(event);\n    this.changingColor.set(true);\n  }\n\n  protected handleUp() {\n    this.changingColor.set(false);\n  }\n\n  private placePointer(event: MouseEvent) {\n    const circleElement = this.circle().nativeElement;\n    const parentStats = circleElement.parentElement.getBoundingClientRect();\n\n    const circleHeight = circleElement.offsetHeight / 2;\n    const circleWidth = circleElement.offsetWidth / 2;\n\n    const top = event.clientY - parentStats.top - circleHeight;\n    const left = event.clientX - parentStats.left - circleWidth;\n\n    circleElement.style.top = `${Math.max(0 - circleHeight, Math.min(top, parentStats.height - circleHeight))}px`;\n    circleElement.style.left = `${Math.max(0 - circleWidth, Math.min(left, parentStats.width - circleWidth))}px`;\n\n    this.setColorByXY(event.clientX - parentStats.left, event.clientY - parentStats.top);\n  }\n}\n","<div class=\"ax-color-box-overlay-trans\">\n  <div\n    class=\"ax-color-box-overlay\"\n    [style.background-color]=\"_bgColor\"\n    (mousemove)=\"handleMove($event)\"\n    (mousedown)=\"handleDown($event)\"\n    (mouseup)=\"handleUp()\"\n    (mouseleave)=\"handleUp()\"\n  >\n    <div class=\"ax-color-box-overlay-g1\"></div>\n    <div class=\"ax-color-box-overlay-g2\"></div>\n    <div #circle class=\"ax-color-box-pointer\"></div>\n  </div>\n</div>\n\n<ax-range-slider\n  class=\"ax-color-box-gradient\"\n  [min]=\"0\"\n  [max]=\"100\"\n  [mode]=\"'single'\"\n  [ngModel]=\"_gradient\"\n  [disabled]=\"_parent.disabled\"\n  [readonly]=\"_parent.readonly\"\n  (ngModelChange)=\"_handleGradientChanged($event)\"\n>\n</ax-range-slider>\n<ax-range-slider\n  class=\"ax-color-box-transparent\"\n  [min]=\"0\"\n  [max]=\"1\"\n  [hasStep]=\"false\"\n  [ngModel]=\"_rgba.a\"\n  [disabled]=\"_parent.disabled\"\n  [readonly]=\"_parent.readonly\"\n  (ngModelChange)=\"_handleAlphaChanged($event)\"\n>\n</ax-range-slider>\n"]}
@@ -73,25 +73,26 @@ export class AXDataPagerNumericSelectorComponent extends AXDataPagerChild {
73
73
  AXUnsubscriber,
74
74
  ], usesInheritance: true, ngImport: i0, template: `
75
75
  <ax-button
76
+ class="ax-sm"
76
77
  [disabled]="_currentPage === 1 || _parent.disabled"
77
78
  look="blank"
78
79
  (onClick)="_handleOnItemClick({ data: 1 })"
79
80
  >
80
- <ax-icon class="ax-icon ax-icon-chevron-double-left ax-text-xl"></ax-icon>
81
+ <ax-icon class="ax-icon ax-icon-chevron-double-left"></ax-icon>
81
82
  </ax-button>
82
83
 
83
84
  @if (!_parent.isLoading) {
84
85
  @for (item of _items; track $index) {
85
86
  <ax-button
86
- class="ax-selected-page-button"
87
+ class="ax-sm"
87
88
  [disabled]="_parent.disabled"
88
- [color]="_currentPage === item.data ? 'primary' : 'solid'"
89
+ [color]="_currentPage === item.data ? 'primary' : 'ghost'"
89
90
  [look]="_currentPage === item.data ? 'solid' : 'blank'"
90
91
  [text]="item.text"
91
92
  (onClick)="_handleOnItemClick(item)"
92
93
  >
93
94
  @if (item.iconClass) {
94
- <ax-icon class="ax-icon ax-text-xl" [ngClass]="item.iconClass"></ax-icon>
95
+ <ax-icon class="ax-icon" [ngClass]="item.iconClass"></ax-icon>
95
96
  }
96
97
  </ax-button>
97
98
  }
@@ -100,11 +101,12 @@ export class AXDataPagerNumericSelectorComponent extends AXDataPagerChild {
100
101
  }
101
102
 
102
103
  <ax-button
104
+ class="ax-sm"
103
105
  [disabled]="_currentPage === _lastPage || _parent.disabled"
104
106
  look="blank"
105
107
  (onClick)="_handleOnItemClick({ data: _lastPage })"
106
108
  >
107
- <ax-icon class="ax-icon ax-icon-chevron-double-right ax-text-xl"></ax-icon>
109
+ <ax-icon class="ax-icon ax-icon-chevron-double-right"></ax-icon>
108
110
  </ax-button>
109
111
  `, isInline: true, dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i2.AXButtonComponent, selector: "ax-button", inputs: ["disabled", "size", "tabIndex", "color", "look", "text", "toggleable", "selected", "type", "responsiveOn", "loadingText"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange", "lookChange", "colorChange", "disabledChange", "responsiveOnChange", "loadingTextChange"] }, { kind: "component", type: i3.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "component", type: i4.AXSkeletonComponent, selector: "ax-skeleton", inputs: ["animated"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
110
112
  }
@@ -114,25 +116,26 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
114
116
  selector: 'ax-data-pager-numeric-selector',
115
117
  template: `
116
118
  <ax-button
119
+ class="ax-sm"
117
120
  [disabled]="_currentPage === 1 || _parent.disabled"
118
121
  look="blank"
119
122
  (onClick)="_handleOnItemClick({ data: 1 })"
120
123
  >
121
- <ax-icon class="ax-icon ax-icon-chevron-double-left ax-text-xl"></ax-icon>
124
+ <ax-icon class="ax-icon ax-icon-chevron-double-left"></ax-icon>
122
125
  </ax-button>
123
126
 
124
127
  @if (!_parent.isLoading) {
125
128
  @for (item of _items; track $index) {
126
129
  <ax-button
127
- class="ax-selected-page-button"
130
+ class="ax-sm"
128
131
  [disabled]="_parent.disabled"
129
- [color]="_currentPage === item.data ? 'primary' : 'solid'"
132
+ [color]="_currentPage === item.data ? 'primary' : 'ghost'"
130
133
  [look]="_currentPage === item.data ? 'solid' : 'blank'"
131
134
  [text]="item.text"
132
135
  (onClick)="_handleOnItemClick(item)"
133
136
  >
134
137
  @if (item.iconClass) {
135
- <ax-icon class="ax-icon ax-text-xl" [ngClass]="item.iconClass"></ax-icon>
138
+ <ax-icon class="ax-icon" [ngClass]="item.iconClass"></ax-icon>
136
139
  }
137
140
  </ax-button>
138
141
  }
@@ -141,11 +144,12 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
141
144
  }
142
145
 
143
146
  <ax-button
147
+ class="ax-sm"
144
148
  [disabled]="_currentPage === _lastPage || _parent.disabled"
145
149
  look="blank"
146
150
  (onClick)="_handleOnItemClick({ data: _lastPage })"
147
151
  >
148
- <ax-icon class="ax-icon ax-icon-chevron-double-right ax-text-xl"></ax-icon>
152
+ <ax-icon class="ax-icon ax-icon-chevron-double-right"></ax-icon>
149
153
  </ax-button>
150
154
  `,
151
155
  changeDetection: ChangeDetectionStrategy.OnPush,
@@ -159,4 +163,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
159
163
  ],
160
164
  }]
161
165
  }] });
162
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1wYWdlci1udW1lcmljLXNlbGVjdG9yLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9kYXRhLXBhZ2VyL3NyYy9saWIvZGF0YS1wYWdlci1udW1lcmljLXNlbGVjdG9yLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDcEQsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN0RixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQzs7Ozs7O0FBRS9EOzs7O0dBSUc7QUFpREgsTUFBTSxPQUFPLG1DQUFvQyxTQUFRLGdCQUFnQjtJQWhEekU7O1FBaURFLFdBQU0sR0FBbUIsRUFBRSxDQUFDO1FBQzVCLGlCQUFZLEdBQUcsQ0FBQyxDQUFDO1FBQ2pCLGNBQVMsR0FBRyxDQUFDLENBQUM7UUFDZCxhQUFRLEdBQUcsS0FBSyxDQUFDO1FBRWpCOztXQUVHO1FBQ0ssa0JBQWEsR0FBRyxDQUFDLENBQUM7S0ErQzNCO0lBN0NDOztPQUVHO0lBQ2dCLFdBQVc7UUFDNUIsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUM7UUFDbEQsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQztRQUN2QyxJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDLFVBQVUsQ0FBQztRQUNyRCxFQUFFO1FBQ0YsSUFBSSxDQUFDLE1BQU0sR0FBRyxFQUFFLENBQUM7UUFFakIsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FDcEIsQ0FBQyxFQUNELENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsYUFBYSxHQUFHLENBQUMsQ0FDakYsQ0FBQztRQUNGLE1BQU0sR0FBRyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxhQUFhLEdBQUcsQ0FBQyxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUNyRSxFQUFFO1FBQ0YsSUFBSSxLQUFLLEdBQUcsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQy9CLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDO2dCQUNmLFNBQVMsRUFBRSxzQkFBc0I7Z0JBQ2pDLElBQUksRUFBRSxLQUFLLEdBQUcsQ0FBQzthQUNoQixDQUFDLENBQUM7UUFDTCxDQUFDO1FBQ0QsRUFBRTtRQUNGLEtBQUssSUFBSSxDQUFDLEdBQUcsS0FBSyxFQUFFLENBQUMsSUFBSSxHQUFHLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQztZQUNsQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQztnQkFDZixJQUFJLEVBQUUsQ0FBQyxDQUFDLFFBQVEsRUFBRTtnQkFDbEIsSUFBSSxFQUFFLENBQUM7YUFDUixDQUFDLENBQUM7UUFDTCxDQUFDO1FBQ0QsSUFBSSxHQUFHLEdBQUcsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQ3pCLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDO2dCQUNmLFNBQVMsRUFBRSx1QkFBdUI7Z0JBQ2xDLElBQUksRUFBRSxHQUFHLEdBQUcsQ0FBQzthQUNkLENBQUMsQ0FBQztRQUNMLENBQUM7UUFDRCxJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFFRDs7T0FFRztJQUNILGtCQUFrQixDQUFDLENBQU07UUFDdkIsSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVE7WUFBRSxPQUFPO1FBQzNELElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztJQUN4QyxDQUFDOzhHQXZEVSxtQ0FBbUM7a0dBQW5DLG1DQUFtQyx5REFSbkM7WUFDVDtnQkFDRSxPQUFPLEVBQUUsZ0JBQWdCO2dCQUN6QixXQUFXLEVBQUUsbUNBQW1DO2FBQ2pEO1lBQ0QsY0FBYztTQUNmLGlEQTVDUzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FtQ1Q7OzJGQVdVLG1DQUFtQztrQkFoRC9DLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLGdDQUFnQztvQkFDMUMsUUFBUSxFQUFFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW1DVDtvQkFDRCxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtvQkFDL0MsYUFBYSxFQUFFLGlCQUFpQixDQUFDLElBQUk7b0JBQ3JDLFNBQVMsRUFBRTt3QkFDVDs0QkFDRSxPQUFPLEVBQUUsZ0JBQWdCOzRCQUN6QixXQUFXLHFDQUFxQzt5QkFDakQ7d0JBQ0QsY0FBYztxQkFDZjtpQkFDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFYQnV0dG9uSXRlbSB9IGZyb20gJ0BhY29yZXgvY29tcG9uZW50cy9idXR0b24nO1xuaW1wb3J0IHsgQVhVbnN1YnNjcmliZXIgfSBmcm9tICdAYWNvcmV4L2NvcmUvdXRpbHMnO1xuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IEFYRGF0YVBhZ2VyQ2hpbGQgfSBmcm9tICcuL2RhdGEtcGFnZXItYmFzZS5jb21wb25lbnQnO1xuXG4vKipcbiAqIENvbXBvbmVudCB0aGF0IHByb3ZpZGVzIG51bWVyaWMgcGFnZSBzZWxlY3Rpb24gY29udHJvbHMgZm9yIGEgZGF0YSBwYWdlci5cbiAqXG4gKiBAY2F0ZWdvcnkgQ29tcG9uZW50c1xuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdheC1kYXRhLXBhZ2VyLW51bWVyaWMtc2VsZWN0b3InLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxheC1idXR0b25cbiAgICAgIFtkaXNhYmxlZF09XCJfY3VycmVudFBhZ2UgPT09IDEgfHwgX3BhcmVudC5kaXNhYmxlZFwiXG4gICAgICBsb29rPVwiYmxhbmtcIlxuICAgICAgKG9uQ2xpY2spPVwiX2hhbmRsZU9uSXRlbUNsaWNrKHsgZGF0YTogMSB9KVwiXG4gICAgPlxuICAgICAgPGF4LWljb24gY2xhc3M9XCJheC1pY29uIGF4LWljb24tY2hldnJvbi1kb3VibGUtbGVmdCBheC10ZXh0LXhsXCI+PC9heC1pY29uPlxuICAgIDwvYXgtYnV0dG9uPlxuXG4gICAgQGlmICghX3BhcmVudC5pc0xvYWRpbmcpIHtcbiAgICAgIEBmb3IgKGl0ZW0gb2YgX2l0ZW1zOyB0cmFjayAkaW5kZXgpIHtcbiAgICAgICAgPGF4LWJ1dHRvblxuICAgICAgICAgIGNsYXNzPVwiYXgtc2VsZWN0ZWQtcGFnZS1idXR0b25cIlxuICAgICAgICAgIFtkaXNhYmxlZF09XCJfcGFyZW50LmRpc2FibGVkXCJcbiAgICAgICAgICBbY29sb3JdPVwiX2N1cnJlbnRQYWdlID09PSBpdGVtLmRhdGEgPyAncHJpbWFyeScgOiAnc29saWQnXCJcbiAgICAgICAgICBbbG9va109XCJfY3VycmVudFBhZ2UgPT09IGl0ZW0uZGF0YSA/ICdzb2xpZCcgOiAnYmxhbmsnXCJcbiAgICAgICAgICBbdGV4dF09XCJpdGVtLnRleHRcIlxuICAgICAgICAgIChvbkNsaWNrKT1cIl9oYW5kbGVPbkl0ZW1DbGljayhpdGVtKVwiXG4gICAgICAgID5cbiAgICAgICAgICBAaWYgKGl0ZW0uaWNvbkNsYXNzKSB7XG4gICAgICAgICAgICA8YXgtaWNvbiBjbGFzcz1cImF4LWljb24gYXgtdGV4dC14bFwiIFtuZ0NsYXNzXT1cIml0ZW0uaWNvbkNsYXNzXCI+PC9heC1pY29uPlxuICAgICAgICAgIH1cbiAgICAgICAgPC9heC1idXR0b24+XG4gICAgICB9XG4gICAgfSBAZWxzZSB7XG4gICAgICA8YXgtc2tlbGV0b24+PC9heC1za2VsZXRvbj5cbiAgICB9XG5cbiAgICA8YXgtYnV0dG9uXG4gICAgICBbZGlzYWJsZWRdPVwiX2N1cnJlbnRQYWdlID09PSBfbGFzdFBhZ2UgfHwgX3BhcmVudC5kaXNhYmxlZFwiXG4gICAgICBsb29rPVwiYmxhbmtcIlxuICAgICAgKG9uQ2xpY2spPVwiX2hhbmRsZU9uSXRlbUNsaWNrKHsgZGF0YTogX2xhc3RQYWdlIH0pXCJcbiAgICA+XG4gICAgICA8YXgtaWNvbiBjbGFzcz1cImF4LWljb24gYXgtaWNvbi1jaGV2cm9uLWRvdWJsZS1yaWdodCBheC10ZXh0LXhsXCI+PC9heC1pY29uPlxuICAgIDwvYXgtYnV0dG9uPlxuICBgLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaCxcbiAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcbiAgcHJvdmlkZXJzOiBbXG4gICAge1xuICAgICAgcHJvdmlkZTogQVhEYXRhUGFnZXJDaGlsZCxcbiAgICAgIHVzZUV4aXN0aW5nOiBBWERhdGFQYWdlck51bWVyaWNTZWxlY3RvckNvbXBvbmVudCxcbiAgICB9LFxuICAgIEFYVW5zdWJzY3JpYmVyLFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBBWERhdGFQYWdlck51bWVyaWNTZWxlY3RvckNvbXBvbmVudCBleHRlbmRzIEFYRGF0YVBhZ2VyQ2hpbGQge1xuICBfaXRlbXM6IEFYQnV0dG9uSXRlbVtdID0gW107XG4gIF9jdXJyZW50UGFnZSA9IDE7XG4gIF9sYXN0UGFnZSA9IDE7XG4gIF9sb2FkaW5nID0gZmFsc2U7XG5cbiAgLyoqXG4gICAqICBAaWdub3JlXG4gICAqL1xuICBwcml2YXRlIF9kaXNwbGF5Q291bnQgPSA1O1xuXG4gIC8qKlxuICAgKiAgQGlnbm9yZVxuICAgKi9cbiAgcHJvdGVjdGVkIG92ZXJyaWRlIGFwcGx5UGFyZW50KCk6IHZvaWQge1xuICAgIHRoaXMuX2N1cnJlbnRQYWdlID0gdGhpcy5fcGFyZW50LmRpc3BsYXlJbmZvLnBhZ2U7XG4gICAgdGhpcy5fbG9hZGluZyA9IHRoaXMuX3BhcmVudC5pc0xvYWRpbmc7XG4gICAgdGhpcy5fbGFzdFBhZ2UgPSB0aGlzLl9wYXJlbnQuZGlzcGxheUluZm8udG90YWxQYWdlcztcbiAgICAvL1xuICAgIHRoaXMuX2l0ZW1zID0gW107XG5cbiAgICBjb25zdCBzdGFydCA9IE1hdGgubWF4KFxuICAgICAgMCxcbiAgICAgIChNYXRoLmNlaWwodGhpcy5fY3VycmVudFBhZ2UgLyB0aGlzLl9kaXNwbGF5Q291bnQpIC0gMSkgKiB0aGlzLl9kaXNwbGF5Q291bnQgKyAxLFxuICAgICk7XG4gICAgY29uc3QgZW5kID0gTWF0aC5taW4oc3RhcnQgKyB0aGlzLl9kaXNwbGF5Q291bnQgLSAxLCB0aGlzLl9sYXN0UGFnZSk7XG4gICAgLy9cbiAgICBpZiAoc3RhcnQgPiB0aGlzLl9kaXNwbGF5Q291bnQpIHtcbiAgICAgIHRoaXMuX2l0ZW1zLnB1c2goe1xuICAgICAgICBpY29uQ2xhc3M6ICdheC1pY29uLWNoZXZyb24tbGVmdCcsXG4gICAgICAgIGRhdGE6IHN0YXJ0IC0gMSxcbiAgICAgIH0pO1xuICAgIH1cbiAgICAvL1xuICAgIGZvciAobGV0IGkgPSBzdGFydDsgaSA8PSBlbmQ7IGkrKykge1xuICAgICAgdGhpcy5faXRlbXMucHVzaCh7XG4gICAgICAgIHRleHQ6IGkudG9TdHJpbmcoKSxcbiAgICAgICAgZGF0YTogaSxcbiAgICAgIH0pO1xuICAgIH1cbiAgICBpZiAoZW5kIDwgdGhpcy5fbGFzdFBhZ2UpIHtcbiAgICAgIHRoaXMuX2l0ZW1zLnB1c2goe1xuICAgICAgICBpY29uQ2xhc3M6ICdheC1pY29uLWNoZXZyb24tcmlnaHQnLFxuICAgICAgICBkYXRhOiBlbmQgKyAxLFxuICAgICAgfSk7XG4gICAgfVxuICAgIHRoaXMuY2RyLmRldGVjdENoYW5nZXMoKTtcbiAgfVxuXG4gIC8qKlxuICAgKiAgQGlnbm9yZVxuICAgKi9cbiAgX2hhbmRsZU9uSXRlbUNsaWNrKGU6IGFueSkge1xuICAgIGlmICh0aGlzLl9wYXJlbnQucmVhZG9ubHkgfHwgdGhpcy5fcGFyZW50LmRpc2FibGVkKSByZXR1cm47XG4gICAgdGhpcy5fcGFyZW50LmdvVG9QYWdlKE51bWJlcihlLmRhdGEpKTtcbiAgfVxufVxuIl19
166
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0YS1wYWdlci1udW1lcmljLXNlbGVjdG9yLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL2xpYnMvY29tcG9uZW50cy9kYXRhLXBhZ2VyL3NyYy9saWIvZGF0YS1wYWdlci1udW1lcmljLXNlbGVjdG9yLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDcEQsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN0RixPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQzs7Ozs7O0FBRS9EOzs7O0dBSUc7QUFtREgsTUFBTSxPQUFPLG1DQUFvQyxTQUFRLGdCQUFnQjtJQWxEekU7O1FBbURFLFdBQU0sR0FBbUIsRUFBRSxDQUFDO1FBQzVCLGlCQUFZLEdBQUcsQ0FBQyxDQUFDO1FBQ2pCLGNBQVMsR0FBRyxDQUFDLENBQUM7UUFDZCxhQUFRLEdBQUcsS0FBSyxDQUFDO1FBRWpCOztXQUVHO1FBQ0ssa0JBQWEsR0FBRyxDQUFDLENBQUM7S0ErQzNCO0lBN0NDOztPQUVHO0lBQ2dCLFdBQVc7UUFDNUIsSUFBSSxDQUFDLFlBQVksR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxJQUFJLENBQUM7UUFDbEQsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLFNBQVMsQ0FBQztRQUN2QyxJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsV0FBVyxDQUFDLFVBQVUsQ0FBQztRQUNyRCxFQUFFO1FBQ0YsSUFBSSxDQUFDLE1BQU0sR0FBRyxFQUFFLENBQUM7UUFFakIsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLEdBQUcsQ0FDcEIsQ0FBQyxFQUNELENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxJQUFJLENBQUMsYUFBYSxHQUFHLENBQUMsQ0FDakYsQ0FBQztRQUNGLE1BQU0sR0FBRyxHQUFHLElBQUksQ0FBQyxHQUFHLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQyxhQUFhLEdBQUcsQ0FBQyxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsQ0FBQztRQUNyRSxFQUFFO1FBQ0YsSUFBSSxLQUFLLEdBQUcsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQy9CLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDO2dCQUNmLFNBQVMsRUFBRSxzQkFBc0I7Z0JBQ2pDLElBQUksRUFBRSxLQUFLLEdBQUcsQ0FBQzthQUNoQixDQUFDLENBQUM7UUFDTCxDQUFDO1FBQ0QsRUFBRTtRQUNGLEtBQUssSUFBSSxDQUFDLEdBQUcsS0FBSyxFQUFFLENBQUMsSUFBSSxHQUFHLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQztZQUNsQyxJQUFJLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQztnQkFDZixJQUFJLEVBQUUsQ0FBQyxDQUFDLFFBQVEsRUFBRTtnQkFDbEIsSUFBSSxFQUFFLENBQUM7YUFDUixDQUFDLENBQUM7UUFDTCxDQUFDO1FBQ0QsSUFBSSxHQUFHLEdBQUcsSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDO1lBQ3pCLElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDO2dCQUNmLFNBQVMsRUFBRSx1QkFBdUI7Z0JBQ2xDLElBQUksRUFBRSxHQUFHLEdBQUcsQ0FBQzthQUNkLENBQUMsQ0FBQztRQUNMLENBQUM7UUFDRCxJQUFJLENBQUMsR0FBRyxDQUFDLGFBQWEsRUFBRSxDQUFDO0lBQzNCLENBQUM7SUFFRDs7T0FFRztJQUNILGtCQUFrQixDQUFDLENBQU07UUFDdkIsSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVEsSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFDLFFBQVE7WUFBRSxPQUFPO1FBQzNELElBQUksQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQztJQUN4QyxDQUFDOzhHQXZEVSxtQ0FBbUM7a0dBQW5DLG1DQUFtQyx5REFSbkM7WUFDVDtnQkFDRSxPQUFPLEVBQUUsZ0JBQWdCO2dCQUN6QixXQUFXLEVBQUUsbUNBQW1DO2FBQ2pEO1lBQ0QsY0FBYztTQUNmLGlEQTlDUzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXFDVDs7MkZBV1UsbUNBQW1DO2tCQWxEL0MsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUsZ0NBQWdDO29CQUMxQyxRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FxQ1Q7b0JBQ0QsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07b0JBQy9DLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO29CQUNyQyxTQUFTLEVBQUU7d0JBQ1Q7NEJBQ0UsT0FBTyxFQUFFLGdCQUFnQjs0QkFDekIsV0FBVyxxQ0FBcUM7eUJBQ2pEO3dCQUNELGNBQWM7cUJBQ2Y7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBWEJ1dHRvbkl0ZW0gfSBmcm9tICdAYWNvcmV4L2NvbXBvbmVudHMvYnV0dG9uJztcbmltcG9ydCB7IEFYVW5zdWJzY3JpYmVyIH0gZnJvbSAnQGFjb3JleC9jb3JlL3V0aWxzJztcbmltcG9ydCB7IENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBDb21wb25lbnQsIFZpZXdFbmNhcHN1bGF0aW9uIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBBWERhdGFQYWdlckNoaWxkIH0gZnJvbSAnLi9kYXRhLXBhZ2VyLWJhc2UuY29tcG9uZW50JztcblxuLyoqXG4gKiBDb21wb25lbnQgdGhhdCBwcm92aWRlcyBudW1lcmljIHBhZ2Ugc2VsZWN0aW9uIGNvbnRyb2xzIGZvciBhIGRhdGEgcGFnZXIuXG4gKlxuICogQGNhdGVnb3J5IENvbXBvbmVudHNcbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXgtZGF0YS1wYWdlci1udW1lcmljLXNlbGVjdG9yJyxcbiAgdGVtcGxhdGU6IGBcbiAgICA8YXgtYnV0dG9uXG4gICAgICBjbGFzcz1cImF4LXNtXCJcbiAgICAgIFtkaXNhYmxlZF09XCJfY3VycmVudFBhZ2UgPT09IDEgfHwgX3BhcmVudC5kaXNhYmxlZFwiXG4gICAgICBsb29rPVwiYmxhbmtcIlxuICAgICAgKG9uQ2xpY2spPVwiX2hhbmRsZU9uSXRlbUNsaWNrKHsgZGF0YTogMSB9KVwiXG4gICAgPlxuICAgICAgPGF4LWljb24gY2xhc3M9XCJheC1pY29uIGF4LWljb24tY2hldnJvbi1kb3VibGUtbGVmdFwiPjwvYXgtaWNvbj5cbiAgICA8L2F4LWJ1dHRvbj5cblxuICAgIEBpZiAoIV9wYXJlbnQuaXNMb2FkaW5nKSB7XG4gICAgICBAZm9yIChpdGVtIG9mIF9pdGVtczsgdHJhY2sgJGluZGV4KSB7XG4gICAgICAgIDxheC1idXR0b25cbiAgICAgICAgICBjbGFzcz1cImF4LXNtXCJcbiAgICAgICAgICBbZGlzYWJsZWRdPVwiX3BhcmVudC5kaXNhYmxlZFwiXG4gICAgICAgICAgW2NvbG9yXT1cIl9jdXJyZW50UGFnZSA9PT0gaXRlbS5kYXRhID8gJ3ByaW1hcnknIDogJ2dob3N0J1wiXG4gICAgICAgICAgW2xvb2tdPVwiX2N1cnJlbnRQYWdlID09PSBpdGVtLmRhdGEgPyAnc29saWQnIDogJ2JsYW5rJ1wiXG4gICAgICAgICAgW3RleHRdPVwiaXRlbS50ZXh0XCJcbiAgICAgICAgICAob25DbGljayk9XCJfaGFuZGxlT25JdGVtQ2xpY2soaXRlbSlcIlxuICAgICAgICA+XG4gICAgICAgICAgQGlmIChpdGVtLmljb25DbGFzcykge1xuICAgICAgICAgICAgPGF4LWljb24gY2xhc3M9XCJheC1pY29uXCIgW25nQ2xhc3NdPVwiaXRlbS5pY29uQ2xhc3NcIj48L2F4LWljb24+XG4gICAgICAgICAgfVxuICAgICAgICA8L2F4LWJ1dHRvbj5cbiAgICAgIH1cbiAgICB9IEBlbHNlIHtcbiAgICAgIDxheC1za2VsZXRvbj48L2F4LXNrZWxldG9uPlxuICAgIH1cblxuICAgIDxheC1idXR0b25cbiAgICAgIGNsYXNzPVwiYXgtc21cIlxuICAgICAgW2Rpc2FibGVkXT1cIl9jdXJyZW50UGFnZSA9PT0gX2xhc3RQYWdlIHx8IF9wYXJlbnQuZGlzYWJsZWRcIlxuICAgICAgbG9vaz1cImJsYW5rXCJcbiAgICAgIChvbkNsaWNrKT1cIl9oYW5kbGVPbkl0ZW1DbGljayh7IGRhdGE6IF9sYXN0UGFnZSB9KVwiXG4gICAgPlxuICAgICAgPGF4LWljb24gY2xhc3M9XCJheC1pY29uIGF4LWljb24tY2hldnJvbi1kb3VibGUtcmlnaHRcIj48L2F4LWljb24+XG4gICAgPC9heC1idXR0b24+XG4gIGAsXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lLFxuICBwcm92aWRlcnM6IFtcbiAgICB7XG4gICAgICBwcm92aWRlOiBBWERhdGFQYWdlckNoaWxkLFxuICAgICAgdXNlRXhpc3Rpbmc6IEFYRGF0YVBhZ2VyTnVtZXJpY1NlbGVjdG9yQ29tcG9uZW50LFxuICAgIH0sXG4gICAgQVhVbnN1YnNjcmliZXIsXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIEFYRGF0YVBhZ2VyTnVtZXJpY1NlbGVjdG9yQ29tcG9uZW50IGV4dGVuZHMgQVhEYXRhUGFnZXJDaGlsZCB7XG4gIF9pdGVtczogQVhCdXR0b25JdGVtW10gPSBbXTtcbiAgX2N1cnJlbnRQYWdlID0gMTtcbiAgX2xhc3RQYWdlID0gMTtcbiAgX2xvYWRpbmcgPSBmYWxzZTtcblxuICAvKipcbiAgICogIEBpZ25vcmVcbiAgICovXG4gIHByaXZhdGUgX2Rpc3BsYXlDb3VudCA9IDU7XG5cbiAgLyoqXG4gICAqICBAaWdub3JlXG4gICAqL1xuICBwcm90ZWN0ZWQgb3ZlcnJpZGUgYXBwbHlQYXJlbnQoKTogdm9pZCB7XG4gICAgdGhpcy5fY3VycmVudFBhZ2UgPSB0aGlzLl9wYXJlbnQuZGlzcGxheUluZm8ucGFnZTtcbiAgICB0aGlzLl9sb2FkaW5nID0gdGhpcy5fcGFyZW50LmlzTG9hZGluZztcbiAgICB0aGlzLl9sYXN0UGFnZSA9IHRoaXMuX3BhcmVudC5kaXNwbGF5SW5mby50b3RhbFBhZ2VzO1xuICAgIC8vXG4gICAgdGhpcy5faXRlbXMgPSBbXTtcblxuICAgIGNvbnN0IHN0YXJ0ID0gTWF0aC5tYXgoXG4gICAgICAwLFxuICAgICAgKE1hdGguY2VpbCh0aGlzLl9jdXJyZW50UGFnZSAvIHRoaXMuX2Rpc3BsYXlDb3VudCkgLSAxKSAqIHRoaXMuX2Rpc3BsYXlDb3VudCArIDEsXG4gICAgKTtcbiAgICBjb25zdCBlbmQgPSBNYXRoLm1pbihzdGFydCArIHRoaXMuX2Rpc3BsYXlDb3VudCAtIDEsIHRoaXMuX2xhc3RQYWdlKTtcbiAgICAvL1xuICAgIGlmIChzdGFydCA+IHRoaXMuX2Rpc3BsYXlDb3VudCkge1xuICAgICAgdGhpcy5faXRlbXMucHVzaCh7XG4gICAgICAgIGljb25DbGFzczogJ2F4LWljb24tY2hldnJvbi1sZWZ0JyxcbiAgICAgICAgZGF0YTogc3RhcnQgLSAxLFxuICAgICAgfSk7XG4gICAgfVxuICAgIC8vXG4gICAgZm9yIChsZXQgaSA9IHN0YXJ0OyBpIDw9IGVuZDsgaSsrKSB7XG4gICAgICB0aGlzLl9pdGVtcy5wdXNoKHtcbiAgICAgICAgdGV4dDogaS50b1N0cmluZygpLFxuICAgICAgICBkYXRhOiBpLFxuICAgICAgfSk7XG4gICAgfVxuICAgIGlmIChlbmQgPCB0aGlzLl9sYXN0UGFnZSkge1xuICAgICAgdGhpcy5faXRlbXMucHVzaCh7XG4gICAgICAgIGljb25DbGFzczogJ2F4LWljb24tY2hldnJvbi1yaWdodCcsXG4gICAgICAgIGRhdGE6IGVuZCArIDEsXG4gICAgICB9KTtcbiAgICB9XG4gICAgdGhpcy5jZHIuZGV0ZWN0Q2hhbmdlcygpO1xuICB9XG5cbiAgLyoqXG4gICAqICBAaWdub3JlXG4gICAqL1xuICBfaGFuZGxlT25JdGVtQ2xpY2soZTogYW55KSB7XG4gICAgaWYgKHRoaXMuX3BhcmVudC5yZWFkb25seSB8fCB0aGlzLl9wYXJlbnQuZGlzYWJsZWQpIHJldHVybjtcbiAgICB0aGlzLl9wYXJlbnQuZ29Ub1BhZ2UoTnVtYmVyKGUuZGF0YSkpO1xuICB9XG59XG4iXX0=