import gradio as gr
from sentiwordnet_calculator import SentimentPipeline

pipe = SentimentPipeline("Tanor/BERTicSENTPOS4", "Tanor/BERTicSENTNEG4")

def calculate(text):
    result = pipe(text)
    # Visual representation
    visual = result
    # Numerical representation
    numerical = {key: round(value, 2) for key, value in result.items()}
    # Create a formatted string
    numerical_str = ", ".join(f"{key}: {value}" for key, value in numerical.items())
    return visual, numerical_str

iface = gr.Interface(
    fn=calculate, 
    inputs=gr.inputs.Textbox(lines=5, placeholder="Enter your text here..."), 
    outputs=[gr.outputs.Label(num_top_classes=3), "text"],
    title="Sentiment Analysis for Serbian",
    description="""
    This tool performs sentiment analysis on the input text using a model trained on Serbian dictionary definitions. 
    The pretrained model [BERTic from classla](https://huggingface.co/classla/bcms-bertic), 
    was fine-tuned on selected definitions from the Serbian WordNet. Please limit the input to 300 tokens. 
    The outputs represent the Positive (POS), Negative (NEG), and Objective (OBJ) sentiment scores.
    """,
    examples=[
        ["osoba koja ne prihvata nove ideje"],
        ["intenzivna ojađenost"],
        ["uopštenih osećanja tuge"],
        ["žalostan zbog gubitka ili uskraćenosti"],
        ["činjenje dobra; osećaj dobrotvornosti"],
        ["Jako pozitivno osećanje poštovanja i privrežen..."],
        ["usrećiti ili zadovoljiti"],
        ["Korisna ili vredna osobina"],
    ]

)

iface.launch()