@xyo-network/react-powered-by-xyo 2.77.0 → 2.77.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/browser/index.cjs +1 -425
- package/dist/browser/index.cjs.map +1 -1
- package/dist/browser/index.js +1 -392
- package/dist/browser/index.js.map +1 -1
- package/dist/neutral/index.cjs +1 -425
- package/dist/neutral/index.cjs.map +1 -1
- package/dist/neutral/index.js +1 -392
- package/dist/neutral/index.js.map +1 -1
- package/dist/node/index.cjs +1 -444
- package/dist/node/index.cjs.map +1 -1
- package/dist/node/index.js +1 -394
- package/dist/node/index.js.map +1 -1
- package/package.json +6 -6
package/dist/browser/index.cjs
CHANGED
|
@@ -1,426 +1,2 @@
|
|
|
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/index.ts
|
|
31
|
-
var src_exports = {};
|
|
32
|
-
__export(src_exports, {
|
|
33
|
-
ArchivistSummary: () => ArchivistSummary,
|
|
34
|
-
BridgeSummary: () => BridgeSummary,
|
|
35
|
-
DebugDialog: () => DebugDialog,
|
|
36
|
-
DivinerSummary: () => DivinerSummary,
|
|
37
|
-
ModuleAccordion: () => ModuleAccordion,
|
|
38
|
-
ModuleDetails: () => ModuleDetails,
|
|
39
|
-
ModuleSummary: () => ModuleSummary,
|
|
40
|
-
NodeDetails: () => NodeDetails,
|
|
41
|
-
PoweredByXyo: () => PoweredByXyo,
|
|
42
|
-
PoweredByXyoButton: () => PoweredByXyoButton,
|
|
43
|
-
SentinelSummary: () => SentinelSummary,
|
|
44
|
-
TypedModuleSummary: () => TypedModuleSummary,
|
|
45
|
-
WitnessSummary: () => WitnessSummary,
|
|
46
|
-
XyoBusy: () => XyoBusy
|
|
47
|
-
});
|
|
48
|
-
module.exports = __toCommonJS(src_exports);
|
|
49
|
-
|
|
50
|
-
// src/components/ArchivistSummary.tsx
|
|
51
|
-
var import_icons_material2 = require("@mui/icons-material");
|
|
52
|
-
|
|
53
|
-
// src/components/ModuleSummary.tsx
|
|
54
|
-
var import_icons_material = require("@mui/icons-material");
|
|
55
|
-
var import_delay = require("@xylabs/delay");
|
|
56
|
-
var import_react_flexbox = require("@xylabs/react-flexbox");
|
|
57
|
-
var import_react_node = require("@xyo-network/react-node");
|
|
58
|
-
var import_react_shared = require("@xyo-network/react-shared");
|
|
59
|
-
var import_react = require("react");
|
|
60
|
-
var import_jsx_runtime = require("react/jsx-runtime");
|
|
61
|
-
var ModuleSummary = ({ children, icon, mod, ...props }) => {
|
|
62
|
-
const [downModules] = (0, import_react_node.useWeakModulesFromNode)(void 0, { direction: "down" });
|
|
63
|
-
const [upModules] = (0, import_react_node.useWeakModulesFromNode)(void 0, { direction: "up" });
|
|
64
|
-
const [busy, setBusy] = (0, import_react.useState)(false);
|
|
65
|
-
const downModulesFromResolve = downModules?.length;
|
|
66
|
-
const upModulesFromResolve = upModules?.length;
|
|
67
|
-
mod?.on("moduleBusy", async ({ busy: busy2 }) => {
|
|
68
|
-
setBusy(busy2);
|
|
69
|
-
await (0, import_delay.delay)(2e3);
|
|
70
|
-
setBusy(false);
|
|
71
|
-
});
|
|
72
|
-
return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_react_flexbox.FlexCol, { alignItems: "stretch", width: "100%", ...props, children: /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(import_react_flexbox.FlexRow, { justifyContent: "flex-start", children: [
|
|
73
|
-
/* @__PURE__ */ (0, import_jsx_runtime.jsxs)(import_react_flexbox.FlexRow, { children: [
|
|
74
|
-
/* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_react_shared.TypographyEx, { color: busy ? "gray" : void 0, children: icon ?? /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_icons_material.Extension, {}) }),
|
|
75
|
-
/* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_react_shared.TypographyEx, { marginX: 1, children: mod?.config?.name ?? "<Unknown>" })
|
|
76
|
-
] }),
|
|
77
|
-
children ?? (downModulesFromResolve !== void 0 && upModulesFromResolve !== void 0) ? `[${downModulesFromResolve}\u2193/${upModulesFromResolve}\u2191]` : null
|
|
78
|
-
] }) });
|
|
79
|
-
};
|
|
80
|
-
|
|
81
|
-
// src/components/ArchivistSummary.tsx
|
|
82
|
-
var import_jsx_runtime2 = require("react/jsx-runtime");
|
|
83
|
-
var ArchivistSummary = ({ mod, ...props }) => {
|
|
84
|
-
return /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(ModuleSummary, { mod, icon: /* @__PURE__ */ (0, import_jsx_runtime2.jsx)(import_icons_material2.Inventory2Rounded, {}), ...props });
|
|
85
|
-
};
|
|
86
|
-
|
|
87
|
-
// src/components/BridgeSummary.tsx
|
|
88
|
-
var import_icons_material3 = require("@mui/icons-material");
|
|
89
|
-
var import_jsx_runtime3 = require("react/jsx-runtime");
|
|
90
|
-
var BridgeSummary = ({ mod, ...props }) => {
|
|
91
|
-
return /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(ModuleSummary, { mod, icon: /* @__PURE__ */ (0, import_jsx_runtime3.jsx)(import_icons_material3.InsertLinkRounded, {}), ...props });
|
|
92
|
-
};
|
|
93
|
-
|
|
94
|
-
// src/components/DebugDialog.tsx
|
|
95
|
-
var import_material4 = require("@mui/material");
|
|
96
|
-
|
|
97
|
-
// src/components/NodeDetails.tsx
|
|
98
|
-
var import_react_flexbox3 = require("@xylabs/react-flexbox");
|
|
99
|
-
var import_react_node3 = require("@xyo-network/react-node");
|
|
100
|
-
|
|
101
|
-
// src/components/ModuleAccordion.tsx
|
|
102
|
-
var import_icons_material8 = require("@mui/icons-material");
|
|
103
|
-
var import_material3 = require("@mui/material");
|
|
104
|
-
|
|
105
|
-
// src/components/ModuleDetails.tsx
|
|
106
|
-
var import_material2 = require("@mui/material");
|
|
107
|
-
var import_react_button2 = require("@xylabs/react-button");
|
|
108
|
-
var import_react_flexbox2 = require("@xylabs/react-flexbox");
|
|
109
|
-
var import_react_promise = require("@xylabs/react-promise");
|
|
110
|
-
var import_module_model = require("@xyo-network/module-model");
|
|
111
|
-
var import_payload_model = require("@xyo-network/payload-model");
|
|
112
|
-
var import_react_property = require("@xyo-network/react-property");
|
|
113
|
-
|
|
114
|
-
// src/components/JsonViewerButton.tsx
|
|
115
|
-
var import_material = require("@mui/material");
|
|
116
|
-
var import_react_button = require("@xylabs/react-button");
|
|
117
|
-
var import_react_payload_raw_info = require("@xyo-network/react-payload-raw-info");
|
|
118
|
-
var import_react2 = require("react");
|
|
119
|
-
var import_jsx_runtime4 = require("react/jsx-runtime");
|
|
120
|
-
var JsonViewerButton = ({ children, jsonViewProps, src, title, ...props }) => {
|
|
121
|
-
const [open, setOpen] = (0, import_react2.useState)(false);
|
|
122
|
-
return /* @__PURE__ */ (0, import_jsx_runtime4.jsxs)(import_jsx_runtime4.Fragment, { children: [
|
|
123
|
-
/* @__PURE__ */ (0, import_jsx_runtime4.jsx)(import_react_button.ButtonEx, { onClick: () => setOpen(!open), ...props, children: children ?? "JSON" }),
|
|
124
|
-
/* @__PURE__ */ (0, import_jsx_runtime4.jsxs)(import_material.Dialog, { open, onClose: () => setOpen(false), children: [
|
|
125
|
-
title ? /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(import_material.DialogTitle, { children: title }) : null,
|
|
126
|
-
/* @__PURE__ */ (0, import_jsx_runtime4.jsx)(import_material.DialogContent, { children: /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(import_react_payload_raw_info.JsonViewerEx, { value: src, ...jsonViewProps }) }),
|
|
127
|
-
/* @__PURE__ */ (0, import_jsx_runtime4.jsx)(import_material.DialogActions, { children: /* @__PURE__ */ (0, import_jsx_runtime4.jsx)(import_react_button.ButtonEx, { onClick: () => setOpen(false), children: "Close" }) })
|
|
128
|
-
] })
|
|
129
|
-
] });
|
|
130
|
-
};
|
|
131
|
-
|
|
132
|
-
// src/components/ModuleDetails.tsx
|
|
133
|
-
var import_jsx_runtime5 = require("react/jsx-runtime");
|
|
134
|
-
var ModuleDetails = ({ mod, ...props }) => {
|
|
135
|
-
const [manifest] = (0, import_react_promise.usePromise)(async () => {
|
|
136
|
-
return await mod?.manifest();
|
|
137
|
-
}, [mod]);
|
|
138
|
-
const [discover] = (0, import_react_promise.usePromise)(async () => {
|
|
139
|
-
return await mod?.state();
|
|
140
|
-
}, [mod]);
|
|
141
|
-
const [describe] = (0, import_react_promise.usePromise)(async () => {
|
|
142
|
-
const state = await mod?.state();
|
|
143
|
-
return state?.find((0, import_payload_model.isPayloadOfSchemaType)(import_module_model.ModuleDescriptionSchema));
|
|
144
|
-
}, [mod]);
|
|
145
|
-
const queries = mod?.queries;
|
|
146
|
-
const config = mod?.config;
|
|
147
|
-
return /* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(import_react_flexbox2.FlexCol, { alignItems: "stretch", ...props, children: [
|
|
148
|
-
/* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_react_property.Property, { title: "Address", value: mod?.address }),
|
|
149
|
-
/* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(import_react_flexbox2.FlexRow, { gap: 1, justifyContent: "space-between", children: [
|
|
150
|
-
/* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(import_material2.ButtonGroup, { children: [
|
|
151
|
-
manifest ? /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(JsonViewerButton, { variant: "contained", src: manifest, children: "Manifest" }) : null,
|
|
152
|
-
config ? /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(JsonViewerButton, { variant: "contained", src: config, children: "Config" }) : null,
|
|
153
|
-
discover ? /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(JsonViewerButton, { variant: "contained", src: discover, children: "Discover" }) : null,
|
|
154
|
-
describe ? /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(JsonViewerButton, { variant: "contained", src: describe, children: "Describe" }) : null,
|
|
155
|
-
queries ? /* @__PURE__ */ (0, import_jsx_runtime5.jsx)(JsonViewerButton, { variant: "contained", src: queries, children: "Queries" }) : null
|
|
156
|
-
] }),
|
|
157
|
-
/* @__PURE__ */ (0, import_jsx_runtime5.jsxs)(import_material2.ButtonGroup, { children: [
|
|
158
|
-
/* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_react_button2.ButtonEx, { target: "_blank", href: `https://explore.xyo.network/block?network=main&address=${mod?.address}`, variant: "outlined", children: "Main" }),
|
|
159
|
-
/* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_react_button2.ButtonEx, { target: "_blank", href: `https://beta.explore.xyo.network/block?network=kerplunk&address=${mod?.address}`, variant: "outlined", children: "Kerplunk" }),
|
|
160
|
-
/* @__PURE__ */ (0, import_jsx_runtime5.jsx)(import_react_button2.ButtonEx, { target: "_blank", href: `https://beta.explore.xyo.network/block?network=local&address=${mod?.address}`, variant: "outlined", children: "Local" })
|
|
161
|
-
] })
|
|
162
|
-
] })
|
|
163
|
-
] });
|
|
164
|
-
};
|
|
165
|
-
|
|
166
|
-
// src/components/TypedModuleSummary.tsx
|
|
167
|
-
var import_archivist_model = require("@xyo-network/archivist-model");
|
|
168
|
-
var import_bridge_model = require("@xyo-network/bridge-model");
|
|
169
|
-
var import_diviner_model = require("@xyo-network/diviner-model");
|
|
170
|
-
var import_node_model = require("@xyo-network/node-model");
|
|
171
|
-
var import_sentinel_model = require("@xyo-network/sentinel-model");
|
|
172
|
-
var import_witness_model = require("@xyo-network/witness-model");
|
|
173
|
-
|
|
174
|
-
// src/components/DivinerSummary.tsx
|
|
175
|
-
var import_icons_material4 = require("@mui/icons-material");
|
|
176
|
-
var import_jsx_runtime6 = require("react/jsx-runtime");
|
|
177
|
-
var DivinerSummary = ({ mod, ...props }) => {
|
|
178
|
-
return /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(ModuleSummary, { mod, icon: /* @__PURE__ */ (0, import_jsx_runtime6.jsx)(import_icons_material4.BubbleChartRounded, {}), ...props });
|
|
179
|
-
};
|
|
180
|
-
|
|
181
|
-
// src/components/NodeSummary.tsx
|
|
182
|
-
var import_icons_material5 = require("@mui/icons-material");
|
|
183
|
-
var import_react_promise2 = require("@xylabs/react-promise");
|
|
184
|
-
var import_react_node2 = require("@xyo-network/react-node");
|
|
185
|
-
var import_jsx_runtime7 = require("react/jsx-runtime");
|
|
186
|
-
var NodeSummary = ({ mod, ...props }) => {
|
|
187
|
-
const [manifest] = (0, import_react_promise2.usePromise)(async () => {
|
|
188
|
-
return await mod?.manifest();
|
|
189
|
-
}, [mod]);
|
|
190
|
-
const [downModules] = (0, import_react_node2.useWeakModulesFromNode)(void 0, { direction: "down" });
|
|
191
|
-
const [upModules] = (0, import_react_node2.useWeakModulesFromNode)(void 0, { direction: "up" });
|
|
192
|
-
const downModulesFromResolve = downModules?.length;
|
|
193
|
-
const upModulesFromResolve = upModules?.length;
|
|
194
|
-
const manifestPublicModules = manifest?.modules?.public?.length;
|
|
195
|
-
return /* @__PURE__ */ (0, import_jsx_runtime7.jsx)(ModuleSummary, { mod, 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 });
|
|
196
|
-
};
|
|
197
|
-
|
|
198
|
-
// src/components/SentinelSummary.tsx
|
|
199
|
-
var import_icons_material6 = require("@mui/icons-material");
|
|
200
|
-
var import_jsx_runtime8 = require("react/jsx-runtime");
|
|
201
|
-
var SentinelSummary = ({ mod, ...props }) => {
|
|
202
|
-
return /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(ModuleSummary, { mod, icon: /* @__PURE__ */ (0, import_jsx_runtime8.jsx)(import_icons_material6.TimerRounded, {}), ...props });
|
|
203
|
-
};
|
|
204
|
-
|
|
205
|
-
// src/components/WitnessSummary.tsx
|
|
206
|
-
var import_icons_material7 = require("@mui/icons-material");
|
|
207
|
-
var import_jsx_runtime9 = require("react/jsx-runtime");
|
|
208
|
-
var WitnessSummary = ({ mod, ...props }) => {
|
|
209
|
-
return /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(ModuleSummary, { mod, icon: /* @__PURE__ */ (0, import_jsx_runtime9.jsx)(import_icons_material7.VisibilityRounded, {}), ...props });
|
|
210
|
-
};
|
|
211
|
-
|
|
212
|
-
// src/components/TypedModuleSummary.tsx
|
|
213
|
-
var import_jsx_runtime10 = require("react/jsx-runtime");
|
|
214
|
-
var TypedModuleSummary = ({ mod, ...props }) => {
|
|
215
|
-
if ((0, import_archivist_model.isArchivistInstance)(mod)) {
|
|
216
|
-
return /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(ArchivistSummary, { mod, ...props });
|
|
217
|
-
}
|
|
218
|
-
if ((0, import_diviner_model.isDivinerInstance)(mod)) {
|
|
219
|
-
return /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(DivinerSummary, { mod, ...props });
|
|
220
|
-
}
|
|
221
|
-
if ((0, import_node_model.isNodeInstance)(mod)) {
|
|
222
|
-
return /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(NodeSummary, { mod, ...props });
|
|
223
|
-
}
|
|
224
|
-
if ((0, import_witness_model.isWitnessInstance)(mod)) {
|
|
225
|
-
return /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(WitnessSummary, { mod, ...props });
|
|
226
|
-
}
|
|
227
|
-
if ((0, import_bridge_model.isBridgeInstance)(mod)) {
|
|
228
|
-
return /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(BridgeSummary, { mod, ...props });
|
|
229
|
-
}
|
|
230
|
-
if ((0, import_sentinel_model.isSentinelInstance)(mod)) {
|
|
231
|
-
return /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(SentinelSummary, { mod, ...props });
|
|
232
|
-
}
|
|
233
|
-
return /* @__PURE__ */ (0, import_jsx_runtime10.jsx)(ModuleSummary, { mod, ...props });
|
|
234
|
-
};
|
|
235
|
-
|
|
236
|
-
// src/components/ModuleAccordion.tsx
|
|
237
|
-
var import_jsx_runtime11 = require("react/jsx-runtime");
|
|
238
|
-
var ModuleAccordion = ({ mod, ...props }) => {
|
|
239
|
-
return /* @__PURE__ */ (0, import_jsx_runtime11.jsxs)(import_material3.Accordion, { ...props, children: [
|
|
240
|
-
/* @__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, { mod }) }),
|
|
241
|
-
/* @__PURE__ */ (0, import_jsx_runtime11.jsx)(import_material3.AccordionDetails, { children: /* @__PURE__ */ (0, import_jsx_runtime11.jsx)(ModuleDetails, { mod }) })
|
|
242
|
-
] });
|
|
243
|
-
};
|
|
244
|
-
|
|
245
|
-
// src/components/NodeDetails.tsx
|
|
246
|
-
var import_jsx_runtime12 = require("react/jsx-runtime");
|
|
247
|
-
var NodeDetails = ({ mod, ...props }) => {
|
|
248
|
-
const [node = mod] = (0, import_react_node3.useProvidedNode)();
|
|
249
|
-
const [children] = (0, import_react_node3.useWeakModulesFromNode)(void 0, { node: node ?? void 0 });
|
|
250
|
-
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) => {
|
|
251
|
-
const instance = child.deref();
|
|
252
|
-
return instance ? /* @__PURE__ */ (0, import_jsx_runtime12.jsx)(ModuleAccordion, { mod: instance }, instance.address) : null;
|
|
253
|
-
}) }) }) : null });
|
|
254
|
-
};
|
|
255
|
-
|
|
256
|
-
// src/components/DebugDialog.tsx
|
|
257
|
-
var import_jsx_runtime13 = require("react/jsx-runtime");
|
|
258
|
-
var DebugDialog = ({ onClose, ...props }) => {
|
|
259
|
-
return /* @__PURE__ */ (0, import_jsx_runtime13.jsxs)(import_material4.Dialog, { ...props, children: [
|
|
260
|
-
/* @__PURE__ */ (0, import_jsx_runtime13.jsx)(import_material4.DialogTitle, { children: "Xyo Module Viewer" }),
|
|
261
|
-
/* @__PURE__ */ (0, import_jsx_runtime13.jsx)(import_material4.DialogContent, { children: /* @__PURE__ */ (0, import_jsx_runtime13.jsx)(NodeDetails, { width: "100%" }) }),
|
|
262
|
-
/* @__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" }) })
|
|
263
|
-
] });
|
|
264
|
-
};
|
|
265
|
-
|
|
266
|
-
// src/components/PoweredByXyo.tsx
|
|
267
|
-
var import_material6 = require("@mui/material");
|
|
268
|
-
var import_delay2 = require("@xylabs/delay");
|
|
269
|
-
var import_forget = require("@xylabs/forget");
|
|
270
|
-
var import_react_async_effect = require("@xylabs/react-async-effect");
|
|
271
|
-
var import_react_flexbox6 = require("@xylabs/react-flexbox");
|
|
272
|
-
var import_react_node4 = require("@xyo-network/react-node");
|
|
273
|
-
var import_react5 = require("react");
|
|
274
|
-
|
|
275
|
-
// src/components/PoweredByXyoButton.tsx
|
|
276
|
-
var import_material5 = require("@mui/material");
|
|
277
|
-
var import_react_button3 = require("@xylabs/react-button");
|
|
278
|
-
var import_react_flexbox5 = require("@xylabs/react-flexbox");
|
|
279
|
-
var import_react4 = require("react");
|
|
280
|
-
|
|
281
|
-
// src/img/index.ts
|
|
282
|
-
var import_xyo_color_logo = __toESM(require("./xyo-color-logo-LHR2SMEM.svg"), 1);
|
|
283
|
-
var import_xyo_color_logo_text_only = __toESM(require("./xyo-color-logo-text-only-QPAW5BSQ.svg"), 1);
|
|
284
|
-
|
|
285
|
-
// src/components/XyoBusy.tsx
|
|
286
|
-
var import_react_flexbox4 = require("@xylabs/react-flexbox");
|
|
287
|
-
var import_react3 = require("react");
|
|
288
|
-
var import_jsx_runtime14 = require("react/jsx-runtime");
|
|
289
|
-
var XyoBusy = ({ widthInPixels, busy, spinsPerSecond = 0.5, ...props }) => {
|
|
290
|
-
const [imageLoaded, setImageLoaded] = (0, import_react3.useState)(false);
|
|
291
|
-
if (!imageLoaded) {
|
|
292
|
-
const img = new Image();
|
|
293
|
-
img.addEventListener("load", () => setImageLoaded(true));
|
|
294
|
-
img.src = import_xyo_color_logo.default;
|
|
295
|
-
}
|
|
296
|
-
return imageLoaded ? /* @__PURE__ */ (0, import_jsx_runtime14.jsx)(
|
|
297
|
-
import_react_flexbox4.FlexCol,
|
|
298
|
-
{
|
|
299
|
-
sx: {
|
|
300
|
-
"@keyframes spin": {
|
|
301
|
-
"0%": {
|
|
302
|
-
transform: "rotate(360deg)"
|
|
303
|
-
},
|
|
304
|
-
"100%": {
|
|
305
|
-
transform: "rotate(0deg)"
|
|
306
|
-
}
|
|
307
|
-
},
|
|
308
|
-
animation: busy ? `spin ${1 / spinsPerSecond}s linear infinite` : void 0,
|
|
309
|
-
animationDirection: "reverse"
|
|
310
|
-
},
|
|
311
|
-
...props,
|
|
312
|
-
children: /* @__PURE__ */ (0, import_jsx_runtime14.jsx)("img", { src: import_xyo_color_logo.default, height: widthInPixels ?? 22 })
|
|
313
|
-
}
|
|
314
|
-
) : null;
|
|
315
|
-
};
|
|
316
|
-
|
|
317
|
-
// src/components/PoweredByXyoButton.tsx
|
|
318
|
-
var import_jsx_runtime15 = require("react/jsx-runtime");
|
|
319
|
-
var PoweredByXyoButton = ({
|
|
320
|
-
busy = false,
|
|
321
|
-
href,
|
|
322
|
-
logoHeight,
|
|
323
|
-
logoTextSize,
|
|
324
|
-
sx,
|
|
325
|
-
target = "_blank",
|
|
326
|
-
variant = "text",
|
|
327
|
-
...props
|
|
328
|
-
}) => {
|
|
329
|
-
const [imageLoaded, setImageLoaded] = (0, import_react4.useState)(false);
|
|
330
|
-
const img = new Image();
|
|
331
|
-
img.addEventListener("load", () => setImageLoaded(true));
|
|
332
|
-
img.src = import_xyo_color_logo_text_only.default;
|
|
333
|
-
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: [
|
|
334
|
-
/* @__PURE__ */ (0, import_jsx_runtime15.jsx)(import_material5.Typography, { style: { fontSize: logoTextSize ?? 10 }, fontSize: "small", children: "Powered by" }),
|
|
335
|
-
/* @__PURE__ */ (0, import_jsx_runtime15.jsxs)(import_react_flexbox5.FlexRow, { children: [
|
|
336
|
-
/* @__PURE__ */ (0, import_jsx_runtime15.jsx)(XyoBusy, { busy }),
|
|
337
|
-
/* @__PURE__ */ (0, import_jsx_runtime15.jsx)("img", { src: import_xyo_color_logo_text_only.default, height: logoHeight ?? 24, width: 45 })
|
|
338
|
-
] })
|
|
339
|
-
] }) }) : null;
|
|
340
|
-
};
|
|
341
|
-
|
|
342
|
-
// src/components/PoweredByXyo.tsx
|
|
343
|
-
var import_jsx_runtime16 = require("react/jsx-runtime");
|
|
344
|
-
var PoweredByXyo = ({
|
|
345
|
-
autoStop,
|
|
346
|
-
busy,
|
|
347
|
-
buttonProps = {},
|
|
348
|
-
debugDialog = false,
|
|
349
|
-
disableAnimation = false,
|
|
350
|
-
href = "https://xyo.network",
|
|
351
|
-
logoHeight,
|
|
352
|
-
logoTextSize,
|
|
353
|
-
onButtonClick,
|
|
354
|
-
node: propNode,
|
|
355
|
-
...props
|
|
356
|
-
}) => {
|
|
357
|
-
const [node] = (0, import_react_node4.useProvidedNode)();
|
|
358
|
-
const [debugDialogOpen, setDebugDialogOpen] = (0, import_react5.useState)(false);
|
|
359
|
-
const busyMap = (0, import_react5.useMemo)(() => ({}), [node]);
|
|
360
|
-
const activeBusy = busy ?? Object.values(busyMap).includes(true);
|
|
361
|
-
const activeOnButtonClick = (debugDialog ? (event) => {
|
|
362
|
-
if (event.shiftKey && event.altKey) {
|
|
363
|
-
setDebugDialogOpen(true);
|
|
364
|
-
} else if (href) {
|
|
365
|
-
window.open(href);
|
|
366
|
-
}
|
|
367
|
-
} : void 0) ?? onButtonClick;
|
|
368
|
-
const activeHref = activeOnButtonClick ? void 0 : href;
|
|
369
|
-
const onKeyDownEscListener = (event) => {
|
|
370
|
-
if (event.key === "Escape" && debugDialogOpen) {
|
|
371
|
-
setDebugDialogOpen(false);
|
|
372
|
-
}
|
|
373
|
-
};
|
|
374
|
-
(0, import_react_async_effect.useAsyncEffect)(
|
|
375
|
-
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
376
|
-
async () => {
|
|
377
|
-
const activeNode = propNode ?? node;
|
|
378
|
-
if (disableAnimation) {
|
|
379
|
-
return;
|
|
380
|
-
} else if (activeNode) {
|
|
381
|
-
const mods = await activeNode?.resolve("*");
|
|
382
|
-
mods?.map((mod) => {
|
|
383
|
-
mod.on("moduleBusy", ({ module: mod2, busy: busy2 }) => {
|
|
384
|
-
busyMap[mod2.address] = busy2;
|
|
385
|
-
if (autoStop) {
|
|
386
|
-
(0, import_forget.forget)(
|
|
387
|
-
(async () => {
|
|
388
|
-
await (0, import_delay2.delay)(1e3);
|
|
389
|
-
busyMap[mod2.address] = false;
|
|
390
|
-
})()
|
|
391
|
-
);
|
|
392
|
-
}
|
|
393
|
-
});
|
|
394
|
-
});
|
|
395
|
-
activeNode?.on("moduleBusy", ({ module: mod, busy: busy2 }) => {
|
|
396
|
-
busyMap[mod.address] = busy2;
|
|
397
|
-
if (autoStop) {
|
|
398
|
-
(0, import_forget.forget)(
|
|
399
|
-
(async () => {
|
|
400
|
-
await (0, import_delay2.delay)(1e3);
|
|
401
|
-
busyMap[mod.address] = false;
|
|
402
|
-
})()
|
|
403
|
-
);
|
|
404
|
-
}
|
|
405
|
-
});
|
|
406
|
-
}
|
|
407
|
-
},
|
|
408
|
-
[disableAnimation, propNode, node, busyMap, autoStop]
|
|
409
|
-
);
|
|
410
|
-
return /* @__PURE__ */ (0, import_jsx_runtime16.jsxs)(import_react_flexbox6.FlexCol, { alignItems: "stretch", position: "absolute", bottom: "0", left: "0", ...props, children: [
|
|
411
|
-
/* @__PURE__ */ (0, import_jsx_runtime16.jsx)(import_material6.Paper, { sx: { borderRadius: 0 }, children: /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(
|
|
412
|
-
PoweredByXyoButton,
|
|
413
|
-
{
|
|
414
|
-
onClick: activeOnButtonClick,
|
|
415
|
-
href: activeHref,
|
|
416
|
-
busy: activeBusy,
|
|
417
|
-
logoHeight,
|
|
418
|
-
logoTextSize,
|
|
419
|
-
fullWidth: true,
|
|
420
|
-
...buttonProps
|
|
421
|
-
}
|
|
422
|
-
) }),
|
|
423
|
-
debugDialog && debugDialogOpen ? /* @__PURE__ */ (0, import_jsx_runtime16.jsx)(DebugDialog, { fullScreen: true, open: debugDialogOpen, onClose: () => setDebugDialogOpen(false), onKeyDown: onKeyDownEscListener }) : null
|
|
424
|
-
] });
|
|
425
|
-
};
|
|
1
|
+
"use strict";var ee=Object.create;var v=Object.defineProperty;var re=Object.getOwnPropertyDescriptor;var te=Object.getOwnPropertyNames;var ne=Object.getPrototypeOf,se=Object.prototype.hasOwnProperty;var ie=(o,e)=>{for(var r in e)v(o,r,{get:e[r],enumerable:!0})},go=(o,e,r,n)=>{if(e&&typeof e=="object"||typeof e=="function")for(let t of te(e))!se.call(o,t)&&t!==r&&v(o,t,{get:()=>e[t],enumerable:!(n=re(e,t))||n.enumerable});return o};var Po=(o,e,r)=>(r=o!=null?ee(ne(o)):{},go(e||!o||!o.__esModule?v(r,"default",{value:o,enumerable:!0}):r,o)),ae=o=>go(v({},"__esModule",{value:!0}),o);var me={};ie(me,{ArchivistSummary:()=>z,BridgeSummary:()=>G,DebugDialog:()=>mo,DivinerSummary:()=>Z,ModuleAccordion:()=>io,ModuleDetails:()=>U,ModuleSummary:()=>a,NodeDetails:()=>lo,PoweredByXyo:()=>le,PoweredByXyoButton:()=>po,SentinelSummary:()=>ro,TypedModuleSummary:()=>so,WitnessSummary:()=>no,XyoBusy:()=>co});module.exports=ae(me);var So=require("@mui/icons-material");var Mo=require("@mui/icons-material"),Bo=require("@xylabs/delay"),F=require("@xylabs/react-flexbox"),$=require("@xyo-network/react-node"),H=require("@xyo-network/react-shared"),wo=require("react"),p=require("react/jsx-runtime"),a=({children:o,icon:e,mod:r,...n})=>{let[t]=(0,$.useWeakModulesFromNode)(void 0,{direction:"down"}),[s]=(0,$.useWeakModulesFromNode)(void 0,{direction:"up"}),[i,d]=(0,wo.useState)(!1),w=t?.length,M=s?.length;return r?.on("moduleBusy",async({busy:S})=>{d(S),await(0,Bo.delay)(2e3),d(!1)}),(0,p.jsx)(F.FlexCol,{alignItems:"stretch",width:"100%",...n,children:(0,p.jsxs)(F.FlexRow,{justifyContent:"flex-start",children:[(0,p.jsxs)(F.FlexRow,{children:[(0,p.jsx)(H.TypographyEx,{color:i?"gray":void 0,children:e??(0,p.jsx)(Mo.Extension,{})}),(0,p.jsx)(H.TypographyEx,{marginX:1,children:r?.config?.name??"<Unknown>"})]}),o??(w!==void 0&&M!==void 0)?`[${w}\u2193/${M}\u2191]`:null]})})};var K=require("react/jsx-runtime"),z=({mod:o,...e})=>(0,K.jsx)(a,{mod:o,icon:(0,K.jsx)(So.Inventory2Rounded,{}),...e});var bo=require("@mui/icons-material");var _=require("react/jsx-runtime"),G=({mod:o,...e})=>(0,_.jsx)(a,{mod:o,icon:(0,_.jsx)(bo.InsertLinkRounded,{}),...e});var u=require("@mui/material");var ao=require("@xylabs/react-flexbox"),A=require("@xyo-network/react-node");var Wo=require("@mui/icons-material"),I=require("@mui/material");var Q=require("@mui/material"),k=require("@xylabs/react-button"),T=require("@xylabs/react-flexbox"),E=require("@xylabs/react-promise"),Do=require("@xyo-network/module-model"),Fo=require("@xyo-network/payload-model"),ho=require("@xyo-network/react-property");var f=require("@mui/material"),q=require("@xylabs/react-button"),Co=require("@xyo-network/react-payload-raw-info"),Io=require("react"),m=require("react/jsx-runtime"),C=({children:o,jsonViewProps:e,src:r,title:n,...t})=>{let[s,i]=(0,Io.useState)(!1);return(0,m.jsxs)(m.Fragment,{children:[(0,m.jsx)(q.ButtonEx,{onClick:()=>i(!s),...t,children:o??"JSON"}),(0,m.jsxs)(f.Dialog,{open:s,onClose:()=>i(!1),children:[n?(0,m.jsx)(f.DialogTitle,{children:n}):null,(0,m.jsx)(f.DialogContent,{children:(0,m.jsx)(Co.JsonViewerEx,{value:r,...e})}),(0,m.jsx)(f.DialogActions,{children:(0,m.jsx)(q.ButtonEx,{onClick:()=>i(!1),children:"Close"})})]})]})};var l=require("react/jsx-runtime"),U=({mod:o,...e})=>{let[r]=(0,E.usePromise)(async()=>await o?.manifest(),[o]),[n]=(0,E.usePromise)(async()=>await o?.state(),[o]),[t]=(0,E.usePromise)(async()=>(await o?.state())?.find((0,Fo.isPayloadOfSchemaType)(Do.ModuleDescriptionSchema)),[o]),s=o?.queries,i=o?.config;return(0,l.jsxs)(T.FlexCol,{alignItems:"stretch",...e,children:[(0,l.jsx)(ho.Property,{title:"Address",value:o?.address}),(0,l.jsxs)(T.FlexRow,{gap:1,justifyContent:"space-between",children:[(0,l.jsxs)(Q.ButtonGroup,{children:[r?(0,l.jsx)(C,{variant:"contained",src:r,children:"Manifest"}):null,i?(0,l.jsx)(C,{variant:"contained",src:i,children:"Config"}):null,n?(0,l.jsx)(C,{variant:"contained",src:n,children:"Discover"}):null,t?(0,l.jsx)(C,{variant:"contained",src:t,children:"Describe"}):null,s?(0,l.jsx)(C,{variant:"contained",src:s,children:"Queries"}):null]}),(0,l.jsxs)(Q.ButtonGroup,{children:[(0,l.jsx)(k.ButtonEx,{target:"_blank",href:`https://explore.xyo.network/block?network=main&address=${o?.address}`,variant:"outlined",children:"Main"}),(0,l.jsx)(k.ButtonEx,{target:"_blank",href:`https://beta.explore.xyo.network/block?network=kerplunk&address=${o?.address}`,variant:"outlined",children:"Kerplunk"}),(0,l.jsx)(k.ButtonEx,{target:"_blank",href:`https://beta.explore.xyo.network/block?network=local&address=${o?.address}`,variant:"outlined",children:"Local"})]})]})]})};var No=require("@xyo-network/archivist-model"),Vo=require("@xyo-network/bridge-model"),Xo=require("@xyo-network/diviner-model"),Lo=require("@xyo-network/node-model"),Jo=require("@xyo-network/sentinel-model"),Oo=require("@xyo-network/witness-model");var Ro=require("@mui/icons-material");var Y=require("react/jsx-runtime"),Z=({mod:o,...e})=>(0,Y.jsx)(a,{mod:o,icon:(0,Y.jsx)(Ro.BubbleChartRounded,{}),...e});var vo=require("@mui/icons-material"),ko=require("@xylabs/react-promise"),j=require("@xyo-network/react-node");var oo=require("react/jsx-runtime"),Eo=({mod:o,...e})=>{let[r]=(0,ko.usePromise)(async()=>await o?.manifest(),[o]),[n]=(0,j.useWeakModulesFromNode)(void 0,{direction:"down"}),[t]=(0,j.useWeakModulesFromNode)(void 0,{direction:"up"}),s=n?.length,i=t?.length,d=r?.modules?.public?.length;return(0,oo.jsx)(a,{mod:o,icon:(0,oo.jsx)(vo.HubRounded,{}),...e,children:d!==void 0&&s!==void 0&&i!==void 0?`[${d}m/${s}\u2193/${i}\u2191]`:null})};var To=require("@mui/icons-material");var eo=require("react/jsx-runtime"),ro=({mod:o,...e})=>(0,eo.jsx)(a,{mod:o,icon:(0,eo.jsx)(To.TimerRounded,{}),...e});var Ao=require("@mui/icons-material");var to=require("react/jsx-runtime"),no=({mod:o,...e})=>(0,to.jsx)(a,{mod:o,icon:(0,to.jsx)(Ao.VisibilityRounded,{}),...e});var y=require("react/jsx-runtime"),so=({mod:o,...e})=>(0,No.isArchivistInstance)(o)?(0,y.jsx)(z,{mod:o,...e}):(0,Xo.isDivinerInstance)(o)?(0,y.jsx)(Z,{mod:o,...e}):(0,Lo.isNodeInstance)(o)?(0,y.jsx)(Eo,{mod:o,...e}):(0,Oo.isWitnessInstance)(o)?(0,y.jsx)(no,{mod:o,...e}):(0,Vo.isBridgeInstance)(o)?(0,y.jsx)(G,{mod:o,...e}):(0,Jo.isSentinelInstance)(o)?(0,y.jsx)(ro,{mod:o,...e}):(0,y.jsx)(a,{mod:o,...e});var x=require("react/jsx-runtime"),io=({mod:o,...e})=>(0,x.jsxs)(I.Accordion,{...e,children:[(0,x.jsx)(I.AccordionSummary,{expandIcon:(0,x.jsx)(Wo.ExpandMore,{}),children:(0,x.jsx)(so,{mod:o})}),(0,x.jsx)(I.AccordionDetails,{children:(0,x.jsx)(U,{mod:o})})]});var B=require("react/jsx-runtime"),lo=({mod:o,...e})=>{let[r=o]=(0,A.useProvidedNode)(),[n]=(0,A.useWeakModulesFromNode)(void 0,{node:r??void 0});return(0,B.jsx)(ao.FlexCol,{alignItems:"stretch",...e,children:n?(0,B.jsx)(B.Fragment,{children:(0,B.jsx)(ao.FlexCol,{alignItems:"stretch",marginY:1,children:n?.map(t=>{let s=t.deref();return s?(0,B.jsx)(io,{mod:s},s.address):null})})}):null})};var g=require("react/jsx-runtime"),mo=({onClose:o,...e})=>(0,g.jsxs)(u.Dialog,{...e,children:[(0,g.jsx)(u.DialogTitle,{children:"Xyo Module Viewer"}),(0,g.jsx)(u.DialogContent,{children:(0,g.jsx)(lo,{width:"100%"})}),(0,g.jsx)(u.DialogActions,{children:(0,g.jsx)(u.Button,{onClick:r=>o?.(r,"backdropClick"),children:"Close"})})]});var Go=require("@mui/material"),fo=require("@xylabs/delay"),yo=require("@xylabs/forget"),qo=require("@xylabs/react-async-effect"),Qo=require("@xylabs/react-flexbox"),Uo=require("@xyo-network/react-node"),L=require("react");var Ko=require("@mui/material"),zo=require("@xylabs/react-button"),X=require("@xylabs/react-flexbox"),_o=require("react");var N=Po(require("./xyo-color-logo-LHR2SMEM.svg"),1),V=Po(require("./xyo-color-logo-text-only-QPAW5BSQ.svg"),1);var $o=require("@xylabs/react-flexbox"),Ho=require("react");var uo=require("react/jsx-runtime"),co=({widthInPixels:o,busy:e,spinsPerSecond:r=.5,...n})=>{let[t,s]=(0,Ho.useState)(!1);if(!t){let i=new Image;i.addEventListener("load",()=>s(!0)),i.src=N.default}return t?(0,uo.jsx)($o.FlexCol,{sx:{"@keyframes spin":{"0%":{transform:"rotate(360deg)"},"100%":{transform:"rotate(0deg)"}},animation:e?`spin ${1/r}s linear infinite`:void 0,animationDirection:"reverse"},...n,children:(0,uo.jsx)("img",{src:N.default,height:o??22})}):null};var P=require("react/jsx-runtime"),po=({busy:o=!1,href:e,logoHeight:r,logoTextSize:n,sx:t,target:s="_blank",variant:i="text",...d})=>{let[w,M]=(0,_o.useState)(!1),S=new Image;return S.addEventListener("load",()=>M(!0)),S.src=V.default,w?(0,P.jsx)(zo.ButtonEx,{href:e,target:s,variant:i,sx:{borderRadius:0,padding:0,...t},...d,children:(0,P.jsxs)(X.FlexCol,{padding:.5,children:[(0,P.jsx)(Ko.Typography,{style:{fontSize:n??10},fontSize:"small",children:"Powered by"}),(0,P.jsxs)(X.FlexRow,{children:[(0,P.jsx)(co,{busy:o}),(0,P.jsx)("img",{src:V.default,height:r??24,width:45})]})]})}):null};var D=require("react/jsx-runtime"),le=({autoStop:o,busy:e,buttonProps:r={},debugDialog:n=!1,disableAnimation:t=!1,href:s="https://xyo.network",logoHeight:i,logoTextSize:d,onButtonClick:w,node:M,...S})=>{let[J]=(0,Uo.useProvidedNode)(),[O,W]=(0,L.useState)(!1),b=(0,L.useMemo)(()=>({}),[J]),Yo=e??Object.values(b).includes(!0),xo=(n?c=>{c.shiftKey&&c.altKey?W(!0):s&&window.open(s)}:void 0)??w,Zo=xo?void 0:s,jo=c=>{c.key==="Escape"&&O&&W(!1)};return(0,qo.useAsyncEffect)(async()=>{let c=M??J;t||c&&((await c?.resolve("*"))?.map(h=>{h.on("moduleBusy",({module:R,busy:oe})=>{b[R.address]=oe,o&&(0,yo.forget)((async()=>{await(0,fo.delay)(1e3),b[R.address]=!1})())})}),c?.on("moduleBusy",({module:h,busy:R})=>{b[h.address]=R,o&&(0,yo.forget)((async()=>{await(0,fo.delay)(1e3),b[h.address]=!1})())}))},[t,M,J,b,o]),(0,D.jsxs)(Qo.FlexCol,{alignItems:"stretch",position:"absolute",bottom:"0",left:"0",...S,children:[(0,D.jsx)(Go.Paper,{sx:{borderRadius:0},children:(0,D.jsx)(po,{onClick:xo,href:Zo,busy:Yo,logoHeight:i,logoTextSize:d,fullWidth:!0,...r})}),n&&O?(0,D.jsx)(mo,{fullScreen:!0,open:O,onClose:()=>W(!1),onKeyDown:jo}):null]})};
|
|
426
2
|
//# sourceMappingURL=index.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../../src/index.ts","../../src/components/ArchivistSummary.tsx","../../src/components/ModuleSummary.tsx","../../src/components/BridgeSummary.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/DivinerSummary.tsx","../../src/components/NodeSummary.tsx","../../src/components/SentinelSummary.tsx","../../src/components/WitnessSummary.tsx","../../src/components/PoweredByXyo.tsx","../../src/components/PoweredByXyoButton.tsx","../../src/img/index.ts","../../src/components/XyoBusy.tsx"],"sourcesContent":["export * from './components'\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>> = ({ mod, ...props }) => {\n return <ModuleSummary mod={mod} 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 { useWeakModulesFromNode } 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 mod?: T\n}\n\nexport const ModuleSummary: React.FC<ModuleSummaryProps> = ({ children, icon, mod, ...props }) => {\n const [downModules] = useWeakModulesFromNode(undefined, { direction: 'down' })\n const [upModules] = useWeakModulesFromNode(undefined, { direction: 'up' })\n const [busy, setBusy] = useState(false)\n\n const downModulesFromResolve = downModules?.length\n const upModulesFromResolve = upModules?.length\n\n mod?.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}>{mod?.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>> = ({ mod, ...props }) => {\n return <ModuleSummary mod={mod} icon={<InsertLinkRoundedIcon />} {...props}></ModuleSummary>\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 { useProvidedNode, useWeakModulesFromNode } 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> = ({ mod, ...props }) => {\n const [node = mod] = useProvidedNode()\n\n const [children] = useWeakModulesFromNode(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) => {\n const instance = child.deref()\n return instance ? <ModuleAccordion key={instance.address} mod={instance} /> : null\n })}\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 mod?: 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> = ({ mod, ...props }) => {\n return (\n <Accordion {...props}>\n <AccordionSummary expandIcon={<ExpandMoreIcon />}>\n <TypedModuleSummary mod={mod} />\n </AccordionSummary>\n <AccordionDetails>\n <ModuleDetails mod={mod} />\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 { ModuleDescriptionPayload, ModuleDescriptionSchema, ModuleInstance } from '@xyo-network/module-model'\nimport { isPayloadOfSchemaType } from '@xyo-network/payload-model'\nimport { Property } from '@xyo-network/react-property'\n\nimport { JsonViewerButton } from './JsonViewerButton'\n\nexport interface ModuleDetailsProps<T extends ModuleInstance = ModuleInstance> extends FlexBoxProps {\n mod?: T\n}\n\nexport const ModuleDetails: React.FC<ModuleDetailsProps> = ({ mod, ...props }) => {\n const [manifest] = usePromise(async () => {\n return await mod?.manifest()\n }, [mod])\n\n const [discover] = usePromise(async () => {\n return await mod?.state()\n }, [mod])\n\n const [describe] = usePromise(async () => {\n const state = await mod?.state()\n return state?.find<ModuleDescriptionPayload>(isPayloadOfSchemaType(ModuleDescriptionSchema))\n }, [mod])\n\n const queries = mod?.queries\n\n const config = mod?.config\n\n return (\n <FlexCol alignItems=\"stretch\" {...props}>\n <Property title=\"Address\" value={mod?.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=${mod?.address}`} variant=\"outlined\">\n Main\n </ButtonEx>\n <ButtonEx target=\"_blank\" href={`https://beta.explore.xyo.network/block?network=kerplunk&address=${mod?.address}`} variant=\"outlined\">\n Kerplunk\n </ButtonEx>\n <ButtonEx target=\"_blank\" href={`https://beta.explore.xyo.network/block?network=local&address=${mod?.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 { JsonViewerEx, JsonViewerExProps } from '@xyo-network/react-payload-raw-info'\nimport { useState } from 'react'\n\nexport interface JsonViewerButtonProps extends ButtonExProps {\n jsonViewProps?: Partial<JsonViewerExProps>\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 ?\n <DialogTitle>{title}</DialogTitle>\n : null}\n <DialogContent>\n <JsonViewerEx value={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-model'\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> = ({ mod, ...props }) => {\n if (isArchivistInstance(mod)) {\n return <ArchivistSummary mod={mod} {...props} />\n }\n if (isDivinerInstance(mod)) {\n return <DivinerSummary mod={mod} {...props} />\n }\n if (isNodeInstance(mod)) {\n return <NodeSummary mod={mod} {...props} />\n }\n if (isWitnessInstance(mod)) {\n return <WitnessSummary mod={mod} {...props} />\n }\n if (isBridgeInstance(mod)) {\n return <BridgeSummary mod={mod} {...props} />\n }\n if (isSentinelInstance(mod)) {\n return <SentinelSummary mod={mod} {...props} />\n }\n return <ModuleSummary mod={mod} {...props} />\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>> = ({ mod, ...props }) => {\n return <ModuleSummary mod={mod} icon={<BubbleChartRoundedIcon />} {...props} />\n}\n","import { HubRounded as HubRoundedIcon } from '@mui/icons-material'\nimport { usePromise } from '@xylabs/react-promise'\nimport { NodeManifest } from '@xyo-network/manifest'\nimport { NodeInstance } from '@xyo-network/node-model'\nimport { useWeakModulesFromNode } from '@xyo-network/react-node'\n\nimport { ModuleSummary, ModuleSummaryProps } from './ModuleSummary'\n\nexport const NodeSummary: React.FC<ModuleSummaryProps<NodeInstance>> = ({ mod, ...props }) => {\n const [manifest] = usePromise(async () => {\n return (await mod?.manifest()) as NodeManifest\n }, [mod])\n\n const [downModules] = useWeakModulesFromNode(undefined, { direction: 'down' })\n const [upModules] = useWeakModulesFromNode(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 mod={mod} 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-model'\n\nimport { ModuleSummary, ModuleSummaryProps } from './ModuleSummary'\n\nexport const SentinelSummary: React.FC<ModuleSummaryProps<SentinelInstance>> = ({ mod, ...props }) => {\n return <ModuleSummary mod={mod} 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>> = ({ mod, ...props }) => {\n return <ModuleSummary mod={mod} icon={<VisibilityRoundedIcon />} {...props} />\n}\n","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).includes(true)\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: mod, busy }) => {\n busyMap[(mod as Module).address] = busy\n if (autoStop) {\n forget(\n (async () => {\n await delay(1000)\n busyMap[(mod as Module).address] = false\n })(),\n )\n }\n })\n })\n activeNode?.on('moduleBusy', ({ module: mod, busy }) => {\n busyMap[(mod as Module).address] = busy\n if (autoStop) {\n forget(\n (async () => {\n await delay(1000)\n busyMap[(mod 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 && debugDialogOpen ?\n <DebugDialog fullScreen open={debugDialogOpen} onClose={() => setDebugDialogOpen(false)} onKeyDown={onKeyDownEscListener} />\n : null}\n </FlexCol>\n )\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.addEventListener('load', () => 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","export { default as xyoColorLogo } from './xyo-color-logo.svg'\nexport { default as xyoColorLogoText } from './xyo-color-logo-text-only.svg'\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.addEventListener('load', () => 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_icons_material","busy","ExtensionIcon","import_jsx_runtime","Inventory2RoundedIcon","import_icons_material","import_jsx_runtime","InsertLinkRoundedIcon","import_material","import_react_flexbox","import_react_node","import_icons_material","import_material","import_material","import_react_button","import_react_flexbox","import_react","import_jsx_runtime","import_jsx_runtime","import_icons_material","import_jsx_runtime","BubbleChartRoundedIcon","import_icons_material","import_react_promise","import_react_node","import_jsx_runtime","HubRoundedIcon","import_icons_material","import_jsx_runtime","TimerRoundedIcon","import_icons_material","import_jsx_runtime","VisibilityRoundedIcon","import_jsx_runtime","import_jsx_runtime","ExpandMoreIcon","import_jsx_runtime","import_jsx_runtime","import_material","import_delay","import_react_flexbox","import_react_node","import_react","import_material","import_react_button","import_react_flexbox","import_react","import_react_flexbox","import_react","import_jsx_runtime","import_jsx_runtime","import_jsx_runtime","mod","busy"]}
|
|
1
|
+
{"version":3,"sources":["../../src/index.ts","../../src/components/ArchivistSummary.tsx","../../src/components/ModuleSummary.tsx","../../src/components/BridgeSummary.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/DivinerSummary.tsx","../../src/components/NodeSummary.tsx","../../src/components/SentinelSummary.tsx","../../src/components/WitnessSummary.tsx","../../src/components/PoweredByXyo.tsx","../../src/components/PoweredByXyoButton.tsx","../../src/img/index.ts","../../src/components/XyoBusy.tsx"],"sourcesContent":["export * from './components'\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>> = ({ mod, ...props }) => {\n return <ModuleSummary mod={mod} 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 { useWeakModulesFromNode } 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 mod?: T\n}\n\nexport const ModuleSummary: React.FC<ModuleSummaryProps> = ({ children, icon, mod, ...props }) => {\n const [downModules] = useWeakModulesFromNode(undefined, { direction: 'down' })\n const [upModules] = useWeakModulesFromNode(undefined, { direction: 'up' })\n const [busy, setBusy] = useState(false)\n\n const downModulesFromResolve = downModules?.length\n const upModulesFromResolve = upModules?.length\n\n mod?.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}>{mod?.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>> = ({ mod, ...props }) => {\n return <ModuleSummary mod={mod} icon={<InsertLinkRoundedIcon />} {...props}></ModuleSummary>\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 { useProvidedNode, useWeakModulesFromNode } 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> = ({ mod, ...props }) => {\n const [node = mod] = useProvidedNode()\n\n const [children] = useWeakModulesFromNode(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) => {\n const instance = child.deref()\n return instance ? <ModuleAccordion key={instance.address} mod={instance} /> : null\n })}\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 mod?: 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> = ({ mod, ...props }) => {\n return (\n <Accordion {...props}>\n <AccordionSummary expandIcon={<ExpandMoreIcon />}>\n <TypedModuleSummary mod={mod} />\n </AccordionSummary>\n <AccordionDetails>\n <ModuleDetails mod={mod} />\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 { ModuleDescriptionPayload, ModuleDescriptionSchema, ModuleInstance } from '@xyo-network/module-model'\nimport { isPayloadOfSchemaType } from '@xyo-network/payload-model'\nimport { Property } from '@xyo-network/react-property'\n\nimport { JsonViewerButton } from './JsonViewerButton'\n\nexport interface ModuleDetailsProps<T extends ModuleInstance = ModuleInstance> extends FlexBoxProps {\n mod?: T\n}\n\nexport const ModuleDetails: React.FC<ModuleDetailsProps> = ({ mod, ...props }) => {\n const [manifest] = usePromise(async () => {\n return await mod?.manifest()\n }, [mod])\n\n const [discover] = usePromise(async () => {\n return await mod?.state()\n }, [mod])\n\n const [describe] = usePromise(async () => {\n const state = await mod?.state()\n return state?.find<ModuleDescriptionPayload>(isPayloadOfSchemaType(ModuleDescriptionSchema))\n }, [mod])\n\n const queries = mod?.queries\n\n const config = mod?.config\n\n return (\n <FlexCol alignItems=\"stretch\" {...props}>\n <Property title=\"Address\" value={mod?.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=${mod?.address}`} variant=\"outlined\">\n Main\n </ButtonEx>\n <ButtonEx target=\"_blank\" href={`https://beta.explore.xyo.network/block?network=kerplunk&address=${mod?.address}`} variant=\"outlined\">\n Kerplunk\n </ButtonEx>\n <ButtonEx target=\"_blank\" href={`https://beta.explore.xyo.network/block?network=local&address=${mod?.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 { JsonViewerEx, JsonViewerExProps } from '@xyo-network/react-payload-raw-info'\nimport { useState } from 'react'\n\nexport interface JsonViewerButtonProps extends ButtonExProps {\n jsonViewProps?: Partial<JsonViewerExProps>\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 ?\n <DialogTitle>{title}</DialogTitle>\n : null}\n <DialogContent>\n <JsonViewerEx value={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-model'\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> = ({ mod, ...props }) => {\n if (isArchivistInstance(mod)) {\n return <ArchivistSummary mod={mod} {...props} />\n }\n if (isDivinerInstance(mod)) {\n return <DivinerSummary mod={mod} {...props} />\n }\n if (isNodeInstance(mod)) {\n return <NodeSummary mod={mod} {...props} />\n }\n if (isWitnessInstance(mod)) {\n return <WitnessSummary mod={mod} {...props} />\n }\n if (isBridgeInstance(mod)) {\n return <BridgeSummary mod={mod} {...props} />\n }\n if (isSentinelInstance(mod)) {\n return <SentinelSummary mod={mod} {...props} />\n }\n return <ModuleSummary mod={mod} {...props} />\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>> = ({ mod, ...props }) => {\n return <ModuleSummary mod={mod} icon={<BubbleChartRoundedIcon />} {...props} />\n}\n","import { HubRounded as HubRoundedIcon } from '@mui/icons-material'\nimport { usePromise } from '@xylabs/react-promise'\nimport { NodeManifest } from '@xyo-network/manifest'\nimport { NodeInstance } from '@xyo-network/node-model'\nimport { useWeakModulesFromNode } from '@xyo-network/react-node'\n\nimport { ModuleSummary, ModuleSummaryProps } from './ModuleSummary'\n\nexport const NodeSummary: React.FC<ModuleSummaryProps<NodeInstance>> = ({ mod, ...props }) => {\n const [manifest] = usePromise(async () => {\n return (await mod?.manifest()) as NodeManifest\n }, [mod])\n\n const [downModules] = useWeakModulesFromNode(undefined, { direction: 'down' })\n const [upModules] = useWeakModulesFromNode(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 mod={mod} 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-model'\n\nimport { ModuleSummary, ModuleSummaryProps } from './ModuleSummary'\n\nexport const SentinelSummary: React.FC<ModuleSummaryProps<SentinelInstance>> = ({ mod, ...props }) => {\n return <ModuleSummary mod={mod} 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>> = ({ mod, ...props }) => {\n return <ModuleSummary mod={mod} icon={<VisibilityRoundedIcon />} {...props} />\n}\n","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).includes(true)\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: mod, busy }) => {\n busyMap[(mod as Module).address] = busy\n if (autoStop) {\n forget(\n (async () => {\n await delay(1000)\n busyMap[(mod as Module).address] = false\n })(),\n )\n }\n })\n })\n activeNode?.on('moduleBusy', ({ module: mod, busy }) => {\n busyMap[(mod as Module).address] = busy\n if (autoStop) {\n forget(\n (async () => {\n await delay(1000)\n busyMap[(mod 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 && debugDialogOpen ?\n <DebugDialog fullScreen open={debugDialogOpen} onClose={() => setDebugDialogOpen(false)} onKeyDown={onKeyDownEscListener} />\n : null}\n </FlexCol>\n )\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.addEventListener('load', () => 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","export { default as xyoColorLogo } from './xyo-color-logo.svg'\nexport { default as xyoColorLogoText } from './xyo-color-logo-text-only.svg'\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.addEventListener('load', () => 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":["src_exports","__export","ArchivistSummary","BridgeSummary","DebugDialog","DivinerSummary","ModuleAccordion","ModuleDetails","ModuleSummary","NodeDetails","PoweredByXyo","PoweredByXyoButton","SentinelSummary","TypedModuleSummary","WitnessSummary","XyoBusy","__toCommonJS","import_icons_material","import_icons_material","import_delay","import_react_flexbox","import_react_node","import_react_shared","import_react","import_jsx_runtime","ModuleSummary","children","icon","mod","props","downModules","upModules","busy","setBusy","downModulesFromResolve","upModulesFromResolve","ExtensionIcon","import_jsx_runtime","ArchivistSummary","mod","props","ModuleSummary","Inventory2RoundedIcon","import_icons_material","import_jsx_runtime","BridgeSummary","mod","props","ModuleSummary","InsertLinkRoundedIcon","import_material","import_react_flexbox","import_react_node","import_icons_material","import_material","import_material","import_react_button","import_react_flexbox","import_react_promise","import_module_model","import_payload_model","import_react_property","import_material","import_react_button","import_react_payload_raw_info","import_react","import_jsx_runtime","JsonViewerButton","children","jsonViewProps","src","title","props","open","setOpen","import_jsx_runtime","ModuleDetails","mod","props","manifest","discover","describe","queries","config","JsonViewerButton","import_archivist_model","import_bridge_model","import_diviner_model","import_node_model","import_sentinel_model","import_witness_model","import_icons_material","import_jsx_runtime","DivinerSummary","mod","props","ModuleSummary","BubbleChartRoundedIcon","import_icons_material","import_react_promise","import_react_node","import_jsx_runtime","NodeSummary","mod","props","manifest","downModules","upModules","downModulesFromResolve","upModulesFromResolve","manifestPublicModules","ModuleSummary","HubRoundedIcon","import_icons_material","import_jsx_runtime","SentinelSummary","mod","props","ModuleSummary","TimerRoundedIcon","import_icons_material","import_jsx_runtime","WitnessSummary","mod","props","ModuleSummary","VisibilityRoundedIcon","import_jsx_runtime","TypedModuleSummary","mod","props","ArchivistSummary","DivinerSummary","NodeSummary","WitnessSummary","BridgeSummary","SentinelSummary","ModuleSummary","import_jsx_runtime","ModuleAccordion","mod","props","ExpandMoreIcon","TypedModuleSummary","ModuleDetails","import_jsx_runtime","NodeDetails","mod","props","node","children","child","instance","ModuleAccordion","import_jsx_runtime","DebugDialog","onClose","props","NodeDetails","event","import_material","import_delay","import_forget","import_react_async_effect","import_react_flexbox","import_react_node","import_react","import_material","import_react_button","import_react_flexbox","import_react","import_xyo_color_logo","import_xyo_color_logo_text_only","import_react_flexbox","import_react","import_jsx_runtime","XyoBusy","widthInPixels","busy","spinsPerSecond","props","imageLoaded","setImageLoaded","img","import_jsx_runtime","PoweredByXyoButton","busy","href","logoHeight","logoTextSize","sx","target","variant","props","imageLoaded","setImageLoaded","img","XyoBusy","import_jsx_runtime","PoweredByXyo","autoStop","busy","buttonProps","debugDialog","disableAnimation","href","logoHeight","logoTextSize","onButtonClick","propNode","props","node","debugDialogOpen","setDebugDialogOpen","busyMap","activeBusy","activeOnButtonClick","event","activeHref","onKeyDownEscListener","activeNode","mod","PoweredByXyoButton","DebugDialog"]}
|