Spaces:
Running
on
Zero
Running
on
Zero
Update breed_recommendation.py
Browse files- breed_recommendation.py +42 -61
breed_recommendation.py
CHANGED
@@ -530,89 +530,69 @@ def create_recommendation_tab(UserPreferences, get_breed_recommendations, format
|
|
530 |
elem_id="recommendation-output"
|
531 |
)
|
532 |
|
533 |
-
def on_find_match_click(*args)
|
534 |
-
"""
|
535 |
-
處理推薦按鈕點擊事件的函數
|
536 |
-
使用生成器來處理中間狀態和最終結果
|
537 |
-
"""
|
538 |
try:
|
539 |
-
#
|
540 |
-
|
541 |
-
<div style="
|
542 |
text-align: center;
|
543 |
padding: 20px;
|
|
|
544 |
background: linear-gradient(to right, rgba(66, 153, 225, 0.1), rgba(72, 187, 120, 0.1));
|
545 |
border-radius: 10px;
|
546 |
-
|
547 |
-
animation: fadeIn 0.5s ease-in-out;
|
548 |
">
|
549 |
<div style="font-size: 40px; margin-bottom: 10px;">🐕</div>
|
550 |
<div style="
|
551 |
color: #2D3748;
|
552 |
font-size: 1.2em;
|
553 |
-
margin-bottom:
|
554 |
font-weight: 500;
|
555 |
">Finding your perfect match...</div>
|
556 |
-
|
557 |
-
<!-- 進度指示動畫 -->
|
558 |
-
<div style="
|
559 |
display: flex;
|
560 |
justify-content: center;
|
561 |
gap: 8px;
|
562 |
margin: 15px 0;
|
563 |
">
|
564 |
-
<
|
565 |
-
width:
|
566 |
-
height:
|
567 |
background: #4299e1;
|
568 |
border-radius: 50%;
|
569 |
-
|
570 |
-
animation
|
571 |
-
"></
|
572 |
-
<
|
573 |
-
width:
|
574 |
-
height:
|
575 |
background: #4299e1;
|
576 |
border-radius: 50%;
|
577 |
-
|
578 |
-
animation
|
579 |
-
"></
|
580 |
-
<
|
581 |
-
width:
|
582 |
-
height:
|
583 |
background: #4299e1;
|
584 |
border-radius: 50%;
|
585 |
-
|
586 |
-
animation
|
587 |
-
"></
|
588 |
</div>
|
589 |
-
|
590 |
-
|
591 |
-
|
592 |
-
|
593 |
-
|
594 |
-
|
595 |
-
margin-top: 10px;
|
596 |
-
">Analyzing your preferences and our database of good boys and girls...</div>
|
597 |
</div>
|
598 |
-
|
599 |
-
|
600 |
-
|
601 |
-
|
602 |
-
|
603 |
-
|
604 |
-
|
605 |
-
@keyframes fadeIn {
|
606 |
-
from { opacity: 0; }
|
607 |
-
to { opacity: 1; }
|
608 |
-
}
|
609 |
-
</style>
|
610 |
-
""")
|
611 |
-
|
612 |
-
# 添加短暫延遲使 loading 動畫可見
|
613 |
-
yield asyncio.sleep(1)
|
614 |
-
|
615 |
-
# 創建用戶偏好對象並獲取推薦
|
616 |
user_prefs = UserPreferences(
|
617 |
living_space=args[0],
|
618 |
yard_access=args[1],
|
@@ -681,8 +661,7 @@ def create_recommendation_tab(UserPreferences, get_breed_recommendations, format
|
|
681 |
font-size: 1.1em;
|
682 |
margin: 0;
|
683 |
">
|
684 |
-
🐾 Oops! Something went wrong
|
685 |
-
<br>Please try again!
|
686 |
</p>
|
687 |
</div>
|
688 |
""")
|
@@ -702,7 +681,9 @@ def create_recommendation_tab(UserPreferences, get_breed_recommendations, format
|
|
702 |
children_age,
|
703 |
noise_tolerance
|
704 |
],
|
705 |
-
outputs=recommendation_output
|
|
|
|
|
706 |
)
|
707 |
|
708 |
# 返回頁面組件
|
|
|
530 |
elem_id="recommendation-output"
|
531 |
)
|
532 |
|
533 |
+
def on_find_match_click(*args):
|
|
|
|
|
|
|
|
|
534 |
try:
|
535 |
+
# 立即顯示處理狀態
|
536 |
+
status_html = """
|
537 |
+
<div id="loading-status" style="
|
538 |
text-align: center;
|
539 |
padding: 20px;
|
540 |
+
margin: 20px 0;
|
541 |
background: linear-gradient(to right, rgba(66, 153, 225, 0.1), rgba(72, 187, 120, 0.1));
|
542 |
border-radius: 10px;
|
543 |
+
opacity: 1;
|
|
|
544 |
">
|
545 |
<div style="font-size: 40px; margin-bottom: 10px;">🐕</div>
|
546 |
<div style="
|
547 |
color: #2D3748;
|
548 |
font-size: 1.2em;
|
549 |
+
margin-bottom: 10px;
|
550 |
font-weight: 500;
|
551 |
">Finding your perfect match...</div>
|
552 |
+
<div id="status-dots" style="
|
|
|
|
|
553 |
display: flex;
|
554 |
justify-content: center;
|
555 |
gap: 8px;
|
556 |
margin: 15px 0;
|
557 |
">
|
558 |
+
<span style="
|
559 |
+
width: 10px;
|
560 |
+
height: 10px;
|
561 |
background: #4299e1;
|
562 |
border-radius: 50%;
|
563 |
+
display: inline-block;
|
564 |
+
animation: pulse 1s infinite;
|
565 |
+
"></span>
|
566 |
+
<span style="
|
567 |
+
width: 10px;
|
568 |
+
height: 10px;
|
569 |
background: #4299e1;
|
570 |
border-radius: 50%;
|
571 |
+
display: inline-block;
|
572 |
+
animation: pulse 1s infinite .2s;
|
573 |
+
"></span>
|
574 |
+
<span style="
|
575 |
+
width: 10px;
|
576 |
+
height: 10px;
|
577 |
background: #4299e1;
|
578 |
border-radius: 50%;
|
579 |
+
display: inline-block;
|
580 |
+
animation: pulse 1s infinite .4s;
|
581 |
+
"></span>
|
582 |
</div>
|
583 |
+
<style>
|
584 |
+
@keyframes pulse {
|
585 |
+
0%, 100% { transform: scale(1); opacity: 1; }
|
586 |
+
50% { transform: scale(1.5); opacity: 0.7; }
|
587 |
+
}
|
588 |
+
</style>
|
|
|
|
|
589 |
</div>
|
590 |
+
"""
|
591 |
+
|
592 |
+
# 返回載入狀態
|
593 |
+
yield gr.HTML(status_html)
|
594 |
+
|
595 |
+
# 建立用戶偏好
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
596 |
user_prefs = UserPreferences(
|
597 |
living_space=args[0],
|
598 |
yard_access=args[1],
|
|
|
661 |
font-size: 1.1em;
|
662 |
margin: 0;
|
663 |
">
|
664 |
+
🐾 Oops! Something went wrong. Please try again!
|
|
|
665 |
</p>
|
666 |
</div>
|
667 |
""")
|
|
|
681 |
children_age,
|
682 |
noise_tolerance
|
683 |
],
|
684 |
+
outputs=recommendation_output,
|
685 |
+
show_progress=True, # 顯示進度
|
686 |
+
queue=False # 允許連續點擊
|
687 |
)
|
688 |
|
689 |
# 返回頁面組件
|