import json
import os
from pathlib import Path
import gradio as gr
def generate_html():
css = """
.character-gallery table {
border-collapse: collapse;
table-layout: fixed;
width: 100%;
}
.character-gallery th, .character-gallery td {
padding: 8px;
}
.character-gallery img {
width: 150px;
height: 200px;
object-fit: cover;
}
.character-gallery .placeholder {
width: 150px;
height: 200px;
background-color: gray;
}
.character-gallery td {
text-align: center;
vertical-align: middle;
}
"""
table_html = f'
'
# Iterate through files in image folder
for file in Path("characters").glob("*"):
if file.name.endswith(".json"):
json_name = file.name
image_name = file.name.replace(".json", "")
table_html += ""
if Path(f"characters/{image_name}.png").exists():
image_html = f'
'
elif Path(f"characters/{image_name}.jpg").exists():
image_html = f'
'
else:
image_html = ""
table_html += f"{image_html} | {image_name} | "
table_html += "
"
table_html += "
"
return table_html
def ui():
with gr.Accordion("Character gallery"):
update = gr.Button("Refresh")
gallery = gr.HTML(value=generate_html())
update.click(generate_html, [], gallery)