Преглед на файлове

✨fix: has_more logic in ChatMessageListApi to ensure correct on behavior when no more messages are available. (#24661)

tags/1.8.1
Eric Guo преди 2 месеца
родител
ревизия
ecf74d91e2
No account linked to committer's email address
променени са 1 файла, в които са добавени 12 реда и са изтрити 8 реда
  1. 12
    8
      api/controllers/console/app/message.py

+ 12
- 8
api/controllers/console/app/message.py Целия файл

@@ -95,18 +95,22 @@ class ChatMessageListApi(Resource):
.all()
)

# Initialize has_more based on whether we have a full page
if len(history_messages) == args["limit"]:
current_page_first_message = history_messages[-1]

has_more = db.session.scalar(
select(
exists().where(
Message.conversation_id == conversation.id,
Message.created_at < current_page_first_message.created_at,
Message.id != current_page_first_message.id,
# Check if there are more messages before the current page
has_more = db.session.scalar(
select(
exists().where(
Message.conversation_id == conversation.id,
Message.created_at < current_page_first_message.created_at,
Message.id != current_page_first_message.id,
)
)
)
)
else:
# If we don't have a full page, there are no more messages
has_more = False

history_messages = list(reversed(history_messages))


Loading…
Отказ
Запис