@acorex/components 5.0.35 → 5.0.39
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/alert/alert-button.component.mjs +3 -3
- package/esm2020/lib/alert/alert-content.component.mjs +3 -3
- package/esm2020/lib/alert/alert-footer.component.mjs +3 -3
- package/esm2020/lib/alert/alert-suffix.component.mjs +3 -3
- package/esm2020/lib/alert/alert-title.component.mjs +3 -3
- package/esm2020/lib/alert/alert.component.mjs +3 -3
- package/esm2020/lib/alert/alert.module.mjs +4 -4
- package/esm2020/lib/avatar/avatar.component.mjs +3 -3
- package/esm2020/lib/avatar/avatar.module.mjs +4 -4
- package/esm2020/lib/badge/badge.component.mjs +5 -5
- package/esm2020/lib/badge/badge.module.mjs +4 -4
- package/esm2020/lib/base/common.module.mjs +4 -4
- package/esm2020/lib/base/custom-cdk-overlay.service.mjs +6 -6
- package/esm2020/lib/base/mixin/base-components.class.mjs +3 -3
- package/esm2020/lib/base/mixin/button-mixin.class.mjs +16 -5
- package/esm2020/lib/base/mixin/datalist-component.class.mjs +40 -9
- package/esm2020/lib/base/mixin/dropdown-mixin.class.mjs +21 -10
- package/esm2020/lib/base/mixin/interactive-mixin.class.mjs +2 -2
- package/esm2020/lib/base/mixin/selection-component.class.mjs +17 -3
- package/esm2020/lib/base/mixin/value-mixin.class.mjs +26 -14
- package/esm2020/lib/base/overlay.service.mjs +3 -3
- package/esm2020/lib/base/responsive.directive.mjs +3 -3
- package/esm2020/lib/button/button-group.component.mjs +3 -3
- package/esm2020/lib/button/button-item.component.mjs +5 -6
- package/esm2020/lib/button/button.component.mjs +3 -3
- package/esm2020/lib/button/button.module.mjs +4 -4
- package/esm2020/lib/calendar/calendar.class.mjs +3 -3
- package/esm2020/lib/calendar/calendar.component.mjs +8 -4
- package/esm2020/lib/calendar/calendar.module.mjs +4 -4
- package/esm2020/lib/carousel/carousel-arrows.component.mjs +3 -3
- package/esm2020/lib/carousel/carousel-item.component.mjs +3 -3
- package/esm2020/lib/carousel/carousel-pager.component.mjs +3 -3
- package/esm2020/lib/carousel/carousel.class.mjs +3 -3
- package/esm2020/lib/carousel/carousel.component.mjs +3 -3
- package/esm2020/lib/carousel/carousel.module.mjs +4 -4
- package/esm2020/lib/checkbox/checkbox.component.mjs +7 -16
- package/esm2020/lib/checkbox/checkbox.module.mjs +7 -6
- package/esm2020/lib/datalist/datalist.component.mjs +3 -3
- package/esm2020/lib/datalist/datalist.module.mjs +4 -4
- package/esm2020/lib/datepicker/datepicker.component.mjs +30 -15
- package/esm2020/lib/datepicker/datepicker.module.mjs +4 -4
- package/esm2020/lib/decorators/addon.component.mjs +20 -0
- package/esm2020/lib/decorators/content.component.mjs +3 -3
- package/esm2020/lib/decorators/decorators.module.mjs +7 -6
- package/esm2020/lib/decorators/header.component.mjs +3 -3
- package/esm2020/lib/decorators/index.mjs +2 -1
- package/esm2020/lib/decorators/prefix.component.mjs +6 -6
- package/esm2020/lib/decorators/suffix.component.mjs +6 -6
- package/esm2020/lib/dialog/dialog.component.mjs +3 -3
- package/esm2020/lib/dialog/dialog.module.mjs +4 -4
- package/esm2020/lib/dialog/dialog.service.mjs +4 -5
- package/esm2020/lib/drawer/drawer-container.component.mjs +3 -3
- package/esm2020/lib/drawer/drawer-content.component.mjs +3 -3
- package/esm2020/lib/drawer/drawer.component.mjs +3 -3
- package/esm2020/lib/drawer/drawer.module.mjs +4 -4
- package/esm2020/lib/dropdown/dropdown-panel.component.mjs +5 -5
- package/esm2020/lib/dropdown/dropdown.module.mjs +7 -8
- package/esm2020/lib/dropdown/index.mjs +1 -2
- package/esm2020/lib/form/form-field.component.mjs +3 -3
- package/esm2020/lib/form/form-field.module.mjs +4 -4
- package/esm2020/lib/form/form-hint.component.mjs +3 -3
- package/esm2020/lib/form/form.component.mjs +3 -3
- package/esm2020/lib/icon/icon.component.mjs +5 -5
- package/esm2020/lib/icon/icon.module.mjs +4 -4
- package/esm2020/lib/input-mask/input-mask.component.mjs +21 -7
- package/esm2020/lib/input-mask/input-mask.module.mjs +7 -6
- package/esm2020/lib/label/label.component.mjs +12 -5
- package/esm2020/lib/label/label.module.mjs +4 -4
- package/esm2020/lib/loading/loading-spinner.component.mjs +10 -7
- package/esm2020/lib/loading/loading.component.mjs +14 -6
- package/esm2020/lib/loading/loading.directive.mjs +3 -3
- package/esm2020/lib/loading/loading.module.mjs +6 -6
- package/esm2020/lib/loading/loading.service.mjs +3 -3
- package/esm2020/lib/number-box/number-box.component.mjs +124 -184
- package/esm2020/lib/number-box/number-box.module.mjs +15 -9
- package/esm2020/lib/page/base-page.class.mjs +3 -3
- package/esm2020/lib/page/page-footer.component.mjs +3 -3
- package/esm2020/lib/page/page.component.mjs +3 -3
- package/esm2020/lib/page/page.module.mjs +4 -4
- package/esm2020/lib/password-box/password-box.component.mjs +8 -9
- package/esm2020/lib/password-box/password-box.module.mjs +4 -4
- package/esm2020/lib/popover/popover.component.mjs +32 -48
- package/esm2020/lib/popover/popover.module.mjs +4 -4
- package/esm2020/lib/popup/popup.component.mjs +7 -7
- package/esm2020/lib/popup/popup.module.mjs +6 -7
- package/esm2020/lib/popup/popup.service.mjs +6 -5
- package/esm2020/lib/radio/radio.component.mjs +3 -3
- package/esm2020/lib/radio/radio.module.mjs +4 -4
- package/esm2020/lib/range-slider/range-slider.component.mjs +3 -3
- package/esm2020/lib/range-slider/range-slider.module.mjs +4 -4
- package/esm2020/lib/selectbox/selectbox.component.mjs +69 -31
- package/esm2020/lib/selectbox/selectbox.module.mjs +9 -7
- package/esm2020/lib/selection-list/selection-list.component.mjs +3 -3
- package/esm2020/lib/selection-list/selection-list.module.mjs +4 -4
- package/esm2020/lib/side-menu/side-menu.component.mjs +3 -3
- package/esm2020/lib/side-menu/side-menu.module.mjs +4 -4
- package/esm2020/lib/switch/switch.component.mjs +3 -3
- package/esm2020/lib/switch/switch.module.mjs +4 -4
- package/esm2020/lib/tabs/tab-content.directive.mjs +3 -3
- package/esm2020/lib/tabs/tab-item.component.mjs +3 -3
- package/esm2020/lib/tabs/tabs.component.mjs +3 -3
- package/esm2020/lib/tabs/tabs.module.mjs +4 -4
- package/esm2020/lib/textbox/textbox.component.mjs +10 -37
- package/esm2020/lib/textbox/textbox.module.mjs +4 -4
- package/esm2020/lib/time-box/time-box.component.mjs +6 -8
- package/esm2020/lib/time-box/time-box.module.mjs +4 -4
- package/esm2020/lib/toast/toast.component.mjs +3 -3
- package/esm2020/lib/toast/toast.module.mjs +4 -4
- package/esm2020/lib/toast/toast.service.mjs +3 -3
- package/esm2020/lib/tooltip/tooltip.component.mjs +3 -3
- package/esm2020/lib/tooltip/tooltip.directive.mjs +3 -3
- package/esm2020/lib/tooltip/tooltip.module.mjs +4 -4
- package/esm2020/lib/validation/validation-rule.widget.mjs +3 -3
- package/esm2020/lib/validation/validation.module.mjs +4 -4
- package/fesm2015/acorex-components.mjs +968 -914
- package/fesm2015/acorex-components.mjs.map +1 -1
- package/fesm2020/acorex-components.mjs +964 -914
- package/fesm2020/acorex-components.mjs.map +1 -1
- package/lib/base/mixin/button-mixin.class.d.ts +8 -4
- package/lib/base/mixin/datalist-component.class.d.ts +4 -1
- package/lib/base/mixin/dropdown-mixin.class.d.ts +1 -3
- package/lib/base/mixin/interactive-mixin.class.d.ts +3 -1
- package/lib/base/mixin/mixin.class.d.ts +5 -4
- package/lib/base/mixin/selection-component.class.d.ts +8 -0
- package/lib/base/mixin/value-mixin.class.d.ts +3 -1
- package/lib/calendar/calendar.component.d.ts +1 -0
- package/lib/checkbox/checkbox.component.d.ts +2 -4
- package/lib/checkbox/checkbox.module.d.ts +2 -1
- package/lib/datepicker/datepicker.component.d.ts +16 -8
- package/lib/decorators/addon.component.d.ts +8 -0
- package/lib/decorators/decorators.module.d.ts +3 -2
- package/lib/decorators/index.d.ts +1 -0
- package/lib/decorators/prefix.component.d.ts +1 -1
- package/lib/decorators/suffix.component.d.ts +1 -1
- package/lib/dropdown/dropdown.module.d.ts +8 -9
- package/lib/dropdown/index.d.ts +0 -1
- package/lib/icon/icon.component.d.ts +1 -1
- package/lib/input-mask/input-mask.component.d.ts +13 -2
- package/lib/input-mask/input-mask.module.d.ts +2 -1
- package/lib/label/label.component.d.ts +3 -0
- package/lib/loading/loading-spinner.component.d.ts +1 -0
- package/lib/loading/loading.component.d.ts +4 -2
- package/lib/number-box/number-box.component.d.ts +30 -23
- package/lib/number-box/number-box.module.d.ts +4 -2
- package/lib/popover/popover.component.d.ts +2 -1
- package/lib/popup/popup.component.d.ts +1 -1
- package/lib/selectbox/selectbox.component.d.ts +15 -5
- package/lib/selectbox/selectbox.module.d.ts +8 -6
- package/lib/textbox/textbox.component.d.ts +1 -4
- package/package.json +4 -4
- package/esm2020/lib/dropdown/dropdown.component.mjs +0 -28
- package/lib/dropdown/dropdown.component.d.ts +0 -12
|
@@ -14,16 +14,16 @@ export class AXLoadingModule {
|
|
|
14
14
|
AXConfig.set({
|
|
15
15
|
layout: {
|
|
16
16
|
loading: {
|
|
17
|
-
spinner: AXLoadingSpinnerComponent
|
|
17
|
+
spinner: AXLoadingSpinnerComponent,
|
|
18
18
|
}
|
|
19
19
|
}
|
|
20
20
|
});
|
|
21
21
|
}
|
|
22
22
|
}
|
|
23
|
-
AXLoadingModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.
|
|
24
|
-
AXLoadingModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.
|
|
25
|
-
AXLoadingModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.
|
|
26
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.
|
|
23
|
+
AXLoadingModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: AXLoadingModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
24
|
+
AXLoadingModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: AXLoadingModule, declarations: [AXLoadingComponent, AXLoadingDirective, AXLoadingSpinnerComponent], imports: [CommonModule, OverlayModule, PortalModule], exports: [AXLoadingComponent, AXLoadingDirective, AXLoadingSpinnerComponent] });
|
|
25
|
+
AXLoadingModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: AXLoadingModule, providers: [], imports: [[...MODULES]] });
|
|
26
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: AXLoadingModule, decorators: [{
|
|
27
27
|
type: NgModule,
|
|
28
28
|
args: [{
|
|
29
29
|
declarations: [...COMPONENT],
|
|
@@ -32,4 +32,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
32
32
|
providers: [],
|
|
33
33
|
}]
|
|
34
34
|
}], ctorParameters: function () { return []; } });
|
|
35
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
35
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGluZy5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hY29yZXgvY29tcG9uZW50cy9zcmMvbGliL2xvYWRpbmcvbG9hZGluZy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDekQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDekQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3JELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUNuRCxPQUFPLEVBQUUseUJBQXlCLEVBQUUsTUFBTSw2QkFBNkIsQ0FBQztBQUN4RSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sY0FBYyxDQUFDOztBQUV4QyxNQUFNLFNBQVMsR0FBRyxDQUFDLGtCQUFrQixFQUFFLGtCQUFrQixFQUFFLHlCQUF5QixDQUFDLENBQUM7QUFDdEYsTUFBTSxPQUFPLEdBQUcsQ0FBQyxZQUFZLEVBQUUsYUFBYSxFQUFFLFlBQVksQ0FBQyxDQUFDO0FBUTVELE1BQU0sT0FBTyxlQUFlO0lBR3hCO1FBQ0ksUUFBUSxDQUFDLEdBQUcsQ0FBQztZQUNULE1BQU0sRUFBRTtnQkFDSixPQUFPLEVBQUU7b0JBQ0wsT0FBTyxFQUFFLHlCQUF5QjtpQkFDckM7YUFDSjtTQUNKLENBQUMsQ0FBQTtJQUVOLENBQUM7OzRHQVpRLGVBQWU7NkdBQWYsZUFBZSxpQkFUVCxrQkFBa0IsRUFBRSxrQkFBa0IsRUFBRSx5QkFBeUIsYUFDbkUsWUFBWSxFQUFFLGFBQWEsRUFBRSxZQUFZLGFBRHZDLGtCQUFrQixFQUFFLGtCQUFrQixFQUFFLHlCQUF5Qjs2R0FTdkUsZUFBZSxhQUZiLEVBQUUsWUFGSixDQUFDLEdBQUcsT0FBTyxDQUFDOzJGQUlaLGVBQWU7a0JBTjNCLFFBQVE7bUJBQUM7b0JBQ04sWUFBWSxFQUFFLENBQUMsR0FBRyxTQUFTLENBQUM7b0JBQzVCLE9BQU8sRUFBRSxDQUFDLEdBQUcsT0FBTyxDQUFDO29CQUNyQixPQUFPLEVBQUUsQ0FBQyxHQUFHLFNBQVMsQ0FBQztvQkFDdkIsU0FBUyxFQUFFLEVBQUU7aUJBQ2hCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgQVhMb2FkaW5nQ29tcG9uZW50IH0gZnJvbSAnLi9sb2FkaW5nLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEFYTG9hZGluZ0RpcmVjdGl2ZSB9IGZyb20gJy4vbG9hZGluZy5kaXJlY3RpdmUnO1xyXG5pbXBvcnQgeyBPdmVybGF5TW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL292ZXJsYXknO1xyXG5pbXBvcnQgeyBQb3J0YWxNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jZGsvcG9ydGFsJztcclxuaW1wb3J0IHsgQVhMb2FkaW5nU3Bpbm5lckNvbXBvbmVudCB9IGZyb20gJy4vbG9hZGluZy1zcGlubmVyLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEFYQ29uZmlnIH0gZnJvbSAnQGFjb3JleC9jb3JlJztcclxuXHJcbmNvbnN0IENPTVBPTkVOVCA9IFtBWExvYWRpbmdDb21wb25lbnQsIEFYTG9hZGluZ0RpcmVjdGl2ZSwgQVhMb2FkaW5nU3Bpbm5lckNvbXBvbmVudF07XHJcbmNvbnN0IE1PRFVMRVMgPSBbQ29tbW9uTW9kdWxlLCBPdmVybGF5TW9kdWxlLCBQb3J0YWxNb2R1bGVdO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICAgIGRlY2xhcmF0aW9uczogWy4uLkNPTVBPTkVOVF0sXHJcbiAgICBpbXBvcnRzOiBbLi4uTU9EVUxFU10sXHJcbiAgICBleHBvcnRzOiBbLi4uQ09NUE9ORU5UXSxcclxuICAgIHByb3ZpZGVyczogW10sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBWExvYWRpbmdNb2R1bGUge1xyXG5cclxuXHJcbiAgICBjb25zdHJ1Y3RvcigpIHtcclxuICAgICAgICBBWENvbmZpZy5zZXQoe1xyXG4gICAgICAgICAgICBsYXlvdXQ6IHtcclxuICAgICAgICAgICAgICAgIGxvYWRpbmc6IHtcclxuICAgICAgICAgICAgICAgICAgICBzcGlubmVyOiBBWExvYWRpbmdTcGlubmVyQ29tcG9uZW50LFxyXG4gICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgfSlcclxuXHJcbiAgICB9XHJcbn1cclxuIl19
|
|
@@ -143,9 +143,9 @@ export class AXLoadingService {
|
|
|
143
143
|
return loaderId ?? DEFAULT_LOADER_ID;
|
|
144
144
|
}
|
|
145
145
|
}
|
|
146
|
-
AXLoadingService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.
|
|
147
|
-
AXLoadingService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.
|
|
148
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.
|
|
146
|
+
AXLoadingService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: AXLoadingService, deps: [{ token: i0.NgZone }, { token: i1.AXOverlayService }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
147
|
+
AXLoadingService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: AXLoadingService, providedIn: 'root' });
|
|
148
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: AXLoadingService, decorators: [{
|
|
149
149
|
type: Injectable,
|
|
150
150
|
args: [{
|
|
151
151
|
providedIn: 'root'
|
|
@@ -1,11 +1,16 @@
|
|
|
1
|
-
import { Component, ViewEncapsulation, ChangeDetectionStrategy, Input,
|
|
1
|
+
import { Component, ViewEncapsulation, ChangeDetectionStrategy, Input, ViewChild, } from '@angular/core';
|
|
2
|
+
import IMask from 'imask';
|
|
3
|
+
import { IMaskDirective } from 'angular-imask';
|
|
2
4
|
import { AXBaseTextBoxMixin } from '../base';
|
|
3
5
|
import { TEXTBOX_INPUTS, TEXTBOX_OUTPUT, } from '../base/mixin/textbox-mixin.class';
|
|
6
|
+
import _ from 'lodash';
|
|
4
7
|
import * as i0 from "@angular/core";
|
|
5
|
-
import * as i1 from "
|
|
6
|
-
import * as i2 from "../
|
|
7
|
-
import * as i3 from "
|
|
8
|
-
import * as i4 from "@angular/
|
|
8
|
+
import * as i1 from "../button/button.component";
|
|
9
|
+
import * as i2 from "../decorators/prefix.component";
|
|
10
|
+
import * as i3 from "../icon/icon.component";
|
|
11
|
+
import * as i4 from "@angular/forms";
|
|
12
|
+
import * as i5 from "angular-imask";
|
|
13
|
+
import * as i6 from "@angular/common";
|
|
9
14
|
/**
|
|
10
15
|
* The NumberBox is a component which detects user interaction and triggers a corresponding event
|
|
11
16
|
*
|
|
@@ -15,40 +20,64 @@ export class AXNumberBoxComponent extends AXBaseTextBoxMixin {
|
|
|
15
20
|
/**
|
|
16
21
|
* @ignore
|
|
17
22
|
*/
|
|
18
|
-
constructor(elementRef, cdr
|
|
23
|
+
constructor(elementRef, cdr) {
|
|
19
24
|
super(elementRef, cdr);
|
|
20
25
|
this.cdr = cdr;
|
|
21
|
-
this.
|
|
22
|
-
/**
|
|
23
|
-
* A character value that specifies the separator character.
|
|
24
|
-
*/
|
|
25
|
-
this.separator = ',';
|
|
26
|
-
/**
|
|
27
|
-
* Specifies whether the Separator character will be displayed or not
|
|
28
|
-
*/
|
|
29
|
-
this.thousandSeparator = false;
|
|
26
|
+
this._padDecimalZeros = false;
|
|
30
27
|
/**
|
|
31
28
|
* Specifies the value that is used to increment or decrement the **Integer** part of number
|
|
32
29
|
*/
|
|
33
30
|
this.step = 1;
|
|
34
|
-
|
|
35
|
-
* Specifies the number of decimals that the user can enter
|
|
36
|
-
*/
|
|
37
|
-
this.scale = 0;
|
|
31
|
+
this._decimals = 0;
|
|
38
32
|
/**
|
|
39
33
|
* Specifies the value that is used to increment or decrement the **Deciaml** part of number
|
|
40
34
|
*/
|
|
41
|
-
this.decimalStep =
|
|
35
|
+
this.decimalStep = 'auto';
|
|
42
36
|
/**
|
|
43
37
|
* Specifies whether the Up and Down spin buttons will be rendered or not
|
|
44
38
|
*/
|
|
45
39
|
this.showSpinButtons = true;
|
|
46
|
-
this._minValue = Number.
|
|
47
|
-
this._maxValue = Number.
|
|
48
|
-
this.
|
|
40
|
+
this._minValue = Number.MIN_SAFE_INTEGER;
|
|
41
|
+
this._maxValue = Number.MAX_SAFE_INTEGER;
|
|
42
|
+
this.toNum = (val) => {
|
|
43
|
+
return Number(val.replace(/[^0-9.-]+/g, ''));
|
|
44
|
+
};
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* A character value that specifies the separator character.
|
|
48
|
+
*/
|
|
49
|
+
get thousandsSeparator() {
|
|
50
|
+
return this._thousandsSeparator;
|
|
51
|
+
}
|
|
52
|
+
set thousandsSeparator(v) {
|
|
53
|
+
this._setOption({
|
|
54
|
+
name: "thousandsSeparator",
|
|
55
|
+
value: v ?? '',
|
|
56
|
+
});
|
|
57
|
+
}
|
|
58
|
+
/**
|
|
59
|
+
* A character value that specifies the separator character.
|
|
60
|
+
*/
|
|
61
|
+
get padDecimalZeros() {
|
|
62
|
+
return this._padDecimalZeros;
|
|
49
63
|
}
|
|
50
|
-
|
|
51
|
-
|
|
64
|
+
set padDecimalZeros(v) {
|
|
65
|
+
this._setOption({
|
|
66
|
+
name: "padDecimalZeros",
|
|
67
|
+
value: v,
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
/**
|
|
71
|
+
* Specifies the number of decimals that the user can enter
|
|
72
|
+
*/
|
|
73
|
+
get decimals() {
|
|
74
|
+
return this._decimals;
|
|
75
|
+
}
|
|
76
|
+
set decimals(v) {
|
|
77
|
+
this._setOption({
|
|
78
|
+
name: "decimals",
|
|
79
|
+
value: v ?? 0,
|
|
80
|
+
});
|
|
52
81
|
}
|
|
53
82
|
/**
|
|
54
83
|
* Specifies the smallest value that is valid
|
|
@@ -57,7 +86,10 @@ export class AXNumberBoxComponent extends AXBaseTextBoxMixin {
|
|
|
57
86
|
return this._minValue;
|
|
58
87
|
}
|
|
59
88
|
set minValue(v) {
|
|
60
|
-
this.
|
|
89
|
+
this._setOption({
|
|
90
|
+
name: "minValue",
|
|
91
|
+
value: v != null ? Number(v) : Number.MIN_SAFE_INTEGER,
|
|
92
|
+
});
|
|
61
93
|
}
|
|
62
94
|
/**
|
|
63
95
|
* Specifies the greatest value that is valid
|
|
@@ -66,179 +98,91 @@ export class AXNumberBoxComponent extends AXBaseTextBoxMixin {
|
|
|
66
98
|
return this._maxValue;
|
|
67
99
|
}
|
|
68
100
|
set maxValue(v) {
|
|
69
|
-
this.
|
|
101
|
+
this._setOption({
|
|
102
|
+
name: "maxValue",
|
|
103
|
+
value: v != null ? Number(v) : Number.MAX_SAFE_INTEGER,
|
|
104
|
+
});
|
|
70
105
|
}
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
get displayText() {
|
|
75
|
-
return this._displayText;
|
|
106
|
+
onViewInit() {
|
|
107
|
+
super.onViewInit();
|
|
108
|
+
this._updateMask();
|
|
76
109
|
}
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
this.
|
|
110
|
+
_onOptionChanged(option) {
|
|
111
|
+
super._onOptionChanged(option);
|
|
112
|
+
this._updateMask();
|
|
113
|
+
}
|
|
114
|
+
_updateMask() {
|
|
115
|
+
if (!this._maskObj) {
|
|
116
|
+
this._maskObj = IMask.createMask({
|
|
117
|
+
mask: Number,
|
|
118
|
+
min: this.minValue,
|
|
119
|
+
max: this.maxValue,
|
|
120
|
+
thousandsSeparator: this.thousandsSeparator || '',
|
|
121
|
+
scale: this.decimals,
|
|
122
|
+
radix: '.',
|
|
123
|
+
padFractionalZeros: this.decimals > 0 && this.padDecimalZeros
|
|
124
|
+
});
|
|
125
|
+
}
|
|
126
|
+
else {
|
|
127
|
+
this._maskObj.updateOptions({
|
|
128
|
+
min: this.minValue,
|
|
129
|
+
max: this.maxValue,
|
|
130
|
+
thousandsSeparator: this.thousandsSeparator || '',
|
|
131
|
+
scale: this.decimals,
|
|
132
|
+
radix: '.',
|
|
133
|
+
padFractionalZeros: this.decimals > 0 && this.padDecimalZeros
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
this._maskDirective?.maskRef?.updateValue();
|
|
137
|
+
this._maskDirective?.maskRef?.updateControl();
|
|
80
138
|
}
|
|
81
139
|
_handleOnKeydownEvent(e) {
|
|
82
140
|
const ignore = () => {
|
|
83
141
|
e.preventDefault();
|
|
84
142
|
e.stopPropagation();
|
|
85
143
|
};
|
|
86
|
-
const toNum = (val) => {
|
|
87
|
-
return Number(val.replace(/[^0-9.-]+/g, ''));
|
|
88
|
-
};
|
|
89
|
-
const nums = Array(10)
|
|
90
|
-
.fill(0)
|
|
91
|
-
.map((v, i) => i.toString());
|
|
92
|
-
const chars = [
|
|
93
|
-
'.',
|
|
94
|
-
'-',
|
|
95
|
-
'Backspace',
|
|
96
|
-
'ArrowDown',
|
|
97
|
-
'ArrowUp',
|
|
98
|
-
'ArrowRight',
|
|
99
|
-
'ArrowLeft',
|
|
100
|
-
'Tab',
|
|
101
|
-
'Enter',
|
|
102
|
-
];
|
|
103
144
|
const input = e.target;
|
|
104
|
-
const key = e.key;
|
|
105
145
|
const valStr = input.value;
|
|
106
|
-
const val = toNum(valStr);
|
|
107
146
|
const decimalPointIndex = valStr.indexOf('.');
|
|
108
147
|
const selectionStart = input.selectionStart;
|
|
109
148
|
const selectionEnd = input.selectionEnd;
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
ignore();
|
|
114
|
-
}
|
|
115
|
-
if (e.key === 'ArrowDown' || e.key === 'ArrowUp') {
|
|
116
|
-
const stepVal = decimalPointIndex > -1
|
|
117
|
-
? selectionStart >= decimalPointIndex
|
|
118
|
-
? this.decimalStep
|
|
119
|
-
: this.step
|
|
120
|
-
: this.step;
|
|
121
|
-
if (e.key === 'ArrowDown') {
|
|
122
|
-
this.value = val - stepVal;
|
|
149
|
+
if (e.key === 'ArrowUp' || e.key === 'ArrowDown') {
|
|
150
|
+
if (selectionStart > decimalPointIndex && this.decimals > 0) {
|
|
151
|
+
e.key === 'ArrowDown' ? this.decimalStepDown() : this.decimalStepUp();
|
|
123
152
|
}
|
|
124
153
|
else {
|
|
125
|
-
|
|
154
|
+
e.key === 'ArrowDown' ? this.stepDown() : this.stepUp();
|
|
126
155
|
}
|
|
127
156
|
ignore();
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
const chr = valStr.substr(selectionStart - 1, 1);
|
|
132
|
-
if (!nums.includes(chr)) {
|
|
133
|
-
ignore();
|
|
134
|
-
input.setSelectionRange(selectionStart - 1, selectionStart - 1);
|
|
135
|
-
}
|
|
136
|
-
else {
|
|
137
|
-
const newVal = toNum(valStr.substr(0, selectionStart - 1) + valStr.substr(selectionEnd));
|
|
138
|
-
input.value = this._format(newVal);
|
|
139
|
-
this.value = newVal;
|
|
140
|
-
ignore();
|
|
141
|
-
if (newVal == 0) {
|
|
142
|
-
input.setSelectionRange(1, 1);
|
|
143
|
-
}
|
|
144
|
-
else {
|
|
145
|
-
input.setSelectionRange(selectionStart - 1, selectionStart - 1);
|
|
146
|
-
}
|
|
147
|
-
}
|
|
148
|
-
}
|
|
149
|
-
else if (e.key == '.') {
|
|
150
|
-
if (!this.scale) {
|
|
151
|
-
ignore();
|
|
152
|
-
}
|
|
153
|
-
else if (decimalPointIndex > -1) {
|
|
154
|
-
input.setSelectionRange(decimalPointIndex + 1, decimalPointIndex + 1);
|
|
155
|
-
ignore();
|
|
156
|
-
}
|
|
157
|
-
else {
|
|
158
|
-
if (input.selectionEnd != valStr.length) {
|
|
159
|
-
input.setSelectionRange(valStr.length, valStr.length);
|
|
160
|
-
ignore();
|
|
161
|
-
}
|
|
162
|
-
}
|
|
163
|
-
}
|
|
164
|
-
else if (e.key == '-') {
|
|
165
|
-
const index = valStr.indexOf('-');
|
|
166
|
-
if (index > -1) {
|
|
167
|
-
ignore();
|
|
168
|
-
}
|
|
169
|
-
else {
|
|
170
|
-
this.value = Math.abs(this.value) * -1;
|
|
171
|
-
input.setSelectionRange(index + 1, index + 1);
|
|
172
|
-
ignore();
|
|
173
|
-
}
|
|
174
|
-
}
|
|
175
|
-
else if (nums.includes(key)) {
|
|
176
|
-
const newVal = toNum(valStr.substr(0, selectionStart) + key + valStr.substr(selectionEnd));
|
|
177
|
-
if (newVal < this.minValue) {
|
|
178
|
-
//TODO : highlight correct number
|
|
179
|
-
//input.value = this._format(this.minValue);
|
|
180
|
-
//const diff = this.minValue - val;
|
|
181
|
-
//this.value = this.minValue;
|
|
182
|
-
//ignore();
|
|
183
|
-
// setTimeout(() => {
|
|
184
|
-
// input.setSelectionRange(input.selectionStart + 1, this.minValue.toString().length);
|
|
185
|
-
// }, 50);
|
|
186
|
-
}
|
|
187
|
-
else if (newVal > this.maxValue) {
|
|
188
|
-
input.value = this._format(this.maxValue);
|
|
189
|
-
this.value = this.maxValue;
|
|
190
|
-
ignore();
|
|
191
|
-
}
|
|
192
|
-
else {
|
|
193
|
-
input.value = this._format(newVal);
|
|
194
|
-
this.value = newVal;
|
|
195
|
-
ignore();
|
|
196
|
-
}
|
|
157
|
+
setTimeout(() => {
|
|
158
|
+
input.setSelectionRange(selectionStart, selectionStart);
|
|
159
|
+
});
|
|
197
160
|
}
|
|
198
161
|
super._emitOnKeydownEvent(e);
|
|
199
162
|
}
|
|
163
|
+
_handleUpDownClick(e, v) {
|
|
164
|
+
v == 1 ? this.stepUp() : this.stepDown();
|
|
165
|
+
}
|
|
200
166
|
_onValueChanging(value) {
|
|
201
|
-
return
|
|
167
|
+
return _.toNumber(value);
|
|
202
168
|
}
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
return this.allowNull ? null : this.minValue;
|
|
206
|
-
}
|
|
207
|
-
else if (value > this.maxValue) {
|
|
208
|
-
return this.maxValue;
|
|
209
|
-
}
|
|
210
|
-
else if (value < this.minValue) {
|
|
211
|
-
return this.minValue;
|
|
212
|
-
}
|
|
213
|
-
return parseFloat(value.toFixed(this.scale));
|
|
169
|
+
stepUp() {
|
|
170
|
+
this.value += this.step;
|
|
214
171
|
}
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
this._maskService.thousandSeparator = this.separator;
|
|
218
|
-
this._maskService.allowNegativeNumbers = true;
|
|
219
|
-
const format = `separator.${this.scale}`;
|
|
220
|
-
return this._maskService.applyMask(value?.toString(), format);
|
|
221
|
-
}
|
|
222
|
-
else {
|
|
223
|
-
this._maskService.thousandSeparator = '';
|
|
224
|
-
this._maskService.allowNegativeNumbers = true;
|
|
225
|
-
const format = `separator.${this.scale}`;
|
|
226
|
-
return this._maskService.applyMask(value?.toString(), format);
|
|
227
|
-
}
|
|
172
|
+
stepDown() {
|
|
173
|
+
this.value -= this.step;
|
|
228
174
|
}
|
|
229
|
-
|
|
230
|
-
this.
|
|
175
|
+
decimalStepUp() {
|
|
176
|
+
this.value += this.decimalStep == 'auto' ? (1 / Math.pow(10, this.decimals)) : this.decimalStep;
|
|
231
177
|
}
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
input.value = this._format(this.value);
|
|
236
|
-
this._emitOnFocusEvent(e);
|
|
178
|
+
decimalStepDown() {
|
|
179
|
+
this.value -= this.decimalStep == 'auto' ? (1 / Math.pow(10, this.decimals)) : this.decimalStep;
|
|
180
|
+
;
|
|
237
181
|
}
|
|
238
182
|
}
|
|
239
|
-
AXNumberBoxComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.
|
|
240
|
-
AXNumberBoxComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.
|
|
241
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.
|
|
183
|
+
AXNumberBoxComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: AXNumberBoxComponent, deps: [{ token: i0.ElementRef }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
184
|
+
AXNumberBoxComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.2.0", type: AXNumberBoxComponent, selector: "ax-number-box", inputs: { disabled: "disabled", readonly: "readonly", tabIndex: "tabIndex", size: "size", value: "value", placeholder: "placeholder", maxLength: "maxLength", allowNull: "allowNull", debounceTime: "debounceTime", name: "name", checked: "checked", thousandsSeparator: "thousandsSeparator", padDecimalZeros: "padDecimalZeros", step: "step", decimals: "decimals", decimalStep: "decimalStep", showSpinButtons: "showSpinButtons", minValue: "minValue", maxValue: "maxValue" }, outputs: { valueChange: "valueChange", onValueChanged: "onValueChanged", onBlur: "onBlur", onFocus: "onFocus" }, host: { classAttribute: "ax-editor-container" }, viewQueries: [{ propertyName: "_maskDirective", first: true, predicate: IMaskDirective, descendants: true }], usesInheritance: true, ngImport: i0, template: "<ng-content select=\"ax-prefix\">\r\n</ng-content>\r\n<input class=\"ax-input\" type=\"text\" \r\n [attr.placeholder]=\"placeholder\" \r\n [imask]=\"_maskObj\" \r\n [unmask]=\"'typed'\"\r\n [attr.min]=\"minValue\"\r\n [attr.max]=\"maxValue\" \r\n [class.ax-state-disabled]=\"disabled\" \r\n [class.ax-state-readonly]=\"readonly\"\r\n [disabled]=\"disabled\" \r\n [readonly]=\"readonly\" \r\n [tabindex]=\"tabIndex\" \r\n [(ngModel)]=\"value\"\r\n (focus)=\"_emitOnFocusEvent($event)\" (blur)=\"_emitOnFocusEvent($event)\" (keydown)=\"_handleOnKeydownEvent($event)\"\r\n autocomplete=\"off\">\r\n\r\n<div class=\"ax-number-box-arrows\" *ngIf=\"showSpinButtons && !(disabled || readonly)\">\r\n <ax-button color=\"light\" look=\"blank\" (onClick)=\"_handleUpDownClick($event,1)\">\r\n <ax-prefix>\r\n <ax-icon class=\"ax-ic-arrow-fill ax-rotate-90\">\r\n </ax-icon>\r\n </ax-prefix>\r\n </ax-button>\r\n <ax-button color=\"light\" look=\"blank\" (onClick)=\"_handleUpDownClick($event,-1)\">\r\n <ax-prefix>\r\n <ax-icon class=\"ax-ic-arrow-fill ax--rotate-90\">\r\n </ax-icon>\r\n </ax-prefix>\r\n </ax-button>\r\n</div>\r\n<ng-content select=\"ax-suffix\">\r\n</ng-content>\r\n<ng-content select=\"ax-validation-rule\">\r\n</ng-content>", components: [{ type: i1.AXButtonComponent, selector: "ax-button", inputs: ["disabled", "tabIndex", "size", "text", "submitBehavior", "cancelBehavior", "color", "look", "toggleable", "selected"], outputs: ["onBlur", "onFocus", "onClick", "selectedChange", "toggleableChange"] }, { type: i2.AXDecoratorPrefixComponent, selector: "ax-prefix" }, { type: i3.AXIconComponent, selector: "ax-icon", inputs: ["icon"] }], directives: [{ type: i4.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { type: i5.IMaskDirective, selector: "[imask]", inputs: ["imask", "unmask", "imaskElement"], outputs: ["accept", "complete"], exportAs: ["imask"] }, { type: i4.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { type: i4.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
185
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: AXNumberBoxComponent, decorators: [{
|
|
242
186
|
type: Component,
|
|
243
187
|
args: [{ selector: 'ax-number-box', inputs: [
|
|
244
188
|
'disabled',
|
|
@@ -253,17 +197,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
253
197
|
'onBlur',
|
|
254
198
|
'onFocus',
|
|
255
199
|
...TEXTBOX_OUTPUT,
|
|
256
|
-
], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: { class: 'ax-
|
|
257
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }
|
|
258
|
-
type: HostBinding,
|
|
259
|
-
args: ['class']
|
|
260
|
-
}], separator: [{
|
|
200
|
+
], changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, host: { class: 'ax-editor-container' }, template: "<ng-content select=\"ax-prefix\">\r\n</ng-content>\r\n<input class=\"ax-input\" type=\"text\" \r\n [attr.placeholder]=\"placeholder\" \r\n [imask]=\"_maskObj\" \r\n [unmask]=\"'typed'\"\r\n [attr.min]=\"minValue\"\r\n [attr.max]=\"maxValue\" \r\n [class.ax-state-disabled]=\"disabled\" \r\n [class.ax-state-readonly]=\"readonly\"\r\n [disabled]=\"disabled\" \r\n [readonly]=\"readonly\" \r\n [tabindex]=\"tabIndex\" \r\n [(ngModel)]=\"value\"\r\n (focus)=\"_emitOnFocusEvent($event)\" (blur)=\"_emitOnFocusEvent($event)\" (keydown)=\"_handleOnKeydownEvent($event)\"\r\n autocomplete=\"off\">\r\n\r\n<div class=\"ax-number-box-arrows\" *ngIf=\"showSpinButtons && !(disabled || readonly)\">\r\n <ax-button color=\"light\" look=\"blank\" (onClick)=\"_handleUpDownClick($event,1)\">\r\n <ax-prefix>\r\n <ax-icon class=\"ax-ic-arrow-fill ax-rotate-90\">\r\n </ax-icon>\r\n </ax-prefix>\r\n </ax-button>\r\n <ax-button color=\"light\" look=\"blank\" (onClick)=\"_handleUpDownClick($event,-1)\">\r\n <ax-prefix>\r\n <ax-icon class=\"ax-ic-arrow-fill ax--rotate-90\">\r\n </ax-icon>\r\n </ax-prefix>\r\n </ax-button>\r\n</div>\r\n<ng-content select=\"ax-suffix\">\r\n</ng-content>\r\n<ng-content select=\"ax-validation-rule\">\r\n</ng-content>" }]
|
|
201
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { thousandsSeparator: [{
|
|
261
202
|
type: Input
|
|
262
|
-
}],
|
|
203
|
+
}], padDecimalZeros: [{
|
|
263
204
|
type: Input
|
|
264
205
|
}], step: [{
|
|
265
206
|
type: Input
|
|
266
|
-
}],
|
|
207
|
+
}], decimals: [{
|
|
267
208
|
type: Input
|
|
268
209
|
}], decimalStep: [{
|
|
269
210
|
type: Input
|
|
@@ -273,9 +214,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
273
214
|
type: Input
|
|
274
215
|
}], maxValue: [{
|
|
275
216
|
type: Input
|
|
276
|
-
}],
|
|
277
|
-
type:
|
|
278
|
-
|
|
279
|
-
type: Input
|
|
217
|
+
}], _maskDirective: [{
|
|
218
|
+
type: ViewChild,
|
|
219
|
+
args: [IMaskDirective]
|
|
280
220
|
}] } });
|
|
281
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number-box.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/number-box/number-box.component.ts","../../../../../../projects/acorex/components/src/lib/number-box/number-box.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  HostBinding,\r\n} from '@angular/core';\r\nimport { MaskApplierService } from 'ngx-mask';\r\nimport { AXBaseTextBoxMixin } from '../base';\r\nimport {\r\n  TEXTBOX_INPUTS,\r\n  TEXTBOX_OUTPUT,\r\n} from '../base/mixin/textbox-mixin.class';\r\n\r\n/**\r\n * The NumberBox 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-number-box',\r\n  templateUrl: './number-box.component.html',\r\n  inputs: [\r\n    'disabled',\r\n    'readonly',\r\n    'tabIndex',\r\n    'size',\r\n    'value',\r\n    ...TEXTBOX_INPUTS,\r\n  ],\r\n  outputs: [\r\n    'valueChange',\r\n    'onValueChanged',\r\n    'onBlur',\r\n    'onFocus',\r\n    ...TEXTBOX_OUTPUT,\r\n  ],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  encapsulation: ViewEncapsulation.None,\r\n  host: { class: 'ax-number-box ax-editor-container' },\r\n})\r\nexport class AXNumberBoxComponent extends AXBaseTextBoxMixin {\r\n\r\n  @HostBinding('class')\r\n  private get __hostClass(): string {\r\n    return `${this.cssClass} ax-${this.size}`;\r\n  }\r\n\r\n  /**\r\n  *  A character value that specifies the separator character.\r\n  */\r\n  @Input()\r\n  separator: string = ',';\r\n\r\n   /**\r\n  *  Specifies whether the Separator character will be displayed or not\r\n  */\r\n  @Input()\r\n  thousandSeparator: boolean = false;\r\n\r\n   /**\r\n  *  Specifies the value that is used to increment or decrement the **Integer** part of number\r\n  */\r\n  @Input()\r\n  step: number = 1;\r\n\r\n  /**\r\n  *  Specifies the number of decimals that the user can enter\r\n  */\r\n  @Input()\r\n  scale: number = 0;\r\n\r\n  /**\r\n  *  Specifies the value that is used to increment or decrement the **Deciaml** part of number\r\n  */\r\n  @Input()\r\n  decimalStep: number = 0.1;\r\n\r\n  /**\r\n  *  Specifies whether the Up and Down spin buttons will be rendered or not\r\n  */\r\n  @Input()\r\n  showSpinButtons: boolean = true;\r\n\r\n  private _minValue: number = Number.MIN_VALUE;\r\n\r\n  /**\r\n  *  Specifies the smallest value that is valid\r\n  */\r\n  @Input()\r\n  public get minValue(): number {\r\n    return this._minValue;\r\n  }\r\n  public set minValue(v: number) {\r\n    this._minValue = v ? Number(v) : Number.MIN_VALUE;\r\n  }\r\n\r\n  private _maxValue: number = Number.MAX_VALUE;\r\n\r\n  /**\r\n  *  Specifies the greatest value that is valid\r\n  */\r\n  @Input()\r\n  public get maxValue(): number {\r\n    return this._maxValue;\r\n  }\r\n  public set maxValue(v: number) {\r\n    this._maxValue = v ? Number(v) : Number.MAX_VALUE;\r\n  }\r\n\r\n  @Output()\r\n  public displayTextChange: EventEmitter<string> = new EventEmitter<string>();\r\n  private _displayText: string;\r\n\r\n  /**\r\n  *  The formatted string which is displaying in the numberbox\r\n  */\r\n  @Input()\r\n  public get displayText(): string {\r\n    return this._displayText;\r\n  }\r\n\r\n  public set displayText(v: string) {\r\n    this._displayText = v;\r\n    this.displayTextChange.emit(v);\r\n  }\r\n\r\n\r\n  /**\r\n  *  @ignore\r\n  */\r\n  constructor(\r\n    elementRef: ElementRef,\r\n    private cdr: ChangeDetectorRef,\r\n    private _maskService: MaskApplierService\r\n  ) {\r\n    super(elementRef, cdr);\r\n  }\r\n\r\n  _handleOnKeydownEvent(e: KeyboardEvent) {\r\n    const ignore = () => {\r\n      e.preventDefault();\r\n      e.stopPropagation();\r\n    };\r\n    const toNum = (val: string) => {\r\n      return Number(val.replace(/[^0-9.-]+/g, ''));\r\n    };\r\n    const nums: string[] = Array(10)\r\n      .fill(0)\r\n      .map((v, i) => i.toString());\r\n    const chars: string[] = [\r\n      '.',\r\n      '-',\r\n      'Backspace',\r\n      'ArrowDown',\r\n      'ArrowUp',\r\n      'ArrowRight',\r\n      'ArrowLeft',\r\n      'Tab',\r\n      'Enter',\r\n    ];\r\n    const input = e.target as HTMLInputElement;\r\n    const key = e.key;\r\n    const valStr = input.value;\r\n    const val = toNum(valStr);\r\n    const decimalPointIndex = valStr.indexOf('.');\r\n    const selectionStart = input.selectionStart;\r\n    const selectionEnd = input.selectionEnd;\r\n    //\r\n\r\n    //\r\n    if (![...nums, ...chars].includes(key)) {\r\n      ignore();\r\n    }\r\n    if (e.key === 'ArrowDown' || e.key === 'ArrowUp') {\r\n      const stepVal =\r\n        decimalPointIndex > -1\r\n          ? selectionStart >= decimalPointIndex\r\n            ? this.decimalStep\r\n            : this.step\r\n          : this.step;\r\n      if (e.key === 'ArrowDown') {\r\n        this.value = val - stepVal;\r\n      } else {\r\n        this.value = val + stepVal;\r\n      }\r\n      ignore();\r\n      input.setSelectionRange(selectionStart, selectionStart);\r\n    } else if (e.key == 'Backspace') {\r\n      const chr = valStr.substr(selectionStart - 1, 1);\r\n      if (!nums.includes(chr)) {\r\n        ignore();\r\n        input.setSelectionRange(selectionStart - 1, selectionStart - 1);\r\n      } else {\r\n        const newVal = toNum(\r\n          valStr.substr(0, selectionStart - 1) + valStr.substr(selectionEnd)\r\n        );\r\n        input.value = this._format(newVal);\r\n        this.value = newVal;\r\n        ignore();\r\n        if (newVal == 0) {\r\n          input.setSelectionRange(1, 1);\r\n        } else {\r\n          input.setSelectionRange(selectionStart - 1, selectionStart - 1);\r\n        }\r\n      }\r\n    } else if (e.key == '.') {\r\n      if (!this.scale) {\r\n        ignore();\r\n      } else if (decimalPointIndex > -1) {\r\n        input.setSelectionRange(decimalPointIndex + 1, decimalPointIndex + 1);\r\n        ignore();\r\n      } else {\r\n        if (input.selectionEnd != valStr.length) {\r\n          input.setSelectionRange(valStr.length, valStr.length);\r\n          ignore();\r\n        }\r\n      }\r\n    } else if (e.key == '-') {\r\n      const index = valStr.indexOf('-');\r\n      if (index > -1) {\r\n        ignore();\r\n      } else {\r\n        this.value = Math.abs(this.value) * -1;\r\n        input.setSelectionRange(index + 1, index + 1);\r\n        ignore();\r\n      }\r\n    } else if (nums.includes(key)) {\r\n      const newVal = toNum(\r\n        valStr.substr(0, selectionStart) + key + valStr.substr(selectionEnd)\r\n      );\r\n      if (newVal < this.minValue) {\r\n        //TODO : highlight correct number\r\n        //input.value = this._format(this.minValue);\r\n        //const diff = this.minValue - val;\r\n        //this.value = this.minValue;\r\n        //ignore();\r\n        // setTimeout(() => {\r\n        //     input.setSelectionRange(input.selectionStart + 1, this.minValue.toString().length);\r\n        // }, 50);\r\n      } else if (newVal > this.maxValue) {\r\n        input.value = this._format(this.maxValue);\r\n        this.value = this.maxValue;\r\n        ignore();\r\n      } else {\r\n        input.value = this._format(newVal);\r\n        this.value = newVal;\r\n        ignore();\r\n      }\r\n    }\r\n    super._emitOnKeydownEvent(e);\r\n  }\r\n\r\n  _onValueChanging(value: number) {\r\n    return this._fixValue(value);\r\n  }\r\n\r\n  _fixValue(value: number): number {\r\n    if (value == null || value == undefined) {\r\n      return this.allowNull ? null : this.minValue;\r\n    } else if (value > this.maxValue) {\r\n      return this.maxValue;\r\n    } else if (value < this.minValue) {\r\n      return this.minValue;\r\n    }\r\n    return parseFloat(value.toFixed(this.scale));\r\n  }\r\n\r\n  _format(value: number): string {\r\n    if (this.thousandSeparator) {\r\n      this._maskService.thousandSeparator = this.separator;\r\n      this._maskService.allowNegativeNumbers = true;\r\n      const format = `separator.${this.scale}`;\r\n      return this._maskService.applyMask(value?.toString(), format);\r\n    } else {\r\n      this._maskService.thousandSeparator = '';\r\n      this._maskService.allowNegativeNumbers = true;\r\n      const format = `separator.${this.scale}`;\r\n      return this._maskService.applyMask(value?.toString(), format);\r\n    }\r\n  }\r\n\r\n  _onValueChanged(oldValue: any, newValue: any): void {\r\n    this.displayText = this._format(newValue);\r\n  }\r\n\r\n  _handleOnBlurEvent(e: FocusEvent) {\r\n    const input = e.target as HTMLInputElement;\r\n    this.value = this._fixValue(this.value);\r\n    input.value = this._format(this.value);\r\n    this._emitOnFocusEvent(e);\r\n  }\r\n}\r\n","<ng-content select=\"ax-prefix\">\r\n</ng-content>\r\n<input class=\"ax-input\" type=\"text\" [attr.pattern]=\"'[\\d\\.]*'\" [attr.placeholder]=\"placeholder\" [attr.min]=\"minValue\"\r\n    [attr.max]=\"maxValue\" [class.ax-state-disabled]=\"disabled\" [class.ax-state-readonly]=\"readonly\"\r\n    [disabled]=\"disabled\" [readonly]=\"readonly\" [tabindex]=\"tabIndex\" [ngModel]=\"displayText\"\r\n    (focus)=\"_emitOnFocusEvent($event)\" (blur)=\"_handleOnBlurEvent($event)\" (keydown)=\"_handleOnKeydownEvent($event)\"\r\n    autocomplete=\"off\">\r\n<ax-button color=\"light\" look=\"blank\" (onClick)=\"clear()\" [tabIndex]=\"-1\"\r\n    *ngIf=\"value && allowNull && !(disabled || readonly)\">\r\n    <i class=\"ax-icon-x icon\"></i>\r\n</ax-button>\r\n<ng-content select=\"ax-suffix\">\r\n</ng-content>\r\n<ng-content select=\"ax-validation-rule\">\r\n</ng-content>"]}
|
|
221
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"number-box.component.js","sourceRoot":"","sources":["../../../../../../projects/acorex/components/src/lib/number-box/number-box.component.ts","../../../../../../projects/acorex/components/src/lib/number-box/number-box.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  ElementRef,\r\n  ChangeDetectorRef,\r\n  Input,\r\n  Output,\r\n  EventEmitter,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport IMask from 'imask';\r\nimport { IMaskDirective } from 'angular-imask';\r\nimport { AXBaseTextBoxMixin, AXClickEvent, AXComponentOptionChanged } from '../base';\r\nimport {\r\n  TEXTBOX_INPUTS,\r\n  TEXTBOX_OUTPUT,\r\n} from '../base/mixin/textbox-mixin.class';\r\nimport _ from 'lodash';\r\n\r\n/**\r\n * The NumberBox 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-number-box',\r\n  templateUrl: './number-box.component.html',\r\n  inputs: [\r\n    'disabled',\r\n    'readonly',\r\n    'tabIndex',\r\n    'size',\r\n    'value',\r\n    ...TEXTBOX_INPUTS,\r\n  ],\r\n  outputs: [\r\n    'valueChange',\r\n    'onValueChanged',\r\n    'onBlur',\r\n    'onFocus',\r\n    ...TEXTBOX_OUTPUT,\r\n  ],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  encapsulation: ViewEncapsulation.None,\r\n  host: { class: 'ax-editor-container' },\r\n})\r\nexport class AXNumberBoxComponent extends AXBaseTextBoxMixin {\r\n\r\n\r\n\r\n\r\n  private _thousandsSeparator: string;\r\n  /**\r\n  *  A character value that specifies the separator character.\r\n  */\r\n  @Input()\r\n  public get thousandsSeparator(): string {\r\n    return this._thousandsSeparator;\r\n  }\r\n  public set thousandsSeparator(v: string) {\r\n    this._setOption({\r\n      name: \"thousandsSeparator\",\r\n      value: v ?? '',\r\n    })\r\n  }\r\n\r\n  private _padDecimalZeros: boolean = false;\r\n  /**\r\n  *  A character value that specifies the separator character.\r\n  */\r\n  @Input()\r\n  public get padDecimalZeros(): boolean {\r\n    return this._padDecimalZeros;\r\n  }\r\n  public set padDecimalZeros(v: boolean) {\r\n    this._setOption({\r\n      name: \"padDecimalZeros\",\r\n      value: v,\r\n    })\r\n  }\r\n\r\n\r\n\r\n\r\n  /**\r\n *  Specifies the value that is used to increment or decrement the **Integer** part of number\r\n */\r\n  @Input()\r\n  step: number = 1;\r\n\r\n\r\n\r\n  private _decimals: number = 0;\r\n  /**\r\n  *  Specifies the number of decimals that the user can enter\r\n  */\r\n  @Input()\r\n  public get decimals(): number {\r\n    return this._decimals;\r\n  }\r\n  public set decimals(v: number) {\r\n    this._setOption({\r\n      name: \"decimals\",\r\n      value: v ?? 0,\r\n    })\r\n  }\r\n\r\n\r\n  /**\r\n  *  Specifies the value that is used to increment or decrement the **Deciaml** part of number\r\n  */\r\n  @Input()\r\n  decimalStep: number | 'auto' = 'auto';\r\n\r\n  /**\r\n  *  Specifies whether the Up and Down spin buttons will be rendered or not\r\n  */\r\n  @Input()\r\n  showSpinButtons: boolean = true;\r\n\r\n  private _minValue: number = Number.MIN_SAFE_INTEGER;\r\n  /**\r\n  *  Specifies the smallest value that is valid\r\n  */\r\n  @Input()\r\n  public get minValue(): number {\r\n    return this._minValue;\r\n  }\r\n  public set minValue(v: number) {\r\n    this._setOption({\r\n      name: \"minValue\",\r\n      value: v != null ? Number(v) : Number.MIN_SAFE_INTEGER,\r\n    })\r\n  }\r\n\r\n  private _maxValue: number = Number.MAX_SAFE_INTEGER;\r\n  /**\r\n  *  Specifies the greatest value that is valid\r\n  */\r\n  @Input()\r\n  public get maxValue(): number {\r\n    return this._maxValue;\r\n  }\r\n  public set maxValue(v: number) {\r\n    this._setOption({\r\n      name: \"maxValue\",\r\n      value: v != null ? Number(v) : Number.MAX_SAFE_INTEGER,\r\n    })\r\n  }\r\n\r\n\r\n  /**\r\n  *  @ignore\r\n  */\r\n  _maskObj: IMask.MaskedNumber\r\n\r\n\r\n  @ViewChild(IMaskDirective)\r\n  private _maskDirective: IMaskDirective<IMask.MaskedNumber>;\r\n\r\n  /**\r\n  *  @ignore\r\n  */\r\n  constructor(\r\n    elementRef: ElementRef,\r\n    private cdr: ChangeDetectorRef\r\n  ) {\r\n    super(elementRef, cdr);\r\n  }\r\n\r\n\r\n  private toNum = (val: string): number => {\r\n    return Number(val.replace(/[^0-9.-]+/g, ''));\r\n  };\r\n\r\n  onViewInit(): void {\r\n    super.onViewInit();\r\n    this._updateMask();\r\n  }\r\n\r\n\r\n  _onOptionChanged(option: AXComponentOptionChanged): void {\r\n    super._onOptionChanged(option);\r\n    this._updateMask();\r\n  }\r\n\r\n  private _updateMask() {\r\n    if (!this._maskObj) {\r\n      this._maskObj = IMask.createMask({\r\n        mask: Number,\r\n        min: this.minValue,\r\n        max: this.maxValue,\r\n        thousandsSeparator: this.thousandsSeparator || '',\r\n        scale: this.decimals,\r\n        radix: '.',\r\n        padFractionalZeros: this.decimals > 0 && this.padDecimalZeros\r\n      });\r\n    }\r\n    else {\r\n      this._maskObj.updateOptions({\r\n        min: this.minValue,\r\n        max: this.maxValue,\r\n        thousandsSeparator: this.thousandsSeparator || '',\r\n        scale: this.decimals,\r\n        radix: '.',\r\n        padFractionalZeros: this.decimals > 0 && this.padDecimalZeros\r\n      })\r\n    }\r\n    this._maskDirective?.maskRef?.updateValue();\r\n    this._maskDirective?.maskRef?.updateControl();\r\n\r\n  }\r\n\r\n  _handleOnKeydownEvent(e: KeyboardEvent) {\r\n    const ignore = () => {\r\n      e.preventDefault();\r\n      e.stopPropagation();\r\n    };\r\n    const input = e.target as HTMLInputElement;\r\n    const valStr = input.value;\r\n    const decimalPointIndex = valStr.indexOf('.');\r\n    const selectionStart = input.selectionStart;\r\n    const selectionEnd = input.selectionEnd;\r\n\r\n    if (e.key === 'ArrowUp' || e.key === 'ArrowDown') {\r\n      if (selectionStart > decimalPointIndex && this.decimals > 0) {\r\n        e.key === 'ArrowDown' ? this.decimalStepDown() : this.decimalStepUp();\r\n      }\r\n      else {\r\n        e.key === 'ArrowDown' ? this.stepDown() : this.stepUp();\r\n      }\r\n      ignore();\r\n      setTimeout(() => {\r\n        input.setSelectionRange(selectionStart, selectionStart);\r\n      });\r\n    }\r\n    super._emitOnKeydownEvent(e);\r\n  }\r\n\r\n  _handleUpDownClick(e: AXClickEvent, v: -1 | 1) {\r\n    v == 1 ? this.stepUp() : this.stepDown();\r\n  }\r\n\r\n\r\n  _onValueChanging(value: any) {\r\n      return _.toNumber(value);\r\n  }\r\n\r\n\r\n  stepUp() {\r\n    this.value += this.step;\r\n  }\r\n\r\n  stepDown() {\r\n    this.value -= this.step;\r\n  }\r\n\r\n  decimalStepUp() {\r\n    this.value += this.decimalStep == 'auto' ? (1 / Math.pow(10, this.decimals)) : this.decimalStep;\r\n  }\r\n\r\n  decimalStepDown() {\r\n    this.value -= this.decimalStep == 'auto' ? (1 / Math.pow(10, this.decimals)) : this.decimalStep;;\r\n  }\r\n\r\n}\r\n","<ng-content select=\"ax-prefix\">\r\n</ng-content>\r\n<input class=\"ax-input\" type=\"text\"  \r\n    [attr.placeholder]=\"placeholder\" \r\n    [imask]=\"_maskObj\" \r\n    [unmask]=\"'typed'\"\r\n    [attr.min]=\"minValue\"\r\n    [attr.max]=\"maxValue\" \r\n    [class.ax-state-disabled]=\"disabled\" \r\n    [class.ax-state-readonly]=\"readonly\"\r\n    [disabled]=\"disabled\" \r\n    [readonly]=\"readonly\" \r\n    [tabindex]=\"tabIndex\" \r\n    [(ngModel)]=\"value\"\r\n    (focus)=\"_emitOnFocusEvent($event)\" (blur)=\"_emitOnFocusEvent($event)\" (keydown)=\"_handleOnKeydownEvent($event)\"\r\n    autocomplete=\"off\">\r\n\r\n<div class=\"ax-number-box-arrows\" *ngIf=\"showSpinButtons && !(disabled || readonly)\">\r\n    <ax-button color=\"light\" look=\"blank\" (onClick)=\"_handleUpDownClick($event,1)\">\r\n        <ax-prefix>\r\n            <ax-icon class=\"ax-ic-arrow-fill ax-rotate-90\">\r\n            </ax-icon>\r\n        </ax-prefix>\r\n    </ax-button>\r\n    <ax-button color=\"light\" look=\"blank\" (onClick)=\"_handleUpDownClick($event,-1)\">\r\n        <ax-prefix>\r\n            <ax-icon class=\"ax-ic-arrow-fill ax--rotate-90\">\r\n            </ax-icon>\r\n        </ax-prefix>\r\n    </ax-button>\r\n</div>\r\n<ng-content select=\"ax-suffix\">\r\n</ng-content>\r\n<ng-content select=\"ax-validation-rule\">\r\n</ng-content>"]}
|
|
@@ -3,24 +3,30 @@ import { CommonModule } from '@angular/common';
|
|
|
3
3
|
import { AXNumberBoxComponent } from './number-box.component';
|
|
4
4
|
import { FormsModule } from '@angular/forms';
|
|
5
5
|
import { AXButtonModule } from '../button';
|
|
6
|
-
import {
|
|
6
|
+
import { IMaskModule } from 'angular-imask';
|
|
7
|
+
import { AXEditorDecoratorModule } from '../decorators';
|
|
8
|
+
import { AXIconModule } from '../icon';
|
|
7
9
|
import * as i0 from "@angular/core";
|
|
8
|
-
import * as i1 from "ngx-mask";
|
|
9
10
|
const COMPONENT = [AXNumberBoxComponent];
|
|
10
11
|
const MODULES = [
|
|
11
12
|
CommonModule,
|
|
12
13
|
FormsModule,
|
|
13
14
|
AXButtonModule,
|
|
14
|
-
|
|
15
|
+
AXEditorDecoratorModule,
|
|
16
|
+
AXIconModule,
|
|
17
|
+
IMaskModule
|
|
15
18
|
];
|
|
16
19
|
export class AXNumberBoxModule {
|
|
17
20
|
}
|
|
18
|
-
AXNumberBoxModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.
|
|
19
|
-
AXNumberBoxModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.
|
|
21
|
+
AXNumberBoxModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: AXNumberBoxModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
22
|
+
AXNumberBoxModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: AXNumberBoxModule, declarations: [AXNumberBoxComponent], imports: [CommonModule,
|
|
20
23
|
FormsModule,
|
|
21
|
-
AXButtonModule,
|
|
22
|
-
|
|
23
|
-
|
|
24
|
+
AXButtonModule,
|
|
25
|
+
AXEditorDecoratorModule,
|
|
26
|
+
AXIconModule,
|
|
27
|
+
IMaskModule], exports: [AXNumberBoxComponent] });
|
|
28
|
+
AXNumberBoxModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: AXNumberBoxModule, providers: [], imports: [[...MODULES]] });
|
|
29
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: AXNumberBoxModule, decorators: [{
|
|
24
30
|
type: NgModule,
|
|
25
31
|
args: [{
|
|
26
32
|
declarations: [...COMPONENT],
|
|
@@ -29,4 +35,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImpor
|
|
|
29
35
|
providers: [],
|
|
30
36
|
}]
|
|
31
37
|
}] });
|
|
32
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
38
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVtYmVyLWJveC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hY29yZXgvY29tcG9uZW50cy9zcmMvbGliL251bWJlci1ib3gvbnVtYmVyLWJveC5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUN6QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDL0MsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDOUQsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBQzdDLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxXQUFXLENBQUM7QUFDM0MsT0FBTyxFQUFDLFdBQVcsRUFBQyxNQUFNLGVBQWUsQ0FBQztBQUMxQyxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDeEQsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLFNBQVMsQ0FBQzs7QUFFdkMsTUFBTSxTQUFTLEdBQUcsQ0FBQyxvQkFBb0IsQ0FBQyxDQUFDO0FBQ3pDLE1BQU0sT0FBTyxHQUFHO0lBQ1osWUFBWTtJQUNaLFdBQVc7SUFDWCxjQUFjO0lBQ2QsdUJBQXVCO0lBQ3ZCLFlBQVk7SUFDWixXQUFXO0NBQ2QsQ0FBQztBQVFGLE1BQU0sT0FBTyxpQkFBaUI7OzhHQUFqQixpQkFBaUI7K0dBQWpCLGlCQUFpQixpQkFoQlgsb0JBQW9CLGFBRW5DLFlBQVk7UUFDWixXQUFXO1FBQ1gsY0FBYztRQUNkLHVCQUF1QjtRQUN2QixZQUFZO1FBQ1osV0FBVyxhQVBJLG9CQUFvQjsrR0FnQjFCLGlCQUFpQixhQUZmLEVBQUUsWUFGSixDQUFDLEdBQUcsT0FBTyxDQUFDOzJGQUlaLGlCQUFpQjtrQkFON0IsUUFBUTttQkFBQztvQkFDTixZQUFZLEVBQUUsQ0FBQyxHQUFHLFNBQVMsQ0FBQztvQkFDNUIsT0FBTyxFQUFFLENBQUMsR0FBRyxPQUFPLENBQUM7b0JBQ3JCLE9BQU8sRUFBRSxDQUFDLEdBQUcsU0FBUyxDQUFDO29CQUN2QixTQUFTLEVBQUUsRUFBRTtpQkFDaEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xyXG5pbXBvcnQgeyBBWE51bWJlckJveENvbXBvbmVudCB9IGZyb20gJy4vbnVtYmVyLWJveC5jb21wb25lbnQnO1xyXG5pbXBvcnQgeyBGb3Jtc01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Zvcm1zJztcclxuaW1wb3J0IHsgQVhCdXR0b25Nb2R1bGUgfSBmcm9tICcuLi9idXR0b24nO1xyXG5pbXBvcnQge0lNYXNrTW9kdWxlfSBmcm9tICdhbmd1bGFyLWltYXNrJztcclxuaW1wb3J0IHsgQVhFZGl0b3JEZWNvcmF0b3JNb2R1bGUgfSBmcm9tICcuLi9kZWNvcmF0b3JzJztcclxuaW1wb3J0IHsgQVhJY29uTW9kdWxlIH0gZnJvbSAnLi4vaWNvbic7XHJcblxyXG5jb25zdCBDT01QT05FTlQgPSBbQVhOdW1iZXJCb3hDb21wb25lbnRdO1xyXG5jb25zdCBNT0RVTEVTID0gW1xyXG4gICAgQ29tbW9uTW9kdWxlLFxyXG4gICAgRm9ybXNNb2R1bGUsXHJcbiAgICBBWEJ1dHRvbk1vZHVsZSxcclxuICAgIEFYRWRpdG9yRGVjb3JhdG9yTW9kdWxlLFxyXG4gICAgQVhJY29uTW9kdWxlLFxyXG4gICAgSU1hc2tNb2R1bGVcclxuXTtcclxuXHJcbkBOZ01vZHVsZSh7XHJcbiAgICBkZWNsYXJhdGlvbnM6IFsuLi5DT01QT05FTlRdLFxyXG4gICAgaW1wb3J0czogWy4uLk1PRFVMRVNdLFxyXG4gICAgZXhwb3J0czogWy4uLkNPTVBPTkVOVF0sXHJcbiAgICBwcm92aWRlcnM6IFtdLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgQVhOdW1iZXJCb3hNb2R1bGUgeyB9XHJcbiJdfQ==
|
|
@@ -53,9 +53,9 @@ export class AXBasePageComponent {
|
|
|
53
53
|
this.onClosed.unsubscribe();
|
|
54
54
|
}
|
|
55
55
|
}
|
|
56
|
-
AXBasePageComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.
|
|
57
|
-
AXBasePageComponent.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.
|
|
58
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.
|
|
56
|
+
AXBasePageComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: AXBasePageComponent, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
|
|
57
|
+
AXBasePageComponent.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: AXBasePageComponent });
|
|
58
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.2.0", ngImport: i0, type: AXBasePageComponent, decorators: [{
|
|
59
59
|
type: Injectable
|
|
60
60
|
}], propDecorators: { pageContainer: [{
|
|
61
61
|
type: ViewChild,
|