@xyo-network/react-panel 2.41.43 → 2.41.45
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/cjs/contexts/Provider.js +54 -60
- package/dist/cjs/contexts/Provider.js.map +1 -1
- package/dist/docs.json +147 -115
- package/dist/esm/contexts/Provider.js +52 -58
- package/dist/esm/contexts/Provider.js.map +1 -1
- package/dist/types/contexts/Provider.d.ts +3 -0
- package/dist/types/contexts/Provider.d.ts.map +1 -1
- package/package.json +12 -11
- package/src/contexts/Provider.tsx +56 -65
@@ -4,19 +4,15 @@ import { useAsyncEffect } from '@xylabs/react-shared';
|
|
4
4
|
import { ArchivistWrapper } from '@xyo-network/archivist';
|
5
5
|
import { SimpleModuleResolver } from '@xyo-network/module';
|
6
6
|
import { XyoPanel, XyoPanelConfigSchema } from '@xyo-network/panel';
|
7
|
-
import { useArchivist } from '@xyo-network/react-archivist';
|
8
|
-
import { useAccount } from '@xyo-network/react-wallet';
|
9
7
|
import { useEffect, useMemo, useState } from 'react';
|
10
8
|
import { PanelContext } from './Context';
|
11
9
|
import { ReportStatus } from './State';
|
12
|
-
export const PanelProvider = ({ archivist
|
13
|
-
const { archivist } = useArchivist();
|
10
|
+
export const PanelProvider = ({ account, archivist, children, witnesses = [], required = false }) => {
|
14
11
|
const [panel, setPanel] = useState();
|
15
12
|
const [history, setHistory] = useState();
|
16
13
|
const [progress, setProgress] = useState({});
|
17
14
|
const [status, setStatus] = useState(ReportStatus.Idle);
|
18
15
|
const [reportingErrors, setReportingErrors] = useState();
|
19
|
-
const { account } = useAccount();
|
20
16
|
const resolver = useMemo(() => {
|
21
17
|
const resolver = new SimpleModuleResolver().add(witnesses);
|
22
18
|
return archivist ? resolver.add(new ArchivistWrapper(archivist)) : resolver;
|
@@ -24,60 +20,58 @@ export const PanelProvider = ({ archivist: archivistProp, children, witnesses =
|
|
24
20
|
useAsyncEffect(
|
25
21
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
26
22
|
async (mounted) => {
|
27
|
-
const
|
28
|
-
const
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
}
|
42
|
-
},
|
43
|
-
onReportStart: () => {
|
44
|
-
if (mounted()) {
|
45
|
-
setProgress({ archivists: {}, witnesses: {} });
|
46
|
-
setStatus(ReportStatus.Started);
|
47
|
-
}
|
48
|
-
},
|
49
|
-
onWitnessReportEnd: (witness, error) => {
|
50
|
-
const witnesses = progress.witnesses ?? {};
|
51
|
-
witnesses[witness.address] = {
|
52
|
-
status: error ? ReportStatus.Failed : ReportStatus.Succeeded,
|
53
|
-
witness,
|
54
|
-
};
|
55
|
-
if (mounted()) {
|
56
|
-
setProgress({
|
57
|
-
archivists: progress.archivists,
|
58
|
-
witnesses,
|
59
|
-
});
|
60
|
-
}
|
61
|
-
},
|
62
|
-
onWitnessReportStart: (witness) => {
|
63
|
-
const witnesses = progress.witnesses ?? {};
|
64
|
-
witnesses[witness.address] = {
|
65
|
-
status: ReportStatus.Started,
|
66
|
-
witness,
|
67
|
-
};
|
68
|
-
if (mounted()) {
|
69
|
-
setProgress({
|
70
|
-
archivists: progress.archivists,
|
71
|
-
witnesses,
|
72
|
-
});
|
73
|
-
}
|
74
|
-
},
|
75
|
-
schema: XyoPanelConfigSchema,
|
76
|
-
witnesses: witnesses.map((witness) => witness.address),
|
23
|
+
const archivistWrapper = archivist ? new ArchivistWrapper(archivist) : undefined;
|
24
|
+
const panel = await XyoPanel.create({
|
25
|
+
account,
|
26
|
+
config: {
|
27
|
+
archivists: [archivistWrapper?.address],
|
28
|
+
onReportEnd: (_, errors) => {
|
29
|
+
if (mounted()) {
|
30
|
+
setProgress({
|
31
|
+
archivists: progress.archivists,
|
32
|
+
witnesses: progress.witnesses,
|
33
|
+
});
|
34
|
+
setStatus(errors ? ReportStatus.Failed : ReportStatus.Succeeded);
|
35
|
+
setReportingErrors(errors);
|
36
|
+
}
|
77
37
|
},
|
78
|
-
|
79
|
-
|
80
|
-
|
38
|
+
onReportStart: () => {
|
39
|
+
if (mounted()) {
|
40
|
+
setProgress({ archivists: {}, witnesses: {} });
|
41
|
+
setStatus(ReportStatus.Started);
|
42
|
+
}
|
43
|
+
},
|
44
|
+
onWitnessReportEnd: (witness, error) => {
|
45
|
+
const witnesses = progress.witnesses ?? {};
|
46
|
+
witnesses[witness.address] = {
|
47
|
+
status: error ? ReportStatus.Failed : ReportStatus.Succeeded,
|
48
|
+
witness,
|
49
|
+
};
|
50
|
+
if (mounted()) {
|
51
|
+
setProgress({
|
52
|
+
archivists: progress.archivists,
|
53
|
+
witnesses,
|
54
|
+
});
|
55
|
+
}
|
56
|
+
},
|
57
|
+
onWitnessReportStart: (witness) => {
|
58
|
+
const witnesses = progress.witnesses ?? {};
|
59
|
+
witnesses[witness.address] = {
|
60
|
+
status: ReportStatus.Started,
|
61
|
+
witness,
|
62
|
+
};
|
63
|
+
if (mounted()) {
|
64
|
+
setProgress({
|
65
|
+
archivists: progress.archivists,
|
66
|
+
witnesses,
|
67
|
+
});
|
68
|
+
}
|
69
|
+
},
|
70
|
+
schema: XyoPanelConfigSchema,
|
71
|
+
witnesses: witnesses.map((witness) => witness.address),
|
72
|
+
},
|
73
|
+
resolver,
|
74
|
+
});
|
81
75
|
setPanel(panel);
|
82
76
|
await delay(0);
|
83
77
|
},
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"Provider.js","sourceRoot":"","sources":["../../../src/contexts/Provider.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAA;AACrC,OAAO,EAAE,cAAc,EAAgB,MAAM,sBAAsB,CAAA;
|
1
|
+
{"version":3,"file":"Provider.js","sourceRoot":"","sources":["../../../src/contexts/Provider.tsx"],"names":[],"mappings":"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"}
|
@@ -1,8 +1,11 @@
|
|
1
1
|
/// <reference types="react" />
|
2
2
|
import { WithChildren } from '@xylabs/react-shared';
|
3
|
+
import { Account } from '@xyo-network/account';
|
3
4
|
import { PayloadArchivist } from '@xyo-network/archivist';
|
4
5
|
import { WitnessWrapper } from '@xyo-network/witness';
|
5
6
|
export interface PanelProviderProps {
|
7
|
+
/** Account used by the panel for signing */
|
8
|
+
account?: Account;
|
6
9
|
/** @deprecated - panel no longer uses archive but relies on an archivist */
|
7
10
|
archive?: string;
|
8
11
|
archivist?: PayloadArchivist;
|
@@ -1 +1 @@
|
|
1
|
-
{"version":3,"file":"Provider.d.ts","sourceRoot":"","sources":["../../../src/contexts/Provider.tsx"],"names":[],"mappings":";AACA,OAAO,EAAkB,YAAY,EAAE,MAAM,sBAAsB,CAAA;AACnE,OAAO,EAAoB,gBAAgB,EAAE,MAAM,wBAAwB,CAAA;
|
1
|
+
{"version":3,"file":"Provider.d.ts","sourceRoot":"","sources":["../../../src/contexts/Provider.tsx"],"names":[],"mappings":";AACA,OAAO,EAAkB,YAAY,EAAE,MAAM,sBAAsB,CAAA;AACnE,OAAO,EAAE,OAAO,EAAE,MAAM,sBAAsB,CAAA;AAC9C,OAAO,EAAoB,gBAAgB,EAAE,MAAM,wBAAwB,CAAA;AAI3E,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAA;AAMrD,MAAM,WAAW,kBAAkB;IACjC,4CAA4C;IAC5C,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,4EAA4E;IAC5E,OAAO,CAAC,EAAE,MAAM,CAAA;IAChB,SAAS,CAAC,EAAE,gBAAgB,CAAA;IAC5B,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,SAAS,CAAC,EAAE,cAAc,EAAE,CAAA;CAC7B;AAED,eAAO,MAAM,aAAa,EAAE,KAAK,CAAC,EAAE,CAAC,YAAY,CAAC,kBAAkB,CAAC,CAiFpE,CAAA"}
|
package/package.json
CHANGED
@@ -11,18 +11,19 @@
|
|
11
11
|
},
|
12
12
|
"dependencies": {
|
13
13
|
"@xylabs/delay": "^2.6.16",
|
14
|
-
"@xylabs/react-shared": "^2.15.
|
15
|
-
"@xyo-network/
|
16
|
-
"@xyo-network/
|
17
|
-
"@xyo-network/
|
18
|
-
"@xyo-network/
|
19
|
-
"@xyo-network/
|
20
|
-
"@xyo-network/react-shared": "^2.41.
|
21
|
-
"@xyo-network/
|
22
|
-
"@xyo-network/witness": "^2.43.24"
|
14
|
+
"@xylabs/react-shared": "^2.15.17",
|
15
|
+
"@xyo-network/account": "^2.43.27",
|
16
|
+
"@xyo-network/archivist": "^2.43.27",
|
17
|
+
"@xyo-network/boundwitness-model": "^2.43.27",
|
18
|
+
"@xyo-network/module": "^2.43.27",
|
19
|
+
"@xyo-network/panel": "^2.43.27",
|
20
|
+
"@xyo-network/react-shared": "^2.41.45",
|
21
|
+
"@xyo-network/witness": "^2.43.27"
|
23
22
|
},
|
24
23
|
"devDependencies": {
|
25
|
-
"@xylabs/ts-scripts-yarn3": "2.
|
24
|
+
"@xylabs/ts-scripts-yarn3": "^2.13.9",
|
25
|
+
"@xylabs/tsconfig-react": "^2.13.9",
|
26
|
+
"typescript": "^4.9.5"
|
26
27
|
},
|
27
28
|
"peerDependencies": {
|
28
29
|
"@mui/icons-material": "^5",
|
@@ -76,5 +77,5 @@
|
|
76
77
|
},
|
77
78
|
"sideEffects": false,
|
78
79
|
"types": "dist/types/index.d.ts",
|
79
|
-
"version": "2.41.
|
80
|
+
"version": "2.41.45"
|
80
81
|
}
|
@@ -1,11 +1,10 @@
|
|
1
1
|
import { delay } from '@xylabs/delay'
|
2
2
|
import { useAsyncEffect, WithChildren } from '@xylabs/react-shared'
|
3
|
+
import { Account } from '@xyo-network/account'
|
3
4
|
import { ArchivistWrapper, PayloadArchivist } from '@xyo-network/archivist'
|
4
5
|
import { XyoBoundWitness } from '@xyo-network/boundwitness-model'
|
5
6
|
import { SimpleModuleResolver } from '@xyo-network/module'
|
6
7
|
import { XyoPanel, XyoPanelConfig, XyoPanelConfigSchema } from '@xyo-network/panel'
|
7
|
-
import { useArchivist } from '@xyo-network/react-archivist'
|
8
|
-
import { useAccount } from '@xyo-network/react-wallet'
|
9
8
|
import { WitnessWrapper } from '@xyo-network/witness'
|
10
9
|
import { useEffect, useMemo, useState } from 'react'
|
11
10
|
|
@@ -13,6 +12,8 @@ import { PanelContext } from './Context'
|
|
13
12
|
import { PanelReportProgress, ReportStatus } from './State'
|
14
13
|
|
15
14
|
export interface PanelProviderProps {
|
15
|
+
/** Account used by the panel for signing */
|
16
|
+
account?: Account
|
16
17
|
/** @deprecated - panel no longer uses archive but relies on an archivist */
|
17
18
|
archive?: string
|
18
19
|
archivist?: PayloadArchivist
|
@@ -20,21 +21,13 @@ export interface PanelProviderProps {
|
|
20
21
|
witnesses?: WitnessWrapper[]
|
21
22
|
}
|
22
23
|
|
23
|
-
export const PanelProvider: React.FC<WithChildren<PanelProviderProps>> = ({
|
24
|
-
archivist: archivistProp,
|
25
|
-
children,
|
26
|
-
witnesses = [],
|
27
|
-
required = false,
|
28
|
-
}) => {
|
29
|
-
const { archivist } = useArchivist()
|
24
|
+
export const PanelProvider: React.FC<WithChildren<PanelProviderProps>> = ({ account, archivist, children, witnesses = [], required = false }) => {
|
30
25
|
const [panel, setPanel] = useState<XyoPanel>()
|
31
26
|
const [history, setHistory] = useState<XyoBoundWitness[]>()
|
32
27
|
const [progress, setProgress] = useState<PanelReportProgress>({})
|
33
28
|
const [status, setStatus] = useState(ReportStatus.Idle)
|
34
29
|
const [reportingErrors, setReportingErrors] = useState<Error[]>()
|
35
30
|
|
36
|
-
const { account } = useAccount()
|
37
|
-
|
38
31
|
const resolver = useMemo(() => {
|
39
32
|
const resolver = new SimpleModuleResolver().add(witnesses)
|
40
33
|
return archivist ? resolver.add(new ArchivistWrapper(archivist)) : resolver
|
@@ -43,60 +36,58 @@ export const PanelProvider: React.FC<WithChildren<PanelProviderProps>> = ({
|
|
43
36
|
useAsyncEffect(
|
44
37
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
45
38
|
async (mounted) => {
|
46
|
-
const
|
47
|
-
const
|
48
|
-
|
49
|
-
|
50
|
-
|
51
|
-
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
58
|
-
|
59
|
-
|
60
|
-
|
61
|
-
|
62
|
-
|
63
|
-
|
64
|
-
|
65
|
-
|
66
|
-
|
67
|
-
|
68
|
-
|
69
|
-
|
70
|
-
|
71
|
-
|
72
|
-
|
73
|
-
|
74
|
-
|
75
|
-
|
76
|
-
|
77
|
-
|
78
|
-
|
79
|
-
|
80
|
-
|
81
|
-
|
82
|
-
|
83
|
-
|
84
|
-
|
85
|
-
|
86
|
-
|
87
|
-
|
88
|
-
|
89
|
-
|
90
|
-
|
91
|
-
|
92
|
-
|
93
|
-
|
94
|
-
|
95
|
-
|
96
|
-
|
97
|
-
|
98
|
-
})
|
99
|
-
: undefined
|
39
|
+
const archivistWrapper = archivist ? new ArchivistWrapper(archivist) : undefined
|
40
|
+
const panel = await XyoPanel.create({
|
41
|
+
account,
|
42
|
+
config: {
|
43
|
+
archivists: [archivistWrapper?.address],
|
44
|
+
onReportEnd: (_, errors?: Error[]) => {
|
45
|
+
if (mounted()) {
|
46
|
+
setProgress({
|
47
|
+
archivists: progress.archivists,
|
48
|
+
witnesses: progress.witnesses,
|
49
|
+
})
|
50
|
+
setStatus(errors ? ReportStatus.Failed : ReportStatus.Succeeded)
|
51
|
+
setReportingErrors(errors)
|
52
|
+
}
|
53
|
+
},
|
54
|
+
onReportStart: () => {
|
55
|
+
if (mounted()) {
|
56
|
+
setProgress({ archivists: {}, witnesses: {} })
|
57
|
+
setStatus(ReportStatus.Started)
|
58
|
+
}
|
59
|
+
},
|
60
|
+
onWitnessReportEnd: (witness: WitnessWrapper, error?: Error) => {
|
61
|
+
const witnesses = progress.witnesses ?? {}
|
62
|
+
witnesses[witness.address] = {
|
63
|
+
status: error ? ReportStatus.Failed : ReportStatus.Succeeded,
|
64
|
+
witness,
|
65
|
+
}
|
66
|
+
if (mounted()) {
|
67
|
+
setProgress({
|
68
|
+
archivists: progress.archivists,
|
69
|
+
witnesses,
|
70
|
+
})
|
71
|
+
}
|
72
|
+
},
|
73
|
+
onWitnessReportStart: (witness: WitnessWrapper) => {
|
74
|
+
const witnesses = progress.witnesses ?? {}
|
75
|
+
witnesses[witness.address] = {
|
76
|
+
status: ReportStatus.Started,
|
77
|
+
witness,
|
78
|
+
}
|
79
|
+
if (mounted()) {
|
80
|
+
setProgress({
|
81
|
+
archivists: progress.archivists,
|
82
|
+
witnesses,
|
83
|
+
})
|
84
|
+
}
|
85
|
+
},
|
86
|
+
schema: XyoPanelConfigSchema,
|
87
|
+
witnesses: witnesses.map((witness) => witness.address),
|
88
|
+
} as XyoPanelConfig,
|
89
|
+
resolver,
|
90
|
+
})
|
100
91
|
setPanel(panel)
|
101
92
|
await delay(0)
|
102
93
|
},
|