import os import json import datetime import requests import numpy as np import gradio as gr from pathlib import Path from model.model_registry import * from .constants import LOGDIR, LOG_SERVER_ADDR, APPEND_JSON, SAVE_IMAGE, SAVE_VIDEO, SAVE_LOG from typing import Union enable_btn = gr.update(interactive=True, visible=True) disable_btn = gr.update(interactive=False) invisible_btn = gr.update(interactive=False, visible=False) no_change_btn = gr.update(value="No Change", interactive=True, visible=True) def build_about(): about_markdown = f""" # About Us """ gr.Markdown(about_markdown, elem_id="about_markdown") acknowledgment_md = """ ### Acknowledgment
""" # 定义一个HTML组件来创建链接和处理点击事件 html_code = """This platform is designed for academic usage, for details please refer to disclaimer.
""" block_css = """ #notice_markdown { font-size: 110% } #notice_markdown th { display: none; } #notice_markdown td { padding-top: 6px; padding-bottom: 6px; } #model_description_markdown { font-size: 110% } #leaderboard_markdown { font-size: 110% } #leaderboard_markdown td { padding-top: 6px; padding-bottom: 6px; } #leaderboard_dataframe td { line-height: 0.1em; } #about_markdown { font-size: 110% } #ack_markdown { font-size: 110% } #input_box textarea { } footer { display:none !important } .image-about img { margin: 0 30px; margin-top: 30px; height: 60px; max-height: 100%; width: auto; float: left; .input-image, .image-preview { margin: 0 30px; height: 30px; max-height: 100%; width: auto; max-width: 30%;} } .custom-button { border-radius: 8px; } .best-button { border-radius: 8px; } .row { display: flex; justify-content: space-between; } .send-button { background: rgb(168, 230, 207); color: rgb(0, 198, 171); } .submit-button { color: red; } #custom-width {width: 100px !important;} #centered-row { display: flex; justify-content: center; } #btncolor1 {background: rgb(168, 230, 207);} #btncolor2 {background: rgb(253, 255, 171);} #btncolor3 {background: rgb(255, 211, 182);} #btncolor4 {background: rgb(255, 170, 165);} #btnblue {background: linear-gradient(to bottom right, rgb(222, 235, 247), rgb(189,215,238)); color: rgb(0, 112, 192); border: 1px solid rgb(189,215,238);} #btnpink {background: rgb(255, 168, 184);} #centered-text { display: flex; justify-content: center; align-items: center; height: 100%; width: 100%; font-size: 150%; } """ # #btncolor1 {background: rgb(128, 214, 255);} #btncolor2 {background: rgb(237, 247, 152);} #btncolor3 {background: rgb(250, 181, 122);} #btncolor4 {background: rgb(240, 104, 104);} #btncolor1 {background: rgb(112, 161, 215);} #btncolor2 {background: rgb(161, 222, 147);} #btncolor3 {background: rgb(247, 244, 139);} #btncolor4 {background: rgb(244, 124, 124);} #btncolor1 {background: rgb(168, 230, 207);} #btncolor2 {background: rgb(253, 255, 171);} #btncolor3 {background: rgb(255, 211, 182);} #btncolor4 {background: rgb(255, 170, 165);} #btncolor1 {background: rgb(255, 212, 96);} #btncolor2 {background: rgb(240, 123, 63);} #btncolor3 {background: rgb(234, 84, 85);} #btncolor4 {background: rgb(45, 64, 89);} #btncolor1 {background: rgb(255, 189, 57);} #btncolor2 {background: rgb(230, 28, 93);} #btncolor3 {background: rgb(147, 0, 119);} #btncolor4 {background: rgb(58, 0, 136);} # max-width: 100px; # .custom-button { # padding: 10px 15px; # text-align: center; # text-decoration: none; # display: inline-block; # font-size: 16px; # cursor: pointer; # border-radius: 8px; # } # { # background-color: green; /* 背景颜色 */ # color: white; /* 文字颜色 */ # border: none; /* 无边框 */ # padding: 10px 20px; /* 内边距 */ # text-align: center; /* 文本居中 */ # text-decoration: none; /* 无下划线 */ # display: inline-block; /* 行内块 */ # font-size: 16px; /* 字体大小 */ # margin: 4px 2px; /* 外边距 */ # cursor: pointer; /* 鼠标指针 */ # border-radius: 5px; /* 圆角边框 */ # } # .custom-button:hover { # background-color: darkgreen; /* 悬停时的背景颜色 */ # } def enable_loop_buttons(): return tuple(gr.update(loop=True) for i in range(4)) def enable_vote_buttons(): return tuple(gr.update(visible=True, interactive=i<=4) for i in range(6)) def disable_vote_buttons(): return tuple(gr.update(visible=False, interactive=False) for i in range(6)) def disable_vote(): return tuple(gr.update(interactive=False) for i in range(18)) def enable_vote_mode_buttons(mode, textbox): print(mode) if not textbox.strip(): return tuple(gr.update(visible=False, interactive=False) for _ in range(24)) else: if mode == "Best": return (gr.update(visible=True, interactive=True),) * 5 + \ (gr.update(visible=False, interactive=False),) * 16 + \ (gr.update(visible=True, interactive=False),) * 2 + \ (gr.update(visible=True, interactive=True),) elif mode == "Rank": return (gr.update(visible=False, interactive=False),) * 5 + \ (gr.update(visible=True, interactive=True),) * 16 + \ (gr.update(visible=True, interactive=True),) * 3 def disable_vote_mode_buttons(): return tuple(gr.update(visible=False, interactive=False) for _ in range(24)) def enable_order_buttons(): return tuple(gr.update(interactive=True) for _ in range(5)) def disable_order_buttons(textbox, cache="False"): if cache=="True": return (gr.update(interactive=False), gr.update(interactive=False), gr.update(interactive=False), gr.update(interactive=False), gr.update(interactive=True)) if not textbox.strip(): return (gr.update(interactive=True), gr.update(interactive=True), gr.update(interactive=True), gr.update(interactive=True), gr.update(interactive=True)) else: return (gr.update(interactive=False), gr.update(interactive=False), gr.update(interactive=False), gr.update(interactive=False), gr.update(interactive=True)) def enable_video_order_buttons(): return tuple(gr.update(interactive=True) for _ in range(4)) def disable_video_order_buttons(): return (gr.update(interactive=False), gr.update(interactive=False), gr.update(interactive=False), gr.update(interactive=True)) def clear_history(): return None, "", None def clear_history_side_by_side(): return None, None, "", None, None def clear_history_side_by_side_anony(): return None, None, None, None, gr.update(visible=True, interactive=True, value=""), gr.update(visible=True, interactive=True, value=""), None, None, None, None, \ gr.Markdown("", visible=False), gr.Markdown("", visible=False), gr.Markdown("", visible=False), gr.Markdown("", visible=False) def clear_history_ie(): return None, "", "", "", None, None def clear_history_side_by_side_ie(): return None, None, "", "", "", None, None, None def clear_history_side_by_side_ie_anony(): return None, None, "", "", "", None, None, None, gr.Markdown("", visible=False), gr.Markdown("", visible=False) def get_ip(request: gr.Request): if request: if "cf-connecting-ip" in request.headers: ip = request.headers["cf-connecting-ip"] or request.client.host else: ip = request.client.host else: ip = None return ip def get_conv_log_filename(): t = datetime.datetime.now() name = os.path.join(LOGDIR, f"{t.year}-{t.month:02d}-{t.day:02d}-conv.json") return name def save_image_file_on_log_server(image_file:str): return 1 image_file = Path(image_file).absolute().relative_to(os.getcwd()) image_file = str(image_file) # Open the image file in binary mode url = f"{LOG_SERVER_ADDR}/{SAVE_IMAGE}" with open(image_file, 'rb') as f: # Make the POST request, sending the image file and the image path response = requests.post(url, files={'image': f}, data={'image_path': image_file}) return response def save_video_file_on_log_server(video_file:str): return 1 video_file = Path(video_file).absolute().relative_to(os.getcwd()) video_file = str(video_file) # Open the video file in binary mode url = f"{LOG_SERVER_ADDR}/{SAVE_VIDEO}" with open(video_file, 'rb') as f: # Make the POST request, sending the video file and the video path response = requests.post(url, files={'video': f}, data={'video_path': video_file}) return response def append_json_item_on_log_server(json_item: Union[dict, str], log_file: str): return 1 if isinstance(json_item, dict): json_item = json.dumps(json_item) log_file = Path(log_file).absolute().relative_to(os.getcwd()) log_file = str(log_file) url = f"{LOG_SERVER_ADDR}/{APPEND_JSON}" # Make the POST request, sending the JSON string and the log file name response = requests.post(url, data={'json_str': json_item, 'file_name': log_file}) return response def save_log_str_on_log_server(log_str: str, log_file: str): return 1 log_file = Path(log_file).absolute().relative_to(os.getcwd()) log_file = str(log_file) url = f"{LOG_SERVER_ADDR}/{SAVE_LOG}" # Make the POST request, sending the log message and the log file name response = requests.post(url, data={'message': log_str, 'log_path': log_file}) return response