@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.
- package/LICENSE +165 -0
- package/README.md +70 -0
- package/dist/cjs/components/ApiErrorAlert.d.ts +9 -0
- package/dist/cjs/components/ApiErrorAlert.d.ts.map +1 -0
- package/dist/cjs/components/ApiErrorAlert.js +13 -0
- package/dist/cjs/components/ApiErrorAlert.js.map +1 -0
- package/dist/cjs/components/JsonRouteWrapper/JsonApiButton.d.ts +4 -0
- package/dist/cjs/components/JsonRouteWrapper/JsonApiButton.d.ts.map +1 -0
- package/dist/cjs/components/JsonRouteWrapper/JsonApiButton.js +15 -0
- package/dist/cjs/components/JsonRouteWrapper/JsonApiButton.js.map +1 -0
- package/dist/cjs/components/JsonRouteWrapper/JsonRouteWrapper.d.ts +11 -0
- package/dist/cjs/components/JsonRouteWrapper/JsonRouteWrapper.d.ts.map +1 -0
- package/dist/cjs/components/JsonRouteWrapper/JsonRouteWrapper.js +47 -0
- package/dist/cjs/components/JsonRouteWrapper/JsonRouteWrapper.js.map +1 -0
- package/dist/cjs/components/JsonRouteWrapper/index.d.ts +3 -0
- package/dist/cjs/components/JsonRouteWrapper/index.d.ts.map +1 -0
- package/dist/cjs/components/JsonRouteWrapper/index.js +6 -0
- package/dist/cjs/components/JsonRouteWrapper/index.js.map +1 -0
- package/dist/cjs/components/ResultLoader.d.ts +9 -0
- package/dist/cjs/components/ResultLoader.d.ts.map +1 -0
- package/dist/cjs/components/ResultLoader.js +24 -0
- package/dist/cjs/components/ResultLoader.js.map +1 -0
- package/dist/cjs/components/index.d.ts +4 -0
- package/dist/cjs/components/index.d.ts.map +1 -0
- package/dist/cjs/components/index.js +7 -0
- package/dist/cjs/components/index.js.map +1 -0
- package/dist/cjs/hooks/ResolvePayloadArgs.d.ts +5 -0
- package/dist/cjs/hooks/ResolvePayloadArgs.d.ts.map +1 -0
- package/dist/cjs/hooks/ResolvePayloadArgs.js +3 -0
- package/dist/cjs/hooks/ResolvePayloadArgs.js.map +1 -0
- package/dist/cjs/hooks/index.d.ts +6 -0
- package/dist/cjs/hooks/index.d.ts.map +1 -0
- package/dist/cjs/hooks/index.js +9 -0
- package/dist/cjs/hooks/index.js.map +1 -0
- package/dist/cjs/hooks/lib/FetchHuriHashOptions.d.ts +4 -0
- package/dist/cjs/hooks/lib/FetchHuriHashOptions.d.ts.map +1 -0
- package/dist/cjs/hooks/lib/FetchHuriHashOptions.js +3 -0
- package/dist/cjs/hooks/lib/FetchHuriHashOptions.js.map +1 -0
- package/dist/cjs/hooks/lib/findHuriNetwork.d.ts +4 -0
- package/dist/cjs/hooks/lib/findHuriNetwork.d.ts.map +1 -0
- package/dist/cjs/hooks/lib/findHuriNetwork.js +14 -0
- package/dist/cjs/hooks/lib/findHuriNetwork.js.map +1 -0
- package/dist/cjs/hooks/lib/index.d.ts +3 -0
- package/dist/cjs/hooks/lib/index.d.ts.map +1 -0
- package/dist/cjs/hooks/lib/index.js +6 -0
- package/dist/cjs/hooks/lib/index.js.map +1 -0
- package/dist/cjs/hooks/useHuriHash.d.ts +13 -0
- package/dist/cjs/hooks/useHuriHash.d.ts.map +1 -0
- package/dist/cjs/hooks/useHuriHash.js +33 -0
- package/dist/cjs/hooks/useHuriHash.js.map +1 -0
- package/dist/cjs/hooks/useLoadPayload.d.ts +3 -0
- package/dist/cjs/hooks/useLoadPayload.d.ts.map +1 -0
- package/dist/cjs/hooks/useLoadPayload.js +57 -0
- package/dist/cjs/hooks/useLoadPayload.js.map +1 -0
- package/dist/cjs/hooks/useResolveHuri.d.ts +10 -0
- package/dist/cjs/hooks/useResolveHuri.d.ts.map +1 -0
- package/dist/cjs/hooks/useResolveHuri.js +68 -0
- package/dist/cjs/hooks/useResolveHuri.js.map +1 -0
- package/dist/cjs/index.d.ts +2 -0
- package/dist/cjs/index.d.ts.map +1 -0
- package/dist/cjs/index.js +5 -0
- package/dist/cjs/index.js.map +1 -0
- package/dist/docs.json +19042 -0
- package/dist/esm/components/ApiErrorAlert.d.ts +9 -0
- package/dist/esm/components/ApiErrorAlert.d.ts.map +1 -0
- package/dist/esm/components/ApiErrorAlert.js +7 -0
- package/dist/esm/components/ApiErrorAlert.js.map +1 -0
- package/dist/esm/components/JsonRouteWrapper/JsonApiButton.d.ts +4 -0
- package/dist/esm/components/JsonRouteWrapper/JsonApiButton.d.ts.map +1 -0
- package/dist/esm/components/JsonRouteWrapper/JsonApiButton.js +11 -0
- package/dist/esm/components/JsonRouteWrapper/JsonApiButton.js.map +1 -0
- package/dist/esm/components/JsonRouteWrapper/JsonRouteWrapper.d.ts +11 -0
- package/dist/esm/components/JsonRouteWrapper/JsonRouteWrapper.d.ts.map +1 -0
- package/dist/esm/components/JsonRouteWrapper/JsonRouteWrapper.js +41 -0
- package/dist/esm/components/JsonRouteWrapper/JsonRouteWrapper.js.map +1 -0
- package/dist/esm/components/JsonRouteWrapper/index.d.ts +3 -0
- package/dist/esm/components/JsonRouteWrapper/index.d.ts.map +1 -0
- package/dist/esm/components/JsonRouteWrapper/index.js +3 -0
- package/dist/esm/components/JsonRouteWrapper/index.js.map +1 -0
- package/dist/esm/components/ResultLoader.d.ts +9 -0
- package/dist/esm/components/ResultLoader.d.ts.map +1 -0
- package/dist/esm/components/ResultLoader.js +20 -0
- package/dist/esm/components/ResultLoader.js.map +1 -0
- package/dist/esm/components/index.d.ts +4 -0
- package/dist/esm/components/index.d.ts.map +1 -0
- package/dist/esm/components/index.js +4 -0
- package/dist/esm/components/index.js.map +1 -0
- package/dist/esm/hooks/ResolvePayloadArgs.d.ts +5 -0
- package/dist/esm/hooks/ResolvePayloadArgs.d.ts.map +1 -0
- package/dist/esm/hooks/ResolvePayloadArgs.js +2 -0
- package/dist/esm/hooks/ResolvePayloadArgs.js.map +1 -0
- package/dist/esm/hooks/index.d.ts +6 -0
- package/dist/esm/hooks/index.d.ts.map +1 -0
- package/dist/esm/hooks/index.js +6 -0
- package/dist/esm/hooks/index.js.map +1 -0
- package/dist/esm/hooks/lib/FetchHuriHashOptions.d.ts +4 -0
- package/dist/esm/hooks/lib/FetchHuriHashOptions.d.ts.map +1 -0
- package/dist/esm/hooks/lib/FetchHuriHashOptions.js +2 -0
- package/dist/esm/hooks/lib/FetchHuriHashOptions.js.map +1 -0
- package/dist/esm/hooks/lib/findHuriNetwork.d.ts +4 -0
- package/dist/esm/hooks/lib/findHuriNetwork.d.ts.map +1 -0
- package/dist/esm/hooks/lib/findHuriNetwork.js +9 -0
- package/dist/esm/hooks/lib/findHuriNetwork.js.map +1 -0
- package/dist/esm/hooks/lib/index.d.ts +3 -0
- package/dist/esm/hooks/lib/index.d.ts.map +1 -0
- package/dist/esm/hooks/lib/index.js +3 -0
- package/dist/esm/hooks/lib/index.js.map +1 -0
- package/dist/esm/hooks/useHuriHash.d.ts +13 -0
- package/dist/esm/hooks/useHuriHash.d.ts.map +1 -0
- package/dist/esm/hooks/useHuriHash.js +30 -0
- package/dist/esm/hooks/useHuriHash.js.map +1 -0
- package/dist/esm/hooks/useLoadPayload.d.ts +3 -0
- package/dist/esm/hooks/useLoadPayload.d.ts.map +1 -0
- package/dist/esm/hooks/useLoadPayload.js +52 -0
- package/dist/esm/hooks/useLoadPayload.js.map +1 -0
- package/dist/esm/hooks/useResolveHuri.d.ts +10 -0
- package/dist/esm/hooks/useResolveHuri.d.ts.map +1 -0
- package/dist/esm/hooks/useResolveHuri.js +64 -0
- package/dist/esm/hooks/useResolveHuri.js.map +1 -0
- package/dist/esm/index.d.ts +2 -0
- package/dist/esm/index.d.ts.map +1 -0
- package/dist/esm/index.js +2 -0
- package/dist/esm/index.js.map +1 -0
- package/package.json +80 -0
- package/src/components/ApiErrorAlert.tsx +21 -0
- package/src/components/JsonRouteWrapper/JsonApiButton.tsx +19 -0
- package/src/components/JsonRouteWrapper/JsonRouteWrapper.stories.tsx +68 -0
- package/src/components/JsonRouteWrapper/JsonRouteWrapper.tsx +85 -0
- package/src/components/JsonRouteWrapper/index.ts +2 -0
- package/src/components/ResultLoader.stories.tsx +37 -0
- package/src/components/ResultLoader.tsx +26 -0
- package/src/components/index.ts +3 -0
- package/src/hooks/ResolvePayloadArgs.ts +6 -0
- package/src/hooks/index.ts +5 -0
- package/src/hooks/lib/FetchHuriHashOptions.ts +3 -0
- package/src/hooks/lib/findHuriNetwork.ts +13 -0
- package/src/hooks/lib/index.ts +2 -0
- package/src/hooks/useHuriHash.stories.tsx +108 -0
- package/src/hooks/useHuriHash.tsx +40 -0
- package/src/hooks/useLoadPayload.stories.tsx +69 -0
- package/src/hooks/useLoadPayload.tsx +59 -0
- package/src/hooks/useResolveHuri.tsx +75 -0
- 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 @@
|
|
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 @@
|
|
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 @@
|
|
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 @@
|
|
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 @@
|
|
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 @@
|
|
1
|
+
{"version":3,"file":"ResolvePayloadArgs.js","sourceRoot":"","sources":["../../../src/hooks/ResolvePayloadArgs.ts"],"names":[],"mappings":""}
|
@@ -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 @@
|
|
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 @@
|
|
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 @@
|
|
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 @@
|
|
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 @@
|
|
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 @@
|
|
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 @@
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAA"}
|
@@ -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
|
+
}
|