valtech-components 2.0.381 → 2.0.382

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.
@@ -120,14 +120,22 @@ export class MultiSelectSearchComponent {
120
120
  return;
121
121
  }
122
122
  const controlValue = this.props.control.value;
123
- if (!Array.isArray(controlValue) || controlValue.length === 0) {
123
+ if (!controlValue || controlValue === '') {
124
124
  this.selectedItems = [];
125
125
  return;
126
126
  }
127
+ // Handle both array and string formats
128
+ let valueArray = [];
129
+ if (Array.isArray(controlValue)) {
130
+ valueArray = controlValue;
131
+ }
132
+ else if (typeof controlValue === 'string') {
133
+ valueArray = controlValue.split(',').filter(v => v.trim() !== '');
134
+ }
127
135
  if (this.props.options && this.props.options.length > 0) {
128
136
  const map = new Map(this.props.options.map(opt => [opt[this.valueProperty], opt]));
129
- this.selectedItems = controlValue
130
- .map(value => map.get(value))
137
+ this.selectedItems = valueArray
138
+ .map(value => map.get(value.toString().trim()))
131
139
  .filter(item => item !== undefined);
132
140
  }
133
141
  else {
@@ -189,15 +197,12 @@ export class MultiSelectSearchComponent {
189
197
  }
190
198
  }
191
199
  selectItem(item) {
192
- console.log('selectItem called with:', item);
193
200
  const index = this.tempSelectedItems.findIndex(selectedItem => selectedItem[this.valueProperty] === item[this.valueProperty]);
194
201
  if (index === -1) {
195
202
  this.tempSelectedItems.push(item);
196
- console.log('Item added, tempSelectedItems:', this.tempSelectedItems);
197
203
  }
198
204
  else {
199
205
  this.tempSelectedItems.splice(index, 1);
200
- console.log('Item removed, tempSelectedItems:', this.tempSelectedItems);
201
206
  }
202
207
  }
203
208
  isItemSelected(item) {
@@ -207,10 +212,8 @@ export class MultiSelectSearchComponent {
207
212
  this.tempSelectedItems = [];
208
213
  }
209
214
  applySelection() {
210
- console.log('applySelection called, tempSelectedItems:', this.tempSelectedItems);
211
215
  this.selectedItems = [...this.tempSelectedItems];
212
216
  this.updateDisplayValue();
213
- console.log('About to call applyChanges with selectedItems:', this.selectedItems);
214
217
  this.applyChanges();
215
218
  this.cancelModal();
216
219
  }
@@ -227,19 +230,25 @@ export class MultiSelectSearchComponent {
227
230
  }
228
231
  }
229
232
  applyChanges() {
230
- console.log('applyChanges called, props.control exists:', !!this.props?.control);
231
233
  if (!this.props?.control) {
232
- console.log('No control found, exiting applyChanges');
233
234
  return;
234
235
  }
235
236
  try {
236
237
  this.isProcessingChanges = true;
237
238
  const values = this.selectedItems.map(item => item[this.valueProperty]);
238
- console.log('Setting control value to:', values);
239
- this.props.control.setValue(values);
239
+ const stringValue = values.join(',');
240
+ this.props.control.setValue(stringValue);
240
241
  this.props.control.markAsDirty();
242
+ this.props.control.markAsTouched();
241
243
  this.props.control.updateValueAndValidity();
242
- console.log('Control value after setValue:', this.props.control.value);
244
+ // Debug validators if still having issues
245
+ if (this.props.control.invalid) {
246
+ console.warn('Control is invalid after setValue:', {
247
+ value: this.props.control.value,
248
+ errors: this.props.control.errors,
249
+ validators: this.props.control.validator
250
+ });
251
+ }
243
252
  }
244
253
  finally {
245
254
  this.isProcessingChanges = false;
@@ -249,7 +258,7 @@ export class MultiSelectSearchComponent {
249
258
  this.selectedItems = [];
250
259
  this.displayValue = '';
251
260
  if (this.props?.control) {
252
- this.props.control.setValue([]);
261
+ this.props.control.setValue('');
253
262
  }
254
263
  this.changeDetector.detectChanges();
255
264
  }
@@ -393,4 +402,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
393
402
  }], props: [{
394
403
  type: Input
395
404
  }] } });
396
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-select-search.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/src/lib/components/molecules/multi-select-search/multi-select-search.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EACL,iBAAiB,EACjB,SAAS,EACT,MAAM,EACN,KAAK,EAIL,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,WAAW,EAAE,mBAAmB,EAAE,MAAM,gBAAgB,CAAC;AAClE,OAAO,EAAE,WAAW,EAAY,MAAM,gBAAgB,CAAC;AAEvD,OAAO,EAAE,WAAW,EAAE,MAAM,iCAAiC,CAAC;AAC9D,OAAO,EAAE,WAAW,EAAE,MAAM,uDAAuD,CAAC;AACpF,OAAO,EAAE,0BAA0B,EAAE,MAAM,qCAAqC,CAAC;AACjF,OAAO,EAAE,mBAAmB,EAAE,MAAM,4BAA4B,CAAC;AAEjE,OAAO,EAAE,kBAAkB,EAAE,MAAM,kCAAkC,CAAC;;;;;AA2EtE,MAAM,OAAO,0BAA0B;IAuBrC;QAnBS,kBAAa,GAAW,MAAM,CAAC;QAC/B,kBAAa,GAAW,IAAI,CAAC;QAI9B,gBAAW,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;QAC1C,SAAI,GAAG,MAAM,CAAC,WAAW,CAAC,CAAC;QACnB,mBAAc,GAAG,MAAM,CAAC,iBAAiB,CAAC,CAAC;QAEnD,eAAU,GAAW,EAAE,CAAC;QACxB,kBAAa,GAAkB,EAAE,CAAC;QAClC,kBAAa,GAAkB,EAAE,CAAC;QAClC,sBAAiB,GAAkB,EAAE,CAAC;QACtC,iBAAY,GAAW,EAAE,CAAC;QAElB,oBAAe,GAAU,EAAE,CAAC;QAC5B,wBAAmB,GAAG,KAAK,CAAC;QAIlC,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,SAAS,EAAE,gBAAgB,EAAE,uBAAuB,CAAC,CAAC;QAC5F,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,SAAS,EAAE,eAAe,EAAE,qBAAqB,CAAC,CAAC;IACjG,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,iBAAiB,EAAE,CAAC;QACzB,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,CAAC,iCAAiC,EAAE,CAAC;QACzC,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,CAAC,uBAAuB,EAAE,CAAC;IACjC,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,wBAAwB,EAAE,CAAC;YAClC,IAAI,CAAC,wBAAwB,CAAC,WAAW,EAAE,CAAC;QAC9C,CAAC;IACH,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC7B,OAAO;QACT,CAAC;QAED,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC;YACrB,IAAI,CAAC;gBACH,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;gBAEhC,IAAI,IAAI,CAAC,wBAAwB,EAAE,CAAC;oBAClC,IAAI,CAAC,wBAAwB,CAAC,WAAW,EAAE,CAAC;gBAC9C,CAAC;gBAED,IAAI,IAAI,CAAC,KAAK,EAAE,OAAO,EAAE,CAAC;oBACxB,MAAM,cAAc,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;oBAEvF,IAAI,cAAc,EAAE,CAAC;wBACnB,IAAI,CAAC,eAAe,GAAG,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC;wBAC/C,IAAI,CAAC,eAAe,EAAE,CAAC;oBACzB,CAAC;gBACH,CAAC;gBAED,IAAI,CAAC,iCAAiC,EAAE,CAAC;gBACzC,IAAI,CAAC,kBAAkB,EAAE,CAAC;gBAC1B,IAAI,CAAC,uBAAuB,EAAE,CAAC;YACjC,CAAC;oBAAS,CAAC;gBACT,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;YACnC,CAAC;QACH,CAAC;IACH,CAAC;IAED,gBAAgB;QACd,IAAI,IAAI,CAAC,mBAAmB,EAAE,CAAC;YAC7B,OAAO;QACT,CAAC;QAED,IAAI,CAAC;YACH,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;YAChC,IAAI,CAAC,eAAe,EAAE,CAAC;YACvB,IAAI,CAAC,iCAAiC,EAAE,CAAC;YACzC,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC1B,IAAI,CAAC,uBAAuB,EAAE,CAAC;QACjC,CAAC;gBAAS,CAAC;YACT,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;QACnC,CAAC;IACH,CAAC;IAEO,uBAAuB;QAC7B,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO;YAAE,OAAO;QAEjC,IAAI,CAAC,wBAAwB,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,YAAY,CAAC,SAAS,CAAC,GAAG,EAAE;YAC7E,IAAI,IAAI,CAAC,mBAAmB;gBAAE,OAAO;YAErC,IAAI,CAAC;gBACH,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;gBAChC,IAAI,CAAC,iCAAiC,EAAE,CAAC;gBACzC,IAAI,CAAC,kBAAkB,EAAE,CAAC;YAC5B,CAAC;oBAAS,CAAC;gBACT,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;YACnC,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAEO,eAAe,CAAC,WAAkB,EAAE,UAAiB;QAC3D,IAAI,WAAW,KAAK,UAAU;YAAE,OAAO,IAAI,CAAC;QAC5C,IAAI,CAAC,WAAW,IAAI,CAAC,UAAU;YAAE,OAAO,WAAW,KAAK,UAAU,CAAC;QACnE,IAAI,WAAW,CAAC,MAAM,KAAK,UAAU,CAAC,MAAM;YAAE,OAAO,KAAK,CAAC;QAE3D,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,WAAW,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YAC5C,IAAI,WAAW,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,UAAU,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE,CAAC;gBAC7E,OAAO,KAAK,CAAC;YACf,CAAC;QACH,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAEO,eAAe;QACrB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,KAAK,EAAE,OAAO,IAAI,EAAE,CAAC;IACjD,CAAC;IAEO,iCAAiC;QACvC,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,EAAE,CAAC;YACzB,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;YACxB,OAAO;QACT,CAAC;QAED,MAAM,YAAY,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC;QAC9C,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,YAAY,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC9D,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;YACxB,OAAO;QACT,CAAC;QAED,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;YACxD,MAAM,GAAG,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,aAAa,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;YACnF,IAAI,CAAC,aAAa,GAAG,YAAY;iBAC9B,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;iBAC5B,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,KAAK,SAAS,CAAC,CAAC;QACxC,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;QAC1B,CAAC;IACH,CAAC;IAEO,iBAAiB;QACvB,0BAA0B,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IACzC,CAAC;IAED,QAAQ,CAAC,KAAU;QACjB,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC;YAClC,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;YACxE,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;YACpC,OAAO;QACT,CAAC;QAED,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,IAAI,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YAC5D,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;YACxB,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;YACpC,OAAO;QACT,CAAC;QAED,MAAM,MAAM,GAAG,mBAAmB,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC,CAAC;QACxD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE;YACvD,MAAM,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC;gBACvC,CAAC,CAAC,mBAAmB,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;gBACxE,CAAC,CAAC,EAAE,CAAC;YACP,MAAM,KAAK,GAAG,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC;gBACvC,CAAC,CAAC,mBAAmB,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC;gBACxE,CAAC,CAAC,EAAE,CAAC;YACP,OAAO,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,KAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;QAC1D,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;IACtC,CAAC;IAED,OAAO;QACL,OAAO,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;IACzB,CAAC;IAED,MAAM;QACJ,OAAO,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAC;IACxB,CAAC;IAED,SAAS;QACP,IAAI,CAAC,iCAAiC,EAAE,CAAC;QACzC,IAAI,CAAC,iBAAiB,GAAG,CAAC,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC;QACjD,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YACf,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC;QACvB,CAAC;IACH,CAAC;IAED,sBAAsB,CAAC,KAAiB;QACtC,KAAK,CAAC,cAAc,EAAE,CAAC;QACvB,KAAK,CAAC,eAAe,EAAE,CAAC;QACxB,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;IAED,WAAW;QACT,uDAAuD;QACvD,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;QACrB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;QACxE,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;QACpC,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;YACf,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC;QACvB,CAAC;IACH,CAAC;IAED,UAAU,CAAC,IAAS;QAClB,OAAO,CAAC,GAAG,CAAC,yBAAyB,EAAE,IAAI,CAAC,CAAC;QAC7C,MAAM,KAAK,GAAG,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAC5C,YAAY,CAAC,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAC9E,CAAC;QAEF,IAAI,KAAK,KAAK,CAAC,CAAC,EAAE,CAAC;YACjB,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;YAClC,OAAO,CAAC,GAAG,CAAC,gCAAgC,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC;QACxE,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,iBAAiB,CAAC,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC;YACxC,OAAO,CAAC,GAAG,CAAC,kCAAkC,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC;QAC1E,CAAC;IACH,CAAC;IAED,cAAc,CAAC,IAAS;QACtB,OAAO,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAChC,YAAY,CAAC,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,aAAa,CAAC,KAAK,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAC9E,CAAC;IACJ,CAAC;IAED,cAAc;QACZ,IAAI,CAAC,iBAAiB,GAAG,EAAE,CAAC;IAC9B,CAAC;IAED,cAAc;QACZ,OAAO,CAAC,GAAG,CAAC,2CAA2C,EAAE,IAAI,CAAC,iBAAiB,CAAC,CAAC;QACjF,IAAI,CAAC,aAAa,GAAG,CAAC,GAAG,IAAI,CAAC,iBAAiB,CAAC,CAAC;QACjD,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,OAAO,CAAC,GAAG,CAAC,gDAAgD,EAAE,IAAI,CAAC,aAAa,CAAC,CAAC;QAClF,IAAI,CAAC,YAAY,EAAE,CAAC;QACpB,IAAI,CAAC,WAAW,EAAE,CAAC;IACrB,CAAC;IAED,kBAAkB;QAChB,IAAI,IAAI,CAAC,aAAa,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACpC,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;YACvB,OAAO;QACT,CAAC;QAED,IAAI,IAAI,CAAC,aAAa,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACpC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAChE,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,YAAY,GAAG,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,0BAA0B,CAAC;QAC7E,CAAC;IACH,CAAC;IAED,YAAY;QACV,OAAO,CAAC,GAAG,CAAC,4CAA4C,EAAE,CAAC,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;QACjF,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,EAAE,CAAC;YACzB,OAAO,CAAC,GAAG,CAAC,wCAAwC,CAAC,CAAC;YACtD,OAAO;QACT,CAAC;QAED,IAAI,CAAC;YACH,IAAI,CAAC,mBAAmB,GAAG,IAAI,CAAC;YAEhC,MAAM,MAAM,GAAG,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC;YACxE,OAAO,CAAC,GAAG,CAAC,2BAA2B,EAAE,MAAM,CAAC,CAAC;YACjD,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;YACpC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,WAAW,EAAE,CAAC;YACjC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,sBAAsB,EAAE,CAAC;YAC5C,OAAO,CAAC,GAAG,CAAC,+BAA+B,EAAE,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QACzE,CAAC;gBAAS,CAAC;YACT,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;QACnC,CAAC;IACH,CAAC;IAED,KAAK;QACH,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;QACxB,IAAI,CAAC,YAAY,GAAG,EAAE,CAAC;QACvB,IAAI,IAAI,CAAC,KAAK,EAAE,OAAO,EAAE,CAAC;YACxB,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QAClC,CAAC;QACD,IAAI,CAAC,cAAc,CAAC,aAAa,EAAE,CAAC;IACtC,CAAC;+GA1RU,0BAA0B;mGAA1B,0BAA0B,gVArE3B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4DT,wGA7DS,YAAY,+PAAE,WAAW,w8EAAE,WAAW,uIAAE,kBAAkB,oIAAE,mBAAmB;;4FAsE9E,0BAA0B;kBAzEtC,SAAS;+BACE,yBAAyB,cACvB,IAAI,WACP,CAAC,YAAY,EAAE,WAAW,EAAE,WAAW,EAAE,kBAAkB,EAAE,mBAAmB,CAAC,YAChF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA4DT;wDAUmB,KAAK;sBAAxB,SAAS;uBAAC,OAAO;gBAET,KAAK;sBAAb,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,KAAK;sBAAb,KAAK","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectorRef,\n  Component,\n  inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { IonicModule, IonModal } from '@ionic/angular';\nimport { Subscription } from 'rxjs';\nimport { IconService } from '../../../services/icons.service';\nimport { LangService } from '../../../services/lang-provider/lang-provider.service';\nimport { applyDefaultValueToControl } from '../../../shared/utils/form-defaults';\nimport { replaceSpecialChars } from '../../../shared/utils/text';\nimport { InputMetadata, InputOption } from '../../types';\nimport { SearchbarComponent } from '../searchbar/searchbar.component';\n\n@Component({\n  selector: 'val-multi-select-search',\n  standalone: true,\n  imports: [CommonModule, IonicModule, FormsModule, SearchbarComponent, ReactiveFormsModule],\n  template: `\n    <ion-input\n      type=\"text\"\n      [value]=\"displayValue\"\n      [placeholder]=\"props?.placeholder || placeholder\"\n      readonly\n      (mousedown)=\"preventDefaultBehavior($event)\"\n    />\n\n    <ion-input style=\"position: absolute;\" [formControl]=\"props.control\" type=\"hidden\"></ion-input>\n\n    <ion-modal\n      #modal\n      [initialBreakpoint]=\"1\"\n      [breakpoints]=\"[0, 0.5, 0.75, 1]\"\n      (didDismiss)=\"cancelModal()\"\n    >\n      <ng-template>\n        <ion-header>\n          <ion-toolbar>\n            <ion-title>{{ label }}</ion-title>\n            <ion-buttons slot=\"end\">\n              <ion-button (click)=\"cancelModal()\">Cerrar</ion-button>\n            </ion-buttons>\n          </ion-toolbar>\n          <ion-toolbar>\n            <val-searchbar (filterEvent)=\"onFilter($event)\" (focusEvent)=\"onFocus()\" (blurEvent)=\"onBlur()\" />\n          </ion-toolbar>\n        </ion-header>\n        <ion-content>\n          <ion-item *ngIf=\"tempSelectedItems.length > 0\" lines=\"none\" color=\"light\">\n            <ion-icon name=\"checkmark-circle-outline\" slot=\"start\" color=\"success\"></ion-icon>\n            <ion-label>\n              <h3>{{ tempSelectedItems.length }} item{{ tempSelectedItems.length === 1 ? '' : 's' }} seleccionado{{ tempSelectedItems.length === 1 ? '' : 's' }}</h3>\n            </ion-label>\n          </ion-item>\n          <ion-list>\n            <ion-item *ngFor=\"let item of filteredItems\" button (click)=\"selectItem(item)\" detail=\"false\">\n              <ion-checkbox \n                [checked]=\"isItemSelected(item)\" \n                slot=\"start\"\n                [disabled]=\"true\"\n              ></ion-checkbox>\n              <ion-label>{{ item[labelProperty] }}</ion-label>\n            </ion-item>\n            <ion-item *ngIf=\"filteredItems.length === 0\" lines=\"none\">\n              <ion-label color=\"dark\">No se encontraron resultados</ion-label>\n            </ion-item>\n          </ion-list>\n        </ion-content>\n        <ion-footer *ngIf=\"tempSelectedItems.length > 0\">\n          <ion-toolbar>\n            <ion-buttons slot=\"end\">\n              <ion-button (click)=\"clearSelection()\">Limpiar</ion-button>\n              <ion-button fill=\"solid\" (click)=\"applySelection()\">Aplicar ({{ tempSelectedItems.length }})</ion-button>\n            </ion-buttons>\n          </ion-toolbar>\n        </ion-footer>\n      </ng-template>\n    </ion-modal>\n  `,\n  styles: [\n    `\n      ion-header {\n        padding: 8px 8px 0px 8px;\n      }\n    `,\n  ],\n})\nexport class MultiSelectSearchComponent implements OnChanges, OnDestroy {\n  @ViewChild('modal') modal!: IonModal;\n\n  @Input() label: string;\n  @Input() labelProperty: string = 'name';\n  @Input() valueProperty: string = 'id';\n  @Input() placeholder: string;\n  @Input() props: InputMetadata;\n\n  private langService = inject(LangService);\n  icon = inject(IconService);\n  private changeDetector = inject(ChangeDetectorRef);\n\n  searchTerm: string = '';\n  filteredItems: InputOption[] = [];\n  selectedItems: InputOption[] = [];\n  tempSelectedItems: InputOption[] = [];\n  displayValue: string = '';\n\n  private previousOptions: any[] = [];\n  private isProcessingChanges = false;\n  private valueChangesSubscription?: Subscription;\n\n  constructor() {\n    this.label = this.langService.getText('_global', 'selectMultiple', 'Seleccionar múltiples');\n    this.placeholder = this.langService.getText('_global', 'selectOptions', 'Seleccione opciones');\n  }\n\n  ngOnInit() {\n    this.applyDefaultValue();\n    this.initializeItems();\n    this.syncControlValueWithSelectedItems();\n    this.updateDisplayValue();\n    this.subscribeToValueChanges();\n  }\n\n  ngOnDestroy() {\n    if (this.valueChangesSubscription) {\n      this.valueChangesSubscription.unsubscribe();\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.isProcessingChanges) {\n      return;\n    }\n\n    if (changes['props']) {\n      try {\n        this.isProcessingChanges = true;\n\n        if (this.valueChangesSubscription) {\n          this.valueChangesSubscription.unsubscribe();\n        }\n\n        if (this.props?.options) {\n          const optionsChanged = !this.areOptionsEqual(this.previousOptions, this.props.options);\n\n          if (optionsChanged) {\n            this.previousOptions = [...this.props.options];\n            this.initializeItems();\n          }\n        }\n\n        this.syncControlValueWithSelectedItems();\n        this.updateDisplayValue();\n        this.subscribeToValueChanges();\n      } finally {\n        this.isProcessingChanges = false;\n      }\n    }\n  }\n\n  ionViewWillEnter(): void {\n    if (this.isProcessingChanges) {\n      return;\n    }\n\n    try {\n      this.isProcessingChanges = true;\n      this.initializeItems();\n      this.syncControlValueWithSelectedItems();\n      this.updateDisplayValue();\n      this.subscribeToValueChanges();\n    } finally {\n      this.isProcessingChanges = false;\n    }\n  }\n\n  private subscribeToValueChanges() {\n    if (!this.props?.control) return;\n\n    this.valueChangesSubscription = this.props.control.valueChanges.subscribe(() => {\n      if (this.isProcessingChanges) return;\n\n      try {\n        this.isProcessingChanges = true;\n        this.syncControlValueWithSelectedItems();\n        this.updateDisplayValue();\n      } finally {\n        this.isProcessingChanges = false;\n      }\n    });\n  }\n\n  private areOptionsEqual(prevOptions: any[], newOptions: any[]): boolean {\n    if (prevOptions === newOptions) return true;\n    if (!prevOptions || !newOptions) return prevOptions === newOptions;\n    if (prevOptions.length !== newOptions.length) return false;\n    \n    for (let i = 0; i < prevOptions.length; i++) {\n      if (prevOptions[i][this.valueProperty] !== newOptions[i][this.valueProperty]) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  private initializeItems(): void {\n    this.filteredItems = this.props?.options || [];\n  }\n\n  private syncControlValueWithSelectedItems(): void {\n    if (!this.props?.control) {\n      this.selectedItems = [];\n      return;\n    }\n\n    const controlValue = this.props.control.value;\n    if (!Array.isArray(controlValue) || controlValue.length === 0) {\n      this.selectedItems = [];\n      return;\n    }\n\n    if (this.props.options && this.props.options.length > 0) {\n      const map = new Map(this.props.options.map(opt => [opt[this.valueProperty], opt]));\n      this.selectedItems = controlValue\n        .map(value => map.get(value))\n        .filter(item => item !== undefined);\n    } else {\n      this.selectedItems = [];\n    }\n  }\n\n  private applyDefaultValue(): void {\n    applyDefaultValueToControl(this.props);\n  }\n\n  onFilter(event: any) {\n    if (!event || event.trim() === '') {\n      this.filteredItems = this.props?.options ? [...this.props.options] : [];\n      this.changeDetector.detectChanges();\n      return;\n    }\n\n    if (!this.props?.options || this.props.options.length === 0) {\n      this.filteredItems = [];\n      this.changeDetector.detectChanges();\n      return;\n    }\n\n    const search = replaceSpecialChars(event.toLowerCase());\n    this.filteredItems = this.props.options.filter(element => {\n      const label = element[this.labelProperty]\n        ? replaceSpecialChars(String(element[this.labelProperty]).toLowerCase())\n        : '';\n      const value = element[this.valueProperty]\n        ? replaceSpecialChars(String(element[this.valueProperty]).toLowerCase())\n        : '';\n      return label.includes(search) || value.includes(search);\n    });\n    this.changeDetector.detectChanges();\n  }\n\n  onFocus() {\n    console.log('onFocus');\n  }\n\n  onBlur() {\n    console.log('onBlur');\n  }\n\n  openModal() {\n    this.syncControlValueWithSelectedItems();\n    this.tempSelectedItems = [...this.selectedItems];\n    this.updateDisplayValue();\n    if (this.modal) {\n      this.modal.present();\n    }\n  }\n\n  preventDefaultBehavior(event: MouseEvent) {\n    event.preventDefault();\n    event.stopPropagation();\n    this.openModal();\n  }\n\n  cancelModal() {\n    // Reset filter and show all options when closing modal\n    this.searchTerm = '';\n    this.filteredItems = this.props?.options ? [...this.props.options] : [];\n    this.changeDetector.detectChanges();\n    if (this.modal) {\n      this.modal.dismiss();\n    }\n  }\n\n  selectItem(item: any) {\n    console.log('selectItem called with:', item);\n    const index = this.tempSelectedItems.findIndex(\n      selectedItem => selectedItem[this.valueProperty] === item[this.valueProperty]\n    );\n\n    if (index === -1) {\n      this.tempSelectedItems.push(item);\n      console.log('Item added, tempSelectedItems:', this.tempSelectedItems);\n    } else {\n      this.tempSelectedItems.splice(index, 1);\n      console.log('Item removed, tempSelectedItems:', this.tempSelectedItems);\n    }\n  }\n\n  isItemSelected(item: any): boolean {\n    return this.tempSelectedItems.some(\n      selectedItem => selectedItem[this.valueProperty] === item[this.valueProperty]\n    );\n  }\n\n  clearSelection() {\n    this.tempSelectedItems = [];\n  }\n\n  applySelection() {\n    console.log('applySelection called, tempSelectedItems:', this.tempSelectedItems);\n    this.selectedItems = [...this.tempSelectedItems];\n    this.updateDisplayValue();\n    console.log('About to call applyChanges with selectedItems:', this.selectedItems);\n    this.applyChanges();\n    this.cancelModal();\n  }\n\n  updateDisplayValue() {\n    if (this.selectedItems.length === 0) {\n      this.displayValue = '';\n      return;\n    }\n\n    if (this.selectedItems.length === 1) {\n      this.displayValue = this.selectedItems[0][this.labelProperty];\n    } else {\n      this.displayValue = `${this.selectedItems.length} elementos seleccionados`;\n    }\n  }\n\n  applyChanges() {\n    console.log('applyChanges called, props.control exists:', !!this.props?.control);\n    if (!this.props?.control) {\n      console.log('No control found, exiting applyChanges');\n      return;\n    }\n\n    try {\n      this.isProcessingChanges = true;\n\n      const values = this.selectedItems.map(item => item[this.valueProperty]);\n      console.log('Setting control value to:', values);\n      this.props.control.setValue(values);\n      this.props.control.markAsDirty();\n      this.props.control.updateValueAndValidity();\n      console.log('Control value after setValue:', this.props.control.value);\n    } finally {\n      this.isProcessingChanges = false;\n    }\n  }\n\n  reset() {\n    this.selectedItems = [];\n    this.displayValue = '';\n    if (this.props?.control) {\n      this.props.control.setValue([]);\n    }\n    this.changeDetector.detectChanges();\n  }\n}"]}
405
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"multi-select-search.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/src/lib/components/molecules/multi-select-search/multi-select-search.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectorRef,\n  Component,\n  inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  SimpleChanges,\n  ViewChild,\n} from '@angular/core';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { IonicModule, IonModal } from '@ionic/angular';\nimport { Subscription } from 'rxjs';\nimport { IconService } from '../../../services/icons.service';\nimport { LangService } from '../../../services/lang-provider/lang-provider.service';\nimport { applyDefaultValueToControl } from '../../../shared/utils/form-defaults';\nimport { replaceSpecialChars } from '../../../shared/utils/text';\nimport { InputMetadata, InputOption } from '../../types';\nimport { SearchbarComponent } from '../searchbar/searchbar.component';\n\n@Component({\n  selector: 'val-multi-select-search',\n  standalone: true,\n  imports: [CommonModule, IonicModule, FormsModule, SearchbarComponent, ReactiveFormsModule],\n  template: `\n    <ion-input\n      type=\"text\"\n      [value]=\"displayValue\"\n      [placeholder]=\"props?.placeholder || placeholder\"\n      readonly\n      (mousedown)=\"preventDefaultBehavior($event)\"\n    />\n\n    <ion-input style=\"position: absolute;\" [formControl]=\"props.control\" type=\"hidden\"></ion-input>\n\n    <ion-modal\n      #modal\n      [initialBreakpoint]=\"1\"\n      [breakpoints]=\"[0, 0.5, 0.75, 1]\"\n      (didDismiss)=\"cancelModal()\"\n    >\n      <ng-template>\n        <ion-header>\n          <ion-toolbar>\n            <ion-title>{{ label }}</ion-title>\n            <ion-buttons slot=\"end\">\n              <ion-button (click)=\"cancelModal()\">Cerrar</ion-button>\n            </ion-buttons>\n          </ion-toolbar>\n          <ion-toolbar>\n            <val-searchbar (filterEvent)=\"onFilter($event)\" (focusEvent)=\"onFocus()\" (blurEvent)=\"onBlur()\" />\n          </ion-toolbar>\n        </ion-header>\n        <ion-content>\n          <ion-item *ngIf=\"tempSelectedItems.length > 0\" lines=\"none\" color=\"light\">\n            <ion-icon name=\"checkmark-circle-outline\" slot=\"start\" color=\"success\"></ion-icon>\n            <ion-label>\n              <h3>{{ tempSelectedItems.length }} item{{ tempSelectedItems.length === 1 ? '' : 's' }} seleccionado{{ tempSelectedItems.length === 1 ? '' : 's' }}</h3>\n            </ion-label>\n          </ion-item>\n          <ion-list>\n            <ion-item *ngFor=\"let item of filteredItems\" button (click)=\"selectItem(item)\" detail=\"false\">\n              <ion-checkbox \n                [checked]=\"isItemSelected(item)\" \n                slot=\"start\"\n                [disabled]=\"true\"\n              ></ion-checkbox>\n              <ion-label>{{ item[labelProperty] }}</ion-label>\n            </ion-item>\n            <ion-item *ngIf=\"filteredItems.length === 0\" lines=\"none\">\n              <ion-label color=\"dark\">No se encontraron resultados</ion-label>\n            </ion-item>\n          </ion-list>\n        </ion-content>\n        <ion-footer *ngIf=\"tempSelectedItems.length > 0\">\n          <ion-toolbar>\n            <ion-buttons slot=\"end\">\n              <ion-button (click)=\"clearSelection()\">Limpiar</ion-button>\n              <ion-button fill=\"solid\" (click)=\"applySelection()\">Aplicar ({{ tempSelectedItems.length }})</ion-button>\n            </ion-buttons>\n          </ion-toolbar>\n        </ion-footer>\n      </ng-template>\n    </ion-modal>\n  `,\n  styles: [\n    `\n      ion-header {\n        padding: 8px 8px 0px 8px;\n      }\n    `,\n  ],\n})\nexport class MultiSelectSearchComponent implements OnChanges, OnDestroy {\n  @ViewChild('modal') modal!: IonModal;\n\n  @Input() label: string;\n  @Input() labelProperty: string = 'name';\n  @Input() valueProperty: string = 'id';\n  @Input() placeholder: string;\n  @Input() props: InputMetadata;\n\n  private langService = inject(LangService);\n  icon = inject(IconService);\n  private changeDetector = inject(ChangeDetectorRef);\n\n  searchTerm: string = '';\n  filteredItems: InputOption[] = [];\n  selectedItems: InputOption[] = [];\n  tempSelectedItems: InputOption[] = [];\n  displayValue: string = '';\n\n  private previousOptions: any[] = [];\n  private isProcessingChanges = false;\n  private valueChangesSubscription?: Subscription;\n\n  constructor() {\n    this.label = this.langService.getText('_global', 'selectMultiple', 'Seleccionar múltiples');\n    this.placeholder = this.langService.getText('_global', 'selectOptions', 'Seleccione opciones');\n  }\n\n  ngOnInit() {\n    this.applyDefaultValue();\n    this.initializeItems();\n    this.syncControlValueWithSelectedItems();\n    this.updateDisplayValue();\n    this.subscribeToValueChanges();\n  }\n\n  ngOnDestroy() {\n    if (this.valueChangesSubscription) {\n      this.valueChangesSubscription.unsubscribe();\n    }\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (this.isProcessingChanges) {\n      return;\n    }\n\n    if (changes['props']) {\n      try {\n        this.isProcessingChanges = true;\n\n        if (this.valueChangesSubscription) {\n          this.valueChangesSubscription.unsubscribe();\n        }\n\n        if (this.props?.options) {\n          const optionsChanged = !this.areOptionsEqual(this.previousOptions, this.props.options);\n\n          if (optionsChanged) {\n            this.previousOptions = [...this.props.options];\n            this.initializeItems();\n          }\n        }\n\n        this.syncControlValueWithSelectedItems();\n        this.updateDisplayValue();\n        this.subscribeToValueChanges();\n      } finally {\n        this.isProcessingChanges = false;\n      }\n    }\n  }\n\n  ionViewWillEnter(): void {\n    if (this.isProcessingChanges) {\n      return;\n    }\n\n    try {\n      this.isProcessingChanges = true;\n      this.initializeItems();\n      this.syncControlValueWithSelectedItems();\n      this.updateDisplayValue();\n      this.subscribeToValueChanges();\n    } finally {\n      this.isProcessingChanges = false;\n    }\n  }\n\n  private subscribeToValueChanges() {\n    if (!this.props?.control) return;\n\n    this.valueChangesSubscription = this.props.control.valueChanges.subscribe(() => {\n      if (this.isProcessingChanges) return;\n\n      try {\n        this.isProcessingChanges = true;\n        this.syncControlValueWithSelectedItems();\n        this.updateDisplayValue();\n      } finally {\n        this.isProcessingChanges = false;\n      }\n    });\n  }\n\n  private areOptionsEqual(prevOptions: any[], newOptions: any[]): boolean {\n    if (prevOptions === newOptions) return true;\n    if (!prevOptions || !newOptions) return prevOptions === newOptions;\n    if (prevOptions.length !== newOptions.length) return false;\n    \n    for (let i = 0; i < prevOptions.length; i++) {\n      if (prevOptions[i][this.valueProperty] !== newOptions[i][this.valueProperty]) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  private initializeItems(): void {\n    this.filteredItems = this.props?.options || [];\n  }\n\n  private syncControlValueWithSelectedItems(): void {\n    if (!this.props?.control) {\n      this.selectedItems = [];\n      return;\n    }\n\n    const controlValue = this.props.control.value;\n    if (!controlValue || controlValue === '') {\n      this.selectedItems = [];\n      return;\n    }\n\n    // Handle both array and string formats\n    let valueArray: string[] = [];\n    if (Array.isArray(controlValue)) {\n      valueArray = controlValue;\n    } else if (typeof controlValue === 'string') {\n      valueArray = controlValue.split(',').filter(v => v.trim() !== '');\n    }\n\n    if (this.props.options && this.props.options.length > 0) {\n      const map = new Map(this.props.options.map(opt => [opt[this.valueProperty], opt]));\n      this.selectedItems = valueArray\n        .map(value => map.get(value.toString().trim()))\n        .filter(item => item !== undefined);\n    } else {\n      this.selectedItems = [];\n    }\n  }\n\n  private applyDefaultValue(): void {\n    applyDefaultValueToControl(this.props);\n  }\n\n  onFilter(event: any) {\n    if (!event || event.trim() === '') {\n      this.filteredItems = this.props?.options ? [...this.props.options] : [];\n      this.changeDetector.detectChanges();\n      return;\n    }\n\n    if (!this.props?.options || this.props.options.length === 0) {\n      this.filteredItems = [];\n      this.changeDetector.detectChanges();\n      return;\n    }\n\n    const search = replaceSpecialChars(event.toLowerCase());\n    this.filteredItems = this.props.options.filter(element => {\n      const label = element[this.labelProperty]\n        ? replaceSpecialChars(String(element[this.labelProperty]).toLowerCase())\n        : '';\n      const value = element[this.valueProperty]\n        ? replaceSpecialChars(String(element[this.valueProperty]).toLowerCase())\n        : '';\n      return label.includes(search) || value.includes(search);\n    });\n    this.changeDetector.detectChanges();\n  }\n\n  onFocus() {\n    console.log('onFocus');\n  }\n\n  onBlur() {\n    console.log('onBlur');\n  }\n\n  openModal() {\n    this.syncControlValueWithSelectedItems();\n    this.tempSelectedItems = [...this.selectedItems];\n    this.updateDisplayValue();\n    if (this.modal) {\n      this.modal.present();\n    }\n  }\n\n  preventDefaultBehavior(event: MouseEvent) {\n    event.preventDefault();\n    event.stopPropagation();\n    this.openModal();\n  }\n\n  cancelModal() {\n    // Reset filter and show all options when closing modal\n    this.searchTerm = '';\n    this.filteredItems = this.props?.options ? [...this.props.options] : [];\n    this.changeDetector.detectChanges();\n    if (this.modal) {\n      this.modal.dismiss();\n    }\n  }\n\n  selectItem(item: any) {\n    const index = this.tempSelectedItems.findIndex(\n      selectedItem => selectedItem[this.valueProperty] === item[this.valueProperty]\n    );\n\n    if (index === -1) {\n      this.tempSelectedItems.push(item);\n    } else {\n      this.tempSelectedItems.splice(index, 1);\n    }\n  }\n\n  isItemSelected(item: any): boolean {\n    return this.tempSelectedItems.some(\n      selectedItem => selectedItem[this.valueProperty] === item[this.valueProperty]\n    );\n  }\n\n  clearSelection() {\n    this.tempSelectedItems = [];\n  }\n\n  applySelection() {\n    this.selectedItems = [...this.tempSelectedItems];\n    this.updateDisplayValue();\n    this.applyChanges();\n    this.cancelModal();\n  }\n\n  updateDisplayValue() {\n    if (this.selectedItems.length === 0) {\n      this.displayValue = '';\n      return;\n    }\n\n    if (this.selectedItems.length === 1) {\n      this.displayValue = this.selectedItems[0][this.labelProperty];\n    } else {\n      this.displayValue = `${this.selectedItems.length} elementos seleccionados`;\n    }\n  }\n\n  applyChanges() {\n    if (!this.props?.control) {\n      return;\n    }\n\n    try {\n      this.isProcessingChanges = true;\n\n      const values = this.selectedItems.map(item => item[this.valueProperty]);\n      const stringValue = values.join(',');\n      this.props.control.setValue(stringValue);\n      this.props.control.markAsDirty();\n      this.props.control.markAsTouched();\n      this.props.control.updateValueAndValidity();\n      \n      // Debug validators if still having issues\n      if (this.props.control.invalid) {\n        console.warn('Control is invalid after setValue:', {\n          value: this.props.control.value,\n          errors: this.props.control.errors,\n          validators: this.props.control.validator\n        });\n      }\n    } finally {\n      this.isProcessingChanges = false;\n    }\n  }\n\n  reset() {\n    this.selectedItems = [];\n    this.displayValue = '';\n    if (this.props?.control) {\n      this.props.control.setValue('');\n    }\n    this.changeDetector.detectChanges();\n  }\n}"]}
@@ -7619,14 +7619,22 @@ class MultiSelectSearchComponent {
7619
7619
  return;
7620
7620
  }
7621
7621
  const controlValue = this.props.control.value;
7622
- if (!Array.isArray(controlValue) || controlValue.length === 0) {
7622
+ if (!controlValue || controlValue === '') {
7623
7623
  this.selectedItems = [];
7624
7624
  return;
7625
7625
  }
7626
+ // Handle both array and string formats
7627
+ let valueArray = [];
7628
+ if (Array.isArray(controlValue)) {
7629
+ valueArray = controlValue;
7630
+ }
7631
+ else if (typeof controlValue === 'string') {
7632
+ valueArray = controlValue.split(',').filter(v => v.trim() !== '');
7633
+ }
7626
7634
  if (this.props.options && this.props.options.length > 0) {
7627
7635
  const map = new Map(this.props.options.map(opt => [opt[this.valueProperty], opt]));
7628
- this.selectedItems = controlValue
7629
- .map(value => map.get(value))
7636
+ this.selectedItems = valueArray
7637
+ .map(value => map.get(value.toString().trim()))
7630
7638
  .filter(item => item !== undefined);
7631
7639
  }
7632
7640
  else {
@@ -7688,15 +7696,12 @@ class MultiSelectSearchComponent {
7688
7696
  }
7689
7697
  }
7690
7698
  selectItem(item) {
7691
- console.log('selectItem called with:', item);
7692
7699
  const index = this.tempSelectedItems.findIndex(selectedItem => selectedItem[this.valueProperty] === item[this.valueProperty]);
7693
7700
  if (index === -1) {
7694
7701
  this.tempSelectedItems.push(item);
7695
- console.log('Item added, tempSelectedItems:', this.tempSelectedItems);
7696
7702
  }
7697
7703
  else {
7698
7704
  this.tempSelectedItems.splice(index, 1);
7699
- console.log('Item removed, tempSelectedItems:', this.tempSelectedItems);
7700
7705
  }
7701
7706
  }
7702
7707
  isItemSelected(item) {
@@ -7706,10 +7711,8 @@ class MultiSelectSearchComponent {
7706
7711
  this.tempSelectedItems = [];
7707
7712
  }
7708
7713
  applySelection() {
7709
- console.log('applySelection called, tempSelectedItems:', this.tempSelectedItems);
7710
7714
  this.selectedItems = [...this.tempSelectedItems];
7711
7715
  this.updateDisplayValue();
7712
- console.log('About to call applyChanges with selectedItems:', this.selectedItems);
7713
7716
  this.applyChanges();
7714
7717
  this.cancelModal();
7715
7718
  }
@@ -7726,19 +7729,25 @@ class MultiSelectSearchComponent {
7726
7729
  }
7727
7730
  }
7728
7731
  applyChanges() {
7729
- console.log('applyChanges called, props.control exists:', !!this.props?.control);
7730
7732
  if (!this.props?.control) {
7731
- console.log('No control found, exiting applyChanges');
7732
7733
  return;
7733
7734
  }
7734
7735
  try {
7735
7736
  this.isProcessingChanges = true;
7736
7737
  const values = this.selectedItems.map(item => item[this.valueProperty]);
7737
- console.log('Setting control value to:', values);
7738
- this.props.control.setValue(values);
7738
+ const stringValue = values.join(',');
7739
+ this.props.control.setValue(stringValue);
7739
7740
  this.props.control.markAsDirty();
7741
+ this.props.control.markAsTouched();
7740
7742
  this.props.control.updateValueAndValidity();
7741
- console.log('Control value after setValue:', this.props.control.value);
7743
+ // Debug validators if still having issues
7744
+ if (this.props.control.invalid) {
7745
+ console.warn('Control is invalid after setValue:', {
7746
+ value: this.props.control.value,
7747
+ errors: this.props.control.errors,
7748
+ validators: this.props.control.validator
7749
+ });
7750
+ }
7742
7751
  }
7743
7752
  finally {
7744
7753
  this.isProcessingChanges = false;
@@ -7748,7 +7757,7 @@ class MultiSelectSearchComponent {
7748
7757
  this.selectedItems = [];
7749
7758
  this.displayValue = '';
7750
7759
  if (this.props?.control) {
7751
- this.props.control.setValue([]);
7760
+ this.props.control.setValue('');
7752
7761
  }
7753
7762
  this.changeDetector.detectChanges();
7754
7763
  }