@sd-angular/core 1.0.78 → 1.0.79

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 (44) hide show
  1. package/bundles/sd-angular-core-chip.umd.js +197 -43
  2. package/bundles/sd-angular-core-chip.umd.js.map +1 -1
  3. package/bundles/sd-angular-core-chip.umd.min.js +2 -2
  4. package/bundles/sd-angular-core-chip.umd.min.js.map +1 -1
  5. package/bundles/sd-angular-core-grid-material.umd.js +1 -1
  6. package/bundles/sd-angular-core-grid-material.umd.js.map +1 -1
  7. package/bundles/sd-angular-core-grid-material.umd.min.js +1 -1
  8. package/bundles/sd-angular-core-grid-material.umd.min.js.map +1 -1
  9. package/bundles/sd-angular-core-loading.umd.js +367 -22
  10. package/bundles/sd-angular-core-loading.umd.js.map +1 -1
  11. package/bundles/sd-angular-core-loading.umd.min.js +15 -1
  12. package/bundles/sd-angular-core-loading.umd.min.js.map +1 -1
  13. package/bundles/sd-angular-core-radio.umd.js +36 -21
  14. package/bundles/sd-angular-core-radio.umd.js.map +1 -1
  15. package/bundles/sd-angular-core-radio.umd.min.js +2 -2
  16. package/bundles/sd-angular-core-radio.umd.min.js.map +1 -1
  17. package/bundles/sd-angular-core-select.umd.js +0 -1
  18. package/bundles/sd-angular-core-select.umd.js.map +1 -1
  19. package/bundles/sd-angular-core-select.umd.min.js +2 -2
  20. package/bundles/sd-angular-core-select.umd.min.js.map +1 -1
  21. package/chip/sd-angular-core-chip.metadata.json +1 -1
  22. package/chip/src/lib/chip.component.d.ts +6 -4
  23. package/esm2015/chip/src/lib/chip.component.js +156 -33
  24. package/esm2015/grid-material/src/lib/components/desktop-cell-view/desktop-cell-view.component.js +2 -2
  25. package/esm2015/loading/src/lib/loading.service.js +49 -14
  26. package/esm2015/radio/src/lib/radio.component.js +36 -21
  27. package/esm2015/select/src/lib/select.component.js +1 -2
  28. package/fesm2015/sd-angular-core-chip.js +155 -32
  29. package/fesm2015/sd-angular-core-chip.js.map +1 -1
  30. package/fesm2015/sd-angular-core-grid-material.js +1 -1
  31. package/fesm2015/sd-angular-core-grid-material.js.map +1 -1
  32. package/fesm2015/sd-angular-core-loading.js +48 -13
  33. package/fesm2015/sd-angular-core-loading.js.map +1 -1
  34. package/fesm2015/sd-angular-core-radio.js +35 -21
  35. package/fesm2015/sd-angular-core-radio.js.map +1 -1
  36. package/fesm2015/sd-angular-core-select.js +0 -1
  37. package/fesm2015/sd-angular-core-select.js.map +1 -1
  38. package/grid-material/sd-angular-core-grid-material.metadata.json +1 -1
  39. package/loading/sd-angular-core-loading.metadata.json +1 -1
  40. package/loading/src/lib/loading.service.d.ts +5 -2
  41. package/package.json +1 -1
  42. package/radio/sd-angular-core-radio.metadata.json +1 -1
  43. package/radio/src/lib/radio.component.d.ts +5 -5
  44. package/{sd-angular-core-1.0.78.tgz → sd-angular-core-1.0.79.tgz} +0 -0
@@ -1,15 +1,15 @@
1
- var _name, _form, _itemChanges, _items, _subscription, _updateValidator;
2
- import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
1
+ var _name, _form, _itemChanges, _items, _allItems, _allItem, _cache, _delay, _itemsChanges, _subscription, _updateValidator, _loadItems, _loadSelectedItems;
2
+ import { __awaiter, __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
3
3
  import { Component, Input, ViewChild, Output, EventEmitter, ChangeDetectorRef, ContentChild } from '@angular/core';
4
4
  import { COMMA, ENTER } from '@angular/cdk/keycodes';
5
- import { map, startWith } from 'rxjs/operators';
5
+ import { debounceTime, map, startWith, switchMap } from 'rxjs/operators';
6
6
  import * as uuid from 'uuid';
7
7
  import { NgForm, FormControl, Validators } from '@angular/forms';
8
- import { Subscription, Subject } from 'rxjs';
8
+ import { Subscription, Subject, BehaviorSubject, combineLatest } from 'rxjs';
9
9
  import { SdUtilityService } from '@sd-angular/core/utility';
10
10
  import { MatAutocompleteTrigger } from '@angular/material/autocomplete';
11
11
  import { SdChipDisplayDef } from './directives/sd-chip-display-def.directive';
12
- import { SdViewDefDirective } from '@sd-angular/core/common';
12
+ import { SdFormControl, SdViewDefDirective } from '@sd-angular/core/common';
13
13
  class SdChipErrotStateMatcher {
14
14
  constructor(formControl) {
15
15
  this.formControl = formControl;
@@ -31,8 +31,25 @@ export class SdChip {
31
31
  this.removable = true;
32
32
  _itemChanges.set(this, new Subject());
33
33
  _items.set(this, []);
34
+ // @Input() set items(items: undefined | any[]) {
35
+ // if (!items) {
36
+ // this.#items = [];
37
+ // } else if (Array.isArray(items)) {
38
+ // this.#items = items.filter(e => (e ?? '').toString().trim() !== '');
39
+ // } else {
40
+ // this.#items = items;
41
+ // }
42
+ // this.inputControl.updateValueAndValidity();
43
+ // this.#itemChanges.next(this.items);
44
+ // }
45
+ // Server search
46
+ this.loading = false;
47
+ _allItems.set(this, void 0);
48
+ _allItem.set(this, {});
49
+ _cache.set(this, {});
50
+ _delay.set(this, 200); // Sau khoảng thời gian delay nếu không có thay đổi thì thì mới bắt đầu thực hiện gọi hàm
51
+ _itemsChanges.set(this, new BehaviorSubject([]));
34
52
  this.limit = 50;
35
- this.selectedItems = [];
36
53
  // Validator
37
54
  this.isRequired = false;
38
55
  this.modelChange = new EventEmitter();
@@ -41,7 +58,7 @@ export class SdChip {
41
58
  this.chipSelected = new EventEmitter();
42
59
  this.isFocused = false;
43
60
  this.inputControl = new FormControl();
44
- this.formControl = new FormControl();
61
+ this.formControl = new SdFormControl();
45
62
  this.matcher = new SdChipErrotStateMatcher(this.formControl);
46
63
  _subscription.set(this, new Subscription());
47
64
  _updateValidator.set(this, () => {
@@ -62,6 +79,39 @@ export class SdChip {
62
79
  this.formControl.setAsyncValidators(asyncValidators);
63
80
  this.formControl.updateValueAndValidity();
64
81
  });
82
+ _loadItems.set(this, (searchText, items) => __awaiter(this, void 0, void 0, function* () {
83
+ searchText = (searchText === null || searchText === void 0 ? void 0 : searchText.toString()) || '';
84
+ if (__classPrivateFieldGet(this, _cache)[searchText] === undefined) {
85
+ this.loading = true;
86
+ const results = yield items(searchText).catch(() => []).finally(() => this.loading = false);
87
+ const objItem = Array.toObject(results, this.valueField);
88
+ __classPrivateFieldSet(this, _allItem, Object.assign(Object.assign({}, __classPrivateFieldGet(this, _allItem)), objItem));
89
+ __classPrivateFieldGet(this, _cache)[searchText] = results.union(this.valueField);
90
+ }
91
+ // if (!this.multiple) {
92
+ // return this.#cache[searchText];
93
+ // }
94
+ const selectedItems = yield __classPrivateFieldGet(this, _loadSelectedItems).call(this, this.formControl.value, items);
95
+ // Đưa những selectedItems lên đầu nếu không mat-select-trigger sẽ không work
96
+ return [...selectedItems, ...__classPrivateFieldGet(this, _cache)[searchText]].union(this.valueField);
97
+ }));
98
+ _loadSelectedItems.set(this, (value, items) => __awaiter(this, void 0, void 0, function* () {
99
+ if (!(value === null || value === void 0 ? void 0 : value.toString())) {
100
+ return [];
101
+ }
102
+ const values = Array.isArray(value) ? value : [value];
103
+ if (!this.valueField && !this.displayField) {
104
+ return values;
105
+ }
106
+ this.loading = true;
107
+ if (values.some(val => __classPrivateFieldGet(this, _allItem)[val] === undefined)) {
108
+ const results = yield items(value, true).catch(() => []).finally(() => this.loading = false);
109
+ const objItem = Array.toObject(results, this.valueField);
110
+ const objValue = Array.toObject(values.map(val => ({ [val === null || val === void 0 ? void 0 : val.toString()]: { [this.valueField]: val, [this.displayField]: val } })), this.valueField);
111
+ __classPrivateFieldSet(this, _allItem, Object.assign(Object.assign(Object.assign({}, objValue), __classPrivateFieldGet(this, _allItem)), objItem));
112
+ }
113
+ return values.map(val => { var _a; return (_a = __classPrivateFieldGet(this, _allItem)[val === null || val === void 0 ? void 0 : val.toString()]) !== null && _a !== void 0 ? _a : { [this.valueField]: val, [this.displayField]: val }; });
114
+ }));
65
115
  this.filter = (value) => {
66
116
  return __classPrivateFieldGet(this, _items).filter(item => {
67
117
  var _a;
@@ -211,26 +261,25 @@ export class SdChip {
211
261
  this.removable = (val === '') || val;
212
262
  }
213
263
  set items(items) {
264
+ __classPrivateFieldSet(this, _delay, 0);
214
265
  if (!items) {
215
- __classPrivateFieldSet(this, _items, []);
266
+ __classPrivateFieldGet(this, _itemsChanges).next([]);
216
267
  }
217
268
  else if (Array.isArray(items)) {
218
- __classPrivateFieldSet(this, _items, items.filter(e => (e !== null && e !== void 0 ? e : '').toString().trim() !== ''));
269
+ __classPrivateFieldGet(this, _itemsChanges).next(items.filter(e => e !== null && e !== undefined));
219
270
  }
220
271
  else {
221
- __classPrivateFieldSet(this, _items, items);
272
+ __classPrivateFieldSet(this, _delay, 500);
273
+ __classPrivateFieldGet(this, _itemsChanges).next(items);
222
274
  }
223
- this.inputControl.updateValueAndValidity();
224
- __classPrivateFieldGet(this, _itemChanges).next(this.items);
275
+ this.formControl.updateValueAndValidity();
225
276
  }
226
277
  // model
227
278
  set model(values) {
228
279
  if (!Array.isArray(values)) {
229
280
  values = [];
230
281
  }
231
- this.formControl.setValue(values, {
232
- emitEvent: false
233
- });
282
+ this.formControl.setValue(values);
234
283
  }
235
284
  set required(val) {
236
285
  this.isRequired = (val === '') || val;
@@ -261,24 +310,98 @@ export class SdChip {
261
310
  }
262
311
  ngAfterViewInit() {
263
312
  var _a;
264
- __classPrivateFieldGet(this, _subscription).add(this.formControl.valueChanges.subscribe(() => {
265
- const values = this.formControl.value || [];
266
- this.selectedItems = __classPrivateFieldGet(this, _items).filter(item => values.findIndex(value => value === (item === null || item === void 0 ? void 0 : item[this.valueField])) !== -1);
267
- this.modelChange.emit(values);
268
- this.sdChange.emit(values);
269
- setTimeout(() => {
270
- var _a;
271
- (_a = __classPrivateFieldGet(this, _form)) === null || _a === void 0 ? void 0 : _a.markAsDirty();
272
- }, 0);
313
+ __classPrivateFieldGet(this, _subscription).add(this.formControl.sdChanges.subscribe(() => {
314
+ this.ref.markForCheck();
273
315
  }));
274
- __classPrivateFieldGet(this, _subscription).add(__classPrivateFieldGet(this, _itemChanges).pipe(startWith(__classPrivateFieldGet(this, _items))).subscribe(() => {
275
- const values = this.formControl.value || [];
276
- this.selectedItems = [];
277
- for (const value of values) {
278
- const item = __classPrivateFieldGet(this, _items).find(e => (e === null || e === void 0 ? void 0 : e[this.valueField]) === value) || {};
279
- this.selectedItems.push(Object.assign(Object.assign({}, item), { [this.valueField]: value }));
316
+ __classPrivateFieldSet(this, _allItems, combineLatest([
317
+ __classPrivateFieldGet(this, _itemsChanges).asObservable(),
318
+ this.inputControl.valueChanges.pipe(startWith(''), debounceTime(__classPrivateFieldGet(this, _delay))),
319
+ this.formControl.valueChanges.pipe(startWith(this.formControl.value))
320
+ ]).pipe(switchMap(([items, val, formValue]) => __awaiter(this, void 0, void 0, function* () {
321
+ if (typeof (items) === 'function') {
322
+ return yield __classPrivateFieldGet(this, _loadItems).call(this, val, items);
280
323
  }
281
- }));
324
+ __classPrivateFieldSet(this, _allItem, items.toObject(this.valueField));
325
+ const isArray = Array.isArray(formValue);
326
+ const hasFields = !!this.valueField && !!this.displayField;
327
+ const filteredItems = items.filter(item => {
328
+ const value = hasFields ? item[this.valueField] : item;
329
+ const display = hasFields ? item[this.displayField] : item;
330
+ if (String.aliasIncludes(value, val) || String.aliasIncludes(display, val)) {
331
+ return true;
332
+ }
333
+ if (isArray) {
334
+ return formValue.some(e => e === value);
335
+ }
336
+ return formValue === value;
337
+ });
338
+ if (items.length <= this.limit) {
339
+ return filteredItems;
340
+ }
341
+ // Đưa những selectedItems lên đầu nếu không mat-select-trigger sẽ không work
342
+ return filteredItems.sort((current, next) => {
343
+ const value1 = hasFields ? current[this.valueField] : current;
344
+ const value2 = hasFields ? next[this.valueField] : next;
345
+ let flag1 = 0;
346
+ let flag2 = 0;
347
+ if (isArray) {
348
+ flag1 = formValue.some(e => e === value1) ? 1 : 0;
349
+ flag2 = formValue.some(e => e === value2) ? 1 : 0;
350
+ return flag2 - flag1;
351
+ }
352
+ flag1 = formValue === value1 ? 1 : 0;
353
+ flag2 = formValue === value2 ? 1 : 0;
354
+ return flag2 - flag1;
355
+ });
356
+ }))));
357
+ this.selectedItems = combineLatest([
358
+ __classPrivateFieldGet(this, _itemsChanges).asObservable(),
359
+ this.formControl.valueChanges.pipe(startWith(this.formControl.value))
360
+ ])
361
+ .pipe(switchMap(([items, val]) => __awaiter(this, void 0, void 0, function* () {
362
+ // Vì một số lý do chưa xác định mà khi sử dụng sdViewDef thì khi chuyển sang dạng view sẽ trigger val = null
363
+ // Nhưng formControl.value vẫn có giá trị đúng nên thực hiện gán val = this.formControl.value;
364
+ val = this.formControl.value;
365
+ if (!(val === null || val === void 0 ? void 0 : val.toString())) {
366
+ return [];
367
+ }
368
+ const values = Array.isArray(val) ? val : [val];
369
+ if (!this.valueField) {
370
+ return values;
371
+ }
372
+ if (typeof (items) === 'function') {
373
+ return yield __classPrivateFieldGet(this, _loadSelectedItems).call(this, val, items);
374
+ }
375
+ return values.map(value => {
376
+ return (items === null || items === void 0 ? void 0 : items.find(item => item[this.valueField] === value)) || {
377
+ [this.valueField]: value,
378
+ [this.displayField]: value
379
+ };
380
+ });
381
+ })));
382
+ this.filteredItems = __classPrivateFieldGet(this, _allItems).pipe(map(allItems => allItems.paging(this.limit)));
383
+ // this.display = this.selectedItems.pipe(
384
+ // map(selectedItems => selectedItems?.map(item => this.displayField ? item[this.displayField] : item)?.join(', ')));
385
+ // this.#subscription.add(this.formControl.valueChanges.subscribe(() => {
386
+ // const values: (string | number)[] = this.formControl.value || [];
387
+ // this.selectedItems = this.#items.filter(item => values.findIndex(value => value === item?.[this.valueField]) !== -1);
388
+ // this.modelChange.emit(values);
389
+ // this.sdChange.emit(values);
390
+ // setTimeout(() => {
391
+ // this.#form?.markAsDirty();
392
+ // }, 0);
393
+ // }));
394
+ // this.#subscription.add(this.#itemChanges.pipe(startWith(this.#items)).subscribe(() => {
395
+ // const values: (string | number)[] = this.formControl.value || [];
396
+ // this.selectedItems = [];
397
+ // for (const value of values) {
398
+ // const item = this.#items.find(e => e?.[this.valueField] === value) || {};
399
+ // this.selectedItems.push({
400
+ // ...item,
401
+ // [this.valueField]: value
402
+ // });
403
+ // }
404
+ // }));
282
405
  (_a = __classPrivateFieldGet(this, _form)) === null || _a === void 0 ? void 0 : _a.addControl(__classPrivateFieldGet(this, _name), this.formControl);
283
406
  }
284
407
  ngOnDestroy() {
@@ -287,7 +410,7 @@ export class SdChip {
287
410
  __classPrivateFieldGet(this, _subscription).unsubscribe();
288
411
  }
289
412
  }
290
- _name = new WeakMap(), _form = new WeakMap(), _itemChanges = new WeakMap(), _items = new WeakMap(), _subscription = new WeakMap(), _updateValidator = new WeakMap();
413
+ _name = new WeakMap(), _form = new WeakMap(), _itemChanges = new WeakMap(), _items = new WeakMap(), _allItems = new WeakMap(), _allItem = new WeakMap(), _cache = new WeakMap(), _delay = new WeakMap(), _itemsChanges = new WeakMap(), _subscription = new WeakMap(), _updateValidator = new WeakMap(), _loadItems = new WeakMap(), _loadSelectedItems = new WeakMap();
291
414
  SdChip.decorators = [
292
415
  { type: Component, args: [{
293
416
  selector: 'sd-chip',
@@ -326,4 +449,4 @@ SdChip.propDecorators = {
326
449
  sdView: [{ type: ContentChild, args: [SdViewDefDirective,] }],
327
450
  sdChipDisplay: [{ type: ContentChild, args: [SdChipDisplayDef,] }]
328
451
  };
329
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chip.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/chip/","sources":["src/lib/chip.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  OnInit, OnDestroy,\r\n  AfterViewInit,\r\n  ChangeDetectorRef,\r\n  ElementRef,\r\n  ContentChild\r\n} from '@angular/core';\r\nimport { COMMA, ENTER } from '@angular/cdk/keycodes';\r\nimport { map, startWith, switchMap } from 'rxjs/operators';\r\n\r\nimport * as uuid from 'uuid';\r\nimport { NgForm, NgModel, FormControl, FormGroup, ValidatorFn, AsyncValidatorFn, Validators, FormGroupDirective } from '@angular/forms';\r\nimport { Observable, Subscription, Subject } from 'rxjs';\r\nimport { SdUtilityService } from '@sd-angular/core/utility';\r\nimport { SdTranslateService } from '@sd-angular/core/translate';\r\nimport { MatChipInputEvent, MatChipList } from '@angular/material/chips';\r\nimport { MatAutocomplete, MatAutocompleteSelectedEvent, MatAutocompleteTrigger } from '@angular/material/autocomplete';\r\nimport { SdChipUpdate } from './chip.model';\r\nimport { ErrorStateMatcher } from '@angular/material/core';\r\nimport { SdChipDisplayDef } from './directives/sd-chip-display-def.directive';\r\nimport { SdViewDefDirective } from '@sd-angular/core/common';\r\n\r\nclass SdChipErrotStateMatcher 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\r\n@Component({\r\n  selector: 'sd-chip',\r\n  templateUrl: './chip.component.html',\r\n  styleUrls: ['./chip.component.scss']\r\n})\r\nexport class SdChip implements OnInit, OnDestroy, AfterViewInit {\r\n  #name = uuid.v4();\r\n  @Input() set name(val: string) {\r\n    if (val) {\r\n      this.#name = val;\r\n    }\r\n  }\r\n  separatorKeysCodes: number[] = [ENTER, COMMA];\r\n  selectable = true;\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() valueField: string;\r\n  @Input() displayField: string;\r\n  @Input() placeholder: string;\r\n  removable: boolean | ((item: any) => boolean) = true;\r\n  @Input('removable') set _removable(val: '' | boolean | ((item: any) => boolean)) {\r\n    this.removable = (val === '') || val;\r\n  }\r\n  #itemChanges = new Subject<any[]>();\r\n  #items: any[] = [];\r\n  @Input() set items(items: undefined | any[]) {\r\n    if (!items) {\r\n      this.#items = [];\r\n    } else if (Array.isArray(items)) {\r\n      this.#items = items.filter(e => (e ?? '').toString().trim() !== '');\r\n    } else {\r\n      this.#items = items;\r\n    }\r\n    this.inputControl.updateValueAndValidity();\r\n    this.#itemChanges.next(this.items);\r\n  }\r\n  @Input() limit = 50;\r\n  selectedItems: any[] = [];\r\n  filteredItems: Observable<any[]>;\r\n\r\n  ipt: any;\r\n\r\n  // model\r\n  @Input() set model(values: undefined | (string | number)[]) {\r\n    if (!Array.isArray(values)) {\r\n      values = [];\r\n    }\r\n    this.formControl.setValue(values, {\r\n      emitEvent: false\r\n    });\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  min: number;\r\n  @Input('min') set pMin(val: number | string) {\r\n    this.min = +val || 0;\r\n    this.#updateValidator();\r\n  }\r\n  max: number;\r\n  @Input('max') set pMax(val: number | string) {\r\n    this.max = +val || 0;\r\n    this.#updateValidator();\r\n  }\r\n  @Output() modelChange = new EventEmitter();\r\n\r\n  // Optional\r\n  @Input() set disabled(val: boolean | '') {\r\n    val = (val === '') || val;\r\n    if (val) {\r\n      this.formControl.disable();\r\n      this.inputControl.disable();\r\n    } else {\r\n      this.formControl.enable();\r\n      this.inputControl.enable();\r\n    }\r\n  }\r\n\r\n  @Output() sdChange = new EventEmitter<any[]>();\r\n  @Output() sdUpdate = new EventEmitter<SdChipUpdate>();\r\n  @Output() chipSelected = new EventEmitter<any>();\r\n\r\n  @ViewChild('input') input: ElementRef<HTMLInputElement>;\r\n  @ViewChild('auto') matAutocomplete: MatAutocomplete;\r\n  @ViewChild('chipList', { static: true }) chipList: MatChipList;\r\n  @ViewChild(MatAutocompleteTrigger, { read: MatAutocompleteTrigger }) autocompleteTrigger: MatAutocompleteTrigger;\r\n  @ContentChild(SdViewDefDirective) sdView: SdViewDefDirective;\r\n  @ContentChild(SdChipDisplayDef) sdChipDisplay: SdChipDisplayDef;\r\n  isFocused = false;\r\n  inputControl = new FormControl();\r\n  formControl = new FormControl();\r\n  matcher = new SdChipErrotStateMatcher(this.formControl);\r\n  #subscription = new Subscription();\r\n  constructor(\r\n    private ref: ChangeDetectorRef,\r\n    private utilityService: SdUtilityService) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.filteredItems = this.inputControl.valueChanges.pipe(\r\n      startWith<string | { [key: string]: string }>(''),\r\n      map(item => typeof item === 'string' ? item : (item?.[this.displayField] ?? '')),\r\n      map(name => this.filter(name))\r\n    );\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.#subscription.add(this.formControl.valueChanges.subscribe(() => {\r\n      const values: (string | number)[] = this.formControl.value || [];\r\n      this.selectedItems = this.#items.filter(item => values.findIndex(value => value === item?.[this.valueField]) !== -1);\r\n      this.modelChange.emit(values);\r\n      this.sdChange.emit(values);\r\n      setTimeout(() => {\r\n        this.#form?.markAsDirty();\r\n      }, 0);\r\n    }));\r\n    this.#subscription.add(this.#itemChanges.pipe(startWith(this.#items)).subscribe(() => {\r\n      const values: (string | number)[] = this.formControl.value || [];\r\n      this.selectedItems = [];\r\n      for (const value of values) {\r\n        const item = this.#items.find(e => e?.[this.valueField] === value) || {};\r\n        this.selectedItems.push({\r\n          ...item,\r\n          [this.valueField]: value\r\n        });\r\n      }\r\n    }));\r\n    this.#form?.addControl(this.#name, this.formControl);\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  #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.min > 0) {\r\n      validators.push(Validators.minLength(this.min));\r\n    }\r\n    if (this.max > 0) {\r\n      validators.push(Validators.maxLength(this.max));\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  filter = (value: string): { [key: string]: string }[] => {\r\n    return this.#items\r\n      .filter(item => {\r\n        if (this.formControl.value?.some(val => val === item[this.valueField])) {\r\n          return false;\r\n        }\r\n        return !value || this.utilityService.changeAliasLowerCase(item[this.displayField])\r\n          .indexOf(this.utilityService.changeAliasLowerCase(value)) !== -1;\r\n      }).filter((item, index) => index < this.limit);\r\n  }\r\n\r\n  onAdd = (event: MatChipInputEvent): void => {\r\n    // Add item only when MatAutocomplete is not open\r\n    // To make sure this does not conflict with OptionSelected Event\r\n    if (!this.matAutocomplete.isOpen) {\r\n      const value = (event.value ?? '').toString().toLowerCase().trim();\r\n      if (value) {\r\n\r\n        const item = this.#items.find(e => e[this.displayField]\r\n          && e[this.displayField].toString().toLowerCase().trim() === value);\r\n\r\n        if (item) {\r\n          const values: (string | number)[] = this.formControl.value ?? [];\r\n          values.push(item[this.valueField]);\r\n          this.formControl.setValue(values);\r\n        }\r\n      }\r\n      this.inputControl.setValue('');\r\n    }\r\n  }\r\n\r\n  // andn1 viết để xử lý tạm us B2B1D-18289 ở S69\r\n  onAdd2 = (event: MatChipInputEvent): void => {\r\n\r\n    const value = (event.value ?? '').toString().toLowerCase().trim();\r\n    if (value) {\r\n      const item = this.#items.find(e => e[this.valueField]\r\n        && e[this.valueField].toString().toLowerCase().trim() === value);\r\n\r\n      if (item) {\r\n        const values: (string | number)[] = this.formControl.value ?? [];\r\n        if (!values.includes(item[this.valueField])) {\r\n          values.push(item[this.valueField]);\r\n        }\r\n        this.formControl.setValue(values);\r\n      }\r\n    }\r\n    this.inputControl.setValue('');\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  onRemove = (item: any): void => {\r\n    const values: (string | number)[] = this.formControl.value ?? [];\r\n    this.formControl.setValue(values.filter(value => item?.[this.valueField] !== value));\r\n    this.inputControl.setValue('');\r\n  }\r\n\r\n  select = (item: any): void => {\r\n    this.chipSelected.emit(item);\r\n  }\r\n\r\n  onSelect = (event: MatAutocompleteSelectedEvent) => {\r\n    const value = (event.option.value?.[this.valueField] ?? '').toString().trim();\r\n    if (value) {\r\n      const item = this.#items.find(e => e[this.valueField]\r\n        && e[this.valueField].toString().trim() === value);\r\n      if (item) {\r\n        const values: (string | number)[] = this.formControl.value ?? [];\r\n        values.push(item[this.valueField]);\r\n        this.formControl.setValue(values);\r\n        this.input.nativeElement.value = '';\r\n        this.inputControl.setValue('');\r\n        setTimeout(() => {\r\n          this.autocompleteTrigger?.openPanel();\r\n        }, 0);\r\n      }\r\n    }\r\n  }\r\n\r\n  displayFn = (value: string | { [key: string]: string }): string | undefined => {\r\n    if (typeof value === 'string') {\r\n      if (!this.#items) {\r\n        return undefined;\r\n      }\r\n      const selectedItem = this.#items.find(item => item[this.valueField] === value);\r\n      if (selectedItem) {\r\n        return selectedItem[this.displayField];\r\n      }\r\n      if (this.#items.some(item => item[this.displayField].toLowerCase().indexOf(value.toLowerCase()) !== -1)) {\r\n        return value;\r\n      } else {\r\n        return undefined;\r\n      }\r\n    } else {\r\n      return value ? value[this.displayField] : undefined;\r\n    }\r\n  }\r\n\r\n  onFocus = () => {\r\n    this.isFocused = true;\r\n    this.inputControl.setValue('');\r\n    // this.inputControl.updateValueAndValidity();\r\n  }\r\n\r\n  onBlur = () => {\r\n    this.isFocused = false;\r\n    this.inputControl.setValue('', {\r\n      emitEvent: false\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  focus = () => {\r\n    this.isFocused = true;\r\n    setTimeout(() => {\r\n      this.autocompleteTrigger?.openPanel();\r\n      this.input?.nativeElement?.focus();\r\n    }, 100);\r\n  }\r\n\r\n  onClear = ($event?: any) => {\r\n    $event?.stopPropagation();\r\n    this.inputControl.setValue('');\r\n    this.formControl.setValue([]);\r\n    this.autocompleteTrigger?.openPanel();\r\n    this.ref.detectChanges();\r\n  }\r\n}\r\n"]}
452
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chip.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/chip/","sources":["src/lib/chip.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  OnInit, OnDestroy,\r\n  AfterViewInit,\r\n  ChangeDetectorRef,\r\n  ElementRef,\r\n  ContentChild\r\n} from '@angular/core';\r\nimport { COMMA, ENTER } from '@angular/cdk/keycodes';\r\nimport { debounceTime, map, startWith, switchMap } from 'rxjs/operators';\r\n\r\nimport * as uuid from 'uuid';\r\nimport { NgForm, NgModel, FormControl, FormGroup, ValidatorFn, AsyncValidatorFn, Validators, FormGroupDirective } from '@angular/forms';\r\nimport { Observable, Subscription, Subject, BehaviorSubject, combineLatest } from 'rxjs';\r\nimport { SdUtilityService } from '@sd-angular/core/utility';\r\nimport { SdTranslateService } from '@sd-angular/core/translate';\r\nimport { MatChipInputEvent, MatChipList } from '@angular/material/chips';\r\nimport { MatAutocomplete, MatAutocompleteSelectedEvent, MatAutocompleteTrigger } from '@angular/material/autocomplete';\r\nimport { SdChipUpdate } from './chip.model';\r\nimport { ErrorStateMatcher } from '@angular/material/core';\r\nimport { SdChipDisplayDef } from './directives/sd-chip-display-def.directive';\r\nimport { SdFormControl, SdViewDefDirective } from '@sd-angular/core/common';\r\n\r\nclass SdChipErrotStateMatcher 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\r\n@Component({\r\n  selector: 'sd-chip',\r\n  templateUrl: './chip.component.html',\r\n  styleUrls: ['./chip.component.scss']\r\n})\r\nexport class SdChip implements OnInit, OnDestroy, AfterViewInit {\r\n  #name = uuid.v4();\r\n  @Input() set name(val: string) {\r\n    if (val) {\r\n      this.#name = val;\r\n    }\r\n  }\r\n  separatorKeysCodes: number[] = [ENTER, COMMA];\r\n  selectable = true;\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() valueField: string;\r\n  @Input() displayField: string;\r\n  @Input() placeholder: string;\r\n  removable: boolean | ((item: any) => boolean) = true;\r\n  @Input('removable') set _removable(val: '' | boolean | ((item: any) => boolean)) {\r\n    this.removable = (val === '') || val;\r\n  }\r\n  #itemChanges = new Subject<any[]>();\r\n  #items: any[] = [];\r\n  // @Input() set items(items: undefined | any[]) {\r\n  //   if (!items) {\r\n  //     this.#items = [];\r\n  //   } else if (Array.isArray(items)) {\r\n  //     this.#items = items.filter(e => (e ?? '').toString().trim() !== '');\r\n  //   } else {\r\n  //     this.#items = items;\r\n  //   }\r\n  //   this.inputControl.updateValueAndValidity();\r\n  //   this.#itemChanges.next(this.items);\r\n  // }\r\n  // Server search\r\n  loading = false;\r\n  #allItems: Observable<any[]>;\r\n  #allItem: {\r\n    [key: string]: any\r\n  } = {};\r\n  #cache: {\r\n    [key: string]: any[]\r\n  } = {};\r\n  #delay = 200; // Sau khoảng thời gian delay nếu không có thay đổi thì thì mới bắt đầu thực hiện gọi hàm\r\n  #itemsChanges = new BehaviorSubject<any[] | SearchFunc>([]);\r\n  @Input() set items(items: undefined | any[] | SearchFunc) {\r\n    this.#delay = 0;\r\n    if (!items) {\r\n      this.#itemsChanges.next([]);\r\n    } else if (Array.isArray(items)) {\r\n      this.#itemsChanges.next(items.filter(e => e !== null && e !== undefined));\r\n    } else {\r\n      this.#delay = 500;\r\n      this.#itemsChanges.next(items);\r\n    }\r\n    this.formControl.updateValueAndValidity();\r\n  }\r\n  @Input() limit = 50;\r\n  selectedItems: Observable<any[]>;\r\n  filteredItems: Observable<any[]>;\r\n\r\n  ipt: any;\r\n\r\n  // model\r\n  @Input() set model(values: undefined | (string | number)[]) {\r\n    if (!Array.isArray(values)) {\r\n      values = [];\r\n    }\r\n    this.formControl.setValue(values);\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  min: number;\r\n  @Input('min') set pMin(val: number | string) {\r\n    this.min = +val || 0;\r\n    this.#updateValidator();\r\n  }\r\n  max: number;\r\n  @Input('max') set pMax(val: number | string) {\r\n    this.max = +val || 0;\r\n    this.#updateValidator();\r\n  }\r\n  @Output() modelChange = new EventEmitter();\r\n\r\n  // Optional\r\n  @Input() set disabled(val: boolean | '') {\r\n    val = (val === '') || val;\r\n    if (val) {\r\n      this.formControl.disable();\r\n      this.inputControl.disable();\r\n    } else {\r\n      this.formControl.enable();\r\n      this.inputControl.enable();\r\n    }\r\n  }\r\n\r\n  @Output() sdChange = new EventEmitter<any[]>();\r\n  @Output() sdUpdate = new EventEmitter<SdChipUpdate>();\r\n  @Output() chipSelected = new EventEmitter<any>();\r\n\r\n  @ViewChild('input') input: ElementRef<HTMLInputElement>;\r\n  @ViewChild('auto') matAutocomplete: MatAutocomplete;\r\n  @ViewChild('chipList', { static: true }) chipList: MatChipList;\r\n  @ViewChild(MatAutocompleteTrigger, { read: MatAutocompleteTrigger }) autocompleteTrigger: MatAutocompleteTrigger;\r\n  @ContentChild(SdViewDefDirective) sdView: SdViewDefDirective;\r\n  @ContentChild(SdChipDisplayDef) sdChipDisplay: SdChipDisplayDef;\r\n  isFocused = false;\r\n  inputControl = new FormControl();\r\n  formControl = new SdFormControl();\r\n  matcher = new SdChipErrotStateMatcher(this.formControl);\r\n  #subscription = new Subscription();\r\n  constructor(\r\n    private ref: ChangeDetectorRef,\r\n    private utilityService: SdUtilityService) {\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.filteredItems = this.inputControl.valueChanges.pipe(\r\n      startWith<string | { [key: string]: string }>(''),\r\n      map(item => typeof item === 'string' ? item : (item?.[this.displayField] ?? '')),\r\n      map(name => this.filter(name))\r\n    );\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.#subscription.add(this.formControl.sdChanges.subscribe(() => {\r\n      this.ref.markForCheck();\r\n    }));\r\n    this.#allItems = combineLatest([\r\n      this.#itemsChanges.asObservable(),\r\n      this.inputControl.valueChanges.pipe(startWith(''), debounceTime(this.#delay)),\r\n      this.formControl.valueChanges.pipe(startWith(this.formControl.value))]).pipe(\r\n        switchMap(async ([items, val, formValue]) => {\r\n          if (typeof (items) === 'function') {\r\n            return await this.#loadItems(val, items);\r\n          }\r\n          this.#allItem = items.toObject(this.valueField);\r\n          const isArray = Array.isArray(formValue);\r\n          const hasFields = !!this.valueField && !!this.displayField;\r\n          const filteredItems = items.filter(item => {\r\n            const value = hasFields ? item[this.valueField] : item;\r\n            const display = hasFields ? item[this.displayField] : item;\r\n            if (String.aliasIncludes(value, val) || String.aliasIncludes(display, val)) {\r\n              return true;\r\n            }\r\n            if (isArray) {\r\n              return formValue.some(e => e === value);\r\n            }\r\n            return formValue === value;\r\n          });\r\n          if (items.length <= this.limit) {\r\n            return filteredItems;\r\n          }\r\n          // Đưa những selectedItems lên đầu nếu không mat-select-trigger sẽ không work\r\n          return filteredItems.sort((current, next) => {\r\n            const value1 = hasFields ? current[this.valueField] : current;\r\n            const value2 = hasFields ? next[this.valueField] : next;\r\n            let flag1 = 0;\r\n            let flag2 = 0;\r\n            if (isArray) {\r\n              flag1 = formValue.some(e => e === value1) ? 1 : 0;\r\n              flag2 = formValue.some(e => e === value2) ? 1 : 0;\r\n              return flag2 - flag1;\r\n            }\r\n            flag1 = formValue === value1 ? 1 : 0;\r\n            flag2 = formValue === value2 ? 1 : 0;\r\n            return flag2 - flag1;\r\n          });\r\n        }));\r\n    this.selectedItems = combineLatest([\r\n      this.#itemsChanges.asObservable(),\r\n      this.formControl.valueChanges.pipe(startWith(this.formControl.value))])\r\n      .pipe(\r\n        switchMap(async ([items, val]) => {\r\n          // Vì một số lý do chưa xác định mà khi sử dụng sdViewDef thì khi chuyển sang dạng view sẽ trigger val = null\r\n          // Nhưng formControl.value vẫn có giá trị đúng nên thực hiện gán val = this.formControl.value;\r\n          val = this.formControl.value;\r\n          if (!val?.toString()) {\r\n            return [];\r\n          }\r\n          const values = Array.isArray(val) ? val : [val];\r\n          if (!this.valueField) {\r\n            return values;\r\n          }\r\n          if (typeof (items) === 'function') {\r\n            return await this.#loadSelectedItems(val, items);\r\n          }\r\n          return values.map(value => {\r\n            return items?.find(item => item[this.valueField] === value) || {\r\n              [this.valueField]: value,\r\n              [this.displayField]: value\r\n            };\r\n          });\r\n        })\r\n      );\r\n    this.filteredItems = this.#allItems.pipe(map(allItems => allItems.paging(this.limit)));\r\n    // this.display = this.selectedItems.pipe(\r\n    //   map(selectedItems => selectedItems?.map(item => this.displayField ? item[this.displayField] : item)?.join(', ')));\r\n    // this.#subscription.add(this.formControl.valueChanges.subscribe(() => {\r\n    //   const values: (string | number)[] = this.formControl.value || [];\r\n    //   this.selectedItems = this.#items.filter(item => values.findIndex(value => value === item?.[this.valueField]) !== -1);\r\n    //   this.modelChange.emit(values);\r\n    //   this.sdChange.emit(values);\r\n    //   setTimeout(() => {\r\n    //     this.#form?.markAsDirty();\r\n    //   }, 0);\r\n    // }));\r\n    // this.#subscription.add(this.#itemChanges.pipe(startWith(this.#items)).subscribe(() => {\r\n    //   const values: (string | number)[] = this.formControl.value || [];\r\n    //   this.selectedItems = [];\r\n    //   for (const value of values) {\r\n    //     const item = this.#items.find(e => e?.[this.valueField] === value) || {};\r\n    //     this.selectedItems.push({\r\n    //       ...item,\r\n    //       [this.valueField]: value\r\n    //     });\r\n    //   }\r\n    // }));\r\n    this.#form?.addControl(this.#name, this.formControl);\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  #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.min > 0) {\r\n      validators.push(Validators.minLength(this.min));\r\n    }\r\n    if (this.max > 0) {\r\n      validators.push(Validators.maxLength(this.max));\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  #loadItems = async (searchText: string, items: SearchFunc) => {\r\n    searchText = searchText?.toString() || '';\r\n    if (this.#cache[searchText] === undefined) {\r\n      this.loading = true;\r\n      const results = await items(searchText).catch(() => []).finally(() => this.loading = false);\r\n      const objItem = Array.toObject(results, this.valueField);\r\n      this.#allItem = {\r\n        ...this.#allItem,\r\n        ...objItem\r\n      };\r\n      this.#cache[searchText] = results.union(this.valueField);\r\n    }\r\n    // if (!this.multiple) {\r\n    //   return this.#cache[searchText];\r\n    // }\r\n    const selectedItems = await this.#loadSelectedItems(this.formControl.value, items);\r\n    // Đưa những selectedItems lên đầu nếu không mat-select-trigger sẽ không work\r\n    return [...selectedItems, ...this.#cache[searchText]].union(this.valueField);\r\n  }\r\n\r\n  #loadSelectedItems = async (value: string | string[], items: SearchFunc) => {\r\n    if (!value?.toString()) {\r\n      return [];\r\n    }\r\n    const values = Array.isArray(value) ? value : [value];\r\n    if (!this.valueField && !this.displayField) {\r\n      return values;\r\n    }\r\n    this.loading = true;\r\n    if (values.some(val => this.#allItem[val] === undefined)) {\r\n      const results = await items(value, true).catch(() => []).finally(() => this.loading = false);\r\n      const objItem = Array.toObject(results, this.valueField);\r\n      const objValue = Array.toObject(\r\n        values.map(val => ({ [val?.toString()]: { [this.valueField]: val, [this.displayField]: val } })), this.valueField);\r\n      this.#allItem = {\r\n        ...objValue,\r\n        ...this.#allItem,\r\n        ...objItem\r\n      };\r\n    }\r\n    return values.map(val => this.#allItem[val?.toString()] ?? { [this.valueField]: val, [this.displayField]: val });\r\n  }\r\n\r\n  filter = (value: string): { [key: string]: string }[] => {\r\n    return this.#items\r\n      .filter(item => {\r\n        if (this.formControl.value?.some(val => val === item[this.valueField])) {\r\n          return false;\r\n        }\r\n        return !value || this.utilityService.changeAliasLowerCase(item[this.displayField])\r\n          .indexOf(this.utilityService.changeAliasLowerCase(value)) !== -1;\r\n      }).filter((item, index) => index < this.limit);\r\n  }\r\n\r\n  onAdd = (event: MatChipInputEvent): void => {\r\n    // Add item only when MatAutocomplete is not open\r\n    // To make sure this does not conflict with OptionSelected Event\r\n    if (!this.matAutocomplete.isOpen) {\r\n      const value = (event.value ?? '').toString().toLowerCase().trim();\r\n      if (value) {\r\n\r\n        const item = this.#items.find(e => e[this.displayField]\r\n          && e[this.displayField].toString().toLowerCase().trim() === value);\r\n\r\n        if (item) {\r\n          const values: (string | number)[] = this.formControl.value ?? [];\r\n          values.push(item[this.valueField]);\r\n          this.formControl.setValue(values);\r\n        }\r\n      }\r\n      this.inputControl.setValue('');\r\n    }\r\n  }\r\n\r\n  // andn1 viết để xử lý tạm us B2B1D-18289 ở S69\r\n  onAdd2 = (event: MatChipInputEvent): void => {\r\n\r\n    const value = (event.value ?? '').toString().toLowerCase().trim();\r\n    if (value) {\r\n      const item = this.#items.find(e => e[this.valueField]\r\n        && e[this.valueField].toString().toLowerCase().trim() === value);\r\n\r\n      if (item) {\r\n        const values: (string | number)[] = this.formControl.value ?? [];\r\n        if (!values.includes(item[this.valueField])) {\r\n          values.push(item[this.valueField]);\r\n        }\r\n        this.formControl.setValue(values);\r\n      }\r\n    }\r\n    this.inputControl.setValue('');\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  onRemove = (item: any): void => {\r\n    const values: (string | number)[] = this.formControl.value ?? [];\r\n    this.formControl.setValue(values.filter(value => item?.[this.valueField] !== value));\r\n    this.inputControl.setValue('');\r\n  }\r\n\r\n  select = (item: any): void => {\r\n    this.chipSelected.emit(item);\r\n  }\r\n\r\n  onSelect = (event: MatAutocompleteSelectedEvent) => {\r\n    const value = (event.option.value?.[this.valueField] ?? '').toString().trim();\r\n    if (value) {\r\n      const item = this.#items.find(e => e[this.valueField]\r\n        && e[this.valueField].toString().trim() === value);\r\n      if (item) {\r\n        const values: (string | number)[] = this.formControl.value ?? [];\r\n        values.push(item[this.valueField]);\r\n        this.formControl.setValue(values);\r\n        this.input.nativeElement.value = '';\r\n        this.inputControl.setValue('');\r\n        setTimeout(() => {\r\n          this.autocompleteTrigger?.openPanel();\r\n        }, 0);\r\n      }\r\n    }\r\n  }\r\n\r\n  displayFn = (value: string | { [key: string]: string }): string | undefined => {\r\n    if (typeof value === 'string') {\r\n      if (!this.#items) {\r\n        return undefined;\r\n      }\r\n      const selectedItem = this.#items.find(item => item[this.valueField] === value);\r\n      if (selectedItem) {\r\n        return selectedItem[this.displayField];\r\n      }\r\n      if (this.#items.some(item => item[this.displayField].toLowerCase().indexOf(value.toLowerCase()) !== -1)) {\r\n        return value;\r\n      } else {\r\n        return undefined;\r\n      }\r\n    } else {\r\n      return value ? value[this.displayField] : undefined;\r\n    }\r\n  }\r\n\r\n  onFocus = () => {\r\n    this.isFocused = true;\r\n    this.inputControl.setValue('');\r\n    // this.inputControl.updateValueAndValidity();\r\n  }\r\n\r\n  onBlur = () => {\r\n    this.isFocused = false;\r\n    this.inputControl.setValue('', {\r\n      emitEvent: false\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  focus = () => {\r\n    this.isFocused = true;\r\n    setTimeout(() => {\r\n      this.autocompleteTrigger?.openPanel();\r\n      this.input?.nativeElement?.focus();\r\n    }, 100);\r\n  }\r\n\r\n  onClear = ($event?: any) => {\r\n    $event?.stopPropagation();\r\n    this.inputControl.setValue('');\r\n    this.formControl.setValue([]);\r\n    this.autocompleteTrigger?.openPanel();\r\n    this.ref.detectChanges();\r\n  }\r\n}\r\n\r\ntype SearchFunc = (searchText?: string | string[], isFormValue?: boolean) => Promise<any[]>;"]}
@@ -5,7 +5,7 @@ export class SdDesktopCellView {
5
5
  SdDesktopCellView.decorators = [
6
6
  { type: Component, args: [{
7
7
  selector: 'sd-desktop-cell-view',
8
- template: "<ng-container *ngIf=\"item[column.field] | cellView:item:column:gridOption:key | async as view\">\r\n <ng-container *ngIf=\"view.display.hasHtml;else useValue\">\r\n <div *ngIf=\"view.click\" (click)=\"view.click()\" class=\"text-break cursor-pointer\" [matTooltip]=\"view.tooltip\"\r\n [class.text-center]=\"view.display.align === 'center'\" [class.text-right]=\"view.display.align === 'right'\"\r\n [innerHTML]=\"view.display.html | safeHtml\">\r\n </div>\r\n <div *ngIf=\"!view.click\" class=\"text-break\" [matTooltip]=\"view.tooltip\"\r\n [class.text-center]=\"view.display.align === 'center'\" [class.text-right]=\"view.display.align === 'right'\"\r\n [innerHTML]=\"view.display.html | safeHtml\">\r\n </div>\r\n </ng-container>\r\n <ng-template #useValue>\r\n <ng-container *ngIf=\"!!view.badge; else noBadge\">\r\n <sd-badge [type]=\"view.badge.type\" [title]=\"view.display.value\" [color]=\"view.badge.color\"\r\n [icon]=\"view.badge.icon\" [tooltip]=\"view.tooltip\" (sdClick)=\"column.click(item[column.field], item)\"></sd-badge>\r\n </ng-container>\r\n <ng-template #noBadge>\r\n <ng-container *ngIf=\"column.type !== 'children'; else childrenView\">\r\n <div *ngIf=\"column.type !== 'image'\" class=\"text-break\" [class.text-center]=\"view.display.align === 'center'\"\r\n [class.text-right]=\"view.display.align === 'right'\" [matTooltip]=\"view.tooltip\">\r\n <a *ngIf=\"!!view.click\" href=\"javascript:;\" (click)=\"view.click()\">{{view.display.value}}</a>\r\n <ng-container *ngIf=\"!view.click\">{{view.display.value}}\r\n </ng-container>\r\n </div>\r\n <div *ngIf=\"column.type === 'image'\" class=\"align-middle text-center\">\r\n <img *ngIf=\"view.display.value\" [src]=\"view.display.value\" [width]=\"column.option?.width\"\r\n [height]=\"column.option?.height\" class=\"c-image\" (click)=\"!!view.click && view.click()\"\r\n [class.cursor-pointer]=\"!!view.click\">\r\n <mat-icon *ngIf=\"!view.display.value\" class=\"c-img\" [class.cursor-pointer]=\"!!view.click\"\r\n (click)=\"!!view.click && view.click()\">\r\n image</mat-icon>\r\n </div>\r\n </ng-container>\r\n <ng-template #childrenView>\r\n <sd-desktop-cell-children-view [key]=\"key\" [item]=\"item\" [column]=\"column\">\r\n </sd-desktop-cell-children-view>\r\n </ng-template>\r\n </ng-template>\r\n </ng-template>\r\n</ng-container>",
8
+ template: "<ng-container *ngIf=\"item[column.field] | cellView:item:column:gridOption:key | async as view\">\r\n <ng-container *ngIf=\"view.display.hasHtml;else useValue\">\r\n <div *ngIf=\"view.click\" (click)=\"view.click()\" class=\"text-break cursor-pointer\" [matTooltip]=\"view.tooltip\"\r\n [class.text-center]=\"view.display.align === 'center'\" [class.text-right]=\"view.display.align === 'right'\"\r\n [innerHTML]=\"view.display.html | safeHtml\">\r\n </div>\r\n <div *ngIf=\"!view.click\" class=\"text-break\" [matTooltip]=\"view.tooltip\"\r\n [class.text-center]=\"view.display.align === 'center'\" [class.text-right]=\"view.display.align === 'right'\"\r\n [innerHTML]=\"view.display.html | safeHtml\">\r\n </div>\r\n </ng-container>\r\n <ng-template #useValue>\r\n <ng-container *ngIf=\"!!view.badge; else noBadge\">\r\n <sd-badge [type]=\"view.badge.type\" [title]=\"view.display.value\" [color]=\"view.badge.color\"\r\n [icon]=\"view.badge.icon\" [tooltip]=\"view.tooltip\" (sdClick)=\"!!view.click && view.click()\"></sd-badge>\r\n </ng-container>\r\n <ng-template #noBadge>\r\n <ng-container *ngIf=\"column.type !== 'children'; else childrenView\">\r\n <div *ngIf=\"column.type !== 'image'\" class=\"text-break\" [class.text-center]=\"view.display.align === 'center'\"\r\n [class.text-right]=\"view.display.align === 'right'\" [matTooltip]=\"view.tooltip\">\r\n <a *ngIf=\"!!view.click\" href=\"javascript:;\" (click)=\"view.click()\">{{view.display.value}}</a>\r\n <ng-container *ngIf=\"!view.click\">{{view.display.value}}\r\n </ng-container>\r\n </div>\r\n <div *ngIf=\"column.type === 'image'\" class=\"align-middle text-center\">\r\n <img *ngIf=\"view.display.value\" [src]=\"view.display.value\" [width]=\"column.option?.width\"\r\n [height]=\"column.option?.height\" class=\"c-image\" (click)=\"!!view.click && view.click()\"\r\n [class.cursor-pointer]=\"!!view.click\">\r\n <mat-icon *ngIf=\"!view.display.value\" class=\"c-img\" [class.cursor-pointer]=\"!!view.click\"\r\n (click)=\"!!view.click && view.click()\">\r\n image</mat-icon>\r\n </div>\r\n </ng-container>\r\n <ng-template #childrenView>\r\n <sd-desktop-cell-children-view [key]=\"key\" [item]=\"item\" [column]=\"column\">\r\n </sd-desktop-cell-children-view>\r\n </ng-template>\r\n </ng-template>\r\n </ng-template>\r\n</ng-container>",
9
9
  changeDetection: ChangeDetectionStrategy.OnPush,
10
10
  styles: [".text-black400{color:#757575}.c-color-success{color:#4caf50}.c-color-danger{color:#f82c13}.c-image{-o-object-fit:contain;margin:5px 0;object-fit:contain}.c-img{font-size:30px;opacity:.5}.c-img.pointer:hover{opacity:.9}"]
11
11
  },] }
@@ -18,4 +18,4 @@ SdDesktopCellView.propDecorators = {
18
18
  item: [{ type: Input }],
19
19
  gridOption: [{ type: Input }]
20
20
  };
21
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVza3RvcC1jZWxsLXZpZXcuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IkM6L1VzZXJzL25naGlhdHQxNV9vbmVtb3VudC9Eb2N1bWVudHMvbGliLWNvcmUtdWkvcHJvamVjdHMvc2QtY29yZS9ncmlkLW1hdGVyaWFsLyIsInNvdXJjZXMiOlsic3JjL2xpYi9jb21wb25lbnRzL2Rlc2t0b3AtY2VsbC12aWV3L2Rlc2t0b3AtY2VsbC12aWV3LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBYSxNQUFNLGVBQWUsQ0FBQztBQVVyRixNQUFNLE9BQU8saUJBQWlCO0lBTTVCLGdCQUNJLENBQUM7OztZQWJOLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsc0JBQXNCO2dCQUNoQywwL0VBQWlEO2dCQUVqRCxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTs7YUFDaEQ7Ozs7bUJBRUUsS0FBSztrQkFDTCxLQUFLO3FCQUNMLEtBQUs7bUJBQ0wsS0FBSzt5QkFDTCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXQsIFF1ZXJ5TGlzdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBTZEdyaWRNYXRlcmlhbENvbHVtbiB9IGZyb20gJy4uLy4uL21vZGVscy9ncmlkLWNvbHVtbi5tb2RlbCc7XHJcbmltcG9ydCB7IFNkR3JpZE1hdGVyaWFsT3B0aW9uIH0gZnJvbSAnLi4vLi4vbW9kZWxzL2dyaWQtb3B0aW9uLm1vZGVsJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnc2QtZGVza3RvcC1jZWxsLXZpZXcnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9kZXNrdG9wLWNlbGwtdmlldy5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vZGVza3RvcC1jZWxsLXZpZXcuY29tcG9uZW50LnNjc3MnXSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxyXG59KVxyXG5leHBvcnQgY2xhc3MgU2REZXNrdG9wQ2VsbFZpZXcge1xyXG4gIEBJbnB1dCgpIHNkSWQ6IHN0cmluZztcclxuICBASW5wdXQoKSBrZXk6IHN0cmluZztcclxuICBASW5wdXQoKSBjb2x1bW46IFNkR3JpZE1hdGVyaWFsQ29sdW1uO1xyXG4gIEBJbnB1dCgpIGl0ZW06IGFueTtcclxuICBASW5wdXQoKSBncmlkT3B0aW9uOiBTZEdyaWRNYXRlcmlhbE9wdGlvbjtcclxuICBjb25zdHJ1Y3RvcihcclxuICApIHsgfVxyXG59XHJcbiJdfQ==
21
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGVza3RvcC1jZWxsLXZpZXcuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IkM6L1VzZXJzL25naGlhdHQxNV9vbmVtb3VudC9Eb2N1bWVudHMvbGliLWNvcmUtdWkvcHJvamVjdHMvc2QtY29yZS9ncmlkLW1hdGVyaWFsLyIsInNvdXJjZXMiOlsic3JjL2xpYi9jb21wb25lbnRzL2Rlc2t0b3AtY2VsbC12aWV3L2Rlc2t0b3AtY2VsbC12aWV3LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBYSxNQUFNLGVBQWUsQ0FBQztBQVVyRixNQUFNLE9BQU8saUJBQWlCO0lBTTVCLGdCQUNJLENBQUM7OztZQWJOLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsc0JBQXNCO2dCQUNoQyxnL0VBQWlEO2dCQUVqRCxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTs7YUFDaEQ7Ozs7bUJBRUUsS0FBSztrQkFDTCxLQUFLO3FCQUNMLEtBQUs7bUJBQ0wsS0FBSzt5QkFDTCxLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXQsIFF1ZXJ5TGlzdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBTZEdyaWRNYXRlcmlhbENvbHVtbiB9IGZyb20gJy4uLy4uL21vZGVscy9ncmlkLWNvbHVtbi5tb2RlbCc7XHJcbmltcG9ydCB7IFNkR3JpZE1hdGVyaWFsT3B0aW9uIH0gZnJvbSAnLi4vLi4vbW9kZWxzL2dyaWQtb3B0aW9uLm1vZGVsJztcclxuXHJcbkBDb21wb25lbnQoe1xyXG4gIHNlbGVjdG9yOiAnc2QtZGVza3RvcC1jZWxsLXZpZXcnLFxyXG4gIHRlbXBsYXRlVXJsOiAnLi9kZXNrdG9wLWNlbGwtdmlldy5jb21wb25lbnQuaHRtbCcsXHJcbiAgc3R5bGVVcmxzOiBbJy4vZGVza3RvcC1jZWxsLXZpZXcuY29tcG9uZW50LnNjc3MnXSxcclxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxyXG59KVxyXG5leHBvcnQgY2xhc3MgU2REZXNrdG9wQ2VsbFZpZXcge1xyXG4gIEBJbnB1dCgpIHNkSWQ6IHN0cmluZztcclxuICBASW5wdXQoKSBrZXk6IHN0cmluZztcclxuICBASW5wdXQoKSBjb2x1bW46IFNkR3JpZE1hdGVyaWFsQ29sdW1uO1xyXG4gIEBJbnB1dCgpIGl0ZW06IGFueTtcclxuICBASW5wdXQoKSBncmlkT3B0aW9uOiBTZEdyaWRNYXRlcmlhbE9wdGlvbjtcclxuICBjb25zdHJ1Y3RvcihcclxuICApIHsgfVxyXG59XHJcbiJdfQ==
@@ -1,30 +1,65 @@
1
- import { Injectable } from "@angular/core";
2
- import $ from "jquery";
1
+ var _createLoading;
2
+ import { __classPrivateFieldGet } from "tslib";
3
+ import { Injectable, RendererFactory2 } from "@angular/core";
3
4
  import * as i0 from "@angular/core";
4
5
  export class SdLoadingService {
5
- constructor() {
6
+ constructor(rendererFactory) {
6
7
  this.loadingId = "L8d556b9b-f6dd-46e9-9710-757e65d82839";
7
8
  this.start = (element = "body") => {
8
- $(element).append(this.loadingNormal);
9
+ const ele = document.querySelector(element);
10
+ this.loadingElement = __classPrivateFieldGet(this, _createLoading).call(this);
11
+ ele.append(this.loadingElement);
9
12
  };
10
13
  this.isLoading = () => {
11
- return $(`#${this.loadingId}`).length > 0;
14
+ return !!this.loadingElement;
12
15
  };
13
16
  this.stop = (element = "body") => {
14
- $(element).children(`#${this.loadingId}`).remove();
17
+ var _a;
18
+ (_a = this.loadingElement) === null || _a === void 0 ? void 0 : _a.remove();
19
+ this.loadingElement = undefined;
15
20
  };
16
- }
17
- // Loading
18
- get loadingNormal() {
19
- // tslint:disable-next-line: max-line-length
20
- return `<div class="sd-loading" id="${this.loadingId}" style="top:0;left:0;height:100vh;width:100vw;position:absolute;opacity:0.6;background:#FFFFFF;z-index: 99999;"><i class="fa fa-5x fa-spinner fa-pulse" style="margin-top:calc(50vh - 2.5rem);margin-left:calc(50vw - 2.5rem)"></i></div>`;
21
+ _createLoading.set(this, () => {
22
+ const renderer = this.renderer;
23
+ const container = this.renderer.createElement('div');
24
+ const icon = this.renderer.createElement('i');
25
+ const containerStyle = {
26
+ position: 'absolute',
27
+ top: 0,
28
+ left: 0,
29
+ height: '100%',
30
+ width: '100%',
31
+ opacity: 0.6,
32
+ background: '#FFFFFF',
33
+ 'z-index': 99999
34
+ };
35
+ const iconStyle = {
36
+ position: 'absolute',
37
+ top: 'calc(50% - 2.5rem)',
38
+ left: 'calc(50% - 2.5rem)',
39
+ };
40
+ renderer.addClass(container, 'sd-loading');
41
+ renderer.setAttribute(container, 'id', this.loadingId);
42
+ Object.entries(containerStyle).forEach((entry) => {
43
+ renderer.setStyle(container, entry[0], entry[1]);
44
+ });
45
+ renderer.setAttribute(icon, 'class', 'fa fa-5x fa-spinner fa-pulse');
46
+ Object.entries(iconStyle).forEach((entry) => {
47
+ renderer.setStyle(icon, entry[0], entry[1]);
48
+ });
49
+ container.appendChild(icon);
50
+ return container;
51
+ });
52
+ this.renderer = rendererFactory.createRenderer(null, null);
21
53
  }
22
54
  }
23
- SdLoadingService.ɵprov = i0.ɵɵdefineInjectable({ factory: function SdLoadingService_Factory() { return new SdLoadingService(); }, token: SdLoadingService, providedIn: "root" });
55
+ _createLoading = new WeakMap();
56
+ SdLoadingService.ɵprov = i0.ɵɵdefineInjectable({ factory: function SdLoadingService_Factory() { return new SdLoadingService(i0.ɵɵinject(i0.RendererFactory2)); }, token: SdLoadingService, providedIn: "root" });
24
57
  SdLoadingService.decorators = [
25
58
  { type: Injectable, args: [{
26
59
  providedIn: "root",
27
60
  },] }
28
61
  ];
29
- SdLoadingService.ctorParameters = () => [];
30
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGluZy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IkM6L1VzZXJzL25naGlhdHQxNV9vbmVtb3VudC9Eb2N1bWVudHMvbGliLWNvcmUtdWkvcHJvamVjdHMvc2QtY29yZS9sb2FkaW5nLyIsInNvdXJjZXMiOlsic3JjL2xpYi9sb2FkaW5nLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUMzQyxPQUFPLENBQUMsTUFBTSxRQUFRLENBQUM7O0FBS3ZCLE1BQU0sT0FBTyxnQkFBZ0I7SUFHM0I7UUFGUSxjQUFTLEdBQUcsdUNBQXVDLENBQUM7UUFVNUQsVUFBSyxHQUFHLENBQUMsVUFBa0IsTUFBTSxFQUFFLEVBQUU7WUFDbkMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsYUFBYSxDQUFDLENBQUM7UUFDeEMsQ0FBQyxDQUFDO1FBRUYsY0FBUyxHQUFHLEdBQUcsRUFBRTtZQUNmLE9BQU8sQ0FBQyxDQUFDLElBQUksSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDLENBQUMsTUFBTSxHQUFHLENBQUMsQ0FBQztRQUM1QyxDQUFDLENBQUM7UUFFRixTQUFJLEdBQUcsQ0FBQyxVQUFrQixNQUFNLEVBQUUsRUFBRTtZQUNsQyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsUUFBUSxDQUFDLElBQUksSUFBSSxDQUFDLFNBQVMsRUFBRSxDQUFDLENBQUMsTUFBTSxFQUFFLENBQUM7UUFDckQsQ0FBQyxDQUFDO0lBbEJhLENBQUM7SUFFaEIsVUFBVTtJQUNWLElBQVksYUFBYTtRQUN2Qiw0Q0FBNEM7UUFDNUMsT0FBTywrQkFBK0IsSUFBSSxDQUFDLFNBQVMsNE9BQTRPLENBQUM7SUFDblMsQ0FBQzs7OztZQVpGLFVBQVUsU0FBQztnQkFDVixVQUFVLEVBQUUsTUFBTTthQUNuQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEluamVjdGFibGUgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgJCBmcm9tIFwianF1ZXJ5XCI7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogXCJyb290XCIsXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBTZExvYWRpbmdTZXJ2aWNlIHtcclxuICBwcml2YXRlIGxvYWRpbmdJZCA9IFwiTDhkNTU2YjliLWY2ZGQtNDZlOS05NzEwLTc1N2U2NWQ4MjgzOVwiO1xyXG5cclxuICBjb25zdHJ1Y3RvcigpIHt9XHJcblxyXG4gIC8vIExvYWRpbmdcclxuICBwcml2YXRlIGdldCBsb2FkaW5nTm9ybWFsKCkge1xyXG4gICAgLy8gdHNsaW50OmRpc2FibGUtbmV4dC1saW5lOiBtYXgtbGluZS1sZW5ndGhcclxuICAgIHJldHVybiBgPGRpdiBjbGFzcz1cInNkLWxvYWRpbmdcIiBpZD1cIiR7dGhpcy5sb2FkaW5nSWR9XCIgc3R5bGU9XCJ0b3A6MDtsZWZ0OjA7aGVpZ2h0OjEwMHZoO3dpZHRoOjEwMHZ3O3Bvc2l0aW9uOmFic29sdXRlO29wYWNpdHk6MC42O2JhY2tncm91bmQ6I0ZGRkZGRjt6LWluZGV4OiA5OTk5OTtcIj48aSBjbGFzcz1cImZhIGZhLTV4IGZhLXNwaW5uZXIgZmEtcHVsc2VcIiBzdHlsZT1cIm1hcmdpbi10b3A6Y2FsYyg1MHZoIC0gMi41cmVtKTttYXJnaW4tbGVmdDpjYWxjKDUwdncgLSAyLjVyZW0pXCI+PC9pPjwvZGl2PmA7XHJcbiAgfVxyXG5cclxuICBzdGFydCA9IChlbGVtZW50OiBzdHJpbmcgPSBcImJvZHlcIikgPT4ge1xyXG4gICAgJChlbGVtZW50KS5hcHBlbmQodGhpcy5sb2FkaW5nTm9ybWFsKTtcclxuICB9O1xyXG5cclxuICBpc0xvYWRpbmcgPSAoKSA9PiB7XHJcbiAgICByZXR1cm4gJChgIyR7dGhpcy5sb2FkaW5nSWR9YCkubGVuZ3RoID4gMDtcclxuICB9O1xyXG5cclxuICBzdG9wID0gKGVsZW1lbnQ6IHN0cmluZyA9IFwiYm9keVwiKSA9PiB7XHJcbiAgICAkKGVsZW1lbnQpLmNoaWxkcmVuKGAjJHt0aGlzLmxvYWRpbmdJZH1gKS5yZW1vdmUoKTtcclxuICB9O1xyXG59XHJcbiJdfQ==
62
+ SdLoadingService.ctorParameters = () => [
63
+ { type: RendererFactory2 }
64
+ ];
65
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGluZy5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IkM6L1VzZXJzL25naGlhdHQxNV9vbmVtb3VudC9Eb2N1bWVudHMvbGliLWNvcmUtdWkvcHJvamVjdHMvc2QtY29yZS9sb2FkaW5nLyIsInNvdXJjZXMiOlsic3JjL2xpYi9sb2FkaW5nLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFhLGdCQUFnQixFQUFFLE1BQU0sZUFBZSxDQUFDOztBQUt4RSxNQUFNLE9BQU8sZ0JBQWdCO0lBTTNCLFlBQ0UsZUFBaUM7UUFOM0IsY0FBUyxHQUFHLHVDQUF1QyxDQUFDO1FBVzVELFVBQUssR0FBRyxDQUFDLFVBQWtCLE1BQU0sRUFBRSxFQUFFO1lBQ25DLE1BQU0sR0FBRyxHQUFHLFFBQVEsQ0FBQyxhQUFhLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDNUMsSUFBSSxDQUFDLGNBQWMsR0FBRyxrREFBQSxJQUFJLENBQWlCLENBQUM7WUFDNUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLENBQUM7UUFDbEMsQ0FBQyxDQUFDO1FBRUYsY0FBUyxHQUFHLEdBQUcsRUFBRTtZQUNmLE9BQU8sQ0FBQyxDQUFDLElBQUksQ0FBQyxjQUFjLENBQUM7UUFDL0IsQ0FBQyxDQUFDO1FBRUYsU0FBSSxHQUFHLENBQUMsVUFBa0IsTUFBTSxFQUFFLEVBQUU7O1lBQ2xDLE1BQUEsSUFBSSxDQUFDLGNBQWMsMENBQUUsTUFBTSxHQUFHO1lBQzlCLElBQUksQ0FBQyxjQUFjLEdBQUcsU0FBUyxDQUFDO1FBQ2xDLENBQUMsQ0FBQztRQUVGLHlCQUFpQixHQUFnQixFQUFFO1lBQ2pDLE1BQU0sUUFBUSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUM7WUFDL0IsTUFBTSxTQUFTLEdBQWdCLElBQUksQ0FBQyxRQUFRLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ2xFLE1BQU0sSUFBSSxHQUFnQixJQUFJLENBQUMsUUFBUSxDQUFDLGFBQWEsQ0FBQyxHQUFHLENBQUMsQ0FBQztZQUMzRCxNQUFNLGNBQWMsR0FBRztnQkFDckIsUUFBUSxFQUFFLFVBQVU7Z0JBQ3BCLEdBQUcsRUFBRSxDQUFDO2dCQUNOLElBQUksRUFBRSxDQUFDO2dCQUNQLE1BQU0sRUFBRSxNQUFNO2dCQUNkLEtBQUssRUFBRSxNQUFNO2dCQUNiLE9BQU8sRUFBRSxHQUFHO2dCQUNaLFVBQVUsRUFBRSxTQUFTO2dCQUNyQixTQUFTLEVBQUUsS0FBSzthQUNqQixDQUFBO1lBQ0QsTUFBTSxTQUFTLEdBQUc7Z0JBQ2hCLFFBQVEsRUFBRSxVQUFVO2dCQUNwQixHQUFHLEVBQUUsb0JBQW9CO2dCQUN6QixJQUFJLEVBQUUsb0JBQW9CO2FBQzNCLENBQUE7WUFDRCxRQUFRLENBQUMsUUFBUSxDQUFDLFNBQVMsRUFBRSxZQUFZLENBQUMsQ0FBQztZQUMzQyxRQUFRLENBQUMsWUFBWSxDQUFDLFNBQVMsRUFBRSxJQUFJLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxDQUFDO1lBRXZELE1BQU0sQ0FBQyxPQUFPLENBQUMsY0FBYyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUU7Z0JBQy9DLFFBQVEsQ0FBQyxRQUFRLENBQUMsU0FBUyxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNuRCxDQUFDLENBQUMsQ0FBQztZQUNILFFBQVEsQ0FBQyxZQUFZLENBQUMsSUFBSSxFQUFFLE9BQU8sRUFBRSw4QkFBOEIsQ0FBQyxDQUFDO1lBQ3JFLE1BQU0sQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLENBQUMsT0FBTyxDQUFDLENBQUMsS0FBSyxFQUFFLEVBQUU7Z0JBQzFDLFFBQVEsQ0FBQyxRQUFRLENBQUMsSUFBSSxFQUFFLEtBQUssQ0FBQyxDQUFDLENBQUMsRUFBRSxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUM5QyxDQUFDLENBQUMsQ0FBQztZQUVILFNBQVMsQ0FBQyxXQUFXLENBQUMsSUFBSSxDQUFDLENBQUM7WUFDNUIsT0FBTyxTQUFTLENBQUM7UUFDbkIsQ0FBQyxFQUFBO1FBbERDLElBQUksQ0FBQyxRQUFRLEdBQUcsZUFBZSxDQUFDLGNBQWMsQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLENBQUM7SUFDN0QsQ0FBQzs7Ozs7WUFiRixVQUFVLFNBQUM7Z0JBQ1YsVUFBVSxFQUFFLE1BQU07YUFDbkI7OztZQUorQixnQkFBZ0IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3RhYmxlLCBSZW5kZXJlcjIsIFJlbmRlcmVyRmFjdG9yeTIgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46IFwicm9vdFwiLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgU2RMb2FkaW5nU2VydmljZSB7XHJcbiAgcHJpdmF0ZSBsb2FkaW5nSWQgPSBcIkw4ZDU1NmI5Yi1mNmRkLTQ2ZTktOTcxMC03NTdlNjVkODI4MzlcIjtcclxuXHJcbiAgcHJpdmF0ZSBsb2FkaW5nRWxlbWVudDogSFRNTEVsZW1lbnQgfCB1bmRlZmluZWQ7XHJcbiAgXHJcbiAgcHJpdmF0ZSByZW5kZXJlcjogUmVuZGVyZXIyO1xyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgcmVuZGVyZXJGYWN0b3J5OiBSZW5kZXJlckZhY3RvcnkyXHJcbiAgKSB7XHJcbiAgICB0aGlzLnJlbmRlcmVyID0gcmVuZGVyZXJGYWN0b3J5LmNyZWF0ZVJlbmRlcmVyKG51bGwsIG51bGwpO1xyXG4gIH1cclxuXHJcbiAgc3RhcnQgPSAoZWxlbWVudDogc3RyaW5nID0gXCJib2R5XCIpID0+IHtcclxuICAgIGNvbnN0IGVsZSA9IGRvY3VtZW50LnF1ZXJ5U2VsZWN0b3IoZWxlbWVudCk7XHJcbiAgICB0aGlzLmxvYWRpbmdFbGVtZW50ID0gdGhpcy4jY3JlYXRlTG9hZGluZygpO1xyXG4gICAgZWxlLmFwcGVuZCh0aGlzLmxvYWRpbmdFbGVtZW50KTtcclxuICB9O1xyXG5cclxuICBpc0xvYWRpbmcgPSAoKSA9PiB7XHJcbiAgICByZXR1cm4gISF0aGlzLmxvYWRpbmdFbGVtZW50O1xyXG4gIH07XHJcblxyXG4gIHN0b3AgPSAoZWxlbWVudDogc3RyaW5nID0gXCJib2R5XCIpID0+IHtcclxuICAgIHRoaXMubG9hZGluZ0VsZW1lbnQ/LnJlbW92ZSgpO1xyXG4gICAgdGhpcy5sb2FkaW5nRWxlbWVudCA9IHVuZGVmaW5lZDtcclxuICB9O1xyXG5cclxuICAjY3JlYXRlTG9hZGluZyA9ICgpOiBIVE1MRWxlbWVudCA9PiB7XHJcbiAgICBjb25zdCByZW5kZXJlciA9IHRoaXMucmVuZGVyZXI7XHJcbiAgICBjb25zdCBjb250YWluZXI6IEhUTUxFbGVtZW50ID0gdGhpcy5yZW5kZXJlci5jcmVhdGVFbGVtZW50KCdkaXYnKTtcclxuICAgIGNvbnN0IGljb246IEhUTUxFbGVtZW50ID0gdGhpcy5yZW5kZXJlci5jcmVhdGVFbGVtZW50KCdpJyk7XHJcbiAgICBjb25zdCBjb250YWluZXJTdHlsZSA9IHtcclxuICAgICAgcG9zaXRpb246ICdhYnNvbHV0ZScsXHJcbiAgICAgIHRvcDogMCxcclxuICAgICAgbGVmdDogMCxcclxuICAgICAgaGVpZ2h0OiAnMTAwJScsXHJcbiAgICAgIHdpZHRoOiAnMTAwJScsXHJcbiAgICAgIG9wYWNpdHk6IDAuNixcclxuICAgICAgYmFja2dyb3VuZDogJyNGRkZGRkYnLFxyXG4gICAgICAnei1pbmRleCc6IDk5OTk5XHJcbiAgICB9XHJcbiAgICBjb25zdCBpY29uU3R5bGUgPSB7XHJcbiAgICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxyXG4gICAgICB0b3A6ICdjYWxjKDUwJSAtIDIuNXJlbSknLFxyXG4gICAgICBsZWZ0OiAnY2FsYyg1MCUgLSAyLjVyZW0pJyxcclxuICAgIH1cclxuICAgIHJlbmRlcmVyLmFkZENsYXNzKGNvbnRhaW5lciwgJ3NkLWxvYWRpbmcnKTtcclxuICAgIHJlbmRlcmVyLnNldEF0dHJpYnV0ZShjb250YWluZXIsICdpZCcsIHRoaXMubG9hZGluZ0lkKTtcclxuICAgIFxyXG4gICAgT2JqZWN0LmVudHJpZXMoY29udGFpbmVyU3R5bGUpLmZvckVhY2goKGVudHJ5KSA9PiB7XHJcbiAgICAgIHJlbmRlcmVyLnNldFN0eWxlKGNvbnRhaW5lciwgZW50cnlbMF0sIGVudHJ5WzFdKTtcclxuICAgIH0pO1xyXG4gICAgcmVuZGVyZXIuc2V0QXR0cmlidXRlKGljb24sICdjbGFzcycsICdmYSBmYS01eCBmYS1zcGlubmVyIGZhLXB1bHNlJyk7XHJcbiAgICBPYmplY3QuZW50cmllcyhpY29uU3R5bGUpLmZvckVhY2goKGVudHJ5KSA9PiB7XHJcbiAgICAgIHJlbmRlcmVyLnNldFN0eWxlKGljb24sIGVudHJ5WzBdLCBlbnRyeVsxXSk7XHJcbiAgICB9KTtcclxuXHJcbiAgICBjb250YWluZXIuYXBwZW5kQ2hpbGQoaWNvbik7XHJcbiAgICByZXR1cm4gY29udGFpbmVyO1xyXG4gIH1cclxufVxyXG4iXX0=