| | import sys |
| | import re |
| |
|
| | import streamlit as st |
| |
|
| | from vectara_agentic.agent import AgentStatusType |
| | from agent import initialize_agent |
| | from config import get_agent_config |
| |
|
| | initial_prompt = "How can I help you today?" |
| |
|
| |
|
| | def format_log_msg(log_msg: str): |
| | max_log_msg_size = 500 |
| | return log_msg if len(log_msg) <= max_log_msg_size else log_msg[:max_log_msg_size]+'...' |
| |
|
| | def agent_progress_callback(status_type: AgentStatusType, msg: str): |
| | output = f'<span style="color:blue;">{status_type.value}</span>: {msg}' |
| | st.session_state.log_messages.append(output) |
| | if 'status' in st.session_state: |
| | latest_message = '' |
| | if status_type == AgentStatusType.TOOL_CALL: |
| | match = re.search(r"'([^']*)'", msg) |
| | tool_name = match.group(1) if match else "Unknown tool" |
| | latest_message = f"Calling tool {tool_name}..." |
| | elif status_type == AgentStatusType.TOOL_OUTPUT: |
| | latest_message = "Analyzing tool output..." |
| | else: |
| | return |
| | |
| | st.session_state.status.update(label=latest_message) |
| | |
| | with st.session_state.status: |
| | for log_msg in st.session_state.log_messages: |
| | st.markdown(format_log_msg(log_msg), unsafe_allow_html=True) |
| |
|
| | @st.dialog(title="Agent logs", width='large') |
| | def show_modal(): |
| | for log_msg in st.session_state.log_messages: |
| | st.markdown(format_log_msg(log_msg), unsafe_allow_html=True) |
| |
|
| | async def launch_bot(): |
| | def reset(): |
| | st.session_state.messages = [{"role": "assistant", "content": initial_prompt, "avatar": "π¦"}] |
| | st.session_state.log_messages = [] |
| | st.session_state.prompt = None |
| | st.session_state.ex_prompt = None |
| | st.session_state.first_turn = True |
| | st.session_state.show_logs = False |
| | if 'agent' not in st.session_state: |
| | st.session_state.agent = initialize_agent(cfg, agent_progress_callback=agent_progress_callback) |
| | else: |
| | st.session_state.agent.clear_memory() |
| |
|
| | if 'cfg' not in st.session_state: |
| | cfg = get_agent_config() |
| | st.session_state.cfg = cfg |
| | st.session_state.ex_prompt = None |
| | reset() |
| |
|
| | cfg = st.session_state.cfg |
| | print(f'Configuration: {cfg}') |
| |
|
| | |
| |
|
| | |
| | for message in st.session_state.messages: |
| | print(f'Message: {message}') |
| | with st.chat_message(message["role"], avatar=message["avatar"]): |
| | st.write(message["content"]) |
| |
|
| |
|
| | |
| | if st.session_state.ex_prompt: |
| | prompt = st.session_state.ex_prompt |
| | else: |
| | prompt = st.chat_input() |
| | if prompt: |
| | st.session_state.messages.append({"role": "user", "content": prompt, "avatar": 'π§βπ»'}) |
| | st.session_state.prompt = prompt |
| | st.session_state.log_messages = [] |
| | st.session_state.show_logs = False |
| | with st.chat_message("user", avatar='π§βπ»'): |
| | print(f"Starting new question: {prompt}\n") |
| | st.write(prompt) |
| | st.session_state.ex_prompt = None |
| | |
| | |
| | if st.session_state.prompt: |
| | with st.chat_message("assistant", avatar='π€'): |
| | st.session_state.status = st.status('Processing...', expanded=False) |
| | res = st.session_state.agent.chat(st.session_state.prompt) |
| | |
| | res = str(res) |
| | message = {"role": "assistant", "content": res, "avatar": 'π€'} |
| | st.session_state.messages.append(message) |
| | st.markdown(res) |
| |
|
| |
|
| | st.session_state.ex_prompt = None |
| | st.session_state.prompt = None |
| | st.session_state.first_turn = False |
| | st.rerun() |
| |
|
| | sys.stdout.flush() |