143 lines
6.3 KiB
Python
143 lines
6.3 KiB
Python
import gradio as gr
|
|
|
|
# gradio可用颜色列表
|
|
# gr.themes.utils.colors.slate (石板色)
|
|
# gr.themes.utils.colors.gray (灰色)
|
|
# gr.themes.utils.colors.zinc (锌色)
|
|
# gr.themes.utils.colors.neutral (中性色)
|
|
# gr.themes.utils.colors.stone (石头色)
|
|
# gr.themes.utils.colors.red (红色)
|
|
# gr.themes.utils.colors.orange (橙色)
|
|
# gr.themes.utils.colors.amber (琥珀色)
|
|
# gr.themes.utils.colors.yellow (黄色)
|
|
# gr.themes.utils.colors.lime (酸橙色)
|
|
# gr.themes.utils.colors.green (绿色)
|
|
# gr.themes.utils.colors.emerald (祖母绿)
|
|
# gr.themes.utils.colors.teal (青蓝色)
|
|
# gr.themes.utils.colors.cyan (青色)
|
|
# gr.themes.utils.colors.sky (天蓝色)
|
|
# gr.themes.utils.colors.blue (蓝色)
|
|
# gr.themes.utils.colors.indigo (靛蓝色)
|
|
# gr.themes.utils.colors.violet (紫罗兰色)
|
|
# gr.themes.utils.colors.purple (紫色)
|
|
# gr.themes.utils.colors.fuchsia (洋红色)
|
|
# gr.themes.utils.colors.pink (粉红色)
|
|
# gr.themes.utils.colors.rose (玫瑰色)
|
|
|
|
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(
|
|
# Colors
|
|
input_background_fill_dark="*neutral_800",
|
|
# Transition
|
|
button_transition="none",
|
|
# Shadows
|
|
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",
|
|
# Button borders
|
|
input_border_width="1px",
|
|
input_background_fill="white",
|
|
# Gradients
|
|
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;
|
|
}
|
|
""" |