@skyux/autonumeric 7.0.0-beta.1 → 7.0.0-beta.3
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/documentation.json +56 -56
- package/esm2020/lib/modules/autonumeric/autonumeric.directive.mjs +81 -78
- package/fesm2015/skyux-autonumeric.mjs +82 -79
- package/fesm2015/skyux-autonumeric.mjs.map +1 -1
- package/fesm2020/skyux-autonumeric.mjs +81 -78
- package/fesm2020/skyux-autonumeric.mjs.map +1 -1
- package/lib/modules/autonumeric/autonumeric.directive.d.ts +3 -25
- package/package.json +1 -1
|
@@ -1,3 +1,5 @@
|
|
|
1
|
+
var _SkyAutonumericDirective_instances, _SkyAutonumericDirective_autonumericInstance, _SkyAutonumericDirective_autonumericOptions, _SkyAutonumericDirective_control, _SkyAutonumericDirective_isFirstChange, _SkyAutonumericDirective_value, _SkyAutonumericDirective_ngUnsubscribe, _SkyAutonumericDirective_elementRef, _SkyAutonumericDirective_globalConfig, _SkyAutonumericDirective_renderer, _SkyAutonumericDirective_changeDetector, _SkyAutonumericDirective_getNumericValue, _SkyAutonumericDirective_isInputValueTheCurrencySymbol, _SkyAutonumericDirective_getInputValue, _SkyAutonumericDirective_updateAutonumericInstance, _SkyAutonumericDirective_mergeOptions, _SkyAutonumericDirective_onChange, _SkyAutonumericDirective_onTouched;
|
|
2
|
+
import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
1
3
|
import { ChangeDetectorRef, Directive, ElementRef, HostListener, Input, Renderer2, forwardRef, } from '@angular/core';
|
|
2
4
|
import { NG_VALIDATORS, NG_VALUE_ACCESSOR, } from '@angular/forms';
|
|
3
5
|
import AutoNumeric from 'autonumeric';
|
|
@@ -22,90 +24,98 @@ const SKY_AUTONUMERIC_VALIDATOR = {
|
|
|
22
24
|
*/
|
|
23
25
|
export class SkyAutonumericDirective {
|
|
24
26
|
constructor(elementRef, globalConfig, renderer, changeDetector) {
|
|
25
|
-
this
|
|
26
|
-
this.globalConfig = globalConfig;
|
|
27
|
-
this.renderer = renderer;
|
|
28
|
-
this.changeDetector = changeDetector;
|
|
27
|
+
_SkyAutonumericDirective_instances.add(this);
|
|
29
28
|
/**
|
|
30
29
|
* @internal
|
|
31
30
|
*/
|
|
32
31
|
this.skyAutonumericFormChangesUnformatted = false;
|
|
33
|
-
this
|
|
34
|
-
this
|
|
35
|
-
|
|
32
|
+
_SkyAutonumericDirective_autonumericInstance.set(this, void 0);
|
|
33
|
+
_SkyAutonumericDirective_autonumericOptions.set(this, void 0);
|
|
34
|
+
_SkyAutonumericDirective_control.set(this, void 0);
|
|
35
|
+
_SkyAutonumericDirective_isFirstChange.set(this, true);
|
|
36
|
+
_SkyAutonumericDirective_value.set(this, void 0);
|
|
37
|
+
_SkyAutonumericDirective_ngUnsubscribe.set(this, new Subject());
|
|
38
|
+
_SkyAutonumericDirective_elementRef.set(this, void 0);
|
|
39
|
+
_SkyAutonumericDirective_globalConfig.set(this, void 0);
|
|
40
|
+
_SkyAutonumericDirective_renderer.set(this, void 0);
|
|
41
|
+
_SkyAutonumericDirective_changeDetector.set(this, void 0);
|
|
36
42
|
// istanbul ignore next
|
|
37
|
-
|
|
38
|
-
|
|
43
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function , @typescript-eslint/no-unused-vars
|
|
44
|
+
_SkyAutonumericDirective_onChange.set(this, (_) => { });
|
|
39
45
|
// istanbul ignore next
|
|
40
|
-
|
|
41
|
-
this
|
|
46
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
47
|
+
_SkyAutonumericDirective_onTouched.set(this, () => { });
|
|
48
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_elementRef, elementRef, "f");
|
|
49
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_globalConfig, globalConfig, "f");
|
|
50
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_renderer, renderer, "f");
|
|
51
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_changeDetector, changeDetector, "f");
|
|
52
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_autonumericInstance, new AutoNumeric(elementRef.nativeElement), "f");
|
|
42
53
|
}
|
|
43
54
|
/**
|
|
44
55
|
* Assigns the name of a property from `SkyAutonumericOptionsProvider`.
|
|
45
56
|
*/
|
|
46
57
|
set skyAutonumeric(value) {
|
|
47
|
-
this
|
|
48
|
-
this.
|
|
58
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_autonumericOptions, __classPrivateFieldGet(this, _SkyAutonumericDirective_instances, "m", _SkyAutonumericDirective_mergeOptions).call(this, value), "f");
|
|
59
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_instances, "m", _SkyAutonumericDirective_updateAutonumericInstance).call(this);
|
|
49
60
|
}
|
|
50
61
|
ngOnInit() {
|
|
51
62
|
// Ensure that we set the global config even if no local config has been given.
|
|
52
|
-
if (!this
|
|
53
|
-
this
|
|
63
|
+
if (!__classPrivateFieldGet(this, _SkyAutonumericDirective_autonumericOptions, "f")) {
|
|
64
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_autonumericOptions, __classPrivateFieldGet(this, _SkyAutonumericDirective_globalConfig, "f").getConfig(), "f");
|
|
54
65
|
}
|
|
55
|
-
this.
|
|
56
|
-
fromEvent(this.
|
|
57
|
-
.pipe(takeUntil(this
|
|
66
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_instances, "m", _SkyAutonumericDirective_updateAutonumericInstance).call(this);
|
|
67
|
+
fromEvent(__classPrivateFieldGet(this, _SkyAutonumericDirective_elementRef, "f").nativeElement, 'input')
|
|
68
|
+
.pipe(takeUntil(__classPrivateFieldGet(this, _SkyAutonumericDirective_ngUnsubscribe, "f")))
|
|
58
69
|
.subscribe(() => {
|
|
59
|
-
const numericValue = this.
|
|
70
|
+
const numericValue = __classPrivateFieldGet(this, _SkyAutonumericDirective_instances, "m", _SkyAutonumericDirective_getNumericValue).call(this);
|
|
60
71
|
/* istanbul ignore else */
|
|
61
|
-
if (this
|
|
62
|
-
this
|
|
63
|
-
this.
|
|
72
|
+
if (__classPrivateFieldGet(this, _SkyAutonumericDirective_value, "f") !== numericValue) {
|
|
73
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_value, numericValue, "f");
|
|
74
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_onChange, "f").call(this, numericValue);
|
|
64
75
|
}
|
|
65
76
|
/* istanbul ignore else */
|
|
66
|
-
if (this
|
|
67
|
-
this.
|
|
77
|
+
if (__classPrivateFieldGet(this, _SkyAutonumericDirective_control, "f") && !__classPrivateFieldGet(this, _SkyAutonumericDirective_control, "f").dirty) {
|
|
78
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_control, "f").markAsDirty();
|
|
68
79
|
}
|
|
69
|
-
this.
|
|
80
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_changeDetector, "f").markForCheck();
|
|
70
81
|
});
|
|
71
82
|
}
|
|
72
83
|
ngOnDestroy() {
|
|
73
|
-
this.
|
|
74
|
-
this.
|
|
84
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_ngUnsubscribe, "f").next();
|
|
85
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_ngUnsubscribe, "f").complete();
|
|
75
86
|
}
|
|
76
87
|
/**
|
|
77
88
|
* Implemented as part of ControlValueAccessor.
|
|
78
89
|
*/
|
|
79
90
|
setDisabledState(value) {
|
|
80
|
-
this.
|
|
91
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_renderer, "f").setProperty(__classPrivateFieldGet(this, _SkyAutonumericDirective_elementRef, "f").nativeElement, 'disabled', value);
|
|
81
92
|
}
|
|
82
93
|
writeValue(value) {
|
|
83
|
-
if (this
|
|
84
|
-
this
|
|
85
|
-
this.
|
|
94
|
+
if (__classPrivateFieldGet(this, _SkyAutonumericDirective_value, "f") !== value) {
|
|
95
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_value, value, "f");
|
|
96
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_onChange, "f").call(this, value);
|
|
86
97
|
// Mark the control as "pristine" if it is initialized with a value.
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
this
|
|
90
|
-
this.control.markAsPristine();
|
|
98
|
+
if (__classPrivateFieldGet(this, _SkyAutonumericDirective_isFirstChange, "f") && __classPrivateFieldGet(this, _SkyAutonumericDirective_control, "f") && __classPrivateFieldGet(this, _SkyAutonumericDirective_value, "f") !== null) {
|
|
99
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_isFirstChange, false, "f");
|
|
100
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_control, "f").markAsPristine();
|
|
91
101
|
}
|
|
92
102
|
}
|
|
93
103
|
if (typeof value === 'number') {
|
|
94
104
|
if (this.skyAutonumericFormChangesUnformatted) {
|
|
95
|
-
this.
|
|
105
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_autonumericInstance, "f").setUnformatted(value);
|
|
96
106
|
}
|
|
97
107
|
else {
|
|
98
|
-
this.
|
|
108
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_autonumericInstance, "f").set(value);
|
|
99
109
|
}
|
|
100
110
|
}
|
|
101
111
|
else {
|
|
102
|
-
this.
|
|
112
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_autonumericInstance, "f").clear();
|
|
103
113
|
}
|
|
104
114
|
}
|
|
105
115
|
validate(control) {
|
|
106
116
|
const noErrors = null;
|
|
107
|
-
if (!this
|
|
108
|
-
this
|
|
117
|
+
if (!__classPrivateFieldGet(this, _SkyAutonumericDirective_control, "f")) {
|
|
118
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_control, control, "f");
|
|
109
119
|
}
|
|
110
120
|
if (control.value === null || control.value === undefined) {
|
|
111
121
|
return noErrors;
|
|
@@ -118,50 +128,43 @@ export class SkyAutonumericDirective {
|
|
|
118
128
|
return noErrors;
|
|
119
129
|
}
|
|
120
130
|
registerOnChange(fn) {
|
|
121
|
-
this
|
|
131
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_onChange, fn, "f");
|
|
122
132
|
}
|
|
123
133
|
registerOnTouched(fn) {
|
|
124
|
-
this
|
|
134
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_onTouched, fn, "f");
|
|
125
135
|
}
|
|
126
136
|
onBlur() {
|
|
127
|
-
this.
|
|
128
|
-
}
|
|
129
|
-
getNumericValue() {
|
|
130
|
-
const inputValue = this.getInputValue();
|
|
131
|
-
return inputValue && !this.isInputValueTheCurrencySymbol(inputValue)
|
|
132
|
-
? this.autonumericInstance.getNumber()
|
|
133
|
-
: undefined;
|
|
134
|
-
}
|
|
135
|
-
/**
|
|
136
|
-
* Due to AutoNumeric's hover logic - when AutoNumeric has a currency symbol the value
|
|
137
|
-
* that we get back on empty fields will be the currency symbol.
|
|
138
|
-
* The following logic ensures that we don't accidentally set
|
|
139
|
-
* a form value when the only input was the programatically-added currency symbol.
|
|
140
|
-
*/
|
|
141
|
-
isInputValueTheCurrencySymbol(inputValue) {
|
|
142
|
-
/* istanbul ignore next */
|
|
143
|
-
const currencySymbol = (this.autonumericOptions?.currencySymbol ?? '').trim();
|
|
144
|
-
return !!currencySymbol && inputValue === currencySymbol;
|
|
137
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_onTouched, "f").call(this);
|
|
145
138
|
}
|
|
146
|
-
|
|
147
|
-
|
|
139
|
+
}
|
|
140
|
+
_SkyAutonumericDirective_autonumericInstance = new WeakMap(), _SkyAutonumericDirective_autonumericOptions = new WeakMap(), _SkyAutonumericDirective_control = new WeakMap(), _SkyAutonumericDirective_isFirstChange = new WeakMap(), _SkyAutonumericDirective_value = new WeakMap(), _SkyAutonumericDirective_ngUnsubscribe = new WeakMap(), _SkyAutonumericDirective_elementRef = new WeakMap(), _SkyAutonumericDirective_globalConfig = new WeakMap(), _SkyAutonumericDirective_renderer = new WeakMap(), _SkyAutonumericDirective_changeDetector = new WeakMap(), _SkyAutonumericDirective_onChange = new WeakMap(), _SkyAutonumericDirective_onTouched = new WeakMap(), _SkyAutonumericDirective_instances = new WeakSet(), _SkyAutonumericDirective_getNumericValue = function _SkyAutonumericDirective_getNumericValue() {
|
|
141
|
+
const inputValue = __classPrivateFieldGet(this, _SkyAutonumericDirective_instances, "m", _SkyAutonumericDirective_getInputValue).call(this);
|
|
142
|
+
const numericValue = __classPrivateFieldGet(this, _SkyAutonumericDirective_autonumericInstance, "f").getNumber();
|
|
143
|
+
return inputValue &&
|
|
144
|
+
!__classPrivateFieldGet(this, _SkyAutonumericDirective_instances, "m", _SkyAutonumericDirective_isInputValueTheCurrencySymbol).call(this, inputValue) &&
|
|
145
|
+
typeof numericValue === 'number'
|
|
146
|
+
? numericValue
|
|
147
|
+
: undefined;
|
|
148
|
+
}, _SkyAutonumericDirective_isInputValueTheCurrencySymbol = function _SkyAutonumericDirective_isInputValueTheCurrencySymbol(inputValue) {
|
|
149
|
+
/* istanbul ignore next */
|
|
150
|
+
const currencySymbol = (__classPrivateFieldGet(this, _SkyAutonumericDirective_autonumericOptions, "f")?.currencySymbol ?? '').trim();
|
|
151
|
+
return !!currencySymbol && inputValue === currencySymbol;
|
|
152
|
+
}, _SkyAutonumericDirective_getInputValue = function _SkyAutonumericDirective_getInputValue() {
|
|
153
|
+
return __classPrivateFieldGet(this, _SkyAutonumericDirective_elementRef, "f").nativeElement.value;
|
|
154
|
+
}, _SkyAutonumericDirective_updateAutonumericInstance = function _SkyAutonumericDirective_updateAutonumericInstance() {
|
|
155
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_autonumericInstance, "f").update(__classPrivateFieldGet(this, _SkyAutonumericDirective_autonumericOptions, "f"));
|
|
156
|
+
}, _SkyAutonumericDirective_mergeOptions = function _SkyAutonumericDirective_mergeOptions(value) {
|
|
157
|
+
const globalOptions = __classPrivateFieldGet(this, _SkyAutonumericDirective_globalConfig, "f").getConfig();
|
|
158
|
+
let newOptions;
|
|
159
|
+
if (typeof value === 'string') {
|
|
160
|
+
const predefinedOptions = AutoNumeric.getPredefinedOptions();
|
|
161
|
+
newOptions = predefinedOptions[value];
|
|
148
162
|
}
|
|
149
|
-
|
|
150
|
-
|
|
163
|
+
else {
|
|
164
|
+
newOptions = value;
|
|
151
165
|
}
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
let newOptions;
|
|
155
|
-
if (typeof value === 'string') {
|
|
156
|
-
const predefinedOptions = AutoNumeric.getPredefinedOptions();
|
|
157
|
-
newOptions = predefinedOptions[value];
|
|
158
|
-
}
|
|
159
|
-
else {
|
|
160
|
-
newOptions = value;
|
|
161
|
-
}
|
|
162
|
-
return Object.assign({}, globalOptions, newOptions);
|
|
163
|
-
}
|
|
164
|
-
}
|
|
166
|
+
return Object.assign({}, globalOptions, newOptions);
|
|
167
|
+
};
|
|
165
168
|
SkyAutonumericDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyAutonumericDirective, deps: [{ token: i0.ElementRef }, { token: i1.SkyAutonumericOptionsProvider }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
166
169
|
SkyAutonumericDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: SkyAutonumericDirective, selector: "input[skyAutonumeric]", inputs: { skyAutonumeric: "skyAutonumeric", skyAutonumericFormChangesUnformatted: "skyAutonumericFormChangesUnformatted" }, host: { listeners: { "blur": "onBlur()" } }, providers: [SKY_AUTONUMERIC_VALUE_ACCESSOR, SKY_AUTONUMERIC_VALIDATOR], ngImport: i0 });
|
|
167
170
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyAutonumericDirective, decorators: [{
|
|
@@ -178,4 +181,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
178
181
|
type: HostListener,
|
|
179
182
|
args: ['blur']
|
|
180
183
|
}] } });
|
|
181
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autonumeric.directive.js","sourceRoot":"","sources":["../../../../../../../../libs/components/autonumeric/src/lib/modules/autonumeric/autonumeric.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Directive,\n  ElementRef,\n  HostListener,\n  Input,\n  OnDestroy,\n  OnInit,\n  Renderer2,\n  forwardRef,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  ValidationErrors,\n  Validator,\n} from '@angular/forms';\n\nimport AutoNumeric from 'autonumeric';\nimport { Subject, fromEvent } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyAutonumericOptions } from './autonumeric-options';\nimport { SkyAutonumericOptionsProvider } from './autonumeric-options-provider';\n\nconst SKY_AUTONUMERIC_VALUE_ACCESSOR = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => SkyAutonumericDirective),\n  multi: true,\n};\n\nconst SKY_AUTONUMERIC_VALIDATOR = {\n  provide: NG_VALIDATORS,\n  useExisting: forwardRef(() => SkyAutonumericDirective),\n  multi: true,\n};\n\n/**\n * Wraps the [autoNumeric utility](https://github.com/autoNumeric/autoNumeric) to format\n * any type of number, including currency.\n */\n@Directive({\n  selector: 'input[skyAutonumeric]',\n  providers: [SKY_AUTONUMERIC_VALUE_ACCESSOR, SKY_AUTONUMERIC_VALIDATOR],\n})\nexport class SkyAutonumericDirective\n  implements OnInit, OnDestroy, ControlValueAccessor, Validator\n{\n  /**\n   * Assigns the name of a property from `SkyAutonumericOptionsProvider`.\n   */\n  @Input()\n  public set skyAutonumeric(value: SkyAutonumericOptions) {\n    this.autonumericOptions = this.mergeOptions(value);\n    this.updateAutonumericInstance();\n  }\n\n  /**\n   * @internal\n   */\n  @Input()\n  public skyAutonumericFormChangesUnformatted = false;\n\n  private autonumericInstance: AutoNumeric;\n  private autonumericOptions: SkyAutonumericOptions | undefined;\n  private control: AbstractControl | undefined;\n  private isFirstChange = true;\n  private value: number | undefined;\n\n  private ngUnsubscribe = new Subject<void>();\n\n  constructor(\n    private elementRef: ElementRef,\n    private globalConfig: SkyAutonumericOptionsProvider,\n    private renderer: Renderer2,\n    private changeDetector: ChangeDetectorRef\n  ) {\n    this.autonumericInstance = new AutoNumeric(this.elementRef.nativeElement);\n  }\n\n  public ngOnInit(): void {\n    // Ensure that we set the global config even if no local config has been given.\n    if (!this.autonumericOptions) {\n      this.autonumericOptions = this.globalConfig.getConfig();\n    }\n    this.updateAutonumericInstance();\n\n    fromEvent(this.elementRef.nativeElement, 'input')\n      .pipe(takeUntil(this.ngUnsubscribe))\n      .subscribe(() => {\n        const numericValue: number | undefined = this.getNumericValue();\n\n        /* istanbul ignore else */\n        if (this.value !== numericValue) {\n          this.value = numericValue;\n          this.onChange(numericValue);\n        }\n\n        /* istanbul ignore else */\n        if (this.control && !this.control.dirty) {\n          this.control.markAsDirty();\n        }\n\n        this.changeDetector.markForCheck();\n      });\n  }\n\n  public ngOnDestroy(): void {\n    this.ngUnsubscribe.next();\n    this.ngUnsubscribe.complete();\n  }\n\n  /**\n   * Implemented as part of ControlValueAccessor.\n   */\n  public setDisabledState(value: boolean): void {\n    this.renderer.setProperty(this.elementRef.nativeElement, 'disabled', value);\n  }\n\n  public writeValue(value: number | undefined): void {\n    if (this.value !== value) {\n      this.value = value;\n      this.onChange(value);\n\n      // Mark the control as \"pristine\" if it is initialized with a value.\n      const initializedWithValue =\n        this.isFirstChange && this.control && this.value !== null;\n      if (initializedWithValue) {\n        this.isFirstChange = false;\n        this.control!.markAsPristine();\n      }\n    }\n\n    if (typeof value === 'number') {\n      if (this.skyAutonumericFormChangesUnformatted) {\n        this.autonumericInstance.setUnformatted(value);\n      } else {\n        this.autonumericInstance.set(value);\n      }\n    } else {\n      this.autonumericInstance.clear();\n    }\n  }\n\n  public validate(control: AbstractControl): ValidationErrors | null {\n    const noErrors = null;\n\n    if (!this.control) {\n      this.control = control;\n    }\n\n    if (control.value === null || control.value === undefined) {\n      return noErrors;\n    }\n\n    if (typeof control.value !== 'number') {\n      return {\n        notTypeOfNumber: { value: control.value },\n      };\n    }\n\n    return noErrors;\n  }\n\n  public registerOnChange(fn: (value: number | undefined) => void): void {\n    this.onChange = fn;\n  }\n\n  public registerOnTouched(fn: () => void): void {\n    this.onTouched = fn;\n  }\n\n  @HostListener('blur')\n  public onBlur(): void {\n    this.onTouched();\n  }\n\n  private getNumericValue(): number | undefined {\n    const inputValue = this.getInputValue();\n    return inputValue && !this.isInputValueTheCurrencySymbol(inputValue)\n      ? this.autonumericInstance.getNumber()\n      : undefined;\n  }\n\n  /**\n   * Due to AutoNumeric's hover logic - when AutoNumeric has a currency symbol the value\n   * that we get back on empty fields will be the currency symbol.\n   * The following logic ensures that we don't accidentally set\n   * a form value when the only input was the programatically-added currency symbol.\n   */\n  private isInputValueTheCurrencySymbol(inputValue: string): boolean {\n    /* istanbul ignore next */\n    const currencySymbol = (\n      (this.autonumericOptions as AutoNumeric.Options)?.currencySymbol ?? ''\n    ).trim();\n    return !!currencySymbol && inputValue === currencySymbol;\n  }\n\n  private getInputValue(): string {\n    return this.elementRef.nativeElement.value;\n  }\n\n  private updateAutonumericInstance(): void {\n    this.autonumericInstance.update(\n      this.autonumericOptions as AutoNumeric.Options\n    );\n  }\n\n  private mergeOptions(value: SkyAutonumericOptions): SkyAutonumericOptions {\n    const globalOptions = this.globalConfig.getConfig();\n\n    let newOptions: SkyAutonumericOptions;\n    if (typeof value === 'string') {\n      const predefinedOptions = AutoNumeric.getPredefinedOptions();\n      newOptions = predefinedOptions[\n        value as keyof AutoNumeric.Options\n      ] as AutoNumeric.Options;\n    } else {\n      newOptions = value;\n    }\n\n    return Object.assign({}, globalOptions, newOptions);\n  }\n\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  // istanbul ignore next\n  private onChange = (_: number | undefined) => {};\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  // istanbul ignore next\n  private onTouched = () => {};\n}\n"]}
|
|
184
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"autonumeric.directive.js","sourceRoot":"","sources":["../../../../../../../../libs/components/autonumeric/src/lib/modules/autonumeric/autonumeric.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectorRef,\n  Directive,\n  ElementRef,\n  HostListener,\n  Input,\n  OnDestroy,\n  OnInit,\n  Renderer2,\n  forwardRef,\n} from '@angular/core';\nimport {\n  AbstractControl,\n  ControlValueAccessor,\n  NG_VALIDATORS,\n  NG_VALUE_ACCESSOR,\n  ValidationErrors,\n  Validator,\n} from '@angular/forms';\n\nimport AutoNumeric from 'autonumeric';\nimport { Subject, fromEvent } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { SkyAutonumericOptions } from './autonumeric-options';\nimport { SkyAutonumericOptionsProvider } from './autonumeric-options-provider';\n\nconst SKY_AUTONUMERIC_VALUE_ACCESSOR = {\n  provide: NG_VALUE_ACCESSOR,\n  useExisting: forwardRef(() => SkyAutonumericDirective),\n  multi: true,\n};\n\nconst SKY_AUTONUMERIC_VALIDATOR = {\n  provide: NG_VALIDATORS,\n  useExisting: forwardRef(() => SkyAutonumericDirective),\n  multi: true,\n};\n\n/**\n * Wraps the [autoNumeric utility](https://github.com/autoNumeric/autoNumeric) to format\n * any type of number, including currency.\n */\n@Directive({\n  selector: 'input[skyAutonumeric]',\n  providers: [SKY_AUTONUMERIC_VALUE_ACCESSOR, SKY_AUTONUMERIC_VALIDATOR],\n})\nexport class SkyAutonumericDirective\n  implements OnInit, OnDestroy, ControlValueAccessor, Validator\n{\n  /**\n   * Assigns the name of a property from `SkyAutonumericOptionsProvider`.\n   */\n  @Input()\n  public set skyAutonumeric(value: SkyAutonumericOptions | undefined) {\n    this.#autonumericOptions = this.#mergeOptions(value);\n    this.#updateAutonumericInstance();\n  }\n\n  /**\n   * @internal\n   */\n  @Input()\n  public skyAutonumericFormChangesUnformatted: boolean | undefined = false;\n\n  #autonumericInstance: AutoNumeric;\n  #autonumericOptions: SkyAutonumericOptions | undefined;\n  #control: AbstractControl | undefined;\n  #isFirstChange = true;\n  #value: number | undefined;\n\n  #ngUnsubscribe = new Subject<void>();\n\n  #elementRef: ElementRef;\n  #globalConfig: SkyAutonumericOptionsProvider;\n  #renderer: Renderer2;\n  #changeDetector: ChangeDetectorRef;\n\n  constructor(\n    elementRef: ElementRef,\n    globalConfig: SkyAutonumericOptionsProvider,\n    renderer: Renderer2,\n    changeDetector: ChangeDetectorRef\n  ) {\n    this.#elementRef = elementRef;\n    this.#globalConfig = globalConfig;\n    this.#renderer = renderer;\n    this.#changeDetector = changeDetector;\n\n    this.#autonumericInstance = new AutoNumeric(elementRef.nativeElement);\n  }\n\n  public ngOnInit(): void {\n    // Ensure that we set the global config even if no local config has been given.\n    if (!this.#autonumericOptions) {\n      this.#autonumericOptions = this.#globalConfig.getConfig();\n    }\n    this.#updateAutonumericInstance();\n\n    fromEvent(this.#elementRef.nativeElement, 'input')\n      .pipe(takeUntil(this.#ngUnsubscribe))\n      .subscribe(() => {\n        const numericValue: number | undefined = this.#getNumericValue();\n\n        /* istanbul ignore else */\n        if (this.#value !== numericValue) {\n          this.#value = numericValue;\n          this.#onChange(numericValue);\n        }\n\n        /* istanbul ignore else */\n        if (this.#control && !this.#control.dirty) {\n          this.#control.markAsDirty();\n        }\n\n        this.#changeDetector.markForCheck();\n      });\n  }\n\n  public ngOnDestroy(): void {\n    this.#ngUnsubscribe.next();\n    this.#ngUnsubscribe.complete();\n  }\n\n  /**\n   * Implemented as part of ControlValueAccessor.\n   */\n  public setDisabledState(value: boolean): void {\n    this.#renderer.setProperty(\n      this.#elementRef.nativeElement,\n      'disabled',\n      value\n    );\n  }\n\n  public writeValue(value: number | undefined): void {\n    if (this.#value !== value) {\n      this.#value = value;\n      this.#onChange(value);\n\n      // Mark the control as \"pristine\" if it is initialized with a value.\n      if (this.#isFirstChange && this.#control && this.#value !== null) {\n        this.#isFirstChange = false;\n        this.#control.markAsPristine();\n      }\n    }\n\n    if (typeof value === 'number') {\n      if (this.skyAutonumericFormChangesUnformatted) {\n        this.#autonumericInstance.setUnformatted(value);\n      } else {\n        this.#autonumericInstance.set(value);\n      }\n    } else {\n      this.#autonumericInstance.clear();\n    }\n  }\n\n  public validate(control: AbstractControl): ValidationErrors | null {\n    const noErrors = null;\n\n    if (!this.#control) {\n      this.#control = control;\n    }\n\n    if (control.value === null || control.value === undefined) {\n      return noErrors;\n    }\n\n    if (typeof control.value !== 'number') {\n      return {\n        notTypeOfNumber: { value: control.value },\n      };\n    }\n\n    return noErrors;\n  }\n\n  public registerOnChange(fn: (value: number | undefined) => void): void {\n    this.#onChange = fn;\n  }\n\n  public registerOnTouched(fn: () => void): void {\n    this.#onTouched = fn;\n  }\n\n  @HostListener('blur')\n  public onBlur(): void {\n    this.#onTouched();\n  }\n\n  #getNumericValue(): number | undefined {\n    const inputValue = this.#getInputValue();\n    const numericValue = this.#autonumericInstance.getNumber();\n    return inputValue &&\n      !this.#isInputValueTheCurrencySymbol(inputValue) &&\n      typeof numericValue === 'number'\n      ? numericValue\n      : undefined;\n  }\n\n  /**\n   * Due to AutoNumeric's hover logic - when AutoNumeric has a currency symbol, the value\n   * that we get back on empty fields will be the currency symbol.\n   * The following logic ensures that we don't accidentally set\n   * a form value when the only input was the programatically-added currency symbol.\n   */\n  #isInputValueTheCurrencySymbol(inputValue: string): boolean {\n    /* istanbul ignore next */\n    const currencySymbol = (\n      (this.#autonumericOptions as AutoNumeric.Options)?.currencySymbol ?? ''\n    ).trim();\n    return !!currencySymbol && inputValue === currencySymbol;\n  }\n\n  #getInputValue(): string {\n    return this.#elementRef.nativeElement.value;\n  }\n\n  #updateAutonumericInstance(): void {\n    this.#autonumericInstance.update(\n      this.#autonumericOptions as AutoNumeric.Options\n    );\n  }\n\n  #mergeOptions(\n    value: SkyAutonumericOptions | undefined\n  ): SkyAutonumericOptions {\n    const globalOptions: SkyAutonumericOptions = this.#globalConfig.getConfig();\n\n    let newOptions: SkyAutonumericOptions | undefined;\n    if (typeof value === 'string') {\n      const predefinedOptions = AutoNumeric.getPredefinedOptions();\n      newOptions = predefinedOptions[\n        value as keyof AutoNumeric.Options\n      ] as AutoNumeric.Options;\n    } else {\n      newOptions = value;\n    }\n\n    return Object.assign({}, globalOptions, newOptions);\n  }\n\n  // istanbul ignore next\n  // eslint-disable-next-line @typescript-eslint/no-empty-function , @typescript-eslint/no-unused-vars\n  #onChange = (_: number | undefined) => {};\n  // istanbul ignore next\n  // eslint-disable-next-line @typescript-eslint/no-empty-function\n  #onTouched = () => {};\n}\n"]}
|
|
@@ -2,6 +2,7 @@ import * as i0 from '@angular/core';
|
|
|
2
2
|
import { Injectable, forwardRef, Directive, Input, HostListener, NgModule } from '@angular/core';
|
|
3
3
|
import { CommonModule } from '@angular/common';
|
|
4
4
|
import { NG_VALUE_ACCESSOR, NG_VALIDATORS, FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
5
|
+
import { __classPrivateFieldSet, __classPrivateFieldGet } from 'tslib';
|
|
5
6
|
import AutoNumeric from 'autonumeric';
|
|
6
7
|
import { Subject, fromEvent } from 'rxjs';
|
|
7
8
|
import { takeUntil } from 'rxjs/operators';
|
|
@@ -28,6 +29,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImpor
|
|
|
28
29
|
}]
|
|
29
30
|
}] });
|
|
30
31
|
|
|
32
|
+
var _SkyAutonumericDirective_instances, _SkyAutonumericDirective_autonumericInstance, _SkyAutonumericDirective_autonumericOptions, _SkyAutonumericDirective_control, _SkyAutonumericDirective_isFirstChange, _SkyAutonumericDirective_value, _SkyAutonumericDirective_ngUnsubscribe, _SkyAutonumericDirective_elementRef, _SkyAutonumericDirective_globalConfig, _SkyAutonumericDirective_renderer, _SkyAutonumericDirective_changeDetector, _SkyAutonumericDirective_getNumericValue, _SkyAutonumericDirective_isInputValueTheCurrencySymbol, _SkyAutonumericDirective_getInputValue, _SkyAutonumericDirective_updateAutonumericInstance, _SkyAutonumericDirective_mergeOptions, _SkyAutonumericDirective_onChange, _SkyAutonumericDirective_onTouched;
|
|
31
33
|
const SKY_AUTONUMERIC_VALUE_ACCESSOR = {
|
|
32
34
|
provide: NG_VALUE_ACCESSOR,
|
|
33
35
|
useExisting: forwardRef(() => SkyAutonumericDirective),
|
|
@@ -44,90 +46,98 @@ const SKY_AUTONUMERIC_VALIDATOR = {
|
|
|
44
46
|
*/
|
|
45
47
|
class SkyAutonumericDirective {
|
|
46
48
|
constructor(elementRef, globalConfig, renderer, changeDetector) {
|
|
47
|
-
this
|
|
48
|
-
this.globalConfig = globalConfig;
|
|
49
|
-
this.renderer = renderer;
|
|
50
|
-
this.changeDetector = changeDetector;
|
|
49
|
+
_SkyAutonumericDirective_instances.add(this);
|
|
51
50
|
/**
|
|
52
51
|
* @internal
|
|
53
52
|
*/
|
|
54
53
|
this.skyAutonumericFormChangesUnformatted = false;
|
|
55
|
-
this
|
|
56
|
-
this
|
|
57
|
-
|
|
54
|
+
_SkyAutonumericDirective_autonumericInstance.set(this, void 0);
|
|
55
|
+
_SkyAutonumericDirective_autonumericOptions.set(this, void 0);
|
|
56
|
+
_SkyAutonumericDirective_control.set(this, void 0);
|
|
57
|
+
_SkyAutonumericDirective_isFirstChange.set(this, true);
|
|
58
|
+
_SkyAutonumericDirective_value.set(this, void 0);
|
|
59
|
+
_SkyAutonumericDirective_ngUnsubscribe.set(this, new Subject());
|
|
60
|
+
_SkyAutonumericDirective_elementRef.set(this, void 0);
|
|
61
|
+
_SkyAutonumericDirective_globalConfig.set(this, void 0);
|
|
62
|
+
_SkyAutonumericDirective_renderer.set(this, void 0);
|
|
63
|
+
_SkyAutonumericDirective_changeDetector.set(this, void 0);
|
|
58
64
|
// istanbul ignore next
|
|
59
|
-
|
|
60
|
-
|
|
65
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function , @typescript-eslint/no-unused-vars
|
|
66
|
+
_SkyAutonumericDirective_onChange.set(this, (_) => { });
|
|
61
67
|
// istanbul ignore next
|
|
62
|
-
|
|
63
|
-
this
|
|
68
|
+
// eslint-disable-next-line @typescript-eslint/no-empty-function
|
|
69
|
+
_SkyAutonumericDirective_onTouched.set(this, () => { });
|
|
70
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_elementRef, elementRef, "f");
|
|
71
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_globalConfig, globalConfig, "f");
|
|
72
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_renderer, renderer, "f");
|
|
73
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_changeDetector, changeDetector, "f");
|
|
74
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_autonumericInstance, new AutoNumeric(elementRef.nativeElement), "f");
|
|
64
75
|
}
|
|
65
76
|
/**
|
|
66
77
|
* Assigns the name of a property from `SkyAutonumericOptionsProvider`.
|
|
67
78
|
*/
|
|
68
79
|
set skyAutonumeric(value) {
|
|
69
|
-
this
|
|
70
|
-
this.
|
|
80
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_autonumericOptions, __classPrivateFieldGet(this, _SkyAutonumericDirective_instances, "m", _SkyAutonumericDirective_mergeOptions).call(this, value), "f");
|
|
81
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_instances, "m", _SkyAutonumericDirective_updateAutonumericInstance).call(this);
|
|
71
82
|
}
|
|
72
83
|
ngOnInit() {
|
|
73
84
|
// Ensure that we set the global config even if no local config has been given.
|
|
74
|
-
if (!this
|
|
75
|
-
this
|
|
85
|
+
if (!__classPrivateFieldGet(this, _SkyAutonumericDirective_autonumericOptions, "f")) {
|
|
86
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_autonumericOptions, __classPrivateFieldGet(this, _SkyAutonumericDirective_globalConfig, "f").getConfig(), "f");
|
|
76
87
|
}
|
|
77
|
-
this.
|
|
78
|
-
fromEvent(this.
|
|
79
|
-
.pipe(takeUntil(this
|
|
88
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_instances, "m", _SkyAutonumericDirective_updateAutonumericInstance).call(this);
|
|
89
|
+
fromEvent(__classPrivateFieldGet(this, _SkyAutonumericDirective_elementRef, "f").nativeElement, 'input')
|
|
90
|
+
.pipe(takeUntil(__classPrivateFieldGet(this, _SkyAutonumericDirective_ngUnsubscribe, "f")))
|
|
80
91
|
.subscribe(() => {
|
|
81
|
-
const numericValue = this.
|
|
92
|
+
const numericValue = __classPrivateFieldGet(this, _SkyAutonumericDirective_instances, "m", _SkyAutonumericDirective_getNumericValue).call(this);
|
|
82
93
|
/* istanbul ignore else */
|
|
83
|
-
if (this
|
|
84
|
-
this
|
|
85
|
-
this.
|
|
94
|
+
if (__classPrivateFieldGet(this, _SkyAutonumericDirective_value, "f") !== numericValue) {
|
|
95
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_value, numericValue, "f");
|
|
96
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_onChange, "f").call(this, numericValue);
|
|
86
97
|
}
|
|
87
98
|
/* istanbul ignore else */
|
|
88
|
-
if (this
|
|
89
|
-
this.
|
|
99
|
+
if (__classPrivateFieldGet(this, _SkyAutonumericDirective_control, "f") && !__classPrivateFieldGet(this, _SkyAutonumericDirective_control, "f").dirty) {
|
|
100
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_control, "f").markAsDirty();
|
|
90
101
|
}
|
|
91
|
-
this.
|
|
102
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_changeDetector, "f").markForCheck();
|
|
92
103
|
});
|
|
93
104
|
}
|
|
94
105
|
ngOnDestroy() {
|
|
95
|
-
this.
|
|
96
|
-
this.
|
|
106
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_ngUnsubscribe, "f").next();
|
|
107
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_ngUnsubscribe, "f").complete();
|
|
97
108
|
}
|
|
98
109
|
/**
|
|
99
110
|
* Implemented as part of ControlValueAccessor.
|
|
100
111
|
*/
|
|
101
112
|
setDisabledState(value) {
|
|
102
|
-
this.
|
|
113
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_renderer, "f").setProperty(__classPrivateFieldGet(this, _SkyAutonumericDirective_elementRef, "f").nativeElement, 'disabled', value);
|
|
103
114
|
}
|
|
104
115
|
writeValue(value) {
|
|
105
|
-
if (this
|
|
106
|
-
this
|
|
107
|
-
this.
|
|
116
|
+
if (__classPrivateFieldGet(this, _SkyAutonumericDirective_value, "f") !== value) {
|
|
117
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_value, value, "f");
|
|
118
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_onChange, "f").call(this, value);
|
|
108
119
|
// Mark the control as "pristine" if it is initialized with a value.
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
this
|
|
112
|
-
this.control.markAsPristine();
|
|
120
|
+
if (__classPrivateFieldGet(this, _SkyAutonumericDirective_isFirstChange, "f") && __classPrivateFieldGet(this, _SkyAutonumericDirective_control, "f") && __classPrivateFieldGet(this, _SkyAutonumericDirective_value, "f") !== null) {
|
|
121
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_isFirstChange, false, "f");
|
|
122
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_control, "f").markAsPristine();
|
|
113
123
|
}
|
|
114
124
|
}
|
|
115
125
|
if (typeof value === 'number') {
|
|
116
126
|
if (this.skyAutonumericFormChangesUnformatted) {
|
|
117
|
-
this.
|
|
127
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_autonumericInstance, "f").setUnformatted(value);
|
|
118
128
|
}
|
|
119
129
|
else {
|
|
120
|
-
this.
|
|
130
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_autonumericInstance, "f").set(value);
|
|
121
131
|
}
|
|
122
132
|
}
|
|
123
133
|
else {
|
|
124
|
-
this.
|
|
134
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_autonumericInstance, "f").clear();
|
|
125
135
|
}
|
|
126
136
|
}
|
|
127
137
|
validate(control) {
|
|
128
138
|
const noErrors = null;
|
|
129
|
-
if (!this
|
|
130
|
-
this
|
|
139
|
+
if (!__classPrivateFieldGet(this, _SkyAutonumericDirective_control, "f")) {
|
|
140
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_control, control, "f");
|
|
131
141
|
}
|
|
132
142
|
if (control.value === null || control.value === undefined) {
|
|
133
143
|
return noErrors;
|
|
@@ -140,51 +150,44 @@ class SkyAutonumericDirective {
|
|
|
140
150
|
return noErrors;
|
|
141
151
|
}
|
|
142
152
|
registerOnChange(fn) {
|
|
143
|
-
this
|
|
153
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_onChange, fn, "f");
|
|
144
154
|
}
|
|
145
155
|
registerOnTouched(fn) {
|
|
146
|
-
this
|
|
156
|
+
__classPrivateFieldSet(this, _SkyAutonumericDirective_onTouched, fn, "f");
|
|
147
157
|
}
|
|
148
158
|
onBlur() {
|
|
149
|
-
this.
|
|
150
|
-
}
|
|
151
|
-
getNumericValue() {
|
|
152
|
-
const inputValue = this.getInputValue();
|
|
153
|
-
return inputValue && !this.isInputValueTheCurrencySymbol(inputValue)
|
|
154
|
-
? this.autonumericInstance.getNumber()
|
|
155
|
-
: undefined;
|
|
156
|
-
}
|
|
157
|
-
/**
|
|
158
|
-
* Due to AutoNumeric's hover logic - when AutoNumeric has a currency symbol the value
|
|
159
|
-
* that we get back on empty fields will be the currency symbol.
|
|
160
|
-
* The following logic ensures that we don't accidentally set
|
|
161
|
-
* a form value when the only input was the programatically-added currency symbol.
|
|
162
|
-
*/
|
|
163
|
-
isInputValueTheCurrencySymbol(inputValue) {
|
|
164
|
-
var _a, _b;
|
|
165
|
-
/* istanbul ignore next */
|
|
166
|
-
const currencySymbol = ((_b = (_a = this.autonumericOptions) === null || _a === void 0 ? void 0 : _a.currencySymbol) !== null && _b !== void 0 ? _b : '').trim();
|
|
167
|
-
return !!currencySymbol && inputValue === currencySymbol;
|
|
168
|
-
}
|
|
169
|
-
getInputValue() {
|
|
170
|
-
return this.elementRef.nativeElement.value;
|
|
171
|
-
}
|
|
172
|
-
updateAutonumericInstance() {
|
|
173
|
-
this.autonumericInstance.update(this.autonumericOptions);
|
|
174
|
-
}
|
|
175
|
-
mergeOptions(value) {
|
|
176
|
-
const globalOptions = this.globalConfig.getConfig();
|
|
177
|
-
let newOptions;
|
|
178
|
-
if (typeof value === 'string') {
|
|
179
|
-
const predefinedOptions = AutoNumeric.getPredefinedOptions();
|
|
180
|
-
newOptions = predefinedOptions[value];
|
|
181
|
-
}
|
|
182
|
-
else {
|
|
183
|
-
newOptions = value;
|
|
184
|
-
}
|
|
185
|
-
return Object.assign({}, globalOptions, newOptions);
|
|
159
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_onTouched, "f").call(this);
|
|
186
160
|
}
|
|
187
161
|
}
|
|
162
|
+
_SkyAutonumericDirective_autonumericInstance = new WeakMap(), _SkyAutonumericDirective_autonumericOptions = new WeakMap(), _SkyAutonumericDirective_control = new WeakMap(), _SkyAutonumericDirective_isFirstChange = new WeakMap(), _SkyAutonumericDirective_value = new WeakMap(), _SkyAutonumericDirective_ngUnsubscribe = new WeakMap(), _SkyAutonumericDirective_elementRef = new WeakMap(), _SkyAutonumericDirective_globalConfig = new WeakMap(), _SkyAutonumericDirective_renderer = new WeakMap(), _SkyAutonumericDirective_changeDetector = new WeakMap(), _SkyAutonumericDirective_onChange = new WeakMap(), _SkyAutonumericDirective_onTouched = new WeakMap(), _SkyAutonumericDirective_instances = new WeakSet(), _SkyAutonumericDirective_getNumericValue = function _SkyAutonumericDirective_getNumericValue() {
|
|
163
|
+
const inputValue = __classPrivateFieldGet(this, _SkyAutonumericDirective_instances, "m", _SkyAutonumericDirective_getInputValue).call(this);
|
|
164
|
+
const numericValue = __classPrivateFieldGet(this, _SkyAutonumericDirective_autonumericInstance, "f").getNumber();
|
|
165
|
+
return inputValue &&
|
|
166
|
+
!__classPrivateFieldGet(this, _SkyAutonumericDirective_instances, "m", _SkyAutonumericDirective_isInputValueTheCurrencySymbol).call(this, inputValue) &&
|
|
167
|
+
typeof numericValue === 'number'
|
|
168
|
+
? numericValue
|
|
169
|
+
: undefined;
|
|
170
|
+
}, _SkyAutonumericDirective_isInputValueTheCurrencySymbol = function _SkyAutonumericDirective_isInputValueTheCurrencySymbol(inputValue) {
|
|
171
|
+
var _a, _b;
|
|
172
|
+
/* istanbul ignore next */
|
|
173
|
+
const currencySymbol = ((_b = (_a = __classPrivateFieldGet(this, _SkyAutonumericDirective_autonumericOptions, "f")) === null || _a === void 0 ? void 0 : _a.currencySymbol) !== null && _b !== void 0 ? _b : '').trim();
|
|
174
|
+
return !!currencySymbol && inputValue === currencySymbol;
|
|
175
|
+
}, _SkyAutonumericDirective_getInputValue = function _SkyAutonumericDirective_getInputValue() {
|
|
176
|
+
return __classPrivateFieldGet(this, _SkyAutonumericDirective_elementRef, "f").nativeElement.value;
|
|
177
|
+
}, _SkyAutonumericDirective_updateAutonumericInstance = function _SkyAutonumericDirective_updateAutonumericInstance() {
|
|
178
|
+
__classPrivateFieldGet(this, _SkyAutonumericDirective_autonumericInstance, "f").update(__classPrivateFieldGet(this, _SkyAutonumericDirective_autonumericOptions, "f"));
|
|
179
|
+
}, _SkyAutonumericDirective_mergeOptions = function _SkyAutonumericDirective_mergeOptions(value) {
|
|
180
|
+
const globalOptions = __classPrivateFieldGet(this, _SkyAutonumericDirective_globalConfig, "f").getConfig();
|
|
181
|
+
let newOptions;
|
|
182
|
+
if (typeof value === 'string') {
|
|
183
|
+
const predefinedOptions = AutoNumeric.getPredefinedOptions();
|
|
184
|
+
newOptions = predefinedOptions[value];
|
|
185
|
+
}
|
|
186
|
+
else {
|
|
187
|
+
newOptions = value;
|
|
188
|
+
}
|
|
189
|
+
return Object.assign({}, globalOptions, newOptions);
|
|
190
|
+
};
|
|
188
191
|
SkyAutonumericDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyAutonumericDirective, deps: [{ token: i0.ElementRef }, { token: SkyAutonumericOptionsProvider }, { token: i0.Renderer2 }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
189
192
|
SkyAutonumericDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.0", type: SkyAutonumericDirective, selector: "input[skyAutonumeric]", inputs: { skyAutonumeric: "skyAutonumeric", skyAutonumericFormChangesUnformatted: "skyAutonumericFormChangesUnformatted" }, host: { listeners: { "blur": "onBlur()" } }, providers: [SKY_AUTONUMERIC_VALUE_ACCESSOR, SKY_AUTONUMERIC_VALIDATOR], ngImport: i0 });
|
|
190
193
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.0", ngImport: i0, type: SkyAutonumericDirective, decorators: [{
|