cilog-lib 1.2.7 → 1.3.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.
@@ -11,6 +11,7 @@ export var ColType;
11
11
  ColType["File"] = "File";
12
12
  ColType["Text"] = "Text";
13
13
  ColType["Number"] = "Number";
14
+ ColType["CilogNumber"] = "CilogNumber";
14
15
  ColType["SelectButton"] = "SelectButton";
15
16
  ColType["Switch"] = "Switch";
16
17
  ColType["Button"] = "Button";
@@ -43,4 +44,4 @@ export var ModeCalendar;
43
44
  ModeCalendar["Year"] = "year";
44
45
  ModeCalendar["Month"] = "month";
45
46
  })(ModeCalendar || (ModeCalendar = {}));
46
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JpbGxlLmVudW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jaWxvZy1saWIvc3JjL2xpYi9oZWxwZXJzL2VudW1zL2dyaWxsZS5lbnVtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLFFBSVg7QUFKRCxXQUFZLFFBQVE7SUFDaEIsMkJBQWUsQ0FBQTtJQUNmLHlCQUFhLENBQUE7SUFDYiw2QkFBaUIsQ0FBQTtBQUNyQixDQUFDLEVBSlcsUUFBUSxLQUFSLFFBQVEsUUFJbkI7QUFFRCxNQUFNLENBQU4sSUFBWSxPQVlYO0FBWkQsV0FBWSxPQUFPO0lBQ2Ysc0NBQTJCLENBQUE7SUFDM0IsZ0NBQXFCLENBQUE7SUFDckIsd0JBQWEsQ0FBQTtJQUNiLHdCQUFhLENBQUE7SUFDYiw0QkFBaUIsQ0FBQTtJQUNqQix3Q0FBNkIsQ0FBQTtJQUM3Qiw0QkFBaUIsQ0FBQTtJQUNqQiw0QkFBaUIsQ0FBQTtJQUNqQiwwQkFBZSxDQUFBO0lBQ2Ysd0JBQWEsQ0FBQTtJQUNiLDBCQUFlLENBQUE7QUFDbkIsQ0FBQyxFQVpXLE9BQU8sS0FBUCxPQUFPLFFBWWxCO0FBRUQsTUFBTSxDQUFOLElBQVksUUFPWDtBQVBELFdBQVksUUFBUTtJQUNoQixtQ0FBdUIsQ0FBQTtJQUN2QiwrQkFBbUIsQ0FBQTtJQUNuQix5QkFBYSxDQUFBO0lBQ2IsK0JBQW1CLENBQUE7SUFDbkIseUJBQWEsQ0FBQTtJQUNiLDZCQUFpQixDQUFBO0FBQ3JCLENBQUMsRUFQVyxRQUFRLEtBQVIsUUFBUSxRQU9uQjtBQUVELE1BQU0sQ0FBTixJQUFZLGFBR1g7QUFIRCxXQUFZLGFBQWE7SUFDckIsNEJBQVcsQ0FBQTtJQUNYLHNDQUFxQixDQUFBO0FBQ3pCLENBQUMsRUFIVyxhQUFhLEtBQWIsYUFBYSxRQUd4QjtBQUVELE1BQU0sQ0FBTixJQUFZLFdBR1g7QUFIRCxXQUFZLFdBQVc7SUFDbkIsbUNBQW9CLENBQUE7SUFDcEIsaUNBQWtCLENBQUE7QUFDdEIsQ0FBQyxFQUhXLFdBQVcsS0FBWCxXQUFXLFFBR3RCO0FBRUQsTUFBTSxDQUFOLElBQVksWUFJWDtBQUpELFdBQVksWUFBWTtJQUNwQiw2QkFBYSxDQUFBO0lBQ2IsNkJBQWEsQ0FBQTtJQUNiLCtCQUFlLENBQUE7QUFDbkIsQ0FBQyxFQUpXLFlBQVksS0FBWixZQUFZLFFBSXZCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gUG9zaXRpb24ge1xyXG4gICAgUmlnaHQgPSAncmlnaHQnLFxyXG4gICAgTGVmdCA9ICdsZWZ0JyxcclxuICAgIENlbnRlciA9ICdjZW50ZXInXHJcbn1cclxuXHJcbmV4cG9ydCBlbnVtIENvbFR5cGUge1xyXG4gICAgTXVsdGlTZWxlY3QgPSAnTXVsdGlTZWxlY3QnLFxyXG4gICAgRHJvcGRvd24gPSAnRHJvcGRvd24nLFxyXG4gICAgRmlsZSA9ICdGaWxlJyxcclxuICAgIFRleHQgPSAnVGV4dCcsXHJcbiAgICBOdW1iZXIgPSAnTnVtYmVyJyxcclxuICAgIFNlbGVjdEJ1dHRvbiA9ICdTZWxlY3RCdXR0b24nLFxyXG4gICAgU3dpdGNoID0gJ1N3aXRjaCcsXHJcbiAgICBCdXR0b24gPSAnQnV0dG9uJyxcclxuICAgIEltYWdlID0gJ0ltYWdlJyxcclxuICAgIERhdGUgPSAnRGF0ZScsXHJcbiAgICBTdGF0ZSA9ICdTdGF0ZSdcclxufVxyXG5cclxuZXhwb3J0IGVudW0gU2V2ZXJpdHkge1xyXG4gICAgU2Vjb25kYXJ5ID0gJ3NlY29uZGFyeScsXHJcbiAgICBTdWNjZXNzID0gJ3N1Y2Nlc3MnLFxyXG4gICAgSW5mbyA9ICdpbmZvJyxcclxuICAgIFdhcm5pbmcgPSAnd2FybmluZycsXHJcbiAgICBIZWxwID0gJ2hlbHAnLFxyXG4gICAgRGFuZ2VyID0gJ2RhbmdlcidcclxufVxyXG5cclxuZXhwb3J0IGVudW0gTW9kZVNlbGVjdGlvbiB7XHJcbiAgICBSb3cgPSAncm93JyxcclxuICAgIENoZWNrYm94ID0gJ2NoZWNrYm94J1xyXG59XHJcblxyXG5leHBvcnQgZW51bSBUaGVtZUdyaWxsZSB7XHJcbiAgICBCcm93biA9ICdncmlkX2Jyb3duJyxcclxuICAgIEdyZXkgPSAnZ3JpZF9ncmV5J1xyXG59XHJcblxyXG5leHBvcnQgZW51bSBNb2RlQ2FsZW5kYXIge1xyXG4gICAgRGF0ZSA9ICdkYXRlJyxcclxuICAgIFllYXIgPSAneWVhcicsXHJcbiAgICBNb250aCA9ICdtb250aCdcclxufVxyXG4iXX0=
47
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3JpbGxlLmVudW0uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jaWxvZy1saWIvc3JjL2xpYi9oZWxwZXJzL2VudW1zL2dyaWxsZS5lbnVtLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE1BQU0sQ0FBTixJQUFZLFFBSVg7QUFKRCxXQUFZLFFBQVE7SUFDaEIsMkJBQWUsQ0FBQTtJQUNmLHlCQUFhLENBQUE7SUFDYiw2QkFBaUIsQ0FBQTtBQUNyQixDQUFDLEVBSlcsUUFBUSxLQUFSLFFBQVEsUUFJbkI7QUFFRCxNQUFNLENBQU4sSUFBWSxPQWFYO0FBYkQsV0FBWSxPQUFPO0lBQ2Ysc0NBQTJCLENBQUE7SUFDM0IsZ0NBQXFCLENBQUE7SUFDckIsd0JBQWEsQ0FBQTtJQUNiLHdCQUFhLENBQUE7SUFDYiw0QkFBaUIsQ0FBQTtJQUNqQixzQ0FBMkIsQ0FBQTtJQUMzQix3Q0FBNkIsQ0FBQTtJQUM3Qiw0QkFBaUIsQ0FBQTtJQUNqQiw0QkFBaUIsQ0FBQTtJQUNqQiwwQkFBZSxDQUFBO0lBQ2Ysd0JBQWEsQ0FBQTtJQUNiLDBCQUFlLENBQUE7QUFDbkIsQ0FBQyxFQWJXLE9BQU8sS0FBUCxPQUFPLFFBYWxCO0FBRUQsTUFBTSxDQUFOLElBQVksUUFPWDtBQVBELFdBQVksUUFBUTtJQUNoQixtQ0FBdUIsQ0FBQTtJQUN2QiwrQkFBbUIsQ0FBQTtJQUNuQix5QkFBYSxDQUFBO0lBQ2IsK0JBQW1CLENBQUE7SUFDbkIseUJBQWEsQ0FBQTtJQUNiLDZCQUFpQixDQUFBO0FBQ3JCLENBQUMsRUFQVyxRQUFRLEtBQVIsUUFBUSxRQU9uQjtBQUVELE1BQU0sQ0FBTixJQUFZLGFBR1g7QUFIRCxXQUFZLGFBQWE7SUFDckIsNEJBQVcsQ0FBQTtJQUNYLHNDQUFxQixDQUFBO0FBQ3pCLENBQUMsRUFIVyxhQUFhLEtBQWIsYUFBYSxRQUd4QjtBQUVELE1BQU0sQ0FBTixJQUFZLFdBR1g7QUFIRCxXQUFZLFdBQVc7SUFDbkIsbUNBQW9CLENBQUE7SUFDcEIsaUNBQWtCLENBQUE7QUFDdEIsQ0FBQyxFQUhXLFdBQVcsS0FBWCxXQUFXLFFBR3RCO0FBRUQsTUFBTSxDQUFOLElBQVksWUFJWDtBQUpELFdBQVksWUFBWTtJQUNwQiw2QkFBYSxDQUFBO0lBQ2IsNkJBQWEsQ0FBQTtJQUNiLCtCQUFlLENBQUE7QUFDbkIsQ0FBQyxFQUpXLFlBQVksS0FBWixZQUFZLFFBSXZCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGVudW0gUG9zaXRpb24ge1xyXG4gICAgUmlnaHQgPSAncmlnaHQnLFxyXG4gICAgTGVmdCA9ICdsZWZ0JyxcclxuICAgIENlbnRlciA9ICdjZW50ZXInXHJcbn1cclxuXHJcbmV4cG9ydCBlbnVtIENvbFR5cGUge1xyXG4gICAgTXVsdGlTZWxlY3QgPSAnTXVsdGlTZWxlY3QnLFxyXG4gICAgRHJvcGRvd24gPSAnRHJvcGRvd24nLFxyXG4gICAgRmlsZSA9ICdGaWxlJyxcclxuICAgIFRleHQgPSAnVGV4dCcsXHJcbiAgICBOdW1iZXIgPSAnTnVtYmVyJyxcclxuICAgIENpbG9nTnVtYmVyID0gJ0NpbG9nTnVtYmVyJyxcclxuICAgIFNlbGVjdEJ1dHRvbiA9ICdTZWxlY3RCdXR0b24nLFxyXG4gICAgU3dpdGNoID0gJ1N3aXRjaCcsXHJcbiAgICBCdXR0b24gPSAnQnV0dG9uJyxcclxuICAgIEltYWdlID0gJ0ltYWdlJyxcclxuICAgIERhdGUgPSAnRGF0ZScsXHJcbiAgICBTdGF0ZSA9ICdTdGF0ZSdcclxufVxyXG5cclxuZXhwb3J0IGVudW0gU2V2ZXJpdHkge1xyXG4gICAgU2Vjb25kYXJ5ID0gJ3NlY29uZGFyeScsXHJcbiAgICBTdWNjZXNzID0gJ3N1Y2Nlc3MnLFxyXG4gICAgSW5mbyA9ICdpbmZvJyxcclxuICAgIFdhcm5pbmcgPSAnd2FybmluZycsXHJcbiAgICBIZWxwID0gJ2hlbHAnLFxyXG4gICAgRGFuZ2VyID0gJ2RhbmdlcidcclxufVxyXG5cclxuZXhwb3J0IGVudW0gTW9kZVNlbGVjdGlvbiB7XHJcbiAgICBSb3cgPSAncm93JyxcclxuICAgIENoZWNrYm94ID0gJ2NoZWNrYm94J1xyXG59XHJcblxyXG5leHBvcnQgZW51bSBUaGVtZUdyaWxsZSB7XHJcbiAgICBCcm93biA9ICdncmlkX2Jyb3duJyxcclxuICAgIEdyZXkgPSAnZ3JpZF9ncmV5J1xyXG59XHJcblxyXG5leHBvcnQgZW51bSBNb2RlQ2FsZW5kYXIge1xyXG4gICAgRGF0ZSA9ICdkYXRlJyxcclxuICAgIFllYXIgPSAneWVhcicsXHJcbiAgICBNb250aCA9ICdtb250aCdcclxufVxyXG4iXX0=
@@ -11,14 +11,17 @@ export class CilogInputNumberComponent {
11
11
  this.onBlur = new EventEmitter();
12
12
  this.valueStr = '';
13
13
  this.specialKeys = ['Tab', 'End', 'Home', 'ArrowLeft', 'ArrowRight'];
14
- this.onChangeE = (rating) => { };
15
- this.onTouchedE = () => { };
16
14
  }
17
15
  ngOnInit() {
18
16
  this.regex = new RegExp(`^-?\\d{1,3}(?:\\d{3})*(\\.\\d{0,${this.maxDecimals || Infinity}})?$|^-?\\d{1,3}(?:\\d{3})*\\,\\d{0,${this.maxDecimals || Infinity}}$`);
19
17
  }
20
18
  onKeyDownEvent(event) {
21
- if (this.specialKeys.indexOf(event.key) !== -1 || event.key == 'Enter') {
19
+ if (this.specialKeys.indexOf(event.key) !== -1) {
20
+ return;
21
+ }
22
+ if (event.key == 'Enter') {
23
+ this.onChangeInput(this.value);
24
+ this.onChange.emit(this.value);
22
25
  return;
23
26
  }
24
27
  let current = this.cilogInputNumber.nativeElement.value;
@@ -27,10 +30,9 @@ export class CilogInputNumberComponent {
27
30
  let next = current;
28
31
  if (event.key === '.') {
29
32
  let positionStartPoint = this.cilogInputNumber.nativeElement.selectionStart;
30
- next = [current.slice(0, positionStart), ',', current.slice(positionStart)].join('').replace(/\s/g, '');
33
+ next = [current.slice(0, positionStart), ',', current.slice(positionEnd)].join('').replace(/\s/g, '');
31
34
  if (String(next).match(this.regex)) {
32
- this.cilogInputNumber.nativeElement.value = (+next.replace(',', '.')).toLocaleString('fr-FR');
33
- this.onInputEvent();
35
+ this.acceptValue(next, false);
34
36
  }
35
37
  else {
36
38
  if (current.slice(positionStart)[0] == ',') {
@@ -38,63 +40,81 @@ export class CilogInputNumberComponent {
38
40
  this.cilogInputNumber.nativeElement.selectionEnd = positionStartPoint + 1;
39
41
  }
40
42
  }
41
- event.preventDefault();
42
43
  }
43
44
  else if (event.key === 'Backspace') {
44
- if (this.cilogInputNumber.nativeElement.selectionStart != this.cilogInputNumber.nativeElement.selectionEnd) {
45
- next = [current.slice(0, positionStart), current.slice(positionEnd)].join('').replace(/\s/g, '');
45
+ if (positionStart == positionEnd && /\s/g.test(current.slice(positionStart - 1, positionStart))) {
46
+ this.cilogInputNumber.nativeElement.selectionStart = positionStart - 1;
47
+ this.cilogInputNumber.nativeElement.selectionEnd = positionStart - 1;
46
48
  }
47
49
  else {
48
- next = [current.slice(0, positionStart - 1), current.slice(positionEnd)].join('').replace(/\s/g, '');
50
+ if (this.cilogInputNumber.nativeElement.selectionStart != this.cilogInputNumber.nativeElement.selectionEnd) {
51
+ next = [current.slice(0, positionStart), current.slice(positionEnd)].join('').replace(/\s/g, '');
52
+ }
53
+ else {
54
+ next = [current.slice(0, positionStart - 1), current.slice(positionEnd)].join('').replace(/\s/g, '');
55
+ }
56
+ this.checkValue(next, event);
49
57
  }
50
- this.checkValue(next);
51
58
  }
52
59
  else {
53
- next = [current.slice(0, positionStart), event.key, current.slice(positionStart)].join('').replace(/\s/g, '');
54
- this.checkValue(next);
55
60
  if (event.key === ',' && current.slice(positionStart)[0] == ',') {
56
61
  this.cilogInputNumber.nativeElement.selectionStart += 1;
57
62
  }
63
+ else {
64
+ next = [current.slice(0, positionStart), event.key, current.slice(positionEnd)].join('').replace(/\s/g, '');
65
+ this.checkValue(next, event);
66
+ }
58
67
  }
68
+ event.preventDefault();
59
69
  }
60
- checkValue(next) {
70
+ checkValue(next, event) {
61
71
  if (!String(next).match(this.regex)) {
62
- if (next != '') {
63
- event.preventDefault();
72
+ if (next == '') {
73
+ this.acceptValue(next, event);
64
74
  }
65
75
  }
66
76
  else {
67
77
  let number = +(next.replace(',', '.'));
68
- if (this.min != null && number < this.min) {
69
- event.preventDefault();
70
- }
71
- else if (this.max != null && number > this.max) {
72
- event.preventDefault();
78
+ if (this.min == null || number >= this.min) {
79
+ if (this.max == null || number <= this.max) {
80
+ this.acceptValue(next, event);
81
+ }
73
82
  }
74
83
  }
75
84
  }
76
- onInputEvent() {
77
- let positionStart = this.cilogInputNumber.nativeElement.selectionStart;
85
+ acceptValue(value, event) {
86
+ const positionStart = this.cilogInputNumber.nativeElement.selectionStart;
87
+ const positionEnd = this.cilogInputNumber.nativeElement.selectionEnd;
88
+ if (value != '') {
89
+ if (this.maxDecimals != null) {
90
+ this.cilogInputNumber.nativeElement.value = (+value.replace(',', '.')).toLocaleString('fr-FR', { maximumFractionDigits: this.maxDecimals });
91
+ }
92
+ else {
93
+ this.cilogInputNumber.nativeElement.value = (+value.replace(',', '.')).toLocaleString('fr-FR');
94
+ }
95
+ if (value.slice(-1) == ',') {
96
+ this.cilogInputNumber.nativeElement.value += ',';
97
+ }
98
+ }
99
+ else {
100
+ this.cilogInputNumber.nativeElement.value = '';
101
+ }
102
+ if (positionStart == positionEnd) {
103
+ this.cilogInputNumber.nativeElement.selectionStart = event.key != 'Backspace' ? (positionStart + 1) : (positionStart - 1);
104
+ this.cilogInputNumber.nativeElement.selectionEnd = event.key != 'Backspace' ? (positionStart + 1) : (positionStart - 1);
105
+ }
106
+ else {
107
+ this.cilogInputNumber.nativeElement.selectionStart = positionStart;
108
+ this.cilogInputNumber.nativeElement.selectionEnd = positionStart;
109
+ }
78
110
  if (this.cilogInputNumber.nativeElement.value.replace(/\s/g, '') == '' || this.cilogInputNumber.nativeElement.value.replace(/\s/g, '') == '-') {
79
111
  this.writeValue(null);
80
112
  }
81
113
  else {
82
114
  this.writeValue(+(this.cilogInputNumber.nativeElement.value.replace(',', '.').replaceAll(/\s/g, '')));
83
115
  }
116
+ this.onChangeInput(this.value);
84
117
  this.onInput.emit(this.value);
85
- setTimeout(() => {
86
- this.cilogInputNumber.nativeElement.selectionStart = positionStart;
87
- this.cilogInputNumber.nativeElement.selectionEnd = positionStart;
88
- });
89
- }
90
- onChangeEvent() {
91
- this.onChange.emit(this.value);
92
- }
93
- onBlurEvent(event) {
94
- this.onBlur.emit(this.value);
95
- }
96
- onFocusEvent(event) {
97
- this.onFocus.emit(this.value);
98
118
  }
99
119
  writeValue(value) {
100
120
  this.value = value;
@@ -102,17 +122,6 @@ export class CilogInputNumberComponent {
102
122
  this.valueStr = '';
103
123
  }
104
124
  else {
105
- //if (this.maxDecimals != null && this.maxDecimals > -1) {
106
- // if (this.value.toString().split('.').length == 2 && this.maxDecimals <= this.value.toString().split('.')[1].length) {
107
- // this.valueStr = this.value.toFixed(this.maxDecimals);
108
- // this.valueStr = this.valueStr;
109
- // } else {
110
- // this.valueStr = this.value.toString();
111
- // }
112
- //} else {
113
- // this.valueStr = this.value.toString();
114
- //}
115
- //this.valueStr = this.valueStr.replace('.', ',');
116
125
  if (this.maxDecimals != null) {
117
126
  this.valueStr = this.value.toLocaleString('fr-FR', { maximumFractionDigits: this.maxDecimals });
118
127
  }
@@ -121,21 +130,31 @@ export class CilogInputNumberComponent {
121
130
  }
122
131
  }
123
132
  }
133
+ onBlurEvent(event) {
134
+ this.onChangeInput(this.value);
135
+ this.onChange.emit(this.value);
136
+ this.onBlur.emit(this.value);
137
+ }
138
+ onFocusEvent(event) {
139
+ this.onFocus.emit(this.value);
140
+ }
141
+ onChangeInput(val) { }
142
+ onTouchedInput() { }
124
143
  registerOnChange(fn) {
125
- this.onChangeE = fn;
144
+ this.onChangeInput = fn;
126
145
  }
127
146
  registerOnTouched(fn) {
128
- this.onTouchedE = fn;
147
+ this.onTouchedInput = fn;
129
148
  }
130
149
  }
131
150
  CilogInputNumberComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: CilogInputNumberComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
132
- CilogInputNumberComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.0", type: CilogInputNumberComponent, selector: "cilog-input-number", inputs: { min: "min", max: "max", maxDecimals: "maxDecimals", prefixe: "prefixe", suffixe: "suffixe" }, outputs: { onInput: "onInput", onChange: "onChange", onFocus: "onFocus", onBlur: "onBlur" }, host: { listeners: { "keydown": "onKeyDownEvent($event)", "input": "onInputEvent($event)", "change": "onChangeEvent($event)" } }, providers: [
151
+ CilogInputNumberComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.0", type: CilogInputNumberComponent, selector: "cilog-input-number", inputs: { min: "min", max: "max", maxDecimals: "maxDecimals", prefixe: "prefixe", suffixe: "suffixe", inputStyleClass: "inputStyleClass" }, outputs: { onInput: "onInput", onChange: "onChange", onFocus: "onFocus", onBlur: "onBlur" }, host: { listeners: { "keydown": "onKeyDownEvent($event)" } }, providers: [
133
152
  {
134
153
  provide: NG_VALUE_ACCESSOR,
135
154
  useExisting: forwardRef(() => CilogInputNumberComponent),
136
155
  multi: true
137
156
  }
138
- ], viewQueries: [{ propertyName: "cilogInputNumber", first: true, predicate: ["cilogInputNumber"], descendants: true }], ngImport: i0, template: "<div class=\"input-group w-full\">\r\n\r\n <span class=\"input-group-addon prefixe\"\r\n *ngIf=\"prefixe != null\">\r\n {{ prefixe }}\r\n </span>\r\n\r\n <input #cilogInputNumber\r\n pInputText\r\n type=\"text\"\r\n [value]=\"valueStr\"\r\n (focus)=\"onFocusEvent($event)\"\r\n (blur)=\"onBlurEvent($event)\"\r\n class=\"w-full z-1\"\r\n [ngClass]=\"suffixe != null && prefixe != null ? 'border-noround' : prefixe != null ? 'border-noround-left' : suffixe != null ? 'border-noround-right' : null\" />\r\n\r\n <span class=\"input-group-addon suffixe\"\r\n *ngIf=\"suffixe != null\">\r\n {{ suffixe }}\r\n </span>\r\n\r\n</div>\r\n", styles: [":host ::ng-deep .input-group{display:flex}:host ::ng-deep .input-group-addon{background-color:#fff;border:1px solid #ccc;padding:9px 12px;max-width:5rem;overflow:hidden;font-weight:700}:host ::ng-deep .prefixe{border-radius:4px 0 0 4px;border-right:none}:host ::ng-deep .suffixe{border-radius:0 4px 4px 0;border-left:none}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.InputText, selector: "[pInputText]" }] });
157
+ ], viewQueries: [{ propertyName: "cilogInputNumber", first: true, predicate: ["cilogInputNumber"], descendants: true }], ngImport: i0, template: "<div class=\"input-group w-full\">\r\n\r\n <span class=\"input-group-addon prefixe\"\r\n *ngIf=\"prefixe != null\">\r\n {{ prefixe }}\r\n </span>\r\n\r\n <input #cilogInputNumber\r\n pInputText\r\n type=\"text\"\r\n [value]=\"valueStr\"\r\n (focus)=\"onFocusEvent($event)\"\r\n (blur)=\"onBlurEvent($event)\"\r\n [class]=\"'w-full z-1' + (inputStyleClass == null ? '' : ' ' + inputStyleClass)\"\r\n [ngClass]=\"suffixe != null && prefixe != null ? 'border-noround' : prefixe != null ? 'border-noround-left' : suffixe != null ? 'border-noround-right' : null\" />\r\n\r\n <span class=\"input-group-addon suffixe\"\r\n *ngIf=\"suffixe != null\">\r\n {{ suffixe }}\r\n </span>\r\n\r\n</div>\r\n", styles: [":host ::ng-deep .input-group{display:flex}:host ::ng-deep .input-group-addon{background-color:#fff;border:1px solid #ccc;padding:9px 12px;max-width:5rem;overflow:hidden;font-weight:700}:host ::ng-deep .prefixe{border-radius:4px 0 0 4px;border-right:none}:host ::ng-deep .suffixe{border-radius:0 4px 4px 0;border-left:none}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.InputText, selector: "[pInputText]" }] });
139
158
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImport: i0, type: CilogInputNumberComponent, decorators: [{
140
159
  type: Component,
141
160
  args: [{ selector: 'cilog-input-number', providers: [
@@ -144,7 +163,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImpor
144
163
  useExisting: forwardRef(() => CilogInputNumberComponent),
145
164
  multi: true
146
165
  }
147
- ], template: "<div class=\"input-group w-full\">\r\n\r\n <span class=\"input-group-addon prefixe\"\r\n *ngIf=\"prefixe != null\">\r\n {{ prefixe }}\r\n </span>\r\n\r\n <input #cilogInputNumber\r\n pInputText\r\n type=\"text\"\r\n [value]=\"valueStr\"\r\n (focus)=\"onFocusEvent($event)\"\r\n (blur)=\"onBlurEvent($event)\"\r\n class=\"w-full z-1\"\r\n [ngClass]=\"suffixe != null && prefixe != null ? 'border-noround' : prefixe != null ? 'border-noround-left' : suffixe != null ? 'border-noround-right' : null\" />\r\n\r\n <span class=\"input-group-addon suffixe\"\r\n *ngIf=\"suffixe != null\">\r\n {{ suffixe }}\r\n </span>\r\n\r\n</div>\r\n", styles: [":host ::ng-deep .input-group{display:flex}:host ::ng-deep .input-group-addon{background-color:#fff;border:1px solid #ccc;padding:9px 12px;max-width:5rem;overflow:hidden;font-weight:700}:host ::ng-deep .prefixe{border-radius:4px 0 0 4px;border-right:none}:host ::ng-deep .suffixe{border-radius:0 4px 4px 0;border-left:none}\n"] }]
166
+ ], template: "<div class=\"input-group w-full\">\r\n\r\n <span class=\"input-group-addon prefixe\"\r\n *ngIf=\"prefixe != null\">\r\n {{ prefixe }}\r\n </span>\r\n\r\n <input #cilogInputNumber\r\n pInputText\r\n type=\"text\"\r\n [value]=\"valueStr\"\r\n (focus)=\"onFocusEvent($event)\"\r\n (blur)=\"onBlurEvent($event)\"\r\n [class]=\"'w-full z-1' + (inputStyleClass == null ? '' : ' ' + inputStyleClass)\"\r\n [ngClass]=\"suffixe != null && prefixe != null ? 'border-noround' : prefixe != null ? 'border-noround-left' : suffixe != null ? 'border-noround-right' : null\" />\r\n\r\n <span class=\"input-group-addon suffixe\"\r\n *ngIf=\"suffixe != null\">\r\n {{ suffixe }}\r\n </span>\r\n\r\n</div>\r\n", styles: [":host ::ng-deep .input-group{display:flex}:host ::ng-deep .input-group-addon{background-color:#fff;border:1px solid #ccc;padding:9px 12px;max-width:5rem;overflow:hidden;font-weight:700}:host ::ng-deep .prefixe{border-radius:4px 0 0 4px;border-right:none}:host ::ng-deep .suffixe{border-radius:0 4px 4px 0;border-left:none}\n"] }]
148
167
  }], ctorParameters: function () { return []; }, propDecorators: { min: [{
149
168
  type: Input
150
169
  }], max: [{
@@ -155,6 +174,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImpor
155
174
  type: Input
156
175
  }], suffixe: [{
157
176
  type: Input
177
+ }], inputStyleClass: [{
178
+ type: Input
158
179
  }], onInput: [{
159
180
  type: Output
160
181
  }], onChange: [{
@@ -169,11 +190,5 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.0", ngImpor
169
190
  }], onKeyDownEvent: [{
170
191
  type: HostListener,
171
192
  args: ['keydown', ['$event']]
172
- }], onInputEvent: [{
173
- type: HostListener,
174
- args: ['input', ['$event']]
175
- }], onChangeEvent: [{
176
- type: HostListener,
177
- args: ['change', ['$event']]
178
193
  }] } });
179
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cilog-input-number.component.js","sourceRoot":"","sources":["../../../../../../projects/cilog-lib/src/lib/views/cilog-input-number/cilog-input-number.component.ts","../../../../../../projects/cilog-lib/src/lib/views/cilog-input-number/cilog-input-number.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, forwardRef, HostListener, Input, OnInit, Output, ViewChild } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\n@Component({\n    selector: 'cilog-input-number',\n    templateUrl: './cilog-input-number.component.html',\n    styleUrls: ['./cilog-input-number.component.scss'],\n    providers: [\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: forwardRef(() => CilogInputNumberComponent),\r\n            multi: true\r\n        }\r\n    ]\n})\nexport class CilogInputNumberComponent implements OnInit, ControlValueAccessor {\n\n    value: number;\n\n    @Input() min: number;\r\n    @Input() max: number;\n    @Input() maxDecimals: number;\n    @Input() prefixe: string;\n    @Input() suffixe: string;\n\n    @Output() onInput: EventEmitter<number> = new EventEmitter<number>();\n    @Output() onChange: EventEmitter<number> = new EventEmitter<number>();\n    @Output() onFocus: EventEmitter<number> = new EventEmitter<number>();\n    @Output() onBlur: EventEmitter<number> = new EventEmitter<number>();\n\n    valueStr: string = '';\n\n    @ViewChild('cilogInputNumber') cilogInputNumber: ElementRef;\n\n    private regex: RegExp;\n    private specialKeys: Array<string> = ['Tab', 'End', 'Home', 'ArrowLeft', 'ArrowRight'];\n\n    constructor() { }\r\n\n    ngOnInit() {\n        this.regex = new RegExp(`^-?\\\\d{1,3}(?:\\\\d{3})*(\\\\.\\\\d{0,${this.maxDecimals || Infinity}})?$|^-?\\\\d{1,3}(?:\\\\d{3})*\\\\,\\\\d{0,${this.maxDecimals || Infinity}}$`);\n    }\n\n    @HostListener('keydown', ['$event'])\n    onKeyDownEvent(event: KeyboardEvent) {\n        if (this.specialKeys.indexOf(event.key) !== -1 || event.key == 'Enter') {\n            return;\n        }\n\n        let current: string = this.cilogInputNumber.nativeElement.value;\n\n        const positionStart = this.cilogInputNumber.nativeElement.selectionStart;\n        const positionEnd = this.cilogInputNumber.nativeElement.selectionEnd;\n\n        let next: string = current;\n        if (event.key === '.') {\n            let positionStartPoint: number = this.cilogInputNumber.nativeElement.selectionStart;\n            next = [current.slice(0, positionStart), ',', current.slice(positionStart)].join('').replace(/\\s/g, '');\n            if (String(next).match(this.regex)) {\n                this.cilogInputNumber.nativeElement.value = (+next.replace(',', '.')).toLocaleString('fr-FR');\r\n                this.onInputEvent();\r\n            } else {\n                if (current.slice(positionStart)[0] == ',') {\r\n                    this.cilogInputNumber.nativeElement.selectionStart = positionStartPoint + 1;\n                    this.cilogInputNumber.nativeElement.selectionEnd = positionStartPoint + 1;\r\n                }\r\n            }\n            event.preventDefault();\n        } else if (event.key === 'Backspace') {\n            if (this.cilogInputNumber.nativeElement.selectionStart != this.cilogInputNumber.nativeElement.selectionEnd) {\n                next = [current.slice(0, positionStart), current.slice(positionEnd)].join('').replace(/\\s/g, '');\r\n            } else {\n                next = [current.slice(0, positionStart - 1), current.slice(positionEnd)].join('').replace(/\\s/g, '');\r\n            }\n            this.checkValue(next);\n        } else {\n            next = [current.slice(0, positionStart), event.key, current.slice(positionStart)].join('').replace(/\\s/g, '');\n            this.checkValue(next);\n            if (event.key === ',' && current.slice(positionStart)[0] == ',') {\n                this.cilogInputNumber.nativeElement.selectionStart += 1;\r\n            }\n        }\n    }\n\n    checkValue(next: string) {\n        if (!String(next).match(this.regex)) {\n            if (next != '') {\n                event.preventDefault();\r\n            }\n        } else {\n            let number: number = +(next.replace(',', '.'));\n            if (this.min != null && number < this.min) {\n                event.preventDefault();\n            } else if (this.max != null && number > this.max) {\n                event.preventDefault();\n            }\r\n        }\r\n    }\n\n    @HostListener('input', ['$event'])\n    onInputEvent() {\r\n        let positionStart = this.cilogInputNumber.nativeElement.selectionStart;\r\n        if (this.cilogInputNumber.nativeElement.value.replace(/\\s/g, '') == '' || this.cilogInputNumber.nativeElement.value.replace(/\\s/g, '') == '-') {\r\n            this.writeValue(null);\r\n        } else {\r\n            this.writeValue(+(this.cilogInputNumber.nativeElement.value.replace(',', '.').replaceAll(/\\s/g, '')));\r\n        }\r\n        this.onInput.emit(this.value);\r\n        setTimeout(() => {\r\n            this.cilogInputNumber.nativeElement.selectionStart = positionStart;\r\n            this.cilogInputNumber.nativeElement.selectionEnd = positionStart;\r\n        });\r\n    }\n\n    @HostListener('change', ['$event'])\n    onChangeEvent() {\r\n        this.onChange.emit(this.value);\r\n    }\n\n    onBlurEvent(event) {\r\n        this.onBlur.emit(this.value);\r\n    }\n\n    onFocusEvent(event) {\r\n        this.onFocus.emit(this.value);\r\n    }\n\r\n    onChangeE = (rating: number) => { };\r\n\r\n    onTouchedE = () => { };\n\n    writeValue(value: number): void {\r\n        this.value = value;\n        if (this.value == null) {\n            this.valueStr = '';\r\n        } else {\n            //if (this.maxDecimals != null && this.maxDecimals > -1) {\n            //    if (this.value.toString().split('.').length == 2 && this.maxDecimals <= this.value.toString().split('.')[1].length) {\n            //        this.valueStr = this.value.toFixed(this.maxDecimals);\n            //        this.valueStr = this.valueStr;\n            //    } else {\n            //        this.valueStr = this.value.toString();\r\n            //    }\n            //} else {\n            //    this.valueStr = this.value.toString();\r\n            //}\r\n            //this.valueStr = this.valueStr.replace('.', ',');\r\n            if (this.maxDecimals != null) {\r\n                this.valueStr = this.value.toLocaleString('fr-FR', { maximumFractionDigits: this.maxDecimals });\r\n            } else {\r\n                this.valueStr = this.value.toLocaleString('fr-FR');\r\n            }\r\n        }\r\n    }\r\n\r\n    registerOnChange(fn: (data: number) => void): void {\r\n        this.onChangeE = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: () => void): void {\r\n        this.onTouchedE = fn;\r\n    }\n}\n","<div class=\"input-group w-full\">\r\n\r\n    <span class=\"input-group-addon prefixe\"\r\n          *ngIf=\"prefixe != null\">\r\n        {{ prefixe }}\r\n    </span>\r\n\r\n    <input #cilogInputNumber\r\n           pInputText\r\n           type=\"text\"\r\n           [value]=\"valueStr\"\r\n           (focus)=\"onFocusEvent($event)\"\r\n           (blur)=\"onBlurEvent($event)\"\r\n           class=\"w-full z-1\"\r\n           [ngClass]=\"suffixe != null && prefixe != null ? 'border-noround' : prefixe != null ? 'border-noround-left' : suffixe != null ? 'border-noround-right' : null\" />\r\n\r\n    <span class=\"input-group-addon suffixe\"\r\n          *ngIf=\"suffixe != null\">\r\n        {{ suffixe }}\r\n    </span>\r\n\r\n</div>\r\n"]}
194
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cilog-input-number.component.js","sourceRoot":"","sources":["../../../../../../projects/cilog-lib/src/lib/views/cilog-input-number/cilog-input-number.component.ts","../../../../../../projects/cilog-lib/src/lib/views/cilog-input-number/cilog-input-number.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, forwardRef, HostListener, Input, OnInit, Output, ViewChild } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\n\n@Component({\n    selector: 'cilog-input-number',\n    templateUrl: './cilog-input-number.component.html',\n    styleUrls: ['./cilog-input-number.component.scss'],\n    providers: [\r\n        {\r\n            provide: NG_VALUE_ACCESSOR,\r\n            useExisting: forwardRef(() => CilogInputNumberComponent),\r\n            multi: true\r\n        }\r\n    ]\n})\nexport class CilogInputNumberComponent implements OnInit, ControlValueAccessor {\n\n    value: number;\n\n    @Input() min: number;\r\n    @Input() max: number;\n    @Input() maxDecimals: number;\n    @Input() prefixe: string;\n    @Input() suffixe: string;\n    @Input() inputStyleClass: string;\n\n    @Output() onInput: EventEmitter<number> = new EventEmitter<number>();\n    @Output() onChange: EventEmitter<number> = new EventEmitter<number>();\n    @Output() onFocus: EventEmitter<number> = new EventEmitter<number>();\n    @Output() onBlur: EventEmitter<number> = new EventEmitter<number>();\n\n    valueStr: string = '';\n\n    @ViewChild('cilogInputNumber') cilogInputNumber: ElementRef;\n\n    private regex: RegExp;\n    private specialKeys: Array<string> = ['Tab', 'End', 'Home', 'ArrowLeft', 'ArrowRight'];\n\n    constructor() { }\r\n\n    ngOnInit() {\n        this.regex = new RegExp(`^-?\\\\d{1,3}(?:\\\\d{3})*(\\\\.\\\\d{0,${this.maxDecimals || Infinity}})?$|^-?\\\\d{1,3}(?:\\\\d{3})*\\\\,\\\\d{0,${this.maxDecimals || Infinity}}$`);\n    }\n\n    @HostListener('keydown', ['$event'])\n    onKeyDownEvent(event: KeyboardEvent) {\n\n        if (this.specialKeys.indexOf(event.key) !== -1) {\n            return;\n        }\n\n        if (event.key == 'Enter') {\r\n            this.onChangeInput(this.value);\r\n            this.onChange.emit(this.value);\r\n            return;\r\n        }\n\n        let current: string = this.cilogInputNumber.nativeElement.value;\n\n        const positionStart = this.cilogInputNumber.nativeElement.selectionStart;\n        const positionEnd = this.cilogInputNumber.nativeElement.selectionEnd;\n\n        let next: string = current;\n        if (event.key === '.') {\n            let positionStartPoint: number = this.cilogInputNumber.nativeElement.selectionStart;\n            next = [current.slice(0, positionStart), ',', current.slice(positionEnd)].join('').replace(/\\s/g, '');\n            if (String(next).match(this.regex)) {\r\n                this.acceptValue(next, false);\r\n            } else {\n                if (current.slice(positionStart)[0] == ',') {\r\n                    this.cilogInputNumber.nativeElement.selectionStart = positionStartPoint + 1;\n                    this.cilogInputNumber.nativeElement.selectionEnd = positionStartPoint + 1;\r\n                }\r\n            }\n        } else if (event.key === 'Backspace') {\n            if (positionStart == positionEnd && /\\s/g.test(current.slice(positionStart - 1, positionStart))) {\r\n                this.cilogInputNumber.nativeElement.selectionStart = positionStart - 1;\n                this.cilogInputNumber.nativeElement.selectionEnd = positionStart - 1;\r\n            } else {\n                if (this.cilogInputNumber.nativeElement.selectionStart != this.cilogInputNumber.nativeElement.selectionEnd) {\n                    next = [current.slice(0, positionStart), current.slice(positionEnd)].join('').replace(/\\s/g, '');\r\n                } else {\n                    next = [current.slice(0, positionStart - 1), current.slice(positionEnd)].join('').replace(/\\s/g, '');\r\n                }\n                this.checkValue(next, event);\r\n            }\n        } else {\n            if (event.key === ',' && current.slice(positionStart)[0] == ',') {\n                this.cilogInputNumber.nativeElement.selectionStart += 1;\r\n            } else {\n                next = [current.slice(0, positionStart), event.key, current.slice(positionEnd)].join('').replace(/\\s/g, '');\n                this.checkValue(next, event);\r\n            }\n        }\n        event.preventDefault();\n    }\n\n    checkValue(next: string, event) {\n        if (!String(next).match(this.regex)) {\n            if (next == '') {\n                this.acceptValue(next, event);\r\n            }\n        } else {\n            let number: number = +(next.replace(',', '.'));\r\n            if (this.min == null || number >= this.min) {\r\n                if (this.max == null || number <= this.max) {\n                    this.acceptValue(next, event);\n                }\r\n            }\r\n        }\r\n    }\n\n    acceptValue(value: string, event) {\n        const positionStart = this.cilogInputNumber.nativeElement.selectionStart;\n        const positionEnd = this.cilogInputNumber.nativeElement.selectionEnd;\n\n        if (value != '') {\n            if (this.maxDecimals != null) {\r\n                this.cilogInputNumber.nativeElement.value = (+value.replace(',', '.')).toLocaleString('fr-FR', { maximumFractionDigits: this.maxDecimals });\r\n            } else {\r\n                this.cilogInputNumber.nativeElement.value = (+value.replace(',', '.')).toLocaleString('fr-FR');\r\n            }\r\n            if (value.slice(-1) == ',') {\r\n                this.cilogInputNumber.nativeElement.value += ',';\r\n            }\r\n        } else {\n            this.cilogInputNumber.nativeElement.value = '';\r\n        }\n\n        if (positionStart == positionEnd) {\n\n            this.cilogInputNumber.nativeElement.selectionStart = event.key != 'Backspace' ? (positionStart + 1) : (positionStart - 1);\r\n            this.cilogInputNumber.nativeElement.selectionEnd = event.key != 'Backspace' ? (positionStart + 1) : (positionStart - 1);\r\n        } else {\n            this.cilogInputNumber.nativeElement.selectionStart = positionStart;\r\n            this.cilogInputNumber.nativeElement.selectionEnd = positionStart;\r\n        }\n\n        if (this.cilogInputNumber.nativeElement.value.replace(/\\s/g, '') == '' || this.cilogInputNumber.nativeElement.value.replace(/\\s/g, '') == '-') {\r\n            this.writeValue(null);\r\n        } else {\r\n            this.writeValue(+(this.cilogInputNumber.nativeElement.value.replace(',', '.').replaceAll(/\\s/g, '')));\r\n        }\r\n        this.onChangeInput(this.value);\r\n        this.onInput.emit(this.value);\r\n    }\n\n    writeValue(value: number): void {\r\n        this.value = value;\n        if (this.value == null) {\n            this.valueStr = '';\r\n        } else {\r\n            if (this.maxDecimals != null) {\r\n                this.valueStr = this.value.toLocaleString('fr-FR', { maximumFractionDigits: this.maxDecimals });\r\n            } else {\r\n                this.valueStr = this.value.toLocaleString('fr-FR');\r\n            }\r\n        }\r\n    }\n\n    onBlurEvent(event) {\r\n        this.onChangeInput(this.value);\r\n        this.onChange.emit(this.value);\r\n        this.onBlur.emit(this.value);\r\n    }\n\n    onFocusEvent(event) {\r\n        this.onFocus.emit(this.value);\r\n    }\n\r\n    onChangeInput(val: number) { }\r\n\r\n    onTouchedInput() { }\r\n\r\n    registerOnChange(fn: () => void): void {\r\n        this.onChangeInput = fn;\r\n    }\r\n\r\n    registerOnTouched(fn: () => void): void {\r\n        this.onTouchedInput = fn;\r\n    }\n}\n","<div class=\"input-group w-full\">\r\n\r\n    <span class=\"input-group-addon prefixe\"\r\n          *ngIf=\"prefixe != null\">\r\n        {{ prefixe }}\r\n    </span>\r\n\r\n    <input #cilogInputNumber\r\n           pInputText\r\n           type=\"text\"\r\n           [value]=\"valueStr\"\r\n           (focus)=\"onFocusEvent($event)\"\r\n           (blur)=\"onBlurEvent($event)\"\r\n           [class]=\"'w-full z-1' + (inputStyleClass == null ? '' : ' ' + inputStyleClass)\"\r\n           [ngClass]=\"suffixe != null && prefixe != null ? 'border-noround' : prefixe != null ? 'border-noround-left' : suffixe != null ? 'border-noround-right' : null\" />\r\n\r\n    <span class=\"input-group-addon suffixe\"\r\n          *ngIf=\"suffixe != null\">\r\n        {{ suffixe }}\r\n    </span>\r\n\r\n</div>\r\n"]}