|
import gradio as gr |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
def adjust_theme(): |
|
try: |
|
color_er = gr.themes.utils.colors.pink |
|
set_theme = gr.themes.Default( |
|
primary_hue=gr.themes.utils.colors.orange, |
|
neutral_hue=gr.themes.utils.colors.gray, |
|
font=["sans-serif", "Microsoft YaHei", "ui-sans-serif", "system-ui", "sans-serif", gr.themes.utils.fonts.GoogleFont("Source Sans Pro")], |
|
font_mono=["ui-monospace", "Consolas", "monospace", gr.themes.utils.fonts.GoogleFont("IBM Plex Mono")]) |
|
set_theme.set( |
|
|
|
input_background_fill_dark="*neutral_800", |
|
|
|
button_transition="none", |
|
|
|
button_shadow="*shadow_drop", |
|
button_shadow_hover="*shadow_drop_lg", |
|
button_shadow_active="*shadow_inset", |
|
input_shadow="0 0 0 *shadow_spread transparent, *shadow_inset", |
|
input_shadow_focus="0 0 0 *shadow_spread *secondary_50, *shadow_inset", |
|
input_shadow_focus_dark="0 0 0 *shadow_spread *neutral_700, *shadow_inset", |
|
checkbox_label_shadow="*shadow_drop", |
|
block_shadow="*shadow_drop", |
|
form_gap_width="1px", |
|
|
|
input_border_width="1px", |
|
input_background_fill="white", |
|
|
|
stat_background_fill="linear-gradient(to right, *primary_400, *primary_200)", |
|
stat_background_fill_dark="linear-gradient(to right, *primary_400, *primary_600)", |
|
error_background_fill=f"linear-gradient(to right, {color_er.c100}, *background_fill_secondary)", |
|
error_background_fill_dark="*background_fill_primary", |
|
checkbox_label_background_fill="linear-gradient(to top, *neutral_50, white)", |
|
checkbox_label_background_fill_dark="linear-gradient(to top, *neutral_900, *neutral_800)", |
|
checkbox_label_background_fill_hover="linear-gradient(to top, *neutral_100, white)", |
|
checkbox_label_background_fill_hover_dark="linear-gradient(to top, *neutral_900, *neutral_800)", |
|
button_primary_background_fill="linear-gradient(to bottom right, *primary_100, *primary_300)", |
|
button_primary_background_fill_dark="linear-gradient(to bottom right, *primary_500, *primary_600)", |
|
button_primary_background_fill_hover="linear-gradient(to bottom right, *primary_100, *primary_200)", |
|
button_primary_background_fill_hover_dark="linear-gradient(to bottom right, *primary_500, *primary_500)", |
|
button_primary_border_color_dark="*primary_500", |
|
button_secondary_background_fill="linear-gradient(to bottom right, *neutral_100, *neutral_200)", |
|
button_secondary_background_fill_dark="linear-gradient(to bottom right, *neutral_600, *neutral_700)", |
|
button_secondary_background_fill_hover="linear-gradient(to bottom right, *neutral_100, *neutral_100)", |
|
button_secondary_background_fill_hover_dark="linear-gradient(to bottom right, *neutral_600, *neutral_600)", |
|
button_cancel_background_fill=f"linear-gradient(to bottom right, {color_er.c100}, {color_er.c200})", |
|
button_cancel_background_fill_dark=f"linear-gradient(to bottom right, {color_er.c600}, {color_er.c700})", |
|
button_cancel_background_fill_hover=f"linear-gradient(to bottom right, {color_er.c100}, {color_er.c100})", |
|
button_cancel_background_fill_hover_dark=f"linear-gradient(to bottom right, {color_er.c600}, {color_er.c600})", |
|
button_cancel_border_color=color_er.c200, |
|
button_cancel_border_color_dark=color_er.c600, |
|
button_cancel_text_color=color_er.c600, |
|
button_cancel_text_color_dark="white", |
|
) |
|
except: |
|
set_theme = None; print('gradio版本较旧, 不能自定义字体和颜色') |
|
return set_theme |
|
|
|
advanced_css = """ |
|
.markdown-body table { |
|
margin: 1em 0; |
|
border-collapse: collapse; |
|
empty-cells: show; |
|
} |
|
.markdown-body th, .markdown-body td { |
|
border: 1.2px solid var(--border-color-primary); |
|
padding: 5px; |
|
} |
|
.markdown-body thead { |
|
background-color: rgba(175,184,193,0.2); |
|
} |
|
.markdown-body thead th { |
|
padding: .5em .2em; |
|
} |
|
# 以下 CSS 来自对 https://github.com/GaiZhenbiao/ChuanhuChatGPT 的移植。 |
|
/* list */ |
|
ol:not(.options), ul:not(.options) { |
|
padding-inline-start: 2em !important; |
|
} |
|
/* 对话气泡 */ |
|
[class *= "message"] { |
|
border-radius: var(--radius-xl) !important; |
|
padding: var(--spacing-xl) !important; |
|
font-size: var(--text-md) !important; |
|
line-height: var(--line-md) !important; |
|
min-height: calc(var(--text-md)*var(--line-md) + 2*var(--spacing-xl)); |
|
min-width: calc(var(--text-md)*var(--line-md) + 2*var(--spacing-xl)); |
|
} |
|
[data-testid = "bot"] { |
|
max-width: 85%; |
|
width: auto !important; |
|
border-bottom-left-radius: 0 !important; |
|
} |
|
[data-testid = "user"] { |
|
max-width: 85%; |
|
width: auto !important; |
|
border-bottom-right-radius: 0 !important; |
|
} |
|
/* 行内代码 */ |
|
code { |
|
display: inline; |
|
white-space: break-spaces; |
|
border-radius: 6px; |
|
margin: 0 2px 0 2px; |
|
padding: .2em .4em .1em .4em; |
|
background-color: rgba(175,184,193,0.2); |
|
} |
|
/* 代码块 */ |
|
pre code { |
|
display: block; |
|
overflow: auto; |
|
white-space: pre; |
|
background-color: rgba(175,184,193,0.2); |
|
border-radius: 10px; |
|
padding: 1em; |
|
margin: 1em 2em 1em 0.5em; |
|
} |
|
""" |