From c7d5be908e24ee7677140c1cf983836f2e413cf0 Mon Sep 17 00:00:00 2001
From: zhaoqingang <zhaoqg0118@163.com>
Date: 星期二, 10 十二月 2024 18:26:20 +0800
Subject: [PATCH] 会话菜单增加

---
 app/service/dialog.py |   19 +++++++++++++++++--
 1 files changed, 17 insertions(+), 2 deletions(-)

diff --git a/app/service/dialog.py b/app/service/dialog.py
index 8e1d265..d78fbbe 100644
--- a/app/service/dialog.py
+++ b/app/service/dialog.py
@@ -5,7 +5,7 @@
 from Log import logger
 
 
-async def get_dialog_list(db, user_id):
+async def get_dialog_list(db, user_id, keyword, page_size, page_index):
     user = db.query(UserModel).filter(UserModel.id == user_id).first()
     if user is None:
         return {"rows": []}
@@ -23,7 +23,22 @@
                 group_dialog_table.c.group_id.in_(group_list)
             )
         )
-    return {"rows": [kld.to_json() for kld in query.all()]}
+    if keyword:
+        query = query.filter(DialogModel.name.like('%{}%'.format(keyword)))
+    total = query.count()
+    if page_size:
+        query = query.limit(page_size).offset((page_index - 1) * page_size)
+
+    rows = []
+    user_id_set = set()
+    for kld in query.all():
+        user_id_set.add(kld.tenant_id)
+        rows.append(kld.to_json())
+    print(rows)
+    user_dict = {i.id: i.to_dict() for i in db.query(UserModel).filter(UserModel.id.in_(user_id_set)).all()}
+    for r in rows:
+        r["user"] = user_dict.get(r["user_id"], {})
+    return {"total":  total, "rows": rows}
 
 
 async def update_session_history(db, data: dict, user_id):

--
Gitblit v1.8.0