Spaces:
Paused
Paused
Update app.py
Browse files
app.py
CHANGED
|
@@ -402,7 +402,8 @@ def update_session_list():
|
|
| 402 |
def load_session_history(selected_session):
|
| 403 |
try:
|
| 404 |
if not selected_session:
|
| 405 |
-
return
|
|
|
|
| 406 |
# ์ธ์
ID ์ถ์ถ
|
| 407 |
session_id = selected_session.split(" (")[0] if " (" in selected_session else selected_session
|
| 408 |
|
|
@@ -412,16 +413,82 @@ def load_session_history(selected_session):
|
|
| 412 |
SELECT prompt, response, timestamp
|
| 413 |
FROM chat_history
|
| 414 |
WHERE session_id = ?
|
| 415 |
-
ORDER BY timestamp
|
| 416 |
""", (session_id,))
|
| 417 |
history = c.fetchall()
|
| 418 |
conn.close()
|
| 419 |
|
| 420 |
-
#
|
| 421 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 422 |
except Exception as e:
|
| 423 |
print(f"Error loading session history: {e}")
|
| 424 |
-
return
|
| 425 |
|
| 426 |
def save_chat(session_id, prompt, response):
|
| 427 |
print(f"Starting save_chat with session_id: {session_id}")
|
|
@@ -477,11 +544,12 @@ with gr.Blocks(css_paths="app.css",theme=theme) as demo:
|
|
| 477 |
|
| 478 |
with antd.Drawer(open=False, title="history", placement="left", width="900px") as history_drawer:
|
| 479 |
history_output = legacy.Chatbot(show_label=False, flushing=False, height=960, elem_classes="history_chatbot")
|
|
|
|
| 480 |
|
| 481 |
with antd.Drawer(
|
| 482 |
open=False,
|
| 483 |
title="Session History",
|
| 484 |
-
placement="right",
|
| 485 |
width="900px",
|
| 486 |
elem_classes="session-drawer"
|
| 487 |
) as session_drawer:
|
|
@@ -492,10 +560,9 @@ with gr.Blocks(css_paths="app.css",theme=theme) as demo:
|
|
| 492 |
choices=[],
|
| 493 |
elem_classes="session-list"
|
| 494 |
)
|
| 495 |
-
|
| 496 |
-
|
| 497 |
-
|
| 498 |
-
elem_classes="session-chatbot"
|
| 499 |
)
|
| 500 |
close_btn = antd.Button(
|
| 501 |
"Close",
|
|
@@ -503,6 +570,17 @@ with gr.Blocks(css_paths="app.css",theme=theme) as demo:
|
|
| 503 |
elem_classes="close-btn"
|
| 504 |
)
|
| 505 |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
| 506 |
# ๋ฉ์ธ ์ปจํ
์ธ ๋ฅผ ์ํ Row
|
| 507 |
with antd.Row(gutter=[32, 12]) as layout:
|
| 508 |
# ์ข์ธก ํจ๋
|
|
|
|
| 402 |
def load_session_history(selected_session):
|
| 403 |
try:
|
| 404 |
if not selected_session:
|
| 405 |
+
return gr.update(), gr.update()
|
| 406 |
+
|
| 407 |
# ์ธ์
ID ์ถ์ถ
|
| 408 |
session_id = selected_session.split(" (")[0] if " (" in selected_session else selected_session
|
| 409 |
|
|
|
|
| 413 |
SELECT prompt, response, timestamp
|
| 414 |
FROM chat_history
|
| 415 |
WHERE session_id = ?
|
| 416 |
+
ORDER BY timestamp DESC
|
| 417 |
""", (session_id,))
|
| 418 |
history = c.fetchall()
|
| 419 |
conn.close()
|
| 420 |
|
| 421 |
+
# ํ๋กฌํํธ ์นด๋์ฉ HTML ์์ฑ
|
| 422 |
+
cards_html = """
|
| 423 |
+
<style>
|
| 424 |
+
.prompt-grid {
|
| 425 |
+
display: grid;
|
| 426 |
+
grid-template-columns: repeat(auto-fill, minmax(250px, 1fr));
|
| 427 |
+
gap: 20px;
|
| 428 |
+
padding: 20px;
|
| 429 |
+
}
|
| 430 |
+
.prompt-card {
|
| 431 |
+
background: white;
|
| 432 |
+
border: 1px solid #eee;
|
| 433 |
+
border-radius: 8px;
|
| 434 |
+
padding: 15px;
|
| 435 |
+
cursor: pointer;
|
| 436 |
+
transition: all 0.3s ease;
|
| 437 |
+
box-shadow: 0 2px 5px rgba(0,0,0,0.1);
|
| 438 |
+
}
|
| 439 |
+
.prompt-card:hover {
|
| 440 |
+
transform: translateY(-2px);
|
| 441 |
+
box-shadow: 0 4px 10px rgba(0,0,0,0.15);
|
| 442 |
+
}
|
| 443 |
+
.timestamp {
|
| 444 |
+
font-size: 0.8em;
|
| 445 |
+
color: #666;
|
| 446 |
+
margin-top: 10px;
|
| 447 |
+
}
|
| 448 |
+
</style>
|
| 449 |
+
<div class="prompt-grid">
|
| 450 |
+
"""
|
| 451 |
+
|
| 452 |
+
for i, (prompt, response, timestamp) in enumerate(history):
|
| 453 |
+
# ํ๋กฌํํธ ํ
์คํธ๋ฅผ ์ ์ ํ ๊ธธ์ด๋ก ์๋ฅด๊ธฐ
|
| 454 |
+
short_prompt = prompt[:100] + "..." if len(prompt) > 100 else prompt
|
| 455 |
+
formatted_time = datetime.strptime(timestamp, '%Y-%m-%d %H:%M:%S.%f').strftime('%Y-%m-%d %H:%M')
|
| 456 |
+
|
| 457 |
+
cards_html += f"""
|
| 458 |
+
<div class="prompt-card" onclick="showResponse({i})">
|
| 459 |
+
<div>{short_prompt}</div>
|
| 460 |
+
<div class="timestamp">{formatted_time}</div>
|
| 461 |
+
</div>
|
| 462 |
+
"""
|
| 463 |
+
|
| 464 |
+
cards_html += "</div>"
|
| 465 |
+
|
| 466 |
+
# JavaScript ํจ์ ์ถ๊ฐ
|
| 467 |
+
cards_html += """
|
| 468 |
+
<script>
|
| 469 |
+
function showResponse(index) {
|
| 470 |
+
const responses = %s;
|
| 471 |
+
document.getElementById('code-display').innerHTML = `<pre><code>${responses[index]}</code></pre>`;
|
| 472 |
+
}
|
| 473 |
+
</script>
|
| 474 |
+
""" % json.dumps([response for _, response, _ in history])
|
| 475 |
+
|
| 476 |
+
# ์ฝ๋ ํ์ ์์ญ ์ถ๊ฐ
|
| 477 |
+
cards_html += """
|
| 478 |
+
<div id="code-display" style="
|
| 479 |
+
margin-top: 20px;
|
| 480 |
+
padding: 20px;
|
| 481 |
+
background: #f5f5f5;
|
| 482 |
+
border-radius: 8px;
|
| 483 |
+
display: none;
|
| 484 |
+
"></div>
|
| 485 |
+
"""
|
| 486 |
+
|
| 487 |
+
return gr.HTML(value=cards_html)
|
| 488 |
+
|
| 489 |
except Exception as e:
|
| 490 |
print(f"Error loading session history: {e}")
|
| 491 |
+
return gr.HTML("Error loading history")
|
| 492 |
|
| 493 |
def save_chat(session_id, prompt, response):
|
| 494 |
print(f"Starting save_chat with session_id: {session_id}")
|
|
|
|
| 544 |
|
| 545 |
with antd.Drawer(open=False, title="history", placement="left", width="900px") as history_drawer:
|
| 546 |
history_output = legacy.Chatbot(show_label=False, flushing=False, height=960, elem_classes="history_chatbot")
|
| 547 |
+
|
| 548 |
|
| 549 |
with antd.Drawer(
|
| 550 |
open=False,
|
| 551 |
title="Session History",
|
| 552 |
+
placement="right",
|
| 553 |
width="900px",
|
| 554 |
elem_classes="session-drawer"
|
| 555 |
) as session_drawer:
|
|
|
|
| 560 |
choices=[],
|
| 561 |
elem_classes="session-list"
|
| 562 |
)
|
| 563 |
+
# Chatbot์ HTML๋ก ๋ณ๊ฒฝ
|
| 564 |
+
session_history = gr.HTML(
|
| 565 |
+
elem_classes="session-history"
|
|
|
|
| 566 |
)
|
| 567 |
close_btn = antd.Button(
|
| 568 |
"Close",
|
|
|
|
| 570 |
elem_classes="close-btn"
|
| 571 |
)
|
| 572 |
|
| 573 |
+
# ์ด๋ฒคํธ ํธ๋ค๋ฌ ์์
|
| 574 |
+
session_list.change(
|
| 575 |
+
load_session_history,
|
| 576 |
+
inputs=[session_list],
|
| 577 |
+
outputs=[session_history]
|
| 578 |
+
)
|
| 579 |
+
|
| 580 |
+
|
| 581 |
+
|
| 582 |
+
|
| 583 |
+
|
| 584 |
# ๋ฉ์ธ ์ปจํ
์ธ ๋ฅผ ์ํ Row
|
| 585 |
with antd.Row(gutter=[32, 12]) as layout:
|
| 586 |
# ์ข์ธก ํจ๋
|