diff --git a/src/core/routes/test.py b/src/core/routes/test.py index de5cd01..c92c6bc 100644 --- a/src/core/routes/test.py +++ b/src/core/routes/test.py @@ -1,4 +1,4 @@ -from typing import List +from typing import List, Dict from fastapi import APIRouter, HTTPException from pydantic import BaseModel import uuid @@ -36,6 +36,18 @@ def get_hyperledger_fabric_answer(question): return responses.get(question, "Question not found in the database.") +@router.get("/response-keys", response_model=List[Dict[str, str]]) +def get_response_keys() -> List[Dict[str, str]]: + """ + Returns a list of dictionaries containing 'id' and 'name' for each key in the responses dictionary. + """ + res = [ + {"id": str(index + 1), "name": key} + for index, key in enumerate(responses.keys()) + ] + return res + + # TODO: Get all chats for a user in a paginated format @router.post("/conversations") def get_conversations( diff --git a/src/frontend/components/chat-page.tsx b/src/frontend/components/chat-page.tsx index bdbfe7b..5f0fb61 100644 --- a/src/frontend/components/chat-page.tsx +++ b/src/frontend/components/chat-page.tsx @@ -3,6 +3,8 @@ import React, { useState } from 'react'; import ChatHeader from './chat-header'; import { Message } from '@/lib/types'; +import { Suspense } from 'react'; +import WelcomeSection from './welcome-section'; import ChatBottomBar from './chat-bottom-bar'; import ChatSection from './chat-section'; @@ -23,11 +25,18 @@ const ChatPage = (props: Props) => { }; return ( -
+
+ + {messages.length === 0 && ( + Loading....

}> + +
+ )}
+
); diff --git a/src/frontend/components/welcome-section.tsx b/src/frontend/components/welcome-section.tsx index 07be1c2..f488df7 100644 --- a/src/frontend/components/welcome-section.tsx +++ b/src/frontend/components/welcome-section.tsx @@ -1,13 +1,59 @@ -import React from 'react'; +'use-client'; +import React, { + useState, + useEffect +} from 'react'; import { IconHyperledger } from './icons/IconHyperledger'; +import { SERVER_BASE_URL } from '@/lib/const'; +import { Suspense } from 'react'; type Props = {}; +interface Message { + id: string; + name: string; +} + const WelcomeSection = (props: Props) => { + const [messages, setMessages] = useState< + Message[] + >([]); + + useEffect(() => { + async function fetchData() { + const response = await fetch( + SERVER_BASE_URL + '/response-keys' + ); + const data = await response.json(); + setMessages(data); + } + + fetchData(); + }, []); + return ( -
- -
+ <> +
+ +
+ + Loading....

}> +
+ {messages.map((user: Message) => ( +
  • +
    +

    + {user.name} +

    +
    +
  • + ))} +
    +
    + ); };