Logo

dev-resources.site

for different kinds of informations.

Building Talk-to-Page: Chat or Talk with Any Website

Published at
1/6/2025
Categories
coagents
copilotkit
nextjs
langchain
Author
komsenapati
Author
11 person written this
komsenapati
open
Building Talk-to-Page: Chat or Talk with Any Website

Ever thought of chatting with a webpage or literally talking to it? Well, I built an app that does just that! Itā€™s called Talk-to-Page. You simply input a URL, and you can start a conversation with the page.

Hereā€™s a quick demo of how it works:


Why Did I Build This?

Chatbots are cool, but theyā€™re not perfect. Most donā€™t understand the specific details of a web page. If you build a chatbot with Retrieval Augmented Generation (RAG), it often feels limited. You set it up for one page, and itā€™s stuck with that static content.

So, I thought: Why not make it dynamic?

What if you could give the chatbot any URL and let it adapt on the go?

Thatā€™s how Talk-to-Page was born!


How It Came Together

I used my coagents-starter kit as the foundation. Itā€™s a setup I built for creating full-stack apps with AI agents using LangGraph and CopilotKit.

Hereā€™s the starter kit, in case you want to check it out:

GitHub logo kom-senapati / coagents-starter

šŸ¤– Starter kit for building agentic full-stack apps

CoAgents Starter

This example contains a simple starter project.

These instructions assume you are in the coagents-starter/ directory

Running the Agent

First, install the dependencies:

cd agent
poetry install
Enter fullscreen mode Exit fullscreen mode

Then, create a .env file inside ./agent with the following:

GROQ_API_KEY=...

IMPORTANT: Make sure the OpenAI API Key you provide, supports gpt-4o.

Then, run the demo:

poetry run demo
Enter fullscreen mode Exit fullscreen mode

Running the UI

First, install the dependencies:

cd ./ui
pnpm i
Enter fullscreen mode Exit fullscreen mode

Then, create a .env file inside ./ui with the following:

GROQ_API_KEY=...

Then, run the Next.js project:

pnpm run dev
Enter fullscreen mode Exit fullscreen mode

Usage

Navigate to http://localhost:3000.

LangGraph Studio

Run LangGraph studio, then load the ./agent folder into it.

Make sure to create teh .env mentioned above first!

Troubleshooting

A few things to try if you are running into trouble:

  1. Make sure there is no other local application server running on the 8000 port.
  2. Under /agent/my_agent/demo.py, change 0.0.0.0 to 127.0.0.1 or to localhost

The backend uses FastAPI for deploying the LangGraph agent, while the frontend is built with Next.js.


Building the Agent

The first step was to create the agent. I followed a modular approach, breaking it into smaller parts like state, nodes, and edges. You can see the folder structure here:

Agent Code

I renamed my_agent to rag_agent. This meant updating the name everywhereā€”folders, files (like demo.py), and config (like langgraph.json and pyproject.toml).

Url Updating stuff:

  • Node: I added a new node called update_url that updates the agentā€™s retriever whenever the URL changes.
  • Edge: Created an edge called new_url that listens for a "URL UPDATED" message and triggers the update_url node to update the retriever.

Except that it's a self-RAG agent. You can check out its tutorial and code here.

Hereā€™s what the final agent graph looks like:

graph-img


Building the UI

The UI was fairly straightforward, but I wanted to make it interesting. Instead of using CopilotKitā€™s built-in copilot, I built a custom chat-bot interface.

You can find the code here:

Custom Chat Interface

For backgrounds, I added a retro grid background using Magic UIā€™s Retro Grid. I also implemented a Matrix Rain background using v0.dev which remained active for 5s when the URL was updated.

Voice Interaction:

For a better experience than that of a normal chatbot, I added the following:

  • Speech-to-text for user input.
  • Text-to-speech for AI responses.

So now, you can literally talk to a webpage. Cool, right? šŸ˜‰


Getting It All Working

The starter kit comes pre-configured with Tailwind CSS, Shadcn, and CopilotKit. For the agent to work, I just updated the agent name in ui/app/layout.tsx.


My Experience

Building this app was a fun and rewarding experience. Learning LangGraph and LangChain took some time, but the CopilotKit integration was surprisingly smooth.

Big thanks to the CopilotKit documentation for making things easy to follow!


Thatā€™s how I built Talk-to-Page!

What do you think about this project? Would you build something similar? Let me know!

Have a great day! Till next time!

If you loved this, please star CopilotKit and talk-to-page :)

Star CopilotKit ā­

Star talk-to-page šŸ¤

Follow me for more content like this!

langchain Article's
30 articles in total
Favicon
Get More Done with LangChainā€™s AI Email Assistant (EAIA)
Favicon
[Boost]
Favicon
Unlocking AI-Powered Conversations: Building a Retrieval-Augmented Generation (RAG) Chatbot
Favicon
AI Innovations to Watch in 2024: Transforming Everyday Life
Favicon
Calling LangChain from Go (Part 1)
Favicon
LangChain vs. LangGraph
Favicon
Mastering Real-Time AI: A Developerā€™s Guide to Building Streaming LLMs with FastAPI and Transformers
Favicon
Integrating LangChain with FastAPI for Asynchronous Streaming
Favicon
AI Agents + LangGraph: The Winning Formula for Sales Outreach Automation
Favicon
Building Talk-to-Page: Chat or Talk with Any Website
Favicon
AI Agents: The Future of Intelligent Automation
Favicon
Boost Customer Support: AI Agents, LangGraph, and RAG for Email Automation
Favicon
Using LangChain to Search Your Own PDF Documents
Favicon
Lang Everything: The Missing Guide to LangChain's Ecosystem
Favicon
How to make an AI agent with OpenAI, Langgraph, and MongoDB šŸ’”āœØ
Favicon
Novita AI API Key with LangChain
Favicon
7 Cutting-Edge AI Frameworks Every Developer Should Master in 2024
Favicon
My 2025 AI Engineer Roadmap List
Favicon
AI Agents Architecture, Actors and Microservices: Let's Try LangGraph Command
Favicon
How to integrate pgvector's Docker image with Langchain?
Favicon
A Practical Guide to Reducing LLM Hallucinations with Sandboxed Code Interpreter
Favicon
LangGraph with LLM and Pinecone Integration. What is LangGraph
Favicon
Choosing a Vector Store for LangChain
Favicon
Roadmap for Gen AI dev in 2025
Favicon
AI-Powered Graph Exploration with LangChain's NLP Capabilities, Question Answer Using Langchain
Favicon
Potenciando Aplicaciones de IA con AWS Bedrock y Streamlit
Favicon
How Spring Boot and LangChain4J Enable Powerful Retrieval-Augmented Generation (RAG)
Favicon
Get Started with LangChain: A Step-by-Step Tutorial for Beginners
Favicon
Building RAG-Powered Applications with LangChain, Pinecone, and OpenAI
Favicon
What is Chunk Size and Chunk Overlap

Featured ones: