@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.
- package/dist/useFilter.d.ts +1 -0
- package/dist/useFilter.js +5 -2
- package/dist/useSimpleFilter.d.ts +1 -0
- package/dist/useSimpleFilter.js +5 -2
- package/package.json +1 -1
package/dist/useFilter.d.ts
CHANGED
|
@@ -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,
|
|
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
|
/**
|
package/dist/useSimpleFilter.js
CHANGED
|
@@ -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,
|
|
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) {
|