@promoboxx/use-filter 1.8.2 → 1.9.0

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.
@@ -18,6 +18,7 @@ interface UseFilterOptions<TFilter, TResult> {
18
18
  * In case you want to change the default debounce duration.
19
19
  */
20
20
  debounceDuration?: number;
21
+ onBeforeSaveFilter?: (filterInfo: FilterInfo<TFilter>) => FilterInfo<TFilter>;
21
22
  }
22
23
  export interface FilterApi<TFilter, TResult> {
23
24
  /**
package/dist/useFilter.js CHANGED
@@ -48,6 +48,7 @@ function useFilter(namespace, options) {
48
48
  onChange: options.onChange,
49
49
  debounceDuration: options.debounceDuration,
50
50
  defaultFilterInfo: options.defaultFilterInfo,
51
+ onBeforeSaveFilter: options.onBeforeSaveFilter,
51
52
  };
52
53
  var ctxRef = react_1.useRef(ctxRefValue);
53
54
  react_1.useEffect(function () {
@@ -82,7 +83,9 @@ function useFilter(namespace, options) {
82
83
  var makeRequest = function () {
83
84
  lastRefreshAtRef.current = filterInfo.lastRefreshAt;
84
85
  var response = ctxRef.current.onChange(filterInfo, updateReasonRef.current);
85
- store_1.getFilterStore().saveFilter(namespace, filterInfo);
86
+ store_1.getFilterStore().saveFilter(namespace, ctxRef.current.onBeforeSaveFilter
87
+ ? ctxRef.current.onBeforeSaveFilter(filterInfo)
88
+ : filterInfo);
86
89
  if (!response) {
87
90
  setIsLoading(false);
88
91
  return;
@@ -164,7 +167,7 @@ function useFilter(namespace, options) {
164
167
  if (shallowEqual_1.default(previous.filter, nextFilter)) {
165
168
  return previous;
166
169
  }
167
- return __assign(__assign({}, previous), { offset: 0, page: 1, totalResults: 1, totalPages: 1, filter: nextFilter, lastRefreshAt: new Date().getTime(), shouldRunImmediately: shouldRunImmediately });
170
+ return __assign(__assign({}, previous), { offset: 0, page: 1, totalResults: 1, totalPages: 1, filter: nextFilter, lastRefreshAt: new Date().getTime(), cursor: undefined, nextCursor: undefined, shouldRunImmediately: shouldRunImmediately });
168
171
  });
169
172
  }, []),
170
173
  resetFilter: react_1.useCallback(function (shouldRunImmediately) {
@@ -10,6 +10,7 @@ interface UseSimpleFilterOptions<TFilter> {
10
10
  * In case you want to change the default debounce duration.
11
11
  */
12
12
  debounceDuration?: number;
13
+ onBeforeSaveFilter?: (filterInfo: SimpleFilterInfo<TFilter>) => SimpleFilterInfo<TFilter>;
13
14
  }
14
15
  export interface SimpleFilterApi<TFilter> {
15
16
  /**
@@ -26,6 +26,7 @@ function useSimpleFilter(namespace, options) {
26
26
  namespace: namespace,
27
27
  debounceDuration: options.debounceDuration,
28
28
  defaultFilterInfo: options.defaultFilterInfo,
29
+ onBeforeSaveFilter: options.onBeforeSaveFilter,
29
30
  };
30
31
  var ctxRef = react_1.useRef(ctxRefValue);
31
32
  react_1.useEffect(function () {
@@ -49,7 +50,9 @@ function useSimpleFilter(namespace, options) {
49
50
  var timeout = undefined;
50
51
  function makeRequest() {
51
52
  lastRefreshAtRef.current = filterInfo.lastRefreshAt;
52
- store_1.getFilterStore().saveFilter(ctxRef.current.namespace, filterInfo);
53
+ store_1.getFilterStore().saveFilter(ctxRef.current.namespace, (ctxRef.current.onBeforeSaveFilter
54
+ ? ctxRef.current.onBeforeSaveFilter(filterInfo)
55
+ : filterInfo));
53
56
  setDebouncedFilterInfo(filterInfo);
54
57
  setIsLoading(false);
55
58
  }
@@ -79,7 +82,7 @@ function useSimpleFilter(namespace, options) {
79
82
  if (shallowEqual_1.default(previous.filter, nextFilter)) {
80
83
  return previous;
81
84
  }
82
- return __assign(__assign({}, previous), { shouldRunImmediately: shouldRunImmediately, offset: 0, page: 1, totalResults: 1, totalPages: 1, filter: nextFilter, lastRefreshAt: new Date().getTime() });
85
+ return __assign(__assign({}, previous), { shouldRunImmediately: shouldRunImmediately, offset: 0, page: 1, totalResults: 1, totalPages: 1, filter: nextFilter, cursor: undefined, lastRefreshAt: new Date().getTime() });
83
86
  });
84
87
  }, []),
85
88
  pagingInfo: react_1.useCallback(function (total) {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@promoboxx/use-filter",
3
- "version": "1.8.2",
3
+ "version": "1.9.0",
4
4
  "description": "",
5
5
  "main": "dist/useFilter.js",
6
6
  "keywords": [],