openfree's picture
Update app.py
d51b0b3 verified
raw
history blame
3.22 kB
import requests
import gradio as gr
from datetime import datetime
# ๊ณ ์ •๋œ ์‚ฌ์šฉ์ž ์ด๋ฆ„
USERNAME = "openfree"
def format_timestamp(timestamp):
if timestamp:
dt = datetime.fromisoformat(timestamp.replace('Z', '+00:00'))
return dt.strftime('%Y-%m-%d %H:%M')
return 'N/A'
def get_space_card(space):
"""Generate HTML card for a space"""
space_name = space["repo_id"].split('/')[-1]
return f"""
<div style='border: 1px solid #ddd; padding: 15px; margin: 10px; border-radius: 8px;
background-color: white; box-shadow: 2px 2px 5px rgba(0,0,0,0.1);
transition: transform 0.2s ease-in-out;'
onmouseover='this.style.transform="scale(1.02)"'
onmouseout='this.style.transform="scale(1)"'>
<h3 style='color: #2d2d2d; margin: 0 0 10px 0;'>
<a href='https://huggingface.co/spaces/{space["repo_id"]}' target='_blank'
style='text-decoration: none; color: #2d2d2d;'>
{space_name}
</a>
</h3>
<p style='margin: 5px 0;'><strong>Description:</strong>
{space.get("description", "No description available")}</p>
<p style='margin: 5px 0;'><strong>Last Modified:</strong>
{format_timestamp(space.get("lastModified"))}</p>
<p style='margin: 5px 0;'><strong>Likes:</strong>
{space.get("likes", 0)} โค๏ธ</p>
<div style='margin-top: 10px;'>
<a href='https://huggingface.co/spaces/{space["repo_id"]}' target='_blank'
style='background-color: #0084ff; color: white; padding: 5px 10px;
border-radius: 5px; text-decoration: none; display: inline-block;'>
View Space
</a>
</div>
</div>
"""
def get_user_spaces():
# ๊ณต๊ฐœ API ํ˜ธ์ถœ (ํ† ํฐ ๋ถˆํ•„์š”)
response = requests.get(
f"https://huggingface.co/api/models?author={USERNAME}&filter=space",
headers={"Accept": "application/json"}
)
if response.status_code != 200:
return f"Error: Failed to fetch spaces (Status Code: {response.status_code})"
spaces = response.json()
if not spaces:
return "No public Spaces found for this user."
# Create HTML grid layout with title and count
html_content = f"""
<div style='padding: 20px; background-color: #f5f5f5;'>
<div style='margin-bottom: 20px;'>
<p style='color: #666; margin: 0;'>Found {len(spaces)} public spaces</p>
</div>
<div style='
display: grid;
grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
gap: 20px;
'>
{"".join(get_space_card(space) for space in spaces)}
</div>
</div>
"""
return html_content
# Creating the Gradio interface
app = gr.Interface(
fn=get_user_spaces,
inputs=None,
outputs=gr.HTML(),
title=f"Hugging Face Public Spaces - {USERNAME}",
description=f"Displays public Spaces from {USERNAME}",
theme=gr.themes.Soft(),
css="""
.gradio-container {
max-width: 100% !important;
}
"""
)
# Launch the Gradio app
if __name__ == "__main__":
app.launch()