@bravura/ui 5.2.3 → 6.0.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.
Files changed (140) hide show
  1. package/CHANGELOG.md +630 -616
  2. package/README.md +56 -56
  3. package/_index.scss +5 -5
  4. package/fesm2022/bravura-ui-alert-testing.mjs.map +1 -1
  5. package/fesm2022/bravura-ui-alert.mjs +13 -13
  6. package/fesm2022/bravura-ui-alert.mjs.map +1 -1
  7. package/fesm2022/bravura-ui-behavior.mjs +25 -21
  8. package/fesm2022/bravura-ui-behavior.mjs.map +1 -1
  9. package/fesm2022/bravura-ui-clip-note.mjs +15 -14
  10. package/fesm2022/bravura-ui-clip-note.mjs.map +1 -1
  11. package/fesm2022/bravura-ui-common.mjs +5 -5
  12. package/fesm2022/bravura-ui-common.mjs.map +1 -1
  13. package/fesm2022/bravura-ui-currency-input.mjs +10 -9
  14. package/fesm2022/bravura-ui-currency-input.mjs.map +1 -1
  15. package/fesm2022/bravura-ui-decimal-input.mjs +10 -9
  16. package/fesm2022/bravura-ui-decimal-input.mjs.map +1 -1
  17. package/fesm2022/bravura-ui-discrete-input.mjs +9 -9
  18. package/fesm2022/bravura-ui-discrete-input.mjs.map +1 -1
  19. package/fesm2022/bravura-ui-file-upload.mjs +12 -12
  20. package/fesm2022/bravura-ui-file-upload.mjs.map +1 -1
  21. package/fesm2022/bravura-ui-form-field.mjs +14 -13
  22. package/fesm2022/bravura-ui-form-field.mjs.map +1 -1
  23. package/fesm2022/bravura-ui-icon-font.mjs +10 -9
  24. package/fesm2022/bravura-ui-icon-font.mjs.map +1 -1
  25. package/fesm2022/bravura-ui-panel.mjs +18 -17
  26. package/fesm2022/bravura-ui-panel.mjs.map +1 -1
  27. package/fesm2022/bravura-ui-phone-number.mjs +20 -17
  28. package/fesm2022/bravura-ui-phone-number.mjs.map +1 -1
  29. package/fesm2022/bravura-ui-radio-panel-testing.mjs.map +1 -1
  30. package/fesm2022/bravura-ui-radio-panel.mjs +14 -14
  31. package/fesm2022/bravura-ui-radio-panel.mjs.map +1 -1
  32. package/fesm2022/bravura-ui-selection-panel.mjs +14 -13
  33. package/fesm2022/bravura-ui-selection-panel.mjs.map +1 -1
  34. package/fesm2022/bravura-ui-skeletons.mjs +18 -13
  35. package/fesm2022/bravura-ui-skeletons.mjs.map +1 -1
  36. package/fesm2022/bravura-ui-stepper.mjs +30 -28
  37. package/fesm2022/bravura-ui-stepper.mjs.map +1 -1
  38. package/fesm2022/bravura-ui-tooltip.mjs +14 -13
  39. package/fesm2022/bravura-ui-tooltip.mjs.map +1 -1
  40. package/m3-theme.scss +155 -155
  41. package/package.json +12 -52
  42. package/radio-panel/_radio-panel-theme.scss +11 -11
  43. package/selection-panel/_selection-panel-theme.scss +33 -33
  44. package/stepper/_stepper-theme.scss +20 -20
  45. package/stepper/public-api.d.ts +1 -1
  46. package/stepper/{step-label-prefix.directive.d.ts → step-label-top.directive.d.ts} +5 -5
  47. package/stepper/stepper.module.d.ts +2 -2
  48. package/theme/_ui-theme-legacy.scss +112 -112
  49. package/theme/_ui-theme.scss +101 -101
  50. package/esm2022/alert/alert-container.component.mjs +0 -207
  51. package/esm2022/alert/alert-message.component.mjs +0 -101
  52. package/esm2022/alert/alert.module.mjs +0 -22
  53. package/esm2022/alert/bravura-ui-alert.mjs +0 -5
  54. package/esm2022/alert/public-api.mjs +0 -2
  55. package/esm2022/alert/testing/bravura-ui-alert-testing.mjs +0 -5
  56. package/esm2022/alert/testing/test-api.mjs +0 -44
  57. package/esm2022/behavior/await.directive.mjs +0 -133
  58. package/esm2022/behavior/behavior.module.mjs +0 -37
  59. package/esm2022/behavior/bravura-ui-behavior.mjs +0 -5
  60. package/esm2022/behavior/observe-content-class.directive.mjs +0 -63
  61. package/esm2022/behavior/public-api.mjs +0 -6
  62. package/esm2022/behavior/sizing-monitor.directive.mjs +0 -31
  63. package/esm2022/behavior/sizing.directive.mjs +0 -256
  64. package/esm2022/bravura-ui.mjs +0 -5
  65. package/esm2022/clip-note/bravura-ui-clip-note.mjs +0 -5
  66. package/esm2022/clip-note/clip-note.component.mjs +0 -216
  67. package/esm2022/clip-note/clip-note.directive.mjs +0 -141
  68. package/esm2022/clip-note/clip-note.module.mjs +0 -32
  69. package/esm2022/clip-note/public-api.mjs +0 -2
  70. package/esm2022/common/bravura-ui-common.mjs +0 -5
  71. package/esm2022/common/common-utils.mjs +0 -34
  72. package/esm2022/common/common.module.mjs +0 -53
  73. package/esm2022/common/public-api.mjs +0 -3
  74. package/esm2022/currency-input/bravura-ui-currency-input.mjs +0 -5
  75. package/esm2022/currency-input/currency-input.directive.mjs +0 -276
  76. package/esm2022/currency-input/currency-input.module.mjs +0 -19
  77. package/esm2022/currency-input/public-api.mjs +0 -2
  78. package/esm2022/decimal-input/bravura-ui-decimal-input.mjs +0 -5
  79. package/esm2022/decimal-input/decimal-input.directive.mjs +0 -122
  80. package/esm2022/decimal-input/decimal-input.module.mjs +0 -19
  81. package/esm2022/decimal-input/public-api.mjs +0 -2
  82. package/esm2022/discrete-input/bravura-ui-discrete-input.mjs +0 -5
  83. package/esm2022/discrete-input/discrete-input.component.mjs +0 -337
  84. package/esm2022/discrete-input/discrete-input.module.mjs +0 -21
  85. package/esm2022/discrete-input/public-api.mjs +0 -3
  86. package/esm2022/file-upload/bravura-ui-file-upload.mjs +0 -5
  87. package/esm2022/file-upload/file-upload.component.mjs +0 -400
  88. package/esm2022/file-upload/file-upload.module.mjs +0 -44
  89. package/esm2022/file-upload/file-upload.service.mjs +0 -29
  90. package/esm2022/file-upload/public-api.mjs +0 -7
  91. package/esm2022/form-field/bravura-ui-form-field.mjs +0 -5
  92. package/esm2022/form-field/form-field.component.mjs +0 -82
  93. package/esm2022/form-field/form-field.module.mjs +0 -33
  94. package/esm2022/form-field/public-api.mjs +0 -3
  95. package/esm2022/icon-font/bravura-ui-icon-font.mjs +0 -5
  96. package/esm2022/icon-font/icon-font.module.mjs +0 -22
  97. package/esm2022/icon-font/icon.directive.mjs +0 -102
  98. package/esm2022/icon-font/public-api.mjs +0 -4
  99. package/esm2022/icon-font/utilities.mjs +0 -51
  100. package/esm2022/panel/bravura-ui-panel.mjs +0 -5
  101. package/esm2022/panel/panel-section.component.mjs +0 -41
  102. package/esm2022/panel/panel.component.mjs +0 -87
  103. package/esm2022/panel/panel.module.mjs +0 -23
  104. package/esm2022/panel/public-api.mjs +0 -2
  105. package/esm2022/panel/tinted.directive.mjs +0 -60
  106. package/esm2022/phone-number/bravura-ui-phone-number.mjs +0 -5
  107. package/esm2022/phone-number/phone-number.directive.mjs +0 -188
  108. package/esm2022/phone-number/phone-number.module.mjs +0 -24
  109. package/esm2022/phone-number/phone-number.pipe.mjs +0 -47
  110. package/esm2022/phone-number/phone-number.validator.mjs +0 -64
  111. package/esm2022/phone-number/public-api.mjs +0 -2
  112. package/esm2022/public-api.mjs +0 -2
  113. package/esm2022/radio-panel/bravura-ui-radio-panel.mjs +0 -5
  114. package/esm2022/radio-panel/public-api.mjs +0 -4
  115. package/esm2022/radio-panel/radio-panel-item.component.mjs +0 -93
  116. package/esm2022/radio-panel/radio-panel.component.mjs +0 -81
  117. package/esm2022/radio-panel/radio-panel.module.mjs +0 -25
  118. package/esm2022/radio-panel/testing/bravura-ui-radio-panel-testing.mjs +0 -5
  119. package/esm2022/radio-panel/testing/test-api.mjs +0 -46
  120. package/esm2022/selection-panel/bravura-ui-selection-panel.mjs +0 -5
  121. package/esm2022/selection-panel/public-api.mjs +0 -4
  122. package/esm2022/selection-panel/selection-panel-item.component.mjs +0 -163
  123. package/esm2022/selection-panel/selection-panel.directive.mjs +0 -119
  124. package/esm2022/selection-panel/selection-panel.module.mjs +0 -23
  125. package/esm2022/skeletons/bravura-ui-skeletons.mjs +0 -5
  126. package/esm2022/skeletons/public-api.mjs +0 -4
  127. package/esm2022/skeletons/skeleton-loader-presets.directive.mjs +0 -83
  128. package/esm2022/skeletons/skeleton-loader.component.mjs +0 -76
  129. package/esm2022/skeletons/skeletons.module.mjs +0 -35
  130. package/esm2022/stepper/bravura-ui-stepper.mjs +0 -5
  131. package/esm2022/stepper/public-api.mjs +0 -4
  132. package/esm2022/stepper/step-label-prefix.directive.mjs +0 -40
  133. package/esm2022/stepper/stepper-animation.mjs +0 -23
  134. package/esm2022/stepper/stepper.component.mjs +0 -178
  135. package/esm2022/stepper/stepper.module.mjs +0 -53
  136. package/esm2022/tooltip/bravura-ui-tooltip.mjs +0 -5
  137. package/esm2022/tooltip/public-api.mjs +0 -4
  138. package/esm2022/tooltip/tooltip.component.mjs +0 -63
  139. package/esm2022/tooltip/tooltip.directive.mjs +0 -150
  140. package/esm2022/tooltip/tooltip.module.mjs +0 -25
@@ -1,276 +0,0 @@
1
- import { DecimalPipe, getCurrencySymbol } from '@angular/common';
2
- import { DEFAULT_CURRENCY_CODE, Directive, forwardRef, HostBinding, HostListener, Inject, Input, LOCALE_ID, Optional, Self, ɵfindLocaleData } from '@angular/core';
3
- import { NG_VALUE_ACCESSOR } from '@angular/forms';
4
- import { MAT_FORM_FIELD } from '@angular/material/form-field';
5
- import { MatInput } from '@angular/material/input';
6
- import { noop } from 'rxjs';
7
- import * as i0 from "@angular/core";
8
- import * as i1 from "@angular/material/form-field";
9
- /* tslint:disable:no-empty */
10
- export const noop_consumer = (_) => { };
11
- /**
12
- * This directive will enhance an input element to format the numbers entered to a currency amount.
13
- */
14
- export class CurrencyInputDirective {
15
- constructor(_el, _renderer, _locale, _defaultCurrencyCode, _field) {
16
- this._el = _el;
17
- this._renderer = _renderer;
18
- this._locale = _locale;
19
- this._defaultCurrencyCode = _defaultCurrencyCode;
20
- this._field = _field;
21
- /**
22
- * true to allow negative input, otherwise false
23
- * Default to false.
24
- */
25
- this.allowNegative = false;
26
- /**
27
- * Provide the currency code to format the entered amount.
28
- * Uses angular token DEFAULT_CURRENCY_CODE by default.
29
- */
30
- this.currencyCode = '';
31
- /**
32
- * true if no decimal digits allowed, otherwise false.
33
- * Default to false.
34
- */
35
- this.baseUnitOnly = false;
36
- /**
37
- * The format the of the amount either in wide or narrow.
38
- */
39
- this.format = 'wide';
40
- this.placeholder = '';
41
- this.autocomplete = 'off';
42
- this.type = 'text';
43
- this.inputMode = 'decimal';
44
- this.change = noop_consumer;
45
- this.onTouch = noop;
46
- this._symbol = '$';
47
- this._ds = '.'; // decimal separator
48
- this._trailing = false;
49
- const userAgent = navigator.userAgent;
50
- this._safari = !userAgent.match(/Firefox/i) && !userAgent.match(/Chrome/i) && !!userAgent.match(/safari/i);
51
- this._currencyUpdated();
52
- }
53
- ngOnInit() { }
54
- ngOnChanges() {
55
- this._currencyUpdated();
56
- this.onInput();
57
- }
58
- onInput() {
59
- this._formatCurrency(this._el, false, true);
60
- }
61
- onFocus() {
62
- this._formatCurrency(this._el, false, true);
63
- }
64
- onblur() {
65
- this.onTouch();
66
- this._formatCurrency(this._el, true, false);
67
- }
68
- writeValue(value) {
69
- value = this._decimalPipe.transform(value);
70
- this._renderer.setProperty(this._el.nativeElement, 'value', value);
71
- this._formatCurrency(this._el, true, false);
72
- }
73
- registerOnChange(fn) {
74
- this.change = fn;
75
- }
76
- registerOnTouched(fn) {
77
- this.onTouch = fn;
78
- }
79
- _updatePlaceholder() {
80
- this.placeholder = this.placeholder || this._0Text;
81
- if (this._field?._control instanceof MatInput) {
82
- this._field._control.placeholder = this.placeholder;
83
- }
84
- }
85
- _currencyUpdated() {
86
- this.currencyCode = this.currencyCode || this._defaultCurrencyCode;
87
- this._symbol = getCurrencySymbol(this.currencyCode, this.format, this._locale) || '$';
88
- const localeData = ɵfindLocaleData(this._locale);
89
- this._ds = localeData[13][0];
90
- this._decimalPipe = new DecimalPipe(this._locale);
91
- const curFormat = localeData[14][2];
92
- this._trailing = curFormat.indexOf('¤') > 0;
93
- this._updatePlaceholder();
94
- }
95
- _formatCurrency(input, blur, focus) {
96
- // appends $ to value, validates decimal side
97
- // and puts cursor back in right position.
98
- // get input value
99
- let input_val = input.nativeElement.value;
100
- // don't validate empty input
101
- if (input_val === '') {
102
- this.change(null);
103
- return;
104
- }
105
- const minus = this.allowNegative ? '-' : '';
106
- // remove non digit values except currency symbol, decimal separator and hypen
107
- const reg = new RegExp(`[^0-9${minus}${this._symbol}${this._ds}]`, 'g');
108
- let sanitiseValue = input_val.replace(reg, '');
109
- if (sanitiseValue === '' || sanitiseValue === this._symbol) {
110
- this.change(null);
111
- this._renderer.setProperty(input.nativeElement, 'value', '');
112
- return;
113
- }
114
- else if ((this.allowNegative && sanitiseValue === `-${this._symbol}`) ||
115
- sanitiseValue === '-' ||
116
- sanitiseValue === '--') {
117
- this.change(null);
118
- this._renderer.setProperty(input.nativeElement, 'value', '-');
119
- return;
120
- }
121
- const negative = this.allowNegative && input_val.indexOf('-') >= 0;
122
- // original length
123
- const original_len = input_val.length;
124
- // initial caret position
125
- let caret_pos = input.nativeElement.selectionStart;
126
- input_val = input_val.replace(RegExp(`[^0-9${minus}${this._ds}]`, 'g'), '').replace(/^\.\./, '');
127
- // check for decimal
128
- if (input_val.indexOf(this._ds) >= 0) {
129
- // get position of first decimal
130
- // this prevents multiple decimals from
131
- // being entered
132
- let decimal_pos = input_val.indexOf(this._ds);
133
- // split number by decimal point
134
- let left_side = input_val.substring(0, decimal_pos);
135
- let right_side = input_val.substring(decimal_pos);
136
- // add commas to left side of number
137
- left_side = this._formatNumber(left_side, blur) || '';
138
- // no value append a zero for decimal values
139
- if (!left_side.length) {
140
- left_side = '0';
141
- }
142
- if (!this.baseUnitOnly) {
143
- // validate right side
144
- right_side = right_side.replace(/\D/g, '');
145
- // Limit decimal to only 2 digits
146
- let v = Number(`0.${right_side}`);
147
- if (v) {
148
- const length = right_side.length > 1 ? 2 : 1;
149
- right_side = v.toFixed(length).substring(2, 4);
150
- }
151
- // On blur make sure 2 numbers after decimal
152
- if (blur) {
153
- right_side += '00';
154
- }
155
- right_side = right_side.substring(0, 2);
156
- // join number by .
157
- input_val = left_side + this._ds + right_side;
158
- }
159
- else {
160
- input_val = left_side;
161
- }
162
- }
163
- else {
164
- input_val = this._formatNumber(input_val, blur);
165
- // final formatting
166
- if (blur && !this.baseUnitOnly) {
167
- input_val += `${this._ds}00`;
168
- }
169
- }
170
- const numStr = input_val;
171
- // append the currency symbol
172
- if (!this._safari || !focus) {
173
- if (this._trailing) {
174
- input_val = input_val + ' ' + this._symbol;
175
- }
176
- else {
177
- input_val = this._symbol + input_val;
178
- }
179
- }
180
- if (negative) {
181
- // append the hypen back to the value if a negative value was entered
182
- input_val = `-${input_val}`;
183
- }
184
- const num = this._convert((negative ? '-' : '') + numStr);
185
- // update control value first with the number
186
- this.change(Number(num));
187
- if (blur && num === 0) {
188
- input_val = this._0Text;
189
- }
190
- // update dom with the formatted value
191
- this._renderer.setProperty(input.nativeElement, 'value', input_val);
192
- // put caret back in the right position
193
- let updated_len = input_val.length;
194
- if (caret_pos) {
195
- caret_pos = updated_len - original_len + caret_pos;
196
- if (input_val.substring(caret_pos - this._symbol.length) === this._symbol && this._trailing) {
197
- caret_pos -= this._symbol.length + 1;
198
- }
199
- }
200
- if (!this._safari) {
201
- input.nativeElement.setSelectionRange(caret_pos, caret_pos);
202
- }
203
- }
204
- // format the number into currency format
205
- _formatNumber(n, blur = false) {
206
- // format number 1000000 to 1,234,567
207
- n = n.replace(/\D/g, '');
208
- if (blur) {
209
- n = n.replace(/^0+/, '');
210
- }
211
- return this._decimalPipe.transform(n, '1.0-0');
212
- }
213
- _convert(input) {
214
- const val = input
215
- .replace(this._ds, 'd')
216
- .replace(/[^0-9d-]/g, '')
217
- .replace('d', '.');
218
- return parseFloat(val);
219
- }
220
- get _0Text() {
221
- const decimalStr = this.baseUnitOnly ? '' : `${this._ds}00`;
222
- return this._trailing ? `0${decimalStr} ${this._symbol}` : `${this._symbol}0${decimalStr}`;
223
- }
224
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: CurrencyInputDirective, deps: [{ token: i0.ElementRef, self: true }, { token: i0.Renderer2 }, { token: LOCALE_ID }, { token: DEFAULT_CURRENCY_CODE }, { token: MAT_FORM_FIELD, optional: true }], target: i0.ɵɵFactoryTarget.Directive }); }
225
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.2", type: CurrencyInputDirective, selector: "input[buiCurrencyInput],input[currencyCode],input[data-type=currency]", inputs: { allowNegative: "allowNegative", currencyCode: "currencyCode", baseUnitOnly: "baseUnitOnly", format: "format" }, host: { listeners: { "input": "onInput()", "focus": "onFocus()", "blur": "onblur()" }, properties: { "placeholder": "this.placeholder", "autocomplete": "this.autocomplete", "type": "this.type", "attr.inputmode": "this.inputMode" } }, providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => CurrencyInputDirective), multi: true }], usesOnChanges: true, ngImport: i0 }); }
226
- }
227
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: CurrencyInputDirective, decorators: [{
228
- type: Directive,
229
- args: [{
230
- selector: 'input[buiCurrencyInput],input[currencyCode],input[data-type=currency]',
231
- providers: [{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => CurrencyInputDirective), multi: true }]
232
- }]
233
- }], ctorParameters: () => [{ type: i0.ElementRef, decorators: [{
234
- type: Self
235
- }] }, { type: i0.Renderer2 }, { type: undefined, decorators: [{
236
- type: Inject,
237
- args: [LOCALE_ID]
238
- }] }, { type: undefined, decorators: [{
239
- type: Inject,
240
- args: [DEFAULT_CURRENCY_CODE]
241
- }] }, { type: i1.MatFormField, decorators: [{
242
- type: Optional
243
- }, {
244
- type: Inject,
245
- args: [MAT_FORM_FIELD]
246
- }] }], propDecorators: { allowNegative: [{
247
- type: Input
248
- }], currencyCode: [{
249
- type: Input
250
- }], baseUnitOnly: [{
251
- type: Input
252
- }], format: [{
253
- type: Input
254
- }], placeholder: [{
255
- type: HostBinding,
256
- args: ['placeholder']
257
- }], autocomplete: [{
258
- type: HostBinding,
259
- args: ['autocomplete']
260
- }], type: [{
261
- type: HostBinding,
262
- args: ['type']
263
- }], inputMode: [{
264
- type: HostBinding,
265
- args: ['attr.inputmode']
266
- }], onInput: [{
267
- type: HostListener,
268
- args: ['input']
269
- }], onFocus: [{
270
- type: HostListener,
271
- args: ['focus']
272
- }], onblur: [{
273
- type: HostListener,
274
- args: ['blur']
275
- }] } });
276
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"currency-input.directive.js","sourceRoot":"","sources":["../../../../projects/ui/currency-input/currency-input.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { DecimalPipe, getCurrencySymbol } from '@angular/common';\r\nimport {\r\n\tDEFAULT_CURRENCY_CODE,\r\n\tDirective,\r\n\tElementRef,\r\n\tforwardRef,\r\n\tHostBinding,\r\n\tHostListener,\r\n\tInject,\r\n\tInput,\r\n\tLOCALE_ID,\r\n\tOnChanges,\r\n\tOnInit,\r\n\tOptional,\r\n\tRenderer2,\r\n\tSelf,\r\n\tɵfindLocaleData\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { MatFormField, MAT_FORM_FIELD } from '@angular/material/form-field';\r\nimport { MatInput } from '@angular/material/input';\r\nimport { noop } from 'rxjs';\r\n\r\n/* tslint:disable:no-empty */\r\nexport const noop_consumer = (_: any) => {};\r\n\r\n/**\r\n * This directive will enhance an input element to format the numbers entered to a currency amount.\r\n */\r\n@Directive({\r\n\tselector: 'input[buiCurrencyInput],input[currencyCode],input[data-type=currency]',\r\n\tproviders: [{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => CurrencyInputDirective), multi: true }]\r\n})\r\nexport class CurrencyInputDirective implements OnInit, OnChanges, ControlValueAccessor {\r\n\t/**\r\n\t * true to allow negative input, otherwise false\r\n\t * Default to false.\r\n\t */\r\n\t@Input()\r\n\tallowNegative: boolean = false;\r\n\r\n\t/**\r\n\t * Provide the currency code to format the entered amount.\r\n\t * Uses angular token DEFAULT_CURRENCY_CODE by default.\r\n\t */\r\n\t@Input()\r\n\tcurrencyCode: string = '';\r\n\r\n\t/**\r\n\t * true if no decimal digits allowed, otherwise false.\r\n\t * Default to false.\r\n\t */\r\n\t@Input()\r\n\tbaseUnitOnly = false;\r\n\r\n\t/**\r\n\t * The format the of the amount either in wide or narrow.\r\n\t */\r\n\t@Input()\r\n\tformat: 'narrow' | 'wide' = 'wide';\r\n\r\n\t@HostBinding('placeholder')\r\n\tprivate placeholder: string = '';\r\n\r\n\t@HostBinding('autocomplete')\r\n\tprivate autocomplete = 'off';\r\n\r\n\t@HostBinding('type')\r\n\tprivate type = 'text';\r\n\r\n\t@HostBinding('attr.inputmode')\r\n\tprivate inputMode = 'decimal';\r\n\r\n\tprivate change = noop_consumer;\r\n\tprivate onTouch = noop;\r\n\tprivate _safari: boolean;\r\n\tprivate _symbol: string = '$';\r\n\tprivate _decimalPipe!: DecimalPipe;\r\n\r\n\tprivate _ds = '.'; // decimal separator\r\n\tprivate _trailing = false;\r\n\r\n\tconstructor(\r\n\t\t@Self() private _el: ElementRef<HTMLInputElement>,\r\n\t\tprivate _renderer: Renderer2,\r\n\t\t@Inject(LOCALE_ID) private _locale: string,\r\n\t\t@Inject(DEFAULT_CURRENCY_CODE) private _defaultCurrencyCode: string,\r\n\t\t@Optional() @Inject(MAT_FORM_FIELD) private _field?: MatFormField\r\n\t) {\r\n\t\tconst userAgent = navigator.userAgent;\r\n\t\tthis._safari = !userAgent.match(/Firefox/i) && !userAgent.match(/Chrome/i) && !!userAgent.match(/safari/i);\r\n\t\tthis._currencyUpdated();\r\n\t}\r\n\r\n\tngOnInit() {}\r\n\r\n\tngOnChanges(): void {\r\n\t\tthis._currencyUpdated();\r\n\t\tthis.onInput();\r\n\t}\r\n\r\n\t@HostListener('input')\r\n\tonInput() {\r\n\t\tthis._formatCurrency(this._el, false, true);\r\n\t}\r\n\r\n\t@HostListener('focus')\r\n\tonFocus() {\r\n\t\tthis._formatCurrency(this._el, false, true);\r\n\t}\r\n\r\n\t@HostListener('blur')\r\n\tonblur() {\r\n\t\tthis.onTouch();\r\n\t\tthis._formatCurrency(this._el, true, false);\r\n\t}\r\n\r\n\twriteValue(value: any) {\r\n\t\tvalue = this._decimalPipe.transform(value);\r\n\t\tthis._renderer.setProperty(this._el.nativeElement, 'value', value);\r\n\t\tthis._formatCurrency(this._el, true, false);\r\n\t}\r\n\r\n\tregisterOnChange(fn: any) {\r\n\t\tthis.change = fn;\r\n\t}\r\n\r\n\tregisterOnTouched(fn: any) {\r\n\t\tthis.onTouch = fn;\r\n\t}\r\n\r\n\tprivate _updatePlaceholder() {\r\n\t\tthis.placeholder = this.placeholder || this._0Text;\r\n\t\tif (this._field?._control instanceof MatInput) {\r\n\t\t\tthis._field._control.placeholder = this.placeholder;\r\n\t\t}\r\n\t}\r\n\r\n\tprivate _currencyUpdated() {\r\n\t\tthis.currencyCode = this.currencyCode || this._defaultCurrencyCode;\r\n\t\tthis._symbol = getCurrencySymbol(this.currencyCode, this.format, this._locale) || '$';\r\n\t\tconst localeData = ɵfindLocaleData(this._locale);\r\n\t\tthis._ds = localeData[13][0];\r\n\t\tthis._decimalPipe = new DecimalPipe(this._locale);\r\n\t\tconst curFormat: string = localeData[14][2];\r\n\t\tthis._trailing = curFormat.indexOf('¤') > 0;\r\n\t\tthis._updatePlaceholder();\r\n\t}\r\n\r\n\tprivate _formatCurrency(input: ElementRef<HTMLInputElement>, blur: boolean, focus: boolean) {\r\n\t\t// appends $ to value, validates decimal side\r\n\t\t// and puts cursor back in right position.\r\n\t\t// get input value\r\n\t\tlet input_val = input.nativeElement.value;\r\n\r\n\t\t// don't validate empty input\r\n\t\tif (input_val === '') {\r\n\t\t\tthis.change(null);\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tconst minus = this.allowNegative ? '-' : '';\r\n\r\n\t\t// remove non digit values except currency symbol, decimal separator and hypen\r\n\t\tconst reg = new RegExp(`[^0-9${minus}${this._symbol}${this._ds}]`, 'g');\r\n\r\n\t\tlet sanitiseValue = input_val.replace(reg, '');\r\n\r\n\t\tif (sanitiseValue === '' || sanitiseValue === this._symbol) {\r\n\t\t\tthis.change(null);\r\n\t\t\tthis._renderer.setProperty(input.nativeElement, 'value', '');\r\n\t\t\treturn;\r\n\t\t} else if (\r\n\t\t\t(this.allowNegative && sanitiseValue === `-${this._symbol}`) ||\r\n\t\t\tsanitiseValue === '-' ||\r\n\t\t\tsanitiseValue === '--'\r\n\t\t) {\r\n\t\t\tthis.change(null);\r\n\t\t\tthis._renderer.setProperty(input.nativeElement, 'value', '-');\r\n\t\t\treturn;\r\n\t\t}\r\n\r\n\t\tconst negative = this.allowNegative && input_val.indexOf('-') >= 0;\r\n\r\n\t\t// original length\r\n\t\tconst original_len = input_val.length;\r\n\r\n\t\t// initial caret position\r\n\t\tlet caret_pos = input.nativeElement.selectionStart;\r\n\r\n\t\tinput_val = input_val.replace(RegExp(`[^0-9${minus}${this._ds}]`, 'g'), '').replace(/^\\.\\./, '');\r\n\t\t// check for decimal\r\n\t\tif (input_val.indexOf(this._ds) >= 0) {\r\n\t\t\t// get position of first decimal\r\n\t\t\t// this prevents multiple decimals from\r\n\t\t\t// being entered\r\n\t\t\tlet decimal_pos = input_val.indexOf(this._ds);\r\n\r\n\t\t\t// split number by decimal point\r\n\t\t\tlet left_side = input_val.substring(0, decimal_pos);\r\n\t\t\tlet right_side = input_val.substring(decimal_pos);\r\n\r\n\t\t\t// add commas to left side of number\r\n\t\t\tleft_side = this._formatNumber(left_side, blur) || '';\r\n\r\n\t\t\t// no value append a zero for decimal values\r\n\t\t\tif (!left_side.length) {\r\n\t\t\t\tleft_side = '0';\r\n\t\t\t}\r\n\r\n\t\t\tif (!this.baseUnitOnly) {\r\n\t\t\t\t// validate right side\r\n\t\t\t\tright_side = right_side.replace(/\\D/g, '');\r\n\r\n\t\t\t\t// Limit decimal to only 2 digits\r\n\t\t\t\tlet v = Number(`0.${right_side}`);\r\n\t\t\t\tif (v) {\r\n\t\t\t\t\tconst length = right_side.length > 1 ? 2 : 1;\r\n\t\t\t\t\tright_side = v.toFixed(length).substring(2, 4);\r\n\t\t\t\t}\r\n\r\n\t\t\t\t// On blur make sure 2 numbers after decimal\r\n\t\t\t\tif (blur) {\r\n\t\t\t\t\tright_side += '00';\r\n\t\t\t\t}\r\n\r\n\t\t\t\tright_side = right_side.substring(0, 2);\r\n\r\n\t\t\t\t// join number by .\r\n\t\t\t\tinput_val = left_side + this._ds + right_side;\r\n\t\t\t} else {\r\n\t\t\t\tinput_val = left_side;\r\n\t\t\t}\r\n\t\t} else {\r\n\t\t\tinput_val = this._formatNumber(input_val, blur);\r\n\r\n\t\t\t// final formatting\r\n\t\t\tif (blur && !this.baseUnitOnly) {\r\n\t\t\t\tinput_val += `${this._ds}00`;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tconst numStr = input_val;\r\n\t\t// append the currency symbol\r\n\t\tif (!this._safari || !focus) {\r\n\t\t\tif (this._trailing) {\r\n\t\t\t\tinput_val = input_val + ' ' + this._symbol;\r\n\t\t\t} else {\r\n\t\t\t\tinput_val = this._symbol + input_val;\r\n\t\t\t}\r\n\t\t}\r\n\r\n\t\tif (negative) {\r\n\t\t\t// append the hypen back to the value if a negative value was entered\r\n\t\t\tinput_val = `-${input_val}`;\r\n\t\t}\r\n\r\n\t\tconst num = this._convert((negative ? '-' : '') + numStr);\r\n\r\n\t\t// update control value first with the number\r\n\t\tthis.change(Number(num));\r\n\r\n\t\tif (blur && num === 0) {\r\n\t\t\tinput_val = this._0Text;\r\n\t\t}\r\n\r\n\t\t// update dom with the formatted value\r\n\t\tthis._renderer.setProperty(input.nativeElement, 'value', input_val);\r\n\t\t// put caret back in the right position\r\n\t\tlet updated_len = input_val.length;\r\n\t\tif (caret_pos) {\r\n\t\t\tcaret_pos = updated_len - original_len + caret_pos;\r\n\t\t\tif (input_val.substring(caret_pos - this._symbol.length) === this._symbol && this._trailing) {\r\n\t\t\t\tcaret_pos -= this._symbol.length + 1;\r\n\t\t\t}\r\n\t\t}\r\n\t\tif (!this._safari) {\r\n\t\t\tinput.nativeElement.setSelectionRange(caret_pos, caret_pos);\r\n\t\t}\r\n\t}\r\n\r\n\t// format the number into currency format\r\n\tprivate _formatNumber(n: string, blur: boolean = false) {\r\n\t\t// format number 1000000 to 1,234,567\r\n\t\tn = n.replace(/\\D/g, '');\r\n\t\tif (blur) {\r\n\t\t\tn = n.replace(/^0+/, '');\r\n\t\t}\r\n\t\treturn this._decimalPipe.transform(n, '1.0-0') as string;\r\n\t}\r\n\r\n\tprivate _convert(input: string): number {\r\n\t\tconst val = input\r\n\t\t\t.replace(this._ds, 'd')\r\n\t\t\t.replace(/[^0-9d-]/g, '')\r\n\t\t\t.replace('d', '.');\r\n\t\treturn parseFloat(val);\r\n\t}\r\n\r\n\tprivate get _0Text(): string {\r\n\t\tconst decimalStr = this.baseUnitOnly ? '' : `${this._ds}00`;\r\n\t\treturn this._trailing ? `0${decimalStr} ${this._symbol}` : `${this._symbol}0${decimalStr}`;\r\n\t}\r\n}\r\n"]}
@@ -1,19 +0,0 @@
1
- import { CommonModule } from '@angular/common';
2
- import { NgModule } from '@angular/core';
3
- import { CurrencyInputDirective } from './currency-input.directive';
4
- import * as i0 from "@angular/core";
5
- export class CurrencyInputModule {
6
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: CurrencyInputModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
7
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.2", ngImport: i0, type: CurrencyInputModule, declarations: [CurrencyInputDirective], imports: [CommonModule], exports: [CurrencyInputDirective] }); }
8
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: CurrencyInputModule, imports: [CommonModule] }); }
9
- }
10
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: CurrencyInputModule, decorators: [{
11
- type: NgModule,
12
- args: [{
13
- declarations: [CurrencyInputDirective],
14
- imports: [CommonModule],
15
- exports: [CurrencyInputDirective]
16
- }]
17
- }] });
18
- export { CurrencyInputDirective };
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY3VycmVuY3ktaW5wdXQubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkvY3VycmVuY3ktaW5wdXQvY3VycmVuY3ktaW5wdXQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDRCQUE0QixDQUFDOztBQU9wRSxNQUFNLE9BQU8sbUJBQW1COzhHQUFuQixtQkFBbUI7K0dBQW5CLG1CQUFtQixpQkFKaEIsc0JBQXNCLGFBQzNCLFlBQVksYUFDWixzQkFBc0I7K0dBRXBCLG1CQUFtQixZQUhyQixZQUFZOzsyRkFHVixtQkFBbUI7a0JBTC9CLFFBQVE7bUJBQUM7b0JBQ1QsWUFBWSxFQUFFLENBQUMsc0JBQXNCLENBQUM7b0JBQ3RDLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztvQkFDdkIsT0FBTyxFQUFFLENBQUMsc0JBQXNCLENBQUM7aUJBQ2pDOztBQUdELE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ3VycmVuY3lJbnB1dERpcmVjdGl2ZSB9IGZyb20gJy4vY3VycmVuY3ktaW5wdXQuZGlyZWN0aXZlJztcclxuXHJcbkBOZ01vZHVsZSh7XHJcblx0ZGVjbGFyYXRpb25zOiBbQ3VycmVuY3lJbnB1dERpcmVjdGl2ZV0sXHJcblx0aW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXHJcblx0ZXhwb3J0czogW0N1cnJlbmN5SW5wdXREaXJlY3RpdmVdXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBDdXJyZW5jeUlucHV0TW9kdWxlIHt9XHJcblxyXG5leHBvcnQgeyBDdXJyZW5jeUlucHV0RGlyZWN0aXZlIH07XHJcbiJdfQ==
@@ -1,2 +0,0 @@
1
- export * from './currency-input.module';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL2N1cnJlbmN5LWlucHV0L3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyx5QkFBeUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vY3VycmVuY3ktaW5wdXQubW9kdWxlJztcclxuIl19
@@ -1,5 +0,0 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './public-api';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnJhdnVyYS11aS1kZWNpbWFsLWlucHV0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvdWkvZGVjaW1hbC1pbnB1dC9icmF2dXJhLXVpLWRlY2ltYWwtaW5wdXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==
@@ -1,122 +0,0 @@
1
- import { DecimalPipe } from '@angular/common';
2
- import { Directive, forwardRef, HostBinding, HostListener, Input, Self } from '@angular/core';
3
- import { NG_VALUE_ACCESSOR } from '@angular/forms';
4
- import { noop } from 'rxjs';
5
- import * as i0 from "@angular/core";
6
- /* tslint:disable:no-empty */
7
- export const noop_consumer = (_) => { };
8
- /**
9
- * This directive will enhance an input element to format the numbers entered to a decimal amount.
10
- */
11
- export class DecimalInputDirective {
12
- constructor(_el, _renderer) {
13
- this._el = _el;
14
- this._renderer = _renderer;
15
- /**
16
- * number of decimal places allowed
17
- */
18
- this.buiDecimalInput = 2;
19
- this.placeholder = '';
20
- this.autocomplete = 'off';
21
- this.type = 'number';
22
- this.inputMode = 'decimal';
23
- this.change = noop_consumer;
24
- this.onTouch = noop;
25
- }
26
- ngOnChanges() {
27
- this.buiDecimalInput = this.buiDecimalInput || 2;
28
- this.onInput();
29
- }
30
- onInput() {
31
- const value = this._el.nativeElement.value;
32
- const decimalPart = value.split('.')[1];
33
- if (decimalPart && decimalPart.length > this.buiDecimalInput) {
34
- const indexOfPeriod = value.indexOf('.');
35
- const newValue = value.substring(0, indexOfPeriod + this.buiDecimalInput + 1);
36
- this._renderer.setProperty(this._el.nativeElement, 'value', newValue);
37
- }
38
- const resolvedValue = this._el.nativeElement.value;
39
- this.change(resolvedValue === '' || resolvedValue === null || resolvedValue === undefined ? null : Number(resolvedValue));
40
- }
41
- onKeypress(evt) {
42
- const target = evt.target;
43
- const value = target.value;
44
- const isSpace = evt.key === ' ';
45
- if (isSpace ||
46
- (!['.', '-'].includes(evt.key) && isNaN(Number(evt.key))) ||
47
- (evt.key === '.' && value.indexOf('.') > 0)) {
48
- evt.preventDefault();
49
- }
50
- }
51
- onblur() {
52
- this.onTouch();
53
- this._resetDecimalPlaces();
54
- }
55
- writeValue(value) {
56
- this._renderer.setProperty(this._el.nativeElement, 'value', value);
57
- this._resetDecimalPlaces();
58
- }
59
- registerOnChange(fn) {
60
- this.change = fn;
61
- }
62
- registerOnTouched(fn) {
63
- this.onTouch = fn;
64
- }
65
- _resetDecimalPlaces() {
66
- const value = this._el.nativeElement.value;
67
- if (value === '' || value === null || value === undefined) {
68
- return;
69
- }
70
- const splitValues = value.split('.');
71
- let newValue = '';
72
- if (splitValues[1] && splitValues[1].length > this.buiDecimalInput) {
73
- newValue = value.substring(0, splitValues[0].length + 1 + this.buiDecimalInput);
74
- }
75
- else {
76
- this.buiDecimalInput = this.buiDecimalInput < 0 ? 0 : this.buiDecimalInput;
77
- newValue = Number(value).toFixed(this.buiDecimalInput);
78
- }
79
- this._renderer.setProperty(this._el.nativeElement, 'value', newValue);
80
- }
81
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: DecimalInputDirective, deps: [{ token: i0.ElementRef, self: true }, { token: i0.Renderer2 }], target: i0.ɵɵFactoryTarget.Directive }); }
82
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "18.2.2", type: DecimalInputDirective, selector: "input[buiDecimalInput]", inputs: { buiDecimalInput: "buiDecimalInput" }, host: { listeners: { "input": "onInput()", "keypress": "onKeypress($event)", "blur": "onblur()" }, properties: { "placeholder": "this.placeholder", "autocomplete": "this.autocomplete", "type": "this.type", "attr.inputmode": "this.inputMode" } }, providers: [
83
- DecimalPipe,
84
- { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => DecimalInputDirective), multi: true }
85
- ], usesOnChanges: true, ngImport: i0 }); }
86
- }
87
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: DecimalInputDirective, decorators: [{
88
- type: Directive,
89
- args: [{
90
- selector: 'input[buiDecimalInput]',
91
- providers: [
92
- DecimalPipe,
93
- { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => DecimalInputDirective), multi: true }
94
- ]
95
- }]
96
- }], ctorParameters: () => [{ type: i0.ElementRef, decorators: [{
97
- type: Self
98
- }] }, { type: i0.Renderer2 }], propDecorators: { buiDecimalInput: [{
99
- type: Input
100
- }], placeholder: [{
101
- type: HostBinding,
102
- args: ['placeholder']
103
- }], autocomplete: [{
104
- type: HostBinding,
105
- args: ['autocomplete']
106
- }], type: [{
107
- type: HostBinding,
108
- args: ['type']
109
- }], inputMode: [{
110
- type: HostBinding,
111
- args: ['attr.inputmode']
112
- }], onInput: [{
113
- type: HostListener,
114
- args: ['input']
115
- }], onKeypress: [{
116
- type: HostListener,
117
- args: ['keypress', ['$event']]
118
- }], onblur: [{
119
- type: HostListener,
120
- args: ['blur']
121
- }] } });
122
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"decimal-input.directive.js","sourceRoot":"","sources":["../../../../projects/ui/decimal-input/decimal-input.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { DecimalPipe } from '@angular/common';\r\nimport {\r\n\tDirective,\r\n\tElementRef,\r\n\tforwardRef,\r\n\tHostBinding,\r\n\tHostListener,\r\n\tInput,\r\n\tOnChanges,\r\n\tRenderer2,\r\n\tSelf\r\n} from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { noop } from 'rxjs';\r\n\r\n/* tslint:disable:no-empty */\r\nexport const noop_consumer = (_: any) => {};\r\n\r\n/**\r\n * This directive will enhance an input element to format the numbers entered to a decimal amount.\r\n */\r\n@Directive({\r\n\tselector: 'input[buiDecimalInput]',\r\n\tproviders: [\r\n\t\tDecimalPipe,\r\n\t\t{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => DecimalInputDirective), multi: true }\r\n\t]\r\n})\r\nexport class DecimalInputDirective implements OnChanges, ControlValueAccessor {\r\n\t/**\r\n\t * number of decimal places allowed\r\n\t */\r\n\t@Input()\r\n\tbuiDecimalInput: number = 2;\r\n\r\n\t@HostBinding('placeholder')\r\n\tprivate placeholder: string = '';\r\n\r\n\t@HostBinding('autocomplete')\r\n\tprivate autocomplete = 'off';\r\n\r\n\t@HostBinding('type')\r\n\tprivate type = 'number';\r\n\r\n\t@HostBinding('attr.inputmode')\r\n\tprivate inputMode = 'decimal';\r\n\r\n\tprivate change = noop_consumer;\r\n\tprivate onTouch = noop;\r\n\r\n\tconstructor(@Self() private _el: ElementRef<HTMLInputElement>, private _renderer: Renderer2) {}\r\n\r\n\tngOnChanges(): void {\r\n\t\tthis.buiDecimalInput = this.buiDecimalInput || 2;\r\n\t\tthis.onInput();\r\n\t}\r\n\r\n\t@HostListener('input')\r\n\tonInput() {\r\n\t\tconst value = this._el.nativeElement.value;\r\n\r\n\t\tconst decimalPart = value.split('.')[1];\r\n\r\n\t\tif (decimalPart && decimalPart.length > this.buiDecimalInput) {\r\n\t\t\tconst indexOfPeriod = value.indexOf('.');\r\n\t\t\tconst newValue = value.substring(0, indexOfPeriod + this.buiDecimalInput + 1);\r\n\t\t\tthis._renderer.setProperty(this._el.nativeElement, 'value', newValue);\r\n\t\t}\r\n\t\tconst resolvedValue = this._el.nativeElement.value;\r\n\t\tthis.change(\r\n\t\t\tresolvedValue === '' || resolvedValue === null || resolvedValue === undefined ? null : Number(resolvedValue)\r\n\t\t);\r\n\t}\r\n\r\n\t@HostListener('keypress', ['$event'])\r\n\tonKeypress(evt: KeyboardEvent) {\r\n\t\tconst target = evt.target as HTMLInputElement;\r\n\t\tconst value = target.value;\r\n\t\tconst isSpace = evt.key === ' ';\r\n\r\n\t\tif (\r\n\t\t\tisSpace ||\r\n\t\t\t(!['.', '-'].includes(evt.key) && isNaN(Number(evt.key))) ||\r\n\t\t\t(evt.key === '.' && value.indexOf('.') > 0)\r\n\t\t) {\r\n\t\t\tevt.preventDefault();\r\n\t\t}\r\n\t}\r\n\r\n\t@HostListener('blur')\r\n\tonblur() {\r\n\t\tthis.onTouch();\r\n\t\tthis._resetDecimalPlaces();\r\n\t}\r\n\r\n\twriteValue(value: any) {\r\n\t\tthis._renderer.setProperty(this._el.nativeElement, 'value', value);\r\n\t\tthis._resetDecimalPlaces();\r\n\t}\r\n\r\n\tregisterOnChange(fn: any) {\r\n\t\tthis.change = fn;\r\n\t}\r\n\r\n\tregisterOnTouched(fn: any) {\r\n\t\tthis.onTouch = fn;\r\n\t}\r\n\r\n\tprivate _resetDecimalPlaces() {\r\n\t\tconst value = this._el.nativeElement.value;\r\n\t\tif (value === '' || value === null || value === undefined) {\r\n\t\t\treturn;\r\n\t\t}\r\n\t\tconst splitValues = value.split('.');\r\n\t\tlet newValue = '';\r\n\t\tif (splitValues[1] && splitValues[1].length > this.buiDecimalInput) {\r\n\t\t\tnewValue = value.substring(0, splitValues[0].length + 1 + this.buiDecimalInput);\r\n\t\t} else {\r\n\t\t\tthis.buiDecimalInput = this.buiDecimalInput < 0 ? 0 : this.buiDecimalInput;\r\n\t\t\tnewValue = Number(value).toFixed(this.buiDecimalInput);\r\n\t\t}\r\n\t\tthis._renderer.setProperty(this._el.nativeElement, 'value', newValue);\r\n\t}\r\n}\r\n"]}
@@ -1,19 +0,0 @@
1
- import { CommonModule } from '@angular/common';
2
- import { NgModule } from '@angular/core';
3
- import { DecimalInputDirective } from './decimal-input.directive';
4
- import * as i0 from "@angular/core";
5
- export class DecimalInputModule {
6
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: DecimalInputModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
7
- static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "18.2.2", ngImport: i0, type: DecimalInputModule, declarations: [DecimalInputDirective], imports: [CommonModule], exports: [DecimalInputDirective] }); }
8
- static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: DecimalInputModule, imports: [CommonModule] }); }
9
- }
10
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.2", ngImport: i0, type: DecimalInputModule, decorators: [{
11
- type: NgModule,
12
- args: [{
13
- declarations: [DecimalInputDirective],
14
- imports: [CommonModule],
15
- exports: [DecimalInputDirective]
16
- }]
17
- }] });
18
- export { DecimalInputDirective };
19
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVjaW1hbC1pbnB1dC5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy91aS9kZWNpbWFsLWlucHV0L2RlY2ltYWwtaW5wdXQubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3pDLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDJCQUEyQixDQUFDOztBQU9sRSxNQUFNLE9BQU8sa0JBQWtCOzhHQUFsQixrQkFBa0I7K0dBQWxCLGtCQUFrQixpQkFKZixxQkFBcUIsYUFDMUIsWUFBWSxhQUNaLHFCQUFxQjsrR0FFbkIsa0JBQWtCLFlBSHBCLFlBQVk7OzJGQUdWLGtCQUFrQjtrQkFMOUIsUUFBUTttQkFBQztvQkFDVCxZQUFZLEVBQUUsQ0FBQyxxQkFBcUIsQ0FBQztvQkFDckMsT0FBTyxFQUFFLENBQUMsWUFBWSxDQUFDO29CQUN2QixPQUFPLEVBQUUsQ0FBQyxxQkFBcUIsQ0FBQztpQkFDaEM7O0FBRUQsT0FBTyxFQUFFLHFCQUFxQixFQUFFLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IERlY2ltYWxJbnB1dERpcmVjdGl2ZSB9IGZyb20gJy4vZGVjaW1hbC1pbnB1dC5kaXJlY3RpdmUnO1xuXG5ATmdNb2R1bGUoe1xuXHRkZWNsYXJhdGlvbnM6IFtEZWNpbWFsSW5wdXREaXJlY3RpdmVdLFxuXHRpbXBvcnRzOiBbQ29tbW9uTW9kdWxlXSxcblx0ZXhwb3J0czogW0RlY2ltYWxJbnB1dERpcmVjdGl2ZV1cbn0pXG5leHBvcnQgY2xhc3MgRGVjaW1hbElucHV0TW9kdWxlIHt9XG5leHBvcnQgeyBEZWNpbWFsSW5wdXREaXJlY3RpdmUgfTtcbiJdfQ==
@@ -1,2 +0,0 @@
1
- export * from './decimal-input.module';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL2RlY2ltYWwtaW5wdXQvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLHdCQUF3QixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9kZWNpbWFsLWlucHV0Lm1vZHVsZSc7XG4iXX0=
@@ -1,5 +0,0 @@
1
- /**
2
- * Generated bundle index. Do not edit.
3
- */
4
- export * from './public-api';
5
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYnJhdnVyYS11aS1kaXNjcmV0ZS1pbnB1dC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL3VpL2Rpc2NyZXRlLWlucHV0L2JyYXZ1cmEtdWktZGlzY3JldGUtaW5wdXQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLGNBQWMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogR2VuZXJhdGVkIGJ1bmRsZSBpbmRleC4gRG8gbm90IGVkaXQuXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9wdWJsaWMtYXBpJztcbiJdfQ==