Spaces:
Paused
Paused
| from __future__ import annotations | |
| from collections.abc import Iterable | |
| from gradio.themes.base import Base | |
| from gradio.themes.utils import colors, fonts, sizes | |
| class Aurora(Base): | |
| def __init__( | |
| self, | |
| *, | |
| primary_hue: colors.Color | str = colors.emerald, | |
| secondary_hue: colors.Color | str = colors.sky, | |
| neutral_hue: colors.Color | str = colors.zinc, | |
| spacing_size: sizes.Size | str = sizes.spacing_md, | |
| radius_size: sizes.Size | str = sizes.radius_xxl, | |
| text_size: sizes.Size | str = sizes.text_md, | |
| font: fonts.Font | str | Iterable[fonts.Font | str] = ( | |
| fonts.GoogleFont("Noto Sans Sans"), | |
| "ui-sans-serif", | |
| "system-ui", | |
| "sans-serif", | |
| ), | |
| font_mono: fonts.Font | str | Iterable[fonts.Font | str] = ( | |
| fonts.GoogleFont("Noto Sans Display"), | |
| "ui-monospace", | |
| "Consolas", | |
| "monospace", | |
| ), | |
| ): | |
| super().__init__( | |
| primary_hue=primary_hue, | |
| secondary_hue=secondary_hue, | |
| neutral_hue=neutral_hue, | |
| spacing_size=spacing_size, | |
| radius_size=radius_size, | |
| text_size=text_size, | |
| font=font, | |
| font_mono=font_mono, | |
| ) | |
| self.name = "aurora-gradient" | |
| super().set( | |
| body_background_fill="linear-gradient(135deg, #d1ffd3 0% 0%, #e9fff6 20%, #d3edff 45%, #ebd4f9 70%, #f2d0ff 100%), radial-gradient(circle at 30% 30%, rgba(255, 255, 255, 0.05), transparent 70%)", | |
| body_background_fill_dark="#121212", | |
| body_text_color_dark="#8ab4ff", | |
| # Minimal styling defaults | |
| button_border_width="0.5px", | |
| checkbox_label_border_width="1px", | |
| button_transform_hover="scale(1.05)", | |
| button_transition="all 0.25s ease-in-out", | |
| # Slider gradient | |
| slider_color="cyan", | |
| # Primary button (Aurora gradient) | |
| button_primary_background_fill="linear-gradient(135deg, #14e81e 0%, #00ea8d 20%, #017ed5 45%, #b53dff 70%, #8d00c4 100%), radial-gradient(circle at 30% 30%, rgba(255,255,255,0.05), transparent 70%);", | |
| button_primary_background_fill_hover="linear-gradient(135deg, #14e81e 0%, #00ea8d 20%, #017ed5 45%, #b53dff 70%, #8d00c4 100%), radial-gradient(circle at 30% 30%, rgba(255,255,255,0.05), transparent 70%);", | |
| button_primary_text_color="white", | |
| # Secondary button | |
| button_secondary_background_fill="rgba(12, 18, 35, 0.75)", | |
| button_secondary_background_fill_hover="linear-gradient(#0000, #0000) padding-box, linear-gradient(135deg, rgb(255 255 255 / 90%) 0%, rgb(195 255 231 / 90%) 20%, rgb(101 192 255 / 90%) 45%, rgb(221 167 255 / 90%) 70%, rgb(218 122 255 / 90%) 100%);", | |
| button_secondary_text_color="#fff", | |
| button_secondary_text_color_hover="black", | |
| # Button hover glows | |
| button_primary_shadow_hover="0 0 3px rgba(90,220,255,0.35), 0 0 10px rgba(45,245,195,0.28), 0 0 20px rgba(150,120,255,0.25)", | |
| button_secondary_shadow_hover="none", | |
| # Dark mode variants | |
| button_primary_background_fill_dark="linear-gradient(135deg, #14e81e 0%, #00ea8d 20%, #017ed5 45%, #b53dff 70%, #8d00c4 100%), radial-gradient(circle at 30% 30%, rgba(255,255,255,0.05), transparent 70%);", | |
| button_primary_background_fill_hover_dark="linear-gradient(135deg, #14e81e 0%, #00ea8d 20%, #017ed5 45%, #b53dff 70%, #8d00c4 100%), radial-gradient(circle at 30% 30%, rgba(255,255,255,0.05), transparent 70%);", | |
| button_primary_text_color_dark="white", | |
| button_primary_text_color_hover_dark="black", | |
| button_secondary_background_fill_dark="rgba(12, 18, 35, 0.75)", | |
| button_secondary_background_fill_hover_dark="linear-gradient(#0000, #0000) padding-box, linear-gradient(135deg, rgb(255 255 255 / 90%) 0%, rgb(195 255 231 / 90%) 20%, rgb(101 192 255 / 90%) 45%, rgb(221 167 255 / 90%) 70%, rgb(218 122 255 / 90%) 100%);", | |
| button_secondary_text_color_dark="#dfe7ff", | |
| button_secondary_text_color_hover_dark="black", | |
| button_primary_shadow_dark="0 0 3px rgba(90,220,255,0.35), 0 0 10px rgba(45,245,195,0.28), 0 0 20px rgba(150,120,255,0.25)", | |
| button_secondary_shadow_dark="none", | |
| block_title_background_fill="linear-gradient(135deg, #14e81e 0%, #00ea8d 20%, #017ed5 45%, #b53dff 70%, #8d00c4 100%), radial-gradient(circle at 30% 30%, rgba(255,255,255,0.05), transparent 70%);", | |
| block_title_background_fill_dark="linear-gradient(135deg, #14e81e 0%, #00ea8d 20%, #017ed5 45%, #b53dff 70%, #8d00c4 100%), radial-gradient(circle at 30% 30%, rgba(255,255,255,0.05), transparent 70%);", | |
| block_label_padding="*spacing_sm *spacing_lg", | |
| block_label_background_fill="black", | |
| block_label_background_fill_dark="linear-gradient(135deg, #14e81e 0%, #00ea8d 20%, #017ed5 45%, #b53dff 70%, #8d00c4 100%), radial-gradient(circle at 30% 30%, rgba(255,255,255,0.05), transparent 70%);", | |
| block_label_radius="*radius_md", | |
| block_label_text_size="*text_md", | |
| block_label_text_weight="600", | |
| block_label_text_color="*primary_500", | |
| block_label_text_color_dark="white", | |
| block_title_radius="*block_label_radius", | |
| block_title_padding="*block_label_padding", | |
| block_title_text_weight="600", | |
| block_title_text_color="white", | |
| block_title_text_color_dark="white", | |
| block_label_margin="*spacing_md", | |
| # Stop/Cancel Button | |
| button_cancel_background_fill=colors.red.c500, | |
| button_cancel_background_fill_dark=colors.red.c700, | |
| button_cancel_background_fill_hover="crimson", | |
| button_cancel_background_fill_hover_dark="crimson", | |
| button_cancel_text_color="white", | |
| button_cancel_text_color_dark="white", | |
| button_cancel_text_color_hover="black", | |
| button_cancel_text_color_hover_dark="black", | |
| button_cancel_shadow_dark="0 0 3px rgba(90,220,255,0.35), 0 0 10px rgba(45,245,195,0.28), 0 0 20px rgba(150,120,255,0.25)", | |
| button_cancel_shadow="none", | |
| # Block shadows (glassy Aurora) | |
| block_shadow="0 0 10px rgba(45, 245, 195, 0.2), 0 0 20px rgba(89, 211, 255, 0.15), 0 0 30px rgba(157, 106, 255, 0.1)", | |
| # Checkbox selection gradient (Aurora) | |
| checkbox_label_background_fill_selected="linear-gradient(135deg, #14e81e 0%, #00ea8d 20%, #017ed5 45%, #b53dff 70%, #8d00c4 100%), radial-gradient(circle at 30% 30%, rgba(255,255,255,0.05), transparent 70%);", | |
| checkbox_label_border_color_selected="#2df5c3", | |
| checkbox_background_color_selected="#2df5c3", | |
| checkbox_label_text_color="#fff", | |
| checkbox_label_text_color_selected="#05090f", | |
| checkbox_label_background_fill_selected_dark="linear-gradient(135deg, #14e81e 0%, #00ea8d 20%, #017ed5 45%, #b53dff 70%, #8d00c4 100%), radial-gradient(circle at 30% 30%, rgba(255,255,255,0.05), transparent 70%);", | |
| checkbox_label_border_color_selected_dark="#2df5c3", | |
| checkbox_background_color_selected_dark="#2df5c3", | |
| checkbox_label_text_color_selected_dark="#05090f", | |
| ) | |
| aurora = Aurora() |