@monolith-forensics/monolith-ui 1.2.72 → 1.2.73
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,7 @@
|
|
|
1
1
|
import { FilterDefinition } from "./types";
|
|
2
2
|
export interface UserFilterDefinitionsParams {
|
|
3
3
|
filterDef: FilterDefinition[];
|
|
4
|
+
overrides?: Partial<FilterDefinition>[];
|
|
4
5
|
}
|
|
5
6
|
export type UseFilterDefinitionsType = (p: UserFilterDefinitionsParams) => FilterDefinition[];
|
|
6
|
-
export declare function useFilterDefinitions({ filterDef, }: UserFilterDefinitionsParams): FilterDefinition[];
|
|
7
|
+
export declare function useFilterDefinitions({ filterDef, overrides, }: UserFilterDefinitionsParams): FilterDefinition[];
|
|
@@ -1,7 +1,43 @@
|
|
|
1
|
+
var __rest = (this && this.__rest) || function (s, e) {
|
|
2
|
+
var t = {};
|
|
3
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
4
|
+
t[p] = s[p];
|
|
5
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
6
|
+
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
7
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
8
|
+
t[p[i]] = s[p[i]];
|
|
9
|
+
}
|
|
10
|
+
return t;
|
|
11
|
+
};
|
|
1
12
|
import { useQueries } from "@tanstack/react-query";
|
|
2
|
-
|
|
13
|
+
const mergeOverrides = (filterDef, overrides) => {
|
|
14
|
+
return filterDef.map((f) => {
|
|
15
|
+
const override = overrides.find((o) => o.dataField === f.dataField);
|
|
16
|
+
if (!override) {
|
|
17
|
+
return f;
|
|
18
|
+
}
|
|
19
|
+
const { query, dropDownOptions } = override, rest = __rest(override, ["query", "dropDownOptions"]);
|
|
20
|
+
// Handle merge directly on query and dropDownOptions
|
|
21
|
+
// prevents overriding the entire query object
|
|
22
|
+
// allows user to override specific properties
|
|
23
|
+
if (query) {
|
|
24
|
+
f.query = Object.assign(Object.assign({}, query), override.query);
|
|
25
|
+
}
|
|
26
|
+
if (dropDownOptions) {
|
|
27
|
+
f.dropDownOptions = Object.assign(Object.assign({}, dropDownOptions), override.dropDownOptions);
|
|
28
|
+
}
|
|
29
|
+
// Merge override with original filter def
|
|
30
|
+
return Object.assign(Object.assign({}, f), rest);
|
|
31
|
+
});
|
|
32
|
+
};
|
|
33
|
+
export function useFilterDefinitions({ filterDef, overrides, }) {
|
|
34
|
+
let _filterDef = filterDef;
|
|
35
|
+
if (!!overrides) {
|
|
36
|
+
_filterDef = mergeOverrides(filterDef, overrides);
|
|
37
|
+
}
|
|
3
38
|
// Keeps track of filters that have queries
|
|
4
39
|
const queryIndex = [];
|
|
40
|
+
// Get query options from filter defs
|
|
5
41
|
const queries = filterDef
|
|
6
42
|
.filter((f, i) => {
|
|
7
43
|
// Track array index of filter def that has a query
|
|
@@ -10,9 +46,11 @@ export function useFilterDefinitions({ filterDef, }) {
|
|
|
10
46
|
return hasQuery;
|
|
11
47
|
})
|
|
12
48
|
.map((filter) => filter.query);
|
|
49
|
+
// run queries from filter defs
|
|
13
50
|
const result = useQueries({
|
|
14
51
|
queries,
|
|
15
52
|
});
|
|
53
|
+
// Add useQueries result data to filter def as options
|
|
16
54
|
queryIndex.forEach((index, i) => {
|
|
17
55
|
var _a;
|
|
18
56
|
// User query index to add useQueries result data to filter def as options
|