@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.
- package/color-palette/lib/color-palette-input.component.d.ts +6 -1
- package/cron-job/lib/cron-job-container/cron-job-container.component.d.ts +11 -13
- package/cron-job/lib/cron-job.service.d.ts +3 -3
- package/cron-job/lib/day/day.component.d.ts +3 -1
- package/cron-job/lib/day/day.service.d.ts +2 -2
- package/cron-job/lib/hours/hours.component.d.ts +3 -1
- package/cron-job/lib/hours/hours.service.d.ts +2 -2
- package/cron-job/lib/minutes/minutes.component.d.ts +3 -1
- package/cron-job/lib/minutes/minutes.service.d.ts +2 -2
- package/cron-job/lib/month/month.component.d.ts +3 -1
- package/cron-job/lib/month/month.service.d.ts +2 -2
- package/cron-job/lib/seconds/seconds.component.d.ts +3 -1
- package/cron-job/lib/seconds/seconds.service.d.ts +2 -2
- package/cron-job/lib/year/year.component.d.ts +3 -1
- package/cron-job/lib/year/year.service.d.ts +2 -2
- package/data-pager/lib/data-pager-info.component.d.ts +4 -4
- package/data-pager/lib/data-pager.component.d.ts +1 -0
- package/esm2022/badge/lib/badge.component.mjs +2 -2
- package/esm2022/button/lib/button-item-list.component.mjs +2 -2
- package/esm2022/color-palette/lib/color-palette-input.component.mjs +2 -1
- package/esm2022/color-palette/lib/color-palette-picker.component.mjs +3 -3
- package/esm2022/cron-job/lib/cron-job-container/cron-job-container.component.mjs +62 -45
- package/esm2022/cron-job/lib/cron-job.service.mjs +5 -5
- package/esm2022/cron-job/lib/day/day.component.mjs +8 -4
- package/esm2022/cron-job/lib/day/day.service.mjs +4 -4
- package/esm2022/cron-job/lib/hours/hours.component.mjs +8 -4
- package/esm2022/cron-job/lib/hours/hours.service.mjs +4 -4
- package/esm2022/cron-job/lib/minutes/minutes.component.mjs +8 -4
- package/esm2022/cron-job/lib/minutes/minutes.service.mjs +4 -4
- package/esm2022/cron-job/lib/month/month.component.mjs +8 -4
- package/esm2022/cron-job/lib/month/month.service.mjs +4 -4
- package/esm2022/cron-job/lib/seconds/seconds.component.mjs +8 -4
- package/esm2022/cron-job/lib/seconds/seconds.service.mjs +4 -4
- package/esm2022/cron-job/lib/year/year.component.mjs +8 -4
- package/esm2022/cron-job/lib/year/year.service.mjs +4 -4
- package/esm2022/data-pager/lib/data-pager-info.component.mjs +8 -7
- package/esm2022/data-pager/lib/data-pager-next-buttons.components.mjs +39 -8
- package/esm2022/data-pager/lib/data-pager-numeric-selector.component.mjs +27 -15
- package/esm2022/data-pager/lib/data-pager-pagesize-dropdown.component.mjs +3 -15
- package/esm2022/data-pager/lib/data-pager-prev-buttons.component.mjs +37 -7
- package/esm2022/data-pager/lib/data-pager.component.mjs +12 -6
- package/esm2022/image-editor/lib/image-editor-container/image-editor-container.component.mjs +5 -4
- package/esm2022/image-editor/lib/image-editor-toolbar/image-editor-toolbar.component.mjs +2 -2
- package/esm2022/image-editor/lib/image-editor-tools/image-editor-color-picker/image-editor-color-picker.component.mjs +3 -3
- package/esm2022/image-editor/lib/image-editor-view/image-editor-view.component.mjs +55 -16
- package/esm2022/image-editor/lib/image-editor.service.mjs +1 -1
- package/esm2022/list/lib/list.component.mjs +2 -2
- package/esm2022/step-wizard/lib/step-wizard.component.mjs +20 -3
- package/esm2022/tabs/lib/tabs.component.mjs +18 -13
- package/esm2022/uploader/lib/uploader-dialog-container/uploader-dialog-container.component.mjs +3 -3
- package/esm2022/uploader/lib/uploader-drop-zone/uploader-drop-zone.component.mjs +3 -3
- package/fesm2022/acorex-components-badge.mjs +2 -2
- package/fesm2022/acorex-components-badge.mjs.map +1 -1
- package/fesm2022/acorex-components-button.mjs +2 -2
- package/fesm2022/acorex-components-button.mjs.map +1 -1
- package/fesm2022/acorex-components-color-palette.mjs +3 -2
- package/fesm2022/acorex-components-color-palette.mjs.map +1 -1
- package/fesm2022/acorex-components-cron-job.mjs +109 -68
- package/fesm2022/acorex-components-cron-job.mjs.map +1 -1
- package/fesm2022/acorex-components-data-pager.mjs +123 -56
- package/fesm2022/acorex-components-data-pager.mjs.map +1 -1
- package/fesm2022/acorex-components-image-editor.mjs +60 -22
- package/fesm2022/acorex-components-image-editor.mjs.map +1 -1
- package/fesm2022/acorex-components-list.mjs +2 -2
- package/fesm2022/acorex-components-list.mjs.map +1 -1
- package/fesm2022/acorex-components-step-wizard.mjs +18 -1
- package/fesm2022/acorex-components-step-wizard.mjs.map +1 -1
- package/fesm2022/acorex-components-tabs.mjs +17 -12
- package/fesm2022/acorex-components-tabs.mjs.map +1 -1
- package/fesm2022/acorex-components-uploader.mjs +4 -4
- package/fesm2022/acorex-components-uploader.mjs.map +1 -1
- package/image-editor/lib/image-editor-container/image-editor-container.component.d.ts +2 -0
- package/image-editor/lib/image-editor-view/image-editor-view.component.d.ts +16 -3
- package/image-editor/lib/image-editor.service.d.ts +2 -2
- package/package.json +1 -1
- package/step-wizard/lib/step-wizard.component.d.ts +2 -1
- 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:
|
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 {
|
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
|
-
|
22
|
-
protected
|
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, {}, { "
|
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
|
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<
|
21
|
-
static ɵprov: i0.ɵɵInjectableDeclaration<
|
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 {
|
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:
|
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 {
|
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:
|
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 {
|
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:
|
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 {
|
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:
|
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 {
|
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:
|
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 {
|
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:
|
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
|
-
|
16
|
-
|
15
|
+
* @ignore
|
16
|
+
*/
|
17
17
|
protected _textFormatted: string;
|
18
18
|
protected translateService: AXTranslationService;
|
19
19
|
/**
|
20
|
-
|
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:.
|
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:.
|
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":"AAAA,OAAO,EAAuB,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAEjF,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACjE,OAAO,EAEL,uBAAuB,EACvB,SAAS,EACT,WAAW,EACX,MAAM,EACN,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,4BAA4B,EAAE,6BAA6B,EAAE,MAAM,uBAAuB,CAAC;;;;;;;AAEpG;;;;GAIG;AAmBH,MAAM,OAAO,4BAA6B,SAAQ,eAAe;IA2B/D;;OAEG;IACH,YAES,OAAsC,EACrC,aAA6B;QAErC,KAAK,EAAE,CAAC;QAHD,YAAO,GAAP,OAAO,CAA+B;QACrC,kBAAa,GAAb,aAAa,CAAgB;QAhCvC,YAAO,GAAG,IAAI,CAAC;QAEf,UAAK,GAAQ;YACX,CAAC,EAAE,CAAC;YACJ,CAAC,EAAE,CAAC;YACJ,CAAC,EAAE,CAAC;YACJ,CAAC,EAAE,CAAC;SACL,CAAC;QAEF,SAAI,GAAG,EAAE,CAAC;QAEV;;WAEG;QACO,eAAU,GAAmB,KAAK,CAAC;QAE7C;;WAEG;QACO,oBAAe,GAAkB;YACzC,IAAI,EAAE,gCAAgC;YACtC,OAAO,EAAE,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC,EAAE,EAAE;gBACrB,OAAO,CAAC,CAAC,UAAU,EAAE,UAAU,CAAC,GAAG,CAAC,IAAI,GAAG,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,IAAI,EAAE,CAAC;YACrF,CAAC;SACF,CAAC;QAWA,OAAO,CAAC,cAAc,CAAC,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YAC1E,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC;QACxC,CAAC,CAAC,CAAC;QACH,OAAO,CAAC,eAAe,CAAC,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YAC3E,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAC1B,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACK,WAAW,CAAC,IAAa,KAAK;QACpC,MAAM,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC;QACjC,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;YACf,IAAI,CAAC,KAAK,GAAG;gBACX,CAAC,EAAE,IAAI;gBACP,CAAC,EAAE,IAAI;gBACP,CAAC,EAAE,IAAI;gBACP,CAAC,EAAE,IAAI;aACR,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,IAAI,IAAI,CAAC,UAAU,IAAI,MAAM,EAAE,CAAC;gBAC9B,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,WAAW,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC;YAC3D,CAAC;YACD,IAAI,IAAI,CAAC,UAAU,IAAI,KAAK,EAAE,CAAC;gBAC7B,IAAI,CAAC,IAAI,GAAG,WAAW,CAAC,QAAQ,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;YACjD,CAAC;YACD,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC;gBAC5B,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC;YAC3B,CAAC;QACH,CAAC;QACD,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAED;;OAEG;IACH,eAAe;QACb,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAED;;OAEG;IACH,sBAAsB;QACpB,QAAQ,IAAI,CAAC,UAAU,EAAE,CAAC;YACxB,KAAK,MAAM;gBACT,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;gBACxB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;gBACvB,MAAM;YACR;gBACE,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC;gBACzB,MAAM;QACV,CAAC;IACH,CAAC;IAED;;OAEG;IACH,uBAAuB,CAAC,CAA8B;QACpD,IAAI,CAAC,CAAC,iBAAiB,EAAE,CAAC;YACxB,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC;YAC7B,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC;YAClC,MAAM,MAAM,GAAG,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC;YAC3C,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,WAAW,CAAC,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC,iBAAiB,CAAC,CAAC;QACtF,CAAC;IACH,CAAC;IAED;;OAEG;IACO,uBAAuB,CAAC,CAA8B;QAC9D,IAAI,CAAC,CAAC,iBAAiB,IAAI,CAAC,CAAC,KAAK,EAAE,IAAI,EAAE,IAAI,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,CAAC;YAChE,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,iBAAiB,CAAC,CAAC;QACzD,CAAC;IACH,CAAC;IAED;;OAEG;IACK,UAAU;QAChB,IAAI,CAAC,OAAO,GAAG,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAChD,CAAC;IAED;;OAEG;IACH,IACY,WAAW;QACrB,OAAO,wBAAwB,CAAC;IAClC,CAAC;8GAhIU,4BAA4B,kBA+B7B,6BAA6B;kGA/B5B,4BAA4B,wGAR5B;YACT;gBACE,OAAO,EAAE,4BAA4B;gBACrC,WAAW,EAAE,4BAA4B;aAC1C;YACD,cAAc;SACf,iDClCH,4jFA2FA;;2FDvDa,4BAA4B;kBAlBxC,SAAS;+BACE,wBAAwB,iBAOnB,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM,aACpC;wBACT;4BACE,OAAO,EAAE,4BAA4B;4BACrC,WAAW,8BAA8B;yBAC1C;wBACD,cAAc;qBACf;;0BAiCE,MAAM;2BAAC,6BAA6B;sEA+F3B,WAAW;sBADtB,WAAW;uBAAC,OAAO","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":"AAAA,OAAO,EAAuB,eAAe,EAAE,MAAM,2BAA2B,CAAC;AAEjF,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,oBAAoB,CAAC;AACjE,OAAO,EAEL,uBAAuB,EACvB,SAAS,EACT,WAAW,EACX,MAAM,EACN,iBAAiB,GAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,4BAA4B,EAAE,6BAA6B,EAAE,MAAM,uBAAuB,CAAC;;;;;;;AAEpG;;;;GAIG;AAmBH,MAAM,OAAO,4BAA6B,SAAQ,eAAe;IA2B/D;;OAEG;IACH,YAES,OAAsC,EACrC,aAA6B;QAErC,KAAK,EAAE,CAAC;QAHD,YAAO,GAAP,OAAO,CAA+B;QACrC,kBAAa,GAAb,aAAa,CAAgB;QAhCvC,YAAO,GAAG,IAAI,CAAC;QAEf,UAAK,GAAmD;YACtD,CAAC,EAAE,CAAC;YACJ,CAAC,EAAE,CAAC;YACJ,CAAC,EAAE,CAAC;YACJ,CAAC,EAAE,CAAC;SACL,CAAC;QAEF,SAAI,GAAG,EAAE,CAAC;QAEV;;WAEG;QACO,eAAU,GAAmB,KAAK,CAAC;QAE7C;;WAEG;QACO,oBAAe,GAAkB;YACzC,IAAI,EAAE,gCAAgC;YACtC,OAAO,EAAE,CAAC,GAAQ,EAAE,CAAM,EAAE,CAAM,EAAE,EAAE;gBACpC,OAAO,CAAC,CAAC,UAAU,EAAE,UAAU,CAAC,GAAG,CAAC,IAAI,GAAG,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,IAAI,EAAE,CAAC;YACrF,CAAC;SACF,CAAC;QAWA,OAAO,CAAC,cAAc,CAAC,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YAC1E,IAAI,CAAC,WAAW,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC;QACxC,CAAC,CAAC,CAAC;QACH,OAAO,CAAC,eAAe,CAAC,IAAI,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YAC3E,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAC1B,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACK,WAAW,CAAC,CAAC,GAAG,KAAK;QAC3B,MAAM,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC;QACjC,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,IAAI,CAAC,IAAI,GAAG,EAAE,CAAC;YACf,IAAI,CAAC,KAAK,GAAG;gBACX,CAAC,EAAE,IAAI;gBACP,CAAC,EAAE,IAAI;gBACP,CAAC,EAAE,IAAI;gBACP,CAAC,EAAE,IAAI;aACR,CAAC;QACJ,CAAC;aAAM,CAAC;YACN,IAAI,IAAI,CAAC,UAAU,IAAI,MAAM,EAAE,CAAC;gBAC9B,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,KAAK,EAAE,WAAW,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC,CAAC;YAC3D,CAAC;YACD,IAAI,IAAI,CAAC,UAAU,IAAI,KAAK,EAAE,CAAC;gBAC7B,IAAI,CAAC,IAAI,GAAG,WAAW,CAAC,QAAQ,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;YACjD,CAAC;YACD,IAAI,CAAC,CAAC,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC;gBAC5B,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC;YAC3B,CAAC;QACH,CAAC;QACD,IAAI,CAAC,UAAU,EAAE,CAAC;QAClB,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC;IAC3B,CAAC;IAED;;OAEG;IACH,eAAe;QACb,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAED;;OAEG;IACH,sBAAsB;QACpB,QAAQ,IAAI,CAAC,UAAU,EAAE,CAAC;YACxB,KAAK,MAAM;gBACT,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;gBACxB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;gBACvB,MAAM;YACR;gBACE,IAAI,CAAC,UAAU,GAAG,MAAM,CAAC;gBACzB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,CAAC;gBACvB,MAAM;QACV,CAAC;IACH,CAAC;IAED;;OAEG;IACH,uBAAuB,CAAC,CAA8B;QACpD,IAAI,CAAC,CAAC,iBAAiB,EAAE,CAAC;YACxB,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,KAAK,CAAC;YAC7B,MAAM,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,GAAG,IAAI,CAAC,KAAK,CAAC;YAClC,MAAM,MAAM,GAAG,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC;YAC3C,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,WAAW,CAAC,QAAQ,CAAC,MAAM,EAAE,MAAM,CAAC,EAAE,CAAC,CAAC,iBAAiB,CAAC,CAAC;QACtF,CAAC;IACH,CAAC;IAED;;OAEG;IACO,uBAAuB,CAAC,CAA8B;QAC9D,IAAI,CAAC,CAAC,iBAAiB,IAAI,CAAC,CAAC,KAAK,EAAE,IAAI,EAAE,IAAI,IAAI,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,CAAC;YAChE,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,iBAAiB,CAAC,CAAC;QACzD,CAAC;IACH,CAAC;IAED;;OAEG;IACK,UAAU;QAChB,IAAI,CAAC,OAAO,GAAG,WAAW,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAChD,CAAC;IAED;;OAEG;IACH,IACY,WAAW;QACrB,OAAO,wBAAwB,CAAC;IAClC,CAAC;8GAjIU,4BAA4B,kBA+B7B,6BAA6B;kGA/B5B,4BAA4B,wGAR5B;YACT;gBACE,OAAO,EAAE,4BAA4B;gBACrC,WAAW,EAAE,4BAA4B;aAC1C;YACD,cAAc;SACf,iDClCH,4jFA2FA;;2FDvDa,4BAA4B;kBAlBxC,SAAS;+BACE,wBAAwB,iBAOnB,iBAAiB,CAAC,IAAI,mBACpB,uBAAuB,CAAC,MAAM,aACpC;wBACT;4BACE,OAAO,EAAE,4BAA4B;4BACrC,WAAW,8BAA8B;yBAC1C;wBACD,cAAc;qBACf;;0BAiCE,MAAM;2BAAC,6BAA6B;sEAgG3B,WAAW;sBADtB,WAAW;uBAAC,OAAO","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
|
-
|
135
|
-
|
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"]}
|