pp-bot
|
7ae26b3368
|
docs(recent-calls): 架构文档补充(#42~#44)
新增 Doc/recent_calls_architecture.md:
- 功能范围、目录结构、数据流图
- API 端点 /app/api/call/records 字段映射表
- 通话状态枚举(0-6)与未接来电判断逻辑
- ViewModel 设计、UI 结构、路由说明
- 设计决策(无用户名映射、全量拉取、离线可用)
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
|
2026-03-24 20:32:27 +09:00 |
|
pp-bot
|
8744e2c0b7
|
feat(settings): 收藏列表 + 最近呼叫全量实现(#42~#45)
## 收藏(Gitea #42~#45)
- `FetchFavoritesRequest` / `DeleteFavoriteRequest`:ApiRequestable,对齐 iOS FavouriteService
- `FetchFavoritesUseCase`:GET 分页拉取 → upsert FavoriteRepository
- `DeleteFavoriteUseCase`:POST delete → 同步删本地 DB
- `FavoritesViewModel`:分页/刷新/加载更多/删除,DB Stream 驱动
- `FavoritesPage`:列表 + RefreshIndicator + Dismissible 左滑删除 + 类型图标 + 空状态
- `AppRouteName.settingsFavorites` + 路由注册 + auth guard
- `settings_page.dart` 收藏行 onTap 接入导航
## 最近呼叫(框架,API 对接待续)
- `CallLogRequest` / `FetchCallLogsUseCase` / `RecentCallsViewModel`
- `RecentCallsPage`:双 Tab(全部/未接)+ _CallLogTile(图标/时长/时间)
- `AppRouteName.settingsRecentCalls` + 路由注册
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
|
2026-03-24 20:30:56 +09:00 |
|
pp-bot
|
db10d1fcd2
|
feat(mine): 我的 Tab UI 重设计(#39~#41)
- ProfileHeroCard:72pt 渐变头像(8色 uid%8 主题)、@J{uid} handle、bio 简介、掩码手机号
- AppBar:compact,右侧 QR 图标 + 编辑铅笔
- 彩色图标行(_IconBox 36pt 圆角)+ 4 卡片组对齐 iOS SettingsView
- 账户:我的钱包 / 账户安全
- 工具:收藏 / 最近呼叫 / 链接设备 / 聊天文件夹
- 偏好设置:通知和声音 / 隐私设置 / 黑名单 / 语言 / 主题
- 关于:用户协议 / 隐私政策 / 版本号
- SettingsState 增加 bio 字段(#41),loadProfile 同步赋值
- Doc/mine_tab_architecture.md 补充 UI 重设计章节(§7)
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
|
2026-03-24 20:14:34 +09:00 |
|
pp-bot
|
2eb2299709
|
fix: 修复多图消息无法显示的三个根因
根因 1 — MessageItem.toEntity() id=0 主键碰撞:
WS 拉取的每条消息均用 id=0 insertOrReplace,批量消息相互覆盖,
DB 中只留最后一条。改为 id=messageId(服务端唯一 ID)。
根因 2 — SendMessageUseCase 乐观写入 id=0 碰撞:
批量图片发送时所有乐观行共享 id=0,逐条覆盖。
改用负微秒时间戳作为临时唯一 id,HTTP 确认后用真实 messageId 替换。
根因 3 — watchByChatId 无 ORDER BY:
DB 消息顺序不确定,宫格分组算法依赖时间升序失败。
在 MessageRepositoryImpl.watchByChatId 及 _buildDisplayItems 中
分别按 sendTime ASC + chatIdx ASC 排序。
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
|
2026-03-24 15:45:41 +09:00 |
|
pp-bot
|
2354e92c64
|
feat: 多图宫格气泡全量实现 (#36~#38)
- #36 ImageGridBubble: 2 列×116pt / 3 列×78pt, 3pt 间距, 8pt 外层/4pt 单格圆角, tap→ImageViewerPage
- #37 ChatDisplayItem + _buildDisplayItems: 连续 typ=2 同 sendId Δt<5s 分组为宫格,iOS ChatView.buildDisplayItems parity
- #38 SendImageUseCase.sendBatch: Future.wait 并行上传 → 顺序快速发送,ImagePickerSheet 改用 sendBatch
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
|
2026-03-24 14:09:27 +09:00 |
|
pp-bot
|
b971900263
|
feat: 图片预览与发送全量实现 (#31~#35)
- #31 ImageMessageBubble: typ=2 气泡,max 220pt / min 80pt 尺寸规则,进度环叠层
- #32 ImageViewerPage: photo_view 全屏查看,PhotoViewGallery 多图滑动,保存+分享工具栏
- #33 ImagePickerSheet + SendImageUseCase: 相册/相机选图(最多9张),裁剪,dart:ui 解析宽高,FormData CDN 上传,typ=2 发送
- #34 image_cropper 接入:_PreviewTile 点击裁剪,iOS TOCropViewController 对齐
- #35 _MessageBubble BubbleKind 路由:typ switch → 各媒体气泡,输入栏新增附件按钮
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
|
2026-03-24 13:20:56 +09:00 |
|
pp-bot
|
23fc6b0c86
|
feat: WebView/媒体/红包详情全量实现 (#25~#30)
#25 MiniAppWebViewPage + MiniAppRouter
- webview_flutter 加载 {apiBaseUrl}/miniapp/{appId}/index.html?gameId=...&token=...
- MiniAppFloatButton 接收 chatId/chatType,默认打开 WebView
- BannerState 新增 appId 字段,由 GameBannerData.appId 填充
#26 open_filex 文件打开
- FileMessageBubble 下载完成后调用 OpenFilex.open(localPath)
- 打开失败时 SnackBar 提示
#27 audioplayers 音频播放
- AudioPlaybackService(Notifier):单例 AudioPlayer,togglePlay/pause/seek
- AudioMessageBubble 接入:播放态图标切换、进度 mm:ss 显示
#28 video_player + chewie 视频全屏
- VideoPlayerPage:本地文件 / HTTP 双模,chewie 控制栏
- VideoMessageBubble 默认 onTap → push VideoPlayerPage
#29 红包领取排行榜详情页
- GET /payment/rp/detail → RpDetailData + RpRecordItem DTO
- GetRpDetailUseCase + getRpDetailUseCaseProvider
- RedEnvelopeDetailSheet:汇总行 + 领取排行列表,头像/昵称/金额/时间
#30 MINE_RP 地雷红包发包 UI
- _RpType 新增 mine(MINE_RP),显示地雷金额输入框
- SendRpRequest.parameters 携带 mineAmount
- RedEnvelopeBubble:非活跃状态直接打开详情,活跃状态领取后打开排行榜
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
|
2026-03-24 12:53:55 +09:00 |
|
pp-bot
|
e715a0673b
|
feat(chat): 发收消息全量实现 (#25~#28)
- 移除 @riverpod/@freezed 注解依赖,全部改为手写 Provider(无需 build_runner)
· LoginState 改为纯 Dart,LoginViewModel/ThemeViewModel/ChatViewModel 改为 Notifier
· UserNotifier 改为 FamilyAsyncNotifier<User?,int>,mini_app_provider 改为手写 Provider
· 15 个 StreamProvider/StreamProvider.family 从 @riverpod 迁移至手写
- 发送消息(#25)
· SendMessageRequest/SendMessageResponse DTO
· SendMessageUseCase:乐观写入 DB → HTTP POST → 更新 Chat 摘要
- 接收消息 WS(#26)
· WsMessageService:监听 mode2 WS 帧 → HTTP 补拉 → DB 写入 → Chat 更新
· FetchHistoryRequest/FetchHistoryResponse DTO(GET /app/api/chat/history)
· FetchHistoryUseCase:拉取 → insertOrReplaceAll
- DI 装配(chat_service_providers.dart)
· wsMessageServiceProvider、sendMessageUseCaseProvider、fetchHistoryUseCaseProvider
- 聊天列表页(#27)
· ChatListViewModel(Notifier<void>)+ chat_page.dart 真实会话列表 UI
· ListTile:头像首字母、最新消息摘要、未读角标、时间格式化
- 聊天详情页(#28)
· ChatDetailViewModel(FamilyNotifier<ChatDetailState,int>)+ chat_detail_page.dart
· 消息气泡(自己/他人分左右)、底部输入框、发送状态与错误提示
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
|
2026-03-23 23:16:44 +09:00 |
|
pp-bot
|
d9539d391c
|
feat(redpacket): 红包与游戏横幅全量实现 (#19~#24)
- #19 fix: SendRedEnvelopeUseCase 动态取 currencyType(workspaceId>0 取
workspace.currency,修复 iOS 硬编码 PEA → 150001 错误)
- #20: RedEnvelopeBubble typ=8,四态(橙色领取/已领/过期/抢完)+ 领取按钮
- #21: ReceiveRedEnvelopeUseCase POST /app/api/wallet/rp/receive,
typed JSON body(避免 code=30007),SnackBar 反馈
- #22: SendRedEnvelopeSheet BottomSheet,STANDARD_RP + LUCKY_RP,
发送成功后构建 typ=8 content JSON 回调给 ChatPage
- #23: BannerViewModel Notifier,Group.topic 双格式解析(JSON object/string),
FetchBannerUseCase + Timer 倒计时 + applyNewRound WS 接口
- #24: BannerView 游戏横幅条(状态/倒计时/上期结果),
MiniAppFloatButton 悬浮按钮(hasGame 显示/隐藏,onTap TODO #25)
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
|
2026-03-23 23:11:29 +09:00 |
|
pp-bot
|
83774f5f61
|
feat(file-download): 文件下载全量实现 (#14~#18)
- CdnUrlResolver: 相对路径/S3 URL 统一解析为 apiBaseUrl 代理链路 (#14)
- FileDownloadManager: Notifier<Map<url, state>>,四态(idle/progress/done/failed),
断点续传 + 取消令牌 + 本地缓存(systemTemp/im_file_cache) (#15)
- FileMessageBubble: 三态 UI,文件类型图标/颜色,大小格式化,
idle/failed 点击触发下载,done 点击回调 open_filex TODO (#16)
- AudioMessageBubble: 语音消息下载框架,静态波形装饰,
播放 TODO(audioplayers 接入后解开) (#17)
- VideoMessageBubble: 缩略图 Image.network + CdnUrlResolver,
播放按钮覆盖,上传进度环,video_player 接入 TODO (#18)
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
|
2026-03-23 20:02:46 +09:00 |
|
pp-bot
|
aeeda6f059
|
feat(mine): 我的 Tab 全量实现 (#5~#13)
从 im-client-ios-swift-demo 搬运 Settings 逻辑,对齐 Gitea issue #5–#13
## 基础设施
- AuthNotifier 新增 currentUid 字段,login() 接受 uid 参数 (#5)
- LoginViewModel 登录成功后传入 user.uid
- ApiPaths 补充 account/block/store 系列路径
- Tab 重命名"设置"→"我的",icon 改为 person_outline (#5)
- AppRouteName 新增5条子路由 (edit-profile/blocklist/language/network-diagnostics/about)
- app_router + auth_guard 同步注册新路由
## Settings Feature
- SettingsViewModel 重写为 NotifierProvider(去除 @riverpod 依赖)
- build() 自动触发 loadProfile()
- logout() 完整流程:API → WS 断开 → DB 关闭 → AuthNotifier
- 6 个 navigateTo* 方法
- SettingsPage 完整 UI:资料卡 / 偏好设置 / 工具 / 关于 / 退出登录按钮 (#5 #7)
- FetchProfileUseCase: GET /app/api/user/profile (#5)
- LogoutUseCase: logout + disconnect + closeDatabase (#7)
- UpdateProfileUseCase + UpdateProfileRequest: POST /app/api/user/update-profile (#6)
- EditProfilePage + EditProfileViewModel: 昵称/bio 编辑 (#6)
- LanguagePage: 语言选择 UI 框架,l10n_sdk 待接入 (#9)
- BlocklistPage: 黑名单框架,API 待实现 (#10)
- NetworkDiagnosticsPage + ViewModel: 四步诊断(连通/TCP/DNS/HTTPS)(#12)
- AboutPage: 版本号 + 服务条款/隐私政策入口 (#13)
- settings_providers.dart: 扩展 DI 装配
## 文档
- Doc/mine_tab_architecture.md: 架构说明、数据流、路由、待完成事项
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
|
2026-03-23 17:20:51 +09:00 |
|
cody
|
33c31b87ac
|
Merge pull request '网络 SDK 包含中间生成代码,更新脚本,升级版本号,隔离 pre-commit 脚本范围' (#23) from cody/network_SDK/update-script into dev
Reviewed-on: https://gitea.winwayinfo.com/CUS-IM/customer-im-client/pulls/23
|
2026-03-10 19:24:49 +08:00 |
|
Cody
|
db8d269944
|
网络 SDK 包含中间生成代码,更新脚本,升级版本号,隔离 pre-commit 脚本范围
|
2026-03-10 19:22:58 +08:00 |
|
cody
|
890e102543
|
Merge pull request 'Update:修正publish腳本' (#22) from ethan/sdk/script/update_publish_script into dev
Reviewed-on: https://gitea.winwayinfo.com/CUS-IM/customer-im-client/pulls/22
|
2026-03-10 18:07:49 +08:00 |
|
ethan
|
2f380a7619
|
Update:
1.修正publish腳本
|
2026-03-10 18:06:03 +08:00 |
|
cody
|
0775bd1843
|
Merge pull request 'Test sdk update' (#21) from ethan/sdk/cipher_guard_sdk/version_test into dev
Reviewed-on: https://gitea.winwayinfo.com/CUS-IM/customer-im-client/pulls/21
|
2026-03-10 17:47:39 +08:00 |
|
ethan
|
a48a69ae5d
|
test sdk update
|
2026-03-10 17:44:31 +08:00 |
|
cody
|
238616b976
|
Merge pull request 'bump sdk version' (#18) from happi/dev/update-storage-sdk into dev
Reviewed-on: https://gitea.winwayinfo.com/CUS-IM/customer-im-client/pulls/18
|
2026-03-10 17:12:48 +08:00 |
|
Happi (哈比)
|
654f6e28c9
|
bump sdk version
|
2026-03-10 17:12:14 +08:00 |
|
cody
|
9c0f01da1e
|
Merge pull request '脚本更新' (#17) from cody/script-update into dev
Reviewed-on: https://gitea.winwayinfo.com/CUS-IM/customer-im-client/pulls/17
|
2026-03-10 16:52:59 +08:00 |
|
Cody
|
270abf4741
|
脚本更新
|
2026-03-10 16:52:41 +08:00 |
|
cody
|
5240ea810b
|
Merge pull request '升级 ws 解密 SDK 版本' (#16) from cody/upgrade—protocol-SDK-version into dev
Reviewed-on: https://gitea.winwayinfo.com/CUS-IM/customer-im-client/pulls/16
|
2026-03-10 16:49:56 +08:00 |
|
Cody
|
b058127173
|
升级 ws 解密 SDK 版本
|
2026-03-10 16:49:35 +08:00 |
|
cody
|
d55fcd1a1d
|
Merge pull request 'Update:主項目和SDK開發流程說明' (#14) from josh/dev/melos/script/sdk_and_main_flow into dev
Reviewed-on: https://gitea.winwayinfo.com/CUS-IM/customer-im-client/pulls/14
|
2026-03-10 15:50:51 +08:00 |
|
ethan
|
92f4632ee2
|
Update:
1.SDK開發流程說明 ReadMe.md
2.主項目開發流程說明
3.新增Sdk發布腳本
4.新增repo鏈結/取消鏈結指令
|
2026-03-10 15:46:27 +08:00 |
|
wangfeng
|
92d41f628a
|
Merge pull request 'Update:主項目分離SDK' (#13) from josh/dev/melos/evn/seperate_app_and_sdk into dev
Reviewed-on: https://gitea.winwayinfo.com/CUS-IM/customer-im-client/pulls/13
|
2026-03-10 14:24:59 +08:00 |
|
wangfeng
|
f82a01ab8d
|
Merge pull request '所有数据库表,提供相应的provider、桥接等方法' (#12) from happi/dev/database-update into dev
Reviewed-on: https://gitea.winwayinfo.com/CUS-IM/customer-im-client/pulls/12
|
2026-03-10 13:38:33 +08:00 |
|
Happi (哈比)
|
5eaff7ede3
|
同步dbretry接口
|
2026-03-10 12:49:49 +08:00 |
|
ethan
|
13126a99e0
|
Fix:
1.sdk位置
2.dart_jsonwebtoken本版適配cipher_guard_sdk版本.
|
2026-03-10 12:48:41 +08:00 |
|
Happi (哈比)
|
1c996075e3
|
更新upsert
|
2026-03-10 12:41:02 +08:00 |
|
ethan
|
c8ebf1abfb
|
Separate app and sdk
|
2026-03-10 12:30:07 +08:00 |
|
Happi (哈比)
|
56bdae8db3
|
Merge branch 'dev' into happi/dev/database-update
|
2026-03-10 12:10:26 +08:00 |
|
Happi (哈比)
|
8130bf63fa
|
所有数据库表,提供相应的provider、桥接等方法
|
2026-03-10 12:09:45 +08:00 |
|
wangfeng
|
c80b4245b7
|
Merge pull request '颜色,基础组件重新封装,降低理解难度,分层更明显。入口更抽象' (#11) from cody/UI_base_Refactor into dev
Reviewed-on: https://gitea.winwayinfo.com/CUS-IM/customer-im-client/pulls/11
|
2026-03-10 10:55:09 +08:00 |
|
Cody
|
e6e81e046f
|
更新架构文档
|
2026-03-10 10:24:34 +08:00 |
|
Cody
|
ed93d556d6
|
颜色,基础组件重新封装,降低理解难度,分层更明显。入口更抽象
|
2026-03-10 09:38:07 +08:00 |
|
wangfeng
|
ea3192bd65
|
Merge pull request '业务更新User所需(企业成员、聊天室群组成员)' (#10) from happi/dev/database-update into dev
Reviewed-on: https://gitea.winwayinfo.com/CUS-IM/customer-im-client/pulls/10
|
2026-03-09 20:26:47 +08:00 |
|
Happi (哈比)
|
084b7bbd23
|
Merge branch 'dev' into happi/dev/database-update
# Conflicts:
# apps/im_app/lib/features/login/presentation/login_view_model.dart
|
2026-03-09 20:17:03 +08:00 |
|
Happi (哈比)
|
e29caed253
|
更新
|
2026-03-09 19:39:18 +08:00 |
|
wangfeng
|
049f068e32
|
Merge pull request 'feat(Core UI): common 常量' (#7) from dk/dev-0307 into dev
Reviewed-on: https://gitea.winwayinfo.com/CUS-IM/customer-im-client/pulls/7
|
2026-03-09 19:33:21 +08:00 |
|
wangfeng
|
61c3bfcdc6
|
Merge pull request '网络请求打通,ws 打通' (#9) from cody/network_demo into dev
Reviewed-on: https://gitea.winwayinfo.com/CUS-IM/customer-im-client/pulls/9
|
2026-03-09 19:32:11 +08:00 |
|
Happi (哈比)
|
790d7453ca
|
Merge branch 'dev' into happi/dev/database-update
|
2026-03-09 19:16:12 +08:00 |
|
Happi (哈比)
|
8f77a14818
|
业务更新User所需(企业成员、聊天室群组成员)
|
2026-03-09 19:15:51 +08:00 |
|
Cody
|
3c1976b343
|
网络请求打通,ws 打通
|
2026-03-09 19:05:55 +08:00 |
|
DK
|
68a43b3613
|
feat(Core UI): 白天黑夜模式
|
2026-03-09 16:48:07 +08:00 |
|
wangfeng
|
997d821447
|
Merge pull request 'User表结构和数据同步完全按照架构进行调整 + 新增改、删案例' (#8) from happi/dev/database-update into dev
Reviewed-on: https://gitea.winwayinfo.com/CUS-IM/customer-im-client/pulls/8
|
2026-03-09 16:22:39 +08:00 |
|
DK
|
59a866e540
|
feat(Core UI): 基础定义
|
2026-03-09 15:39:46 +08:00 |
|
Happi (哈比)
|
c278d1329e
|
Merge branch 'dev' into happi/dev/database-update
# Conflicts:
# apps/im_app/lib/data/models/user_dto.dart
# apps/im_app/lib/data/remote/login_request.dart
# apps/im_app/lib/features/chat/presentation/chat_db_test_view_model.dart
# apps/im_app/lib/features/chat/view/chat_db_test_page.dart
# apps/im_app/lib/features/login/presentation/login_view_model.dart
|
2026-03-09 15:08:45 +08:00 |
|
Happi (哈比)
|
fe54f79b21
|
数据和测试案例按照架构来处理
|
2026-03-09 14:59:29 +08:00 |
|
Happi (哈比)
|
7b78da86e7
|
更新测试案例
|
2026-03-09 13:03:44 +08:00 |
|