@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.
Files changed (76) hide show
  1. package/autocomplete/sd-angular-core-autocomplete.metadata.json +1 -1
  2. package/bundles/sd-angular-core-autocomplete.umd.js +1 -1
  3. package/bundles/sd-angular-core-autocomplete.umd.js.map +1 -1
  4. package/bundles/sd-angular-core-autocomplete.umd.min.js +1 -1
  5. package/bundles/sd-angular-core-autocomplete.umd.min.js.map +1 -1
  6. package/bundles/sd-angular-core-comment.umd.js +2 -2
  7. package/bundles/sd-angular-core-comment.umd.js.map +1 -1
  8. package/bundles/sd-angular-core-comment.umd.min.js +1 -1
  9. package/bundles/sd-angular-core-comment.umd.min.js.map +1 -1
  10. package/bundles/sd-angular-core-form.umd.js +6 -4
  11. package/bundles/sd-angular-core-form.umd.js.map +1 -1
  12. package/bundles/sd-angular-core-form.umd.min.js +1 -1
  13. package/bundles/sd-angular-core-form.umd.min.js.map +1 -1
  14. package/bundles/sd-angular-core-grid-material.umd.js +1 -1
  15. package/bundles/sd-angular-core-grid-material.umd.js.map +1 -1
  16. package/bundles/sd-angular-core-grid-material.umd.min.js +1 -1
  17. package/bundles/sd-angular-core-grid-material.umd.min.js.map +1 -1
  18. package/bundles/sd-angular-core-grid.umd.js +1 -1
  19. package/bundles/sd-angular-core-grid.umd.js.map +1 -1
  20. package/bundles/sd-angular-core-grid.umd.min.js +1 -1
  21. package/bundles/sd-angular-core-grid.umd.min.js.map +1 -1
  22. package/bundles/sd-angular-core-input-number.umd.js +745 -0
  23. package/bundles/sd-angular-core-input-number.umd.js.map +1 -0
  24. package/bundles/sd-angular-core-input-number.umd.min.js +16 -0
  25. package/bundles/sd-angular-core-input-number.umd.min.js.map +1 -0
  26. package/bundles/sd-angular-core-popover.umd.js +3 -1
  27. package/bundles/sd-angular-core-popover.umd.js.map +1 -1
  28. package/bundles/sd-angular-core-popover.umd.min.js +1 -1
  29. package/bundles/sd-angular-core-popover.umd.min.js.map +1 -1
  30. package/bundles/sd-angular-core.umd.js +4 -4
  31. package/bundles/sd-angular-core.umd.min.js +1 -1
  32. package/bundles/sd-angular-core.umd.min.js.map +1 -1
  33. package/comment/sd-angular-core-comment.metadata.json +1 -1
  34. package/esm2015/autocomplete/src/lib/autocomplete.component.js +2 -2
  35. package/esm2015/comment/src/lib/comment.component.js +3 -3
  36. package/esm2015/form/src/lib/form.module.js +4 -1
  37. package/esm2015/grid/src/lib/components/grid-desktop-column-edit/grid-desktop-column-edit.component.js +2 -2
  38. package/esm2015/grid-material/src/lib/components/desktop-cell-editor/desktop-cell-editor.component.js +2 -2
  39. package/esm2015/input-number/index.js +2 -0
  40. package/esm2015/input-number/sd-angular-core-input-number.js +5 -0
  41. package/esm2015/input-number/src/lib/input-number.component.js +335 -0
  42. package/esm2015/input-number/src/lib/input-number.module.js +34 -0
  43. package/esm2015/input-number/src/public-api.js +6 -0
  44. package/esm2015/popover/src/lib/directives/popover-trigger.directive.js +4 -2
  45. package/esm2015/public-api.js +2 -1
  46. package/fesm2015/sd-angular-core-autocomplete.js +1 -1
  47. package/fesm2015/sd-angular-core-autocomplete.js.map +1 -1
  48. package/fesm2015/sd-angular-core-comment.js +2 -2
  49. package/fesm2015/sd-angular-core-comment.js.map +1 -1
  50. package/fesm2015/sd-angular-core-form.js +3 -0
  51. package/fesm2015/sd-angular-core-form.js.map +1 -1
  52. package/fesm2015/sd-angular-core-grid-material.js +1 -1
  53. package/fesm2015/sd-angular-core-grid-material.js.map +1 -1
  54. package/fesm2015/sd-angular-core-grid.js +1 -1
  55. package/fesm2015/sd-angular-core-grid.js.map +1 -1
  56. package/fesm2015/sd-angular-core-input-number.js +373 -0
  57. package/fesm2015/sd-angular-core-input-number.js.map +1 -0
  58. package/fesm2015/sd-angular-core-popover.js +3 -1
  59. package/fesm2015/sd-angular-core-popover.js.map +1 -1
  60. package/fesm2015/sd-angular-core.js +1 -0
  61. package/fesm2015/sd-angular-core.js.map +1 -1
  62. package/form/sd-angular-core-form.metadata.json +1 -1
  63. package/grid/sd-angular-core-grid.metadata.json +1 -1
  64. package/grid-material/sd-angular-core-grid-material.metadata.json +1 -1
  65. package/input-number/index.d.ts +1 -0
  66. package/input-number/package.json +12 -0
  67. package/input-number/sd-angular-core-input-number.d.ts +4 -0
  68. package/input-number/sd-angular-core-input-number.metadata.json +1 -0
  69. package/input-number/src/lib/input-number.component.d.ts +62 -0
  70. package/input-number/src/lib/input-number.module.d.ts +2 -0
  71. package/input-number/src/public-api.d.ts +2 -0
  72. package/package.json +1 -1
  73. package/popover/sd-angular-core-popover.metadata.json +1 -1
  74. package/popover/src/lib/directives/popover-trigger.directive.d.ts +1 -0
  75. package/public-api.d.ts +1 -0
  76. 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"]}
@@ -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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiJDOi9Vc2Vycy9uZ2hpYXR0MTVfb25lbW91bnQvRG9jdW1lbnRzL2xpYi1jb3JlLXVpL3Byb2plY3RzL3NkLWNvcmUvc3JjLyIsInNvdXJjZXMiOlsicHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLHlCQUF5QixDQUFDO0FBQ2pDLE9BQU8sd0JBQXdCLENBQUM7QUFDaEMsT0FBTyxvQ0FBb0MsQ0FBQztBQUM1QyxPQUFPLHVCQUF1QixDQUFDO0FBQy9CLE9BQU8sMkJBQTJCLENBQUM7QUFDbkMsT0FBTywyQkFBMkIsQ0FBQztBQUNuQyxPQUFPLHVCQUF1QixDQUFDO0FBQy9CLE9BQU8sOEJBQThCLENBQUM7QUFDdEMsT0FBTyw2QkFBNkIsQ0FBQztBQUNyQyxPQUFPLHdCQUF3QixDQUFDO0FBQ2hDLE9BQU8sd0JBQXdCLENBQUM7QUFDaEMsT0FBTyx5QkFBeUIsQ0FBQztBQUNqQyxPQUFPLCtCQUErQixDQUFDO0FBQ3ZDLE9BQU8sZ0NBQWdDLENBQUM7QUFDeEMsT0FBTywwQkFBMEIsQ0FBQztBQUNsQyxPQUFPLHlCQUF5QixDQUFDO0FBQ2pDLE9BQU8sa0NBQWtDLENBQUM7QUFDMUMsT0FBTyxxQkFBcUIsQ0FBQztBQUM3QixPQUFPLHdCQUF3QixDQUFDO0FBQ2hDLE9BQU8sOEJBQThCLENBQUM7QUFFdEMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBQ2pELE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUN2RCxjQUFjLHVCQUF1QixDQUFDO0FBRXRDLE9BQU8sRUFBRSxXQUFXLEVBQUUsWUFBWSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDakUsMENBQTBDO0FBQzFDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLDBCQUEwQixDQUFDO0FBQ3pDLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLGlDQUFpQyxDQUFDO0FBQ2hELGNBQWMsd0JBQXdCLENBQUM7QUFDdkMsY0FBYyw4QkFBOEIsQ0FBQztBQUM3QyxjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsNEJBQTRCLENBQUM7QUFDM0MsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsT0FBTyxFQUFFLGNBQWMsRUFBd0IsTUFBTSxnQ0FBZ0MsQ0FBQztBQUN0RixjQUFjLGdDQUFnQyxDQUFDO0FBQy9DLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYyx3QkFBd0IsQ0FBQztBQUN2QyxjQUFjLHVCQUF1QixDQUFDO0FBQ3RDLGNBQWMsK0JBQStCLENBQUM7QUFDOUMsY0FBYyx5QkFBeUIsQ0FBQztBQUN4QyxjQUFjLHdCQUF3QixDQUFDO0FBQ3ZDLGNBQWMsdUJBQXVCLENBQUM7QUFDdEMsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLDBCQUEwQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICdAc2QtYW5ndWxhci9jb3JlL2NvbW1vbic7XHJcbmltcG9ydCAnQHNkLWFuZ3VsYXIvY29yZS9sYWJlbCc7XHJcbmltcG9ydCAnQHNkLWFuZ3VsYXIvY29yZS9pbnB1dC11cGxvYWQtZmlsZSc7XHJcbmltcG9ydCAnQHNkLWFuZ3VsYXIvY29yZS9jaGlwJztcclxuaW1wb3J0ICdAc2QtYW5ndWxhci9jb3JlL3RleHRhcmVhJztcclxuaW1wb3J0ICdAc2QtYW5ndWxhci9jb3JlL2NoZWNrYm94JztcclxuaW1wb3J0ICdAc2QtYW5ndWxhci9jb3JlL3RpbWUnO1xyXG5pbXBvcnQgJ0BzZC1hbmd1bGFyL2NvcmUvc2lkZS1kcmF3ZXInO1xyXG5pbXBvcnQgJ0BzZC1hbmd1bGFyL2NvcmUvdGFiLXJvdXRlcic7XHJcbmltcG9ydCAnQHNkLWFuZ3VsYXIvY29yZS9leGNlbCc7XHJcbmltcG9ydCAnQHNkLWFuZ3VsYXIvY29yZS9pbnB1dCc7XHJcbmltcG9ydCAnQHNkLWFuZ3VsYXIvY29yZS9zZWxlY3QnO1xyXG5pbXBvcnQgJ0BzZC1hbmd1bGFyL2NvcmUvcXVpY2stYWN0aW9uJztcclxuaW1wb3J0ICdAc2QtYW5ndWxhci9jb3JlL2ltYWdlLXByZXZpZXcnO1xyXG5pbXBvcnQgJ0BzZC1hbmd1bGFyL2NvcmUvY29tbWVudCc7XHJcbmltcG9ydCAnQHNkLWFuZ3VsYXIvY29yZS9maWx0ZXInO1xyXG5pbXBvcnQgJ0BzZC1hbmd1bGFyL2NvcmUvbW9kYWwtcmVzaXphYmxlJztcclxuaW1wb3J0ICdAc2QtYW5ndWxhci9jb3JlL2RiJztcclxuaW1wb3J0ICdAc2QtYW5ndWxhci9jb3JlL2dyb3VwJztcclxuaW1wb3J0ICdAc2QtYW5ndWxhci9jb3JlL2pzb24tZWRpdG9yJztcclxuXHJcbmV4cG9ydCB7IFNkQ29yZU1vZHVsZSB9IGZyb20gJy4vbGliL2NvcmUubW9kdWxlJztcclxuZXhwb3J0IHsgTWF0ZXJpYWxNb2R1bGUgfSBmcm9tICcuL2xpYi9tYXRlcmlhbC5tb2R1bGUnO1xyXG5leHBvcnQgKiBmcm9tICcuL2xpYi9tYXRlcmlhbC5tb2R1bGUnO1xyXG5cclxuZXhwb3J0IHsgU2RBcGlNb2R1bGUsIFNkQXBpU2VydmljZSB9IGZyb20gJ0BzZC1hbmd1bGFyL2NvcmUvYXBpJztcclxuLy8gZXhwb3J0ICogZnJvbSAnQHNkLWFuZ3VsYXIvY29yZS9leGNlbCc7XHJcbmV4cG9ydCAqIGZyb20gJ0BzZC1hbmd1bGFyL2NvcmUvbG9hZGluZyc7XHJcbmV4cG9ydCAqIGZyb20gJ0BzZC1hbmd1bGFyL2NvcmUvbm90aWZ5JztcclxuZXhwb3J0ICogZnJvbSAnQHNkLWFuZ3VsYXIvY29yZS9zZXR0aW5nJztcclxuZXhwb3J0ICogZnJvbSAnQHNkLWFuZ3VsYXIvY29yZS90cmFuc2xhdGUnO1xyXG5leHBvcnQgKiBmcm9tICdAc2QtYW5ndWxhci9jb3JlL3V0aWxpdHknO1xyXG5leHBvcnQgKiBmcm9tICdAc2QtYW5ndWxhci9jb3JlL2R5bmFtaWMtcmVwb3J0JztcclxuZXhwb3J0ICogZnJvbSAnQHNkLWFuZ3VsYXIvY29yZS9jaGFydCc7XHJcbmV4cG9ydCAqIGZyb20gJ0BzZC1hbmd1bGFyL2NvcmUvdXBsb2FkLWZpbGUnO1xyXG5leHBvcnQgKiBmcm9tICdAc2QtYW5ndWxhci9jb3JlL2RhdGUtcmFuZ2UnO1xyXG5leHBvcnQgKiBmcm9tICdAc2QtYW5ndWxhci9jb3JlL2RhdGUtdGltZSc7XHJcbmV4cG9ydCAqIGZyb20gJ0BzZC1hbmd1bGFyL2NvcmUvYnV0dG9uJztcclxuZXhwb3J0ICogZnJvbSAnQHNkLWFuZ3VsYXIvY29yZS9rb252YSc7XHJcbmV4cG9ydCAqIGZyb20gJ0BzZC1hbmd1bGFyL2NvcmUvYXV0b2NvbXBsZXRlJztcclxuZXhwb3J0IHsgU2RHcmlkTWF0ZXJpYWwsIFNkR3JpZE1hdGVyaWFsT3B0aW9uIH0gZnJvbSAnQHNkLWFuZ3VsYXIvY29yZS9ncmlkLW1hdGVyaWFsJztcclxuZXhwb3J0ICogZnJvbSAnQHNkLWFuZ3VsYXIvY29yZS9zZWxlY3QtZWRpdG9yJztcclxuZXhwb3J0ICogZnJvbSAnQHNkLWFuZ3VsYXIvY29yZS9lZGl0b3InO1xyXG5leHBvcnQgKiBmcm9tICdAc2QtYW5ndWxhci9jb3JlL21vZGFsJztcclxuZXhwb3J0ICogZnJvbSAnQHNkLWFuZ3VsYXIvY29yZS9ncmlkJztcclxuZXhwb3J0ICogZnJvbSAnQHNkLWFuZ3VsYXIvY29yZS91cGxvYWQtZXhjZWwnO1xyXG5leHBvcnQgKiBmcm9tICdAc2QtYW5ndWxhci9jb3JlL3N3aXRjaCc7XHJcbmV4cG9ydCAqIGZyb20gJ0BzZC1hbmd1bGFyL2NvcmUvcmFkaW8nO1xyXG5leHBvcnQgKiBmcm9tICdAc2QtYW5ndWxhci9jb3JlL2Zvcm0nO1xyXG5leHBvcnQgKiBmcm9tICdAc2QtYW5ndWxhci9jb3JlL3NlcnZpY2UnO1xyXG5leHBvcnQgKiBmcm9tICdAc2QtYW5ndWxhci9jb3JlL3BvcG92ZXInO1xyXG4iXX0=
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
  },] }