Update app.py
Browse files
app.py
CHANGED
@@ -452,8 +452,9 @@ def load_session_history(selected_session=None):
|
|
452 |
if TEMPLATE_CACHE:
|
453 |
return TEMPLATE_CACHE
|
454 |
|
455 |
-
|
456 |
-
|
|
|
457 |
|
458 |
html_content = """
|
459 |
<style>
|
@@ -501,11 +502,30 @@ def load_session_history(selected_session=None):
|
|
501 |
padding: 8px;
|
502 |
border-radius: 4px;
|
503 |
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
504 |
</style>
|
505 |
<div class="prompt-grid" id="promptGrid">
|
506 |
"""
|
507 |
|
508 |
-
|
|
|
509 |
html_content += f"""
|
510 |
<div class="prompt-card" onclick="copyToInput(this)" data-prompt="{html.escape(item.get('prompt', ''))}">
|
511 |
<img src="{item.get('image_url', '')}" class="card-image" loading="lazy" alt="{html.escape(item.get('name', ''))}">
|
@@ -514,19 +534,61 @@ def load_session_history(selected_session=None):
|
|
514 |
</div>
|
515 |
"""
|
516 |
|
517 |
-
|
|
|
518 |
<script>
|
519 |
-
|
|
|
|
|
|
|
|
|
520 |
const prompt = card.dataset.prompt;
|
521 |
const textarea = document.querySelector('.ant-input-textarea-large textarea');
|
522 |
-
if (textarea) {
|
523 |
textarea.value = prompt;
|
524 |
-
textarea.dispatchEvent(new Event('input', { bubbles: true }));
|
525 |
document.querySelector('.session-drawer .close-btn').click();
|
526 |
-
}
|
527 |
-
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
528 |
</script>
|
529 |
</div>
|
|
|
530 |
"""
|
531 |
|
532 |
TEMPLATE_CACHE = gr.HTML(value=html_content)
|
|
|
452 |
if TEMPLATE_CACHE:
|
453 |
return TEMPLATE_CACHE
|
454 |
|
455 |
+
json_data = load_json_data()
|
456 |
+
initial_items = json_data[:12] # 초기 12개
|
457 |
+
remaining_items = json_data[12:] # 나머지 항목들
|
458 |
|
459 |
html_content = """
|
460 |
<style>
|
|
|
502 |
padding: 8px;
|
503 |
border-radius: 4px;
|
504 |
}
|
505 |
+
#loadMore {
|
506 |
+
display: block;
|
507 |
+
margin: 20px auto;
|
508 |
+
padding: 10px 20px;
|
509 |
+
background: #1890ff;
|
510 |
+
color: white;
|
511 |
+
border: none;
|
512 |
+
border-radius: 4px;
|
513 |
+
cursor: pointer;
|
514 |
+
}
|
515 |
+
#loadMore:hover {
|
516 |
+
background: #40a9ff;
|
517 |
+
}
|
518 |
+
.loading {
|
519 |
+
text-align: center;
|
520 |
+
padding: 20px;
|
521 |
+
display: none;
|
522 |
+
}
|
523 |
</style>
|
524 |
<div class="prompt-grid" id="promptGrid">
|
525 |
"""
|
526 |
|
527 |
+
# 초기 12개 아이템 추가
|
528 |
+
for item in initial_items:
|
529 |
html_content += f"""
|
530 |
<div class="prompt-card" onclick="copyToInput(this)" data-prompt="{html.escape(item.get('prompt', ''))}">
|
531 |
<img src="{item.get('image_url', '')}" class="card-image" loading="lazy" alt="{html.escape(item.get('name', ''))}">
|
|
|
534 |
</div>
|
535 |
"""
|
536 |
|
537 |
+
# 나머지 아이템들을 JavaScript 데이터로 저장
|
538 |
+
html_content += f"""
|
539 |
<script>
|
540 |
+
const remainingItems = {json.dumps(remaining_items)};
|
541 |
+
let currentIndex = 0;
|
542 |
+
const ITEMS_PER_LOAD = 12;
|
543 |
+
|
544 |
+
function copyToInput(card) {{
|
545 |
const prompt = card.dataset.prompt;
|
546 |
const textarea = document.querySelector('.ant-input-textarea-large textarea');
|
547 |
+
if (textarea) {{
|
548 |
textarea.value = prompt;
|
549 |
+
textarea.dispatchEvent(new Event('input', {{ bubbles: true }}));
|
550 |
document.querySelector('.session-drawer .close-btn').click();
|
551 |
+
}}
|
552 |
+
}}
|
553 |
+
|
554 |
+
function loadMoreItems() {{
|
555 |
+
const grid = document.getElementById('promptGrid');
|
556 |
+
const endIndex = Math.min(currentIndex + ITEMS_PER_LOAD, remainingItems.length);
|
557 |
+
|
558 |
+
for (let i = currentIndex; i < endIndex; i++) {{
|
559 |
+
const item = remainingItems[i];
|
560 |
+
const card = document.createElement('div');
|
561 |
+
card.className = 'prompt-card';
|
562 |
+
card.onclick = () => copyToInput(card);
|
563 |
+
card.dataset.prompt = item.prompt;
|
564 |
+
|
565 |
+
card.innerHTML = `
|
566 |
+
<img src="${{item.image_url}}" class="card-image" loading="lazy" alt="${{item.name}}">
|
567 |
+
<div class="card-name">${{item.name}}</div>
|
568 |
+
<div class="card-prompt">${{item.prompt}}</div>
|
569 |
+
`;
|
570 |
+
|
571 |
+
grid.appendChild(card);
|
572 |
+
}}
|
573 |
+
|
574 |
+
currentIndex = endIndex;
|
575 |
+
|
576 |
+
// 모든 아이템을 로드했으면 버튼 숨기기
|
577 |
+
if (currentIndex >= remainingItems.length) {{
|
578 |
+
document.getElementById('loadMore').style.display = 'none';
|
579 |
+
}}
|
580 |
+
}}
|
581 |
+
|
582 |
+
// 스크롤 이벤트 리스너 추가
|
583 |
+
document.querySelector('.session-drawer').addEventListener('scroll', function(e) {{
|
584 |
+
const drawer = e.target;
|
585 |
+
if (drawer.scrollHeight - drawer.scrollTop - drawer.clientHeight < 100) {{
|
586 |
+
loadMoreItems();
|
587 |
+
}}
|
588 |
+
}});
|
589 |
</script>
|
590 |
</div>
|
591 |
+
<div class="loading">Loading more items...</div>
|
592 |
"""
|
593 |
|
594 |
TEMPLATE_CACHE = gr.HTML(value=html_content)
|