@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,14 +1,29 @@
1
- var _name, _model, _required, _subscription, _updateValidator;
1
+ var _name, _form, _model, _required, _subscription, _updateValidator;
2
2
  import { __classPrivateFieldGet, __classPrivateFieldSet } from "tslib";
3
- import { Component, Input, Output, EventEmitter, ChangeDetectorRef } from '@angular/core';
4
- import { FormControl, Validators } from '@angular/forms';
3
+ import { Component, Input, Output, EventEmitter, ChangeDetectorRef, ChangeDetectionStrategy } from '@angular/core';
4
+ import { NgForm, Validators } from '@angular/forms';
5
+ import { SdFormControl } from '@sd-angular/core/common';
5
6
  import { Subscription } from 'rxjs';
6
7
  import * as uuid from 'uuid';
7
8
  export class SdRadio {
8
9
  constructor(ref) {
9
10
  this.ref = ref;
10
11
  _name.set(this, uuid.v4());
11
- this.formControl = new FormControl();
12
+ this.formControl = new SdFormControl();
13
+ // get isNumber() {
14
+ // if (this.#model || this.#model === 0) {
15
+ // return typeof (this.#model) === 'number';
16
+ // }
17
+ // if (this.items?.length) {
18
+ // if (this.valueField) {
19
+ // return typeof (this.items[0][this.valueField]) === 'number';
20
+ // } else {
21
+ // return typeof (this.items[0]) === 'number';
22
+ // }
23
+ // }
24
+ // return false;
25
+ // }
26
+ _form.set(this, void 0);
12
27
  this.display = 'row';
13
28
  // Model
14
29
  _model.set(this, void 0);
@@ -38,20 +53,15 @@ export class SdRadio {
38
53
  __classPrivateFieldSet(this, _name, val);
39
54
  }
40
55
  }
41
- get isNumber() {
42
- var _a;
43
- if (__classPrivateFieldGet(this, _model) || __classPrivateFieldGet(this, _model) === 0) {
44
- return typeof (__classPrivateFieldGet(this, _model)) === 'number';
45
- }
46
- if ((_a = this.items) === null || _a === void 0 ? void 0 : _a.length) {
47
- if (this.valueField) {
48
- return typeof (this.items[0][this.valueField]) === 'number';
56
+ set form(val) {
57
+ if (val) {
58
+ if (val instanceof NgForm) {
59
+ __classPrivateFieldSet(this, _form, val.form);
49
60
  }
50
61
  else {
51
- return typeof (this.items[0]) === 'number';
62
+ __classPrivateFieldSet(this, _form, val);
52
63
  }
53
64
  }
54
- return false;
55
65
  }
56
66
  set model(value) {
57
67
  __classPrivateFieldSet(this, _model, value);
@@ -83,15 +93,19 @@ export class SdRadio {
83
93
  }
84
94
  }
85
95
  ngOnInit() {
96
+ __classPrivateFieldGet(this, _subscription).add(this.formControl.sdChanges.subscribe(() => {
97
+ this.formControl.updateValueAndValidity();
98
+ this.ref.markForCheck();
99
+ }));
86
100
  }
87
101
  ngAfterViewInit() {
88
102
  var _a;
89
103
  __classPrivateFieldGet(this, _subscription).add(this.formControl.valueChanges.subscribe(value => {
90
104
  var _a;
91
105
  let val = value;
92
- if (this.isNumber && Number.isNumber(value)) {
93
- val = +value;
94
- }
106
+ // if (this.isNumber && Number.isNumber(value)) {
107
+ // val = +value;
108
+ // }
95
109
  this.modelChange.emit(val);
96
110
  this.sdChange.emit(val);
97
111
  this.sdSelection.emit({
@@ -110,19 +124,20 @@ export class SdRadio {
110
124
  }
111
125
  });
112
126
  }
113
- (_a = this.form) === null || _a === void 0 ? void 0 : _a.form.addControl(__classPrivateFieldGet(this, _name), this.formControl);
127
+ (_a = __classPrivateFieldGet(this, _form)) === null || _a === void 0 ? void 0 : _a.addControl(__classPrivateFieldGet(this, _name), this.formControl);
114
128
  }
115
129
  ngOnDestroy() {
116
130
  var _a;
117
131
  __classPrivateFieldGet(this, _subscription).unsubscribe();
118
- (_a = this.form) === null || _a === void 0 ? void 0 : _a.form.removeControl(__classPrivateFieldGet(this, _name));
132
+ (_a = __classPrivateFieldGet(this, _form)) === null || _a === void 0 ? void 0 : _a.removeControl(__classPrivateFieldGet(this, _name));
119
133
  }
120
134
  }
121
- _name = new WeakMap(), _model = new WeakMap(), _required = new WeakMap(), _subscription = new WeakMap(), _updateValidator = new WeakMap();
135
+ _name = new WeakMap(), _form = new WeakMap(), _model = new WeakMap(), _required = new WeakMap(), _subscription = new WeakMap(), _updateValidator = new WeakMap();
122
136
  SdRadio.decorators = [
123
137
  { type: Component, args: [{
124
138
  selector: 'sd-radio',
125
139
  template: "<section [ngClass]=\"{'c-section': display == 'row'}\">\r\n <label *ngIf=\"label\" class=\"sd-label d-block mr-2\">{{label}} </label>\r\n <mat-radio-group [ngClass]=\"{'c-radio-group-column': display == 'column', 'c-radio-group-row': display == 'row'}\"\r\n [formControl]=\"formControl\">\r\n <mat-radio-button color=\"primary\" [ngClass]=\"{'m-0': display == 'column', 'mr-16': display == 'row'}\"\r\n *ngFor=\"let item of items\" [value]=\"item[valueField]\">\r\n {{item[displayField]}}\r\n </mat-radio-button>\r\n </mat-radio-group>\r\n</section>",
140
+ changeDetection: ChangeDetectionStrategy.OnPush,
126
141
  styles: [".c-section{align-content:center;align-items:center}.c-radio-group-column{display:flex;flex-direction:column}.c-radio-group-row{display:flex;flex-direction:row}"]
127
142
  },] }
128
143
  ];
@@ -145,4 +160,4 @@ SdRadio.propDecorators = {
145
160
  sdChange: [{ type: Output }],
146
161
  sdSelection: [{ type: Output }]
147
162
  };
148
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/radio/","sources":["src/lib/radio.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, ChangeDetectorRef, AfterViewInit, OnDestroy, OnInit } from '@angular/core';\r\nimport { NgForm, FormControl, Validators, ValidatorFn } from '@angular/forms';\r\nimport { Subscription } from 'rxjs';\r\nimport * as uuid from 'uuid';\r\n\r\n@Component({\r\n  selector: 'sd-radio',\r\n  templateUrl: './radio.component.html',\r\n  styleUrls: ['./radio.component.scss']\r\n})\r\nexport class SdRadio implements OnInit, AfterViewInit, OnDestroy {\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  formControl = new FormControl();\r\n  get isNumber() {\r\n    if (this.#model || this.#model === 0) {\r\n      return typeof (this.#model) === 'number';\r\n    }\r\n    if (this.items?.length) {\r\n      if (this.valueField) {\r\n        return typeof (this.items[0][this.valueField]) === 'number';\r\n      } else {\r\n        return typeof (this.items[0]) === 'number';\r\n      }\r\n    }\r\n    return false;\r\n  }\r\n  @Input() form: NgForm;\r\n  @Input() label: string;\r\n  @Input() placeholder: string;\r\n  @Input() display: 'row' | 'column' = 'row';\r\n  // Model\r\n  #model: number | string;\r\n  @Input() set model(value: number | string) {\r\n    this.#model = value;\r\n    const val = (value ?? '') + '';\r\n    if (val !== this.formControl.value) {\r\n      this.formControl.setValue(val, {\r\n        emitEvent: false\r\n      });\r\n    }\r\n  }\r\n  // Items\r\n  items: any[] = [];\r\n  @Input('items') set pItems(items: any[]) {\r\n    if (!Array.isArray(items)) {\r\n      this.items = [];\r\n    }\r\n    this.items = items;\r\n  }\r\n  @Input() valueField: string;\r\n  @Input() displayField: string;\r\n\r\n  // Validator\r\n  #required = false;\r\n  @Input() set required(val: boolean | '') {\r\n    this.#required = (val === '') || val;\r\n    this.#updateValidator();\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    } else {\r\n      this.formControl.enable();\r\n    }\r\n  }\r\n  @Output() modelChange = new EventEmitter();\r\n  @Output() sdChange = new EventEmitter();\r\n  @Output() sdSelection = new EventEmitter<{ value: any | any[], item?: any }>();\r\n  #subscription = new Subscription();\r\n  constructor(\r\n    private ref: ChangeDetectorRef) { }\r\n\r\n  ngOnInit() {\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.#subscription.add(this.formControl.valueChanges.subscribe(value => {\r\n      let val = value;\r\n      if (this.isNumber && Number.isNumber(value)) {\r\n        val = +value;\r\n      }\r\n      this.modelChange.emit(val);\r\n      this.sdChange.emit(val);\r\n      this.sdSelection.emit({\r\n        value: val,\r\n        item: this.items?.find(e => val?.toString() === e?.[this.valueField]?.toString())\r\n      });\r\n    }));\r\n    if((this.#model === undefined || this.#model === null) && this.#required) {\r\n      setTimeout(() => {\r\n        if(this.valueField) {\r\n          this.formControl.setValue(this.items[0]?.[this.valueField]);\r\n        } else {\r\n          this.formControl.setValue(this.items[0]);\r\n        }\r\n      });\r\n    }\r\n    this.form?.form.addControl(this.#name, this.formControl);\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.#subscription.unsubscribe();\r\n    this.form?.form.removeControl(this.#name);\r\n  }\r\n\r\n  #updateValidator = () => {\r\n    this.formControl.clearValidators();\r\n    const validators: ValidatorFn[] = [];\r\n    if (this.#required) {\r\n      validators.push(Validators.required);\r\n    }\r\n    this.formControl.setValidators(validators);\r\n    this.formControl.updateValueAndValidity();\r\n  }\r\n\r\n  reValidate = () => {\r\n    this.formControl.updateValueAndValidity({ emitEvent: true });\r\n  }\r\n}\r\n"]}
163
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"radio.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/radio/","sources":["src/lib/radio.component.ts"],"names":[],"mappings":";;AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,EAAE,YAAY,EAAE,iBAAiB,EAAoC,uBAAuB,EAAE,MAAM,eAAe,CAAC;AACrJ,OAAO,EAAE,MAAM,EAAE,UAAU,EAA0B,MAAM,gBAAgB,CAAC;AAC5E,OAAO,EAAE,aAAa,EAAE,MAAM,yBAAyB,CAAC;AACxD,OAAO,EAAE,YAAY,EAAE,MAAM,MAAM,CAAC;AACpC,OAAO,KAAK,IAAI,MAAM,MAAM,CAAC;AAQ7B,MAAM,OAAO,OAAO;IA2ElB,YACS,GAAsB;QAAtB,QAAG,GAAH,GAAG,CAAmB;QA3E/B,gBAAQ,IAAI,CAAC,EAAE,EAAE,EAAC;QAMlB,gBAAW,GAAG,IAAI,aAAa,EAAE,CAAC;QAClC,mBAAmB;QACnB,4CAA4C;QAC5C,gDAAgD;QAChD,MAAM;QACN,8BAA8B;QAC9B,6BAA6B;QAC7B,qEAAqE;QACrE,eAAe;QACf,oDAAoD;QACpD,QAAQ;QACR,MAAM;QACN,kBAAkB;QAClB,IAAI;QACJ,wBAAiB;QAYR,YAAO,GAAqB,KAAK,CAAC;QAC3C,QAAQ;QACR,yBAAwB;QAUxB,QAAQ;QACR,UAAK,GAAU,EAAE,CAAC;QAUlB,YAAY;QACZ,oBAAY,KAAK,EAAC;QAcR,gBAAW,GAAG,IAAI,YAAY,EAAE,CAAC;QACjC,aAAQ,GAAG,IAAI,YAAY,EAAE,CAAC;QAC9B,gBAAW,GAAG,IAAI,YAAY,EAAsC,CAAC;QAC/E,wBAAgB,IAAI,YAAY,EAAE,EAAC;QA0CnC,2BAAmB,GAAG,EAAE;YACtB,IAAI,CAAC,WAAW,CAAC,eAAe,EAAE,CAAC;YACnC,MAAM,UAAU,GAAkB,EAAE,CAAC;YACrC,6CAAoB;gBAClB,UAAU,CAAC,IAAI,CAAC,UAAU,CAAC,QAAQ,CAAC,CAAC;aACtC;YACD,IAAI,CAAC,WAAW,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;YAC3C,IAAI,CAAC,WAAW,CAAC,sBAAsB,EAAE,CAAC;QAC5C,CAAC,EAAA;QAED,eAAU,GAAG,GAAG,EAAE;YAChB,IAAI,CAAC,WAAW,CAAC,sBAAsB,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QAC/D,CAAC,CAAA;IAnDG,CAAC;IA3EL,IAAa,IAAI,CAAC,GAAW;QAC3B,IAAI,GAAG,EAAE;YACP,uBAAA,IAAI,SAAS,GAAG,EAAC;SAClB;IACH,CAAC;IAgBD,IAAa,IAAI,CAAC,GAAuB;QACvC,IAAI,GAAG,EAAE;YACP,IAAI,GAAG,YAAY,MAAM,EAAE;gBACzB,uBAAA,IAAI,SAAS,GAAG,CAAC,IAAI,EAAC;aACvB;iBAAM;gBACL,uBAAA,IAAI,SAAS,GAAG,EAAC;aAClB;SACF;IACH,CAAC;IAMD,IAAa,KAAK,CAAC,KAAsB;QACvC,uBAAA,IAAI,UAAU,KAAK,EAAC;QACpB,MAAM,GAAG,GAAG,CAAC,KAAK,aAAL,KAAK,cAAL,KAAK,GAAI,EAAE,CAAC,GAAG,EAAE,CAAC;QAC/B,IAAI,GAAG,KAAK,IAAI,CAAC,WAAW,CAAC,KAAK,EAAE;YAClC,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,GAAG,EAAE;gBAC7B,SAAS,EAAE,KAAK;aACjB,CAAC,CAAC;SACJ;IACH,CAAC;IAGD,IAAoB,MAAM,CAAC,KAAY;QACrC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YACzB,IAAI,CAAC,KAAK,GAAG,EAAE,CAAC;SACjB;QACD,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IAMD,IAAa,QAAQ,CAAC,GAAiB;QACrC,uBAAA,IAAI,aAAa,CAAC,GAAG,KAAK,EAAE,CAAC,IAAI,GAAG,EAAC;QACrC,oDAAA,IAAI,CAAmB,CAAC;IAC1B,CAAC;IACD,WAAW;IACX,IAAa,QAAQ,CAAC,GAAiB;QACrC,GAAG,GAAG,CAAC,GAAG,KAAK,EAAE,CAAC,IAAI,GAAG,CAAC;QAC1B,IAAI,GAAG,EAAE;YACP,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC;SAC5B;aAAM;YACL,IAAI,CAAC,WAAW,CAAC,MAAM,EAAE,CAAC;SAC3B;IACH,CAAC;IASD,QAAQ;QACN,4CAAmB,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,SAAS,CAAC,SAAS,CAAC,GAAG,EAAE;YAC/D,IAAI,CAAC,WAAW,CAAC,sBAAsB,EAAE,CAAC;YAC1C,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,CAAC;QAC1B,CAAC,CAAC,CAAC,CAAC;IACN,CAAC;IAED,eAAe;;QACb,4CAAmB,GAAG,CAAC,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE;;YACrE,IAAI,GAAG,GAAG,KAAK,CAAC;YAChB,iDAAiD;YACjD,kBAAkB;YAClB,IAAI;YACJ,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAC3B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YACxB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC;gBACpB,KAAK,EAAE,GAAG;gBACV,IAAI,QAAE,IAAI,CAAC,KAAK,0CAAE,IAAI,CAAC,CAAC,CAAC,EAAE,WAAC,OAAA,CAAA,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,QAAQ,eAAO,CAAC,aAAD,CAAC,uBAAD,CAAC,CAAG,IAAI,CAAC,UAAU,2CAAG,QAAQ,GAAE,CAAA,EAAA,CAAC;aAClF,CAAC,CAAC;QACL,CAAC,CAAC,CAAC,CAAC;QACJ,IAAG,CAAC,yCAAgB,SAAS,IAAI,yCAAgB,IAAI,CAAC,2CAAkB,EAAE;YACxE,UAAU,CAAC,GAAG,EAAE;;gBACd,IAAG,IAAI,CAAC,UAAU,EAAE;oBAClB,IAAI,CAAC,WAAW,CAAC,QAAQ,OAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,0CAAG,IAAI,CAAC,UAAU,EAAE,CAAC;iBAC7D;qBAAM;oBACL,IAAI,CAAC,WAAW,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;iBAC1C;YACH,CAAC,CAAC,CAAC;SACJ;QACD,mFAAY,UAAU,sCAAa,IAAI,CAAC,WAAW,EAAE;IACvD,CAAC;IAED,WAAW;;QACT,4CAAmB,WAAW,EAAE,CAAC;QACjC,mFAAY,aAAa,sCAAa;IACxC,CAAC;;;;YAxHF,SAAS,SAAC;gBACT,QAAQ,EAAE,UAAU;gBACpB,ukBAAqC;gBAErC,eAAe,EAAE,uBAAuB,CAAC,MAAM;;aAChD;;;YAXgD,iBAAiB;;;mBAc/D,KAAK;mBAoBL,KAAK;oBASL,KAAK;0BACL,KAAK;sBACL,KAAK;oBAGL,KAAK;qBAWL,KAAK,SAAC,OAAO;yBAMb,KAAK;2BACL,KAAK;uBAIL,KAAK;uBAKL,KAAK;0BAQL,MAAM;uBACN,MAAM;0BACN,MAAM","sourcesContent":["import { Component, Input, Output, EventEmitter, ChangeDetectorRef, AfterViewInit, OnDestroy, OnInit, ChangeDetectionStrategy } from '@angular/core';\r\nimport { NgForm, Validators, ValidatorFn, FormGroup } from '@angular/forms';\r\nimport { SdFormControl } from '@sd-angular/core/common';\r\nimport { Subscription } from 'rxjs';\r\nimport * as uuid from 'uuid';\r\n\r\n@Component({\r\n  selector: 'sd-radio',\r\n  templateUrl: './radio.component.html',\r\n  styleUrls: ['./radio.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class SdRadio implements OnInit, AfterViewInit, OnDestroy {\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  formControl = new SdFormControl();\r\n  // get isNumber() {\r\n  //   if (this.#model || this.#model === 0) {\r\n  //     return typeof (this.#model) === 'number';\r\n  //   }\r\n  //   if (this.items?.length) {\r\n  //     if (this.valueField) {\r\n  //       return typeof (this.items[0][this.valueField]) === 'number';\r\n  //     } else {\r\n  //       return typeof (this.items[0]) === 'number';\r\n  //     }\r\n  //   }\r\n  //   return false;\r\n  // }\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  @Input() display: 'row' | 'column' = 'row';\r\n  // Model\r\n  #model: number | string;\r\n  @Input() set model(value: number | string) {\r\n    this.#model = value;\r\n    const val = (value ?? '') + '';\r\n    if (val !== this.formControl.value) {\r\n      this.formControl.setValue(val, {\r\n        emitEvent: false\r\n      });\r\n    }\r\n  }\r\n  // Items\r\n  items: any[] = [];\r\n  @Input('items') set pItems(items: any[]) {\r\n    if (!Array.isArray(items)) {\r\n      this.items = [];\r\n    }\r\n    this.items = items;\r\n  }\r\n  @Input() valueField: string;\r\n  @Input() displayField: string;\r\n\r\n  // Validator\r\n  #required = false;\r\n  @Input() set required(val: boolean | '') {\r\n    this.#required = (val === '') || val;\r\n    this.#updateValidator();\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    } else {\r\n      this.formControl.enable();\r\n    }\r\n  }\r\n  @Output() modelChange = new EventEmitter();\r\n  @Output() sdChange = new EventEmitter();\r\n  @Output() sdSelection = new EventEmitter<{ value: any | any[], item?: any }>();\r\n  #subscription = new Subscription();\r\n  constructor(\r\n    public ref: ChangeDetectorRef\r\n  ) { }\r\n\r\n  ngOnInit() {\r\n    this.#subscription.add(this.formControl.sdChanges.subscribe(() => {\r\n      this.formControl.updateValueAndValidity();\r\n      this.ref.markForCheck();\r\n    }));\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.#subscription.add(this.formControl.valueChanges.subscribe(value => {\r\n      let val = value;\r\n      // if (this.isNumber && Number.isNumber(value)) {\r\n      //   val = +value;\r\n      // }\r\n      this.modelChange.emit(val);\r\n      this.sdChange.emit(val);\r\n      this.sdSelection.emit({\r\n        value: val,\r\n        item: this.items?.find(e => val?.toString() === e?.[this.valueField]?.toString())\r\n      });\r\n    }));\r\n    if((this.#model === undefined || this.#model === null) && this.#required) {\r\n      setTimeout(() => {\r\n        if(this.valueField) {\r\n          this.formControl.setValue(this.items[0]?.[this.valueField]);\r\n        } else {\r\n          this.formControl.setValue(this.items[0]);\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.#subscription.unsubscribe();\r\n    this.#form?.removeControl(this.#name);\r\n  }\r\n\r\n  #updateValidator = () => {\r\n    this.formControl.clearValidators();\r\n    const validators: ValidatorFn[] = [];\r\n    if (this.#required) {\r\n      validators.push(Validators.required);\r\n    }\r\n    this.formControl.setValidators(validators);\r\n    this.formControl.updateValueAndValidity();\r\n  }\r\n\r\n  reValidate = () => {\r\n    this.formControl.updateValueAndValidity({ emitEvent: true });\r\n  }\r\n}\r\n"]}
@@ -273,7 +273,6 @@ export class SdSelect {
273
273
  }
274
274
  ngOnInit() {
275
275
  __classPrivateFieldGet(this, _subscription).add(this.formControl.sdChanges.subscribe(() => {
276
- this.formControl.updateValueAndValidity();
277
276
  this.ref.markForCheck();
278
277
  }));
279
278
  __classPrivateFieldSet(this, _allItems, combineLatest([
@@ -402,4 +401,4 @@ SdSelect.propDecorators = {
402
401
  sdSelection: [{ type: Output }],
403
402
  sdView: [{ type: ContentChild, args: [SdViewDefDirective,] }]
404
403
  };
405
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/select/","sources":["src/lib/select.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, ChangeDetectorRef, AfterViewInit, OnDestroy, OnInit, ViewChild, ChangeDetectionStrategy, ContentChild } from '@angular/core';\r\nimport { NgForm, Validators, ValidatorFn, AbstractControl, AsyncValidatorFn, FormGroup } from '@angular/forms';\r\nimport * as uuid from 'uuid';\r\nimport { MatSelect, MatSelectChange } from '@angular/material/select';\r\nimport { BehaviorSubject, combineLatest, Observable, of, Subject, Subscription } from 'rxjs';\r\nimport { debounceTime, map, startWith, switchMap } from 'rxjs/operators';\r\nimport { MatInput } from '@angular/material/input';\r\nimport { SdSelectDisplayDefDirective } from './select-display-def.directive';\r\nimport { SdFormControl, SdViewDefDirective } from '@sd-angular/core/common';\r\nimport { MatTooltip } from '@angular/material/tooltip';\r\n@Component({\r\n  selector: 'sd-select',\r\n  templateUrl: './select.component.html',\r\n  styleUrls: ['./select.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class SdSelect implements OnInit, AfterViewInit, OnDestroy {\r\n  #input: MatInput;\r\n  @ViewChild(MatInput) set input(input: MatInput) {\r\n    if (this.#input !== input) {\r\n      this.#input = input;\r\n      this.#input.value = null;\r\n    }\r\n  }\r\n  @ViewChild('select') select: MatSelect;\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  disableErrorMessage = false;\r\n  @Input('disableErrorMessage') set _disableErrorMessage(val: boolean | '') {\r\n    this.disableErrorMessage = (val === '') || val;\r\n    val = (val === '') || val;\r\n  }\r\n  formControl = new SdFormControl();\r\n\r\n  searchTerm$ = new Subject<string>();\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\r\n  // Model\r\n  display: Observable<string>;\r\n  @Input() set model(value: undefined | boolean | number | string | (number | string)[]) {\r\n    this.formControl.setValue(value);\r\n  }\r\n  // Items\r\n\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.searchTerm$.next('');\r\n  }\r\n  @Input() valueField: string;\r\n  @Input() displayField: string;\r\n\r\n  // Server search\r\n  loading = false;\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\r\n  // Validator\r\n  isRequired = false;\r\n  #validator: (value: any) => string | Promise<string>;\r\n  @Input() set required(val: boolean | '') {\r\n    this.isRequired = (val === '') || val;\r\n    this.#updateValidator();\r\n  }\r\n  @Input() set validator(validator: (value: any) => string | Promise<string>) {\r\n    this.#validator = validator;\r\n    this.#updateValidator();\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    } else {\r\n      this.formControl.enable();\r\n    }\r\n  }\r\n  multiple = false;\r\n  @Input('multiple') set _multiple(val: boolean | '') {\r\n    this.multiple = (val === '') || val;\r\n  }\r\n  @Input() limit = 100;\r\n  filtered = false;\r\n  @Input('filtered') set _filtered(val: boolean | '') {\r\n    this.filtered = (val === '') || val;\r\n  }\r\n  @ContentChild(SdSelectDisplayDefDirective) selectDisplayDef: SdSelectDisplayDefDirective;\r\n  selectAll = false;\r\n  @Input('selectAll') set _selectAll(val: boolean | '') {\r\n    this.selectAll = (val === '') || val;\r\n  }\r\n\r\n  @Output() modelChange = new EventEmitter();\r\n  @Output() sdChange = new EventEmitter();\r\n  @Output() sdSelection = new EventEmitter<{ value: any | any[], item?: any, items?: any[] }>();\r\n  #subscription = new Subscription();\r\n  selectedItems: Observable<any[]>;\r\n  #allItems: Observable<any[]>;\r\n  filteredItems: Observable<any[]>;\r\n  #allItem: {\r\n    [key: string]: any\r\n  } = {};\r\n  allSelected = false;\r\n  #cache: {\r\n    [key: string]: any[]\r\n  } = {};\r\n  @ContentChild(SdViewDefDirective) sdView: SdViewDefDirective;\r\n  isFocused = false;\r\n\r\n  constructor(\r\n    private ref: ChangeDetectorRef) { }\r\n\r\n  ngOnInit() {\r\n    this.#subscription.add(this.formControl.sdChanges.subscribe(() => {\r\n      this.formControl.updateValueAndValidity();\r\n      this.ref.markForCheck();\r\n    }));\r\n    this.#allItems = combineLatest([\r\n      this.#itemsChanges.asObservable(),\r\n      this.searchTerm$.asObservable().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  }\r\n\r\n  ngAfterViewInit() {\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.#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  #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  #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  onSelectionChange = (change: MatSelectChange) => {\r\n    this.allSelected = !this.select.options.some(e => !e.selected);\r\n    const value = change?.value ?? '';\r\n    if (this.multiple) {\r\n      this.#onChange(value || []);\r\n    } else {\r\n      this.searchTerm$.next('');\r\n      this.#onChange(value);\r\n    }\r\n  }\r\n\r\n  onSelectAll() {\r\n    if (this.allSelected) {\r\n      this.formControl.setValue(this.select.options.map(e => e.value));\r\n    } else {\r\n      this.formControl.setValue([]);\r\n    }\r\n    this.#onChange(this.formControl.value);\r\n  }\r\n\r\n  reValidate = () => {\r\n    this.formControl.updateValueAndValidity({ emitEvent: true });\r\n  }\r\n\r\n  #onChange = async (value: boolean | number | string | (number | string)[]) => {\r\n    if (Array.isArray(value)) {\r\n      this.modelChange.emit(value);\r\n      this.sdChange.emit(value);\r\n      this.sdSelection.emit({\r\n        value: value,\r\n        items: value.map(val => this.#allItem[val?.toString()])\r\n      });\r\n    } else {\r\n      this.modelChange.emit(value);\r\n      this.sdChange.emit(value);\r\n      this.sdSelection.emit({\r\n        value: value,\r\n        item: this.#allItem[value?.toString()]\r\n      });\r\n    }\r\n  }\r\n\r\n  clear = ($event?: any) => {\r\n    $event?.stopPropagation();\r\n    if (this.multiple) {\r\n      this.formControl.setValue([]);\r\n      this.modelChange.emit([]);\r\n      this.sdChange.emit([]);\r\n      this.sdSelection.emit({\r\n        value: [],\r\n        items: []\r\n      });\r\n    } else {\r\n      this.formControl.setValue(null);\r\n      this.modelChange.emit(null);\r\n      this.sdChange.emit(null);\r\n      this.sdSelection.emit({\r\n        value: null,\r\n        item: null\r\n      });\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.select?.focus();\r\n      this.select?.open();\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  onOpenChange = (isOpened: boolean) => {\r\n    if (isOpened) {\r\n      this.isFocused = true;\r\n      if (this.#input) {\r\n        this.#input.value = null;\r\n      }\r\n      this.searchTerm$.next('');\r\n    } else {\r\n      this.isFocused = false;\r\n    }\r\n  }\r\n\r\n  onOptionChange = (tooltip: MatTooltip) => {\r\n    tooltip?.hide();\r\n  }\r\n\r\n  trackByKey = (index, item) => {\r\n    if (this.valueField) {\r\n      return item?.[this.valueField];\r\n    }\r\n    return item;\r\n  }\r\n}\r\n\r\ntype SearchFunc = (searchText?: string | string[], isFormValue?: boolean) => Promise<any[]>;"]}
404
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/select/","sources":["src/lib/select.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, ChangeDetectorRef, AfterViewInit, OnDestroy, OnInit, ViewChild, ChangeDetectionStrategy, ContentChild } from '@angular/core';\r\nimport { NgForm, Validators, ValidatorFn, AbstractControl, AsyncValidatorFn, FormGroup } from '@angular/forms';\r\nimport * as uuid from 'uuid';\r\nimport { MatSelect, MatSelectChange } from '@angular/material/select';\r\nimport { BehaviorSubject, combineLatest, Observable, of, Subject, Subscription } from 'rxjs';\r\nimport { debounceTime, map, startWith, switchMap } from 'rxjs/operators';\r\nimport { MatInput } from '@angular/material/input';\r\nimport { SdSelectDisplayDefDirective } from './select-display-def.directive';\r\nimport { SdFormControl, SdViewDefDirective } from '@sd-angular/core/common';\r\nimport { MatTooltip } from '@angular/material/tooltip';\r\n@Component({\r\n  selector: 'sd-select',\r\n  templateUrl: './select.component.html',\r\n  styleUrls: ['./select.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class SdSelect implements OnInit, AfterViewInit, OnDestroy {\r\n  #input: MatInput;\r\n  @ViewChild(MatInput) set input(input: MatInput) {\r\n    if (this.#input !== input) {\r\n      this.#input = input;\r\n      this.#input.value = null;\r\n    }\r\n  }\r\n  @ViewChild('select') select: MatSelect;\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  disableErrorMessage = false;\r\n  @Input('disableErrorMessage') set _disableErrorMessage(val: boolean | '') {\r\n    this.disableErrorMessage = (val === '') || val;\r\n    val = (val === '') || val;\r\n  }\r\n  formControl = new SdFormControl();\r\n\r\n  searchTerm$ = new Subject<string>();\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\r\n  // Model\r\n  display: Observable<string>;\r\n  @Input() set model(value: undefined | boolean | number | string | (number | string)[]) {\r\n    this.formControl.setValue(value);\r\n  }\r\n  // Items\r\n\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.searchTerm$.next('');\r\n  }\r\n  @Input() valueField: string;\r\n  @Input() displayField: string;\r\n\r\n  // Server search\r\n  loading = false;\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\r\n  // Validator\r\n  isRequired = false;\r\n  #validator: (value: any) => string | Promise<string>;\r\n  @Input() set required(val: boolean | '') {\r\n    this.isRequired = (val === '') || val;\r\n    this.#updateValidator();\r\n  }\r\n  @Input() set validator(validator: (value: any) => string | Promise<string>) {\r\n    this.#validator = validator;\r\n    this.#updateValidator();\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    } else {\r\n      this.formControl.enable();\r\n    }\r\n  }\r\n  multiple = false;\r\n  @Input('multiple') set _multiple(val: boolean | '') {\r\n    this.multiple = (val === '') || val;\r\n  }\r\n  @Input() limit = 100;\r\n  filtered = false;\r\n  @Input('filtered') set _filtered(val: boolean | '') {\r\n    this.filtered = (val === '') || val;\r\n  }\r\n  @ContentChild(SdSelectDisplayDefDirective) selectDisplayDef: SdSelectDisplayDefDirective;\r\n  selectAll = false;\r\n  @Input('selectAll') set _selectAll(val: boolean | '') {\r\n    this.selectAll = (val === '') || val;\r\n  }\r\n\r\n  @Output() modelChange = new EventEmitter();\r\n  @Output() sdChange = new EventEmitter();\r\n  @Output() sdSelection = new EventEmitter<{ value: any | any[], item?: any, items?: any[] }>();\r\n  #subscription = new Subscription();\r\n  selectedItems: Observable<any[]>;\r\n  #allItems: Observable<any[]>;\r\n  filteredItems: Observable<any[]>;\r\n  #allItem: {\r\n    [key: string]: any\r\n  } = {};\r\n  allSelected = false;\r\n  #cache: {\r\n    [key: string]: any[]\r\n  } = {};\r\n  @ContentChild(SdViewDefDirective) sdView: SdViewDefDirective;\r\n  isFocused = false;\r\n\r\n  constructor(\r\n    private ref: ChangeDetectorRef) { }\r\n\r\n  ngOnInit() {\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.searchTerm$.asObservable().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  }\r\n\r\n  ngAfterViewInit() {\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.#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  #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  #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  onSelectionChange = (change: MatSelectChange) => {\r\n    this.allSelected = !this.select.options.some(e => !e.selected);\r\n    const value = change?.value ?? '';\r\n    if (this.multiple) {\r\n      this.#onChange(value || []);\r\n    } else {\r\n      this.searchTerm$.next('');\r\n      this.#onChange(value);\r\n    }\r\n  }\r\n\r\n  onSelectAll() {\r\n    if (this.allSelected) {\r\n      this.formControl.setValue(this.select.options.map(e => e.value));\r\n    } else {\r\n      this.formControl.setValue([]);\r\n    }\r\n    this.#onChange(this.formControl.value);\r\n  }\r\n\r\n  reValidate = () => {\r\n    this.formControl.updateValueAndValidity({ emitEvent: true });\r\n  }\r\n\r\n  #onChange = async (value: boolean | number | string | (number | string)[]) => {\r\n    if (Array.isArray(value)) {\r\n      this.modelChange.emit(value);\r\n      this.sdChange.emit(value);\r\n      this.sdSelection.emit({\r\n        value: value,\r\n        items: value.map(val => this.#allItem[val?.toString()])\r\n      });\r\n    } else {\r\n      this.modelChange.emit(value);\r\n      this.sdChange.emit(value);\r\n      this.sdSelection.emit({\r\n        value: value,\r\n        item: this.#allItem[value?.toString()]\r\n      });\r\n    }\r\n  }\r\n\r\n  clear = ($event?: any) => {\r\n    $event?.stopPropagation();\r\n    if (this.multiple) {\r\n      this.formControl.setValue([]);\r\n      this.modelChange.emit([]);\r\n      this.sdChange.emit([]);\r\n      this.sdSelection.emit({\r\n        value: [],\r\n        items: []\r\n      });\r\n    } else {\r\n      this.formControl.setValue(null);\r\n      this.modelChange.emit(null);\r\n      this.sdChange.emit(null);\r\n      this.sdSelection.emit({\r\n        value: null,\r\n        item: null\r\n      });\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.select?.focus();\r\n      this.select?.open();\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  onOpenChange = (isOpened: boolean) => {\r\n    if (isOpened) {\r\n      this.isFocused = true;\r\n      if (this.#input) {\r\n        this.#input.value = null;\r\n      }\r\n      this.searchTerm$.next('');\r\n    } else {\r\n      this.isFocused = false;\r\n    }\r\n  }\r\n\r\n  onOptionChange = (tooltip: MatTooltip) => {\r\n    tooltip?.hide();\r\n  }\r\n\r\n  trackByKey = (index, item) => {\r\n    if (this.valueField) {\r\n      return item?.[this.valueField];\r\n    }\r\n    return item;\r\n  }\r\n}\r\n\r\ntype SearchFunc = (searchText?: string | string[], isFormValue?: boolean) => Promise<any[]>;"]}
@@ -3,15 +3,15 @@ import { CommonModule } from '@angular/common';
3
3
  import { MatIconModule } from '@angular/material/icon';
4
4
  import { MatTooltipModule } from '@angular/material/tooltip';
5
5
  import { MatProgressSpinnerModule } from '@angular/material/progress-spinner';
6
- import { __classPrivateFieldGet, __classPrivateFieldSet } from 'tslib';
6
+ import { __awaiter, __classPrivateFieldGet, __classPrivateFieldSet } from 'tslib';
7
7
  import { ENTER, COMMA } from '@angular/cdk/keycodes';
8
- import { startWith, map } from 'rxjs/operators';
8
+ import { startWith, map, debounceTime, switchMap } from 'rxjs/operators';
9
9
  import { v4 } from 'uuid';
10
10
  import { FormControl, Validators, NgForm, FormsModule, ReactiveFormsModule } from '@angular/forms';
11
- import { Subject, Subscription } from 'rxjs';
11
+ import { Subject, BehaviorSubject, Subscription, combineLatest } from 'rxjs';
12
12
  import { SdUtilityService } from '@sd-angular/core/utility';
13
13
  import { MatAutocompleteTrigger, MatAutocompleteModule } from '@angular/material/autocomplete';
14
- import { SdViewDefDirective, SdCommonModule } from '@sd-angular/core/common';
14
+ import { SdFormControl, SdViewDefDirective, SdCommonModule } from '@sd-angular/core/common';
15
15
  import { MatInputModule } from '@angular/material/input';
16
16
  import { MatFormFieldModule } from '@angular/material/form-field';
17
17
  import { SdTranslateModule } from '@sd-angular/core/translate';
@@ -31,7 +31,7 @@ SdChipDisplayDef.ctorParameters = () => [
31
31
  { type: TemplateRef }
32
32
  ];
33
33
 
34
- var _name, _form, _itemChanges, _items, _subscription, _updateValidator;
34
+ var _name, _form, _itemChanges, _items, _allItems, _allItem, _cache, _delay, _itemsChanges, _subscription, _updateValidator, _loadItems, _loadSelectedItems;
35
35
  class SdChipErrotStateMatcher {
36
36
  constructor(formControl) {
37
37
  this.formControl = formControl;
@@ -53,8 +53,25 @@ class SdChip {
53
53
  this.removable = true;
54
54
  _itemChanges.set(this, new Subject());
55
55
  _items.set(this, []);
56
+ // @Input() set items(items: undefined | any[]) {
57
+ // if (!items) {
58
+ // this.#items = [];
59
+ // } else if (Array.isArray(items)) {
60
+ // this.#items = items.filter(e => (e ?? '').toString().trim() !== '');
61
+ // } else {
62
+ // this.#items = items;
63
+ // }
64
+ // this.inputControl.updateValueAndValidity();
65
+ // this.#itemChanges.next(this.items);
66
+ // }
67
+ // Server search
68
+ this.loading = false;
69
+ _allItems.set(this, void 0);
70
+ _allItem.set(this, {});
71
+ _cache.set(this, {});
72
+ _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
73
+ _itemsChanges.set(this, new BehaviorSubject([]));
56
74
  this.limit = 50;
57
- this.selectedItems = [];
58
75
  // Validator
59
76
  this.isRequired = false;
60
77
  this.modelChange = new EventEmitter();
@@ -63,7 +80,7 @@ class SdChip {
63
80
  this.chipSelected = new EventEmitter();
64
81
  this.isFocused = false;
65
82
  this.inputControl = new FormControl();
66
- this.formControl = new FormControl();
83
+ this.formControl = new SdFormControl();
67
84
  this.matcher = new SdChipErrotStateMatcher(this.formControl);
68
85
  _subscription.set(this, new Subscription());
69
86
  _updateValidator.set(this, () => {
@@ -84,6 +101,39 @@ class SdChip {
84
101
  this.formControl.setAsyncValidators(asyncValidators);
85
102
  this.formControl.updateValueAndValidity();
86
103
  });
104
+ _loadItems.set(this, (searchText, items) => __awaiter(this, void 0, void 0, function* () {
105
+ searchText = (searchText === null || searchText === void 0 ? void 0 : searchText.toString()) || '';
106
+ if (__classPrivateFieldGet(this, _cache)[searchText] === undefined) {
107
+ this.loading = true;
108
+ const results = yield items(searchText).catch(() => []).finally(() => this.loading = false);
109
+ const objItem = Array.toObject(results, this.valueField);
110
+ __classPrivateFieldSet(this, _allItem, Object.assign(Object.assign({}, __classPrivateFieldGet(this, _allItem)), objItem));
111
+ __classPrivateFieldGet(this, _cache)[searchText] = results.union(this.valueField);
112
+ }
113
+ // if (!this.multiple) {
114
+ // return this.#cache[searchText];
115
+ // }
116
+ const selectedItems = yield __classPrivateFieldGet(this, _loadSelectedItems).call(this, this.formControl.value, items);
117
+ // Đưa những selectedItems lên đầu nếu không mat-select-trigger sẽ không work
118
+ return [...selectedItems, ...__classPrivateFieldGet(this, _cache)[searchText]].union(this.valueField);
119
+ }));
120
+ _loadSelectedItems.set(this, (value, items) => __awaiter(this, void 0, void 0, function* () {
121
+ if (!(value === null || value === void 0 ? void 0 : value.toString())) {
122
+ return [];
123
+ }
124
+ const values = Array.isArray(value) ? value : [value];
125
+ if (!this.valueField && !this.displayField) {
126
+ return values;
127
+ }
128
+ this.loading = true;
129
+ if (values.some(val => __classPrivateFieldGet(this, _allItem)[val] === undefined)) {
130
+ const results = yield items(value, true).catch(() => []).finally(() => this.loading = false);
131
+ const objItem = Array.toObject(results, this.valueField);
132
+ const objValue = Array.toObject(values.map(val => ({ [val === null || val === void 0 ? void 0 : val.toString()]: { [this.valueField]: val, [this.displayField]: val } })), this.valueField);
133
+ __classPrivateFieldSet(this, _allItem, Object.assign(Object.assign(Object.assign({}, objValue), __classPrivateFieldGet(this, _allItem)), objItem));
134
+ }
135
+ 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 }; });
136
+ }));
87
137
  this.filter = (value) => {
88
138
  return __classPrivateFieldGet(this, _items).filter(item => {
89
139
  var _a;
@@ -233,26 +283,25 @@ class SdChip {
233
283
  this.removable = (val === '') || val;
234
284
  }
235
285
  set items(items) {
286
+ __classPrivateFieldSet(this, _delay, 0);
236
287
  if (!items) {
237
- __classPrivateFieldSet(this, _items, []);
288
+ __classPrivateFieldGet(this, _itemsChanges).next([]);
238
289
  }
239
290
  else if (Array.isArray(items)) {
240
- __classPrivateFieldSet(this, _items, items.filter(e => (e !== null && e !== void 0 ? e : '').toString().trim() !== ''));
291
+ __classPrivateFieldGet(this, _itemsChanges).next(items.filter(e => e !== null && e !== undefined));
241
292
  }
242
293
  else {
243
- __classPrivateFieldSet(this, _items, items);
294
+ __classPrivateFieldSet(this, _delay, 500);
295
+ __classPrivateFieldGet(this, _itemsChanges).next(items);
244
296
  }
245
- this.inputControl.updateValueAndValidity();
246
- __classPrivateFieldGet(this, _itemChanges).next(this.items);
297
+ this.formControl.updateValueAndValidity();
247
298
  }
248
299
  // model
249
300
  set model(values) {
250
301
  if (!Array.isArray(values)) {
251
302
  values = [];
252
303
  }
253
- this.formControl.setValue(values, {
254
- emitEvent: false
255
- });
304
+ this.formControl.setValue(values);
256
305
  }
257
306
  set required(val) {
258
307
  this.isRequired = (val === '') || val;
@@ -283,24 +332,98 @@ class SdChip {
283
332
  }
284
333
  ngAfterViewInit() {
285
334
  var _a;
286
- __classPrivateFieldGet(this, _subscription).add(this.formControl.valueChanges.subscribe(() => {
287
- const values = this.formControl.value || [];
288
- this.selectedItems = __classPrivateFieldGet(this, _items).filter(item => values.findIndex(value => value === (item === null || item === void 0 ? void 0 : item[this.valueField])) !== -1);
289
- this.modelChange.emit(values);
290
- this.sdChange.emit(values);
291
- setTimeout(() => {
292
- var _a;
293
- (_a = __classPrivateFieldGet(this, _form)) === null || _a === void 0 ? void 0 : _a.markAsDirty();
294
- }, 0);
335
+ __classPrivateFieldGet(this, _subscription).add(this.formControl.sdChanges.subscribe(() => {
336
+ this.ref.markForCheck();
295
337
  }));
296
- __classPrivateFieldGet(this, _subscription).add(__classPrivateFieldGet(this, _itemChanges).pipe(startWith(__classPrivateFieldGet(this, _items))).subscribe(() => {
297
- const values = this.formControl.value || [];
298
- this.selectedItems = [];
299
- for (const value of values) {
300
- const item = __classPrivateFieldGet(this, _items).find(e => (e === null || e === void 0 ? void 0 : e[this.valueField]) === value) || {};
301
- this.selectedItems.push(Object.assign(Object.assign({}, item), { [this.valueField]: value }));
338
+ __classPrivateFieldSet(this, _allItems, combineLatest([
339
+ __classPrivateFieldGet(this, _itemsChanges).asObservable(),
340
+ this.inputControl.valueChanges.pipe(startWith(''), debounceTime(__classPrivateFieldGet(this, _delay))),
341
+ this.formControl.valueChanges.pipe(startWith(this.formControl.value))
342
+ ]).pipe(switchMap(([items, val, formValue]) => __awaiter(this, void 0, void 0, function* () {
343
+ if (typeof (items) === 'function') {
344
+ return yield __classPrivateFieldGet(this, _loadItems).call(this, val, items);
302
345
  }
303
- }));
346
+ __classPrivateFieldSet(this, _allItem, items.toObject(this.valueField));
347
+ const isArray = Array.isArray(formValue);
348
+ const hasFields = !!this.valueField && !!this.displayField;
349
+ const filteredItems = items.filter(item => {
350
+ const value = hasFields ? item[this.valueField] : item;
351
+ const display = hasFields ? item[this.displayField] : item;
352
+ if (String.aliasIncludes(value, val) || String.aliasIncludes(display, val)) {
353
+ return true;
354
+ }
355
+ if (isArray) {
356
+ return formValue.some(e => e === value);
357
+ }
358
+ return formValue === value;
359
+ });
360
+ if (items.length <= this.limit) {
361
+ return filteredItems;
362
+ }
363
+ // Đưa những selectedItems lên đầu nếu không mat-select-trigger sẽ không work
364
+ return filteredItems.sort((current, next) => {
365
+ const value1 = hasFields ? current[this.valueField] : current;
366
+ const value2 = hasFields ? next[this.valueField] : next;
367
+ let flag1 = 0;
368
+ let flag2 = 0;
369
+ if (isArray) {
370
+ flag1 = formValue.some(e => e === value1) ? 1 : 0;
371
+ flag2 = formValue.some(e => e === value2) ? 1 : 0;
372
+ return flag2 - flag1;
373
+ }
374
+ flag1 = formValue === value1 ? 1 : 0;
375
+ flag2 = formValue === value2 ? 1 : 0;
376
+ return flag2 - flag1;
377
+ });
378
+ }))));
379
+ this.selectedItems = combineLatest([
380
+ __classPrivateFieldGet(this, _itemsChanges).asObservable(),
381
+ this.formControl.valueChanges.pipe(startWith(this.formControl.value))
382
+ ])
383
+ .pipe(switchMap(([items, val]) => __awaiter(this, void 0, void 0, function* () {
384
+ // 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
385
+ // Nhưng formControl.value vẫn có giá trị đúng nên thực hiện gán val = this.formControl.value;
386
+ val = this.formControl.value;
387
+ if (!(val === null || val === void 0 ? void 0 : val.toString())) {
388
+ return [];
389
+ }
390
+ const values = Array.isArray(val) ? val : [val];
391
+ if (!this.valueField) {
392
+ return values;
393
+ }
394
+ if (typeof (items) === 'function') {
395
+ return yield __classPrivateFieldGet(this, _loadSelectedItems).call(this, val, items);
396
+ }
397
+ return values.map(value => {
398
+ return (items === null || items === void 0 ? void 0 : items.find(item => item[this.valueField] === value)) || {
399
+ [this.valueField]: value,
400
+ [this.displayField]: value
401
+ };
402
+ });
403
+ })));
404
+ this.filteredItems = __classPrivateFieldGet(this, _allItems).pipe(map(allItems => allItems.paging(this.limit)));
405
+ // this.display = this.selectedItems.pipe(
406
+ // map(selectedItems => selectedItems?.map(item => this.displayField ? item[this.displayField] : item)?.join(', ')));
407
+ // this.#subscription.add(this.formControl.valueChanges.subscribe(() => {
408
+ // const values: (string | number)[] = this.formControl.value || [];
409
+ // this.selectedItems = this.#items.filter(item => values.findIndex(value => value === item?.[this.valueField]) !== -1);
410
+ // this.modelChange.emit(values);
411
+ // this.sdChange.emit(values);
412
+ // setTimeout(() => {
413
+ // this.#form?.markAsDirty();
414
+ // }, 0);
415
+ // }));
416
+ // this.#subscription.add(this.#itemChanges.pipe(startWith(this.#items)).subscribe(() => {
417
+ // const values: (string | number)[] = this.formControl.value || [];
418
+ // this.selectedItems = [];
419
+ // for (const value of values) {
420
+ // const item = this.#items.find(e => e?.[this.valueField] === value) || {};
421
+ // this.selectedItems.push({
422
+ // ...item,
423
+ // [this.valueField]: value
424
+ // });
425
+ // }
426
+ // }));
304
427
  (_a = __classPrivateFieldGet(this, _form)) === null || _a === void 0 ? void 0 : _a.addControl(__classPrivateFieldGet(this, _name), this.formControl);
305
428
  }
306
429
  ngOnDestroy() {
@@ -309,7 +432,7 @@ class SdChip {
309
432
  __classPrivateFieldGet(this, _subscription).unsubscribe();
310
433
  }
311
434
  }
312
- _name = new WeakMap(), _form = new WeakMap(), _itemChanges = new WeakMap(), _items = new WeakMap(), _subscription = new WeakMap(), _updateValidator = new WeakMap();
435
+ _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();
313
436
  SdChip.decorators = [
314
437
  { type: Component, args: [{
315
438
  selector: 'sd-chip',