LinkedinMonitor / ui /config.py
GuglielmoTor's picture
Update ui/config.py
cd66f1f verified
import gradio as gr
# Custom CSS for enhanced UI
custom_title_css = """
/* Target the HTML component specifically */
.gradio-html .main-title {
font-size: 48px !important;
font-weight: 800 !important;
color: #0077B5 !important;
text-align: center !important;
margin: 20px 0 10px 0 !important;
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
text-shadow: 2px 2px 4px rgba(0,0,0,0.1) !important;
}
.gradio-html .main-subtitle {
font-size: 18px !important;
color: #666666 !important;
text-align: center !important;
margin: 0 0 30px 0 !important;
font-weight: 400 !important;
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
}
.gradio-html .title-container {
background: linear-gradient(135deg, #f8fafc 0%, #f1f5f9 100%) !important;
border-radius: 15px !important;
padding: 40px 20px !important;
margin: 20px 0 !important;
box-shadow: 0 8px 25px rgba(0, 0, 0, 0.1) !important;
border: 2px solid #e2e8f0 !important;
}
.gradio-html .emoji-icon {
font-size: 40px !important;
margin-right: 10px !important;
vertical-align: middle !important;
}
/* Alternative approach - target by element directly */
div[data-testid="HTML"] .main-title,
.gr-html .main-title {
font-size: 48px !important;
font-weight: 800 !important;
color: #0077B5 !important;
text-align: center !important;
margin: 20px 0 10px 0 !important;
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
}
div[data-testid="HTML"] .main-subtitle,
.gr-html .main-subtitle {
font-size: 18px !important;
color: #666666 !important;
text-align: center !important;
margin: 0 0 30px 0 !important;
font-weight: 400 !important;
font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif !important;
}
div[data-testid="HTML"] .title-container,
.gr-html .title-container {
background: #f8fafc !important;
border-radius: 15px !important;
padding: 40px 20px !important;
margin: 20px 0 !important;
box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1) !important;
border: 2px solid #e2e8f0 !important;
}
"""
# Create the interface
custom_css = """
/* Global App Styling */
.gradio-container {
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%) !important;
min-height: 100vh;
font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif !important;
}
/* Main content area */
.main > .wrap {
background: rgba(255, 255, 255, 0.05) !important;
backdrop-filter: blur(20px) !important;
border: 1px solid rgba(255, 255, 255, 0.1) !important;
border-radius: 20px !important;
box-shadow: 0 20px 40px rgba(0, 0, 0, 0.1) !important;
margin: 20px !important;
padding: 30px !important;
}
/* Title Styling */
.main-title {
background: linear-gradient(135deg, #667eea, #764ba2, #f093fb) !important;
-webkit-background-clip: text !important;
-webkit-text-fill-color: transparent !important;
background-clip: text !important;
font-size: 3rem !important;
font-weight: 800 !important;
text-align: center !important;
margin: 0 0 30px 0 !important;
text-shadow: 0 4px 8px rgba(0, 0, 0, 0.1) !important;
letter-spacing: -0.02em !important;
}
/* Subtitle styling */
.main-subtitle {
color: rgba(255, 255, 255, 0.8) !important;
text-align: center !important;
font-size: 1.2rem !important;
font-weight: 400 !important;
margin-bottom: 40px !important;
opacity: 0.9 !important;
}
/* Tab container styling */
.tab-nav > .tab-nav-item {
background: rgba(255, 255, 255, 0.1) !important;
border: 1px solid rgba(255, 255, 255, 0.2) !important;
border-radius: 15px !important;
margin-right: 8px !important;
padding: 12px 24px !important;
color: rgba(255, 255, 255, 0.8) !important;
font-weight: 600 !important;
transition: all 0.3s ease !important;
backdrop-filter: blur(10px) !important;
font-size: 1rem !important;
}
.tab-nav > .tab-nav-item:hover {
background: rgba(255, 255, 255, 0.2) !important;
transform: translateY(-2px) !important;
box-shadow: 0 8px 16px rgba(0, 0, 0, 0.1) !important;
}
.tab-nav > .tab-nav-item.selected {
background: linear-gradient(135deg, rgba(255, 255, 255, 0.3), rgba(255, 255, 255, 0.2)) !important;
color: white !important;
border-color: rgba(255, 255, 255, 0.4) !important;
box-shadow: 0 8px 20px rgba(0, 0, 0, 0.15) !important;
transform: translateY(-2px) !important;
}
/* Tab content area */
.tabitem {
background: rgba(255, 255, 255, 0.02) !important;
border-radius: 20px !important;
padding: 30px !important;
margin-top: 20px !important;
border: 1px solid rgba(255, 255, 255, 0.1) !important;
backdrop-filter: blur(10px) !important;
}
/* Form elements styling */
.gradio-textbox, .gradio-dropdown, .gradio-slider {
background: rgba(255, 255, 255, 0.1) !important;
border: 1px solid rgba(255, 255, 255, 0.2) !important;
border-radius: 12px !important;
color: white !important;
backdrop-filter: blur(10px) !important;
}
.gradio-textbox input, .gradio-dropdown select {
background: transparent !important;
color: white !important;
border: none !important;
}
.gradio-textbox input::placeholder {
color: rgba(255, 255, 255, 0.5) !important;
}
/* Button styling */
button {
background: linear-gradient(135deg, #667eea, #764ba2) !important;
border: none !important;
border-radius: 12px !important;
color: white !important;
font-weight: 600 !important;
padding: 12px 24px !important;
transition: all 0.3s ease !important;
box-shadow: 0 4px 12px rgba(102, 126, 234, 0.3) !important;
}
button:hover {
transform: translateY(-2px) !important;
box-shadow: 0 8px 20px rgba(102, 126, 234, 0.4) !important;
}
/* Status box styling */
.gradio-textbox.status-box {
background: rgba(255, 107, 107, 0.1) !important;
border-color: rgba(255, 107, 107, 0.3) !important;
}
/* Plot containers */
.plot-container {
background: rgba(255, 255, 255, 0.05) !important;
border-radius: 15px !important;
padding: 20px !important;
margin: 15px 0 !important;
border: 1px solid rgba(255, 255, 255, 0.1) !important;
backdrop-filter: blur(10px) !important;
}
/* Card-like components */
.info-card {
background: rgba(255, 255, 255, 0.08) !important;
border-radius: 16px !important;
padding: 24px !important;
margin: 16px 0 !important;
border: 1px solid rgba(255, 255, 255, 0.12) !important;
backdrop-filter: blur(15px) !important;
box-shadow: 0 8px 16px rgba(0, 0, 0, 0.1) !important;
}
/* Markdown content styling */
.prose {
color: rgba(255, 255, 255, 0.9) !important;
}
.prose h1, .prose h2, .prose h3 {
color: white !important;
font-weight: 700 !important;
}
.prose p {
color: rgba(255, 255, 255, 0.8) !important;
line-height: 1.6 !important;
}
/* Loading states */
.loading {
background: linear-gradient(90deg, rgba(255,255,255,0.1) 0%, rgba(255,255,255,0.2) 50%, rgba(255,255,255,0.1) 100%) !important;
background-size: 200% 100% !important;
animation: loading 1.5s infinite !important;
}
@keyframes loading {
0% { background-position: 200% 0; }
100% { background-position: -200% 0; }
}
/* Responsive design */
@media (max-width: 768px) {
.main-title {
font-size: 2rem !important;
}
.tab-nav > .tab-nav-item {
padding: 8px 16px !important;
font-size: 0.9rem !important;
}
.main > .wrap {
margin: 10px !important;
padding: 20px !important;
}
}
/* Floating action elements */
.floating-element {
position: relative !important;
z-index: 10 !important;
}
.floating-element::before {
content: '' !important;
position: absolute !important;
top: -2px !important;
left: -2px !important;
right: -2px !important;
bottom: -2px !important;
background: linear-gradient(45deg, #667eea, #764ba2, #f093fb) !important;
border-radius: inherit !important;
z-index: -1 !important;
opacity: 0 !important;
transition: opacity 0.3s ease !important;
}
.floating-element:hover::before {
opacity: 1 !important;
}
/* Enhanced home tab cards */
.home-card {
background: rgba(255, 255, 255, 0.1) !important;
border: 1px solid rgba(255, 255, 255, 0.2) !important;
border-radius: 20px !important;
padding: 30px !important;
margin: 15px !important;
backdrop-filter: blur(15px) !important;
transition: all 0.3s ease !important;
cursor: pointer !important;
}
.home-card:hover {
transform: translateY(-5px) !important;
box-shadow: 0 15px 30px rgba(0, 0, 0, 0.2) !important;
background: rgba(255, 255, 255, 0.15) !important;
}
.home-card-icon {
font-size: 3rem !important;
margin-bottom: 20px !important;
display: block !important;
text-align: center !important;
}
.home-card-title {
font-size: 1.5rem !important;
font-weight: 700 !important;
color: white !important;
margin-bottom: 10px !important;
text-align: center !important;
}
.home-card-description {
color: rgba(255, 255, 255, 0.7) !important;
text-align: center !important;
line-height: 1.5 !important;
}
"""
# Custom theme with enhanced colors
custom_theme = gr.themes.Soft(
primary_hue="blue",
secondary_hue="purple",
neutral_hue="slate"
).set(
body_background_fill="*primary_50",
body_background_fill_dark="*primary_900",
button_primary_background_fill="linear-gradient(135deg, *primary_500, *secondary_600)",
button_primary_background_fill_hover="linear-gradient(135deg, *primary_600, *secondary_700)",
block_background_fill="rgba(255, 255, 255, 0.05)",
block_border_color="rgba(255, 255, 255, 0.1)",
input_background_fill="rgba(255, 255, 255, 0.1)",
input_border_color="rgba(255, 255, 255, 0.2)"
)