@acorex/components 5.0.7 → 5.0.13
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/bundles/acorex-components.umd.js +1132 -954
- package/bundles/acorex-components.umd.js.map +1 -1
- package/esm2015/lib/badge/badge.component.js +2 -2
- package/esm2015/lib/base/mixin/base-components.class.js +22 -3
- package/esm2015/lib/base/mixin/button-mixin.class.js +92 -105
- package/esm2015/lib/base/mixin/clickable-mixin.class.js +1 -1
- package/esm2015/lib/base/mixin/dropdown-mixin.class.js +63 -9
- package/esm2015/lib/base/mixin/interactive-mixin.class.js +4 -4
- package/esm2015/lib/base/mixin/mixin.class.js +2 -2
- package/esm2015/lib/base/mixin/value-mixin.class.js +9 -4
- package/esm2015/lib/button/button-group.component.js +4 -4
- package/esm2015/lib/calendar/calendar.class.js +97 -0
- package/esm2015/lib/calendar/calendar.component.js +18 -68
- package/esm2015/lib/checkbox/checkbox.component.js +29 -11
- package/esm2015/lib/datepicker/datepicker.component.js +119 -65
- package/esm2015/lib/datepicker/datepicker.module.js +30 -6
- package/esm2015/lib/decorators/content.component.js +26 -0
- package/esm2015/lib/decorators/decorators.module.js +4 -3
- package/esm2015/lib/decorators/index.js +2 -1
- package/esm2015/lib/decorators/prefix.component.js +3 -4
- package/esm2015/lib/decorators/suffix.component.js +3 -4
- package/esm2015/lib/dialog/dialog.component.js +2 -2
- package/esm2015/lib/dropdown/dropdown-panel.component.js +7 -4
- package/esm2015/lib/dropdown/dropdown.component.js +10 -7
- package/esm2015/lib/form/form-hint.component.js +3 -3
- package/esm2015/lib/label/label.component.js +4 -4
- package/esm2015/lib/page/base-page.class.js +2 -1
- package/esm2015/lib/page/page-footer.component.js +3 -7
- package/esm2015/lib/popup/popup.component.js +16 -8
- package/esm2015/lib/radio/index.js +3 -0
- package/esm2015/lib/radio/radio.component.js +22 -0
- package/esm2015/lib/radio/radio.module.js +21 -0
- package/esm2015/lib/selectbox/selectbox.component.js +2 -2
- package/esm2015/lib/selection-list/selection-list.component.js +2 -2
- package/esm2015/lib/tabs/tab-content.directive.js +7 -5
- package/esm2015/lib/tabs/tab-item.component.js +29 -14
- package/esm2015/lib/tabs/tabs.component.js +15 -22
- package/esm2015/public-api.js +2 -1
- package/fesm2015/acorex-components.js +1051 -881
- package/fesm2015/acorex-components.js.map +1 -1
- package/lib/base/mixin/base-components.class.d.ts +23 -18
- package/lib/base/mixin/button-mixin.class.d.ts +12 -17
- package/lib/base/mixin/clickable-mixin.class.d.ts +4 -9
- package/lib/base/mixin/datalist-component.class.d.ts +10 -15
- package/lib/base/mixin/dropdown-mixin.class.d.ts +17 -12
- package/lib/base/mixin/interactive-mixin.class.d.ts +6 -11
- package/lib/base/mixin/loading-mixin.class.d.ts +4 -9
- package/lib/base/mixin/mixin.class.d.ts +182 -164
- package/lib/base/mixin/selection-component.class.d.ts +4 -9
- package/lib/base/mixin/sizable-mixin.class.d.ts +4 -9
- package/lib/base/mixin/textbox-mixin.class.d.ts +5 -12
- package/lib/base/mixin/value-mixin.class.d.ts +16 -20
- package/lib/button/button-item.component.d.ts +10 -20
- package/lib/calendar/calendar.class.d.ts +38 -0
- package/lib/calendar/calendar.component.d.ts +5 -26
- package/lib/checkbox/checkbox.component.d.ts +6 -5
- package/lib/datepicker/datepicker.component.d.ts +170 -16
- package/lib/datepicker/datepicker.module.d.ts +8 -2
- package/lib/decorators/content.component.d.ts +8 -0
- package/lib/decorators/decorators.module.d.ts +3 -2
- package/lib/decorators/index.d.ts +1 -0
- package/lib/dropdown/dropdown-panel.component.d.ts +4 -5
- package/lib/dropdown/dropdown.component.d.ts +5 -6
- package/lib/label/label.component.d.ts +2 -2
- package/lib/popup/popup.component.d.ts +3 -2
- package/lib/radio/index.d.ts +2 -0
- package/lib/radio/radio.component.d.ts +8 -0
- package/lib/radio/radio.module.d.ts +8 -0
- package/lib/tabs/tab-item.component.d.ts +2 -1
- package/lib/tabs/tabs.component.d.ts +2 -4
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/esm2015/lib/dropdown/dropdown-base.class.js +0 -98
- package/lib/dropdown/dropdown-base.class.d.ts +0 -92
|
@@ -9,7 +9,7 @@ export class AXBadgeComponent extends AXBaseComponentMixin {
|
|
|
9
9
|
//TODO: ax-badge
|
|
10
10
|
}
|
|
11
11
|
get __hostClass() {
|
|
12
|
-
return [`ax-bg-${this.color}-100`, `ax-text-${this.color}-
|
|
12
|
+
return [`ax-bg-${this.color}-100`, `ax-text-${this.color}-500`].join(' ');
|
|
13
13
|
}
|
|
14
14
|
}
|
|
15
15
|
AXBadgeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.6", ngImport: i0, type: AXBadgeComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
@@ -31,4 +31,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.6", ngImpor
|
|
|
31
31
|
type: HostBinding,
|
|
32
32
|
args: ['class']
|
|
33
33
|
}] } });
|
|
34
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmFkZ2UuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWNvcmV4L2NvbXBvbmVudHMvc3JjL2xpYi9iYWRnZS9iYWRnZS5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hY29yZXgvY29tcG9uZW50cy9zcmMvbGliL2JhZGdlL2JhZGdlLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsaUJBQWlCLEVBQUUsdUJBQXVCLEVBQWlDLEtBQUssRUFBRSxXQUFXLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekksT0FBTyxFQUFFLG9CQUFvQixFQUFvQixNQUFNLFNBQVMsQ0FBQzs7QUFTakUsTUFBTSxPQUFPLGdCQUFpQixTQUFRLG9CQUFvQjtJQU90RCxZQUNJLFVBQXNCLEVBQ3RCLEdBQXNCO1FBRXRCLEtBQUssQ0FBQyxVQUFVLEVBQUUsR0FBRyxDQUFDLENBQUM7UUFUbEIsU0FBSSxHQUFXLEVBQUUsQ0FBQztRQUVsQixVQUFLLEdBQXFCLE9BQU8sQ0FBQztRQVF2QyxnQkFBZ0I7SUFDcEIsQ0FBQztJQUdELElBQ1ksV0FBVztRQUNuQixPQUFPLENBQUMsU0FBUyxJQUFJLENBQUMsS0FBSyxNQUFNLEVBQUUsV0FBVyxJQUFJLENBQUMsS0FBSyxNQUFNLENBQUMsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7SUFDOUUsQ0FBQzs7NkdBbkJRLGdCQUFnQjtpR0FBaEIsZ0JBQWdCLG9NQ1Y3QixvSkFFNEM7MkZEUS9CLGdCQUFnQjtrQkFQNUIsU0FBUzttQkFBQztvQkFDUCxRQUFRLEVBQUUsVUFBVTtvQkFDcEIsV0FBVyxFQUFFLHdCQUF3QjtvQkFDckMsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07b0JBQy9DLGFBQWEsRUFBRSxpQkFBaUIsQ0FBQyxJQUFJO29CQUNyQyxJQUFJLEVBQUUsRUFBRSxLQUFLLEVBQUUsVUFBVSxFQUFFO2lCQUM5QjtpSUFHWSxJQUFJO3NCQUFaLEtBQUs7Z0JBRUcsS0FBSztzQkFBYixLQUFLO2dCQWFNLFdBQVc7c0JBRHRCLFdBQVc7dUJBQUMsT0FBTyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgVmlld0VuY2Fwc3VsYXRpb24sIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBFbGVtZW50UmVmLCBDaGFuZ2VEZXRlY3RvclJlZiwgSW5wdXQsIEhvc3RCaW5kaW5nIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEFYQmFzZUNvbXBvbmVudE1peGluLCBBWFN0eWxlQ29sb3JUeXBlIH0gZnJvbSAnLi4vYmFzZSc7XHJcblxyXG5AQ29tcG9uZW50KHtcclxuICAgIHNlbGVjdG9yOiAnYXgtYmFkZ2UnLFxyXG4gICAgdGVtcGxhdGVVcmw6ICcuL2JhZGdlLmNvbXBvbmVudC5odG1sJyxcclxuICAgIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG4gICAgZW5jYXBzdWxhdGlvbjogVmlld0VuY2Fwc3VsYXRpb24uTm9uZSxcclxuICAgIGhvc3Q6IHsgY2xhc3M6ICdheC1iYWRnZScgfVxyXG59KVxyXG5leHBvcnQgY2xhc3MgQVhCYWRnZUNvbXBvbmVudCBleHRlbmRzIEFYQmFzZUNvbXBvbmVudE1peGluIHtcclxuXHJcbiAgICBASW5wdXQoKSB0ZXh0OiBzdHJpbmcgPSAnJztcclxuXHJcbiAgICBASW5wdXQoKSBjb2xvcjogQVhTdHlsZUNvbG9yVHlwZSA9ICdsaWdodCc7XHJcblxyXG5cclxuICAgIGNvbnN0cnVjdG9yKFxyXG4gICAgICAgIGVsZW1lbnRSZWY6IEVsZW1lbnRSZWYsXHJcbiAgICAgICAgY2RyOiBDaGFuZ2VEZXRlY3RvclJlZlxyXG4gICAgKSB7XHJcbiAgICAgICAgc3VwZXIoZWxlbWVudFJlZiwgY2RyKTtcclxuICAgICAgICAvL1RPRE86IGF4LWJhZGdlXHJcbiAgICB9XHJcblxyXG5cclxuICAgIEBIb3N0QmluZGluZygnY2xhc3MnKVxyXG4gICAgcHJpdmF0ZSBnZXQgX19ob3N0Q2xhc3MoKTogc3RyaW5nIHtcclxuICAgICAgICByZXR1cm4gW2BheC1iZy0ke3RoaXMuY29sb3J9LTEwMGAsIGBheC10ZXh0LSR7dGhpcy5jb2xvcn0tNTAwYF0uam9pbignICcpO1xyXG4gICAgfVxyXG5cclxuXHJcbn1cclxuIiwiPG5nLWNvbnRlbnQgc2VsZWN0PVwiYXgtcHJlZml4XCI+PC9uZy1jb250ZW50PlxyXG48c3BhbiBjbGFzcz1cImF4LWZvbnQtbWVkaXVtXCI+e3t0ZXh0fX08L3NwYW4+XHJcbjxuZy1jb250ZW50IHNlbGVjdD1cImF4LXN1ZmZpeFwiPjwvbmctY29udGVudD4iXX0=
|
|
@@ -39,6 +39,7 @@ export class AXBaseComponent {
|
|
|
39
39
|
// this._getInnerElement()?.classList.add(this.rtl ? 'ax-rtl' : 'ax-ltr');
|
|
40
40
|
// this._getHostElement().setAttribute('data-id', this.id);
|
|
41
41
|
this.onInit();
|
|
42
|
+
this.onRenderCssClass();
|
|
42
43
|
}
|
|
43
44
|
_onInternalViewInit() {
|
|
44
45
|
this.onViewInit();
|
|
@@ -48,14 +49,32 @@ export class AXBaseComponent {
|
|
|
48
49
|
}
|
|
49
50
|
onInit() {
|
|
50
51
|
}
|
|
52
|
+
onRenderCssClass() {
|
|
53
|
+
}
|
|
51
54
|
onViewInit() {
|
|
52
55
|
}
|
|
53
56
|
onDestroy() {
|
|
54
57
|
}
|
|
55
|
-
|
|
58
|
+
_onOptionChanging(option) {
|
|
56
59
|
return option === null || option === void 0 ? void 0 : option.value;
|
|
57
60
|
}
|
|
58
|
-
|
|
61
|
+
_onOptionChanged(option) {
|
|
62
|
+
}
|
|
63
|
+
_setOption(option) {
|
|
64
|
+
const oldValue = this[option.name];
|
|
65
|
+
const newValue = this._onOptionChanging({ name: option.name, value: option.value });
|
|
66
|
+
//TODO : check real changes
|
|
67
|
+
if (oldValue != newValue) {
|
|
68
|
+
if (option.beforeCallback)
|
|
69
|
+
option.beforeCallback();
|
|
70
|
+
this[`_${option.name}`] = option.value;
|
|
71
|
+
this._onOptionChanged({ name: option.name, newValue, oldValue });
|
|
72
|
+
const emitter = this[`${option.name}Change`];
|
|
73
|
+
if (emitter)
|
|
74
|
+
emitter.emit(newValue);
|
|
75
|
+
if (option.afterCallback)
|
|
76
|
+
option.afterCallback();
|
|
77
|
+
}
|
|
59
78
|
}
|
|
60
79
|
}
|
|
61
80
|
_elementRef = new WeakMap();
|
|
@@ -80,4 +99,4 @@ export const BASE_INPUTS = [
|
|
|
80
99
|
'cssStyle'
|
|
81
100
|
];
|
|
82
101
|
export const BASE_OUTPUT = [];
|
|
83
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
102
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base-components.class.js","sourceRoot":"","sources":["../../../../../../../projects/acorex/components/src/lib/base/mixin/base-components.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, EventEmitter, Inject, Injectable } from \"@angular/core\";\r\nimport { ElementRef } from \"@angular/core\";\r\nimport { Constructor } from \"./constratctor\";\r\n\r\n\r\n/**\r\n* A token that specifies the size of component.\r\n*/\r\nexport type AXElementSize = 'xs' | 'sm' | 'md' | 'lg' | 'xl';\r\n\r\n\r\nexport type AXComponentOptionChanging = { name: string, value?: any };\r\nexport type AXComponentOptionChanged = { name: string, newValue?: any, oldValue?: any };\r\nexport type AXComponentSetOption = { name: string, value?: any, afterCallback?: () => void, beforeCallback?: () => void };\r\n\r\n@Injectable()\r\nexport class AXBaseComponent {\r\n    id: string = `AX${Math.round(Math.random() * Math.pow(10, 10))}`;\r\n\r\n    /**\r\n    * A token that specifies the layout direction of component.\r\n    */\r\n    rtl: boolean;\r\n\r\n    cssClass: string;\r\n    cssStyle: string;\r\n\r\n\r\n    #elementRef: ElementRef;\r\n    _cdr: ChangeDetectorRef;\r\n\r\n    _isInited: boolean;\r\n    _isRendered: boolean;\r\n\r\n    /**\r\n    *  @ignore\r\n    */\r\n    constructor(@Inject(Array) ...args: any[]) {\r\n        this.#elementRef = args[0];\r\n        this._cdr = args[1];\r\n    }\r\n\r\n    ngOnInit() {\r\n        this._isInited = true;\r\n        this._onInternalInit();\r\n    }\r\n\r\n    ngAfterViewInit() {\r\n        this._isRendered = true;\r\n        this._onInternalViewInit();\r\n    }\r\n\r\n    ngOnDestroy() {\r\n        this._onInternalDestroy();\r\n    }\r\n\r\n    _getHostElement<T = HTMLElement>(): T {\r\n        return this.#elementRef.nativeElement as T;\r\n    }\r\n\r\n    _getInnerElement<T = HTMLElement>(): T {\r\n        return this._getHostElement().firstElementChild as unknown as T;\r\n    }\r\n\r\n\r\n    _onInternalInit() {\r\n        (this._getHostElement() as any).__axContext__ = this;\r\n\r\n        if (this.rtl == null) {\r\n            this.rtl = window.getComputedStyle(this._getHostElement(), null).getPropertyValue('direction') === 'rtl';\r\n        }\r\n        //TODO: Apply \r\n        // this._getHostElement().classList.add(this.rtl ? 'ax-rtl' : 'ax-ltr');\r\n        // this._getInnerElement()?.classList.add(this.rtl ? 'ax-rtl' : 'ax-ltr');\r\n        // this._getHostElement().setAttribute('data-id', this.id);\r\n        this.onInit();\r\n        this.onRenderCssClass();\r\n    }\r\n\r\n    _onInternalViewInit() {\r\n        this.onViewInit();\r\n    }\r\n\r\n    _onInternalDestroy() {\r\n        this.onDestroy();\r\n    }\r\n\r\n    onInit() {\r\n    }\r\n\r\n    onRenderCssClass() {\r\n    }\r\n\r\n    onViewInit() {\r\n    }\r\n\r\n    onDestroy() {\r\n    }\r\n\r\n    _onOptionChanging(option: AXComponentOptionChanging) {\r\n        return option?.value;\r\n    }\r\n    _onOptionChanged(option: AXComponentOptionChanged): void {\r\n\r\n    }\r\n\r\n    _setOption(option: AXComponentSetOption) {\r\n        const oldValue = this[option.name];\r\n        const newValue = this._onOptionChanging({ name: option.name, value: option.value });\r\n        //TODO : check real changes\r\n        if (oldValue != newValue) {\r\n            if (option.beforeCallback)\r\n                option.beforeCallback();\r\n            this[`_${option.name}`] = option.value;\r\n            this._onOptionChanged({ name: option.name, newValue, oldValue });\r\n            const emitter = this[`${option.name}Change`] as EventEmitter<any>;\r\n            if (emitter)\r\n                emitter.emit(newValue);\r\n            if (option.afterCallback)\r\n                option.afterCallback();\r\n        }\r\n    }\r\n}\r\n\r\n\r\nexport function _BaseComponenetMixin<TBase extends Constructor<AXBaseComponent>>(Base: TBase) {\r\n    return class extends Base {\r\n        constructor(...args: any[]) {\r\n            super(...args);\r\n        }\r\n    }\r\n}\r\n\r\n\r\nexport const BASE_INPUTS = [\r\n    'rtl',\r\n    'cssClass',\r\n    'cssStyle'\r\n];\r\nexport const BASE_OUTPUT = [];\r\n"]}
|
|
@@ -1,120 +1,107 @@
|
|
|
1
|
-
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
2
1
|
import { EventEmitter } from '@angular/core';
|
|
3
2
|
export function _ButtonComponentMixin(Base) {
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
super(...args);
|
|
8
|
-
/**
|
|
9
|
-
* Defines the primary text to show inside the button.
|
|
10
|
-
*/
|
|
11
|
-
this.text = '';
|
|
12
|
-
/**
|
|
13
|
-
* Trigger click event by Enter Key
|
|
14
|
-
*/
|
|
15
|
-
this.submitBehavior = false;
|
|
16
|
-
/**
|
|
17
|
-
* Trigger click event by Esc Key
|
|
18
|
-
*/
|
|
19
|
-
this.cancelBehavior = false;
|
|
20
|
-
this.colorChange = new EventEmitter();
|
|
21
|
-
_color.set(this, 'primary');
|
|
22
|
-
this.lookChange = new EventEmitter();
|
|
23
|
-
_look.set(this, null);
|
|
24
|
-
this.toggleableChange = new EventEmitter();
|
|
25
|
-
_toggleable.set(this, false);
|
|
26
|
-
this.selectedChange = new EventEmitter();
|
|
27
|
-
_selected.set(this, false);
|
|
28
|
-
}
|
|
3
|
+
return class extends Base {
|
|
4
|
+
constructor(...args) {
|
|
5
|
+
super(...args);
|
|
29
6
|
/**
|
|
30
|
-
*
|
|
7
|
+
* Defines the primary text to show inside the button.
|
|
31
8
|
*/
|
|
32
|
-
|
|
33
|
-
return __classPrivateFieldGet(this, _color);
|
|
34
|
-
}
|
|
35
|
-
set color(value) {
|
|
36
|
-
value = this.onOptionChanging({ name: 'color', value: value });
|
|
37
|
-
if (value != __classPrivateFieldGet(this, _color)) {
|
|
38
|
-
const oldValue = this.color;
|
|
39
|
-
__classPrivateFieldSet(this, _color, value);
|
|
40
|
-
this.colorChange.emit(value);
|
|
41
|
-
this.onOptionChanged({ name: 'color', oldValue, newValue: value });
|
|
42
|
-
this._cdr.markForCheck();
|
|
43
|
-
}
|
|
44
|
-
}
|
|
9
|
+
this.text = '';
|
|
45
10
|
/**
|
|
46
|
-
*
|
|
11
|
+
* Trigger click event by Enter Key
|
|
47
12
|
*/
|
|
48
|
-
|
|
49
|
-
return __classPrivateFieldGet(this, _look);
|
|
50
|
-
}
|
|
51
|
-
set look(value) {
|
|
52
|
-
value = this.onOptionChanging({ name: 'look', value: value });
|
|
53
|
-
if (value != __classPrivateFieldGet(this, _look)) {
|
|
54
|
-
const oldValue = this.color;
|
|
55
|
-
__classPrivateFieldSet(this, _look, value);
|
|
56
|
-
this.lookChange.emit(value);
|
|
57
|
-
this.onOptionChanged({ name: 'look', oldValue, newValue: value });
|
|
58
|
-
this._cdr.markForCheck();
|
|
59
|
-
}
|
|
60
|
-
}
|
|
13
|
+
this.submitBehavior = false;
|
|
61
14
|
/**
|
|
62
|
-
*
|
|
15
|
+
* Trigger click event by Esc Key
|
|
63
16
|
*/
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
17
|
+
this.cancelBehavior = false;
|
|
18
|
+
this.colorChange = new EventEmitter();
|
|
19
|
+
this._color = 'primary';
|
|
20
|
+
this.lookChange = new EventEmitter();
|
|
21
|
+
this._look = null;
|
|
22
|
+
this.toggleableChange = new EventEmitter();
|
|
23
|
+
this._toggleable = false;
|
|
24
|
+
this.selectedChange = new EventEmitter();
|
|
25
|
+
this._selected = false;
|
|
26
|
+
}
|
|
27
|
+
/**
|
|
28
|
+
* Predefined color schemes
|
|
29
|
+
*/
|
|
30
|
+
get color() {
|
|
31
|
+
return this._color;
|
|
32
|
+
}
|
|
33
|
+
set color(value) {
|
|
34
|
+
this._setOption({
|
|
35
|
+
name: 'color',
|
|
36
|
+
value,
|
|
37
|
+
afterCallback: () => {
|
|
38
|
+
this._cdr.markForCheck();
|
|
74
39
|
}
|
|
75
|
-
}
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
40
|
+
});
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Predefined look schemes
|
|
44
|
+
*/
|
|
45
|
+
get look() {
|
|
46
|
+
return this._look;
|
|
47
|
+
}
|
|
48
|
+
set look(value) {
|
|
49
|
+
this._setOption({
|
|
50
|
+
name: 'look',
|
|
51
|
+
value,
|
|
52
|
+
afterCallback: () => {
|
|
88
53
|
this._cdr.markForCheck();
|
|
89
|
-
this.onOptionChanged({ name: 'selected', oldValue, newValue: value });
|
|
90
54
|
}
|
|
91
|
-
}
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Provides visual styling that indicates if the Button is active
|
|
59
|
+
*/
|
|
60
|
+
get toggleable() {
|
|
61
|
+
return this._toggleable;
|
|
62
|
+
}
|
|
63
|
+
set toggleable(value) {
|
|
64
|
+
this._setOption({
|
|
65
|
+
name: 'toggleable',
|
|
66
|
+
value
|
|
67
|
+
});
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* Indicates if the Button is selected or not
|
|
71
|
+
*/
|
|
72
|
+
get selected() {
|
|
73
|
+
return this._selected;
|
|
74
|
+
}
|
|
75
|
+
set selected(value) {
|
|
76
|
+
this._setOption({
|
|
77
|
+
name: 'selected',
|
|
78
|
+
value,
|
|
79
|
+
afterCallback: () => {
|
|
80
|
+
this._cdr.markForCheck();
|
|
98
81
|
}
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
_onInternalViewInit() {
|
|
85
|
+
super._onInternalViewInit();
|
|
86
|
+
if (this.submitBehavior) {
|
|
87
|
+
setTimeout(() => {
|
|
88
|
+
this.focus();
|
|
89
|
+
}, 0);
|
|
99
90
|
}
|
|
100
|
-
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
108
|
-
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
}
|
|
113
|
-
|
|
114
|
-
_look = new WeakMap(),
|
|
115
|
-
_toggleable = new WeakMap(),
|
|
116
|
-
_selected = new WeakMap(),
|
|
117
|
-
_a;
|
|
91
|
+
}
|
|
92
|
+
_onInternalDestroy() {
|
|
93
|
+
super._onInternalDestroy();
|
|
94
|
+
}
|
|
95
|
+
get _classes() {
|
|
96
|
+
const cssClasses = {
|
|
97
|
+
'ax-button-icon': !this.text,
|
|
98
|
+
'ax-state-disabled': this["disabled"],
|
|
99
|
+
'ax-state-selected': this.selected
|
|
100
|
+
};
|
|
101
|
+
cssClasses[`ax-${this.color || 'primary'}${this.look ? '-' + this.look : ''}`] = true;
|
|
102
|
+
return cssClasses;
|
|
103
|
+
}
|
|
104
|
+
};
|
|
118
105
|
}
|
|
119
106
|
export const BUTTON_INPUTS = [
|
|
120
107
|
'text',
|
|
@@ -126,4 +113,4 @@ export const BUTTON_INPUTS = [
|
|
|
126
113
|
'selected',
|
|
127
114
|
];
|
|
128
115
|
export const BUTTON_OUTPUT = ['onBlur', 'onFocus', 'onClick', 'selectedChange', 'toggleableChange'];
|
|
129
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-mixin.class.js","sourceRoot":"","sources":["../../../../../../../projects/acorex/components/src/lib/base/mixin/button-mixin.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter } from '@angular/core';\r\nimport { size } from 'lodash';\r\nimport { AXStyleColorType, AXStyleButtonLook } from '../styles.class';\r\nimport { AXBaseComponent } from './base-components.class';\r\nimport { Constructor } from './constratctor';\r\n\r\nexport function _ButtonComponentMixin<TBase extends Constructor<AXBaseComponent>>(Base: TBase) {\r\n  return class extends Base {\r\n    /**\r\n    *  Defines the primary text to show inside the button.\r\n    */\r\n    text: string = '';\r\n\r\n    /**\r\n    *  Trigger click event by Enter Key \r\n    */\r\n    submitBehavior: boolean = false;\r\n\r\n    /**\r\n    *  Trigger click event by Esc Key\r\n    */\r\n    cancelBehavior: boolean = false;\r\n\r\n\r\n\r\n\r\n    colorChange: EventEmitter<AXStyleColorType> = new EventEmitter();\r\n    #color: AXStyleColorType = 'primary';\r\n    /**\r\n    *  Predefined color schemes\r\n    */\r\n    get color(): AXStyleColorType {\r\n      return this.#color;\r\n    }\r\n    set color(value: AXStyleColorType) {\r\n      value = this.onOptionChanging({ name: 'color', value: value });\r\n      if (value != this.#color) {\r\n        const oldValue = this.color;\r\n        this.#color = value;\r\n        this.colorChange.emit(value);\r\n        this.onOptionChanged({ name: 'color', oldValue, newValue: value });\r\n        this._cdr.markForCheck();\r\n      }\r\n    }\r\n\r\n    lookChange: EventEmitter<AXStyleButtonLook> = new EventEmitter();\r\n    #look?: AXStyleButtonLook = null;\r\n    /**\r\n    *  Predefined look schemes\r\n    */\r\n    get look(): AXStyleButtonLook {\r\n      return this.#look;\r\n    }\r\n    set look(value: AXStyleButtonLook) {\r\n      value = this.onOptionChanging({ name: 'look', value: value });\r\n      if (value != this.#look) {\r\n        const oldValue = this.color;\r\n        this.#look = value;\r\n        this.lookChange.emit(value);\r\n        this.onOptionChanged({ name: 'look', oldValue, newValue: value });\r\n        this._cdr.markForCheck();\r\n      }\r\n    }\r\n\r\n\r\n    toggleableChange: EventEmitter<boolean> = new EventEmitter();\r\n    #toggleable?: boolean = false;\r\n    /**\r\n    *  Provides visual styling that indicates if the Button is active\r\n    */\r\n    get toggleable(): boolean {\r\n      return this.#toggleable;\r\n    }\r\n    set toggleable(value: boolean) {\r\n      value = this.onOptionChanging({ name: 'toggleable', value: value });\r\n      if (value != this.#toggleable) {\r\n        const oldValue = this.toggleable;\r\n        this.#toggleable = value;\r\n        this.toggleableChange.emit(value);\r\n        this.onOptionChanged({ name: 'toggleable', oldValue, newValue: value });\r\n      }\r\n    }\r\n\r\n\r\n    selectedChange: EventEmitter<boolean> = new EventEmitter();\r\n    #selected?: boolean = false;\r\n    /**\r\n    *  Indicates if the Button is selected or not\r\n    */\r\n    get selected(): boolean {\r\n      return this.#selected;\r\n    }\r\n    set selected(value: boolean) {\r\n      value = this.onOptionChanging({ name: 'selected', value: value });\r\n      if (value != this.#selected) {\r\n        const oldValue = this.selected;\r\n        this.#selected = value;\r\n        this.selectedChange.emit(value);\r\n        this._cdr.markForCheck();\r\n        this.onOptionChanged({ name: 'selected', oldValue, newValue: value });\r\n      }\r\n    }\r\n\r\n\r\n\r\n\r\n    constructor(...args: any[]) {\r\n      super(...args);\r\n    }\r\n\r\n    _onInternalViewInit() {\r\n      super._onInternalViewInit();\r\n      if (this.submitBehavior) {\r\n        setTimeout(() => {\r\n          (this as any).focus();\r\n        }, 0);\r\n      }\r\n    }\r\n\r\n    _onInternalDestroy() {\r\n      super._onInternalDestroy();\r\n    }\r\n\r\n\r\n    get _classes() {\r\n      const cssClasses = {\r\n        'ax-button-icon': !this.text,\r\n        'ax-state-disabled': this[\"disabled\"],\r\n        'ax-state-selected': this.selected\r\n      };\r\n      cssClasses[`ax-${this.color || 'primary'}${this.look ? '-' + this.look : ''}`] = true;\r\n      return cssClasses;\r\n    }\r\n  };\r\n}\r\n\r\nexport const BUTTON_INPUTS = [\r\n  'text',\r\n  'submitBehavior',\r\n  'cancelBehavior',\r\n  'color',\r\n  'look',\r\n  'toggleable',\r\n  'selected',\r\n];\r\nexport const BUTTON_OUTPUT = ['onBlur', 'onFocus', 'onClick', 'selectedChange', 'toggleableChange'];\r\n"]}
|
|
116
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"button-mixin.class.js","sourceRoot":"","sources":["../../../../../../../projects/acorex/components/src/lib/base/mixin/button-mixin.class.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAK7C,MAAM,UAAU,qBAAqB,CAA6C,IAAW;IAC3F,OAAO,KAAM,SAAQ,IAAI;QAuFvB,YAAY,GAAG,IAAW;YACxB,KAAK,CAAC,GAAG,IAAI,CAAC,CAAC;YAvFjB;;cAEE;YACF,SAAI,GAAW,EAAE,CAAC;YAElB;;cAEE;YACF,mBAAc,GAAY,KAAK,CAAC;YAEhC;;cAEE;YACF,mBAAc,GAAY,KAAK,CAAC;YAEhC,gBAAW,GAAmC,IAAI,YAAY,EAAE,CAAC;YACjE,WAAM,GAAqB,SAAS,CAAC;YAiBrC,eAAU,GAAoC,IAAI,YAAY,EAAE,CAAC;YACjE,UAAK,GAAuB,IAAI,CAAC;YAkBjC,qBAAgB,GAA0B,IAAI,YAAY,EAAE,CAAC;YAC7D,gBAAW,GAAa,KAAK,CAAC;YAe9B,mBAAc,GAA0B,IAAI,YAAY,EAAE,CAAC;YAC3D,cAAS,GAAa,KAAK,CAAC;QAmB5B,CAAC;QAvED;;UAEE;QACF,IAAI,KAAK;YACP,OAAO,IAAI,CAAC,MAAM,CAAC;QACrB,CAAC;QACD,IAAI,KAAK,CAAC,KAAuB;YAC/B,IAAI,CAAC,UAAU,CAAC;gBACd,IAAI,EAAE,OAAO;gBACb,KAAK;gBACL,aAAa,EAAE,GAAG,EAAE;oBAClB,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;gBAC3B,CAAC;aACF,CAAC,CAAC;QACL,CAAC;QAID;;UAEE;QACF,IAAI,IAAI;YACN,OAAO,IAAI,CAAC,KAAK,CAAC;QACpB,CAAC;QACD,IAAI,IAAI,CAAC,KAAwB;YAC/B,IAAI,CAAC,UAAU,CAAC;gBACd,IAAI,EAAE,MAAM;gBACZ,KAAK;gBACL,aAAa,EAAE,GAAG,EAAE;oBAClB,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;gBAC3B,CAAC;aACF,CAAC,CAAC;QACL,CAAC;QAKD;;UAEE;QACF,IAAI,UAAU;YACZ,OAAO,IAAI,CAAC,WAAW,CAAC;QAC1B,CAAC;QACD,IAAI,UAAU,CAAC,KAAc;YAC3B,IAAI,CAAC,UAAU,CAAC;gBACd,IAAI,EAAE,YAAY;gBAClB,KAAK;aACN,CAAC,CAAC;QACL,CAAC;QAKD;;UAEE;QACF,IAAI,QAAQ;YACV,OAAO,IAAI,CAAC,SAAS,CAAC;QACxB,CAAC;QACD,IAAI,QAAQ,CAAC,KAAc;YACzB,IAAI,CAAC,UAAU,CAAC;gBACd,IAAI,EAAE,UAAU;gBAChB,KAAK;gBACL,aAAa,EAAE,GAAG,EAAE;oBAClB,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC;gBAC3B,CAAC;aACF,CAAC,CAAC;QACL,CAAC;QAMD,mBAAmB;YACjB,KAAK,CAAC,mBAAmB,EAAE,CAAC;YAC5B,IAAI,IAAI,CAAC,cAAc,EAAE;gBACvB,UAAU,CAAC,GAAG,EAAE;oBACb,IAAY,CAAC,KAAK,EAAE,CAAC;gBACxB,CAAC,EAAE,CAAC,CAAC,CAAC;aACP;QACH,CAAC;QAED,kBAAkB;YAChB,KAAK,CAAC,kBAAkB,EAAE,CAAC;QAC7B,CAAC;QAGD,IAAI,QAAQ;YACV,MAAM,UAAU,GAAG;gBACjB,gBAAgB,EAAE,CAAC,IAAI,CAAC,IAAI;gBAC5B,mBAAmB,EAAE,IAAI,CAAC,UAAU,CAAC;gBACrC,mBAAmB,EAAE,IAAI,CAAC,QAAQ;aACnC,CAAC;YACF,UAAU,CAAC,MAAM,IAAI,CAAC,KAAK,IAAI,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,GAAG,IAAI,CAAC;YACtF,OAAO,UAAU,CAAC;QACpB,CAAC;KACF,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,MAAM,aAAa,GAAG;IAC3B,MAAM;IACN,gBAAgB;IAChB,gBAAgB;IAChB,OAAO;IACP,MAAM;IACN,YAAY;IACZ,UAAU;CACX,CAAC;AACF,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAE,gBAAgB,EAAE,kBAAkB,CAAC,CAAC","sourcesContent":["import { EventEmitter } from '@angular/core';\r\nimport { AXStyleColorType, AXStyleButtonLook } from '../styles.class';\r\nimport { AXBaseComponent } from './base-components.class';\r\nimport { Constructor } from './constratctor';\r\n\r\nexport function _ButtonComponentMixin<TBase extends Constructor<AXBaseComponent>>(Base: TBase) {\r\n  return class extends Base {\r\n    /**\r\n    *  Defines the primary text to show inside the button.\r\n    */\r\n    text: string = '';\r\n\r\n    /**\r\n    *  Trigger click event by Enter Key \r\n    */\r\n    submitBehavior: boolean = false;\r\n\r\n    /**\r\n    *  Trigger click event by Esc Key\r\n    */\r\n    cancelBehavior: boolean = false;\r\n\r\n    colorChange: EventEmitter<AXStyleColorType> = new EventEmitter();\r\n    _color: AXStyleColorType = 'primary';\r\n    /**\r\n    *  Predefined color schemes\r\n    */\r\n    get color(): AXStyleColorType {\r\n      return this._color;\r\n    }\r\n    set color(value: AXStyleColorType) {\r\n      this._setOption({\r\n        name: 'color',\r\n        value,\r\n        afterCallback: () => {\r\n          this._cdr.markForCheck();\r\n        }\r\n      });\r\n    }\r\n\r\n    lookChange: EventEmitter<AXStyleButtonLook> = new EventEmitter();\r\n    _look?: AXStyleButtonLook = null;\r\n    /**\r\n    *  Predefined look schemes\r\n    */\r\n    get look(): AXStyleButtonLook {\r\n      return this._look;\r\n    }\r\n    set look(value: AXStyleButtonLook) {\r\n      this._setOption({\r\n        name: 'look',\r\n        value,\r\n        afterCallback: () => {\r\n          this._cdr.markForCheck();\r\n        }\r\n      });\r\n    }\r\n\r\n\r\n    toggleableChange: EventEmitter<boolean> = new EventEmitter();\r\n    _toggleable?: boolean = false;\r\n    /**\r\n    *  Provides visual styling that indicates if the Button is active\r\n    */\r\n    get toggleable(): boolean {\r\n      return this._toggleable;\r\n    }\r\n    set toggleable(value: boolean) {\r\n      this._setOption({\r\n        name: 'toggleable',\r\n        value\r\n      });\r\n    }\r\n\r\n\r\n    selectedChange: EventEmitter<boolean> = new EventEmitter();\r\n    _selected?: boolean = false;\r\n    /**\r\n    *  Indicates if the Button is selected or not\r\n    */\r\n    get selected(): boolean {\r\n      return this._selected;\r\n    }\r\n    set selected(value: boolean) {\r\n      this._setOption({\r\n        name: 'selected',\r\n        value,\r\n        afterCallback: () => {\r\n          this._cdr.markForCheck();\r\n        }\r\n      });\r\n    }\r\n\r\n    constructor(...args: any[]) {\r\n      super(...args);\r\n    }\r\n\r\n    _onInternalViewInit() {\r\n      super._onInternalViewInit();\r\n      if (this.submitBehavior) {\r\n        setTimeout(() => {\r\n          (this as any).focus();\r\n        }, 0);\r\n      }\r\n    }\r\n\r\n    _onInternalDestroy() {\r\n      super._onInternalDestroy();\r\n    }\r\n\r\n\r\n    get _classes() {\r\n      const cssClasses = {\r\n        'ax-button-icon': !this.text,\r\n        'ax-state-disabled': this[\"disabled\"],\r\n        'ax-state-selected': this.selected\r\n      };\r\n      cssClasses[`ax-${this.color || 'primary'}${this.look ? '-' + this.look : ''}`] = true;\r\n      return cssClasses;\r\n    }\r\n  };\r\n}\r\n\r\nexport const BUTTON_INPUTS = [\r\n  'text',\r\n  'submitBehavior',\r\n  'cancelBehavior',\r\n  'color',\r\n  'look',\r\n  'toggleable',\r\n  'selected',\r\n];\r\nexport const BUTTON_OUTPUT = ['onBlur', 'onFocus', 'onClick', 'selectedChange', 'toggleableChange'];\r\n"]}
|
|
@@ -21,4 +21,4 @@ export function _ClickableComponenetMixin(Base) {
|
|
|
21
21
|
}
|
|
22
22
|
};
|
|
23
23
|
}
|
|
24
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
24
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2xpY2thYmxlLW1peGluLmNsYXNzLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYWNvcmV4L2NvbXBvbmVudHMvc3JjL2xpYi9iYXNlL21peGluL2NsaWNrYWJsZS1taXhpbi5jbGFzcy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBTTdDLE1BQU0sVUFBVSx5QkFBeUIsQ0FBNkMsSUFBVztJQUM3RixPQUFPLEtBQU0sU0FBUSxJQUFJO1FBZ0JyQjs7VUFFRTtRQUNGLFlBQVksR0FBRyxJQUFXO1lBQ3RCLEtBQUssQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDO1lBbEJuQjs7O2NBR0U7WUFDRixZQUFPLEdBQStCLElBQUksWUFBWSxFQUFnQixDQUFDO1FBZXZFLENBQUM7UUFiRCxpQkFBaUIsQ0FBQyxDQUFhO1lBQzNCLElBQUksQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDO2dCQUNkLFNBQVMsRUFBRSxJQUFJO2dCQUNmLFdBQVcsRUFBRSxJQUFJLENBQUMsZUFBZSxFQUFFO2dCQUNuQyxXQUFXLEVBQUUsQ0FBQzthQUNqQixDQUFDLENBQUM7UUFDUCxDQUFDO0tBUUosQ0FBQTtBQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBFdmVudEVtaXR0ZXIgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBBWEJhc2VDb21wb25lbnQgfSBmcm9tIFwiLi9iYXNlLWNvbXBvbmVudHMuY2xhc3NcIjtcclxuaW1wb3J0IHsgQ29uc3RydWN0b3IgfSBmcm9tIFwiLi9jb25zdHJhdGN0b3JcIjtcclxuaW1wb3J0IHsgQVhDbGlja0V2ZW50IH0gZnJvbSBcIi4uL2V2ZW50cy5jbGFzc1wiO1xyXG5cclxuXHJcbmV4cG9ydCBmdW5jdGlvbiBfQ2xpY2thYmxlQ29tcG9uZW5ldE1peGluPFRCYXNlIGV4dGVuZHMgQ29uc3RydWN0b3I8QVhCYXNlQ29tcG9uZW50Pj4oQmFzZTogVEJhc2Upe1xyXG4gICAgcmV0dXJuIGNsYXNzIGV4dGVuZHMgQmFzZSB7XHJcblxyXG4gICAgICAgIC8qKlxyXG4gICAgICAgICogIEZpcmVzIGVhY2ggdGltZSB0aGUgdXNlciBjbGlja3MgdGhlIGJ1dHRvbi5cclxuICAgICAgICAqICBAZXZlbnRcclxuICAgICAgICAqL1xyXG4gICAgICAgIG9uQ2xpY2s6IEV2ZW50RW1pdHRlcjxBWENsaWNrRXZlbnQ+ID0gbmV3IEV2ZW50RW1pdHRlcjxBWENsaWNrRXZlbnQ+KCk7XHJcblxyXG4gICAgICAgIF9lbWl0T25DbGlja0V2ZW50KGU6IE1vdXNlRXZlbnQpOiB2b2lkIHtcclxuICAgICAgICAgICAgdGhpcy5vbkNsaWNrLmVtaXQoe1xyXG4gICAgICAgICAgICAgICAgY29tcG9uZW50OiB0aGlzLFxyXG4gICAgICAgICAgICAgICAgaHRtbEVsZW1lbnQ6IHRoaXMuX2dldEhvc3RFbGVtZW50KCksXHJcbiAgICAgICAgICAgICAgICBuYXRpdmVFdmVudDogZVxyXG4gICAgICAgICAgICB9KTtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIC8qKlxyXG4gICAgICAgICogIEBpZ25vcmVcclxuICAgICAgICAqL1xyXG4gICAgICAgIGNvbnN0cnVjdG9yKC4uLmFyZ3M6IGFueVtdKSB7XHJcbiAgICAgICAgICAgIHN1cGVyKC4uLmFyZ3MpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxufVxyXG5cclxuIl19
|
|
@@ -1,18 +1,14 @@
|
|
|
1
|
-
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
2
|
-
import { coerceBooleanProperty } from "@angular/cdk/coercion";
|
|
3
1
|
import { EventEmitter } from "@angular/core";
|
|
4
2
|
export function _DropdownComponenetMixin(Base) {
|
|
5
|
-
var _readonly;
|
|
6
3
|
class Mixin extends Base {
|
|
7
4
|
constructor(...args) {
|
|
8
5
|
super(...args);
|
|
9
|
-
_readonly.set(this, false);
|
|
10
6
|
this.fitParent = true;
|
|
7
|
+
this.readonly = false;
|
|
11
8
|
this.onOpened = new EventEmitter();
|
|
12
9
|
this.onClosed = new EventEmitter();
|
|
10
|
+
this.position = [];
|
|
13
11
|
}
|
|
14
|
-
get readonly() { return __classPrivateFieldGet(this, _readonly); }
|
|
15
|
-
set readonly(value) { __classPrivateFieldSet(this, _readonly, coerceBooleanProperty(value)); }
|
|
16
12
|
_emitOnOpenedEvent() {
|
|
17
13
|
//** call from interactive mixin **//
|
|
18
14
|
//(this as any).focus();
|
|
@@ -23,14 +19,72 @@ export function _DropdownComponenetMixin(Base) {
|
|
|
23
19
|
});
|
|
24
20
|
}
|
|
25
21
|
_emitOnClosedEvent() {
|
|
26
|
-
this.focus();
|
|
27
22
|
this.onClosed.emit({
|
|
28
23
|
component: this,
|
|
29
24
|
htmlElement: this._getHostElement()
|
|
30
25
|
});
|
|
31
26
|
}
|
|
27
|
+
onViewInit() {
|
|
28
|
+
if (this.dropdownWidth == null) {
|
|
29
|
+
if (this.fitParent === true) {
|
|
30
|
+
this.dropdownWidth = this._getInnerElement().offsetWidth;
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
// wait for documentElement
|
|
34
|
+
setTimeout(() => {
|
|
35
|
+
if (this.position.length == 0) {
|
|
36
|
+
const offset = Number(getComputedStyle(document.documentElement).getPropertyValue('--ax-base-size').replace('px', ''));
|
|
37
|
+
const list = [
|
|
38
|
+
{
|
|
39
|
+
originX: 'start',
|
|
40
|
+
originY: 'bottom',
|
|
41
|
+
overlayX: 'start',
|
|
42
|
+
overlayY: 'top',
|
|
43
|
+
offsetY: offset
|
|
44
|
+
},
|
|
45
|
+
{
|
|
46
|
+
originX: 'start',
|
|
47
|
+
originY: 'top',
|
|
48
|
+
overlayX: 'start',
|
|
49
|
+
overlayY: 'bottom',
|
|
50
|
+
offsetY: -offset
|
|
51
|
+
}
|
|
52
|
+
];
|
|
53
|
+
this.position.push(...list);
|
|
54
|
+
}
|
|
55
|
+
}, 500);
|
|
56
|
+
}
|
|
57
|
+
toggle() {
|
|
58
|
+
if (this['disabled'] !== true) {
|
|
59
|
+
this.popover.toggle();
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
close() {
|
|
63
|
+
if (!this.isOpen || this['disabled']) {
|
|
64
|
+
return;
|
|
65
|
+
}
|
|
66
|
+
this.popover.close();
|
|
67
|
+
this._emitOnClosedEvent();
|
|
68
|
+
}
|
|
69
|
+
open() {
|
|
70
|
+
if (this.isOpen || this['disabled']) {
|
|
71
|
+
return;
|
|
72
|
+
}
|
|
73
|
+
this.popover.open();
|
|
74
|
+
this._emitOnOpenedEvent();
|
|
75
|
+
}
|
|
76
|
+
get isOpen() {
|
|
77
|
+
var _a;
|
|
78
|
+
return (_a = this.popover) === null || _a === void 0 ? void 0 : _a.isOpen;
|
|
79
|
+
}
|
|
32
80
|
}
|
|
33
|
-
_readonly = new WeakMap();
|
|
34
81
|
return Mixin;
|
|
35
82
|
}
|
|
36
|
-
|
|
83
|
+
export const DROPDOWN_INPUTS = [
|
|
84
|
+
'isOpen',
|
|
85
|
+
'fitParent',
|
|
86
|
+
'dropdownWidth',
|
|
87
|
+
'position'
|
|
88
|
+
];
|
|
89
|
+
export const DROPDOWN_OUTPUT = ['onOpened', 'onClosed'];
|
|
90
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown-mixin.class.js","sourceRoot":"","sources":["../../../../../../../projects/acorex/components/src/lib/base/mixin/dropdown-mixin.class.ts"],"names":[],"mappings":"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","sourcesContent":["import { EventEmitter } from \"@angular/core\";\r\nimport { AXBaseComponent } from \"./base-components.class\";\r\nimport { Constructor } from \"./constratctor\";\r\nimport { AXEvent } from \"../events.class\";\r\nimport { AXPopoverComponent } from \"../../popover/popover.component\";\r\nimport { AXConnectedPosition } from \"../drawing.class\";\r\n\r\n\r\n\r\nexport interface DropdownComponentInterface\r\n{\r\n    open():void;\r\n    close():void;\r\n    toggle():void;\r\n    isOpen:boolean;\r\n}\r\n\r\n\r\nexport function _DropdownComponenetMixin<TBase extends Constructor<AXBaseComponent>>(Base: TBase) {\r\n\r\n    abstract class Mixin extends Base {\r\n        fitParent: boolean = true;\r\n        readonly: boolean = false;\r\n    \r\n        dropdownWidth: number;\r\n    \r\n        onOpened: EventEmitter<AXEvent> = new EventEmitter<AXEvent>();\r\n        onClosed: EventEmitter<AXEvent> = new EventEmitter<AXEvent>();\r\n    \r\n        abstract popover: AXPopoverComponent;\r\n    \r\n        position: AXConnectedPosition[] = [];\r\n    \r\n        _emitOnOpenedEvent() {\r\n            //** call from interactive mixin **//\r\n            //(this as any).focus();\r\n            //\r\n            this.onOpened.emit({\r\n                component: this,\r\n                htmlElement: this._getHostElement()\r\n            });\r\n        }\r\n    \r\n        _emitOnClosedEvent() {\r\n            this.onClosed.emit({\r\n                component: this,\r\n                htmlElement: this._getHostElement()\r\n            });\r\n        }\r\n    \r\n        onViewInit() {\r\n            if (this.dropdownWidth == null) {\r\n                if (this.fitParent === true) {\r\n                    this.dropdownWidth = this._getInnerElement().offsetWidth;\r\n                }\r\n            }\r\n            // wait for documentElement\r\n            setTimeout(() => {\r\n                if (this.position.length == 0) {\r\n                    const offset = Number(getComputedStyle(document.documentElement).getPropertyValue('--ax-base-size').replace('px', ''));\r\n                    const list: AXConnectedPosition[] = [\r\n                        {\r\n                            originX: 'start',\r\n                            originY: 'bottom',\r\n                            overlayX: 'start',\r\n                            overlayY: 'top',\r\n                            offsetY: offset\r\n                        },\r\n                        {\r\n                            originX: 'start',\r\n                            originY: 'top',\r\n                            overlayX: 'start',\r\n                            overlayY: 'bottom',\r\n                            offsetY: -offset\r\n                        }\r\n                    ];\r\n                    this.position.push(...list);\r\n                }\r\n            }, 500);\r\n        }\r\n    \r\n        toggle() {\r\n            if (this['disabled'] !== true) {\r\n                this.popover.toggle();\r\n            }\r\n        }\r\n    \r\n        close() {\r\n            if (!this.isOpen || this['disabled']) {\r\n                return;\r\n            }\r\n            this.popover.close();\r\n            this._emitOnClosedEvent();\r\n        }\r\n    \r\n        open() {\r\n            if (this.isOpen || this['disabled']) {\r\n                return;\r\n            }\r\n            this.popover.open();\r\n            this._emitOnOpenedEvent();\r\n        }\r\n    \r\n        get isOpen(): boolean {\r\n            return this.popover?.isOpen;\r\n        }\r\n    \r\n        constructor(...args: any[]) {\r\n            super(...args);\r\n        }\r\n\r\n    }\r\n\r\n    return Mixin;\r\n}\r\n\r\n\r\nexport const DROPDOWN_INPUTS = [\r\n    'isOpen',\r\n    'fitParent',\r\n    'dropdownWidth',\r\n    'position'\r\n  ];\r\n  export const DROPDOWN_OUTPUT = ['onOpened', 'onClosed'];"]}
|
|
@@ -10,7 +10,7 @@ export function _InteractiveComponenetMixin(Base) {
|
|
|
10
10
|
constructor(...args) {
|
|
11
11
|
super(...args);
|
|
12
12
|
_disabled.set(this, false);
|
|
13
|
-
_tabIndex.set(this,
|
|
13
|
+
_tabIndex.set(this, null);
|
|
14
14
|
/**
|
|
15
15
|
* Fires each time the component gets focused.
|
|
16
16
|
* @event
|
|
@@ -27,11 +27,11 @@ export function _InteractiveComponenetMixin(Base) {
|
|
|
27
27
|
*/
|
|
28
28
|
get disabled() { return __classPrivateFieldGet(this, _disabled); }
|
|
29
29
|
set disabled(value) {
|
|
30
|
-
value = this.
|
|
30
|
+
value = this._onOptionChanging({ name: 'disabled', value: value });
|
|
31
31
|
if (value != this.disabled) {
|
|
32
32
|
const oldValue = this.disabled;
|
|
33
33
|
__classPrivateFieldSet(this, _disabled, coerceBooleanProperty(value));
|
|
34
|
-
this.
|
|
34
|
+
this._onOptionChanged({ name: 'disabled', oldValue, newValue: value });
|
|
35
35
|
this._cdr.markForCheck();
|
|
36
36
|
}
|
|
37
37
|
}
|
|
@@ -74,4 +74,4 @@ export const INTERACTIVE_INPUTS = [
|
|
|
74
74
|
'tabIndex',
|
|
75
75
|
];
|
|
76
76
|
export const INTERACTIVE_OUTPUT = ['onBlur', 'onFocus'];
|
|
77
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
77
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW50ZXJhY3RpdmUtbWl4aW4uY2xhc3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hY29yZXgvY29tcG9uZW50cy9zcmMvbGliL2Jhc2UvbWl4aW4vaW50ZXJhY3RpdmUtbWl4aW4uY2xhc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3BGLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFNN0MsTUFBTSxVQUFVLDJCQUEyQixDQUE2QyxJQUFXOztJQUMvRixNQUFlLEtBQU0sU0FBUSxJQUFJO1FBa0U3Qjs7VUFFRTtRQUNGLFlBQVksR0FBRyxJQUFXO1lBQ3RCLEtBQUssQ0FBQyxHQUFHLElBQUksQ0FBQyxDQUFDO1lBcEVuQixvQkFBcUIsS0FBSyxFQUFDO1lBaUIzQixvQkFBb0IsSUFBSSxFQUFDO1lBU3pCOzs7Y0FHRTtZQUNGLFlBQU8sR0FBK0IsSUFBSSxZQUFZLEVBQWdCLENBQUM7WUFVdkU7OztjQUdFO1lBQ0YsV0FBTSxHQUErQixJQUFJLFlBQVksRUFBZ0IsQ0FBQztRQXlCdEUsQ0FBQztRQXBFRDs7VUFFRTtRQUNGLElBQUksUUFBUSxLQUFjLCtDQUFzQixDQUFDLENBQUM7UUFDbEQsSUFBSSxRQUFRLENBQUMsS0FBYztZQUN2QixLQUFLLEdBQUcsSUFBSSxDQUFDLGlCQUFpQixDQUFDLEVBQUUsSUFBSSxFQUFFLFVBQVUsRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLENBQUMsQ0FBQztZQUNuRSxJQUFJLEtBQUssSUFBSSxJQUFJLENBQUMsUUFBUSxFQUFFO2dCQUN4QixNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDO2dCQUMvQix1QkFBQSxJQUFJLGFBQWEscUJBQXFCLENBQUMsS0FBSyxDQUFDLEVBQUM7Z0JBQzlDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxFQUFFLElBQUksRUFBRSxVQUFVLEVBQUUsUUFBUSxFQUFFLFFBQVEsRUFBRSxLQUFLLEVBQUUsQ0FBQyxDQUFDO2dCQUN2RSxJQUFJLENBQUMsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO2FBQzVCO1FBQ0wsQ0FBQztRQUtEOztVQUVFO1FBQ0YsSUFBSSxRQUFRLEtBQWEsT0FBTyxJQUFJLENBQUMsUUFBUSxJQUFLLElBQVksQ0FBQyxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsd0NBQWUsQ0FBQyxDQUFDLENBQUM7UUFDaEcsSUFBSSxRQUFRLENBQUMsS0FBYTtZQUN0Qix1QkFBQSxJQUFJLGFBQWEsS0FBSyxJQUFJLElBQUksQ0FBQyxDQUFDLENBQUMsb0JBQW9CLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBQztRQUNyRSxDQUFDO1FBUUQsaUJBQWlCLENBQUMsQ0FBYTtZQUMzQixJQUFJLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQztnQkFDZCxTQUFTLEVBQUUsSUFBSTtnQkFDZixXQUFXLEVBQUUsSUFBSSxDQUFDLGVBQWUsRUFBRTtnQkFDbkMsV0FBVyxFQUFFLENBQUM7YUFDakIsQ0FBQyxDQUFDO1FBQ1AsQ0FBQztRQVFELGdCQUFnQixDQUFDLENBQWE7WUFDMUIsSUFBSSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUM7Z0JBQ2IsU0FBUyxFQUFFLElBQUk7Z0JBQ2YsV0FBVyxFQUFFLElBQUksQ0FBQyxlQUFlLEVBQUU7Z0JBQ25DLFdBQVcsRUFBRSxDQUFDO2FBQ2pCLENBQUMsQ0FBQztRQUNQLENBQUM7UUFFRDs7VUFFRTtRQUNGLEtBQUs7WUFDRCxNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsZUFBZSxFQUFFLENBQUMsYUFBYSxDQUFjLDBFQUEwRSxDQUFDLENBQUM7WUFDaEosSUFBSSxTQUFTLEVBQUU7Z0JBQ1gsU0FBUyxDQUFDLEtBQUssRUFBRSxDQUFDO2FBQ3JCO1FBQ0wsQ0FBQztLQVFKOztJQUNELE9BQU8sS0FBSyxDQUFDO0FBQ2pCLENBQUM7QUFFRCxNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRztJQUM5QixVQUFVO0lBQ1YsVUFBVTtDQUNYLENBQUM7QUFDRixNQUFNLENBQUMsTUFBTSxrQkFBa0IsR0FBRyxDQUFDLFFBQVEsRUFBRSxTQUFTLENBQUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IGNvZXJjZUJvb2xlYW5Qcm9wZXJ0eSwgY29lcmNlTnVtYmVyUHJvcGVydHkgfSBmcm9tIFwiQGFuZ3VsYXIvY2RrL2NvZXJjaW9uXCI7XHJcbmltcG9ydCB7IEV2ZW50RW1pdHRlciB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IEFYQmFzZUNvbXBvbmVudCB9IGZyb20gXCIuL2Jhc2UtY29tcG9uZW50cy5jbGFzc1wiO1xyXG5pbXBvcnQgeyBDb25zdHJ1Y3RvciB9IGZyb20gXCIuL2NvbnN0cmF0Y3RvclwiO1xyXG5pbXBvcnQgeyBBWEZvY3VzRXZlbnQgfSBmcm9tIFwiLi4vZXZlbnRzLmNsYXNzXCI7XHJcblxyXG5cclxuZXhwb3J0IGZ1bmN0aW9uIF9JbnRlcmFjdGl2ZUNvbXBvbmVuZXRNaXhpbjxUQmFzZSBleHRlbmRzIENvbnN0cnVjdG9yPEFYQmFzZUNvbXBvbmVudD4+KEJhc2U6IFRCYXNlKSB7XHJcbiAgICBhYnN0cmFjdCBjbGFzcyBNaXhpbiBleHRlbmRzIEJhc2Uge1xyXG5cclxuICAgICAgICAjZGlzYWJsZWQ6IGJvb2xlYW4gPSBmYWxzZTtcclxuICAgICAgICAvKipcclxuICAgICAgICAqICBJZiBzZXQgdG8gdHJ1ZSwgaXQgZGlzYWJsZXMgdGhlIGNvbXBvbmVudC5cclxuICAgICAgICAqL1xyXG4gICAgICAgIGdldCBkaXNhYmxlZCgpOiBib29sZWFuIHsgcmV0dXJuIHRoaXMuI2Rpc2FibGVkOyB9XHJcbiAgICAgICAgc2V0IGRpc2FibGVkKHZhbHVlOiBib29sZWFuKSB7XHJcbiAgICAgICAgICAgIHZhbHVlID0gdGhpcy5fb25PcHRpb25DaGFuZ2luZyh7IG5hbWU6ICdkaXNhYmxlZCcsIHZhbHVlOiB2YWx1ZSB9KTtcclxuICAgICAgICAgICAgaWYgKHZhbHVlICE9IHRoaXMuZGlzYWJsZWQpIHtcclxuICAgICAgICAgICAgICAgIGNvbnN0IG9sZFZhbHVlID0gdGhpcy5kaXNhYmxlZDtcclxuICAgICAgICAgICAgICAgIHRoaXMuI2Rpc2FibGVkID0gY29lcmNlQm9vbGVhblByb3BlcnR5KHZhbHVlKTtcclxuICAgICAgICAgICAgICAgIHRoaXMuX29uT3B0aW9uQ2hhbmdlZCh7IG5hbWU6ICdkaXNhYmxlZCcsIG9sZFZhbHVlLCBuZXdWYWx1ZTogdmFsdWUgfSk7XHJcbiAgICAgICAgICAgICAgICB0aGlzLl9jZHIubWFya0ZvckNoZWNrKCk7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9XHJcblxyXG5cclxuXHJcbiAgICAgICAgI3RhYkluZGV4OiBudW1iZXIgPSBudWxsO1xyXG4gICAgICAgIC8qKlxyXG4gICAgICAgICogIFNwZWNpZmllcyB0aGUgdGFiaW5kZXggb2YgdGhlIGNvbXBvbmVudC5cclxuICAgICAgICAqL1xyXG4gICAgICAgIGdldCB0YWJJbmRleCgpOiBudW1iZXIgeyByZXR1cm4gdGhpcy5kaXNhYmxlZCB8fCAodGhpcyBhcyBhbnkpLnJlYWRvbmx5ID8gLTEgOiB0aGlzLiN0YWJJbmRleDsgfVxyXG4gICAgICAgIHNldCB0YWJJbmRleCh2YWx1ZTogbnVtYmVyKSB7XHJcbiAgICAgICAgICAgIHRoaXMuI3RhYkluZGV4ID0gdmFsdWUgIT0gbnVsbCA/IGNvZXJjZU51bWJlclByb3BlcnR5KHZhbHVlKSA6IDA7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICAvKipcclxuICAgICAgICAqICBGaXJlcyBlYWNoIHRpbWUgdGhlIGNvbXBvbmVudCBnZXRzIGZvY3VzZWQuXHJcbiAgICAgICAgKiAgQGV2ZW50XHJcbiAgICAgICAgKi9cclxuICAgICAgICBvbkZvY3VzOiBFdmVudEVtaXR0ZXI8QVhGb2N1c0V2ZW50PiA9IG5ldyBFdmVudEVtaXR0ZXI8QVhGb2N1c0V2ZW50PigpO1xyXG5cclxuICAgICAgICBfZW1pdE9uRm9jdXNFdmVudChlOiBGb2N1c0V2ZW50KTogdm9pZCB7XHJcbiAgICAgICAgICAgIHRoaXMub25Gb2N1cy5lbWl0KHtcclxuICAgICAgICAgICAgICAgIGNvbXBvbmVudDogdGhpcyxcclxuICAgICAgICAgICAgICAgIGh0bWxFbGVtZW50OiB0aGlzLl9nZXRIb3N0RWxlbWVudCgpLFxyXG4gICAgICAgICAgICAgICAgbmF0aXZlRXZlbnQ6IGVcclxuICAgICAgICAgICAgfSk7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICAvKipcclxuICAgICAgICAqICBGaXJlcyBlYWNoIHRpbWUgdGhlIGNvbXBvbmVudCBnZXRzIGJsdXJyZWQuXHJcbiAgICAgICAgKiAgQGV2ZW50XHJcbiAgICAgICAgKi9cclxuICAgICAgICBvbkJsdXI6IEV2ZW50RW1pdHRlcjxBWEZvY3VzRXZlbnQ+ID0gbmV3IEV2ZW50RW1pdHRlcjxBWEZvY3VzRXZlbnQ+KCk7XHJcblxyXG4gICAgICAgIF9lbWl0T25CbHVyRXZlbnQoZTogRm9jdXNFdmVudCk6IHZvaWQge1xyXG4gICAgICAgICAgICB0aGlzLm9uQmx1ci5lbWl0KHtcclxuICAgICAgICAgICAgICAgIGNvbXBvbmVudDogdGhpcyxcclxuICAgICAgICAgICAgICAgIGh0bWxFbGVtZW50OiB0aGlzLl9nZXRIb3N0RWxlbWVudCgpLFxyXG4gICAgICAgICAgICAgICAgbmF0aXZlRXZlbnQ6IGVcclxuICAgICAgICAgICAgfSk7XHJcbiAgICAgICAgfVxyXG5cclxuICAgICAgICAvKipcclxuICAgICAgICAqICBGb2N1c2VzIHRoZSBjb21wb25lbnQuXHJcbiAgICAgICAgKi9cclxuICAgICAgICBmb2N1cygpOiB2b2lkIHtcclxuICAgICAgICAgICAgY29uc3QgZm9jdXNhYmxlID0gdGhpcy5fZ2V0SG9zdEVsZW1lbnQoKS5xdWVyeVNlbGVjdG9yPEhUTUxFbGVtZW50PignYnV0dG9uLCBbaHJlZl0sIGlucHV0LCBzZWxlY3QsIHRleHRhcmVhLCBbdGFiaW5kZXhdOm5vdChbdGFiaW5kZXg9XCItMVwiXSknKTtcclxuICAgICAgICAgICAgaWYgKGZvY3VzYWJsZSkge1xyXG4gICAgICAgICAgICAgICAgZm9jdXNhYmxlLmZvY3VzKCk7XHJcbiAgICAgICAgICAgIH1cclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIC8qKlxyXG4gICAgICAgICogIEBpZ25vcmVcclxuICAgICAgICAqL1xyXG4gICAgICAgIGNvbnN0cnVjdG9yKC4uLmFyZ3M6IGFueVtdKSB7XHJcbiAgICAgICAgICAgIHN1cGVyKC4uLmFyZ3MpO1xyXG4gICAgICAgIH1cclxuICAgIH1cclxuICAgIHJldHVybiBNaXhpbjtcclxufVxyXG5cclxuZXhwb3J0IGNvbnN0IElOVEVSQUNUSVZFX0lOUFVUUyA9IFtcclxuICAgICdkaXNhYmxlZCcsXHJcbiAgICAndGFiSW5kZXgnLFxyXG4gIF07XHJcbiAgZXhwb3J0IGNvbnN0IElOVEVSQUNUSVZFX09VVFBVVCA9IFsnb25CbHVyJywgJ29uRm9jdXMnXTsiXX0=
|
|
@@ -18,5 +18,5 @@ export const AXBaseTextBoxMixin = _SizableComponenetMixin(_InteractiveComponenet
|
|
|
18
18
|
export const AXBaseSelectionValueMixin = _SizableComponenetMixin(_InteractiveComponenetMixin(_DatalistComponenetMixin(_SelectionComponenetMixin(_ValueComponenetMixin(AXBaseComponent)))));
|
|
19
19
|
export const AXBaseValueDropdownMixin = _SizableComponenetMixin(_InteractiveComponenetMixin(_DropdownComponenetMixin(_DatalistComponenetMixin(_ValueComponenetMixin(AXBaseComponent)))));
|
|
20
20
|
export const AXBaseSelectionDropdownMixin = _SizableComponenetMixin(_InteractiveComponenetMixin(_DropdownComponenetMixin(_DatalistComponenetMixin(_SelectionComponenetMixin(_ValueComponenetMixin(AXBaseComponent))))));
|
|
21
|
-
export const
|
|
22
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
21
|
+
export const AXBaseDropdownMixin = _SizableComponenetMixin(_InteractiveComponenetMixin(_DropdownComponenetMixin(AXBaseComponent)));
|
|
22
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWl4aW4uY2xhc3MuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hY29yZXgvY29tcG9uZW50cy9zcmMvbGliL2Jhc2UvbWl4aW4vbWl4aW4uY2xhc3MudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLGVBQWUsRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ2hGLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQzdELE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3BFLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDO0FBQ3RFLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBQ2xFLE9BQU8sRUFBRSwyQkFBMkIsRUFBRSxNQUFNLDJCQUEyQixDQUFDO0FBRXhFLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBQ3hFLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ2hFLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ2hFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBRTVELE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUFHLG9CQUFvQixDQUFDLGVBQWUsQ0FBQyxDQUFDO0FBRTFFLE1BQU0sQ0FBQyxNQUFNLHVCQUF1QixHQUFHLHVCQUF1QixDQUM1RCxvQkFBb0IsQ0FBQyxlQUFlLENBQUMsQ0FDdEMsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLDRCQUE0QixHQUFHLHVCQUF1QixDQUNqRSwyQkFBMkIsQ0FBQyxlQUFlLENBQUMsQ0FDN0MsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLG9CQUFvQixHQUFHLHVCQUF1QixDQUN6RCwyQkFBMkIsQ0FBQyx5QkFBeUIsQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUN4RSxDQUFDO0FBRUYsTUFBTSxDQUFDLE1BQU0saUJBQWlCLEdBQUcsdUJBQXVCLENBQ3RELDJCQUEyQixDQUN6Qix5QkFBeUIsQ0FBQyxxQkFBcUIsQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUNsRSxDQUNGLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSx5QkFBeUIsR0FBRyx1QkFBdUIsQ0FDOUQsMkJBQTJCLENBQUMscUJBQXFCLENBQU0sZUFBZSxDQUFDLENBQUMsQ0FDekUsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLGtCQUFrQixHQUFHLHVCQUF1QixDQUN2RCwyQkFBMkIsQ0FDekIscUJBQXFCLENBQUMsdUJBQXVCLENBQUMsZUFBZSxDQUFDLENBQUMsQ0FDaEUsQ0FDRixDQUFDO0FBR0YsTUFBTSxDQUFDLE1BQU0seUJBQXlCLEdBQUcsdUJBQXVCLENBQzlELDJCQUEyQixDQUN6Qix3QkFBd0IsQ0FDdEIseUJBQXlCLENBQUMscUJBQXFCLENBQU0sZUFBZSxDQUFDLENBQUMsQ0FDdkUsQ0FDRixDQUNGLENBQUM7QUFFRixNQUFNLENBQUMsTUFBTSx3QkFBd0IsR0FBRyx1QkFBdUIsQ0FDN0QsMkJBQTJCLENBQ3pCLHdCQUF3QixDQUN0Qix3QkFBd0IsQ0FBQyxxQkFBcUIsQ0FBTSxlQUFlLENBQUMsQ0FBQyxDQUN0RSxDQUNGLENBQ0YsQ0FBQztBQUVGLE1BQU0sQ0FBQyxNQUFNLDRCQUE0QixHQUFHLHVCQUF1QixDQUNqRSwyQkFBMkIsQ0FDekIsd0JBQXdCLENBQ3RCLHdCQUF3QixDQUN0Qix5QkFBeUIsQ0FBQyxxQkFBcUIsQ0FBTSxlQUFlLENBQUMsQ0FBQyxDQUN2RSxDQUNGLENBQ0YsQ0FDRixDQUFDO0FBR0YsTUFBTSxDQUFDLE1BQU0sbUJBQW1CLEdBQUcsdUJBQXVCLENBQ3hELDJCQUEyQixDQUFDLHdCQUF3QixDQUFDLGVBQWUsQ0FBQyxDQUFDLENBQ3ZFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBBWEJhc2VDb21wb25lbnQsIF9CYXNlQ29tcG9uZW5ldE1peGluIH0gZnJvbSAnLi9iYXNlLWNvbXBvbmVudHMuY2xhc3MnO1xyXG5pbXBvcnQgeyBfQnV0dG9uQ29tcG9uZW50TWl4aW4gfSBmcm9tICcuL2J1dHRvbi1taXhpbi5jbGFzcyc7XHJcbmltcG9ydCB7IF9DbGlja2FibGVDb21wb25lbmV0TWl4aW4gfSBmcm9tICcuL2NsaWNrYWJsZS1taXhpbi5jbGFzcyc7XHJcbmltcG9ydCB7IF9EYXRhbGlzdENvbXBvbmVuZXRNaXhpbiB9IGZyb20gJy4vZGF0YWxpc3QtY29tcG9uZW50LmNsYXNzJztcclxuaW1wb3J0IHsgX0Ryb3Bkb3duQ29tcG9uZW5ldE1peGluIH0gZnJvbSAnLi9kcm9wZG93bi1taXhpbi5jbGFzcyc7XHJcbmltcG9ydCB7IF9JbnRlcmFjdGl2ZUNvbXBvbmVuZXRNaXhpbiB9IGZyb20gJy4vaW50ZXJhY3RpdmUtbWl4aW4uY2xhc3MnO1xyXG5pbXBvcnQgeyBfTG9hZGluZ0NvbXBvbmVuZXRNaXhpbiB9IGZyb20gJy4vbG9hZGluZy1taXhpbi5jbGFzcyc7XHJcbmltcG9ydCB7IF9TZWxlY3Rpb25Db21wb25lbmV0TWl4aW4gfSBmcm9tICcuL3NlbGVjdGlvbi1jb21wb25lbnQuY2xhc3MnO1xyXG5pbXBvcnQgeyBfU2l6YWJsZUNvbXBvbmVuZXRNaXhpbiB9IGZyb20gJy4vc2l6YWJsZS1taXhpbi5jbGFzcyc7XHJcbmltcG9ydCB7IF9UZXh0Ym94Q29tcG9uZW5ldE1peGluIH0gZnJvbSAnLi90ZXh0Ym94LW1peGluLmNsYXNzJztcclxuaW1wb3J0IHsgX1ZhbHVlQ29tcG9uZW5ldE1peGluIH0gZnJvbSAnLi92YWx1ZS1taXhpbi5jbGFzcyc7XHJcblxyXG5leHBvcnQgY29uc3QgQVhCYXNlQ29tcG9uZW50TWl4aW4gPSBfQmFzZUNvbXBvbmVuZXRNaXhpbihBWEJhc2VDb21wb25lbnQpO1xyXG5cclxuZXhwb3J0IGNvbnN0IEFYU2l6YWJsZUNvbXBvbmVudE1peGluID0gX1NpemFibGVDb21wb25lbmV0TWl4aW4oXHJcbiAgX0Jhc2VDb21wb25lbmV0TWl4aW4oQVhCYXNlQ29tcG9uZW50KVxyXG4pO1xyXG5cclxuZXhwb3J0IGNvbnN0IEFYSW50ZXJhY3RpdmVDb21wb25lbmV0TWl4aW4gPSBfU2l6YWJsZUNvbXBvbmVuZXRNaXhpbihcclxuICBfSW50ZXJhY3RpdmVDb21wb25lbmV0TWl4aW4oQVhCYXNlQ29tcG9uZW50KVxyXG4pO1xyXG5cclxuZXhwb3J0IGNvbnN0IEFYQmFzZUNsaWNrYWJsZU1peGluID0gX1NpemFibGVDb21wb25lbmV0TWl4aW4oXHJcbiAgX0ludGVyYWN0aXZlQ29tcG9uZW5ldE1peGluKF9DbGlja2FibGVDb21wb25lbmV0TWl4aW4oQVhCYXNlQ29tcG9uZW50KSlcclxuKTtcclxuXHJcbmV4cG9ydCBjb25zdCBBWEJhc2VCdXR0b25NaXhpbiA9IF9TaXphYmxlQ29tcG9uZW5ldE1peGluKFxyXG4gIF9JbnRlcmFjdGl2ZUNvbXBvbmVuZXRNaXhpbihcclxuICAgIF9DbGlja2FibGVDb21wb25lbmV0TWl4aW4oX0J1dHRvbkNvbXBvbmVudE1peGluKEFYQmFzZUNvbXBvbmVudCkpXHJcbiAgKVxyXG4pO1xyXG5cclxuZXhwb3J0IGNvbnN0IEFYQmFzZVZhbHVlQ29tcG9uZW50TWl4aW4gPSBfU2l6YWJsZUNvbXBvbmVuZXRNaXhpbihcclxuICBfSW50ZXJhY3RpdmVDb21wb25lbmV0TWl4aW4oX1ZhbHVlQ29tcG9uZW5ldE1peGluPGFueT4oQVhCYXNlQ29tcG9uZW50KSlcclxuKTtcclxuXHJcbmV4cG9ydCBjb25zdCBBWEJhc2VUZXh0Qm94TWl4aW4gPSBfU2l6YWJsZUNvbXBvbmVuZXRNaXhpbihcclxuICBfSW50ZXJhY3RpdmVDb21wb25lbmV0TWl4aW4oXHJcbiAgICBfVmFsdWVDb21wb25lbmV0TWl4aW4oX1RleHRib3hDb21wb25lbmV0TWl4aW4oQVhCYXNlQ29tcG9uZW50KSlcclxuICApXHJcbik7XHJcblxyXG5cclxuZXhwb3J0IGNvbnN0IEFYQmFzZVNlbGVjdGlvblZhbHVlTWl4aW4gPSBfU2l6YWJsZUNvbXBvbmVuZXRNaXhpbihcclxuICBfSW50ZXJhY3RpdmVDb21wb25lbmV0TWl4aW4oXHJcbiAgICBfRGF0YWxpc3RDb21wb25lbmV0TWl4aW4oXHJcbiAgICAgIF9TZWxlY3Rpb25Db21wb25lbmV0TWl4aW4oX1ZhbHVlQ29tcG9uZW5ldE1peGluPGFueT4oQVhCYXNlQ29tcG9uZW50KSlcclxuICAgIClcclxuICApXHJcbik7XHJcblxyXG5leHBvcnQgY29uc3QgQVhCYXNlVmFsdWVEcm9wZG93bk1peGluID0gX1NpemFibGVDb21wb25lbmV0TWl4aW4oXHJcbiAgX0ludGVyYWN0aXZlQ29tcG9uZW5ldE1peGluKFxyXG4gICAgX0Ryb3Bkb3duQ29tcG9uZW5ldE1peGluKFxyXG4gICAgICBfRGF0YWxpc3RDb21wb25lbmV0TWl4aW4oX1ZhbHVlQ29tcG9uZW5ldE1peGluPGFueT4oQVhCYXNlQ29tcG9uZW50KSlcclxuICAgIClcclxuICApXHJcbik7XHJcblxyXG5leHBvcnQgY29uc3QgQVhCYXNlU2VsZWN0aW9uRHJvcGRvd25NaXhpbiA9IF9TaXphYmxlQ29tcG9uZW5ldE1peGluKFxyXG4gIF9JbnRlcmFjdGl2ZUNvbXBvbmVuZXRNaXhpbihcclxuICAgIF9Ecm9wZG93bkNvbXBvbmVuZXRNaXhpbihcclxuICAgICAgX0RhdGFsaXN0Q29tcG9uZW5ldE1peGluKFxyXG4gICAgICAgIF9TZWxlY3Rpb25Db21wb25lbmV0TWl4aW4oX1ZhbHVlQ29tcG9uZW5ldE1peGluPGFueT4oQVhCYXNlQ29tcG9uZW50KSlcclxuICAgICAgKVxyXG4gICAgKVxyXG4gIClcclxuKTtcclxuXHJcblxyXG5leHBvcnQgY29uc3QgQVhCYXNlRHJvcGRvd25NaXhpbiA9IF9TaXphYmxlQ29tcG9uZW5ldE1peGluKFxyXG4gIF9JbnRlcmFjdGl2ZUNvbXBvbmVuZXRNaXhpbihfRHJvcGRvd25Db21wb25lbmV0TWl4aW4oQVhCYXNlQ29tcG9uZW50KSlcclxuKTtcclxuXHJcbiJdfQ==
|