@recursyve/nice-data-filter-kit 14.3.3 → 14.3.5

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,5 +1,5 @@
1
1
  import { plainToInstance } from 'class-transformer';
2
- import { map, takeUntil, debounceTime, switchMap, distinctUntilChanged } from 'rxjs/operators';
2
+ import { map, takeUntil, debounceTime, switchMap, distinctUntilChanged, withLatestFrom } from 'rxjs/operators';
3
3
  import { HttpParams } from '@angular/common/http';
4
4
  import * as i5 from '@recursyve/nice-ui-kit.v2';
5
5
  import { isNullOrUndefined, ObjectUtils, FileUtils, ArrayUtils, ExportBottomSheetComponent, NiceLoadingSpinnerModule, NiceTypeaheadModule, NiceExportBottomSheetModule, NiceAsyncTypeaheadProvider, NICE_ASYNC_TYPEAHEAD_PROVIDER, NiceAsyncTypeaheadModule } from '@recursyve/nice-ui-kit.v2';
@@ -3053,8 +3053,10 @@ class NiceFilterViewService {
3053
3053
  const { filterParameters } = this.store.getValue();
3054
3054
  const newRules = {
3055
3055
  order: filterParameters.order,
3056
+ fallbackOrder: filterParameters.fallbackOrder,
3056
3057
  start: 0,
3057
3058
  length: filterParameters.length,
3059
+ data: filterParameters.data,
3058
3060
  rules
3059
3061
  };
3060
3062
  this.setParameters(newRules);
@@ -3078,7 +3080,7 @@ class NiceFilterViewService {
3078
3080
  // Array replace
3079
3081
  newRules = [
3080
3082
  ...currentQuery.rules.slice(0, currentQuery.rules.indexOf(oldRule)),
3081
- query,
3083
+ rule,
3082
3084
  ...currentQuery.rules.slice(currentQuery.rules.indexOf(oldRule) + 1, currentQuery.rules.length)
3083
3085
  ];
3084
3086
  }
@@ -3087,7 +3089,7 @@ class NiceFilterViewService {
3087
3089
  }
3088
3090
  }
3089
3091
  else {
3090
- newRules = [...newRules, query];
3092
+ newRules = [...newRules, rule];
3091
3093
  }
3092
3094
  this.setRules({
3093
3095
  condition: currentQuery.condition,
@@ -3168,6 +3170,7 @@ class AdvancedFiltersUtils {
3168
3170
  ...base,
3169
3171
  value: AdvancedFiltersUtils.isDoubleInput(operator) ? ["", ""] : ""
3170
3172
  };
3173
+ case FilterType.Number:
3171
3174
  case FilterType.Select:
3172
3175
  return {
3173
3176
  ...base,
@@ -3185,11 +3188,6 @@ class AdvancedFiltersUtils {
3185
3188
  ? [config.options?.[0].key, config.options?.[0].key]
3186
3189
  : config.options?.[0].key
3187
3190
  };
3188
- case FilterType.Number:
3189
- return {
3190
- ...base,
3191
- value: AdvancedFiltersUtils.isDoubleInput(operator) ? [0, 0] : 0
3192
- };
3193
3191
  }
3194
3192
  }
3195
3193
  }
@@ -3362,7 +3360,10 @@ class NiceAdvancedFiltersButtonComponent {
3362
3360
  this.query = query;
3363
3361
  this.service = service;
3364
3362
  this.shouldShowAdvancedFilters$ = this.query.selectSubState("showAdvancedFilters");
3365
- this.hasParameters$ = this.query.selectFilterParameters().pipe(map((parameter) => !!parameter.rules?.length));
3363
+ this.hasParameters$ = this.query.selectFilterParameters().pipe(withLatestFrom(this.query.selectFilterConfig()), map(([parameter, config]) => !!parameter
3364
+ .rules
3365
+ ?.filter((rule) => config.some((conf) => conf.id === rule.rules[0].id))
3366
+ ?.length));
3366
3367
  }
3367
3368
  clickToggleShowAdvancedFilters() {
3368
3369
  this.service.updateSubState("showAdvancedFilters", !this.query.getSubState("showAdvancedFilters"));
@@ -4314,7 +4315,10 @@ class NiceFilterQueryParamsDirective {
4314
4315
  const { filterParameters, filterResult } = this.query.getValue();
4315
4316
  if (FilterUtils.filterChangeNeedsRefresh(filterParameters, params) ||
4316
4317
  !filterResult) {
4317
- this.service.setParameters(params);
4318
+ this.service.setParameters({
4319
+ ...params,
4320
+ fallbackOrder: filterParameters.fallbackOrder
4321
+ });
4318
4322
  }
4319
4323
  if (!this._initialized) {
4320
4324
  this._initialized = true;