mis-crystal-design-system 18.1.8 → 18.1.10-test

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.
@@ -1,6 +1,6 @@
1
- import { Component, signal, input, output } from '@angular/core';
2
- import { slideFromRight } from '../animations/slideFromRight';
1
+ import { Component, effect, signal, computed, input, output } from '@angular/core';
3
2
  import { FormControl, FormGroup } from '@angular/forms';
3
+ import { slideFromRight } from '../animations/slideFromRight';
4
4
  import * as i0 from "@angular/core";
5
5
  import * as i1 from "../has-value.pipe";
6
6
  import * as i2 from "@angular/common";
@@ -12,6 +12,7 @@ import * as i7 from "mis-crystal-design-system/input";
12
12
  import * as i8 from "mis-crystal-design-system/datepicker_v2";
13
13
  import * as i9 from "mis-crystal-design-system/daterangepicker_v2";
14
14
  import * as i10 from "mis-crystal-design-system/checkbox";
15
+ const _c0 = () => [];
15
16
  function FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_3_Template(rf, ctx) { if (rf & 1) {
16
17
  const _r3 = i0.ɵɵgetCurrentView();
17
18
  i0.ɵɵelementContainerStart(0);
@@ -20,10 +21,11 @@ function FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_3_Template
20
21
  i0.ɵɵelementEnd()();
21
22
  i0.ɵɵelementContainerEnd();
22
23
  } if (rf & 2) {
24
+ let tmp_7_0;
23
25
  const filter_r4 = i0.ɵɵnextContext(2).$implicit;
24
26
  const ctx_r1 = i0.ɵɵnextContext(2);
25
27
  i0.ɵɵadvance(2);
26
- i0.ɵɵproperty("label", filter_r4.placeholder || "Select")("selectedItems", ctx_r1.filterForm.get(filter_r4.key).value)("data", filter_r4.options)("searchEnabled", true)("showSelectedCount", true)("enableSelectAll", true)("hideApplyButton", false);
28
+ i0.ɵɵproperty("label", filter_r4.placeholder || "Select")("selectedItems", ((tmp_7_0 = ctx_r1.filterForm.get(filter_r4.key)) == null ? null : tmp_7_0.value) || i0.ɵɵpureFunction0(7, _c0))("data", filter_r4.options)("searchEnabled", true)("showSelectedCount", true)("enableSelectAll", true)("hideApplyButton", false);
27
29
  } }
28
30
  function FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_4_Template(rf, ctx) { if (rf & 1) {
29
31
  const _r5 = i0.ɵɵgetCurrentView();
@@ -33,10 +35,11 @@ function FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_4_Template
33
35
  i0.ɵɵelementEnd()();
34
36
  i0.ɵɵelementContainerEnd();
35
37
  } if (rf & 2) {
38
+ let tmp_8_0;
36
39
  const filter_r4 = i0.ɵɵnextContext(2).$implicit;
37
40
  const ctx_r1 = i0.ɵɵnextContext(2);
38
41
  i0.ɵɵadvance(2);
39
- i0.ɵɵproperty("data", filter_r4.options)("searchEnabled", true)("selectedItem", ctx_r1.filterForm.get(filter_r4.key).value);
42
+ i0.ɵɵproperty("data", filter_r4.options)("searchEnabled", true)("selectedItem", (tmp_8_0 = ctx_r1.filterForm.get(filter_r4.key)) == null ? null : tmp_8_0.value);
40
43
  } }
41
44
  function FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_5_div_2_Template(rf, ctx) { if (rf & 1) {
42
45
  const _r6 = i0.ɵɵgetCurrentView();
@@ -52,7 +55,7 @@ function FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_5_div_2_Te
52
55
  const filter_r4 = i0.ɵɵnextContext(3).$implicit;
53
56
  const ctx_r1 = i0.ɵɵnextContext(2);
54
57
  i0.ɵɵadvance();
55
- i0.ɵɵproperty("type", "Default")("checked", (tmp_9_0 = ctx_r1.filterForm.get(filter_r4.key).value) == null ? null : tmp_9_0.includes(option_r7.value));
58
+ i0.ɵɵproperty("type", "Default")("checked", (tmp_9_0 = ctx_r1.filterForm.get(filter_r4.key)) == null ? null : tmp_9_0.value == null ? null : tmp_9_0.value.includes(option_r7.value));
56
59
  i0.ɵɵadvance(2);
57
60
  i0.ɵɵtextInterpolate(option_r7.label);
58
61
  } }
@@ -70,18 +73,18 @@ function FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_5_Template
70
73
  function FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_6_Template(rf, ctx) { if (rf & 1) {
71
74
  const _r8 = i0.ɵɵgetCurrentView();
72
75
  i0.ɵɵelementContainerStart(0);
73
- i0.ɵɵtext(1);
74
- i0.ɵɵelementStart(2, "mis-input", 25)(3, "input", 26);
75
- i0.ɵɵlistener("dateChange", function FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_6_Template_input_dateChange_3_listener($event) { i0.ɵɵrestoreView(_r8); const filter_r4 = i0.ɵɵnextContext(2).$implicit; const ctx_r1 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r1.onDateChange($event, filter_r4.key, filter_r4)); });
76
+ i0.ɵɵelementStart(1, "mis-input", 25)(2, "input", 26);
77
+ i0.ɵɵlistener("dateChange", function FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_6_Template_input_dateChange_2_listener($event) { i0.ɵɵrestoreView(_r8); const filter_r4 = i0.ɵɵnextContext(2).$implicit; const ctx_r1 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r1.onDateChange($event, filter_r4.key, filter_r4)); });
76
78
  i0.ɵɵelementEnd()();
77
79
  i0.ɵɵelementContainerEnd();
78
80
  } if (rf & 2) {
81
+ let tmp_7_0;
82
+ let tmp_8_0;
83
+ let tmp_9_0;
79
84
  const filter_r4 = i0.ɵɵnextContext(2).$implicit;
80
85
  const ctx_r1 = i0.ɵɵnextContext(2);
81
- i0.ɵɵadvance();
82
- i0.ɵɵtextInterpolate1(" ", filter_r4.placeholder, " ");
83
86
  i0.ɵɵadvance(2);
84
- i0.ɵɵproperty("dpConfig", filter_r4.datepickerConfig)("placeholder", ctx_r1.filterForm.get(filter_r4.key).value ? ctx_r1.filterForm.get(filter_r4.key).value : filter_r4.placeholder || "Select")("value", ctx_r1.filterForm.get(filter_r4.key).value ? ctx_r1.filterForm.get(filter_r4.key).value : filter_r4.placeholder || "Select")("selectedDate", ctx_r1.filterForm.get(filter_r4.key).value)("positionX", "end")("offsetX", -10);
87
+ i0.ɵɵproperty("dpConfig", filter_r4.datePickerConfig)("placeholder", ((tmp_7_0 = ctx_r1.filterForm.get(filter_r4.key)) == null ? null : tmp_7_0.value) || filter_r4.placeholder || "Select")("value", ((tmp_8_0 = ctx_r1.filterForm.get(filter_r4.key)) == null ? null : tmp_8_0.value) || filter_r4.placeholder || "Select")("selectedDate", (tmp_9_0 = ctx_r1.filterForm.get(filter_r4.key)) == null ? null : tmp_9_0.value)("positionX", "end")("offsetX", -10);
85
88
  } }
86
89
  function FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_7_Template(rf, ctx) { if (rf & 1) {
87
90
  const _r9 = i0.ɵɵgetCurrentView();
@@ -144,7 +147,7 @@ function FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_10_Templat
144
147
  i0.ɵɵadvance(3);
145
148
  i0.ɵɵtextInterpolate((filter_r4 == null ? null : filter_r4.options == null ? null : filter_r4.options[1] == null ? null : filter_r4.options[1].label) || "Max");
146
149
  i0.ɵɵadvance();
147
- i0.ɵɵproperty("placeholder", filter_r4.placeholder || "Type here")("min", (ctx_r1.filterForm.get == null ? null : (tmp_11_0 = ctx_r1.filterForm.get(filter_r4.key)) == null ? null : (tmp_11_0 = tmp_11_0.get("min")) == null ? null : tmp_11_0.value) || 0);
150
+ i0.ɵɵproperty("placeholder", filter_r4.placeholder || "Type here")("min", ((tmp_11_0 = ctx_r1.filterForm.get(filter_r4.key)) == null ? null : (tmp_11_0 = tmp_11_0.get("min")) == null ? null : tmp_11_0.value) || 0);
148
151
  } }
149
152
  function FilterPanelComponent_div_0_ng_container_9_div_1_div_11_Template(rf, ctx) { if (rf & 1) {
150
153
  i0.ɵɵelement(0, "div", 34);
@@ -153,7 +156,7 @@ function FilterPanelComponent_div_0_ng_container_9_div_1_Template(rf, ctx) { if
153
156
  i0.ɵɵelementStart(0, "div", 13)(1, "span", 14);
154
157
  i0.ɵɵtext(2);
155
158
  i0.ɵɵelementEnd();
156
- i0.ɵɵtemplate(3, FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_3_Template, 3, 7, "ng-container", 15)(4, FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_4_Template, 3, 3, "ng-container", 15)(5, FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_5_Template, 3, 1, "ng-container", 15)(6, FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_6_Template, 4, 7, "ng-container", 15)(7, FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_7_Template, 3, 6, "ng-container", 15)(8, FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_8_Template, 3, 2, "ng-container", 15)(9, FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_9_Template, 3, 2, "ng-container", 15)(10, FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_10_Template, 10, 6, "ng-container", 15)(11, FilterPanelComponent_div_0_ng_container_9_div_1_div_11_Template, 1, 0, "div", 16);
159
+ i0.ɵɵtemplate(3, FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_3_Template, 3, 8, "ng-container", 15)(4, FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_4_Template, 3, 3, "ng-container", 15)(5, FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_5_Template, 3, 1, "ng-container", 15)(6, FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_6_Template, 3, 6, "ng-container", 15)(7, FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_7_Template, 3, 6, "ng-container", 15)(8, FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_8_Template, 3, 2, "ng-container", 15)(9, FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_9_Template, 3, 2, "ng-container", 15)(10, FilterPanelComponent_div_0_ng_container_9_div_1_ng_container_10_Template, 10, 6, "ng-container", 15)(11, FilterPanelComponent_div_0_ng_container_9_div_1_div_11_Template, 1, 0, "div", 16);
157
160
  i0.ɵɵelementEnd();
158
161
  } if (rf & 2) {
159
162
  const ctx_r9 = i0.ɵɵnextContext();
@@ -226,92 +229,161 @@ function FilterPanelComponent_div_0_Template(rf, ctx) { if (rf & 1) {
226
229
  export class FilterPanelComponent {
227
230
  constructor(hasValue) {
228
231
  this.hasValue = hasValue;
229
- // Signal inputs replacing @Input()
232
+ this.isInitialized = false;
233
+ /* --- signal-based Inputs / Outputs --- */
230
234
  this.show = input(false);
231
235
  this.config = input.required();
232
236
  this.emitFiltersAfterSettingNewValues = input(false);
233
- // Signal outputs replacing @Output()
234
237
  this.onClose = output();
235
238
  this.onApply = output();
239
+ /* --- form + internal state --- */
236
240
  this.filterForm = new FormGroup({});
241
+ // keep a signal snapshot of form value so computed can react
242
+ this._formValueSignal = signal({});
243
+ // last applied snapshot (signal so template/logic can read reliably)
244
+ this.lastAppliedData = signal(null);
245
+ // date range readable for template
237
246
  this.dateRangeSelectedDates = signal({
238
247
  startDate: '',
239
- endDate: '',
248
+ endDate: ''
240
249
  });
241
- }
242
- // Method to calculate filter count (not a computed signal because form values aren't reactive)
243
- getFilterCount() {
244
- let count = 0;
245
- const formValue = this.filterForm.value;
246
- this.config().forEach((filter) => {
247
- const value = formValue[filter.key];
248
- // Special handling for range type - only count if at least one value is set
249
- if (filter.type === 'range') {
250
- if (value && (value.min !== null || value.max !== null)) {
250
+ /* computed filterCount */
251
+ this.filterCount = computed(() => {
252
+ const formValue = this._formValueSignal();
253
+ const cfg = this.config();
254
+ let count = 0;
255
+ for (const filter of cfg) {
256
+ const value = formValue[filter.key];
257
+ if (filter.type === 'range') {
258
+ if (value && (value.min !== null || value.max !== null)) {
259
+ count++;
260
+ }
261
+ continue;
262
+ }
263
+ if (filter.type === 'multiSelect' || filter.type === 'checkbox') {
264
+ if (Array.isArray(value) && value.length > 0) {
265
+ count++;
266
+ }
267
+ continue;
268
+ }
269
+ if (this.hasValue.transform(value)) {
251
270
  count++;
252
271
  }
253
- return;
254
272
  }
255
- // Special handling for multiSelect/checkbox - check array length directly
256
- if (filter.type === 'multiSelect' || filter.type === 'checkbox') {
257
- if (Array.isArray(value) && value.length > 0) {
258
- count++;
273
+ return count;
274
+ });
275
+ // Effect to react to config changes - must allow signal writes since we update internal signals
276
+ effect(() => {
277
+ try {
278
+ const cfg = this.config();
279
+ if (cfg && Array.isArray(cfg) && cfg.length > 0) {
280
+ // Only initialize form if not already done, or if config structure changed
281
+ if (!this.isInitialized || this.hasConfigChanged(cfg)) {
282
+ this.initializeFormControls(cfg);
283
+ this.isInitialized = true;
284
+ }
285
+ // Always check for selectedValue changes
286
+ this.setFilterValue(cfg);
259
287
  }
260
- return;
261
288
  }
262
- // For other types, use hasValue pipe
263
- if (this.hasValue.transform(value)) {
264
- count++;
289
+ catch (error) {
290
+ console.warn('FilterPanel: Error in config effect', error);
265
291
  }
266
- });
267
- return count;
292
+ }, { allowSignalWrites: true });
268
293
  }
294
+ /* --- Lifecycle --- */
269
295
  ngOnInit() {
270
- // Access the config signal value by calling it like a function
271
- this.initializeFormControls(this.config());
296
+ // subscribe form changes so computed/filterCount update
297
+ this.subscribeFormChanges();
272
298
  }
299
+ ngOnDestroy() {
300
+ this.formSubscription?.unsubscribe();
301
+ }
302
+ /* --- Form init & helpers --- */
273
303
  initializeFormControls(config) {
274
- this.filterForm = new FormGroup({});
275
- config.forEach((filter) => {
276
- let control;
277
- if (filter.type === 'range') {
278
- control = new FormGroup({
279
- min: new FormControl(null),
280
- max: new FormControl(null),
281
- }, {
282
- validators: (group) => {
283
- const min = group.get('min').value;
284
- const max = group.get('max').value;
285
- if (min !== null && max !== null && min > max) {
286
- return { rangeError: 'Min value should be less than max value' };
287
- }
288
- return null;
289
- }
290
- });
291
- }
292
- else if (filter.type === 'multiSelect' || filter.type === 'checkbox') {
293
- control = new FormControl([]);
294
- }
295
- else if (filter.type === 'select') {
296
- control = new FormControl('');
304
+ // build a fresh form to match config
305
+ const newForm = new FormGroup({});
306
+ const rangeValidator = (group) => {
307
+ const min = group.get('min')?.value;
308
+ const max = group.get('max')?.value;
309
+ if (min !== null && max !== null && min > max) {
310
+ return { rangeError: 'Min value should be less than max value' };
297
311
  }
298
- else {
299
- control = new FormControl(null);
312
+ return null;
313
+ };
314
+ for (const filter of config) {
315
+ let control;
316
+ switch (filter.type) {
317
+ case 'range':
318
+ control = new FormGroup({
319
+ min: new FormControl(null),
320
+ max: new FormControl(null)
321
+ }, { validators: rangeValidator });
322
+ break;
323
+ case 'multiSelect':
324
+ case 'checkbox':
325
+ control = new FormControl(Array.isArray(filter.defaultValue) ? filter.defaultValue : []);
326
+ break;
327
+ case 'select':
328
+ control = new FormControl(filter.defaultValue ?? '');
329
+ break;
330
+ default:
331
+ control = new FormControl(filter.defaultValue ?? null);
300
332
  }
301
333
  if (this.hasValue.transform(filter.defaultValue)) {
302
334
  control.setValue(filter.defaultValue);
303
335
  }
304
- this.filterForm.addControl(filter.key, control);
336
+ newForm.addControl(filter.key, control);
337
+ }
338
+ // replace form safely
339
+ // preserve subscription so valueChanges continues to update _formValueSignal
340
+ this.filterForm = newForm;
341
+ // update signal snapshot immediately
342
+ this._formValueSignal.set({ ...this.filterForm.value });
343
+ // re-subscribe to new form's valueChanges
344
+ this.subscribeFormChanges();
345
+ }
346
+ subscribeFormChanges() {
347
+ // unsubscribe previous subscription if any
348
+ this.formSubscription?.unsubscribe();
349
+ // subscribe to valueChanges; set snapshot signal
350
+ this.formSubscription = this.filterForm.valueChanges?.subscribe((value) => {
351
+ this._formValueSignal.set({ ...value });
305
352
  });
353
+ // also set initial snapshot in case valueChanges doesn't emit immediately
354
+ this._formValueSignal.set({ ...this.filterForm.value });
355
+ }
356
+ getControl(key) {
357
+ return this.filterForm.get(key);
358
+ }
359
+ /**
360
+ * Check if config structure has changed (new keys or removed keys)
361
+ * Used to determine if form needs to be rebuilt
362
+ */
363
+ hasConfigChanged(newConfig) {
364
+ const currentKeys = Object.keys(this.filterForm.controls).sort();
365
+ const newKeys = newConfig.map(f => f.key).sort();
366
+ if (currentKeys.length !== newKeys.length) {
367
+ return true;
368
+ }
369
+ return currentKeys.some((key, index) => key !== newKeys[index]);
306
370
  }
371
+ /* --- Actions / UI handlers --- */
307
372
  closePanel() {
308
- if (this.lastAppliedData) {
309
- this.filterForm.setValue(this.lastAppliedData);
373
+ const last = this.lastAppliedData();
374
+ if (last) {
375
+ try {
376
+ // prefer setValue (ensures shape matches); fallback to patchValue
377
+ this.filterForm.setValue(last);
378
+ }
379
+ catch {
380
+ this.filterForm.patchValue(last);
381
+ }
310
382
  }
311
383
  else {
312
384
  this.clearFormValues();
313
385
  }
314
- // Emit the close event using the signal output
386
+ // emit close event
315
387
  this.onClose.emit();
316
388
  }
317
389
  applyFilters() {
@@ -319,70 +391,102 @@ export class FilterPanelComponent {
319
391
  this.filterForm.markAllAsTouched();
320
392
  return;
321
393
  }
322
- this.lastAppliedData = { ...this.filterForm.value };
323
- // Emit the apply event with the filter data using the signal output
394
+ const snapshot = { ...this.filterForm.value };
395
+ this.lastAppliedData.set(snapshot);
324
396
  this.onApply.emit({
325
- filterData: this.filterForm.value,
326
- filterCount: this.getFilterCount()
397
+ filterData: snapshot,
398
+ filterCount: this.filterCount()
327
399
  });
400
+ // consistent behavior with earlier implementation:
401
+ // hide panel (parent should read show() to close) and restore form state via closePanel
402
+ // Note: we don't mutate show() here; parent owns show signal
328
403
  this.closePanel();
329
404
  }
405
+ resetFilters() {
406
+ this.clearFormValues();
407
+ // call applyFilters to maintain previous behavior (validation + emit)
408
+ this.applyFilters();
409
+ }
410
+ /* --- Value setters --- */
330
411
  handleSelect(event, filterKey, filter) {
331
- this.filterForm.get(filterKey).setValue(event);
412
+ const ctrl = this.getControl(filterKey);
413
+ // For multiSelect, extract values from array of objects (if needed)
414
+ let valueToSet = event;
415
+ if (filter.type === 'multiSelect' && Array.isArray(event)) {
416
+ // Check if it's an array of objects with 'value' property
417
+ if (event.length > 0 && typeof event[0] === 'object' && 'value' in event[0]) {
418
+ valueToSet = event.map((item) => item.value || item);
419
+ }
420
+ }
421
+ ctrl?.setValue(valueToSet);
332
422
  if (filter.onChange) {
423
+ // keep same callback contract: pass event, config and form snapshot
333
424
  filter.onChange(event, this.config(), this.filterForm.value);
334
425
  }
335
426
  }
336
- onDateChange(event, filterKey, filter) {
337
- this.filterForm.get(filterKey).setValue(event);
338
- if (typeof event === 'object') {
339
- this.dateRangeSelectedDates.set({
340
- startDate: event.startDate,
341
- endDate: event.endDate,
342
- });
343
- }
344
- }
345
427
  handleCheckbox(event, filterKey, checkboxValue, filter) {
346
- const currentValues = this.filterForm.get(filterKey).value;
347
- if (event.value) {
348
- this.filterForm.get(filterKey).setValue([...currentValues, checkboxValue]);
428
+ const ctrl = this.getControl(filterKey);
429
+ const current = Array.isArray(ctrl?.value) ? [...ctrl.value] : [];
430
+ if (event?.value) {
431
+ ctrl?.setValue([...current, checkboxValue]);
349
432
  }
350
433
  else {
351
- this.filterForm.get(filterKey).setValue(currentValues.filter((value) => value !== checkboxValue));
434
+ ctrl?.setValue(current.filter((v) => v !== checkboxValue));
352
435
  }
353
436
  if (filter.onChange) {
354
437
  filter.onChange(event, this.config(), this.filterForm.value);
355
438
  }
356
439
  }
440
+ onDateChange(event, filterKey, filter) {
441
+ const ctrl = this.getControl(filterKey);
442
+ ctrl?.setValue(event);
443
+ if (event && typeof event === 'object' && 'startDate' in event && 'endDate' in event) {
444
+ this.dateRangeSelectedDates.set({
445
+ startDate: event.startDate,
446
+ endDate: event.endDate
447
+ });
448
+ }
449
+ }
450
+ /* --- Clear / Set values helpers --- */
357
451
  clearFormValues() {
358
- const resetValues = {};
359
- this.config().forEach((filter) => {
360
- let defaultValue = filter.defaultValue || null;
452
+ const resets = {};
453
+ for (const filter of this.config()) {
454
+ let defaultValue = filter.defaultValue ?? null;
361
455
  if (filter.type === 'multiSelect' || filter.type === 'checkbox') {
362
- defaultValue = filter.defaultValue || [];
456
+ defaultValue = filter.defaultValue ?? [];
363
457
  }
364
458
  if (filter.type === 'range') {
365
- defaultValue = filter.defaultValue || { min: null, max: null };
459
+ defaultValue = filter.defaultValue ?? { min: null, max: null };
366
460
  }
367
- resetValues[filter.key] = defaultValue;
368
- });
369
- this.filterForm.patchValue(resetValues);
370
- }
371
- resetFilters() {
372
- this.clearFormValues();
373
- this.applyFilters();
461
+ resets[filter.key] = defaultValue;
462
+ }
463
+ // patch to avoid shape mismatch errors
464
+ this.filterForm.patchValue(resets);
465
+ this._formValueSignal.set({ ...this.filterForm.value });
374
466
  }
467
+ /**
468
+ * Applies filter.selectedValue when parent provides selectedValue.
469
+ * Called by the config effect (so runs on initial load and on config changes).
470
+ */
375
471
  setFilterValue(config) {
376
472
  let anyValueSet = false;
377
473
  for (const filter of config) {
378
- if (filter?.selectedValue) {
379
- this.filterForm.get(filter.key).setValue(filter.selectedValue);
380
- anyValueSet = true;
474
+ if (this.hasValue.transform(filter?.selectedValue)) {
475
+ const ctrl = this.getControl(filter.key);
476
+ if (ctrl) {
477
+ ctrl.setValue(filter.selectedValue);
478
+ anyValueSet = true;
479
+ }
381
480
  }
382
481
  }
383
482
  if (anyValueSet && this.emitFiltersAfterSettingNewValues()) {
483
+ // respect the parent flag — apply and emit
384
484
  this.applyFilters();
385
485
  }
486
+ else {
487
+ // make sure our snapshot signal is fresh
488
+ this._formValueSignal.set({ ...this.filterForm.value });
489
+ }
386
490
  }
387
491
  static { this.ɵfac = function FilterPanelComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || FilterPanelComponent)(i0.ɵɵdirectiveInject(i1.HasValuePipe)); }; }
388
492
  static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: FilterPanelComponent, selectors: [["mis-filter-panel"]], inputs: { show: [1, "show"], config: [1, "config"], emitFiltersAfterSettingNewValues: [1, "emitFiltersAfterSettingNewValues"] }, outputs: { onClose: "onClose", onApply: "onApply" }, decls: 1, vars: 1, consts: [["class", "filter-panel-container", 4, "ngIf"], [1, "filter-panel-container"], [1, "panel-header"], ["width", "25", "height", "25", "viewBox", "0 0 25 25", "fill", "none", "xmlns", "http://www.w3.org/2000/svg", 1, "close-icon", 3, "click"], ["id", "ic-navigation-cancel-24"], ["id", "Union", "fill-rule", "evenodd", "clip-rule", "evenodd", "d", "M8.60468 6.64355C8.09036 6.12923 7.25649 6.12923 6.74218 6.64355C6.22787 7.15786 6.22787 7.99173 6.74218 8.50604L10.4938 12.2576L6.7431 16.0083C6.22879 16.5226 6.22879 17.3564 6.7431 17.8708C7.25742 18.3851 8.09129 18.3851 8.60560 17.8708L12.3562 14.1201L16.1068 17.8707C16.6211 18.3850 17.4550 18.3850 17.9693 17.8707C18.4836 17.3564 18.4836 16.5225 17.9693 16.0082L14.2187 12.2576L17.9702 8.50613C18.4845 7.99181 18.4845 7.15794 17.9702 6.64363C17.4559 6.12932 16.6220 6.12932 16.1077 6.64363L12.3562 10.3951L8.60468 6.64355Z", "fill", "#181F33"], [1, "horizontal-divider", "first"], [1, "filters", 3, "formGroup"], [4, "ngFor", "ngForOf"], [1, "actions"], [3, "click", "name", "size", "type"], [3, "click", "name", "size", "type", "disabled"], ["class", "filter", 4, "ngIf"], [1, "filter"], [1, "filter-title"], [4, "ngIf"], ["class", "horizontal-divider", 4, "ngIf"], [1, "multiselect-filter"], ["width", "100%", "height", "44px", 1, "no-padding", 3, "onChange", "label", "selectedItems", "data", "searchEnabled", "showSelectedCount", "enableSelectAll", "hideApplyButton"], ["width", "100%", "height", "44px", 3, "onChange", "data", "searchEnabled", "selectedItem"], [1, "checkbox-row"], ["class", "checkbox-container", 4, "ngFor", "ngForOf"], [1, "checkbox-container"], [3, "valueChange", "type", "checked"], [1, "checkbox-label"], ["type", "rounded"], ["misTzDp", "", "misInput", "", "type", "text", "readonly", "", 1, "mis-input", 3, "dateChange", "dpConfig", "placeholder", "value", "selectedDate", "positionX", "offsetX"], ["misTzDrp", "", "misInput", "", "type", "text", "readonly", "", 1, "mis-input", 3, "dateChange", "placeholder", "value", "positionX", "positionY", "selectedDates", "dpConfig"], ["misInput", "", "type", "text", 1, "input", 3, "placeholder", "formControlName"], ["misInput", "", "type", "number", 1, "input", 3, "placeholder", "formControlName"], [1, "range-container", 3, "formGroup"], [1, "range-inner-container"], ["misInput", "", "type", "number", "formControlName", "min", 1, "input", 3, "placeholder"], ["misInput", "", "type", "number", "formControlName", "max", 1, "input", 3, "placeholder", "min"], [1, "horizontal-divider"]], template: function FilterPanelComponent_Template(rf, ctx) { if (rf & 1) {
@@ -393,7 +497,7 @@ export class FilterPanelComponent {
393
497
  }
394
498
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(FilterPanelComponent, [{
395
499
  type: Component,
396
- args: [{ selector: 'mis-filter-panel', animations: [slideFromRight], template: "<div class=\"filter-panel-container\" *ngIf=\"show()\" @slideFromRight>\n <div class=\"panel-header\">\n <span>Filters</span>\n <svg class=\"close-icon\" (click)=\"closePanel()\" width=\"25\" height=\"25\" viewBox=\"0 0 25 25\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <g id=\"ic-navigation-cancel-24\">\n <path id=\"Union\" fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M8.60468 6.64355C8.09036 6.12923 7.25649 6.12923 6.74218 6.64355C6.22787 7.15786 6.22787 7.99173 6.74218 8.50604L10.4938 12.2576L6.7431 16.0083C6.22879 16.5226 6.22879 17.3564 6.7431 17.8708C7.25742 18.3851 8.09129 18.3851 8.60560 17.8708L12.3562 14.1201L16.1068 17.8707C16.6211 18.3850 17.4550 18.3850 17.9693 17.8707C18.4836 17.3564 18.4836 16.5225 17.9693 16.0082L14.2187 12.2576L17.9702 8.50613C18.4845 7.99181 18.4845 7.15794 17.9702 6.64363C17.4559 6.12932 16.6220 6.12932 16.1077 6.64363L12.3562 10.3951L8.60468 6.64355Z\" fill=\"#181F33\" />\n </g>\n </svg>\n </div>\n\n <div class=\"horizontal-divider first\"></div>\n\n <div class=\"filters\" [formGroup]=\"filterForm\">\n <ng-container *ngFor=\"let filter of config(); let last = last\">\n <div class=\"filter\" *ngIf=\"!filter.hidden\">\n <span class=\"filter-title\">{{filter.title}}</span>\n <ng-container *ngIf=\"filter.type === 'multiSelect'\">\n <div class=\"multiselect-filter\">\n <mis-multi-select-dropdown class=\"no-padding\" [label]=\"filter.placeholder || 'Select'\" [selectedItems]=\"filterForm.get(filter.key).value\" (onChange)=\"handleSelect($event, filter.key, filter)\" [data]=\"filter.options\" [searchEnabled]=\"true\"\n [showSelectedCount]=\"true\" [enableSelectAll]=\"true\"\n [hideApplyButton]=\"false\" width=\"100%\" height=\"44px\"></mis-multi-select-dropdown>\n </div>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'select'\">\n <div class=\"multiselect-filter\">\n <mis-dropdown [data]=\"filter.options\" [searchEnabled]=\"true\" width=\"100%\" height=\"44px\"\n (onChange)=\"handleSelect($event, filter.key, filter)\" [selectedItem]=\"filterForm.get(filter.key).value\">\n </mis-dropdown>\n </div>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'checkbox'\">\n <div class=\"checkbox-row\">\n <div *ngFor=\"let option of filter.options\" class=\"checkbox-container\">\n <mis-checkbox [type]=\"'Default'\" [checked]=\"filterForm.get(filter.key).value?.includes(option.value)\" (valueChange)=\"handleCheckbox($event, filter.key, option.value, filter)\"></mis-checkbox>\n <span class=\"checkbox-label\">{{option.label}}</span>\n </div>\n </div>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'datePicker'\">\n {{filter.placeholder}}\n <mis-input type=\"rounded\">\n <input misTzDp misInput type=\"text\" readonly class=\"mis-input\" [dpConfig]=\"filter.datepickerConfig\" [placeholder]=\"filterForm.get(filter.key).value ? filterForm.get(filter.key).value : (filter.placeholder || 'Select')\" [value]=\"filterForm.get(filter.key).value ? filterForm.get(filter.key).value : (filter.placeholder || 'Select')\" (dateChange)=\"onDateChange($event, filter.key, filter)\" [selectedDate]=\"filterForm.get(filter.key).value\" [positionX]=\"'end'\" [offsetX]=\"-10\">\n </mis-input>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'dateRangePicker'\">\n <mis-input type=\"rounded\">\n <input misTzDrp misInput type=\"text\" class=\"mis-input\" readonly\n [placeholder]=\"(!dateRangeSelectedDates().startDate && !dateRangeSelectedDates().endDate) ? (filter.placeholder || 'Select') : dateRangeSelectedDates().startDate + ' - ' + dateRangeSelectedDates().endDate\"\n [value]=\"(!dateRangeSelectedDates().startDate && !dateRangeSelectedDates().endDate) ? (filter.placeholder || 'Select') : dateRangeSelectedDates().startDate + ' - ' + dateRangeSelectedDates().endDate\" [positionX]=\"'start'\"\n [positionY]=\"'top'\" [selectedDates]=\"dateRangeSelectedDates()\" (dateChange)=\"onDateChange($event, filter.key, filter)\"\n [dpConfig]=\"filter.dateRangePickerConfig\" />\n </mis-input>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'text'\">\n <mis-input type=\"rounded\">\n <input misInput type=\"text\" class=\"input\" [placeholder]=\"filter.placeholder || 'Type here'\" [formControlName]=\"filter.key\">\n </mis-input>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'number'\">\n <mis-input type=\"rounded\">\n <input misInput type=\"number\" class=\"input\" [placeholder]=\"filter.placeholder || 'Type here'\" [formControlName]=\"filter.key\">\n </mis-input>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'range'\">\n <div class=\"range-container\" [formGroup]=\"filterForm.get(filter.key)\">\n <div class=\"range-inner-container\">\n <span>{{ filter?.options?.[0]?.label || 'Min' }}</span>\n <input\n misInput\n type=\"number\"\n class=\"input\"\n [placeholder]=\"filter.placeholder || 'Type here'\"\n formControlName=\"min\"\n />\n </div>\n <div class=\"range-inner-container\">\n <span>{{ filter?.options?.[1]?.label || 'Max' }}</span>\n <input\n misInput\n type=\"number\"\n class=\"input\"\n [placeholder]=\"filter.placeholder || 'Type here'\"\n formControlName=\"max\"\n [min]=\"filterForm.get?.(filter.key)?.get('min')?.value || 0\"\n />\n </div>\n </div>\n </ng-container>\n <div class=\"horizontal-divider\" *ngIf=\"!last\"></div>\n </div>\n </ng-container>\n </div>\n\n <div class=\"actions\">\n <mis-button [name]=\"'Clear All'\" [size]=\"'Small'\" [type]=\"'Text'\" (click)=\"resetFilters()\"></mis-button>\n <mis-button [name]=\"'Apply'\" [size]=\"'Small'\" [type]=\"'Solid'\" (click)=\"applyFilters()\" [disabled]=\"filterForm.invalid\"></mis-button>\n </div>\n</div>\n\n", styles: [":root{--pmry-200: #99BAF7;--pmry-100: #CBDDFB;--pmry-500: #0937B2;--pmry-400: #3C68D0;--pmry-600: #062A99;--pmry-700: #041F80;--pmry-300: #638FE7;--pmry-800: #021567;--pmry-900: #010F55;--sec-d-purple: #40447F;--sec-maroon: #6B034E;--sec-mud-red: #B23600;--sec-orange: #ED711C;--sec-purple: #815FD5;--sec-teal: #10ADAE;--sec-yellow: #D4900C;--sec-green: #547F40;--sec-bright-green: #27D22E;--sec-dark-teal: #035F6B;--sec-chocolate: #7C2F33;--sec-rube-pink: #C13D6D;--sec-cerulean: #0087B2;--sem-error: #B00020;--sem-info: #0091FF;--sem-warning: #FF9D00;--sem-success: #38AF49;--grey-bg-1: #FAFAFA;--grey-bg: #F5F5F5;--grey-seperators: #E0E0E0;--grey-disabled: #C8CDD3;--grey-hover: #F5F7FC;--grey-pressed: #E6EBF7;--grey-row: #F5F7FC;--dec-light-yellow: #F4E7C3;--dec-light-purple: #DACFF9;--dec-light-green: #E4F5E9;--dec-light-green2: #F1FFF3;--dec-light-pink: #FAE1EA;--dec-: #F4CBC1;--dec-lt-orange: #FAEFED;--dec-light-blue: #CFECF9;--dec-row-selection: #F1FDF8;--dec-row-selection2: #F2FBFF;--dec-row-lines: #D3E1E9;--text-white: #FFFFFF;--text-muted: #6A737D;--text-black: #181F33;--MR-solid-blue2:#C8D5F6;--MR-solid-purple:#C9C3FB;--MR-solid-orange:#EEAC9F;--MR-solid-green:#ACDADA;--MR-solid-brown:#E8C8AF;--MR-solid-yellow:#FFEFC7;--MR-solid-blue:#BBE6FF;--MR-solid-pink:#FFC6F2;--tr-hover:#F0F3FA;--tr-pressed:#DAE1F3;--brand-primary: #0937B2;--brand-primary-light: #3C68D0;--brand-primary-dark: #062A99;--brand-primary-darker: #041F80;--brand-primary-lighter: #638FE7;--brand-primary-lightest: #CBDDFB;--brand-primary-hover: #F0F3FA;--brand-primary-active: #DAE1F3;--brand-secondary: #ED711C;--brand-secondary-light: #F09E65;--brand-secondary-dark: #B23600;--brand-secondary-lighter: #FFC6F2;--brand-accent: #10ADAE;--brand-accent-light: #16CBBC;--brand-accent-dark: #035F6B;--brand-accent-lighter: #ACDADA;--brand-success: #38AF49;--brand-success-light: #4CAF50;--brand-success-dark: #216531;--brand-success-lighter: #E4F5E9;--brand-success-lightest: #F1FFF3;--brand-error: #B00020;--brand-error-light: #F04E4E;--brand-error-dark: #A60060;--brand-error-lighter: #FAE1EA;--brand-error-lightest: #FDF2F2;--brand-warning: #FF9D00;--brand-warning-light: #D4900C;--brand-warning-dark: #624000;--brand-warning-lighter: #F4E7C3;--brand-warning-lightest: #FAEFED;--brand-info: #0091FF;--brand-info-light: #35A1FF;--brand-info-dark: #0087B2;--brand-info-lighter: #CFECF9;--text-primary: #181F33;--text-secondary: #6A737D;--text-tertiary: #929DAB;--text-disabled: #929DAB;--text-primary-87: rgba(24, 31, 51, .87);--text-primary-60: rgba(24, 31, 51, .6);--text-primary-38: rgba(24, 31, 51, .38);--text-primary-12: rgba(24, 31, 51, .12);--bg-primary: #FFFFFF;--bg-secondary: #FAFAFA;--bg-tertiary: #F5F5F5;--bg-overlay: rgba(0, 0, 0, .32);--bg-overlay-light: rgba(0, 0, 0, .12);--bg-overlay-lighter: rgba(0, 0, 0, .08);--bg-overlay-lightest: rgba(0, 0, 0, .04);--border-primary: #E0E0E0;--border-secondary: #D6DCE2;--border-tertiary: #C8CDD3;--border-light: #F1F4F8;--border-primary-12: rgba(0, 0, 0, .12);--border-primary-08: rgba(0, 0, 0, .08);--border-primary-06: rgba(0, 0, 0, .06);--shadow-primary: rgba(0, 0, 0, .12);--shadow-secondary: rgba(0, 0, 0, .08);--shadow-tertiary: rgba(0, 0, 0, .04);--shadow-light: rgba(0, 0, 0, .06);--status-available: #929DAB;--status-unavailable: #CCD3DA;--status-hotseat: #857BFF;--status-multiteam: #10ADAE;--status-selected: #10ADAE;--status-upcoming: #D4900C;--status-room: #38AF49;--status-room-booked: #B23600;--status-room-unavailable: #181F33;--team-color-1: #F8C52E;--team-color-2: #FA8E20;--team-color-3: #987CDD;--team-color-4: #16CBBC;--team-color-5: #E65010;--team-color-6: #A60060;--team-color-7: #ED323B;--team-color-8: #35A1FF;--team-color-9: #80D348}.filter-panel-container{display:flex;flex-direction:column;height:100%;max-width:100%;min-width:20rem;position:absolute;right:0;background:var(--bg-primary, #FFFFFF);top:0;z-index:999;box-shadow:0 0 5px #000000a6;transition:all .3s ease}.filter-panel-container .panel-header{display:flex;flex-direction:row;justify-content:space-between;align-items:center;font-weight:700;margin:0 1rem;flex-basis:5%}.filter-panel-container .panel-header span{font-size:1.25rem}.filter-panel-container .panel-header .close-icon{cursor:pointer;border-radius:50%;transform:scale(1.4);padding:.3rem;transition:all .3s ease}.filter-panel-container .panel-header .close-icon:hover{background:var(--bg-tertiary, #F5F5F5)}.filter-panel-container .panel-header .close-icon:active{background:var(--border-primary, #E0E0E0)}.filter-panel-container .mat-divider.horizontal{margin:1rem}.filters{display:flex;flex-direction:column;flex:1;row-gap:.5rem;overflow:auto;padding:0 1rem}.filters .filter{display:flex;flex-direction:column}.filters .filter .filter-title{color:var(--text-secondary, #6A737D);font-size:.875rem;font-weight:700;line-height:20px;letter-spacing:.25px}.filters .filter .checkbox-row{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding:.8rem 0}.filters .filter .checkbox-row .checkbox-container{display:flex;flex-direction:row;align-items:center;gap:.5rem}.filters .filter .checkbox-row .checkbox-label{display:block;width:8rem}.filters .filter .checkbox-row ::ng-deep .mat-checkbox-inner-container{width:20px;height:20px}.filters .filter .checkbox-row ::ng-deep .mat-checkbox-frame{border-radius:5px}.filters .filter .multiselect-filter,.filters .filter mis-input{padding:.7rem 0}.horizontal-divider{display:block;width:100%;height:1px;margin:.5rem 0;background:var(--border-primary, #E0E0E0)}.first{margin-top:0}.actions{display:flex;flex-direction:row;justify-content:end;align-items:center;gap:1rem;border-top:1px solid var(--border-primary, #E0E0E0);flex-basis:4%;padding:.5rem}.actions button{font-weight:700;border-radius:.5rem;width:6rem}.no-padding ::ng-deep .container{padding:0!important}.range-container{display:flex;justify-content:space-between;padding:.8rem 0}.range-container .range-inner-container{display:flex;flex-direction:column}.range-container .range-inner-container input{height:2.2rem;outline:none;border-radius:.375rem;border:1px solid var(--border-primary, #E0E0E0);width:8rem;padding:0 .5rem}.range-container .range-inner-container span{margin-bottom:.2rem}input.ng-invalid.ng-touched{border:1px solid var(--brand-error, #B00020);background-color:var(--brand-error-lightest, #FDF2F2)}\n"] }]
500
+ args: [{ selector: 'mis-filter-panel', animations: [slideFromRight], template: "<div class=\"filter-panel-container\" *ngIf=\"show()\" @slideFromRight>\n <div class=\"panel-header\">\n <span>Filters</span>\n <svg class=\"close-icon\" (click)=\"closePanel()\" width=\"25\" height=\"25\" viewBox=\"0 0 25 25\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <g id=\"ic-navigation-cancel-24\">\n <path id=\"Union\" fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M8.60468 6.64355C8.09036 6.12923 7.25649 6.12923 6.74218 6.64355C6.22787 7.15786 6.22787 7.99173 6.74218 8.50604L10.4938 12.2576L6.7431 16.0083C6.22879 16.5226 6.22879 17.3564 6.7431 17.8708C7.25742 18.3851 8.09129 18.3851 8.60560 17.8708L12.3562 14.1201L16.1068 17.8707C16.6211 18.3850 17.4550 18.3850 17.9693 17.8707C18.4836 17.3564 18.4836 16.5225 17.9693 16.0082L14.2187 12.2576L17.9702 8.50613C18.4845 7.99181 18.4845 7.15794 17.9702 6.64363C17.4559 6.12932 16.6220 6.12932 16.1077 6.64363L12.3562 10.3951L8.60468 6.64355Z\" fill=\"#181F33\" />\n </g>\n </svg>\n </div>\n \n <div class=\"horizontal-divider first\"></div>\n \n <div class=\"filters\" [formGroup]=\"filterForm\">\n <ng-container *ngFor=\"let filter of config(); let last = last\">\n <div class=\"filter\" *ngIf=\"!filter.hidden\">\n <span class=\"filter-title\">{{filter.title}}</span>\n <ng-container *ngIf=\"filter.type === 'multiSelect'\">\n <div class=\"multiselect-filter\">\n <mis-multi-select-dropdown class=\"no-padding\" [label]=\"filter.placeholder || 'Select'\" [selectedItems]=\"filterForm.get(filter.key)?.value || []\" (onChange)=\"handleSelect($event, filter.key, filter)\" [data]=\"filter.options\" [searchEnabled]=\"true\"\n [showSelectedCount]=\"true\" [enableSelectAll]=\"true\"\n [hideApplyButton]=\"false\" width=\"100%\" height=\"44px\"></mis-multi-select-dropdown>\n </div>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'select'\">\n <div class=\"multiselect-filter\">\n <mis-dropdown [data]=\"filter.options\" [searchEnabled]=\"true\" width=\"100%\" height=\"44px\"\n (onChange)=\"handleSelect($event, filter.key, filter)\" [selectedItem]=\"filterForm.get(filter.key)?.value\">\n </mis-dropdown>\n </div>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'checkbox'\">\n <div class=\"checkbox-row\">\n <div *ngFor=\"let option of filter.options\" class=\"checkbox-container\">\n <mis-checkbox [type]=\"'Default'\" [checked]=\"filterForm.get(filter.key)?.value?.includes(option.value)\" (valueChange)=\"handleCheckbox($event, filter.key, option.value, filter)\"></mis-checkbox>\n <span class=\"checkbox-label\">{{option.label}}</span>\n </div>\n </div>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'datePicker'\">\n <mis-input type=\"rounded\">\n <input misTzDp misInput type=\"text\" readonly class=\"mis-input\" [dpConfig]=\"filter.datePickerConfig\" [placeholder]=\"filterForm.get(filter.key)?.value || filter.placeholder || 'Select'\" [value]=\"filterForm.get(filter.key)?.value || filter.placeholder || 'Select'\" (dateChange)=\"onDateChange($event, filter.key, filter)\" [selectedDate]=\"filterForm.get(filter.key)?.value\" [positionX]=\"'end'\" [offsetX]=\"-10\">\n </mis-input>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'dateRangePicker'\">\n <mis-input type=\"rounded\">\n <input misTzDrp misInput type=\"text\" class=\"mis-input\" readonly\n [placeholder]=\"(!dateRangeSelectedDates().startDate && !dateRangeSelectedDates().endDate) ? (filter.placeholder || 'Select') : dateRangeSelectedDates().startDate + ' - ' + dateRangeSelectedDates().endDate\"\n [value]=\"(!dateRangeSelectedDates().startDate && !dateRangeSelectedDates().endDate) ? (filter.placeholder || 'Select') : dateRangeSelectedDates().startDate + ' - ' + dateRangeSelectedDates().endDate\" [positionX]=\"'start'\"\n [positionY]=\"'top'\" [selectedDates]=\"dateRangeSelectedDates()\" (dateChange)=\"onDateChange($event, filter.key, filter)\"\n [dpConfig]=\"filter.dateRangePickerConfig\" />\n </mis-input>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'text'\">\n <mis-input type=\"rounded\">\n <input misInput type=\"text\" class=\"input\" [placeholder]=\"filter.placeholder || 'Type here'\" [formControlName]=\"filter.key\">\n </mis-input>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'number'\">\n <mis-input type=\"rounded\">\n <input misInput type=\"number\" class=\"input\" [placeholder]=\"filter.placeholder || 'Type here'\" [formControlName]=\"filter.key\">\n </mis-input>\n </ng-container>\n <ng-container *ngIf=\"filter.type === 'range'\">\n <div class=\"range-container\" [formGroup]=\"filterForm.get(filter.key)\">\n <div class=\"range-inner-container\">\n <span>{{ filter?.options?.[0]?.label || 'Min' }}</span>\n <input\n misInput\n type=\"number\"\n class=\"input\"\n [placeholder]=\"filter.placeholder || 'Type here'\"\n formControlName=\"min\"\n />\n </div>\n <div class=\"range-inner-container\">\n <span>{{ filter?.options?.[1]?.label || 'Max' }}</span>\n <input\n misInput\n type=\"number\"\n class=\"input\"\n [placeholder]=\"filter.placeholder || 'Type here'\"\n formControlName=\"max\"\n [min]=\"filterForm.get(filter.key)?.get('min')?.value || 0\"\n />\n </div>\n </div>\n </ng-container>\n <div class=\"horizontal-divider\" *ngIf=\"!last\"></div>\n </div>\n </ng-container>\n </div>\n \n <div class=\"actions\">\n <mis-button [name]=\"'Clear All'\" [size]=\"'Small'\" [type]=\"'Text'\" (click)=\"resetFilters()\"></mis-button>\n <mis-button [name]=\"'Apply'\" [size]=\"'Small'\" [type]=\"'Solid'\" (click)=\"applyFilters()\" [disabled]=\"filterForm.invalid\"></mis-button>\n </div>\n </div>", styles: [":root{--pmry-200: #99BAF7;--pmry-100: #CBDDFB;--pmry-500: #0937B2;--pmry-400: #3C68D0;--pmry-600: #062A99;--pmry-700: #041F80;--pmry-300: #638FE7;--pmry-800: #021567;--pmry-900: #010F55;--sec-d-purple: #40447F;--sec-maroon: #6B034E;--sec-mud-red: #B23600;--sec-orange: #ED711C;--sec-purple: #815FD5;--sec-teal: #10ADAE;--sec-yellow: #D4900C;--sec-green: #547F40;--sec-bright-green: #27D22E;--sec-dark-teal: #035F6B;--sec-chocolate: #7C2F33;--sec-rube-pink: #C13D6D;--sec-cerulean: #0087B2;--sem-error: #B00020;--sem-info: #0091FF;--sem-warning: #FF9D00;--sem-success: #38AF49;--grey-bg-1: #FAFAFA;--grey-bg: #F5F5F5;--grey-seperators: #E0E0E0;--grey-disabled: #C8CDD3;--grey-hover: #F5F7FC;--grey-pressed: #E6EBF7;--grey-row: #F5F7FC;--dec-light-yellow: #F4E7C3;--dec-light-purple: #DACFF9;--dec-light-green: #E4F5E9;--dec-light-green2: #F1FFF3;--dec-light-pink: #FAE1EA;--dec-: #F4CBC1;--dec-lt-orange: #FAEFED;--dec-light-blue: #CFECF9;--dec-row-selection: #F1FDF8;--dec-row-selection2: #F2FBFF;--dec-row-lines: #D3E1E9;--text-white: #FFFFFF;--text-muted: #6A737D;--text-black: #181F33;--MR-solid-blue2:#C8D5F6;--MR-solid-purple:#C9C3FB;--MR-solid-orange:#EEAC9F;--MR-solid-green:#ACDADA;--MR-solid-brown:#E8C8AF;--MR-solid-yellow:#FFEFC7;--MR-solid-blue:#BBE6FF;--MR-solid-pink:#FFC6F2;--tr-hover:#F0F3FA;--tr-pressed:#DAE1F3;--brand-primary: #0937B2;--brand-primary-light: #3C68D0;--brand-primary-dark: #062A99;--brand-primary-darker: #041F80;--brand-primary-lighter: #638FE7;--brand-primary-lightest: #CBDDFB;--brand-primary-hover: #F0F3FA;--brand-primary-active: #DAE1F3;--brand-secondary: #ED711C;--brand-secondary-light: #F09E65;--brand-secondary-dark: #B23600;--brand-secondary-lighter: #FFC6F2;--brand-accent: #10ADAE;--brand-accent-light: #16CBBC;--brand-accent-dark: #035F6B;--brand-accent-lighter: #ACDADA;--brand-success: #38AF49;--brand-success-light: #4CAF50;--brand-success-dark: #216531;--brand-success-lighter: #E4F5E9;--brand-success-lightest: #F1FFF3;--brand-error: #B00020;--brand-error-light: #F04E4E;--brand-error-dark: #A60060;--brand-error-lighter: #FAE1EA;--brand-error-lightest: #FDF2F2;--brand-warning: #FF9D00;--brand-warning-light: #D4900C;--brand-warning-dark: #624000;--brand-warning-lighter: #F4E7C3;--brand-warning-lightest: #FAEFED;--brand-info: #0091FF;--brand-info-light: #35A1FF;--brand-info-dark: #0087B2;--brand-info-lighter: #CFECF9;--text-primary: #181F33;--text-secondary: #6A737D;--text-tertiary: #929DAB;--text-disabled: #929DAB;--text-primary-87: rgba(24, 31, 51, .87);--text-primary-60: rgba(24, 31, 51, .6);--text-primary-38: rgba(24, 31, 51, .38);--text-primary-12: rgba(24, 31, 51, .12);--bg-primary: #FFFFFF;--bg-secondary: #FAFAFA;--bg-tertiary: #F5F5F5;--bg-overlay: rgba(0, 0, 0, .32);--bg-overlay-light: rgba(0, 0, 0, .12);--bg-overlay-lighter: rgba(0, 0, 0, .08);--bg-overlay-lightest: rgba(0, 0, 0, .04);--border-primary: #E0E0E0;--border-secondary: #D6DCE2;--border-tertiary: #C8CDD3;--border-light: #F1F4F8;--border-primary-12: rgba(0, 0, 0, .12);--border-primary-08: rgba(0, 0, 0, .08);--border-primary-06: rgba(0, 0, 0, .06);--shadow-primary: rgba(0, 0, 0, .12);--shadow-secondary: rgba(0, 0, 0, .08);--shadow-tertiary: rgba(0, 0, 0, .04);--shadow-light: rgba(0, 0, 0, .06);--status-available: #929DAB;--status-unavailable: #CCD3DA;--status-hotseat: #857BFF;--status-multiteam: #10ADAE;--status-selected: #10ADAE;--status-upcoming: #D4900C;--status-room: #38AF49;--status-room-booked: #B23600;--status-room-unavailable: #181F33;--team-color-1: #F8C52E;--team-color-2: #FA8E20;--team-color-3: #987CDD;--team-color-4: #16CBBC;--team-color-5: #E65010;--team-color-6: #A60060;--team-color-7: #ED323B;--team-color-8: #35A1FF;--team-color-9: #80D348}.filter-panel-container{display:flex;flex-direction:column;height:100%;max-width:100%;min-width:20rem;position:absolute;right:0;background:var(--bg-primary, #FFFFFF);top:0;z-index:999;box-shadow:0 0 5px #000000a6;transition:all .3s ease}.filter-panel-container .panel-header{display:flex;flex-direction:row;justify-content:space-between;align-items:center;font-weight:700;margin:0 1rem;flex-basis:5%}.filter-panel-container .panel-header span{font-size:1.25rem}.filter-panel-container .panel-header .close-icon{cursor:pointer;border-radius:50%;transform:scale(1.4);padding:.3rem;transition:all .3s ease}.filter-panel-container .panel-header .close-icon:hover{background:var(--bg-tertiary, #F5F5F5)}.filter-panel-container .panel-header .close-icon:active{background:var(--border-primary, #E0E0E0)}.filter-panel-container .mat-divider.horizontal{margin:1rem}.filters{display:flex;flex-direction:column;flex:1;row-gap:.5rem;overflow:auto;padding:0 1rem}.filters .filter{display:flex;flex-direction:column}.filters .filter .filter-title{color:var(--text-secondary, #6A737D);font-size:.875rem;font-weight:700;line-height:20px;letter-spacing:.25px}.filters .filter .checkbox-row{display:flex;flex-direction:row;justify-content:space-between;align-items:center;padding:.8rem 0}.filters .filter .checkbox-row .checkbox-container{display:flex;flex-direction:row;align-items:center;gap:.5rem}.filters .filter .checkbox-row .checkbox-label{display:block;width:8rem}.filters .filter .checkbox-row ::ng-deep .mat-checkbox-inner-container{width:20px;height:20px}.filters .filter .checkbox-row ::ng-deep .mat-checkbox-frame{border-radius:5px}.filters .filter .multiselect-filter,.filters .filter mis-input{padding:.7rem 0}.horizontal-divider{display:block;width:100%;height:1px;margin:.5rem 0;background:var(--border-primary, #E0E0E0)}.first{margin-top:0}.actions{display:flex;flex-direction:row;justify-content:end;align-items:center;gap:1rem;border-top:1px solid var(--border-primary, #E0E0E0);flex-basis:4%;padding:.5rem}.actions button{font-weight:700;border-radius:.5rem;width:6rem}.no-padding ::ng-deep .container{padding:0!important}.range-container{display:flex;justify-content:space-between;padding:.8rem 0}.range-container .range-inner-container{display:flex;flex-direction:column}.range-container .range-inner-container input{height:2.2rem;outline:none;border-radius:.375rem;border:1px solid var(--border-primary, #E0E0E0);width:8rem;padding:0 .5rem}.range-container .range-inner-container span{margin-bottom:.2rem}input.ng-invalid.ng-touched{border:1px solid var(--brand-error, #B00020);background-color:var(--brand-error-lightest, #FDF2F2)}\n"] }]
397
501
  }], () => [{ type: i1.HasValuePipe }], null); })();
398
502
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(FilterPanelComponent, { className: "FilterPanelComponent" }); })();
399
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-panel.component.js","sourceRoot":"","sources":["../../../../../projects/mis-components/filter/filter-panel/filter-panel.component.ts","../../../../../projects/mis-components/filter/filter-panel/filter-panel.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, signal, WritableSignal, computed, input, output } from '@angular/core';\nimport { slideFromRight } from '../animations/slideFromRight';\nimport { FormControl, FormGroup } from '@angular/forms';\nimport { IDatePickerConfig } from 'mis-crystal-design-system/datepicker_v2';\nimport { IRSelectedDatesConfig } from 'mis-crystal-design-system/specificdatepicker';\nimport { IDatePickerConfig as IDateRangePickerConfig } from \"mis-crystal-design-system/daterangepicker_v2\";\nimport { HasValuePipe } from '../has-value.pipe';\n\n\nexport interface FilterPanelConfig {\n  key: string;\n  title: string;\n  type: 'multiSelect' | 'select' | 'datePicker' | 'dateRangePicker' | 'checkbox' | 'radio' | 'text' | 'number' | 'range';\n  options?: Array<{\n    label: string;\n    value: string;\n    data?: any[];\n  }>;\n  placeholder?: string;\n  hidden?: boolean;\n  datePickerConfig?: IDatePickerConfig;\n  dateRangePickerConfig?: IDateRangePickerConfig;\n  onChange?: (event: any, config?: FilterPanelConfig[], formValue?: any) => void;\n  defaultValue?: any;\n  selectedValue?: any;\n}\n\n@Component({\n  selector: 'mis-filter-panel',\n  templateUrl: './filter-panel.component.html',\n  styleUrls: ['./filter-panel.component.scss'],\n  animations: [slideFromRight]\n})\nexport class FilterPanelComponent implements OnInit {\n  constructor(private hasValue: HasValuePipe) {}\n\n  // Signal inputs replacing @Input()\n  public show = input<boolean>(false);\n  public config = input.required<FilterPanelConfig[]>();\n  public emitFiltersAfterSettingNewValues = input<boolean>(false);\n\n  // Signal outputs replacing @Output()\n  public onClose = output();\n  public onApply = output<{ filterData: any, filterCount: number }>();\n\n  filterForm: FormGroup = new FormGroup({});\n  lastAppliedData: any;\n\n  public dateRangeSelectedDates: WritableSignal<IRSelectedDatesConfig> = signal({\n    startDate: '',\n    endDate: '',\n  });\n\n  // Method to calculate filter count (not a computed signal because form values aren't reactive)\n  getFilterCount(): number {\n    let count = 0;\n    const formValue = this.filterForm.value;\n    \n    this.config().forEach((filter: FilterPanelConfig) => {\n      const value = formValue[filter.key];\n      \n      // Special handling for range type - only count if at least one value is set\n      if (filter.type === 'range') {\n        if (value && (value.min !== null || value.max !== null)) {\n          count++;\n        }\n        return;\n      }\n      \n      // Special handling for multiSelect/checkbox - check array length directly\n      if (filter.type === 'multiSelect' || filter.type === 'checkbox') {\n        if (Array.isArray(value) && value.length > 0) {\n          count++;\n        }\n        return;\n      }\n      \n      // For other types, use hasValue pipe\n      if (this.hasValue.transform(value)) {\n        count++;\n      }\n    });\n    \n    return count;\n  }\n\n  ngOnInit() {\n    // Access the config signal value by calling it like a function\n    this.initializeFormControls(this.config());\n  }\n\n  initializeFormControls(config: FilterPanelConfig[]) {\n    this.filterForm = new FormGroup({});\n    config.forEach((filter: FilterPanelConfig) => {\n      let control: any;\n      if (filter.type === 'range') {\n        control = new FormGroup({\n          min: new FormControl(null),\n          max: new FormControl(null),\n        }, {\n          validators: (group: FormGroup) => {\n            const min = group.get('min').value;\n            const max = group.get('max').value;\n            if (min !== null && max !== null && min > max) {\n              return { rangeError: 'Min value should be less than max value' };\n            }\n            return null;\n          }\n        });\n      } else if (filter.type === 'multiSelect' || filter.type === 'checkbox') {\n        control = new FormControl([]);\n      } else if (filter.type === 'select') {\n        control = new FormControl('');\n      } else {\n        control = new FormControl(null);\n      }\n      if (this.hasValue.transform(filter.defaultValue)) {\n        control.setValue(filter.defaultValue);\n      }\n      this.filterForm.addControl(filter.key, control);\n    });\n  }\n\n  closePanel() {\n    if (this.lastAppliedData) {\n      this.filterForm.setValue(this.lastAppliedData);\n    } else {\n      this.clearFormValues();\n    }\n    // Emit the close event using the signal output\n    this.onClose.emit();\n  }\n\n  applyFilters() {\n    if (this.filterForm.invalid) {\n      this.filterForm.markAllAsTouched();\n      return;\n    }\n  \n    this.lastAppliedData = { ...this.filterForm.value };\n    // Emit the apply event with the filter data using the signal output\n    this.onApply.emit({\n      filterData: this.filterForm.value,\n      filterCount: this.getFilterCount()\n    });\n    this.closePanel();\n  }\n\n  handleSelect(event: any, filterKey: string, filter: FilterPanelConfig) {\n    this.filterForm.get(filterKey).setValue(event);\n    if (filter.onChange) {\n      filter.onChange(event, this.config(), this.filterForm.value);\n    }\n  }\n\n  onDateChange(event: any, filterKey: string, filter: FilterPanelConfig) {\n    this.filterForm.get(filterKey).setValue(event);\n    if (typeof event === 'object') {\n      this.dateRangeSelectedDates.set({\n        startDate: event.startDate,\n        endDate: event.endDate,\n      });\n    }\n  }\n\n  handleCheckbox(event: any, filterKey: string, checkboxValue: string, filter: FilterPanelConfig) {\n    const currentValues = this.filterForm.get(filterKey).value;\n    if (event.value) {\n      this.filterForm.get(filterKey).setValue([...currentValues, checkboxValue]);\n    } else {\n      this.filterForm.get(filterKey).setValue(currentValues.filter((value: string) => value !== checkboxValue));\n    }\n    if (filter.onChange) {\n      filter.onChange(event, this.config(), this.filterForm.value);\n    }\n  }\n\n  clearFormValues() {\n    const resetValues: any = {};\n    this.config().forEach((filter: FilterPanelConfig) => {\n      let defaultValue: any = filter.defaultValue || null;\n      if (filter.type === 'multiSelect' || filter.type === 'checkbox') {\n        defaultValue = filter.defaultValue || [];\n      }\n      if (filter.type === 'range') {\n        defaultValue = filter.defaultValue || { min: null, max: null };\n      }\n      resetValues[filter.key] = defaultValue;\n    });\n    this.filterForm.patchValue(resetValues);\n  }\n\n  resetFilters() {\n    this.clearFormValues();\n    this.applyFilters();\n  }\n\n  setFilterValue(config: FilterPanelConfig[]) {\n    let anyValueSet = false;\n    for (const filter of config) {\n      if (filter?.selectedValue) {\n        this.filterForm.get(filter.key).setValue(filter.selectedValue);\n        anyValueSet = true;\n      }\n    }\n    if (anyValueSet && this.emitFiltersAfterSettingNewValues()) {\n      this.applyFilters();\n    }\n  }\n}\n\n","<div class=\"filter-panel-container\" *ngIf=\"show()\" @slideFromRight>\n  <div class=\"panel-header\">\n      <span>Filters</span>\n      <svg class=\"close-icon\" (click)=\"closePanel()\" width=\"25\" height=\"25\" viewBox=\"0 0 25 25\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n          <g id=\"ic-navigation-cancel-24\">\n              <path id=\"Union\" fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M8.60468 6.64355C8.09036 6.12923 7.25649 6.12923 6.74218 6.64355C6.22787 7.15786 6.22787 7.99173 6.74218 8.50604L10.4938 12.2576L6.7431 16.0083C6.22879 16.5226 6.22879 17.3564 6.7431 17.8708C7.25742 18.3851 8.09129 18.3851 8.60560 17.8708L12.3562 14.1201L16.1068 17.8707C16.6211 18.3850 17.4550 18.3850 17.9693 17.8707C18.4836 17.3564 18.4836 16.5225 17.9693 16.0082L14.2187 12.2576L17.9702 8.50613C18.4845 7.99181 18.4845 7.15794 17.9702 6.64363C17.4559 6.12932 16.6220 6.12932 16.1077 6.64363L12.3562 10.3951L8.60468 6.64355Z\" fill=\"#181F33\" />\n          </g>\n      </svg>\n  </div>\n\n  <div class=\"horizontal-divider first\"></div>\n\n  <div class=\"filters\" [formGroup]=\"filterForm\">\n      <ng-container *ngFor=\"let filter of config(); let last = last\">\n          <div class=\"filter\" *ngIf=\"!filter.hidden\">\n              <span class=\"filter-title\">{{filter.title}}</span>\n              <ng-container *ngIf=\"filter.type === 'multiSelect'\">\n                  <div class=\"multiselect-filter\">\n                      <mis-multi-select-dropdown class=\"no-padding\" [label]=\"filter.placeholder || 'Select'\" [selectedItems]=\"filterForm.get(filter.key).value\" (onChange)=\"handleSelect($event, filter.key, filter)\" [data]=\"filter.options\" [searchEnabled]=\"true\"\n                          [showSelectedCount]=\"true\" [enableSelectAll]=\"true\"\n                          [hideApplyButton]=\"false\" width=\"100%\" height=\"44px\"></mis-multi-select-dropdown>\n                  </div>\n              </ng-container>\n              <ng-container *ngIf=\"filter.type === 'select'\">\n                  <div class=\"multiselect-filter\">\n                      <mis-dropdown [data]=\"filter.options\" [searchEnabled]=\"true\" width=\"100%\" height=\"44px\"\n                              (onChange)=\"handleSelect($event, filter.key, filter)\" [selectedItem]=\"filterForm.get(filter.key).value\">\n                      </mis-dropdown>\n                  </div>\n              </ng-container>\n              <ng-container *ngIf=\"filter.type === 'checkbox'\">\n                  <div class=\"checkbox-row\">\n                      <div *ngFor=\"let option of filter.options\" class=\"checkbox-container\">\n                          <mis-checkbox [type]=\"'Default'\" [checked]=\"filterForm.get(filter.key).value?.includes(option.value)\" (valueChange)=\"handleCheckbox($event, filter.key, option.value, filter)\"></mis-checkbox>\n                          <span class=\"checkbox-label\">{{option.label}}</span>\n                      </div>\n                  </div>\n              </ng-container>\n              <ng-container *ngIf=\"filter.type === 'datePicker'\">\n                  {{filter.placeholder}}\n                  <mis-input type=\"rounded\">\n                      <input misTzDp misInput type=\"text\" readonly class=\"mis-input\" [dpConfig]=\"filter.datepickerConfig\" [placeholder]=\"filterForm.get(filter.key).value ? filterForm.get(filter.key).value : (filter.placeholder || 'Select')\" [value]=\"filterForm.get(filter.key).value ? filterForm.get(filter.key).value : (filter.placeholder || 'Select')\" (dateChange)=\"onDateChange($event, filter.key, filter)\" [selectedDate]=\"filterForm.get(filter.key).value\" [positionX]=\"'end'\" [offsetX]=\"-10\">\n                  </mis-input>\n              </ng-container>\n              <ng-container *ngIf=\"filter.type === 'dateRangePicker'\">\n                  <mis-input type=\"rounded\">\n                      <input misTzDrp misInput type=\"text\" class=\"mis-input\" readonly\n                          [placeholder]=\"(!dateRangeSelectedDates().startDate && !dateRangeSelectedDates().endDate) ? (filter.placeholder || 'Select') : dateRangeSelectedDates().startDate + ' - ' + dateRangeSelectedDates().endDate\"\n                          [value]=\"(!dateRangeSelectedDates().startDate && !dateRangeSelectedDates().endDate) ? (filter.placeholder || 'Select') : dateRangeSelectedDates().startDate + ' - ' + dateRangeSelectedDates().endDate\" [positionX]=\"'start'\"\n                          [positionY]=\"'top'\" [selectedDates]=\"dateRangeSelectedDates()\" (dateChange)=\"onDateChange($event, filter.key, filter)\"\n                          [dpConfig]=\"filter.dateRangePickerConfig\" />\n                  </mis-input>\n              </ng-container>\n              <ng-container *ngIf=\"filter.type === 'text'\">\n                  <mis-input type=\"rounded\">\n                      <input misInput type=\"text\" class=\"input\" [placeholder]=\"filter.placeholder || 'Type here'\" [formControlName]=\"filter.key\">\n                  </mis-input>\n              </ng-container>\n              <ng-container *ngIf=\"filter.type === 'number'\">\n                  <mis-input type=\"rounded\">\n                      <input misInput type=\"number\" class=\"input\" [placeholder]=\"filter.placeholder || 'Type here'\" [formControlName]=\"filter.key\">\n                  </mis-input>\n              </ng-container>\n              <ng-container *ngIf=\"filter.type === 'range'\">\n                  <div class=\"range-container\" [formGroup]=\"filterForm.get(filter.key)\">\n                      <div class=\"range-inner-container\">\n                          <span>{{ filter?.options?.[0]?.label || 'Min' }}</span>\n                          <input\n                              misInput\n                              type=\"number\"\n                              class=\"input\"\n                              [placeholder]=\"filter.placeholder || 'Type here'\"\n                              formControlName=\"min\"\n                          />\n                      </div>\n                      <div class=\"range-inner-container\">\n                          <span>{{ filter?.options?.[1]?.label || 'Max' }}</span>\n                          <input\n                              misInput\n                              type=\"number\"\n                              class=\"input\"\n                              [placeholder]=\"filter.placeholder || 'Type here'\"\n                              formControlName=\"max\"\n                              [min]=\"filterForm.get?.(filter.key)?.get('min')?.value || 0\"\n                          />\n                      </div>\n                  </div>\n              </ng-container>\n              <div class=\"horizontal-divider\" *ngIf=\"!last\"></div>\n          </div>\n      </ng-container>\n  </div>\n\n  <div class=\"actions\">\n      <mis-button [name]=\"'Clear All'\" [size]=\"'Small'\" [type]=\"'Text'\" (click)=\"resetFilters()\"></mis-button>\n      <mis-button [name]=\"'Apply'\" [size]=\"'Small'\" [type]=\"'Solid'\" (click)=\"applyFilters()\" [disabled]=\"filterForm.invalid\"></mis-button>\n  </div>\n</div>\n\n"]}
503
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-panel.component.js","sourceRoot":"","sources":["../../../../../projects/mis-components/filter/filter-panel/filter-panel.component.ts","../../../../../projects/mis-components/filter/filter-panel/filter-panel.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  OnDestroy,\n  effect,\n  signal,\n  computed,\n  input,\n  output,\n  WritableSignal\n} from '@angular/core';\nimport { FormControl, FormGroup, AbstractControl, ValidatorFn, ValidationErrors } from '@angular/forms';\nimport { Subscription } from 'rxjs';\nimport { slideFromRight } from '../animations/slideFromRight';\nimport { IDatePickerConfig } from 'mis-crystal-design-system/datepicker_v2';\nimport { IRSelectedDatesConfig } from 'mis-crystal-design-system/specificdatepicker';\nimport { IDatePickerConfig as IDateRangePickerConfig } from 'mis-crystal-design-system/daterangepicker_v2';\nimport { HasValuePipe } from '../has-value.pipe';\n\nexport interface FilterOption {\n  label: string;\n  value: string;\n  data?: any[];\n}\n\nexport type FilterType =\n  | 'multiSelect'\n  | 'select'\n  | 'datePicker'\n  | 'dateRangePicker'\n  | 'checkbox'\n  | 'radio'\n  | 'text'\n  | 'number'\n  | 'range';\n\nexport interface FilterPanelConfig {\n  key: string;\n  title: string;\n  type: FilterType;\n  options?: FilterOption[];\n  placeholder?: string;\n  hidden?: boolean;\n  datePickerConfig?: IDatePickerConfig;\n  dateRangePickerConfig?: IDateRangePickerConfig;\n  onChange?: (event: any, config?: FilterPanelConfig[], formValue?: any) => void;\n  defaultValue?: any;\n  selectedValue?: any;\n}\n\n@Component({\n  selector: 'mis-filter-panel',\n  templateUrl: './filter-panel.component.html',\n  styleUrls: ['./filter-panel.component.scss'],\n  animations: [slideFromRight]\n})\nexport class FilterPanelComponent implements OnInit, OnDestroy {\n  private isInitialized = false;\n\n  constructor(private hasValue: HasValuePipe) {\n    // Effect to react to config changes - must allow signal writes since we update internal signals\n    effect(() => {\n      try {\n        const cfg = this.config();\n        if (cfg && Array.isArray(cfg) && cfg.length > 0) {\n          // Only initialize form if not already done, or if config structure changed\n          if (!this.isInitialized || this.hasConfigChanged(cfg)) {\n            this.initializeFormControls(cfg);\n            this.isInitialized = true;\n          }\n          // Always check for selectedValue changes\n          this.setFilterValue(cfg);\n        }\n      } catch (error) {\n        console.warn('FilterPanel: Error in config effect', error);\n      }\n    }, { allowSignalWrites: true });\n  }\n\n  /* --- signal-based Inputs / Outputs --- */\n  public show = input<boolean>(false);\n  public config = input.required<FilterPanelConfig[]>();\n  public emitFiltersAfterSettingNewValues = input<boolean>(false);\n\n  public onClose = output<void>();\n  public onApply = output<{ filterData: any; filterCount: number }>();\n\n  /* --- form + internal state --- */\n  filterForm: FormGroup = new FormGroup({});\n  private formSubscription?: Subscription;\n\n  // keep a signal snapshot of form value so computed can react\n  private _formValueSignal: WritableSignal<Record<string, any>> = signal({});\n\n  // last applied snapshot (signal so template/logic can read reliably)\n  public lastAppliedData: WritableSignal<Record<string, any> | null> = signal(null);\n\n  // date range readable for template\n  public dateRangeSelectedDates: WritableSignal<IRSelectedDatesConfig> = signal({\n    startDate: '',\n    endDate: ''\n  });\n\n  /* computed filterCount */\n  public filterCount = computed(() => {\n    const formValue = this._formValueSignal();\n    const cfg = this.config();\n    let count = 0;\n\n    for (const filter of cfg) {\n      const value = formValue[filter.key];\n\n      if (filter.type === 'range') {\n        if (value && (value.min !== null || value.max !== null)) {\n          count++;\n        }\n        continue;\n      }\n\n      if (filter.type === 'multiSelect' || filter.type === 'checkbox') {\n        if (Array.isArray(value) && value.length > 0) {\n          count++;\n        }\n        continue;\n      }\n\n      if (this.hasValue.transform(value)) {\n        count++;\n      }\n    }\n\n    return count;\n  });\n\n  /* --- Lifecycle --- */\n  ngOnInit(): void {\n    // subscribe form changes so computed/filterCount update\n    this.subscribeFormChanges();\n  }\n\n  ngOnDestroy(): void {\n    this.formSubscription?.unsubscribe();\n  }\n\n  /* --- Form init & helpers --- */\n  initializeFormControls(config: FilterPanelConfig[]): void {\n    // build a fresh form to match config\n    const newForm = new FormGroup({});\n\n    const rangeValidator: ValidatorFn = (group: AbstractControl): ValidationErrors | null => {\n      const min = (group.get('min') as FormControl)?.value;\n      const max = (group.get('max') as FormControl)?.value;\n      if (min !== null && max !== null && min > max) {\n        return { rangeError: 'Min value should be less than max value' };\n      }\n      return null;\n    };\n\n    for (const filter of config) {\n      let control: AbstractControl;\n\n      switch (filter.type) {\n        case 'range':\n          control = new FormGroup(\n            {\n              min: new FormControl(null),\n              max: new FormControl(null)\n            },\n            { validators: rangeValidator }\n          );\n          break;\n\n        case 'multiSelect':\n        case 'checkbox':\n          control = new FormControl(Array.isArray(filter.defaultValue) ? filter.defaultValue : []);\n          break;\n\n        case 'select':\n          control = new FormControl(filter.defaultValue ?? '');\n          break;\n\n        default:\n          control = new FormControl(filter.defaultValue ?? null);\n      }\n\n      if (this.hasValue.transform(filter.defaultValue)) {\n        control.setValue(filter.defaultValue);\n      }\n\n      newForm.addControl(filter.key, control);\n    }\n\n    // replace form safely\n    // preserve subscription so valueChanges continues to update _formValueSignal\n    this.filterForm = newForm;\n    // update signal snapshot immediately\n    this._formValueSignal.set({ ...this.filterForm.value });\n\n    // re-subscribe to new form's valueChanges\n    this.subscribeFormChanges();\n  }\n\n  private subscribeFormChanges(): void {\n    // unsubscribe previous subscription if any\n    this.formSubscription?.unsubscribe();\n\n    // subscribe to valueChanges; set snapshot signal\n    this.formSubscription = this.filterForm.valueChanges?.subscribe((value) => {\n      this._formValueSignal.set({ ...value });\n    });\n\n    // also set initial snapshot in case valueChanges doesn't emit immediately\n    this._formValueSignal.set({ ...this.filterForm.value });\n  }\n\n  private getControl(key: string) {\n    return this.filterForm.get(key);\n  }\n\n  /**\n   * Check if config structure has changed (new keys or removed keys)\n   * Used to determine if form needs to be rebuilt\n   */\n  private hasConfigChanged(newConfig: FilterPanelConfig[]): boolean {\n    const currentKeys = Object.keys(this.filterForm.controls).sort();\n    const newKeys = newConfig.map(f => f.key).sort();\n    \n    if (currentKeys.length !== newKeys.length) {\n      return true;\n    }\n    \n    return currentKeys.some((key, index) => key !== newKeys[index]);\n  }\n\n  /* --- Actions / UI handlers --- */\n  closePanel(): void {\n    const last = this.lastAppliedData();\n    if (last) {\n      try {\n        // prefer setValue (ensures shape matches); fallback to patchValue\n        this.filterForm.setValue(last);\n      } catch {\n        this.filterForm.patchValue(last);\n      }\n    } else {\n      this.clearFormValues();\n    }\n\n    // emit close event\n    this.onClose.emit();\n  }\n\n  applyFilters(): void {\n    if (this.filterForm.invalid) {\n      this.filterForm.markAllAsTouched();\n      return;\n    }\n\n    const snapshot = { ...this.filterForm.value };\n    this.lastAppliedData.set(snapshot);\n\n    this.onApply.emit({\n      filterData: snapshot,\n      filterCount: this.filterCount()\n    });\n\n    // consistent behavior with earlier implementation:\n    // hide panel (parent should read show() to close) and restore form state via closePanel\n    // Note: we don't mutate show() here; parent owns show signal\n    this.closePanel();\n  }\n\n  resetFilters(): void {\n    this.clearFormValues();\n    // call applyFilters to maintain previous behavior (validation + emit)\n    this.applyFilters();\n  }\n\n  /* --- Value setters --- */\n  handleSelect(event: any, filterKey: string, filter: FilterPanelConfig): void {\n    const ctrl = this.getControl(filterKey);\n    \n    // For multiSelect, extract values from array of objects (if needed)\n    let valueToSet = event;\n    if (filter.type === 'multiSelect' && Array.isArray(event)) {\n      // Check if it's an array of objects with 'value' property\n      if (event.length > 0 && typeof event[0] === 'object' && 'value' in event[0]) {\n        valueToSet = event.map((item: any) => item.value || item);\n      }\n    }\n    \n    ctrl?.setValue(valueToSet);\n    if (filter.onChange) {\n      // keep same callback contract: pass event, config and form snapshot\n      filter.onChange(event, this.config(), this.filterForm.value);\n    }\n  }\n\n  handleCheckbox(event: any, filterKey: string, checkboxValue: string, filter: FilterPanelConfig): void {\n    const ctrl = this.getControl(filterKey);\n    const current = Array.isArray(ctrl?.value) ? [...ctrl.value] : [];\n    if (event?.value) {\n      ctrl?.setValue([...current, checkboxValue]);\n    } else {\n      ctrl?.setValue(current.filter((v) => v !== checkboxValue));\n    }\n\n    if (filter.onChange) {\n      filter.onChange(event, this.config(), this.filterForm.value);\n    }\n  }\n\n  onDateChange(event: any, filterKey: string, filter: FilterPanelConfig): void {\n    const ctrl = this.getControl(filterKey);\n    ctrl?.setValue(event);\n\n    if (event && typeof event === 'object' && 'startDate' in event && 'endDate' in event) {\n      this.dateRangeSelectedDates.set({\n        startDate: event.startDate,\n        endDate: event.endDate\n      });\n    }\n  }\n\n  /* --- Clear / Set values helpers --- */\n  clearFormValues(): void {\n    const resets: Record<string, any> = {};\n\n    for (const filter of this.config()) {\n      let defaultValue: any = filter.defaultValue ?? null;\n      if (filter.type === 'multiSelect' || filter.type === 'checkbox') {\n        defaultValue = filter.defaultValue ?? [];\n      }\n      if (filter.type === 'range') {\n        defaultValue = filter.defaultValue ?? { min: null, max: null };\n      }\n      resets[filter.key] = defaultValue;\n    }\n\n    // patch to avoid shape mismatch errors\n    this.filterForm.patchValue(resets);\n    this._formValueSignal.set({ ...this.filterForm.value });\n  }\n\n  /**\n   * Applies filter.selectedValue when parent provides selectedValue.\n   * Called by the config effect (so runs on initial load and on config changes).\n   */\n  setFilterValue(config: FilterPanelConfig[]): void {\n    let anyValueSet = false;\n\n    for (const filter of config) {\n      if (this.hasValue.transform(filter?.selectedValue)) {\n        const ctrl = this.getControl(filter.key);\n        if (ctrl) {\n          ctrl.setValue(filter.selectedValue);\n          anyValueSet = true;\n        }\n      }\n    }\n\n    if (anyValueSet && this.emitFiltersAfterSettingNewValues()) {\n      // respect the parent flag — apply and emit\n      this.applyFilters();\n    } else {\n      // make sure our snapshot signal is fresh\n      this._formValueSignal.set({ ...this.filterForm.value });\n    }\n  }\n}","<div class=\"filter-panel-container\" *ngIf=\"show()\" @slideFromRight>\n    <div class=\"panel-header\">\n        <span>Filters</span>\n        <svg class=\"close-icon\" (click)=\"closePanel()\" width=\"25\" height=\"25\" viewBox=\"0 0 25 25\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n            <g id=\"ic-navigation-cancel-24\">\n                <path id=\"Union\" fill-rule=\"evenodd\" clip-rule=\"evenodd\" d=\"M8.60468 6.64355C8.09036 6.12923 7.25649 6.12923 6.74218 6.64355C6.22787 7.15786 6.22787 7.99173 6.74218 8.50604L10.4938 12.2576L6.7431 16.0083C6.22879 16.5226 6.22879 17.3564 6.7431 17.8708C7.25742 18.3851 8.09129 18.3851 8.60560 17.8708L12.3562 14.1201L16.1068 17.8707C16.6211 18.3850 17.4550 18.3850 17.9693 17.8707C18.4836 17.3564 18.4836 16.5225 17.9693 16.0082L14.2187 12.2576L17.9702 8.50613C18.4845 7.99181 18.4845 7.15794 17.9702 6.64363C17.4559 6.12932 16.6220 6.12932 16.1077 6.64363L12.3562 10.3951L8.60468 6.64355Z\" fill=\"#181F33\" />\n            </g>\n        </svg>\n    </div>\n  \n    <div class=\"horizontal-divider first\"></div>\n  \n    <div class=\"filters\" [formGroup]=\"filterForm\">\n        <ng-container *ngFor=\"let filter of config(); let last = last\">\n            <div class=\"filter\" *ngIf=\"!filter.hidden\">\n                <span class=\"filter-title\">{{filter.title}}</span>\n                <ng-container *ngIf=\"filter.type === 'multiSelect'\">\n                    <div class=\"multiselect-filter\">\n                        <mis-multi-select-dropdown class=\"no-padding\" [label]=\"filter.placeholder || 'Select'\" [selectedItems]=\"filterForm.get(filter.key)?.value || []\" (onChange)=\"handleSelect($event, filter.key, filter)\" [data]=\"filter.options\" [searchEnabled]=\"true\"\n                            [showSelectedCount]=\"true\" [enableSelectAll]=\"true\"\n                            [hideApplyButton]=\"false\" width=\"100%\" height=\"44px\"></mis-multi-select-dropdown>\n                    </div>\n                </ng-container>\n                <ng-container *ngIf=\"filter.type === 'select'\">\n                    <div class=\"multiselect-filter\">\n                        <mis-dropdown [data]=\"filter.options\" [searchEnabled]=\"true\" width=\"100%\" height=\"44px\"\n                                (onChange)=\"handleSelect($event, filter.key, filter)\" [selectedItem]=\"filterForm.get(filter.key)?.value\">\n                        </mis-dropdown>\n                    </div>\n                </ng-container>\n                <ng-container *ngIf=\"filter.type === 'checkbox'\">\n                    <div class=\"checkbox-row\">\n                        <div *ngFor=\"let option of filter.options\" class=\"checkbox-container\">\n                            <mis-checkbox [type]=\"'Default'\" [checked]=\"filterForm.get(filter.key)?.value?.includes(option.value)\" (valueChange)=\"handleCheckbox($event, filter.key, option.value, filter)\"></mis-checkbox>\n                            <span class=\"checkbox-label\">{{option.label}}</span>\n                        </div>\n                    </div>\n                </ng-container>\n                <ng-container *ngIf=\"filter.type === 'datePicker'\">\n                    <mis-input type=\"rounded\">\n                        <input misTzDp misInput type=\"text\" readonly class=\"mis-input\" [dpConfig]=\"filter.datePickerConfig\" [placeholder]=\"filterForm.get(filter.key)?.value || filter.placeholder || 'Select'\" [value]=\"filterForm.get(filter.key)?.value || filter.placeholder || 'Select'\" (dateChange)=\"onDateChange($event, filter.key, filter)\" [selectedDate]=\"filterForm.get(filter.key)?.value\" [positionX]=\"'end'\" [offsetX]=\"-10\">\n                    </mis-input>\n                </ng-container>\n                <ng-container *ngIf=\"filter.type === 'dateRangePicker'\">\n                    <mis-input type=\"rounded\">\n                        <input misTzDrp misInput type=\"text\" class=\"mis-input\" readonly\n                            [placeholder]=\"(!dateRangeSelectedDates().startDate && !dateRangeSelectedDates().endDate) ? (filter.placeholder || 'Select') : dateRangeSelectedDates().startDate + ' - ' + dateRangeSelectedDates().endDate\"\n                            [value]=\"(!dateRangeSelectedDates().startDate && !dateRangeSelectedDates().endDate) ? (filter.placeholder || 'Select') : dateRangeSelectedDates().startDate + ' - ' + dateRangeSelectedDates().endDate\" [positionX]=\"'start'\"\n                            [positionY]=\"'top'\" [selectedDates]=\"dateRangeSelectedDates()\" (dateChange)=\"onDateChange($event, filter.key, filter)\"\n                            [dpConfig]=\"filter.dateRangePickerConfig\" />\n                    </mis-input>\n                </ng-container>\n                <ng-container *ngIf=\"filter.type === 'text'\">\n                    <mis-input type=\"rounded\">\n                        <input misInput type=\"text\" class=\"input\" [placeholder]=\"filter.placeholder || 'Type here'\" [formControlName]=\"filter.key\">\n                    </mis-input>\n                </ng-container>\n                <ng-container *ngIf=\"filter.type === 'number'\">\n                    <mis-input type=\"rounded\">\n                        <input misInput type=\"number\" class=\"input\" [placeholder]=\"filter.placeholder || 'Type here'\" [formControlName]=\"filter.key\">\n                    </mis-input>\n                </ng-container>\n                <ng-container *ngIf=\"filter.type === 'range'\">\n                    <div class=\"range-container\" [formGroup]=\"filterForm.get(filter.key)\">\n                        <div class=\"range-inner-container\">\n                            <span>{{ filter?.options?.[0]?.label || 'Min' }}</span>\n                            <input\n                                misInput\n                                type=\"number\"\n                                class=\"input\"\n                                [placeholder]=\"filter.placeholder || 'Type here'\"\n                                formControlName=\"min\"\n                            />\n                        </div>\n                        <div class=\"range-inner-container\">\n                            <span>{{ filter?.options?.[1]?.label || 'Max' }}</span>\n                            <input\n                                misInput\n                                type=\"number\"\n                                class=\"input\"\n                                [placeholder]=\"filter.placeholder || 'Type here'\"\n                                formControlName=\"max\"\n                                [min]=\"filterForm.get(filter.key)?.get('min')?.value || 0\"\n                            />\n                        </div>\n                    </div>\n                </ng-container>\n                <div class=\"horizontal-divider\" *ngIf=\"!last\"></div>\n            </div>\n        </ng-container>\n    </div>\n  \n    <div class=\"actions\">\n        <mis-button [name]=\"'Clear All'\" [size]=\"'Small'\" [type]=\"'Text'\" (click)=\"resetFilters()\"></mis-button>\n        <mis-button [name]=\"'Apply'\" [size]=\"'Small'\" [type]=\"'Solid'\" (click)=\"applyFilters()\" [disabled]=\"filterForm.invalid\"></mis-button>\n    </div>\n  </div>"]}