@ptsecurity/mosaic 16.0.0 → 16.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/_theming.scss +9 -1
- package/_visual.scss +1 -1
- package/code-block/_code-block-theme.scss +8 -0
- package/core/locales/en-US.d.ts +7 -0
- package/core/locales/es-LA.d.ts +6 -0
- package/core/locales/fa-IR.d.ts +6 -0
- package/core/locales/locale-service.d.ts +39 -0
- package/core/locales/pt-BR.d.ts +6 -0
- package/core/locales/ru-RU.d.ts +8 -0
- package/core/locales/zh-CN.d.ts +6 -0
- package/core/pop-up/constants.d.ts +2 -1
- package/dropdown/dropdown.scss +6 -6
- package/esm2022/core/locales/en-US.mjs +9 -2
- package/esm2022/core/locales/es-LA.mjs +9 -1
- package/esm2022/core/locales/fa-IR.mjs +7 -1
- package/esm2022/core/locales/pt-BR.mjs +7 -1
- package/esm2022/core/locales/ru-RU.mjs +12 -2
- package/esm2022/core/locales/zh-CN.mjs +7 -1
- package/esm2022/core/option/option.mjs +2 -1
- package/esm2022/core/pop-up/constants.mjs +2 -1
- package/esm2022/core/pop-up/pop-up-trigger.mjs +11 -2
- package/esm2022/core/version.mjs +2 -2
- package/esm2022/datepicker/datepicker-input.directive.mjs +9 -1
- package/esm2022/dropdown/dropdown.component.mjs +3 -3
- package/esm2022/form-field/form-field.mjs +3 -3
- package/esm2022/form-field/password-hint.mjs +8 -5
- package/esm2022/input/input-number.mjs +260 -42
- package/esm2022/loader-overlay/loader-overlay.component.mjs +2 -2
- package/esm2022/modal/modal.component.mjs +7 -4
- package/esm2022/modal/modal.service.mjs +2 -2
- package/esm2022/navbar/navbar.component.mjs +2 -2
- package/esm2022/navbar/vertical-navbar.component.mjs +3 -3
- package/esm2022/popover/popover.component.mjs +3 -3
- package/esm2022/select/select.component.mjs +4 -4
- package/esm2022/timezone/timezone-select.component.mjs +3 -3
- package/esm2022/tree-select/tree-select.component.mjs +3 -3
- package/fesm2022/ptsecurity-mosaic-core.mjs +57 -3
- package/fesm2022/ptsecurity-mosaic-core.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-datepicker.mjs +8 -0
- package/fesm2022/ptsecurity-mosaic-datepicker.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-dropdown.mjs +2 -2
- package/fesm2022/ptsecurity-mosaic-dropdown.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-form-field.mjs +9 -6
- package/fesm2022/ptsecurity-mosaic-form-field.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-input.mjs +258 -42
- package/fesm2022/ptsecurity-mosaic-input.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-loader-overlay.mjs +2 -2
- package/fesm2022/ptsecurity-mosaic-loader-overlay.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-modal.mjs +7 -4
- package/fesm2022/ptsecurity-mosaic-modal.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-navbar.mjs +4 -4
- package/fesm2022/ptsecurity-mosaic-navbar.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-popover.mjs +2 -2
- package/fesm2022/ptsecurity-mosaic-popover.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-select.mjs +3 -3
- package/fesm2022/ptsecurity-mosaic-select.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-timezone.mjs +2 -2
- package/fesm2022/ptsecurity-mosaic-timezone.mjs.map +1 -1
- package/fesm2022/ptsecurity-mosaic-tree-select.mjs +2 -2
- package/fesm2022/ptsecurity-mosaic-tree-select.mjs.map +1 -1
- package/form-field/password-hint.d.ts +2 -1
- package/input/input-number.d.ts +61 -10
- package/loader-overlay/loader-overlay.scss +9 -2
- package/modal/modal.component.d.ts +1 -0
- package/navbar/navbar-item.scss +5 -0
- package/package.json +19 -18
- package/prebuilt-themes/dark-theme.css +1 -1
- package/prebuilt-themes/default-theme.css +1 -1
@@ -1,11 +1,14 @@
|
|
1
|
-
import {
|
2
|
-
import {
|
3
|
-
import {
|
4
|
-
import {
|
1
|
+
import { coerceBooleanProperty } from '@angular/cdk/coercion';
|
2
|
+
import { Attribute, Directive, ElementRef, EventEmitter, forwardRef, Inject, Input, Optional, Renderer2 } from '@angular/core';
|
3
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
4
|
+
import { END, C, V, X, A, Z, DELETE, BACKSPACE, TAB, ENTER, ESCAPE, NUMPAD_MINUS, DASH, FF_MINUS, LEFT_ARROW, RIGHT_ARROW, HOME, UP_ARROW, DOWN_ARROW, isFunctionKey, isNumberKey, isNumpadKey } from '@ptsecurity/cdk/keycodes';
|
5
|
+
import { MC_LOCALE_SERVICE, McLocaleService } from '@ptsecurity/mosaic/core';
|
6
|
+
import { Subject, Subscription } from 'rxjs';
|
5
7
|
import * as i0 from "@angular/core";
|
6
|
-
import * as i1 from "@
|
8
|
+
import * as i1 from "@ptsecurity/mosaic/core";
|
7
9
|
export const BIG_STEP = 10;
|
8
10
|
export const SMALL_STEP = 1;
|
11
|
+
// TODO: подставлять локализованный сплиттер
|
9
12
|
export function normalizeSplitter(value) {
|
10
13
|
return value ? value.replace(/,/g, '.') : value;
|
11
14
|
}
|
@@ -29,20 +32,78 @@ export function add(value1, value2) {
|
|
29
32
|
const precision = Math.max(getPrecision(value1), getPrecision(value2));
|
30
33
|
return (value1 * precision + value2 * precision) / precision;
|
31
34
|
}
|
35
|
+
export const MC_NUMBER_INPUT_VALUE_ACCESSOR = {
|
36
|
+
provide: NG_VALUE_ACCESSOR,
|
37
|
+
useExisting: forwardRef(() => McNumberInput),
|
38
|
+
multi: true
|
39
|
+
};
|
32
40
|
export class McNumberInput {
|
41
|
+
get value() {
|
42
|
+
return this._value;
|
43
|
+
}
|
44
|
+
set value(value) {
|
45
|
+
const oldValue = this.value;
|
46
|
+
this._value = value;
|
47
|
+
if (oldValue !== value) {
|
48
|
+
this.setViewValue(this.formatNumber(value));
|
49
|
+
this.valueChange.emit(value);
|
50
|
+
}
|
51
|
+
}
|
52
|
+
get disabled() {
|
53
|
+
return this._disabled;
|
54
|
+
}
|
55
|
+
set disabled(value) {
|
56
|
+
const newValue = coerceBooleanProperty(value);
|
57
|
+
const element = this.nativeElement;
|
58
|
+
if (this._disabled !== newValue) {
|
59
|
+
this._disabled = newValue;
|
60
|
+
this.disabledChange.emit(newValue);
|
61
|
+
}
|
62
|
+
// We need to null check the `blur` method, because it's undefined during SSR.
|
63
|
+
if (newValue && element.blur) {
|
64
|
+
// Normally, native input elements automatically blur if they turn disabled. This behavior
|
65
|
+
// is problematic, because it would mean that it triggers another change detection cycle,
|
66
|
+
// which then causes a changed after checked error if the input element was focused before.
|
67
|
+
element.blur();
|
68
|
+
}
|
69
|
+
}
|
33
70
|
get nativeElement() {
|
34
71
|
return this.elementRef.nativeElement;
|
35
72
|
}
|
36
|
-
|
73
|
+
get viewValue() {
|
74
|
+
return this.nativeElement.value;
|
75
|
+
}
|
76
|
+
get ngControl() {
|
77
|
+
return this.control;
|
78
|
+
}
|
79
|
+
constructor(elementRef, renderer, step, bigStep, min, max, localeService) {
|
37
80
|
this.elementRef = elementRef;
|
38
|
-
this.
|
39
|
-
this.
|
81
|
+
this.renderer = renderer;
|
82
|
+
this.localeService = localeService;
|
83
|
+
/** Emits when the value changes (either due to user input or programmatic change). */
|
84
|
+
this.valueChange = new EventEmitter();
|
85
|
+
/** Emits when the disabled state has changed */
|
86
|
+
this.disabledChange = new EventEmitter();
|
40
87
|
this.stateChanges = new Subject();
|
88
|
+
this.withThousandSeparator = true;
|
89
|
+
this._disabled = false;
|
90
|
+
this.focused = false;
|
91
|
+
this.localeSubscription = Subscription.EMPTY;
|
92
|
+
// tslint:disable-next-line:no-empty
|
93
|
+
this.onTouched = () => { };
|
94
|
+
// tslint:disable-next-line:no-empty
|
95
|
+
this.cvaOnChange = () => { };
|
96
|
+
this.updateLocaleParams = (id) => {
|
97
|
+
this.numberLocaleConfig = this.localeService.locales[id].input.number;
|
98
|
+
this.setViewValue(this.formatNumber(this.value));
|
99
|
+
};
|
41
100
|
this.step = isDigit(step) ? parseFloat(step) : SMALL_STEP;
|
42
101
|
this.bigStep = isDigit(bigStep) ? parseFloat(bigStep) : BIG_STEP;
|
43
102
|
this.min = isDigit(min) ? parseFloat(min) : -Infinity;
|
44
103
|
this.max = isDigit(max) ? parseFloat(max) : Infinity;
|
104
|
+
setTimeout(() => this.nativeElement.type = 'text', 0);
|
45
105
|
if ('valueAsNumber' in this.nativeElement) {
|
106
|
+
/* переделать алгоритм */
|
46
107
|
Object.defineProperty(Object.getPrototypeOf(this.nativeElement), 'valueAsNumber', {
|
47
108
|
// tslint:disable-next-line:no-reserved-keywords
|
48
109
|
get() {
|
@@ -51,6 +112,38 @@ export class McNumberInput {
|
|
51
112
|
}
|
52
113
|
});
|
53
114
|
}
|
115
|
+
this.allNumberLocaleConfigs = this.localeService.locales.items
|
116
|
+
.map((localeItem) => {
|
117
|
+
return { id: localeItem.id, config: this.localeService.locales[localeItem.id].input.number };
|
118
|
+
});
|
119
|
+
this.localeSubscription = this.localeService.changes.subscribe(this.updateLocaleParams);
|
120
|
+
}
|
121
|
+
ngOnDestroy() {
|
122
|
+
this.localeSubscription.unsubscribe();
|
123
|
+
this.valueChange.complete();
|
124
|
+
this.disabledChange.complete();
|
125
|
+
}
|
126
|
+
onContainerClick() {
|
127
|
+
this.focus();
|
128
|
+
}
|
129
|
+
focus() {
|
130
|
+
this.nativeElement.focus();
|
131
|
+
}
|
132
|
+
// Implemented as part of ControlValueAccessor.
|
133
|
+
writeValue(value) {
|
134
|
+
this.value = value;
|
135
|
+
}
|
136
|
+
// Implemented as part of ControlValueAccessor.
|
137
|
+
registerOnChange(fn) {
|
138
|
+
this.cvaOnChange = fn;
|
139
|
+
}
|
140
|
+
// Implemented as part of ControlValueAccessor.
|
141
|
+
registerOnTouched(fn) {
|
142
|
+
this.onTouched = fn;
|
143
|
+
}
|
144
|
+
// Implemented as part of ControlValueAccessor.
|
145
|
+
setDisabledState(isDisabled) {
|
146
|
+
this.disabled = isDisabled;
|
54
147
|
}
|
55
148
|
focusChanged(isFocused) {
|
56
149
|
if (isFocused !== this.focused) {
|
@@ -66,32 +159,39 @@ export class McNumberInput {
|
|
66
159
|
const isCtrlV = (e) => e.keyCode === V && (e.ctrlKey || e.metaKey);
|
67
160
|
const isCtrlX = (e) => e.keyCode === X && (e.ctrlKey || e.metaKey);
|
68
161
|
const isCtrlZ = (e) => e.keyCode === Z && (e.ctrlKey || e.metaKey);
|
69
|
-
const
|
70
|
-
|
71
|
-
(e.keyCode >= NUMPAD_ZERO && e.keyCode <= NUMPAD_NINE);
|
72
|
-
const isPeriod = (e) => e.key === '.' || e.key === ',';
|
162
|
+
const isPeriod = (e) => this.numberLocaleConfig.groupSeparator.includes(e.key)
|
163
|
+
|| [this.numberLocaleConfig.fractionSeparator, '.'].includes(e.key);
|
73
164
|
const minuses = [NUMPAD_MINUS, DASH, FF_MINUS];
|
74
165
|
const serviceKeys = [DELETE, BACKSPACE, TAB, ESCAPE, ENTER];
|
75
166
|
const arrows = [LEFT_ARROW, RIGHT_ARROW];
|
76
167
|
const allowedKeys = [HOME, END].concat(arrows).concat(serviceKeys).concat(minuses);
|
77
168
|
if (minuses.includes(keyCode) &&
|
78
|
-
(this.
|
169
|
+
(this.viewValue.includes(event.key) || this.min >= 0)) {
|
79
170
|
event.preventDefault();
|
80
171
|
return;
|
81
172
|
}
|
173
|
+
if (isPeriod(event)) {
|
174
|
+
if (event.key === this.numberLocaleConfig.fractionSeparator &&
|
175
|
+
this.viewValue.indexOf(this.numberLocaleConfig.fractionSeparator) !== -1) {
|
176
|
+
event.preventDefault();
|
177
|
+
return;
|
178
|
+
}
|
179
|
+
}
|
82
180
|
if (allowedKeys.indexOf(keyCode) !== -1 ||
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
181
|
+
[
|
182
|
+
isCtrlA,
|
183
|
+
isCtrlC,
|
184
|
+
isCtrlV,
|
185
|
+
isCtrlX,
|
186
|
+
isCtrlZ,
|
187
|
+
isFunctionKey,
|
188
|
+
isPeriod
|
189
|
+
].some((fn) => fn(event))) {
|
90
190
|
// let it happen, don't do anything
|
91
191
|
return;
|
92
192
|
}
|
93
193
|
// Ensure that it is not a number and stop the keypress
|
94
|
-
if (event.shiftKey || !
|
194
|
+
if (event.shiftKey || !isNumberKey(event) && !isNumpadKey(event)) {
|
95
195
|
event.preventDefault();
|
96
196
|
// process steps
|
97
197
|
const step = event.shiftKey ? this.bigStep : this.step;
|
@@ -103,48 +203,153 @@ export class McNumberInput {
|
|
103
203
|
}
|
104
204
|
}
|
105
205
|
}
|
206
|
+
onInput(event) {
|
207
|
+
const currentValueLength = this.formatNumber(this.value)?.length || 0;
|
208
|
+
setTimeout(() => {
|
209
|
+
const fromPaste = event.inputType === 'insertFromPaste';
|
210
|
+
let formattedValue;
|
211
|
+
if (fromPaste) {
|
212
|
+
formattedValue = this.formatNumber(this.valueFromPaste);
|
213
|
+
}
|
214
|
+
else {
|
215
|
+
/*this.viewValue is raw and should be reformatted to localized number */
|
216
|
+
formattedValue = this.formatViewValue();
|
217
|
+
const offsetWhenSeparatorAdded = 2;
|
218
|
+
Promise.resolve().then(() => {
|
219
|
+
if (Math.abs(this.viewValue.length - currentValueLength) === offsetWhenSeparatorAdded) {
|
220
|
+
const cursorPosition = Math.max(0, (this.nativeElement.selectionStart || 0) + Math.sign(this.viewValue.length - currentValueLength));
|
221
|
+
this.renderer.setProperty(this.nativeElement, 'selectionStart', cursorPosition);
|
222
|
+
this.renderer.setProperty(this.nativeElement, 'selectionEnd', cursorPosition);
|
223
|
+
}
|
224
|
+
});
|
225
|
+
}
|
226
|
+
this.setViewValue(formattedValue, !fromPaste);
|
227
|
+
this.viewToModelUpdate(formattedValue);
|
228
|
+
});
|
229
|
+
}
|
106
230
|
onPaste(event) {
|
107
|
-
|
231
|
+
this.valueFromPaste = this.checkAndNormalizeLocalizedNumber(event.clipboardData?.getData('text'));
|
232
|
+
if (this.valueFromPaste === null) {
|
108
233
|
event.preventDefault();
|
109
234
|
}
|
110
235
|
}
|
111
236
|
stepUp(step) {
|
112
|
-
this.
|
113
|
-
const res = Math.max(Math.min(add(this.
|
114
|
-
this.
|
115
|
-
this.
|
237
|
+
this.nativeElement.focus();
|
238
|
+
const res = Math.max(Math.min(add(this.value || 0, step), this.max), this.min);
|
239
|
+
this.setViewValue(this.formatNumber(res));
|
240
|
+
this._value = res;
|
241
|
+
this.cvaOnChange(res);
|
242
|
+
this.valueChange.emit(res);
|
116
243
|
}
|
117
244
|
stepDown(step) {
|
118
|
-
this.
|
119
|
-
const res = Math.min(Math.max(add(this.
|
120
|
-
this.
|
121
|
-
this.
|
245
|
+
this.nativeElement.focus();
|
246
|
+
const res = Math.min(Math.max(add(this.value || 0, -step), this.min), this.max);
|
247
|
+
this.setViewValue(this.formatNumber(res));
|
248
|
+
this._value = res;
|
249
|
+
this.cvaOnChange(res);
|
250
|
+
this.valueChange.emit(res);
|
122
251
|
}
|
123
|
-
|
124
|
-
|
125
|
-
|
252
|
+
setViewValue(value, savePosition = false) {
|
253
|
+
const cursorPosition = this.nativeElement.selectionStart;
|
254
|
+
this.renderer.setProperty(this.nativeElement, 'value', value);
|
255
|
+
if (savePosition) {
|
256
|
+
this.renderer.setProperty(this.nativeElement, 'selectionStart', cursorPosition);
|
257
|
+
this.renderer.setProperty(this.nativeElement, 'selectionEnd', cursorPosition);
|
126
258
|
}
|
127
259
|
}
|
128
|
-
|
129
|
-
|
260
|
+
viewToModelUpdate(newValue) {
|
261
|
+
const normalizedValue = newValue === null ? null : +this.normalizeNumber(newValue);
|
262
|
+
if (normalizedValue !== this.value) {
|
263
|
+
this._value = normalizedValue;
|
264
|
+
this.cvaOnChange(normalizedValue);
|
265
|
+
this.valueChange.emit(normalizedValue);
|
266
|
+
}
|
267
|
+
this.ngControl?.updateValueAndValidity({ emitEvent: false });
|
268
|
+
}
|
269
|
+
formatViewValue() {
|
270
|
+
if (this.viewValue === null || this.viewValue === '' || Number.isNaN(+this.normalizeNumber(this.viewValue))) {
|
271
|
+
return null;
|
272
|
+
}
|
273
|
+
const separator = this.numberLocaleConfig.groupSeparator.includes(' ')
|
274
|
+
&& this.numberLocaleConfig.fractionSeparator === ','
|
275
|
+
? /[,.]/
|
276
|
+
: this.numberLocaleConfig.fractionSeparator;
|
277
|
+
const [intPart, fractionPart] = this.viewValue.split(separator)
|
278
|
+
.map((valuePart) => this.normalizeNumber(valuePart));
|
279
|
+
return this.createLocalizedNumberFromParts(+intPart, fractionPart);
|
280
|
+
}
|
281
|
+
formatNumber(value) {
|
282
|
+
if (value === null || value === undefined) {
|
283
|
+
return null;
|
284
|
+
}
|
285
|
+
const [intPart, fractionPart] = value.toString().split('.');
|
286
|
+
return this.createLocalizedNumberFromParts(+intPart, fractionPart);
|
287
|
+
}
|
288
|
+
createLocalizedNumberFromParts(intPart, fractionPart) {
|
289
|
+
const formatOptions = {
|
290
|
+
useGrouping: this.withThousandSeparator,
|
291
|
+
maximumFractionDigits: 20
|
292
|
+
};
|
293
|
+
if (this.withThousandSeparator && this.numberLocaleConfig.startFormattingFrom) {
|
294
|
+
formatOptions.useGrouping = intPart >= Math.pow(
|
295
|
+
// tslint:disable-next-line:no-magic-numbers
|
296
|
+
10, this.numberLocaleConfig.startFormattingFrom);
|
297
|
+
}
|
298
|
+
const localeId = this.localeService.id === 'es-LA' ? 'ru-RU' : this.localeService.id;
|
299
|
+
const formatter = new Intl.NumberFormat(localeId, formatOptions);
|
300
|
+
const formattedFractionPart = fractionPart?.split('')
|
301
|
+
.map((numChar) => formatter.format(+numChar)).join('');
|
302
|
+
return formattedFractionPart === undefined
|
303
|
+
? formatter.format(intPart)
|
304
|
+
: `${formatter.format(intPart)}${this.numberLocaleConfig.fractionSeparator}${formattedFractionPart}`;
|
305
|
+
}
|
306
|
+
/**
|
307
|
+
* Method that returns a string representation of a number without localized separators
|
308
|
+
*/
|
309
|
+
normalizeNumber(value, customConfig) {
|
310
|
+
if (value === null || value === undefined) {
|
311
|
+
return '';
|
312
|
+
}
|
313
|
+
const { groupSeparator, fractionSeparator } = customConfig || this.numberLocaleConfig;
|
314
|
+
const groupSeparatorRegexp = new RegExp(`[${groupSeparator.join('')}]`, 'g');
|
315
|
+
const fractionSeparatorRegexp = new RegExp(`\\${fractionSeparator}`, 'g');
|
316
|
+
return value.toString()
|
317
|
+
.replace(groupSeparatorRegexp, '')
|
318
|
+
.replace(fractionSeparatorRegexp, '.');
|
319
|
+
}
|
320
|
+
checkAndNormalizeLocalizedNumber(num) {
|
321
|
+
if (num === null || num === undefined) {
|
322
|
+
return null;
|
323
|
+
}
|
324
|
+
/* if some locale input config satisfies pasted number, try to normalise with selected locale config */
|
325
|
+
let numberOutput = null;
|
326
|
+
for (const { config } of this.allNumberLocaleConfigs) {
|
327
|
+
const normalized = +this.normalizeNumber(num, config);
|
328
|
+
if (!Number.isNaN(normalized)) {
|
329
|
+
numberOutput = normalized;
|
330
|
+
break;
|
331
|
+
}
|
332
|
+
}
|
333
|
+
return numberOutput;
|
334
|
+
}
|
335
|
+
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.5", ngImport: i0, type: McNumberInput, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: 'step', attribute: true }, { token: 'big-step', attribute: true }, { token: 'min', attribute: true }, { token: 'max', attribute: true }, { token: MC_LOCALE_SERVICE, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
|
336
|
+
/** @nocollapse */ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.1.5", type: McNumberInput, selector: "input[mcInput][type=\"number\"]", inputs: { bigStep: "bigStep", step: "step", min: "min", max: "max", withThousandSeparator: "withThousandSeparator", startFormattingFrom: "startFormattingFrom", value: "value", disabled: "disabled" }, host: { listeners: { "blur": "focusChanged(false)", "focus": "focusChanged(true)", "paste": "onPaste($event)", "keydown": "onKeyDown($event)", "input": "onInput($event)" } }, providers: [MC_NUMBER_INPUT_VALUE_ACCESSOR], exportAs: ["mcNumericalInput"], ngImport: i0 }); }
|
130
337
|
}
|
131
338
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.5", ngImport: i0, type: McNumberInput, decorators: [{
|
132
339
|
type: Directive,
|
133
340
|
args: [{
|
134
341
|
selector: `input[mcInput][type="number"]`,
|
135
342
|
exportAs: 'mcNumericalInput',
|
343
|
+
providers: [MC_NUMBER_INPUT_VALUE_ACCESSOR],
|
136
344
|
host: {
|
137
345
|
'(blur)': 'focusChanged(false)',
|
138
346
|
'(focus)': 'focusChanged(true)',
|
139
347
|
'(paste)': 'onPaste($event)',
|
140
|
-
'(keydown)': 'onKeyDown($event)'
|
348
|
+
'(keydown)': 'onKeyDown($event)',
|
349
|
+
'(input)': 'onInput($event)'
|
141
350
|
}
|
142
351
|
}]
|
143
|
-
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type:
|
144
|
-
type: Optional
|
145
|
-
}, {
|
146
|
-
type: Self
|
147
|
-
}] }, { type: undefined, decorators: [{
|
352
|
+
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: undefined, decorators: [{
|
148
353
|
type: Attribute,
|
149
354
|
args: ['step']
|
150
355
|
}] }, { type: undefined, decorators: [{
|
@@ -156,6 +361,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.5", ngImpor
|
|
156
361
|
}] }, { type: undefined, decorators: [{
|
157
362
|
type: Attribute,
|
158
363
|
args: ['max']
|
364
|
+
}] }, { type: i1.McLocaleService, decorators: [{
|
365
|
+
type: Optional
|
366
|
+
}, {
|
367
|
+
type: Inject,
|
368
|
+
args: [MC_LOCALE_SERVICE]
|
159
369
|
}] }]; }, propDecorators: { bigStep: [{
|
160
370
|
type: Input
|
161
371
|
}], step: [{
|
@@ -164,5 +374,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.5", ngImpor
|
|
164
374
|
type: Input
|
165
375
|
}], max: [{
|
166
376
|
type: Input
|
377
|
+
}], withThousandSeparator: [{
|
378
|
+
type: Input
|
379
|
+
}], startFormattingFrom: [{
|
380
|
+
type: Input
|
381
|
+
}], value: [{
|
382
|
+
type: Input
|
383
|
+
}], disabled: [{
|
384
|
+
type: Input
|
167
385
|
}] } });
|
168
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-number.js","sourceRoot":"","sources":["../../../../packages/mosaic/input/input-number.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    Attribute,\n    Directive,\n    ElementRef,\n    Input,\n    Optional,\n    Self\n} from '@angular/core';\nimport { NgControl } from '@angular/forms';\nimport {\n    END, C, V, X, A, Z, DELETE, BACKSPACE, TAB, ENTER,\n    ESCAPE, ZERO, NINE, NUMPAD_ZERO, NUMPAD_NINE, NUMPAD_MINUS, DASH,\n    FF_MINUS, LEFT_ARROW, RIGHT_ARROW, HOME, UP_ARROW, DOWN_ARROW, F1, F12\n} from '@ptsecurity/cdk/keycodes';\nimport { Subject } from 'rxjs';\n\n\nexport const BIG_STEP = 10;\nexport const SMALL_STEP = 1;\n\nexport function normalizeSplitter(value: string): string {\n    return value ? value.replace(/,/g, '.') : value;\n}\n\nexport function isFloat(value: string): boolean {\n    return /^-?\\d+\\.\\d+$/.test(value);\n}\n\nexport function isInt(value: string): boolean {\n    return /^-?\\d+$/.test(value);\n}\n\nexport function isDigit(value: string): boolean {\n    return isFloat(value) || isInt(value);\n}\n\nexport function getPrecision(value: number): number {\n    const arr = value.toString().split('.');\n\n    return arr.length === 1\n        ? 1\n        // tslint:disable-next-line:no-magic-numbers\n        :  Math.pow(10, arr[1].length);\n}\n\nexport function add(value1: number, value2: number): number {\n    const precision = Math.max(getPrecision(value1), getPrecision(value2));\n\n    return (value1 * precision + value2 * precision) / precision;\n}\n\n\n@Directive({\n    selector: `input[mcInput][type=\"number\"]`,\n    exportAs: 'mcNumericalInput',\n    host: {\n        '(blur)': 'focusChanged(false)',\n        '(focus)': 'focusChanged(true)',\n        '(paste)': 'onPaste($event)',\n        '(keydown)': 'onKeyDown($event)'\n    }\n})\nexport class McNumberInput {\n    @Input()\n    bigStep: number;\n\n    @Input()\n    step: number;\n\n    @Input()\n    min: number;\n\n    @Input()\n    max: number;\n\n    value: any;\n\n    focused: boolean = false;\n\n    readonly stateChanges: Subject<void> = new Subject<void>();\n\n    get nativeElement(): HTMLInputElement {\n        return this.elementRef.nativeElement;\n    }\n\n    constructor(\n        private elementRef: ElementRef,\n        @Optional() @Self() private ngControl: NgControl,\n        @Attribute('step') step: string,\n        @Attribute('big-step') bigStep: string,\n        @Attribute('min') min: string,\n        @Attribute('max') max: string\n    ) {\n        this.step = isDigit(step) ? parseFloat(step) : SMALL_STEP;\n        this.bigStep = isDigit(bigStep) ? parseFloat(bigStep) : BIG_STEP;\n        this.min = isDigit(min) ? parseFloat(min) : -Infinity;\n        this.max = isDigit(max) ? parseFloat(max) : Infinity;\n\n        if ('valueAsNumber' in this.nativeElement) {\n            Object.defineProperty(Object.getPrototypeOf(this.nativeElement), 'valueAsNumber', {\n                // tslint:disable-next-line:no-reserved-keywords\n                get() {\n                    const res = parseFloat(normalizeSplitter(this.value));\n\n                    return isNaN(res) ? null : res;\n                }\n            });\n        }\n    }\n\n    focusChanged(isFocused: boolean) {\n        if (isFocused !== this.focused) {\n            this.focused = isFocused;\n            this.stateChanges.next();\n        }\n    }\n\n    onKeyDown(event: KeyboardEvent) {\n        // tslint:disable-next-line:deprecation\n        const keyCode = event.keyCode;\n\n        const isCtrlA = (e) => e.keyCode === A && (e.ctrlKey || e.metaKey);\n        const isCtrlC = (e) => e.keyCode === C && (e.ctrlKey || e.metaKey);\n        const isCtrlV = (e) => e.keyCode === V && (e.ctrlKey || e.metaKey);\n        const isCtrlX = (e) => e.keyCode === X && (e.ctrlKey || e.metaKey);\n        const isCtrlZ = (e) => e.keyCode === Z && (e.ctrlKey || e.metaKey);\n\n        const isFKey = (e) => e.keyCode >= F1 && e.keyCode <= F12;\n\n        const isNumber = (e) => (e.keyCode >= ZERO && e.keyCode <= NINE) ||\n            (e.keyCode >= NUMPAD_ZERO && e.keyCode <= NUMPAD_NINE);\n\n        const isPeriod = (e) => e.key === '.' || e.key === ',';\n\n        const minuses = [NUMPAD_MINUS, DASH, FF_MINUS];\n        const serviceKeys = [DELETE, BACKSPACE, TAB, ESCAPE, ENTER];\n        const arrows = [LEFT_ARROW, RIGHT_ARROW];\n        const allowedKeys =  [HOME, END].concat(arrows).concat(serviceKeys).concat(minuses);\n\n        if (\n            minuses.includes(keyCode) &&\n            (this.nativeElement.valueAsNumber || this.min >= 0 || this.nativeElement.validity?.badInput)\n        ) {\n            event.preventDefault();\n\n            return;\n        }\n\n        if (allowedKeys.indexOf(keyCode) !== -1 ||\n            isCtrlA(event) ||\n            isCtrlC(event) ||\n            isCtrlV(event) ||\n            isCtrlX(event) ||\n            isCtrlZ(event) ||\n            isFKey(event) ||\n            isPeriod(event)\n        ) {\n            // let it happen, don't do anything\n            return;\n        }\n        // Ensure that it is not a number and stop the keypress\n        if (event.shiftKey || !isNumber(event)) {\n            event.preventDefault();\n\n            // process steps\n            const step = event.shiftKey ? this.bigStep : this.step;\n\n            if (keyCode === UP_ARROW) {\n                this.stepUp(step);\n            }\n\n            if (keyCode === DOWN_ARROW) {\n                this.stepDown(step);\n            }\n        }\n    }\n\n    onPaste(event) {\n        if (!isDigit(normalizeSplitter(event.clipboardData.getData('text')))) {\n            event.preventDefault();\n        }\n    }\n\n    stepUp(step: number) {\n        this.elementRef.nativeElement.focus();\n\n        const res = Math.max(Math.min(add(this.nativeElement.valueAsNumber || 0, step), this.max), this.min);\n\n        this.nativeElement.value = res.toString();\n\n        this.viewToModelUpdate(this.nativeElement.valueAsNumber);\n    }\n\n    stepDown(step: number) {\n        this.elementRef.nativeElement.focus();\n\n        const res = Math.min(Math.max(add(this.nativeElement.valueAsNumber || 0, -step), this.min), this.max);\n\n        this.nativeElement.value = res.toString();\n\n        this.viewToModelUpdate(this.nativeElement.valueAsNumber);\n    }\n\n    private viewToModelUpdate(value: number) {\n        if (this.ngControl) {\n            this.ngControl.control!.setValue(value);\n        }\n    }\n}\n"]}
|
386
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-number.js","sourceRoot":"","sources":["../../../../packages/mosaic/input/input-number.ts"],"names":[],"mappings":"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","sourcesContent":["import { coerceBooleanProperty } from '@angular/cdk/coercion';\nimport {\n    Attribute,\n    Directive,\n    ElementRef, EventEmitter, forwardRef, Inject,\n    Input, OnDestroy, Optional,\n    Renderer2\n} from '@angular/core';\nimport { AbstractControl, ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport {\n    END, C, V, X, A, Z, DELETE, BACKSPACE, TAB, ENTER,\n    ESCAPE, NUMPAD_MINUS, DASH,\n    FF_MINUS, LEFT_ARROW, RIGHT_ARROW, HOME, UP_ARROW, DOWN_ARROW, isFunctionKey,\n    isNumberKey, isNumpadKey\n} from '@ptsecurity/cdk/keycodes';\nimport { MC_LOCALE_SERVICE, McLocaleService } from '@ptsecurity/mosaic/core';\nimport { McFormFieldControl } from '@ptsecurity/mosaic/form-field';\nimport { Subject, Subscription } from 'rxjs';\n\n\nexport const BIG_STEP = 10;\nexport const SMALL_STEP = 1;\n\n// TODO: подставлять локализованный сплиттер\nexport function normalizeSplitter(value: string): string {\n    return value ? value.replace(/,/g, '.') : value;\n}\n\nexport function isFloat(value: string): boolean {\n    return /^-?\\d+\\.\\d+$/.test(value);\n}\n\nexport function isInt(value: string): boolean {\n    return /^-?\\d+$/.test(value);\n}\n\nexport function isDigit(value: string): boolean {\n    return isFloat(value) || isInt(value);\n}\n\nexport function getPrecision(value: number): number {\n    const arr = value.toString().split('.');\n\n    return arr.length === 1\n        ? 1\n        // tslint:disable-next-line:no-magic-numbers\n        :  Math.pow(10, arr[1].length);\n}\n\nexport function add(value1: number, value2: number): number {\n    const precision = Math.max(getPrecision(value1), getPrecision(value2));\n\n    return (value1 * precision + value2 * precision) / precision;\n}\n\nexport const MC_NUMBER_INPUT_VALUE_ACCESSOR: any = {\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: forwardRef(() => McNumberInput),\n    multi: true\n};\n\ninterface NumberLocaleConfig {\n    groupSeparator: string[];\n    fractionSeparator: string;\n    startFormattingFrom?: number;\n}\n\n@Directive({\n    selector: `input[mcInput][type=\"number\"]`,\n    exportAs: 'mcNumericalInput',\n    providers: [MC_NUMBER_INPUT_VALUE_ACCESSOR],\n    host: {\n        '(blur)': 'focusChanged(false)',\n        '(focus)': 'focusChanged(true)',\n        '(paste)': 'onPaste($event)',\n        '(keydown)': 'onKeyDown($event)',\n        '(input)': 'onInput($event)'\n    }\n})\nexport class McNumberInput implements McFormFieldControl<any>, ControlValueAccessor, OnDestroy {\n    /** Emits when the value changes (either due to user input or programmatic change). */\n    valueChange = new EventEmitter<number | null>();\n\n    /** Emits when the disabled state has changed */\n    disabledChange = new EventEmitter<boolean>();\n\n    readonly stateChanges: Subject<void> = new Subject<void>();\n\n    id: string;\n\n    placeholder: string;\n\n    empty: boolean;\n\n    required: boolean;\n\n    errorState: boolean;\n\n    controlType?: string | undefined;\n\n    @Input()\n    bigStep: number;\n\n    @Input()\n    step: number;\n\n    @Input()\n    min: number;\n\n    @Input()\n    max: number;\n\n    @Input()\n    withThousandSeparator: boolean = true;\n\n    /**\n     * Include thousand separator from custom index. For example, it will be useful in tables.\n     */\n    @Input()\n    startFormattingFrom?: number;\n\n    @Input()\n    get value(): number | null {\n        return this._value;\n    }\n\n    set value(value: number | null) {\n        const oldValue = this.value;\n        this._value = value;\n\n        if (oldValue !== value) {\n            this.setViewValue(this.formatNumber(value));\n\n            this.valueChange.emit(value);\n        }\n    }\n\n    private _value: number | null;\n\n    @Input()\n    get disabled(): boolean {\n        return this._disabled;\n    }\n\n    set disabled(value: boolean) {\n        const newValue = coerceBooleanProperty(value);\n        const element = this.nativeElement;\n\n        if (this._disabled !== newValue) {\n            this._disabled = newValue;\n            this.disabledChange.emit(newValue);\n        }\n\n        // We need to null check the `blur` method, because it's undefined during SSR.\n        if (newValue && element.blur) {\n            // Normally, native input elements automatically blur if they turn disabled. This behavior\n            // is problematic, because it would mean that it triggers another change detection cycle,\n            // which then causes a changed after checked error if the input element was focused before.\n            element.blur();\n        }\n    }\n\n    private _disabled: boolean = false;\n\n    focused: boolean = false;\n\n    get nativeElement(): HTMLInputElement {\n        return this.elementRef.nativeElement;\n    }\n\n    get viewValue(): string {\n        return this.nativeElement.value;\n    }\n\n    get ngControl(): any {\n        return this.control;\n    }\n\n    private control: AbstractControl;\n\n    private readonly allNumberLocaleConfigs: { id: string; config: NumberLocaleConfig }[];\n\n    private numberLocaleConfig: NumberLocaleConfig;\n\n    private valueFromPaste: number | null;\n\n    private localeSubscription = Subscription.EMPTY;\n\n    constructor(\n        private elementRef: ElementRef,\n        private readonly renderer: Renderer2,\n        @Attribute('step') step: string,\n        @Attribute('big-step') bigStep: string,\n        @Attribute('min') min: string,\n        @Attribute('max') max: string,\n        @Optional() @Inject(MC_LOCALE_SERVICE) private localeService: McLocaleService\n    ) {\n        this.step = isDigit(step) ? parseFloat(step) : SMALL_STEP;\n        this.bigStep = isDigit(bigStep) ? parseFloat(bigStep) : BIG_STEP;\n        this.min = isDigit(min) ? parseFloat(min) : -Infinity;\n        this.max = isDigit(max) ? parseFloat(max) : Infinity;\n\n        setTimeout(() => this.nativeElement.type = 'text', 0);\n\n        if ('valueAsNumber' in this.nativeElement) {\n            /* переделать алгоритм  */\n            Object.defineProperty(Object.getPrototypeOf(this.nativeElement), 'valueAsNumber', {\n                // tslint:disable-next-line:no-reserved-keywords\n                get() {\n                    const res = parseFloat(normalizeSplitter(this.value));\n\n                    return isNaN(res) ? null : res;\n                }\n            });\n        }\n\n        this.allNumberLocaleConfigs = this.localeService.locales.items\n            .map((localeItem: { id: string; name: string }) => {\n                return { id: localeItem.id, config: this.localeService.locales[localeItem.id].input.number };\n            });\n\n        this.localeSubscription = this.localeService.changes.subscribe(this.updateLocaleParams);\n    }\n\n    ngOnDestroy(): void {\n        this.localeSubscription.unsubscribe();\n        this.valueChange.complete();\n        this.disabledChange.complete();\n    }\n\n    onContainerClick(): void {\n        this.focus();\n    }\n\n    focus(): void {\n        this.nativeElement.focus();\n    }\n\n    // Implemented as part of ControlValueAccessor.\n    writeValue(value: number | null): void {\n        this.value = value;\n    }\n\n    // Implemented as part of ControlValueAccessor.\n    registerOnChange(fn: (value: any) => void): void {\n        this.cvaOnChange = fn;\n    }\n\n    // Implemented as part of ControlValueAccessor.\n    registerOnTouched(fn: () => void): void {\n        this.onTouched = fn;\n    }\n\n    // Implemented as part of ControlValueAccessor.\n    setDisabledState(isDisabled: boolean): void {\n        this.disabled = isDisabled;\n    }\n\n    focusChanged(isFocused: boolean) {\n        if (isFocused !== this.focused) {\n            this.focused = isFocused;\n            this.stateChanges.next();\n        }\n    }\n\n    // tslint:disable-next-line:no-empty\n    onTouched = () => {};\n\n    onKeyDown(event: KeyboardEvent) {\n        // tslint:disable-next-line:deprecation\n        const keyCode = event.keyCode;\n\n        const isCtrlA = (e) => e.keyCode === A && (e.ctrlKey || e.metaKey);\n        const isCtrlC = (e) => e.keyCode === C && (e.ctrlKey || e.metaKey);\n        const isCtrlV = (e) => e.keyCode === V && (e.ctrlKey || e.metaKey);\n        const isCtrlX = (e) => e.keyCode === X && (e.ctrlKey || e.metaKey);\n        const isCtrlZ = (e) => e.keyCode === Z && (e.ctrlKey || e.metaKey);\n\n        const isPeriod = (e) => this.numberLocaleConfig.groupSeparator.includes(e.key)\n            || [this.numberLocaleConfig.fractionSeparator, '.'].includes(e.key);\n\n        const minuses = [NUMPAD_MINUS, DASH, FF_MINUS];\n        const serviceKeys = [DELETE, BACKSPACE, TAB, ESCAPE, ENTER];\n        const arrows = [LEFT_ARROW, RIGHT_ARROW];\n        const allowedKeys =  [HOME, END].concat(arrows).concat(serviceKeys).concat(minuses);\n\n        if (\n            minuses.includes(keyCode) &&\n            (this.viewValue.includes(event.key) || this.min >= 0)\n        ) {\n            event.preventDefault();\n\n            return;\n        }\n\n        if (isPeriod(event)) {\n            if (event.key === this.numberLocaleConfig.fractionSeparator &&\n                this.viewValue.indexOf(this.numberLocaleConfig.fractionSeparator) !== -1) {\n                event.preventDefault();\n\n                return;\n            }\n        }\n\n        if (allowedKeys.indexOf(keyCode) !== -1 ||\n            [\n                isCtrlA,\n                isCtrlC,\n                isCtrlV,\n                isCtrlX,\n                isCtrlZ,\n                isFunctionKey,\n                isPeriod\n            ].some((fn) => fn(event))\n        ) {\n            // let it happen, don't do anything\n            return;\n        }\n        // Ensure that it is not a number and stop the keypress\n        if (event.shiftKey || !isNumberKey(event) && !isNumpadKey(event)) {\n            event.preventDefault();\n\n            // process steps\n            const step = event.shiftKey ? this.bigStep : this.step;\n\n            if (keyCode === UP_ARROW) {\n                this.stepUp(step);\n            }\n\n            if (keyCode === DOWN_ARROW) {\n                this.stepDown(step);\n            }\n        }\n    }\n\n    onInput(event: InputEvent) {\n        const currentValueLength = this.formatNumber(this.value)?.length || 0;\n\n        setTimeout(() => {\n            const fromPaste = event.inputType === 'insertFromPaste';\n            let formattedValue: string | null;\n            if (fromPaste) {\n                formattedValue = this.formatNumber(this.valueFromPaste);\n            } else {\n                /*this.viewValue is raw and should be reformatted to localized number */\n                formattedValue = this.formatViewValue();\n\n                const offsetWhenSeparatorAdded = 2;\n\n                Promise.resolve().then(() => {\n                    if (Math.abs(this.viewValue.length - currentValueLength) === offsetWhenSeparatorAdded) {\n                        const cursorPosition = Math.max(\n                            0,\n                            (this.nativeElement.selectionStart || 0) + Math.sign(\n                                this.viewValue.length - currentValueLength\n                            )\n                        );\n\n                        this.renderer.setProperty(this.nativeElement, 'selectionStart', cursorPosition);\n                        this.renderer.setProperty(this.nativeElement, 'selectionEnd', cursorPosition);\n                    }\n                });\n            }\n            this.setViewValue(formattedValue, !fromPaste);\n            this.viewToModelUpdate(formattedValue);\n        });\n    }\n\n    onPaste(event: ClipboardEvent) {\n       this.valueFromPaste = this.checkAndNormalizeLocalizedNumber(event.clipboardData?.getData('text'));\n       if (this.valueFromPaste === null) { event.preventDefault(); }\n    }\n\n    stepUp(step: number) {\n        this.nativeElement.focus();\n\n        const res = Math.max(Math.min(add(this.value || 0, step), this.max), this.min);\n\n        this.setViewValue(this.formatNumber(res));\n\n        this._value = res;\n        this.cvaOnChange(res);\n        this.valueChange.emit(res);\n    }\n\n    stepDown(step: number) {\n        this.nativeElement.focus();\n\n        const res = Math.min(Math.max(add(this.value || 0, -step), this.min), this.max);\n\n        this.setViewValue(this.formatNumber(res));\n\n        this._value = res;\n        this.cvaOnChange(res);\n        this.valueChange.emit(res);\n    }\n\n    // tslint:disable-next-line:no-empty\n    private cvaOnChange: (value: any) => void = () => {};\n\n    private setViewValue(value: string | null, savePosition: boolean = false) {\n        const cursorPosition = this.nativeElement.selectionStart;\n\n        this.renderer.setProperty(this.nativeElement, 'value', value);\n\n        if (savePosition) {\n            this.renderer.setProperty(this.nativeElement, 'selectionStart', cursorPosition);\n            this.renderer.setProperty(this.nativeElement, 'selectionEnd', cursorPosition);\n        }\n    }\n\n    private viewToModelUpdate(newValue: string | null) {\n        const normalizedValue = newValue === null ? null : +this.normalizeNumber(newValue);\n\n        if (normalizedValue !== this.value) {\n            this._value = normalizedValue;\n            this.cvaOnChange(normalizedValue);\n            this.valueChange.emit(normalizedValue);\n        }\n\n        this.ngControl?.updateValueAndValidity({ emitEvent: false });\n    }\n\n    private formatViewValue(): string | null {\n        if (this.viewValue === null || this.viewValue === '' || Number.isNaN(+this.normalizeNumber(this.viewValue))) {\n            return null;\n        }\n\n        const separator = this.numberLocaleConfig.groupSeparator.includes(' ')\n        && this.numberLocaleConfig.fractionSeparator === ','\n            ? /[,.]/\n            : this.numberLocaleConfig.fractionSeparator;\n\n        const [intPart, fractionPart] = this.viewValue.split(separator)\n            .map((valuePart) => this.normalizeNumber(valuePart));\n\n        return this.createLocalizedNumberFromParts(+intPart, fractionPart);\n    }\n\n    private formatNumber(value: number | null | undefined): string | null {\n        if (value === null || value === undefined) { return null; }\n\n        const [intPart, fractionPart] = value.toString().split('.');\n\n        return this.createLocalizedNumberFromParts(+intPart, fractionPart);\n    }\n\n    private createLocalizedNumberFromParts(intPart: number, fractionPart?: string): string {\n        const formatOptions = {\n            useGrouping: this.withThousandSeparator,\n            maximumFractionDigits: 20\n        };\n\n        if (this.withThousandSeparator && this.numberLocaleConfig.startFormattingFrom) {\n            formatOptions.useGrouping = intPart >= Math.pow(\n                // tslint:disable-next-line:no-magic-numbers\n                10, this.numberLocaleConfig.startFormattingFrom\n            );\n        }\n\n        const localeId = this.localeService.id === 'es-LA' ? 'ru-RU' : this.localeService.id;\n\n        const formatter = new Intl.NumberFormat(localeId, formatOptions);\n        const formattedFractionPart = fractionPart?.split('')\n            .map((numChar) => formatter.format(+numChar)).join('');\n\n        return formattedFractionPart === undefined\n            ? formatter.format(intPart)\n            : `${ formatter.format(intPart) }${ this.numberLocaleConfig.fractionSeparator }${ formattedFractionPart }`;\n    }\n\n    /**\n     * Method that returns a string representation of a number without localized separators\n     */\n    private normalizeNumber(value: string | null | undefined, customConfig?: NumberLocaleConfig): string {\n        if (value === null || value === undefined) { return ''; }\n\n        const { groupSeparator, fractionSeparator } = customConfig || this.numberLocaleConfig;\n        const groupSeparatorRegexp = new RegExp(`[${groupSeparator.join('')}]`, 'g');\n        const fractionSeparatorRegexp = new RegExp(`\\\\${fractionSeparator}`, 'g');\n\n        return value.toString()\n            .replace(groupSeparatorRegexp, '')\n            .replace(fractionSeparatorRegexp, '.');\n    }\n\n    private updateLocaleParams = (id: string) => {\n        this.numberLocaleConfig = this.localeService.locales[id].input.number;\n\n        this.setViewValue(this.formatNumber(this.value));\n    }\n\n    private checkAndNormalizeLocalizedNumber(num: string | null | undefined): number | null {\n        if (num === null || num === undefined) { return null; }\n\n        /* if some locale input config satisfies pasted number, try to normalise with selected locale config */\n        let numberOutput: number | null = null;\n        for (const { config } of this.allNumberLocaleConfigs) {\n            const normalized = +this.normalizeNumber(num, config);\n            if (!Number.isNaN(normalized)) {\n                numberOutput = normalized;\n                break;\n            }\n        }\n\n        return numberOutput;\n    }\n}\n"]}
|
@@ -71,7 +71,7 @@ export class McLoaderOverlay {
|
|
71
71
|
this.renderer.removeClass(this.elementRef.nativeElement.parentElement, mcLoaderOverlayParent);
|
72
72
|
}
|
73
73
|
/** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.1.5", ngImport: i0, type: McLoaderOverlay, deps: [{ token: i0.ElementRef }, { token: i0.Renderer2 }, { token: 'fixed-top', attribute: true, optional: true }], target: i0.ɵɵFactoryTarget.Component }); }
|
74
|
-
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.5", type: McLoaderOverlay, selector: "mc-loader-overlay", inputs: { text: "text", caption: "caption" }, host: { properties: { "class.mc-loader-overlay_empty": "isEmpty", "class.mc-loader-overlay_center": "!isFixedTop", "class.mc-loader-overlay_fixed-top": "isFixedTop" }, classAttribute: "mc-loader-overlay" }, queries: [{ propertyName: "externalIndicator", first: true, predicate: McLoaderOverlayIndicator, descendants: true }, { propertyName: "externalText", first: true, predicate: McLoaderOverlayText, descendants: true }, { propertyName: "externalCaption", first: true, predicate: McLoaderOverlayCaption, descendants: true }], ngImport: i0, template: "<div class=\"mc-loader-overlay__container\">\n <ng-container [ngSwitch]=\"isExternalIndicator\">\n <ng-content *ngSwitchCase=\"true\" select=\"[mc-loader-overlay-indicator]\"></ng-content>\n <mc-progress-spinner *ngSwitchDefault [mode]=\"'indeterminate'\"></mc-progress-spinner>\n </ng-container>\n\n <ng-container [ngSwitch]=\"isExternalText\">\n <ng-content *ngSwitchCase=\"true\" select=\"[mc-loader-overlay-text]\"></ng-content>\n <ng-container *ngSwitchDefault>\n <div class=\"mc-loader-overlay-text\" *ngIf=\"text\">{{ text }}</div>\n </ng-container>\n </ng-container>\n\n <ng-container [ngSwitch]=\"isExternalCaption\">\n <ng-content *ngSwitchCase=\"true\" select=\"[mc-loader-overlay-caption]\"></ng-content>\n <ng-container *ngSwitchDefault>\n <div class=\"mc-loader-overlay-caption\" *ngIf=\"caption\">{{ caption }}</div>\n </ng-container>\n </ng-container>\n</div>\n", styles: [".mc-loader-overlay_parent{position:relative}.mc-loader-overlay{position:absolute;display:flex;flex-direction:column;justify-content:center;align-items:center;inset:0;z-index:1000}.mc-loader-overlay .mc-loader-overlay__container{display:flex;flex-direction:column;justify-content:center;align-items:center;width:80%;max-width:80%}.mc-loader-overlay.mc-loader-overlay_fixed-top{justify-content:unset}.mc-loader-overlay.mc-loader-overlay_fixed-top .mc-loader-overlay__container{margin-top:72px}.mc-loader-overlay.mc-loader-overlay_center:not(.mc-loader-overlay_empty) .mc-loader-overlay__container{transform:translateY(-40%)}.mc-loader-overlay-text{margin-top:8px;max-width:480px;text-align:center}.mc-loader-overlay-caption{margin-top:2px;max-width:480px;text-align:center}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i1.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "component", type: i2.McProgressSpinner, selector: "mc-progress-spinner", inputs: ["color", "id", "value", "mode", "size"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
74
|
+
/** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.1.5", type: McLoaderOverlay, selector: "mc-loader-overlay", inputs: { text: "text", caption: "caption" }, host: { properties: { "class.mc-loader-overlay_empty": "isEmpty", "class.mc-loader-overlay_center": "!isFixedTop", "class.mc-loader-overlay_fixed-top": "isFixedTop" }, classAttribute: "mc-loader-overlay" }, queries: [{ propertyName: "externalIndicator", first: true, predicate: McLoaderOverlayIndicator, descendants: true }, { propertyName: "externalText", first: true, predicate: McLoaderOverlayText, descendants: true }, { propertyName: "externalCaption", first: true, predicate: McLoaderOverlayCaption, descendants: true }], ngImport: i0, template: "<div class=\"mc-loader-overlay__container\">\n <ng-container [ngSwitch]=\"isExternalIndicator\">\n <ng-content *ngSwitchCase=\"true\" select=\"[mc-loader-overlay-indicator]\"></ng-content>\n <mc-progress-spinner *ngSwitchDefault [mode]=\"'indeterminate'\"></mc-progress-spinner>\n </ng-container>\n\n <ng-container [ngSwitch]=\"isExternalText\">\n <ng-content *ngSwitchCase=\"true\" select=\"[mc-loader-overlay-text]\"></ng-content>\n <ng-container *ngSwitchDefault>\n <div class=\"mc-loader-overlay-text\" *ngIf=\"text\">{{ text }}</div>\n </ng-container>\n </ng-container>\n\n <ng-container [ngSwitch]=\"isExternalCaption\">\n <ng-content *ngSwitchCase=\"true\" select=\"[mc-loader-overlay-caption]\"></ng-content>\n <ng-container *ngSwitchDefault>\n <div class=\"mc-loader-overlay-caption\" *ngIf=\"caption\">{{ caption }}</div>\n </ng-container>\n </ng-container>\n</div>\n", styles: [".mc-loader-overlay_parent{position:relative}.mc-loader-overlay{position:absolute;display:flex;flex-direction:column;justify-content:center;align-items:center;inset:0;z-index:1000}.mc-loader-overlay .mc-loader-overlay__container{display:flex;flex-direction:column;justify-content:center;align-items:center;width:80%;max-width:80%}.mc-loader-overlay.mc-loader-overlay_fixed-top{justify-content:unset}.mc-loader-overlay.mc-loader-overlay_fixed-top .mc-loader-overlay__container{margin-top:var(--mc-loader-overlay-size-fixed-top-padding, 72px)}.mc-loader-overlay.mc-loader-overlay_center:not(.mc-loader-overlay_empty) .mc-loader-overlay__container{transform:translateY(var(--mc-loader-overlay-size-center-optical-compensation, -40%))}.mc-loader-overlay-text{margin-top:8px;max-width:480px;text-align:center}.mc-loader-overlay-caption{margin-top:2px;max-width:480px;text-align:center}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { kind: "directive", type: i1.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }, { kind: "directive", type: i1.NgSwitchDefault, selector: "[ngSwitchDefault]" }, { kind: "component", type: i2.McProgressSpinner, selector: "mc-progress-spinner", inputs: ["color", "id", "value", "mode", "size"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); }
|
75
75
|
}
|
76
76
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.5", ngImport: i0, type: McLoaderOverlay, decorators: [{
|
77
77
|
type: Component,
|
@@ -80,7 +80,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.1.5", ngImpor
|
|
80
80
|
'[class.mc-loader-overlay_empty]': 'isEmpty',
|
81
81
|
'[class.mc-loader-overlay_center]': '!isFixedTop',
|
82
82
|
'[class.mc-loader-overlay_fixed-top]': 'isFixedTop'
|
83
|
-
}, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<div class=\"mc-loader-overlay__container\">\n <ng-container [ngSwitch]=\"isExternalIndicator\">\n <ng-content *ngSwitchCase=\"true\" select=\"[mc-loader-overlay-indicator]\"></ng-content>\n <mc-progress-spinner *ngSwitchDefault [mode]=\"'indeterminate'\"></mc-progress-spinner>\n </ng-container>\n\n <ng-container [ngSwitch]=\"isExternalText\">\n <ng-content *ngSwitchCase=\"true\" select=\"[mc-loader-overlay-text]\"></ng-content>\n <ng-container *ngSwitchDefault>\n <div class=\"mc-loader-overlay-text\" *ngIf=\"text\">{{ text }}</div>\n </ng-container>\n </ng-container>\n\n <ng-container [ngSwitch]=\"isExternalCaption\">\n <ng-content *ngSwitchCase=\"true\" select=\"[mc-loader-overlay-caption]\"></ng-content>\n <ng-container *ngSwitchDefault>\n <div class=\"mc-loader-overlay-caption\" *ngIf=\"caption\">{{ caption }}</div>\n </ng-container>\n </ng-container>\n</div>\n", styles: [".mc-loader-overlay_parent{position:relative}.mc-loader-overlay{position:absolute;display:flex;flex-direction:column;justify-content:center;align-items:center;inset:0;z-index:1000}.mc-loader-overlay .mc-loader-overlay__container{display:flex;flex-direction:column;justify-content:center;align-items:center;width:80%;max-width:80%}.mc-loader-overlay.mc-loader-overlay_fixed-top{justify-content:unset}.mc-loader-overlay.mc-loader-overlay_fixed-top .mc-loader-overlay__container{margin-top:72px}.mc-loader-overlay.mc-loader-overlay_center:not(.mc-loader-overlay_empty) .mc-loader-overlay__container{transform:translateY(-40%)}.mc-loader-overlay-text{margin-top:8px;max-width:480px;text-align:center}.mc-loader-overlay-caption{margin-top:2px;max-width:480px;text-align:center}\n"] }]
|
83
|
+
}, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, template: "<div class=\"mc-loader-overlay__container\">\n <ng-container [ngSwitch]=\"isExternalIndicator\">\n <ng-content *ngSwitchCase=\"true\" select=\"[mc-loader-overlay-indicator]\"></ng-content>\n <mc-progress-spinner *ngSwitchDefault [mode]=\"'indeterminate'\"></mc-progress-spinner>\n </ng-container>\n\n <ng-container [ngSwitch]=\"isExternalText\">\n <ng-content *ngSwitchCase=\"true\" select=\"[mc-loader-overlay-text]\"></ng-content>\n <ng-container *ngSwitchDefault>\n <div class=\"mc-loader-overlay-text\" *ngIf=\"text\">{{ text }}</div>\n </ng-container>\n </ng-container>\n\n <ng-container [ngSwitch]=\"isExternalCaption\">\n <ng-content *ngSwitchCase=\"true\" select=\"[mc-loader-overlay-caption]\"></ng-content>\n <ng-container *ngSwitchDefault>\n <div class=\"mc-loader-overlay-caption\" *ngIf=\"caption\">{{ caption }}</div>\n </ng-container>\n </ng-container>\n</div>\n", styles: [".mc-loader-overlay_parent{position:relative}.mc-loader-overlay{position:absolute;display:flex;flex-direction:column;justify-content:center;align-items:center;inset:0;z-index:1000}.mc-loader-overlay .mc-loader-overlay__container{display:flex;flex-direction:column;justify-content:center;align-items:center;width:80%;max-width:80%}.mc-loader-overlay.mc-loader-overlay_fixed-top{justify-content:unset}.mc-loader-overlay.mc-loader-overlay_fixed-top .mc-loader-overlay__container{margin-top:var(--mc-loader-overlay-size-fixed-top-padding, 72px)}.mc-loader-overlay.mc-loader-overlay_center:not(.mc-loader-overlay_empty) .mc-loader-overlay__container{transform:translateY(var(--mc-loader-overlay-size-center-optical-compensation, -40%))}.mc-loader-overlay-text{margin-top:8px;max-width:480px;text-align:center}.mc-loader-overlay-caption{margin-top:2px;max-width:480px;text-align:center}\n"] }]
|
84
84
|
}], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.Renderer2 }, { type: undefined, decorators: [{
|
85
85
|
type: Optional
|
86
86
|
}, {
|