tuikit-atomicx-vue3 0.1.1 → 3.3.0-beta.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (455) hide show
  1. package/dist/MessageInput.vue_vue_type_script_setup_true_lang-XRL7A5Gj.js +123 -0
  2. package/dist/{PopoverTrigger-ByOI-vdB.js → PopoverTrigger-BKOIHfdS.js} +1 -1
  3. package/dist/{PopperContent-BaiCn-CA.js → PopperContent-DtL7HVWz.js} +29 -21
  4. package/dist/baseComp/TuiSwitch.js +2 -2
  5. package/dist/baseComp/index.d.ts +0 -1
  6. package/dist/baseComp/index.js +1 -3
  7. package/dist/chat/index.d.ts +2230 -4090
  8. package/dist/chat/index.js +16 -8
  9. package/dist/components/Avatar/Avatar.js +35 -10
  10. package/dist/components/Avatar/Avatar.vue.d.ts +1 -1
  11. package/dist/components/BarrageInput/BarrageInput.vue.d.ts +2 -2
  12. package/dist/components/BarrageInput/BarrageInputH5.js +30 -10
  13. package/dist/components/BarrageInput/BarrageInputH5.vue.d.ts +2 -2
  14. package/dist/components/BarrageInput/EmojiPicker/EmojiPicker.js +1 -1
  15. package/dist/components/BarrageInput/TextEditor/index.js +13 -5
  16. package/dist/components/BarrageInput/constants.d.ts +3 -0
  17. package/dist/components/BarrageInput/constants.js +6 -0
  18. package/dist/components/BarrageInput/i18n/en-US/index.d.ts +2 -0
  19. package/dist/components/BarrageInput/i18n/en-US/index.js +3 -1
  20. package/dist/components/BarrageInput/i18n/zh-CN/index.d.ts +2 -0
  21. package/dist/components/BarrageInput/i18n/zh-CN/index.js +3 -1
  22. package/dist/components/BarrageInput/index.d.ts +18 -18
  23. package/dist/components/BarrageList/BarrageList.js +5 -6
  24. package/dist/components/BarrageList/BarrageListH5.js +5 -6
  25. package/dist/components/BarrageList/Message/MessageLayout/MessageLayout.js +1 -1
  26. package/dist/components/BarrageList/Message/MessageLayout/MessageMeta/MessageMeta.js +5 -4
  27. package/dist/components/BarrageList/Message/MessageLayout/MessageMeta/MessageMeta.vue.d.ts +2 -2
  28. package/dist/components/BarrageList/Message/MessageLayout/MessageMeta/MessageStatusIcon.js +7 -4
  29. package/dist/components/BarrageList/Message/TextMessage/TextMessage.js +1 -1
  30. package/dist/components/ChatSetting/ChatSetting.js +8 -11
  31. package/dist/components/ChatSetting/GroupChatSetting/GroupActions/GroupActions.js +2 -1
  32. package/dist/components/ChatSetting/GroupChatSetting/GroupChatSetting.js +2 -1
  33. package/dist/components/ChatSetting/GroupChatSetting/GroupInfo/GroupInfo.js +2 -2
  34. package/dist/components/ChatSetting/GroupChatSetting/GroupManagement/GroupManagement.js +2 -1
  35. package/dist/components/ChatSetting/GroupChatSetting/GroupMembers/GroupMembers.js +2 -2
  36. package/dist/components/ChatSetting/SettingItem/SettingItem.js +116 -89
  37. package/dist/components/ChatSetting/i18n/index.d.ts +191 -1
  38. package/dist/components/ChatSetting/i18n/index.js +3 -4
  39. package/dist/components/ChatSetting/index.js +4 -0
  40. package/dist/components/ContactList/ContactInfo/BlacklistInfo/BlacklistInfo.js +78 -0
  41. package/dist/components/ContactList/ContactInfo/BlacklistInfo/BlacklistInfo.vue.d.ts +33 -0
  42. package/dist/components/ContactList/ContactInfo/BlacklistInfo/index.d.ts +1 -0
  43. package/dist/components/ContactList/ContactInfo/BlacklistInfo/index.js +4 -0
  44. package/dist/components/ContactList/ContactInfo/ContactInfo.js +257 -0
  45. package/dist/components/ContactList/ContactInfo/ContactInfo.vue.d.ts +56 -0
  46. package/dist/components/ContactList/ContactInfo/FriendApplicationInfo/FriendApplicationInfo.js +96 -0
  47. package/dist/components/ContactList/ContactInfo/FriendApplicationInfo/FriendApplicationInfo.vue.d.ts +37 -0
  48. package/dist/components/ContactList/ContactInfo/FriendApplicationInfo/index.d.ts +1 -0
  49. package/dist/components/ContactList/ContactInfo/FriendApplicationInfo/index.js +4 -0
  50. package/dist/components/ContactList/ContactInfo/FriendInfo/FriendInfo.js +228 -0
  51. package/dist/components/ContactList/ContactInfo/FriendInfo/FriendInfo.vue.d.ts +39 -0
  52. package/dist/components/ContactList/ContactInfo/FriendInfo/index.d.ts +1 -0
  53. package/dist/components/ContactList/ContactInfo/FriendInfo/index.js +4 -0
  54. package/dist/components/ContactList/ContactInfo/GroupApplicationInfo/GroupApplicationInfo.js +101 -0
  55. package/dist/components/ContactList/ContactInfo/GroupApplicationInfo/GroupApplicationInfo.vue.d.ts +37 -0
  56. package/dist/components/ContactList/ContactInfo/GroupApplicationInfo/index.d.ts +1 -0
  57. package/dist/components/ContactList/ContactInfo/GroupApplicationInfo/index.js +4 -0
  58. package/dist/components/ContactList/ContactInfo/GroupInfo/GroupInfo.js +154 -0
  59. package/dist/components/ContactList/ContactInfo/GroupInfo/GroupInfo.vue.d.ts +37 -0
  60. package/dist/components/ContactList/ContactInfo/GroupInfo/index.d.ts +1 -0
  61. package/dist/components/ContactList/ContactInfo/GroupInfo/index.js +4 -0
  62. package/dist/components/ContactList/ContactInfo/SearchGroupInfo/SearchGroupInfo.js +141 -0
  63. package/dist/components/ContactList/ContactInfo/SearchGroupInfo/SearchGroupInfo.vue.d.ts +32 -0
  64. package/dist/components/ContactList/ContactInfo/SearchGroupInfo/index.d.ts +1 -0
  65. package/dist/components/ContactList/ContactInfo/SearchGroupInfo/index.js +4 -0
  66. package/dist/components/ContactList/ContactInfo/SearchUserInfo/SearchUserInfo.js +122 -0
  67. package/dist/components/ContactList/ContactInfo/SearchUserInfo/SearchUserInfo.vue.d.ts +33 -0
  68. package/dist/components/ContactList/ContactInfo/SearchUserInfo/index.d.ts +1 -0
  69. package/dist/components/ContactList/ContactInfo/SearchUserInfo/index.js +4 -0
  70. package/dist/components/ContactList/ContactInfo/index.d.ts +8 -0
  71. package/dist/components/ContactList/ContactInfo/index.js +18 -0
  72. package/dist/components/ContactList/ContactList.js +281 -0
  73. package/dist/components/ContactList/ContactList.vue.d.ts +41 -0
  74. package/dist/components/ContactList/ContactListItem/BlacklistItem/BlacklistItem.js +52 -0
  75. package/dist/components/ContactList/ContactListItem/BlacklistItem/BlacklistItem.vue.d.ts +25 -0
  76. package/dist/components/ContactList/ContactListItem/BlacklistItem/index.d.ts +1 -0
  77. package/dist/components/ContactList/ContactListItem/BlacklistItem/index.js +4 -0
  78. package/dist/components/ContactList/ContactListItem/ContactListItem.js +4 -0
  79. package/dist/components/ContactList/ContactListItem/ContactListItem.vue.d.ts +30 -0
  80. package/dist/components/ContactList/ContactListItem/FriendApplicationItem/FriendApplicationItem.js +76 -0
  81. package/dist/components/ContactList/ContactListItem/FriendApplicationItem/FriendApplicationItem.vue.d.ts +27 -0
  82. package/dist/components/ContactList/ContactListItem/FriendApplicationItem/index.d.ts +1 -0
  83. package/dist/components/ContactList/ContactListItem/FriendApplicationItem/index.js +4 -0
  84. package/dist/components/ContactList/ContactListItem/FriendItem/FriendItem.js +53 -0
  85. package/dist/components/ContactList/ContactListItem/FriendItem/FriendItem.vue.d.ts +25 -0
  86. package/dist/components/ContactList/ContactListItem/FriendItem/index.d.ts +1 -0
  87. package/dist/components/ContactList/ContactListItem/FriendItem/index.js +4 -0
  88. package/dist/components/ContactList/ContactListItem/GroupApplicationItem/GroupApplicationItem.js +79 -0
  89. package/dist/components/ContactList/ContactListItem/GroupApplicationItem/GroupApplicationItem.vue.d.ts +27 -0
  90. package/dist/components/ContactList/ContactListItem/GroupApplicationItem/index.d.ts +1 -0
  91. package/dist/components/ContactList/ContactListItem/GroupApplicationItem/index.js +4 -0
  92. package/dist/components/ContactList/ContactListItem/GroupItem/GroupItem.js +52 -0
  93. package/dist/components/ContactList/ContactListItem/GroupItem/GroupItem.vue.d.ts +25 -0
  94. package/dist/components/ContactList/ContactListItem/GroupItem/index.d.ts +1 -0
  95. package/dist/components/ContactList/ContactListItem/GroupItem/index.js +4 -0
  96. package/dist/components/ContactList/ContactListItem/index.d.ts +6 -0
  97. package/dist/components/ContactList/ContactListItem/index.js +95 -0
  98. package/dist/components/ContactList/ContactSearch/ContactSearch.js +85 -0
  99. package/dist/components/ContactList/ContactSearch/ContactSearch.vue.d.ts +8 -0
  100. package/dist/components/ContactList/ContactSearch/index.d.ts +1 -0
  101. package/dist/components/ContactList/ContactSearch/index.js +4 -0
  102. package/dist/components/ContactList/constants/const.d.ts +3 -0
  103. package/dist/components/ContactList/constants/const.js +6 -0
  104. package/dist/components/ContactList/hooks/index.d.ts +1 -0
  105. package/dist/components/ContactList/hooks/index.js +4 -0
  106. package/dist/components/ContactList/hooks/useContactList.d.ts +9 -0
  107. package/dist/components/ContactList/hooks/useContactList.js +18 -0
  108. package/dist/components/ContactList/i18n/en-US.d.ts +77 -0
  109. package/dist/components/ContactList/i18n/en-US.js +80 -0
  110. package/dist/components/ContactList/i18n/index.d.ts +4 -0
  111. package/dist/components/ContactList/i18n/index.js +6 -0
  112. package/dist/components/ContactList/i18n/zh-CN.d.ts +77 -0
  113. package/dist/components/ContactList/i18n/zh-CN.js +80 -0
  114. package/dist/components/ContactList/index.d.ts +310 -0
  115. package/dist/components/ContactList/index.js +16 -0
  116. package/dist/components/ConversationList/ConversationActions/ConversationActions.js +31 -46
  117. package/dist/components/ConversationList/ConversationActions/ConversationActions.vue.d.ts +1 -10
  118. package/dist/components/ConversationList/ConversationCreate/ConversationCreate.js +160 -100
  119. package/dist/components/ConversationList/ConversationCreate/ConversationCreate.vue.d.ts +0 -3
  120. package/dist/components/ConversationList/ConversationCreate/ConversationCreateButton/ConversationCreateButton.js +79 -17
  121. package/dist/components/ConversationList/ConversationCreate/ConversationCreateButton/ConversationCreateButton.vue.d.ts +6 -12
  122. package/dist/components/ConversationList/ConversationCreate/ConversationCreateGroupDetail/ConversationCreateGroupDetail.js +78 -158
  123. package/dist/components/ConversationList/ConversationCreate/ConversationCreateGroupDetail/ConversationCreateGroupDetail.vue.d.ts +5 -4
  124. package/dist/components/ConversationList/ConversationCreate/ConversationCreateUserSelectList/ConversationCreateUserSelectList.js +38 -207
  125. package/dist/components/ConversationList/ConversationCreate/ConversationCreateUserSelectList/ConversationCreateUserSelectList.vue.d.ts +3 -9
  126. package/dist/components/ConversationList/ConversationCreate/ConversationGroupTypeInfo/ConversationGroupTypeInfo.js +35 -23
  127. package/dist/components/ConversationList/ConversationCreate/ConversationGroupTypeInfo/ConversationGroupTypeInfo.vue.d.ts +2 -11
  128. package/dist/components/ConversationList/ConversationCreate/ConversationGroupTypeInfo/index.js +1 -2
  129. package/dist/components/ConversationList/ConversationCreate/ConversationGroupTypeInfo/type.d.ts +2 -7
  130. package/dist/components/ConversationList/ConversationCreate/ConversationGroupTypeInfo/type.js +6 -14
  131. package/dist/components/ConversationList/ConversationCreate/index.d.ts +0 -2
  132. package/dist/components/ConversationList/ConversationCreate/index.js +5 -9
  133. package/dist/components/ConversationList/ConversationList.js +51 -39
  134. package/dist/components/ConversationList/ConversationList.vue.d.ts +654 -1510
  135. package/dist/components/ConversationList/ConversationListContent/ConversationListContent.js +4 -4
  136. package/dist/components/ConversationList/ConversationListContent/ConversationListContent.vue.d.ts +1 -1
  137. package/dist/components/ConversationList/ConversationPlaceHolder/ConversationPlaceHolder.js +2 -2
  138. package/dist/components/ConversationList/ConversationPreview/ConversationPreview.vue.d.ts +596 -1404
  139. package/dist/components/ConversationList/ConversationPreview/ConversationPreviewAbstract.js +1 -1
  140. package/dist/components/ConversationList/ConversationPreview/ConversationPreviewUI.js +13 -29
  141. package/dist/components/ConversationList/ConversationPreview/ConversationPreviewUI.vue.d.ts +146 -348
  142. package/dist/components/ConversationList/ConversationPreview/index.js +3 -3
  143. package/dist/components/ConversationList/ConversationPreview/utils.js +8 -8
  144. package/dist/components/ConversationList/ConversationSearch/ConversationSearch.js +5 -5
  145. package/dist/components/ConversationList/ConversationSearch/ConversationSearch.vue.d.ts +8 -8
  146. package/dist/components/ConversationList/hooks/useConversation.d.ts +6 -0
  147. package/dist/components/ConversationList/hooks/useConversation.js +20 -0
  148. package/dist/components/ConversationList/hooks/useConversationCreate.d.ts +5 -0
  149. package/dist/components/ConversationList/hooks/useConversationCreate.js +24 -0
  150. package/dist/components/ConversationList/i18n/en-US.d.ts +16 -0
  151. package/dist/components/ConversationList/i18n/en-US.js +25 -7
  152. package/dist/components/ConversationList/i18n/zh-CN.d.ts +16 -0
  153. package/dist/components/ConversationList/i18n/zh-CN.js +24 -6
  154. package/dist/components/ConversationList/index.d.ts +2096 -4595
  155. package/dist/components/{LiveStreamView → LiveCoreView}/DefaultStreamViewUI.js +1 -1
  156. package/dist/components/LiveCoreView/index.d.ts +4 -0
  157. package/dist/components/{LiveStreamView → LiveCoreView}/index.js +68 -74
  158. package/dist/components/LiveList/LiveList.js +71 -45
  159. package/dist/components/LiveList/LiveListH5.js +14 -15
  160. package/dist/components/LiveScenePanel/CameraSettingDialog.js +1 -2
  161. package/dist/components/LiveScenePanel/icons/AddIcon.js +2 -2
  162. package/dist/components/LiveScenePanel/icons/CameraIcon.js +2 -2
  163. package/dist/components/LiveScenePanel/icons/CameraMirror.js +2 -2
  164. package/dist/components/LiveScenePanel/icons/CameraUnmirror.js +2 -2
  165. package/dist/components/LiveScenePanel/icons/ImageIcon.js +2 -2
  166. package/dist/components/LiveScenePanel/icons/MoreIcon.js +2 -2
  167. package/dist/components/LiveScenePanel/icons/ScreenIcon.js +2 -2
  168. package/dist/components/MessageInput/AttachmentPicker/index.js +1 -1
  169. package/dist/components/MessageInput/EmojiPicker/EmojiPicker.js +1 -1
  170. package/dist/components/MessageInput/MessageInput.js +1 -1
  171. package/dist/components/MessageInput/QuotedMessagePreview/index.js +2 -2
  172. package/dist/components/MessageInput/SendButton/index.js +1 -1
  173. package/dist/components/MessageInput/TextEditor/index.js +6 -5
  174. package/dist/components/MessageInput/i18n/index.d.ts +24 -1
  175. package/dist/components/MessageInput/i18n/index.js +7 -8
  176. package/dist/components/MessageInput/index.d.ts +409 -6
  177. package/dist/components/MessageInput/index.js +23 -125
  178. package/dist/components/MessageList/Message/AudioMessage/PlayButton.js +3 -3
  179. package/dist/components/MessageList/Message/ImageMessage/ImageMessage.js +2 -2
  180. package/dist/components/MessageList/Message/MessageLayout/MessageActionDropdown/MessageActionDropdown.js +3 -3
  181. package/dist/components/MessageList/Message/MessageLayout/MessageActionDropdown/MessageActionDropdown.vue.d.ts +5 -5
  182. package/dist/components/MessageList/Message/MessageLayout/MessageLayout.js +1 -1
  183. package/dist/components/MessageList/Message/MessageLayout/MessageMeta/MessageMeta.js +34 -30
  184. package/dist/components/MessageList/Message/MessageLayout/MessageMeta/MessageMeta.vue.d.ts +0 -10
  185. package/dist/components/MessageList/MessageForward/MessageForward.js +4 -4
  186. package/dist/components/MessageList/MessageList.js +66 -60
  187. package/dist/components/MessageList/MessageList.vue.d.ts +3 -3
  188. package/dist/components/MessageList/ScrollToBottom/ScrollToBottom.js +32 -0
  189. package/dist/components/MessageList/ScrollToBottom/ScrollToBottom.vue.d.ts +6 -0
  190. package/dist/components/MessageList/ScrollToBottom/index.d.ts +3 -0
  191. package/dist/components/MessageList/ScrollToBottom/index.js +4 -0
  192. package/dist/components/MessageList/i18n/en-US.d.ts +5 -0
  193. package/dist/components/MessageList/i18n/en-US.js +6 -1
  194. package/dist/components/MessageList/i18n/index.d.ts +85 -1
  195. package/dist/components/MessageList/i18n/index.js +7 -8
  196. package/dist/components/MessageList/i18n/zh-CN.d.ts +5 -0
  197. package/dist/components/MessageList/i18n/zh-CN.js +6 -1
  198. package/dist/components/MessageList/index.js +4 -0
  199. package/dist/components/Search/Search.js +4 -4
  200. package/dist/components/Search/Search.vue.d.ts +4 -4
  201. package/dist/components/Search/SearchAdvanced/DateRangePicker/DateRangePicker.js +15 -9
  202. package/dist/components/Search/SearchAdvanced/MessageAdvanced/MessageAdvanced.js +12 -7
  203. package/dist/components/Search/SearchAdvanced/SearchAdvanced.js +2 -2
  204. package/dist/components/Search/SearchAdvanced/SearchTab/SearchTab.js +10 -5
  205. package/dist/components/Search/SearchAdvanced/UserAdvanced/UserAdvanced.js +10 -10
  206. package/dist/components/Search/SearchBar/SearchBar.js +3 -2
  207. package/dist/components/Search/SearchResults/EmptyResult/EmptyResult.js +1 -1
  208. package/dist/components/Search/SearchResults/SearchResults.js +82 -69
  209. package/dist/components/Search/SearchResults/SearchResultsItem/Conversation/Conversation.js +8 -8
  210. package/dist/components/Search/SearchResults/SearchResultsItem/utils/highlightText.d.ts +5 -6
  211. package/dist/components/Search/i18n/en-US/Search.js +9 -9
  212. package/dist/components/Search/i18n/zh-CN/Search.js +13 -13
  213. package/dist/components/Search/index.d.ts +6 -6
  214. package/dist/components/StreamMixer/LocalMixer/MixerControl.js +14 -10
  215. package/dist/components/StreamMixer/LocalMixer/index.js +81 -56
  216. package/dist/components/StreamMixer/icons/CameraMirror.js +2 -2
  217. package/dist/components/StreamMixer/icons/Delete.js +2 -2
  218. package/dist/components/StreamMixer/icons/Down.js +2 -2
  219. package/dist/components/StreamMixer/icons/Rotation.js +2 -2
  220. package/dist/components/StreamMixer/icons/Up.js +2 -2
  221. package/dist/components/StreamMixer/index.js +2 -2
  222. package/dist/components/StreamView/common/StreamCover/index.js +2 -2
  223. package/dist/components/UserPicker/components/TreeMode/TreeNode.js +2 -2
  224. package/dist/components/UserPicker/i18n/index.d.ts +15 -1
  225. package/dist/components/UserPicker/i18n/index.js +3 -4
  226. package/dist/components/UserPicker/index.d.ts +0 -1
  227. package/dist/components/UserPicker/index.js +6 -3
  228. package/dist/components/VideoSettingPanel/VideoPreview.js +3 -4
  229. package/dist/components/VideoSettingPanel/VideoProfile.js +3 -4
  230. package/dist/components/VideoSettingPanel/i18n/en-US/index.d.ts +5 -0
  231. package/dist/components/VideoSettingPanel/i18n/en-US/index.js +8 -3
  232. package/dist/components/VideoSettingPanel/i18n/zh-CN/index.d.ts +5 -0
  233. package/dist/components/VideoSettingPanel/i18n/zh-CN/index.js +8 -3
  234. package/dist/components/VideoSettingPanel/index.js +3 -3
  235. package/dist/hooks/useLongPress.d.ts +4 -4
  236. package/dist/hooks/useMessageActions.js +5 -5
  237. package/dist/hooks/useMouseHover.d.ts +7 -5
  238. package/dist/hooks/useMouseHover.js +3 -1
  239. package/dist/index.js +12 -6
  240. package/dist/rtc/index.d.ts +22 -20
  241. package/dist/rtc/index.js +6 -3
  242. package/dist/states/BarrageListState/BarrageListState.js +3 -2
  243. package/dist/states/CoHostState.d.ts +1 -1
  244. package/dist/states/CoHostState.js +59 -62
  245. package/dist/states/ContactListState/ContactListState.d.ts +16 -16
  246. package/dist/states/ContactListState/ContactListState.js +20 -20
  247. package/dist/states/ConversationListState/ConversationListState.d.ts +13 -12
  248. package/dist/states/ConversationListState/ConversationListState.js +19 -19
  249. package/dist/states/LiveSeatState/seatEventManager.js +3 -5
  250. package/dist/states/LiveSeatState/usePlayStream/MixStreamPlayer.js +9 -0
  251. package/dist/states/LiveState/index.d.ts +4 -4
  252. package/dist/states/LiveState/index.js +4 -2
  253. package/dist/states/LoginState.js +1 -3
  254. package/dist/states/MessageInputState/MessageInputState.js +18 -18
  255. package/dist/states/SearchState.d.ts +2 -2
  256. package/dist/states/SearchState.js +124 -127
  257. package/dist/styles/index.css +1954 -1070
  258. package/dist/types/contact.d.ts +145 -9
  259. package/dist/types/conversation.d.ts +36 -28
  260. package/dist/types/conversation.js +22 -0
  261. package/dist/types/index.js +5 -3
  262. package/dist/types/live.d.ts +2 -3
  263. package/dist/types/types.d.ts +0 -8
  264. package/dist/types/types.js +0 -10
  265. package/dist/utils/time.d.ts +2 -2
  266. package/dist/utils/time.js +253 -1471
  267. package/package.json +23 -5
  268. package/src/baseComp/View/View.vue +1 -2
  269. package/src/baseComp/index.ts +1 -2
  270. package/src/chat/index.ts +11 -0
  271. package/src/components/Avatar/Avatar.vue +12 -11
  272. package/src/components/BarrageInput/BarrageInputH5.vue +36 -9
  273. package/src/components/BarrageInput/TextEditor/TextEditor.vue +13 -5
  274. package/src/components/BarrageInput/constants.ts +3 -0
  275. package/src/components/BarrageInput/i18n/en-US/index.ts +2 -0
  276. package/src/components/BarrageInput/i18n/zh-CN/index.ts +2 -0
  277. package/src/components/BarrageList/BarrageList.vue +2 -2
  278. package/src/components/BarrageList/BarrageListH5.vue +2 -2
  279. package/src/components/BarrageList/Message/MessageLayout/MessageLayout.vue +0 -1
  280. package/src/components/BarrageList/Message/MessageLayout/MessageMeta/MessageMeta.vue +5 -2
  281. package/src/components/BarrageList/Message/MessageLayout/MessageMeta/MessageStatusIcon.vue +7 -3
  282. package/src/components/BarrageList/Message/TextMessage/TextMessage.vue +3 -3
  283. package/src/components/ChatSetting/ChatSetting.vue +6 -10
  284. package/src/components/ChatSetting/GroupChatSetting/GroupInfo/GroupInfo.vue +1 -1
  285. package/src/components/ChatSetting/SettingItem/SettingItem.vue +40 -36
  286. package/src/components/ChatSetting/i18n/index.ts +3 -5
  287. package/src/components/ChatSetting/index.ts +5 -1
  288. package/src/components/ContactList/ContactInfo/BlacklistInfo/BlacklistInfo.scss +50 -0
  289. package/src/components/ContactList/ContactInfo/BlacklistInfo/BlacklistInfo.vue +71 -0
  290. package/src/components/ContactList/ContactInfo/BlacklistInfo/index.ts +1 -0
  291. package/src/components/ContactList/ContactInfo/ContactInfo.scss +33 -0
  292. package/src/components/ContactList/ContactInfo/ContactInfo.vue +256 -0
  293. package/src/components/ContactList/ContactInfo/FriendApplicationInfo/FriendApplicationInfo.scss +82 -0
  294. package/src/components/ContactList/ContactInfo/FriendApplicationInfo/FriendApplicationInfo.vue +88 -0
  295. package/src/components/ContactList/ContactInfo/FriendApplicationInfo/index.ts +1 -0
  296. package/src/components/ContactList/ContactInfo/FriendInfo/FriendInfo.scss +92 -0
  297. package/src/components/ContactList/ContactInfo/FriendInfo/FriendInfo.vue +219 -0
  298. package/src/components/ContactList/ContactInfo/FriendInfo/index.ts +1 -0
  299. package/src/components/ContactList/ContactInfo/GroupApplicationInfo/GroupApplicationInfo.scss +82 -0
  300. package/src/components/ContactList/ContactInfo/GroupApplicationInfo/GroupApplicationInfo.vue +99 -0
  301. package/src/components/ContactList/ContactInfo/GroupApplicationInfo/index.ts +1 -0
  302. package/src/components/ContactList/ContactInfo/GroupInfo/GroupInfo.scss +52 -0
  303. package/src/components/ContactList/ContactInfo/GroupInfo/GroupInfo.vue +146 -0
  304. package/src/components/ContactList/ContactInfo/GroupInfo/index.ts +1 -0
  305. package/src/components/ContactList/ContactInfo/SearchGroupInfo/SearchGroupInfo.scss +111 -0
  306. package/src/components/ContactList/ContactInfo/SearchGroupInfo/SearchGroupInfo.vue +147 -0
  307. package/src/components/ContactList/ContactInfo/SearchGroupInfo/index.ts +1 -0
  308. package/src/components/ContactList/ContactInfo/SearchUserInfo/SearchUserInfo.scss +111 -0
  309. package/src/components/ContactList/ContactInfo/SearchUserInfo/SearchUserInfo.vue +128 -0
  310. package/src/components/ContactList/ContactInfo/SearchUserInfo/index.ts +1 -0
  311. package/src/components/ContactList/ContactInfo/index.ts +8 -0
  312. package/src/components/ContactList/ContactList.scss +124 -0
  313. package/src/components/ContactList/ContactList.vue +299 -0
  314. package/src/components/ContactList/ContactListItem/BlacklistItem/BlacklistItem.scss +39 -0
  315. package/src/components/ContactList/ContactListItem/BlacklistItem/BlacklistItem.vue +47 -0
  316. package/src/components/ContactList/ContactListItem/BlacklistItem/index.ts +1 -0
  317. package/src/components/ContactList/ContactListItem/ContactListItem.vue +98 -0
  318. package/src/components/ContactList/ContactListItem/FriendApplicationItem/FriendApplicationItem.scss +58 -0
  319. package/src/components/ContactList/ContactListItem/FriendApplicationItem/FriendApplicationItem.vue +70 -0
  320. package/src/components/ContactList/ContactListItem/FriendApplicationItem/index.ts +1 -0
  321. package/src/components/ContactList/ContactListItem/FriendItem/FriendItem.scss +39 -0
  322. package/src/components/ContactList/ContactListItem/FriendItem/FriendItem.vue +47 -0
  323. package/src/components/ContactList/ContactListItem/FriendItem/index.ts +1 -0
  324. package/src/components/ContactList/ContactListItem/GroupApplicationItem/GroupApplicationItem.scss +57 -0
  325. package/src/components/ContactList/ContactListItem/GroupApplicationItem/GroupApplicationItem.vue +78 -0
  326. package/src/components/ContactList/ContactListItem/GroupApplicationItem/index.ts +1 -0
  327. package/src/components/ContactList/ContactListItem/GroupItem/GroupItem.scss +39 -0
  328. package/src/components/ContactList/ContactListItem/GroupItem/GroupItem.vue +47 -0
  329. package/src/components/ContactList/ContactListItem/GroupItem/index.ts +1 -0
  330. package/src/components/ContactList/ContactListItem/index.ts +6 -0
  331. package/src/components/ContactList/ContactSearch/ContactSearch.scss +58 -0
  332. package/src/components/ContactList/ContactSearch/ContactSearch.vue +98 -0
  333. package/src/components/ContactList/ContactSearch/index.ts +1 -0
  334. package/src/components/ContactList/constants/const.ts +7 -0
  335. package/src/components/ContactList/hooks/index.ts +1 -0
  336. package/src/components/ContactList/hooks/useContactList.ts +21 -0
  337. package/src/components/ContactList/i18n/en-US.ts +77 -0
  338. package/src/components/ContactList/i18n/index.ts +4 -0
  339. package/src/components/ContactList/i18n/zh-CN.ts +77 -0
  340. package/src/components/ContactList/index.ts +18 -0
  341. package/src/components/ConversationList/ConversationActions/ConversationActions.scss +34 -35
  342. package/src/components/ConversationList/ConversationActions/ConversationActions.vue +15 -29
  343. package/src/components/ConversationList/ConversationCreate/ConversationCreate.scss +11 -37
  344. package/src/components/ConversationList/ConversationCreate/ConversationCreate.vue +154 -69
  345. package/src/components/ConversationList/ConversationCreate/ConversationCreateButton/ConversationCreateButton.scss +37 -1
  346. package/src/components/ConversationList/ConversationCreate/ConversationCreateButton/ConversationCreateButton.vue +70 -15
  347. package/src/components/ConversationList/ConversationCreate/ConversationCreateGroupDetail/ConversationCreateGroupDetail.scss +19 -66
  348. package/src/components/ConversationList/ConversationCreate/ConversationCreateGroupDetail/ConversationCreateGroupDetail.vue +72 -139
  349. package/src/components/ConversationList/ConversationCreate/ConversationCreateUserSelectList/ConversationCreateUserSelectList.scss +5 -129
  350. package/src/components/ConversationList/ConversationCreate/ConversationCreateUserSelectList/ConversationCreateUserSelectList.vue +42 -183
  351. package/src/components/ConversationList/ConversationCreate/ConversationGroupTypeInfo/ConversationGroupTypeInfo.scss +14 -11
  352. package/src/components/ConversationList/ConversationCreate/ConversationGroupTypeInfo/ConversationGroupTypeInfo.vue +23 -18
  353. package/src/components/ConversationList/ConversationCreate/ConversationGroupTypeInfo/type.ts +2 -8
  354. package/src/components/ConversationList/ConversationCreate/index.ts +0 -2
  355. package/src/components/ConversationList/ConversationList.scss +1 -0
  356. package/src/components/ConversationList/ConversationList.vue +44 -25
  357. package/src/components/ConversationList/ConversationListContent/ConversationListContent.scss +2 -5
  358. package/src/components/ConversationList/ConversationPlaceHolder/ConversationPlaceHolder.vue +2 -2
  359. package/src/components/ConversationList/ConversationPreview/ConversationPreviewAbstract.vue +1 -1
  360. package/src/components/ConversationList/ConversationPreview/ConversationPreviewUI.vue +6 -19
  361. package/src/components/ConversationList/ConversationPreview/utils.ts +11 -11
  362. package/src/components/ConversationList/hooks/useConversation.ts +21 -0
  363. package/src/components/ConversationList/hooks/useConversationCreate.ts +29 -0
  364. package/src/components/ConversationList/i18n/en-US.ts +26 -6
  365. package/src/components/ConversationList/i18n/zh-CN.ts +25 -5
  366. package/src/components/{LiveStreamView → LiveCoreView}/index.ts +4 -3
  367. package/src/components/{LiveStreamView → LiveCoreView}/index.vue +109 -88
  368. package/src/components/LiveList/LiveList.vue +94 -38
  369. package/src/components/LiveList/LiveListH5.vue +47 -23
  370. package/src/components/MessageInput/MessageInput.module.scss +1 -1
  371. package/src/components/MessageInput/QuotedMessagePreview/QuotedMessagePreview.vue +2 -2
  372. package/src/components/MessageInput/SendButton/SendButton.vue +1 -1
  373. package/src/components/MessageInput/TextEditor/Editor.scss +3 -2
  374. package/src/components/MessageInput/TextEditor/TextEditor.module.scss +1 -0
  375. package/src/components/MessageInput/TextEditor/TextEditor.vue +2 -0
  376. package/src/components/MessageInput/i18n/index.ts +1 -7
  377. package/src/components/MessageInput/index.ts +25 -8
  378. package/src/components/MessageList/Message/MessageLayout/MessageActionDropdown/MessageActionDropdown.vue +4 -4
  379. package/src/components/MessageList/Message/MessageLayout/MessageLayout.vue +0 -1
  380. package/src/components/MessageList/Message/MessageLayout/MessageMeta/MessageMeta.vue +16 -17
  381. package/src/components/MessageList/MessageForward/MessageForward.vue +2 -2
  382. package/src/components/MessageList/MessageList.vue +21 -5
  383. package/src/components/MessageList/ScrollToBottom/ScrollToBottom.vue +50 -0
  384. package/src/components/MessageList/ScrollToBottom/index.ts +5 -0
  385. package/src/components/MessageList/i18n/en-US.ts +5 -0
  386. package/src/components/MessageList/i18n/index.ts +1 -5
  387. package/src/components/MessageList/i18n/zh-CN.ts +5 -0
  388. package/src/components/MessageList/index.ts +4 -1
  389. package/src/components/Search/Search.vue +0 -4
  390. package/src/components/Search/SearchAdvanced/DateRangePicker/DateRangePicker.vue +125 -38
  391. package/src/components/Search/SearchAdvanced/MessageAdvanced/MessageAdvanced.vue +24 -16
  392. package/src/components/Search/SearchAdvanced/SearchAdvanced.vue +9 -7
  393. package/src/components/Search/SearchAdvanced/SearchTab/SearchTab.vue +4 -3
  394. package/src/components/Search/SearchAdvanced/UserAdvanced/UserAdvanced.scss +0 -1
  395. package/src/components/Search/SearchAdvanced/UserAdvanced/UserAdvanced.vue +57 -23
  396. package/src/components/Search/SearchBar/SearchBar.scss +0 -2
  397. package/src/components/Search/SearchBar/SearchBar.vue +7 -5
  398. package/src/components/Search/SearchResults/EmptyResult/EmptyResult.vue +4 -2
  399. package/src/components/Search/SearchResults/SearchResults.scss +5 -11
  400. package/src/components/Search/SearchResults/SearchResults.vue +25 -29
  401. package/src/components/Search/SearchResults/SearchResultsItem/Conversation/Conversation.scss +1 -9
  402. package/src/components/Search/SearchResults/SearchResultsItem/utils/highlightText.ts +15 -16
  403. package/src/components/Search/i18n/en-US/Search.ts +9 -9
  404. package/src/components/Search/i18n/zh-CN/Search.ts +13 -13
  405. package/src/components/StreamMixer/LocalMixer/MixerControl.vue +20 -15
  406. package/src/components/StreamMixer/LocalMixer/index.vue +130 -57
  407. package/src/components/StreamMixer/index.vue +3 -3
  408. package/src/components/UserPicker/i18n/index.ts +1 -5
  409. package/src/components/UserPicker/index.ts +4 -3
  410. package/src/components/VideoSettingPanel/VideoPreview.vue +13 -8
  411. package/src/components/VideoSettingPanel/VideoProfile.vue +5 -5
  412. package/src/components/VideoSettingPanel/i18n/en-US/index.ts +8 -3
  413. package/src/components/VideoSettingPanel/i18n/zh-CN/index.ts +8 -3
  414. package/src/components/VideoSettingPanel/index.vue +15 -9
  415. package/src/hooks/useLongPress.ts +7 -18
  416. package/src/hooks/useMessageActions.ts +5 -5
  417. package/src/hooks/useMouseHover.ts +9 -7
  418. package/src/rtc/index.ts +6 -3
  419. package/src/types/contact.ts +175 -12
  420. package/src/types/conversation.ts +42 -32
  421. package/src/types/live.ts +3 -5
  422. package/src/types/types.ts +0 -28
  423. package/src/utils/time.ts +8 -10
  424. package/dist/baseComp/Popup/Popup.js +0 -132
  425. package/dist/baseComp/Popup/Popup.vue.d.ts +0 -54
  426. package/dist/baseComp/Popup/index.d.ts +0 -2
  427. package/dist/baseComp/Popup/index.js +0 -4
  428. package/dist/components/ConversationList/ConversationCreate/ConversationCreateSelectView/ConversationCreateSelectView.js +0 -65
  429. package/dist/components/ConversationList/ConversationCreate/ConversationCreateSelectView/ConversationCreateSelectView.vue.d.ts +0 -17
  430. package/dist/components/ConversationList/ConversationCreate/ConversationCreateSelectView/index.d.ts +0 -1
  431. package/dist/components/ConversationList/ConversationCreate/ConversationCreateSelectView/index.js +0 -4
  432. package/dist/components/ConversationList/ConversationCreate/hooks/useConversationCreate.d.ts +0 -9
  433. package/dist/components/ConversationList/ConversationCreate/hooks/useConversationCreate.js +0 -96
  434. package/dist/components/ConversationList/ConversationCreate/static/word.d.ts +0 -6
  435. package/dist/components/ConversationList/ConversationCreate/static/word.js +0 -4
  436. package/dist/components/LiveStreamView/index.d.ts +0 -4
  437. package/src/baseComp/Popup/Popup.vue +0 -156
  438. package/src/baseComp/Popup/index.ts +0 -2
  439. package/src/components/ConversationList/ConversationCreate/ConversationCreateSelectView/ConversationCreateSelectView.scss +0 -36
  440. package/src/components/ConversationList/ConversationCreate/ConversationCreateSelectView/ConversationCreateSelectView.vue +0 -44
  441. package/src/components/ConversationList/ConversationCreate/ConversationCreateSelectView/index.ts +0 -1
  442. package/src/components/ConversationList/ConversationCreate/hooks/useConversationCreate.ts +0 -132
  443. package/src/components/ConversationList/ConversationCreate/static/word.ts +0 -300
  444. /package/dist/components/{LiveStreamView → LiveCoreView}/DefaultStreamViewUI.vue.d.ts +0 -0
  445. /package/dist/components/{LiveStreamView → LiveCoreView}/i18n/en-US/index.d.ts +0 -0
  446. /package/dist/components/{LiveStreamView → LiveCoreView}/i18n/en-US/index.js +0 -0
  447. /package/dist/components/{LiveStreamView → LiveCoreView}/i18n/index.d.ts +0 -0
  448. /package/dist/components/{LiveStreamView → LiveCoreView}/i18n/index.js +0 -0
  449. /package/dist/components/{LiveStreamView → LiveCoreView}/i18n/zh-CN/index.d.ts +0 -0
  450. /package/dist/components/{LiveStreamView → LiveCoreView}/i18n/zh-CN/index.js +0 -0
  451. /package/dist/components/{LiveStreamView → LiveCoreView}/index.vue.d.ts +0 -0
  452. /package/src/components/{LiveStreamView → LiveCoreView}/DefaultStreamViewUI.vue +0 -0
  453. /package/src/components/{LiveStreamView → LiveCoreView}/i18n/en-US/index.ts +0 -0
  454. /package/src/components/{LiveStreamView → LiveCoreView}/i18n/index.ts +0 -0
  455. /package/src/components/{LiveStreamView → LiveCoreView}/i18n/zh-CN/index.ts +0 -0
@@ -1,204 +1,63 @@
1
1
  <template>
2
- <div :class="[$style.conversationCreateUserSelectList]">
3
- <div :class="$style.conversationCreateUserSelectList__searchInput">
4
- <TUIInput
5
- v-model="searchValue"
6
- :prefixIcon="IconSearchChat"
7
- :placeholder="t('TUIConversation.Search')"
8
- @change="searchValueChange"
9
- />
10
- </div>
11
-
12
- <ConversationCreateSelectView
13
- v-if="isCreateGroup"
14
- :select-list="selectList"
15
- :set-select-list="handleSelectListUpdate"
2
+ <div
3
+ :class="[
4
+ $style.conversationCreateUserSelectList,
5
+ isH5 && $style['conversationCreateUserSelectList--h5'],
6
+ ]"
7
+ >
8
+ <UserPicker
9
+ displayMode="list"
10
+ :data-source="renderFriendList"
11
+ :default-selected-items="selectList"
12
+ :maxCount="!isCreateGroup ? 1: undefined"
13
+ :onSelectedChange="handleSelectListUpdate"
16
14
  />
17
-
18
- <div
19
- v-if="!isCreateGroup"
20
- role="presentation"
21
- :class="[$style.conversationCreateUserSelectList__user, $style['conversationCreateUserSelectList__user--active']]"
22
- @click="createGroup"
23
- >
24
- <IconSearchMore size="24px" />
25
- <div :class="$style.conversationCreateUserSelectList__userName">
26
- {{ t('TUIConversation.New group chat') }}
27
- </div>
28
- </div>
29
-
30
- <div :class="[$style.conversationCreateUserSelectList__container, className]">
31
- <div :class="$style.conversationCreateUserSelectList__list">
32
- <div :class="$style.conversationCreateUserSelectList__groupContainer">
33
- <div
34
- v-for="(group, key) in friendList"
35
- v-show="group.length !== 0"
36
- :key="key"
37
- :class="$style.conversationCreateUserSelectList__groupBox"
38
- >
39
- <div :class="$style.conversationCreateUserSelectList__title">
40
- {{ key }}
41
- </div>
42
- <label
43
- v-for="profile in group"
44
- :key="profile.userID"
45
- role="presentation"
46
- :class="$style.conversationCreateUserSelectList__user"
47
- :for="`userChecked-${key}-${profile.userID}`"
48
- @click="handleUserItem(profile)"
49
- >
50
- <Avatar :src="profile.avatar" />
51
- <div :class="$style.conversationCreateUserSelectList__userName">
52
- {{ profile.nick || profile.userID }}
53
- </div>
54
- <div
55
- v-if="isCreateGroup"
56
- :class="$style.conversationCreateUserSelectList__userCheckbox"
57
- >
58
- <IconCheckSm
59
- v-if="selectList.find(item => item.userID === profile.userID)"
60
- :class="$style.conversationCreateUserSelectList__activeIcon"
61
- />
62
- <IconAddCircle v-else />
63
- </div>
64
- </label>
65
- </div>
66
- </div>
67
- </div>
68
- </div>
69
-
70
- <div
71
- v-if="isCreateGroup"
72
- :class="$style.conversationCreateUserSelectList__nextContainer"
73
- >
74
- <TUIButton @click="next">
75
- {{ t('TUIConversation.Next') }}
76
- </TUIButton>
77
- </div>
78
15
  </div>
79
16
  </template>
80
17
 
81
18
  <script lang="ts" setup>
82
- import { ref, watch } from 'vue';
83
- import {
84
- TUIInput,
85
- TUIButton,
86
- IconSearchMore,
87
- IconCheckSm,
88
- IconAddCircle,
89
- IconSearchChat,
90
- TUIToast,
91
- useUIKit,
92
- } from '@tencentcloud/uikit-base-component-vue3';
19
+ import { computed } from 'vue';
93
20
  import { useContactListState } from '../../../../states/ContactListState';
94
- import { useConversationListState } from '../../../../states/ConversationListState';
95
- import { PageStateTypes } from '../../../../types';
96
- import { Avatar } from '../../../Avatar';
97
- import { ConversationCreateSelectView } from '../ConversationCreateSelectView';
98
- import { useConversationCreate } from '../hooks/useConversationCreate';
21
+ import { isH5 } from '../../../../utils/env';
22
+ import { UserPicker } from '../../../UserPicker';
99
23
  import type {
100
24
  ConversationCreateUserSelectListProps,
101
- UserProfile,
102
- ConversationCreateUsers,
103
- ConversationModel,
25
+ Friend,
104
26
  } from '../../../../types';
27
+ import type { IUserPickerResult } from '../../../UserPicker';
105
28
 
106
29
  const props = defineProps<ConversationCreateUserSelectListProps>();
107
30
 
108
31
  const emit = defineEmits<{
109
32
  'update:is-create-group': [value: boolean];
110
- 'update:select-list': [list: UserProfile[]];
111
- 'update:page-state': [state: PageStateTypes];
112
- 'beforeCreateConversation': [userID: string];
113
- 'conversationCreated': [conversation: ConversationModel];
33
+ 'update:select-list': [list: Friend[]];
114
34
  }>();
115
35
 
116
- const { t } = useUIKit();
117
- const { friendList: friendListResult } = useContactListState();
118
- const { createC2CConversation } = useConversationListState();
119
-
120
- const searchValue = ref('');
121
- const conversationList = ref(props.conversationList);
122
- const friendList = ref<ConversationCreateUsers>({});
123
-
124
- const {
125
- friendListSortResult,
126
- getFriendListSortSearchResult,
127
- } = useConversationCreate(
128
- conversationList,
129
- friendListResult,
130
- );
131
-
132
- // Methods
133
- const searchValueChange = (value: string | number) => {
134
- const stringValue = String(value);
135
- searchValue.value = stringValue;
136
- friendList.value = getFriendListSortSearchResult(stringValue);
137
- };
138
-
139
- const createGroup = () => {
140
- emit('update:is-create-group', true);
141
- props.setSelectList([]);
142
- props.setIsCreateGroup(true);
143
- };
144
-
145
- const userSelectListChange = (profile: UserProfile) => {
146
- const { userID } = profile;
147
- const newList = [...props.selectList];
148
-
149
- if (!newList.find(item => item.userID === userID)) {
150
- newList.push(profile);
151
- } else {
152
- const index = newList.findIndex(item => item.userID === userID);
153
- newList.splice(index, 1);
154
- }
155
- emit('update:select-list', newList);
156
- props.setSelectList(newList);
36
+ const { friendList } = useContactListState();
37
+
38
+ const selectList = computed(() => props.selectList.map((item) => {
39
+ const { userID, nick, avatar, remark } = item;
40
+ return {
41
+ key: userID,
42
+ label: remark || nick || userID,
43
+ avatarUrl: avatar,
44
+ };
45
+ }));
46
+
47
+ const renderFriendList = computed(() => friendList.value.map((item) => {
48
+ const { userID, nick, avatar, remark } = item;
49
+ return {
50
+ key: userID,
51
+ label: remark || nick || userID,
52
+ avatarUrl: avatar,
53
+ };
54
+ }));
55
+
56
+ const handleSelectListUpdate = (list: IUserPickerResult) => {
57
+ const selectFriendList = friendList.value.filter(item => list.some(selected => selected.key === item.userID));
58
+ emit('update:select-list', selectFriendList);
59
+ props.setSelectList(selectFriendList);
157
60
  };
158
-
159
- const _createConversation = async (profile: UserProfile) => {
160
- if (props.isCreateGroup) {
161
- return;
162
- }
163
-
164
- const { userID } = profile;
165
- emit('beforeCreateConversation', userID);
166
- props.onBeforeCreateConversation?.(userID);
167
-
168
- try {
169
- const conversation = await createC2CConversation(userID);
170
- emit('conversationCreated', conversation);
171
- props.onConversationCreated?.(conversation);
172
- } catch (error: any) {
173
- TUIToast.error({ message: error.message });
174
- }
175
- };
176
-
177
- const handleUserItem = (profile: UserProfile) => {
178
- if (props.isCreateGroup) {
179
- userSelectListChange(profile);
180
- } else {
181
- _createConversation(profile);
182
- }
183
- };
184
-
185
- const next = () => {
186
- if (!props.selectList || props.selectList.length === 0) {
187
- TUIToast.error({ message: t('TUIConversation.Participant cannot be empty') });
188
- return;
189
- }
190
- emit('update:page-state', PageStateTypes.CREATE_DETAIL);
191
- props.setPageState(PageStateTypes.CREATE_DETAIL);
192
- };
193
-
194
- const handleSelectListUpdate = (list: UserProfile[]) => {
195
- emit('update:select-list', list);
196
- props.setSelectList(list);
197
- };
198
-
199
- watch(friendListSortResult, (newValue) => {
200
- friendList.value = newValue;
201
- }, { immediate: true });
202
61
  </script>
203
62
 
204
63
  <style lang="scss" module>
@@ -1,14 +1,13 @@
1
+ @use '../../../../styles/mixins/_scrollbar.scss' as scrollbar;
2
+
1
3
  .conversationGroupTypeInfo {
4
+ flex: 1;
2
5
  display: flex;
3
6
  flex-direction: column;
4
- padding: 0 10px;
7
+ gap: 10px;
5
8
  overflow-y: scroll;
9
+ @include scrollbar.scrollbar-hidden();
6
10
  color: var(--text-color-primary);
7
- scrollbar-width: none;
8
- -ms-overflow-style: none;
9
- &::-webkit-scrollbar {
10
- display: none;
11
- }
12
11
 
13
12
  &__box {
14
13
  display: flex;
@@ -16,7 +15,6 @@
16
15
  gap: 8px;
17
16
  border-radius: 16px;
18
17
  padding: 12px 16px;
19
- margin-top: 12px;
20
18
  cursor: pointer;
21
19
  background-color: var(--bg-color-operate);
22
20
  border: 1px solid var(--stroke-color-primary);
@@ -30,6 +28,12 @@
30
28
  }
31
29
  }
32
30
 
31
+ &__header {
32
+ display: flex;
33
+ justify-content: space-between;
34
+ align-items: center;
35
+ }
36
+
33
37
  &__title {
34
38
  font-size: 16px;
35
39
  display: flex;
@@ -45,10 +49,9 @@
45
49
  }
46
50
 
47
51
  &__document {
48
- font-size: 16px;
49
- text-align: justify;
52
+ font-size: 12px;
53
+ line-height: 16px;
50
54
  text-decoration: none;
51
- margin: 1rem auto;
52
55
 
53
56
  &:link,
54
57
  &:active,
@@ -58,6 +61,6 @@
58
61
  }
59
62
 
60
63
  &__activeIcon {
61
- fill: var(--text-color-link) !important;
64
+ color: var(--checkbox-color-selected);
62
65
  }
63
66
  }
@@ -9,45 +9,50 @@
9
9
  }]"
10
10
  @click="selectGroupType(type)"
11
11
  >
12
- <div :class="$style.conversationGroupTypeInfo__title">
12
+ <div :class="$style.conversationGroupTypeInfo__header">
13
+ <div :class="$style.conversationGroupTypeInfo__title">
14
+ <Avatar
15
+ size="sm"
16
+ :src="getDefaultAvatar(type)"
17
+ />
18
+ {{ t(`TUIConversation.${name}`) }}
19
+ </div>
13
20
  <IconCheckSm
14
21
  v-if="type === groupType"
15
22
  :class="$style.conversationGroupTypeInfo__activeIcon"
16
23
  />
17
- {{ t(`TUIConversation.${name}`) }}
18
24
  </div>
19
25
  <div :class="$style.conversationGroupTypeInfo__description">
20
26
  {{ t(`TUIConversation.${des}`) }}
27
+ <a
28
+ :class="$style.conversationGroupTypeInfo__document"
29
+ target="_blank"
30
+ href="https://trtc.io/document/33529?platform=web&product=chat&menulabel=uikit#group-types"
31
+ rel="bookmark noreferrer"
32
+ >
33
+ {{ t('TUIConversation.See the documentation for details') }}
34
+ </a>
21
35
  </div>
22
36
  </div>
23
- <a
24
- :class="$style.conversationGroupTypeInfo__document"
25
- target="_blank"
26
- href="https://trtc.io/document/33529?platform=web&product=chat&menulabel=uikit#group-types"
27
- rel="bookmark noreferrer"
28
- >
29
- {{ t('TUIConversation.Details') }}
30
- </a>
31
37
  </div>
32
38
  </template>
33
39
 
34
40
  <script lang="ts" setup>
35
41
  import { IconCheckSm, useUIKit } from '@tencentcloud/uikit-base-component-vue3';
36
- import { PageStateTypes } from '../../../../types';
42
+ import {
43
+ Avatar,
44
+ } from '../../../Avatar';
45
+ import { useConversationCreate } from '../../hooks/useConversationCreate';
37
46
  import { typeInfoList } from './type';
38
- import type { GroupType } from './type';
47
+ import type { GroupType, ConversationGroupTypeInfoProps } from '../../../../types';
39
48
 
40
- const props = defineProps<{
41
- groupType: GroupType;
42
- setGroupType: (type: GroupType) => void;
43
- setPageState: (state: PageStateTypes) => void;
44
- }>();
49
+ const props = defineProps<ConversationGroupTypeInfoProps>();
45
50
 
46
51
  const { t } = useUIKit();
52
+ const { getDefaultAvatar } = useConversationCreate();
47
53
 
48
54
  const selectGroupType = (type: GroupType) => {
49
55
  props.setGroupType(type);
50
- props.setPageState(PageStateTypes.CREATE_DETAIL);
51
56
  };
52
57
  </script>
53
58
 
@@ -1,10 +1,4 @@
1
- export enum GroupType {
2
- WORK = 'Private',
3
- PUBLIC = 'Public',
4
- MEETING = 'ChatRoom',
5
- AVCHATROOM = 'AVChatRoom',
6
- COMMUNITY = 'Community',
7
- }
1
+ import { GroupType } from '../../../../types';
8
2
 
9
3
  export interface ConversationGroupTypeInfoItem {
10
4
  type: GroupType;
@@ -18,4 +12,4 @@ export const typeInfoList: ConversationGroupTypeInfoItem[] = [
18
12
  { type: GroupType.MEETING, name: 'Meeting', des: 'After the group is created, a user can join and quit the group freely and can view the messages sent before joining the group. It is suitable for scenarios that integrate Tencent Real-Time Communication (TRTC), such as audio and video conferences and online education. See the documentation for details.' },
19
13
  { type: GroupType.AVCHATROOM, name: 'AVChatRoom', des: 'After a group is created, a user can join and quit the group freely. The group can have an unlimited number of members, but it does not store message history. It can be combined with Live Video Broadcasting (LVB) to support on-screen comment scenarios. See the documentation for details.' },
20
14
  { type: GroupType.COMMUNITY, name: 'Community', des: 'After creation, you can enter and leave at will, support up to 100,000 people, support historical message storage, and after users search for group ID and initiate a group application, they can join the group without administrator approval. See product documentation for details.' },
21
- ];
15
+ ];
@@ -1,8 +1,6 @@
1
1
  export { default as ConversationCreate } from './ConversationCreate.vue';
2
2
  export { default as ConversationCreateButton } from './ConversationCreateButton/ConversationCreateButton.vue';
3
3
  export { default as ConversationCreateGroupDetail } from './ConversationCreateGroupDetail/ConversationCreateGroupDetail.vue';
4
- export { default as ConversationCreateSelectView } from './ConversationCreateSelectView/ConversationCreateSelectView.vue';
5
4
  export { default as ConversationCreateUserSelectList } from './ConversationCreateUserSelectList/ConversationCreateUserSelectList.vue';
6
5
  export { default as ConversationGroupTypeInfo } from './ConversationGroupTypeInfo/ConversationGroupTypeInfo.vue';
7
- export { useConversationCreate } from './hooks/useConversationCreate';
8
6
  export { typeInfoList } from './ConversationGroupTypeInfo';
@@ -1,5 +1,6 @@
1
1
  .conversationList {
2
2
  width: 100%;
3
+ height: 100%;
3
4
  flex-shrink: 1;
4
5
  box-sizing: border-box;
5
6
  overflow: hidden;
@@ -14,11 +14,11 @@
14
14
  >
15
15
  <component
16
16
  :is="ConversationSearch"
17
- v-if="ConversationSearch"
17
+ v-if="enableSearch"
18
18
  />
19
19
  <component
20
20
  :is="ConversationCreate"
21
- :visible="enableCreate"
21
+ v-if="enableCreate"
22
22
  :conversation-list="conversationList"
23
23
  @update:visible="setIsCreateModelShow"
24
24
  @before-create="handleBeforeCreate"
@@ -65,6 +65,7 @@ import { ConversationListHeader as DefaultConversationListHeader } from './Conve
65
65
  import PlaceHolder from './ConversationPlaceHolder';
66
66
  import { ConversationPreview, ConversationPreviewUI as DefaultConversationPreviewUI } from './ConversationPreview';
67
67
  import { ConversationSearch as DefaultConversationSearch } from './ConversationSearch';
68
+ import { useConversation } from './hooks/useConversation';
68
69
  import type {
69
70
  CreateGroupParams,
70
71
  ConversationModel,
@@ -79,6 +80,8 @@ interface Props extends ConversationListProps {
79
80
 
80
81
  const props = withDefaults(defineProps<Props>(), {
81
82
  enableActions: true,
83
+ enableCreate: true,
84
+ enableSearch: true,
82
85
  Header: () => DefaultConversationListHeader,
83
86
  List: () => DefaultConversationListContent,
84
87
  Preview: () => DefaultConversationPreviewUI,
@@ -106,25 +109,38 @@ const emit = defineEmits<{
106
109
  conversationCreated: [conversation: ConversationModel];
107
110
  }>();
108
111
 
109
- const enableCreateConversation = ref(false);
112
+ const {
113
+ filter,
114
+ sort,
115
+ enableActions,
116
+ actionsConfig: propActionsConfig,
117
+ enableCreate: propEnableCreate,
118
+ enableSearch: propEnableSearch,
119
+ onBeforeCreateConversation,
120
+ onConversationCreated,
121
+ } = props;
122
+ const { conversationList, setActiveConversation } = useConversationListState();
123
+ const { setEnableCreate, setEnableSearch } = useConversation();
124
+
110
125
  const conversationActionList = ref<string[]>([]);
111
- const renderConversationList = ref<ConversationModel[]>([]);
112
- const { conversationList = [], setActiveConversation } = useConversationListState();
113
126
 
114
- watch(
115
- () => conversationList,
116
- (newList) => {
117
- let _conversationList = newList.value as ConversationModel[];
118
- if (props.filter) {
119
- _conversationList = props.filter(_conversationList);
120
- }
121
- if (props.sort) {
122
- _conversationList = props.sort(_conversationList);
123
- }
124
- renderConversationList.value = _conversationList;
125
- },
126
- { deep: true },
127
- );
127
+ const renderConversationList = computed(() => {
128
+ if (!conversationList.value) {
129
+ return [];
130
+ }
131
+
132
+ let _conversationList = conversationList.value;
133
+
134
+ if (filter && typeof filter === 'function') {
135
+ _conversationList = filter(_conversationList);
136
+ }
137
+
138
+ if (sort && typeof sort === 'function') {
139
+ _conversationList = sort(_conversationList);
140
+ }
141
+
142
+ return _conversationList;
143
+ });
128
144
 
129
145
  const isCreateModelShow = ref(false);
130
146
  const actionsConfig = ref<ConversationActionsConfig>({
@@ -134,10 +150,13 @@ const actionsConfig = ref<ConversationActionsConfig>({
134
150
  enablePin: true,
135
151
  });
136
152
 
137
- const enableCreate = computed(() => (props.enableCreate || enableCreateConversation) ?? true);
153
+ const enableCreate = computed(() => propEnableCreate);
154
+ const enableSearch = computed(() => propEnableSearch);
155
+ setEnableCreate(enableCreate.value);
156
+ setEnableSearch(enableSearch.value);
138
157
 
139
158
  watch(
140
- () => [props.actionsConfig, conversationActionList],
159
+ (): [ConversationActionsConfig | undefined, string[] | null] => [propActionsConfig, conversationActionList.value],
141
160
  ([newActionsConfig, newConversationActionList]) => {
142
161
  if (!newActionsConfig && !newConversationActionList) {
143
162
  actionsConfig.value = {
@@ -177,16 +196,16 @@ const setIsCreateModelShow = (visible: boolean) => {
177
196
 
178
197
  const handleBeforeCreate = (params: string | CreateGroupParams) => {
179
198
  emit('beforeCreateConversation', params);
180
- if (props.onBeforeCreateConversation) {
181
- return props.onBeforeCreateConversation(params);
199
+ if (onBeforeCreateConversation) {
200
+ return onBeforeCreateConversation(params);
182
201
  }
183
202
  return params;
184
203
  };
185
204
 
186
205
  const handleCreated = (conversation: ConversationModel) => {
187
206
  emit('conversationCreated', conversation);
188
- if (props.onConversationCreated) {
189
- props.onConversationCreated(conversation);
207
+ if (onConversationCreated) {
208
+ onConversationCreated(conversation);
190
209
  }
191
210
  };
192
211
  </script>
@@ -1,3 +1,4 @@
1
+ @use '../../../styles/mixins/_scrollbar.scss' as scrollbar;
1
2
  .conversationListContent {
2
3
  flex: 1;
3
4
  display: flex;
@@ -5,11 +6,7 @@
5
6
  flex-direction: column;
6
7
  background-color: var(--bg-color-operate, #f5f5f5);
7
8
  color: var(--text-color-primary, #333);
8
- scrollbar-width: none;
9
- -ms-overflow-style: none;
10
- &::-webkit-scrollbar {
11
- display: none;
12
- }
9
+ @include scrollbar.scrollbar-hidden();
13
10
 
14
11
  .placeholder-error,
15
12
  .placeholder-loading,
@@ -1,7 +1,7 @@
1
1
  <template>
2
2
  <div :class="[$style.conversationPlaceHolder, className]">
3
3
  <div :class="$style.conversationPlaceHolder__icon">
4
- <IconLoading
4
+ <IconLiveLoading
5
5
  v-if="type === PlaceHolderTypes.LOADING"
6
6
  :class="$style.conversationPlaceHolder__loading"
7
7
  />
@@ -45,7 +45,7 @@
45
45
 
46
46
  <script setup lang="ts">
47
47
  import { computed, withDefaults, defineProps } from 'vue';
48
- import { TUIButton, useUIKit, IconLoading } from '@tencentcloud/uikit-base-component-vue3';
48
+ import { TUIButton, useUIKit, IconLiveLoading } from '@tencentcloud/uikit-base-component-vue3';
49
49
  import { PlaceHolderTypes } from '../../../types/conversation';
50
50
  import type { ConversationPlaceHolderProps } from '../../../types/conversation';
51
51
 
@@ -1,7 +1,7 @@
1
1
  <template>
2
2
  <div :class="$style.conversationPreview__abstract">
3
3
  <template v-if="draftTextAbstract">
4
- <label :class="$style.conversationPreview__drafts">{{ t('TUIChat.[Drafts]') }}</label>
4
+ <label :class="$style.conversationPreview__drafts">[{{ t('TUIConversation.Drafts') }}]</label>
5
5
  {{ ' ' }}
6
6
  {{ draftTextAbstract }}
7
7
  </template>
@@ -12,11 +12,8 @@
12
12
  conversation?.isMuted && [$style['conversationPreview--mute']],
13
13
  ]"
14
14
  :style="style"
15
+ v-bind="longPressEvents"
15
16
  @click="handleClick"
16
- @touchstart="handleTouchStart"
17
- @touchend="handleTouchEnd"
18
- @mouseenter="handleMouseEnter"
19
- @mouseleave="handleMouseLeave"
20
17
  >
21
18
  <slot>
22
19
  <div :class="$style['conversationPreview__avatar']">
@@ -107,14 +104,16 @@ const { activeConversation, setActiveConversation } = useConversationListState()
107
104
  const conversationPreviewRef = ref<HTMLElement>();
108
105
  const isActionMenuActive = ref(false);
109
106
 
110
- const { isHovering } = useMouseHover(conversationPreviewRef);
111
- const { handleTouchStart, handleTouchEnd } = useLongPress(() => {
107
+ const { isHovered } = useMouseHover(conversationPreviewRef);
108
+ const { getEventHandlers } = useLongPress(() => {
112
109
  if (isH5) {
113
110
  isActionMenuActive.value = true;
114
111
  }
115
112
  });
116
113
 
117
- watch(isHovering, (newValue) => {
114
+ const longPressEvents = getEventHandlers();
115
+
116
+ watch(isHovered, (newValue) => {
118
117
  if (!isH5) {
119
118
  isActionMenuActive.value = newValue;
120
119
  }
@@ -125,18 +124,6 @@ const handleClick = () => {
125
124
  setActiveConversation(props.conversation.conversationID);
126
125
  };
127
126
 
128
- const handleMouseEnter = () => {
129
- if (!isH5) {
130
- isActionMenuActive.value = true;
131
- }
132
- };
133
-
134
- const handleMouseLeave = () => {
135
- if (!isH5) {
136
- isActionMenuActive.value = false;
137
- }
138
- };
139
-
140
127
  const handleCloseActionsModal = () => {
141
128
  isActionMenuActive.value = false;
142
129
  };