@xyo-network/react-api 2.32.0-rc.11

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 (143) hide show
  1. package/LICENSE +165 -0
  2. package/README.md +70 -0
  3. package/dist/cjs/components/ApiErrorAlert.d.ts +9 -0
  4. package/dist/cjs/components/ApiErrorAlert.d.ts.map +1 -0
  5. package/dist/cjs/components/ApiErrorAlert.js +13 -0
  6. package/dist/cjs/components/ApiErrorAlert.js.map +1 -0
  7. package/dist/cjs/components/JsonRouteWrapper/JsonApiButton.d.ts +4 -0
  8. package/dist/cjs/components/JsonRouteWrapper/JsonApiButton.d.ts.map +1 -0
  9. package/dist/cjs/components/JsonRouteWrapper/JsonApiButton.js +15 -0
  10. package/dist/cjs/components/JsonRouteWrapper/JsonApiButton.js.map +1 -0
  11. package/dist/cjs/components/JsonRouteWrapper/JsonRouteWrapper.d.ts +11 -0
  12. package/dist/cjs/components/JsonRouteWrapper/JsonRouteWrapper.d.ts.map +1 -0
  13. package/dist/cjs/components/JsonRouteWrapper/JsonRouteWrapper.js +47 -0
  14. package/dist/cjs/components/JsonRouteWrapper/JsonRouteWrapper.js.map +1 -0
  15. package/dist/cjs/components/JsonRouteWrapper/index.d.ts +3 -0
  16. package/dist/cjs/components/JsonRouteWrapper/index.d.ts.map +1 -0
  17. package/dist/cjs/components/JsonRouteWrapper/index.js +6 -0
  18. package/dist/cjs/components/JsonRouteWrapper/index.js.map +1 -0
  19. package/dist/cjs/components/ResultLoader.d.ts +9 -0
  20. package/dist/cjs/components/ResultLoader.d.ts.map +1 -0
  21. package/dist/cjs/components/ResultLoader.js +24 -0
  22. package/dist/cjs/components/ResultLoader.js.map +1 -0
  23. package/dist/cjs/components/index.d.ts +4 -0
  24. package/dist/cjs/components/index.d.ts.map +1 -0
  25. package/dist/cjs/components/index.js +7 -0
  26. package/dist/cjs/components/index.js.map +1 -0
  27. package/dist/cjs/hooks/ResolvePayloadArgs.d.ts +5 -0
  28. package/dist/cjs/hooks/ResolvePayloadArgs.d.ts.map +1 -0
  29. package/dist/cjs/hooks/ResolvePayloadArgs.js +3 -0
  30. package/dist/cjs/hooks/ResolvePayloadArgs.js.map +1 -0
  31. package/dist/cjs/hooks/index.d.ts +6 -0
  32. package/dist/cjs/hooks/index.d.ts.map +1 -0
  33. package/dist/cjs/hooks/index.js +9 -0
  34. package/dist/cjs/hooks/index.js.map +1 -0
  35. package/dist/cjs/hooks/lib/FetchHuriHashOptions.d.ts +4 -0
  36. package/dist/cjs/hooks/lib/FetchHuriHashOptions.d.ts.map +1 -0
  37. package/dist/cjs/hooks/lib/FetchHuriHashOptions.js +3 -0
  38. package/dist/cjs/hooks/lib/FetchHuriHashOptions.js.map +1 -0
  39. package/dist/cjs/hooks/lib/findHuriNetwork.d.ts +4 -0
  40. package/dist/cjs/hooks/lib/findHuriNetwork.d.ts.map +1 -0
  41. package/dist/cjs/hooks/lib/findHuriNetwork.js +14 -0
  42. package/dist/cjs/hooks/lib/findHuriNetwork.js.map +1 -0
  43. package/dist/cjs/hooks/lib/index.d.ts +3 -0
  44. package/dist/cjs/hooks/lib/index.d.ts.map +1 -0
  45. package/dist/cjs/hooks/lib/index.js +6 -0
  46. package/dist/cjs/hooks/lib/index.js.map +1 -0
  47. package/dist/cjs/hooks/useHuriHash.d.ts +13 -0
  48. package/dist/cjs/hooks/useHuriHash.d.ts.map +1 -0
  49. package/dist/cjs/hooks/useHuriHash.js +33 -0
  50. package/dist/cjs/hooks/useHuriHash.js.map +1 -0
  51. package/dist/cjs/hooks/useLoadPayload.d.ts +3 -0
  52. package/dist/cjs/hooks/useLoadPayload.d.ts.map +1 -0
  53. package/dist/cjs/hooks/useLoadPayload.js +57 -0
  54. package/dist/cjs/hooks/useLoadPayload.js.map +1 -0
  55. package/dist/cjs/hooks/useResolveHuri.d.ts +10 -0
  56. package/dist/cjs/hooks/useResolveHuri.d.ts.map +1 -0
  57. package/dist/cjs/hooks/useResolveHuri.js +68 -0
  58. package/dist/cjs/hooks/useResolveHuri.js.map +1 -0
  59. package/dist/cjs/index.d.ts +2 -0
  60. package/dist/cjs/index.d.ts.map +1 -0
  61. package/dist/cjs/index.js +5 -0
  62. package/dist/cjs/index.js.map +1 -0
  63. package/dist/docs.json +19042 -0
  64. package/dist/esm/components/ApiErrorAlert.d.ts +9 -0
  65. package/dist/esm/components/ApiErrorAlert.d.ts.map +1 -0
  66. package/dist/esm/components/ApiErrorAlert.js +7 -0
  67. package/dist/esm/components/ApiErrorAlert.js.map +1 -0
  68. package/dist/esm/components/JsonRouteWrapper/JsonApiButton.d.ts +4 -0
  69. package/dist/esm/components/JsonRouteWrapper/JsonApiButton.d.ts.map +1 -0
  70. package/dist/esm/components/JsonRouteWrapper/JsonApiButton.js +11 -0
  71. package/dist/esm/components/JsonRouteWrapper/JsonApiButton.js.map +1 -0
  72. package/dist/esm/components/JsonRouteWrapper/JsonRouteWrapper.d.ts +11 -0
  73. package/dist/esm/components/JsonRouteWrapper/JsonRouteWrapper.d.ts.map +1 -0
  74. package/dist/esm/components/JsonRouteWrapper/JsonRouteWrapper.js +41 -0
  75. package/dist/esm/components/JsonRouteWrapper/JsonRouteWrapper.js.map +1 -0
  76. package/dist/esm/components/JsonRouteWrapper/index.d.ts +3 -0
  77. package/dist/esm/components/JsonRouteWrapper/index.d.ts.map +1 -0
  78. package/dist/esm/components/JsonRouteWrapper/index.js +3 -0
  79. package/dist/esm/components/JsonRouteWrapper/index.js.map +1 -0
  80. package/dist/esm/components/ResultLoader.d.ts +9 -0
  81. package/dist/esm/components/ResultLoader.d.ts.map +1 -0
  82. package/dist/esm/components/ResultLoader.js +20 -0
  83. package/dist/esm/components/ResultLoader.js.map +1 -0
  84. package/dist/esm/components/index.d.ts +4 -0
  85. package/dist/esm/components/index.d.ts.map +1 -0
  86. package/dist/esm/components/index.js +4 -0
  87. package/dist/esm/components/index.js.map +1 -0
  88. package/dist/esm/hooks/ResolvePayloadArgs.d.ts +5 -0
  89. package/dist/esm/hooks/ResolvePayloadArgs.d.ts.map +1 -0
  90. package/dist/esm/hooks/ResolvePayloadArgs.js +2 -0
  91. package/dist/esm/hooks/ResolvePayloadArgs.js.map +1 -0
  92. package/dist/esm/hooks/index.d.ts +6 -0
  93. package/dist/esm/hooks/index.d.ts.map +1 -0
  94. package/dist/esm/hooks/index.js +6 -0
  95. package/dist/esm/hooks/index.js.map +1 -0
  96. package/dist/esm/hooks/lib/FetchHuriHashOptions.d.ts +4 -0
  97. package/dist/esm/hooks/lib/FetchHuriHashOptions.d.ts.map +1 -0
  98. package/dist/esm/hooks/lib/FetchHuriHashOptions.js +2 -0
  99. package/dist/esm/hooks/lib/FetchHuriHashOptions.js.map +1 -0
  100. package/dist/esm/hooks/lib/findHuriNetwork.d.ts +4 -0
  101. package/dist/esm/hooks/lib/findHuriNetwork.d.ts.map +1 -0
  102. package/dist/esm/hooks/lib/findHuriNetwork.js +9 -0
  103. package/dist/esm/hooks/lib/findHuriNetwork.js.map +1 -0
  104. package/dist/esm/hooks/lib/index.d.ts +3 -0
  105. package/dist/esm/hooks/lib/index.d.ts.map +1 -0
  106. package/dist/esm/hooks/lib/index.js +3 -0
  107. package/dist/esm/hooks/lib/index.js.map +1 -0
  108. package/dist/esm/hooks/useHuriHash.d.ts +13 -0
  109. package/dist/esm/hooks/useHuriHash.d.ts.map +1 -0
  110. package/dist/esm/hooks/useHuriHash.js +30 -0
  111. package/dist/esm/hooks/useHuriHash.js.map +1 -0
  112. package/dist/esm/hooks/useLoadPayload.d.ts +3 -0
  113. package/dist/esm/hooks/useLoadPayload.d.ts.map +1 -0
  114. package/dist/esm/hooks/useLoadPayload.js +52 -0
  115. package/dist/esm/hooks/useLoadPayload.js.map +1 -0
  116. package/dist/esm/hooks/useResolveHuri.d.ts +10 -0
  117. package/dist/esm/hooks/useResolveHuri.d.ts.map +1 -0
  118. package/dist/esm/hooks/useResolveHuri.js +64 -0
  119. package/dist/esm/hooks/useResolveHuri.js.map +1 -0
  120. package/dist/esm/index.d.ts +2 -0
  121. package/dist/esm/index.d.ts.map +1 -0
  122. package/dist/esm/index.js +2 -0
  123. package/dist/esm/index.js.map +1 -0
  124. package/package.json +80 -0
  125. package/src/components/ApiErrorAlert.tsx +21 -0
  126. package/src/components/JsonRouteWrapper/JsonApiButton.tsx +19 -0
  127. package/src/components/JsonRouteWrapper/JsonRouteWrapper.stories.tsx +68 -0
  128. package/src/components/JsonRouteWrapper/JsonRouteWrapper.tsx +85 -0
  129. package/src/components/JsonRouteWrapper/index.ts +2 -0
  130. package/src/components/ResultLoader.stories.tsx +37 -0
  131. package/src/components/ResultLoader.tsx +26 -0
  132. package/src/components/index.ts +3 -0
  133. package/src/hooks/ResolvePayloadArgs.ts +6 -0
  134. package/src/hooks/index.ts +5 -0
  135. package/src/hooks/lib/FetchHuriHashOptions.ts +3 -0
  136. package/src/hooks/lib/findHuriNetwork.ts +13 -0
  137. package/src/hooks/lib/index.ts +2 -0
  138. package/src/hooks/useHuriHash.stories.tsx +108 -0
  139. package/src/hooks/useHuriHash.tsx +40 -0
  140. package/src/hooks/useLoadPayload.stories.tsx +69 -0
  141. package/src/hooks/useLoadPayload.tsx +59 -0
  142. package/src/hooks/useResolveHuri.tsx +75 -0
  143. package/src/index.ts +1 -0
@@ -0,0 +1,9 @@
1
+ /// <reference types="react" />
2
+ import { AlertProps } from '@mui/material';
3
+ import { XyoApiError } from '@xyo-network/api';
4
+ export interface ApiErrorAlertProps extends AlertProps {
5
+ call?: XyoApiError;
6
+ }
7
+ declare const ApiErrorAlert: React.FC<ApiErrorAlertProps>;
8
+ export { ApiErrorAlert };
9
+ //# sourceMappingURL=ApiErrorAlert.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ApiErrorAlert.d.ts","sourceRoot":"","sources":["../../../src/components/ApiErrorAlert.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAS,UAAU,EAA0B,MAAM,eAAe,CAAA;AACzE,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAE9C,MAAM,WAAW,kBAAmB,SAAQ,UAAU;IACpD,IAAI,CAAC,EAAE,WAAW,CAAA;CACnB;AAED,QAAA,MAAM,aAAa,EAAE,KAAK,CAAC,EAAE,CAAC,kBAAkB,CAW/C,CAAA;AAED,OAAO,EAAE,aAAa,EAAE,CAAA"}
@@ -0,0 +1,7 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { Alert, AlertTitle, Typography } from '@mui/material';
3
+ const ApiErrorAlert = ({ call, ...props }) => {
4
+ return (_jsxs(Alert, { severity: "error", ...props, children: [_jsx(AlertTitle, { children: "Whoops! Something went wrong" }), _jsx(Typography, { sx: { wordBreak: 'break-all' }, children: call?.config?.url }), _jsx(Typography, { variant: "caption", mr: 0.5, fontWeight: "bold", children: "Error:" }), _jsx(Typography, { variant: "caption", children: call?.message })] }));
5
+ };
6
+ export { ApiErrorAlert };
7
+ //# sourceMappingURL=ApiErrorAlert.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ApiErrorAlert.js","sourceRoot":"","sources":["../../../src/components/ApiErrorAlert.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,KAAK,EAAc,UAAU,EAAE,UAAU,EAAE,MAAM,eAAe,CAAA;AAOzE,MAAM,aAAa,GAAiC,CAAC,EAAE,IAAI,EAAE,GAAG,KAAK,EAAE,EAAE,EAAE;IACzE,OAAO,CACL,MAAC,KAAK,IAAC,QAAQ,EAAC,OAAO,KAAK,KAAK,aAC/B,KAAC,UAAU,+CAA0C,EACrD,KAAC,UAAU,IAAC,EAAE,EAAE,EAAE,SAAS,EAAE,WAAW,EAAE,YAAG,IAAI,EAAE,MAAM,EAAE,GAAG,GAAc,EAC5E,KAAC,UAAU,IAAC,OAAO,EAAC,SAAS,EAAC,EAAE,EAAE,GAAG,EAAE,UAAU,EAAC,MAAM,uBAE3C,EACb,KAAC,UAAU,IAAC,OAAO,EAAC,SAAS,YAAE,IAAI,EAAE,OAAO,GAAc,IACpD,CACT,CAAA;AACH,CAAC,CAAA;AAED,OAAO,EAAE,aAAa,EAAE,CAAA"}
@@ -0,0 +1,4 @@
1
+ /// <reference types="react" />
2
+ import { ButtonExProps } from '@xylabs/react-button';
3
+ export declare const JsonApiButton: React.FC<ButtonExProps>;
4
+ //# sourceMappingURL=JsonApiButton.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"JsonApiButton.d.ts","sourceRoot":"","sources":["../../../../src/components/JsonRouteWrapper/JsonApiButton.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAY,aAAa,EAAE,MAAM,sBAAsB,CAAA;AAG9D,eAAO,MAAM,aAAa,EAAE,KAAK,CAAC,EAAE,CAAC,aAAa,CAejD,CAAA"}
@@ -0,0 +1,11 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { ButtonEx } from '@xylabs/react-button';
3
+ import { useSearchParams } from 'react-router-dom';
4
+ export const JsonApiButton = (props) => {
5
+ const [searchParams, setSearchParams] = useSearchParams();
6
+ return (_jsx(ButtonEx, { marginX: 2, variant: "outlined", onClick: () => {
7
+ searchParams.set('json', 'true');
8
+ setSearchParams(searchParams);
9
+ }, ...props, children: "JSON" }));
10
+ };
11
+ //# sourceMappingURL=JsonApiButton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"JsonApiButton.js","sourceRoot":"","sources":["../../../../src/components/JsonRouteWrapper/JsonApiButton.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,EAAiB,MAAM,sBAAsB,CAAA;AAC9D,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAA;AAElD,MAAM,CAAC,MAAM,aAAa,GAA4B,CAAC,KAAK,EAAE,EAAE;IAC9D,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,eAAe,EAAE,CAAA;IACzD,OAAO,CACL,KAAC,QAAQ,IACP,OAAO,EAAE,CAAC,EACV,OAAO,EAAC,UAAU,EAClB,OAAO,EAAE,GAAG,EAAE;YACZ,YAAY,CAAC,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;YAChC,eAAe,CAAC,YAAY,CAAC,CAAA;QAC/B,CAAC,KACG,KAAK,qBAGA,CACZ,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1,11 @@
1
+ /// <reference types="react" />
2
+ import { FlexBoxProps } from '@xylabs/react-flexbox';
3
+ import { ReactJsonViewProps } from 'react-json-view';
4
+ export interface JsonFromPromiseProps extends FlexBoxProps {
5
+ callback: () => Promise<object | undefined>;
6
+ noBackButton?: boolean;
7
+ noJsonButton?: boolean;
8
+ jsonViewProps?: ReactJsonViewProps;
9
+ }
10
+ export declare const JsonRouteWrapper: React.FC<JsonFromPromiseProps>;
11
+ //# sourceMappingURL=JsonRouteWrapper.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"JsonRouteWrapper.d.ts","sourceRoot":"","sources":["../../../../src/components/JsonRouteWrapper/JsonRouteWrapper.tsx"],"names":[],"mappings":";AAEA,OAAO,EAAE,YAAY,EAAoB,MAAM,uBAAuB,CAAA;AAItE,OAAO,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAA;AAOpD,MAAM,WAAW,oBAAqB,SAAQ,YAAY;IACxD,QAAQ,EAAE,MAAM,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC,CAAA;IAC3C,YAAY,CAAC,EAAE,OAAO,CAAA;IACtB,YAAY,CAAC,EAAE,OAAO,CAAA;IACtB,aAAa,CAAC,EAAE,kBAAkB,CAAA;CACnC;AAED,eAAO,MAAM,gBAAgB,EAAE,KAAK,CAAC,EAAE,CAAC,oBAAoB,CAgE3D,CAAA"}
@@ -0,0 +1,41 @@
1
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { ButtonEx } from '@xylabs/react-button';
3
+ import { ErrorDialog } from '@xylabs/react-dialogs';
4
+ import { FlexCol, FlexRow } from '@xylabs/react-flexbox';
5
+ import { useAsyncEffect } from '@xylabs/react-shared';
6
+ import { lazy, Suspense, useState } from 'react';
7
+ import { useSearchParams } from 'react-router-dom';
8
+ import { JsonApiButton } from './JsonApiButton';
9
+ const JsonView = lazy(() => import(/* webpackChunkName: "jsonView" */ 'react-json-view'));
10
+ export const JsonRouteWrapper = ({ callback, children, noBackButton = false, noJsonButton = false, jsonViewProps, ...props }) => {
11
+ const [apiResponse, setApiResponse] = useState();
12
+ const [apiError, setApiError] = useState();
13
+ const [searchParams, setSearchParams] = useSearchParams();
14
+ const active = !!searchParams.get('json');
15
+ useAsyncEffect(
16
+ // eslint-disable-next-line react-hooks/exhaustive-deps
17
+ async (mounted) => {
18
+ try {
19
+ const response = await callback();
20
+ if (mounted()) {
21
+ setApiResponse(response);
22
+ }
23
+ }
24
+ catch (ex) {
25
+ if (mounted()) {
26
+ const error = ex;
27
+ if (error.isXyoError) {
28
+ setApiError(error);
29
+ }
30
+ else {
31
+ throw ex;
32
+ }
33
+ }
34
+ }
35
+ }, [callback]);
36
+ return (_jsx(FlexCol, { ...props, children: active ? (_jsxs(_Fragment, { children: [_jsx(Suspense, { fallback: null, children: apiResponse && _jsx(JsonView, { src: apiResponse, collapseStringsAfterLength: 64, ...jsonViewProps }) }), !noBackButton && (_jsx(FlexRow, { marginY: 3, children: _jsx(ButtonEx, { flexDirection: "row", variant: "outlined", onClick: () => {
37
+ searchParams.delete('json');
38
+ setSearchParams(searchParams);
39
+ }, children: "Back" }) })), _jsx(ErrorDialog, { title: "Error Fetching JSON", error: apiError, open: !!apiError, onAction: () => setApiError(undefined) })] })) : (_jsxs(_Fragment, { children: [children, !noJsonButton && _jsx(JsonApiButton, { marginTop: 2 })] })) }));
40
+ };
41
+ //# sourceMappingURL=JsonRouteWrapper.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"JsonRouteWrapper.js","sourceRoot":"","sources":["../../../../src/components/JsonRouteWrapper/JsonRouteWrapper.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAA;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAA;AACnD,OAAO,EAAgB,OAAO,EAAE,OAAO,EAAE,MAAM,uBAAuB,CAAA;AACtE,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAA;AAErD,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAEhD,OAAO,EAAE,eAAe,EAAE,MAAM,kBAAkB,CAAA;AAElD,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAE/C,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,EAAE,CAAC,MAAM,CAAC,kCAAkC,CAAC,iBAAiB,CAAC,CAAC,CAAA;AASzF,MAAM,CAAC,MAAM,gBAAgB,GAAmC,CAAC,EAC/D,QAAQ,EACR,QAAQ,EACR,YAAY,GAAG,KAAK,EACpB,YAAY,GAAG,KAAK,EACpB,aAAa,EACb,GAAG,KAAK,EACT,EAAE,EAAE;IACH,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,EAAU,CAAA;IACxD,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,QAAQ,EAAe,CAAA;IACvD,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,eAAe,EAAE,CAAA;IACzD,MAAM,MAAM,GAAG,CAAC,CAAC,YAAY,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;IAEzC,cAAc;IACZ,uDAAuD;IACvD,KAAK,EAAE,OAAO,EAAE,EAAE;QAChB,IAAI;YACF,MAAM,QAAQ,GAAG,MAAM,QAAQ,EAAE,CAAA;YACjC,IAAI,OAAO,EAAE,EAAE;gBACb,cAAc,CAAC,QAAQ,CAAC,CAAA;aACzB;SACF;QAAC,OAAO,EAAE,EAAE;YACX,IAAI,OAAO,EAAE,EAAE;gBACb,MAAM,KAAK,GAAG,EAAiB,CAAA;gBAC/B,IAAI,KAAK,CAAC,UAAU,EAAE;oBACpB,WAAW,CAAC,KAAK,CAAC,CAAA;iBACnB;qBAAM;oBACL,MAAM,EAAE,CAAA;iBACT;aACF;SACF;IACH,CAAC,EACD,CAAC,QAAQ,CAAC,CACX,CAAA;IAED,OAAO,CACL,KAAC,OAAO,OAAK,KAAK,YACf,MAAM,CAAC,CAAC,CAAC,CACR,8BACE,KAAC,QAAQ,IAAC,QAAQ,EAAE,IAAI,YAAG,WAAW,IAAI,KAAC,QAAQ,IAAC,GAAG,EAAE,WAAW,EAAE,0BAA0B,EAAE,EAAE,KAAM,aAAa,GAAI,GAAY,EACtI,CAAC,YAAY,IAAI,CAChB,KAAC,OAAO,IAAC,OAAO,EAAE,CAAC,YACjB,KAAC,QAAQ,IACP,aAAa,EAAC,KAAK,EACnB,OAAO,EAAC,UAAU,EAClB,OAAO,EAAE,GAAG,EAAE;4BACZ,YAAY,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;4BAC3B,eAAe,CAAC,YAAY,CAAC,CAAA;wBAC/B,CAAC,qBAGQ,GACH,CACX,EACD,KAAC,WAAW,IAAC,KAAK,EAAC,qBAAqB,EAAC,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,CAAC,CAAC,QAAQ,EAAE,QAAQ,EAAE,GAAG,EAAE,CAAC,WAAW,CAAC,SAAS,CAAC,GAAI,IACrH,CACJ,CAAC,CAAC,CAAC,CACF,8BACG,QAAQ,EACR,CAAC,YAAY,IAAI,KAAC,aAAa,IAAC,SAAS,EAAE,CAAC,GAAI,IAChD,CACJ,GACO,CACX,CAAA;AACH,CAAC,CAAA"}
@@ -0,0 +1,3 @@
1
+ export * from './JsonApiButton';
2
+ export * from './JsonRouteWrapper';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/components/JsonRouteWrapper/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAA;AAC/B,cAAc,oBAAoB,CAAA"}
@@ -0,0 +1,3 @@
1
+ export * from './JsonApiButton';
2
+ export * from './JsonRouteWrapper';
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/JsonRouteWrapper/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAA;AAC/B,cAAc,oBAAoB,CAAA"}
@@ -0,0 +1,9 @@
1
+ import { XyoApiError } from '@xyo-network/api';
2
+ import { PropsWithChildren } from 'react';
3
+ export interface HandleItemDetailLoadingProps<T> {
4
+ apiError: Error | XyoApiError | undefined;
5
+ notFound: boolean;
6
+ searchResult: T | undefined;
7
+ }
8
+ export declare function ResultLoader<T>(props: PropsWithChildren<HandleItemDetailLoadingProps<T>>): JSX.Element;
9
+ //# sourceMappingURL=ResultLoader.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ResultLoader.d.ts","sourceRoot":"","sources":["../../../src/components/ResultLoader.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAE9C,OAAO,EAAE,iBAAiB,EAAE,MAAM,OAAO,CAAA;AAEzC,MAAM,WAAW,4BAA4B,CAAC,CAAC;IAC7C,QAAQ,EAAE,KAAK,GAAG,WAAW,GAAG,SAAS,CAAA;IACzC,QAAQ,EAAE,OAAO,CAAA;IACjB,YAAY,EAAE,CAAC,GAAG,SAAS,CAAA;CAC5B;AAED,wBAAgB,YAAY,CAAC,CAAC,EAAE,KAAK,EAAE,iBAAiB,CAAC,4BAA4B,CAAC,CAAC,CAAC,CAAC,eAcxF"}
@@ -0,0 +1,20 @@
1
+ import { jsx as _jsx, Fragment as _Fragment } from "react/jsx-runtime";
2
+ import { FlexGrowRow } from '@xylabs/react-flexbox';
3
+ import { NotFound } from '@xyo-network/react-shared';
4
+ export function ResultLoader(props) {
5
+ const { notFound, apiError, searchResult, children } = props;
6
+ if (notFound) {
7
+ return _jsx(NotFound, {});
8
+ }
9
+ // Defer error handling to the children
10
+ if (apiError) {
11
+ return _jsx(_Fragment, { children: children });
12
+ }
13
+ if (searchResult === undefined) {
14
+ return _jsx(FlexGrowRow, { busy: true, minHeight: "50px" });
15
+ }
16
+ else {
17
+ return _jsx(_Fragment, { children: children });
18
+ }
19
+ }
20
+ //# sourceMappingURL=ResultLoader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ResultLoader.js","sourceRoot":"","sources":["../../../src/components/ResultLoader.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAA;AAEnD,OAAO,EAAE,QAAQ,EAAE,MAAM,2BAA2B,CAAA;AASpD,MAAM,UAAU,YAAY,CAAI,KAAyD;IACvF,MAAM,EAAE,QAAQ,EAAE,QAAQ,EAAE,YAAY,EAAE,QAAQ,EAAE,GAAG,KAAK,CAAA;IAC5D,IAAI,QAAQ,EAAE;QACZ,OAAO,KAAC,QAAQ,KAAG,CAAA;KACpB;IACD,uCAAuC;IACvC,IAAI,QAAQ,EAAE;QACZ,OAAO,4BAAG,QAAQ,GAAI,CAAA;KACvB;IACD,IAAI,YAAY,KAAK,SAAS,EAAE;QAC9B,OAAO,KAAC,WAAW,IAAC,IAAI,QAAC,SAAS,EAAC,MAAM,GAAG,CAAA;KAC7C;SAAM;QACL,OAAO,4BAAG,QAAQ,GAAI,CAAA;KACvB;AACH,CAAC"}
@@ -0,0 +1,4 @@
1
+ export * from './ApiErrorAlert';
2
+ export * from './JsonRouteWrapper';
3
+ export * from './ResultLoader';
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAA;AAC/B,cAAc,oBAAoB,CAAA;AAClC,cAAc,gBAAgB,CAAA"}
@@ -0,0 +1,4 @@
1
+ export * from './ApiErrorAlert';
2
+ export * from './JsonRouteWrapper';
3
+ export * from './ResultLoader';
4
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/index.ts"],"names":[],"mappings":"AAAA,cAAc,iBAAiB,CAAA;AAC/B,cAAc,oBAAoB,CAAA;AAClC,cAAc,gBAAgB,CAAA"}
@@ -0,0 +1,5 @@
1
+ import { XyoApiError } from '@xyo-network/api';
2
+ import { XyoPayload } from '@xyo-network/payload';
3
+ export declare type UsePayload = [XyoPayload?, boolean?, XyoApiError?];
4
+ export declare type UseHuriOrHash = [...UsePayload, boolean?];
5
+ //# sourceMappingURL=ResolvePayloadArgs.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ResolvePayloadArgs.d.ts","sourceRoot":"","sources":["../../../src/hooks/ResolvePayloadArgs.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAC9C,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAA;AAEjD,oBAAY,UAAU,GAAG,CAAC,UAAU,CAAC,EAAE,OAAO,CAAC,EAAE,WAAW,CAAC,CAAC,CAAA;AAE9D,oBAAY,aAAa,GAAG,CAAC,GAAG,UAAU,EAAE,OAAO,CAAC,CAAC,CAAA"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=ResolvePayloadArgs.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ResolvePayloadArgs.js","sourceRoot":"","sources":["../../../src/hooks/ResolvePayloadArgs.ts"],"names":[],"mappings":""}
@@ -0,0 +1,6 @@
1
+ export * from './lib';
2
+ export * from './ResolvePayloadArgs';
3
+ export * from './useHuriHash';
4
+ export * from './useLoadPayload';
5
+ export * from './useResolveHuri';
6
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/hooks/index.ts"],"names":[],"mappings":"AAAA,cAAc,OAAO,CAAA;AACrB,cAAc,sBAAsB,CAAA;AACpC,cAAc,eAAe,CAAA;AAC7B,cAAc,kBAAkB,CAAA;AAChC,cAAc,kBAAkB,CAAA"}
@@ -0,0 +1,6 @@
1
+ export * from './lib';
2
+ export * from './ResolvePayloadArgs';
3
+ export * from './useHuriHash';
4
+ export * from './useLoadPayload';
5
+ export * from './useResolveHuri';
6
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/hooks/index.ts"],"names":[],"mappings":"AAAA,cAAc,OAAO,CAAA;AACrB,cAAc,sBAAsB,CAAA;AACpC,cAAc,eAAe,CAAA;AAC7B,cAAc,kBAAkB,CAAA;AAChC,cAAc,kBAAkB,CAAA"}
@@ -0,0 +1,4 @@
1
+ export interface FetchHuriHashOptions {
2
+ changeActiveNetwork?: boolean;
3
+ }
4
+ //# sourceMappingURL=FetchHuriHashOptions.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FetchHuriHashOptions.d.ts","sourceRoot":"","sources":["../../../../src/hooks/lib/FetchHuriHashOptions.ts"],"names":[],"mappings":"AAAA,MAAM,WAAW,oBAAoB;IACnC,mBAAmB,CAAC,EAAE,OAAO,CAAA;CAC9B"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=FetchHuriHashOptions.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"FetchHuriHashOptions.js","sourceRoot":"","sources":["../../../../src/hooks/lib/FetchHuriHashOptions.ts"],"names":[],"mappings":""}
@@ -0,0 +1,4 @@
1
+ import { XyoNetworkPayload } from '@xyo-network/network';
2
+ import { Huri } from '@xyo-network/payload';
3
+ export declare const findHuriNetwork: (huriInstance: Huri, networks?: XyoNetworkPayload[]) => XyoNetworkPayload | undefined;
4
+ //# sourceMappingURL=findHuriNetwork.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"findHuriNetwork.d.ts","sourceRoot":"","sources":["../../../../src/hooks/lib/findHuriNetwork.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,sBAAsB,CAAA;AACxD,OAAO,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAA;AAE3C,eAAO,MAAM,eAAe,iBAAkB,IAAI,aAAa,iBAAiB,EAAE,kCASjF,CAAA"}
@@ -0,0 +1,9 @@
1
+ export const findHuriNetwork = (huriInstance, networks) => {
2
+ // see if huri archivist matches any archivist in the network configs
3
+ return networks
4
+ ?.filter((network) => network.nodes?.find((node) => {
5
+ return node.type === 'archivist' && new URL(node.uri).hostname === huriInstance.archivist;
6
+ }))
7
+ .shift();
8
+ };
9
+ //# sourceMappingURL=findHuriNetwork.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"findHuriNetwork.js","sourceRoot":"","sources":["../../../../src/hooks/lib/findHuriNetwork.ts"],"names":[],"mappings":"AAGA,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,YAAkB,EAAE,QAA8B,EAAE,EAAE;IACpF,qEAAqE;IACrE,OAAO,QAAQ;QACb,EAAE,MAAM,CAAC,CAAC,OAAO,EAAE,EAAE,CACnB,OAAO,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE;QAC3B,OAAO,IAAI,CAAC,IAAI,KAAK,WAAW,IAAI,IAAI,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,QAAQ,KAAK,YAAY,CAAC,SAAS,CAAA;IAC3F,CAAC,CAAC,CACH;SACA,KAAK,EAAE,CAAA;AACZ,CAAC,CAAA"}
@@ -0,0 +1,3 @@
1
+ export * from './FetchHuriHashOptions';
2
+ export * from './findHuriNetwork';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/hooks/lib/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAA;AACtC,cAAc,mBAAmB,CAAA"}
@@ -0,0 +1,3 @@
1
+ export * from './FetchHuriHashOptions';
2
+ export * from './findHuriNetwork';
3
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/hooks/lib/index.ts"],"names":[],"mappings":"AAAA,cAAc,wBAAwB,CAAA;AACtC,cAAc,mBAAmB,CAAA"}
@@ -0,0 +1,13 @@
1
+ import { Huri } from '@xyo-network/payload';
2
+ import { FetchHuriHashOptions } from './lib';
3
+ /**
4
+ * Resolve a hash or a huri regardless of network
5
+ */
6
+ declare const useHuriHash: (huriOrHash?: string | Huri, huriUri?: string, options?: FetchHuriHashOptions) => [({
7
+ schema: string;
8
+ previousHash?: string | undefined;
9
+ sources?: string[] | undefined;
10
+ timestamp?: number | undefined;
11
+ } | undefined)?, (boolean | undefined)?, (import("@xyo-network/api").XyoApiError<any, any> | undefined)?, (boolean | undefined)?];
12
+ export { useHuriHash };
13
+ //# sourceMappingURL=useHuriHash.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useHuriHash.d.ts","sourceRoot":"","sources":["../../../src/hooks/useHuriHash.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAA;AAG3C,OAAO,EAAE,oBAAoB,EAAE,MAAM,OAAO,CAAA;AAK5C;;GAEG;AACH,QAAA,MAAM,WAAW,gBAAiB,MAAM,GAAG,IAAI,YAAY,MAAM,YAAY,oBAAoB;;;;;iIA0BhG,CAAA;AAED,OAAO,EAAE,WAAW,EAAE,CAAA"}
@@ -0,0 +1,30 @@
1
+ import { Huri } from '@xyo-network/payload';
2
+ import { useCallback } from 'react';
3
+ import { useLoadPayload } from './useLoadPayload';
4
+ import { useResolveHuri } from './useResolveHuri';
5
+ /**
6
+ * Resolve a hash or a huri regardless of network
7
+ */
8
+ const useHuriHash = (huriOrHash, huriUri, options) => {
9
+ const hash = useCallback((huriOrHash) => {
10
+ if (huriOrHash) {
11
+ if (typeof huriOrHash === 'string') {
12
+ return huriOrHash;
13
+ }
14
+ if (huriOrHash instanceof Huri) {
15
+ return huriOrHash.hash;
16
+ }
17
+ }
18
+ }, []);
19
+ const providedHash = hash(huriOrHash);
20
+ //AT: TODO -> Talk about this pattern
21
+ // Optimistically try to grab the has from the current network and archive
22
+ const [payload, notFound, apiError] = useLoadPayload(providedHash);
23
+ // if a huriUri was passed, we can safely override the notFound from the hash only query
24
+ const notFoundOverride = huriUri ? true : notFound;
25
+ // If payload isn't found, fallback to the huriUri
26
+ const [huriPayload, huriPayloadNotFound, huriApiError, networkNotFound] = useResolveHuri(huriUri, notFoundOverride, options);
27
+ return [payload ?? huriPayload, huriPayloadNotFound, apiError ?? huriApiError, networkNotFound];
28
+ };
29
+ export { useHuriHash };
30
+ //# sourceMappingURL=useHuriHash.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useHuriHash.js","sourceRoot":"","sources":["../../../src/hooks/useHuriHash.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,sBAAsB,CAAA;AAC3C,OAAO,EAAE,WAAW,EAAE,MAAM,OAAO,CAAA;AAInC,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA;AACjD,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA;AAEjD;;GAEG;AACH,MAAM,WAAW,GAAG,CAAC,UAA0B,EAAE,OAAgB,EAAE,OAA8B,EAAiB,EAAE;IAClH,MAAM,IAAI,GAAG,WAAW,CAAC,CAAC,UAA0B,EAAE,EAAE;QACtD,IAAI,UAAU,EAAE;YACd,IAAI,OAAO,UAAU,KAAK,QAAQ,EAAE;gBAClC,OAAO,UAAU,CAAA;aAClB;YACD,IAAI,UAAU,YAAY,IAAI,EAAE;gBAC9B,OAAO,UAAU,CAAC,IAAI,CAAA;aACvB;SACF;IACH,CAAC,EAAE,EAAE,CAAC,CAAA;IAEN,MAAM,YAAY,GAAG,IAAI,CAAC,UAAU,CAAC,CAAA;IAErC,qCAAqC;IAErC,0EAA0E;IAC1E,MAAM,CAAC,OAAO,EAAE,QAAQ,EAAE,QAAQ,CAAC,GAAG,cAAc,CAAC,YAAY,CAAC,CAAA;IAElE,wFAAwF;IACxF,MAAM,gBAAgB,GAAG,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,QAAQ,CAAA;IAElD,kDAAkD;IAClD,MAAM,CAAC,WAAW,EAAE,mBAAmB,EAAE,YAAY,EAAE,eAAe,CAAC,GAAG,cAAc,CAAC,OAAO,EAAE,gBAAgB,EAAE,OAAO,CAAC,CAAA;IAE5H,OAAO,CAAC,OAAO,IAAI,WAAW,EAAE,mBAAmB,EAAE,QAAQ,IAAI,YAAY,EAAE,eAAe,CAAC,CAAA;AACjG,CAAC,CAAA;AAED,OAAO,EAAE,WAAW,EAAE,CAAA"}
@@ -0,0 +1,3 @@
1
+ import { UsePayload } from './ResolvePayloadArgs';
2
+ export declare const useLoadPayload: (hash?: string) => UsePayload;
3
+ //# sourceMappingURL=useLoadPayload.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useLoadPayload.d.ts","sourceRoot":"","sources":["../../../src/hooks/useLoadPayload.tsx"],"names":[],"mappings":"AAOA,OAAO,EAAE,UAAU,EAAE,MAAM,sBAAsB,CAAA;AAEjD,eAAO,MAAM,cAAc,UAAW,MAAM,eAiD3C,CAAA"}
@@ -0,0 +1,52 @@
1
+ import { useAsyncEffect } from '@xylabs/react-shared';
2
+ import { useArchive } from '@xyo-network/react-archive';
3
+ import { useArchivistApi } from '@xyo-network/react-archivist-api';
4
+ import { useEffect, useState } from 'react';
5
+ export const useLoadPayload = (hash) => {
6
+ const { api } = useArchivistApi();
7
+ const { archive } = useArchive();
8
+ const [localHash, setLocalHash] = useState();
9
+ const [notFound, setNotFound] = useState();
10
+ const [apiError, setApiError] = useState();
11
+ const [payload, setPayload] = useState();
12
+ const reset = () => {
13
+ setPayload(undefined);
14
+ setApiError(undefined);
15
+ setNotFound(undefined);
16
+ };
17
+ // allow for hash changes to retrigger the api call
18
+ useEffect(() => {
19
+ if (hash !== localHash) {
20
+ setLocalHash(hash);
21
+ reset();
22
+ }
23
+ }, [hash, localHash]);
24
+ useAsyncEffect(
25
+ // eslint-disable-next-line react-hooks/exhaustive-deps
26
+ async (mounted) => {
27
+ if (api && localHash && localHash.length > 0 && notFound === undefined) {
28
+ reset();
29
+ try {
30
+ const result = await api?.archive(archive).payload.hash(localHash).get();
31
+ if (mounted()) {
32
+ if (result?.length) {
33
+ setPayload(result[0]);
34
+ setNotFound(false);
35
+ }
36
+ else if (result?.length === 0) {
37
+ setNotFound(true);
38
+ setPayload(undefined);
39
+ }
40
+ }
41
+ }
42
+ catch (e) {
43
+ reset();
44
+ setNotFound(false);
45
+ setApiError(e);
46
+ console.error(e);
47
+ }
48
+ }
49
+ }, [hash, api, archive, payload, notFound, localHash]);
50
+ return [payload, notFound, apiError];
51
+ };
52
+ //# sourceMappingURL=useLoadPayload.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useLoadPayload.js","sourceRoot":"","sources":["../../../src/hooks/useLoadPayload.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAA;AAGrD,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAA;AACvD,OAAO,EAAE,eAAe,EAAE,MAAM,kCAAkC,CAAA;AAClE,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAI3C,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,IAAa,EAAc,EAAE;IAC1D,MAAM,EAAE,GAAG,EAAE,GAAG,eAAe,EAAE,CAAA;IACjC,MAAM,EAAE,OAAO,EAAE,GAAG,UAAU,EAAE,CAAA;IAChC,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,EAAU,CAAA;IACpD,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,QAAQ,EAAW,CAAA;IACnD,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,QAAQ,EAAe,CAAA;IACvD,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,QAAQ,EAAc,CAAA;IAEpD,MAAM,KAAK,GAAG,GAAG,EAAE;QACjB,UAAU,CAAC,SAAS,CAAC,CAAA;QACrB,WAAW,CAAC,SAAS,CAAC,CAAA;QACtB,WAAW,CAAC,SAAS,CAAC,CAAA;IACxB,CAAC,CAAA;IAED,mDAAmD;IACnD,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,IAAI,KAAK,SAAS,EAAE;YACtB,YAAY,CAAC,IAAI,CAAC,CAAA;YAClB,KAAK,EAAE,CAAA;SACR;IACH,CAAC,EAAE,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC,CAAA;IAErB,cAAc;IACZ,uDAAuD;IACvD,KAAK,EAAE,OAAO,EAAE,EAAE;QAChB,IAAI,GAAG,IAAI,SAAS,IAAI,SAAS,CAAC,MAAM,GAAG,CAAC,IAAI,QAAQ,KAAK,SAAS,EAAE;YACtE,KAAK,EAAE,CAAA;YACP,IAAI;gBACF,MAAM,MAAM,GAAG,MAAM,GAAG,EAAE,OAAO,CAAC,OAAO,CAAC,CAAC,OAAO,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,CAAA;gBACxE,IAAI,OAAO,EAAE,EAAE;oBACb,IAAI,MAAM,EAAE,MAAM,EAAE;wBAClB,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAA;wBACrB,WAAW,CAAC,KAAK,CAAC,CAAA;qBACnB;yBAAM,IAAI,MAAM,EAAE,MAAM,KAAK,CAAC,EAAE;wBAC/B,WAAW,CAAC,IAAI,CAAC,CAAA;wBACjB,UAAU,CAAC,SAAS,CAAC,CAAA;qBACtB;iBACF;aACF;YAAC,OAAO,CAAC,EAAE;gBACV,KAAK,EAAE,CAAA;gBACP,WAAW,CAAC,KAAK,CAAC,CAAA;gBAClB,WAAW,CAAC,CAAgB,CAAC,CAAA;gBAC7B,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAA;aACjB;SACF;IACH,CAAC,EACD,CAAC,IAAI,EAAE,GAAG,EAAE,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,SAAS,CAAC,CACnD,CAAA;IACD,OAAO,CAAC,OAAO,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAA;AACtC,CAAC,CAAA"}
@@ -0,0 +1,10 @@
1
+ import { XyoApiError } from '@xyo-network/api';
2
+ import { FetchHuriHashOptions } from './lib';
3
+ declare const useResolveHuri: (huriUri?: string, dependentNotFound?: boolean, options?: FetchHuriHashOptions) => [({
4
+ schema: string;
5
+ previousHash?: string | undefined;
6
+ sources?: string[] | undefined;
7
+ timestamp?: number | undefined;
8
+ } | undefined)?, (boolean | undefined)?, (XyoApiError<any, any> | undefined)?, (boolean | undefined)?];
9
+ export { useResolveHuri };
10
+ //# sourceMappingURL=useResolveHuri.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useResolveHuri.d.ts","sourceRoot":"","sources":["../../../src/hooks/useResolveHuri.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AAK9C,OAAO,EAAE,oBAAoB,EAAmB,MAAM,OAAO,CAAA;AAG7D,QAAA,MAAM,cAAc,aAAc,MAAM,sBAAsB,OAAO,YAAY,oBAAoB;;;;;sGA+DpG,CAAA;AAED,OAAO,EAAE,cAAc,EAAE,CAAA"}
@@ -0,0 +1,64 @@
1
+ import { useAsyncEffect } from '@xylabs/react-shared';
2
+ import { Huri } from '@xyo-network/payload';
3
+ import { useNetwork } from '@xyo-network/react-network';
4
+ import { useEffect, useState } from 'react';
5
+ import { findHuriNetwork } from './lib';
6
+ const useResolveHuri = (huriUri, dependentNotFound, options) => {
7
+ const { network, networks, setNetwork } = useNetwork();
8
+ const [huriPayload, setHuriPayload] = useState();
9
+ const [huriPayloadNotFound, setHuriPayloadNotFound] = useState();
10
+ const [huriNetworkNotFound, setHuriNetworkNotFound] = useState();
11
+ const [huriApiError, setHuriApiError] = useState();
12
+ const { changeActiveNetwork } = options ?? {};
13
+ //AT: TODO -> Talk about this pattern
14
+ const reset = () => {
15
+ setHuriPayload(undefined);
16
+ setHuriPayloadNotFound(undefined);
17
+ setHuriApiError(undefined);
18
+ };
19
+ useEffect(() => {
20
+ // Initially, sync local not found with dependent's status
21
+ setHuriPayloadNotFound(dependentNotFound);
22
+ }, [dependentNotFound]);
23
+ useAsyncEffect(
24
+ // eslint-disable-next-line react-hooks/exhaustive-deps
25
+ async (mounted) => {
26
+ // if dependent value is resolved, don't do anything, if not resolved, try to resolve huriUri
27
+ if (dependentNotFound && huriUri) {
28
+ reset();
29
+ const huriInstance = new Huri(huriUri);
30
+ const foundHuriNetwork = findHuriNetwork(huriInstance, networks);
31
+ if (foundHuriNetwork && mounted()) {
32
+ if (network !== foundHuriNetwork && changeActiveNetwork) {
33
+ setNetwork?.(foundHuriNetwork);
34
+ return;
35
+ }
36
+ try {
37
+ const huriPayload = await huriInstance.fetch();
38
+ if (mounted()) {
39
+ if (huriPayload) {
40
+ setHuriPayload(huriPayload);
41
+ setHuriPayloadNotFound(false);
42
+ }
43
+ else {
44
+ setHuriPayloadNotFound(true);
45
+ }
46
+ }
47
+ }
48
+ catch (e) {
49
+ if (mounted()) {
50
+ setHuriPayloadNotFound(false);
51
+ setHuriPayload(undefined);
52
+ setHuriApiError(e);
53
+ }
54
+ }
55
+ }
56
+ else {
57
+ setHuriNetworkNotFound(true);
58
+ }
59
+ }
60
+ }, [huriUri, network, networks, dependentNotFound, setNetwork, changeActiveNetwork]);
61
+ return [huriPayload, huriPayloadNotFound, huriApiError, huriNetworkNotFound];
62
+ };
63
+ export { useResolveHuri };
64
+ //# sourceMappingURL=useResolveHuri.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"useResolveHuri.js","sourceRoot":"","sources":["../../../src/hooks/useResolveHuri.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAA;AAErD,OAAO,EAAE,IAAI,EAAc,MAAM,sBAAsB,CAAA;AACvD,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAA;AACvD,OAAO,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAA;AAE3C,OAAO,EAAwB,eAAe,EAAE,MAAM,OAAO,CAAA;AAG7D,MAAM,cAAc,GAAG,CAAC,OAAgB,EAAE,iBAA2B,EAAE,OAA8B,EAAiB,EAAE;IACtH,MAAM,EAAE,OAAO,EAAE,QAAQ,EAAE,UAAU,EAAE,GAAG,UAAU,EAAE,CAAA;IACtD,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,EAAc,CAAA;IAC5D,MAAM,CAAC,mBAAmB,EAAE,sBAAsB,CAAC,GAAG,QAAQ,EAAW,CAAA;IACzE,MAAM,CAAC,mBAAmB,EAAE,sBAAsB,CAAC,GAAG,QAAQ,EAAW,CAAA;IACzE,MAAM,CAAC,YAAY,EAAE,eAAe,CAAC,GAAG,QAAQ,EAAe,CAAA;IAE/D,MAAM,EAAE,mBAAmB,EAAE,GAAG,OAAO,IAAI,EAAE,CAAA;IAE7C,qCAAqC;IACrC,MAAM,KAAK,GAAG,GAAG,EAAE;QACjB,cAAc,CAAC,SAAS,CAAC,CAAA;QACzB,sBAAsB,CAAC,SAAS,CAAC,CAAA;QACjC,eAAe,CAAC,SAAS,CAAC,CAAA;IAC5B,CAAC,CAAA;IAED,SAAS,CAAC,GAAG,EAAE;QACb,0DAA0D;QAC1D,sBAAsB,CAAC,iBAAiB,CAAC,CAAA;IAC3C,CAAC,EAAE,CAAC,iBAAiB,CAAC,CAAC,CAAA;IAEvB,cAAc;IACZ,uDAAuD;IACvD,KAAK,EAAE,OAAO,EAAE,EAAE;QAChB,6FAA6F;QAC7F,IAAI,iBAAiB,IAAI,OAAO,EAAE;YAChC,KAAK,EAAE,CAAA;YACP,MAAM,YAAY,GAAG,IAAI,IAAI,CAAC,OAAO,CAAC,CAAA;YAEtC,MAAM,gBAAgB,GAAG,eAAe,CAAC,YAAY,EAAE,QAAQ,CAAC,CAAA;YAEhE,IAAI,gBAAgB,IAAI,OAAO,EAAE,EAAE;gBACjC,IAAI,OAAO,KAAK,gBAAgB,IAAI,mBAAmB,EAAE;oBACvD,UAAU,EAAE,CAAC,gBAAgB,CAAC,CAAA;oBAC9B,OAAM;iBACP;gBAED,IAAI;oBACF,MAAM,WAAW,GAAG,MAAM,YAAY,CAAC,KAAK,EAAE,CAAA;oBAC9C,IAAI,OAAO,EAAE,EAAE;wBACb,IAAI,WAAW,EAAE;4BACf,cAAc,CAAC,WAAW,CAAC,CAAA;4BAC3B,sBAAsB,CAAC,KAAK,CAAC,CAAA;yBAC9B;6BAAM;4BACL,sBAAsB,CAAC,IAAI,CAAC,CAAA;yBAC7B;qBACF;iBACF;gBAAC,OAAO,CAAC,EAAE;oBACV,IAAI,OAAO,EAAE,EAAE;wBACb,sBAAsB,CAAC,KAAK,CAAC,CAAA;wBAC7B,cAAc,CAAC,SAAS,CAAC,CAAA;wBACzB,eAAe,CAAC,CAAgB,CAAC,CAAA;qBAClC;iBACF;aACF;iBAAM;gBACL,sBAAsB,CAAC,IAAI,CAAC,CAAA;aAC7B;SACF;IACH,CAAC,EACD,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,iBAAiB,EAAE,UAAU,EAAE,mBAAmB,CAAC,CACjF,CAAA;IAED,OAAO,CAAC,WAAW,EAAE,mBAAmB,EAAE,YAAY,EAAE,mBAAmB,CAAC,CAAA;AAC9E,CAAC,CAAA;AAED,OAAO,EAAE,cAAc,EAAE,CAAA"}
@@ -0,0 +1,2 @@
1
+ export * from './components';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAA"}
@@ -0,0 +1,2 @@
1
+ export * from './components';
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAA"}
package/package.json ADDED
@@ -0,0 +1,80 @@
1
+ {
2
+ "name": "@xyo-network/react-api",
3
+ "author": {
4
+ "email": "support@xyo.network",
5
+ "name": "XYO Development Team",
6
+ "url": "https://xyo.network"
7
+ },
8
+ "bugs": {
9
+ "email": "support@xyo.network",
10
+ "url": "https://github.com/XYOracleNetwork/sdk-xyo-react-js/issues"
11
+ },
12
+ "dependencies": {
13
+ "@xylabs/react-button": "^2.14.16",
14
+ "@xylabs/react-dialogs": "^2.14.16",
15
+ "@xylabs/react-flexbox": "^2.14.16",
16
+ "@xylabs/react-shared": "^2.14.16",
17
+ "@xyo-network/react-archive": "^2.32.0-rc.11",
18
+ "@xyo-network/react-archivist-api": "^2.32.0-rc.11",
19
+ "@xyo-network/react-network": "^2.32.0-rc.11",
20
+ "@xyo-network/react-shared": "^2.32.0-rc.11",
21
+ "react-json-view": "^1.21.3",
22
+ "tslib": "^2.4.0"
23
+ },
24
+ "peerDependencies": {
25
+ "@mui/icons-material": "^5.10.3",
26
+ "@mui/material": "^5.10.3",
27
+ "@mui/styles": "^5.10.3",
28
+ "@xyo-network/api": "^2.30.0-rc.3",
29
+ "@xyo-network/network": "^2.30.0-rc.3",
30
+ "@xyo-network/payload": "^2.30.0-rc.3",
31
+ "react": "^18.2.0",
32
+ "react-dom": "^18.2.0",
33
+ "react-router-dom": "^6.3.0"
34
+ },
35
+ "description": "Common React library for all XYO projects that use React",
36
+ "browser": "dist/esm/index.js",
37
+ "docs": "dist/docs.json",
38
+ "exports": {
39
+ ".": {
40
+ "node": {
41
+ "import": "./dist/esm/index.js",
42
+ "require": "./dist/cjs/index.js"
43
+ },
44
+ "browser": {
45
+ "import": "./dist/esm/index.js",
46
+ "require": "./dist/cjs/index.js"
47
+ },
48
+ "default": "./dist/esm/index.js"
49
+ },
50
+ "./dist/docs.json": {
51
+ "default": "./dist/docs.json"
52
+ },
53
+ "./package.json": "./package.json"
54
+ },
55
+ "main": "dist/cjs/index.js",
56
+ "module": "dist/esm/index.js",
57
+ "homepage": "https://xyo.network",
58
+ "keywords": [
59
+ "xyo",
60
+ "utility",
61
+ "typescript",
62
+ "react"
63
+ ],
64
+ "license": "LGPL-3.0",
65
+ "publishConfig": {
66
+ "access": "public"
67
+ },
68
+ "repository": {
69
+ "type": "git",
70
+ "url": "https://github.com/XYOracleNetwork/sdk-xyo-react-js.git"
71
+ },
72
+ "scripts": {
73
+ "lint-pkg": "npmPkgJsonLint .",
74
+ "license": "yarn license-checker --exclude \"MIT, ISC, Apache-2.0, BSD, BSD-2-Clause, CC-BY-4.0, Unlicense, CC-BY-3.0, CC0-1.0\""
75
+ },
76
+ "sideEffects": false,
77
+ "types": "dist/esm/index.d.ts",
78
+ "version": "2.32.0-rc.11",
79
+ "stableVersion": "2.31.3"
80
+ }