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
@@ -0,0 +1,77 @@
1
+ export default {
2
+ TUIContact: {
3
+ // ContactList组件翻译
4
+ 'New contacts': '新的联系人',
5
+ 'Group applications': '群聊申请',
6
+ 'My friends': '我的好友',
7
+ 'My groups': '我的群聊',
8
+ 'Blacklist': '黑名单',
9
+ 'Search contacts': '搜索联系人',
10
+ 'No contacts': '暂无联系人',
11
+ 'No Result': '无搜索结果',
12
+ 'Add friend/group': '添加好友/群聊',
13
+ 'Unknown contact type': '未知联系人类型',
14
+ 'Request to add you as friend': '请求添加您为好友',
15
+ 'Apply to join group': '申请加入群聊',
16
+ 'Invite you to join group': '邀请您加入群聊',
17
+ 'Application status': '申请状态',
18
+ 'Pending': '待处理',
19
+ 'Application note': '申请备注',
20
+ 'None': '无',
21
+ 'Verification info': '验证信息',
22
+ 'Personal signature': '个性签名',
23
+ 'Remark name': '备注名',
24
+ 'Save': '保存',
25
+ 'Add to blacklist': '加入黑名单',
26
+ 'Send message': '发送消息',
27
+ 'Apply to add friend': '申请添加好友',
28
+ 'Add friend failed': '添加好友失败',
29
+ 'User is already your friend': '该用户已是您的好友',
30
+ 'Friend request sent, waiting for confirmation': '好友请求已发送,等待确认',
31
+ 'Application info': '申请信息',
32
+ 'Please enter application info...': '请输入申请信息...',
33
+ 'Group ID': '群ID',
34
+ 'Group type': '群类型',
35
+ 'Group introduction': '群介绍',
36
+ 'No introduction': '暂无介绍',
37
+ 'Work group': '工作群',
38
+ 'Public group': '公开群',
39
+ 'Meeting group': '会议群',
40
+ 'Live group': '直播群',
41
+ 'Community': '社群',
42
+ 'Unknown': '未知',
43
+ 'You are already in this group': '您已在该群中',
44
+ 'Group application sent, waiting for admin approval': '入群申请已发送,等待管理员审核',
45
+ 'Apply to join group failed': '申请入群失败',
46
+ 'Remove from blacklist': '移出黑名单',
47
+ 'dismiss group': '解散群组',
48
+ 'quit group': '退出群组',
49
+ 'Enter group chat': '进入群聊',
50
+ 'Confirm dismiss group': '确认解散群组?',
51
+ 'Confirm quit group': '确认退出群组?',
52
+ 'Agree': '同意',
53
+ 'Refuse': '拒绝',
54
+ 'Accept': '接受',
55
+ 'Submit': '确认',
56
+ 'Cancel': '取消',
57
+ 'Delete friend': '删除好友',
58
+ 'Confirm delete friend': '确认删除好友?',
59
+ 'Friends': '好友',
60
+ 'User': '用户',
61
+ 'ID': 'ID',
62
+ 'Send Message': '发送消息',
63
+ 'Signature': '签名',
64
+ 'Blocked List': '黑名单列表',
65
+ 'Group List': '群聊列表',
66
+ 'Enter a userID': '输入用户ID',
67
+ 'Enter the verification info': '输入验证信息',
68
+ 'Request to join': '申请加入',
69
+ 'Requested': '已申请',
70
+ 'Handled': '已处理',
71
+ 'remark': '备注',
72
+ 'block': '拉黑',
73
+ 'waiting for verification': '等待验证',
74
+ 'verification info': '验证信息',
75
+ 'Send application': '发送申请',
76
+ },
77
+ };
@@ -0,0 +1,18 @@
1
+ import { addI18n } from '../../i18n';
2
+ import { ContactInfo as ContactInfoComponent } from './ContactInfo';
3
+ import ContactListComponent from './ContactList.vue';
4
+ import { ContactListItem as ContactListItemComponent } from './ContactListItem';
5
+ import { enResource, zhResource } from './i18n';
6
+
7
+ addI18n('en-US', { translation: enResource });
8
+ addI18n('zh-CN', { translation: zhResource });
9
+
10
+ const ContactListItem = ContactListItemComponent;
11
+ const ContactInfo = ContactInfoComponent;
12
+ const ContactList = ContactListComponent;
13
+
14
+ export {
15
+ ContactList,
16
+ ContactListItem,
17
+ ContactInfo,
18
+ };
@@ -18,56 +18,55 @@
18
18
  }
19
19
  }
20
20
 
21
- &__container {
22
- position: absolute;
23
- top: 100%;
24
- right: 0;
25
- border-radius: 4px;
26
- box-shadow: 0 0 10px var(--shadow-color);
27
- background-color: var(--bg-color-operate);
28
- z-index: 100;
29
- min-width: 120px;
21
+ &__h5 {
22
+ z-index: 5;
23
+ position: fixed;
24
+ width: 100%;
25
+ height: 100%;
26
+ top: 0;
27
+ left: 0;
28
+ display: flex;
29
+ flex-direction: column;
30
+ justify-content: flex-end;
31
+ background: var(--bg-color-mask)
30
32
  }
31
33
 
32
34
  &__h5__container {
33
- position: fixed;
34
- bottom: 0;
35
- left: 0;
36
- right: 0;
37
35
  background-color: var(--bg-color-operate);
38
36
  border-radius: 8px 8px 0 0;
39
37
  box-shadow: 0 0 10px var(--shadow-color);
40
- z-index: 100;
41
- padding: 16px;
38
+
39
+ .conversationActions__item {
40
+ text-align: center;
41
+ font-weight: 400;
42
+ font-size: 17px;
43
+ line-height: 22px;
44
+ padding: 16px 0;
45
+ border-bottom: 1px solid var(--stroke-color-primary);
46
+ color: var(--button-color-primary-default);
47
+
48
+ &:last-child {
49
+ border-bottom: none;
50
+ color: var(--text-color-error);
51
+ }
52
+ }
42
53
  }
43
54
 
44
55
  &__item {
45
- padding: 8px 12px;
46
- cursor: pointer;
47
56
  font-size: 14px;
48
- color: var(--text-color-primary, #333);
49
- border-bottom: 1px solid var(--stroke-color-primary, #f0f0f0);
50
- transition: background-color 0.2s;
51
- display: flex;
52
- align-items: center;
53
- gap: 8px;
57
+ line-height: 19px;
58
+ padding: 9px 16px;
59
+ cursor: pointer;
60
+ font-weight: 400;
61
+ box-sizing: border-box;
62
+ color: var(--text-color-primary);
54
63
 
55
64
  &:hover {
56
- background-color: var(--dropdown-color-active, #f8f9fa);
57
- }
58
-
59
- &:last-child {
60
- border-bottom: none;
65
+ background-color: var(--dropdown-color-active);
61
66
  }
62
67
 
63
68
  &--delete {
64
- color: var(--text-color-error, #dc3545);
65
- }
66
-
67
- .action-icon {
68
- width: 16px;
69
- height: 16px;
70
- flex-shrink: 0;
69
+ color: var(--text-color-error);
71
70
  }
72
71
  }
73
72
  }
@@ -1,23 +1,14 @@
1
1
  <template>
2
2
  <div
3
3
  :class="[$style.conversationActions, {
4
- [$style.conversationActions__H5]: isH5,
4
+ [$style.conversationActions__h5]: isH5,
5
5
  }, className]"
6
6
  :style="style"
7
7
  @click="handleMaskClick"
8
8
  >
9
9
  <div
10
- :class="$style.conversationActions__popupIcon"
11
- @click="toggleClick"
12
- >
13
- <slot name="popupIcon">
14
- <IconEllipsis />
15
- </slot>
16
- </div>
17
-
18
- <div
19
- v-if="PopupElements || isH5"
20
- :class="$style.conversationActions__H5__container"
10
+ v-if="isH5"
11
+ :class="$style.conversationActions__h5__container"
21
12
  @click.stop
22
13
  >
23
14
  <div
@@ -31,22 +22,18 @@
31
22
  {{ action.label }}
32
23
  </div>
33
24
  </div>
34
-
35
- <Popup
25
+ <TUIDropdown
36
26
  v-else
37
- :open="Boolean(anchor)"
38
- :anchor="anchor"
27
+ trigger="click"
39
28
  placement="bottom-end"
40
- disable-portal
41
- :slot-props="{
42
- root: {
43
- style: {
44
- zIndex: 5,
45
- },
46
- },
47
- }"
48
29
  >
49
- <div :class="$style.conversationActions__container">
30
+ <div
31
+ :class="$style.conversationActions__popupIcon"
32
+ @click="toggleClick"
33
+ >
34
+ <IconEllipsis />
35
+ </div>
36
+ <template #dropdown>
50
37
  <div
51
38
  v-for="(action, key) in enabledActions"
52
39
  :key="key"
@@ -57,16 +44,15 @@
57
44
  >
58
45
  {{ action.label }}
59
46
  </div>
60
- </div>
61
- </Popup>
47
+ </template>
48
+ </TUIDropdown>
62
49
  </div>
63
50
  </template>
64
51
 
65
52
  <script lang="ts" setup>
66
53
  import { computed, ref, watch } from 'vue';
67
54
  import TUIChatEngine from '@tencentcloud/chat-uikit-engine';
68
- import { IconEllipsis, useUIKit } from '@tencentcloud/uikit-base-component-vue3';
69
- import { Popup } from '../../../baseComp';
55
+ import { IconEllipsis, useUIKit, TUIDropdown } from '@tencentcloud/uikit-base-component-vue3';
70
56
  import { useConversationListState } from '../../../states/ConversationListState';
71
57
  import { isH5 } from '../../../utils';
72
58
  import type {
@@ -5,43 +5,17 @@
5
5
  justify-content: center;
6
6
  }
7
7
 
8
- &__main {
9
- position: absolute;
10
- top: 0;
11
- left: 0;
12
- right: 0;
13
- bottom: 0;
14
- background-color: var(--bg-color-operate);
15
- color: var(--text-color-primary);
16
- z-index: 100;
17
- display: flex;
18
- flex-direction: column;
19
- }
20
-
21
- &__header {
22
- display: flex;
23
- align-items: center;
24
- padding: 12px;
25
- background-color: var(--bg-color-topbar, #f5f5f5);
26
- }
27
-
28
- &__icon {
29
- cursor: pointer;
30
- padding: 4px;
31
- border-radius: 4px;
32
- transition: background-color 0.2s;
33
- color: var(--text-color-link, #e0e0e0);
34
- }
35
-
36
- &__title {
37
- margin-left: 12px;
38
- font-size: 16px;
39
- font-weight: 500;
40
- color: var(--text-color-primary, #333);
8
+ &__detail {
9
+ flex: 1;
41
10
  }
11
+ }
42
12
 
43
- &__content {
44
- flex: 1;
45
- overflow: hidden;
13
+ :deep(.conversationCreate__dialog) {
14
+ width: 100%;
15
+ height: 100%;
16
+ max-width: 100%;
17
+ border-radius: 0;
18
+ .dialog-body {
19
+ height: 0;
46
20
  }
47
- }
21
+ }
@@ -1,66 +1,69 @@
1
1
  <template>
2
2
  <div
3
- v-if="visible"
4
- :class="[$style.conversationCreate__container, className]"
5
- :style="style"
3
+ :class="['conversationCreate__container', {['conversationCreate__detail']: !enableSearch }]"
6
4
  >
7
- <ConversationCreateButton
8
- v-if="!showCreateConversation"
9
- @click="toggleCreateConversation(true)"
10
- />
11
-
12
- <div
13
- v-if="showCreateConversation"
14
- :class="$style.conversationCreate__main"
5
+ <ConversationCreateButton @click="openCreateConversation" />
6
+
7
+ <TUIDialog
8
+ :visible="showCreateConversation"
9
+ :title="dialogTitles"
10
+ :confirm-text="dialogConfirmText"
11
+ :cancel-text="dialogCancelText"
12
+ :custom-classes="[isH5 ? 'conversationCreate__dialog' : '']"
13
+ @confirm="handleConfirm"
14
+ @cancel="handleCancel"
15
+ @close="resetCreatePageState"
15
16
  >
16
- <div :class="$style.conversationCreate__header">
17
- <div
18
- :class="$style.conversationCreate__icon"
19
- @click="back"
20
- >
21
- <IconArrowStrokeBack />
22
- </div>
23
- <div :class="$style.conversationCreate__title">
24
- {{ !isCreateGroup ? t('TUIConversation.Start chat') : t('TUIConversation.Add Participants') }}
25
- </div>
26
- </div>
27
-
28
17
  <ConversationCreateUserSelectList
29
18
  v-if="pageState === PageStateTypes.USER_SELECT"
30
19
  :is-create-group="isCreateGroup"
31
- :set-is-create-group="setIsCreateGroup"
32
20
  :select-list="selectList"
33
21
  :set-select-list="setSelectList"
34
- :conversation-list="conversationList"
35
22
  :set-page-state="setPageState"
36
- :on-before-create-conversation="handleBeforeCreate"
37
- :on-conversation-created="handleCreated"
38
23
  />
39
24
 
40
25
  <ConversationCreateGroupDetail
41
26
  v-else
42
27
  :page-state="pageState"
43
28
  :profile-list="selectList"
29
+ :group-info="groupInfo"
44
30
  :set-page-state="setPageState"
45
- :on-before-create-conversation="handleBeforeCreate"
46
- :on-conversation-created="handleCreated"
31
+ @update-group-info="updateGroupInfo"
47
32
  />
48
- </div>
33
+ </TUIDialog>
49
34
  </div>
50
35
  </template>
51
36
 
52
37
  <script lang="ts" setup>
53
- import { ref, watch } from 'vue';
38
+ import { computed, ref } from 'vue';
54
39
  import { TUIConversationService } from '@tencentcloud/chat-uikit-engine';
55
- import { IconArrowStrokeBack, useUIKit } from '@tencentcloud/uikit-base-component-vue3';
56
- import { PageStateTypes } from '../../../types';
40
+ import { useUIKit, TUIDialog, TUIToast } from '@tencentcloud/uikit-base-component-vue3';
41
+ import { useConversationListState } from '../../../states/ConversationListState';
42
+ import { useLoginState } from '../../../states/LoginState';
43
+ import { PageStateTypes, CreateConvTypes, GroupType } from '../../../types';
44
+ import { isH5 } from '../../../utils/env';
45
+ import { useConversation } from '../hooks/useConversation';
46
+ import { useConversationCreate } from '../hooks/useConversationCreate';
57
47
  import ConversationCreateButton from './ConversationCreateButton/ConversationCreateButton.vue';
58
48
  import ConversationCreateGroupDetail from './ConversationCreateGroupDetail/ConversationCreateGroupDetail.vue';
59
49
  import ConversationCreateUserSelectList from './ConversationCreateUserSelectList/ConversationCreateUserSelectList.vue';
60
- import type { ConversationModel, ConversationCreateProps, CreateGroupParams } from '../../../types';
50
+ import type { ConversationModel, ConversationCreateProps, CreateGroupParams, CreateGroupInfo, Friend } from '../../../types';
51
+
52
+ const { t } = useUIKit();
53
+ const { enableSearch } = useConversation();
54
+ const { getDefaultAvatar } = useConversationCreate();
55
+ const { loginUserInfo } = useLoginState();
56
+ const { createC2CConversation, createGroupConversation } = useConversationListState();
57
+
58
+ const GROUP_NAME_LIMIT = 20;
59
+ const GROUP_INFO_DEFAULTS: CreateGroupInfo = {
60
+ avatar: getDefaultAvatar(GroupType.WORK),
61
+ name: '',
62
+ groupID: '',
63
+ type: GroupType.WORK,
64
+ };
61
65
 
62
66
  const props = withDefaults(defineProps<ConversationCreateProps>(), {
63
- visible: true,
64
67
  conversationList: () => [],
65
68
  });
66
69
 
@@ -70,12 +73,16 @@ const emit = defineEmits<{
70
73
  'conversationCreated': [conversation: ConversationModel];
71
74
  }>();
72
75
 
73
- const { t } = useUIKit();
74
-
75
76
  const showCreateConversation = ref(false);
76
77
  const isCreateGroup = ref(false);
77
78
  const pageState = ref<PageStateTypes>(PageStateTypes.USER_SELECT);
78
- const selectList = ref<any[]>([]);
79
+ const selectList = ref<Friend[]>([]);
80
+ const groupInfo = ref<CreateGroupInfo>({
81
+ avatar: getDefaultAvatar(GroupType.WORK),
82
+ name: '',
83
+ groupID: '',
84
+ type: GroupType.WORK,
85
+ });
79
86
 
80
87
  const setIsCreateGroup = (value: boolean) => {
81
88
  isCreateGroup.value = value;
@@ -85,65 +92,143 @@ const setPageState = (value: PageStateTypes) => {
85
92
  pageState.value = value;
86
93
  };
87
94
 
88
- const setSelectList = (value: any[]) => {
95
+ const setSelectList = (value: Friend[]) => {
89
96
  selectList.value = value;
90
97
  };
91
98
 
99
+ const openCreateConversation = (value: CreateConvTypes) => {
100
+ if (value === CreateConvTypes.GROUP) {
101
+ setIsCreateGroup(true);
102
+ } else {
103
+ setIsCreateGroup(false);
104
+ }
105
+ showCreateConversation.value = true;
106
+ };
107
+
92
108
  const toggleCreateConversation = (value: boolean) => {
93
109
  showCreateConversation.value = value;
94
110
  };
95
111
 
96
112
  const resetCreatePageState = () => {
113
+ toggleCreateConversation(false);
114
+ groupInfo.value = GROUP_INFO_DEFAULTS;
97
115
  isCreateGroup.value = false;
98
116
  pageState.value = PageStateTypes.USER_SELECT;
99
117
  selectList.value = [];
100
118
  };
101
119
 
102
120
  const _onConversationCreated = (conversation: ConversationModel) => {
103
- toggleCreateConversation(false);
104
121
  resetCreatePageState();
105
122
  TUIConversationService.switchConversation(conversation.conversationID);
106
123
  emit('conversationCreated', conversation);
124
+ props.onConversationCreated?.(conversation);
107
125
  };
108
126
 
109
- const back = () => {
110
- if (isCreateGroup.value) {
111
- switch (pageState.value) {
112
- case PageStateTypes.USER_SELECT:
113
- setIsCreateGroup(false);
114
- break;
115
- case PageStateTypes.CREATE_DETAIL:
116
- setPageState(PageStateTypes.USER_SELECT);
117
- setSelectList([]);
118
- break;
119
- case PageStateTypes.GROUP_TYPE:
120
- setPageState(PageStateTypes.CREATE_DETAIL);
121
- break;
122
- default:
123
- break;
124
- }
125
- } else {
126
- toggleCreateConversation(false);
127
- resetCreatePageState();
127
+ const pageStateTitle = {
128
+ [PageStateTypes.USER_SELECT]: t('TUIConversation.Add Participants'),
129
+ [PageStateTypes.CREATE_DETAIL]: t('TUIConversation.New group chat'),
130
+ [PageStateTypes.GROUP_TYPE]: t('TUIConversation.New group chat'),
131
+ };
132
+
133
+ const pageStateConfirmText = {
134
+ [PageStateTypes.USER_SELECT]: t('TUIConversation.Next'),
135
+ [PageStateTypes.CREATE_DETAIL]: t('TUIConversation.Start chat'),
136
+ [PageStateTypes.GROUP_TYPE]: t('TUIConversation.Confirm'),
137
+ };
138
+ const pageStateCancelText = {
139
+ [PageStateTypes.USER_SELECT]: t('TUIConversation.Cancel'),
140
+ [PageStateTypes.CREATE_DETAIL]: t('TUIConversation.Prev'),
141
+ [PageStateTypes.GROUP_TYPE]: t('TUIConversation.Prev'),
142
+ };
143
+ const dialogCancelText = computed(() => {
144
+ if (!isCreateGroup.value) {
145
+ return t('TUIConversation.Cancel');
146
+ }
147
+ return pageStateCancelText[pageState.value];
148
+ });
149
+
150
+ const dialogTitles = computed(() => {
151
+ if (!isCreateGroup.value) {
152
+ return t('TUIConversation.Start chat');
128
153
  }
154
+ return pageStateTitle[pageState.value];
155
+ });
156
+
157
+ const dialogConfirmText = computed(() => !isCreateGroup.value ? t('TUIConversation.Start chat') : pageStateConfirmText[pageState.value]);
158
+
159
+ const updateGroupInfo = (value: CreateGroupInfo) => {
160
+ groupInfo.value = value;
129
161
  };
130
162
 
131
- const handleBeforeCreate = (params: string | CreateGroupParams) => {
132
- if (props.onBeforeCreateConversation) {
133
- return props.onBeforeCreateConversation(params);
163
+ const handleCreateC2CConversation = async () => {
164
+ const { userID } = selectList.value[0];
165
+ emit('beforeCreateConversation', userID);
166
+ props.onBeforeCreateConversation?.(userID);
167
+
168
+ try {
169
+ const conversation = await createC2CConversation(userID);
170
+ _onConversationCreated(conversation);
171
+ } catch (error: any) {
172
+ TUIToast.error({ message: error.message });
134
173
  }
135
- return params;
136
174
  };
137
175
 
138
- const handleCreated = (conversation: ConversationModel) => {
139
- _onConversationCreated(conversation);
176
+ const handleCreateGroupConversation = async () => {
177
+ const options = {
178
+ ...groupInfo.value,
179
+ memberList: selectList.value.map(item => ({
180
+ userID: item.userID,
181
+ })),
182
+ } as unknown as CreateGroupParams;
183
+
184
+ emit('beforeCreateConversation', options);
185
+ props.onBeforeCreateConversation?.(options);
186
+
187
+ try {
188
+ const conversation = await createGroupConversation(options);
189
+ _onConversationCreated(conversation);
190
+ } catch (error: any) {
191
+ TUIToast.error({ message: error.message });
192
+ }
140
193
  };
141
194
 
142
- watch(showCreateConversation, (newValue) => {
143
- emit('update:visible', newValue);
144
- });
195
+ const generateGroupName = (userList: Friend[]) => {
196
+ const selfName = loginUserInfo.value?.userName || loginUserInfo.value?.userId || '';
197
+ const name = selfName + userList.map(item => item?.remark || item?.nick || item?.userID).join('、');
198
+ return name.length >= GROUP_NAME_LIMIT ? name.slice(0, GROUP_NAME_LIMIT) : name;
199
+ };
200
+
201
+ const handleConfirm = () => {
202
+ if (selectList.value.length === 0) {
203
+ TUIToast.error({ message: t('TUIConversation.Participant cannot be empty') });
204
+ return;
205
+ }
206
+ if (!isCreateGroup.value) {
207
+ handleCreateC2CConversation();
208
+ toggleCreateConversation(false);
209
+ } else if (pageState.value === PageStateTypes.USER_SELECT) {
210
+ groupInfo.value.name = generateGroupName(selectList.value);
211
+ setPageState(PageStateTypes.CREATE_DETAIL);
212
+ } else if (pageState.value === PageStateTypes.CREATE_DETAIL) {
213
+ handleCreateGroupConversation();
214
+ toggleCreateConversation(false);
215
+ } else {
216
+ setPageState(PageStateTypes.CREATE_DETAIL);
217
+ }
218
+ };
219
+
220
+ const handleCancel = () => {
221
+ if (pageState.value === PageStateTypes.USER_SELECT) {
222
+ toggleCreateConversation(false);
223
+ resetCreatePageState();
224
+ } else if (pageState.value === PageStateTypes.CREATE_DETAIL) {
225
+ setPageState(PageStateTypes.USER_SELECT);
226
+ } else if (pageState.value === PageStateTypes.GROUP_TYPE) {
227
+ setPageState(PageStateTypes.CREATE_DETAIL);
228
+ }
229
+ };
145
230
  </script>
146
231
 
147
- <style lang="scss" module>
232
+ <style lang="scss" scoped>
148
233
  @import './ConversationCreate.scss';
149
234
  </style>
@@ -2,6 +2,42 @@
2
2
  display: flex;
3
3
  align-items: center;
4
4
  cursor: pointer;
5
- color: var(--text-color-link);
6
5
  margin-right: 10px;
6
+ }
7
+
8
+ .conversation-create-dropdown {
9
+ display: flex;
10
+ justify-content: center;
11
+ padding: 5px 10px;
12
+ }
13
+
14
+ .conversation-create-list {
15
+ margin: 0;
16
+ display: flex;
17
+ flex-direction: column;
18
+ justify-content: center;
19
+ padding: 5px 0;
20
+ gap: 10px;
21
+ }
22
+
23
+ .conversation-create-list--detail {
24
+ padding: 10px 20px;
25
+ flex-direction: row;
26
+ justify-content: space-between;
27
+ align-items: center;
28
+ }
29
+
30
+ .conversation-create-item {
31
+ margin: 0;
32
+ padding: 0;
33
+ display: flex;
34
+ align-items: center;
35
+ gap: 6px;
36
+ cursor: pointer;
37
+ color: var(--text-color-primary);
38
+ }
39
+
40
+ .conversation-create-text {
41
+ font-size: 14px;
42
+ font-weight: 400;
7
43
  }