mirror of
https://github.com/gradio-app/gradio.git
synced 2025-01-24 10:54:04 +08:00
d0ec3d97f2
* seafoam * theme * save * Update guides/06_other-tutorials/theming-guide.md Co-authored-by: Ali Abdalla <ali.si3luwa@gmail.com> * Update guides/06_other-tutorials/theming-guide.md Co-authored-by: Ali Abdalla <ali.si3luwa@gmail.com> * Update guides/06_other-tutorials/theming-guide.md Co-authored-by: Ali Abdalla <ali.si3luwa@gmail.com> * Update guides/06_other-tutorials/theming-guide.md Co-authored-by: Ali Abdalla <ali.si3luwa@gmail.com> * Update guides/06_other-tutorials/theming-guide.md Co-authored-by: Ali Abdalla <ali.si3luwa@gmail.com> * Update guides/06_other-tutorials/theming-guide.md Co-authored-by: Ali Abdalla <ali.si3luwa@gmail.com> * Update guides/06_other-tutorials/theming-guide.md Co-authored-by: Ali Abdalla <ali.si3luwa@gmail.com> --------- Co-authored-by: Ali Abdalla <ali.si3luwa@gmail.com>
79 lines
2.7 KiB
Python
79 lines
2.7 KiB
Python
from __future__ import annotations
|
|
from typing import Iterable
|
|
import gradio as gr
|
|
from gradio.themes.base import Base
|
|
from gradio.themes.utils import colors, fonts, sizes
|
|
import time
|
|
|
|
|
|
class Seafoam(Base):
|
|
def __init__(
|
|
self,
|
|
*,
|
|
primary_hue: colors.Color | str = colors.emerald,
|
|
secondary_hue: colors.Color | str = colors.blue,
|
|
neutral_hue: colors.Color | str = colors.blue,
|
|
spacing_size: sizes.Size | str = sizes.spacing_md,
|
|
radius_size: sizes.Size | str = sizes.radius_md,
|
|
text_size: sizes.Size | str = sizes.text_lg,
|
|
font: fonts.Font
|
|
| str
|
|
| Iterable[fonts.Font | str] = (
|
|
fonts.GoogleFont("Quicksand"),
|
|
"ui-sans-serif",
|
|
"sans-serif",
|
|
),
|
|
font_mono: fonts.Font
|
|
| str
|
|
| Iterable[fonts.Font | str] = (
|
|
fonts.GoogleFont("IBM Plex Mono"),
|
|
"ui-monospace",
|
|
"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,
|
|
)
|
|
super().set(
|
|
body_background_fill="repeating-linear-gradient(45deg, *primary_200, *primary_200 10px, *primary_50 10px, *primary_50 20px)",
|
|
body_background_fill_dark="repeating-linear-gradient(45deg, *primary_800, *primary_800 10px, *primary_900 10px, *primary_900 20px)",
|
|
button_primary_background_fill="linear-gradient(90deg, *primary_300, *secondary_400)",
|
|
button_primary_background_fill_hover="linear-gradient(90deg, *primary_200, *secondary_300)",
|
|
button_primary_text_color="white",
|
|
button_primary_background_fill_dark="linear-gradient(90deg, *primary_600, *secondary_800)",
|
|
slider_color="*secondary_300",
|
|
slider_color_dark="*secondary_600",
|
|
block_title_text_weight="600",
|
|
block_border_width="3px",
|
|
block_shadow="*shadow_drop_lg",
|
|
button_shadow="*shadow_drop_lg",
|
|
button_large_padding="32px",
|
|
)
|
|
|
|
|
|
seafoam = Seafoam()
|
|
|
|
with gr.Blocks(theme=seafoam) as demo:
|
|
textbox = gr.Textbox(label="Name")
|
|
slider = gr.Slider(label="Count", minimum=0, maximum=100, step=1)
|
|
with gr.Row():
|
|
button = gr.Button("Submit", variant="primary")
|
|
clear = gr.Button("Clear")
|
|
output = gr.Textbox(label="Output")
|
|
|
|
def repeat(name, count):
|
|
time.sleep(3)
|
|
return name * count
|
|
|
|
button.click(repeat, [textbox, slider], output)
|
|
|
|
if __name__ == "__main__":
|
|
demo.launch()
|