Spaces:
Running
on
Zero
Running
on
Zero
File size: 2,777 Bytes
c9ca579 e1e239a 1c3216f 07d03e7 954f085 5b0f841 a185be6 954f085 5b0f841 07d03e7 5b0f841 954f085 07d03e7 954f085 ae87863 07d03e7 1c3216f df9dfdd f62245a 06597e0 1c3216f 954f085 1c3216f 31a1026 9fe0992 954f085 06597e0 954f085 39bde3d 9fe0992 1c0af73 954f085 1c0af73 954f085 9fe0992 06597e0 fabaa3c de0f0d9 954f085 07d03e7 cada336 48006fa |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 |
import gradio as gr
import spaces
from chatbot import model_inference, EXAMPLES, chatbot
from voice_chat import respond
# Define custom CSS for better styling
custom_css = """
.gradio-container {
font-family: 'Roboto', sans-serif;
}
.main-header {
text-align: center;
color: #4a4a4a;
margin-bottom: 2rem;
}
.tab-header {
font-size: 1.2rem;
font-weight: bold;
margin-bottom: 1rem;
}
.custom-chatbot {
border-radius: 10px;
box-shadow: 0 4px 6px rgba(0, 0, 0, 0.1);
}
.custom-button {
background-color: #3498db;
color: white;
border: none;
padding: 10px 20px;
border-radius: 5px;
cursor: pointer;
transition: background-color 0.3s ease;
}
.custom-button:hover {
background-color: #2980b9;
}
"""
# Define Gradio theme
theme = gr.themes.Soft(
primary_hue="indigo",
secondary_hue="blue",
neutral_hue="slate",
font=[gr.themes.GoogleFont('Roboto'), "sans-serif"]
)
# Chat interface block
with gr.Blocks(css=custom_css) as chat:
gr.Markdown("### π¬ OpenGPT 4o Chat", elem_classes="tab-header")
gr.ChatInterface(
fn=model_inference,
chatbot=chatbot,
examples=EXAMPLES,
multimodal=True,
cache_examples=False,
autofocus=False,
concurrency_limit=10
)
# Voice chat block
with gr.Blocks() as voice:
gr.Markdown("### π£οΈ Voice Chat", elem_classes="tab-header")
gr.Markdown("Try Voice Chat from the link below:")
gr.HTML('<a href="https://huggingface.co/spaces/KingNish/Voicee" target="_blank" class="custom-button">Open Voice Chat</a>')
with gr.Blocks() as image_gen_pro:
gr.HTML("<iframe src='https://kingnish-image-gen-pro.hf.space' width='100%' height='2000px' style='border-radius: 8px;'></iframe>")
with gr.Blocks() as flux_fast:
gr.HTML("<iframe src='https://prodia-flux-1-dev.hf.space' width='100%' height='2000px' style='border-radius: 8px;'></iframe>")
# Image engine block
with gr.Blocks() as image:
gr.Markdown("### πΌοΈ Image Engine", elem_classes="tab-header")
gr.TabbedInterface([flux_fast, image_gen_pro], ['High Quality Image Gen'],['Image gen and editing'])
# Video engine block
with gr.Blocks() as video:
gr.Markdown("### π₯ Video Engine", elem_classes="tab-header")
gr.HTML("<iframe src='https://kingnish-instant-video.hf.space' width='100%' height='3000px' style='border-radius: 8px;'></iframe>")
# Main application block
with gr.Blocks(theme=theme, title="OpenGPT 4o DEMO") as demo:
gr.Markdown("# π OpenGPT 4o", elem_classes="main-header")
gr.TabbedInterface(
[chat, voice, image, video],
['π¬ SuperChat', 'π£οΈ Voice Chat', 'πΌοΈ Image Engine', 'π₯ Video Engine']
)
demo.queue(max_size=300)
demo.launch() |