@acorex/components 18.16.0-next.4 → 18.16.0-next.6

Sign up to get free protection for your applications and to get access to all the features.
Files changed (77) hide show
  1. package/color-palette/lib/color-palette-input.component.d.ts +6 -1
  2. package/cron-job/lib/cron-job-container/cron-job-container.component.d.ts +11 -13
  3. package/cron-job/lib/cron-job.service.d.ts +3 -3
  4. package/cron-job/lib/day/day.component.d.ts +3 -1
  5. package/cron-job/lib/day/day.service.d.ts +2 -2
  6. package/cron-job/lib/hours/hours.component.d.ts +3 -1
  7. package/cron-job/lib/hours/hours.service.d.ts +2 -2
  8. package/cron-job/lib/minutes/minutes.component.d.ts +3 -1
  9. package/cron-job/lib/minutes/minutes.service.d.ts +2 -2
  10. package/cron-job/lib/month/month.component.d.ts +3 -1
  11. package/cron-job/lib/month/month.service.d.ts +2 -2
  12. package/cron-job/lib/seconds/seconds.component.d.ts +3 -1
  13. package/cron-job/lib/seconds/seconds.service.d.ts +2 -2
  14. package/cron-job/lib/year/year.component.d.ts +3 -1
  15. package/cron-job/lib/year/year.service.d.ts +2 -2
  16. package/data-pager/lib/data-pager-info.component.d.ts +4 -4
  17. package/data-pager/lib/data-pager.component.d.ts +1 -0
  18. package/esm2022/badge/lib/badge.component.mjs +2 -2
  19. package/esm2022/button/lib/button-item-list.component.mjs +2 -2
  20. package/esm2022/color-palette/lib/color-palette-input.component.mjs +2 -1
  21. package/esm2022/color-palette/lib/color-palette-picker.component.mjs +3 -3
  22. package/esm2022/cron-job/lib/cron-job-container/cron-job-container.component.mjs +62 -45
  23. package/esm2022/cron-job/lib/cron-job.service.mjs +5 -5
  24. package/esm2022/cron-job/lib/day/day.component.mjs +8 -4
  25. package/esm2022/cron-job/lib/day/day.service.mjs +4 -4
  26. package/esm2022/cron-job/lib/hours/hours.component.mjs +8 -4
  27. package/esm2022/cron-job/lib/hours/hours.service.mjs +4 -4
  28. package/esm2022/cron-job/lib/minutes/minutes.component.mjs +8 -4
  29. package/esm2022/cron-job/lib/minutes/minutes.service.mjs +4 -4
  30. package/esm2022/cron-job/lib/month/month.component.mjs +8 -4
  31. package/esm2022/cron-job/lib/month/month.service.mjs +4 -4
  32. package/esm2022/cron-job/lib/seconds/seconds.component.mjs +8 -4
  33. package/esm2022/cron-job/lib/seconds/seconds.service.mjs +4 -4
  34. package/esm2022/cron-job/lib/year/year.component.mjs +8 -4
  35. package/esm2022/cron-job/lib/year/year.service.mjs +4 -4
  36. package/esm2022/data-pager/lib/data-pager-info.component.mjs +8 -7
  37. package/esm2022/data-pager/lib/data-pager-next-buttons.components.mjs +39 -8
  38. package/esm2022/data-pager/lib/data-pager-numeric-selector.component.mjs +27 -15
  39. package/esm2022/data-pager/lib/data-pager-pagesize-dropdown.component.mjs +3 -15
  40. package/esm2022/data-pager/lib/data-pager-prev-buttons.component.mjs +37 -7
  41. package/esm2022/data-pager/lib/data-pager.component.mjs +12 -6
  42. package/esm2022/image-editor/lib/image-editor-container/image-editor-container.component.mjs +5 -4
  43. package/esm2022/image-editor/lib/image-editor-toolbar/image-editor-toolbar.component.mjs +2 -2
  44. package/esm2022/image-editor/lib/image-editor-tools/image-editor-color-picker/image-editor-color-picker.component.mjs +3 -3
  45. package/esm2022/image-editor/lib/image-editor-view/image-editor-view.component.mjs +55 -16
  46. package/esm2022/image-editor/lib/image-editor.service.mjs +1 -1
  47. package/esm2022/list/lib/list.component.mjs +2 -2
  48. package/esm2022/step-wizard/lib/step-wizard.component.mjs +20 -3
  49. package/esm2022/tabs/lib/tabs.component.mjs +18 -13
  50. package/esm2022/uploader/lib/uploader-dialog-container/uploader-dialog-container.component.mjs +3 -3
  51. package/esm2022/uploader/lib/uploader-drop-zone/uploader-drop-zone.component.mjs +3 -3
  52. package/fesm2022/acorex-components-badge.mjs +2 -2
  53. package/fesm2022/acorex-components-badge.mjs.map +1 -1
  54. package/fesm2022/acorex-components-button.mjs +2 -2
  55. package/fesm2022/acorex-components-button.mjs.map +1 -1
  56. package/fesm2022/acorex-components-color-palette.mjs +3 -2
  57. package/fesm2022/acorex-components-color-palette.mjs.map +1 -1
  58. package/fesm2022/acorex-components-cron-job.mjs +109 -68
  59. package/fesm2022/acorex-components-cron-job.mjs.map +1 -1
  60. package/fesm2022/acorex-components-data-pager.mjs +123 -56
  61. package/fesm2022/acorex-components-data-pager.mjs.map +1 -1
  62. package/fesm2022/acorex-components-image-editor.mjs +60 -22
  63. package/fesm2022/acorex-components-image-editor.mjs.map +1 -1
  64. package/fesm2022/acorex-components-list.mjs +2 -2
  65. package/fesm2022/acorex-components-list.mjs.map +1 -1
  66. package/fesm2022/acorex-components-step-wizard.mjs +18 -1
  67. package/fesm2022/acorex-components-step-wizard.mjs.map +1 -1
  68. package/fesm2022/acorex-components-tabs.mjs +17 -12
  69. package/fesm2022/acorex-components-tabs.mjs.map +1 -1
  70. package/fesm2022/acorex-components-uploader.mjs +4 -4
  71. package/fesm2022/acorex-components-uploader.mjs.map +1 -1
  72. package/image-editor/lib/image-editor-container/image-editor-container.component.d.ts +2 -0
  73. package/image-editor/lib/image-editor-view/image-editor-view.component.d.ts +16 -3
  74. package/image-editor/lib/image-editor.service.d.ts +2 -2
  75. package/package.json +1 -1
  76. package/step-wizard/lib/step-wizard.component.d.ts +2 -1
  77. package/tabs/lib/tabs.component.d.ts +1 -0
@@ -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
@@ -1,4 +1,4 @@
1
- import { AXClickEvent } from '@acorex/components/common';
1
+ import { MXInputBaseValueComponent } from '@acorex/components/common';
2
2
  import { AXTabLocation, AXTabLook, AXTabsComponent } from '@acorex/components/tabs';
3
3
  import { DayService } from '../day/day.service';
4
4
  import { HoursService } from '../hours/hours.service';
@@ -7,25 +7,23 @@ import { MonthService } from '../month/month.service';
7
7
  import { SecondsService } from '../seconds/seconds.service';
8
8
  import { YearService } from '../year/year.service';
9
9
  import * as i0 from "@angular/core";
10
- export declare class AXCronJobContainerComponent {
10
+ export declare class AXCronJobContainerComponent extends MXInputBaseValueComponent<string> {
11
11
  #private;
12
+ protected secondsService: SecondsService;
13
+ protected minutesService: MinutesService;
14
+ protected hoursService: HoursService;
15
+ protected monthService: MonthService;
16
+ protected dayService: DayService;
17
+ protected yearService: YearService;
12
18
  protected tabComponent: import("@angular/core").Signal<AXTabsComponent>;
13
19
  protected activeTab: import("@angular/core").WritableSignal<string>;
14
- protected expResult: string;
15
- onExpressionChange: import("@angular/core").OutputEmitterRef<AXClickEvent>;
16
20
  protected options: import("@angular/core").WritableSignal<{
17
21
  fit: boolean;
18
22
  look: AXTabLook;
19
23
  location: AXTabLocation;
20
24
  }>;
21
- protected secondsService: SecondsService;
22
- protected minutesService: MinutesService;
23
- protected hoursService: HoursService;
24
- protected monthService: MonthService;
25
- protected dayService: DayService;
26
- protected yearService: YearService;
27
- protected onGetModel(): void;
28
- protected reverseExpression(cronExpressionPattern: string): void;
25
+ onGetModel(): void;
26
+ protected internalValueChanged(cronExpressionPattern: string): void;
29
27
  static ɵfac: i0.ɵɵFactoryDeclaration<AXCronJobContainerComponent, never>;
30
- static ɵcmp: i0.ɵɵComponentDeclaration<AXCronJobContainerComponent, "ax-cron-job-container", never, {}, { "onExpressionChange": "onExpressionChange"; }, never, never, false, never>;
28
+ static ɵcmp: i0.ɵɵComponentDeclaration<AXCronJobContainerComponent, "ax-cron-job-container", never, {}, { "onValueChanged": "onValueChanged"; }, never, never, false, never>;
31
29
  }
@@ -1,6 +1,6 @@
1
1
  import { DropDownItem, RegexItemsIndex } from './types/shared.model';
2
2
  import * as i0 from "@angular/core";
3
- export declare class StringService {
3
+ export declare class CronJobService {
4
4
  addComma(str: string): string;
5
5
  getRegexItem(cronExpressionPattern: string, itemIndex: RegexItemsIndex): string;
6
6
  getIntervalCronData(regex: string): {
@@ -17,6 +17,6 @@ export declare class StringService {
17
17
  xst: number;
18
18
  } | undefined;
19
19
  mapItemsToDropDownItem(items: Array<string>, dropDowndata?: Array<string>): Array<DropDownItem>;
20
- static ɵfac: i0.ɵɵFactoryDeclaration<StringService, never>;
21
- static ɵprov: i0.ɵɵInjectableDeclaration<StringService>;
20
+ static ɵfac: i0.ɵɵFactoryDeclaration<CronJobService, never>;
21
+ static ɵprov: i0.ɵɵInjectableDeclaration<CronJobService>;
22
22
  }
@@ -9,6 +9,8 @@ export declare class AXCronDayComponent {
9
9
  protected boMonthDropDownList: DropDownItem[];
10
10
  protected daysIndexInMonth: number[];
11
11
  protected zeroTo30: number[];
12
+ dayChanged: import("@angular/core").OutputEmitterRef<void>;
13
+ protected inputChange(): void;
12
14
  protected changeHandler(e: AXValueChangedEvent): void;
13
15
  protected changeHandler2(e: AXValueChangedEvent): void;
14
16
  protected get daysList(): Array<string>;
@@ -18,5 +20,5 @@ export declare class AXCronDayComponent {
18
20
  protected get isBoMonthCustom(): boolean;
19
21
  protected get isBoMonthBefore(): boolean;
20
22
  static ɵfac: i0.ɵɵFactoryDeclaration<AXCronDayComponent, never>;
21
- static ɵcmp: i0.ɵɵComponentDeclaration<AXCronDayComponent, "ax-cron-day", never, {}, {}, never, never, false, never>;
23
+ static ɵcmp: i0.ɵɵComponentDeclaration<AXCronDayComponent, "ax-cron-day", never, {}, { "dayChanged": "dayChanged"; }, never, never, false, never>;
22
24
  }
@@ -1,4 +1,4 @@
1
- import { StringService } from '../cron-job.service';
1
+ import { CronJobService } from '../cron-job.service';
2
2
  import { IExpression } from '../types/iexpression';
3
3
  import { Day } from './day.model';
4
4
  import * as i0 from "@angular/core";
@@ -6,7 +6,7 @@ export declare class DayService implements IExpression {
6
6
  private stringService;
7
7
  dayModel: Day;
8
8
  daysList: Array<string>;
9
- constructor(stringService: StringService);
9
+ constructor(stringService: CronJobService);
10
10
  getExpression(): any;
11
11
  expressionValidation(preCronExpressionPattern: string, newCronExpressionPattern: string): string;
12
12
  reversExpression(cronExpressionPattern: string): void;
@@ -7,8 +7,10 @@ export declare class AXCronHoursComponent {
7
7
  hoursService: HoursService;
8
8
  protected dropdownList: DropDownItem[];
9
9
  protected zeroTo23: number[];
10
+ hoursChanged: import("@angular/core").OutputEmitterRef<void>;
11
+ protected inputChange(): void;
10
12
  protected changeHandler(e: AXValueChangedEvent): void;
11
13
  protected get isCustom(): boolean;
12
14
  static ɵfac: i0.ɵɵFactoryDeclaration<AXCronHoursComponent, never>;
13
- static ɵcmp: i0.ɵɵComponentDeclaration<AXCronHoursComponent, "ax-cron-hours", never, {}, {}, never, never, false, never>;
15
+ static ɵcmp: i0.ɵɵComponentDeclaration<AXCronHoursComponent, "ax-cron-hours", never, {}, { "hoursChanged": "hoursChanged"; }, never, never, false, never>;
14
16
  }
@@ -1,11 +1,11 @@
1
- import { StringService } from '../cron-job.service';
1
+ import { CronJobService } from '../cron-job.service';
2
2
  import { IExpression } from '../types/iexpression';
3
3
  import { Hours } from './hours.model';
4
4
  import * as i0 from "@angular/core";
5
5
  export declare class HoursService implements IExpression {
6
6
  private stringService;
7
7
  hourModel: Hours;
8
- constructor(stringService: StringService);
8
+ constructor(stringService: CronJobService);
9
9
  getExpression(): string;
10
10
  reversExpression(cronExpressionPattern: string): void;
11
11
  static ɵfac: i0.ɵɵFactoryDeclaration<HoursService, never>;
@@ -7,8 +7,10 @@ export declare class AXCronMinutesComponent {
7
7
  protected minutesService: MinutesService;
8
8
  protected dropdownList: DropDownItem[];
9
9
  protected zeroTo59: number[];
10
+ minutesChanged: import("@angular/core").OutputEmitterRef<void>;
11
+ protected inputChange(): void;
10
12
  protected changeHandler(e: AXValueChangedEvent): void;
11
13
  protected get isCustom(): boolean;
12
14
  static ɵfac: i0.ɵɵFactoryDeclaration<AXCronMinutesComponent, never>;
13
- static ɵcmp: i0.ɵɵComponentDeclaration<AXCronMinutesComponent, "ax-cron-minutes", never, {}, {}, never, never, false, never>;
15
+ static ɵcmp: i0.ɵɵComponentDeclaration<AXCronMinutesComponent, "ax-cron-minutes", never, {}, { "minutesChanged": "minutesChanged"; }, never, never, false, never>;
14
16
  }
@@ -1,11 +1,11 @@
1
- import { StringService } from '../cron-job.service';
1
+ import { CronJobService } from '../cron-job.service';
2
2
  import { IExpression } from '../types/iexpression';
3
3
  import { Minutes } from './minutes.model';
4
4
  import * as i0 from "@angular/core";
5
5
  export declare class MinutesService implements IExpression {
6
6
  private stringService;
7
7
  minuteModel: Minutes;
8
- constructor(stringService: StringService);
8
+ constructor(stringService: CronJobService);
9
9
  getExpression(): string;
10
10
  reversExpression(cronExpressionPattern: string): void;
11
11
  static ɵfac: i0.ɵɵFactoryDeclaration<MinutesService, never>;
@@ -8,9 +8,11 @@ export declare class AXCronMonthComponent {
8
8
  protected dropdownList: DropDownItem[];
9
9
  protected dropdownList2: DropDownItem[];
10
10
  protected oneTo12: DropDownItem[];
11
+ monthChanged: import("@angular/core").OutputEmitterRef<void>;
12
+ protected inputChange(): void;
11
13
  protected changeHandler(e: AXValueChangedEvent): void;
12
14
  protected get isCustom(): boolean;
13
15
  protected get monthsList(): Array<string>;
14
16
  static ɵfac: i0.ɵɵFactoryDeclaration<AXCronMonthComponent, never>;
15
- static ɵcmp: i0.ɵɵComponentDeclaration<AXCronMonthComponent, "ax-cron-month", never, {}, {}, never, never, false, never>;
17
+ static ɵcmp: i0.ɵɵComponentDeclaration<AXCronMonthComponent, "ax-cron-month", never, {}, { "monthChanged": "monthChanged"; }, never, never, false, never>;
16
18
  }
@@ -1,4 +1,4 @@
1
- import { StringService } from '../cron-job.service';
1
+ import { CronJobService } from '../cron-job.service';
2
2
  import { IExpression } from '../types/iexpression';
3
3
  import { Month } from './month.model';
4
4
  import * as i0 from "@angular/core";
@@ -6,7 +6,7 @@ export declare class MonthService implements IExpression {
6
6
  private stringService;
7
7
  monthModel: Month;
8
8
  monthList: Array<string>;
9
- constructor(stringService: StringService);
9
+ constructor(stringService: CronJobService);
10
10
  getExpression(): string;
11
11
  reversExpression(cronExpressionPattern: string): void;
12
12
  static ɵfac: i0.ɵɵFactoryDeclaration<MonthService, never>;
@@ -5,10 +5,12 @@ import * as i0 from "@angular/core";
5
5
  export declare class AXCronSecondsComponent {
6
6
  #private;
7
7
  protected secondsService: SecondsService;
8
+ secondsChanged: import("@angular/core").OutputEmitterRef<void>;
8
9
  protected dropdownList: DropDownItem[];
9
10
  protected zeroTo59: number[];
11
+ protected inputChange(): void;
10
12
  protected changeHandler(e: AXValueChangedEvent): void;
11
13
  protected get isCustom(): boolean;
12
14
  static ɵfac: i0.ɵɵFactoryDeclaration<AXCronSecondsComponent, never>;
13
- static ɵcmp: i0.ɵɵComponentDeclaration<AXCronSecondsComponent, "ax-cron-seconds", never, {}, {}, never, never, false, never>;
15
+ static ɵcmp: i0.ɵɵComponentDeclaration<AXCronSecondsComponent, "ax-cron-seconds", never, {}, { "secondsChanged": "secondsChanged"; }, never, never, false, never>;
14
16
  }
@@ -1,11 +1,11 @@
1
- import { StringService } from '../cron-job.service';
1
+ import { CronJobService } from '../cron-job.service';
2
2
  import { IExpression } from '../types/iexpression';
3
3
  import { Seconds } from './seconds.model';
4
4
  import * as i0 from "@angular/core";
5
5
  export declare class SecondsService implements IExpression {
6
6
  private stringService;
7
7
  secondModel: Seconds;
8
- constructor(stringService: StringService);
8
+ constructor(stringService: CronJobService);
9
9
  getExpression(): string;
10
10
  reversExpression(cronExpressionPattern: string): void;
11
11
  static ɵfac: i0.ɵɵFactoryDeclaration<SecondsService, never>;
@@ -7,9 +7,11 @@ export declare class AXCronYearComponent {
7
7
  yearService: YearService;
8
8
  protected dropdownList: DropDownItem[];
9
9
  protected oneTo100: DropDownItem[];
10
+ yearChanged: import("@angular/core").OutputEmitterRef<void>;
11
+ protected inputChange(): void;
10
12
  protected changeHandler(e: AXValueChangedEvent): void;
11
13
  protected get isCustom(): boolean;
12
14
  protected getYearByOffset(offset: number): number;
13
15
  static ɵfac: i0.ɵɵFactoryDeclaration<AXCronYearComponent, never>;
14
- static ɵcmp: i0.ɵɵComponentDeclaration<AXCronYearComponent, "ax-cron-year", never, {}, {}, never, never, false, never>;
16
+ static ɵcmp: i0.ɵɵComponentDeclaration<AXCronYearComponent, "ax-cron-year", never, {}, { "yearChanged": "yearChanged"; }, never, never, false, never>;
15
17
  }
@@ -1,10 +1,10 @@
1
- import { StringService } from '../cron-job.service';
1
+ import { CronJobService } from '../cron-job.service';
2
2
  import { Year } from './year.model';
3
3
  import * as i0 from "@angular/core";
4
4
  export declare class YearService {
5
5
  private stringService;
6
6
  yearModel: Year;
7
- constructor(stringService: StringService);
7
+ constructor(stringService: CronJobService);
8
8
  getExpression(): string;
9
9
  reversExpression(cronExpressionPattern: string): void;
10
10
  static ɵfac: i0.ɵɵFactoryDeclaration<YearService, never>;
@@ -12,13 +12,13 @@ export declare class AXDataPagerInfoComponent extends AXDataPagerChild {
12
12
  */
13
13
  text: string;
14
14
  /**
15
- * @ignore
16
- */
15
+ * @ignore
16
+ */
17
17
  protected _textFormatted: string;
18
18
  protected translateService: AXTranslationService;
19
19
  /**
20
- * @ignore
21
- */
20
+ * @ignore
21
+ */
22
22
  protected applyParent(): void;
23
23
  static ɵfac: i0.ɵɵFactoryDeclaration<AXDataPagerInfoComponent, never>;
24
24
  static ɵcmp: i0.ɵɵComponentDeclaration<AXDataPagerInfoComponent, "ax-data-pager-info", never, { "text": { "alias": "text"; "required": false; }; }, {}, never, never, false, never>;
@@ -145,6 +145,7 @@ export declare class AXDataPagerComponent extends MXValueComponent<number> {
145
145
  * @ignore
146
146
  */
147
147
  goToPage(page: number): void;
148
+ get __hostClass(): string;
148
149
  static ɵfac: i0.ɵɵFactoryDeclaration<AXDataPagerComponent, [{ optional: true; }]>;
149
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>;
150
151
  }
@@ -18,11 +18,11 @@ export class AXBadgeComponent extends MXColorLookComponent {
18
18
  return `ax-el-${this.color}-${this.look} ${!this.text() ? 'ax-mini-badge' : ''} ${this.text()?.length == 1 ? 'ax-single-badge' : ''}`;
19
19
  }
20
20
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXBadgeComponent, deps: null, target: i0.ɵɵFactoryTarget.Component }); }
21
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: AXBadgeComponent, selector: "ax-badge", inputs: { color: { classPropertyName: "color", publicName: "color", isSignal: false, isRequired: false, transformFunction: null }, look: { classPropertyName: "look", publicName: "look", isSignal: false, isRequired: false, transformFunction: null }, text: { classPropertyName: "text", publicName: "text", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class": "this.__hostClass" } }, usesInheritance: true, ngImport: i0, template: "<ng-content select=\"ax-prefix\"></ng-content>\n@if (text) {\n <span class=\"ax-badge-text\">{{ text() }}</span>\n}\n<ng-content select=\"ax-suffix\"></ng-content>\n", styles: ["ax-badge{display:inline-block;border-radius:9999px;border-width:1px;border-color:transparent;font-size:.75rem}ax-badge.ax-mini-badge{height:.5rem;width:.5rem}ax-badge.ax-mini-badge .ax-badge-text{display:none}ax-badge.ax-single-badge{display:flex;height:1.25rem;width:1.25rem;align-items:center;justify-content:center}ax-badge.ax-single-badge .ax-badge-text{padding:0}ax-badge .ax-badge-text{white-space:nowrap;word-break:break-all;padding:.25rem .375rem}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
21
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.0", type: AXBadgeComponent, selector: "ax-badge", inputs: { color: { classPropertyName: "color", publicName: "color", isSignal: false, isRequired: false, transformFunction: null }, look: { classPropertyName: "look", publicName: "look", isSignal: false, isRequired: false, transformFunction: null }, text: { classPropertyName: "text", publicName: "text", isSignal: true, isRequired: false, transformFunction: null } }, host: { properties: { "class": "this.__hostClass" } }, usesInheritance: true, ngImport: i0, template: "<ng-content select=\"ax-prefix\"></ng-content>\n@if (text) {\n <span class=\"ax-badge-text\">{{ text() }}</span>\n}\n<ng-content select=\"ax-suffix\"></ng-content>\n", styles: ["ax-badge{display:inline-block;border-radius:9999px;border-width:1px;border-color:transparent;font-size:.75rem;max-height:fit-content}ax-badge.ax-mini-badge{height:.5rem;width:.5rem}ax-badge.ax-mini-badge .ax-badge-text{display:none}ax-badge.ax-single-badge{display:flex;height:1.25rem;width:1.25rem;align-items:center;justify-content:center}ax-badge.ax-single-badge .ax-badge-text{padding:0}ax-badge .ax-badge-text{white-space:nowrap;word-break:break-all;padding:.25rem .375rem}\n"], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
22
22
  }
23
23
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXBadgeComponent, decorators: [{
24
24
  type: Component,
25
- args: [{ selector: 'ax-badge', inputs: ['color', 'look'], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-content select=\"ax-prefix\"></ng-content>\n@if (text) {\n <span class=\"ax-badge-text\">{{ text() }}</span>\n}\n<ng-content select=\"ax-suffix\"></ng-content>\n", styles: ["ax-badge{display:inline-block;border-radius:9999px;border-width:1px;border-color:transparent;font-size:.75rem}ax-badge.ax-mini-badge{height:.5rem;width:.5rem}ax-badge.ax-mini-badge .ax-badge-text{display:none}ax-badge.ax-single-badge{display:flex;height:1.25rem;width:1.25rem;align-items:center;justify-content:center}ax-badge.ax-single-badge .ax-badge-text{padding:0}ax-badge .ax-badge-text{white-space:nowrap;word-break:break-all;padding:.25rem .375rem}\n"] }]
25
+ args: [{ selector: 'ax-badge', inputs: ['color', 'look'], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<ng-content select=\"ax-prefix\"></ng-content>\n@if (text) {\n <span class=\"ax-badge-text\">{{ text() }}</span>\n}\n<ng-content select=\"ax-suffix\"></ng-content>\n", styles: ["ax-badge{display:inline-block;border-radius:9999px;border-width:1px;border-color:transparent;font-size:.75rem;max-height:fit-content}ax-badge.ax-mini-badge{height:.5rem;width:.5rem}ax-badge.ax-mini-badge .ax-badge-text{display:none}ax-badge.ax-single-badge{display:flex;height:1.25rem;width:1.25rem;align-items:center;justify-content:center}ax-badge.ax-single-badge .ax-badge-text{padding:0}ax-badge .ax-badge-text{white-space:nowrap;word-break:break-all;padding:.25rem .375rem}\n"] }]
26
26
  }], propDecorators: { __hostClass: [{
27
27
  type: HostBinding,
28
28
  args: ['class']
@@ -111,7 +111,7 @@ export class AXButtonItemListComponent extends MXInteractiveComponent {
111
111
  }
112
112
  }
113
113
  <ng-content select="ax-button-item, ax-title, ax-divider, ng-container"></ng-content>
114
- `, isInline: true, styles: ["ax-button-item-list{padding:.5rem}ax-button-item-list.ax-action-list .ax-action-item{border-radius:var(--ax-rounded-border-default);margin-bottom:.25rem}\n"], dependencies: [{ kind: "component", type: i1.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "component", type: i1.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: "component", type: i2.AXButtonItemComponent, selector: "ax-button-item", inputs: ["color", "disabled", "text", "selected", "divided", "data", "name"], outputs: ["onClick", "onFocus", "onBlur", "disabledChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
114
+ `, isInline: true, styles: ["ax-button-item-list.ax-action-list{padding:.25rem 0}ax-button-item-list.ax-action-list .ax-action-item:not(ax-button-item-list.ax-action-list .ax-action-item:last-child){margin-bottom:.25rem}\n"], dependencies: [{ kind: "component", type: i1.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { kind: "component", type: i1.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: "component", type: i2.AXButtonItemComponent, selector: "ax-button-item", inputs: ["color", "disabled", "text", "selected", "divided", "data", "name"], outputs: ["onClick", "onFocus", "onBlur", "disabledChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
115
115
  }
116
116
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImport: i0, type: AXButtonItemListComponent, decorators: [{
117
117
  type: Component,
@@ -135,7 +135,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
135
135
  }
136
136
  }
137
137
  <ng-content select="ax-button-item, ax-title, ax-divider, ng-container"></ng-content>
138
- `, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, styles: ["ax-button-item-list{padding:.5rem}ax-button-item-list.ax-action-list .ax-action-item{border-radius:var(--ax-rounded-border-default);margin-bottom:.25rem}\n"] }]
138
+ `, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, styles: ["ax-button-item-list.ax-action-list{padding:.25rem 0}ax-button-item-list.ax-action-list .ax-action-item:not(ax-button-item-list.ax-action-list .ax-action-item:last-child){margin-bottom:.25rem}\n"] }]
139
139
  }], ctorParameters: () => [{ type: i3.AXClosbaleComponent, decorators: [{
140
140
  type: Optional
141
141
  }, {
@@ -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"]}
@@ -131,8 +131,8 @@ export class AXColorPalettePickerComponent extends MXBaseComponent {
131
131
  }
132
132
  const surface = this.getHostElement().querySelector('.ax-color-box-overlay');
133
133
  const pointer = this.getHostElement().querySelector('.ax-color-box-pointer');
134
- let x = e.offsetX;
135
- let y = e.offsetY;
134
+ const x = e.offsetX;
135
+ const y = e.offsetY;
136
136
  this.setColorByXY(x, y);
137
137
  }
138
138
  /**
@@ -248,4 +248,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
248
248
  type: HostBinding,
249
249
  args: ['class']
250
250
  }] } });
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"]}
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 = 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","<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"]}