|
import streamlit as st
|
|
import logging
|
|
from .semantic_process import process_semantic_analysis
|
|
from ..chatbot.chatbot import initialize_chatbot, process_semantic_chat_input
|
|
from ..database.database_oldFromV2 import store_file_semantic_contents, retrieve_file_contents, delete_file, get_user_files
|
|
from ..utils.widget_utils import generate_unique_key
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
def get_translation(t, key, default):
|
|
return t.get(key, default)
|
|
|
|
def display_semantic_interface(lang_code, nlp_models, t):
|
|
|
|
if 'semantic_chatbot' not in st.session_state:
|
|
st.session_state.semantic_chatbot = initialize_chatbot('semantic')
|
|
|
|
st.markdown("""
|
|
<style>
|
|
.semantic-initial-message {
|
|
background-color: #f0f2f6;
|
|
border-left: 5px solid #4CAF50;
|
|
padding: 10px;
|
|
border-radius: 5px;
|
|
font-size: 16px;
|
|
margin-bottom: 20px;
|
|
}
|
|
.stButton > button {
|
|
width: 100%;
|
|
height: 3em;
|
|
}
|
|
.chat-container {
|
|
height: 400px;
|
|
overflow-y: auto;
|
|
border: 1px solid #ddd;
|
|
padding: 10px;
|
|
border-radius: 5px;
|
|
}
|
|
.file-management-container {
|
|
position: sticky;
|
|
top: 0;
|
|
z-index: 999;
|
|
background-color: white;
|
|
padding: 10px;
|
|
border-bottom: 1px solid #ddd;
|
|
display: flex;
|
|
justify-content: space-between;
|
|
align-items: flex-start;
|
|
margin-bottom: 20px;
|
|
}
|
|
.file-management-item {
|
|
flex: 1;
|
|
margin: 0 5px;
|
|
}
|
|
.stButton > button {
|
|
width: 100%;
|
|
height: 3em;
|
|
}
|
|
.stSelectbox {
|
|
margin-top: -5px;
|
|
}
|
|
</style>
|
|
""", unsafe_allow_html=True)
|
|
|
|
st.markdown(f"""
|
|
<div class="semantic-initial-message">
|
|
{get_translation(t, 'semantic_initial_message', 'Welcome to the semantic analysis interface.')}
|
|
</div>
|
|
""", unsafe_allow_html=True)
|
|
|
|
|
|
st.markdown('<div class="file-management-container">', unsafe_allow_html=True)
|
|
col1, col2, col3, col4 = st.columns(4)
|
|
|
|
with col1:
|
|
if st.button("Upload File", key=generate_unique_key('semantic', 'upload_button')):
|
|
st.session_state.show_uploader = True
|
|
|
|
with col2:
|
|
user_files = get_user_files(st.session_state.username, 'semantic')
|
|
file_options = [get_translation(t, 'select_saved_file', 'Select a saved file')] + [file['file_name'] for file in user_files]
|
|
selected_file = st.selectbox("", options=file_options, key=generate_unique_key('semantic', 'file_selector'))
|
|
|
|
with col3:
|
|
analyze_button = st.button("Analyze Document", key=generate_unique_key('semantic', 'analyze_document'))
|
|
|
|
with col4:
|
|
delete_button = st.button("Delete File", key=generate_unique_key('semantic', 'delete_file'))
|
|
|
|
st.markdown('</div>', unsafe_allow_html=True)
|
|
|
|
|
|
if st.session_state.get('show_uploader', False):
|
|
uploaded_file = st.file_uploader("Choose a file", type=['txt', 'pdf', 'docx', 'doc', 'odt'], key=generate_unique_key('semantic', 'file_uploader'))
|
|
if uploaded_file is not None:
|
|
file_contents = uploaded_file.getvalue().decode('utf-8')
|
|
if store_file_semantic_contents(st.session_state.username, uploaded_file.name, file_contents):
|
|
st.session_state.file_contents = file_contents
|
|
st.success(get_translation(t, 'file_uploaded_success', 'File uploaded and saved successfully'))
|
|
st.session_state.show_uploader = False
|
|
else:
|
|
st.error(get_translation(t, 'file_upload_error', 'Error uploading file'))
|
|
|
|
|
|
|
|
st.markdown('<div class="analysis-container">', unsafe_allow_html=True)
|
|
col_chat, col_graph = st.columns([1, 1])
|
|
|
|
with col_chat:
|
|
st.subheader(get_translation(t, 'chat_title', 'Semantic Analysis Chat'))
|
|
chat_container = st.container()
|
|
|
|
with chat_container:
|
|
chat_history = st.session_state.get('semantic_chat_history', [])
|
|
for message in chat_history:
|
|
with st.chat_message(message["role"]):
|
|
st.write(message["content"])
|
|
|
|
user_input = st.chat_input(get_translation(t, 'semantic_chat_input', 'Type your message here...'), key=generate_unique_key('semantic', 'chat_input'))
|
|
|
|
if user_input:
|
|
chat_history.append({"role": "user", "content": user_input})
|
|
|
|
if user_input.startswith('/analyze_current'):
|
|
response = process_semantic_chat_input(user_input, lang_code, nlp_models[lang_code], st.session_state.get('file_contents', ''))
|
|
else:
|
|
response = st.session_state.semantic_chatbot.generate_response(user_input, lang_code)
|
|
|
|
chat_history.append({"role": "assistant", "content": response})
|
|
st.session_state.semantic_chat_history = chat_history
|
|
|
|
with col_graph:
|
|
st.subheader(get_translation(t, 'graph_title', 'Semantic Graphs'))
|
|
|
|
|
|
if 'key_concepts' in st.session_state:
|
|
st.write(get_translation(t, 'key_concepts_title', 'Key Concepts'))
|
|
st.markdown('<div class="horizontal-list">', unsafe_allow_html=True)
|
|
for concept, freq in st.session_state.key_concepts:
|
|
st.markdown(f'<span style="margin-right: 10px;">{concept}: {freq:.2f}</span>', unsafe_allow_html=True)
|
|
st.markdown('</div>', unsafe_allow_html=True)
|
|
|
|
if 'entities' in st.session_state:
|
|
st.write(get_translation(t, 'entities_title', 'Entities'))
|
|
st.markdown('<div class="horizontal-list">', unsafe_allow_html=True)
|
|
for entity, type in st.session_state.entities.items():
|
|
st.markdown(f'<span style="margin-right: 10px;">{entity}: {type}</span>', unsafe_allow_html=True)
|
|
st.markdown('</div>', unsafe_allow_html=True)
|
|
|
|
|
|
tab1, tab2 = st.tabs(["Concept Graph", "Entity Graph"])
|
|
|
|
with tab1:
|
|
if 'concept_graph' in st.session_state:
|
|
st.pyplot(st.session_state.concept_graph)
|
|
|
|
with tab2:
|
|
if 'entity_graph' in st.session_state:
|
|
st.pyplot(st.session_state.entity_graph)
|
|
|
|
st.markdown('</div>', unsafe_allow_html=True)
|
|
|
|
if st.button(get_translation(t, 'clear_chat', 'Clear chat'), key=generate_unique_key('semantic', 'clear_chat')):
|
|
st.session_state.semantic_chat_history = []
|
|
st.rerun() |