Merge pull request #258 from waku-org/chore/refactor

chore(web-chat): cleanup refactor
This commit is contained in:
Danish Arora 2023-08-03 13:42:33 +05:30 committed by GitHub
commit a636462c2b
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 78 additions and 67 deletions

View File

@ -1,11 +1,8 @@
import { useEffect, useRef } from "react"; import { useEffect, useRef } from "react";
import { Message } from "./Message"; import { Message } from "./Message";
import type { ChatListProps } from "./types";
interface Props { export default function ChatList(props: ChatListProps) {
messages: Message[];
}
export default function ChatList(props: Props) {
const renderedMessages = props.messages.map((message) => ( const renderedMessages = props.messages.map((message) => (
<div <div
key={ key={

View File

@ -1,13 +1,9 @@
import { ChangeEvent, KeyboardEvent, useEffect, useState } from "react"; import { ChangeEvent, KeyboardEvent, useEffect, useState } from "react";
import { useWaku } from "@waku/react"; import { useWaku } from "@waku/react";
import { LightNode } from "@waku/interfaces"; import { LightNode } from "@waku/interfaces";
import { MessageInputProps } from "./types";
interface Props { export default function MessageInput(props: MessageInputProps) {
hasLightPushPeers: boolean;
sendMessage: ((msg: string) => Promise<void>) | undefined;
}
export default function MessageInput(props: Props) {
const { hasLightPushPeers } = props; const { hasLightPushPeers } = props;
const { node } = useWaku<LightNode>(); const { node } = useWaku<LightNode>();

View File

@ -2,17 +2,11 @@ import type { LightNode } from "@waku/interfaces";
import ChatList from "./ChatList"; import ChatList from "./ChatList";
import MessageInput from "./MessageInput"; import MessageInput from "./MessageInput";
import { useWaku, useContentPair, useLightPush } from "@waku/react"; import { useWaku, useContentPair, useLightPush } from "@waku/react";
import { Message } from "./Message";
import { ChatMessage } from "./chat_message"; import { ChatMessage } from "./chat_message";
import { useNodePeers, usePeers } from "./hooks"; import { useNodePeers, usePeers } from "./hooks";
import type { RoomProps } from "./types";
interface Props { export default function Room(props: RoomProps) {
messages: Message[];
commandHandler: (cmd: string) => void;
nick: string;
}
export default function Room(props: Props) {
const { node } = useWaku<LightNode>(); const { node } = useWaku<LightNode>();
const { encoder } = useContentPair(); const { encoder } = useContentPair();
const { push: onPush } = useLightPush({ node, encoder }); const { push: onPush } = useLightPush({ node, encoder });

View File

@ -1,9 +1 @@
import { Protocols } from "@waku/interfaces";
export const CONTENT_TOPIC = "/toy-chat/2/huilong/proto"; export const CONTENT_TOPIC = "/toy-chat/2/huilong/proto";
export const PROTOCOLS = [
Protocols.Filter,
Protocols.Store,
Protocols.LightPush,
];

View File

@ -1,18 +1,17 @@
import React, { useEffect, useState } from "react"; import React, { useEffect, useState } from "react";
import { generate } from "server-name-generator"; import { generate } from "server-name-generator";
import { Message } from "./Message"; import { Message } from "./Message";
import { EPeersByDiscoveryEvents, LightNode, Tags } from "@waku/interfaces";
import type { PeerId } from "@libp2p/interface-peer-id"; import type { PeerId } from "@libp2p/interface-peer-id";
import type { Peer } from "@libp2p/interface-peer-store";
import {
EPeersByDiscoveryEvents,
LightNode,
StoreQueryOptions,
Waku,
Tags,
} from "@waku/interfaces";
import type { waku } from "@waku/sdk";
import { useFilterMessages, useStoreMessages } from "@waku/react"; import { useFilterMessages, useStoreMessages } from "@waku/react";
import type {
UseMessagesParams,
UseMessagesResult,
UsePeersParams,
UsePeersResults,
} from "./types";
import { handleCatch } from "./utils";
export const usePersistentNick = (): [ export const usePersistentNick = (): [
string, string,
@ -29,14 +28,6 @@ export const usePersistentNick = (): [
return [nick, setNick]; return [nick, setNick];
}; };
type UseMessagesParams = {
node: undefined | LightNode;
decoder: undefined | waku.Decoder;
options: StoreQueryOptions;
};
type UseMessagesResult = [Message[], (v: Message[]) => void];
export const useMessages = (params: UseMessagesParams): UseMessagesResult => { export const useMessages = (params: UseMessagesParams): UseMessagesResult => {
const { messages: newMessages } = useFilterMessages(params); const { messages: newMessages } = useFilterMessages(params);
const { messages: storedMessages } = useStoreMessages(params); const { messages: storedMessages } = useStoreMessages(params);
@ -163,17 +154,6 @@ export const useNodePeers = (node: undefined | LightNode) => {
}; };
}; };
type UsePeersParams = {
node: undefined | Waku;
};
type UsePeersResults = {
allConnected?: PeerId[];
storePeers?: PeerId[];
filterPeers?: PeerId[];
lightPushPeers?: PeerId[];
};
/** /**
* Hook returns map of peers for different protocols. * Hook returns map of peers for different protocols.
* If protocol is not implemented on the node peers are undefined. * If protocol is not implemented on the node peers are undefined.
@ -216,13 +196,3 @@ export const usePeers = (params: UsePeersParams): UsePeersResults => {
return peers; return peers;
}; };
function handleCatch(promise?: Promise<Peer[]>): Promise<Peer[] | undefined> {
if (!promise) {
return Promise.resolve(undefined);
}
return promise.catch((_) => {
return undefined;
});
}

View File

@ -6,7 +6,8 @@ import { wakuPeerExchangeDiscovery } from "@waku/peer-exchange";
import "./index.css"; import "./index.css";
import App from "./App"; import App from "./App";
import { CONTENT_TOPIC, PROTOCOLS } from "./config"; import { CONTENT_TOPIC } from "./config";
import { Protocols } from "@waku/interfaces";
const NODE_OPTIONS = { const NODE_OPTIONS = {
libp2p: { libp2p: {
@ -23,7 +24,15 @@ const NODE_OPTIONS = {
ReactDOM.render( ReactDOM.render(
<React.StrictMode> <React.StrictMode>
<LightNodeProvider options={NODE_OPTIONS} protocols={PROTOCOLS}> <LightNodeProvider
options={NODE_OPTIONS}
protocols={[
Protocols.Relay,
Protocols.Store,
Protocols.Filter,
Protocols.LightPush,
]}
>
<ContentPairProvider contentTopic={CONTENT_TOPIC}> <ContentPairProvider contentTopic={CONTENT_TOPIC}>
<App /> <App />
</ContentPairProvider> </ContentPairProvider>

View File

@ -0,0 +1,38 @@
import type { PeerId } from "@libp2p/interface-peer-id";
import type { LightNode, StoreQueryOptions, Waku } from "@waku/interfaces";
import type { Decoder } from "@waku/sdk";
import type { Message } from "./Message";
export type UsePeersParams = {
node: undefined | Waku;
};
export type UsePeersResults = {
allConnected?: PeerId[];
storePeers?: PeerId[];
filterPeers?: PeerId[];
lightPushPeers?: PeerId[];
};
export type UseMessagesParams = {
node: undefined | LightNode;
decoder: undefined | Decoder;
options: StoreQueryOptions;
};
export type UseMessagesResult = [Message[], (v: Message[]) => void];
export interface ChatListProps {
messages: Message[];
}
export interface MessageInputProps {
hasLightPushPeers: boolean;
sendMessage: ((msg: string) => Promise<void>) | undefined;
}
export interface RoomProps {
messages: Message[];
commandHandler: (cmd: string) => void;
nick: string;
}

View File

@ -0,0 +1,15 @@
import type { Peer } from "@libp2p/interface-peer-store";
export async function handleCatch(
promise?: Promise<Peer[]>
): Promise<Peer[] | undefined> {
if (!promise) {
return Promise.resolve(undefined);
}
try {
return await promise;
} catch (_) {
return undefined;
}
}