bi-sdk-react 0.0.48 → 0.0.49
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/package.json
CHANGED
|
@@ -44,6 +44,8 @@ type PageContextType = {
|
|
|
44
44
|
) => void;
|
|
45
45
|
getVars: (id: string) => Record<string, any>;
|
|
46
46
|
setVar: (item: SchemaItemType, key: string, value: any) => void;
|
|
47
|
+
getItemData: (id: string) => any;
|
|
48
|
+
setItemData: (id: string, data: any) => void;
|
|
47
49
|
};
|
|
48
50
|
|
|
49
51
|
export const PageContext = createContext<PageContextType>({
|
|
@@ -76,6 +78,8 @@ export const PageContext = createContext<PageContextType>({
|
|
|
76
78
|
handleCallback: () => {},
|
|
77
79
|
getVars: () => ({}),
|
|
78
80
|
setVar: () => {},
|
|
81
|
+
getItemData: () => {},
|
|
82
|
+
setItemData: () => {},
|
|
79
83
|
});
|
|
80
84
|
|
|
81
85
|
type PageProviderProps = React.PropsWithChildren<
|
|
@@ -107,6 +111,7 @@ export const PageProvider: React.FC<PageProviderProps> = ({
|
|
|
107
111
|
fetch,
|
|
108
112
|
children,
|
|
109
113
|
}) => {
|
|
114
|
+
const [itemDatas, setItemDatas] = useState<Record<string, any>>({});
|
|
110
115
|
const [deviceWidth, setDeviceWidth] = useState<number>(0);
|
|
111
116
|
const updateSelectedItem = (props?: Partial<SchemaItemType> | null) => {
|
|
112
117
|
setSelectedItem?.(Object.assign(selectedItem!, props || {}));
|
|
@@ -170,6 +175,14 @@ export const PageProvider: React.FC<PageProviderProps> = ({
|
|
|
170
175
|
});
|
|
171
176
|
};
|
|
172
177
|
|
|
178
|
+
const getItemData = (id: string) => {
|
|
179
|
+
return itemDatas[id] || {};
|
|
180
|
+
};
|
|
181
|
+
|
|
182
|
+
const setItemData = (id: string, data: any) => {
|
|
183
|
+
setItemDatas((d) => ({ ...d, [id]: data }));
|
|
184
|
+
};
|
|
185
|
+
|
|
173
186
|
useEffect(() => {
|
|
174
187
|
const nextGlobal: Record<string, any> = {};
|
|
175
188
|
(schema.variables || []).forEach((item) => {
|
|
@@ -205,6 +218,8 @@ export const PageProvider: React.FC<PageProviderProps> = ({
|
|
|
205
218
|
handleCallback,
|
|
206
219
|
getVars,
|
|
207
220
|
setVar,
|
|
221
|
+
getItemData,
|
|
222
|
+
setItemData,
|
|
208
223
|
}}
|
|
209
224
|
>
|
|
210
225
|
{children}
|
|
@@ -10,7 +10,7 @@ type Props = {
|
|
|
10
10
|
};
|
|
11
11
|
|
|
12
12
|
export const useDatasource = ({ item, signal }: Props): any => {
|
|
13
|
-
const { fetch, getVars } = useContext(PageContext);
|
|
13
|
+
const { fetch, getVars, setItemData } = useContext(PageContext);
|
|
14
14
|
const [datasource, setDatasource] = useState<any>(null);
|
|
15
15
|
useEffect(() => {
|
|
16
16
|
if (!item?.datasource) {
|
|
@@ -21,9 +21,12 @@ export const useDatasource = ({ item, signal }: Props): any => {
|
|
|
21
21
|
switch (source) {
|
|
22
22
|
case "custom":
|
|
23
23
|
try {
|
|
24
|
-
|
|
24
|
+
const next = JSON.parse(item?.datasource?.custom || "[]");
|
|
25
|
+
setDatasource(next);
|
|
26
|
+
setItemData(item.id || "", next);
|
|
25
27
|
} catch (e) {
|
|
26
28
|
setDatasource(null);
|
|
29
|
+
setItemData(item.id || "", null);
|
|
27
30
|
}
|
|
28
31
|
break;
|
|
29
32
|
case "dataset":
|
|
@@ -36,6 +39,7 @@ export const useDatasource = ({ item, signal }: Props): any => {
|
|
|
36
39
|
},
|
|
37
40
|
);
|
|
38
41
|
setDatasource(null);
|
|
42
|
+
setItemData(item.id || "", null);
|
|
39
43
|
return;
|
|
40
44
|
}
|
|
41
45
|
const vars = getVars(item.id || "");
|
|
@@ -43,14 +47,17 @@ export const useDatasource = ({ item, signal }: Props): any => {
|
|
|
43
47
|
.dataset(item?.datasource.dataset.id, vars)
|
|
44
48
|
.then((res) => {
|
|
45
49
|
setDatasource(res || null);
|
|
50
|
+
setItemData(item.id || "", res || null);
|
|
46
51
|
})
|
|
47
52
|
.catch((err) => {
|
|
48
53
|
console.error("dataset fetch error", err);
|
|
49
54
|
setDatasource(null);
|
|
55
|
+
setItemData(item.id || "", null);
|
|
50
56
|
});
|
|
51
57
|
break;
|
|
52
58
|
default:
|
|
53
59
|
setDatasource(null);
|
|
60
|
+
setItemData(item.id || "", null);
|
|
54
61
|
break;
|
|
55
62
|
}
|
|
56
63
|
}, [item?.datasource, signal]);
|