| import gradio as gr |
| from toolbox import get_conf |
| CODE_HIGHLIGHT, = get_conf('CODE_HIGHLIGHT') |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
| |
|
|
|
|
| def adjust_theme(): |
| try: |
| color_er = gr.themes.utils.colors.fuchsia |
| 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 = """ |
| /* 设置表格的外边距为1em,内部单元格之间边框合并,空单元格显示. */ |
| .markdown-body table { |
| margin: 1em 0; |
| border-collapse: collapse; |
| empty-cells: show; |
| } |
| |
| /* 设置表格单元格的内边距为5px,边框粗细为1.2px,颜色为--border-color-primary. */ |
| .markdown-body th, .markdown-body td { |
| border: 1.2px solid var(--border-color-primary); |
| padding: 5px; |
| } |
| |
| /* 设置表头背景颜色为rgba(175,184,193,0.2),透明度为0.2. */ |
| .markdown-body thead { |
| background-color: rgba(175,184,193,0.2); |
| } |
| |
| /* 设置表头单元格的内边距为0.5em和0.2em. */ |
| .markdown-body thead th { |
| padding: .5em .2em; |
| } |
| |
| /* 去掉列表前缀的默认间距,使其与文本线对齐. */ |
| .markdown-body ol, .markdown-body ul { |
| 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: 95%; |
| /* width: auto !important; */ |
| border-bottom-left-radius: 0 !important; |
| } |
| [data-testid = "user"] { |
| max-width: 100%; |
| /* width: auto !important; */ |
| border-bottom-right-radius: 0 !important; |
| } |
| |
| /* 行内代码的背景设为淡灰色,设定圆角和间距. */ |
| .markdown-body 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); |
| } |
| /* 设定代码块的样式,包括背景颜色、内、外边距、圆角。 */ |
| .markdown-body 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; |
| } |
| |
| """ |
|
|
| if CODE_HIGHLIGHT: |
| advanced_css += """ |
| |
| .hll { background-color: #ffffcc } |
| .c { color: #3D7B7B; font-style: italic } /* Comment */ |
| .err { border: 1px solid #FF0000 } /* Error */ |
| .k { color: hsl(197, 94%, 51%); font-weight: bold } /* Keyword */ |
| .o { color: #666666 } /* Operator */ |
| .ch { color: #3D7B7B; font-style: italic } /* Comment.Hashbang */ |
| .cm { color: #3D7B7B; font-style: italic } /* Comment.Multiline */ |
| .cp { color: #9C6500 } /* Comment.Preproc */ |
| .cpf { color: #3D7B7B; font-style: italic } /* Comment.PreprocFile */ |
| .c1 { color: #3D7B7B; font-style: italic } /* Comment.Single */ |
| .cs { color: #3D7B7B; font-style: italic } /* Comment.Special */ |
| .gd { color: #A00000 } /* Generic.Deleted */ |
| .ge { font-style: italic } /* Generic.Emph */ |
| .gr { color: #E40000 } /* Generic.Error */ |
| .gh { color: #000080; font-weight: bold } /* Generic.Heading */ |
| .gi { color: #008400 } /* Generic.Inserted */ |
| .go { color: #717171 } /* Generic.Output */ |
| .gp { color: #000080; font-weight: bold } /* Generic.Prompt */ |
| .gs { font-weight: bold } /* Generic.Strong */ |
| .gu { color: #800080; font-weight: bold } /* Generic.Subheading */ |
| .gt { color: #a9dd00 } /* Generic.Traceback */ |
| .kc { color: #008000; font-weight: bold } /* Keyword.Constant */ |
| .kd { color: #008000; font-weight: bold } /* Keyword.Declaration */ |
| .kn { color: #008000; font-weight: bold } /* Keyword.Namespace */ |
| .kp { color: #008000 } /* Keyword.Pseudo */ |
| .kr { color: #008000; font-weight: bold } /* Keyword.Reserved */ |
| .kt { color: #B00040 } /* Keyword.Type */ |
| .m { color: #666666 } /* Literal.Number */ |
| .s { color: #BA2121 } /* Literal.String */ |
| .na { color: #687822 } /* Name.Attribute */ |
| .nb { color: #e5f8c3 } /* Name.Builtin */ |
| .nc { color: #ffad65; font-weight: bold } /* Name.Class */ |
| .no { color: #880000 } /* Name.Constant */ |
| .nd { color: #AA22FF } /* Name.Decorator */ |
| .ni { color: #717171; font-weight: bold } /* Name.Entity */ |
| .ne { color: #CB3F38; font-weight: bold } /* Name.Exception */ |
| .nf { color: #f9f978 } /* Name.Function */ |
| .nl { color: #767600 } /* Name.Label */ |
| .nn { color: #0000FF; font-weight: bold } /* Name.Namespace */ |
| .nt { color: #008000; font-weight: bold } /* Name.Tag */ |
| .nv { color: #19177C } /* Name.Variable */ |
| .ow { color: #AA22FF; font-weight: bold } /* Operator.Word */ |
| .w { color: #bbbbbb } /* Text.Whitespace */ |
| .mb { color: #666666 } /* Literal.Number.Bin */ |
| .mf { color: #666666 } /* Literal.Number.Float */ |
| .mh { color: #666666 } /* Literal.Number.Hex */ |
| .mi { color: #666666 } /* Literal.Number.Integer */ |
| .mo { color: #666666 } /* Literal.Number.Oct */ |
| .sa { color: #BA2121 } /* Literal.String.Affix */ |
| .sb { color: #BA2121 } /* Literal.String.Backtick */ |
| .sc { color: #BA2121 } /* Literal.String.Char */ |
| .dl { color: #BA2121 } /* Literal.String.Delimiter */ |
| .sd { color: #BA2121; font-style: italic } /* Literal.String.Doc */ |
| .s2 { color: #2bf840 } /* Literal.String.Double */ |
| .se { color: #AA5D1F; font-weight: bold } /* Literal.String.Escape */ |
| .sh { color: #BA2121 } /* Literal.String.Heredoc */ |
| .si { color: #A45A77; font-weight: bold } /* Literal.String.Interpol */ |
| .sx { color: #008000 } /* Literal.String.Other */ |
| .sr { color: #A45A77 } /* Literal.String.Regex */ |
| .s1 { color: #BA2121 } /* Literal.String.Single */ |
| .ss { color: #19177C } /* Literal.String.Symbol */ |
| .bp { color: #008000 } /* Name.Builtin.Pseudo */ |
| .fm { color: #0000FF } /* Name.Function.Magic */ |
| .vc { color: #19177C } /* Name.Variable.Class */ |
| .vg { color: #19177C } /* Name.Variable.Global */ |
| .vi { color: #19177C } /* Name.Variable.Instance */ |
| .vm { color: #19177C } /* Name.Variable.Magic */ |
| .il { color: #666666 } /* Literal.Number.Integer.Long */ |
| """ |
|
|