@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.
@@ -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: archivistProp, children, witnesses = [], required = false, }) => {
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 activeArchivist = archivistProp ?? archivist;
28
- const archivistWrapper = activeArchivist ? new ArchivistWrapper(activeArchivist) : undefined;
29
- const panel = archivistWrapper
30
- ? await XyoPanel.create({
31
- config: {
32
- archivists: [archivistWrapper.address],
33
- onReportEnd: (_, errors) => {
34
- if (mounted()) {
35
- setProgress({
36
- archivists: progress.archivists,
37
- witnesses: progress.witnesses,
38
- });
39
- setStatus(errors ? ReportStatus.Failed : ReportStatus.Succeeded);
40
- setReportingErrors(errors);
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
- resolver,
79
- })
80
- : undefined;
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":"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"}
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;AAM3E,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAA;AAMrD,MAAM,WAAW,kBAAkB;IACjC,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,CA2FpE,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",
15
- "@xyo-network/archivist": "^2.43.24",
16
- "@xyo-network/boundwitness-model": "^2.43.24",
17
- "@xyo-network/module": "^2.43.24",
18
- "@xyo-network/panel": "^2.43.24",
19
- "@xyo-network/react-archivist": "^2.41.43",
20
- "@xyo-network/react-shared": "^2.41.43",
21
- "@xyo-network/react-wallet": "^2.41.43",
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.12.30"
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.43"
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 activeArchivist: PayloadArchivist | undefined = archivistProp ?? archivist
47
- const archivistWrapper = activeArchivist ? new ArchivistWrapper(activeArchivist) : undefined
48
- const panel = archivistWrapper
49
- ? await XyoPanel.create({
50
- config: {
51
- archivists: [archivistWrapper.address],
52
- onReportEnd: (_, errors?: Error[]) => {
53
- if (mounted()) {
54
- setProgress({
55
- archivists: progress.archivists,
56
- witnesses: progress.witnesses,
57
- })
58
- setStatus(errors ? ReportStatus.Failed : ReportStatus.Succeeded)
59
- setReportingErrors(errors)
60
- }
61
- },
62
- onReportStart: () => {
63
- if (mounted()) {
64
- setProgress({ archivists: {}, witnesses: {} })
65
- setStatus(ReportStatus.Started)
66
- }
67
- },
68
- onWitnessReportEnd: (witness: WitnessWrapper, error?: Error) => {
69
- const witnesses = progress.witnesses ?? {}
70
- witnesses[witness.address] = {
71
- status: error ? ReportStatus.Failed : ReportStatus.Succeeded,
72
- witness,
73
- }
74
- if (mounted()) {
75
- setProgress({
76
- archivists: progress.archivists,
77
- witnesses,
78
- })
79
- }
80
- },
81
- onWitnessReportStart: (witness: WitnessWrapper) => {
82
- const witnesses = progress.witnesses ?? {}
83
- witnesses[witness.address] = {
84
- status: ReportStatus.Started,
85
- witness,
86
- }
87
- if (mounted()) {
88
- setProgress({
89
- archivists: progress.archivists,
90
- witnesses,
91
- })
92
- }
93
- },
94
- schema: XyoPanelConfigSchema,
95
- witnesses: witnesses.map((witness) => witness.address),
96
- } as XyoPanelConfig,
97
- resolver,
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
  },