myrta-ui 14.0.0-beta.1 → 14.0.0-beta.2
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/README.md +1 -0
- package/esm2020/lib/components/badges/components/badge/badge.component.mjs +2 -2
- package/esm2020/lib/components/button/button.component.mjs +3 -3
- package/esm2020/lib/components/cdk-tooltip/cdk-tooltip.directive.mjs +1 -1
- package/esm2020/lib/components/chars-left/chars-left.component.mjs +6 -3
- package/esm2020/lib/components/dropdown/dropdown.component.mjs +2 -2
- package/esm2020/lib/components/error-message/error-message.component.mjs +7 -4
- package/esm2020/lib/components/form/checkbox/checkbox.component.mjs +5 -12
- package/esm2020/lib/components/form/checkbox/checkbox.enum.mjs +2 -5
- package/esm2020/lib/components/form/checkbox-group/checkbox-group.component.mjs +10 -4
- package/esm2020/lib/components/form/checkbox-group/components/checkbox-group-header/checkbox-group-header.component.mjs +1 -1
- package/esm2020/lib/components/form/checkbox-group/components/checkbox-group-item/checkbox-group-item.component.mjs +24 -15
- package/esm2020/lib/components/form/document-editor/document-editor.component.mjs +1 -1
- package/esm2020/lib/components/form/editor/config/default-inline-style.mjs +6 -0
- package/esm2020/lib/components/form/editor/editor.component.mjs +45 -13
- package/esm2020/lib/components/form/editor/editor.enum.mjs +2 -0
- package/esm2020/lib/components/form/input-date-time/input-date-time.component.mjs +50 -18
- package/esm2020/lib/components/form/input-date-time/input-date-time.enum.mjs +1 -1
- package/esm2020/lib/components/form/input-datepicker/input-datepicker.component.mjs +13 -8
- package/esm2020/lib/components/form/input-file/input-file.component.mjs +4 -3
- package/esm2020/lib/components/form/input-file-image/components/file-image-edit-modal/file-image-edit-modal.component.mjs +3 -3
- package/esm2020/lib/components/form/input-file-image/input-file-image.component.mjs +23 -12
- package/esm2020/lib/components/form/input-file-image/input-file-image.enum.mjs +3 -3
- package/esm2020/lib/components/form/input-number/input-number.component.mjs +54 -27
- package/esm2020/lib/components/form/input-number/input-number.enum.mjs +1 -1
- package/esm2020/lib/components/form/input-opt/components/input-opt/input-opt.component.mjs +2 -4
- package/esm2020/lib/components/form/input-password/input-password.component.mjs +37 -23
- package/esm2020/lib/components/form/input-password/input-password.enum.mjs +1 -1
- package/esm2020/lib/components/form/input-password/input-password.module.mjs +12 -4
- package/esm2020/lib/components/form/input-phone/input-phone.component.mjs +2 -2
- package/esm2020/lib/components/form/input-search/input-search.component.mjs +44 -36
- package/esm2020/lib/components/form/input-search/input-search.enum.mjs +1 -1
- package/esm2020/lib/components/form/input-search/input-search.module.mjs +7 -4
- package/esm2020/lib/components/form/input-select/input-select.component.mjs +10 -4
- package/esm2020/lib/components/form/input-tel/assets/base64.mjs +4 -0
- package/esm2020/lib/components/form/input-tel/data/all-countries.mjs +1323 -0
- package/esm2020/lib/components/form/input-tel/data/country-iso.enum.mjs +247 -0
- package/esm2020/lib/components/form/input-tel/data/phone-number-format.enum.mjs +6 -0
- package/esm2020/lib/components/form/input-tel/data/search-country-field.enum.mjs +8 -0
- package/esm2020/lib/components/form/input-tel/directives/input-tel.directive.mjs +62 -0
- package/esm2020/lib/components/form/input-tel/enums/input-phone.enum.mjs +7 -0
- package/esm2020/lib/components/form/input-tel/input-tel.component.mjs +389 -0
- package/esm2020/lib/components/form/input-tel/input-tel.module.mjs +47 -0
- package/esm2020/lib/components/form/input-tel/models/country.model.mjs +2 -0
- package/esm2020/lib/components/form/input-text/input-text.component.mjs +35 -29
- package/esm2020/lib/components/form/input-textarea/input-textarea.component.mjs +47 -42
- package/esm2020/lib/components/form/input-timepicker/input-timepicker.component.mjs +3 -3
- package/esm2020/lib/components/form/radio/radio.component.mjs +3 -3
- package/esm2020/lib/components/form/radio-group/components/radio-group-header/radio-group-header.component.mjs +49 -0
- package/esm2020/lib/components/form/radio-group/components/radio-group-item/radio-group-item.component.mjs +69 -0
- package/esm2020/lib/components/form/radio-group/helpers/filter-search-group.mjs +27 -0
- package/esm2020/lib/components/form/radio-group/helpers/get-item-by-id.mjs +11 -0
- package/esm2020/lib/components/form/radio-group/helpers/move-selected-to-first.mjs +27 -0
- package/esm2020/lib/components/form/radio-group/models/radio-group.model.mjs +2 -0
- package/esm2020/lib/components/form/radio-group/radio-group.component.mjs +185 -0
- package/esm2020/lib/components/form/radio-group/radio-group.module.mjs +47 -0
- package/esm2020/lib/components/form/rating/rating.component.mjs +4 -4
- package/esm2020/lib/components/form/switch/switch.component.mjs +2 -2
- package/esm2020/lib/components/gallery/components/gallery-confirm-modal/gallery-confirm-modal.component.mjs +3 -3
- package/esm2020/lib/components/gallery/components/gallery-item/gallery-item.component.mjs +4 -4
- package/esm2020/lib/components/hint-error-message/hint-error-message.component.mjs +6 -6
- package/esm2020/lib/components/label/label.component.mjs +3 -3
- package/esm2020/lib/components/modal/modal.component.mjs +13 -3
- package/esm2020/lib/components/paginator/paginator.component.mjs +16 -6
- package/esm2020/lib/components/paginator/paginator.module.mjs +8 -8
- package/esm2020/lib/components/progress/progress.component.mjs +2 -2
- package/esm2020/lib/components/save-state/components/save-state-editor/save-state-editor.component.mjs +2 -2
- package/esm2020/lib/components/save-state/save-state.component.mjs +3 -3
- package/esm2020/lib/components/save-state/save-state.enum.mjs +1 -1
- package/esm2020/lib/components/table/table.component.mjs +3 -3
- package/esm2020/lib/components/tabs/tabs-group/tabs-group.component.mjs +2 -2
- package/esm2020/lib/components/tooltip/tooltip-trigger/tooltip-trigger.component.mjs +4 -14
- package/esm2020/lib/components/wrappers/content-wrapper/content-wrapper.component.mjs +2 -2
- package/esm2020/lib/enums/typed.input.state.mjs +1 -1
- package/esm2020/lib/services/index.mjs +2 -1
- package/esm2020/lib/services/mrx-autosave/mrx-autosave.service.mjs +1 -1
- package/esm2020/lib/services/mrx-form-validator/constants/invalid-messages.mjs +10 -0
- package/esm2020/lib/services/mrx-form-validator/helpers/get-error-message.helper.mjs +10 -0
- package/esm2020/lib/services/mrx-form-validator/helpers/get-sorting-validations.helper.mjs +28 -0
- package/esm2020/lib/services/mrx-form-validator/models/index.mjs +4 -0
- package/esm2020/lib/services/mrx-form-validator/models/validations-options.model.mjs +2 -0
- package/esm2020/lib/services/mrx-form-validator/models/validations-settings.model.mjs +2 -0
- package/esm2020/lib/services/mrx-form-validator/models/validations-types.model.mjs +22 -0
- package/esm2020/lib/services/mrx-form-validator/mrx-form-validator.mjs +84 -183
- package/esm2020/lib/services/mrx-form-validator/validations/callback.validation.mjs +15 -0
- package/esm2020/lib/services/mrx-form-validator/validations/email.validation.mjs +11 -0
- package/esm2020/lib/services/mrx-form-validator/validations/max-length.validation.mjs +10 -0
- package/esm2020/lib/services/mrx-form-validator/validations/max-value.validation.mjs +10 -0
- package/esm2020/lib/services/mrx-form-validator/validations/min-length.validation.mjs +11 -0
- package/esm2020/lib/services/mrx-form-validator/validations/min-value.validation.mjs +10 -0
- package/esm2020/lib/services/mrx-form-validator/validations/pattern.validation.mjs +11 -0
- package/esm2020/lib/services/mrx-form-validator/validations/required.validation.mjs +22 -0
- package/esm2020/public-api.mjs +7 -1
- package/fesm2015/myrta-ui.mjs +4004 -1339
- package/fesm2015/myrta-ui.mjs.map +1 -1
- package/fesm2020/myrta-ui.mjs +3999 -1341
- package/fesm2020/myrta-ui.mjs.map +1 -1
- package/lib/components/chars-left/chars-left.component.d.ts +1 -0
- package/lib/components/error-message/error-message.component.d.ts +2 -1
- package/lib/components/form/checkbox/checkbox.component.d.ts +2 -4
- package/lib/components/form/checkbox/checkbox.enum.d.ts +0 -4
- package/lib/components/form/checkbox-group/checkbox-group.component.d.ts +3 -1
- package/lib/components/form/checkbox-group/components/checkbox-group-item/checkbox-group-item.component.d.ts +4 -1
- package/lib/components/form/editor/config/default-inline-style.d.ts +11 -0
- package/lib/components/form/editor/editor.component.d.ts +13 -4
- package/lib/components/form/editor/editor.enum.d.ts +5 -0
- package/lib/components/form/input-date-time/input-date-time.component.d.ts +6 -2
- package/lib/components/form/input-date-time/input-date-time.enum.d.ts +1 -1
- package/lib/components/form/input-datepicker/input-datepicker.component.d.ts +2 -1
- package/lib/components/form/input-file-image/components/file-image-edit-modal/file-image-edit-modal.component.d.ts +6 -0
- package/lib/components/form/input-file-image/input-file-image.component.d.ts +4 -2
- package/lib/components/form/input-file-image/input-file-image.enum.d.ts +2 -2
- package/lib/components/form/input-number/input-number.component.d.ts +11 -3
- package/lib/components/form/input-number/input-number.enum.d.ts +2 -2
- package/lib/components/form/input-opt/components/input-opt/input-opt.component.d.ts +2 -2
- package/lib/components/form/input-password/input-password.component.d.ts +14 -9
- package/lib/components/form/input-password/input-password.enum.d.ts +4 -0
- package/lib/components/form/input-password/input-password.module.d.ts +3 -1
- package/lib/components/form/input-search/input-search.component.d.ts +15 -11
- package/lib/components/form/input-search/input-search.enum.d.ts +5 -0
- package/lib/components/form/input-search/input-search.module.d.ts +2 -1
- package/lib/components/form/input-select/input-select.component.d.ts +3 -1
- package/lib/components/form/input-tel/assets/base64.d.ts +3 -0
- package/lib/components/form/input-tel/data/all-countries.d.ts +1 -0
- package/lib/components/form/input-tel/data/country-iso.enum.d.ts +245 -0
- package/lib/components/form/input-tel/data/phone-number-format.enum.d.ts +5 -0
- package/lib/components/form/input-tel/data/search-country-field.enum.d.ts +6 -0
- package/lib/components/form/input-tel/directives/input-tel.directive.d.ts +21 -0
- package/lib/components/form/input-tel/enums/input-phone.enum.d.ts +11 -0
- package/lib/components/form/input-tel/input-tel.component.d.ts +89 -0
- package/lib/components/form/input-tel/input-tel.module.d.ts +14 -0
- package/lib/components/form/input-tel/models/country.model.d.ts +18 -0
- package/lib/components/form/input-text/input-text.component.d.ts +12 -9
- package/lib/components/form/input-textarea/input-textarea.component.d.ts +12 -15
- package/lib/components/form/radio-group/components/radio-group-header/radio-group-header.component.d.ts +20 -0
- package/lib/components/form/radio-group/components/radio-group-item/radio-group-item.component.d.ts +28 -0
- package/lib/components/form/radio-group/helpers/filter-search-group.d.ts +2 -0
- package/lib/components/form/radio-group/helpers/get-item-by-id.d.ts +2 -0
- package/lib/components/form/radio-group/helpers/move-selected-to-first.d.ts +2 -0
- package/lib/components/form/radio-group/models/radio-group.model.d.ts +12 -0
- package/lib/components/form/radio-group/radio-group.component.d.ts +60 -0
- package/lib/components/form/radio-group/radio-group.module.d.ts +16 -0
- package/lib/components/modal/modal.component.d.ts +1 -0
- package/lib/components/paginator/paginator.component.d.ts +3 -1
- package/lib/components/paginator/paginator.module.d.ts +3 -3
- package/lib/components/save-state/save-state.enum.d.ts +1 -1
- package/lib/components/tooltip/tooltip-trigger/tooltip-trigger.component.d.ts +0 -1
- package/lib/services/index.d.ts +1 -0
- package/lib/services/mrx-autosave/mrx-autosave.service.d.ts +1 -1
- package/lib/services/mrx-form-validator/constants/invalid-messages.d.ts +9 -0
- package/lib/services/mrx-form-validator/helpers/get-error-message.helper.d.ts +3 -0
- package/lib/services/mrx-form-validator/helpers/get-sorting-validations.helper.d.ts +2 -0
- package/lib/services/mrx-form-validator/models/index.d.ts +3 -0
- package/lib/services/mrx-form-validator/models/validations-options.model.d.ts +28 -0
- package/lib/services/mrx-form-validator/models/validations-settings.model.d.ts +7 -0
- package/lib/services/mrx-form-validator/models/validations-types.model.d.ts +19 -0
- package/lib/services/mrx-form-validator/mrx-form-validator.d.ts +4 -32
- package/lib/services/mrx-form-validator/validations/callback.validation.d.ts +6 -0
- package/lib/services/mrx-form-validator/validations/email.validation.d.ts +6 -0
- package/lib/services/mrx-form-validator/validations/max-length.validation.d.ts +6 -0
- package/lib/services/mrx-form-validator/validations/max-value.validation.d.ts +6 -0
- package/lib/services/mrx-form-validator/validations/min-length.validation.d.ts +6 -0
- package/lib/services/mrx-form-validator/validations/min-value.validation.d.ts +6 -0
- package/lib/services/mrx-form-validator/validations/pattern.validation.d.ts +6 -0
- package/lib/services/mrx-form-validator/validations/required.validation.d.ts +6 -0
- package/package.json +3 -1
- package/public-api.d.ts +5 -0
|
@@ -2,6 +2,7 @@ import { ChangeDetectionStrategy, Component, EventEmitter, forwardRef, Input, Ou
|
|
|
2
2
|
import { NG_VALUE_ACCESSOR, Validators } from '@angular/forms';
|
|
3
3
|
import { InputNumberSizesEnum } from './input-number.enum';
|
|
4
4
|
import { v4 as uuidv4 } from 'uuid';
|
|
5
|
+
import { distinctUntilChanged, pairwise, startWith } from 'rxjs/operators';
|
|
5
6
|
import * as i0 from "@angular/core";
|
|
6
7
|
import * as i1 from "@angular/forms";
|
|
7
8
|
import * as i2 from "@angular/common";
|
|
@@ -12,6 +13,7 @@ const noop = () => {
|
|
|
12
13
|
};
|
|
13
14
|
export class InputNumberComponent {
|
|
14
15
|
constructor(fb) {
|
|
16
|
+
this.value = null;
|
|
15
17
|
this.disabled = false;
|
|
16
18
|
this.readonly = false;
|
|
17
19
|
this.decimals = 2;
|
|
@@ -30,10 +32,13 @@ export class InputNumberComponent {
|
|
|
30
32
|
this.allowNegative = false;
|
|
31
33
|
this.size = 'large';
|
|
32
34
|
this.isNullableValue = false;
|
|
35
|
+
this.isAutoCorrectingValue = false;
|
|
33
36
|
// ERROR
|
|
34
37
|
this.invalid = false;
|
|
35
38
|
this.checkInvalid = null;
|
|
39
|
+
this.changed = new EventEmitter();
|
|
36
40
|
this.modelChange = new EventEmitter();
|
|
41
|
+
this.blurred = new EventEmitter();
|
|
37
42
|
this.numberForm = fb.group({
|
|
38
43
|
number: [''],
|
|
39
44
|
});
|
|
@@ -128,40 +133,46 @@ export class InputNumberComponent {
|
|
|
128
133
|
this._delimitersInitialised = true;
|
|
129
134
|
}
|
|
130
135
|
ngOnInit() {
|
|
131
|
-
this.numberForm.valueChanges.subscribe(
|
|
132
|
-
|
|
133
|
-
if (this.numberForm.valid) {
|
|
134
|
-
const num = this.numberForm.value.number;
|
|
135
|
-
let numValue;
|
|
136
|
-
if (num === '') {
|
|
137
|
-
this.propagateChange(null);
|
|
138
|
-
this.modelChange.emit({ value: null, id: this.uuid });
|
|
139
|
-
}
|
|
140
|
-
if (num && typeof (num) === 'string') {
|
|
141
|
-
numValue = parseFloat(num.replace(',', '.').split(this.thousandsSeparator).join(''));
|
|
142
|
-
this.propagateChange(numValue);
|
|
143
|
-
this.modelChange.emit({ value: numValue, id: this.uuid });
|
|
144
|
-
}
|
|
145
|
-
else if (typeof (num) === 'number') {
|
|
146
|
-
numValue = num;
|
|
147
|
-
this.propagateChange(numValue);
|
|
148
|
-
this.modelChange.emit({ value: numValue, id: this.uuid });
|
|
149
|
-
}
|
|
150
|
-
}
|
|
151
|
-
}
|
|
136
|
+
this.numberForm.valueChanges.pipe(startWith(null), distinctUntilChanged(), pairwise()).subscribe(([oldValue, newValue]) => {
|
|
137
|
+
this._formattingValue(newValue.number);
|
|
152
138
|
});
|
|
153
139
|
this.numberForm.statusChanges.subscribe(val => {
|
|
154
140
|
this.checkIsValid();
|
|
155
141
|
});
|
|
156
142
|
}
|
|
143
|
+
_formattingValue(insideValue) {
|
|
144
|
+
if (this.invokeChanged) {
|
|
145
|
+
if (this.numberForm.valid) {
|
|
146
|
+
if (!insideValue && insideValue !== 0) {
|
|
147
|
+
this.updateValue(null);
|
|
148
|
+
}
|
|
149
|
+
else {
|
|
150
|
+
this.updateValue(insideValue);
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
}
|
|
157
155
|
resetToMax(event) {
|
|
158
156
|
event.preventDefault();
|
|
159
157
|
const f = this.getControl('number');
|
|
160
158
|
f.setValue(this._max);
|
|
161
159
|
}
|
|
162
160
|
checkIsValid() {
|
|
163
|
-
|
|
164
|
-
|
|
161
|
+
if (!this.isAutoCorrectingValue) {
|
|
162
|
+
const f = this.getControl('number');
|
|
163
|
+
this._isValid = this.numberForm.disabled || (f && f.valid || (!f.dirty && !f.touched));
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
onPhoneInputBlur() {
|
|
167
|
+
if (this.isAutoCorrectingValue) {
|
|
168
|
+
const f = this.getControl('number');
|
|
169
|
+
if (f.value > this._max) {
|
|
170
|
+
f.setValue(this._max);
|
|
171
|
+
}
|
|
172
|
+
if (f.value < this._min) {
|
|
173
|
+
f.setValue(this._min);
|
|
174
|
+
}
|
|
175
|
+
}
|
|
165
176
|
}
|
|
166
177
|
writeValue(value) {
|
|
167
178
|
const f = this.getControl('number');
|
|
@@ -176,17 +187,27 @@ export class InputNumberComponent {
|
|
|
176
187
|
registerOnTouched(fn) {
|
|
177
188
|
this.onTouchedCallback = fn;
|
|
178
189
|
}
|
|
190
|
+
updateValue(insideValue) {
|
|
191
|
+
this.value = insideValue;
|
|
192
|
+
this.changed.emit(insideValue);
|
|
193
|
+
this.modelChange.emit({ value: insideValue, id: this.uuid });
|
|
194
|
+
this.propagateChange(insideValue);
|
|
195
|
+
}
|
|
196
|
+
onBlur(event) {
|
|
197
|
+
this.onPhoneInputBlur();
|
|
198
|
+
this.blurred.emit({ value: this.value, id: this.uuid });
|
|
199
|
+
}
|
|
179
200
|
}
|
|
180
201
|
InputNumberComponent._delimitersInitialised = false;
|
|
181
202
|
InputNumberComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: InputNumberComponent, deps: [{ token: i1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component });
|
|
182
|
-
InputNumberComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: InputNumberComponent, selector: "mrx-input-number", inputs: { fields: "fields", placeholder: "placeholder", innerClass: "innerClass", customClasses: "customClasses", required: "required", allowNegative: "allowNegative", size: "size", separator: "separator", decimalSeparator: "decimalSeparator", isNullableValue: "isNullableValue", invalid: "invalid", checkInvalid: "checkInvalid", setNumberType: ["numberType", "setNumberType"], setInvalidMessage: ["invalidMessage", "setInvalidMessage"], setDisabled: ["disabled", "setDisabled"], setReadonly: ["readonly", "setReadonly"], setMin: ["minValue", "setMin"], setMax: ["maxValue", "setMax"] }, outputs: { modelChange: "modelChange" }, providers: [
|
|
203
|
+
InputNumberComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.3.0", type: InputNumberComponent, selector: "mrx-input-number", inputs: { fields: "fields", placeholder: "placeholder", innerClass: "innerClass", customClasses: "customClasses", required: "required", allowNegative: "allowNegative", size: "size", separator: "separator", decimalSeparator: "decimalSeparator", isNullableValue: "isNullableValue", isAutoCorrectingValue: "isAutoCorrectingValue", invalid: "invalid", checkInvalid: "checkInvalid", setNumberType: ["numberType", "setNumberType"], setInvalidMessage: ["invalidMessage", "setInvalidMessage"], setDisabled: ["disabled", "setDisabled"], setReadonly: ["readonly", "setReadonly"], setMin: ["minValue", "setMin"], setMax: ["maxValue", "setMax"] }, outputs: { changed: "changed", modelChange: "modelChange", blurred: "blurred" }, providers: [
|
|
183
204
|
{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => InputNumberComponent), multi: true },
|
|
184
|
-
], viewQueries: [{ propertyName: "inputElement", first: true, predicate: ["inputElement"], descendants: true }], ngImport: i0, template: "<div\r\n class=\"mrx-input-number\"\r\n [class]=\"getClasses\"\r\n [class.mrx-input-error]=\"!isValid || invalid\"\r\n [class.-disabled]=\"disabled\"\r\n [class.-readonly]=\"readonly\"\r\n>\r\n <div class=\"mrx-input-number__wrapper\">\r\n <form [formGroup]=\"numberForm\">\r\n <div>\r\n <input\r\n #inputElement\r\n autocomplete=\"nope\"\r\n formControlName=\"number\"\r\n type=\"text\"\r\n [thousandSeparator]=\"thousandsSeparator\"\r\n [decimalMarker]=\"decimalMarker\"\r\n [class]=\"innerClass\"\r\n [mask]=\"'separator.' + decimals\"\r\n [allowNegativeNumbers]=\"allowNegative\"\r\n [placeholder]=\"placeholder ? placeholder : ''\"\r\n />\r\n </div>\r\n </form>\r\n </div>\r\n\r\n <mrx-error-message *ngIf=\"!isValid && invalidMessageStart\">\r\n {{invalidMessageStart}}\r\n <a href=\"#\" (click)=\"resetToMax($event)\">{{maxMessage}}</a>\r\n {{invalidMessageEnd}}\r\n </mrx-error-message>\r\n\r\n <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n", styles: [".mrx-input-number.mrx-input-number{width:100%;position:relative}.mrx-input-number.mrx-input-number .mrx-input-text__wrapper{position:relative}.mrx-input-number.mrx-input-number input{box-sizing:border-box;border:var(--border-width-default) solid var(--neutral-bg-stroke-default);border-radius:var(--border-radius-1);width:100%;outline:none;transition:outline-width .2s,border .2s}.mrx-input-number.mrx-input-number input:focus,.mrx-input-number.mrx-input-number input:active{outline:var(--neutral-bg-island-default) solid var(--border-width-focused)}.mrx-input-number.mrx-input-number input:hover{border:var(--border-width-default) solid var(--neutral-bg-stroke-hover)}.mrx-input-number.mrx-input-number.mrx-input__readonly input[type=tel]:disabled{background-color:inherit}.mrx-input-number.mrx-input-number.mrx-input__readonly input{background-color:inherit}.mrx-input-number.mrx-input-number.mrx-input-number-lg input{font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-input-number.mrx-input-number.mrx-input-number-lg:not(.mrx-input-number-with-icon) input{padding:calc(var(--spacing-3) + var(--spacing-
|
|
205
|
+
], viewQueries: [{ propertyName: "inputElement", first: true, predicate: ["inputElement"], descendants: true }], ngImport: i0, template: "<div\r\n class=\"mrx-input-number\"\r\n [class]=\"getClasses\"\r\n [class.mrx-input-error]=\"!isValid || invalid\"\r\n [class.-disabled]=\"disabled\"\r\n [class.-readonly]=\"readonly\"\r\n>\r\n <div class=\"mrx-input-number__wrapper\">\r\n <form [formGroup]=\"numberForm\">\r\n <div>\r\n <input\r\n #inputElement\r\n autocomplete=\"nope\"\r\n formControlName=\"number\"\r\n type=\"text\"\r\n [thousandSeparator]=\"thousandsSeparator\"\r\n [decimalMarker]=\"decimalMarker\"\r\n [class]=\"innerClass\"\r\n [mask]=\"'separator.' + decimals\"\r\n [allowNegativeNumbers]=\"allowNegative\"\r\n [placeholder]=\"placeholder ? placeholder : ''\"\r\n (blur)=\"onBlur($event)\"\r\n />\r\n </div>\r\n </form>\r\n </div>\r\n\r\n <mrx-error-message *ngIf=\"!isValid && invalidMessageStart\">\r\n {{invalidMessageStart}}\r\n <a href=\"#\" (click)=\"resetToMax($event)\">{{maxMessage}}</a>\r\n {{invalidMessageEnd}}\r\n </mrx-error-message>\r\n\r\n <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n", styles: [".mrx-input-number.mrx-input-number{width:100%;position:relative}.mrx-input-number.mrx-input-number .mrx-input-text__wrapper{position:relative}.mrx-input-number.mrx-input-number input{box-sizing:border-box;border:var(--border-width-default) solid var(--neutral-bg-stroke-default);border-radius:var(--border-radius-1);width:100%;outline:none;transition:outline-width .2s,border .2s}.mrx-input-number.mrx-input-number input:focus,.mrx-input-number.mrx-input-number input:active{outline:var(--neutral-bg-island-default) solid var(--border-width-focused)}.mrx-input-number.mrx-input-number input:hover{border:var(--border-width-default) solid var(--neutral-bg-stroke-hover)}.mrx-input-number.mrx-input-number.mrx-input__readonly input[type=tel]:disabled{background-color:inherit}.mrx-input-number.mrx-input-number.mrx-input__readonly input{background-color:inherit}.mrx-input-number.mrx-input-number.mrx-input-number-lg input{font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-input-number.mrx-input-number.mrx-input-number-lg:not(.mrx-input-number-with-icon) input{padding:calc(var(--spacing-3) + var(--spacing-half) - var(--border-width-default)) var(--spacing-4)}.mrx-input-number.mrx-input-number.mrx-input-number-lg.mrx-input-number-with-icon input{padding:calc(var(--spacing-3) + var(--spacing-half) - var(--border-width-default)) var(--spacing-4) calc(var(--spacing-3) + var(--spacing-half) - var(--border-width-default)) calc(var(--spacing-module) * 10)}.mrx-input-number.mrx-input-number.mrx-input-number-md input{font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-input-number.mrx-input-number.mrx-input-number-md:not(.mrx-input-number-with-icon) input{padding:calc(var(--spacing-2) + var(--spacing-half) - var(--border-width-default)) var(--spacing-4)}.mrx-input-number.mrx-input-number.mrx-input-number-md.mrx-input-number-with-icon input{padding:calc(var(--spacing-2) + var(--spacing-half) - var(--border-width-default)) var(--spacing-4) calc(var(--spacing-2) + var(--spacing-half) - var(--border-width-default)) calc(var(--spacing-module) * 10)}.mrx-input-number.mrx-input-number.mrx-input-number-sm input{font-family:var(--body-sm-font-family);font-size:var(--body-sm-font-size);font-weight:var(--body-sm-font-weight);line-height:var(--body-sm-line-height)}.mrx-input-number.mrx-input-number.mrx-input-number-sm:not(.mrx-input-number-with-icon) input{padding:calc(var(--spacing-2) - var(--border-width-default)) var(--spacing-4)}.mrx-input-number.mrx-input-number.mrx-input-number-sm.mrx-input-number-with-icon input{padding:calc(var(--spacing-2) - var(--border-width-default)) var(--spacing-4) calc(var(--spacing-2) - var(--border-width-default)) var(--spacing-8)}.mrx-input-number.mrx-input-number.mrx-input-error input{border-color:var(--system-bg-controls-negative-default)}.mrx-input-number.mrx-input-number.mrx-input-checked-error input{border-color:var(--system-bg-controls-negative-default);background-color:var(--system-bg-negative-secondary)}.mrx-input-number.mrx-input-number.mrx-input-checked-success input{background-color:var(--system-bg-positive-secondary);border-color:var(--system-bg-controls-positive-default)}.mrx-input-number.mrx-input-number.-disabled input{background-color:var(--neutral-bg-disabled, #EEF0F4);-webkit-text-fill-color:var(--neutral-text-tertiary, #71767E);color:var(--neutral-text-tertiary, #71767E)}.mrx-input-number.mrx-input-number.-readonly input{background-color:var(--neutral-bg-disabled, #EEF0F4);-webkit-text-fill-color:var(--neutral-text-primary, #262626);color:var(--neutral-text-primary, #262626)}\n"], dependencies: [{ kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i1.FormGroupDirective, selector: "[formGroup]", inputs: ["formGroup"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i1.FormControlName, selector: "[formControlName]", inputs: ["formControlName", "disabled", "ngModel"], outputs: ["ngModelChange"] }, { kind: "component", type: i3.SaveStateComponent, selector: "mrx-save-state", inputs: ["type", "fields", "id"] }, { kind: "component", type: i4.ErrorMessageComponent, selector: "mrx-error-message", inputs: ["invalid", "invalidMessage", "customClasses"] }, { kind: "directive", type: i5.NgxMaskDirective, selector: "input[mask], textarea[mask]", inputs: ["mask", "specialCharacters", "patterns", "prefix", "suffix", "thousandSeparator", "decimalMarker", "dropSpecialCharacters", "hiddenInput", "showMaskTyped", "placeHolderCharacter", "shownMaskExpression", "showTemplate", "clearIfNotMatch", "validation", "separatorLimit", "allowNegativeNumbers", "leadZeroDateTime", "leadZero", "triggerOnMaskChange", "apm", "inputTransformFn", "outputTransformFn", "keepCharacterPositions"], outputs: ["maskFilled"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
185
206
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: InputNumberComponent, decorators: [{
|
|
186
207
|
type: Component,
|
|
187
208
|
args: [{ selector: 'mrx-input-number', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
188
209
|
{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => InputNumberComponent), multi: true },
|
|
189
|
-
], template: "<div\r\n class=\"mrx-input-number\"\r\n [class]=\"getClasses\"\r\n [class.mrx-input-error]=\"!isValid || invalid\"\r\n [class.-disabled]=\"disabled\"\r\n [class.-readonly]=\"readonly\"\r\n>\r\n <div class=\"mrx-input-number__wrapper\">\r\n <form [formGroup]=\"numberForm\">\r\n <div>\r\n <input\r\n #inputElement\r\n autocomplete=\"nope\"\r\n formControlName=\"number\"\r\n type=\"text\"\r\n [thousandSeparator]=\"thousandsSeparator\"\r\n [decimalMarker]=\"decimalMarker\"\r\n [class]=\"innerClass\"\r\n [mask]=\"'separator.' + decimals\"\r\n [allowNegativeNumbers]=\"allowNegative\"\r\n [placeholder]=\"placeholder ? placeholder : ''\"\r\n />\r\n </div>\r\n </form>\r\n </div>\r\n\r\n <mrx-error-message *ngIf=\"!isValid && invalidMessageStart\">\r\n {{invalidMessageStart}}\r\n <a href=\"#\" (click)=\"resetToMax($event)\">{{maxMessage}}</a>\r\n {{invalidMessageEnd}}\r\n </mrx-error-message>\r\n\r\n <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n", styles: [".mrx-input-number.mrx-input-number{width:100%;position:relative}.mrx-input-number.mrx-input-number .mrx-input-text__wrapper{position:relative}.mrx-input-number.mrx-input-number input{box-sizing:border-box;border:var(--border-width-default) solid var(--neutral-bg-stroke-default);border-radius:var(--border-radius-1);width:100%;outline:none;transition:outline-width .2s,border .2s}.mrx-input-number.mrx-input-number input:focus,.mrx-input-number.mrx-input-number input:active{outline:var(--neutral-bg-island-default) solid var(--border-width-focused)}.mrx-input-number.mrx-input-number input:hover{border:var(--border-width-default) solid var(--neutral-bg-stroke-hover)}.mrx-input-number.mrx-input-number.mrx-input__readonly input[type=tel]:disabled{background-color:inherit}.mrx-input-number.mrx-input-number.mrx-input__readonly input{background-color:inherit}.mrx-input-number.mrx-input-number.mrx-input-number-lg input{font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-input-number.mrx-input-number.mrx-input-number-lg:not(.mrx-input-number-with-icon) input{padding:calc(var(--spacing-3) + var(--spacing-
|
|
210
|
+
], template: "<div\r\n class=\"mrx-input-number\"\r\n [class]=\"getClasses\"\r\n [class.mrx-input-error]=\"!isValid || invalid\"\r\n [class.-disabled]=\"disabled\"\r\n [class.-readonly]=\"readonly\"\r\n>\r\n <div class=\"mrx-input-number__wrapper\">\r\n <form [formGroup]=\"numberForm\">\r\n <div>\r\n <input\r\n #inputElement\r\n autocomplete=\"nope\"\r\n formControlName=\"number\"\r\n type=\"text\"\r\n [thousandSeparator]=\"thousandsSeparator\"\r\n [decimalMarker]=\"decimalMarker\"\r\n [class]=\"innerClass\"\r\n [mask]=\"'separator.' + decimals\"\r\n [allowNegativeNumbers]=\"allowNegative\"\r\n [placeholder]=\"placeholder ? placeholder : ''\"\r\n (blur)=\"onBlur($event)\"\r\n />\r\n </div>\r\n </form>\r\n </div>\r\n\r\n <mrx-error-message *ngIf=\"!isValid && invalidMessageStart\">\r\n {{invalidMessageStart}}\r\n <a href=\"#\" (click)=\"resetToMax($event)\">{{maxMessage}}</a>\r\n {{invalidMessageEnd}}\r\n </mrx-error-message>\r\n\r\n <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n", styles: [".mrx-input-number.mrx-input-number{width:100%;position:relative}.mrx-input-number.mrx-input-number .mrx-input-text__wrapper{position:relative}.mrx-input-number.mrx-input-number input{box-sizing:border-box;border:var(--border-width-default) solid var(--neutral-bg-stroke-default);border-radius:var(--border-radius-1);width:100%;outline:none;transition:outline-width .2s,border .2s}.mrx-input-number.mrx-input-number input:focus,.mrx-input-number.mrx-input-number input:active{outline:var(--neutral-bg-island-default) solid var(--border-width-focused)}.mrx-input-number.mrx-input-number input:hover{border:var(--border-width-default) solid var(--neutral-bg-stroke-hover)}.mrx-input-number.mrx-input-number.mrx-input__readonly input[type=tel]:disabled{background-color:inherit}.mrx-input-number.mrx-input-number.mrx-input__readonly input{background-color:inherit}.mrx-input-number.mrx-input-number.mrx-input-number-lg input{font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-input-number.mrx-input-number.mrx-input-number-lg:not(.mrx-input-number-with-icon) input{padding:calc(var(--spacing-3) + var(--spacing-half) - var(--border-width-default)) var(--spacing-4)}.mrx-input-number.mrx-input-number.mrx-input-number-lg.mrx-input-number-with-icon input{padding:calc(var(--spacing-3) + var(--spacing-half) - var(--border-width-default)) var(--spacing-4) calc(var(--spacing-3) + var(--spacing-half) - var(--border-width-default)) calc(var(--spacing-module) * 10)}.mrx-input-number.mrx-input-number.mrx-input-number-md input{font-family:var(--body-md-font-family);font-size:var(--body-md-font-size);font-weight:var(--body-md-font-weight);line-height:var(--body-md-line-height)}.mrx-input-number.mrx-input-number.mrx-input-number-md:not(.mrx-input-number-with-icon) input{padding:calc(var(--spacing-2) + var(--spacing-half) - var(--border-width-default)) var(--spacing-4)}.mrx-input-number.mrx-input-number.mrx-input-number-md.mrx-input-number-with-icon input{padding:calc(var(--spacing-2) + var(--spacing-half) - var(--border-width-default)) var(--spacing-4) calc(var(--spacing-2) + var(--spacing-half) - var(--border-width-default)) calc(var(--spacing-module) * 10)}.mrx-input-number.mrx-input-number.mrx-input-number-sm input{font-family:var(--body-sm-font-family);font-size:var(--body-sm-font-size);font-weight:var(--body-sm-font-weight);line-height:var(--body-sm-line-height)}.mrx-input-number.mrx-input-number.mrx-input-number-sm:not(.mrx-input-number-with-icon) input{padding:calc(var(--spacing-2) - var(--border-width-default)) var(--spacing-4)}.mrx-input-number.mrx-input-number.mrx-input-number-sm.mrx-input-number-with-icon input{padding:calc(var(--spacing-2) - var(--border-width-default)) var(--spacing-4) calc(var(--spacing-2) - var(--border-width-default)) var(--spacing-8)}.mrx-input-number.mrx-input-number.mrx-input-error input{border-color:var(--system-bg-controls-negative-default)}.mrx-input-number.mrx-input-number.mrx-input-checked-error input{border-color:var(--system-bg-controls-negative-default);background-color:var(--system-bg-negative-secondary)}.mrx-input-number.mrx-input-number.mrx-input-checked-success input{background-color:var(--system-bg-positive-secondary);border-color:var(--system-bg-controls-positive-default)}.mrx-input-number.mrx-input-number.-disabled input{background-color:var(--neutral-bg-disabled, #EEF0F4);-webkit-text-fill-color:var(--neutral-text-tertiary, #71767E);color:var(--neutral-text-tertiary, #71767E)}.mrx-input-number.mrx-input-number.-readonly input{background-color:var(--neutral-bg-disabled, #EEF0F4);-webkit-text-fill-color:var(--neutral-text-primary, #262626);color:var(--neutral-text-primary, #262626)}\n"] }]
|
|
190
211
|
}], ctorParameters: function () { return [{ type: i1.FormBuilder }]; }, propDecorators: { fields: [{
|
|
191
212
|
type: Input
|
|
192
213
|
}], placeholder: [{
|
|
@@ -207,6 +228,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
207
228
|
type: Input
|
|
208
229
|
}], isNullableValue: [{
|
|
209
230
|
type: Input
|
|
231
|
+
}], isAutoCorrectingValue: [{
|
|
232
|
+
type: Input
|
|
210
233
|
}], invalid: [{
|
|
211
234
|
type: Input
|
|
212
235
|
}], checkInvalid: [{
|
|
@@ -232,7 +255,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
232
255
|
}], setMax: [{
|
|
233
256
|
type: Input,
|
|
234
257
|
args: ['maxValue']
|
|
258
|
+
}], changed: [{
|
|
259
|
+
type: Output
|
|
235
260
|
}], modelChange: [{
|
|
236
261
|
type: Output
|
|
262
|
+
}], blurred: [{
|
|
263
|
+
type: Output
|
|
237
264
|
}] } });
|
|
238
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-number.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/input-number/input-number.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/input-number/input-number.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport {\r\n  ControlValueAccessor,\r\n  FormBuilder,\r\n  FormControl,\r\n  FormGroup,\r\n  NG_VALUE_ACCESSOR,\r\n  Validators\r\n} from '@angular/forms';\r\nimport {\r\n  InputNumberSizesEnum,\r\n  InputNumberSizesTypes,\r\n  InputNumberType,\r\n  InputNumberValueWithId\r\n} from './input-number.enum';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { Field } from '../../../services/mrx-autosave/mrx-autosave.service';\r\n\r\nconst noop = () => {\r\n};\r\n\r\nexport type DecimalMarkerType = '.' | ',' | ['.', ','];\r\n\r\n@Component({\r\n  selector: 'mrx-input-number',\r\n  templateUrl: './input-number.component.html',\r\n  styleUrls: ['./input-number.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => InputNumberComponent), multi: true },\r\n  ]\r\n})\r\nexport class InputNumberComponent implements ControlValueAccessor, OnInit {\r\n\r\n  public static decimalMarker?: DecimalMarkerType;\r\n  private static _delimitersInitialised = false;\r\n  public static thousandsSeparator: string;\r\n\r\n  public disabled = false;\r\n  public readonly = false;\r\n\r\n  numberForm: FormGroup;\r\n  invalidMessageStart: string | undefined | null;\r\n  invalidMessageEnd: string | undefined | null;\r\n  decimals = 2;\r\n\r\n  private invokeChanged = true;\r\n  private onTouchedCallback: () => void = noop;\r\n  private propagateChange: (_: any) => void = noop;\r\n  private _min = -999999999.99;\r\n  private _max = 999999999.99;\r\n  private _isValid = true;\r\n\r\n\r\n  // SAVE STATE\r\n  public uuid: string = uuidv4();\r\n  @Input() public fields: Field[] = [];\r\n\r\n  @Input() public placeholder?: string;\r\n  @Input() public innerClass = '';\r\n  @Input() public customClasses = '';\r\n  @Input() public required = false;\r\n  @Input() public allowNegative = false;\r\n  @Input() public size: InputNumberSizesTypes = 'large';\r\n  @Input() public separator?: string;\r\n  @Input() public decimalSeparator?: DecimalMarkerType;\r\n  @Input() public isNullableValue = false;\r\n\r\n  // ERROR\r\n  @Input() public invalid = false;\r\n  @Input() public checkInvalid: true | false | null = null;\r\n\r\n  @ViewChild('inputElement') inputElement!: ElementRef;\r\n\r\n  @Input('numberType')\r\n  public set setNumberType(value: InputNumberType) {\r\n    this.decimals = value === 'float' ? 2 : value === 'percent' ? 1 : 0;\r\n  }\r\n\r\n  @Input('invalidMessage')\r\n  public set setInvalidMessage(value: string) {\r\n    if (value) {\r\n      const para = value.split('{0}');\r\n      this.invalidMessageStart = para[0];\r\n      this.invalidMessageEnd = para[1];\r\n    } else {\r\n      this.invalidMessageStart = null;\r\n      this.invalidMessageEnd = null;\r\n    }\r\n  }\r\n\r\n  @Input('disabled')\r\n  public set setDisabled(value: boolean) {\r\n    this.invokeChanged = false;\r\n    this.disabled = value\r\n    if (value) {\r\n      this.numberForm.disable();\r\n    } else {\r\n      this.numberForm.enable();\r\n    }\r\n    this.invokeChanged = true;\r\n  }\r\n\r\n  @Input('readonly')\r\n  public set setReadonly(value: boolean) {\r\n    this.invokeChanged = false;\r\n    this.readonly = value\r\n    if (value) {\r\n      this.numberForm.disable();\r\n    } else {\r\n      this.numberForm.enable();\r\n    }\r\n    this.invokeChanged = true;\r\n  }\r\n\r\n  @Input('minValue')\r\n  public set setMin(val: number) {\r\n    if (val) {\r\n      this._min = val;\r\n      const c = this.getControl('number');\r\n      if (c) {\r\n        c.setValidators([Validators.min(this._min), Validators.max(this._max)]);\r\n      }\r\n    }\r\n  }\r\n\r\n  @Input('maxValue')\r\n  public set setMax(val: number) {\r\n    if (val) {\r\n      this._max = val;\r\n      const c = this.getControl('number');\r\n      if (c) {\r\n        c.setValidators([Validators.min(this._min), Validators.max(this._max)]);\r\n      }\r\n    }\r\n  }\r\n\r\n  @Output() public modelChange: EventEmitter<InputNumberValueWithId> = new EventEmitter<InputNumberValueWithId>();\r\n\r\n  constructor(fb: FormBuilder) {\r\n    this.numberForm = fb.group({\r\n      number: [''],\r\n    });\r\n\r\n    InputNumberComponent.initNumberFormat();\r\n  }\r\n\r\n  get getClasses(): string {\r\n    return `${InputNumberSizesEnum[this.size]} ${this.customClasses}`;\r\n  }\r\n\r\n  get decimalMarker(): '.' | ',' | ['.', ','] {\r\n    return this.decimalSeparator || InputNumberComponent.decimalMarker || ',';\r\n  }\r\n\r\n  get thousandsSeparator(): string {\r\n    return this.separator || InputNumberComponent.thousandsSeparator;\r\n  }\r\n\r\n  get isValid(): boolean {\r\n    return this._isValid;\r\n  }\r\n\r\n  get maxMessage(): string {\r\n    const dec = this.decimalMarker[0];\r\n    return this._max.toLocaleString('en').split(',').join(this.thousandsSeparator).replace('.', dec);\r\n  }\r\n\r\n  get isVerified(): boolean {\r\n    const f = this.getControl('number');\r\n    return !this.required ||\r\n      (this.required && f.value !== null && f.value !== undefined && this.isValid);\r\n  }\r\n\r\n  static initNumberFormat(): void {\r\n    if (this._delimitersInitialised) {\r\n      return;\r\n    }\r\n    // системный формат числа с дробной частью и группой разраядов (тысячи)\r\n    const c = Intl.NumberFormat().formatToParts(1234.5);\r\n\r\n    const t = c.find(x => x.type === 'group')?.value;\r\n\r\n    // разделитель групп\r\n    this.thousandsSeparator = t?.charCodeAt(0) === 160 ? ' ' : t || ' ';\r\n\r\n    // разделитель дробной части\r\n    this.decimalMarker = (c.find(x => x.type === 'decimal')?.value as (',' | '.'));\r\n\r\n    this._delimitersInitialised = true;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.numberForm.valueChanges.subscribe(val => {\r\n      if (this.invokeChanged) {\r\n        if (this.numberForm.valid) {\r\n          const num = this.numberForm.value.number;\r\n          let numValue: number;\r\n          if (num === '') {\r\n            this.propagateChange(null);\r\n            this.modelChange.emit({ value: null, id: this.uuid });\r\n          }\r\n          if (num && typeof (num) === 'string') {\r\n            numValue = parseFloat(num.replace(',', '.').split(this.thousandsSeparator).join(''));\r\n            this.propagateChange(numValue);\r\n            this.modelChange.emit({ value: numValue, id: this.uuid });\r\n          } else if (typeof (num) === 'number') {\r\n            numValue = num;\r\n            this.propagateChange(numValue);\r\n            this.modelChange.emit({ value: numValue, id: this.uuid });\r\n          }\r\n        }\r\n      }\r\n    });\r\n    this.numberForm.statusChanges.subscribe(val => {\r\n      this.checkIsValid();\r\n    });\r\n  }\r\n\r\n  resetToMax(event: any) {\r\n    event.preventDefault();\r\n\r\n    const f = this.getControl('number');\r\n    f.setValue(this._max);\r\n  }\r\n\r\n  checkIsValid() {\r\n    const f = this.getControl('number');\r\n    this._isValid = this.numberForm.disabled || (f && f.valid || (!f.dirty && !f.touched));\r\n  }\r\n\r\n  writeValue(value: any): void {\r\n    const f = this.getControl('number');\r\n    f.setValue(value, { emitEvent: false, emitViewToModelChange: false });\r\n  }\r\n\r\n  getControl(name: string) {\r\n    return this.numberForm.get(name) as FormControl;\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.propagateChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouchedCallback = fn;\r\n  }\r\n}\r\n","<div\r\n    class=\"mrx-input-number\"\r\n    [class]=\"getClasses\"\r\n    [class.mrx-input-error]=\"!isValid || invalid\"\r\n    [class.-disabled]=\"disabled\"\r\n    [class.-readonly]=\"readonly\"\r\n>\r\n  <div class=\"mrx-input-number__wrapper\">\r\n    <form [formGroup]=\"numberForm\">\r\n      <div>\r\n        <input\r\n            #inputElement\r\n            autocomplete=\"nope\"\r\n            formControlName=\"number\"\r\n            type=\"text\"\r\n            [thousandSeparator]=\"thousandsSeparator\"\r\n            [decimalMarker]=\"decimalMarker\"\r\n            [class]=\"innerClass\"\r\n            [mask]=\"'separator.' + decimals\"\r\n            [allowNegativeNumbers]=\"allowNegative\"\r\n            [placeholder]=\"placeholder ? placeholder : ''\"\r\n        />\r\n      </div>\r\n    </form>\r\n  </div>\r\n\r\n  <mrx-error-message *ngIf=\"!isValid && invalidMessageStart\">\r\n    {{invalidMessageStart}}\r\n    <a href=\"#\" (click)=\"resetToMax($event)\">{{maxMessage}}</a>\r\n    {{invalidMessageEnd}}\r\n  </mrx-error-message>\r\n\r\n  <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n"]}
|
|
265
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-number.component.js","sourceRoot":"","sources":["../../../../../../../projects/myrta-ui/src/lib/components/form/input-number/input-number.component.ts","../../../../../../../projects/myrta-ui/src/lib/components/form/input-number/input-number.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  forwardRef,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  ViewChild\r\n} from '@angular/core';\r\nimport {\r\n  ControlValueAccessor,\r\n  FormBuilder,\r\n  FormControl,\r\n  FormGroup,\r\n  NG_VALUE_ACCESSOR,\r\n  Validators\r\n} from '@angular/forms';\r\nimport {\r\n  InputNumberSizesEnum,\r\n  InputNumberSizesTypes,\r\n  InputNumberType, InputNumberValueTypes,\r\n  InputNumberValueWithId\r\n} from './input-number.enum';\r\nimport { v4 as uuidv4 } from 'uuid';\r\nimport { Field } from '../../../services';\r\nimport { distinctUntilChanged, pairwise, startWith } from 'rxjs/operators';\r\n\r\nconst noop = () => {\r\n};\r\n\r\nexport type DecimalMarkerType = '.' | ',' | ['.', ','];\r\n\r\n@Component({\r\n  selector: 'mrx-input-number',\r\n  templateUrl: './input-number.component.html',\r\n  styleUrls: ['./input-number.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => InputNumberComponent), multi: true},\r\n  ]\r\n})\r\nexport class InputNumberComponent implements ControlValueAccessor, OnInit {\r\n\r\n  public static decimalMarker?: DecimalMarkerType;\r\n  private static _delimitersInitialised = false;\r\n  public static thousandsSeparator: string;\r\n\r\n  public value: InputNumberValueTypes = null;\r\n  public disabled = false;\r\n  public readonly = false;\r\n\r\n  numberForm: FormGroup;\r\n  invalidMessageStart: string | undefined | null;\r\n  invalidMessageEnd: string | undefined | null;\r\n  decimals = 2;\r\n\r\n  private invokeChanged = true;\r\n  private onTouchedCallback: () => void = noop;\r\n  private propagateChange: (_: any) => void = noop;\r\n  private _min = -999999999.99;\r\n  private _max = 999999999.99;\r\n  private _isValid = true;\r\n\r\n\r\n  // SAVE STATE\r\n  public uuid: string = uuidv4();\r\n  @Input() public fields: Field[] = [];\r\n\r\n  @Input() public placeholder?: string;\r\n  @Input() public innerClass = '';\r\n  @Input() public customClasses = '';\r\n  @Input() public required = false;\r\n  @Input() public allowNegative = false;\r\n  @Input() public size: InputNumberSizesTypes = 'large';\r\n  @Input() public separator?: string;\r\n  @Input() public decimalSeparator?: DecimalMarkerType;\r\n  @Input() public isNullableValue = false;\r\n  @Input() public isAutoCorrectingValue = false;\r\n\r\n  // ERROR\r\n  @Input() public invalid = false;\r\n  @Input() public checkInvalid: true | false | null = null;\r\n\r\n  @ViewChild('inputElement') inputElement!: ElementRef;\r\n\r\n  @Input('numberType')\r\n  public set setNumberType(value: InputNumberType) {\r\n    this.decimals = value === 'float' ? 2 : value === 'percent' ? 1 : 0;\r\n  }\r\n\r\n  @Input('invalidMessage')\r\n  public set setInvalidMessage(value: string) {\r\n    if (value) {\r\n      const para = value.split('{0}');\r\n      this.invalidMessageStart = para[0];\r\n      this.invalidMessageEnd = para[1];\r\n    } else {\r\n      this.invalidMessageStart = null;\r\n      this.invalidMessageEnd = null;\r\n    }\r\n  }\r\n\r\n  @Input('disabled')\r\n  public set setDisabled(value: boolean) {\r\n    this.invokeChanged = false;\r\n    this.disabled = value;\r\n    if (value) {\r\n      this.numberForm.disable();\r\n    } else {\r\n      this.numberForm.enable();\r\n    }\r\n    this.invokeChanged = true;\r\n  }\r\n\r\n  @Input('readonly')\r\n  public set setReadonly(value: boolean) {\r\n    this.invokeChanged = false;\r\n    this.readonly = value;\r\n    if (value) {\r\n      this.numberForm.disable();\r\n    } else {\r\n      this.numberForm.enable();\r\n    }\r\n    this.invokeChanged = true;\r\n  }\r\n\r\n  @Input('minValue')\r\n  public set setMin(val: number) {\r\n    if (val) {\r\n      this._min = val;\r\n      const c = this.getControl('number');\r\n      if (c) {\r\n        c.setValidators([Validators.min(this._min), Validators.max(this._max)]);\r\n      }\r\n    }\r\n  }\r\n\r\n  @Input('maxValue')\r\n  public set setMax(val: number) {\r\n    if (val) {\r\n      this._max = val;\r\n      const c = this.getControl('number');\r\n      if (c) {\r\n        c.setValidators([Validators.min(this._min), Validators.max(this._max)]);\r\n      }\r\n    }\r\n  }\r\n\r\n  @Output() public changed: EventEmitter<InputNumberValueTypes> = new EventEmitter<InputNumberValueTypes>();\r\n  @Output() public modelChange: EventEmitter<InputNumberValueWithId> = new EventEmitter<InputNumberValueWithId>();\r\n  @Output() public blurred: EventEmitter<InputNumberValueWithId> = new EventEmitter<InputNumberValueWithId>();\r\n\r\n  constructor(fb: FormBuilder) {\r\n    this.numberForm = fb.group({\r\n      number: [''],\r\n    });\r\n\r\n    InputNumberComponent.initNumberFormat();\r\n  }\r\n\r\n  get getClasses(): string {\r\n    return `${InputNumberSizesEnum[this.size]} ${this.customClasses}`;\r\n  }\r\n\r\n  get decimalMarker(): '.' | ',' | ['.', ','] {\r\n    return this.decimalSeparator || InputNumberComponent.decimalMarker || ',';\r\n  }\r\n\r\n  get thousandsSeparator(): string {\r\n    return this.separator || InputNumberComponent.thousandsSeparator;\r\n  }\r\n\r\n  get isValid(): boolean {\r\n    return this._isValid;\r\n  }\r\n\r\n  get maxMessage(): string {\r\n    const dec = this.decimalMarker[0];\r\n    return this._max.toLocaleString('en').split(',').join(this.thousandsSeparator).replace('.', dec);\r\n  }\r\n\r\n  get isVerified(): boolean {\r\n    const f = this.getControl('number');\r\n    return !this.required ||\r\n      (this.required && f.value !== null && f.value !== undefined && this.isValid);\r\n  }\r\n\r\n  static initNumberFormat(): void {\r\n    if (this._delimitersInitialised) {\r\n      return;\r\n    }\r\n    // системный формат числа с дробной частью и группой разраядов (тысячи)\r\n    const c = Intl.NumberFormat().formatToParts(1234.5);\r\n\r\n    const t = c.find(x => x.type === 'group')?.value;\r\n\r\n    // разделитель групп\r\n    this.thousandsSeparator = t?.charCodeAt(0) === 160 ? ' ' : t || ' ';\r\n\r\n    // разделитель дробной части\r\n    this.decimalMarker = (c.find(x => x.type === 'decimal')?.value as (',' | '.'));\r\n\r\n    this._delimitersInitialised = true;\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.numberForm.valueChanges.pipe(\r\n      startWith(null),\r\n      distinctUntilChanged(),\r\n      pairwise()\r\n    ).subscribe(([oldValue, newValue]) => {\r\n      this._formattingValue(newValue.number);\r\n    });\r\n    this.numberForm.statusChanges.subscribe(val => {\r\n      this.checkIsValid();\r\n    });\r\n  }\r\n\r\n  private _formattingValue(insideValue: InputNumberValueTypes) {\r\n    if (this.invokeChanged) {\r\n      if (this.numberForm.valid) {\r\n        if (!insideValue && insideValue !== 0) {\r\n          this.updateValue(null);\r\n        } else {\r\n          this.updateValue(insideValue);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  resetToMax(event: any) {\r\n    event.preventDefault();\r\n\r\n    const f = this.getControl('number');\r\n    f.setValue(this._max);\r\n  }\r\n\r\n  checkIsValid() {\r\n    if (!this.isAutoCorrectingValue) {\r\n      const f = this.getControl('number');\r\n      this._isValid = this.numberForm.disabled || (f && f.valid || (!f.dirty && !f.touched));\r\n    }\r\n  }\r\n\r\n  onPhoneInputBlur() {\r\n    if (this.isAutoCorrectingValue) {\r\n      const f = this.getControl('number');\r\n\r\n      if (f.value > this._max) {\r\n        f.setValue(this._max);\r\n      }\r\n\r\n      if (f.value < this._min) {\r\n        f.setValue(this._min);\r\n      }\r\n    }\r\n  }\r\n\r\n  writeValue(value: any): void {\r\n    const f = this.getControl('number');\r\n    f.setValue(value, {emitEvent: false, emitViewToModelChange: false});\r\n  }\r\n\r\n  getControl(name: string) {\r\n    return this.numberForm.get(name) as FormControl;\r\n  }\r\n\r\n  registerOnChange(fn: any): void {\r\n    this.propagateChange = fn;\r\n  }\r\n\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouchedCallback = fn;\r\n  }\r\n\r\n  public updateValue(insideValue: InputNumberValueTypes) {\r\n    this.value = insideValue;\r\n    this.changed.emit(insideValue);\r\n    this.modelChange.emit({value: insideValue, id: this.uuid});\r\n    this.propagateChange(insideValue);\r\n  }\r\n\r\n  public onBlur(event: FocusEvent) {\r\n    this.onPhoneInputBlur()\r\n    this.blurred.emit({value: this.value, id: this.uuid})\r\n  }\r\n}\r\n","<div\r\n    class=\"mrx-input-number\"\r\n    [class]=\"getClasses\"\r\n    [class.mrx-input-error]=\"!isValid || invalid\"\r\n    [class.-disabled]=\"disabled\"\r\n    [class.-readonly]=\"readonly\"\r\n>\r\n  <div class=\"mrx-input-number__wrapper\">\r\n    <form [formGroup]=\"numberForm\">\r\n      <div>\r\n        <input\r\n            #inputElement\r\n            autocomplete=\"nope\"\r\n            formControlName=\"number\"\r\n            type=\"text\"\r\n            [thousandSeparator]=\"thousandsSeparator\"\r\n            [decimalMarker]=\"decimalMarker\"\r\n            [class]=\"innerClass\"\r\n            [mask]=\"'separator.' + decimals\"\r\n            [allowNegativeNumbers]=\"allowNegative\"\r\n            [placeholder]=\"placeholder ? placeholder : ''\"\r\n            (blur)=\"onBlur($event)\"\r\n        />\r\n      </div>\r\n    </form>\r\n  </div>\r\n\r\n  <mrx-error-message *ngIf=\"!isValid && invalidMessageStart\">\r\n    {{invalidMessageStart}}\r\n    <a href=\"#\" (click)=\"resetToMax($event)\">{{maxMessage}}</a>\r\n    {{invalidMessageEnd}}\r\n  </mrx-error-message>\r\n\r\n  <mrx-save-state [id]=\"uuid\" [fields]=\"fields\"></mrx-save-state>\r\n</div>\r\n"]}
|
|
@@ -4,4 +4,4 @@ export var InputNumberSizesEnum;
|
|
|
4
4
|
InputNumberSizesEnum["medium"] = "mrx-input-number-md";
|
|
5
5
|
InputNumberSizesEnum["large"] = "mrx-input-number-lg";
|
|
6
6
|
})(InputNumberSizesEnum || (InputNumberSizesEnum = {}));
|
|
7
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
7
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtbnVtYmVyLmVudW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9teXJ0YS11aS9zcmMvbGliL2NvbXBvbmVudHMvZm9ybS9pbnB1dC1udW1iZXIvaW5wdXQtbnVtYmVyLmVudW0udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsTUFBTSxDQUFOLElBQVksb0JBSVg7QUFKRCxXQUFZLG9CQUFvQjtJQUM5QixxREFBK0IsQ0FBQTtJQUMvQixzREFBZ0MsQ0FBQTtJQUNoQyxxREFBK0IsQ0FBQTtBQUNqQyxDQUFDLEVBSlcsb0JBQW9CLEtBQXBCLG9CQUFvQixRQUkvQiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCB0eXBlIElucHV0TnVtYmVyVHlwZSA9ICdpbnQnIHwgJ2Zsb2F0JyB8ICdwZXJjZW50JztcclxuXHJcbmV4cG9ydCBlbnVtIElucHV0TnVtYmVyU2l6ZXNFbnVtIHtcclxuICAnc21hbGwnID0gJ21yeC1pbnB1dC1udW1iZXItc20nLFxyXG4gICdtZWRpdW0nID0gJ21yeC1pbnB1dC1udW1iZXItbWQnLFxyXG4gICdsYXJnZScgPSAnbXJ4LWlucHV0LW51bWJlci1sZycsXHJcbn1cclxuXHJcbmV4cG9ydCB0eXBlIElucHV0TnVtYmVyU2l6ZXNUeXBlcyA9ICdzbWFsbCcgfCAnbWVkaXVtJyB8ICdsYXJnZSc7XHJcblxyXG5leHBvcnQgdHlwZSBJbnB1dE51bWJlclZhbHVlVHlwZXMgPSBudW1iZXIgfCBudWxsO1xyXG5cclxuZXhwb3J0IGludGVyZmFjZSBJbnB1dE51bWJlclZhbHVlV2l0aElkIHtcclxuICB2YWx1ZTogSW5wdXROdW1iZXJWYWx1ZVR5cGVzLFxyXG4gIGlkOiBzdHJpbmdcclxufVxyXG4iXX0=
|
|
@@ -139,7 +139,6 @@ export class InputOptComponent {
|
|
|
139
139
|
}
|
|
140
140
|
}
|
|
141
141
|
handleFocus(index) {
|
|
142
|
-
// @ts-ignore
|
|
143
142
|
this.focusedInputHasValue = !!this.ngxOtpArray.controls[index].value;
|
|
144
143
|
if (this.otpConfig.behavior === NgxOtpBehavior.LEGACY &&
|
|
145
144
|
this.focusedInputHasValue) {
|
|
@@ -168,7 +167,6 @@ export class InputOptComponent {
|
|
|
168
167
|
}
|
|
169
168
|
setUpOtpForm() {
|
|
170
169
|
for (let i = 0; i < this.otpConfig.otpLength; i++) {
|
|
171
|
-
// @ts-ignore
|
|
172
170
|
this.ngxOtpArray.push(new FormControl('', [Validators.required]));
|
|
173
171
|
}
|
|
174
172
|
}
|
|
@@ -323,7 +321,7 @@ InputOptComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", vers
|
|
|
323
321
|
useExisting: forwardRef(() => InputOptComponent),
|
|
324
322
|
multi: true,
|
|
325
323
|
},
|
|
326
|
-
], viewQueries: [{ propertyName: "otpInputElements", predicate: ["otpInputElement"], descendants: true }], ngImport: i0, template: "<form\r\n [ngClass]=\"getContainerClasses\"\r\n class=\"mrx-input-otp-container\"\r\n [class]=\"getClasses\"\r\n>\r\n <div\r\n *ngFor=\"let control of ngxOtpArray.controls; let i = index\"\r\n [ngClass]=\"getInputBoxClasses\"\r\n [class.mrx-input-error]=\"invalid\"\r\n [class]=\"checkValidClasses\"\r\n class=\"mrx-input-otp-box\"\r\n >\r\n <label [attr.aria-label]=\"ariaLabels[i]\">\r\n <input\r\n #otpInputElement\r\n [id]=\"'mrx-input-otp-' + i\"\r\n [formControl]=\"convertToFormControl(control)\"\r\n [mrxOptPattern]=\"otpConfig.pattern\"\r\n [type]=\"getInputType()\"\r\n [ngClass]=\"styles[i]\"\r\n (keyup)=\"handleKeyUp(i, $event.key)\"\r\n (keyup.backspace)=\"handleDelete(i)\"\r\n (keyup.arrowLeft)=\"stepBackward(i)\"\r\n (keyup.arrowRight)=\"stepForward(i)\"\r\n (focus)=\"handleFocus(i)\"\r\n class=\"mrx-input-otp\"\r\n maxlength=\"1\"\r\n autocapitalize=\"off\"\r\n spellcheck=\"false\"\r\n />\r\n </label>\r\n </div>\r\n</form>\r\n\r\n<mrx-error-message\r\n *ngIf=\"invalid && isInvalidMessage\"\r\n customClasses=\"text-left\"\r\n [invalidMessage]=\"invalidMessage\"\r\n></mrx-error-message>\r\n", styles: [".mrx-input-otp{background:var(--brand-bg-tertiary-default, #FFF);color:var(--neutral-text-primary, #262626);text-align:center;outline:0}.mrx-input-otp-container{display:flex}.mrx-input-otp-box label{margin-bottom:0}.mrx-input-otp-disabled{opacity:.3}.mrx-input-otp-container.mrx-input-opt-lg{gap:12px}.mrx-input-otp-container.mrx-input-opt-lg .mrx-input-otp{width:var(--sizing-12);height:var(--sizing-12);border-radius:var(--border-radius-1);border:1px solid var(--neutral-bg-stroke-default, #DAD5CE);font-family:var(--headlines-lvl-3-font-family);font-weight:var(--headlines-lvl-3-font-weight);line-height:var(--headlines-lvl-3-line-height);font-size:var(--headlines-lvl-3-font-size)}.mrx-input-otp-container.mrx-input-opt-md{gap:10px}.mrx-input-otp-container.mrx-input-opt-md .mrx-input-otp{width:var(--sizing-10);height:var(--sizing-10);border-radius:var(--border-radius-1);border:1px solid var(--neutral-bg-stroke-default, #DAD5CE);font-family:var(--headlines-lvl-4-font-family);font-weight:var(--headlines-lvl-4-font-weight);line-height:var(--headlines-lvl-4-line-height);font-size:var(--headlines-lvl-4-font-size)}.mrx-input-otp-container.mrx-input-opt-responsive{flex-wrap:wrap;gap:12px}.mrx-input-otp-container.mrx-input-opt-responsive .mrx-input-otp{width:var(--sizing-12);height:var(--sizing-12);border-radius:var(--border-radius-1);border:1px solid var(--neutral-bg-stroke-default, #DAD5CE);font-family:var(--headlines-lvl-3-font-family);font-weight:var(--headlines-lvl-3-font-weight);line-height:var(--headlines-lvl-3-line-height);font-size:var(--headlines-lvl-3-font-size)}@media (max-width: 576px){.mrx-input-otp-container.mrx-input-opt-responsive{gap:10px}.mrx-input-otp-container.mrx-input-opt-responsive .mrx-input-otp{width:var(--sizing-10);height:var(--sizing-10);font-family:var(--headlines-lvl-4-font-family);font-weight:var(--headlines-lvl-4-font-weight);line-height:var(--headlines-lvl-4-line-height);font-size:var(--headlines-lvl-4-font-size)}}@media (max-width: 370px){.mrx-input-otp-container.mrx-input-opt-responsive{gap:8px}.mrx-input-otp-container.mrx-input-opt-responsive .mrx-input-otp{width:var(--sizing-8);height:var(--sizing-8);font-family:var(--headlines-lvl-5-font-family);font-weight:var(--headlines-lvl-5-font-weight);line-height:var(--headlines-lvl-5-line-height);font-size:var(--headlines-lvl-5-font-size)}}.mrx-input-otp-container .mrx-input-otp-box.mrx-input-error .mrx-input-otp{border-color:var(--system-bg-controls-negative-default)}.mrx-input-otp-container .mrx-input-otp-box.mrx-input-checked-error .mrx-input-otp{border-color:var(--system-bg-controls-negative-default);background-color:var(--system-bg-negative-secondary)}.mrx-input-otp-container .mrx-input-otp-box.mrx-input-checked-success .mrx-input-otp{background-color:var(--system-bg-positive-secondary);border-color:var(--system-bg-controls-positive-default)}\n"], dependencies: [{ kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.ErrorMessageComponent, selector: "mrx-error-message", inputs: ["invalidMessage", "customClasses"] }, { kind: "directive", type: i5.OptPatternDirective, selector: "[mrxOptPattern]", inputs: ["mrxOptPattern"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
324
|
+
], viewQueries: [{ propertyName: "otpInputElements", predicate: ["otpInputElement"], descendants: true }], ngImport: i0, template: "<form\r\n [ngClass]=\"getContainerClasses\"\r\n class=\"mrx-input-otp-container\"\r\n [class]=\"getClasses\"\r\n>\r\n <div\r\n *ngFor=\"let control of ngxOtpArray.controls; let i = index\"\r\n [ngClass]=\"getInputBoxClasses\"\r\n [class.mrx-input-error]=\"invalid\"\r\n [class]=\"checkValidClasses\"\r\n class=\"mrx-input-otp-box\"\r\n >\r\n <label [attr.aria-label]=\"ariaLabels[i]\">\r\n <input\r\n #otpInputElement\r\n [id]=\"'mrx-input-otp-' + i\"\r\n [formControl]=\"convertToFormControl(control)\"\r\n [mrxOptPattern]=\"otpConfig.pattern\"\r\n [type]=\"getInputType()\"\r\n [ngClass]=\"styles[i]\"\r\n (keyup)=\"handleKeyUp(i, $event.key)\"\r\n (keyup.backspace)=\"handleDelete(i)\"\r\n (keyup.arrowLeft)=\"stepBackward(i)\"\r\n (keyup.arrowRight)=\"stepForward(i)\"\r\n (focus)=\"handleFocus(i)\"\r\n class=\"mrx-input-otp\"\r\n maxlength=\"1\"\r\n autocapitalize=\"off\"\r\n spellcheck=\"false\"\r\n />\r\n </label>\r\n </div>\r\n</form>\r\n\r\n<mrx-error-message\r\n *ngIf=\"invalid && isInvalidMessage\"\r\n customClasses=\"text-left\"\r\n [invalidMessage]=\"invalidMessage\"\r\n></mrx-error-message>\r\n", styles: [".mrx-input-otp{background:var(--brand-bg-tertiary-default, #FFF);color:var(--neutral-text-primary, #262626);text-align:center;outline:0}.mrx-input-otp-container{display:flex}.mrx-input-otp-box label{margin-bottom:0}.mrx-input-otp-disabled{opacity:.3}.mrx-input-otp-container.mrx-input-opt-lg{gap:12px}.mrx-input-otp-container.mrx-input-opt-lg .mrx-input-otp{width:var(--sizing-12);height:var(--sizing-12);border-radius:var(--border-radius-1);border:1px solid var(--neutral-bg-stroke-default, #DAD5CE);font-family:var(--headlines-lvl-3-font-family);font-weight:var(--headlines-lvl-3-font-weight);line-height:var(--headlines-lvl-3-line-height);font-size:var(--headlines-lvl-3-font-size)}.mrx-input-otp-container.mrx-input-opt-md{gap:10px}.mrx-input-otp-container.mrx-input-opt-md .mrx-input-otp{width:var(--sizing-10);height:var(--sizing-10);border-radius:var(--border-radius-1);border:1px solid var(--neutral-bg-stroke-default, #DAD5CE);font-family:var(--headlines-lvl-4-font-family);font-weight:var(--headlines-lvl-4-font-weight);line-height:var(--headlines-lvl-4-line-height);font-size:var(--headlines-lvl-4-font-size)}.mrx-input-otp-container.mrx-input-opt-responsive{flex-wrap:wrap;gap:12px}.mrx-input-otp-container.mrx-input-opt-responsive .mrx-input-otp{width:var(--sizing-12);height:var(--sizing-12);border-radius:var(--border-radius-1);border:1px solid var(--neutral-bg-stroke-default, #DAD5CE);font-family:var(--headlines-lvl-3-font-family);font-weight:var(--headlines-lvl-3-font-weight);line-height:var(--headlines-lvl-3-line-height);font-size:var(--headlines-lvl-3-font-size)}@media (max-width: 576px){.mrx-input-otp-container.mrx-input-opt-responsive{gap:10px}.mrx-input-otp-container.mrx-input-opt-responsive .mrx-input-otp{width:var(--sizing-10);height:var(--sizing-10);font-family:var(--headlines-lvl-4-font-family);font-weight:var(--headlines-lvl-4-font-weight);line-height:var(--headlines-lvl-4-line-height);font-size:var(--headlines-lvl-4-font-size)}}@media (max-width: 370px){.mrx-input-otp-container.mrx-input-opt-responsive{gap:8px}.mrx-input-otp-container.mrx-input-opt-responsive .mrx-input-otp{width:var(--sizing-8);height:var(--sizing-8);font-family:var(--headlines-lvl-5-font-family);font-weight:var(--headlines-lvl-5-font-weight);line-height:var(--headlines-lvl-5-line-height);font-size:var(--headlines-lvl-5-font-size)}}.mrx-input-otp-container .mrx-input-otp-box.mrx-input-error .mrx-input-otp{border-color:var(--system-bg-controls-negative-default)}.mrx-input-otp-container .mrx-input-otp-box.mrx-input-checked-error .mrx-input-otp{border-color:var(--system-bg-controls-negative-default);background-color:var(--system-bg-negative-secondary)}.mrx-input-otp-container .mrx-input-otp-box.mrx-input-checked-success .mrx-input-otp{background-color:var(--system-bg-positive-secondary);border-color:var(--system-bg-controls-positive-default)}\n"], dependencies: [{ kind: "directive", type: i2.ɵNgNoValidate, selector: "form:not([ngNoForm]):not([ngNativeValidate])" }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgControlStatusGroup, selector: "[formGroupName],[formArrayName],[ngModelGroup],[formGroup],form:not([ngNoForm]),[ngForm]" }, { kind: "directive", type: i2.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i2.NgForm, selector: "form:not([ngNoForm]):not([formGroup]),ng-form,[ngForm]", inputs: ["ngFormOptions"], outputs: ["ngSubmit"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i4.ErrorMessageComponent, selector: "mrx-error-message", inputs: ["invalid", "invalidMessage", "customClasses"] }, { kind: "directive", type: i5.OptPatternDirective, selector: "[mrxOptPattern]", inputs: ["mrxOptPattern"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
327
325
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImport: i0, type: InputOptComponent, decorators: [{
|
|
328
326
|
type: Component,
|
|
329
327
|
args: [{ selector: 'mrx-input-opt', changeDetection: ChangeDetectionStrategy.OnPush, providers: [
|
|
@@ -360,4 +358,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.3.0", ngImpor
|
|
|
360
358
|
type: HostListener,
|
|
361
359
|
args: ['paste', ['$event']]
|
|
362
360
|
}] } });
|
|
363
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-opt.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/myrta-ui/src/lib/components/form/input-opt/components/input-opt/input-opt.component.ts","../../../../../../../../../projects/myrta-ui/src/lib/components/form/input-opt/components/input-opt/input-opt.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy, ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter, forwardRef, HostListener, Input, OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  QueryList,\r\n  ViewChildren\r\n} from '@angular/core';\r\nimport { AbstractControl, FormArray, FormControl, NG_VALUE_ACCESSOR, Validators } from '@angular/forms';\r\nimport { NgxOtpBehavior, NgxOtpInputConfig, NgxOtpStatus } from '../../models/input-opt.model';\r\nimport { Subscription } from 'rxjs';\r\nimport { InputOptService } from '../../services/input-opt.service';\r\nimport { InputOptSizesEnum, InputOptSizesTypes } from './input-opt.enum';\r\nimport { InputTextValueTypes } from '../../../input-text/input-text.enum';\r\n\r\n@Component({\r\n  selector: 'mrx-input-opt',\r\n  templateUrl: './input-opt.component.html',\r\n  styleUrls: ['./input-opt.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => InputOptComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class InputOptComponent implements OnInit, AfterViewInit, OnDestroy {\r\n  private defaultPattern = /^.+$/;\r\n  private DEFAULT_ARIA_LABEL = 'One time password input';\r\n  private LAST_INPUT_INDEX!: number;\r\n  private inputs!: HTMLInputElement[];\r\n  private isNgxOtpArrayDisabled = false;\r\n  private ngxOtpArray$!: Subscription;\r\n  private focusedInputHasValue = false;\r\n  private isInit = false;\r\n\r\n  ngxOtpArray = new FormArray([]);\r\n  ariaLabels: string[] = [];\r\n  pattern!: RegExp;\r\n  styles: string[][] = [];\r\n\r\n  otpConfig: NgxOtpInputConfig = {\r\n    otpLength: 6,\r\n    autofocus: true,\r\n    autoblur: true,\r\n    behavior: NgxOtpBehavior.DEFAULT,\r\n    pattern: this.defaultPattern,\r\n    classList: {\r\n      container: '',\r\n      inputBox: '',\r\n      input: '',\r\n      inputFilled: '',\r\n      inputDisabled: '',\r\n      inputSuccess: '',\r\n      inputError: '',\r\n    }\r\n  };\r\n\r\n  @Input() public size: InputOptSizesTypes = 'large';\r\n  @Input() public customClasses = '';\r\n  @Input() public invalid = false;\r\n  @Input() public invalidMessage: string | string[] = '';\r\n  @Input() public checkInvalid: true | false | null = null;\r\n\r\n  @Input() set disable(isDisabled: boolean) {\r\n    this.handleDisable(isDisabled);\r\n    this.isNgxOtpArrayDisabled = isDisabled;\r\n  }\r\n\r\n  @Input() set config(c: NgxOtpInputConfig) {\r\n    this.otpConfig = {...this.otpConfig, ...c};\r\n    if (this.otpConfig.classList?.input) {\r\n      this.setInitialStyles();\r\n    }\r\n    if (!c.pattern) {\r\n      this.otpConfig.pattern = this.defaultPattern;\r\n    }\r\n  }\r\n\r\n  @Input() set status(status: NgxOtpStatus) {\r\n    this.handleStatusChange(status);\r\n  }\r\n\r\n  @ViewChildren('otpInputElement') otpInputElements!: QueryList<ElementRef>;\r\n\r\n  @Output() change: EventEmitter<string[]> = new EventEmitter<string[]>();\r\n  @Output() fillChange: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n  constructor(\r\n    private readonly otpService: InputOptService,\r\n    private readonly ref: ChangeDetectorRef\r\n  ) {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.setUpOtpForm();\r\n    this.setUpAriaLabels();\r\n    this.LAST_INPUT_INDEX = this.otpConfig.otpLength - 1;\r\n    this.otpFormChangeListener();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.setNativeHTMLElements();\r\n    this.setInitialFocus();\r\n    this.setNumericInputIfPossible();\r\n    this.handleDisable(this.isNgxOtpArrayDisabled);\r\n    this.isInit = true;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.ngxOtpArray$.unsubscribe();\r\n  }\r\n\r\n  public get isInvalidMessage(): boolean {\r\n    return !!this.invalidMessage || !!this.invalidMessage.length;\r\n  }\r\n\r\n  public get checkValidClasses(): string {\r\n    return this.checkInvalid === false ?\r\n      'mrx-input-checked-success' :\r\n      this.checkInvalid === true ? 'mrx-input-checked-error' : '';\r\n  }\r\n\r\n  get getClasses(): string {\r\n    return `${InputOptSizesEnum[this.size]} ${this.customClasses}`;\r\n  }\r\n\r\n  get getContainerClasses(): string | string[] {\r\n    return this.otpConfig?.classList?.container || ''\r\n  }\r\n\r\n  get getInputBoxClasses(): string | string[] {\r\n    return this.otpConfig?.classList?.inputBox || ''\r\n  }\r\n\r\n  convertToFormControl(absCtrl: AbstractControl | null): FormControl {\r\n    return absCtrl as FormControl;\r\n  }\r\n\r\n  clear(): void {\r\n    if (this.otpConfig.classList && this.otpConfig.classList.inputFilled) {\r\n      this.removeStyleFromAll(this.otpConfig.classList.inputFilled);\r\n    }\r\n\r\n    this.ngxOtpArray.reset();\r\n    this.ref.detectChanges();\r\n\r\n    if (this.otpConfig.autofocus) {\r\n      this.setFocus(0);\r\n    }\r\n  }\r\n\r\n  handleKeyUp(index: number, value: string): void {\r\n    // @ts-ignore\r\n    if (this.otpConfig.pattern.test(value) && value !== 'Backspace') {\r\n      if (this.otpConfig.classList && this.otpConfig.classList.inputFilled) {\r\n        this.addStyle(index, this.otpConfig.classList.inputFilled);\r\n      }\r\n      if (!this.ngxOtpArray.valid) {\r\n        this.getFormControlByIndex(index).setValue(value, {emitEvent: false});\r\n        this.stepForward(index);\r\n      } else {\r\n        this.blur();\r\n      }\r\n    }\r\n  }\r\n\r\n  handleDelete(index: number): void {\r\n    if (this.otpConfig.classList && this.otpConfig.classList.inputFilled) {\r\n      this.removeStyle(index, this.otpConfig.classList.inputFilled);\r\n    }\r\n\r\n    if (\r\n      (this.otpConfig.behavior === NgxOtpBehavior.LEGACY &&\r\n        !this.focusedInputHasValue) ||\r\n      this.otpConfig.behavior !== NgxOtpBehavior.LEGACY\r\n    ) {\r\n      this.stepBackward(index);\r\n    } else {\r\n      this.focusedInputHasValue = false;\r\n    }\r\n  }\r\n\r\n  handleFocus(index: number): void {\r\n    // @ts-ignore\r\n    this.focusedInputHasValue = !!this.ngxOtpArray.controls[index].value;\r\n    if (\r\n      this.otpConfig.behavior === NgxOtpBehavior.LEGACY &&\r\n      this.focusedInputHasValue\r\n    ) {\r\n      this.inputs[index].select();\r\n    }\r\n  }\r\n\r\n  stepBackward(index: number): void {\r\n    if (index > 0) {\r\n      this.setFocus(index - 1);\r\n    }\r\n  }\r\n\r\n  stepForward(index: number): void {\r\n    if (index < this.LAST_INPUT_INDEX) {\r\n      this.setFocus(index + 1);\r\n    }\r\n  }\r\n\r\n  private otpFormChangeListener(): void {\r\n    this.ngxOtpArray$ = this.ngxOtpArray.valueChanges.subscribe((values) => {\r\n      if (this.isInit) {\r\n        this.change.emit(values);\r\n\r\n        if (this.ngxOtpArray.valid) {\r\n          this.fillChange.emit(values.join(''));\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  private setUpOtpForm(): void {\r\n    for (let i = 0; i < this.otpConfig.otpLength; i++) {\r\n      // @ts-ignore\r\n      this.ngxOtpArray.push(new FormControl('', [Validators.required]));\r\n    }\r\n  }\r\n\r\n  private setUpAriaLabels(): void {\r\n    const labels = this.otpConfig.ariaLabels;\r\n\r\n    this.ariaLabels = Array.isArray(labels)\r\n      ? labels\r\n      : new Array(this.otpConfig.otpLength).fill(\r\n        labels || this.DEFAULT_ARIA_LABEL\r\n      );\r\n  }\r\n\r\n  private setNativeHTMLElements(): void {\r\n    this.inputs = this.otpInputElements.map((element) => element.nativeElement);\r\n  }\r\n\r\n  private setInitialFocus(): void {\r\n    if (this.otpConfig.autofocus) {\r\n      this.setFocus(0);\r\n    }\r\n  }\r\n\r\n  private setInitialStyles(): void {\r\n    this.styles = this.otpService.init2DArray(this.otpConfig.otpLength);\r\n\r\n    if (this.otpConfig.classList && this.otpConfig.classList.input) {\r\n      this.addStyleToAll(this.otpConfig.classList.input);\r\n    }\r\n  }\r\n\r\n  private setFocus(index: number): void {\r\n    this.inputs[index].focus();\r\n  }\r\n\r\n  private setNumericInputIfPossible(): void {\r\n    if (this.otpConfig.numericInputMode) {\r\n      this.otpConfig.pattern = this.defaultPattern;\r\n      this.inputs.map((element) => {\r\n        element.setAttribute('inputmode', 'numeric');\r\n        element.setAttribute('pattern', '[0-9]*');\r\n      });\r\n    }\r\n  }\r\n\r\n  private blur(): void {\r\n    if (this.otpConfig.autoblur) {\r\n      this.inputs.map((input) => input.blur());\r\n    }\r\n  }\r\n\r\n  private handlePaste(value: string): void {\r\n    // @ts-ignore\r\n    if (this.otpConfig.pattern.test(value)) {\r\n      let lastIndex = 0;\r\n      value\r\n        .split('')\r\n        .slice(0, this.otpConfig.otpLength)\r\n        .map((character: string, index: number) => {\r\n          if (this.otpConfig.classList && this.otpConfig.classList.inputFilled) {\r\n            this.addStyle(index, this.otpConfig.classList.inputFilled);\r\n          }\r\n          this.getFormControlByIndex(index).setValue(character);\r\n          lastIndex = index;\r\n        });\r\n\r\n      if (this.ngxOtpArray.valid) {\r\n        this.blur();\r\n      } else {\r\n        this.setFocus(lastIndex + 1);\r\n      }\r\n    }\r\n  }\r\n\r\n  private handleDisable(isDisabled: boolean): void {\r\n    if (isDisabled) {\r\n      this.ngxOtpArray.disable();\r\n      if (this.otpConfig.classList && this.otpConfig.classList.inputDisabled) {\r\n        this.addStyleToAll(this.otpConfig.classList.inputDisabled);\r\n      }\r\n    } else {\r\n      this.ngxOtpArray.enable();\r\n      if (this.otpConfig.classList && this.otpConfig.classList.inputDisabled) {\r\n        this.removeStyleFromAll(this.otpConfig.classList.inputDisabled);\r\n      }\r\n    }\r\n  }\r\n\r\n  private handleStatusChange(status: NgxOtpStatus): void {\r\n    if (this.otpConfig.classList && (this.otpConfig.classList.inputSuccess && this.otpConfig.classList.inputError)) {\r\n      this.removeStyleFromAll([\r\n        ...this.otpService.toArray(\r\n          this.otpConfig.classList.inputSuccess\r\n        ),\r\n        ...this.otpService.toArray(this.otpConfig.classList.inputError),\r\n      ]);\r\n    }\r\n\r\n    if (status) {\r\n      if (status === 'success') {\r\n        if (this.otpConfig.classList && this.otpConfig.classList.inputSuccess) {\r\n          this.addStyleToAll(this.otpConfig.classList.inputSuccess);\r\n        }\r\n      } else if (status === 'error') {\r\n        if (this.otpConfig.classList && this.otpConfig.classList.inputError) {\r\n          this.addStyleToAll(this.otpConfig.classList.inputError);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private getFormControlByIndex(index: number): FormControl {\r\n    return this.ngxOtpArray.controls[index] as FormControl;\r\n  }\r\n\r\n  private addStyle(index: number, styles: string | string[]): void {\r\n    this.styles = this.otpService.addItemAtIndex(\r\n      this.styles,\r\n      index,\r\n      this.otpService.toArray(styles)\r\n    );\r\n  }\r\n\r\n  private addStyleToAll(styles: string | string[]): void {\r\n    this.styles = this.otpService.addItemToAll(\r\n      this.styles,\r\n      this.otpService.toArray(styles)\r\n    );\r\n  }\r\n\r\n  private removeStyle(index: number, styles: string | string[]): void {\r\n    this.styles = this.otpService.removeItemAtIndex(\r\n      this.styles,\r\n      index,\r\n      this.otpService.toArray(styles)\r\n    );\r\n  }\r\n\r\n  private removeStyleFromAll(styles: string | string[]): void {\r\n    this.styles = this.otpService.removeItemFromAll(\r\n      this.styles,\r\n      this.otpService.toArray(styles)\r\n    );\r\n  }\r\n\r\n  private onChange = (value: InputTextValueTypes) => {\r\n  };\r\n  private onTouched = () => {\r\n  };\r\n\r\n  public registerOnChange(fn: any) {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: () => {}): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  public writeValue(outsideValue: InputTextValueTypes) {\r\n    if (outsideValue) {\r\n      let lastIndex = 0;\r\n      String(outsideValue)\r\n        .split('')\r\n        .slice(0, this.otpConfig.otpLength)\r\n        .map((character: string, index: number) => {\r\n          if (this.otpConfig.classList && this.otpConfig.classList.inputFilled) {\r\n            this.addStyle(index, this.otpConfig.classList.inputFilled);\r\n          }\r\n          this.getFormControlByIndex(index).setValue(character, {emitEvent: false});\r\n          lastIndex = index;\r\n        });\r\n\r\n      if (this.ngxOtpArray.valid) {\r\n        this.blur();\r\n      } else {\r\n        this.setFocus(lastIndex + 1);\r\n      }\r\n    }\r\n  }\r\n\r\n  @HostListener('paste', ['$event']) onPaste(event: ClipboardEvent): void {\r\n    event.preventDefault();\r\n    // @ts-ignore\r\n    this.handlePaste(event.clipboardData.getData('text'));\r\n  }\r\n\r\n  getInputType(): 'text' | 'password' | 'tel' {\r\n    return this.otpConfig.isPasswordInput ? 'password' : this.otpConfig.isNumberInput ? 'tel' : 'text';\r\n  }\r\n}\r\n","<form\r\n  [ngClass]=\"getContainerClasses\"\r\n  class=\"mrx-input-otp-container\"\r\n  [class]=\"getClasses\"\r\n>\r\n  <div\r\n    *ngFor=\"let control of ngxOtpArray.controls; let i = index\"\r\n    [ngClass]=\"getInputBoxClasses\"\r\n    [class.mrx-input-error]=\"invalid\"\r\n    [class]=\"checkValidClasses\"\r\n    class=\"mrx-input-otp-box\"\r\n  >\r\n    <label [attr.aria-label]=\"ariaLabels[i]\">\r\n      <input\r\n        #otpInputElement\r\n        [id]=\"'mrx-input-otp-' + i\"\r\n        [formControl]=\"convertToFormControl(control)\"\r\n        [mrxOptPattern]=\"otpConfig.pattern\"\r\n        [type]=\"getInputType()\"\r\n        [ngClass]=\"styles[i]\"\r\n        (keyup)=\"handleKeyUp(i, $event.key)\"\r\n        (keyup.backspace)=\"handleDelete(i)\"\r\n        (keyup.arrowLeft)=\"stepBackward(i)\"\r\n        (keyup.arrowRight)=\"stepForward(i)\"\r\n        (focus)=\"handleFocus(i)\"\r\n        class=\"mrx-input-otp\"\r\n        maxlength=\"1\"\r\n        autocapitalize=\"off\"\r\n        spellcheck=\"false\"\r\n      />\r\n    </label>\r\n  </div>\r\n</form>\r\n\r\n<mrx-error-message\r\n  *ngIf=\"invalid && isInvalidMessage\"\r\n  customClasses=\"text-left\"\r\n  [invalidMessage]=\"invalidMessage\"\r\n></mrx-error-message>\r\n"]}
|
|
361
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-opt.component.js","sourceRoot":"","sources":["../../../../../../../../../projects/myrta-ui/src/lib/components/form/input-opt/components/input-opt/input-opt.component.ts","../../../../../../../../../projects/myrta-ui/src/lib/components/form/input-opt/components/input-opt/input-opt.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectionStrategy, ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter, forwardRef, HostListener, Input, OnDestroy,\r\n  OnInit,\r\n  Output,\r\n  QueryList,\r\n  ViewChildren\r\n} from '@angular/core';\r\nimport { AbstractControl, FormArray, FormControl, NG_VALUE_ACCESSOR, Validators } from '@angular/forms';\r\nimport { NgxOtpBehavior, NgxOtpInputConfig, NgxOtpStatus } from '../../models/input-opt.model';\r\nimport { Subscription } from 'rxjs';\r\nimport { InputOptService } from '../../services/input-opt.service';\r\nimport { InputOptSizesEnum, InputOptSizesTypes } from './input-opt.enum';\r\nimport { InputTextValueTypes } from '../../../input-text/input-text.enum';\r\n\r\n@Component({\r\n  selector: 'mrx-input-opt',\r\n  templateUrl: './input-opt.component.html',\r\n  styleUrls: ['./input-opt.component.less'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => InputOptComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class InputOptComponent implements OnInit, AfterViewInit, OnDestroy {\r\n  private defaultPattern = /^.+$/;\r\n  private DEFAULT_ARIA_LABEL = 'One time password input';\r\n  private LAST_INPUT_INDEX!: number;\r\n  private inputs!: HTMLInputElement[];\r\n  private isNgxOtpArrayDisabled = false;\r\n  private ngxOtpArray$!: Subscription;\r\n  private focusedInputHasValue = false;\r\n  private isInit = false;\r\n\r\n  ngxOtpArray: any = new FormArray([]);\r\n  ariaLabels: string[] = [];\r\n  pattern!: RegExp;\r\n  styles: string[][] = [];\r\n\r\n  otpConfig: NgxOtpInputConfig = {\r\n    otpLength: 6,\r\n    autofocus: true,\r\n    autoblur: true,\r\n    behavior: NgxOtpBehavior.DEFAULT,\r\n    pattern: this.defaultPattern,\r\n    classList: {\r\n      container: '',\r\n      inputBox: '',\r\n      input: '',\r\n      inputFilled: '',\r\n      inputDisabled: '',\r\n      inputSuccess: '',\r\n      inputError: '',\r\n    }\r\n  };\r\n\r\n  @Input() public size: InputOptSizesTypes = 'large';\r\n  @Input() public customClasses = '';\r\n  @Input() public invalid = false;\r\n  @Input() public invalidMessage: string | string[] = '';\r\n  @Input() public checkInvalid: true | false | null = null;\r\n\r\n  @Input() set disable(isDisabled: boolean) {\r\n    this.handleDisable(isDisabled);\r\n    this.isNgxOtpArrayDisabled = isDisabled;\r\n  }\r\n\r\n  @Input() set config(c: NgxOtpInputConfig) {\r\n    this.otpConfig = {...this.otpConfig, ...c};\r\n    if (this.otpConfig.classList?.input) {\r\n      this.setInitialStyles();\r\n    }\r\n    if (!c.pattern) {\r\n      this.otpConfig.pattern = this.defaultPattern;\r\n    }\r\n  }\r\n\r\n  @Input() set status(status: NgxOtpStatus) {\r\n    this.handleStatusChange(status);\r\n  }\r\n\r\n  @ViewChildren('otpInputElement') otpInputElements!: QueryList<ElementRef>;\r\n\r\n  @Output() change: EventEmitter<string[]> = new EventEmitter<string[]>();\r\n  @Output() fillChange: EventEmitter<string> = new EventEmitter<string>();\r\n\r\n  constructor(\r\n    private readonly otpService: InputOptService,\r\n    private readonly ref: ChangeDetectorRef\r\n  ) {\r\n  }\r\n\r\n  ngOnInit(): void {\r\n    this.setUpOtpForm();\r\n    this.setUpAriaLabels();\r\n    this.LAST_INPUT_INDEX = this.otpConfig.otpLength - 1;\r\n    this.otpFormChangeListener();\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.setNativeHTMLElements();\r\n    this.setInitialFocus();\r\n    this.setNumericInputIfPossible();\r\n    this.handleDisable(this.isNgxOtpArrayDisabled);\r\n    this.isInit = true;\r\n  }\r\n\r\n  ngOnDestroy(): void {\r\n    this.ngxOtpArray$.unsubscribe();\r\n  }\r\n\r\n  public get isInvalidMessage(): boolean {\r\n    return !!this.invalidMessage || !!this.invalidMessage.length;\r\n  }\r\n\r\n  public get checkValidClasses(): string {\r\n    return this.checkInvalid === false ?\r\n      'mrx-input-checked-success' :\r\n      this.checkInvalid === true ? 'mrx-input-checked-error' : '';\r\n  }\r\n\r\n  get getClasses(): string {\r\n    return `${InputOptSizesEnum[this.size]} ${this.customClasses}`;\r\n  }\r\n\r\n  get getContainerClasses(): string | string[] {\r\n    return this.otpConfig?.classList?.container || ''\r\n  }\r\n\r\n  get getInputBoxClasses(): string | string[] {\r\n    return this.otpConfig?.classList?.inputBox || ''\r\n  }\r\n\r\n  convertToFormControl(absCtrl: AbstractControl | null): FormControl {\r\n    return absCtrl as FormControl;\r\n  }\r\n\r\n  clear(): void {\r\n    if (this.otpConfig.classList && this.otpConfig.classList.inputFilled) {\r\n      this.removeStyleFromAll(this.otpConfig.classList.inputFilled);\r\n    }\r\n\r\n    this.ngxOtpArray.reset();\r\n    this.ref.detectChanges();\r\n\r\n    if (this.otpConfig.autofocus) {\r\n      this.setFocus(0);\r\n    }\r\n  }\r\n\r\n  handleKeyUp(index: number, value: string): void {\r\n    // @ts-ignore\r\n    if (this.otpConfig.pattern.test(value) && value !== 'Backspace') {\r\n      if (this.otpConfig.classList && this.otpConfig.classList.inputFilled) {\r\n        this.addStyle(index, this.otpConfig.classList.inputFilled);\r\n      }\r\n      if (!this.ngxOtpArray.valid) {\r\n        this.getFormControlByIndex(index).setValue(value, {emitEvent: false});\r\n        this.stepForward(index);\r\n      } else {\r\n        this.blur();\r\n      }\r\n    }\r\n  }\r\n\r\n  handleDelete(index: number): void {\r\n    if (this.otpConfig.classList && this.otpConfig.classList.inputFilled) {\r\n      this.removeStyle(index, this.otpConfig.classList.inputFilled);\r\n    }\r\n\r\n    if (\r\n      (this.otpConfig.behavior === NgxOtpBehavior.LEGACY &&\r\n        !this.focusedInputHasValue) ||\r\n      this.otpConfig.behavior !== NgxOtpBehavior.LEGACY\r\n    ) {\r\n      this.stepBackward(index);\r\n    } else {\r\n      this.focusedInputHasValue = false;\r\n    }\r\n  }\r\n\r\n  handleFocus(index: number): void {\r\n    this.focusedInputHasValue = !!this.ngxOtpArray.controls[index].value;\r\n\r\n    if (\r\n      this.otpConfig.behavior === NgxOtpBehavior.LEGACY &&\r\n      this.focusedInputHasValue\r\n    ) {\r\n      this.inputs[index].select();\r\n    }\r\n  }\r\n\r\n  stepBackward(index: number): void {\r\n    if (index > 0) {\r\n      this.setFocus(index - 1);\r\n    }\r\n  }\r\n\r\n  stepForward(index: number): void {\r\n    if (index < this.LAST_INPUT_INDEX) {\r\n      this.setFocus(index + 1);\r\n    }\r\n  }\r\n\r\n  private otpFormChangeListener(): void {\r\n    this.ngxOtpArray$ = this.ngxOtpArray.valueChanges.subscribe((values: any) => {\r\n      if (this.isInit) {\r\n        this.change.emit(values);\r\n\r\n        if (this.ngxOtpArray.valid) {\r\n          this.fillChange.emit(values.join(''));\r\n        }\r\n      }\r\n    });\r\n  }\r\n\r\n  private setUpOtpForm(): void {\r\n    for (let i = 0; i < this.otpConfig.otpLength; i++) {\r\n      this.ngxOtpArray.push(new FormControl('', [Validators.required]));\r\n    }\r\n  }\r\n\r\n  private setUpAriaLabels(): void {\r\n    const labels = this.otpConfig.ariaLabels;\r\n\r\n    this.ariaLabels = Array.isArray(labels)\r\n      ? labels\r\n      : new Array(this.otpConfig.otpLength).fill(\r\n        labels || this.DEFAULT_ARIA_LABEL\r\n      );\r\n  }\r\n\r\n  private setNativeHTMLElements(): void {\r\n    this.inputs = this.otpInputElements.map((element) => element.nativeElement);\r\n  }\r\n\r\n  private setInitialFocus(): void {\r\n    if (this.otpConfig.autofocus) {\r\n      this.setFocus(0);\r\n    }\r\n  }\r\n\r\n  private setInitialStyles(): void {\r\n    this.styles = this.otpService.init2DArray(this.otpConfig.otpLength);\r\n\r\n    if (this.otpConfig.classList && this.otpConfig.classList.input) {\r\n      this.addStyleToAll(this.otpConfig.classList.input);\r\n    }\r\n  }\r\n\r\n  private setFocus(index: number): void {\r\n    this.inputs[index].focus();\r\n  }\r\n\r\n  private setNumericInputIfPossible(): void {\r\n    if (this.otpConfig.numericInputMode) {\r\n      this.otpConfig.pattern = this.defaultPattern;\r\n      this.inputs.map((element) => {\r\n        element.setAttribute('inputmode', 'numeric');\r\n        element.setAttribute('pattern', '[0-9]*');\r\n      });\r\n    }\r\n  }\r\n\r\n  private blur(): void {\r\n    if (this.otpConfig.autoblur) {\r\n      this.inputs.map((input) => input.blur());\r\n    }\r\n  }\r\n\r\n  private handlePaste(value: string): void {\r\n    // @ts-ignore\r\n    if (this.otpConfig.pattern.test(value)) {\r\n      let lastIndex = 0;\r\n      value\r\n        .split('')\r\n        .slice(0, this.otpConfig.otpLength)\r\n        .map((character: string, index: number) => {\r\n          if (this.otpConfig.classList && this.otpConfig.classList.inputFilled) {\r\n            this.addStyle(index, this.otpConfig.classList.inputFilled);\r\n          }\r\n          this.getFormControlByIndex(index).setValue(character);\r\n          lastIndex = index;\r\n        });\r\n\r\n      if (this.ngxOtpArray.valid) {\r\n        this.blur();\r\n      } else {\r\n        this.setFocus(lastIndex + 1);\r\n      }\r\n    }\r\n  }\r\n\r\n  private handleDisable(isDisabled: boolean): void {\r\n    if (isDisabled) {\r\n      this.ngxOtpArray.disable();\r\n      if (this.otpConfig.classList && this.otpConfig.classList.inputDisabled) {\r\n        this.addStyleToAll(this.otpConfig.classList.inputDisabled);\r\n      }\r\n    } else {\r\n      this.ngxOtpArray.enable();\r\n      if (this.otpConfig.classList && this.otpConfig.classList.inputDisabled) {\r\n        this.removeStyleFromAll(this.otpConfig.classList.inputDisabled);\r\n      }\r\n    }\r\n  }\r\n\r\n  private handleStatusChange(status: NgxOtpStatus): void {\r\n    if (this.otpConfig.classList && (this.otpConfig.classList.inputSuccess && this.otpConfig.classList.inputError)) {\r\n      this.removeStyleFromAll([\r\n        ...this.otpService.toArray(\r\n          this.otpConfig.classList.inputSuccess\r\n        ),\r\n        ...this.otpService.toArray(this.otpConfig.classList.inputError),\r\n      ]);\r\n    }\r\n\r\n    if (status) {\r\n      if (status === 'success') {\r\n        if (this.otpConfig.classList && this.otpConfig.classList.inputSuccess) {\r\n          this.addStyleToAll(this.otpConfig.classList.inputSuccess);\r\n        }\r\n      } else if (status === 'error') {\r\n        if (this.otpConfig.classList && this.otpConfig.classList.inputError) {\r\n          this.addStyleToAll(this.otpConfig.classList.inputError);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private getFormControlByIndex(index: number): FormControl {\r\n    return this.ngxOtpArray.controls[index] as FormControl;\r\n  }\r\n\r\n  private addStyle(index: number, styles: string | string[]): void {\r\n    this.styles = this.otpService.addItemAtIndex(\r\n      this.styles,\r\n      index,\r\n      this.otpService.toArray(styles)\r\n    );\r\n  }\r\n\r\n  private addStyleToAll(styles: string | string[]): void {\r\n    this.styles = this.otpService.addItemToAll(\r\n      this.styles,\r\n      this.otpService.toArray(styles)\r\n    );\r\n  }\r\n\r\n  private removeStyle(index: number, styles: string | string[]): void {\r\n    this.styles = this.otpService.removeItemAtIndex(\r\n      this.styles,\r\n      index,\r\n      this.otpService.toArray(styles)\r\n    );\r\n  }\r\n\r\n  private removeStyleFromAll(styles: string | string[]): void {\r\n    this.styles = this.otpService.removeItemFromAll(\r\n      this.styles,\r\n      this.otpService.toArray(styles)\r\n    );\r\n  }\r\n\r\n  private onChange = (value: InputTextValueTypes) => {\r\n  };\r\n  private onTouched = () => {\r\n  };\r\n\r\n  public registerOnChange(fn: any) {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  public registerOnTouched(fn: () => {}): void {\r\n    this.onTouched = fn;\r\n  }\r\n\r\n  public writeValue(outsideValue: InputTextValueTypes) {\r\n    if (outsideValue) {\r\n      let lastIndex = 0;\r\n      String(outsideValue)\r\n        .split('')\r\n        .slice(0, this.otpConfig.otpLength)\r\n        .map((character: string, index: number) => {\r\n          if (this.otpConfig.classList && this.otpConfig.classList.inputFilled) {\r\n            this.addStyle(index, this.otpConfig.classList.inputFilled);\r\n          }\r\n          this.getFormControlByIndex(index).setValue(character, {emitEvent: false});\r\n          lastIndex = index;\r\n        });\r\n\r\n      if (this.ngxOtpArray.valid) {\r\n        this.blur();\r\n      } else {\r\n        this.setFocus(lastIndex + 1);\r\n      }\r\n    }\r\n  }\r\n\r\n  @HostListener('paste', ['$event']) onPaste(event: ClipboardEvent): void {\r\n    event.preventDefault();\r\n    // @ts-ignore\r\n    this.handlePaste(event.clipboardData.getData('text'));\r\n  }\r\n\r\n  getInputType(): 'text' | 'password' | 'tel' {\r\n    return this.otpConfig.isPasswordInput ? 'password' : this.otpConfig.isNumberInput ? 'tel' : 'text';\r\n  }\r\n}\r\n","<form\r\n  [ngClass]=\"getContainerClasses\"\r\n  class=\"mrx-input-otp-container\"\r\n  [class]=\"getClasses\"\r\n>\r\n  <div\r\n    *ngFor=\"let control of ngxOtpArray.controls; let i = index\"\r\n    [ngClass]=\"getInputBoxClasses\"\r\n    [class.mrx-input-error]=\"invalid\"\r\n    [class]=\"checkValidClasses\"\r\n    class=\"mrx-input-otp-box\"\r\n  >\r\n    <label [attr.aria-label]=\"ariaLabels[i]\">\r\n      <input\r\n        #otpInputElement\r\n        [id]=\"'mrx-input-otp-' + i\"\r\n        [formControl]=\"convertToFormControl(control)\"\r\n        [mrxOptPattern]=\"otpConfig.pattern\"\r\n        [type]=\"getInputType()\"\r\n        [ngClass]=\"styles[i]\"\r\n        (keyup)=\"handleKeyUp(i, $event.key)\"\r\n        (keyup.backspace)=\"handleDelete(i)\"\r\n        (keyup.arrowLeft)=\"stepBackward(i)\"\r\n        (keyup.arrowRight)=\"stepForward(i)\"\r\n        (focus)=\"handleFocus(i)\"\r\n        class=\"mrx-input-otp\"\r\n        maxlength=\"1\"\r\n        autocapitalize=\"off\"\r\n        spellcheck=\"false\"\r\n      />\r\n    </label>\r\n  </div>\r\n</form>\r\n\r\n<mrx-error-message\r\n  *ngIf=\"invalid && isInvalidMessage\"\r\n  customClasses=\"text-left\"\r\n  [invalidMessage]=\"invalidMessage\"\r\n></mrx-error-message>\r\n"]}
|