@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.
Files changed (74) hide show
  1. package/dist/cjs/contexts/DivinedPayload/Context.d.ts +4 -0
  2. package/dist/cjs/contexts/DivinedPayload/Context.d.ts.map +1 -0
  3. package/dist/cjs/contexts/DivinedPayload/Context.js +6 -0
  4. package/dist/cjs/contexts/DivinedPayload/Context.js.map +1 -0
  5. package/dist/cjs/contexts/DivinedPayload/Provider.d.ts +10 -0
  6. package/dist/cjs/contexts/DivinedPayload/Provider.d.ts.map +1 -0
  7. package/dist/cjs/contexts/DivinedPayload/Provider.js +34 -0
  8. package/dist/cjs/contexts/DivinedPayload/Provider.js.map +1 -0
  9. package/dist/cjs/contexts/DivinedPayload/State.d.ts +9 -0
  10. package/dist/cjs/contexts/DivinedPayload/State.d.ts.map +1 -0
  11. package/dist/cjs/contexts/DivinedPayload/State.js +3 -0
  12. package/dist/cjs/contexts/DivinedPayload/State.js.map +1 -0
  13. package/dist/cjs/contexts/DivinedPayload/hooks/index.d.ts +2 -0
  14. package/dist/cjs/contexts/DivinedPayload/hooks/index.d.ts.map +1 -0
  15. package/dist/cjs/contexts/DivinedPayload/hooks/index.js +5 -0
  16. package/dist/cjs/contexts/DivinedPayload/hooks/index.js.map +1 -0
  17. package/dist/cjs/contexts/DivinedPayload/hooks/useBuildHuri.d.ts +2 -0
  18. package/dist/cjs/contexts/DivinedPayload/hooks/useBuildHuri.d.ts.map +1 -0
  19. package/dist/cjs/contexts/DivinedPayload/hooks/useBuildHuri.js +15 -0
  20. package/dist/cjs/contexts/DivinedPayload/hooks/useBuildHuri.js.map +1 -0
  21. package/dist/cjs/contexts/DivinedPayload/index.d.ts +4 -0
  22. package/dist/cjs/contexts/DivinedPayload/index.d.ts.map +1 -0
  23. package/dist/cjs/contexts/DivinedPayload/index.js +7 -0
  24. package/dist/cjs/contexts/DivinedPayload/index.js.map +1 -0
  25. package/dist/cjs/contexts/DivinedPayload/use.d.ts +2 -0
  26. package/dist/cjs/contexts/DivinedPayload/use.d.ts.map +1 -0
  27. package/dist/cjs/contexts/DivinedPayload/use.js +8 -0
  28. package/dist/cjs/contexts/DivinedPayload/use.js.map +1 -0
  29. package/dist/cjs/contexts/index.d.ts +1 -0
  30. package/dist/cjs/contexts/index.d.ts.map +1 -1
  31. package/dist/cjs/contexts/index.js +1 -0
  32. package/dist/cjs/contexts/index.js.map +1 -1
  33. package/dist/docs.json +502 -210
  34. package/dist/esm/contexts/DivinedPayload/Context.d.ts +4 -0
  35. package/dist/esm/contexts/DivinedPayload/Context.d.ts.map +1 -0
  36. package/dist/esm/contexts/DivinedPayload/Context.js +3 -0
  37. package/dist/esm/contexts/DivinedPayload/Context.js.map +1 -0
  38. package/dist/esm/contexts/DivinedPayload/Provider.d.ts +10 -0
  39. package/dist/esm/contexts/DivinedPayload/Provider.d.ts.map +1 -0
  40. package/dist/esm/contexts/DivinedPayload/Provider.js +26 -0
  41. package/dist/esm/contexts/DivinedPayload/Provider.js.map +1 -0
  42. package/dist/esm/contexts/DivinedPayload/State.d.ts +9 -0
  43. package/dist/esm/contexts/DivinedPayload/State.d.ts.map +1 -0
  44. package/dist/esm/contexts/DivinedPayload/State.js +2 -0
  45. package/dist/esm/contexts/DivinedPayload/State.js.map +1 -0
  46. package/dist/esm/contexts/DivinedPayload/hooks/index.d.ts +2 -0
  47. package/dist/esm/contexts/DivinedPayload/hooks/index.d.ts.map +1 -0
  48. package/dist/esm/contexts/DivinedPayload/hooks/index.js +2 -0
  49. package/dist/esm/contexts/DivinedPayload/hooks/index.js.map +1 -0
  50. package/dist/esm/contexts/DivinedPayload/hooks/useBuildHuri.d.ts +2 -0
  51. package/dist/esm/contexts/DivinedPayload/hooks/useBuildHuri.d.ts.map +1 -0
  52. package/dist/esm/contexts/DivinedPayload/hooks/useBuildHuri.js +10 -0
  53. package/dist/esm/contexts/DivinedPayload/hooks/useBuildHuri.js.map +1 -0
  54. package/dist/esm/contexts/DivinedPayload/index.d.ts +4 -0
  55. package/dist/esm/contexts/DivinedPayload/index.d.ts.map +1 -0
  56. package/dist/esm/contexts/DivinedPayload/index.js +4 -0
  57. package/dist/esm/contexts/DivinedPayload/index.js.map +1 -0
  58. package/dist/esm/contexts/DivinedPayload/use.d.ts +2 -0
  59. package/dist/esm/contexts/DivinedPayload/use.d.ts.map +1 -0
  60. package/dist/esm/contexts/DivinedPayload/use.js +4 -0
  61. package/dist/esm/contexts/DivinedPayload/use.js.map +1 -0
  62. package/dist/esm/contexts/index.d.ts +1 -0
  63. package/dist/esm/contexts/index.d.ts.map +1 -1
  64. package/dist/esm/contexts/index.js +1 -0
  65. package/dist/esm/contexts/index.js.map +1 -1
  66. package/package.json +20 -18
  67. package/src/contexts/DivinedPayload/Context.tsx +5 -0
  68. package/src/contexts/DivinedPayload/Provider.tsx +46 -0
  69. package/src/contexts/DivinedPayload/State.ts +9 -0
  70. package/src/contexts/DivinedPayload/hooks/index.ts +1 -0
  71. package/src/contexts/DivinedPayload/hooks/useBuildHuri.tsx +12 -0
  72. package/src/contexts/DivinedPayload/index.ts +3 -0
  73. package/src/contexts/DivinedPayload/use.ts +5 -0
  74. package/src/contexts/index.ts +1 -0
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ import { DivinedPayloadState } from './State';
3
+ export declare const DivinedPayloadContext: import("react").Context<DivinedPayloadState & import("@xyo-network/react-shared").ContextExState>;
4
+ //# sourceMappingURL=Context.d.ts.map
@@ -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,3 @@
1
+ import { createContextEx } from '@xyo-network/react-shared';
2
+ export const DivinedPayloadContext = createContextEx();
3
+ //# sourceMappingURL=Context.js.map
@@ -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,2 @@
1
+ export {};
2
+ //# sourceMappingURL=State.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"State.js","sourceRoot":"","sources":["../../../../src/contexts/DivinedPayload/State.ts"],"names":[],"mappings":""}
@@ -0,0 +1,2 @@
1
+ export * from './useBuildHuri';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -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,2 @@
1
+ export * from './useBuildHuri';
2
+ //# sourceMappingURL=index.js.map
@@ -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,2 @@
1
+ export declare const useBuildHuri: (hash?: string) => string | undefined;
2
+ //# sourceMappingURL=useBuildHuri.d.ts.map
@@ -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,4 @@
1
+ export * from './Context';
2
+ export * from './Provider';
3
+ export * from './use';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -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,4 @@
1
+ export * from './Context';
2
+ export * from './Provider';
3
+ export * from './use';
4
+ //# sourceMappingURL=index.js.map
@@ -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,2 @@
1
+ export declare const useDivinedPayload: () => Omit<import("./State").DivinedPayloadState & import("@xyo-network/react-shared").ContextExState, "provided">;
2
+ //# sourceMappingURL=use.d.ts.map
@@ -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,4 @@
1
+ import { useContextEx } from '@xyo-network/react-shared';
2
+ import { DivinedPayloadContext } from './Context';
3
+ export const useDivinedPayload = () => useContextEx(DivinedPayloadContext, 'DivinedPayload', true);
4
+ //# sourceMappingURL=use.js.map
@@ -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,3 +1,4 @@
1
+ export * from './DivinedPayload';
1
2
  export * from './Payload';
2
3
  export * from './PayloadDiviner';
3
4
  //# sourceMappingURL=index.d.ts.map
@@ -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,3 +1,4 @@
1
+ export * from './DivinedPayload';
1
2
  export * from './Payload';
2
3
  export * from './PayloadDiviner';
3
4
  //# sourceMappingURL=index.js.map
@@ -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.0",
14
- "@emotion/styled": "^11.10.0",
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.29.0",
22
- "@xyo-network/archivist": "^2.29.0",
23
- "@xyo-network/diviner": "^2.29.0",
24
- "@xyo-network/network": "^2.29.0",
25
- "@xyo-network/payload": "^2.29.0",
26
- "@xyo-network/react-archive": "^2.31.1",
27
- "@xyo-network/react-archivist": "^2.31.1",
28
- "@xyo-network/react-archivist-api": "^2.31.1",
29
- "@xyo-network/react-network": "^2.31.1",
30
- "@xyo-network/react-property": "^2.31.1",
31
- "@xyo-network/react-schema": "^2.31.1",
32
- "@xyo-network/react-shared": "^2.31.1",
33
- "@xyo-network/utils": "^2.29.0",
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
- "@xylabs/tsconfig-dom": "^2.5.163",
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.31.1"
90
+ "version": "2.32.0-rc.2",
91
+ "stableVersion": "2.31.2"
90
92
  }
@@ -0,0 +1,5 @@
1
+ import { createContextEx } from '@xyo-network/react-shared'
2
+
3
+ import { DivinedPayloadState } from './State'
4
+
5
+ export const DivinedPayloadContext = createContextEx<DivinedPayloadState>()
@@ -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
+ }
@@ -0,0 +1,3 @@
1
+ export * from './Context'
2
+ export * from './Provider'
3
+ export * from './use'
@@ -0,0 +1,5 @@
1
+ import { useContextEx } from '@xyo-network/react-shared'
2
+
3
+ import { DivinedPayloadContext } from './Context'
4
+
5
+ export const useDivinedPayload = () => useContextEx(DivinedPayloadContext, 'DivinedPayload', true)
@@ -1,2 +1,3 @@
1
+ export * from './DivinedPayload'
1
2
  export * from './Payload'
2
3
  export * from './PayloadDiviner'