@xyo-network/react-powered-by-xyo 2.64.9 → 2.64.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/browser/index.cjs +2 -2
- package/dist/browser/index.js +2 -2
- package/dist/docs.json +54748 -41740
- package/dist/node/index.cjs +2 -2
- package/dist/node/index.js +2 -2
- package/package.json +20 -20
- package/dist/browser/components/ArchivistSummary.cjs +0 -61
- package/dist/browser/components/ArchivistSummary.cjs.map +0 -1
- package/dist/browser/components/ArchivistSummary.js +0 -40
- package/dist/browser/components/ArchivistSummary.js.map +0 -1
- package/dist/browser/components/BridgeSummary.cjs +0 -61
- package/dist/browser/components/BridgeSummary.cjs.map +0 -1
- package/dist/browser/components/BridgeSummary.js +0 -40
- package/dist/browser/components/BridgeSummary.js.map +0 -1
- package/dist/browser/components/DebugDialog.cjs +0 -244
- package/dist/browser/components/DebugDialog.cjs.map +0 -1
- package/dist/browser/components/DebugDialog.js +0 -213
- package/dist/browser/components/DebugDialog.js.map +0 -1
- package/dist/browser/components/DivinerSummary.cjs +0 -61
- package/dist/browser/components/DivinerSummary.cjs.map +0 -1
- package/dist/browser/components/DivinerSummary.js +0 -40
- package/dist/browser/components/DivinerSummary.js.map +0 -1
- package/dist/browser/components/JsonViewerButton.cjs +0 -52
- package/dist/browser/components/JsonViewerButton.cjs.map +0 -1
- package/dist/browser/components/JsonViewerButton.js +0 -21
- package/dist/browser/components/JsonViewerButton.js.map +0 -1
- package/dist/browser/components/ModuleAccordion.cjs +0 -219
- package/dist/browser/components/ModuleAccordion.cjs.map +0 -1
- package/dist/browser/components/ModuleAccordion.js +0 -188
- package/dist/browser/components/ModuleAccordion.js.map +0 -1
- package/dist/browser/components/ModuleDetails.cjs +0 -92
- package/dist/browser/components/ModuleDetails.cjs.map +0 -1
- package/dist/browser/components/ModuleDetails.js +0 -61
- package/dist/browser/components/ModuleDetails.js.map +0 -1
- package/dist/browser/components/ModuleSummary.cjs +0 -52
- package/dist/browser/components/ModuleSummary.cjs.map +0 -1
- package/dist/browser/components/ModuleSummary.js +0 -31
- package/dist/browser/components/ModuleSummary.js.map +0 -1
- package/dist/browser/components/NodeDetails.cjs +0 -231
- package/dist/browser/components/NodeDetails.cjs.map +0 -1
- package/dist/browser/components/NodeDetails.js +0 -200
- package/dist/browser/components/NodeDetails.js.map +0 -1
- package/dist/browser/components/NodeSummary.cjs +0 -71
- package/dist/browser/components/NodeSummary.cjs.map +0 -1
- package/dist/browser/components/NodeSummary.js +0 -50
- package/dist/browser/components/NodeSummary.js.map +0 -1
- package/dist/browser/components/PoweredByXyo.cjs +0 -405
- package/dist/browser/components/PoweredByXyo.cjs.map +0 -1
- package/dist/browser/components/PoweredByXyo.js +0 -374
- package/dist/browser/components/PoweredByXyo.js.map +0 -1
- package/dist/browser/components/PoweredByXyoButton.cjs +0 -101
- package/dist/browser/components/PoweredByXyoButton.cjs.map +0 -1
- package/dist/browser/components/PoweredByXyoButton.js +0 -70
- package/dist/browser/components/PoweredByXyoButton.js.map +0 -1
- package/dist/browser/components/SentinelSummary.cjs +0 -61
- package/dist/browser/components/SentinelSummary.cjs.map +0 -1
- package/dist/browser/components/SentinelSummary.js +0 -40
- package/dist/browser/components/SentinelSummary.js.map +0 -1
- package/dist/browser/components/TypedModuleSummary.cjs +0 -138
- package/dist/browser/components/TypedModuleSummary.cjs.map +0 -1
- package/dist/browser/components/TypedModuleSummary.js +0 -117
- package/dist/browser/components/TypedModuleSummary.js.map +0 -1
- package/dist/browser/components/WitnessSummary.cjs +0 -61
- package/dist/browser/components/WitnessSummary.cjs.map +0 -1
- package/dist/browser/components/WitnessSummary.js +0 -40
- package/dist/browser/components/WitnessSummary.js.map +0 -1
- package/dist/browser/components/XyoBusy.cjs +0 -72
- package/dist/browser/components/XyoBusy.cjs.map +0 -1
- package/dist/browser/components/XyoBusy.js +0 -41
- package/dist/browser/components/XyoBusy.js.map +0 -1
- package/dist/browser/components/index.cjs +0 -420
- package/dist/browser/components/index.cjs.map +0 -1
- package/dist/browser/components/index.js +0 -387
- package/dist/browser/components/index.js.map +0 -1
- package/dist/browser/components/stories/simple-node-inline-manifest.cjs +0 -57
- package/dist/browser/components/stories/simple-node-inline-manifest.cjs.map +0 -1
- package/dist/browser/components/stories/simple-node-inline-manifest.js +0 -63
- package/dist/browser/components/stories/simple-node-inline-manifest.js.map +0 -1
- package/dist/browser/img/index.cjs +0 -39
- package/dist/browser/img/index.cjs.map +0 -1
- package/dist/browser/img/index.js +0 -8
- package/dist/browser/img/index.js.map +0 -1
- package/dist/browser/types/images.d.cjs +0 -2
- package/dist/browser/types/images.d.cjs.map +0 -1
- package/dist/browser/types/images.d.js +0 -1
- package/dist/browser/types/images.d.js.map +0 -1
- package/dist/node/components/ArchivistSummary.cjs +0 -66
- package/dist/node/components/ArchivistSummary.cjs.map +0 -1
- package/dist/node/components/ArchivistSummary.js +0 -41
- package/dist/node/components/ArchivistSummary.js.map +0 -1
- package/dist/node/components/BridgeSummary.cjs +0 -66
- package/dist/node/components/BridgeSummary.cjs.map +0 -1
- package/dist/node/components/BridgeSummary.js +0 -41
- package/dist/node/components/BridgeSummary.js.map +0 -1
- package/dist/node/components/DebugDialog.cjs +0 -250
- package/dist/node/components/DebugDialog.cjs.map +0 -1
- package/dist/node/components/DebugDialog.js +0 -215
- package/dist/node/components/DebugDialog.js.map +0 -1
- package/dist/node/components/DivinerSummary.cjs +0 -66
- package/dist/node/components/DivinerSummary.cjs.map +0 -1
- package/dist/node/components/DivinerSummary.js +0 -41
- package/dist/node/components/DivinerSummary.js.map +0 -1
- package/dist/node/components/JsonViewerButton.cjs +0 -56
- package/dist/node/components/JsonViewerButton.cjs.map +0 -1
- package/dist/node/components/JsonViewerButton.js +0 -21
- package/dist/node/components/JsonViewerButton.js.map +0 -1
- package/dist/node/components/ModuleAccordion.cjs +0 -225
- package/dist/node/components/ModuleAccordion.cjs.map +0 -1
- package/dist/node/components/ModuleAccordion.js +0 -190
- package/dist/node/components/ModuleAccordion.js.map +0 -1
- package/dist/node/components/ModuleDetails.cjs +0 -96
- package/dist/node/components/ModuleDetails.cjs.map +0 -1
- package/dist/node/components/ModuleDetails.js +0 -61
- package/dist/node/components/ModuleDetails.js.map +0 -1
- package/dist/node/components/ModuleSummary.cjs +0 -57
- package/dist/node/components/ModuleSummary.cjs.map +0 -1
- package/dist/node/components/ModuleSummary.js +0 -32
- package/dist/node/components/ModuleSummary.js.map +0 -1
- package/dist/node/components/NodeDetails.cjs +0 -237
- package/dist/node/components/NodeDetails.cjs.map +0 -1
- package/dist/node/components/NodeDetails.js +0 -202
- package/dist/node/components/NodeDetails.js.map +0 -1
- package/dist/node/components/NodeSummary.cjs +0 -77
- package/dist/node/components/NodeSummary.cjs.map +0 -1
- package/dist/node/components/NodeSummary.js +0 -52
- package/dist/node/components/NodeSummary.js.map +0 -1
- package/dist/node/components/PoweredByXyo.cjs +0 -411
- package/dist/node/components/PoweredByXyo.cjs.map +0 -1
- package/dist/node/components/PoweredByXyo.js +0 -376
- package/dist/node/components/PoweredByXyo.js.map +0 -1
- package/dist/node/components/PoweredByXyoButton.cjs +0 -105
- package/dist/node/components/PoweredByXyoButton.cjs.map +0 -1
- package/dist/node/components/PoweredByXyoButton.js +0 -70
- package/dist/node/components/PoweredByXyoButton.js.map +0 -1
- package/dist/node/components/SentinelSummary.cjs +0 -66
- package/dist/node/components/SentinelSummary.cjs.map +0 -1
- package/dist/node/components/SentinelSummary.js +0 -41
- package/dist/node/components/SentinelSummary.js.map +0 -1
- package/dist/node/components/TypedModuleSummary.cjs +0 -144
- package/dist/node/components/TypedModuleSummary.cjs.map +0 -1
- package/dist/node/components/TypedModuleSummary.js +0 -119
- package/dist/node/components/TypedModuleSummary.js.map +0 -1
- package/dist/node/components/WitnessSummary.cjs +0 -66
- package/dist/node/components/WitnessSummary.cjs.map +0 -1
- package/dist/node/components/WitnessSummary.js +0 -41
- package/dist/node/components/WitnessSummary.js.map +0 -1
- package/dist/node/components/XyoBusy.cjs +0 -76
- package/dist/node/components/XyoBusy.cjs.map +0 -1
- package/dist/node/components/XyoBusy.js +0 -41
- package/dist/node/components/XyoBusy.js.map +0 -1
- package/dist/node/components/index.cjs +0 -439
- package/dist/node/components/index.cjs.map +0 -1
- package/dist/node/components/index.js +0 -389
- package/dist/node/components/index.js.map +0 -1
- package/dist/node/components/stories/simple-node-inline-manifest.cjs +0 -63
- package/dist/node/components/stories/simple-node-inline-manifest.cjs.map +0 -1
- package/dist/node/components/stories/simple-node-inline-manifest.js +0 -63
- package/dist/node/components/stories/simple-node-inline-manifest.js.map +0 -1
- package/dist/node/img/index.cjs +0 -44
- package/dist/node/img/index.cjs.map +0 -1
- package/dist/node/img/index.js +0 -8
- package/dist/node/img/index.js.map +0 -1
- package/dist/node/types/images.d.cjs +0 -2
- package/dist/node/types/images.d.cjs.map +0 -1
- package/dist/node/types/images.d.js +0 -1
- package/dist/node/types/images.d.js.map +0 -1
- /package/dist/browser/{img/xyo-color-logo.svg → xyo-color-logo-LHR2SMEM.svg} +0 -0
- /package/dist/browser/{img/xyo-color-logo-text-only.svg → xyo-color-logo-text-only-QPAW5BSQ.svg} +0 -0
- /package/dist/node/{img/xyo-color-logo.svg → xyo-color-logo-LHR2SMEM.svg} +0 -0
- /package/dist/node/{img/xyo-color-logo-text-only.svg → xyo-color-logo-text-only-QPAW5BSQ.svg} +0 -0
|
@@ -1,405 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __create = Object.create;
|
|
3
|
-
var __defProp = Object.defineProperty;
|
|
4
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
-
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
-
var __export = (target, all) => {
|
|
9
|
-
for (var name in all)
|
|
10
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
11
|
-
};
|
|
12
|
-
var __copyProps = (to, from, except, desc) => {
|
|
13
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
14
|
-
for (let key of __getOwnPropNames(from))
|
|
15
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
16
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
17
|
-
}
|
|
18
|
-
return to;
|
|
19
|
-
};
|
|
20
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
-
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
-
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
-
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
-
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
26
|
-
mod
|
|
27
|
-
));
|
|
28
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
29
|
-
|
|
30
|
-
// src/components/PoweredByXyo.tsx
|
|
31
|
-
var PoweredByXyo_exports = {};
|
|
32
|
-
__export(PoweredByXyo_exports, {
|
|
33
|
-
PoweredByXyo: () => PoweredByXyo
|
|
34
|
-
});
|
|
35
|
-
module.exports = __toCommonJS(PoweredByXyo_exports);
|
|
36
|
-
var import_material6 = require("@mui/material");
|
|
37
|
-
var import_delay2 = require("@xylabs/delay");
|
|
38
|
-
var import_forget = require("@xylabs/forget");
|
|
39
|
-
var import_react_async_effect = require("@xylabs/react-async-effect");
|
|
40
|
-
var import_react_flexbox6 = require("@xylabs/react-flexbox");
|
|
41
|
-
var import_react_node4 = require("@xyo-network/react-node");
|
|
42
|
-
var import_react5 = require("react");
|
|
43
|
-
|
|
44
|
-
// src/components/DebugDialog.tsx
|
|
45
|
-
var import_material4 = require("@mui/material");
|
|
46
|
-
|
|
47
|
-
// src/components/NodeDetails.tsx
|
|
48
|
-
var import_react_flexbox3 = require("@xylabs/react-flexbox");
|
|
49
|
-
var import_react_node3 = require("@xyo-network/react-node");
|
|
50
|
-
|
|
51
|
-
// src/components/ModuleAccordion.tsx
|
|
52
|
-
var import_icons_material8 = require("@mui/icons-material");
|
|
53
|
-
var import_material3 = require("@mui/material");
|
|
54
|
-
|
|
55
|
-
// src/components/ModuleDetails.tsx
|
|
56
|
-
var import_material2 = require("@mui/material");
|
|
57
|
-
var import_react_button2 = require("@xylabs/react-button");
|
|
58
|
-
var import_react_flexbox = require("@xylabs/react-flexbox");
|
|
59
|
-
var import_react_promise = require("@xylabs/react-promise");
|
|
60
|
-
var import_react_property = require("@xyo-network/react-property");
|
|
61
|
-
|
|
62
|
-
// src/components/JsonViewerButton.tsx
|
|
63
|
-
var import_material = require("@mui/material");
|
|
64
|
-
var import_react_button = require("@xylabs/react-button");
|
|
65
|
-
var import_react = require("react");
|
|
66
|
-
var import_react_json_view = __toESM(require("react-json-view"), 1);
|
|
67
|
-
var import_jsx_runtime = require("react/jsx-runtime");
|
|
68
|
-
var JsonViewerButton = ({ children, jsonViewProps, src, title, ...props }) => {
|
|
69
|
-
const [open, setOpen] = (0, import_react.useState)(false);
|
|
70
|
-
return /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(import_jsx_runtime.Fragment, { children: [
|
|
71
|
-
/* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_react_button.ButtonEx, { onClick: () => setOpen(!open), ...props, children: children ?? "JSON" }),
|
|
72
|
-
/* @__PURE__ */ (0, import_jsx_runtime.jsxs)(import_material.Dialog, { open, onClose: () => setOpen(false), children: [
|
|
73
|
-
title ? /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_material.DialogTitle, { children: title }) : null,
|
|
74
|
-
/* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_material.DialogContent, { children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_react_json_view.default, { src, ...jsonViewProps }) }),
|
|
75
|
-
/* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_material.DialogActions, { children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_react_button.ButtonEx, { onClick: () => setOpen(false), children: "Close" }) })
|
|
76
|
-
] })
|
|
77
|
-
] });
|
|
78
|
-
};
|
|
79
|
-
|
|
80
|
-
// src/components/ModuleDetails.tsx
|
|
81
|
-
var import_jsx_runtime2 = require("react/jsx-runtime");
|
|
82
|
-
var ModuleDetails = ({ module: module2, ...props }) => {
|
|
83
|
-
const [manifest] = (0, import_react_promise.usePromise)(async () => {
|
|
84
|
-
return await module2?.manifest();
|
|
85
|
-
}, [module2]);
|
|
86
|
-
const [discover] = (0, import_react_promise.usePromise)(async () => {
|
|
87
|
-
return await module2?.discover();
|
|
88
|
-
}, [module2]);
|
|
89
|
-
const [describe] = (0, import_react_promise.usePromise)(async () => {
|
|
90
|
-
return await module2?.describe();
|
|
91
|
-
}, [module2]);
|
|
92
|
-
const queries = module2?.queries;
|
|
93
|
-
const config = module2?.config;
|
|
94
|
-
return /* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(import_react_flexbox.FlexCol, { alignItems: "stretch", ...props, children: [
|
|
95
|
-
/* @__PURE__ */ (0, import_jsx_runtime2.jsx)(import_react_property.Property, { title: "Address", value: module2?.address }),
|
|
96
|
-
/* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(import_react_flexbox.FlexRow, { gap: 1, justifyContent: "space-between", children: [
|
|
97
|
-
/* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(import_material2.ButtonGroup, { children: [
|
|
98
|
-
manifest ? /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(JsonViewerButton, { variant: "contained", src: manifest, children: "Manifest" }) : null,
|
|
99
|
-
config ? /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(JsonViewerButton, { variant: "contained", src: config, children: "Config" }) : null,
|
|
100
|
-
discover ? /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(JsonViewerButton, { variant: "contained", src: discover, children: "Discover" }) : null,
|
|
101
|
-
describe ? /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(JsonViewerButton, { variant: "contained", src: describe, children: "Describe" }) : null,
|
|
102
|
-
queries ? /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(JsonViewerButton, { variant: "contained", src: queries, children: "Queries" }) : null
|
|
103
|
-
] }),
|
|
104
|
-
/* @__PURE__ */ (0, import_jsx_runtime2.jsxs)(import_material2.ButtonGroup, { children: [
|
|
105
|
-
/* @__PURE__ */ (0, import_jsx_runtime2.jsx)(import_react_button2.ButtonEx, { target: "_blank", href: `https://explore.xyo.network/block?network=main&address=${module2?.address}`, variant: "outlined", children: "Main" }),
|
|
106
|
-
/* @__PURE__ */ (0, import_jsx_runtime2.jsx)(import_react_button2.ButtonEx, { target: "_blank", href: `https://beta.explore.xyo.network/block?network=kerplunk&address=${module2?.address}`, variant: "outlined", children: "Kerplunk" }),
|
|
107
|
-
/* @__PURE__ */ (0, import_jsx_runtime2.jsx)(import_react_button2.ButtonEx, { target: "_blank", href: `https://beta.explore.xyo.network/block?network=local&address=${module2?.address}`, variant: "outlined", children: "Local" })
|
|
108
|
-
] })
|
|
109
|
-
] })
|
|
110
|
-
] });
|
|
111
|
-
};
|
|
112
|
-
|
|
113
|
-
// src/components/TypedModuleSummary.tsx
|
|
114
|
-
var import_archivist_model = require("@xyo-network/archivist-model");
|
|
115
|
-
var import_bridge_model = require("@xyo-network/bridge-model");
|
|
116
|
-
var import_diviner_model = require("@xyo-network/diviner-model");
|
|
117
|
-
var import_node_model = require("@xyo-network/node-model");
|
|
118
|
-
var import_sentinel = require("@xyo-network/sentinel");
|
|
119
|
-
var import_witness_model = require("@xyo-network/witness-model");
|
|
120
|
-
|
|
121
|
-
// src/components/ArchivistSummary.tsx
|
|
122
|
-
var import_icons_material2 = require("@mui/icons-material");
|
|
123
|
-
|
|
124
|
-
// src/components/ModuleSummary.tsx
|
|
125
|
-
var import_icons_material = require("@mui/icons-material");
|
|
126
|
-
var import_delay = require("@xylabs/delay");
|
|
127
|
-
var import_react_flexbox2 = require("@xylabs/react-flexbox");
|
|
128
|
-
var import_react_node = require("@xyo-network/react-node");
|
|
129
|
-
var import_react_shared = require("@xyo-network/react-shared");
|
|
130
|
-
var import_react2 = require("react");
|
|
131
|
-
var import_jsx_runtime3 = require("react/jsx-runtime");
|
|
132
|
-
var ModuleSummary = ({ children, icon, module: module2, ...props }) => {
|
|
133
|
-
const [downModules] = (0, import_react_node.useModulesFromNode)(void 0, { direction: "down" });
|
|
134
|
-
const [upModules] = (0, import_react_node.useModulesFromNode)(void 0, { direction: "up" });
|
|
135
|
-
const [busy, setBusy] = (0, import_react2.useState)(false);
|
|
136
|
-
const downModulesFromResolve = downModules?.length;
|
|
137
|
-
const upModulesFromResolve = upModules?.length;
|
|
138
|
-
module2?.on("moduleBusy", async ({ busy: busy2 }) => {
|
|
139
|
-
setBusy(busy2);
|
|
140
|
-
await (0, import_delay.delay)(2e3);
|
|
141
|
-
setBusy(false);
|
|
142
|
-
});
|
|
143
|
-
return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(import_react_flexbox2.FlexCol, { alignItems: "stretch", width: "100%", ...props, children: /* @__PURE__ */ (0, import_jsx_runtime3.jsxs)(import_react_flexbox2.FlexRow, { justifyContent: "flex-start", children: [
|
|
144
|
-
/* @__PURE__ */ (0, import_jsx_runtime3.jsxs)(import_react_flexbox2.FlexRow, { children: [
|
|
145
|
-
/* @__PURE__ */ (0, import_jsx_runtime3.jsx)(import_react_shared.TypographyEx, { color: busy ? "gray" : void 0, children: icon ?? /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(import_icons_material.Extension, {}) }),
|
|
146
|
-
/* @__PURE__ */ (0, import_jsx_runtime3.jsx)(import_react_shared.TypographyEx, { marginX: 1, children: module2?.config?.name ?? "<Unknown>" })
|
|
147
|
-
] }),
|
|
148
|
-
children ?? (downModulesFromResolve !== void 0 && upModulesFromResolve !== void 0) ? `[${downModulesFromResolve}\u2193/${upModulesFromResolve}\u2191]` : null
|
|
149
|
-
] }) });
|
|
150
|
-
};
|
|
151
|
-
|
|
152
|
-
// src/components/ArchivistSummary.tsx
|
|
153
|
-
var import_jsx_runtime4 = require("react/jsx-runtime");
|
|
154
|
-
var ArchivistSummary = ({ module: module2, ...props }) => {
|
|
155
|
-
return /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(ModuleSummary, { module: module2, icon: /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(import_icons_material2.Inventory2Rounded, {}), ...props });
|
|
156
|
-
};
|
|
157
|
-
|
|
158
|
-
// src/components/BridgeSummary.tsx
|
|
159
|
-
var import_icons_material3 = require("@mui/icons-material");
|
|
160
|
-
var import_jsx_runtime5 = require("react/jsx-runtime");
|
|
161
|
-
var BridgeSummary = ({ module: module2, ...props }) => {
|
|
162
|
-
return /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(ModuleSummary, { module: module2, icon: /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_icons_material3.InsertLinkRounded, {}), ...props });
|
|
163
|
-
};
|
|
164
|
-
|
|
165
|
-
// src/components/DivinerSummary.tsx
|
|
166
|
-
var import_icons_material4 = require("@mui/icons-material");
|
|
167
|
-
var import_jsx_runtime6 = require("react/jsx-runtime");
|
|
168
|
-
var DivinerSummary = ({ module: module2, ...props }) => {
|
|
169
|
-
return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(ModuleSummary, { module: module2, icon: /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(import_icons_material4.BubbleChartRounded, {}), ...props });
|
|
170
|
-
};
|
|
171
|
-
|
|
172
|
-
// src/components/NodeSummary.tsx
|
|
173
|
-
var import_icons_material5 = require("@mui/icons-material");
|
|
174
|
-
var import_react_promise2 = require("@xylabs/react-promise");
|
|
175
|
-
var import_react_node2 = require("@xyo-network/react-node");
|
|
176
|
-
var import_jsx_runtime7 = require("react/jsx-runtime");
|
|
177
|
-
var NodeSummary = ({ module: module2, ...props }) => {
|
|
178
|
-
const [manifest] = (0, import_react_promise2.usePromise)(async () => {
|
|
179
|
-
return await module2?.manifest();
|
|
180
|
-
}, [module2]);
|
|
181
|
-
const [downModules] = (0, import_react_node2.useModulesFromNode)(void 0, { direction: "down" });
|
|
182
|
-
const [upModules] = (0, import_react_node2.useModulesFromNode)(void 0, { direction: "up" });
|
|
183
|
-
const downModulesFromResolve = downModules?.length;
|
|
184
|
-
const upModulesFromResolve = upModules?.length;
|
|
185
|
-
const manifestPublicModules = manifest?.modules?.public?.length;
|
|
186
|
-
return /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(ModuleSummary, { module: module2, icon: /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(import_icons_material5.HubRounded, {}), ...props, children: manifestPublicModules !== void 0 && downModulesFromResolve !== void 0 && upModulesFromResolve !== void 0 ? `[${manifestPublicModules}m/${downModulesFromResolve}\u2193/${upModulesFromResolve}\u2191]` : null });
|
|
187
|
-
};
|
|
188
|
-
|
|
189
|
-
// src/components/SentinelSummary.tsx
|
|
190
|
-
var import_icons_material6 = require("@mui/icons-material");
|
|
191
|
-
var import_jsx_runtime8 = require("react/jsx-runtime");
|
|
192
|
-
var SentinelSummary = ({ module: module2, ...props }) => {
|
|
193
|
-
return /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(ModuleSummary, { module: module2, icon: /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(import_icons_material6.TimerRounded, {}), ...props });
|
|
194
|
-
};
|
|
195
|
-
|
|
196
|
-
// src/components/WitnessSummary.tsx
|
|
197
|
-
var import_icons_material7 = require("@mui/icons-material");
|
|
198
|
-
var import_jsx_runtime9 = require("react/jsx-runtime");
|
|
199
|
-
var WitnessSummary = ({ module: module2, ...props }) => {
|
|
200
|
-
return /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(ModuleSummary, { module: module2, icon: /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(import_icons_material7.VisibilityRounded, {}), ...props });
|
|
201
|
-
};
|
|
202
|
-
|
|
203
|
-
// src/components/TypedModuleSummary.tsx
|
|
204
|
-
var import_jsx_runtime10 = require("react/jsx-runtime");
|
|
205
|
-
var TypedModuleSummary = ({ module: module2, ...props }) => {
|
|
206
|
-
if ((0, import_archivist_model.isArchivistInstance)(module2)) {
|
|
207
|
-
return /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(ArchivistSummary, { module: module2, ...props });
|
|
208
|
-
}
|
|
209
|
-
if ((0, import_diviner_model.isDivinerInstance)(module2)) {
|
|
210
|
-
return /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(DivinerSummary, { module: module2, ...props });
|
|
211
|
-
}
|
|
212
|
-
if ((0, import_node_model.isNodeInstance)(module2)) {
|
|
213
|
-
return /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(NodeSummary, { module: module2, ...props });
|
|
214
|
-
}
|
|
215
|
-
if ((0, import_witness_model.isWitnessInstance)(module2)) {
|
|
216
|
-
return /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(WitnessSummary, { module: module2, ...props });
|
|
217
|
-
}
|
|
218
|
-
if ((0, import_bridge_model.isBridgeInstance)(module2)) {
|
|
219
|
-
return /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(BridgeSummary, { module: module2, ...props });
|
|
220
|
-
}
|
|
221
|
-
if ((0, import_sentinel.isSentinelInstance)(module2)) {
|
|
222
|
-
return /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(SentinelSummary, { module: module2, ...props });
|
|
223
|
-
}
|
|
224
|
-
return /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(ModuleSummary, { module: module2, ...props });
|
|
225
|
-
};
|
|
226
|
-
|
|
227
|
-
// src/components/ModuleAccordion.tsx
|
|
228
|
-
var import_jsx_runtime11 = require("react/jsx-runtime");
|
|
229
|
-
var ModuleAccordion = ({ module: module2, ...props }) => {
|
|
230
|
-
return /* @__PURE__ */ (0, import_jsx_runtime11.jsxs)(import_material3.Accordion, { ...props, children: [
|
|
231
|
-
/* @__PURE__ */ (0, import_jsx_runtime11.jsx)(import_material3.AccordionSummary, { expandIcon: /* @__PURE__ */ (0, import_jsx_runtime11.jsx)(import_icons_material8.ExpandMore, {}), children: /* @__PURE__ */ (0, import_jsx_runtime11.jsx)(TypedModuleSummary, { module: module2 }) }),
|
|
232
|
-
/* @__PURE__ */ (0, import_jsx_runtime11.jsx)(import_material3.AccordionDetails, { children: /* @__PURE__ */ (0, import_jsx_runtime11.jsx)(ModuleDetails, { module: module2 }) })
|
|
233
|
-
] });
|
|
234
|
-
};
|
|
235
|
-
|
|
236
|
-
// src/components/NodeDetails.tsx
|
|
237
|
-
var import_jsx_runtime12 = require("react/jsx-runtime");
|
|
238
|
-
var NodeDetails = ({ module: module2, ...props }) => {
|
|
239
|
-
const [node = module2] = (0, import_react_node3.useProvidedNode)();
|
|
240
|
-
const [children] = (0, import_react_node3.useModulesFromNode)(void 0, { node: node ?? void 0 });
|
|
241
|
-
return /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(import_react_flexbox3.FlexCol, { alignItems: "stretch", ...props, children: children ? /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(import_jsx_runtime12.Fragment, { children: /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(import_react_flexbox3.FlexCol, { alignItems: "stretch", marginY: 1, children: children?.map((child) => /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(ModuleAccordion, { module: child }, child.address)) }) }) : null });
|
|
242
|
-
};
|
|
243
|
-
|
|
244
|
-
// src/components/DebugDialog.tsx
|
|
245
|
-
var import_jsx_runtime13 = require("react/jsx-runtime");
|
|
246
|
-
var DebugDialog = ({ onClose, ...props }) => {
|
|
247
|
-
return /* @__PURE__ */ (0, import_jsx_runtime13.jsxs)(import_material4.Dialog, { ...props, children: [
|
|
248
|
-
/* @__PURE__ */ (0, import_jsx_runtime13.jsx)(import_material4.DialogTitle, { children: "Xyo Module Viewer" }),
|
|
249
|
-
/* @__PURE__ */ (0, import_jsx_runtime13.jsx)(import_material4.DialogContent, { children: /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(NodeDetails, { width: "100%" }) }),
|
|
250
|
-
/* @__PURE__ */ (0, import_jsx_runtime13.jsx)(import_material4.DialogActions, { children: /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(import_material4.Button, { onClick: (event) => onClose?.(event, "backdropClick"), children: "Close" }) })
|
|
251
|
-
] });
|
|
252
|
-
};
|
|
253
|
-
|
|
254
|
-
// src/components/PoweredByXyoButton.tsx
|
|
255
|
-
var import_material5 = require("@mui/material");
|
|
256
|
-
var import_react_button3 = require("@xylabs/react-button");
|
|
257
|
-
var import_react_flexbox5 = require("@xylabs/react-flexbox");
|
|
258
|
-
var import_react4 = require("react");
|
|
259
|
-
|
|
260
|
-
// src/img/index.ts
|
|
261
|
-
var import_xyo_color_logo = __toESM(require("../img/xyo-color-logo.svg"), 1);
|
|
262
|
-
var import_xyo_color_logo_text_only = __toESM(require("../img/xyo-color-logo-text-only.svg"), 1);
|
|
263
|
-
|
|
264
|
-
// src/components/XyoBusy.tsx
|
|
265
|
-
var import_react_flexbox4 = require("@xylabs/react-flexbox");
|
|
266
|
-
var import_react3 = require("react");
|
|
267
|
-
var import_jsx_runtime14 = require("react/jsx-runtime");
|
|
268
|
-
var XyoBusy = ({ widthInPixels, busy, spinsPerSecond = 0.5, ...props }) => {
|
|
269
|
-
const [imageLoaded, setImageLoaded] = (0, import_react3.useState)(false);
|
|
270
|
-
if (!imageLoaded) {
|
|
271
|
-
const img = new Image();
|
|
272
|
-
img.onload = () => setImageLoaded(true);
|
|
273
|
-
img.src = import_xyo_color_logo.default;
|
|
274
|
-
}
|
|
275
|
-
return imageLoaded ? /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(
|
|
276
|
-
import_react_flexbox4.FlexCol,
|
|
277
|
-
{
|
|
278
|
-
sx: {
|
|
279
|
-
"@keyframes spin": {
|
|
280
|
-
"0%": {
|
|
281
|
-
transform: "rotate(360deg)"
|
|
282
|
-
},
|
|
283
|
-
"100%": {
|
|
284
|
-
transform: "rotate(0deg)"
|
|
285
|
-
}
|
|
286
|
-
},
|
|
287
|
-
animation: busy ? `spin ${1 / spinsPerSecond}s linear infinite` : void 0,
|
|
288
|
-
animationDirection: "reverse"
|
|
289
|
-
},
|
|
290
|
-
...props,
|
|
291
|
-
children: /* @__PURE__ */ (0, import_jsx_runtime14.jsx)("img", { src: import_xyo_color_logo.default, height: widthInPixels ?? 22 })
|
|
292
|
-
}
|
|
293
|
-
) : null;
|
|
294
|
-
};
|
|
295
|
-
|
|
296
|
-
// src/components/PoweredByXyoButton.tsx
|
|
297
|
-
var import_jsx_runtime15 = require("react/jsx-runtime");
|
|
298
|
-
var PoweredByXyoButton = ({
|
|
299
|
-
busy = false,
|
|
300
|
-
href,
|
|
301
|
-
logoHeight,
|
|
302
|
-
logoTextSize,
|
|
303
|
-
sx,
|
|
304
|
-
target = "_blank",
|
|
305
|
-
variant = "text",
|
|
306
|
-
...props
|
|
307
|
-
}) => {
|
|
308
|
-
const [imageLoaded, setImageLoaded] = (0, import_react4.useState)(false);
|
|
309
|
-
const img = new Image();
|
|
310
|
-
img.onload = () => setImageLoaded(true);
|
|
311
|
-
img.src = import_xyo_color_logo_text_only.default;
|
|
312
|
-
return imageLoaded ? /* @__PURE__ */ (0, import_jsx_runtime15.jsx)(import_react_button3.ButtonEx, { href, target, variant, sx: { borderRadius: 0, padding: 0, ...sx }, ...props, children: /* @__PURE__ */ (0, import_jsx_runtime15.jsxs)(import_react_flexbox5.FlexCol, { padding: 0.5, children: [
|
|
313
|
-
/* @__PURE__ */ (0, import_jsx_runtime15.jsx)(import_material5.Typography, { style: { fontSize: logoTextSize ?? 10 }, fontSize: "small", children: "Powered by" }),
|
|
314
|
-
/* @__PURE__ */ (0, import_jsx_runtime15.jsxs)(import_react_flexbox5.FlexRow, { children: [
|
|
315
|
-
/* @__PURE__ */ (0, import_jsx_runtime15.jsx)(XyoBusy, { busy }),
|
|
316
|
-
/* @__PURE__ */ (0, import_jsx_runtime15.jsx)("img", { src: import_xyo_color_logo_text_only.default, height: logoHeight ?? 24, width: 45 })
|
|
317
|
-
] })
|
|
318
|
-
] }) }) : null;
|
|
319
|
-
};
|
|
320
|
-
|
|
321
|
-
// src/components/PoweredByXyo.tsx
|
|
322
|
-
var import_jsx_runtime16 = require("react/jsx-runtime");
|
|
323
|
-
var PoweredByXyo = ({
|
|
324
|
-
autoStop,
|
|
325
|
-
busy,
|
|
326
|
-
buttonProps = {},
|
|
327
|
-
debugDialog = false,
|
|
328
|
-
disableAnimation = false,
|
|
329
|
-
href = "https://xyo.network",
|
|
330
|
-
logoHeight,
|
|
331
|
-
logoTextSize,
|
|
332
|
-
onButtonClick,
|
|
333
|
-
node: propNode,
|
|
334
|
-
...props
|
|
335
|
-
}) => {
|
|
336
|
-
const [node] = (0, import_react_node4.useProvidedNode)();
|
|
337
|
-
const [debugDialogOpen, setDebugDialogOpen] = (0, import_react5.useState)(false);
|
|
338
|
-
const busyMap = (0, import_react5.useMemo)(() => ({}), [node]);
|
|
339
|
-
const activeBusy = busy ?? Object.values(busyMap).reduce((prev, value) => prev || value, false);
|
|
340
|
-
const activeOnButtonClick = (debugDialog ? (event) => {
|
|
341
|
-
if (event.shiftKey && event.altKey) {
|
|
342
|
-
setDebugDialogOpen(true);
|
|
343
|
-
} else if (href) {
|
|
344
|
-
window.open(href);
|
|
345
|
-
}
|
|
346
|
-
} : void 0) ?? onButtonClick;
|
|
347
|
-
const activeHref = activeOnButtonClick ? void 0 : href;
|
|
348
|
-
const onKeyDownEscListener = (event) => {
|
|
349
|
-
if (event.key === "Escape" && debugDialogOpen) {
|
|
350
|
-
setDebugDialogOpen(false);
|
|
351
|
-
}
|
|
352
|
-
};
|
|
353
|
-
(0, import_react_async_effect.useAsyncEffect)(
|
|
354
|
-
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
355
|
-
async () => {
|
|
356
|
-
const activeNode = propNode ?? node;
|
|
357
|
-
if (disableAnimation) {
|
|
358
|
-
return;
|
|
359
|
-
} else if (activeNode) {
|
|
360
|
-
const mods = await activeNode?.resolve();
|
|
361
|
-
mods?.map((mod) => {
|
|
362
|
-
mod.on("moduleBusy", ({ module: module2, busy: busy2 }) => {
|
|
363
|
-
busyMap[module2.address] = busy2;
|
|
364
|
-
if (autoStop) {
|
|
365
|
-
(0, import_forget.forget)(
|
|
366
|
-
(async () => {
|
|
367
|
-
await (0, import_delay2.delay)(1e3);
|
|
368
|
-
busyMap[module2.address] = false;
|
|
369
|
-
})()
|
|
370
|
-
);
|
|
371
|
-
}
|
|
372
|
-
});
|
|
373
|
-
});
|
|
374
|
-
activeNode?.on("moduleBusy", ({ module: module2, busy: busy2 }) => {
|
|
375
|
-
busyMap[module2.address] = busy2;
|
|
376
|
-
if (autoStop) {
|
|
377
|
-
(0, import_forget.forget)(
|
|
378
|
-
(async () => {
|
|
379
|
-
await (0, import_delay2.delay)(1e3);
|
|
380
|
-
busyMap[module2.address] = false;
|
|
381
|
-
})()
|
|
382
|
-
);
|
|
383
|
-
}
|
|
384
|
-
});
|
|
385
|
-
}
|
|
386
|
-
},
|
|
387
|
-
[disableAnimation, propNode, node, busyMap, autoStop]
|
|
388
|
-
);
|
|
389
|
-
return /* @__PURE__ */ (0, import_jsx_runtime16.jsxs)(import_react_flexbox6.FlexCol, { alignItems: "stretch", position: "absolute", bottom: "0", left: "0", ...props, children: [
|
|
390
|
-
/* @__PURE__ */ (0, import_jsx_runtime16.jsx)(import_material6.Paper, { sx: { borderRadius: 0 }, children: /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(
|
|
391
|
-
PoweredByXyoButton,
|
|
392
|
-
{
|
|
393
|
-
onClick: activeOnButtonClick,
|
|
394
|
-
href: activeHref,
|
|
395
|
-
busy: activeBusy,
|
|
396
|
-
logoHeight,
|
|
397
|
-
logoTextSize,
|
|
398
|
-
fullWidth: true,
|
|
399
|
-
...buttonProps
|
|
400
|
-
}
|
|
401
|
-
) }),
|
|
402
|
-
debugDialog ? /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(DebugDialog, { fullScreen: true, open: debugDialogOpen, onClose: () => setDebugDialogOpen(false), onKeyDown: onKeyDownEscListener }) : null
|
|
403
|
-
] });
|
|
404
|
-
};
|
|
405
|
-
//# sourceMappingURL=PoweredByXyo.cjs.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"sources":["../../../src/components/PoweredByXyo.tsx","../../../src/components/DebugDialog.tsx","../../../src/components/NodeDetails.tsx","../../../src/components/ModuleAccordion.tsx","../../../src/components/ModuleDetails.tsx","../../../src/components/JsonViewerButton.tsx","../../../src/components/TypedModuleSummary.tsx","../../../src/components/ArchivistSummary.tsx","../../../src/components/ModuleSummary.tsx","../../../src/components/BridgeSummary.tsx","../../../src/components/DivinerSummary.tsx","../../../src/components/NodeSummary.tsx","../../../src/components/SentinelSummary.tsx","../../../src/components/WitnessSummary.tsx","../../../src/components/PoweredByXyoButton.tsx","../../../src/img/index.ts","../../../src/components/XyoBusy.tsx"],"sourcesContent":["import { Paper } from '@mui/material'\nimport { delay } from '@xylabs/delay'\nimport { forget } from '@xylabs/forget'\nimport { useAsyncEffect } from '@xylabs/react-async-effect'\nimport { ButtonExProps } from '@xylabs/react-button'\nimport { FlexBoxProps, FlexCol } from '@xylabs/react-flexbox'\nimport { Module } from '@xyo-network/module-model'\nimport { NodeInstance } from '@xyo-network/node-model'\nimport { useProvidedNode } from '@xyo-network/react-node'\nimport { KeyboardEvent, useMemo, useState } from 'react'\n\nimport { DebugDialog } from './DebugDialog'\nimport { PoweredByXyoButton, PoweredByXyoButtonProps } from './PoweredByXyoButton'\n\nexport interface PoweredByXyoProps extends FlexBoxProps {\n autoStop?: boolean\n busy?: boolean\n buttonProps?: PoweredByXyoButtonProps\n debugDialog?: boolean\n disableAnimation?: boolean\n href?: ButtonExProps['href']\n logoHeight?: number\n logoTextSize?: number\n node?: NodeInstance\n onButtonClick?: ButtonExProps['onClick']\n}\n\nexport const PoweredByXyo: React.FC<PoweredByXyoProps> = ({\n autoStop,\n busy,\n buttonProps = {},\n debugDialog = false,\n disableAnimation = false,\n href = 'https://xyo.network',\n logoHeight,\n logoTextSize,\n onButtonClick,\n node: propNode,\n ...props\n}) => {\n const [node] = useProvidedNode()\n const [debugDialogOpen, setDebugDialogOpen] = useState(false)\n\n // eslint-disable-next-line react-hooks/exhaustive-deps\n const busyMap: Record<string, boolean> = useMemo(() => ({}), [node])\n\n const activeBusy = busy ?? Object.values(busyMap).reduce((prev, value) => prev || value, false)\n\n const activeOnButtonClick: PoweredByXyoProps['onButtonClick'] =\n (debugDialog\n ? (event) => {\n if (event.shiftKey && event.altKey) {\n setDebugDialogOpen(true)\n } else if (href) {\n window.open(href)\n }\n }\n : undefined) ?? onButtonClick\n\n const activeHref = activeOnButtonClick ? undefined : href\n\n const onKeyDownEscListener = (event: KeyboardEvent<HTMLDivElement>) => {\n if (event.key === 'Escape' && debugDialogOpen) {\n setDebugDialogOpen(false)\n }\n }\n\n useAsyncEffect(\n // eslint-disable-next-line react-hooks/exhaustive-deps\n async () => {\n const activeNode = propNode ?? node\n if (disableAnimation) {\n return\n } else if (activeNode) {\n const mods = await activeNode?.resolve()\n mods?.map((mod) => {\n mod.on('moduleBusy', ({ module, busy }) => {\n busyMap[(module as Module).address] = busy\n if (autoStop) {\n forget(\n (async () => {\n await delay(1000)\n busyMap[(module as Module).address] = false\n })(),\n )\n }\n })\n })\n activeNode?.on('moduleBusy', ({ module, busy }) => {\n busyMap[(module as Module).address] = busy\n if (autoStop) {\n forget(\n (async () => {\n await delay(1000)\n busyMap[(module as Module).address] = false\n })(),\n )\n }\n })\n }\n },\n [disableAnimation, propNode, node, busyMap, autoStop],\n )\n\n return (\n <FlexCol alignItems=\"stretch\" position=\"absolute\" bottom=\"0\" left=\"0\" {...props}>\n <Paper sx={{ borderRadius: 0 }}>\n <PoweredByXyoButton\n onClick={activeOnButtonClick}\n href={activeHref}\n busy={activeBusy}\n logoHeight={logoHeight}\n logoTextSize={logoTextSize}\n fullWidth\n {...buttonProps}\n />\n </Paper>\n {debugDialog ? (\n <DebugDialog fullScreen open={debugDialogOpen} onClose={() => setDebugDialogOpen(false)} onKeyDown={onKeyDownEscListener} />\n ) : null}\n </FlexCol>\n )\n}\n","import { Button, Dialog, DialogActions, DialogContent, DialogProps, DialogTitle } from '@mui/material'\n\nimport { NodeDetails } from './NodeDetails'\n\nexport interface DebugDialogProps extends DialogProps {}\n\nexport const DebugDialog: React.FC<DebugDialogProps> = ({ onClose, ...props }) => {\n return (\n <Dialog {...props}>\n <DialogTitle>Xyo Module Viewer</DialogTitle>\n <DialogContent>\n <NodeDetails width=\"100%\" />\n </DialogContent>\n <DialogActions>\n <Button onClick={(event) => onClose?.(event, 'backdropClick')}>Close</Button>\n </DialogActions>\n </Dialog>\n )\n}\n","import { FlexCol } from '@xylabs/react-flexbox'\nimport { NodeInstance } from '@xyo-network/node-model'\nimport { useModulesFromNode, useProvidedNode } from '@xyo-network/react-node'\n\nimport { ModuleAccordion } from './ModuleAccordion'\nimport { ModuleDetailsProps } from './ModuleDetails'\n\nexport interface NodeViewerProps extends ModuleDetailsProps<NodeInstance> {}\n\nexport const NodeDetails: React.FC<NodeViewerProps> = ({ module, ...props }) => {\n const [node = module] = useProvidedNode()\n\n const [children] = useModulesFromNode(undefined, { node: node ?? undefined })\n\n return (\n <FlexCol alignItems=\"stretch\" {...props}>\n {children ? (\n <>\n <FlexCol alignItems=\"stretch\" marginY={1}>\n {children?.map((child) => <ModuleAccordion key={child.address} module={child} />)}\n </FlexCol>\n </>\n ) : null}\n </FlexCol>\n )\n}\n","import { ExpandMore as ExpandMoreIcon } from '@mui/icons-material'\nimport { ModuleInstance } from '@xyo-network/module-model'\n\nexport interface ModuleAccordionProps<T extends ModuleInstance = ModuleInstance> extends Omit<AccordionProps, 'children'> {\n module?: T\n}\n\nimport { Accordion, AccordionDetails, AccordionProps, AccordionSummary } from '@mui/material'\n\nimport { ModuleDetails } from './ModuleDetails'\nimport { TypedModuleSummary } from './TypedModuleSummary'\n\nexport const ModuleAccordion: React.FC<ModuleAccordionProps> = ({ module, ...props }) => {\n return (\n <Accordion {...props}>\n <AccordionSummary expandIcon={<ExpandMoreIcon />}>\n <TypedModuleSummary module={module} />\n </AccordionSummary>\n <AccordionDetails>\n <ModuleDetails module={module} />\n </AccordionDetails>\n </Accordion>\n )\n}\n","import { ButtonGroup } from '@mui/material'\nimport { ButtonEx } from '@xylabs/react-button'\nimport { FlexBoxProps, FlexCol, FlexRow } from '@xylabs/react-flexbox'\nimport { usePromise } from '@xylabs/react-promise'\nimport { ModuleInstance } from '@xyo-network/module-model'\nimport { Property } from '@xyo-network/react-property'\n\nimport { JsonViewerButton } from './JsonViewerButton'\n\nexport interface ModuleDetailsProps<T extends ModuleInstance = ModuleInstance> extends FlexBoxProps {\n module?: T\n}\n\nexport const ModuleDetails: React.FC<ModuleDetailsProps> = ({ module, ...props }) => {\n const [manifest] = usePromise(async () => {\n return await module?.manifest()\n }, [module])\n\n const [discover] = usePromise(async () => {\n return await module?.discover()\n }, [module])\n\n const [describe] = usePromise(async () => {\n return await module?.describe()\n }, [module])\n\n const queries = module?.queries\n\n const config = module?.config\n\n return (\n <FlexCol alignItems=\"stretch\" {...props}>\n <Property title=\"Address\" value={module?.address} />\n\n <FlexRow gap={1} justifyContent=\"space-between\">\n <ButtonGroup>\n {manifest ? (\n <JsonViewerButton variant=\"contained\" src={manifest}>\n Manifest\n </JsonViewerButton>\n ) : null}\n {config ? (\n <JsonViewerButton variant=\"contained\" src={config}>\n Config\n </JsonViewerButton>\n ) : null}\n {discover ? (\n <JsonViewerButton variant=\"contained\" src={discover}>\n Discover\n </JsonViewerButton>\n ) : null}\n {describe ? (\n <JsonViewerButton variant=\"contained\" src={describe}>\n Describe\n </JsonViewerButton>\n ) : null}\n {queries ? (\n <JsonViewerButton variant=\"contained\" src={queries}>\n Queries\n </JsonViewerButton>\n ) : null}\n </ButtonGroup>\n <ButtonGroup>\n <ButtonEx target=\"_blank\" href={`https://explore.xyo.network/block?network=main&address=${module?.address}`} variant=\"outlined\">\n Main\n </ButtonEx>\n <ButtonEx target=\"_blank\" href={`https://beta.explore.xyo.network/block?network=kerplunk&address=${module?.address}`} variant=\"outlined\">\n Kerplunk\n </ButtonEx>\n <ButtonEx target=\"_blank\" href={`https://beta.explore.xyo.network/block?network=local&address=${module?.address}`} variant=\"outlined\">\n Local\n </ButtonEx>\n </ButtonGroup>\n </FlexRow>\n </FlexCol>\n )\n}\n","import { Dialog, DialogActions, DialogContent, DialogTitle } from '@mui/material'\nimport { ButtonEx, ButtonExProps } from '@xylabs/react-button'\nimport { useState } from 'react'\nimport JsonView, { ReactJsonViewProps } from 'react-json-view'\n\nexport interface JsonViewerButtonProps extends ButtonExProps {\n jsonViewProps?: Partial<ReactJsonViewProps>\n src: object\n}\n\nexport const JsonViewerButton: React.FC<JsonViewerButtonProps> = ({ children, jsonViewProps, src, title, ...props }) => {\n const [open, setOpen] = useState(false)\n return (\n <>\n <ButtonEx onClick={() => setOpen(!open)} {...props}>\n {children ?? 'JSON'}\n </ButtonEx>\n <Dialog open={open} onClose={() => setOpen(false)}>\n {title ? <DialogTitle>{title}</DialogTitle> : null}\n <DialogContent>\n <JsonView src={src} {...jsonViewProps} />\n </DialogContent>\n <DialogActions>\n <ButtonEx onClick={() => setOpen(false)}>Close</ButtonEx>\n </DialogActions>\n </Dialog>\n </>\n )\n}\n","import { isArchivistInstance } from '@xyo-network/archivist-model'\nimport { isBridgeInstance } from '@xyo-network/bridge-model'\nimport { isDivinerInstance } from '@xyo-network/diviner-model'\nimport { isNodeInstance } from '@xyo-network/node-model'\nimport { isSentinelInstance } from '@xyo-network/sentinel'\nimport { isWitnessInstance } from '@xyo-network/witness-model'\n\nimport { ArchivistSummary } from './ArchivistSummary'\nimport { BridgeSummary } from './BridgeSummary'\nimport { DivinerSummary } from './DivinerSummary'\nimport { ModuleSummary, ModuleSummaryProps } from './ModuleSummary'\nimport { NodeSummary } from './NodeSummary'\nimport { SentinelSummary } from './SentinelSummary'\nimport { WitnessSummary } from './WitnessSummary'\n\nexport const TypedModuleSummary: React.FC<ModuleSummaryProps> = ({ module, ...props }) => {\n if (isArchivistInstance(module)) {\n return <ArchivistSummary module={module} {...props} />\n }\n if (isDivinerInstance(module)) {\n return <DivinerSummary module={module} {...props} />\n }\n if (isNodeInstance(module)) {\n return <NodeSummary module={module} {...props} />\n }\n if (isWitnessInstance(module)) {\n return <WitnessSummary module={module} {...props} />\n }\n if (isBridgeInstance(module)) {\n return <BridgeSummary module={module} {...props} />\n }\n if (isSentinelInstance(module)) {\n return <SentinelSummary module={module} {...props} />\n }\n return <ModuleSummary module={module} {...props} />\n}\n","import { Inventory2Rounded as Inventory2RoundedIcon } from '@mui/icons-material'\nimport { ArchivistInstance } from '@xyo-network/archivist-model'\n\nimport { ModuleSummary, ModuleSummaryProps } from './ModuleSummary'\n\nexport const ArchivistSummary: React.FC<ModuleSummaryProps<ArchivistInstance>> = ({ module, ...props }) => {\n return <ModuleSummary module={module} icon={<Inventory2RoundedIcon />} {...props} />\n}\n","import { Extension as ExtensionIcon } from '@mui/icons-material'\nimport { delay } from '@xylabs/delay'\nimport { FlexBoxProps, FlexCol, FlexRow } from '@xylabs/react-flexbox'\nimport { ModuleInstance } from '@xyo-network/module-model'\nimport { useModulesFromNode } from '@xyo-network/react-node'\nimport { TypographyEx } from '@xyo-network/react-shared'\nimport { ReactNode, useState } from 'react'\n\nexport interface ModuleSummaryProps<T extends ModuleInstance = ModuleInstance> extends FlexBoxProps {\n icon?: ReactNode\n module?: T\n}\n\nexport const ModuleSummary: React.FC<ModuleSummaryProps> = ({ children, icon, module, ...props }) => {\n const [downModules] = useModulesFromNode(undefined, { direction: 'down' })\n const [upModules] = useModulesFromNode(undefined, { direction: 'up' })\n const [busy, setBusy] = useState(false)\n\n const downModulesFromResolve = downModules?.length\n const upModulesFromResolve = upModules?.length\n\n module?.on('moduleBusy', async ({ busy }) => {\n setBusy(busy)\n await delay(2000)\n setBusy(false)\n })\n\n return (\n <FlexCol alignItems=\"stretch\" width=\"100%\" {...props}>\n <FlexRow justifyContent=\"flex-start\">\n <FlexRow>\n <TypographyEx color={busy ? 'gray' : undefined}>{icon ?? <ExtensionIcon />}</TypographyEx>\n <TypographyEx marginX={1}>{module?.config?.name ?? '<Unknown>'}</TypographyEx>\n </FlexRow>\n {children ?? (downModulesFromResolve !== undefined && upModulesFromResolve !== undefined)\n ? `[${downModulesFromResolve}↓/${upModulesFromResolve}↑]`\n : null}\n </FlexRow>\n </FlexCol>\n )\n}\n","import { InsertLinkRounded as InsertLinkRoundedIcon } from '@mui/icons-material'\nimport { BridgeInstance } from '@xyo-network/bridge-model'\n\nimport { ModuleSummary, ModuleSummaryProps } from './ModuleSummary'\n\nexport const BridgeSummary: React.FC<ModuleSummaryProps<BridgeInstance>> = ({ module, ...props }) => {\n return <ModuleSummary module={module} icon={<InsertLinkRoundedIcon />} {...props}></ModuleSummary>\n}\n","import { BubbleChartRounded as BubbleChartRoundedIcon } from '@mui/icons-material'\nimport { DivinerInstance } from '@xyo-network/diviner-model'\n\nimport { ModuleSummary, ModuleSummaryProps } from './ModuleSummary'\n\nexport const DivinerSummary: React.FC<ModuleSummaryProps<DivinerInstance>> = ({ module, ...props }) => {\n return <ModuleSummary module={module} icon={<BubbleChartRoundedIcon />} {...props} />\n}\n","import { HubRounded as HubRoundedIcon } from '@mui/icons-material'\nimport { usePromise } from '@xylabs/react-promise'\nimport { NodeInstance } from '@xyo-network/node-model'\nimport { useModulesFromNode } from '@xyo-network/react-node'\n\nimport { ModuleSummary, ModuleSummaryProps } from './ModuleSummary'\n\nexport const NodeSummary: React.FC<ModuleSummaryProps<NodeInstance>> = ({ module, ...props }) => {\n const [manifest] = usePromise(async () => {\n return await module?.manifest()\n }, [module])\n\n const [downModules] = useModulesFromNode(undefined, { direction: 'down' })\n const [upModules] = useModulesFromNode(undefined, { direction: 'up' })\n\n const downModulesFromResolve = downModules?.length\n const upModulesFromResolve = upModules?.length\n\n const manifestPublicModules = manifest?.modules?.public?.length\n\n return (\n <ModuleSummary module={module} icon={<HubRoundedIcon />} {...props}>\n {manifestPublicModules !== undefined && downModulesFromResolve !== undefined && upModulesFromResolve !== undefined\n ? `[${manifestPublicModules}m/${downModulesFromResolve}↓/${upModulesFromResolve}↑]`\n : null}\n </ModuleSummary>\n )\n}\n","import { TimerRounded as TimerRoundedIcon } from '@mui/icons-material'\nimport { SentinelInstance } from '@xyo-network/sentinel'\n\nimport { ModuleSummary, ModuleSummaryProps } from './ModuleSummary'\n\nexport const SentinelSummary: React.FC<ModuleSummaryProps<SentinelInstance>> = ({ module, ...props }) => {\n return <ModuleSummary module={module} icon={<TimerRoundedIcon />} {...props} />\n}\n","import { VisibilityRounded as VisibilityRoundedIcon } from '@mui/icons-material'\nimport { WitnessInstance } from '@xyo-network/witness-model'\n\nimport { ModuleSummary, ModuleSummaryProps } from './ModuleSummary'\n\nexport const WitnessSummary: React.FC<ModuleSummaryProps<WitnessInstance>> = ({ module, ...props }) => {\n return <ModuleSummary module={module} icon={<VisibilityRoundedIcon />} {...props} />\n}\n","import { Typography } from '@mui/material'\nimport { ButtonEx, ButtonExProps } from '@xylabs/react-button'\nimport { FlexCol, FlexRow } from '@xylabs/react-flexbox'\nimport { useState } from 'react'\n\nimport { xyoColorLogoText } from '../img'\nimport { XyoBusy } from './XyoBusy'\n\nexport interface PoweredByXyoButtonProps extends ButtonExProps {\n busy?: boolean\n logoHeight?: number\n logoTextSize?: number\n}\n\nexport const PoweredByXyoButton: React.FC<PoweredByXyoButtonProps> = ({\n busy = false,\n href,\n logoHeight,\n logoTextSize,\n sx,\n target = '_blank',\n variant = 'text',\n ...props\n}) => {\n //preloading image to prevent shifting\n const [imageLoaded, setImageLoaded] = useState(false)\n const img = new Image()\n img.onload = () => setImageLoaded(true)\n img.src = xyoColorLogoText\n return imageLoaded ? (\n <ButtonEx href={href} target={target} variant={variant} sx={{ borderRadius: 0, padding: 0, ...sx }} {...props}>\n <FlexCol padding={0.5}>\n <Typography style={{ fontSize: logoTextSize ?? 10 }} fontSize=\"small\">\n Powered by\n </Typography>\n <FlexRow>\n <XyoBusy busy={busy} />\n <img src={xyoColorLogoText} height={logoHeight ?? 24} width={45} />\n </FlexRow>\n </FlexCol>\n </ButtonEx>\n ) : null\n}\n","import xyoColorLogo from './xyo-color-logo.svg'\nimport xyoColorLogoText from './xyo-color-logo-text-only.svg'\n\nexport { xyoColorLogo, xyoColorLogoText }\n","import { FlexBoxProps, FlexCol } from '@xylabs/react-flexbox'\nimport { useState } from 'react'\n\nimport { xyoColorLogo } from '../img'\n\nexport type XyoBusyProps = Omit<FlexBoxProps, 'children'> & {\n busy?: boolean\n spinsPerSecond?: number\n widthInPixels?: number\n}\n\nexport const XyoBusy: React.FC<XyoBusyProps> = ({ widthInPixels, busy, spinsPerSecond = 0.5, ...props }) => {\n //preloading image to prevent shifting\n const [imageLoaded, setImageLoaded] = useState(false)\n if (!imageLoaded) {\n const img = new Image()\n img.onload = () => setImageLoaded(true)\n img.src = xyoColorLogo\n }\n return imageLoaded ? (\n <FlexCol\n sx={{\n '@keyframes spin': {\n '0%': {\n transform: 'rotate(360deg)',\n },\n '100%': {\n transform: 'rotate(0deg)',\n },\n },\n animation: busy ? `spin ${1 / spinsPerSecond}s linear infinite` : undefined,\n animationDirection: 'reverse',\n }}\n {...props}\n >\n <img src={xyoColorLogo} height={widthInPixels ?? 22} />\n </FlexCol>\n ) : null\n}\n"],"mappings":"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","names":["import_material","import_delay","import_react_flexbox","import_react_node","import_react","import_material","import_react_flexbox","import_react_node","import_icons_material","import_material","import_material","import_react_button","JsonView","import_jsx_runtime","module","import_icons_material","import_react_flexbox","import_react","import_jsx_runtime","module","busy","ExtensionIcon","import_jsx_runtime","module","Inventory2RoundedIcon","import_icons_material","import_jsx_runtime","module","InsertLinkRoundedIcon","import_icons_material","import_jsx_runtime","module","BubbleChartRoundedIcon","import_icons_material","import_react_promise","import_react_node","import_jsx_runtime","module","HubRoundedIcon","import_icons_material","import_jsx_runtime","module","TimerRoundedIcon","import_icons_material","import_jsx_runtime","module","VisibilityRoundedIcon","import_jsx_runtime","module","import_jsx_runtime","module","ExpandMoreIcon","import_jsx_runtime","module","import_jsx_runtime","import_material","import_react_button","import_react_flexbox","import_react","import_react_flexbox","import_react","import_jsx_runtime","xyoColorLogo","import_jsx_runtime","xyoColorLogoText","import_jsx_runtime","module","busy"]}
|