aidbox-react 1.3.5 → 1.5.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/CHANGELOG.md +28 -0
- package/lib/hooks/service.d.ts +3 -2
- package/lib/hooks/service.js +21 -18
- package/lib/hooks/service.js.map +1 -1
- package/package.json +1 -1
- package/src/hooks/service.ts +33 -20
package/CHANGELOG.md
ADDED
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
## 1.5.0
|
|
2
|
+
|
|
3
|
+
- Fix useService hook performance
|
|
4
|
+
|
|
5
|
+
## 1.4.0
|
|
6
|
+
|
|
7
|
+
- Add softReloadAsync ans reloadAsync to useService manager
|
|
8
|
+
|
|
9
|
+
## 1.3.3
|
|
10
|
+
|
|
11
|
+
- Adjust the code for new ts
|
|
12
|
+
|
|
13
|
+
## 1.3.2
|
|
14
|
+
|
|
15
|
+
- Fix build
|
|
16
|
+
|
|
17
|
+
## 1.3.0
|
|
18
|
+
|
|
19
|
+
- findFHIRResources uses getFHIRResources under the hood
|
|
20
|
+
- formatError respects OperationOutcome.issue.diagnostics in addition to OperationOutcome.issue.details.text
|
|
21
|
+
|
|
22
|
+
## 1.2.0
|
|
23
|
+
|
|
24
|
+
- All requests helpers from FHIR module returns Resources wrapped with WithId type-wrapper.
|
|
25
|
+
|
|
26
|
+
## 1.1.1
|
|
27
|
+
|
|
28
|
+
- Stable release
|
package/lib/hooks/service.d.ts
CHANGED
|
@@ -1,7 +1,8 @@
|
|
|
1
1
|
import { RemoteData, RemoteDataResult } from '../libs/remoteData';
|
|
2
2
|
export interface ServiceManager<S, F> {
|
|
3
|
-
reload: () =>
|
|
4
|
-
|
|
3
|
+
reload: () => void;
|
|
4
|
+
reloadAsync: () => Promise<RemoteDataResult<S, F>>;
|
|
5
|
+
softReloadAsync: () => Promise<RemoteDataResult<S, F>>;
|
|
5
6
|
set: (dataOrFn: S | ((data: S) => S)) => void;
|
|
6
7
|
}
|
|
7
8
|
export declare function useService<S = any, F = any>(asyncFunction: () => Promise<RemoteDataResult<S, F>>, deps?: ReadonlyArray<any>): [RemoteData<S, F>, ServiceManager<S, F>];
|
package/lib/hooks/service.js
CHANGED
|
@@ -8,6 +8,8 @@ function useService(asyncFunction, deps) {
|
|
|
8
8
|
var _this = this;
|
|
9
9
|
if (deps === void 0) { deps = []; }
|
|
10
10
|
var _a = react_1.useState(remoteData_1.notAsked), remoteData = _a[0], setRemoteData = _a[1];
|
|
11
|
+
var _b = react_1.useState(0), reloadsCount = _b[0], setReloadsCount = _b[1];
|
|
12
|
+
var reload = react_1.useCallback(function () { return setReloadsCount(function (x) { return x + 1; }); }, []);
|
|
11
13
|
var load = react_1.useCallback(function () { return tslib_1.__awaiter(_this, void 0, void 0, function () {
|
|
12
14
|
var err_1;
|
|
13
15
|
return tslib_1.__generator(this, function (_a) {
|
|
@@ -23,7 +25,7 @@ function useService(asyncFunction, deps) {
|
|
|
23
25
|
}
|
|
24
26
|
});
|
|
25
27
|
}); }, deps);
|
|
26
|
-
var
|
|
28
|
+
var softReloadAsync = react_1.useCallback(function () { return tslib_1.__awaiter(_this, void 0, void 0, function () {
|
|
27
29
|
var response;
|
|
28
30
|
return tslib_1.__generator(this, function (_a) {
|
|
29
31
|
switch (_a.label) {
|
|
@@ -35,7 +37,7 @@ function useService(asyncFunction, deps) {
|
|
|
35
37
|
}
|
|
36
38
|
});
|
|
37
39
|
}); }, tslib_1.__spreadArrays(deps, [load]));
|
|
38
|
-
var
|
|
40
|
+
var reloadAsync = react_1.useCallback(function () { return tslib_1.__awaiter(_this, void 0, void 0, function () {
|
|
39
41
|
var response;
|
|
40
42
|
return tslib_1.__generator(this, function (_a) {
|
|
41
43
|
switch (_a.label) {
|
|
@@ -65,22 +67,23 @@ function useService(asyncFunction, deps) {
|
|
|
65
67
|
});
|
|
66
68
|
}); })();
|
|
67
69
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
68
|
-
}, tslib_1.__spreadArrays(deps, [load]));
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
];
|
|
70
|
+
}, tslib_1.__spreadArrays(deps, [reloadsCount, load]));
|
|
71
|
+
var set = react_1.useCallback(function (dataOrFn) {
|
|
72
|
+
if (typeof dataOrFn === 'function') {
|
|
73
|
+
setRemoteData(function (rd) { return (remoteData_1.isSuccess(rd) ? remoteData_1.success(dataOrFn(rd.data)) : rd); });
|
|
74
|
+
}
|
|
75
|
+
else {
|
|
76
|
+
setRemoteData(remoteData_1.success(dataOrFn));
|
|
77
|
+
}
|
|
78
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
79
|
+
}, deps);
|
|
80
|
+
var manager = react_1.useMemo(function () { return ({
|
|
81
|
+
reload: reload,
|
|
82
|
+
reloadAsync: reloadAsync,
|
|
83
|
+
softReloadAsync: softReloadAsync,
|
|
84
|
+
set: set,
|
|
85
|
+
}); }, [reload, reloadAsync, softReloadAsync, set]);
|
|
86
|
+
return [remoteData, manager];
|
|
84
87
|
}
|
|
85
88
|
exports.useService = useService;
|
|
86
89
|
//# sourceMappingURL=service.js.map
|
package/lib/hooks/service.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"service.js","sourceRoot":"","sources":["../../src/hooks/service.ts"],"names":[],"mappings":";;;;AAAA,+
|
|
1
|
+
{"version":3,"file":"service.js","sourceRoot":"","sources":["../../src/hooks/service.ts"],"names":[],"mappings":";;;;AAAA,+BAAkE;AAElE,iDAAkH;AAalH,SAAgB,UAAU,CACtB,aAAoD,EACpD,IAA6B;IAFjC,iBA8DC;IA5DG,qBAAA,EAAA,SAA6B;IAEvB,IAAA,KAA8B,gBAAQ,CAAmB,qBAAQ,CAAC,EAAjE,UAAU,QAAA,EAAE,aAAa,QAAwC,CAAC;IACnE,IAAA,KAAkC,gBAAQ,CAAC,CAAC,CAAC,EAA5C,YAAY,QAAA,EAAE,eAAe,QAAe,CAAC;IACpD,IAAM,MAAM,GAAG,mBAAW,CAAC,cAAM,OAAA,eAAe,CAAC,UAAC,CAAC,IAAK,OAAA,CAAC,GAAG,CAAC,EAAL,CAAK,CAAC,EAA7B,CAA6B,EAAE,EAAE,CAAC,CAAC;IAEpE,IAAM,IAAI,GAAG,mBAAW,CAAC;;;;;;oBAEV,qBAAM,aAAa,EAAE,EAAA;wBAA5B,sBAAO,SAAqB,EAAC;;;oBAE7B,sBAAO,oBAAO,CAAC,KAAG,CAAC,QAAQ,CAAC,CAAC,CAAC,KAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,KAAG,CAAC,OAAO,CAAC,EAAC;;;;SAGtE,EAAE,IAAI,CAAC,CAAC;IAET,IAAM,eAAe,GAAG,mBAAW,CAAC;;;;wBACf,qBAAM,IAAI,EAAE,EAAA;;oBAAvB,QAAQ,GAAG,SAAY;oBAC7B,aAAa,CAAC,QAAQ,CAAC,CAAC;oBAExB,sBAAO,QAAQ,EAAC;;;SAEnB,yBAAM,IAAI,GAAE,IAAI,GAAE,CAAC;IAEpB,IAAM,WAAW,GAAG,mBAAW,CAAC;;;;;oBAC5B,aAAa,CAAC,oBAAO,CAAC,CAAC;oBACN,qBAAM,IAAI,EAAE,EAAA;;oBAAvB,QAAQ,GAAG,SAAY;oBAC7B,aAAa,CAAC,QAAQ,CAAC,CAAC;oBAExB,sBAAO,QAAQ,EAAC;;;SAEnB,yBAAM,IAAI,GAAE,IAAI,GAAE,CAAC;IAEpB,iBAAS,CAAC;QACN,CAAC;;;;;wBACG,aAAa,CAAC,oBAAO,CAAC,CAAC;wBACvB,KAAA,aAAa,CAAA;wBAAC,qBAAM,IAAI,EAAE,EAAA;;wBAA1B,kBAAc,SAAY,EAAC,CAAC;;;;aAC/B,CAAC,EAAE,CAAC;QACL,uDAAuD;IAC3D,CAAC,yBAAM,IAAI,GAAE,YAAY,EAAE,IAAI,GAAE,CAAC;IAElC,IAAM,GAAG,GAAG,mBAAW,CAAC,UAAC,QAA8B;QACnD,IAAI,OAAO,QAAQ,KAAK,UAAU,EAAE;YAChC,aAAa,CAAC,UAAC,EAAE,IAAK,OAAA,CAAC,sBAAS,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,oBAAO,CAAE,QAA2B,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,EAArE,CAAqE,CAAC,CAAC;SAChG;aAAM;YACH,aAAa,CAAC,oBAAO,CAAC,QAAQ,CAAC,CAAC,CAAC;SACpC;QACD,uDAAuD;IAC3D,CAAC,EAAE,IAAI,CAAC,CAAC;IAET,IAAM,OAAO,GAAG,eAAO,CACnB,cAAM,OAAA,CAAC;QACH,MAAM,QAAA;QACN,WAAW,aAAA;QACX,eAAe,iBAAA;QACf,GAAG,KAAA;KACN,CAAC,EALI,CAKJ,EACF,CAAC,MAAM,EAAE,WAAW,EAAE,eAAe,EAAE,GAAG,CAAC,CAC9C,CAAC;IAEF,OAAO,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;AACjC,CAAC;AA9DD,gCA8DC"}
|
package/package.json
CHANGED
package/src/hooks/service.ts
CHANGED
|
@@ -1,10 +1,15 @@
|
|
|
1
|
-
import { useEffect, useState, useCallback } from 'react';
|
|
1
|
+
import { useEffect, useState, useCallback, useMemo } from 'react';
|
|
2
2
|
|
|
3
3
|
import { loading, notAsked, RemoteData, RemoteDataResult, success, failure, isSuccess } from '../libs/remoteData';
|
|
4
4
|
|
|
5
5
|
export interface ServiceManager<S, F> {
|
|
6
|
-
reload
|
|
7
|
-
|
|
6
|
+
// `reload` just sends signal to reload
|
|
7
|
+
reload: () => void;
|
|
8
|
+
// `reloadAsync` returns Promise and intialize loading from the loading state
|
|
9
|
+
reloadAsync: () => Promise<RemoteDataResult<S, F>>;
|
|
10
|
+
// `softReloadAsync` returns Promise and intialize just updates
|
|
11
|
+
// remoteData with success/failure state without preloading
|
|
12
|
+
softReloadAsync: () => Promise<RemoteDataResult<S, F>>;
|
|
8
13
|
set: (dataOrFn: S | ((data: S) => S)) => void;
|
|
9
14
|
}
|
|
10
15
|
|
|
@@ -13,17 +18,19 @@ export function useService<S = any, F = any>(
|
|
|
13
18
|
deps: ReadonlyArray<any> = []
|
|
14
19
|
): [RemoteData<S, F>, ServiceManager<S, F>] {
|
|
15
20
|
const [remoteData, setRemoteData] = useState<RemoteData<S, F>>(notAsked);
|
|
21
|
+
const [reloadsCount, setReloadsCount] = useState(0);
|
|
22
|
+
const reload = useCallback(() => setReloadsCount((x) => x + 1), []);
|
|
16
23
|
|
|
17
24
|
const load = useCallback(async () => {
|
|
18
25
|
try {
|
|
19
26
|
return await asyncFunction();
|
|
20
|
-
} catch (err) {
|
|
27
|
+
} catch (err: any) {
|
|
21
28
|
return failure(err.response ? err.response.data : err.message);
|
|
22
29
|
}
|
|
23
30
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
24
31
|
}, deps);
|
|
25
32
|
|
|
26
|
-
const
|
|
33
|
+
const softReloadAsync = useCallback(async () => {
|
|
27
34
|
const response = await load();
|
|
28
35
|
setRemoteData(response);
|
|
29
36
|
|
|
@@ -31,7 +38,7 @@ export function useService<S = any, F = any>(
|
|
|
31
38
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
32
39
|
}, [...deps, load]);
|
|
33
40
|
|
|
34
|
-
const
|
|
41
|
+
const reloadAsync = useCallback(async () => {
|
|
35
42
|
setRemoteData(loading);
|
|
36
43
|
const response = await load();
|
|
37
44
|
setRemoteData(response);
|
|
@@ -46,20 +53,26 @@ export function useService<S = any, F = any>(
|
|
|
46
53
|
setRemoteData(await load());
|
|
47
54
|
})();
|
|
48
55
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
49
|
-
}, [...deps, load]);
|
|
56
|
+
}, [...deps, reloadsCount, load]);
|
|
57
|
+
|
|
58
|
+
const set = useCallback((dataOrFn: S | ((data: S) => S)) => {
|
|
59
|
+
if (typeof dataOrFn === 'function') {
|
|
60
|
+
setRemoteData((rd) => (isSuccess(rd) ? success((dataOrFn as (data: S) => S)(rd.data)) : rd));
|
|
61
|
+
} else {
|
|
62
|
+
setRemoteData(success(dataOrFn));
|
|
63
|
+
}
|
|
64
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
65
|
+
}, deps);
|
|
50
66
|
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
{
|
|
67
|
+
const manager = useMemo(
|
|
68
|
+
() => ({
|
|
54
69
|
reload,
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
},
|
|
64
|
-
];
|
|
70
|
+
reloadAsync,
|
|
71
|
+
softReloadAsync,
|
|
72
|
+
set,
|
|
73
|
+
}),
|
|
74
|
+
[reload, reloadAsync, softReloadAsync, set]
|
|
75
|
+
);
|
|
76
|
+
|
|
77
|
+
return [remoteData, manager];
|
|
65
78
|
}
|