tuikit-atomicx-vue3 0.1.1 → 3.3.0

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 (582) hide show
  1. package/dist/AttachmentPicker.module-BesmtGyl.js +11 -0
  2. package/dist/FilePicker.vue_vue_type_script_setup_true_lang-CdJ4DUzE.js +76 -0
  3. package/dist/ImagePicker.vue_vue_type_script_setup_true_lang-CbNUofpK.js +76 -0
  4. package/dist/MessageInput.vue_vue_type_script_setup_true_lang-wUJPjWbx.js +128 -0
  5. package/dist/{PopoverTrigger-ByOI-vdB.js → PopoverTrigger-BKOIHfdS.js} +1 -1
  6. package/dist/{PopperContent-BaiCn-CA.js → PopperContent-DtL7HVWz.js} +29 -21
  7. package/dist/VideoPicker.vue_vue_type_script_setup_true_lang-CmxjbNDJ.js +76 -0
  8. package/dist/baseComp/TuiSwitch.js +2 -2
  9. package/dist/baseComp/index.d.ts +0 -1
  10. package/dist/baseComp/index.js +1 -3
  11. package/dist/chat/index.d.ts +5677 -6176
  12. package/dist/chat/index.js +24 -15
  13. package/dist/components/Avatar/Avatar.js +35 -10
  14. package/dist/components/Avatar/Avatar.vue.d.ts +1 -1
  15. package/dist/components/BarrageInput/BarrageInput.vue.d.ts +2 -2
  16. package/dist/components/BarrageInput/BarrageInputH5.js +60 -16
  17. package/dist/components/BarrageInput/BarrageInputH5.vue.d.ts +2 -2
  18. package/dist/components/BarrageInput/EmojiPicker/EmojiPicker.js +10 -6
  19. package/dist/components/BarrageInput/TextEditor/index.js +27 -11
  20. package/dist/components/BarrageInput/constants.d.ts +3 -0
  21. package/dist/components/BarrageInput/constants.js +6 -0
  22. package/dist/components/BarrageInput/i18n/en-US/index.d.ts +2 -0
  23. package/dist/components/BarrageInput/i18n/en-US/index.js +3 -1
  24. package/dist/components/BarrageInput/i18n/zh-CN/index.d.ts +2 -0
  25. package/dist/components/BarrageInput/i18n/zh-CN/index.js +3 -1
  26. package/dist/components/BarrageInput/index.d.ts +18 -18
  27. package/dist/components/BarrageList/BarrageList.js +5 -6
  28. package/dist/components/BarrageList/BarrageListH5.js +5 -6
  29. package/dist/components/BarrageList/Message/GroupTipMessage/GroupTipMessage.vue.d.ts +4 -4
  30. package/dist/components/BarrageList/Message/MessageLayout/MessageLayout.js +1 -1
  31. package/dist/components/BarrageList/Message/MessageLayout/MessageMeta/MessageMeta.js +5 -4
  32. package/dist/components/BarrageList/Message/MessageLayout/MessageMeta/MessageMeta.vue.d.ts +2 -2
  33. package/dist/components/BarrageList/Message/MessageLayout/MessageMeta/MessageStatusIcon.js +7 -4
  34. package/dist/components/BarrageList/Message/TextMessage/TextMessage.js +12 -4
  35. package/dist/components/BarrageList/i18n/en-US/index.d.ts +1 -0
  36. package/dist/components/BarrageList/i18n/en-US/index.js +2 -1
  37. package/dist/components/BarrageList/i18n/zh-CN/index.d.ts +1 -0
  38. package/dist/components/BarrageList/i18n/zh-CN/index.js +2 -1
  39. package/dist/components/ChatSetting/ChatSetting.js +8 -11
  40. package/dist/components/ChatSetting/GroupChatSetting/GroupActions/GroupActions.js +5 -2
  41. package/dist/components/ChatSetting/GroupChatSetting/GroupChatSetting.js +3 -2
  42. package/dist/components/ChatSetting/GroupChatSetting/GroupInfo/GroupInfo.js +4 -4
  43. package/dist/components/ChatSetting/GroupChatSetting/GroupManagement/GroupManagement.js +3 -2
  44. package/dist/components/ChatSetting/GroupChatSetting/GroupMembers/GroupMembers.js +5 -5
  45. package/dist/components/ChatSetting/SettingItem/SettingItem.js +116 -89
  46. package/dist/components/ChatSetting/i18n/en-US.js +3 -3
  47. package/dist/components/ChatSetting/i18n/index.d.ts +191 -1
  48. package/dist/components/ChatSetting/i18n/index.js +3 -4
  49. package/dist/components/ChatSetting/i18n/zh-CN.js +3 -3
  50. package/dist/components/ChatSetting/index.d.ts +1 -4
  51. package/dist/components/ChatSetting/index.js +7 -6
  52. package/dist/components/CoGuestPanel/CoGuestPanel.js +1 -1
  53. package/dist/components/ContactList/ContactInfo/BlacklistInfo/BlacklistInfo.js +78 -0
  54. package/dist/components/ContactList/ContactInfo/BlacklistInfo/BlacklistInfo.vue.d.ts +33 -0
  55. package/dist/components/ContactList/ContactInfo/BlacklistInfo/index.d.ts +1 -0
  56. package/dist/components/ContactList/ContactInfo/BlacklistInfo/index.js +4 -0
  57. package/dist/components/ContactList/ContactInfo/ContactInfo.js +257 -0
  58. package/dist/components/ContactList/ContactInfo/ContactInfo.vue.d.ts +80 -0
  59. package/dist/components/ContactList/ContactInfo/FriendApplicationInfo/FriendApplicationInfo.js +96 -0
  60. package/dist/components/ContactList/ContactInfo/FriendApplicationInfo/FriendApplicationInfo.vue.d.ts +37 -0
  61. package/dist/components/ContactList/ContactInfo/FriendApplicationInfo/index.d.ts +1 -0
  62. package/dist/components/ContactList/ContactInfo/FriendApplicationInfo/index.js +4 -0
  63. package/dist/components/ContactList/ContactInfo/FriendInfo/FriendInfo.js +228 -0
  64. package/dist/components/ContactList/ContactInfo/FriendInfo/FriendInfo.vue.d.ts +39 -0
  65. package/dist/components/ContactList/ContactInfo/FriendInfo/index.d.ts +1 -0
  66. package/dist/components/ContactList/ContactInfo/FriendInfo/index.js +4 -0
  67. package/dist/components/ContactList/ContactInfo/GroupApplicationInfo/GroupApplicationInfo.js +101 -0
  68. package/dist/components/ContactList/ContactInfo/GroupApplicationInfo/GroupApplicationInfo.vue.d.ts +37 -0
  69. package/dist/components/ContactList/ContactInfo/GroupApplicationInfo/index.d.ts +1 -0
  70. package/dist/components/ContactList/ContactInfo/GroupApplicationInfo/index.js +4 -0
  71. package/dist/components/ContactList/ContactInfo/GroupInfo/GroupInfo.js +155 -0
  72. package/dist/components/ContactList/ContactInfo/GroupInfo/GroupInfo.vue.d.ts +37 -0
  73. package/dist/components/ContactList/ContactInfo/GroupInfo/index.d.ts +1 -0
  74. package/dist/components/ContactList/ContactInfo/GroupInfo/index.js +4 -0
  75. package/dist/components/ContactList/ContactInfo/SearchGroupInfo/SearchGroupInfo.js +141 -0
  76. package/dist/components/ContactList/ContactInfo/SearchGroupInfo/SearchGroupInfo.vue.d.ts +32 -0
  77. package/dist/components/ContactList/ContactInfo/SearchGroupInfo/index.d.ts +1 -0
  78. package/dist/components/ContactList/ContactInfo/SearchGroupInfo/index.js +4 -0
  79. package/dist/components/ContactList/ContactInfo/SearchUserInfo/SearchUserInfo.js +122 -0
  80. package/dist/components/ContactList/ContactInfo/SearchUserInfo/SearchUserInfo.vue.d.ts +33 -0
  81. package/dist/components/ContactList/ContactInfo/SearchUserInfo/index.d.ts +1 -0
  82. package/dist/components/ContactList/ContactInfo/SearchUserInfo/index.js +4 -0
  83. package/dist/components/ContactList/ContactInfo/index.d.ts +8 -0
  84. package/dist/components/ContactList/ContactInfo/index.js +18 -0
  85. package/dist/components/ContactList/ContactList.js +290 -0
  86. package/dist/components/ContactList/ContactList.vue.d.ts +149 -0
  87. package/dist/components/ContactList/ContactListItem/BlacklistItem/BlacklistItem.js +52 -0
  88. package/dist/components/ContactList/ContactListItem/BlacklistItem/BlacklistItem.vue.d.ts +25 -0
  89. package/dist/components/ContactList/ContactListItem/BlacklistItem/index.d.ts +1 -0
  90. package/dist/components/ContactList/ContactListItem/BlacklistItem/index.js +4 -0
  91. package/dist/components/ContactList/ContactListItem/ContactListItem.js +4 -0
  92. package/dist/components/ContactList/ContactListItem/ContactListItem.vue.d.ts +30 -0
  93. package/dist/components/ContactList/ContactListItem/FriendApplicationItem/FriendApplicationItem.js +76 -0
  94. package/dist/components/ContactList/ContactListItem/FriendApplicationItem/FriendApplicationItem.vue.d.ts +27 -0
  95. package/dist/components/ContactList/ContactListItem/FriendApplicationItem/index.d.ts +1 -0
  96. package/dist/components/ContactList/ContactListItem/FriendApplicationItem/index.js +4 -0
  97. package/dist/components/ContactList/ContactListItem/FriendItem/FriendItem.js +53 -0
  98. package/dist/components/ContactList/ContactListItem/FriendItem/FriendItem.vue.d.ts +25 -0
  99. package/dist/components/ContactList/ContactListItem/FriendItem/index.d.ts +1 -0
  100. package/dist/components/ContactList/ContactListItem/FriendItem/index.js +4 -0
  101. package/dist/components/ContactList/ContactListItem/GroupApplicationItem/GroupApplicationItem.js +79 -0
  102. package/dist/components/ContactList/ContactListItem/GroupApplicationItem/GroupApplicationItem.vue.d.ts +27 -0
  103. package/dist/components/ContactList/ContactListItem/GroupApplicationItem/index.d.ts +1 -0
  104. package/dist/components/ContactList/ContactListItem/GroupApplicationItem/index.js +4 -0
  105. package/dist/components/ContactList/ContactListItem/GroupItem/GroupItem.js +52 -0
  106. package/dist/components/ContactList/ContactListItem/GroupItem/GroupItem.vue.d.ts +25 -0
  107. package/dist/components/ContactList/ContactListItem/GroupItem/index.d.ts +1 -0
  108. package/dist/components/ContactList/ContactListItem/GroupItem/index.js +4 -0
  109. package/dist/components/ContactList/ContactListItem/index.d.ts +6 -0
  110. package/dist/components/ContactList/ContactListItem/index.js +95 -0
  111. package/dist/components/ContactList/ContactSearch/ContactSearch.js +85 -0
  112. package/dist/components/ContactList/ContactSearch/ContactSearch.vue.d.ts +8 -0
  113. package/dist/components/ContactList/ContactSearch/index.d.ts +1 -0
  114. package/dist/components/ContactList/ContactSearch/index.js +4 -0
  115. package/dist/components/ContactList/constants/const.d.ts +3 -0
  116. package/dist/components/ContactList/constants/const.js +6 -0
  117. package/dist/components/ContactList/hooks/index.d.ts +1 -0
  118. package/dist/components/ContactList/hooks/index.js +4 -0
  119. package/dist/components/ContactList/hooks/useContactList.d.ts +9 -0
  120. package/dist/components/ContactList/hooks/useContactList.js +18 -0
  121. package/dist/components/ContactList/i18n/en-US.d.ts +77 -0
  122. package/dist/components/ContactList/i18n/en-US.js +80 -0
  123. package/dist/components/ContactList/i18n/index.d.ts +4 -0
  124. package/dist/components/ContactList/i18n/index.js +6 -0
  125. package/dist/components/ContactList/i18n/zh-CN.d.ts +77 -0
  126. package/dist/components/ContactList/i18n/zh-CN.js +80 -0
  127. package/dist/components/ContactList/index.d.ts +442 -0
  128. package/dist/components/ContactList/index.js +16 -0
  129. package/dist/components/ConversationList/ConversationActions/ConversationActions.js +30 -46
  130. package/dist/components/ConversationList/ConversationActions/ConversationActions.vue.d.ts +1 -10
  131. package/dist/components/ConversationList/ConversationCreate/ConversationCreate.js +161 -100
  132. package/dist/components/ConversationList/ConversationCreate/ConversationCreate.vue.d.ts +0 -3
  133. package/dist/components/ConversationList/ConversationCreate/ConversationCreateButton/ConversationCreateButton.js +79 -17
  134. package/dist/components/ConversationList/ConversationCreate/ConversationCreateButton/ConversationCreateButton.vue.d.ts +6 -12
  135. package/dist/components/ConversationList/ConversationCreate/ConversationCreateGroupDetail/ConversationCreateGroupDetail.js +78 -158
  136. package/dist/components/ConversationList/ConversationCreate/ConversationCreateGroupDetail/ConversationCreateGroupDetail.vue.d.ts +5 -4
  137. package/dist/components/ConversationList/ConversationCreate/ConversationCreateUserSelectList/ConversationCreateUserSelectList.js +37 -207
  138. package/dist/components/ConversationList/ConversationCreate/ConversationCreateUserSelectList/ConversationCreateUserSelectList.vue.d.ts +3 -9
  139. package/dist/components/ConversationList/ConversationCreate/ConversationGroupTypeInfo/ConversationGroupTypeInfo.js +35 -23
  140. package/dist/components/ConversationList/ConversationCreate/ConversationGroupTypeInfo/ConversationGroupTypeInfo.vue.d.ts +2 -11
  141. package/dist/components/ConversationList/ConversationCreate/ConversationGroupTypeInfo/index.js +1 -2
  142. package/dist/components/ConversationList/ConversationCreate/ConversationGroupTypeInfo/type.d.ts +2 -7
  143. package/dist/components/ConversationList/ConversationCreate/ConversationGroupTypeInfo/type.js +6 -14
  144. package/dist/components/ConversationList/ConversationCreate/index.d.ts +0 -2
  145. package/dist/components/ConversationList/ConversationCreate/index.js +5 -9
  146. package/dist/components/ConversationList/ConversationList.js +61 -75
  147. package/dist/components/ConversationList/ConversationList.vue.d.ts +844 -3038
  148. package/dist/components/ConversationList/ConversationListContent/ConversationListContent.js +12 -15
  149. package/dist/components/ConversationList/ConversationListContent/ConversationListContent.vue.d.ts +22 -340
  150. package/dist/components/ConversationList/ConversationPlaceHolder/ConversationPlaceHolder.js +2 -2
  151. package/dist/components/ConversationList/ConversationPreview/ConversationPreview.vue.d.ts +654 -1516
  152. package/dist/components/ConversationList/ConversationPreview/ConversationPreviewAbstract.js +15 -15
  153. package/dist/components/ConversationList/ConversationPreview/ConversationPreviewTimestamp.js +14 -14
  154. package/dist/components/ConversationList/ConversationPreview/ConversationPreviewTitle.js +19 -30
  155. package/dist/components/ConversationList/ConversationPreview/ConversationPreviewTitle.vue.d.ts +0 -2
  156. package/dist/components/ConversationList/ConversationPreview/ConversationPreviewUI.js +27 -44
  157. package/dist/components/ConversationList/ConversationPreview/ConversationPreviewUI.vue.d.ts +154 -368
  158. package/dist/components/ConversationList/ConversationPreview/ConversationPreviewUnread.js +14 -14
  159. package/dist/components/ConversationList/ConversationPreview/index.d.ts +1 -1
  160. package/dist/components/ConversationList/ConversationPreview/index.js +20 -24
  161. package/dist/components/ConversationList/ConversationPreview/utils.js +8 -8
  162. package/dist/components/ConversationList/ConversationSearch/ConversationSearch.js +6 -5
  163. package/dist/components/ConversationList/ConversationSearch/ConversationSearch.vue.d.ts +8 -8
  164. package/dist/components/ConversationList/hooks/useConversation.d.ts +6 -0
  165. package/dist/components/ConversationList/hooks/useConversation.js +20 -0
  166. package/dist/components/ConversationList/hooks/useConversationCreate.d.ts +5 -0
  167. package/dist/components/ConversationList/hooks/useConversationCreate.js +24 -0
  168. package/dist/components/ConversationList/i18n/en-US.d.ts +16 -0
  169. package/dist/components/ConversationList/i18n/en-US.js +25 -7
  170. package/dist/components/ConversationList/i18n/zh-CN.d.ts +16 -0
  171. package/dist/components/ConversationList/i18n/zh-CN.js +24 -6
  172. package/dist/components/ConversationList/index.d.ts +2231 -6662
  173. package/dist/components/ConversationList/index.js +1 -1
  174. package/dist/components/{LiveStreamView → LiveCoreView}/DefaultStreamViewUI.js +1 -1
  175. package/dist/components/LiveCoreView/index.d.ts +4 -0
  176. package/dist/components/{LiveStreamView → LiveCoreView}/index.js +154 -105
  177. package/dist/components/{LiveStreamView → LiveCoreView}/index.vue.d.ts +9 -0
  178. package/dist/components/LiveList/LiveList.js +73 -45
  179. package/dist/components/LiveList/LiveListH5.js +80 -75
  180. package/dist/components/LiveList/i18n/en-US/index.d.ts +5 -0
  181. package/dist/components/LiveList/i18n/en-US/index.js +6 -1
  182. package/dist/components/LiveList/i18n/zh-CN/index.d.ts +5 -0
  183. package/dist/components/LiveList/i18n/zh-CN/index.js +6 -1
  184. package/dist/components/LiveList/pullToRefresh.js +204 -0
  185. package/dist/components/LiveList/pullToRefresh.vue.d.ts +86 -0
  186. package/dist/components/LiveScenePanel/CameraSettingDialog.js +7 -7
  187. package/dist/components/LiveScenePanel/icons/AddIcon.js +2 -2
  188. package/dist/components/LiveScenePanel/icons/CameraIcon.js +2 -2
  189. package/dist/components/LiveScenePanel/icons/CameraMirror.js +2 -2
  190. package/dist/components/LiveScenePanel/icons/CameraUnmirror.js +2 -2
  191. package/dist/components/LiveScenePanel/icons/ImageIcon.js +2 -2
  192. package/dist/components/LiveScenePanel/icons/MoreIcon.js +2 -2
  193. package/dist/components/LiveScenePanel/icons/ScreenIcon.js +2 -2
  194. package/dist/components/LiveScenePanel/index.js +3 -3
  195. package/dist/components/MessageInput/AttachmentPicker/AttachmentPicker.vue.d.ts +0 -4
  196. package/dist/components/MessageInput/AttachmentPicker/FilePicker.js +1 -1
  197. package/dist/components/MessageInput/AttachmentPicker/ImagePicker.js +1 -1
  198. package/dist/components/MessageInput/AttachmentPicker/VideoPicker.js +1 -1
  199. package/dist/components/MessageInput/AttachmentPicker/index.js +15 -20
  200. package/dist/components/MessageInput/EmojiPicker/EmojiPicker.js +4 -4
  201. package/dist/components/MessageInput/MessageInput.js +1 -1
  202. package/dist/components/MessageInput/MessageInput.vue.d.ts +6 -9
  203. package/dist/components/MessageInput/QuotedMessagePreview/index.js +2 -2
  204. package/dist/components/MessageInput/SendButton/index.js +1 -1
  205. package/dist/components/MessageInput/TextEditor/TextEditor.vue.d.ts +2 -2
  206. package/dist/components/MessageInput/TextEditor/index.js +24 -14
  207. package/dist/components/MessageInput/i18n/index.d.ts +24 -1
  208. package/dist/components/MessageInput/i18n/index.js +7 -8
  209. package/dist/components/MessageInput/index.d.ts +373 -6
  210. package/dist/components/MessageInput/index.js +23 -125
  211. package/dist/components/MessageList/Message/AudioMessage/PlayButton.js +3 -3
  212. package/dist/components/MessageList/Message/CustomMessage/index.js +2 -2
  213. package/dist/components/MessageList/Message/FaceMessage/FaceMessage.js +7 -5
  214. package/dist/components/MessageList/Message/FaceMessage/FaceMessage.vue.d.ts +8 -8
  215. package/dist/components/MessageList/Message/ImageMessage/ImageMessage.js +2 -2
  216. package/dist/components/MessageList/Message/LocationMessage/LocationMessage.js +2 -1
  217. package/dist/components/MessageList/Message/MergerMessage/MergerMessage.js +2 -1
  218. package/dist/components/MessageList/Message/MessageLayout/MessageActionDropdown/MessageActionDropdown.js +14 -6
  219. package/dist/components/MessageList/Message/MessageLayout/MessageActionDropdown/MessageActionDropdown.vue.d.ts +8 -8
  220. package/dist/components/MessageList/Message/MessageLayout/MessageLayout.js +1 -1
  221. package/dist/components/MessageList/Message/MessageLayout/MessageMeta/MessageMeta.js +34 -30
  222. package/dist/components/MessageList/Message/MessageLayout/MessageMeta/MessageMeta.vue.d.ts +0 -10
  223. package/dist/components/MessageList/MessageForward/MessageForward.js +4 -5
  224. package/dist/components/MessageList/MessageList.js +76 -63
  225. package/dist/components/MessageList/MessageList.vue.d.ts +4 -4
  226. package/dist/components/MessageList/MessageTimeDivider/MessageTimeDivider.js +5 -5
  227. package/dist/components/MessageList/MessageTimeDivider/MessageTimeDivider.vue.d.ts +10 -10
  228. package/dist/components/MessageList/ScrollToBottom/ScrollToBottom.js +32 -0
  229. package/dist/components/MessageList/ScrollToBottom/ScrollToBottom.vue.d.ts +6 -0
  230. package/dist/components/MessageList/ScrollToBottom/index.d.ts +3 -0
  231. package/dist/components/MessageList/ScrollToBottom/index.js +4 -0
  232. package/dist/components/MessageList/i18n/en-US.d.ts +5 -0
  233. package/dist/components/MessageList/i18n/en-US.js +6 -1
  234. package/dist/components/MessageList/i18n/index.d.ts +85 -1
  235. package/dist/components/MessageList/i18n/index.js +7 -8
  236. package/dist/components/MessageList/i18n/zh-CN.d.ts +5 -0
  237. package/dist/components/MessageList/i18n/zh-CN.js +6 -1
  238. package/dist/components/MessageList/index.d.ts +143 -5
  239. package/dist/components/MessageList/index.js +9 -5
  240. package/dist/components/Search/Search.js +5 -7
  241. package/dist/components/Search/Search.vue.d.ts +4 -4
  242. package/dist/components/Search/SearchAdvanced/DateRangePicker/DateRangePicker.js +15 -9
  243. package/dist/components/Search/SearchAdvanced/MessageAdvanced/MessageAdvanced.js +12 -7
  244. package/dist/components/Search/SearchAdvanced/SearchAdvanced.js +2 -2
  245. package/dist/components/Search/SearchAdvanced/SearchTab/SearchTab.js +10 -5
  246. package/dist/components/Search/SearchAdvanced/UserAdvanced/UserAdvanced.js +10 -10
  247. package/dist/components/Search/SearchBar/SearchBar.js +3 -2
  248. package/dist/components/Search/SearchResults/EmptyResult/EmptyResult.js +5 -7
  249. package/dist/components/Search/SearchResults/Loading/Loading.js +2 -4
  250. package/dist/components/Search/SearchResults/SearchResults.js +80 -69
  251. package/dist/components/Search/SearchResults/SearchResultsItem/Conversation/Conversation.js +6 -8
  252. package/dist/components/Search/SearchResults/SearchResultsItem/Group/Group.js +5 -7
  253. package/dist/components/Search/SearchResults/SearchResultsItem/Message/Message.js +19 -21
  254. package/dist/components/Search/SearchResults/SearchResultsItem/SearchResultsItem.js +1 -3
  255. package/dist/components/Search/SearchResults/SearchResultsItem/User/User.js +5 -7
  256. package/dist/components/Search/SearchResults/SearchResultsItem/utils/highlightText.d.ts +5 -6
  257. package/dist/components/Search/i18n/en-US/Search.js +9 -9
  258. package/dist/components/Search/i18n/zh-CN/Search.js +13 -13
  259. package/dist/components/Search/index.d.ts +6 -6
  260. package/dist/components/StreamMixer/LocalMixer/MixerControl.js +14 -10
  261. package/dist/components/StreamMixer/LocalMixer/index.js +90 -59
  262. package/dist/components/StreamMixer/icons/CameraMirror.js +2 -2
  263. package/dist/components/StreamMixer/icons/Delete.js +2 -2
  264. package/dist/components/StreamMixer/icons/Down.js +2 -2
  265. package/dist/components/StreamMixer/icons/Rotation.js +2 -2
  266. package/dist/components/StreamMixer/icons/Up.js +2 -2
  267. package/dist/components/StreamMixer/index.js +2 -2
  268. package/dist/components/StreamView/common/StreamCover/index.js +2 -2
  269. package/dist/components/StreamView/manager/mediaManager.js +1 -1
  270. package/dist/components/UserPicker/UserPicker.js +2 -2
  271. package/dist/components/UserPicker/UserPicker.vue.d.ts +7 -8
  272. package/dist/components/UserPicker/components/ListMode/ListMode.js +14 -17
  273. package/dist/components/UserPicker/components/ListMode/ListMode.vue.d.ts +2 -2
  274. package/dist/components/UserPicker/components/SelectedPanel/SelectedPanel.vue.d.ts +2 -2
  275. package/dist/components/UserPicker/components/TreeMode/TreeMode.vue.d.ts +3 -3
  276. package/dist/components/UserPicker/components/TreeMode/TreeNode.js +2 -2
  277. package/dist/components/UserPicker/components/TreeMode/TreeNode.vue.d.ts +4 -4
  278. package/dist/components/UserPicker/hooks/useSearchFilter.d.ts +3 -3
  279. package/dist/components/UserPicker/hooks/useSelection.d.ts +8 -8
  280. package/dist/components/UserPicker/hooks/useTreeState.d.ts +3 -3
  281. package/dist/components/UserPicker/i18n/index.d.ts +15 -1
  282. package/dist/components/UserPicker/i18n/index.js +3 -4
  283. package/dist/components/UserPicker/index.d.ts +134 -4
  284. package/dist/components/UserPicker/index.js +7 -3
  285. package/dist/components/UserPicker/type.d.ts +18 -18
  286. package/dist/components/VideoSettingPanel/VideoPreview.js +3 -4
  287. package/dist/components/VideoSettingPanel/VideoProfile.js +3 -4
  288. package/dist/components/VideoSettingPanel/i18n/en-US/index.d.ts +5 -0
  289. package/dist/components/VideoSettingPanel/i18n/en-US/index.js +8 -3
  290. package/dist/components/VideoSettingPanel/i18n/zh-CN/index.d.ts +5 -0
  291. package/dist/components/VideoSettingPanel/i18n/zh-CN/index.js +8 -3
  292. package/dist/components/VideoSettingPanel/index.js +3 -3
  293. package/dist/hooks/useLongPress.d.ts +4 -4
  294. package/dist/hooks/useMessageActions.js +5 -5
  295. package/dist/hooks/useMouseHover.d.ts +7 -5
  296. package/dist/hooks/useMouseHover.js +3 -1
  297. package/dist/index.js +17 -8
  298. package/dist/rtc/index.d.ts +31 -20
  299. package/dist/rtc/index.js +6 -3
  300. package/dist/states/BarrageListState/BarrageListState.js +3 -2
  301. package/dist/states/CoHostState.d.ts +1 -1
  302. package/dist/states/CoHostState.js +59 -62
  303. package/dist/states/ContactListState/ContactListState.d.ts +16 -16
  304. package/dist/states/ContactListState/ContactListState.js +20 -20
  305. package/dist/states/ConversationListState/ConversationListState.d.ts +13 -12
  306. package/dist/states/ConversationListState/ConversationListState.js +19 -19
  307. package/dist/states/GroupSettingState/GroupSettingState.js +3 -3
  308. package/dist/states/LiveSeatState/seatEventManager.js +3 -5
  309. package/dist/states/LiveSeatState/usePlayStream/MixStreamPlayer.js +12 -0
  310. package/dist/states/LiveState/index.d.ts +4 -4
  311. package/dist/states/LiveState/index.js +4 -2
  312. package/dist/states/LoginState.js +2 -3
  313. package/dist/states/MessageInputState/MessageInputState.js +39 -19
  314. package/dist/states/SearchState.d.ts +2 -2
  315. package/dist/states/SearchState.js +124 -127
  316. package/dist/styles/index.css +2814 -4214
  317. package/dist/types/contact.d.ts +146 -9
  318. package/dist/types/conversation.d.ts +48 -42
  319. package/dist/types/conversation.js +22 -0
  320. package/dist/types/engine.d.ts +12 -0
  321. package/dist/types/engine.js +15 -0
  322. package/dist/types/index.js +7 -4
  323. package/dist/types/live.d.ts +2 -3
  324. package/dist/types/types.d.ts +0 -8
  325. package/dist/types/types.js +0 -10
  326. package/dist/utils/json.js +0 -1
  327. package/dist/utils/time.d.ts +2 -2
  328. package/dist/utils/time.js +253 -1471
  329. package/package.json +27 -5
  330. package/src/baseComp/View/View.vue +1 -2
  331. package/src/baseComp/index.ts +1 -2
  332. package/src/chat/index.ts +23 -4
  333. package/src/components/Avatar/Avatar.vue +12 -11
  334. package/src/components/BarrageInput/BarrageInputH5.vue +85 -12
  335. package/src/components/BarrageInput/EmojiPicker/EmojiPicker.module.scss +1 -0
  336. package/src/components/BarrageInput/EmojiPicker/EmojiPicker.vue +1 -1
  337. package/src/components/BarrageInput/TextEditor/Editor.scss +1 -1
  338. package/src/components/BarrageInput/TextEditor/TextEditor.module.scss +2 -0
  339. package/src/components/BarrageInput/TextEditor/TextEditor.vue +19 -5
  340. package/src/components/BarrageInput/constants.ts +3 -0
  341. package/src/components/BarrageInput/i18n/en-US/index.ts +2 -0
  342. package/src/components/BarrageInput/i18n/zh-CN/index.ts +2 -0
  343. package/src/components/BarrageList/BarrageList.vue +2 -2
  344. package/src/components/BarrageList/BarrageListH5.vue +2 -2
  345. package/src/components/BarrageList/Message/GroupTipMessage/GroupTipMessage.vue +8 -8
  346. package/src/components/BarrageList/Message/MessageLayout/MessageLayout.vue +0 -1
  347. package/src/components/BarrageList/Message/MessageLayout/MessageMeta/MessageMeta.vue +5 -2
  348. package/src/components/BarrageList/Message/MessageLayout/MessageMeta/MessageStatusIcon.vue +7 -3
  349. package/src/components/BarrageList/Message/TextMessage/TextMessage.vue +13 -3
  350. package/src/components/BarrageList/i18n/en-US/index.ts +1 -0
  351. package/src/components/BarrageList/i18n/zh-CN/index.ts +1 -0
  352. package/src/components/ChatSetting/ChatSetting.vue +6 -10
  353. package/src/components/ChatSetting/GroupChatSetting/GroupActions/GroupActions.vue +5 -2
  354. package/src/components/ChatSetting/GroupChatSetting/GroupChatSetting.vue +5 -4
  355. package/src/components/ChatSetting/GroupChatSetting/GroupInfo/GroupInfo.vue +3 -3
  356. package/src/components/ChatSetting/GroupChatSetting/GroupManagement/GroupManagement.vue +3 -2
  357. package/src/components/ChatSetting/GroupChatSetting/GroupMembers/GroupMembers.vue +3 -3
  358. package/src/components/ChatSetting/SettingItem/SettingItem.vue +48 -41
  359. package/src/components/ChatSetting/i18n/en-US.ts +3 -3
  360. package/src/components/ChatSetting/i18n/index.ts +3 -5
  361. package/src/components/ChatSetting/i18n/zh-CN.ts +3 -3
  362. package/src/components/ChatSetting/index.ts +8 -4
  363. package/src/components/CoGuestPanel/CoGuestPanel.vue +9 -0
  364. package/src/components/ContactList/ContactInfo/BlacklistInfo/BlacklistInfo.scss +52 -0
  365. package/src/components/ContactList/ContactInfo/BlacklistInfo/BlacklistInfo.vue +71 -0
  366. package/src/components/ContactList/ContactInfo/BlacklistInfo/index.ts +1 -0
  367. package/src/components/ContactList/ContactInfo/ContactInfo.scss +33 -0
  368. package/src/components/ContactList/ContactInfo/ContactInfo.vue +264 -0
  369. package/src/components/ContactList/ContactInfo/FriendApplicationInfo/FriendApplicationInfo.scss +84 -0
  370. package/src/components/ContactList/ContactInfo/FriendApplicationInfo/FriendApplicationInfo.vue +88 -0
  371. package/src/components/ContactList/ContactInfo/FriendApplicationInfo/index.ts +1 -0
  372. package/src/components/ContactList/ContactInfo/FriendInfo/FriendInfo.scss +93 -0
  373. package/src/components/ContactList/ContactInfo/FriendInfo/FriendInfo.vue +219 -0
  374. package/src/components/ContactList/ContactInfo/FriendInfo/index.ts +1 -0
  375. package/src/components/ContactList/ContactInfo/GroupApplicationInfo/GroupApplicationInfo.scss +84 -0
  376. package/src/components/ContactList/ContactInfo/GroupApplicationInfo/GroupApplicationInfo.vue +99 -0
  377. package/src/components/ContactList/ContactInfo/GroupApplicationInfo/index.ts +1 -0
  378. package/src/components/ContactList/ContactInfo/GroupInfo/GroupInfo.scss +54 -0
  379. package/src/components/ContactList/ContactInfo/GroupInfo/GroupInfo.vue +147 -0
  380. package/src/components/ContactList/ContactInfo/GroupInfo/index.ts +1 -0
  381. package/src/components/ContactList/ContactInfo/SearchGroupInfo/SearchGroupInfo.scss +111 -0
  382. package/src/components/ContactList/ContactInfo/SearchGroupInfo/SearchGroupInfo.vue +147 -0
  383. package/src/components/ContactList/ContactInfo/SearchGroupInfo/index.ts +1 -0
  384. package/src/components/ContactList/ContactInfo/SearchUserInfo/SearchUserInfo.scss +112 -0
  385. package/src/components/ContactList/ContactInfo/SearchUserInfo/SearchUserInfo.vue +128 -0
  386. package/src/components/ContactList/ContactInfo/SearchUserInfo/index.ts +1 -0
  387. package/src/components/ContactList/ContactInfo/index.ts +8 -0
  388. package/src/components/ContactList/ContactList.scss +125 -0
  389. package/src/components/ContactList/ContactList.vue +314 -0
  390. package/src/components/ContactList/ContactListItem/BlacklistItem/BlacklistItem.scss +39 -0
  391. package/src/components/ContactList/ContactListItem/BlacklistItem/BlacklistItem.vue +47 -0
  392. package/src/components/ContactList/ContactListItem/BlacklistItem/index.ts +1 -0
  393. package/src/components/ContactList/ContactListItem/ContactListItem.vue +98 -0
  394. package/src/components/ContactList/ContactListItem/FriendApplicationItem/FriendApplicationItem.scss +57 -0
  395. package/src/components/ContactList/ContactListItem/FriendApplicationItem/FriendApplicationItem.vue +70 -0
  396. package/src/components/ContactList/ContactListItem/FriendApplicationItem/index.ts +1 -0
  397. package/src/components/ContactList/ContactListItem/FriendItem/FriendItem.scss +39 -0
  398. package/src/components/ContactList/ContactListItem/FriendItem/FriendItem.vue +47 -0
  399. package/src/components/ContactList/ContactListItem/FriendItem/index.ts +1 -0
  400. package/src/components/ContactList/ContactListItem/GroupApplicationItem/GroupApplicationItem.scss +56 -0
  401. package/src/components/ContactList/ContactListItem/GroupApplicationItem/GroupApplicationItem.vue +78 -0
  402. package/src/components/ContactList/ContactListItem/GroupApplicationItem/index.ts +1 -0
  403. package/src/components/ContactList/ContactListItem/GroupItem/GroupItem.scss +39 -0
  404. package/src/components/ContactList/ContactListItem/GroupItem/GroupItem.vue +47 -0
  405. package/src/components/ContactList/ContactListItem/GroupItem/index.ts +1 -0
  406. package/src/components/ContactList/ContactListItem/index.ts +6 -0
  407. package/src/components/ContactList/ContactSearch/ContactSearch.scss +58 -0
  408. package/src/components/ContactList/ContactSearch/ContactSearch.vue +98 -0
  409. package/src/components/ContactList/ContactSearch/index.ts +1 -0
  410. package/src/components/ContactList/constants/const.ts +7 -0
  411. package/src/components/ContactList/hooks/index.ts +1 -0
  412. package/src/components/ContactList/hooks/useContactList.ts +21 -0
  413. package/src/components/ContactList/i18n/en-US.ts +77 -0
  414. package/src/components/ContactList/i18n/index.ts +4 -0
  415. package/src/components/ContactList/i18n/zh-CN.ts +77 -0
  416. package/src/components/ContactList/index.ts +18 -0
  417. package/src/components/ConversationList/ConversationActions/ConversationActions.scss +36 -47
  418. package/src/components/ConversationList/ConversationActions/ConversationActions.vue +15 -29
  419. package/src/components/ConversationList/ConversationCreate/ConversationCreate.scss +11 -37
  420. package/src/components/ConversationList/ConversationCreate/ConversationCreate.vue +155 -69
  421. package/src/components/ConversationList/ConversationCreate/ConversationCreateButton/ConversationCreateButton.scss +37 -1
  422. package/src/components/ConversationList/ConversationCreate/ConversationCreateButton/ConversationCreateButton.vue +70 -15
  423. package/src/components/ConversationList/ConversationCreate/ConversationCreateGroupDetail/ConversationCreateGroupDetail.scss +20 -66
  424. package/src/components/ConversationList/ConversationCreate/ConversationCreateGroupDetail/ConversationCreateGroupDetail.vue +72 -139
  425. package/src/components/ConversationList/ConversationCreate/ConversationCreateUserSelectList/ConversationCreateUserSelectList.scss +5 -129
  426. package/src/components/ConversationList/ConversationCreate/ConversationCreateUserSelectList/ConversationCreateUserSelectList.vue +42 -183
  427. package/src/components/ConversationList/ConversationCreate/ConversationGroupTypeInfo/ConversationGroupTypeInfo.scss +15 -11
  428. package/src/components/ConversationList/ConversationCreate/ConversationGroupTypeInfo/ConversationGroupTypeInfo.vue +23 -18
  429. package/src/components/ConversationList/ConversationCreate/ConversationGroupTypeInfo/type.ts +2 -8
  430. package/src/components/ConversationList/ConversationCreate/index.ts +0 -2
  431. package/src/components/ConversationList/ConversationList.scss +1 -5
  432. package/src/components/ConversationList/ConversationList.vue +53 -60
  433. package/src/components/ConversationList/ConversationListContent/ConversationListContent.scss +3 -5
  434. package/src/components/ConversationList/ConversationListContent/ConversationListContent.vue +13 -18
  435. package/src/components/ConversationList/ConversationPlaceHolder/ConversationPlaceHolder.vue +2 -2
  436. package/src/components/ConversationList/ConversationPreview/ConversationPreview.scss +11 -9
  437. package/src/components/ConversationList/ConversationPreview/ConversationPreview.vue +14 -16
  438. package/src/components/ConversationList/ConversationPreview/ConversationPreviewAbstract.vue +1 -1
  439. package/src/components/ConversationList/ConversationPreview/ConversationPreviewTitle.vue +2 -14
  440. package/src/components/ConversationList/ConversationPreview/ConversationPreviewUI.vue +6 -19
  441. package/src/components/ConversationList/ConversationPreview/index.ts +1 -1
  442. package/src/components/ConversationList/ConversationPreview/utils.ts +11 -11
  443. package/src/components/ConversationList/ConversationSearch/ConversationSearch.vue +1 -0
  444. package/src/components/ConversationList/hooks/useConversation.ts +21 -0
  445. package/src/components/ConversationList/hooks/useConversationCreate.ts +29 -0
  446. package/src/components/ConversationList/i18n/en-US.ts +26 -6
  447. package/src/components/ConversationList/i18n/zh-CN.ts +25 -5
  448. package/src/components/{LiveStreamView → LiveCoreView}/index.ts +4 -3
  449. package/src/components/LiveCoreView/index.vue +420 -0
  450. package/src/components/LiveList/LiveList.vue +97 -38
  451. package/src/components/LiveList/LiveListH5.vue +65 -66
  452. package/src/components/LiveList/i18n/en-US/index.ts +5 -0
  453. package/src/components/LiveList/i18n/zh-CN/index.ts +5 -0
  454. package/src/components/LiveList/pullToRefresh.vue +364 -0
  455. package/src/components/LiveScenePanel/CameraSettingDialog.vue +6 -5
  456. package/src/components/LiveScenePanel/index.vue +2 -2
  457. package/src/components/MessageInput/AttachmentPicker/AttachmentPicker.module.scss +4 -0
  458. package/src/components/MessageInput/AttachmentPicker/AttachmentPicker.vue +12 -17
  459. package/src/components/MessageInput/AttachmentPicker/FilePicker.vue +3 -2
  460. package/src/components/MessageInput/AttachmentPicker/ImagePicker.vue +3 -2
  461. package/src/components/MessageInput/AttachmentPicker/VideoPicker.vue +3 -2
  462. package/src/components/MessageInput/EmojiPicker/EmojiPicker.module.scss +1 -0
  463. package/src/components/MessageInput/MessageInput.module.scss +1 -1
  464. package/src/components/MessageInput/MessageInput.vue +21 -15
  465. package/src/components/MessageInput/QuotedMessagePreview/QuotedMessagePreview.vue +2 -2
  466. package/src/components/MessageInput/SendButton/SendButton.vue +1 -1
  467. package/src/components/MessageInput/TextEditor/Editor.scss +4 -2
  468. package/src/components/MessageInput/TextEditor/TextEditor.module.scss +1 -0
  469. package/src/components/MessageInput/TextEditor/TextEditor.vue +18 -6
  470. package/src/components/MessageInput/i18n/index.ts +1 -7
  471. package/src/components/MessageInput/index.ts +25 -8
  472. package/src/components/MessageInput/types.d.ts +3 -4
  473. package/src/components/MessageList/Message/CustomMessage/CustomMessage.vue +1 -1
  474. package/src/components/MessageList/Message/FaceMessage/FaceMessage.vue +10 -7
  475. package/src/components/MessageList/Message/LocationMessage/LocationMessage.vue +3 -1
  476. package/src/components/MessageList/Message/MergerMessage/MergerMessage.vue +1 -1
  477. package/src/components/MessageList/Message/MessageLayout/MessageActionDropdown/MessageActionDropdown.vue +6 -6
  478. package/src/components/MessageList/Message/MessageLayout/MessageLayout.vue +0 -1
  479. package/src/components/MessageList/Message/MessageLayout/MessageMeta/MessageMeta.vue +16 -17
  480. package/src/components/MessageList/MessageForward/MessageForward.vue +5 -5
  481. package/src/components/MessageList/MessageList.vue +37 -9
  482. package/src/components/MessageList/MessageTimeDivider/MessageTimeDivider.vue +9 -9
  483. package/src/components/MessageList/ScrollToBottom/ScrollToBottom.vue +50 -0
  484. package/src/components/MessageList/ScrollToBottom/index.ts +5 -0
  485. package/src/components/MessageList/i18n/en-US.ts +5 -0
  486. package/src/components/MessageList/i18n/index.ts +1 -5
  487. package/src/components/MessageList/i18n/zh-CN.ts +5 -0
  488. package/src/components/MessageList/index.ts +9 -5
  489. package/src/components/Search/Search.scss +0 -3
  490. package/src/components/Search/Search.vue +0 -4
  491. package/src/components/Search/SearchAdvanced/DateRangePicker/DateRangePicker.vue +125 -38
  492. package/src/components/Search/SearchAdvanced/MessageAdvanced/MessageAdvanced.vue +24 -16
  493. package/src/components/Search/SearchAdvanced/SearchAdvanced.vue +9 -7
  494. package/src/components/Search/SearchAdvanced/SearchTab/SearchTab.vue +4 -3
  495. package/src/components/Search/SearchAdvanced/UserAdvanced/UserAdvanced.scss +0 -1
  496. package/src/components/Search/SearchAdvanced/UserAdvanced/UserAdvanced.vue +57 -23
  497. package/src/components/Search/SearchBar/SearchBar.scss +0 -2
  498. package/src/components/Search/SearchBar/SearchBar.vue +7 -5
  499. package/src/components/Search/SearchResults/EmptyResult/EmptyResult.scss +0 -3
  500. package/src/components/Search/SearchResults/EmptyResult/EmptyResult.vue +4 -2
  501. package/src/components/Search/SearchResults/Loading/Loading.scss +0 -3
  502. package/src/components/Search/SearchResults/SearchResults.scss +12 -27
  503. package/src/components/Search/SearchResults/SearchResults.vue +25 -29
  504. package/src/components/Search/SearchResults/SearchResultsItem/Conversation/Conversation.scss +5 -19
  505. package/src/components/Search/SearchResults/SearchResultsItem/Group/Group.scss +5 -11
  506. package/src/components/Search/SearchResults/SearchResultsItem/Message/Message.scss +5 -11
  507. package/src/components/Search/SearchResults/SearchResultsItem/SearchResultsItem.scss +0 -3
  508. package/src/components/Search/SearchResults/SearchResultsItem/User/User.scss +5 -6
  509. package/src/components/Search/SearchResults/SearchResultsItem/utils/highlightText.ts +15 -16
  510. package/src/components/Search/i18n/en-US/Search.ts +9 -9
  511. package/src/components/Search/i18n/zh-CN/Search.ts +13 -13
  512. package/src/components/StreamMixer/LocalMixer/MixerControl.vue +20 -15
  513. package/src/components/StreamMixer/LocalMixer/index.vue +138 -60
  514. package/src/components/StreamMixer/index.vue +3 -3
  515. package/src/components/StreamView/manager/mediaManager.ts +1 -1
  516. package/src/components/UserPicker/UserPicker.vue +6 -9
  517. package/src/components/UserPicker/components/ListMode/ListMode.vue +3 -7
  518. package/src/components/UserPicker/components/SelectedPanel/SelectedPanel.vue +2 -2
  519. package/src/components/UserPicker/components/TreeMode/TreeMode.vue +3 -3
  520. package/src/components/UserPicker/components/TreeMode/TreeNode.vue +3 -3
  521. package/src/components/UserPicker/hooks/useSearchFilter.ts +15 -14
  522. package/src/components/UserPicker/hooks/useSelection.ts +32 -32
  523. package/src/components/UserPicker/hooks/useTreeState.ts +4 -4
  524. package/src/components/UserPicker/i18n/index.ts +1 -5
  525. package/src/components/UserPicker/index.ts +20 -17
  526. package/src/components/UserPicker/type.ts +18 -18
  527. package/src/components/VideoSettingPanel/VideoPreview.vue +13 -8
  528. package/src/components/VideoSettingPanel/VideoProfile.vue +5 -5
  529. package/src/components/VideoSettingPanel/i18n/en-US/index.ts +8 -3
  530. package/src/components/VideoSettingPanel/i18n/zh-CN/index.ts +8 -3
  531. package/src/components/VideoSettingPanel/index.vue +15 -9
  532. package/src/hooks/useLongPress.ts +7 -18
  533. package/src/hooks/useMessageActions.ts +5 -5
  534. package/src/hooks/useMouseHover.ts +9 -7
  535. package/src/rtc/index.ts +6 -3
  536. package/src/types/contact.ts +176 -12
  537. package/src/types/conversation.ts +54 -46
  538. package/src/types/engine.ts +15 -0
  539. package/src/types/live.ts +3 -5
  540. package/src/types/types.ts +0 -28
  541. package/src/utils/json.ts +0 -4
  542. package/src/utils/time.ts +8 -10
  543. package/dist/AttachmentPicker.module-0_DWsAtr.js +0 -11
  544. package/dist/FilePicker.vue_vue_type_script_setup_true_lang-CaSj3Gh_.js +0 -72
  545. package/dist/ImagePicker.vue_vue_type_script_setup_true_lang-CrzGMmrh.js +0 -72
  546. package/dist/VideoPicker.vue_vue_type_script_setup_true_lang-DTv6TJKr.js +0 -72
  547. package/dist/baseComp/Popup/Popup.js +0 -132
  548. package/dist/baseComp/Popup/Popup.vue.d.ts +0 -54
  549. package/dist/baseComp/Popup/index.d.ts +0 -2
  550. package/dist/baseComp/Popup/index.js +0 -4
  551. package/dist/components/ConversationList/ConversationCreate/ConversationCreateSelectView/ConversationCreateSelectView.js +0 -65
  552. package/dist/components/ConversationList/ConversationCreate/ConversationCreateSelectView/ConversationCreateSelectView.vue.d.ts +0 -17
  553. package/dist/components/ConversationList/ConversationCreate/ConversationCreateSelectView/index.d.ts +0 -1
  554. package/dist/components/ConversationList/ConversationCreate/ConversationCreateSelectView/index.js +0 -4
  555. package/dist/components/ConversationList/ConversationCreate/hooks/useConversationCreate.d.ts +0 -9
  556. package/dist/components/ConversationList/ConversationCreate/hooks/useConversationCreate.js +0 -96
  557. package/dist/components/ConversationList/ConversationCreate/static/word.d.ts +0 -6
  558. package/dist/components/ConversationList/ConversationCreate/static/word.js +0 -4
  559. package/dist/components/LiveStreamView/index.d.ts +0 -4
  560. package/dist/states/UIOpenControlState/UIOpenControlState.d.ts +0 -15
  561. package/dist/states/UIOpenControlState/UIOpenControlState.js +0 -28
  562. package/dist/states/UIOpenControlState/index.d.ts +0 -1
  563. package/dist/states/UIOpenControlState/index.js +0 -4
  564. package/src/baseComp/Popup/Popup.vue +0 -156
  565. package/src/baseComp/Popup/index.ts +0 -2
  566. package/src/components/ConversationList/ConversationCreate/ConversationCreateSelectView/ConversationCreateSelectView.scss +0 -36
  567. package/src/components/ConversationList/ConversationCreate/ConversationCreateSelectView/ConversationCreateSelectView.vue +0 -44
  568. package/src/components/ConversationList/ConversationCreate/ConversationCreateSelectView/index.ts +0 -1
  569. package/src/components/ConversationList/ConversationCreate/hooks/useConversationCreate.ts +0 -132
  570. package/src/components/ConversationList/ConversationCreate/static/word.ts +0 -300
  571. package/src/components/LiveStreamView/index.vue +0 -333
  572. /package/dist/components/{LiveStreamView → LiveCoreView}/DefaultStreamViewUI.vue.d.ts +0 -0
  573. /package/dist/components/{LiveStreamView → LiveCoreView}/i18n/en-US/index.d.ts +0 -0
  574. /package/dist/components/{LiveStreamView → LiveCoreView}/i18n/en-US/index.js +0 -0
  575. /package/dist/components/{LiveStreamView → LiveCoreView}/i18n/index.d.ts +0 -0
  576. /package/dist/components/{LiveStreamView → LiveCoreView}/i18n/index.js +0 -0
  577. /package/dist/components/{LiveStreamView → LiveCoreView}/i18n/zh-CN/index.d.ts +0 -0
  578. /package/dist/components/{LiveStreamView → LiveCoreView}/i18n/zh-CN/index.js +0 -0
  579. /package/src/components/{LiveStreamView → LiveCoreView}/DefaultStreamViewUI.vue +0 -0
  580. /package/src/components/{LiveStreamView → LiveCoreView}/i18n/en-US/index.ts +0 -0
  581. /package/src/components/{LiveStreamView → LiveCoreView}/i18n/index.ts +0 -0
  582. /package/src/components/{LiveStreamView → LiveCoreView}/i18n/zh-CN/index.ts +0 -0
@@ -1,73 +1,62 @@
1
1
  .conversationActions {
2
2
  position: relative;
3
+ display: flex;
3
4
 
4
5
  &__popup-icon {
5
- padding: 4px 8px;
6
+ display: flex;
6
7
  cursor: pointer;
7
- border-radius: 4px;
8
8
  transition: background-color 0.2s;
9
-
10
- &:hover {
11
- background-color: var(--hover-bg-color, #f0f0f0);
12
- }
13
-
14
- .more-icon {
15
- font-size: 16px;
16
- color: var(--text-color-secondary, #666);
17
- font-weight: bold;
18
- }
19
9
  }
20
10
 
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;
11
+ &__h5 {
12
+ z-index: 5;
13
+ position: fixed;
14
+ width: 100%;
15
+ height: 100%;
16
+ top: 0;
17
+ left: 0;
18
+ display: flex;
19
+ flex-direction: column;
20
+ justify-content: flex-end;
21
+ background: var(--bg-color-mask)
30
22
  }
31
23
 
32
24
  &__h5__container {
33
- position: fixed;
34
- bottom: 0;
35
- left: 0;
36
- right: 0;
37
25
  background-color: var(--bg-color-operate);
38
26
  border-radius: 8px 8px 0 0;
39
27
  box-shadow: 0 0 10px var(--shadow-color);
40
- z-index: 100;
41
- padding: 16px;
28
+
29
+ .conversationActions__item {
30
+ text-align: center;
31
+ font-weight: 400;
32
+ font-size: 17px;
33
+ line-height: 22px;
34
+ padding: 16px 0;
35
+ border-bottom: 1px solid var(--stroke-color-primary);
36
+ color: var(--button-color-primary-default);
37
+
38
+ &:last-child {
39
+ border-bottom: none;
40
+ color: var(--text-color-error);
41
+ }
42
+ }
42
43
  }
43
44
 
44
45
  &__item {
45
- padding: 8px 12px;
46
- cursor: pointer;
47
46
  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;
47
+ line-height: 19px;
48
+ padding: 9px 16px;
49
+ cursor: pointer;
50
+ font-weight: 400;
51
+ box-sizing: border-box;
52
+ color: var(--text-color-primary);
54
53
 
55
54
  &:hover {
56
- background-color: var(--dropdown-color-active, #f8f9fa);
57
- }
58
-
59
- &:last-child {
60
- border-bottom: none;
55
+ background-color: var(--dropdown-color-active);
61
56
  }
62
57
 
63
58
  &--delete {
64
- color: var(--text-color-error, #dc3545);
65
- }
66
-
67
- .action-icon {
68
- width: 16px;
69
- height: 16px;
70
- flex-shrink: 0;
59
+ color: var(--text-color-error);
71
60
  }
72
61
  }
73
62
  }
@@ -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__popup-icon']"
32
+ @click="toggleClick"
33
+ >
34
+ <IconEllipsis size="18px" />
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,70 @@
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
+ appendTo="body"
9
+ :visible="showCreateConversation"
10
+ :title="dialogTitles"
11
+ :confirm-text="dialogConfirmText"
12
+ :cancel-text="dialogCancelText"
13
+ :custom-classes="[isH5 ? 'conversationCreate__dialog' : '']"
14
+ @confirm="handleConfirm"
15
+ @cancel="handleCancel"
16
+ @close="resetCreatePageState"
15
17
  >
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
18
  <ConversationCreateUserSelectList
29
19
  v-if="pageState === PageStateTypes.USER_SELECT"
30
20
  :is-create-group="isCreateGroup"
31
- :set-is-create-group="setIsCreateGroup"
32
21
  :select-list="selectList"
33
22
  :set-select-list="setSelectList"
34
- :conversation-list="conversationList"
35
23
  :set-page-state="setPageState"
36
- :on-before-create-conversation="handleBeforeCreate"
37
- :on-conversation-created="handleCreated"
38
24
  />
39
25
 
40
26
  <ConversationCreateGroupDetail
41
27
  v-else
42
28
  :page-state="pageState"
43
29
  :profile-list="selectList"
30
+ :group-info="groupInfo"
44
31
  :set-page-state="setPageState"
45
- :on-before-create-conversation="handleBeforeCreate"
46
- :on-conversation-created="handleCreated"
32
+ @update-group-info="updateGroupInfo"
47
33
  />
48
- </div>
34
+ </TUIDialog>
49
35
  </div>
50
36
  </template>
51
37
 
52
38
  <script lang="ts" setup>
53
- import { ref, watch } from 'vue';
39
+ import { computed, ref } from 'vue';
54
40
  import { TUIConversationService } from '@tencentcloud/chat-uikit-engine';
55
- import { IconArrowStrokeBack, useUIKit } from '@tencentcloud/uikit-base-component-vue3';
56
- import { PageStateTypes } from '../../../types';
41
+ import { useUIKit, TUIDialog, TUIToast } from '@tencentcloud/uikit-base-component-vue3';
42
+ import { useConversationListState } from '../../../states/ConversationListState';
43
+ import { useLoginState } from '../../../states/LoginState';
44
+ import { PageStateTypes, CreateConvTypes, GroupType } from '../../../types';
45
+ import { isH5 } from '../../../utils/env';
46
+ import { useConversation } from '../hooks/useConversation';
47
+ import { useConversationCreate } from '../hooks/useConversationCreate';
57
48
  import ConversationCreateButton from './ConversationCreateButton/ConversationCreateButton.vue';
58
49
  import ConversationCreateGroupDetail from './ConversationCreateGroupDetail/ConversationCreateGroupDetail.vue';
59
50
  import ConversationCreateUserSelectList from './ConversationCreateUserSelectList/ConversationCreateUserSelectList.vue';
60
- import type { ConversationModel, ConversationCreateProps, CreateGroupParams } from '../../../types';
51
+ import type { ConversationModel, ConversationCreateProps, CreateGroupParams, CreateGroupInfo, Friend } from '../../../types';
52
+
53
+ const { t } = useUIKit();
54
+ const { enableSearch } = useConversation();
55
+ const { getDefaultAvatar } = useConversationCreate();
56
+ const { loginUserInfo } = useLoginState();
57
+ const { createC2CConversation, createGroupConversation } = useConversationListState();
58
+
59
+ const GROUP_NAME_LIMIT = 20;
60
+ const GROUP_INFO_DEFAULTS: CreateGroupInfo = {
61
+ avatar: getDefaultAvatar(GroupType.WORK),
62
+ name: '',
63
+ groupID: '',
64
+ type: GroupType.WORK,
65
+ };
61
66
 
62
67
  const props = withDefaults(defineProps<ConversationCreateProps>(), {
63
- visible: true,
64
68
  conversationList: () => [],
65
69
  });
66
70
 
@@ -70,12 +74,16 @@ const emit = defineEmits<{
70
74
  'conversationCreated': [conversation: ConversationModel];
71
75
  }>();
72
76
 
73
- const { t } = useUIKit();
74
-
75
77
  const showCreateConversation = ref(false);
76
78
  const isCreateGroup = ref(false);
77
79
  const pageState = ref<PageStateTypes>(PageStateTypes.USER_SELECT);
78
- const selectList = ref<any[]>([]);
80
+ const selectList = ref<Friend[]>([]);
81
+ const groupInfo = ref<CreateGroupInfo>({
82
+ avatar: getDefaultAvatar(GroupType.WORK),
83
+ name: '',
84
+ groupID: '',
85
+ type: GroupType.WORK,
86
+ });
79
87
 
80
88
  const setIsCreateGroup = (value: boolean) => {
81
89
  isCreateGroup.value = value;
@@ -85,65 +93,143 @@ const setPageState = (value: PageStateTypes) => {
85
93
  pageState.value = value;
86
94
  };
87
95
 
88
- const setSelectList = (value: any[]) => {
96
+ const setSelectList = (value: Friend[]) => {
89
97
  selectList.value = value;
90
98
  };
91
99
 
100
+ const openCreateConversation = (value: CreateConvTypes) => {
101
+ if (value === CreateConvTypes.GROUP) {
102
+ setIsCreateGroup(true);
103
+ } else {
104
+ setIsCreateGroup(false);
105
+ }
106
+ showCreateConversation.value = true;
107
+ };
108
+
92
109
  const toggleCreateConversation = (value: boolean) => {
93
110
  showCreateConversation.value = value;
94
111
  };
95
112
 
96
113
  const resetCreatePageState = () => {
114
+ toggleCreateConversation(false);
115
+ groupInfo.value = GROUP_INFO_DEFAULTS;
97
116
  isCreateGroup.value = false;
98
117
  pageState.value = PageStateTypes.USER_SELECT;
99
118
  selectList.value = [];
100
119
  };
101
120
 
102
121
  const _onConversationCreated = (conversation: ConversationModel) => {
103
- toggleCreateConversation(false);
104
122
  resetCreatePageState();
105
123
  TUIConversationService.switchConversation(conversation.conversationID);
106
124
  emit('conversationCreated', conversation);
125
+ props.onConversationCreated?.(conversation);
107
126
  };
108
127
 
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();
128
+ const pageStateTitle = {
129
+ [PageStateTypes.USER_SELECT]: t('TUIConversation.Add Participants'),
130
+ [PageStateTypes.CREATE_DETAIL]: t('TUIConversation.New group chat'),
131
+ [PageStateTypes.GROUP_TYPE]: t('TUIConversation.New group chat'),
132
+ };
133
+
134
+ const pageStateConfirmText = {
135
+ [PageStateTypes.USER_SELECT]: t('TUIConversation.Next'),
136
+ [PageStateTypes.CREATE_DETAIL]: t('TUIConversation.Start chat'),
137
+ [PageStateTypes.GROUP_TYPE]: t('TUIConversation.Confirm'),
138
+ };
139
+ const pageStateCancelText = {
140
+ [PageStateTypes.USER_SELECT]: t('TUIConversation.Cancel'),
141
+ [PageStateTypes.CREATE_DETAIL]: t('TUIConversation.Prev'),
142
+ [PageStateTypes.GROUP_TYPE]: t('TUIConversation.Prev'),
143
+ };
144
+ const dialogCancelText = computed(() => {
145
+ if (!isCreateGroup.value) {
146
+ return t('TUIConversation.Cancel');
147
+ }
148
+ return pageStateCancelText[pageState.value];
149
+ });
150
+
151
+ const dialogTitles = computed(() => {
152
+ if (!isCreateGroup.value) {
153
+ return t('TUIConversation.Start chat');
128
154
  }
155
+ return pageStateTitle[pageState.value];
156
+ });
157
+
158
+ const dialogConfirmText = computed(() => !isCreateGroup.value ? t('TUIConversation.Start chat') : pageStateConfirmText[pageState.value]);
159
+
160
+ const updateGroupInfo = (value: CreateGroupInfo) => {
161
+ groupInfo.value = value;
129
162
  };
130
163
 
131
- const handleBeforeCreate = (params: string | CreateGroupParams) => {
132
- if (props.onBeforeCreateConversation) {
133
- return props.onBeforeCreateConversation(params);
164
+ const handleCreateC2CConversation = async () => {
165
+ const { userID } = selectList.value[0];
166
+ emit('beforeCreateConversation', userID);
167
+ props.onBeforeCreateConversation?.(userID);
168
+
169
+ try {
170
+ const conversation = await createC2CConversation(userID);
171
+ _onConversationCreated(conversation);
172
+ } catch (error: any) {
173
+ TUIToast.error({ message: error.message });
134
174
  }
135
- return params;
136
175
  };
137
176
 
138
- const handleCreated = (conversation: ConversationModel) => {
139
- _onConversationCreated(conversation);
177
+ const handleCreateGroupConversation = async () => {
178
+ const options = {
179
+ ...groupInfo.value,
180
+ memberList: selectList.value.map(item => ({
181
+ userID: item.userID,
182
+ })),
183
+ } as unknown as CreateGroupParams;
184
+
185
+ emit('beforeCreateConversation', options);
186
+ props.onBeforeCreateConversation?.(options);
187
+
188
+ try {
189
+ const conversation = await createGroupConversation(options);
190
+ _onConversationCreated(conversation);
191
+ } catch (error: any) {
192
+ TUIToast.error({ message: error.message });
193
+ }
140
194
  };
141
195
 
142
- watch(showCreateConversation, (newValue) => {
143
- emit('update:visible', newValue);
144
- });
196
+ const generateGroupName = (userList: Friend[]) => {
197
+ const selfName = loginUserInfo.value?.userName || loginUserInfo.value?.userId || '';
198
+ const name = selfName + userList.map(item => item?.remark || item?.nick || item?.userID).join('、');
199
+ return name.length >= GROUP_NAME_LIMIT ? name.slice(0, GROUP_NAME_LIMIT) : name;
200
+ };
201
+
202
+ const handleConfirm = () => {
203
+ if (selectList.value.length === 0) {
204
+ TUIToast.error({ message: t('TUIConversation.Participant cannot be empty') });
205
+ return;
206
+ }
207
+ if (!isCreateGroup.value) {
208
+ handleCreateC2CConversation();
209
+ toggleCreateConversation(false);
210
+ } else if (pageState.value === PageStateTypes.USER_SELECT) {
211
+ groupInfo.value.name = generateGroupName(selectList.value);
212
+ setPageState(PageStateTypes.CREATE_DETAIL);
213
+ } else if (pageState.value === PageStateTypes.CREATE_DETAIL) {
214
+ handleCreateGroupConversation();
215
+ toggleCreateConversation(false);
216
+ } else {
217
+ setPageState(PageStateTypes.CREATE_DETAIL);
218
+ }
219
+ };
220
+
221
+ const handleCancel = () => {
222
+ if (pageState.value === PageStateTypes.USER_SELECT) {
223
+ toggleCreateConversation(false);
224
+ resetCreatePageState();
225
+ } else if (pageState.value === PageStateTypes.CREATE_DETAIL) {
226
+ setPageState(PageStateTypes.USER_SELECT);
227
+ } else if (pageState.value === PageStateTypes.GROUP_TYPE) {
228
+ setPageState(PageStateTypes.CREATE_DETAIL);
229
+ }
230
+ };
145
231
  </script>
146
232
 
147
- <style lang="scss" module>
233
+ <style lang="scss" scoped>
148
234
  @import './ConversationCreate.scss';
149
235
  </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
  }
@@ -1,29 +1,84 @@
1
1
  <template>
2
- <IconSearchMore
3
- v-if="visible"
4
- :class="[$style['conversation-create-button'], className]"
5
- size="24px"
6
- @click="handleClick"
7
- />
2
+ <template v-if="!enableSearch">
3
+ <ul :class="[$style['conversation-create-list'], {[$style['conversation-create-list--detail']]: !enableSearch }]">
4
+ <li
5
+ v-for="(action, key) in createActions"
6
+ :key="key"
7
+ :class="[$style['conversation-create-item']]"
8
+ @click="() => handleClick(action.key)"
9
+ >
10
+ <component :is="action.icon" />
11
+ <span :class="[$style['conversation-create-text']]">{{ action.label }}</span>
12
+ </li>
13
+ </ul>
14
+ </template>
15
+ <template v-else>
16
+ <TUIDropdown
17
+ trigger="click"
18
+ placement="bottom-end"
19
+ >
20
+ <IconSearchMore
21
+ :class="[$style['conversation-create-button']]"
22
+ :size="`${size}px`"
23
+ />
24
+ <template #dropdown>
25
+ <div :class="[$style['conversation-create-dropdown']]">
26
+ <ul :class="[$style['conversation-create-list']]">
27
+ <li
28
+ v-for="(action, key) in createActions"
29
+ :key="key"
30
+ :class="[$style['conversation-create-item']]"
31
+ @click="() => handleClick(action.key)"
32
+ >
33
+ <component :is="action.icon" />
34
+ <span :class="[$style['conversation-create-text']]">{{ action.label }}</span>
35
+ </li>
36
+ </ul>
37
+ </div>
38
+ </template>
39
+ </TUIDropdown>
40
+ </template>
8
41
  </template>
9
42
 
10
43
  <script lang="ts" setup>
11
- import { IconSearchMore } from '@tencentcloud/uikit-base-component-vue3';
44
+ import { shallowRef } from 'vue';
45
+ import {
46
+ IconSearchMore,
47
+ TUIDropdown,
48
+ IconIconC2c,
49
+ IconStartGroup,
50
+ useUIKit,
51
+ } from '@tencentcloud/uikit-base-component-vue3';
52
+ import { CreateConvTypes } from '../../../../types';
53
+ import { useConversation } from '../../hooks/useConversation';
12
54
  import type { ConversationCreateButtonProps } from '../../../../types';
13
55
 
14
- const props = withDefaults(defineProps<ConversationCreateButtonProps>(), {
15
- visible: true,
16
- height: 24,
17
- width: 24,
56
+ const { t } = useUIKit();
57
+ const { enableSearch } = useConversation();
58
+
59
+ withDefaults(defineProps<ConversationCreateButtonProps>(), {
60
+ size: 24,
18
61
  });
19
62
 
20
63
  const emit = defineEmits<{
21
- click: [event: Event];
64
+ click: [key: CreateConvTypes];
22
65
  }>();
23
66
 
24
- const handleClick = (event: Event) => {
25
- emit('click', event);
26
- props.onClick?.(event);
67
+ const createActions = shallowRef([
68
+ {
69
+ icon: IconIconC2c,
70
+ key: CreateConvTypes.C2C,
71
+ label: t('TUIConversation.Start C2C Chat'),
72
+ },
73
+ {
74
+ icon: IconStartGroup,
75
+ key: CreateConvTypes.GROUP,
76
+ label: t('TUIConversation.Start Group Chat'),
77
+ },
78
+ ]);
79
+
80
+ const handleClick = (action: CreateConvTypes) => {
81
+ emit('click', action);
27
82
  };
28
83
  </script>
29
84