File size: 1,954 Bytes
a576a00
 
 
 
 
e283888
a576a00
 
 
56d29f4
e283888
 
a576a00
 
 
e283888
 
b797bbf
e283888
 
 
 
 
 
 
 
 
 
 
 
 
 
 
76ff797
e283888
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59

from annotated_text import annotation
from json import JSONDecodeError
import logging
from markdown import markdown
import requests

import streamlit as st

from utils.haystack import query, start_haystack
from utils.ui import reset_results, set_initial_state, sidebar
from utils.config import TWITTER_BEARER

set_initial_state()

sidebar()

st.write("# 🐀 What have they been tweeting about lately?")

if st.session_state.get("OPENAI_API_KEY"):
    prompter, template = start_haystack(st.session_state.get("OPENAI_API_KEY"))
    st.session_state["api_key_configured"] = True
    search_bar, button = st.columns(2)
    # Search bar
    with search_bar: 
        username = st.text_input("Please provide a twitter username", on_change=reset_results)

    with button: 
        st.write("")
        st.write("")
        run_pressed = st.button("Search tweets")
else:
    st.write("Please provide your OpenAI Key to start using the application")
    st.write("If you are using a smaller screen, open the sidebar from the top left to provide your OpenAI Key πŸ™Œ")
    
if st.session_state.get("api_key_configured"):
    run_query = (
        run_pressed or username != st.session_state.username
    )

    # Get results for query
    if run_query and username:
        reset_results()
        st.session_state.username = username
        with st.spinner("πŸ”Ž"):
            try:
                st.session_state.result = query(username, prompter, template)
            except JSONDecodeError as je:
                st.error(
                    "πŸ‘“    An error occurred reading the results. Is the document store working?"
                )    
            except Exception as e:
                logging.exception(e)
                st.error("🐞    An error occurred during the request.")            
                
    if st.session_state.result:
        voice = st.session_state.result
        st.write(voice[0])