@peerbit/react 0.0.26 → 0.0.28

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.
@@ -14,13 +14,16 @@ const addressOrDefined = <A, B extends ProgramEvents, P extends Program<A, B>>(
14
14
  type ExtractArgs<T> = T extends Program<infer Args> ? Args : never;
15
15
  type ExtractEvents<T> = T extends Program<any, infer Events> ? Events : never;
16
16
 
17
- export const useProgram = <
17
+ export function useProgram<
18
18
  P extends Program<ExtractArgs<P>, ExtractEvents<P>> &
19
19
  Program<any, ProgramEvents>
20
20
  >(
21
21
  addressOrOpen?: P | string,
22
- options?: OpenOptions<P> & { id?: string; keepOpenOnUnmount?: boolean }
23
- ) => {
22
+ options?: OpenOptions<P> & {
23
+ id?: string;
24
+ keepOpenOnUnmount?: boolean;
25
+ }
26
+ ) {
24
27
  const { peer } = usePeer();
25
28
  let [program, setProgram] = useState<P | undefined>();
26
29
  const [id, setId] = useState<string | undefined>(options?.id);
@@ -42,12 +45,15 @@ export const useProgram = <
42
45
 
43
46
  closingRef.current.then(() => {
44
47
  programLoadingRef.current = peer
45
- ?.open(addressOrOpen, { ...options, existing: "reuse" })
46
- .then((p) => {
48
+ ?.open(addressOrOpen as P | string, {
49
+ ...options,
50
+ existing: "reuse",
51
+ })
52
+ .then((p: P) => {
47
53
  // if program has topics do change listening on peers
48
54
  if (
49
55
  [p, ...p.allPrograms].filter(
50
- (x) =>
56
+ (x: any) =>
51
57
  x.closed === false &&
52
58
  x.getTopics &&
53
59
  x.getTopics?.().length > 0
@@ -56,17 +62,19 @@ export const useProgram = <
56
62
  setPeers([peer.identity.publicKey]);
57
63
  } else {
58
64
  changeListener = () => {
59
- p.getReady().then((set) => {
60
- setPeers([...set.values()]);
61
- });
65
+ p.getReady().then(
66
+ (ready: Map<string, PublicSignKey>) => {
67
+ setPeers([...ready.values()]);
68
+ }
69
+ );
62
70
  };
63
71
  p.events.addEventListener("join", changeListener);
64
72
  p.events.addEventListener("leave", changeListener);
65
73
  p.getReady()
66
- .then((set) => {
67
- setPeers([...set.values()]);
74
+ .then((ready: Map<string, PublicSignKey>) => {
75
+ setPeers([...ready.values()]);
68
76
  })
69
- .catch((e) => {
77
+ .catch((e: any) => {
70
78
  console.log("Error getReady()", e);
71
79
  });
72
80
  }
@@ -78,7 +86,7 @@ export const useProgram = <
78
86
  }
79
87
  return p;
80
88
  })
81
- .catch((e) => {
89
+ .catch((e: unknown) => {
82
90
  console.error("failed to open", e);
83
91
  throw e;
84
92
  })
@@ -110,7 +118,7 @@ export const useProgram = <
110
118
 
111
119
  if (programLoadingRef.current === startRef) {
112
120
  setProgram(undefined);
113
- programLoadingRef.current = undefined;
121
+ programLoadingRef.current = undefined as any;
114
122
  }
115
123
 
116
124
  if (options?.keepOpenOnUnmount) {
@@ -127,7 +135,7 @@ export const useProgram = <
127
135
  options?.id,
128
136
  typeof addressOrOpen === "string"
129
137
  ? addressOrOpen
130
- : addressOrDefined(addressOrOpen),
138
+ : addressOrDefined(addressOrOpen as P),
131
139
  ]);
132
140
  return {
133
141
  program,
@@ -137,4 +145,4 @@ export const useProgram = <
137
145
  peers,
138
146
  id,
139
147
  };
140
- };
148
+ }