@sd-angular/core 1.1.70 → 1.1.73
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/autocomplete/sd-angular-core-autocomplete.metadata.json +1 -1
- package/bundles/sd-angular-core-autocomplete.umd.js +1 -1
- package/bundles/sd-angular-core-autocomplete.umd.js.map +1 -1
- package/bundles/sd-angular-core-autocomplete.umd.min.js +1 -1
- package/bundles/sd-angular-core-autocomplete.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-comment.umd.js +2 -2
- package/bundles/sd-angular-core-comment.umd.js.map +1 -1
- package/bundles/sd-angular-core-comment.umd.min.js +1 -1
- package/bundles/sd-angular-core-comment.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-form.umd.js +6 -4
- package/bundles/sd-angular-core-form.umd.js.map +1 -1
- package/bundles/sd-angular-core-form.umd.min.js +1 -1
- package/bundles/sd-angular-core-form.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-grid-material.umd.js +1 -1
- package/bundles/sd-angular-core-grid-material.umd.js.map +1 -1
- package/bundles/sd-angular-core-grid-material.umd.min.js +1 -1
- package/bundles/sd-angular-core-grid-material.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-grid.umd.js +1 -1
- package/bundles/sd-angular-core-grid.umd.js.map +1 -1
- package/bundles/sd-angular-core-grid.umd.min.js +1 -1
- package/bundles/sd-angular-core-grid.umd.min.js.map +1 -1
- package/bundles/sd-angular-core-input-number.umd.js +745 -0
- package/bundles/sd-angular-core-input-number.umd.js.map +1 -0
- package/bundles/sd-angular-core-input-number.umd.min.js +16 -0
- package/bundles/sd-angular-core-input-number.umd.min.js.map +1 -0
- package/bundles/sd-angular-core-popover.umd.js +3 -1
- package/bundles/sd-angular-core-popover.umd.js.map +1 -1
- package/bundles/sd-angular-core-popover.umd.min.js +1 -1
- package/bundles/sd-angular-core-popover.umd.min.js.map +1 -1
- package/bundles/sd-angular-core.umd.js +4 -4
- package/bundles/sd-angular-core.umd.min.js +1 -1
- package/bundles/sd-angular-core.umd.min.js.map +1 -1
- package/comment/sd-angular-core-comment.metadata.json +1 -1
- package/esm2015/autocomplete/src/lib/autocomplete.component.js +2 -2
- package/esm2015/comment/src/lib/comment.component.js +3 -3
- package/esm2015/form/src/lib/form.module.js +4 -1
- package/esm2015/grid/src/lib/components/grid-desktop-column-edit/grid-desktop-column-edit.component.js +2 -2
- package/esm2015/grid-material/src/lib/components/desktop-cell-editor/desktop-cell-editor.component.js +2 -2
- package/esm2015/input-number/index.js +2 -0
- package/esm2015/input-number/sd-angular-core-input-number.js +5 -0
- package/esm2015/input-number/src/lib/input-number.component.js +335 -0
- package/esm2015/input-number/src/lib/input-number.module.js +34 -0
- package/esm2015/input-number/src/public-api.js +6 -0
- package/esm2015/popover/src/lib/directives/popover-trigger.directive.js +4 -2
- package/esm2015/public-api.js +2 -1
- package/fesm2015/sd-angular-core-autocomplete.js +1 -1
- package/fesm2015/sd-angular-core-autocomplete.js.map +1 -1
- package/fesm2015/sd-angular-core-comment.js +2 -2
- package/fesm2015/sd-angular-core-comment.js.map +1 -1
- package/fesm2015/sd-angular-core-form.js +3 -0
- package/fesm2015/sd-angular-core-form.js.map +1 -1
- package/fesm2015/sd-angular-core-grid-material.js +1 -1
- package/fesm2015/sd-angular-core-grid-material.js.map +1 -1
- package/fesm2015/sd-angular-core-grid.js +1 -1
- package/fesm2015/sd-angular-core-grid.js.map +1 -1
- package/fesm2015/sd-angular-core-input-number.js +373 -0
- package/fesm2015/sd-angular-core-input-number.js.map +1 -0
- package/fesm2015/sd-angular-core-popover.js +3 -1
- package/fesm2015/sd-angular-core-popover.js.map +1 -1
- package/fesm2015/sd-angular-core.js +1 -0
- package/fesm2015/sd-angular-core.js.map +1 -1
- package/form/sd-angular-core-form.metadata.json +1 -1
- package/grid/sd-angular-core-grid.metadata.json +1 -1
- package/grid-material/sd-angular-core-grid-material.metadata.json +1 -1
- package/input-number/index.d.ts +1 -0
- package/input-number/package.json +12 -0
- package/input-number/sd-angular-core-input-number.d.ts +4 -0
- package/input-number/sd-angular-core-input-number.metadata.json +1 -0
- package/input-number/src/lib/input-number.component.d.ts +62 -0
- package/input-number/src/lib/input-number.module.d.ts +2 -0
- package/input-number/src/public-api.d.ts +2 -0
- package/package.json +1 -1
- package/popover/sd-angular-core-popover.metadata.json +1 -1
- package/popover/src/lib/directives/popover-trigger.directive.d.ts +1 -0
- package/public-api.d.ts +1 -0
- package/{sd-angular-core-1.1.70.tgz → sd-angular-core-1.1.73.tgz} +0 -0
|
@@ -0,0 +1,335 @@
|
|
|
1
|
+
var _name, _valueInput, _form, _blurOnEnter_1, _model, _min, _max, _validator, _subscription, _setValueInput, _formatNumber, _updateValidator, _outPutValue, _customValidator;
|
|
2
|
+
import { __awaiter, __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
|
|
3
|
+
import { Component, Input, ViewChild, Output, EventEmitter, ChangeDetectorRef, ContentChild, ChangeDetectionStrategy, Inject, Optional } from '@angular/core';
|
|
4
|
+
import { NgForm, Validators } from '@angular/forms';
|
|
5
|
+
import * as uuid from 'uuid';
|
|
6
|
+
import { debounceTime } from 'rxjs/operators';
|
|
7
|
+
import { Subscription } from 'rxjs';
|
|
8
|
+
// import { SdInputSuffixDirective } from './directives/input-suffix.directive';
|
|
9
|
+
import { SdFormControl } from '@sd-angular/core/common';
|
|
10
|
+
import { SdViewDefDirective } from '@sd-angular/core/common';
|
|
11
|
+
import { SdUtilityService } from '@sd-angular/core/utility';
|
|
12
|
+
import { FORM_CONFIG } from '@sd-angular/core/common';
|
|
13
|
+
class SdInputNumberErrotStateMatcher {
|
|
14
|
+
constructor(formControl) {
|
|
15
|
+
this.formControl = formControl;
|
|
16
|
+
}
|
|
17
|
+
isErrorState(control, form) {
|
|
18
|
+
var _a, _b, _c;
|
|
19
|
+
const isSubmitted = form && form.submitted;
|
|
20
|
+
return !!(((_a = this.formControl) === null || _a === void 0 ? void 0 : _a.invalid) && (((_b = this.formControl) === null || _b === void 0 ? void 0 : _b.dirty) || ((_c = this.formControl) === null || _c === void 0 ? void 0 : _c.touched) || isSubmitted));
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
export class SdInputNumber {
|
|
24
|
+
constructor(ref, formConfig, utilityService) {
|
|
25
|
+
this.ref = ref;
|
|
26
|
+
this.formConfig = formConfig;
|
|
27
|
+
this.utilityService = utilityService;
|
|
28
|
+
this.id = `I${uuid.v4()}`;
|
|
29
|
+
_name.set(this, uuid.v4());
|
|
30
|
+
_valueInput.set(this, void 0);
|
|
31
|
+
_form.set(this, void 0);
|
|
32
|
+
this.disableErrorMessage = false;
|
|
33
|
+
_blurOnEnter_1.set(this, false);
|
|
34
|
+
_model.set(this, void 0);
|
|
35
|
+
this.modelChange = new EventEmitter();
|
|
36
|
+
// Validator
|
|
37
|
+
this.isRequired = false;
|
|
38
|
+
this.isReadonly = false;
|
|
39
|
+
_min.set(this, void 0);
|
|
40
|
+
_max.set(this, void 0);
|
|
41
|
+
_validator.set(this, void 0);
|
|
42
|
+
this.sdChange = new EventEmitter();
|
|
43
|
+
this.sdFocus = new EventEmitter();
|
|
44
|
+
this.sdFocusForceBlur = new EventEmitter();
|
|
45
|
+
this.keyupEnter = new EventEmitter();
|
|
46
|
+
this.formControl = new SdFormControl();
|
|
47
|
+
this.inputControl = new SdFormControl();
|
|
48
|
+
_subscription.set(this, new Subscription());
|
|
49
|
+
this.matcher = new SdInputNumberErrotStateMatcher(this.formControl);
|
|
50
|
+
this.isFocused = false;
|
|
51
|
+
_setValueInput.set(this, (value) => {
|
|
52
|
+
const arrayNext = value.split(',');
|
|
53
|
+
if (arrayNext.length >= 2) {
|
|
54
|
+
return `${__classPrivateFieldGet(this, _formatNumber).call(this, arrayNext[0])},${arrayNext[1]}`;
|
|
55
|
+
}
|
|
56
|
+
return __classPrivateFieldGet(this, _formatNumber).call(this, value);
|
|
57
|
+
});
|
|
58
|
+
_formatNumber.set(this, (string) => {
|
|
59
|
+
return string.toString().replace(/\./g, '').split("").reverse().reduce((acc, num, i, orig) => {
|
|
60
|
+
return num + (num != "-" && i && !(i % 3) ? "." : "") + acc;
|
|
61
|
+
}, "");
|
|
62
|
+
});
|
|
63
|
+
this.reValidate = () => {
|
|
64
|
+
this.formControl.updateValueAndValidity();
|
|
65
|
+
};
|
|
66
|
+
_updateValidator.set(this, () => {
|
|
67
|
+
this.formControl.clearValidators();
|
|
68
|
+
this.formControl.clearAsyncValidators();
|
|
69
|
+
const validators = [];
|
|
70
|
+
const asyncValidators = [];
|
|
71
|
+
if (this.isRequired) {
|
|
72
|
+
validators.push(Validators.required);
|
|
73
|
+
}
|
|
74
|
+
if (__classPrivateFieldGet(this, _validator)) {
|
|
75
|
+
asyncValidators.push(__classPrivateFieldGet(this, _customValidator).call(this, __classPrivateFieldGet(this, _validator)));
|
|
76
|
+
}
|
|
77
|
+
this.formControl.setValidators(validators);
|
|
78
|
+
this.formControl.setAsyncValidators(asyncValidators);
|
|
79
|
+
this.formControl.updateValueAndValidity();
|
|
80
|
+
});
|
|
81
|
+
_outPutValue.set(this, (value) => {
|
|
82
|
+
this.modelChange.emit(value);
|
|
83
|
+
this.sdChange.emit(value);
|
|
84
|
+
});
|
|
85
|
+
this.onKeyupEnter = () => {
|
|
86
|
+
var _a;
|
|
87
|
+
const val = ((_a = this.inputControl.value) !== null && _a !== void 0 ? _a : '').toString();
|
|
88
|
+
if (val.length > val.trim().length) {
|
|
89
|
+
this.inputControl.setValue(val.trim());
|
|
90
|
+
}
|
|
91
|
+
this.keyupEnter.emit(this.inputControl.value);
|
|
92
|
+
if (__classPrivateFieldGet(this, _blurOnEnter_1)) {
|
|
93
|
+
this.blur();
|
|
94
|
+
}
|
|
95
|
+
};
|
|
96
|
+
this.onKeydown = (event) => {
|
|
97
|
+
const key = event.keyCode || event.charCode;
|
|
98
|
+
if (key == 8 || key == 46) {
|
|
99
|
+
return;
|
|
100
|
+
}
|
|
101
|
+
if (key == 46) {
|
|
102
|
+
event.preventDefault();
|
|
103
|
+
return;
|
|
104
|
+
}
|
|
105
|
+
const current = event.target.value;
|
|
106
|
+
const next = current.concat(event.key);
|
|
107
|
+
if (next === '-') {
|
|
108
|
+
return;
|
|
109
|
+
}
|
|
110
|
+
const regexDecimal = new RegExp(/^[+-]?(([0-9]+(\.[0-9])?)+(\,[0-9]*){0,1})$/g);
|
|
111
|
+
if (next && !String(next).match(regexDecimal)) {
|
|
112
|
+
event.preventDefault();
|
|
113
|
+
return;
|
|
114
|
+
}
|
|
115
|
+
};
|
|
116
|
+
this.onFocus = () => {
|
|
117
|
+
var _a;
|
|
118
|
+
this.isFocused = true;
|
|
119
|
+
this.sdFocus.emit();
|
|
120
|
+
if (((_a = this.sdFocusForceBlur.observers) === null || _a === void 0 ? void 0 : _a.length) > 0) {
|
|
121
|
+
this.blur();
|
|
122
|
+
this.sdFocusForceBlur.emit();
|
|
123
|
+
}
|
|
124
|
+
};
|
|
125
|
+
this.onBlur = () => {
|
|
126
|
+
var _a;
|
|
127
|
+
this.isFocused = false;
|
|
128
|
+
let val = ((_a = this.inputControl.value) !== null && _a !== void 0 ? _a : '').toString();
|
|
129
|
+
const arrayValue = val.split(',');
|
|
130
|
+
const value = (val.toString().replace(/\./g, '').replace(/,/g, '.'));
|
|
131
|
+
if (Number(value) > __classPrivateFieldGet(this, _max)) {
|
|
132
|
+
this.inputControl.setValue(__classPrivateFieldGet(this, _formatNumber).call(this, __classPrivateFieldGet(this, _max)));
|
|
133
|
+
return;
|
|
134
|
+
}
|
|
135
|
+
if (Number(value) < __classPrivateFieldGet(this, _min)) {
|
|
136
|
+
this.inputControl.setValue(__classPrivateFieldGet(this, _formatNumber).call(this, __classPrivateFieldGet(this, _min)));
|
|
137
|
+
return;
|
|
138
|
+
}
|
|
139
|
+
if (arrayValue.length >= 2 && arrayValue[1] == '') {
|
|
140
|
+
this.inputControl.setValue(__classPrivateFieldGet(this, _formatNumber).call(this, arrayValue[0]));
|
|
141
|
+
return;
|
|
142
|
+
}
|
|
143
|
+
if (val.length > val.trim().length) {
|
|
144
|
+
this.inputControl.setValue(val.trim());
|
|
145
|
+
}
|
|
146
|
+
};
|
|
147
|
+
this.onClick = () => {
|
|
148
|
+
var _a;
|
|
149
|
+
if ((_a = this.sdView) === null || _a === void 0 ? void 0 : _a.templateRef) {
|
|
150
|
+
if (!this.formControl.disabled && !this.isFocused) {
|
|
151
|
+
this.focus();
|
|
152
|
+
}
|
|
153
|
+
}
|
|
154
|
+
};
|
|
155
|
+
this.blur = () => {
|
|
156
|
+
var _a, _b;
|
|
157
|
+
this.isFocused = false;
|
|
158
|
+
(_b = (_a = this.control) === null || _a === void 0 ? void 0 : _a.nativeElement) === null || _b === void 0 ? void 0 : _b.blur();
|
|
159
|
+
};
|
|
160
|
+
this.focus = () => {
|
|
161
|
+
this.isFocused = true;
|
|
162
|
+
setTimeout(() => {
|
|
163
|
+
var _a, _b;
|
|
164
|
+
(_b = (_a = this.control) === null || _a === void 0 ? void 0 : _a.nativeElement) === null || _b === void 0 ? void 0 : _b.focus();
|
|
165
|
+
}, 100);
|
|
166
|
+
};
|
|
167
|
+
_customValidator.set(this, (func) => {
|
|
168
|
+
return (c) => __awaiter(this, void 0, void 0, function* () {
|
|
169
|
+
const value = c.value || null;
|
|
170
|
+
if (func && typeof (func) === 'function') {
|
|
171
|
+
const result = func(value);
|
|
172
|
+
if (result instanceof Promise) {
|
|
173
|
+
const message = yield result;
|
|
174
|
+
if (message) {
|
|
175
|
+
return {
|
|
176
|
+
customValidator: message
|
|
177
|
+
};
|
|
178
|
+
}
|
|
179
|
+
return null;
|
|
180
|
+
}
|
|
181
|
+
if (result) {
|
|
182
|
+
return {
|
|
183
|
+
customValidator: result
|
|
184
|
+
};
|
|
185
|
+
}
|
|
186
|
+
return null;
|
|
187
|
+
}
|
|
188
|
+
return null;
|
|
189
|
+
});
|
|
190
|
+
});
|
|
191
|
+
}
|
|
192
|
+
set name(val) {
|
|
193
|
+
if (val) {
|
|
194
|
+
__classPrivateFieldSet(this, _name, val);
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
set form(val) {
|
|
198
|
+
if (val) {
|
|
199
|
+
if (val instanceof NgForm) {
|
|
200
|
+
__classPrivateFieldSet(this, _form, val.form);
|
|
201
|
+
}
|
|
202
|
+
else {
|
|
203
|
+
__classPrivateFieldSet(this, _form, val);
|
|
204
|
+
}
|
|
205
|
+
}
|
|
206
|
+
}
|
|
207
|
+
set _disableErrorMessage(val) {
|
|
208
|
+
this.disableErrorMessage = (val === '') || val;
|
|
209
|
+
}
|
|
210
|
+
set _blurOnEnter(val) {
|
|
211
|
+
__classPrivateFieldSet(this, _blurOnEnter_1, (val === '') || val);
|
|
212
|
+
}
|
|
213
|
+
set model(value) {
|
|
214
|
+
if (__classPrivateFieldGet(this, _model) !== value) {
|
|
215
|
+
__classPrivateFieldSet(this, _model, value);
|
|
216
|
+
this.formControl.setValue(value, {
|
|
217
|
+
emitEvent: false
|
|
218
|
+
});
|
|
219
|
+
if (value || value == 0) {
|
|
220
|
+
const val = value.toString().replace(/\./g, ',');
|
|
221
|
+
this.inputControl.setValue(__classPrivateFieldGet(this, _setValueInput).call(this, val));
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
set required(val) {
|
|
226
|
+
this.isRequired = (val === '') || val;
|
|
227
|
+
__classPrivateFieldGet(this, _updateValidator).call(this);
|
|
228
|
+
}
|
|
229
|
+
set readonly(val) {
|
|
230
|
+
this.isReadonly = (val === '') || val;
|
|
231
|
+
}
|
|
232
|
+
set min(val) {
|
|
233
|
+
__classPrivateFieldSet(this, _min, val);
|
|
234
|
+
__classPrivateFieldGet(this, _updateValidator).call(this);
|
|
235
|
+
}
|
|
236
|
+
set max(val) {
|
|
237
|
+
__classPrivateFieldSet(this, _max, val);
|
|
238
|
+
__classPrivateFieldGet(this, _updateValidator).call(this);
|
|
239
|
+
}
|
|
240
|
+
set validator(validator) {
|
|
241
|
+
__classPrivateFieldSet(this, _validator, validator);
|
|
242
|
+
__classPrivateFieldGet(this, _updateValidator).call(this);
|
|
243
|
+
}
|
|
244
|
+
set disabled(val) {
|
|
245
|
+
val = (val === '') || val;
|
|
246
|
+
if (val) {
|
|
247
|
+
this.inputControl.disable();
|
|
248
|
+
this.formControl.disable();
|
|
249
|
+
}
|
|
250
|
+
else {
|
|
251
|
+
this.inputControl.enable();
|
|
252
|
+
this.formControl.enable();
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
ngOnInit() {
|
|
256
|
+
var _a;
|
|
257
|
+
this.appearance = this.appearance || ((_a = this.formConfig) === null || _a === void 0 ? void 0 : _a.appearance);
|
|
258
|
+
__classPrivateFieldGet(this, _subscription).add(this.inputControl.touchChanges.subscribe(() => {
|
|
259
|
+
this.formControl.markAsTouched();
|
|
260
|
+
this.ref.markForCheck();
|
|
261
|
+
}));
|
|
262
|
+
__classPrivateFieldGet(this, _subscription).add(this.formControl.sdChanges.subscribe(() => {
|
|
263
|
+
this.ref.markForCheck();
|
|
264
|
+
}));
|
|
265
|
+
__classPrivateFieldGet(this, _subscription).add(this.inputControl.sdChanges.subscribe(() => {
|
|
266
|
+
this.ref.markForCheck();
|
|
267
|
+
}));
|
|
268
|
+
}
|
|
269
|
+
ngAfterViewInit() {
|
|
270
|
+
var _a;
|
|
271
|
+
__classPrivateFieldGet(this, _subscription).add(this.inputControl.valueChanges.pipe(debounceTime(200)).subscribe(val => {
|
|
272
|
+
if (!val) {
|
|
273
|
+
this.formControl.setValue(undefined);
|
|
274
|
+
this.modelChange.emit(undefined);
|
|
275
|
+
this.sdChange.emit(undefined);
|
|
276
|
+
return;
|
|
277
|
+
}
|
|
278
|
+
const item = __classPrivateFieldGet(this, _setValueInput).call(this, val);
|
|
279
|
+
if (__classPrivateFieldGet(this, _valueInput) === item) {
|
|
280
|
+
return;
|
|
281
|
+
}
|
|
282
|
+
__classPrivateFieldSet(this, _valueInput, item);
|
|
283
|
+
const value = (val.toString().replace(/\./g, '').replace(/,/g, '.'));
|
|
284
|
+
this.inputControl.setValue(item);
|
|
285
|
+
this.formControl.setValue(value);
|
|
286
|
+
__classPrivateFieldGet(this, _outPutValue).call(this, Number(value));
|
|
287
|
+
}));
|
|
288
|
+
(_a = __classPrivateFieldGet(this, _form)) === null || _a === void 0 ? void 0 : _a.addControl(__classPrivateFieldGet(this, _name), this.formControl);
|
|
289
|
+
this.ref.detectChanges();
|
|
290
|
+
}
|
|
291
|
+
ngOnDestroy() {
|
|
292
|
+
var _a;
|
|
293
|
+
(_a = __classPrivateFieldGet(this, _form)) === null || _a === void 0 ? void 0 : _a.removeControl(__classPrivateFieldGet(this, _name));
|
|
294
|
+
__classPrivateFieldGet(this, _subscription).unsubscribe();
|
|
295
|
+
}
|
|
296
|
+
}
|
|
297
|
+
_name = new WeakMap(), _valueInput = new WeakMap(), _form = new WeakMap(), _blurOnEnter_1 = new WeakMap(), _model = new WeakMap(), _min = new WeakMap(), _max = new WeakMap(), _validator = new WeakMap(), _subscription = new WeakMap(), _setValueInput = new WeakMap(), _formatNumber = new WeakMap(), _updateValidator = new WeakMap(), _outPutValue = new WeakMap(), _customValidator = new WeakMap();
|
|
298
|
+
SdInputNumber.decorators = [
|
|
299
|
+
{ type: Component, args: [{
|
|
300
|
+
selector: 'sd-input-number',
|
|
301
|
+
template: "<label *ngIf=\"!appearance && label\" class=\"d-block mb-0 T14M\">{{label}} <span class=\"text-danger mb-2\" *ngIf=\"required\">*</span></label>\r\n<div class=\"d-flex align-items-center\" [class.sd-view]=\"sdView?.templateRef\" [class.c-focused]=\"isFocused\"\r\n [class.c-disabled]=\"formControl.disabled\" (click)=\"onClick()\">\r\n <ng-container *ngIf=\"sdView?.templateRef && !isFocused; else default\">\r\n <ng-container *ngTemplateOutlet=\"sdView.templateRef;context: { value: formControl.value }\">\r\n </ng-container>\r\n </ng-container>\r\n <ng-template #default>\r\n <mat-form-field class=\"sd-md\"\r\n [ngClass]=\"{ 'sd-sm': size === 'sm', 'no-padding-wrapper': disableErrorMessage}\"\r\n [appearance]=\"appearance || 'outline'\">\r\n <mat-label *ngIf=\"appearance && label\">{{label}}</mat-label>\r\n <input [id]=\"id\" [formControl]=\"inputControl\" #control matInput [placeholder]=\"placeholder || label\" [errorStateMatcher]=\"matcher\"\r\n (keyup.enter)=\"onKeyupEnter()\" (focus)=\"onFocus()\" (blur)=\"onBlur()\" (keydown)=\"onKeydown($event)\" [required]=\"isRequired\"\r\n [readonly]=\"isReadonly\" [autocomplete]=\"id\" autocorrect=\"off\" [step]=\"1\">\r\n <mat-error *ngIf=\"formControl?.errors?.required && !disableErrorMessage\">\r\n {{ \"This field is required\" | sdTranslate }}\r\n </mat-error>\r\n <mat-error *ngIf=\"!disableErrorMessage && formControl.errors?.customValidator\">\r\n {{formControl.errors?.customValidator}}\r\n </mat-error>\r\n </mat-form-field>\r\n </ng-template>\r\n</div>",
|
|
302
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
303
|
+
styles: [":host ::ng-deep .mat-form-field.sd-form-tooltip{width:calc(100% - 30px)}:host ::ng-deep .mat-form-field.no-padding-wrapper .mat-form-field-wrapper{padding-bottom:0}:host ::ng-deep .mat-form-field.mat-form-field-appearance-outline.mat-form-field-disabled .mat-form-field-outline{background:#f6f6f6;color:#e9e9e9}:host ::ng-deep .mat-form-field input.mat-input-element:disabled{color:#4d4d4d!important}:host ::ng-deep .mat-form-field .mat-placeholder-required{color:#f82c13}.sd-view:not(.c-focused):not(.c-disabled):hover{background-color:#ebecf0}.sd-tooltip{display:inline-block;margin:auto;text-align:center;width:30px}:host{display:block;padding-top:5px}.sd-md:hover .btn-copy{visibility:visible}.btn-copy{background:#e9e9e9!important;font-size:12px;line-height:26px!important;margin-bottom:3px;visibility:hidden}"]
|
|
304
|
+
},] }
|
|
305
|
+
];
|
|
306
|
+
SdInputNumber.ctorParameters = () => [
|
|
307
|
+
{ type: ChangeDetectorRef },
|
|
308
|
+
{ type: undefined, decorators: [{ type: Inject, args: [FORM_CONFIG,] }, { type: Optional }] },
|
|
309
|
+
{ type: SdUtilityService }
|
|
310
|
+
];
|
|
311
|
+
SdInputNumber.propDecorators = {
|
|
312
|
+
name: [{ type: Input }],
|
|
313
|
+
size: [{ type: Input }],
|
|
314
|
+
form: [{ type: Input }],
|
|
315
|
+
label: [{ type: Input }],
|
|
316
|
+
placeholder: [{ type: Input }],
|
|
317
|
+
_disableErrorMessage: [{ type: Input, args: ['disableErrorMessage',] }],
|
|
318
|
+
_blurOnEnter: [{ type: Input, args: ['blurOnEnter',] }],
|
|
319
|
+
model: [{ type: Input }],
|
|
320
|
+
modelChange: [{ type: Output }],
|
|
321
|
+
required: [{ type: Input }],
|
|
322
|
+
readonly: [{ type: Input }],
|
|
323
|
+
min: [{ type: Input }],
|
|
324
|
+
max: [{ type: Input }],
|
|
325
|
+
validator: [{ type: Input }],
|
|
326
|
+
disabled: [{ type: Input }],
|
|
327
|
+
appearance: [{ type: Input }],
|
|
328
|
+
sdChange: [{ type: Output }],
|
|
329
|
+
sdFocus: [{ type: Output }],
|
|
330
|
+
sdFocusForceBlur: [{ type: Output }],
|
|
331
|
+
keyupEnter: [{ type: Output }],
|
|
332
|
+
control: [{ type: ViewChild, args: ['control',] }],
|
|
333
|
+
sdView: [{ type: ContentChild, args: [SdViewDefDirective,] }]
|
|
334
|
+
};
|
|
335
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-number.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/input-number/","sources":["src/lib/input-number.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  Input,\r\n  ViewChild,\r\n  Output,\r\n  EventEmitter,\r\n  ChangeDetectorRef,\r\n  OnDestroy,\r\n  AfterViewInit,\r\n  ElementRef,\r\n  OnInit,\r\n  ContentChild,\r\n  ChangeDetectionStrategy,\r\n  HostListener,\r\n  Inject,\r\n  Optional\r\n} from '@angular/core';\r\nimport { AbstractControl, NgForm, ValidatorFn, Validators, AsyncValidatorFn, FormGroup, FormControl, FormGroupDirective } from '@angular/forms';\r\nimport * as uuid from 'uuid';\r\nimport { debounceTime } from 'rxjs/operators';\r\nimport { Subscription } from 'rxjs';\r\n// import { SdInputSuffixDirective } from './directives/input-suffix.directive';\r\nimport { SdFormControl } from '@sd-angular/core/common';\r\nimport { SdViewDefDirective } from '@sd-angular/core/common';\r\nimport { SdUtilityService } from '@sd-angular/core/utility';\r\nimport { FORM_CONFIG } from '@sd-angular/core/common';\r\nimport { IFormConfiguration } from '@sd-angular/core/common';\r\nimport { MatFormFieldAppearance } from '@angular/material/form-field';\r\nimport { ErrorStateMatcher } from '@angular/material/core';\r\nclass SdInputNumberErrotStateMatcher implements ErrorStateMatcher {\r\n  constructor(private formControl: FormControl) { }\r\n  isErrorState(control: FormControl | null, form: FormGroupDirective | NgForm | null): boolean {\r\n    const isSubmitted = form && form.submitted;\r\n    return !!(this.formControl?.invalid && (this.formControl?.dirty || this.formControl?.touched || isSubmitted));\r\n  }\r\n}\r\n@Component({\r\n  selector: 'sd-input-number',\r\n  templateUrl: './input-number.component.html',\r\n  styleUrls: ['./input-number.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class SdInputNumber implements OnDestroy, OnInit, AfterViewInit {\r\n  id = `I${uuid.v4()}`;\r\n  #name = uuid.v4();\r\n  #valueInput: string;\r\n  @Input() set name(val: string) {\r\n    if (val) {\r\n      this.#name = val;\r\n    }\r\n  }\r\n  @Input() size: 'sm' | 'lg';\r\n  #form: FormGroup;\r\n  @Input() set form(val: NgForm | FormGroup) {\r\n    if (val) {\r\n      if (val instanceof NgForm) {\r\n        this.#form = val.form;\r\n      } else {\r\n        this.#form = val;\r\n      }\r\n    }\r\n  }\r\n  @Input() label: string;\r\n  @Input() placeholder: string;\r\n  disableErrorMessage = false;\r\n  @Input('disableErrorMessage') set _disableErrorMessage(val: boolean | '') {\r\n    this.disableErrorMessage = (val === '') || val;\r\n  }\r\n  #blurOnEnter = false;\r\n  @Input('blurOnEnter') set _blurOnEnter(val: boolean | '') {\r\n    this.#blurOnEnter = (val === '') || val;\r\n  }\r\n  #model: any;\r\n  @Input() set model(value: any) {\r\n    if (this.#model !== value) {\r\n      this.#model = value;\r\n      this.formControl.setValue(value, {\r\n        emitEvent: false\r\n      });\r\n      if(value || value==0){\r\n        const val = value.toString().replace(/\\./g,',');\r\n        this.inputControl.setValue(this.#setValueInput(val));\r\n      }\r\n    }\r\n  }\r\n  @Output() modelChange = new EventEmitter();\r\n\r\n  // Validator\r\n  isRequired = false;\r\n  @Input() set required(val: boolean | '') {\r\n    this.isRequired = (val === '') || val;\r\n    this.#updateValidator();\r\n  }\r\n\r\n  isReadonly = false;\r\n  @Input() set readonly(val: boolean | '') {\r\n    this.isReadonly = (val === '') || val;\r\n  }\r\n\r\n  #min: number;\r\n  @Input() set min(val: number) {\r\n    this.#min = val;\r\n    this.#updateValidator();\r\n  }\r\n\r\n  #max: number;\r\n  @Input() set max(val: number) {\r\n    this.#max = val;\r\n    this.#updateValidator();\r\n  }\r\n\r\n  #validator: (value: any) => string | Promise<string>;\r\n  @Input() set validator(validator: (value: any) => string | Promise<string>) {\r\n    this.#validator = validator;\r\n    this.#updateValidator();\r\n  }\r\n\r\n  @Input() set disabled(val: boolean | '') {\r\n    val = (val === '') || val;\r\n    if (val) {\r\n      this.inputControl.disable();\r\n      this.formControl.disable();\r\n    } else {\r\n      this.inputControl.enable();\r\n      this.formControl.enable();\r\n    }\r\n  }\r\n  @Input() appearance: MatFormFieldAppearance;\r\n\r\n  @Output() sdChange = new EventEmitter<any>();\r\n  @Output() sdFocus = new EventEmitter<any>();\r\n  @Output() sdFocusForceBlur = new EventEmitter<any>();\r\n  @Output() keyupEnter = new EventEmitter();\r\n\r\n  @ViewChild('control') control: ElementRef;\r\n  formControl = new SdFormControl();\r\n  inputControl = new SdFormControl();\r\n  #subscription = new Subscription();\r\n  matcher = new SdInputNumberErrotStateMatcher(this.formControl);\r\n\r\n  @ContentChild(SdViewDefDirective) sdView: SdViewDefDirective;\r\n  isFocused = false;\r\n  constructor(\r\n    private ref: ChangeDetectorRef,\r\n    @Inject(FORM_CONFIG) @Optional() private formConfig: IFormConfiguration,\r\n    private utilityService: SdUtilityService) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.appearance = this.appearance || this.formConfig?.appearance;\r\n    this.#subscription.add(this.inputControl.touchChanges.subscribe(() => {\r\n      this.formControl.markAsTouched();\r\n      this.ref.markForCheck();\r\n    }));\r\n    this.#subscription.add(this.formControl.sdChanges.subscribe(() => {\r\n      this.ref.markForCheck();\r\n    }));\r\n    this.#subscription.add(this.inputControl.sdChanges.subscribe(() => {\r\n      this.ref.markForCheck();\r\n    }));\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.#subscription.add(this.inputControl.valueChanges.pipe(debounceTime(200)).subscribe(val => {\r\n      if(!val){\r\n        this.formControl.setValue(undefined);\r\n        this.modelChange.emit(undefined);\r\n        this.sdChange.emit(undefined);\r\n        return;\r\n      }\r\n      const item =  this.#setValueInput(val);\r\n      if( this.#valueInput === item){\r\n        return;\r\n      }\r\n      this.#valueInput = item;\r\n      const value = (val.toString().replace(/\\./g,'').replace(/,/g,'.'));\r\n      this.inputControl.setValue(item);\r\n      this.formControl.setValue(value);\r\n      this.#outPutValue(Number(value));\r\n    }));\r\n    this.#form?.addControl(this.#name, this.formControl);\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  #setValueInput=(value)=>{\r\n    const arrayNext = value.split(',');\r\n    if (arrayNext.length>=2) {\r\n      return `${this.#formatNumber(arrayNext[0])},${arrayNext[1]}`;\r\n    }\r\n    return this.#formatNumber(value);\r\n  }\r\n\r\n  #formatNumber=(string) =>{\r\n    return string.toString().replace(/\\./g,'').split(\"\").reverse().reduce((acc, num, i, orig) => {\r\n      return num + (num != \"-\" && i && !(i % 3) ? \".\" : \"\") + acc;\r\n    }, \"\");\r\n  }\r\n\r\n\r\n  ngOnDestroy() {\r\n    this.#form?.removeControl(this.#name);\r\n    this.#subscription.unsubscribe();\r\n  }\r\n\r\n  reValidate = () => {\r\n    this.formControl.updateValueAndValidity();\r\n  }\r\n\r\n  #updateValidator = () => {\r\n    this.formControl.clearValidators();\r\n    this.formControl.clearAsyncValidators();\r\n    const validators: ValidatorFn[] = [];\r\n    const asyncValidators: AsyncValidatorFn[] = [];\r\n    if (this.isRequired) {\r\n      validators.push(Validators.required);\r\n    }\r\n    if (this.#validator) {\r\n      asyncValidators.push(this.#customValidator(this.#validator));\r\n    }\r\n    this.formControl.setValidators(validators);\r\n    this.formControl.setAsyncValidators(asyncValidators);\r\n    this.formControl.updateValueAndValidity();\r\n  }\r\n\r\n  #outPutValue = (value: any) => {\r\n    this.modelChange.emit(value);\r\n    this.sdChange.emit(value);\r\n  }\r\n\r\n  onKeyupEnter = () => {\r\n    const val: string = (this.inputControl.value ?? '').toString();\r\n    if (val.length > val.trim().length) {\r\n      this.inputControl.setValue(val.trim());\r\n    }\r\n    this.keyupEnter.emit(this.inputControl.value);\r\n    if (this.#blurOnEnter) {\r\n      this.blur();\r\n    }\r\n  }\r\n\r\n  onKeydown = (event) => {\r\n    const key = event.keyCode || event.charCode;\r\n    if ( key == 8 || key == 46 ) {\r\n      return;\r\n    }\r\n    if ( key == 46) {\r\n      event.preventDefault();\r\n      return;\r\n    }\r\n    const current: string = event.target.value;\r\n    const next: string = current.concat(event.key);\r\n    if(next === '-'){\r\n      return;\r\n    }\r\n    const regexDecimal: RegExp = new RegExp(/^[+-]?(([0-9]+(\\.[0-9])?)+(\\,[0-9]*){0,1})$/g);\r\n    if (next && !String(next).match(regexDecimal)) {\r\n      event.preventDefault();\r\n      return;\r\n    }\r\n  }\r\n\r\n  onFocus = () => {\r\n    this.isFocused = true;\r\n    this.sdFocus.emit();\r\n    if (this.sdFocusForceBlur.observers?.length > 0) {\r\n      this.blur();\r\n      this.sdFocusForceBlur.emit();\r\n    }\r\n  }\r\n\r\n  onBlur = () => {\r\n    this.isFocused = false;\r\n    let val: string = (this.inputControl.value ?? '').toString();\r\n    const arrayValue = val.split(',');\r\n    const value = (val.toString().replace(/\\./g,'').replace(/,/g,'.'));\r\n    if(Number(value) > this.#max){\r\n      this.inputControl.setValue(this.#formatNumber(this.#max));\r\n      return; \r\n    }\r\n    if(Number(value) < this.#min){\r\n      this.inputControl.setValue(this.#formatNumber(this.#min));\r\n      return; \r\n    }\r\n    if (arrayValue.length>=2 && arrayValue[1] == '') {\r\n      this.inputControl.setValue(this.#formatNumber(arrayValue[0]));\r\n      return;\r\n    }\r\n    if (val.length > val.trim().length) {\r\n      this.inputControl.setValue(val.trim());\r\n    }\r\n  }\r\n\r\n  onClick = () => {\r\n    if (this.sdView?.templateRef) {\r\n      if (!this.formControl.disabled && !this.isFocused) {\r\n        this.focus();\r\n      }\r\n    }\r\n  }\r\n\r\n  blur = () => {\r\n    this.isFocused = false;\r\n    this.control?.nativeElement?.blur();\r\n  }\r\n\r\n  focus = () => {\r\n    this.isFocused = true;\r\n    setTimeout(() => {\r\n      this.control?.nativeElement?.focus();\r\n    }, 100);\r\n  }\r\n\r\n  #customValidator = (func: (value: any) => string | Promise<string>): AsyncValidatorFn => {\r\n    return async (c: AbstractControl): Promise<{ [key: string]: any } | null> => {\r\n      const value = c.value || null;\r\n      if (func && typeof (func) === 'function') {\r\n        const result = func(value);\r\n        if (result instanceof Promise) {\r\n          const message = await result;\r\n          if (message) {\r\n            return {\r\n              customValidator: message\r\n            };\r\n          }\r\n          return null;\r\n        }\r\n        if (result) {\r\n          return {\r\n            customValidator: result\r\n          };\r\n        }\r\n        return null;\r\n      }\r\n      return null;\r\n    };\r\n  }\r\n\r\n}\r\n"]}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { SdInputNumber } from './input-number.component';
|
|
4
|
+
import { FormsModule, ReactiveFormsModule } from '@angular/forms';
|
|
5
|
+
import { MatFormFieldModule } from '@angular/material/form-field';
|
|
6
|
+
import { MatInputModule } from '@angular/material/input';
|
|
7
|
+
import { MatButtonModule } from '@angular/material/button';
|
|
8
|
+
import { MatIconModule } from '@angular/material/icon';
|
|
9
|
+
import { MatTooltipModule } from '@angular/material/tooltip';
|
|
10
|
+
import { SdTranslateModule } from '@sd-angular/core/translate';
|
|
11
|
+
import { SdCommonModule } from '@sd-angular/core/common';
|
|
12
|
+
export class SdInputNumberModule {
|
|
13
|
+
}
|
|
14
|
+
SdInputNumberModule.decorators = [
|
|
15
|
+
{ type: NgModule, args: [{
|
|
16
|
+
declarations: [SdInputNumber],
|
|
17
|
+
imports: [
|
|
18
|
+
CommonModule,
|
|
19
|
+
FormsModule,
|
|
20
|
+
ReactiveFormsModule,
|
|
21
|
+
MatFormFieldModule,
|
|
22
|
+
MatInputModule,
|
|
23
|
+
MatIconModule,
|
|
24
|
+
MatTooltipModule,
|
|
25
|
+
SdTranslateModule,
|
|
26
|
+
SdCommonModule,
|
|
27
|
+
MatButtonModule
|
|
28
|
+
],
|
|
29
|
+
exports: [
|
|
30
|
+
SdInputNumber
|
|
31
|
+
]
|
|
32
|
+
},] }
|
|
33
|
+
];
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtbnVtYmVyLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiJDOi9Vc2Vycy9uZ2hpYXR0MTVfb25lbW91bnQvRG9jdW1lbnRzL2xpYi1jb3JlLXVpL3Byb2plY3RzL3NkLWNvcmUvaW5wdXQtbnVtYmVyLyIsInNvdXJjZXMiOlsic3JjL2xpYi9pbnB1dC1udW1iZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxhQUFhLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUN6RCxPQUFPLEVBQUUsV0FBVyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sOEJBQThCLENBQUM7QUFDbEUsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBQ3pELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUMzRCxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkQsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sMkJBQTJCLENBQUM7QUFDN0QsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFDL0QsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHlCQUF5QixDQUFDO0FBb0J6RCxNQUFNLE9BQU8sbUJBQW1COzs7WUFsQi9CLFFBQVEsU0FBQztnQkFDUixZQUFZLEVBQUUsQ0FBQyxhQUFhLENBQUM7Z0JBQzdCLE9BQU8sRUFBRTtvQkFDUCxZQUFZO29CQUNaLFdBQVc7b0JBQ1gsbUJBQW1CO29CQUNuQixrQkFBa0I7b0JBQ2xCLGNBQWM7b0JBQ2QsYUFBYTtvQkFDYixnQkFBZ0I7b0JBQ2hCLGlCQUFpQjtvQkFDakIsY0FBYztvQkFDZCxlQUFlO2lCQUNoQjtnQkFDRCxPQUFPLEVBQUU7b0JBQ1AsYUFBYTtpQkFDZDthQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcclxuaW1wb3J0IHsgU2RJbnB1dE51bWJlciB9IGZyb20gJy4vaW5wdXQtbnVtYmVyLmNvbXBvbmVudCc7XHJcbmltcG9ydCB7IEZvcm1zTW9kdWxlLCBSZWFjdGl2ZUZvcm1zTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xyXG5pbXBvcnQgeyBNYXRGb3JtRmllbGRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9mb3JtLWZpZWxkJztcclxuaW1wb3J0IHsgTWF0SW5wdXRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pbnB1dCc7XHJcbmltcG9ydCB7IE1hdEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2J1dHRvbic7XHJcbmltcG9ydCB7IE1hdEljb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9pY29uJztcclxuaW1wb3J0IHsgTWF0VG9vbHRpcE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3Rvb2x0aXAnO1xyXG5pbXBvcnQgeyBTZFRyYW5zbGF0ZU1vZHVsZSB9IGZyb20gJ0BzZC1hbmd1bGFyL2NvcmUvdHJhbnNsYXRlJztcclxuaW1wb3J0IHsgU2RDb21tb25Nb2R1bGUgfSBmcm9tICdAc2QtYW5ndWxhci9jb3JlL2NvbW1vbic7XHJcblxyXG5ATmdNb2R1bGUoe1xyXG4gIGRlY2xhcmF0aW9uczogW1NkSW5wdXROdW1iZXJdLFxyXG4gIGltcG9ydHM6IFtcclxuICAgIENvbW1vbk1vZHVsZSxcclxuICAgIEZvcm1zTW9kdWxlLFxyXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZSxcclxuICAgIE1hdEZvcm1GaWVsZE1vZHVsZSxcclxuICAgIE1hdElucHV0TW9kdWxlLFxyXG4gICAgTWF0SWNvbk1vZHVsZSxcclxuICAgIE1hdFRvb2x0aXBNb2R1bGUsXHJcbiAgICBTZFRyYW5zbGF0ZU1vZHVsZSxcclxuICAgIFNkQ29tbW9uTW9kdWxlLFxyXG4gICAgTWF0QnV0dG9uTW9kdWxlXHJcbiAgXSxcclxuICBleHBvcnRzOiBbXHJcbiAgICBTZElucHV0TnVtYmVyXHJcbiAgXVxyXG59KVxyXG5leHBvcnQgY2xhc3MgU2RJbnB1dE51bWJlck1vZHVsZSB7IH1cclxuIl19
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
/*
|
|
2
|
+
* Public API Surface of superdev-angular-core
|
|
3
|
+
*/
|
|
4
|
+
export * from './lib/input-number.module';
|
|
5
|
+
export * from './lib/input-number.component';
|
|
6
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiJDOi9Vc2Vycy9uZ2hpYXR0MTVfb25lbW91bnQvRG9jdW1lbnRzL2xpYi1jb3JlLXVpL3Byb2plY3RzL3NkLWNvcmUvaW5wdXQtbnVtYmVyLyIsInNvdXJjZXMiOlsic3JjL3B1YmxpYy1hcGkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7O0dBRUc7QUFFSCxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsOEJBQThCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxyXG4gKiBQdWJsaWMgQVBJIFN1cmZhY2Ugb2Ygc3VwZXJkZXYtYW5ndWxhci1jb3JlXHJcbiAqL1xyXG5cclxuZXhwb3J0ICogZnJvbSAnLi9saWIvaW5wdXQtbnVtYmVyLm1vZHVsZSc7XHJcbmV4cG9ydCAqIGZyb20gJy4vbGliL2lucHV0LW51bWJlci5jb21wb25lbnQnOyJdfQ==
|
|
@@ -22,6 +22,7 @@ export class PopoverTriggerDirective {
|
|
|
22
22
|
_destroy$.set(this, new Subject());
|
|
23
23
|
this.popoverOpen = false;
|
|
24
24
|
_popover.set(this, void 0);
|
|
25
|
+
this.disabled = false;
|
|
25
26
|
this.popoverOpened = new EventEmitter();
|
|
26
27
|
this.popoverClosed = new EventEmitter();
|
|
27
28
|
this.openPopover = () => {
|
|
@@ -176,7 +177,7 @@ export class PopoverTriggerDirective {
|
|
|
176
177
|
mergedMouseState$
|
|
177
178
|
.pipe(debounceTime(100), distinctUntilChanged(), filter(() => this.platform.isBrowser), takeUntil(__classPrivateFieldGet(this, _destroy$)))
|
|
178
179
|
.subscribe((visible) => {
|
|
179
|
-
if (visible) {
|
|
180
|
+
if (visible && !this.disabled) {
|
|
180
181
|
this.openPopover();
|
|
181
182
|
}
|
|
182
183
|
else {
|
|
@@ -217,7 +218,8 @@ PopoverTriggerDirective.ctorParameters = () => [
|
|
|
217
218
|
PopoverTriggerDirective.propDecorators = {
|
|
218
219
|
popover: [{ type: Input, args: ["sdPopoverTriggerFor",] }],
|
|
219
220
|
popoverData: [{ type: Input, args: ["sdPopoverData",] }],
|
|
221
|
+
disabled: [{ type: Input, args: ["sdPopoverDisabled",] }],
|
|
220
222
|
popoverOpened: [{ type: Output }],
|
|
221
223
|
popoverClosed: [{ type: Output }]
|
|
222
224
|
};
|
|
223
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover-trigger.directive.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/popover/","sources":["src/lib/directives/popover-trigger.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directionality } from \"@angular/cdk/bidi\";\r\nimport {\r\n  FlexibleConnectedPositionStrategy,\r\n  Overlay,\r\n  OverlayConfig,\r\n  OverlayRef,\r\n} from \"@angular/cdk/overlay\";\r\nimport { Platform } from \"@angular/cdk/platform\";\r\nimport { TemplatePortal } from \"@angular/cdk/portal\";\r\nimport {\r\n  AfterContentInit,\r\n  AfterViewInit,\r\n  Directive,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  NgZone,\r\n  OnDestroy,\r\n  Optional,\r\n  Output,\r\n  ViewContainerRef,\r\n} from \"@angular/core\";\r\nimport { fromEvent, merge, Subject, Subscription } from \"rxjs\";\r\nimport {\r\n  auditTime,\r\n  debounceTime,\r\n  distinctUntilChanged,\r\n  filter,\r\n  map,\r\n  mapTo,\r\n  takeUntil,\r\n  tap,\r\n} from \"rxjs/operators\";\r\nimport { Position } from \"../popover.model\";\r\nimport { PopoverComponent } from \"../popover/popover.component\";\r\n\r\n@Directive({\r\n  selector: \"[sdPopoverTriggerFor]\",\r\n  host: {\r\n    \"aria-haspopup\": \"true\",\r\n    class: \"sd-popover-trigger\",\r\n  },\r\n  exportAs: \"sdPopoverTrigger\",\r\n})\r\nexport class PopoverTriggerDirective implements AfterViewInit, OnDestroy {\r\n  #overlayRef: OverlayRef | null = null;\r\n  #popoverClose$ = Subscription.EMPTY;\r\n  #portal: TemplatePortal;\r\n  #destroy$ = new Subject();\r\n\r\n  popoverOpen = false;\r\n\r\n  @Input(\"sdPopoverTriggerFor\")\r\n  get popover() {\r\n    return this.#popover;\r\n  }\r\n  set popover(popover: PopoverComponent) {\r\n    if (popover === this.#popover) {\r\n      return;\r\n    }\r\n    this.#popover = popover;\r\n    this.#popoverClose$.unsubscribe();\r\n    if (popover) {\r\n      this.#popoverClose$ = popover.closed.subscribe(() => {\r\n        this.#destroyPopover();\r\n      });\r\n    }\r\n  }\r\n  #popover: PopoverComponent;\r\n\r\n  @Input(\"sdPopoverData\")\r\n  popoverData: any;\r\n\r\n  @Output() popoverOpened = new EventEmitter<void>();\r\n  @Output() popoverClosed = new EventEmitter<void>();\r\n\r\n  constructor(\r\n    private _overlay: Overlay,\r\n    private _element: ElementRef<HTMLElement>,\r\n    private _ngZone: NgZone,\r\n    private viewContainerRef: ViewContainerRef,\r\n    private elementRef: ElementRef,\r\n    private platform: Platform,\r\n    @Optional() private _dir: Directionality\r\n  ) {}\r\n\r\n  ngAfterViewInit(): void {\r\n    if (this.popover) {\r\n      const nativeElement = this.elementRef.nativeElement;\r\n\r\n      const hostMouseState$ = merge(\r\n        fromEvent(nativeElement, \"mouseenter\").pipe(mapTo(true)),\r\n        fromEvent(nativeElement, \"mouseleave\").pipe(mapTo(false))\r\n      );\r\n\r\n      const popoverMouseState$ = this.popover.mouseState$.pipe(\r\n        // chỉ lấy luồng emit open bởi chính trigger (tránh lỗi nhiều trigger cho một popover)\r\n        filter((v) => !this.popover.trigger || this.popover.trigger == this)\r\n      );\r\n\r\n      const mergedMouseState$ = merge(popoverMouseState$, hostMouseState$);\r\n\r\n      mergedMouseState$\r\n        .pipe(\r\n          debounceTime(100),\r\n          distinctUntilChanged(),\r\n          filter(() => this.platform.isBrowser),\r\n          takeUntil(this.#destroy$)\r\n        )\r\n        .subscribe((visible) => {\r\n          if (visible) {\r\n            this.openPopover();\r\n          } else {\r\n            this.closePopover();\r\n          }\r\n        });\r\n    }\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.#destroy$.next();\r\n    this.#destroy$.complete();\r\n    if (this.#overlayRef) {\r\n      this.#overlayRef.dispose();\r\n      this.#overlayRef = null;\r\n    }\r\n  }\r\n\r\n  openPopover = () => {\r\n    if (this.popoverOpen) {\r\n      return;\r\n    }\r\n\r\n    const overlayRef = this.#createOverlay();\r\n    const overlayConfig = overlayRef.getConfig();\r\n    const positionStrategy =\r\n      overlayConfig.positionStrategy as FlexibleConnectedPositionStrategy;\r\n    this.#setPosition(positionStrategy);\r\n    overlayConfig.hasBackdrop = false;\r\n    overlayRef.attach(this.#getPortal());\r\n    this.popover.trigger = this;\r\n    this.#setIsPopoverOpen(true);\r\n  };\r\n\r\n  closePopover = () => {\r\n    this.popover.closed.emit();\r\n  };\r\n\r\n  #setIsPopoverOpen = (isOpen: boolean) => {\r\n    this.popoverOpen = isOpen;\r\n    this.popoverOpen ? this.popoverOpened.emit() : this.popoverClosed.emit();\r\n  };\r\n\r\n  #getPortal = (): TemplatePortal => {\r\n    if (\r\n      !this.#portal ||\r\n      this.#portal.templateRef !== this.popover.templateRef ||\r\n      this.#portal.context?.data !== this.popoverData\r\n    ) {\r\n      this.#portal = new TemplatePortal(\r\n        this.popover.templateRef,\r\n        this.viewContainerRef,\r\n        {\r\n          data: this.popoverData\r\n        }\r\n      );\r\n    }\r\n\r\n    return this.#portal;\r\n  };\r\n\r\n  #createOverlay = () => {\r\n    if (!this.#overlayRef) {\r\n      const config = this.#getOverlayConfig();\r\n      this.#subscribeToPositions(\r\n        config.positionStrategy as FlexibleConnectedPositionStrategy\r\n      );\r\n      this.#overlayRef = this._overlay.create(config);\r\n    }\r\n\r\n    return this.#overlayRef;\r\n  };\r\n\r\n  #setPosition = (positionStrategy: FlexibleConnectedPositionStrategy) => {\r\n    let originX: \"start\" | \"center\" | \"end\" = \"center\";\r\n    let originY: \"top\" | \"center\" | \"bottom\" = \"top\";\r\n    let overlayX: \"start\" | \"center\" | \"end\" = \"center\";\r\n    let overlayY: \"top\" | \"center\" | \"bottom\" = \"bottom\";\r\n    let offsetX = 0;\r\n    let offsetY = 16;\r\n\r\n    switch (this.popover.position) {\r\n      case \"above\":\r\n        originY = \"top\";\r\n        overlayY = \"bottom\";\r\n        break;\r\n      case \"below\":\r\n        originY = \"bottom\";\r\n        overlayY = \"top\";\r\n        break;\r\n    }\r\n\r\n    positionStrategy.withPositions([\r\n      // theo input\r\n      { originX, originY, overlayX, overlayY, offsetY: originY == \"top\" ? -offsetY : offsetY },\r\n      // giữa trên\r\n      {\r\n        originX: \"center\",\r\n        originY: \"top\",\r\n        overlayX: \"center\",\r\n        overlayY: \"bottom\",\r\n        offsetX,\r\n        offsetY: -offsetY,\r\n      },\r\n      // giữa dưới\r\n      {\r\n        originX: \"center\",\r\n        originY: \"bottom\",\r\n        overlayX: \"center\",\r\n        overlayY: \"top\",\r\n        offsetX,\r\n        offsetY,\r\n      },\r\n    ]);\r\n  };\r\n\r\n  #getOverlayConfig = () => {\r\n    return new OverlayConfig({\r\n      positionStrategy: this._overlay\r\n        .position()\r\n        .flexibleConnectedTo(this._element)\r\n        .withLockedPosition()\r\n        .withGrowAfterOpen()\r\n        .withTransformOriginOn(\".sd-popover-panel\"),\r\n      backdropClass: \"cdk-overlay-transparent-backdrop\",\r\n      panelClass: this.popover.panelClass,\r\n      direction: this._dir,\r\n      width: this.popover.width,\r\n      height: this.popover.height,\r\n    });\r\n  };\r\n\r\n  #subscribeToPositions = (position: FlexibleConnectedPositionStrategy) => {\r\n    if (this.popover.setPositionClasses) {\r\n      position.positionChanges.subscribe((change) => {\r\n        const pos: Position =\r\n          change.connectionPair.overlayY === \"top\" ? \"below\" : \"above\";\r\n\r\n        if (this._ngZone) {\r\n          this._ngZone.run(() => this.popover.setPositionClasses(pos));\r\n        } else {\r\n          this.popover.setPositionClasses(pos);\r\n        }\r\n\r\n        const originElement: HTMLElement = this.elementRef.nativeElement;\r\n        const overlayElement: HTMLElement = (\r\n          this.viewContainerRef.get(0) as any\r\n        )?.rootNodes[0];\r\n        if (originElement && overlayElement) {\r\n          const originRect = originElement.getBoundingClientRect();\r\n          const overlayRect = overlayElement.getBoundingClientRect();\r\n          const originLeft = originRect.left + originRect.width / 2;\r\n          const overlayLeft = overlayRect.left + overlayRect.width / 2;\r\n\r\n          const offset = originLeft - overlayLeft;\r\n\r\n          this.popover.addArrowTranslateX(offset);\r\n        }\r\n      });\r\n    }\r\n  };\r\n\r\n  #destroyPopover = () => {\r\n    if (!this.#overlayRef || !this.popoverOpen) {\r\n      return;\r\n    }\r\n    this.#overlayRef.detach();\r\n    this.#setIsPopoverOpen(false);\r\n  };\r\n}\r\n"]}
|
|
225
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"popover-trigger.directive.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/popover/","sources":["src/lib/directives/popover-trigger.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { Directionality } from \"@angular/cdk/bidi\";\r\nimport {\r\n  FlexibleConnectedPositionStrategy,\r\n  Overlay,\r\n  OverlayConfig,\r\n  OverlayRef,\r\n} from \"@angular/cdk/overlay\";\r\nimport { Platform } from \"@angular/cdk/platform\";\r\nimport { TemplatePortal } from \"@angular/cdk/portal\";\r\nimport {\r\n  AfterContentInit,\r\n  AfterViewInit,\r\n  Directive,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  NgZone,\r\n  OnDestroy,\r\n  Optional,\r\n  Output,\r\n  ViewContainerRef,\r\n} from \"@angular/core\";\r\nimport { fromEvent, merge, Subject, Subscription } from \"rxjs\";\r\nimport {\r\n  auditTime,\r\n  debounceTime,\r\n  distinctUntilChanged,\r\n  filter,\r\n  map,\r\n  mapTo,\r\n  takeUntil,\r\n  tap,\r\n} from \"rxjs/operators\";\r\nimport { Position } from \"../popover.model\";\r\nimport { PopoverComponent } from \"../popover/popover.component\";\r\n\r\n@Directive({\r\n  selector: \"[sdPopoverTriggerFor]\",\r\n  host: {\r\n    \"aria-haspopup\": \"true\",\r\n    class: \"sd-popover-trigger\",\r\n  },\r\n  exportAs: \"sdPopoverTrigger\",\r\n})\r\nexport class PopoverTriggerDirective implements AfterViewInit, OnDestroy {\r\n  #overlayRef: OverlayRef | null = null;\r\n  #popoverClose$ = Subscription.EMPTY;\r\n  #portal: TemplatePortal;\r\n  #destroy$ = new Subject();\r\n\r\n  popoverOpen = false;\r\n\r\n  @Input(\"sdPopoverTriggerFor\")\r\n  get popover() {\r\n    return this.#popover;\r\n  }\r\n  set popover(popover: PopoverComponent) {\r\n    if (popover === this.#popover) {\r\n      return;\r\n    }\r\n    this.#popover = popover;\r\n    this.#popoverClose$.unsubscribe();\r\n    if (popover) {\r\n      this.#popoverClose$ = popover.closed.subscribe(() => {\r\n        this.#destroyPopover();\r\n      });\r\n    }\r\n  }\r\n  #popover: PopoverComponent;\r\n\r\n  @Input(\"sdPopoverData\")\r\n  popoverData: any;\r\n\r\n  @Input(\"sdPopoverDisabled\")\r\n  disabled: boolean = false;\r\n\r\n  @Output() popoverOpened = new EventEmitter<void>();\r\n  @Output() popoverClosed = new EventEmitter<void>();\r\n\r\n  constructor(\r\n    private _overlay: Overlay,\r\n    private _element: ElementRef<HTMLElement>,\r\n    private _ngZone: NgZone,\r\n    private viewContainerRef: ViewContainerRef,\r\n    private elementRef: ElementRef,\r\n    private platform: Platform,\r\n    @Optional() private _dir: Directionality\r\n  ) {}\r\n\r\n  ngAfterViewInit(): void {\r\n    if (this.popover) {\r\n      const nativeElement = this.elementRef.nativeElement;\r\n\r\n      const hostMouseState$ = merge(\r\n        fromEvent(nativeElement, \"mouseenter\").pipe(mapTo(true)),\r\n        fromEvent(nativeElement, \"mouseleave\").pipe(mapTo(false))\r\n      );\r\n\r\n      const popoverMouseState$ = this.popover.mouseState$.pipe(\r\n        // chỉ lấy luồng emit open bởi chính trigger (tránh lỗi nhiều trigger cho một popover)\r\n        filter((v) => !this.popover.trigger || this.popover.trigger == this)\r\n      );\r\n\r\n      const mergedMouseState$ = merge(popoverMouseState$, hostMouseState$);\r\n\r\n      mergedMouseState$\r\n        .pipe(\r\n          debounceTime(100),\r\n          distinctUntilChanged(),\r\n          filter(() => this.platform.isBrowser),\r\n          takeUntil(this.#destroy$)\r\n        )\r\n        .subscribe((visible) => {\r\n          if (visible && !this.disabled) {\r\n            this.openPopover();\r\n          } else {\r\n            this.closePopover();\r\n          }\r\n        });\r\n    }\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.#destroy$.next();\r\n    this.#destroy$.complete();\r\n    if (this.#overlayRef) {\r\n      this.#overlayRef.dispose();\r\n      this.#overlayRef = null;\r\n    }\r\n  }\r\n\r\n  openPopover = () => {\r\n    if (this.popoverOpen) {\r\n      return;\r\n    }\r\n\r\n    const overlayRef = this.#createOverlay();\r\n    const overlayConfig = overlayRef.getConfig();\r\n    const positionStrategy =\r\n      overlayConfig.positionStrategy as FlexibleConnectedPositionStrategy;\r\n    this.#setPosition(positionStrategy);\r\n    overlayConfig.hasBackdrop = false;\r\n    overlayRef.attach(this.#getPortal());\r\n    this.popover.trigger = this;\r\n    this.#setIsPopoverOpen(true);\r\n  };\r\n\r\n  closePopover = () => {\r\n    this.popover.closed.emit();\r\n  };\r\n\r\n  #setIsPopoverOpen = (isOpen: boolean) => {\r\n    this.popoverOpen = isOpen;\r\n    this.popoverOpen ? this.popoverOpened.emit() : this.popoverClosed.emit();\r\n  };\r\n\r\n  #getPortal = (): TemplatePortal => {\r\n    if (\r\n      !this.#portal ||\r\n      this.#portal.templateRef !== this.popover.templateRef ||\r\n      this.#portal.context?.data !== this.popoverData\r\n    ) {\r\n      this.#portal = new TemplatePortal(\r\n        this.popover.templateRef,\r\n        this.viewContainerRef,\r\n        {\r\n          data: this.popoverData\r\n        }\r\n      );\r\n    }\r\n\r\n    return this.#portal;\r\n  };\r\n\r\n  #createOverlay = () => {\r\n    if (!this.#overlayRef) {\r\n      const config = this.#getOverlayConfig();\r\n      this.#subscribeToPositions(\r\n        config.positionStrategy as FlexibleConnectedPositionStrategy\r\n      );\r\n      this.#overlayRef = this._overlay.create(config);\r\n    }\r\n\r\n    return this.#overlayRef;\r\n  };\r\n\r\n  #setPosition = (positionStrategy: FlexibleConnectedPositionStrategy) => {\r\n    let originX: \"start\" | \"center\" | \"end\" = \"center\";\r\n    let originY: \"top\" | \"center\" | \"bottom\" = \"top\";\r\n    let overlayX: \"start\" | \"center\" | \"end\" = \"center\";\r\n    let overlayY: \"top\" | \"center\" | \"bottom\" = \"bottom\";\r\n    let offsetX = 0;\r\n    let offsetY = 16;\r\n\r\n    switch (this.popover.position) {\r\n      case \"above\":\r\n        originY = \"top\";\r\n        overlayY = \"bottom\";\r\n        break;\r\n      case \"below\":\r\n        originY = \"bottom\";\r\n        overlayY = \"top\";\r\n        break;\r\n    }\r\n\r\n    positionStrategy.withPositions([\r\n      // theo input\r\n      { originX, originY, overlayX, overlayY, offsetY: originY == \"top\" ? -offsetY : offsetY },\r\n      // giữa trên\r\n      {\r\n        originX: \"center\",\r\n        originY: \"top\",\r\n        overlayX: \"center\",\r\n        overlayY: \"bottom\",\r\n        offsetX,\r\n        offsetY: -offsetY,\r\n      },\r\n      // giữa dưới\r\n      {\r\n        originX: \"center\",\r\n        originY: \"bottom\",\r\n        overlayX: \"center\",\r\n        overlayY: \"top\",\r\n        offsetX,\r\n        offsetY,\r\n      },\r\n    ]);\r\n  };\r\n\r\n  #getOverlayConfig = () => {\r\n    return new OverlayConfig({\r\n      positionStrategy: this._overlay\r\n        .position()\r\n        .flexibleConnectedTo(this._element)\r\n        .withLockedPosition()\r\n        .withGrowAfterOpen()\r\n        .withTransformOriginOn(\".sd-popover-panel\"),\r\n      backdropClass: \"cdk-overlay-transparent-backdrop\",\r\n      panelClass: this.popover.panelClass,\r\n      direction: this._dir,\r\n      width: this.popover.width,\r\n      height: this.popover.height,\r\n    });\r\n  };\r\n\r\n  #subscribeToPositions = (position: FlexibleConnectedPositionStrategy) => {\r\n    if (this.popover.setPositionClasses) {\r\n      position.positionChanges.subscribe((change) => {\r\n        const pos: Position =\r\n          change.connectionPair.overlayY === \"top\" ? \"below\" : \"above\";\r\n\r\n        if (this._ngZone) {\r\n          this._ngZone.run(() => this.popover.setPositionClasses(pos));\r\n        } else {\r\n          this.popover.setPositionClasses(pos);\r\n        }\r\n\r\n        const originElement: HTMLElement = this.elementRef.nativeElement;\r\n        const overlayElement: HTMLElement = (\r\n          this.viewContainerRef.get(0) as any\r\n        )?.rootNodes[0];\r\n        if (originElement && overlayElement) {\r\n          const originRect = originElement.getBoundingClientRect();\r\n          const overlayRect = overlayElement.getBoundingClientRect();\r\n          const originLeft = originRect.left + originRect.width / 2;\r\n          const overlayLeft = overlayRect.left + overlayRect.width / 2;\r\n\r\n          const offset = originLeft - overlayLeft;\r\n\r\n          this.popover.addArrowTranslateX(offset);\r\n        }\r\n      });\r\n    }\r\n  };\r\n\r\n  #destroyPopover = () => {\r\n    if (!this.#overlayRef || !this.popoverOpen) {\r\n      return;\r\n    }\r\n    this.#overlayRef.detach();\r\n    this.#setIsPopoverOpen(false);\r\n  };\r\n}\r\n"]}
|
package/esm2015/public-api.js
CHANGED
|
@@ -18,6 +18,7 @@ import '@sd-angular/core/modal-resizable';
|
|
|
18
18
|
import '@sd-angular/core/db';
|
|
19
19
|
import '@sd-angular/core/group';
|
|
20
20
|
import '@sd-angular/core/json-editor';
|
|
21
|
+
import '@sd-angular/core/input-number';
|
|
21
22
|
export { SdCoreModule } from './lib/core.module';
|
|
22
23
|
export { MaterialModule } from './lib/material.module';
|
|
23
24
|
export * from './lib/material.module';
|
|
@@ -47,4 +48,4 @@ export * from '@sd-angular/core/radio';
|
|
|
47
48
|
export * from '@sd-angular/core/form';
|
|
48
49
|
export * from '@sd-angular/core/service';
|
|
49
50
|
export * from '@sd-angular/core/popover';
|
|
50
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiJDOi9Vc2Vycy9uZ2hpYXR0MTVfb25lbW91bnQvRG9jdW1lbnRzL2xpYi1jb3JlLXVpL3Byb2plY3RzL3NkLWNvcmUvc3JjLyIsInNvdXJjZXMiOlsicHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLHlCQUF5QixDQUFDO0FBQ2pDLE9BQU8sd0JBQXdCLENBQUM7QUFDaEMsT0FBTyxvQ0FBb0MsQ0FBQztBQUM1QyxPQUFPLHVCQUF1QixDQUFDO0FBQy9CLE9BQU8sMkJBQTJCLENBQUM7QUFDbkMsT0FBTywyQkFBMkIsQ0FBQztBQUNuQyxPQUFPLHVCQUF1QixDQUFDO0FBQy9CLE9BQU8sOEJBQThCLENBQUM7QUFDdEMsT0FBTyw2QkFBNkIsQ0FBQztBQUNyQyxPQUFPLHdCQUF3QixDQUFDO0FBQ2hDLE9BQU8sd0JBQXdCLENBQUM7QUFDaEMsT0FBTyx5QkFBeUIsQ0FBQztBQUNqQyxPQUFPLCtCQUErQixDQUFDO0FBQ3ZDLE9BQU8sZ0NBQWdDLENBQUM7QUFDeEMsT0FBTywwQkFBMEIsQ0FBQztBQUNsQyxPQUFPLHlCQUF5QixDQUFDO0FBQ2pDLE9BQU8sa0NBQWtDLENBQUM7QUFDMUMsT0FBTyxxQkFBcUIsQ0FBQztBQUM3QixPQUFPLHdCQUF3QixDQUFDO0FBQ2hDLE9BQU8sOEJBQThCLENBQUM7QUFDdEMsT0FBTywrQkFBK0IsQ0FBQztBQUV2QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDakQsT0FBTyxFQUFFLGNBQWMsRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3ZELGNBQWMsdUJBQXVCLENBQUM7QUFFdEMsT0FBTyxFQUFFLFdBQVcsRUFBRSxZQUFZLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUNqRSwwQ0FBMEM7QUFDMUMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsNkJBQTZCLENBQUM7QUFDNUMsY0FBYyw0QkFBNEIsQ0FBQztBQUMzQyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxPQUFPLEVBQUUsY0FBYyxFQUF3QixNQUFNLGdDQUFnQyxDQUFDO0FBQ3RGLGNBQWMsZ0NBQWdDLENBQUM7QUFDL0MsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYywrQkFBK0IsQ0FBQztBQUM5QyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyx1QkFBdUIsQ0FBQztBQUN0QyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsMEJBQTBCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgJ0BzZC1hbmd1bGFyL2NvcmUvY29tbW9uJztcclxuaW1wb3J0ICdAc2QtYW5ndWxhci9jb3JlL2xhYmVsJztcclxuaW1wb3J0ICdAc2QtYW5ndWxhci9jb3JlL2lucHV0LXVwbG9hZC1maWxlJztcclxuaW1wb3J0ICdAc2QtYW5ndWxhci9jb3JlL2NoaXAnO1xyXG5pbXBvcnQgJ0BzZC1hbmd1bGFyL2NvcmUvdGV4dGFyZWEnO1xyXG5pbXBvcnQgJ0BzZC1hbmd1bGFyL2NvcmUvY2hlY2tib3gnO1xyXG5pbXBvcnQgJ0BzZC1hbmd1bGFyL2NvcmUvdGltZSc7XHJcbmltcG9ydCAnQHNkLWFuZ3VsYXIvY29yZS9zaWRlLWRyYXdlcic7XHJcbmltcG9ydCAnQHNkLWFuZ3VsYXIvY29yZS90YWItcm91dGVyJztcclxuaW1wb3J0ICdAc2QtYW5ndWxhci9jb3JlL2V4Y2VsJztcclxuaW1wb3J0ICdAc2QtYW5ndWxhci9jb3JlL2lucHV0JztcclxuaW1wb3J0ICdAc2QtYW5ndWxhci9jb3JlL3NlbGVjdCc7XHJcbmltcG9ydCAnQHNkLWFuZ3VsYXIvY29yZS9xdWljay1hY3Rpb24nO1xyXG5pbXBvcnQgJ0BzZC1hbmd1bGFyL2NvcmUvaW1hZ2UtcHJldmlldyc7XHJcbmltcG9ydCAnQHNkLWFuZ3VsYXIvY29yZS9jb21tZW50JztcclxuaW1wb3J0ICdAc2QtYW5ndWxhci9jb3JlL2ZpbHRlcic7XHJcbmltcG9ydCAnQHNkLWFuZ3VsYXIvY29yZS9tb2RhbC1yZXNpemFibGUnO1xyXG5pbXBvcnQgJ0BzZC1hbmd1bGFyL2NvcmUvZGInO1xyXG5pbXBvcnQgJ0BzZC1hbmd1bGFyL2NvcmUvZ3JvdXAnO1xyXG5pbXBvcnQgJ0BzZC1hbmd1bGFyL2NvcmUvanNvbi1lZGl0b3InO1xyXG5pbXBvcnQgJ0BzZC1hbmd1bGFyL2NvcmUvaW5wdXQtbnVtYmVyJztcclxuXHJcbmV4cG9ydCB7IFNkQ29yZU1vZHVsZSB9IGZyb20gJy4vbGliL2NvcmUubW9kdWxlJztcclxuZXhwb3J0IHsgTWF0ZXJpYWxNb2R1bGUgfSBmcm9tICcuL2xpYi9tYXRlcmlhbC5tb2R1bGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tYXRlcmlhbC5tb2R1bGUnO1xyXG5cclxuZXhwb3J0IHsgU2RBcGlNb2R1bGUsIFNkQXBpU2VydmljZSB9IGZyb20gJ0BzZC1hbmd1bGFyL2NvcmUvYXBpJztcclxuLy8gZXhwb3J0ICogZnJvbSAnQHNkLWFuZ3VsYXIvY29yZS9leGNlbCc7XHJcbmV4cG9ydCAqIGZyb20gJ0BzZC1hbmd1bGFyL2NvcmUvbG9hZGluZyc7XHJcbmV4cG9ydCAqIGZyb20gJ0BzZC1hbmd1bGFyL2NvcmUvbm90aWZ5JztcclxuZXhwb3J0ICogZnJvbSAnQHNkLWFuZ3VsYXIvY29yZS9zZXR0aW5nJztcclxuZXhwb3J0ICogZnJvbSAnQHNkLWFuZ3VsYXIvY29yZS90cmFuc2xhdGUnO1xyXG5leHBvcnQgKiBmcm9tICdAc2QtYW5ndWxhci9jb3JlL3V0aWxpdHknO1xyXG5leHBvcnQgKiBmcm9tICdAc2QtYW5ndWxhci9jb3JlL2R5bmFtaWMtcmVwb3J0JztcclxuZXhwb3J0ICogZnJvbSAnQHNkLWFuZ3VsYXIvY29yZS9jaGFydCc7XHJcbmV4cG9ydCAqIGZyb20gJ0BzZC1hbmd1bGFyL2NvcmUvdXBsb2FkLWZpbGUnO1xyXG5leHBvcnQgKiBmcm9tICdAc2QtYW5ndWxhci9jb3JlL2RhdGUtcmFuZ2UnO1xyXG5leHBvcnQgKiBmcm9tICdAc2QtYW5ndWxhci9jb3JlL2RhdGUtdGltZSc7XHJcbmV4cG9ydCAqIGZyb20gJ0BzZC1hbmd1bGFyL2NvcmUvYnV0dG9uJztcclxuZXhwb3J0ICogZnJvbSAnQHNkLWFuZ3VsYXIvY29yZS9rb252YSc7XHJcbmV4cG9ydCAqIGZyb20gJ0BzZC1hbmd1bGFyL2NvcmUvYXV0b2NvbXBsZXRlJztcclxuZXhwb3J0IHsgU2RHcmlkTWF0ZXJpYWwsIFNkR3JpZE1hdGVyaWFsT3B0aW9uIH0gZnJvbSAnQHNkLWFuZ3VsYXIvY29yZS9ncmlkLW1hdGVyaWFsJztcclxuZXhwb3J0ICogZnJvbSAnQHNkLWFuZ3VsYXIvY29yZS9zZWxlY3QtZWRpdG9yJztcclxuZXhwb3J0ICogZnJvbSAnQHNkLWFuZ3VsYXIvY29yZS9lZGl0b3InO1xyXG5leHBvcnQgKiBmcm9tICdAc2QtYW5ndWxhci9jb3JlL21vZGFsJztcclxuZXhwb3J0ICogZnJvbSAnQHNkLWFuZ3VsYXIvY29yZS9ncmlkJztcclxuZXhwb3J0ICogZnJvbSAnQHNkLWFuZ3VsYXIvY29yZS91cGxvYWQtZXhjZWwnO1xyXG5leHBvcnQgKiBmcm9tICdAc2QtYW5ndWxhci9jb3JlL3N3aXRjaCc7XHJcbmV4cG9ydCAqIGZyb20gJ0BzZC1hbmd1bGFyL2NvcmUvcmFkaW8nO1xyXG5leHBvcnQgKiBmcm9tICdAc2QtYW5ndWxhci9jb3JlL2Zvcm0nO1xyXG5leHBvcnQgKiBmcm9tICdAc2QtYW5ndWxhci9jb3JlL3NlcnZpY2UnO1xyXG5leHBvcnQgKiBmcm9tICdAc2QtYW5ndWxhci9jb3JlL3BvcG92ZXInO1xyXG4iXX0=
|
|
@@ -314,7 +314,7 @@ _model = new WeakMap(), _delay = new WeakMap(), _name = new WeakMap(), _form = n
|
|
|
314
314
|
SdAutocomplete.decorators = [
|
|
315
315
|
{ type: Component, args: [{
|
|
316
316
|
selector: 'sd-autocomplete',
|
|
317
|
-
template: "<label *ngIf=\"!appearance && label\" class=\"d-block mb-0 T14M\">{{label}} <span class=\"text-danger mb-2\"\r\n *ngIf=\"isRequired\">*</span></label>\r\n<div class=\"d-flex align-items-center\" [class.sd-view]=\"sdView?.templateRef\" [class.c-focused]=\"isFocused\"\r\n [class.c-disabled]=\"formControl.disabled\" (click)=\"onClick()\">\r\n <ng-container *ngIf=\"sdView?.templateRef && !autocompleteTrigger?.panelOpen && !isFocused; else default\">\r\n <ng-container\r\n *ngTemplateOutlet=\"sdView.templateRef;context: { value: formControl.value, selectedItem: selected | async }\">\r\n </ng-container>\r\n </ng-container>\r\n <ng-template #default>\r\n <mat-form-field class=\"sd-md\" [ngClass]=\"{'sd-sm': size === 'sm', 'no-padding-wrapper': disableErrorMessage}\"\r\n [floatLabel]=\"size === 'sm' || formControl.value ? 'always':'auto'\" [appearance]=\"appearance || 'outline'\">\r\n <mat-label *ngIf=\"appearance && label\">{{ label }}</mat-label>\r\n <input [id]=\"id\" #autocompleteTrigger [formControl]=\"inputControl\" [placeholder]=\"controlPlaceHolder | async\"\r\n [ngClass]=\"{'c-selected': formControl?.value}\" [matAutocomplete]=\"auto\" (focus)=\"onFocus()\" (blur)=\"onBlur()\"\r\n matInput [autocomplete]=\"id\" autocorrect=\"off\" [errorStateMatcher]=\"matcher\" [required]=\"isRequired\" [attr.data-qclabel]=\"label\" [attr.data-qcid]=\"qcId\" #input />\r\n <mat-icon *ngIf=\"!loading && formControl?.value && !inputControl.disabled\" class=\"pointer sd-suffix-icon\"\r\n (click)=\"clear($event)\" matSuffix>cancel\r\n </mat-icon>\r\n <mat-icon *ngIf=\"actionIcon && !loading && !formControl?.value && !inputControl.disabled\"\r\n class=\"pointer sd-suffix-icon\" (click)=\"onAction($event)\" matSuffix>{{actionIcon}}\r\n </mat-icon>\r\n <mat-spinner *ngIf=\"loading\" strokeWidth=\"2\" mode=\"indeterminate\" diameter=\"18\" value=\"100\" matSuffix>\r\n </mat-spinner>\r\n <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"onSelect($event.option.value)\">\r\n <mat-option *ngFor=\"let item of filteredItems | async\" [value]=\"item\" matTooltipPosition=\"above\"\r\n [matTooltip]=\"displayField ? item[displayField] : item\">\r\n <ng-container *ngIf=\"autocompleteDisplayDef?.templateRef\">\r\n <ng-container *ngTemplateOutlet=\"autocompleteDisplayDef.templateRef;context:{item: item}\">\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"!autocompleteDisplayDef?.templateRef\">\r\n {{ displayField ? item[displayField] : item }}\r\n </ng-container>\r\n </mat-option>\r\n </mat-autocomplete>\r\n <mat-error *ngIf=\"formControl?.errors?.required && !disableErrorMessage\">\r\n {{ \"This field is required\" | sdTranslate }}\r\n </mat-error>\r\n </mat-form-field>\r\n </ng-template>\r\n</div>",
|
|
317
|
+
template: "<label *ngIf=\"!appearance && label\" class=\"d-block mb-0 T14M\">{{label}} <span class=\"text-danger mb-2\"\r\n *ngIf=\"isRequired\">*</span></label>\r\n<div class=\"d-flex align-items-center\" [class.sd-view]=\"sdView?.templateRef\" [class.c-focused]=\"isFocused\"\r\n [class.c-disabled]=\"formControl.disabled\" (click)=\"onClick()\">\r\n <ng-container *ngIf=\"sdView?.templateRef && !autocompleteTrigger?.panelOpen && !isFocused; else default\">\r\n <ng-container\r\n *ngTemplateOutlet=\"sdView.templateRef;context: { value: formControl.value, selectedItem: selected | async }\">\r\n </ng-container>\r\n </ng-container>\r\n <ng-template #default>\r\n <mat-form-field class=\"sd-md\" [ngClass]=\"{'sd-sm': size === 'sm', 'no-padding-wrapper': disableErrorMessage}\"\r\n [floatLabel]=\"size === 'sm' || formControl.value ? 'always':'auto'\" [appearance]=\"appearance || 'outline'\">\r\n <mat-label *ngIf=\"appearance && label\">{{ label }}</mat-label>\r\n <input [id]=\"id\" #autocompleteTrigger [formControl]=\"inputControl\" [placeholder]=\"controlPlaceHolder | async\"\r\n [ngClass]=\"{'c-selected': formControl?.value}\" [matAutocomplete]=\"auto\" (focus)=\"onFocus()\" (blur)=\"onBlur()\"\r\n matInput [autocomplete]=\"id\" autocorrect=\"off\" [errorStateMatcher]=\"matcher\" [required]=\"isRequired\" [attr.data-qclabel]=\"label\" [attr.data-qcid]=\"qcId\" #input />\r\n <mat-icon *ngIf=\"!loading && formControl?.value && !inputControl.disabled\" class=\"pointer sd-suffix-icon\"\r\n (click)=\"clear($event)\" matSuffix>cancel\r\n </mat-icon>\r\n <mat-icon *ngIf=\"actionIcon && !loading && !formControl?.value && !inputControl.disabled\"\r\n class=\"pointer sd-suffix-icon\" (click)=\"onAction($event)\" matSuffix>{{actionIcon}}\r\n </mat-icon>\r\n <mat-spinner *ngIf=\"loading\" strokeWidth=\"2\" mode=\"indeterminate\" diameter=\"18\" value=\"100\" matSuffix>\r\n </mat-spinner>\r\n <mat-autocomplete #auto=\"matAutocomplete\" (optionSelected)=\"onSelect($event.option.value)\">\r\n <mat-option *ngFor=\"let item of filteredItems | async\" [value]=\"item\" matTooltipPosition=\"above\"\r\n [matTooltip]=\"displayField ? item[displayField] : item\">\r\n <ng-container *ngIf=\"autocompleteDisplayDef?.templateRef\">\r\n <ng-container *ngTemplateOutlet=\"autocompleteDisplayDef.templateRef;context:{item: item}\">\r\n </ng-container>\r\n </ng-container>\r\n <ng-container *ngIf=\"!autocompleteDisplayDef?.templateRef\">\r\n {{ displayField ? item[displayField] : item }}\r\n </ng-container>\r\n </mat-option>\r\n <mat-option *ngIf=\"!(filteredItems | async)?.length\" \r\n [value]=\"\" style=\"color: #4d4d4d\">\r\n Kh\u00F4ng c\u00F3 d\u1EEF li\u1EC7u\r\n </mat-option>\r\n </mat-autocomplete>\r\n <mat-error *ngIf=\"formControl?.errors?.required && !disableErrorMessage\">\r\n {{ \"This field is required\" | sdTranslate }}\r\n </mat-error>\r\n </mat-form-field>\r\n </ng-template>\r\n</div>",
|
|
318
318
|
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
319
319
|
styles: [":host{display:block;padding-top:5px}:host ::ng-deep .mat-form-field.no-padding-wrapper .mat-form-field-wrapper{padding-bottom:0}:host ::ng-deep .mat-form-field.mat-form-field-appearance-outline.mat-form-field-disabled .mat-form-field-outline{background:#f6f6f6;color:#e9e9e9}:host ::ng-deep .mat-form-field input.c-selected::-moz-placeholder{color:#000;opacity:1}:host ::ng-deep .mat-form-field input.c-selected::placeholder{color:#000;opacity:1}:host ::ng-deep .mat-form-field input.c-selected:-ms-input-placeholder{color:#000}:host ::ng-deep .mat-form-field input.c-selected::-ms-input-placeholder{color:#000}:host ::ng-deep .mat-form-field input.mat-input-element:disabled{color:#4d4d4d}:host ::ng-deep .mat-form-field input.mat-input-element:disabled.c-selected::-moz-placeholder{color:#4d4d4d}:host ::ng-deep .mat-form-field input.mat-input-element:disabled.c-selected::placeholder{color:#4d4d4d}:host ::ng-deep .mat-form-field input.mat-input-element:disabled.c-selected:-ms-input-placeholder{color:#4d4d4d}:host ::ng-deep .mat-form-field input.mat-input-element:disabled.c-selected::-ms-input-placeholder{color:#4d4d4d}:host ::ng-deep .mat-form-field .mat-placeholder-required{color:#f82c13}.sd-view:not(.c-focused):not(.c-disabled):hover{background-color:#ebecf0}"]
|
|
320
320
|
},] }
|