@acorex/components 5.3.2 → 5.4.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/lib/base/components.class.mjs +8 -1
- package/esm2020/lib/base/mixin/base-menu-mixin.class.mjs +6 -3
- package/esm2020/lib/color-palette/color-palette-input.component.mjs +67 -0
- package/esm2020/lib/color-palette/color-palette-picker.component.mjs +17 -0
- package/esm2020/lib/color-palette/color-palette-preview.component.mjs +36 -0
- package/esm2020/lib/color-palette/color-palette-swatches.component.mjs +261 -0
- package/esm2020/lib/color-palette/color-palette.class.mjs +10 -0
- package/esm2020/lib/color-palette/color-palette.component.mjs +46 -0
- package/esm2020/lib/color-palette/color-palette.module.mjs +54 -0
- package/esm2020/lib/color-palette/index.mjs +7 -0
- package/esm2020/lib/color-picker/color-picker.component.mjs +19 -262
- package/esm2020/lib/color-picker/color-picker.module.mjs +12 -6
- package/esm2020/lib/menu/menu.component.mjs +31 -5
- package/esm2020/lib/selectbox/selectbox.component.mjs +2 -1
- package/esm2020/public-api.mjs +2 -1
- package/fesm2015/acorex-components.mjs +1396 -1154
- package/fesm2015/acorex-components.mjs.map +1 -1
- package/fesm2020/acorex-components.mjs +1252 -1014
- package/fesm2020/acorex-components.mjs.map +1 -1
- package/lib/base/components.class.d.ts +8 -0
- package/lib/base/mixin/base-menu-mixin.class.d.ts +1 -1
- package/lib/base/mixin/mixin.class.d.ts +1 -1
- package/lib/color-palette/color-palette-input.component.d.ts +15 -0
- package/lib/color-palette/color-palette-picker.component.d.ts +8 -0
- package/lib/color-palette/color-palette-preview.component.d.ts +12 -0
- package/lib/color-palette/color-palette-swatches.component.d.ts +16 -0
- package/lib/color-palette/color-palette.class.d.ts +12 -0
- package/lib/color-palette/color-palette.component.d.ts +18 -0
- package/lib/color-palette/color-palette.module.d.ts +17 -0
- package/lib/color-palette/index.d.ts +6 -0
- package/lib/color-picker/color-picker.component.d.ts +159 -35
- package/lib/color-picker/color-picker.module.d.ts +2 -1
- package/lib/menu/menu.component.d.ts +8 -2
- package/package.json +4 -4
- package/public-api.d.ts +1 -0
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output, ViewEncapsulation } from '@angular/core';
|
|
2
|
+
import { Subject } from 'rxjs';
|
|
3
|
+
import { AXBaseValueComponentMixin } from '../base';
|
|
4
|
+
import { INTERACTIVE_INPUTS, INTERACTIVE_OUTPUT } from '../base/mixin/interactive-mixin.class';
|
|
5
|
+
import { VALUE_INPUTS, VALUE_OUTPUT } from '../base/mixin/value-mixin.class';
|
|
6
|
+
import { AXColorComponent } from './color-palette.class';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
import * as i1 from "./color-palette-preview.component";
|
|
9
|
+
import * as i2 from "./color-palette-swatches.component";
|
|
10
|
+
import * as i3 from "./color-palette-input.component";
|
|
11
|
+
import * as i4 from "@angular/common";
|
|
12
|
+
export class AXColorPalleteComponent extends AXBaseValueComponentMixin {
|
|
13
|
+
constructor(elementRef, cdr) {
|
|
14
|
+
super(elementRef, cdr);
|
|
15
|
+
this._onInternalColorChanged$ = new Subject();
|
|
16
|
+
this.modeChange = new EventEmitter();
|
|
17
|
+
this._mode = 'hex';
|
|
18
|
+
//
|
|
19
|
+
this._onInternalColorChanged$.subscribe(e => {
|
|
20
|
+
this.value = e.color;
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
/**
|
|
24
|
+
* A character value that specifies the separator character.
|
|
25
|
+
*/
|
|
26
|
+
get mode() {
|
|
27
|
+
return this._mode;
|
|
28
|
+
}
|
|
29
|
+
set mode(v) {
|
|
30
|
+
this._setOption({
|
|
31
|
+
name: "mode",
|
|
32
|
+
value: v,
|
|
33
|
+
});
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
AXColorPalleteComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: AXColorPalleteComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
37
|
+
AXColorPalleteComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.9", type: AXColorPalleteComponent, selector: "ax-color-palette", inputs: { disabled: "disabled", tabIndex: "tabIndex", readonly: "readonly", allowNull: "allowNull", value: "value", debounceTime: "debounceTime", name: "name", checked: "checked", mode: "mode" }, outputs: { onBlur: "onBlur", onFocus: "onFocus", valueChange: "valueChange", onValueChanged: "onValueChanged", modeChange: "modeChange" }, providers: [{ provide: AXColorComponent, useExisting: AXColorPalleteComponent }], usesInheritance: true, ngImport: i0, template: "<ng-content select='ax-header'></ng-content>\r\n\r\n<ng-container [ngTemplateOutlet]=\"default\"></ng-container>\r\n\r\n<ng-template #default>\r\n <ax-color-palette-preview></ax-color-palette-preview>\r\n <ax-color-palette-swatches></ax-color-palette-swatches>\r\n <ng-content select=\"ax-color-palette-favorite\"></ng-content>\r\n <ax-color-palette-input></ax-color-palette-input>\r\n</ng-template>\r\n<ng-content select='ax-footer'></ng-content>", components: [{ type: i1.AXColorPalettePreviewComponent, selector: "ax-color-palette-preview" }, { type: i2.AXColorPaletteSwatchesComponent, selector: "ax-color-palette-swatches, ax-color-palette-favorite", inputs: ["colors"] }, { type: i3.AXColorPaletteInputComponent, selector: "ax-color-palette-input" }], directives: [{ type: i4.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
38
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: AXColorPalleteComponent, decorators: [{
|
|
39
|
+
type: Component,
|
|
40
|
+
args: [{ selector: 'ax-color-palette', changeDetection: ChangeDetectionStrategy.OnPush, inputs: [...INTERACTIVE_INPUTS, ...VALUE_INPUTS], outputs: [...INTERACTIVE_OUTPUT, ...VALUE_OUTPUT], encapsulation: ViewEncapsulation.None, providers: [{ provide: AXColorComponent, useExisting: AXColorPalleteComponent }], template: "<ng-content select='ax-header'></ng-content>\r\n\r\n<ng-container [ngTemplateOutlet]=\"default\"></ng-container>\r\n\r\n<ng-template #default>\r\n <ax-color-palette-preview></ax-color-palette-preview>\r\n <ax-color-palette-swatches></ax-color-palette-swatches>\r\n <ng-content select=\"ax-color-palette-favorite\"></ng-content>\r\n <ax-color-palette-input></ax-color-palette-input>\r\n</ng-template>\r\n<ng-content select='ax-footer'></ng-content>" }]
|
|
41
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { modeChange: [{
|
|
42
|
+
type: Output
|
|
43
|
+
}], mode: [{
|
|
44
|
+
type: Input
|
|
45
|
+
}] } });
|
|
46
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sb3ItcGFsZXR0ZS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hY29yZXgvY29tcG9uZW50cy9zcmMvbGliL2NvbG9yLXBhbGV0dGUvY29sb3ItcGFsZXR0ZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hY29yZXgvY29tcG9uZW50cy9zcmMvbGliL2NvbG9yLXBhbGV0dGUvY29sb3ItcGFsZXR0ZS5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEVBQUUsdUJBQXVCLEVBQXFCLFNBQVMsRUFBYyxZQUFZLEVBQUUsS0FBSyxFQUFFLE1BQU0sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNsSixPQUFPLEVBQUUsT0FBTyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBQy9CLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLFNBQVMsQ0FBQztBQUNwRCxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUMvRixPQUFPLEVBQUUsWUFBWSxFQUFFLFlBQVksRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQzdFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDOzs7Ozs7QUFXekQsTUFBTSxPQUFPLHVCQUF3QixTQUFRLHlCQUF5QjtJQXlCbEUsWUFBWSxVQUFzQixFQUFFLEdBQXNCO1FBQ3RELEtBQUssQ0FBQyxVQUFVLEVBQUUsR0FBRyxDQUFDLENBQUM7UUF4QjNCLDZCQUF3QixHQUFpQixJQUFJLE9BQU8sRUFBTyxDQUFDO1FBSTVELGVBQVUsR0FBOEIsSUFBSSxZQUFZLEVBQWUsQ0FBQztRQUNoRSxVQUFLLEdBQWlCLEtBQUssQ0FBQztRQW9CaEMsRUFBRTtRQUNGLElBQUksQ0FBQyx3QkFBd0IsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLEVBQUU7WUFDeEMsSUFBSSxDQUFDLEtBQUssR0FBRyxDQUFDLENBQUMsS0FBSyxDQUFDO1FBQ3pCLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQXZCRDs7TUFFRTtJQUNGLElBQ1csSUFBSTtRQUNiLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQztJQUNwQixDQUFDO0lBQ0QsSUFBVyxJQUFJLENBQUMsQ0FBYztRQUM1QixJQUFJLENBQUMsVUFBVSxDQUFDO1lBQ2QsSUFBSSxFQUFFLE1BQU07WUFDWixLQUFLLEVBQUUsQ0FBQztTQUNULENBQUMsQ0FBQTtJQUNKLENBQUM7O29IQXBCUSx1QkFBdUI7d0dBQXZCLHVCQUF1QiwwWEFGckIsQ0FBQyxFQUFFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxXQUFXLEVBQUUsdUJBQXVCLEVBQUUsQ0FBQyxpRENmcEYsNmNBVTRDOzJGRE8vQix1QkFBdUI7a0JBVG5DLFNBQVM7K0JBQ0ksa0JBQWtCLG1CQUVYLHVCQUF1QixDQUFDLE1BQU0sVUFDdkMsQ0FBQyxHQUFHLGtCQUFrQixFQUFFLEdBQUcsWUFBWSxDQUFDLFdBQ3ZDLENBQUMsR0FBRyxrQkFBa0IsRUFBRSxHQUFHLFlBQVksQ0FBQyxpQkFDbEMsaUJBQWlCLENBQUMsSUFBSSxhQUMxQixDQUFDLEVBQUUsT0FBTyxFQUFFLGdCQUFnQixFQUFFLFdBQVcseUJBQXlCLEVBQUUsQ0FBQztpSUFRaEYsVUFBVTtzQkFEVCxNQUFNO2dCQU9JLElBQUk7c0JBRGQsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEFYQ29sb3JNb2RlIH0gZnJvbSAnQGFjb3JleC9jb3JlJztcclxuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENoYW5nZURldGVjdG9yUmVmLCBDb21wb25lbnQsIEVsZW1lbnRSZWYsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE91dHB1dCwgVmlld0VuY2Fwc3VsYXRpb24gfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgU3ViamVjdCB9IGZyb20gJ3J4anMnO1xyXG5pbXBvcnQgeyBBWEJhc2VWYWx1ZUNvbXBvbmVudE1peGluIH0gZnJvbSAnLi4vYmFzZSc7XHJcbmltcG9ydCB7IElOVEVSQUNUSVZFX0lOUFVUUywgSU5URVJBQ1RJVkVfT1VUUFVUIH0gZnJvbSAnLi4vYmFzZS9taXhpbi9pbnRlcmFjdGl2ZS1taXhpbi5jbGFzcyc7XHJcbmltcG9ydCB7IFZBTFVFX0lOUFVUUywgVkFMVUVfT1VUUFVUIH0gZnJvbSAnLi4vYmFzZS9taXhpbi92YWx1ZS1taXhpbi5jbGFzcyc7XHJcbmltcG9ydCB7IEFYQ29sb3JDb21wb25lbnQgfSBmcm9tICcuL2NvbG9yLXBhbGV0dGUuY2xhc3MnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgICBzZWxlY3RvcjogJ2F4LWNvbG9yLXBhbGV0dGUnLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL2NvbG9yLXBhbGV0dGUuY29tcG9uZW50Lmh0bWwnLFxyXG4gICAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2gsXHJcbiAgICBpbnB1dHM6IFsuLi5JTlRFUkFDVElWRV9JTlBVVFMsIC4uLlZBTFVFX0lOUFVUU10sXHJcbiAgICBvdXRwdXRzOiBbLi4uSU5URVJBQ1RJVkVfT1VUUFVULCAuLi5WQUxVRV9PVVRQVVRdLFxyXG4gICAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcclxuICAgIHByb3ZpZGVyczogW3sgcHJvdmlkZTogQVhDb2xvckNvbXBvbmVudCwgdXNlRXhpc3Rpbmc6IEFYQ29sb3JQYWxsZXRlQ29tcG9uZW50IH1dXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBWENvbG9yUGFsbGV0ZUNvbXBvbmVudCBleHRlbmRzIEFYQmFzZVZhbHVlQ29tcG9uZW50TWl4aW4ge1xyXG5cclxuICAgIF9vbkludGVybmFsQ29sb3JDaGFuZ2VkJDogU3ViamVjdDxhbnk+ID0gbmV3IFN1YmplY3Q8YW55PigpO1xyXG5cclxuXHJcbiAgICBAT3V0cHV0KClcclxuICAgIG1vZGVDaGFuZ2U6IEV2ZW50RW1pdHRlcjxBWENvbG9yTW9kZT4gPSBuZXcgRXZlbnRFbWl0dGVyPEFYQ29sb3JNb2RlPigpO1xyXG4gICAgcHJpdmF0ZSBfbW9kZTogQVhDb2xvck1vZGUgPSAgJ2hleCc7XHJcbiAgICAvKipcclxuICAgICogIEEgY2hhcmFjdGVyIHZhbHVlIHRoYXQgc3BlY2lmaWVzIHRoZSBzZXBhcmF0b3IgY2hhcmFjdGVyLlxyXG4gICAgKi9cclxuICAgIEBJbnB1dCgpXHJcbiAgICBwdWJsaWMgZ2V0IG1vZGUoKTogQVhDb2xvck1vZGUge1xyXG4gICAgICByZXR1cm4gdGhpcy5fbW9kZTtcclxuICAgIH1cclxuICAgIHB1YmxpYyBzZXQgbW9kZSh2OiBBWENvbG9yTW9kZSkge1xyXG4gICAgICB0aGlzLl9zZXRPcHRpb24oe1xyXG4gICAgICAgIG5hbWU6IFwibW9kZVwiLFxyXG4gICAgICAgIHZhbHVlOiB2LFxyXG4gICAgICB9KVxyXG4gICAgfVxyXG4gICAgXHJcblxyXG5cclxuXHJcbiAgICBjb25zdHJ1Y3RvcihlbGVtZW50UmVmOiBFbGVtZW50UmVmLCBjZHI6IENoYW5nZURldGVjdG9yUmVmKSB7XHJcbiAgICAgICAgc3VwZXIoZWxlbWVudFJlZiwgY2RyKTtcclxuICAgICAgICAvL1xyXG4gICAgICAgIHRoaXMuX29uSW50ZXJuYWxDb2xvckNoYW5nZWQkLnN1YnNjcmliZShlID0+IHtcclxuICAgICAgICAgICAgdGhpcy52YWx1ZSA9IGUuY29sb3I7XHJcbiAgICAgICAgfSk7XHJcbiAgICB9XHJcblxyXG59XHJcbiIsIjxuZy1jb250ZW50IHNlbGVjdD0nYXgtaGVhZGVyJz48L25nLWNvbnRlbnQ+XHJcblxyXG48bmctY29udGFpbmVyIFtuZ1RlbXBsYXRlT3V0bGV0XT1cImRlZmF1bHRcIj48L25nLWNvbnRhaW5lcj5cclxuXHJcbjxuZy10ZW1wbGF0ZSAjZGVmYXVsdD5cclxuICAgIDxheC1jb2xvci1wYWxldHRlLXByZXZpZXc+PC9heC1jb2xvci1wYWxldHRlLXByZXZpZXc+XHJcbiAgICA8YXgtY29sb3ItcGFsZXR0ZS1zd2F0Y2hlcz48L2F4LWNvbG9yLXBhbGV0dGUtc3dhdGNoZXM+XHJcbiAgICA8bmctY29udGVudCBzZWxlY3Q9XCJheC1jb2xvci1wYWxldHRlLWZhdm9yaXRlXCI+PC9uZy1jb250ZW50PlxyXG4gICAgPGF4LWNvbG9yLXBhbGV0dGUtaW5wdXQ+PC9heC1jb2xvci1wYWxldHRlLWlucHV0PlxyXG48L25nLXRlbXBsYXRlPlxyXG48bmctY29udGVudCBzZWxlY3Q9J2F4LWZvb3Rlcic+PC9uZy1jb250ZW50PiJdfQ==
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { AXColorPalleteComponent } from './color-palette.component';
|
|
4
|
+
import { AXTextBoxModule } from '../textbox';
|
|
5
|
+
import { AXLabelModule } from '../label';
|
|
6
|
+
import { AXButtonModule } from '../button';
|
|
7
|
+
import { AXDecoratorModule } from '../decorators';
|
|
8
|
+
import { AXColorPalettePreviewComponent } from './color-palette-preview.component';
|
|
9
|
+
import { AXColorPaletteSwatchesComponent } from './color-palette-swatches.component';
|
|
10
|
+
import { AXColorPaletteInputComponent } from './color-palette-input.component';
|
|
11
|
+
import { AXColorPalettePickerComponent } from './color-palette-picker.component';
|
|
12
|
+
import { AXNumberBoxModule } from '../number-box';
|
|
13
|
+
import * as i0 from "@angular/core";
|
|
14
|
+
const MODULES = [
|
|
15
|
+
AXTextBoxModule,
|
|
16
|
+
AXLabelModule,
|
|
17
|
+
AXButtonModule,
|
|
18
|
+
AXDecoratorModule,
|
|
19
|
+
AXNumberBoxModule
|
|
20
|
+
];
|
|
21
|
+
const CONPONENTS = [
|
|
22
|
+
AXColorPalleteComponent,
|
|
23
|
+
AXColorPalettePreviewComponent,
|
|
24
|
+
AXColorPaletteSwatchesComponent,
|
|
25
|
+
AXColorPaletteInputComponent,
|
|
26
|
+
AXColorPalettePickerComponent
|
|
27
|
+
];
|
|
28
|
+
export class AXColorPaletteModule {
|
|
29
|
+
}
|
|
30
|
+
AXColorPaletteModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: AXColorPaletteModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
31
|
+
AXColorPaletteModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: AXColorPaletteModule, declarations: [AXColorPalleteComponent,
|
|
32
|
+
AXColorPalettePreviewComponent,
|
|
33
|
+
AXColorPaletteSwatchesComponent,
|
|
34
|
+
AXColorPaletteInputComponent,
|
|
35
|
+
AXColorPalettePickerComponent], imports: [CommonModule, AXTextBoxModule,
|
|
36
|
+
AXLabelModule,
|
|
37
|
+
AXButtonModule,
|
|
38
|
+
AXDecoratorModule,
|
|
39
|
+
AXNumberBoxModule], exports: [AXColorPalleteComponent,
|
|
40
|
+
AXColorPalettePreviewComponent,
|
|
41
|
+
AXColorPaletteSwatchesComponent,
|
|
42
|
+
AXColorPaletteInputComponent,
|
|
43
|
+
AXColorPalettePickerComponent] });
|
|
44
|
+
AXColorPaletteModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: AXColorPaletteModule, providers: [], imports: [[CommonModule, ...MODULES]] });
|
|
45
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: AXColorPaletteModule, decorators: [{
|
|
46
|
+
type: NgModule,
|
|
47
|
+
args: [{
|
|
48
|
+
declarations: [...CONPONENTS],
|
|
49
|
+
imports: [CommonModule, ...MODULES],
|
|
50
|
+
exports: [...CONPONENTS],
|
|
51
|
+
providers: [],
|
|
52
|
+
}]
|
|
53
|
+
}] });
|
|
54
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29sb3ItcGFsZXR0ZS5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hY29yZXgvY29tcG9uZW50cy9zcmMvbGliL2NvbG9yLXBhbGV0dGUvY29sb3ItcGFsZXR0ZS5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDcEUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLFlBQVksQ0FBQztBQUM3QyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sVUFBVSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFDM0MsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ2xELE9BQU8sRUFBRSw4QkFBOEIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ25GLE9BQU8sRUFBRSwrQkFBK0IsRUFBRSxNQUFNLG9DQUFvQyxDQUFDO0FBQ3JGLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQy9FLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQ2pGLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFFbEQsTUFBTSxPQUFPLEdBQVU7SUFDbkIsZUFBZTtJQUNmLGFBQWE7SUFDYixjQUFjO0lBQ2QsaUJBQWlCO0lBQ2pCLGlCQUFpQjtDQUNwQixDQUFBO0FBQ0QsTUFBTSxVQUFVLEdBQVU7SUFDdEIsdUJBQXVCO0lBQ3ZCLDhCQUE4QjtJQUM5QiwrQkFBK0I7SUFDL0IsNEJBQTRCO0lBQzVCLDZCQUE2QjtDQUNoQyxDQUFBO0FBUUQsTUFBTSxPQUFPLG9CQUFvQjs7aUhBQXBCLG9CQUFvQjtrSEFBcEIsb0JBQW9CLGlCQWI3Qix1QkFBdUI7UUFDdkIsOEJBQThCO1FBQzlCLCtCQUErQjtRQUMvQiw0QkFBNEI7UUFDNUIsNkJBQTZCLGFBS25CLFlBQVksRUFoQnRCLGVBQWU7UUFDZixhQUFhO1FBQ2IsY0FBYztRQUNkLGlCQUFpQjtRQUNqQixpQkFBaUIsYUFHakIsdUJBQXVCO1FBQ3ZCLDhCQUE4QjtRQUM5QiwrQkFBK0I7UUFDL0IsNEJBQTRCO1FBQzVCLDZCQUE2QjtrSEFTcEIsb0JBQW9CLGFBRmxCLEVBQUUsWUFGSixDQUFDLFlBQVksRUFBRSxHQUFHLE9BQU8sQ0FBQzsyRkFJMUIsb0JBQW9CO2tCQU5oQyxRQUFRO21CQUFDO29CQUNOLFlBQVksRUFBRSxDQUFDLEdBQUcsVUFBVSxDQUFDO29CQUM3QixPQUFPLEVBQUUsQ0FBQyxZQUFZLEVBQUUsR0FBRyxPQUFPLENBQUM7b0JBQ25DLE9BQU8sRUFBRSxDQUFDLEdBQUcsVUFBVSxDQUFDO29CQUN4QixTQUFTLEVBQUUsRUFBRTtpQkFDaEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBBWENvbG9yUGFsbGV0ZUNvbXBvbmVudCB9IGZyb20gJy4vY29sb3ItcGFsZXR0ZS5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBBWFRleHRCb3hNb2R1bGUgfSBmcm9tICcuLi90ZXh0Ym94JztcclxuaW1wb3J0IHsgQVhMYWJlbE1vZHVsZSB9IGZyb20gJy4uL2xhYmVsJztcclxuaW1wb3J0IHsgQVhCdXR0b25Nb2R1bGUgfSBmcm9tICcuLi9idXR0b24nO1xyXG5pbXBvcnQgeyBBWERlY29yYXRvck1vZHVsZSB9IGZyb20gJy4uL2RlY29yYXRvcnMnO1xyXG5pbXBvcnQgeyBBWENvbG9yUGFsZXR0ZVByZXZpZXdDb21wb25lbnQgfSBmcm9tICcuL2NvbG9yLXBhbGV0dGUtcHJldmlldy5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBBWENvbG9yUGFsZXR0ZVN3YXRjaGVzQ29tcG9uZW50IH0gZnJvbSAnLi9jb2xvci1wYWxldHRlLXN3YXRjaGVzLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEFYQ29sb3JQYWxldHRlSW5wdXRDb21wb25lbnQgfSBmcm9tICcuL2NvbG9yLXBhbGV0dGUtaW5wdXQuY29tcG9uZW50JztcclxuaW1wb3J0IHsgQVhDb2xvclBhbGV0dGVQaWNrZXJDb21wb25lbnQgfSBmcm9tICcuL2NvbG9yLXBhbGV0dGUtcGlja2VyLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEFYTnVtYmVyQm94TW9kdWxlIH0gZnJvbSAnLi4vbnVtYmVyLWJveCc7XHJcblxyXG5jb25zdCBNT0RVTEVTOiBhbnlbXSA9IFtcclxuICAgIEFYVGV4dEJveE1vZHVsZSxcclxuICAgIEFYTGFiZWxNb2R1bGUsXHJcbiAgICBBWEJ1dHRvbk1vZHVsZSxcclxuICAgIEFYRGVjb3JhdG9yTW9kdWxlLFxyXG4gICAgQVhOdW1iZXJCb3hNb2R1bGVcclxuXVxyXG5jb25zdCBDT05QT05FTlRTOiBhbnlbXSA9IFtcclxuICAgIEFYQ29sb3JQYWxsZXRlQ29tcG9uZW50LFxyXG4gICAgQVhDb2xvclBhbGV0dGVQcmV2aWV3Q29tcG9uZW50LFxyXG4gICAgQVhDb2xvclBhbGV0dGVTd2F0Y2hlc0NvbXBvbmVudCxcclxuICAgIEFYQ29sb3JQYWxldHRlSW5wdXRDb21wb25lbnQsXHJcbiAgICBBWENvbG9yUGFsZXR0ZVBpY2tlckNvbXBvbmVudFxyXG5dXHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gICAgZGVjbGFyYXRpb25zOiBbLi4uQ09OUE9ORU5UU10sXHJcbiAgICBpbXBvcnRzOiBbQ29tbW9uTW9kdWxlLCAuLi5NT0RVTEVTXSxcclxuICAgIGV4cG9ydHM6IFsuLi5DT05QT05FTlRTXSxcclxuICAgIHByb3ZpZGVyczogW10sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBWENvbG9yUGFsZXR0ZU1vZHVsZSB7IH0iXX0=
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
export * from './color-palette.component';
|
|
2
|
+
export * from './color-palette-preview.component';
|
|
3
|
+
export * from './color-palette-input.component';
|
|
4
|
+
export * from './color-palette-picker.component';
|
|
5
|
+
export * from './color-palette-swatches.component';
|
|
6
|
+
export * from './color-palette.module';
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hY29yZXgvY29tcG9uZW50cy9zcmMvbGliL2NvbG9yLXBhbGV0dGUvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLG1DQUFtQyxDQUFDO0FBQ2xELGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyxrQ0FBa0MsQ0FBQztBQUNqRCxjQUFjLG9DQUFvQyxDQUFDO0FBQ25ELGNBQWMsd0JBQXdCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2NvbG9yLXBhbGV0dGUuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9jb2xvci1wYWxldHRlLXByZXZpZXcuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9jb2xvci1wYWxldHRlLWlucHV0LmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY29sb3ItcGFsZXR0ZS1waWNrZXIuY29tcG9uZW50JztcclxuZXhwb3J0ICogZnJvbSAnLi9jb2xvci1wYWxldHRlLXN3YXRjaGVzLmNvbXBvbmVudCc7XHJcbmV4cG9ydCAqIGZyb20gJy4vY29sb3ItcGFsZXR0ZS5tb2R1bGUnOyJdfQ==
|
|
@@ -1,46 +1,36 @@
|
|
|
1
|
-
import { AXTranslator } from '@acorex/core';
|
|
2
|
-
import { ChangeDetectionStrategy, Component,
|
|
3
|
-
import
|
|
4
|
-
import {
|
|
5
|
-
import {
|
|
6
|
-
import {
|
|
7
|
-
import {
|
|
8
|
-
import { VALUE_INPUTS, VALUE_OUTPUT } from '../base/mixin/value-mixin.class';
|
|
1
|
+
import { AXColorUtil, AXTranslator } from '@acorex/core';
|
|
2
|
+
import { ChangeDetectionStrategy, Component, ViewChild, ViewEncapsulation } from '@angular/core';
|
|
3
|
+
import { AXBaseComponent, AXClosbaleComponent } from '../base';
|
|
4
|
+
import { DROPDOWN_INPUTS, DROPDOWN_OUTPUT, _DropdownComponenetMixin } from '../base/mixin/dropdown-mixin.class';
|
|
5
|
+
import { INTERACTIVE_INPUTS, INTERACTIVE_OUTPUT, _InteractiveComponenetMixin } from '../base/mixin/interactive-mixin.class';
|
|
6
|
+
import { TEXTBOX_INPUTS, TEXTBOX_OUTPUT, _TextboxComponenetMixin } from '../base/mixin/textbox-mixin.class';
|
|
7
|
+
import { VALUE_INPUTS, VALUE_OUTPUT, _ValueComponenetMixin } from '../base/mixin/value-mixin.class';
|
|
9
8
|
import { AXPopoverComponent } from '../popover';
|
|
10
9
|
import * as i0 from "@angular/core";
|
|
11
10
|
import * as i1 from "@acorex/core";
|
|
12
11
|
import * as i2 from "../button/button.component";
|
|
13
12
|
import * as i3 from "../decorators/icon.component";
|
|
14
|
-
import * as i4 from "../
|
|
15
|
-
import * as i5 from "../
|
|
16
|
-
import * as i6 from "
|
|
17
|
-
import * as i7 from "@angular/
|
|
18
|
-
|
|
13
|
+
import * as i4 from "../popover/popover.component";
|
|
14
|
+
import * as i5 from "../color-palette/color-palette.component";
|
|
15
|
+
import * as i6 from "@angular/common";
|
|
16
|
+
import * as i7 from "@angular/cdk/a11y";
|
|
17
|
+
export const AXBaseColorPickerMixin = _InteractiveComponenetMixin(_DropdownComponenetMixin(_ValueComponenetMixin(_TextboxComponenetMixin(AXBaseComponent))));
|
|
19
18
|
/**
|
|
20
19
|
* The Button is a component which detects user interaction and triggers a corresponding event
|
|
21
20
|
*
|
|
22
21
|
* @category Components
|
|
23
22
|
*/
|
|
24
|
-
export class AXColorPickerComponent extends
|
|
23
|
+
export class AXColorPickerComponent extends AXBaseColorPickerMixin {
|
|
25
24
|
/**
|
|
26
25
|
* @ignore
|
|
27
26
|
*/
|
|
28
27
|
constructor(_elementRef, _cdr, _zone, _platform) {
|
|
29
28
|
super(_elementRef, _cdr);
|
|
30
29
|
this._elementRef = _elementRef;
|
|
31
|
-
this._cdr = _cdr;
|
|
32
30
|
this._zone = _zone;
|
|
33
31
|
this._platform = _platform;
|
|
34
|
-
|
|
35
|
-
* Defines the clearButton.
|
|
36
|
-
*/
|
|
37
|
-
this.clearButton = false;
|
|
38
|
-
/**
|
|
39
|
-
* Defines the checkbox.
|
|
40
|
-
*/
|
|
41
|
-
this.checkbox = false;
|
|
32
|
+
this._mode = 'hex';
|
|
42
33
|
this._isMobile = false;
|
|
43
|
-
this._forceFocus = false;
|
|
44
34
|
this._isMobile = this._platform.is('Mobile');
|
|
45
35
|
this._platform.resize.subscribe(() => {
|
|
46
36
|
this._isMobile = this._platform.is('Mobile');
|
|
@@ -48,9 +38,6 @@ export class AXColorPickerComponent extends AXBaseSelectionDropdownMixin {
|
|
|
48
38
|
this._popoverWidth = this._isMobile ? null : this._target.offsetWidth;
|
|
49
39
|
});
|
|
50
40
|
}
|
|
51
|
-
get emptyTemplate() {
|
|
52
|
-
return this._contentEmptyTemplate;
|
|
53
|
-
}
|
|
54
41
|
_handleArrowClickEvent(e) {
|
|
55
42
|
e.nativeEvent.stopPropagation();
|
|
56
43
|
this.toggle();
|
|
@@ -68,257 +55,27 @@ export class AXColorPickerComponent extends AXBaseSelectionDropdownMixin {
|
|
|
68
55
|
super.onViewInit();
|
|
69
56
|
this._popoverWidth = this._isMobile ? null : this._target.offsetWidth;
|
|
70
57
|
}
|
|
71
|
-
refresh() {
|
|
72
|
-
this.value = null;
|
|
73
|
-
super.refresh();
|
|
74
|
-
}
|
|
75
|
-
_handleOnItemClick(e, item) {
|
|
76
|
-
if (this.isItemDisabled(item)) {
|
|
77
|
-
return;
|
|
78
|
-
}
|
|
79
|
-
if (!this.multiple)
|
|
80
|
-
this.close();
|
|
81
|
-
this.toggleSelect(item);
|
|
82
|
-
this._cdr.detectChanges();
|
|
83
|
-
}
|
|
84
|
-
_handleListScroll(e) {
|
|
85
|
-
const list = e.target;
|
|
86
|
-
if ((list.scrollTop < list.scrollHeight - list.clientHeight)) {
|
|
87
|
-
return;
|
|
88
|
-
}
|
|
89
|
-
this._fetchData();
|
|
90
|
-
}
|
|
91
|
-
_checkForLoadData() {
|
|
92
|
-
const list = this.listContainer.nativeElement;
|
|
93
|
-
if (this.loadedCount < this.totalCount && list.scrollHeight < ((list.parentElement.clientHeight) * 1.5)) {
|
|
94
|
-
this._fetchData();
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
_onDataLoaded() {
|
|
98
|
-
if (this.popover.isOpen) {
|
|
99
|
-
setTimeout(() => {
|
|
100
|
-
this._checkForLoadData();
|
|
101
|
-
this.popover.updatePosition();
|
|
102
|
-
if (this._forceFocus) {
|
|
103
|
-
this._focusSelectedItem();
|
|
104
|
-
this._forceFocus = false;
|
|
105
|
-
}
|
|
106
|
-
}, 100);
|
|
107
|
-
}
|
|
108
|
-
}
|
|
109
58
|
_onValueChanged(oldValue, newValue) {
|
|
110
59
|
super._onValueChanged(oldValue, newValue);
|
|
111
|
-
|
|
112
|
-
_handleOnRemoveItemClick(e, item) {
|
|
113
|
-
this.unselectItems(item);
|
|
114
|
-
e.stopPropagation();
|
|
115
|
-
}
|
|
116
|
-
_handleBadgeRemove(e, item) {
|
|
117
|
-
this.unselectItems(item);
|
|
118
|
-
e.stopPropagation();
|
|
119
|
-
this.close();
|
|
120
|
-
}
|
|
121
|
-
_handleKeydown(e) {
|
|
122
|
-
const isLetter = new RegExp(/[a-zA-Z0-9\-]/).test(String.fromCharCode(e.keyCode));
|
|
123
|
-
if (e.code === 'Backspace' && e.type === 'keydown' &&
|
|
124
|
-
((this.allowNull === true && this.selectedItems.length > 0) ||
|
|
125
|
-
(this.allowNull !== true && this.selectedItems.length > 1))) {
|
|
126
|
-
this.isUserInput = true;
|
|
127
|
-
this.unselectItems(this.selectedItems.pop());
|
|
128
|
-
e.preventDefault();
|
|
129
|
-
return;
|
|
130
|
-
}
|
|
131
|
-
else if ((e.code === 'ArrowDown' || e.code === 'ArrowUp' || e.code === 'Space') && !this.popover.isOpen && e.type === 'keydown') {
|
|
132
|
-
if (this.multiple) {
|
|
133
|
-
this.open();
|
|
134
|
-
}
|
|
135
|
-
else {
|
|
136
|
-
this.isUserInput = true;
|
|
137
|
-
if (e.ctrlKey || e.code === 'Space') {
|
|
138
|
-
this.open();
|
|
139
|
-
}
|
|
140
|
-
else {
|
|
141
|
-
this._selectedItemByNav((e.key === 'ArrowDown' ? 1 : -1));
|
|
142
|
-
}
|
|
143
|
-
}
|
|
144
|
-
e.preventDefault();
|
|
145
|
-
return;
|
|
146
|
-
}
|
|
147
|
-
else if (isLetter) {
|
|
148
|
-
this.text = e.key;
|
|
149
|
-
this.open();
|
|
150
|
-
e.preventDefault();
|
|
151
|
-
return;
|
|
152
|
-
}
|
|
153
|
-
}
|
|
154
|
-
_handlePopoverKeydown(e) {
|
|
155
|
-
if (e.target.tagName == "INPUT" && ['Space', 'Backspace'].includes(e.code))
|
|
156
|
-
return;
|
|
157
|
-
if ((e.key === 'ArrowDown' || e.key === 'ArrowUp') && this.displayItems.length > 0) {
|
|
158
|
-
this.isUserInput = true;
|
|
159
|
-
this._focusItemByNav((e.key === 'ArrowDown' ? 1 : -1));
|
|
160
|
-
e.preventDefault();
|
|
161
|
-
}
|
|
162
|
-
else if (e.code === 'Backspace' &&
|
|
163
|
-
((this.allowNull === true && this.selectedItems.length > 0) ||
|
|
164
|
-
(this.allowNull !== true && this.selectedItems.length > 1))) {
|
|
165
|
-
this.isUserInput = true;
|
|
166
|
-
this.unselectItems(this.selectedItems.pop());
|
|
167
|
-
e.preventDefault();
|
|
168
|
-
}
|
|
169
|
-
else if ((e.code === 'Space' || e.code === 'Enter')) {
|
|
170
|
-
debugger;
|
|
171
|
-
e.preventDefault();
|
|
172
|
-
const focusedItemId = this.listContainer.nativeElement.querySelector('.ax-state-focus')?.dataset?.id;
|
|
173
|
-
const focusedItem = _.findLast(this.flatItems, [this.valueField, focusedItemId]);
|
|
174
|
-
if (focusedItem) {
|
|
175
|
-
if (this.isItemDisabled(focusedItem)) {
|
|
176
|
-
return;
|
|
177
|
-
}
|
|
178
|
-
if (this.multiple) {
|
|
179
|
-
this.isUserInput = true;
|
|
180
|
-
this.toggleSelect(focusedItem);
|
|
181
|
-
}
|
|
182
|
-
else {
|
|
183
|
-
this.isUserInput = true;
|
|
184
|
-
this.selectItems(focusedItem);
|
|
185
|
-
this.close();
|
|
186
|
-
}
|
|
187
|
-
}
|
|
188
|
-
}
|
|
189
|
-
else if (e.code === "Tab") {
|
|
190
|
-
this.close();
|
|
191
|
-
e.preventDefault();
|
|
192
|
-
e.stopPropagation();
|
|
193
|
-
}
|
|
194
|
-
else if (e.key === 'Escape') {
|
|
195
|
-
this.close();
|
|
196
|
-
e.preventDefault();
|
|
197
|
-
e.stopPropagation();
|
|
198
|
-
}
|
|
60
|
+
this._colorCode = AXColorUtil.to(newValue, this._mode);
|
|
199
61
|
}
|
|
200
62
|
async _handlePopupOnOpened(e) {
|
|
201
|
-
this.popover.focus();
|
|
202
|
-
if (this.displayItems.length == 0) {
|
|
203
|
-
this._forceFocus = true;
|
|
204
|
-
this._fetchData();
|
|
205
|
-
}
|
|
206
|
-
else {
|
|
207
|
-
this._focusSelectedItem();
|
|
208
|
-
}
|
|
209
|
-
debugger;
|
|
210
|
-
if (this._searchBox && !this._isMobile) {
|
|
211
|
-
this._searchBox.focus();
|
|
212
|
-
}
|
|
213
63
|
}
|
|
214
64
|
_handlePopupOnClosed(e) {
|
|
215
65
|
this.focus();
|
|
216
66
|
}
|
|
217
|
-
_focusItemByNav(sign) {
|
|
218
|
-
const list = this.listContainer.nativeElement;
|
|
219
|
-
const fn = (s) => list.querySelector(s);
|
|
220
|
-
const itemDiv = fn(`.ax-list-item.ax-state-focus`) || fn(`.ax-list-item.ax-state-selected`) || fn(`.ax-list-item`);
|
|
221
|
-
let next = (sign == 1 ? itemDiv.nextElementSibling : itemDiv.previousElementSibling);
|
|
222
|
-
if (next) {
|
|
223
|
-
this._focusItemElement(next);
|
|
224
|
-
}
|
|
225
|
-
else {
|
|
226
|
-
const parent = itemDiv.closest('.ax-list-item-group');
|
|
227
|
-
if (parent) {
|
|
228
|
-
const lis = (sign == 1 ? parent.nextElementSibling : parent.previousElementSibling)?.querySelectorAll('li');
|
|
229
|
-
const a = sign == 1 ? _.first(lis) : _.last(lis);
|
|
230
|
-
if (a) {
|
|
231
|
-
this._focusItemElement(a);
|
|
232
|
-
}
|
|
233
|
-
}
|
|
234
|
-
}
|
|
235
|
-
}
|
|
236
|
-
_focusSelectedItem() {
|
|
237
|
-
this._zone.runOutsideAngular(() => {
|
|
238
|
-
const list = this.listContainer.nativeElement;
|
|
239
|
-
const fn = (s) => list.querySelector(s);
|
|
240
|
-
const itemDiv = fn(`.ax-list-item.ax-state-selected`) || fn(`.ax-list-item`);
|
|
241
|
-
if (itemDiv) {
|
|
242
|
-
this._focusItemElement(itemDiv);
|
|
243
|
-
}
|
|
244
|
-
});
|
|
245
|
-
}
|
|
246
|
-
_focusItemElement(el) {
|
|
247
|
-
this._zone.runOutsideAngular(() => {
|
|
248
|
-
const list = this.listContainer.nativeElement;
|
|
249
|
-
list.querySelectorAll('.ax-list-item').forEach(c => {
|
|
250
|
-
if (c == el) {
|
|
251
|
-
c.classList.add('ax-state-focus');
|
|
252
|
-
el.scrollIntoView({ behavior: 'auto' });
|
|
253
|
-
}
|
|
254
|
-
else {
|
|
255
|
-
c.classList.remove('ax-state-focus');
|
|
256
|
-
}
|
|
257
|
-
});
|
|
258
|
-
if (!this._isMobile && this._searchBox)
|
|
259
|
-
this._searchBox.focus();
|
|
260
|
-
else
|
|
261
|
-
el.focus();
|
|
262
|
-
});
|
|
263
|
-
}
|
|
264
|
-
_selectedItemByNav(sign) {
|
|
265
|
-
const last = _.last(this.selectedItems);
|
|
266
|
-
let i = 0;
|
|
267
|
-
if (last) {
|
|
268
|
-
i = _.findLastIndex(this.flatItems, [this.valueField, last[this.valueField]]);
|
|
269
|
-
}
|
|
270
|
-
i += sign;
|
|
271
|
-
let next = _.nth(this.flatItems, i);
|
|
272
|
-
while (next?.children && next?.children.length) {
|
|
273
|
-
i += sign;
|
|
274
|
-
next = _.nth(this.flatItems, i);
|
|
275
|
-
}
|
|
276
|
-
if (next) {
|
|
277
|
-
this.selectItems(next);
|
|
278
|
-
}
|
|
279
|
-
else if (next == null && sign == 1) {
|
|
280
|
-
this._fetchData();
|
|
281
|
-
}
|
|
282
|
-
}
|
|
283
|
-
_onSearchExprChanged(e) {
|
|
284
|
-
this.empty();
|
|
285
|
-
this._forceFocus = true;
|
|
286
|
-
this._fetchData();
|
|
287
|
-
}
|
|
288
|
-
search(exp) {
|
|
289
|
-
debugger;
|
|
290
|
-
this.empty();
|
|
291
|
-
this._forceFocus = true;
|
|
292
|
-
this._fetchData();
|
|
293
|
-
}
|
|
294
|
-
_fetchData() {
|
|
295
|
-
super._fetchData({ searchQuery: this._searchBox?.searchExp });
|
|
296
|
-
}
|
|
297
67
|
}
|
|
298
68
|
AXColorPickerComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: AXColorPickerComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i0.NgZone }, { token: i1.AXPlatform }], target: i0.ɵɵFactoryTarget.Component });
|
|
299
|
-
AXColorPickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.9", type: AXColorPickerComponent, selector: "ax-color-picker", inputs: { isOpen: "isOpen", fitParent: "fitParent", dropdownWidth: "dropdownWidth", position: "position", disabled: "disabled", tabIndex: "tabIndex", readonly: "readonly", allowNull: "allowNull", value: "value", debounceTime: "debounceTime", name: "name", checked: "checked", placeholder: "placeholder", maxLength: "maxLength", type: "type", autoComplete: "autoComplete"
|
|
69
|
+
AXColorPickerComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.9", type: AXColorPickerComponent, selector: "ax-color-picker", inputs: { isOpen: "isOpen", fitParent: "fitParent", dropdownWidth: "dropdownWidth", position: "position", disabled: "disabled", tabIndex: "tabIndex", readonly: "readonly", allowNull: "allowNull", value: "value", debounceTime: "debounceTime", name: "name", checked: "checked", placeholder: "placeholder", maxLength: "maxLength", type: "type", autoComplete: "autoComplete" }, outputs: { onOpened: "onOpened", onClosed: "onClosed", onBlur: "onBlur", onFocus: "onFocus", valueChange: "valueChange", onValueChanged: "onValueChanged" }, host: { classAttribute: "ax-editor-container ax-drop-down" }, providers: [
|
|
300
70
|
{ provide: AXClosbaleComponent, useExisting: AXColorPickerComponent }
|
|
301
|
-
],
|
|
71
|
+
], viewQueries: [{ propertyName: "popover", first: true, predicate: AXPopoverComponent, descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<ng-content select=\"ax-prefix\">\r\n</ng-content>\r\n<div class=\"ax-dropdown-content\" [class.ax-state-disabled]=\"disabled\" (click)=\"_handleInputClickEvent($event)\">\r\n <div *ngIf=\"value\" class=\"color-badge\" [ngStyle]=\"{'background-color': value}\"></div>\r\n <div class=\"ax-uppercase\">{{_colorCode}}</div>\r\n</div>\r\n<ax-button color=\"light\" look=\"blank\" (onClick)=\"clear()\" [tabIndex]=\"-1\" *ngIf=\"value && !(disabled || readonly)\">\r\n <ax-icon icon=\"ax-ic ax-ic-close\"></ax-icon>\r\n</ax-button>\r\n<ax-button [disabled]=\"disabled\" [tabIndex]=\"-1\" color=\"light\" look=\"blank\" (onClick)=\"_handleArrowClickEvent($event)\">\r\n <ax-icon #icon icon=\"ax-ic ax-ic-chevron ax-transform ax--rotate-90\"></ax-icon>\r\n</ax-button>\r\n<ng-content select=\"ax-validation-rule\">\r\n</ng-content>\r\n<ng-content select=\"ax-suffix\">\r\n</ng-content>\r\n<ax-popover [target]=\"_target\" [position]=\"position\" [openTrigger]=\"'manual'\" [closeTrigger]=\"'clickout'\"\r\n [adaptivityEnabled]=\"true\" (onOpened)=\"_handlePopupOnOpened($event)\" (onClosed)=\"_handlePopupOnClosed($event)\">\r\n <div class=\"ax-overlay-pane\" tabindex=\"0\" aria-modal=\"true\" cdkTrapFocus\r\n [class.ax-overlay-actionsheet]=\"_isMobile\">\r\n <ax-color-palette [(value)]=\"value\" [(mode)]=\"_mode\">\r\n </ax-color-palette>\r\n </div>\r\n</ax-popover>", components: [{ type: i2.AXButtonComponent, selector: "ax-button", inputs: ["disabled", "tabIndex", "size", "color", "look", "text", "submitBehavior", "cancelBehavior", "toggleable", "selected"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange"] }, { type: i3.AXDecoratorIconComponent, selector: "ax-icon", inputs: ["icon"] }, { type: i4.AXPopoverComponent, selector: "ax-popover", inputs: ["target", "position", "openTrigger", "closeTrigger", "hasBackdrop", "backdropClass", "adaptivityEnabled"], outputs: ["onOpened", "onClosed"] }, { type: i5.AXColorPalleteComponent, selector: "ax-color-palette", inputs: ["disabled", "tabIndex", "readonly", "allowNull", "value", "debounceTime", "name", "checked", "mode"], outputs: ["onBlur", "onFocus", "valueChange", "onValueChanged", "modeChange"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { type: i7.CdkTrapFocus, selector: "[cdkTrapFocus]", inputs: ["cdkTrapFocus", "cdkTrapFocusAutoCapture"], exportAs: ["cdkTrapFocus"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
302
72
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.9", ngImport: i0, type: AXColorPickerComponent, decorators: [{
|
|
303
73
|
type: Component,
|
|
304
74
|
args: [{ selector: 'ax-color-picker', inputs: [...DROPDOWN_INPUTS, ...INTERACTIVE_INPUTS, ...VALUE_INPUTS, ...TEXTBOX_INPUTS], outputs: [...DROPDOWN_OUTPUT, ...INTERACTIVE_OUTPUT, ...VALUE_OUTPUT, ...TEXTBOX_OUTPUT], encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
305
75
|
{ provide: AXClosbaleComponent, useExisting: AXColorPickerComponent }
|
|
306
|
-
], host: { class: 'ax-editor-container ax-drop-down' }, template: "<ng-content select=\"ax-prefix\">\r\n</ng-content>\r\n<div class=\"ax-dropdown-content\" [class.ax-state-disabled]=\"disabled\" (click)=\"_handleInputClickEvent($event)\">\r\n \r\n</div>\r\n<ax-button color=\"light\" look=\"blank\" (onClick)=\"clear()\" [tabIndex]=\"-1\"
|
|
76
|
+
], host: { class: 'ax-editor-container ax-drop-down' }, template: "<ng-content select=\"ax-prefix\">\r\n</ng-content>\r\n<div class=\"ax-dropdown-content\" [class.ax-state-disabled]=\"disabled\" (click)=\"_handleInputClickEvent($event)\">\r\n <div *ngIf=\"value\" class=\"color-badge\" [ngStyle]=\"{'background-color': value}\"></div>\r\n <div class=\"ax-uppercase\">{{_colorCode}}</div>\r\n</div>\r\n<ax-button color=\"light\" look=\"blank\" (onClick)=\"clear()\" [tabIndex]=\"-1\" *ngIf=\"value && !(disabled || readonly)\">\r\n <ax-icon icon=\"ax-ic ax-ic-close\"></ax-icon>\r\n</ax-button>\r\n<ax-button [disabled]=\"disabled\" [tabIndex]=\"-1\" color=\"light\" look=\"blank\" (onClick)=\"_handleArrowClickEvent($event)\">\r\n <ax-icon #icon icon=\"ax-ic ax-ic-chevron ax-transform ax--rotate-90\"></ax-icon>\r\n</ax-button>\r\n<ng-content select=\"ax-validation-rule\">\r\n</ng-content>\r\n<ng-content select=\"ax-suffix\">\r\n</ng-content>\r\n<ax-popover [target]=\"_target\" [position]=\"position\" [openTrigger]=\"'manual'\" [closeTrigger]=\"'clickout'\"\r\n [adaptivityEnabled]=\"true\" (onOpened)=\"_handlePopupOnOpened($event)\" (onClosed)=\"_handlePopupOnClosed($event)\">\r\n <div class=\"ax-overlay-pane\" tabindex=\"0\" aria-modal=\"true\" cdkTrapFocus\r\n [class.ax-overlay-actionsheet]=\"_isMobile\">\r\n <ax-color-palette [(value)]=\"value\" [(mode)]=\"_mode\">\r\n </ax-color-palette>\r\n </div>\r\n</ax-popover>" }]
|
|
307
77
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i0.NgZone }, { type: i1.AXPlatform }]; }, propDecorators: { popover: [{
|
|
308
78
|
type: ViewChild,
|
|
309
79
|
args: [AXPopoverComponent, { static: true }]
|
|
310
|
-
}], clearButton: [{
|
|
311
|
-
type: Input
|
|
312
|
-
}], checkbox: [{
|
|
313
|
-
type: Input
|
|
314
|
-
}], listContainer: [{
|
|
315
|
-
type: ViewChild,
|
|
316
|
-
args: ['listContainer', { static: true }]
|
|
317
|
-
}], _contentEmptyTemplate: [{
|
|
318
|
-
type: ContentChild,
|
|
319
|
-
args: ['emptyTemplate']
|
|
320
|
-
}], _handleKeydown: [{
|
|
321
|
-
type: HostListener,
|
|
322
|
-
args: ['keydown', ['$event']]
|
|
323
80
|
}] } });
|
|
324
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/color-picker/color-picker.component.ts","../../../../../../projects/acorex/components/src/lib/color-picker/color-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXPlatform, AXTranslator } from '@acorex/core';\r\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, ElementRef, HostListener, Input, NgZone, TemplateRef, ViewChild, ViewEncapsulation } from '@angular/core';\r\nimport _ from 'lodash';\r\nimport { AXBaseSelectionDropdownMixin, AXClickEvent, AXClosbaleComponent, AXSearchableComponent, AXValueChangedEvent } from '../base';\r\nimport { DATALIST_INPUTS } from '../base/mixin/datalist-component.class';\r\nimport { DROPDOWN_INPUTS, DROPDOWN_OUTPUT } from '../base/mixin/dropdown-mixin.class';\r\nimport { INTERACTIVE_INPUTS, INTERACTIVE_OUTPUT } from '../base/mixin/interactive-mixin.class';\r\nimport { SELECTION_INPUTS, SELECTION_OUTPUT } from '../base/mixin/selection-component.class';\r\nimport { TEXTBOX_INPUTS, TEXTBOX_OUTPUT } from '../base/mixin/textbox-mixin.class';\r\nimport { VALUE_INPUTS, VALUE_OUTPUT } from '../base/mixin/value-mixin.class';\r\nimport { AXPopoverComponent } from '../popover';\r\nimport { AXSearchBoxComponent } from '../searchbox';\r\n\r\n/**\r\n * The Button is a component which detects user interaction and triggers a corresponding event\r\n *\r\n * @category Components\r\n */\r\n@Component({\r\n    selector: 'ax-color-picker',\r\n    templateUrl: 'color-picker.component.html',\r\n    inputs: [...DROPDOWN_INPUTS, ...INTERACTIVE_INPUTS, ...VALUE_INPUTS, ...TEXTBOX_INPUTS],\r\n    outputs: [...DROPDOWN_OUTPUT, ...INTERACTIVE_OUTPUT, ...VALUE_OUTPUT, ...TEXTBOX_OUTPUT],\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [\r\n        { provide: AXClosbaleComponent, useExisting: AXColorPickerComponent }\r\n    ],\r\n    host: { class: 'ax-editor-container ax-drop-down' }\r\n})\r\nexport class AXColorPickerComponent extends AXBaseSelectionDropdownMixin {\r\n\r\n\r\n    @ViewChild(AXPopoverComponent, { static: true })\r\n    popover: AXPopoverComponent;\r\n\r\n\r\n    _target: HTMLDivElement;\r\n    _popoverTitle: string;\r\n    _popoverWidth: number;\r\n\r\n\r\n    /**\r\n     *  Defines the clearButton.\r\n     */\r\n    @Input()\r\n    clearButton: boolean = false;\r\n\r\n\r\n\r\n    /**\r\n     *  Defines the checkbox.\r\n     */\r\n    @Input()\r\n    checkbox: boolean = false;\r\n\r\n    @ViewChild('listContainer', { static: true })\r\n    private listContainer: ElementRef<HTMLDivElement>;\r\n\r\n    @ContentChild('emptyTemplate')\r\n    private _contentEmptyTemplate: TemplateRef<any>;\r\n\r\n\r\n    get emptyTemplate(): TemplateRef<any> {\r\n        return this._contentEmptyTemplate;\r\n    }\r\n\r\n    _isMobile: boolean = false;\r\n    _forceFocus: boolean = false;\r\n    /**\r\n    *  @ignore\r\n    */\r\n    constructor(\r\n        private _elementRef: ElementRef<HTMLDivElement>,\r\n        private _cdr: ChangeDetectorRef,\r\n        private _zone: NgZone,\r\n        private _platform: AXPlatform,\r\n    ) {\r\n        super(_elementRef, _cdr);\r\n        this._isMobile = this._platform.is('Mobile');\r\n        this._platform.resize.subscribe(() => {\r\n            this._isMobile = this._platform.is('Mobile');\r\n            this.popover.dispose();\r\n            this._popoverWidth = this._isMobile ? null : this._target.offsetWidth;\r\n        });\r\n    }\r\n\r\n    _handleArrowClickEvent(e: AXClickEvent) {\r\n        e.nativeEvent.stopPropagation();\r\n        this.toggle();\r\n    }\r\n\r\n    _handleInputClickEvent(e: MouseEvent) {\r\n        e.stopPropagation();\r\n        this.toggle();\r\n    }\r\n\r\n\r\n    onInit() {\r\n        super.onInit();\r\n        this._target = this._elementRef.nativeElement;\r\n\r\n        this._popoverTitle = this.placeholder || AXTranslator.get('selectbox.popover.title')\r\n    }\r\n\r\n    onViewInit() {\r\n        super.onViewInit();\r\n        this._popoverWidth = this._isMobile ? null : this._target.offsetWidth;\r\n    }\r\n\r\n\r\n    refresh() {\r\n        this.value = null;\r\n        super.refresh();\r\n    }\r\n\r\n    _handleOnItemClick(e: MouseEvent, item: any) {\r\n        if (this.isItemDisabled(item)) {\r\n            return;\r\n        }\r\n        if (!this.multiple)\r\n            this.close();\r\n        this.toggleSelect(item);\r\n        this._cdr.detectChanges();\r\n    }\r\n\r\n    _handleListScroll(e: Event) {\r\n        const list = e.target as HTMLDivElement;\r\n        if ((list.scrollTop < list.scrollHeight - list.clientHeight)) {\r\n            return;\r\n        }\r\n        this._fetchData();\r\n    }\r\n\r\n    private _checkForLoadData() {\r\n        const list = this.listContainer.nativeElement;\r\n        if (this.loadedCount < this.totalCount && list.scrollHeight < ((list.parentElement.clientHeight) * 1.5)) {\r\n            this._fetchData();\r\n        }\r\n    }\r\n\r\n    _onDataLoaded() {\r\n        if (this.popover.isOpen) {\r\n            setTimeout(() => {\r\n                this._checkForLoadData();\r\n                this.popover.updatePosition();\r\n                if (this._forceFocus) {\r\n                    this._focusSelectedItem();\r\n                    this._forceFocus = false;\r\n                }\r\n            }, 100);\r\n        }\r\n    }\r\n\r\n    _onValueChanged(oldValue: any, newValue: any) {\r\n        super._onValueChanged(oldValue, newValue);\r\n    }\r\n\r\n    _handleOnRemoveItemClick(e: MouseEvent, item: any) {\r\n        this.unselectItems(item)\r\n        e.stopPropagation();\r\n    }\r\n\r\n    _handleBadgeRemove(e: MouseEvent, item) {\r\n        this.unselectItems(item)\r\n        e.stopPropagation()\r\n        this.close();\r\n    }\r\n\r\n    @HostListener('keydown', ['$event'])\r\n    _handleKeydown(e: KeyboardEvent) {\r\n        const isLetter = new RegExp(/[a-zA-Z0-9\\-]/).test(String.fromCharCode(e.keyCode));\r\n        if (e.code === 'Backspace' && e.type === 'keydown' &&\r\n            ((this.allowNull === true && this.selectedItems.length > 0) ||\r\n                (this.allowNull !== true && this.selectedItems.length > 1))) {\r\n            this.isUserInput = true;\r\n            this.unselectItems(this.selectedItems.pop());\r\n            e.preventDefault();\r\n            return;\r\n        }\r\n        else if ((e.code === 'ArrowDown' || e.code === 'ArrowUp' || e.code === 'Space') && !this.popover.isOpen && e.type === 'keydown') {\r\n            if (this.multiple) {\r\n                this.open();\r\n            }\r\n            else {\r\n                this.isUserInput = true;\r\n                if (e.ctrlKey || e.code === 'Space') {\r\n                    this.open();\r\n                }\r\n                else {\r\n                    this._selectedItemByNav((e.key === 'ArrowDown' ? 1 : -1));\r\n                }\r\n            }\r\n            e.preventDefault();\r\n            return;\r\n        }\r\n        else if (isLetter) {\r\n            this.text = e.key;\r\n            this.open();\r\n            e.preventDefault();\r\n            return;\r\n        }\r\n    }\r\n\r\n\r\n    _handlePopoverKeydown(e: KeyboardEvent) {\r\n        if ((e.target as HTMLElement).tagName == \"INPUT\" && ['Space', 'Backspace'].includes(e.code))\r\n            return;\r\n        if ((e.key === 'ArrowDown' || e.key === 'ArrowUp') && this.displayItems.length > 0) {\r\n            this.isUserInput = true;\r\n            this._focusItemByNav((e.key === 'ArrowDown' ? 1 : -1));\r\n            e.preventDefault();\r\n        }\r\n        else if (e.code === 'Backspace' &&\r\n            ((this.allowNull === true && this.selectedItems.length > 0) ||\r\n                (this.allowNull !== true && this.selectedItems.length > 1))) {\r\n            this.isUserInput = true;\r\n            this.unselectItems(this.selectedItems.pop());\r\n            e.preventDefault();\r\n        }\r\n        else if ((e.code === 'Space' || e.code === 'Enter')) {\r\n            debugger;\r\n            e.preventDefault();\r\n            const focusedItemId = this.listContainer.nativeElement.querySelector<HTMLElement>('.ax-state-focus')?.dataset?.id;\r\n            const focusedItem = _.findLast(this.flatItems, [this.valueField, focusedItemId]);\r\n            if (focusedItem) {\r\n                if (this.isItemDisabled(focusedItem)) {\r\n                    return;\r\n                }\r\n                if (this.multiple) {\r\n                    this.isUserInput = true;\r\n                    this.toggleSelect(focusedItem);\r\n                }\r\n                else {\r\n                    this.isUserInput = true;\r\n                    this.selectItems(focusedItem);\r\n                    this.close();\r\n                }\r\n            }\r\n        }\r\n        else if (e.code === \"Tab\") {\r\n            this.close();\r\n            e.preventDefault();\r\n            e.stopPropagation();\r\n        }\r\n        else if (e.key === 'Escape') {\r\n            this.close();\r\n            e.preventDefault();\r\n            e.stopPropagation();\r\n        }\r\n    }\r\n\r\n    async _handlePopupOnOpened(e) {\r\n        this.popover.focus();\r\n        if (this.displayItems.length == 0) {\r\n            this._forceFocus = true;\r\n            this._fetchData();\r\n        }\r\n        else {\r\n            this._focusSelectedItem();\r\n        }\r\n        debugger\r\n        if (this._searchBox && !this._isMobile) {\r\n            this._searchBox.focus();\r\n        }\r\n    }\r\n\r\n    _handlePopupOnClosed(e) {\r\n        this.focus();\r\n    }\r\n\r\n\r\n    private _focusItemByNav(sign: -1 | 1): void {\r\n\r\n        const list = this.listContainer.nativeElement;\r\n        const fn = (s) => list.querySelector<HTMLElement>(s);\r\n        const itemDiv = fn(`.ax-list-item.ax-state-focus`) || fn(`.ax-list-item.ax-state-selected`) || fn(`.ax-list-item`);\r\n        let next = (sign == 1 ? itemDiv.nextElementSibling : itemDiv.previousElementSibling) as HTMLElement;\r\n        if (next) {\r\n            this._focusItemElement(next);\r\n        }\r\n        else {\r\n            const parent = itemDiv.closest('.ax-list-item-group');\r\n            if (parent) {\r\n                const lis = (sign == 1 ? parent.nextElementSibling : parent.previousElementSibling)?.querySelectorAll('li');\r\n                const a = sign == 1 ? _.first(lis) : _.last(lis);\r\n                if (a) {\r\n                    this._focusItemElement(a);\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n\r\n    private _focusSelectedItem() {\r\n        this._zone.runOutsideAngular(() => {\r\n            const list = this.listContainer.nativeElement;\r\n            const fn = (s) => list.querySelector<HTMLElement>(s);\r\n            const itemDiv = fn(`.ax-list-item.ax-state-selected`) || fn(`.ax-list-item`);\r\n            if (itemDiv) {\r\n                this._focusItemElement(itemDiv);\r\n            }\r\n        });\r\n    }\r\n\r\n    private _focusItemElement(el: HTMLElement) {\r\n        this._zone.runOutsideAngular(() => {\r\n            const list = this.listContainer.nativeElement;\r\n            list.querySelectorAll('.ax-list-item').forEach(c => {\r\n                if (c == el) {\r\n                    c.classList.add('ax-state-focus');\r\n                    el.scrollIntoView({ behavior: 'auto' });\r\n                }\r\n                else {\r\n                    c.classList.remove('ax-state-focus');\r\n                }\r\n            });\r\n            if (!this._isMobile && this._searchBox)\r\n                this._searchBox.focus()\r\n            else\r\n                el.focus();\r\n        });\r\n    }\r\n\r\n\r\n    private _selectedItemByNav(sign: -1 | 1): void {\r\n        const last = _.last(this.selectedItems);\r\n        let i = 0;\r\n        if (last) {\r\n            i = _.findLastIndex(this.flatItems, [this.valueField, last[this.valueField]]);\r\n        }\r\n        i += sign;\r\n        let next = _.nth<any>(this.flatItems, i);\r\n        while (next?.children && next?.children.length) {\r\n            i += sign;\r\n            next = _.nth<any>(this.flatItems, i);\r\n        }\r\n        if (next) {\r\n            this.selectItems(next);\r\n        }\r\n        else if (next == null && sign == 1) {\r\n            this._fetchData();\r\n        }\r\n    }\r\n\r\n\r\n    _onSearchExprChanged(e: AXValueChangedEvent<string>) {\r\n        this.empty();\r\n        this._forceFocus = true;\r\n        this._fetchData();\r\n    }\r\n\r\n\r\n    search(exp:string)\r\n    {\r\n        debugger;\r\n        this.empty();\r\n        this._forceFocus = true;\r\n        this._fetchData();\r\n    }\r\n\r\n    _fetchData() {\r\n        super._fetchData({ searchQuery: this._searchBox?.searchExp });\r\n    }\r\n}","<ng-content select=\"ax-prefix\">\r\n</ng-content>\r\n<div class=\"ax-dropdown-content\" [class.ax-state-disabled]=\"disabled\" (click)=\"_handleInputClickEvent($event)\">\r\n    \r\n</div>\r\n<ax-button color=\"light\" look=\"blank\" (onClick)=\"clear()\" [tabIndex]=\"-1\"\r\n    *ngIf=\"value && clearButton &&  !(disabled || readonly)\">\r\n    <ax-icon icon=\"ax-ic ax-ic-close\"></ax-icon>\r\n</ax-button>\r\n<ax-button [disabled]=\"disabled\" [tabIndex]=\"-1\" color=\"light\" look=\"blank\" (onClick)=\"_handleArrowClickEvent($event)\">\r\n    <ax-prefix *ngIf=\"(isLoading && !this.popover.isOpen);else icon\">\r\n        <ax-loading type=\"spinner\"></ax-loading>\r\n    </ax-prefix>\r\n    <ng-template #icon>\r\n        <ax-icon #icon icon=\"ax-ic ax-ic-chevron ax-transform ax--rotate-90\"></ax-icon>\r\n    </ng-template>\r\n</ax-button>\r\n<ng-content select=\"ax-validation-rule\">\r\n</ng-content>\r\n<ng-content select=\"ax-suffix\">\r\n</ng-content>\r\n<ax-popover [target]=\"_target\" [position]=\"position\" [openTrigger]=\"'manual'\" [closeTrigger]=\"'clickout'\" [adaptivityEnabled]=\"true\"\r\n    (onOpened)=\"_handlePopupOnOpened($event)\" (onClosed)=\"_handlePopupOnClosed($event)\">\r\n    <div class=\"ax-overlay-pane \" (keydown)=\"_handlePopoverKeydown($event)\" tabindex=\"0\" aria-modal=\"true\" cdkTrapFocus\r\n        [class.ax-overlay-actionsheet]=\"_isMobile\" [class.ax-full]=\"_searchBox ||  isLazy\"\r\n        [style.min-width.px]=\"_popoverWidth\">\r\n       \r\n    </div>\r\n</ax-popover> "]}
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"color-picker.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/color-picker/color-picker.component.ts","../../../../../../projects/acorex/components/src/lib/color-picker/color-picker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AXColorMode, AXColorUtil, AXPlatform, AXTranslator } from '@acorex/core';\r\nimport { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChild, ElementRef, HostListener, Input, NgZone, TemplateRef, ViewChild, ViewEncapsulation } from '@angular/core';\r\nimport _ from 'lodash';\r\nimport { AXBaseComponent, AXClickEvent, AXClosbaleComponent, AXSearchableComponent, AXValueChangedEvent } from '../base';\r\nimport { DROPDOWN_INPUTS, DROPDOWN_OUTPUT, _DropdownComponenetMixin } from '../base/mixin/dropdown-mixin.class';\r\nimport { INTERACTIVE_INPUTS, INTERACTIVE_OUTPUT, _InteractiveComponenetMixin } from '../base/mixin/interactive-mixin.class';\r\nimport { TEXTBOX_INPUTS, TEXTBOX_OUTPUT, _TextboxComponenetMixin } from '../base/mixin/textbox-mixin.class';\r\nimport { VALUE_INPUTS, VALUE_OUTPUT, _ValueComponenetMixin } from '../base/mixin/value-mixin.class';\r\nimport { AXPopoverComponent } from '../popover';\r\n\r\nexport const AXBaseColorPickerMixin =\r\n    _InteractiveComponenetMixin(\r\n        _DropdownComponenetMixin(\r\n            _ValueComponenetMixin(\r\n                _TextboxComponenetMixin(AXBaseComponent)\r\n            )\r\n        )\r\n    );\r\n\r\n\r\n/**\r\n * The Button is a component which detects user interaction and triggers a corresponding event\r\n *\r\n * @category Components\r\n */\r\n@Component({\r\n    selector: 'ax-color-picker',\r\n    templateUrl: 'color-picker.component.html',\r\n    inputs: [...DROPDOWN_INPUTS, ...INTERACTIVE_INPUTS, ...VALUE_INPUTS, ...TEXTBOX_INPUTS],\r\n    outputs: [...DROPDOWN_OUTPUT, ...INTERACTIVE_OUTPUT, ...VALUE_OUTPUT, ...TEXTBOX_OUTPUT],\r\n    encapsulation: ViewEncapsulation.None,\r\n    changeDetection: ChangeDetectionStrategy.OnPush,\r\n    providers: [\r\n        { provide: AXClosbaleComponent, useExisting: AXColorPickerComponent }\r\n    ],\r\n    host: { class: 'ax-editor-container ax-drop-down' }\r\n})\r\nexport class AXColorPickerComponent extends AXBaseColorPickerMixin {\r\n\r\n\r\n    @ViewChild(AXPopoverComponent, { static: true })\r\n    popover: AXPopoverComponent;\r\n\r\n\r\n    _target: HTMLDivElement;\r\n    _popoverTitle: string;\r\n    _popoverWidth: number;\r\n    _colorCode: string;\r\n    _mode: AXColorMode = 'hex';\r\n\r\n\r\n\r\n    _isMobile: boolean = false;\r\n    /**\r\n    *  @ignore\r\n    */\r\n    constructor(\r\n        protected _elementRef: ElementRef<HTMLDivElement>,\r\n        _cdr: ChangeDetectorRef,\r\n        private _zone: NgZone,\r\n        private _platform: AXPlatform,\r\n    ) {\r\n        super(_elementRef, _cdr);\r\n        this._isMobile = this._platform.is('Mobile');\r\n        this._platform.resize.subscribe(() => {\r\n            this._isMobile = this._platform.is('Mobile');\r\n            this.popover.dispose();\r\n            this._popoverWidth = this._isMobile ? null : this._target.offsetWidth;\r\n        });\r\n    }\r\n\r\n    _handleArrowClickEvent(e: AXClickEvent) {\r\n        e.nativeEvent.stopPropagation();\r\n        this.toggle();\r\n    }\r\n\r\n    _handleInputClickEvent(e: MouseEvent) {\r\n        e.stopPropagation();\r\n        this.toggle();\r\n    }\r\n\r\n\r\n    onInit() {\r\n        super.onInit();\r\n        this._target = this._elementRef.nativeElement;\r\n\r\n        this._popoverTitle = this.placeholder || AXTranslator.get('selectbox.popover.title')\r\n    }\r\n\r\n    onViewInit() {\r\n        super.onViewInit();\r\n        this._popoverWidth = this._isMobile ? null : this._target.offsetWidth;\r\n    }\r\n\r\n    _onValueChanged(oldValue: any, newValue: any) {\r\n        super._onValueChanged(oldValue, newValue);\r\n        this._colorCode = AXColorUtil.to(newValue, this._mode)\r\n    }\r\n\r\n    async _handlePopupOnOpened(e) {\r\n\r\n    }\r\n\r\n    _handlePopupOnClosed(e) {\r\n        this.focus();\r\n    }\r\n}","<ng-content select=\"ax-prefix\">\r\n</ng-content>\r\n<div class=\"ax-dropdown-content\" [class.ax-state-disabled]=\"disabled\" (click)=\"_handleInputClickEvent($event)\">\r\n    <div *ngIf=\"value\" class=\"color-badge\" [ngStyle]=\"{'background-color': value}\"></div>\r\n    <div class=\"ax-uppercase\">{{_colorCode}}</div>\r\n</div>\r\n<ax-button color=\"light\" look=\"blank\" (onClick)=\"clear()\" [tabIndex]=\"-1\" *ngIf=\"value &&  !(disabled || readonly)\">\r\n    <ax-icon icon=\"ax-ic ax-ic-close\"></ax-icon>\r\n</ax-button>\r\n<ax-button [disabled]=\"disabled\" [tabIndex]=\"-1\" color=\"light\" look=\"blank\" (onClick)=\"_handleArrowClickEvent($event)\">\r\n    <ax-icon #icon icon=\"ax-ic ax-ic-chevron ax-transform ax--rotate-90\"></ax-icon>\r\n</ax-button>\r\n<ng-content select=\"ax-validation-rule\">\r\n</ng-content>\r\n<ng-content select=\"ax-suffix\">\r\n</ng-content>\r\n<ax-popover [target]=\"_target\" [position]=\"position\" [openTrigger]=\"'manual'\" [closeTrigger]=\"'clickout'\"\r\n    [adaptivityEnabled]=\"true\" (onOpened)=\"_handlePopupOnOpened($event)\" (onClosed)=\"_handlePopupOnClosed($event)\">\r\n    <div class=\"ax-overlay-pane\" tabindex=\"0\" aria-modal=\"true\" cdkTrapFocus\r\n        [class.ax-overlay-actionsheet]=\"_isMobile\">\r\n        <ax-color-palette [(value)]=\"value\" [(mode)]=\"_mode\">\r\n        </ax-color-palette>\r\n    </div>\r\n</ax-popover>"]}
|