@xyo-network/react-payload 2.31.1 → 2.32.0-rc.2
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/DivinedPayload/Context.d.ts +4 -0
- package/dist/cjs/contexts/DivinedPayload/Context.d.ts.map +1 -0
- package/dist/cjs/contexts/DivinedPayload/Context.js +6 -0
- package/dist/cjs/contexts/DivinedPayload/Context.js.map +1 -0
- package/dist/cjs/contexts/DivinedPayload/Provider.d.ts +10 -0
- package/dist/cjs/contexts/DivinedPayload/Provider.d.ts.map +1 -0
- package/dist/cjs/contexts/DivinedPayload/Provider.js +34 -0
- package/dist/cjs/contexts/DivinedPayload/Provider.js.map +1 -0
- package/dist/cjs/contexts/DivinedPayload/State.d.ts +9 -0
- package/dist/cjs/contexts/DivinedPayload/State.d.ts.map +1 -0
- package/dist/cjs/contexts/DivinedPayload/State.js +3 -0
- package/dist/cjs/contexts/DivinedPayload/State.js.map +1 -0
- package/dist/cjs/contexts/DivinedPayload/hooks/index.d.ts +2 -0
- package/dist/cjs/contexts/DivinedPayload/hooks/index.d.ts.map +1 -0
- package/dist/cjs/contexts/DivinedPayload/hooks/index.js +5 -0
- package/dist/cjs/contexts/DivinedPayload/hooks/index.js.map +1 -0
- package/dist/cjs/contexts/DivinedPayload/hooks/useBuildHuri.d.ts +2 -0
- package/dist/cjs/contexts/DivinedPayload/hooks/useBuildHuri.d.ts.map +1 -0
- package/dist/cjs/contexts/DivinedPayload/hooks/useBuildHuri.js +15 -0
- package/dist/cjs/contexts/DivinedPayload/hooks/useBuildHuri.js.map +1 -0
- package/dist/cjs/contexts/DivinedPayload/index.d.ts +4 -0
- package/dist/cjs/contexts/DivinedPayload/index.d.ts.map +1 -0
- package/dist/cjs/contexts/DivinedPayload/index.js +7 -0
- package/dist/cjs/contexts/DivinedPayload/index.js.map +1 -0
- package/dist/cjs/contexts/DivinedPayload/use.d.ts +2 -0
- package/dist/cjs/contexts/DivinedPayload/use.d.ts.map +1 -0
- package/dist/cjs/contexts/DivinedPayload/use.js +8 -0
- package/dist/cjs/contexts/DivinedPayload/use.js.map +1 -0
- package/dist/cjs/contexts/index.d.ts +1 -0
- package/dist/cjs/contexts/index.d.ts.map +1 -1
- package/dist/cjs/contexts/index.js +1 -0
- package/dist/cjs/contexts/index.js.map +1 -1
- package/dist/docs.json +502 -210
- package/dist/esm/contexts/DivinedPayload/Context.d.ts +4 -0
- package/dist/esm/contexts/DivinedPayload/Context.d.ts.map +1 -0
- package/dist/esm/contexts/DivinedPayload/Context.js +3 -0
- package/dist/esm/contexts/DivinedPayload/Context.js.map +1 -0
- package/dist/esm/contexts/DivinedPayload/Provider.d.ts +10 -0
- package/dist/esm/contexts/DivinedPayload/Provider.d.ts.map +1 -0
- package/dist/esm/contexts/DivinedPayload/Provider.js +26 -0
- package/dist/esm/contexts/DivinedPayload/Provider.js.map +1 -0
- package/dist/esm/contexts/DivinedPayload/State.d.ts +9 -0
- package/dist/esm/contexts/DivinedPayload/State.d.ts.map +1 -0
- package/dist/esm/contexts/DivinedPayload/State.js +2 -0
- package/dist/esm/contexts/DivinedPayload/State.js.map +1 -0
- package/dist/esm/contexts/DivinedPayload/hooks/index.d.ts +2 -0
- package/dist/esm/contexts/DivinedPayload/hooks/index.d.ts.map +1 -0
- package/dist/esm/contexts/DivinedPayload/hooks/index.js +2 -0
- package/dist/esm/contexts/DivinedPayload/hooks/index.js.map +1 -0
- package/dist/esm/contexts/DivinedPayload/hooks/useBuildHuri.d.ts +2 -0
- package/dist/esm/contexts/DivinedPayload/hooks/useBuildHuri.d.ts.map +1 -0
- package/dist/esm/contexts/DivinedPayload/hooks/useBuildHuri.js +10 -0
- package/dist/esm/contexts/DivinedPayload/hooks/useBuildHuri.js.map +1 -0
- package/dist/esm/contexts/DivinedPayload/index.d.ts +4 -0
- package/dist/esm/contexts/DivinedPayload/index.d.ts.map +1 -0
- package/dist/esm/contexts/DivinedPayload/index.js +4 -0
- package/dist/esm/contexts/DivinedPayload/index.js.map +1 -0
- package/dist/esm/contexts/DivinedPayload/use.d.ts +2 -0
- package/dist/esm/contexts/DivinedPayload/use.d.ts.map +1 -0
- package/dist/esm/contexts/DivinedPayload/use.js +4 -0
- package/dist/esm/contexts/DivinedPayload/use.js.map +1 -0
- package/dist/esm/contexts/index.d.ts +1 -0
- package/dist/esm/contexts/index.d.ts.map +1 -1
- package/dist/esm/contexts/index.js +1 -0
- package/dist/esm/contexts/index.js.map +1 -1
- package/package.json +20 -18
- package/src/contexts/DivinedPayload/Context.tsx +5 -0
- package/src/contexts/DivinedPayload/Provider.tsx +46 -0
- package/src/contexts/DivinedPayload/State.ts +9 -0
- package/src/contexts/DivinedPayload/hooks/index.ts +1 -0
- package/src/contexts/DivinedPayload/hooks/useBuildHuri.tsx +12 -0
- package/src/contexts/DivinedPayload/index.ts +3 -0
- package/src/contexts/DivinedPayload/use.ts +5 -0
- package/src/contexts/index.ts +1 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Context.d.ts","sourceRoot":"","sources":["../../../../src/contexts/DivinedPayload/Context.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAE,mBAAmB,EAAE,MAAM,SAAS,CAAA;AAE7C,eAAO,MAAM,qBAAqB,mGAAyC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Context.js","sourceRoot":"","sources":["../../../../src/contexts/DivinedPayload/Context.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,2BAA2B,CAAA;AAI3D,MAAM,CAAC,MAAM,qBAAqB,GAAG,eAAe,EAAuB,CAAA"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/// <reference types="react" />
|
|
2
|
+
import { WithChildren } from '@xylabs/react-shared';
|
|
3
|
+
interface DivinedPayloadProviderProps extends WithChildren {
|
|
4
|
+
hash?: string;
|
|
5
|
+
}
|
|
6
|
+
export declare const DivinedPayloadProvider: React.FC<DivinedPayloadProviderProps>;
|
|
7
|
+
export declare const DivinedPayloadWithHandleInner: React.FC<WithChildren>;
|
|
8
|
+
export declare const DivinedPayloadWithHandleProvider: React.FC<DivinedPayloadProviderProps>;
|
|
9
|
+
export {};
|
|
10
|
+
//# sourceMappingURL=Provider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Provider.d.ts","sourceRoot":"","sources":["../../../../src/contexts/DivinedPayload/Provider.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAA;AAUnD,UAAU,2BAA4B,SAAQ,YAAY;IACxD,IAAI,CAAC,EAAE,MAAM,CAAA;CACd;AAED,eAAO,MAAM,sBAAsB,EAAE,KAAK,CAAC,EAAE,CAAC,2BAA2B,CAaxE,CAAA;AAED,eAAO,MAAM,6BAA6B,EAAE,KAAK,CAAC,EAAE,CAAC,YAAY,CAQhE,CAAA;AAED,eAAO,MAAM,gCAAgC,EAAE,KAAK,CAAC,EAAE,CAAC,2BAA2B,CAMlF,CAAA"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
import { XyoApiErrorRender } from '@xyo-network/react-auth-service';
|
|
3
|
+
import { ResultLoader } from '@xyo-network/react-webapp';
|
|
4
|
+
import { useParams, useSearchParams } from 'react-router-dom';
|
|
5
|
+
import { useDivinePayload } from '../PayloadDiviner';
|
|
6
|
+
import { DivinedPayloadContext } from './Context';
|
|
7
|
+
import { useBuildHuri } from './hooks';
|
|
8
|
+
import { useDivinedPayload } from './use';
|
|
9
|
+
export const DivinedPayloadProvider = ({ children, hash }) => {
|
|
10
|
+
const { hash: hashParam } = useParams();
|
|
11
|
+
const huriFromHashParam = useBuildHuri(hashParam);
|
|
12
|
+
const [params] = useSearchParams();
|
|
13
|
+
const huriSearchParameter = params.get('huri');
|
|
14
|
+
const decodedHuriParam = decodeURIComponent(huriSearchParameter ?? '');
|
|
15
|
+
const huriUri = hash ?? decodedHuriParam ? decodedHuriParam : huriFromHashParam;
|
|
16
|
+
const [payload, setPayload, payloadError] = useDivinePayload(huriUri);
|
|
17
|
+
return _jsx(DivinedPayloadContext.Provider, { value: { payload, payloadError, provided: true, setPayload }, children: children });
|
|
18
|
+
};
|
|
19
|
+
export const DivinedPayloadWithHandleInner = ({ children }) => {
|
|
20
|
+
const { payload, payloadError } = useDivinedPayload();
|
|
21
|
+
return (_jsx(ResultLoader, { searchResult: payload, apiError: payloadError, notFound: payload === null, children: _jsx(XyoApiErrorRender, { apiError: payloadError, children: children }) }));
|
|
22
|
+
};
|
|
23
|
+
export const DivinedPayloadWithHandleProvider = ({ children, ...props }) => {
|
|
24
|
+
return (_jsx(DivinedPayloadProvider, { ...props, children: _jsx(DivinedPayloadWithHandleInner, { children: children }) }));
|
|
25
|
+
};
|
|
26
|
+
//# sourceMappingURL=Provider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Provider.js","sourceRoot":"","sources":["../../../../src/contexts/DivinedPayload/Provider.tsx"],"names":[],"mappings":";AACA,OAAO,EAAE,iBAAiB,EAAE,MAAM,iCAAiC,CAAA;AACnE,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAA;AACxD,OAAO,EAAE,SAAS,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAA;AAE7D,OAAO,EAAE,gBAAgB,EAAE,MAAM,mBAAmB,CAAA;AACpD,OAAO,EAAE,qBAAqB,EAAE,MAAM,WAAW,CAAA;AACjD,OAAO,EAAE,YAAY,EAAE,MAAM,SAAS,CAAA;AACtC,OAAO,EAAE,iBAAiB,EAAE,MAAM,OAAO,CAAA;AAMzC,MAAM,CAAC,MAAM,sBAAsB,GAA0C,CAAC,EAAE,QAAQ,EAAE,IAAI,EAAE,EAAE,EAAE;IAClG,MAAM,EAAE,IAAI,EAAE,SAAS,EAAE,GAAG,SAAS,EAAE,CAAA;IAEvC,MAAM,iBAAiB,GAAG,YAAY,CAAC,SAAS,CAAC,CAAA;IAEjD,MAAM,CAAC,MAAM,CAAC,GAAG,eAAe,EAAE,CAAA;IAClC,MAAM,mBAAmB,GAAG,MAAM,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;IAC9C,MAAM,gBAAgB,GAAG,kBAAkB,CAAC,mBAAmB,IAAI,EAAE,CAAC,CAAA;IACtE,MAAM,OAAO,GAAG,IAAI,IAAI,gBAAgB,CAAC,CAAC,CAAC,gBAAgB,CAAC,CAAC,CAAC,iBAAiB,CAAA;IAE/E,MAAM,CAAC,OAAO,EAAE,UAAU,EAAE,YAAY,CAAC,GAAG,gBAAgB,CAAC,OAAO,CAAC,CAAA;IAErE,OAAO,KAAC,qBAAqB,CAAC,QAAQ,IAAC,KAAK,EAAE,EAAE,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,IAAI,EAAE,UAAU,EAAE,YAAG,QAAQ,GAAkC,CAAA;AAClJ,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,6BAA6B,GAA2B,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE;IACpF,MAAM,EAAE,OAAO,EAAE,YAAY,EAAE,GAAG,iBAAiB,EAAE,CAAA;IAErD,OAAO,CACL,KAAC,YAAY,IAAC,YAAY,EAAE,OAAO,EAAE,QAAQ,EAAE,YAAY,EAAE,QAAQ,EAAE,OAAO,KAAK,IAAI,YACrF,KAAC,iBAAiB,IAAC,QAAQ,EAAE,YAAY,YAAG,QAAQ,GAAqB,GAC5D,CAChB,CAAA;AACH,CAAC,CAAA;AAED,MAAM,CAAC,MAAM,gCAAgC,GAA0C,CAAC,EAAE,QAAQ,EAAE,GAAG,KAAK,EAAE,EAAE,EAAE;IAChH,OAAO,CACL,KAAC,sBAAsB,OAAK,KAAK,YAC/B,KAAC,6BAA6B,cAAE,QAAQ,GAAiC,GAClD,CAC1B,CAAA;AACH,CAAC,CAAA"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { XyoPayload } from '@xyo-network/payload';
|
|
2
|
+
import { ContextExState } from '@xyo-network/react-shared';
|
|
3
|
+
import { Dispatch } from 'react';
|
|
4
|
+
export interface DivinedPayloadState extends ContextExState {
|
|
5
|
+
payload?: XyoPayload | null;
|
|
6
|
+
setPayload?: Dispatch<XyoPayload | null | undefined>;
|
|
7
|
+
payloadError?: Error;
|
|
8
|
+
}
|
|
9
|
+
//# sourceMappingURL=State.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"State.d.ts","sourceRoot":"","sources":["../../../../src/contexts/DivinedPayload/State.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAA;AACjD,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAA;AAC1D,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAEhC,MAAM,WAAW,mBAAoB,SAAQ,cAAc;IACzD,OAAO,CAAC,EAAE,UAAU,GAAG,IAAI,CAAA;IAC3B,UAAU,CAAC,EAAE,QAAQ,CAAC,UAAU,GAAG,IAAI,GAAG,SAAS,CAAC,CAAA;IACpD,YAAY,CAAC,EAAE,KAAK,CAAA;CACrB"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"State.js","sourceRoot":"","sources":["../../../../src/contexts/DivinedPayload/State.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/contexts/DivinedPayload/hooks/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/contexts/DivinedPayload/hooks/index.ts"],"names":[],"mappings":"AAAA,cAAc,gBAAgB,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useBuildHuri.d.ts","sourceRoot":"","sources":["../../../../../src/contexts/DivinedPayload/hooks/useBuildHuri.tsx"],"names":[],"mappings":"AAEA,eAAO,MAAM,YAAY,UAAW,MAAM,uBASzC,CAAA"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
import { useNetwork } from '@xyo-network/react-network';
|
|
2
|
+
export const useBuildHuri = (hash) => {
|
|
3
|
+
const { network } = useNetwork();
|
|
4
|
+
const networkUri = network?.nodes?.find((node) => node.type === 'archivist')?.uri;
|
|
5
|
+
if (!hash) {
|
|
6
|
+
return;
|
|
7
|
+
}
|
|
8
|
+
return `${networkUri}/${hash}`;
|
|
9
|
+
};
|
|
10
|
+
//# sourceMappingURL=useBuildHuri.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"useBuildHuri.js","sourceRoot":"","sources":["../../../../../src/contexts/DivinedPayload/hooks/useBuildHuri.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAA;AAEvD,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,IAAa,EAAE,EAAE;IAC5C,MAAM,EAAE,OAAO,EAAE,GAAG,UAAU,EAAE,CAAA;IAChC,MAAM,UAAU,GAAG,OAAO,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,IAAI,KAAK,WAAW,CAAC,EAAE,GAAG,CAAA;IAEjF,IAAI,CAAC,IAAI,EAAE;QACT,OAAM;KACP;IAED,OAAO,GAAG,UAAU,IAAI,IAAI,EAAE,CAAA;AAChC,CAAC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/contexts/DivinedPayload/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAA;AACzB,cAAc,YAAY,CAAA;AAC1B,cAAc,OAAO,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/contexts/DivinedPayload/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAA;AACzB,cAAc,YAAY,CAAA;AAC1B,cAAc,OAAO,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use.d.ts","sourceRoot":"","sources":["../../../../src/contexts/DivinedPayload/use.ts"],"names":[],"mappings":"AAIA,eAAO,MAAM,iBAAiB,oHAAoE,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"use.js","sourceRoot":"","sources":["../../../../src/contexts/DivinedPayload/use.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAA;AAExD,OAAO,EAAE,qBAAqB,EAAE,MAAM,WAAW,CAAA;AAEjD,MAAM,CAAC,MAAM,iBAAiB,GAAG,GAAG,EAAE,CAAC,YAAY,CAAC,qBAAqB,EAAE,gBAAgB,EAAE,IAAI,CAAC,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/contexts/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAA;AACzB,cAAc,kBAAkB,CAAA"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/contexts/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAA;AAChC,cAAc,WAAW,CAAA;AACzB,cAAc,kBAAkB,CAAA"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/contexts/index.ts"],"names":[],"mappings":"AAAA,cAAc,WAAW,CAAA;AACzB,cAAc,kBAAkB,CAAA"}
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/contexts/index.ts"],"names":[],"mappings":"AAAA,cAAc,kBAAkB,CAAA;AAChC,cAAc,WAAW,CAAA;AACzB,cAAc,kBAAkB,CAAA"}
|
package/package.json
CHANGED
|
@@ -10,27 +10,29 @@
|
|
|
10
10
|
"url": "https://github.com/XYOracleNetwork/sdk-xyo-react-js/issues"
|
|
11
11
|
},
|
|
12
12
|
"dependencies": {
|
|
13
|
-
"@emotion/react": "^11.10.
|
|
14
|
-
"@emotion/styled": "^11.10.
|
|
13
|
+
"@emotion/react": "^11.10.4",
|
|
14
|
+
"@emotion/styled": "^11.10.4",
|
|
15
15
|
"@mui/icons-material": "^5.10.3",
|
|
16
16
|
"@mui/material": "^5.10.3",
|
|
17
17
|
"@xylabs/react-button": "^2.14.14",
|
|
18
18
|
"@xylabs/react-flexbox": "^2.14.14",
|
|
19
19
|
"@xylabs/react-quick-tip-button": "^2.14.14",
|
|
20
20
|
"@xylabs/react-shared": "^2.14.14",
|
|
21
|
-
"@xyo-network/api": "^2.
|
|
22
|
-
"@xyo-network/archivist": "^2.
|
|
23
|
-
"@xyo-network/diviner": "^2.
|
|
24
|
-
"@xyo-network/network": "^2.
|
|
25
|
-
"@xyo-network/payload": "^2.
|
|
26
|
-
"@xyo-network/react-archive": "^2.
|
|
27
|
-
"@xyo-network/react-archivist": "^2.
|
|
28
|
-
"@xyo-network/react-archivist-api": "^2.
|
|
29
|
-
"@xyo-network/react-
|
|
30
|
-
"@xyo-network/react-
|
|
31
|
-
"@xyo-network/react-
|
|
32
|
-
"@xyo-network/react-
|
|
33
|
-
"@xyo-network/
|
|
21
|
+
"@xyo-network/api": "^2.30.0-rc.3",
|
|
22
|
+
"@xyo-network/archivist": "^2.30.0-rc.3",
|
|
23
|
+
"@xyo-network/diviner": "^2.30.0-rc.3",
|
|
24
|
+
"@xyo-network/network": "^2.30.0-rc.3",
|
|
25
|
+
"@xyo-network/payload": "^2.30.0-rc.3",
|
|
26
|
+
"@xyo-network/react-archive": "^2.32.0-rc.2",
|
|
27
|
+
"@xyo-network/react-archivist": "^2.32.0-rc.2",
|
|
28
|
+
"@xyo-network/react-archivist-api": "^2.32.0-rc.2",
|
|
29
|
+
"@xyo-network/react-auth-service": "^2.32.0-rc.2",
|
|
30
|
+
"@xyo-network/react-network": "^2.32.0-rc.2",
|
|
31
|
+
"@xyo-network/react-property": "^2.32.0-rc.2",
|
|
32
|
+
"@xyo-network/react-schema": "^2.32.0-rc.2",
|
|
33
|
+
"@xyo-network/react-shared": "^2.32.0-rc.2",
|
|
34
|
+
"@xyo-network/react-webapp": "^2.32.0-rc.2",
|
|
35
|
+
"@xyo-network/utils": "^2.30.0-rc.3",
|
|
34
36
|
"lodash": "^4.17.21",
|
|
35
37
|
"react": "^18.2.0",
|
|
36
38
|
"react-dom": "^18.2.0",
|
|
@@ -41,8 +43,7 @@
|
|
|
41
43
|
"description": "Common React library for all XYO projects that use React",
|
|
42
44
|
"devDependencies": {
|
|
43
45
|
"@storybook/react": "^6.5.10",
|
|
44
|
-
"@
|
|
45
|
-
"@xyo-network/react-storybook": "^2.31.1"
|
|
46
|
+
"@xyo-network/react-storybook": "^2.32.0-rc.2"
|
|
46
47
|
},
|
|
47
48
|
"browser": "dist/esm/index.js",
|
|
48
49
|
"docs": "dist/docs.json",
|
|
@@ -86,5 +87,6 @@
|
|
|
86
87
|
},
|
|
87
88
|
"sideEffects": false,
|
|
88
89
|
"types": "dist/esm/index.d.ts",
|
|
89
|
-
"version": "2.
|
|
90
|
+
"version": "2.32.0-rc.2",
|
|
91
|
+
"stableVersion": "2.31.2"
|
|
90
92
|
}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { WithChildren } from '@xylabs/react-shared'
|
|
2
|
+
import { XyoApiErrorRender } from '@xyo-network/react-auth-service'
|
|
3
|
+
import { ResultLoader } from '@xyo-network/react-webapp'
|
|
4
|
+
import { useParams, useSearchParams } from 'react-router-dom'
|
|
5
|
+
|
|
6
|
+
import { useDivinePayload } from '../PayloadDiviner'
|
|
7
|
+
import { DivinedPayloadContext } from './Context'
|
|
8
|
+
import { useBuildHuri } from './hooks'
|
|
9
|
+
import { useDivinedPayload } from './use'
|
|
10
|
+
|
|
11
|
+
interface DivinedPayloadProviderProps extends WithChildren {
|
|
12
|
+
hash?: string
|
|
13
|
+
}
|
|
14
|
+
|
|
15
|
+
export const DivinedPayloadProvider: React.FC<DivinedPayloadProviderProps> = ({ children, hash }) => {
|
|
16
|
+
const { hash: hashParam } = useParams()
|
|
17
|
+
|
|
18
|
+
const huriFromHashParam = useBuildHuri(hashParam)
|
|
19
|
+
|
|
20
|
+
const [params] = useSearchParams()
|
|
21
|
+
const huriSearchParameter = params.get('huri')
|
|
22
|
+
const decodedHuriParam = decodeURIComponent(huriSearchParameter ?? '')
|
|
23
|
+
const huriUri = hash ?? decodedHuriParam ? decodedHuriParam : huriFromHashParam
|
|
24
|
+
|
|
25
|
+
const [payload, setPayload, payloadError] = useDivinePayload(huriUri)
|
|
26
|
+
|
|
27
|
+
return <DivinedPayloadContext.Provider value={{ payload, payloadError, provided: true, setPayload }}>{children}</DivinedPayloadContext.Provider>
|
|
28
|
+
}
|
|
29
|
+
|
|
30
|
+
export const DivinedPayloadWithHandleInner: React.FC<WithChildren> = ({ children }) => {
|
|
31
|
+
const { payload, payloadError } = useDivinedPayload()
|
|
32
|
+
|
|
33
|
+
return (
|
|
34
|
+
<ResultLoader searchResult={payload} apiError={payloadError} notFound={payload === null}>
|
|
35
|
+
<XyoApiErrorRender apiError={payloadError}>{children}</XyoApiErrorRender>
|
|
36
|
+
</ResultLoader>
|
|
37
|
+
)
|
|
38
|
+
}
|
|
39
|
+
|
|
40
|
+
export const DivinedPayloadWithHandleProvider: React.FC<DivinedPayloadProviderProps> = ({ children, ...props }) => {
|
|
41
|
+
return (
|
|
42
|
+
<DivinedPayloadProvider {...props}>
|
|
43
|
+
<DivinedPayloadWithHandleInner>{children}</DivinedPayloadWithHandleInner>
|
|
44
|
+
</DivinedPayloadProvider>
|
|
45
|
+
)
|
|
46
|
+
}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { XyoPayload } from '@xyo-network/payload'
|
|
2
|
+
import { ContextExState } from '@xyo-network/react-shared'
|
|
3
|
+
import { Dispatch } from 'react'
|
|
4
|
+
|
|
5
|
+
export interface DivinedPayloadState extends ContextExState {
|
|
6
|
+
payload?: XyoPayload | null
|
|
7
|
+
setPayload?: Dispatch<XyoPayload | null | undefined>
|
|
8
|
+
payloadError?: Error
|
|
9
|
+
}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
export * from './useBuildHuri'
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { useNetwork } from '@xyo-network/react-network'
|
|
2
|
+
|
|
3
|
+
export const useBuildHuri = (hash?: string) => {
|
|
4
|
+
const { network } = useNetwork()
|
|
5
|
+
const networkUri = network?.nodes?.find((node) => node.type === 'archivist')?.uri
|
|
6
|
+
|
|
7
|
+
if (!hash) {
|
|
8
|
+
return
|
|
9
|
+
}
|
|
10
|
+
|
|
11
|
+
return `${networkUri}/${hash}`
|
|
12
|
+
}
|
package/src/contexts/index.ts
CHANGED