From a046fc7444947e1d58792d1da76f809c421f7c23 Mon Sep 17 00:00:00 2001 From: sofvanh <23138848+sofvanh@users.noreply.github.com> Date: Wed, 8 Jan 2025 15:27:46 +1300 Subject: [PATCH] Elegant handling of 'create graph' --- backend/src/index.ts | 5 +++-- backend/src/websocket/graph/createGraph.ts | 25 ++++++++++++++++++++++ backend/src/websocket/graphHandler.ts | 17 +-------------- frontend/src/views/HomeView.tsx | 21 +++++++----------- 4 files changed, 37 insertions(+), 31 deletions(-) create mode 100644 backend/src/websocket/graph/createGraph.ts diff --git a/backend/src/index.ts b/backend/src/index.ts index 8339be7..eaeab37 100644 --- a/backend/src/index.ts +++ b/backend/src/index.ts @@ -4,11 +4,12 @@ import { Server } from 'socket.io'; import config from './config'; import { handleAuthenticate } from './websocket/auth/authenticate'; import { handleLogout } from './websocket/auth/logout'; -import { handleCreateGraph, handleJoinGraph, handleLeaveGraph } from './websocket/graphHandler'; +import { handleJoinGraph, handleLeaveGraph } from './websocket/graphHandler'; import { handleAddArgument } from './websocket/argumentHandler'; import { handleAddReaction, handleRemoveReaction } from './websocket/reactionHandler'; import { SocketHandler, SocketResponse } from './backendTypes'; import { handleGetGraphs } from './websocket/graph/getGraphs'; +import { handleCreateGraph } from './websocket/graph/createGraph'; const app = express(); const server = http.createServer(app); @@ -56,8 +57,8 @@ io.on('connection', (socket) => { socket.on('authenticate', wrapHandler(handleAuthenticate)); socket.on('logout', wrapHandler(handleLogout)); socket.on('get graphs', wrapHandler(handleGetGraphs)); + socket.on('create graph', wrapHandler(handleCreateGraph)); // TODO Finish transition - socket.on('create graph', (name, callback) => handleCreateGraph(socket, name, callback)); socket.on('join graph', (graphId: string) => handleJoinGraph(socket, graphId)); socket.on('leave graph', (graphId: string) => handleLeaveGraph(socket, graphId)); socket.on('add argument', (args, callback) => handleAddArgument(socket, io, args, callback)); diff --git a/backend/src/websocket/graph/createGraph.ts b/backend/src/websocket/graph/createGraph.ts new file mode 100644 index 0000000..1b7e79d --- /dev/null +++ b/backend/src/websocket/graph/createGraph.ts @@ -0,0 +1,25 @@ +import { SocketHandler } from "../../backendTypes"; +import { createGraph } from "../../db/operations/graphOperations"; + +interface CreateGraphData { + name: string; +} + +interface CreateGraphResponse { + id: string; +} + +export const handleCreateGraph: SocketHandler = async (socket, io, { name }) => { + if (!socket.data.user) { + return { + success: false, + error: 'Authentication required' + } + } + + const graphId = await createGraph(name, socket.data.user.id); + return { + success: true, + data: { id: graphId } + } +} \ No newline at end of file diff --git a/backend/src/websocket/graphHandler.ts b/backend/src/websocket/graphHandler.ts index 400c03f..0b8a038 100644 --- a/backend/src/websocket/graphHandler.ts +++ b/backend/src/websocket/graphHandler.ts @@ -1,20 +1,5 @@ import { Socket } from 'socket.io'; -import { createGraph, getGraphs, getGraphDataWithUserReactions } from '../db/operations/graphOperations'; - -export const handleCreateGraph = async (socket: Socket, name: string, callback?: Function) => { - if (!socket.data.user) { - callback?.({ success: false, error: 'Authentication required' }); - return; - } - - try { - const graphId = await createGraph(name, socket.data.user.id); - callback?.({ success: true, id: graphId }); - } catch (error) { - console.error('Error creating graph:', error); - callback?.({ success: false, error: 'Failed to create graph' }); - } -}; +import { getGraphDataWithUserReactions } from '../db/operations/graphOperations'; export const handleJoinGraph = async (socket: Socket, graphId: string) => { console.log(`Socket ${socket.id} joining graph ${graphId}, user: ${socket.data.user?.id}`); diff --git a/frontend/src/views/HomeView.tsx b/frontend/src/views/HomeView.tsx index 773d012..eabb5fd 100644 --- a/frontend/src/views/HomeView.tsx +++ b/frontend/src/views/HomeView.tsx @@ -18,22 +18,17 @@ const HomeView: React.FC = () => { const handleCreateGraph = (e: React.FormEvent) => { e.preventDefault(); if (graphName.trim() && socket) { - console.log('Sending create graph event'); - socket.emit('create graph', graphName); - setGraphName(''); + socket.emit('create graph', { name: graphName }, (response: any) => { + if (response.success) { + navigate(`/graph/${response.data.id}`); + } else { + console.error('Failed to create graph:', response.error); + setError(response.error); + } + }); } }; - React.useEffect(() => { - socket?.on('graph created', ({ id }) => navigate(`/graph/${id}`)); - socket?.on('graph creation error', ({ message }) => setError(message)); - - return () => { - socket?.off('graph created'); - socket?.off('graph creation error'); - }; - }, [socket, navigate]); - return (

Welcome to MindMeld