@xyo-network/react-wallet 2.60.3 → 2.60.5
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/cjs/contexts/Wallet/Provider.js +3 -3
- package/dist/cjs/contexts/Wallet/Provider.js.map +1 -1
- package/dist/cjs/contexts/Wallet/usePromise.js +79 -0
- package/dist/cjs/contexts/Wallet/usePromise.js.map +1 -0
- package/dist/cjs/hooks/useWallets.js +2 -1
- package/dist/cjs/hooks/useWallets.js.map +1 -1
- package/dist/docs.json +147 -147
- package/dist/esm/contexts/Wallet/Provider.js +2 -2
- package/dist/esm/contexts/Wallet/Provider.js.map +1 -1
- package/dist/esm/contexts/Wallet/usePromise.js +80 -0
- package/dist/esm/contexts/Wallet/usePromise.js.map +1 -0
- package/dist/esm/hooks/useWallets.js +1 -1
- package/dist/esm/hooks/useWallets.js.map +1 -1
- package/dist/types/contexts/Wallet/Provider.d.ts.map +1 -1
- package/dist/types/contexts/Wallet/usePromise.d.ts +11 -0
- package/dist/types/contexts/Wallet/usePromise.d.ts.map +1 -0
- package/package.json +20 -20
- package/src/contexts/Wallet/Provider.tsx +5 -2
- package/src/contexts/Wallet/usePromise.ts +80 -0
- package/src/hooks/useWallets.ts +1 -1
|
@@ -3,10 +3,10 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
3
3
|
exports.WalletProvider = void 0;
|
|
4
4
|
const tslib_1 = require("tslib");
|
|
5
5
|
const jsx_runtime_1 = require("react/jsx-runtime");
|
|
6
|
-
const react_promise_1 = require("@xylabs/react-promise");
|
|
7
6
|
const react_1 = require("react");
|
|
8
7
|
const Context_1 = require("./Context");
|
|
9
8
|
const lib_1 = require("./lib");
|
|
9
|
+
const usePromise_1 = require("./usePromise");
|
|
10
10
|
const WalletProvider = (_a) => {
|
|
11
11
|
var { basePath = lib_1.WalletRootPath, children, defaultActiveAccountIndex = 0, rootWallet = null } = _a, props = tslib_1.__rest(_a, ["basePath", "children", "defaultActiveAccountIndex", "rootWallet"]);
|
|
12
12
|
const [activeAccountIndex, setActiveAccountIndex] = (0, react_1.useState)(defaultActiveAccountIndex);
|
|
@@ -15,7 +15,7 @@ const WalletProvider = (_a) => {
|
|
|
15
15
|
setActiveAccountIndex(defaultActiveAccountIndex);
|
|
16
16
|
}
|
|
17
17
|
}, [defaultActiveAccountIndex]);
|
|
18
|
-
const [coinTypeWallet = null] = (0,
|
|
18
|
+
const [coinTypeWallet = null] = (0, usePromise_1.usePromise)(() => tslib_1.__awaiter(void 0, void 0, void 0, function* () {
|
|
19
19
|
// ensure the wallet has the proper base
|
|
20
20
|
if (rootWallet) {
|
|
21
21
|
if (!(rootWallet === null || rootWallet === void 0 ? void 0 : rootWallet.path.includes(basePath))) {
|
|
@@ -31,7 +31,7 @@ const WalletProvider = (_a) => {
|
|
|
31
31
|
return undefined;
|
|
32
32
|
}
|
|
33
33
|
}), [basePath, rootWallet]);
|
|
34
|
-
const [activeAccount = null] = (0,
|
|
34
|
+
const [activeAccount = null] = (0, usePromise_1.usePromise)(() => tslib_1.__awaiter(void 0, void 0, void 0, function* () { return yield (coinTypeWallet === null || coinTypeWallet === void 0 ? void 0 : coinTypeWallet.derivePath(activeAccountIndex.toString())); }), [coinTypeWallet, activeAccountIndex]);
|
|
35
35
|
return ((0, jsx_runtime_1.jsx)(Context_1.WalletContext.Provider, Object.assign({ value: {
|
|
36
36
|
activeAccount,
|
|
37
37
|
activeAccountIndex,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Provider.js","sourceRoot":"","sources":["../../../../src/contexts/Wallet/Provider.tsx"],"names":[],"mappings":";;;;;
|
|
1
|
+
{"version":3,"file":"Provider.js","sourceRoot":"","sources":["../../../../src/contexts/Wallet/Provider.tsx"],"names":[],"mappings":";;;;;AAEA,iCAA2C;AAE3C,uCAAyC;AACzC,+BAAsC;AACtC,6CAAyC;AAQlC,MAAM,cAAc,GAAgD,CAAC,EAM3E,EAAE,EAAE;QANuE,EAC1E,QAAQ,GAAG,oBAAc,EACzB,QAAQ,EACR,yBAAyB,GAAG,CAAC,EAC7B,UAAU,GAAG,IAAI,OAElB,EADI,KAAK,sBALkE,mEAM3E,CADS;IAER,MAAM,CAAC,kBAAkB,EAAE,qBAAqB,CAAC,GAAG,IAAA,gBAAQ,EAAC,yBAAyB,CAAC,CAAA;IAEvF,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,IAAI,yBAAyB,KAAK,SAAS,EAAE;YAC3C,qBAAqB,CAAC,yBAAyB,CAAC,CAAA;SACjD;IACH,CAAC,EAAE,CAAC,yBAAyB,CAAC,CAAC,CAAA;IAE/B,MAAM,CAAC,cAAc,GAAG,IAAI,CAAC,GAAG,IAAA,uBAAU,EAAC,GAAS,EAAE;QACpD,wCAAwC;QACxC,IAAI,UAAU,EAAE;YACd,IAAI,CAAC,CAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAA,EAAE;gBACxC,IAAI;oBACF,OAAO,MAAM,CAAA,UAAU,aAAV,UAAU,uBAAV,UAAU,CAAE,UAAU,CAAC,QAAQ,CAAC,CAAA,CAAA;iBAC9C;gBAAC,OAAO,CAAC,EAAE;oBACV,OAAO,CAAC,KAAK,CAAC,uCAAuC,EAAE,CAAC,CAAC,CAAA;iBAC1D;aACF;SACF;aAAM;YACL,OAAO,SAAS,CAAA;SACjB;IACH,CAAC,CAAA,EAAE,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC,CAAA;IAE1B,MAAM,CAAC,aAAa,GAAG,IAAI,CAAC,GAAG,IAAA,uBAAU,EACvC,GAAS,EAAE,0DAAC,OAAA,MAAM,CAAA,cAAc,aAAd,cAAc,uBAAd,cAAc,CAAE,UAAU,CAAC,kBAAkB,CAAC,QAAQ,EAAE,CAAC,CAAA,CAAA,GAAA,EAC3E,CAAC,cAAc,EAAE,kBAAkB,CAAC,CACrC,CAAA;IAED,OAAO,CACL,uBAAC,uBAAa,CAAC,QAAQ,kBACrB,KAAK,EAAE;YACL,aAAa;YACb,kBAAkB;YAClB,QAAQ;YACR,cAAc;YACd,QAAQ,EAAE,IAAI;YACd,UAAU;YACV,qBAAqB;SACtB,IACG,KAAK,cAER,QAAQ,IACc,CAC1B,CAAA;AACH,CAAC,CAAA;AAnDY,QAAA,cAAc,kBAmD1B"}
|
|
@@ -0,0 +1,79 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
// Inspired from https://github.com/bsonntag/react-use-promise
|
|
3
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
4
|
+
exports.usePromise = exports.State = void 0;
|
|
5
|
+
const async_mutex_1 = require("async-mutex");
|
|
6
|
+
const react_1 = require("react");
|
|
7
|
+
var State;
|
|
8
|
+
(function (State) {
|
|
9
|
+
State["pending"] = "pending";
|
|
10
|
+
State["rejected"] = "rejected";
|
|
11
|
+
State["resolved"] = "resolved";
|
|
12
|
+
})(State = exports.State || (exports.State = {}));
|
|
13
|
+
/**
|
|
14
|
+
* usePromise -
|
|
15
|
+
*/
|
|
16
|
+
const usePromise = (promise, dependencies, debug = undefined) => {
|
|
17
|
+
const [result, setResult] = (0, react_1.useState)();
|
|
18
|
+
const [error, setError] = (0, react_1.useState)();
|
|
19
|
+
const [state, setState] = (0, react_1.useState)(State.pending);
|
|
20
|
+
const mutex = (0, react_1.useMemo)(() => {
|
|
21
|
+
return new async_mutex_1.Mutex();
|
|
22
|
+
}, []);
|
|
23
|
+
if (debug)
|
|
24
|
+
console.log(`usePromise [${debug}]: started [${typeof promise}]`);
|
|
25
|
+
const promiseMemo = (0, react_1.useMemo)(() => {
|
|
26
|
+
try {
|
|
27
|
+
if (debug)
|
|
28
|
+
console.log(`usePromise [${debug}]: re-memo [${typeof promise}]`);
|
|
29
|
+
setState(State.pending);
|
|
30
|
+
return promise === null || promise === void 0 ? void 0 : promise();
|
|
31
|
+
}
|
|
32
|
+
catch (e) {
|
|
33
|
+
if (debug)
|
|
34
|
+
console.log(`usePromise [${debug}]: useMemo rejection [${typeof promise}]`);
|
|
35
|
+
setResult(undefined);
|
|
36
|
+
setError(e);
|
|
37
|
+
setState(State.rejected);
|
|
38
|
+
}
|
|
39
|
+
}, dependencies);
|
|
40
|
+
if (debug)
|
|
41
|
+
console.log(`usePromise [${debug}] Main Function`);
|
|
42
|
+
(0, react_1.useEffect)(() => {
|
|
43
|
+
if (debug)
|
|
44
|
+
console.log(`usePromise [${debug}] useEffect`);
|
|
45
|
+
mutex === null || mutex === void 0 ? void 0 : mutex.acquire().then(() => {
|
|
46
|
+
promiseMemo === null || promiseMemo === void 0 ? void 0 : promiseMemo.then((payload) => {
|
|
47
|
+
if (debug)
|
|
48
|
+
console.log(`usePromise [${debug}] then`);
|
|
49
|
+
setResult(payload);
|
|
50
|
+
setError(undefined);
|
|
51
|
+
setState(State.resolved);
|
|
52
|
+
mutex === null || mutex === void 0 ? void 0 : mutex.release();
|
|
53
|
+
}).catch((e) => {
|
|
54
|
+
const error = e;
|
|
55
|
+
console.error(`usePromise: ${error.message}`);
|
|
56
|
+
setResult(undefined);
|
|
57
|
+
setError(error);
|
|
58
|
+
setState(State.rejected);
|
|
59
|
+
mutex === null || mutex === void 0 ? void 0 : mutex.release();
|
|
60
|
+
});
|
|
61
|
+
}).catch((e) => {
|
|
62
|
+
const error = e;
|
|
63
|
+
console.error(`usePromise: ${error.message}`);
|
|
64
|
+
setResult(undefined);
|
|
65
|
+
setError(error);
|
|
66
|
+
setState(State.rejected);
|
|
67
|
+
mutex === null || mutex === void 0 ? void 0 : mutex.release();
|
|
68
|
+
});
|
|
69
|
+
return () => {
|
|
70
|
+
if (debug)
|
|
71
|
+
console.log(`usePromise [${debug}] useEffect callback`);
|
|
72
|
+
};
|
|
73
|
+
}, [...dependencies, promiseMemo]);
|
|
74
|
+
if (debug)
|
|
75
|
+
console.log(`usePromise [${debug}] returning ${JSON.stringify([result, error, state], null, 2)}`);
|
|
76
|
+
return [result, error, state];
|
|
77
|
+
};
|
|
78
|
+
exports.usePromise = usePromise;
|
|
79
|
+
//# sourceMappingURL=usePromise.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"usePromise.js","sourceRoot":"","sources":["../../../../src/contexts/Wallet/usePromise.ts"],"names":[],"mappings":";AAAA,8DAA8D;;;AAE9D,6CAAmC;AACnC,iCAAoE;AAEpE,IAAY,KAIX;AAJD,WAAY,KAAK;IACf,4BAAmB,CAAA;IACnB,8BAAqB,CAAA;IACrB,8BAAqB,CAAA;AACvB,CAAC,EAJW,KAAK,GAAL,aAAK,KAAL,aAAK,QAIhB;AAED;;GAEG;AACI,MAAM,UAAU,GAAG,CACxB,OAA2C,EAC3C,YAA4B,EAC5B,QAA4B,SAAS,EACwB,EAAE;IAC/D,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,IAAA,gBAAQ,GAAW,CAAA;IAC/C,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,IAAA,gBAAQ,GAAS,CAAA;IAC3C,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,IAAA,gBAAQ,EAAQ,KAAK,CAAC,OAAO,CAAC,CAAA;IACxD,MAAM,KAAK,GAAG,IAAA,eAAO,EAAC,GAAG,EAAE;QACzB,OAAO,IAAI,mBAAK,EAAE,CAAA;IACpB,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,IAAI,KAAK;QAAE,OAAO,CAAC,GAAG,CAAC,eAAe,KAAK,eAAe,OAAO,OAAO,GAAG,CAAC,CAAA;IAE5E,MAAM,WAAW,GAA6C,IAAA,eAAO,EAAC,GAAG,EAAE;QACzE,IAAI;YACF,IAAI,KAAK;gBAAE,OAAO,CAAC,GAAG,CAAC,eAAe,KAAK,eAAe,OAAO,OAAO,GAAG,CAAC,CAAA;YAC5E,QAAQ,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;YACvB,OAAO,OAAO,aAAP,OAAO,uBAAP,OAAO,EAAI,CAAA;SACnB;QAAC,OAAO,CAAC,EAAE;YACV,IAAI,KAAK;gBAAE,OAAO,CAAC,GAAG,CAAC,eAAe,KAAK,yBAAyB,OAAO,OAAO,GAAG,CAAC,CAAA;YACtF,SAAS,CAAC,SAAS,CAAC,CAAA;YACpB,QAAQ,CAAC,CAAU,CAAC,CAAA;YACpB,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;SACzB;IACH,CAAC,EAAE,YAAY,CAAC,CAAA;IAEhB,IAAI,KAAK;QAAE,OAAO,CAAC,GAAG,CAAC,eAAe,KAAK,iBAAiB,CAAC,CAAA;IAE7D,IAAA,iBAAS,EAAC,GAAG,EAAE;QACb,IAAI,KAAK;YAAE,OAAO,CAAC,GAAG,CAAC,eAAe,KAAK,aAAa,CAAC,CAAA;QACzD,KAAK,aAAL,KAAK,uBAAL,KAAK,CACD,OAAO,GACR,IAAI,CAAC,GAAG,EAAE;YACT,WAAW,aAAX,WAAW,uBAAX,WAAW,CACP,IAAI,CAAC,CAAC,OAAO,EAAE,EAAE;gBACjB,IAAI,KAAK;oBAAE,OAAO,CAAC,GAAG,CAAC,eAAe,KAAK,QAAQ,CAAC,CAAA;gBACpD,SAAS,CAAC,OAAO,CAAC,CAAA;gBAClB,QAAQ,CAAC,SAAS,CAAC,CAAA;gBACnB,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;gBACxB,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,OAAO,EAAE,CAAA;YAClB,CAAC,EACA,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE;gBACX,MAAM,KAAK,GAAG,CAAU,CAAA;gBACxB,OAAO,CAAC,KAAK,CAAC,eAAe,KAAK,CAAC,OAAO,EAAE,CAAC,CAAA;gBAC7C,SAAS,CAAC,SAAS,CAAC,CAAA;gBACpB,QAAQ,CAAC,KAAK,CAAC,CAAA;gBACf,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;gBACxB,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,OAAO,EAAE,CAAA;YAClB,CAAC,CAAC,CAAA;QACN,CAAC,EACA,KAAK,CAAC,CAAC,CAAC,EAAE,EAAE;YACX,MAAM,KAAK,GAAG,CAAU,CAAA;YACxB,OAAO,CAAC,KAAK,CAAC,eAAe,KAAK,CAAC,OAAO,EAAE,CAAC,CAAA;YAC7C,SAAS,CAAC,SAAS,CAAC,CAAA;YACpB,QAAQ,CAAC,KAAK,CAAC,CAAA;YACf,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;YACxB,KAAK,aAAL,KAAK,uBAAL,KAAK,CAAE,OAAO,EAAE,CAAA;QAClB,CAAC,CAAC,CAAA;QACJ,OAAO,GAAG,EAAE;YACV,IAAI,KAAK;gBAAE,OAAO,CAAC,GAAG,CAAC,eAAe,KAAK,sBAAsB,CAAC,CAAA;QACpE,CAAC,CAAA;IACH,CAAC,EAAE,CAAC,GAAG,YAAY,EAAE,WAAW,CAAC,CAAC,CAAA;IAClC,IAAI,KAAK;QAAE,OAAO,CAAC,GAAG,CAAC,eAAe,KAAK,eAAe,IAAI,CAAC,SAAS,CAAC,CAAC,MAAM,EAAE,KAAK,EAAE,KAAK,CAAC,EAAE,IAAI,EAAE,CAAC,CAAC,EAAE,CAAC,CAAA;IAC5G,OAAO,CAAC,MAAM,EAAE,KAAK,EAAE,KAAK,CAAC,CAAA;AAC/B,CAAC,CAAA;AAjEY,QAAA,UAAU,cAiEtB"}
|
|
@@ -1,13 +1,14 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.useWallets = void 0;
|
|
4
|
+
const tslib_1 = require("tslib");
|
|
4
5
|
const react_promise_1 = require("@xylabs/react-promise");
|
|
5
6
|
const contexts_1 = require("../contexts");
|
|
6
7
|
const useWallet_1 = require("./useWallet");
|
|
7
8
|
const useWallets = ({ wallet, paths }) => {
|
|
8
9
|
const walletContextProvided = (0, contexts_1.useWalletProvided)();
|
|
9
10
|
const [foundWallet] = (0, useWallet_1.useWallet)({ wallet });
|
|
10
|
-
const [wallets, error] = (0, react_promise_1.usePromise)(() => (foundWallet ? Promise.all(paths.map((path) => foundWallet.derivePath(path))) : undefined), [foundWallet, paths]);
|
|
11
|
+
const [wallets, error] = (0, react_promise_1.usePromise)(() => tslib_1.__awaiter(void 0, void 0, void 0, function* () { return (foundWallet ? yield Promise.all(paths.map((path) => foundWallet.derivePath(path))) : undefined); }), [foundWallet, paths]);
|
|
11
12
|
return [wallets !== null && wallets !== void 0 ? wallets : (walletContextProvided ? null : wallets), error];
|
|
12
13
|
};
|
|
13
14
|
exports.useWallets = useWallets;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useWallets.js","sourceRoot":"","sources":["../../../src/hooks/useWallets.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"useWallets.js","sourceRoot":"","sources":["../../../src/hooks/useWallets.ts"],"names":[],"mappings":";;;;AAAA,yDAAkD;AAGlD,0CAA+C;AAC/C,2CAAuC;AAOhC,MAAM,UAAU,GAAG,CAAC,EAAE,MAAM,EAAE,KAAK,EAAqB,EAA4D,EAAE;IAC3H,MAAM,qBAAqB,GAAG,IAAA,4BAAiB,GAAE,CAAA;IACjD,MAAM,CAAC,WAAW,CAAC,GAAG,IAAA,qBAAS,EAAC,EAAE,MAAM,EAAE,CAAC,CAAA;IAC3C,MAAM,CAAC,OAAO,EAAE,KAAK,CAAC,GAAG,IAAA,0BAAU,EACjC,GAAS,EAAE,0DAAC,OAAA,CAAC,WAAW,CAAC,CAAC,CAAC,MAAM,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,WAAW,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAA,GAAA,EAC5G,CAAC,WAAW,EAAE,KAAK,CAAC,CACrB,CAAA;IACD,OAAO,CAAC,OAAO,aAAP,OAAO,cAAP,OAAO,GAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,OAAO,CAAC,EAAE,KAAK,CAAC,CAAA;AACrE,CAAC,CAAA;AARY,QAAA,UAAU,cAQtB"}
|