Spaces:
Running
Running
import streamlit as st | |
def apply_custom_styles(): | |
st.markdown(""" | |
<style> | |
.stApp { | |
max-width: 1200px; | |
margin: 0 auto; | |
background: linear-gradient(135deg, #f5f7fa 0%, #e4e9f2 100%); | |
background-attachment: fixed; | |
min-height: 100vh; | |
} | |
.upload-container { | |
border: 2px dashed #0066cc; | |
border-radius: 10px; | |
padding: 20px; | |
text-align: center; | |
margin: 20px 0; | |
background: rgba(255, 255, 255, 0.9); | |
backdrop-filter: blur(5px); | |
} | |
.factor-card { | |
background-color: rgba(255, 255, 255, 0.95); | |
padding: 20px; | |
border-radius: 10px; | |
box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1); | |
margin: 10px 0; | |
backdrop-filter: blur(5px); | |
height: 100%; | |
} | |
.good-factor { | |
border-left: 4px solid #28a745; | |
} | |
.average-factor { | |
border-left: 4px solid #ffc107; | |
} | |
.bad-factor { | |
border-left: 4px solid #dc3545; | |
} | |
.header-container { | |
padding: 2rem 0; | |
margin-bottom: 2rem; | |
background: linear-gradient(90deg, #0066cc 0%, #0099ff 100%); | |
color: white; | |
border-radius: 10px; | |
text-align: center; | |
box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1); | |
} | |
.detailed-factor { | |
padding: 15px; | |
border-radius: 8px; | |
margin: 10px 0; | |
background: rgba(255, 255, 255, 0.9); | |
border-left: 4px solid #666; | |
} | |
.detailed-factor.good { | |
border-left-color: #28a745; | |
background: rgba(40, 167, 69, 0.1); | |
} | |
.detailed-factor.average { | |
border-left-color: #ffc107; | |
background: rgba(255, 193, 7, 0.1); | |
} | |
.detailed-factor.bad { | |
border-left-color: #dc3545; | |
background: rgba(220, 53, 69, 0.1); | |
} | |
.comparison-table { | |
background: white; | |
border-radius: 10px; | |
box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1); | |
margin: 20px 0; | |
} | |
</style> | |
""", unsafe_allow_html=True) | |
def show_factor_section(title, factors, color): | |
if factors: | |
st.markdown(f""" | |
<div class="factor-card {color}-factor"> | |
<h3 style="color: #333;">{title}</h3> | |
<ul style="list-style-type: none; padding-left: 0;"> | |
{"".join(f'<li style="margin: 10px 0; padding: 10px; background: rgba(248, 249, 250, 0.8); border-radius: 5px;">{factor}</li>' for factor in factors)} | |
</ul> | |
</div> | |
""", unsafe_allow_html=True) | |
def show_detailed_factors(good_factors, average_factors, bad_factors): | |
for factor in good_factors: | |
name, explanation = factor.split(':', 1) | |
st.markdown(f""" | |
<div class="detailed-factor good"> | |
<strong>{name}</strong> | |
<p style="margin: 5px 0 0 0; color: #666;">{explanation}</p> | |
</div> | |
""", unsafe_allow_html=True) | |
for factor in average_factors: | |
name, explanation = factor.split(':', 1) | |
st.markdown(f""" | |
<div class="detailed-factor average"> | |
<strong>{name}</strong> | |
<p style="margin: 5px 0 0 0; color: #666;">{explanation}</p> | |
</div> | |
""", unsafe_allow_html=True) | |
for factor in bad_factors: | |
name, explanation = factor.split(':', 1) | |
st.markdown(f""" | |
<div class="detailed-factor bad"> | |
<strong>{name}</strong> | |
<p style="margin: 5px 0 0 0; color: #666;">{explanation}</p> | |
</div> | |
""", unsafe_allow_html=True) | |
def show_factor_summary(summary, verdict, sentiment_title): | |
if len(summary) > 0: | |
st.markdown(f""" | |
<div class="detailed-factor {verdict}"> | |
<strong>{sentiment_title}</strong> | |
<p style="margin: 5px 0 0 0; color: #666;">{summary}</p> | |
</div> | |
""", unsafe_allow_html=True) |