tuikit-atomicx-vue3 3.3.3 → 3.4.1

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 (797) hide show
  1. package/.eslintrc.cjs +33 -0
  2. package/dist/AudioRequestDialog.vue_vue_type_script_setup_true_lang-DESfuJPj.js +89 -0
  3. package/dist/DialogPortal-CvJcEAsn.js +417 -0
  4. package/dist/MaterialRenameDialog.vue_vue_type_script_setup_true_lang-C8oUv-KF.js +36 -0
  5. package/dist/MessageInput.vue_vue_type_script_setup_true_lang-D1G-LitO.js +116 -0
  6. package/dist/PopoverTrigger-L8abAry7.js +607 -0
  7. package/dist/PopperContent-XdhqL8Y2.js +1603 -0
  8. package/dist/Teleport-CSEuZbpM.js +913 -0
  9. package/dist/VideoRequestDialog.vue_vue_type_script_setup_true_lang-DlROoquV.js +89 -0
  10. package/dist/_commonjsHelpers-C6fGbg64.js +6 -0
  11. package/dist/_plugin-vue_export-helper-CHgC5LLL.js +9 -0
  12. package/dist/baseComp/ActionSheep.js +41 -51
  13. package/dist/baseComp/AudioIcon.js +27 -37
  14. package/dist/baseComp/Avatar.js +16 -28
  15. package/dist/baseComp/Dialog/DialogH5.js +56 -82
  16. package/dist/baseComp/Dialog/DialogPC.js +76 -118
  17. package/dist/baseComp/Dialog/index.js +2 -2
  18. package/dist/baseComp/IconButton.js +43 -56
  19. package/dist/baseComp/Input/InputH5.js +85 -128
  20. package/dist/baseComp/Input/InputPC.js +85 -128
  21. package/dist/baseComp/Input/InputWX.js +88 -131
  22. package/dist/baseComp/Input/index.js +5 -5
  23. package/dist/baseComp/MessageBox/index.js +120 -150
  24. package/dist/baseComp/Modal/Modal.js +38 -45
  25. package/dist/baseComp/Modal/index.js +3 -3
  26. package/dist/baseComp/ObserverView/ObserverView.js +50 -86
  27. package/dist/baseComp/ObserverView/index.js +2 -2
  28. package/dist/baseComp/Option/OptionH5.js +29 -40
  29. package/dist/baseComp/Option/OptionPC.js +34 -46
  30. package/dist/baseComp/Option/OptionWX.js +30 -41
  31. package/dist/baseComp/Option/index.js +2 -2
  32. package/dist/baseComp/Select/SelectH5.js +54 -86
  33. package/dist/baseComp/Select/SelectPC.js +78 -120
  34. package/dist/baseComp/Select/SelectWX.js +48 -79
  35. package/dist/baseComp/Select/index.js +2 -2
  36. package/dist/baseComp/SvgIcon.js +17 -22
  37. package/dist/baseComp/TuiSwitch.js +15 -19
  38. package/dist/baseComp/View/View.js +2 -2
  39. package/dist/baseComp/View/index.js +19 -24
  40. package/dist/baseComp/index.js +2 -2
  41. package/dist/baseComp/useZIndex.js +7 -12
  42. package/dist/chat/index.d.ts +1427 -990
  43. package/dist/chat/index.js +57 -73
  44. package/dist/chat/server.js +60 -79
  45. package/dist/components/AudioSetting/AudioMediaControl.js +52 -78
  46. package/dist/components/AudioSetting/AudioRequestDialog.js +2 -2
  47. package/dist/components/AudioSetting/AudioSettingTab.js +72 -102
  48. package/dist/components/AudioSetting/MicrophoneSelect.js +45 -57
  49. package/dist/components/AudioSetting/SpeakerSelect.js +45 -57
  50. package/dist/components/AudioSetting/index.js +3 -3
  51. package/dist/components/AudioSettingPanel/i18n/en-US/index.js +2 -2
  52. package/dist/components/AudioSettingPanel/i18n/index.js +4 -4
  53. package/dist/components/AudioSettingPanel/i18n/zh-CN/index.js +2 -2
  54. package/dist/components/AudioSettingPanel/index.js +102 -147
  55. package/dist/components/Avatar/Avatar.js +88 -140
  56. package/dist/components/Avatar/Avatar.vue.d.ts +1 -1
  57. package/dist/components/Avatar/AvatarBadge/AvatarBadge.js +25 -31
  58. package/dist/components/Avatar/AvatarBadge/index.js +2 -2
  59. package/dist/components/Avatar/constants/avatar.js +7 -12
  60. package/dist/components/Avatar/index.js +9 -9
  61. package/dist/components/BarrageInput/BarrageInput.js +50 -67
  62. package/dist/components/BarrageInput/BarrageInputH5.js +80 -111
  63. package/dist/components/BarrageInput/EmojiPicker/EmojiPicker.js +84 -97
  64. package/dist/components/BarrageInput/EmojiPicker/index.js +2 -2
  65. package/dist/components/BarrageInput/TextEditor/CharacterCountExtension.js +34 -62
  66. package/dist/components/BarrageInput/TextEditor/EditorCore.js +79 -90
  67. package/dist/components/BarrageInput/TextEditor/TextEditor.js +2 -2
  68. package/dist/components/BarrageInput/TextEditor/index.js +81 -125
  69. package/dist/components/BarrageInput/constants.js +2 -2
  70. package/dist/components/BarrageInput/i18n/en-US/index.js +2 -2
  71. package/dist/components/BarrageInput/i18n/index.js +4 -4
  72. package/dist/components/BarrageInput/i18n/zh-CN/index.js +2 -2
  73. package/dist/components/BarrageInput/index.js +11 -11
  74. package/dist/components/BarrageList/BarrageList.js +97 -173
  75. package/dist/components/BarrageList/BarrageListH5.js +96 -171
  76. package/dist/components/BarrageList/ClickAction/UserActionMenu.js +64 -94
  77. package/dist/components/BarrageList/Message/CustomMessage/CustomMessage.js +2 -2
  78. package/dist/components/BarrageList/Message/CustomMessage/index.js +5 -7
  79. package/dist/components/BarrageList/Message/FaceMessage/FaceMessage.js +16 -21
  80. package/dist/components/BarrageList/Message/FaceMessage/index.js +2 -2
  81. package/dist/components/BarrageList/Message/GroupTipMessage/GroupTipMessage.js +2 -2
  82. package/dist/components/BarrageList/Message/GroupTipMessage/index.js +13 -18
  83. package/dist/components/BarrageList/Message/ImageMessage/ImageMessage.js +56 -80
  84. package/dist/components/BarrageList/Message/ImageMessage/index.js +2 -2
  85. package/dist/components/BarrageList/Message/MergerMessage/MergerMessage.js +5 -5
  86. package/dist/components/BarrageList/Message/MergerMessage/index.js +2 -2
  87. package/dist/components/BarrageList/Message/Message.js +2 -2
  88. package/dist/components/BarrageList/Message/MessageLayout/MessageBubble/MessageBubble.js +28 -39
  89. package/dist/components/BarrageList/Message/MessageLayout/MessageBubble/index.js +2 -2
  90. package/dist/components/BarrageList/Message/MessageLayout/MessageLayout.js +93 -101
  91. package/dist/components/BarrageList/Message/MessageLayout/MessageMeta/MessageMeta.js +26 -32
  92. package/dist/components/BarrageList/Message/MessageLayout/MessageMeta/MessageStatusIcon.js +19 -22
  93. package/dist/components/BarrageList/Message/MessageLayout/MessageMeta/index.js +2 -2
  94. package/dist/components/BarrageList/Message/MessageLayout/index.js +2 -2
  95. package/dist/components/BarrageList/Message/RecalledMessage/RecalledMessage.js +31 -39
  96. package/dist/components/BarrageList/Message/RecalledMessage/index.js +2 -2
  97. package/dist/components/BarrageList/Message/TextMessage/TextMessage.js +67 -96
  98. package/dist/components/BarrageList/Message/TextMessage/index.js +2 -2
  99. package/dist/components/BarrageList/Message/index.js +11 -15
  100. package/dist/components/BarrageList/MessageForward/ForwardListItem.js +34 -43
  101. package/dist/components/BarrageList/MessageForward/MessageForward.js +158 -210
  102. package/dist/components/BarrageList/MessageForward/index.js +2 -2
  103. package/dist/components/BarrageList/MessageListContext.js +9 -10
  104. package/dist/components/BarrageList/MessageTimeDivider/MessageTimeDivider.js +20 -28
  105. package/dist/components/BarrageList/MessageTimeDivider/index.js +2 -2
  106. package/dist/components/BarrageList/i18n/en-US/index.js +3 -3
  107. package/dist/components/BarrageList/i18n/index.js +4 -4
  108. package/dist/components/BarrageList/i18n/zh-CN/index.js +3 -3
  109. package/dist/components/BarrageList/index.js +10 -10
  110. package/dist/components/CameraButton/index.js +34 -44
  111. package/dist/components/ChatSetting/C2CChatSetting/C2CChatSetting.js +92 -108
  112. package/dist/components/ChatSetting/C2CChatSetting/index.js +3 -3
  113. package/dist/components/ChatSetting/ChatSetting.js +17 -23
  114. package/dist/components/ChatSetting/GroupChatSetting/GroupActions/GroupActions.js +133 -163
  115. package/dist/components/ChatSetting/GroupChatSetting/GroupActions/index.js +2 -2
  116. package/dist/components/ChatSetting/GroupChatSetting/GroupChatSetting.js +179 -245
  117. package/dist/components/ChatSetting/GroupChatSetting/GroupInfo/GroupInfo.js +124 -181
  118. package/dist/components/ChatSetting/GroupChatSetting/GroupInfo/index.js +2 -2
  119. package/dist/components/ChatSetting/GroupChatSetting/GroupManagement/GroupManagement.js +195 -259
  120. package/dist/components/ChatSetting/GroupChatSetting/GroupManagement/index.js +2 -2
  121. package/dist/components/ChatSetting/GroupChatSetting/GroupManagementEntry/GroupManagementEntry.js +23 -32
  122. package/dist/components/ChatSetting/GroupChatSetting/GroupManagementEntry/index.js +2 -2
  123. package/dist/components/ChatSetting/GroupChatSetting/GroupMembers/GroupMembers.js +149 -212
  124. package/dist/components/ChatSetting/GroupChatSetting/GroupMembers/index.js +2 -2
  125. package/dist/components/ChatSetting/GroupChatSetting/PersonalSettings/PersonalSettings.js +35 -40
  126. package/dist/components/ChatSetting/GroupChatSetting/PersonalSettings/index.js +2 -2
  127. package/dist/components/ChatSetting/GroupChatSetting/index.js +2 -2
  128. package/dist/components/ChatSetting/SettingItem/SettingItem.js +201 -247
  129. package/dist/components/ChatSetting/SettingItem/index.js +2 -2
  130. package/dist/components/ChatSetting/i18n/en-US.js +2 -2
  131. package/dist/components/ChatSetting/i18n/index.js +6 -6
  132. package/dist/components/ChatSetting/i18n/zh-CN.js +2 -2
  133. package/dist/components/ChatSetting/index.js +7 -7
  134. package/dist/components/CoGuestPanel/CoGuestPanel.js +139 -180
  135. package/dist/components/CoGuestPanel/constants.js +2 -2
  136. package/dist/components/CoGuestPanel/i18n/en-US/index.js +9 -9
  137. package/dist/components/CoGuestPanel/i18n/index.js +4 -4
  138. package/dist/components/CoGuestPanel/i18n/zh-CN/index.js +9 -9
  139. package/dist/components/CoGuestPanel/index.js +8 -8
  140. package/dist/components/CoHostPanel/BattlePanel.js +196 -0
  141. package/dist/components/CoHostPanel/BattlePanel.vue.d.ts +19 -0
  142. package/dist/components/CoHostPanel/CoHostPanel.js +109 -0
  143. package/dist/components/CoHostPanel/CoHostPanel.vue.d.ts +19 -0
  144. package/dist/components/CoHostPanel/ConfigSettingPanel.js +110 -0
  145. package/dist/components/CoHostPanel/ConfigSettingPanel.vue.d.ts +33 -0
  146. package/dist/components/CoHostPanel/ConnectionPanel.js +273 -0
  147. package/dist/components/CoHostPanel/ConnectionPanel.vue.d.ts +19 -0
  148. package/dist/components/CoHostPanel/RecommendHostList.js +113 -0
  149. package/dist/components/CoHostPanel/RecommendHostList.vue.d.ts +13 -0
  150. package/dist/components/CoHostPanel/UserList.js +34 -0
  151. package/dist/components/CoHostPanel/UserList.vue.d.ts +28 -0
  152. package/dist/components/CoHostPanel/i18n/en-US/index.d.ts +74 -0
  153. package/dist/components/CoHostPanel/i18n/en-US/index.js +81 -0
  154. package/dist/components/CoHostPanel/i18n/index.d.ts +4 -0
  155. package/dist/components/CoHostPanel/i18n/index.js +6 -0
  156. package/dist/components/CoHostPanel/i18n/zh-CN/index.d.ts +75 -0
  157. package/dist/components/CoHostPanel/i18n/zh-CN/index.js +82 -0
  158. package/dist/components/CoHostPanel/index.d.ts +16 -0
  159. package/dist/components/CoHostPanel/index.js +10 -0
  160. package/dist/components/ContactList/ContactInfo/BlacklistInfo/BlacklistInfo.js +36 -51
  161. package/dist/components/ContactList/ContactInfo/BlacklistInfo/index.js +2 -2
  162. package/dist/components/ContactList/ContactInfo/ContactInfo.js +141 -196
  163. package/dist/components/ContactList/ContactInfo/FriendApplicationInfo/FriendApplicationInfo.js +39 -61
  164. package/dist/components/ContactList/ContactInfo/FriendApplicationInfo/index.js +2 -2
  165. package/dist/components/ContactList/ContactInfo/FriendInfo/FriendInfo.js +109 -160
  166. package/dist/components/ContactList/ContactInfo/FriendInfo/index.js +2 -2
  167. package/dist/components/ContactList/ContactInfo/GroupApplicationInfo/GroupApplicationInfo.js +58 -86
  168. package/dist/components/ContactList/ContactInfo/GroupApplicationInfo/index.js +2 -2
  169. package/dist/components/ContactList/ContactInfo/GroupInfo/GroupInfo.js +99 -133
  170. package/dist/components/ContactList/ContactInfo/GroupInfo/index.js +2 -2
  171. package/dist/components/ContactList/ContactInfo/SearchGroupInfo/SearchGroupInfo.js +86 -118
  172. package/dist/components/ContactList/ContactInfo/SearchGroupInfo/index.js +2 -2
  173. package/dist/components/ContactList/ContactInfo/SearchUserInfo/SearchUserInfo.js +72 -101
  174. package/dist/components/ContactList/ContactInfo/SearchUserInfo/index.js +2 -2
  175. package/dist/components/ContactList/ContactInfo/index.js +16 -16
  176. package/dist/components/ContactList/ContactList.js +164 -235
  177. package/dist/components/ContactList/ContactListItem/BlacklistItem/BlacklistItem.js +29 -38
  178. package/dist/components/ContactList/ContactListItem/BlacklistItem/index.js +2 -2
  179. package/dist/components/ContactList/ContactListItem/ContactListItem.js +2 -2
  180. package/dist/components/ContactList/ContactListItem/FriendApplicationItem/FriendApplicationItem.js +46 -61
  181. package/dist/components/ContactList/ContactListItem/FriendApplicationItem/index.js +2 -2
  182. package/dist/components/ContactList/ContactListItem/FriendItem/FriendItem.js +24 -31
  183. package/dist/components/ContactList/ContactListItem/FriendItem/index.js +2 -2
  184. package/dist/components/ContactList/ContactListItem/GroupApplicationItem/GroupApplicationItem.js +45 -64
  185. package/dist/components/ContactList/ContactListItem/GroupApplicationItem/index.js +2 -2
  186. package/dist/components/ContactList/ContactListItem/GroupItem/GroupItem.js +29 -38
  187. package/dist/components/ContactList/ContactListItem/GroupItem/index.js +2 -2
  188. package/dist/components/ContactList/ContactListItem/index.js +57 -66
  189. package/dist/components/ContactList/ContactSearch/ContactSearch.js +53 -73
  190. package/dist/components/ContactList/ContactSearch/index.js +2 -2
  191. package/dist/components/ContactList/constants/const.js +3 -4
  192. package/dist/components/ContactList/hooks/index.js +2 -2
  193. package/dist/components/ContactList/hooks/useContactList.js +11 -15
  194. package/dist/components/ContactList/i18n/en-US.js +21 -21
  195. package/dist/components/ContactList/i18n/index.js +4 -4
  196. package/dist/components/ContactList/i18n/zh-CN.js +21 -21
  197. package/dist/components/ContactList/index.js +12 -14
  198. package/dist/components/ConversationList/ConversationActions/ConversationActions.js +107 -150
  199. package/dist/components/ConversationList/ConversationActions/index.js +2 -2
  200. package/dist/components/ConversationList/ConversationCreate/ConversationCreate.js +116 -193
  201. package/dist/components/ConversationList/ConversationCreate/ConversationCreateButton/ConversationCreateButton.js +65 -80
  202. package/dist/components/ConversationList/ConversationCreate/ConversationCreateGroupDetail/ConversationCreateGroupDetail.js +108 -126
  203. package/dist/components/ConversationList/ConversationCreate/ConversationCreateUserSelectList/ConversationCreateUserSelectList.js +40 -52
  204. package/dist/components/ConversationList/ConversationCreate/ConversationGroupTypeInfo/ConversationGroupTypeInfo.js +61 -79
  205. package/dist/components/ConversationList/ConversationCreate/ConversationGroupTypeInfo/index.js +4 -4
  206. package/dist/components/ConversationList/ConversationCreate/ConversationGroupTypeInfo/type.js +8 -8
  207. package/dist/components/ConversationList/ConversationCreate/index.js +12 -12
  208. package/dist/components/ConversationList/ConversationList.js +112 -154
  209. package/dist/components/ConversationList/ConversationList.vue.d.ts +72 -72
  210. package/dist/components/ConversationList/ConversationListContent/ConversationListContent.js +27 -33
  211. package/dist/components/ConversationList/ConversationListContent/index.js +2 -2
  212. package/dist/components/ConversationList/ConversationListHeader/ConversationListHeader.js +30 -39
  213. package/dist/components/ConversationList/ConversationListHeader/index.js +2 -2
  214. package/dist/components/ConversationList/ConversationPlaceHolder/ConversationPlaceHolder.js +65 -81
  215. package/dist/components/ConversationList/ConversationPlaceHolder/index.js +2 -2
  216. package/dist/components/ConversationList/ConversationPreview/ConversationPreview.js +2 -2
  217. package/dist/components/ConversationList/ConversationPreview/ConversationPreview.vue.d.ts +72 -72
  218. package/dist/components/ConversationList/ConversationPreview/ConversationPreviewAbstract.js +40 -59
  219. package/dist/components/ConversationList/ConversationPreview/ConversationPreviewTimestamp.js +29 -47
  220. package/dist/components/ConversationList/ConversationPreview/ConversationPreviewTitle.js +25 -42
  221. package/dist/components/ConversationList/ConversationPreview/ConversationPreviewUI.js +84 -111
  222. package/dist/components/ConversationList/ConversationPreview/ConversationPreviewUI.vue.d.ts +18 -18
  223. package/dist/components/ConversationList/ConversationPreview/ConversationPreviewUnread.js +36 -51
  224. package/dist/components/ConversationList/ConversationPreview/index.js +55 -63
  225. package/dist/components/ConversationList/ConversationPreview/utils.js +36 -42
  226. package/dist/components/ConversationList/ConversationSearch/ConversationSearch.js +114 -160
  227. package/dist/components/ConversationList/ConversationSearch/index.js +2 -2
  228. package/dist/components/ConversationList/hooks/useConversation.js +12 -18
  229. package/dist/components/ConversationList/hooks/useConversationCreate.js +17 -18
  230. package/dist/components/ConversationList/i18n/en-US.js +32 -32
  231. package/dist/components/ConversationList/i18n/index.js +4 -4
  232. package/dist/components/ConversationList/i18n/zh-CN.js +32 -32
  233. package/dist/components/ConversationList/index.d.ts +989 -989
  234. package/dist/components/ConversationList/index.js +24 -32
  235. package/dist/components/LiveAudienceList/LiveAudienceList.js +85 -120
  236. package/dist/components/LiveAudienceList/LiveAudienceListH5.js +50 -72
  237. package/dist/components/LiveAudienceList/UserActionMenu.js +82 -124
  238. package/dist/components/LiveAudienceList/i18n/en-US/index.js +2 -2
  239. package/dist/components/LiveAudienceList/i18n/index.js +4 -4
  240. package/dist/components/LiveAudienceList/i18n/zh-CN/index.js +2 -2
  241. package/dist/components/LiveAudienceList/index.js +10 -10
  242. package/dist/components/LiveCoreView/CoreViewDecorate/BattleDecorate.js +152 -0
  243. package/dist/components/LiveCoreView/CoreViewDecorate/BattleDecorate.vue.d.ts +2 -0
  244. package/dist/components/LiveCoreView/CoreViewDecorate/BattleUserDecorate.js +66 -0
  245. package/dist/components/LiveCoreView/CoreViewDecorate/BattleUserDecorate.vue.d.ts +35 -0
  246. package/dist/components/LiveCoreView/CoreViewDecorate/CoHostDecorate.js +54 -0
  247. package/dist/components/LiveCoreView/CoreViewDecorate/CoHostDecorate.vue.d.ts +2 -0
  248. package/dist/components/LiveCoreView/CoreViewDecorate/LiveCoreDecorate.js +35 -0
  249. package/dist/components/LiveCoreView/CoreViewDecorate/LiveCoreDecorate.vue.d.ts +35 -0
  250. package/dist/components/LiveCoreView/DefaultStreamViewUI.js +101 -154
  251. package/dist/components/LiveCoreView/PlayerControl/AudioControl.js +113 -236
  252. package/dist/components/LiveCoreView/PlayerControl/MultiResolution.js +78 -0
  253. package/dist/components/LiveCoreView/PlayerControl/MultiResolution.vue.d.ts +2 -0
  254. package/dist/components/LiveCoreView/PlayerControl/PlayerControl.js +150 -261
  255. package/dist/components/LiveCoreView/PlayerControl/PlayerControlState.d.ts +11 -0
  256. package/dist/components/LiveCoreView/PlayerControl/PlayerControlState.js +234 -379
  257. package/dist/components/LiveCoreView/PlayerControl/index.js +6 -6
  258. package/dist/components/LiveCoreView/PlayerControl/utils/deviceDetection.js +37 -121
  259. package/dist/components/LiveCoreView/PlayerControl/utils/domHelpers.js +32 -53
  260. package/dist/components/LiveCoreView/PlayerControl/utils/fullscreenManager.js +107 -177
  261. package/dist/components/LiveCoreView/i18n/en-US/index.d.ts +6 -0
  262. package/dist/components/LiveCoreView/i18n/en-US/index.js +14 -8
  263. package/dist/components/LiveCoreView/i18n/index.js +4 -4
  264. package/dist/components/LiveCoreView/i18n/zh-CN/index.d.ts +6 -0
  265. package/dist/components/LiveCoreView/i18n/zh-CN/index.js +14 -8
  266. package/dist/components/LiveCoreView/index.js +176 -301
  267. package/dist/components/LiveList/LiveList.js +109 -165
  268. package/dist/components/LiveList/LiveList.vue.d.ts +15 -3
  269. package/dist/components/LiveList/LiveListH5.js +109 -169
  270. package/dist/components/LiveList/i18n/en-US/index.d.ts +1 -1
  271. package/dist/components/LiveList/i18n/en-US/index.js +4 -4
  272. package/dist/components/LiveList/i18n/index.js +4 -4
  273. package/dist/components/LiveList/i18n/zh-CN/index.d.ts +1 -1
  274. package/dist/components/LiveList/i18n/zh-CN/index.js +4 -4
  275. package/dist/components/LiveList/index.d.ts +17 -1
  276. package/dist/components/LiveList/index.js +10 -10
  277. package/dist/components/LiveList/pullToRefresh.js +88 -163
  278. package/dist/components/LiveMonitorView/LiveMonitorView.js +72 -110
  279. package/dist/components/LiveMonitorView/i18n/en-US/index.js +2 -2
  280. package/dist/components/LiveMonitorView/i18n/index.js +4 -4
  281. package/dist/components/LiveMonitorView/i18n/zh-CN/index.js +2 -2
  282. package/dist/components/LiveMonitorView/index.js +7 -7
  283. package/dist/components/LiveScenePanel/CameraSettingDialog.js +126 -188
  284. package/dist/components/LiveScenePanel/LiveSceneSelect.js +79 -106
  285. package/dist/components/LiveScenePanel/MaterialDialog.js +78 -98
  286. package/dist/components/LiveScenePanel/MaterialItem.js +105 -142
  287. package/dist/components/LiveScenePanel/MaterialRenameDialog.js +2 -2
  288. package/dist/components/LiveScenePanel/i18n/en-US/index.js +2 -2
  289. package/dist/components/LiveScenePanel/i18n/index.js +4 -4
  290. package/dist/components/LiveScenePanel/i18n/zh-CN/index.js +2 -2
  291. package/dist/components/LiveScenePanel/icons/AddIcon.js +10 -11
  292. package/dist/components/LiveScenePanel/icons/CameraIcon.js +9 -10
  293. package/dist/components/LiveScenePanel/icons/CameraMirror.js +13 -14
  294. package/dist/components/LiveScenePanel/icons/CameraUnmirror.js +11 -12
  295. package/dist/components/LiveScenePanel/icons/ImageIcon.js +8 -9
  296. package/dist/components/LiveScenePanel/icons/MoreIcon.js +13 -14
  297. package/dist/components/LiveScenePanel/icons/ScreenIcon.js +8 -9
  298. package/dist/components/LiveScenePanel/index.js +142 -190
  299. package/dist/components/MessageInput/AttachmentPicker/AttachmentPicker.js +2 -2
  300. package/dist/components/MessageInput/AttachmentPicker/AttachmentPicker.vue.d.ts +10 -1
  301. package/dist/components/MessageInput/AttachmentPicker/FilePicker.js +63 -2
  302. package/dist/components/MessageInput/AttachmentPicker/FilePicker.vue.d.ts +14 -13
  303. package/dist/components/MessageInput/AttachmentPicker/ImagePicker.js +63 -2
  304. package/dist/components/MessageInput/AttachmentPicker/ImagePicker.vue.d.ts +14 -13
  305. package/dist/components/MessageInput/AttachmentPicker/VideoPicker.js +63 -2
  306. package/dist/components/MessageInput/AttachmentPicker/VideoPicker.vue.d.ts +14 -13
  307. package/dist/components/MessageInput/AttachmentPicker/index.js +70 -72
  308. package/dist/components/MessageInput/AudioCallPicker/AudioCallPicker.js +155 -0
  309. package/dist/components/MessageInput/AudioCallPicker/AudioCallPicker.vue.d.ts +45 -0
  310. package/dist/components/MessageInput/AudioCallPicker/index.d.ts +3 -0
  311. package/dist/components/MessageInput/AudioCallPicker/index.js +4 -0
  312. package/dist/components/MessageInput/EmojiPicker/EmojiPicker.js +108 -96
  313. package/dist/components/MessageInput/EmojiPicker/EmojiPicker.vue.d.ts +34 -6
  314. package/dist/components/MessageInput/EmojiPicker/index.js +2 -2
  315. package/dist/components/MessageInput/MessageInput.js +2 -2
  316. package/dist/components/MessageInput/QuotedMessagePreview/QuotedMessagePreview.js +2 -2
  317. package/dist/components/MessageInput/QuotedMessagePreview/index.js +60 -74
  318. package/dist/components/MessageInput/SendButton/SendButton.js +2 -2
  319. package/dist/components/MessageInput/SendButton/index.js +20 -25
  320. package/dist/components/MessageInput/TextEditor/EditorCore.js +72 -79
  321. package/dist/components/MessageInput/TextEditor/TextEditor.js +2 -2
  322. package/dist/components/MessageInput/TextEditor/index.js +60 -95
  323. package/dist/components/MessageInput/VideoCallPicker/VideoCallPicker.js +158 -0
  324. package/dist/components/MessageInput/VideoCallPicker/VideoCallPicker.vue.d.ts +45 -0
  325. package/dist/components/MessageInput/VideoCallPicker/index.d.ts +3 -0
  326. package/dist/components/MessageInput/VideoCallPicker/index.js +4 -0
  327. package/dist/components/MessageInput/i18n/en-US.d.ts +4 -0
  328. package/dist/components/MessageInput/i18n/en-US.js +7 -3
  329. package/dist/components/MessageInput/i18n/index.d.ts +4 -0
  330. package/dist/components/MessageInput/i18n/index.js +6 -6
  331. package/dist/components/MessageInput/i18n/zh-CN.js +2 -2
  332. package/dist/components/MessageInput/index.d.ts +462 -191
  333. package/dist/components/MessageInput/index.js +23 -25
  334. package/dist/components/MessageList/Message/AudioMessage/AudioMessage.js +50 -65
  335. package/dist/components/MessageList/Message/AudioMessage/PlayButton.js +31 -37
  336. package/dist/components/MessageList/Message/AudioMessage/WaveForm.js +37 -52
  337. package/dist/components/MessageList/Message/AudioMessage/index.js +2 -2
  338. package/dist/components/MessageList/Message/CustomMessage/CallMessage/CallMessage.js +60 -0
  339. package/dist/components/MessageList/Message/CustomMessage/CallMessage/CallMessage.vue.d.ts +16 -0
  340. package/dist/components/MessageList/Message/CustomMessage/CallMessage/index.d.ts +3 -0
  341. package/dist/components/MessageList/Message/CustomMessage/CallMessage/index.js +4 -0
  342. package/dist/components/MessageList/Message/CustomMessage/CustomMessage.js +49 -2
  343. package/dist/components/MessageList/Message/CustomMessage/CustomMessage.vue.d.ts +15 -1
  344. package/dist/components/MessageList/Message/CustomMessage/index.js +2 -10
  345. package/dist/components/MessageList/Message/FaceMessage/FaceMessage.js +16 -20
  346. package/dist/components/MessageList/Message/FaceMessage/index.js +2 -2
  347. package/dist/components/MessageList/Message/FileMessage/FileMessage.js +57 -70
  348. package/dist/components/MessageList/Message/FileMessage/index.js +2 -2
  349. package/dist/components/MessageList/Message/GroupTipMessage/GroupTipMessage.js +2 -2
  350. package/dist/components/MessageList/Message/GroupTipMessage/GroupTipMessage.vue.d.ts +1 -1
  351. package/dist/components/MessageList/Message/GroupTipMessage/index.js +13 -23
  352. package/dist/components/MessageList/Message/GroupTipMessage/resolveGroupTipMessage.d.ts +1 -1
  353. package/dist/components/MessageList/Message/GroupTipMessage/resolveGroupTipMessage.js +41 -59
  354. package/dist/components/MessageList/Message/ImageMessage/ImageMessage.js +106 -169
  355. package/dist/components/MessageList/Message/ImageMessage/index.js +2 -2
  356. package/dist/components/MessageList/Message/LocationMessage/LocationMessage.js +7 -7
  357. package/dist/components/MessageList/Message/LocationMessage/index.js +2 -2
  358. package/dist/components/MessageList/Message/MergerMessage/MergerMessage.js +7 -7
  359. package/dist/components/MessageList/Message/MergerMessage/index.js +2 -2
  360. package/dist/components/MessageList/Message/Message.js +2 -2
  361. package/dist/components/MessageList/Message/MessageLayout/MessageActionDropdown/MessageActionDropdown.js +800 -1074
  362. package/dist/components/MessageList/Message/MessageLayout/MessageActionDropdown/MessageActionDropdown.vue.d.ts +1 -1
  363. package/dist/components/MessageList/Message/MessageLayout/MessageActionDropdown/index.js +2 -2
  364. package/dist/components/MessageList/Message/MessageLayout/MessageBubble/MessageBubble.js +36 -44
  365. package/dist/components/MessageList/Message/MessageLayout/MessageBubble/MessageBubble.vue.d.ts +1 -1
  366. package/dist/components/MessageList/Message/MessageLayout/MessageBubble/index.js +2 -2
  367. package/dist/components/MessageList/Message/MessageLayout/MessageLayout.js +116 -123
  368. package/dist/components/MessageList/Message/MessageLayout/MessageLayout.vue.d.ts +1 -1
  369. package/dist/components/MessageList/Message/MessageLayout/MessageMeta/MessageMeta.js +47 -73
  370. package/dist/components/MessageList/Message/MessageLayout/MessageMeta/MessageStatusIcon.js +24 -27
  371. package/dist/components/MessageList/Message/MessageLayout/MessageMeta/index.js +2 -2
  372. package/dist/components/MessageList/Message/MessageLayout/index.js +2 -2
  373. package/dist/components/MessageList/Message/MessageLayout/useMessageLayoutClasses.js +23 -28
  374. package/dist/components/MessageList/Message/RecalledMessage/RecalledMessage.js +39 -48
  375. package/dist/components/MessageList/Message/RecalledMessage/RecalledMessage.vue.d.ts +2 -2
  376. package/dist/components/MessageList/Message/RecalledMessage/index.js +2 -2
  377. package/dist/components/MessageList/Message/TextMessage/TextMessage.js +80 -102
  378. package/dist/components/MessageList/Message/TextMessage/index.js +2 -2
  379. package/dist/components/MessageList/Message/VideoMessage/VideoMessage.js +68 -92
  380. package/dist/components/MessageList/Message/VideoMessage/index.js +2 -2
  381. package/dist/components/MessageList/Message/index.js +18 -20
  382. package/dist/components/MessageList/MessageForward/ForwardListItem.js +46 -53
  383. package/dist/components/MessageList/MessageForward/MessageForward.js +102 -124
  384. package/dist/components/MessageList/MessageForward/index.js +2 -2
  385. package/dist/components/MessageList/MessageList.js +129 -204
  386. package/dist/components/MessageList/MessageListContext.js +9 -10
  387. package/dist/components/MessageList/MessageTimeDivider/MessageTimeDivider.js +20 -28
  388. package/dist/components/MessageList/MessageTimeDivider/index.js +2 -2
  389. package/dist/components/MessageList/ReadReceiptInfo/ReadReceiptInfo.js +294 -379
  390. package/dist/components/MessageList/ReadReceiptInfo/index.js +2 -2
  391. package/dist/components/MessageList/ScrollToBottom/ScrollToBottom.js +20 -25
  392. package/dist/components/MessageList/ScrollToBottom/index.js +2 -2
  393. package/dist/components/MessageList/i18n/en-US.d.ts +27 -1
  394. package/dist/components/MessageList/i18n/en-US.js +29 -3
  395. package/dist/components/MessageList/i18n/index.d.ts +134 -78
  396. package/dist/components/MessageList/i18n/index.js +6 -6
  397. package/dist/components/MessageList/i18n/zh-CN.d.ts +27 -1
  398. package/dist/components/MessageList/i18n/zh-CN.js +29 -3
  399. package/dist/components/MessageList/index.js +9 -10
  400. package/dist/components/MicButton/AudioIcon.js +27 -37
  401. package/dist/components/MicButton/index.js +37 -52
  402. package/dist/components/Search/Search.js +117 -156
  403. package/dist/components/Search/SearchAdvanced/DateRangePicker/DateRangePicker.js +378 -505
  404. package/dist/components/Search/SearchAdvanced/DateRangePicker/index.js +2 -2
  405. package/dist/components/Search/SearchAdvanced/MessageAdvanced/MessageAdvanced.js +147 -211
  406. package/dist/components/Search/SearchAdvanced/MessageAdvanced/index.js +2 -2
  407. package/dist/components/Search/SearchAdvanced/SearchAdvanced.js +46 -60
  408. package/dist/components/Search/SearchAdvanced/SearchTab/SearchTab.js +39 -51
  409. package/dist/components/Search/SearchAdvanced/SearchTab/index.js +2 -2
  410. package/dist/components/Search/SearchAdvanced/Slider/Slider.js +53 -82
  411. package/dist/components/Search/SearchAdvanced/Slider/index.js +2 -2
  412. package/dist/components/Search/SearchAdvanced/UserAdvanced/UserAdvanced.js +247 -317
  413. package/dist/components/Search/SearchAdvanced/UserAdvanced/index.js +2 -2
  414. package/dist/components/Search/SearchAdvanced/index.js +12 -12
  415. package/dist/components/Search/SearchBar/SearchBar.js +98 -122
  416. package/dist/components/Search/SearchBar/index.js +2 -2
  417. package/dist/components/Search/SearchResults/EmptyResult/EmptyResult.js +26 -37
  418. package/dist/components/Search/SearchResults/EmptyResult/index.js +2 -2
  419. package/dist/components/Search/SearchResults/Loading/Loading.js +13 -19
  420. package/dist/components/Search/SearchResults/Loading/index.js +2 -2
  421. package/dist/components/Search/SearchResults/SearchResults.js +249 -355
  422. package/dist/components/Search/SearchResults/SearchResultsItem/Conversation/Conversation.js +61 -83
  423. package/dist/components/Search/SearchResults/SearchResultsItem/Conversation/index.js +2 -2
  424. package/dist/components/Search/SearchResults/SearchResultsItem/Group/Group.js +40 -52
  425. package/dist/components/Search/SearchResults/SearchResultsItem/Group/index.js +2 -2
  426. package/dist/components/Search/SearchResults/SearchResultsItem/Message/Message.js +134 -181
  427. package/dist/components/Search/SearchResults/SearchResultsItem/Message/index.js +2 -2
  428. package/dist/components/Search/SearchResults/SearchResultsItem/SearchResultsItem.js +40 -46
  429. package/dist/components/Search/SearchResults/SearchResultsItem/User/User.js +56 -75
  430. package/dist/components/Search/SearchResults/SearchResultsItem/User/index.js +2 -2
  431. package/dist/components/Search/SearchResults/SearchResultsItem/index.js +11 -11
  432. package/dist/components/Search/SearchResults/SearchResultsItem/utils/highlightText.js +17 -36
  433. package/dist/components/Search/SearchResults/SearchResultsItem/utils/index.js +2 -2
  434. package/dist/components/Search/SearchResults/index.js +16 -16
  435. package/dist/components/Search/i18n/en-US/DateRangePicker.js +3 -3
  436. package/dist/components/Search/i18n/en-US/Search.js +3 -3
  437. package/dist/components/Search/i18n/en-US/index.js +7 -7
  438. package/dist/components/Search/i18n/index.js +4 -4
  439. package/dist/components/Search/i18n/zh-CN/DateRangePicker.js +3 -3
  440. package/dist/components/Search/i18n/zh-CN/Search.js +3 -3
  441. package/dist/components/Search/i18n/zh-CN/index.js +7 -7
  442. package/dist/components/Search/index.js +20 -26
  443. package/dist/components/StreamMixer/LocalMixer/MixerControl.js +68 -100
  444. package/dist/components/StreamMixer/LocalMixer/index.js +103 -171
  445. package/dist/components/StreamMixer/i18n/en-US/index.js +2 -2
  446. package/dist/components/StreamMixer/i18n/index.js +4 -4
  447. package/dist/components/StreamMixer/i18n/zh-CN/index.js +2 -2
  448. package/dist/components/StreamMixer/icons/CameraMirror.js +13 -14
  449. package/dist/components/StreamMixer/icons/Delete.js +13 -14
  450. package/dist/components/StreamMixer/icons/Down.js +10 -11
  451. package/dist/components/StreamMixer/icons/Rotation.js +11 -12
  452. package/dist/components/StreamMixer/icons/Up.js +10 -11
  453. package/dist/components/StreamMixer/index.js +19 -21
  454. package/dist/components/StreamView/Layout/CustomLayout.js +132 -209
  455. package/dist/components/StreamView/Layout/FloatLayout.js +136 -199
  456. package/dist/components/StreamView/Layout/GridLayout.js +117 -197
  457. package/dist/components/StreamView/Layout/MeetingLayout.js +129 -231
  458. package/dist/components/StreamView/Layout/MixLayout.js +70 -98
  459. package/dist/components/StreamView/common/ArrowStroke.js +26 -29
  460. package/dist/components/StreamView/common/LocalScreenView/index.js +82 -92
  461. package/dist/components/StreamView/common/StreamCover/index.js +33 -62
  462. package/dist/components/StreamView/common/StreamList/index.js +103 -163
  463. package/dist/components/StreamView/common/StreamPlay/index.js +58 -98
  464. package/dist/components/StreamView/common/StreamRegion/StreamRegionPC.js +58 -90
  465. package/dist/components/StreamView/common/StreamRegion/index.js +2 -2
  466. package/dist/components/StreamView/index.js +64 -66
  467. package/dist/components/StreamView/manager/mediaManager.js +125 -236
  468. package/dist/components/UserList/AllUserActions/index.js +2 -2
  469. package/dist/components/UserList/AllUserActions/indexH5.js +59 -69
  470. package/dist/components/UserList/AllUserActions/indexPC.js +61 -73
  471. package/dist/components/UserList/AllUserActions/useIndexHooks.js +32 -39
  472. package/dist/components/UserList/UserItem/UserAction/index.js +2 -2
  473. package/dist/components/UserList/UserItem/UserAction/indexH5.js +47 -61
  474. package/dist/components/UserList/UserItem/UserAction/indexPC.js +86 -130
  475. package/dist/components/UserList/UserItem/UserInfo/index.js +67 -117
  476. package/dist/components/UserList/UserItem/UserInvite/index.js +18 -21
  477. package/dist/components/UserList/UserItem/index.js +2 -2
  478. package/dist/components/UserList/UserItem/indexH5.js +42 -54
  479. package/dist/components/UserList/UserItem/indexPC.js +32 -37
  480. package/dist/components/UserList/UserListContent/index.js +30 -44
  481. package/dist/components/UserList/UserListSearch/index.js +20 -26
  482. package/dist/components/UserList/index.js +50 -63
  483. package/dist/components/UserPicker/UserPicker.js +110 -148
  484. package/dist/components/UserPicker/components/ListMode/ListMode.js +70 -96
  485. package/dist/components/UserPicker/components/ListMode/index.js +2 -2
  486. package/dist/components/UserPicker/components/SearchBar/SearchBar.js +43 -58
  487. package/dist/components/UserPicker/components/SearchBar/index.js +2 -2
  488. package/dist/components/UserPicker/components/SelectedPanel/SelectedPanel.js +69 -94
  489. package/dist/components/UserPicker/components/SelectedPanel/index.js +2 -2
  490. package/dist/components/UserPicker/components/TreeMode/TreeMode.js +33 -42
  491. package/dist/components/UserPicker/components/TreeMode/TreeNode.js +81 -106
  492. package/dist/components/UserPicker/components/TreeMode/index.js +2 -2
  493. package/dist/components/UserPicker/hooks/useSearchFilter.js +39 -80
  494. package/dist/components/UserPicker/hooks/useSelection.js +155 -313
  495. package/dist/components/UserPicker/hooks/useTreeState.js +17 -37
  496. package/dist/components/UserPicker/i18n/en-US.js +2 -2
  497. package/dist/components/UserPicker/i18n/index.js +6 -6
  498. package/dist/components/UserPicker/i18n/zh-CN.js +2 -2
  499. package/dist/components/UserPicker/index.js +7 -7
  500. package/dist/components/VideoSetting/CameraSelect.js +46 -58
  501. package/dist/components/VideoSetting/VideoMediaControl.js +45 -65
  502. package/dist/components/VideoSetting/VideoPreview.js +31 -40
  503. package/dist/components/VideoSetting/VideoProfile.js +38 -46
  504. package/dist/components/VideoSetting/VideoRequestDialog.js +2 -2
  505. package/dist/components/VideoSetting/VideoSettingTab.js +43 -55
  506. package/dist/components/VideoSetting/index.js +3 -3
  507. package/dist/components/VideoSettingPanel/CameraSelect.js +45 -57
  508. package/dist/components/VideoSettingPanel/VideoPreview.js +30 -39
  509. package/dist/components/VideoSettingPanel/VideoProfile.js +36 -44
  510. package/dist/components/VideoSettingPanel/i18n/en-US/index.js +5 -5
  511. package/dist/components/VideoSettingPanel/i18n/index.js +4 -4
  512. package/dist/components/VideoSettingPanel/i18n/zh-CN/index.js +5 -5
  513. package/dist/components/VideoSettingPanel/index.js +48 -63
  514. package/dist/constants/emoji.js +3 -4
  515. package/dist/directives/vClickOutside.js +9 -23
  516. package/dist/directives/vDblTouch.js +26 -51
  517. package/dist/directives/vTap.js +37 -68
  518. package/dist/directives/vTouchScale.js +83 -155
  519. package/dist/handler/index.js +4 -4
  520. package/dist/handler/translator.js +65 -97
  521. package/dist/handler/voiceConverter.js +21 -30
  522. package/dist/hooks/index.d.ts +1 -1
  523. package/dist/hooks/index.js +4 -4
  524. package/dist/hooks/useAudioControl.js +44 -128
  525. package/dist/hooks/useLongPress.js +41 -75
  526. package/dist/hooks/useMessageActions.d.ts +1 -1
  527. package/dist/hooks/useMessageActions.js +46 -57
  528. package/dist/hooks/useMouseHover.js +16 -26
  529. package/dist/hooks/useReadReceipt/useReadReceipt.js +66 -114
  530. package/dist/hooks/useRoomActions/index.js +11 -14
  531. package/dist/hooks/useRoomActions/useRoomAudioAction.js +39 -44
  532. package/dist/hooks/useRoomActions/useRoomScreenAction.js +41 -48
  533. package/dist/hooks/useRoomActions/useRoomVideoAction.js +38 -44
  534. package/dist/hooks/useRoomEngine.js +14 -17
  535. package/dist/hooks/useScroll.js +52 -89
  536. package/dist/hooks/useUserActions/index.js +81 -117
  537. package/dist/hooks/useUserActions/useAdminAction.js +29 -35
  538. package/dist/hooks/useUserActions/useAudioAction.js +36 -40
  539. package/dist/hooks/useUserActions/useChangeNameCardAction/changeNameCardDialog.js +59 -69
  540. package/dist/hooks/useUserActions/useChangeNameCardAction/changeNameCardInput.js +40 -49
  541. package/dist/hooks/useUserActions/useChangeNameCardAction/index.js +43 -51
  542. package/dist/hooks/useUserActions/useChatAction.js +23 -25
  543. package/dist/hooks/useUserActions/useKickUserAction.js +27 -32
  544. package/dist/hooks/useUserActions/useMemberInviteAction.js +24 -40
  545. package/dist/hooks/useUserActions/useSeatAction.js +96 -108
  546. package/dist/hooks/useUserActions/useTransferOwnerAction.js +40 -47
  547. package/dist/hooks/useUserActions/useVideoAction.js +35 -38
  548. package/dist/hooks/useZIndex.js +7 -12
  549. package/dist/i18n/index.js +4 -4
  550. package/dist/index-CeQ4nl87.js +44 -0
  551. package/dist/index-D-KJvDvy.js +5125 -0
  552. package/dist/index-D88ja_7_.js +12047 -0
  553. package/dist/index-DPczIrgX.js +42 -0
  554. package/dist/index-DTq2ybsB.js +33 -0
  555. package/dist/index.d.ts +2 -1
  556. package/dist/index.js +178 -152
  557. package/dist/index.vue_vue_type_script_setup_true_lang-DZIBxSQ7.js +32 -0
  558. package/dist/locales/en-US.js +31 -31
  559. package/dist/locales/index.js +29 -34
  560. package/dist/locales/zh-CN.js +31 -31
  561. package/dist/rtc/index.d.ts +34 -2
  562. package/dist/rtc/index.js +63 -86
  563. package/dist/rtc/server.js +62 -85
  564. package/dist/states/BarrageListState/BarrageListState.js +98 -183
  565. package/dist/states/BarrageListState/index.js +2 -2
  566. package/dist/states/BattleState.d.ts +46 -0
  567. package/dist/states/BattleState.js +117 -0
  568. package/dist/states/C2CSettingState/C2CSettingState.js +52 -92
  569. package/dist/states/C2CSettingState/index.js +2 -2
  570. package/dist/states/CoGuestState.d.ts +1 -1
  571. package/dist/states/CoGuestState.js +191 -291
  572. package/dist/states/CoHostState/CoHostState.d.ts +30 -0
  573. package/dist/states/CoHostState/CoHostState.js +209 -0
  574. package/dist/states/CoHostState/index.d.ts +1 -0
  575. package/dist/states/CoHostState/index.js +4 -0
  576. package/dist/states/ContactListState/ContactListState.js +175 -271
  577. package/dist/states/ContactListState/index.js +2 -2
  578. package/dist/states/ConversationListState/ConversationListState.js +61 -112
  579. package/dist/states/ConversationListState/index.js +2 -2
  580. package/dist/states/DeviceState.js +240 -389
  581. package/dist/states/GroupSettingState/GroupSettingState.js +220 -378
  582. package/dist/states/GroupSettingState/index.js +7 -7
  583. package/dist/states/GroupSettingState/permissions.js +240 -250
  584. package/dist/states/GroupSettingState/types.js +5 -41
  585. package/dist/states/LiveAudienceState.js +100 -132
  586. package/dist/states/LiveMonitorState/api/http.js +1245 -1910
  587. package/dist/states/LiveMonitorState/index.js +92 -148
  588. package/dist/states/LiveMonitorState/player/adapters/trtc.js +54 -106
  589. package/dist/states/LiveMonitorState/player/base/basePlayer.js +111 -169
  590. package/dist/states/LiveMonitorState/player/index.js +10 -10
  591. package/dist/states/LiveMonitorState/player/manager/playerManager.js +27 -33
  592. package/dist/states/LiveMonitorState/player/types/index.js +8 -8
  593. package/dist/states/LiveMonitorState/player/types/player.js +3 -13
  594. package/dist/states/LiveMonitorState/player/types/trtc.js +6 -20
  595. package/dist/states/LiveMonitorState/utils/index.js +17 -22
  596. package/dist/states/LiveSeatState/index.js +16 -16
  597. package/dist/states/LiveSeatState/seatEventManager.js +54 -75
  598. package/dist/states/LiveSeatState/seatManager.js +29 -36
  599. package/dist/states/LiveSeatState/store.js +18 -25
  600. package/dist/states/LiveSeatState/usePlayStream/MixStreamPlayer.js +43 -65
  601. package/dist/states/LiveSeatState/usePlayStream/RTCStreamManager.js +55 -83
  602. package/dist/states/LiveSeatState/usePlayStream/RTCStreamPlayer.js +59 -97
  603. package/dist/states/LiveSeatState/usePlayStream/index.js +44 -96
  604. package/dist/states/LiveSeatState/usePlayStream/useStreamPostion.js +43 -55
  605. package/dist/states/LiveState/index.js +190 -275
  606. package/dist/states/LoginState.js +48 -59
  607. package/dist/states/MessageActionState/MessageActionState.d.ts +6 -6
  608. package/dist/states/MessageActionState/MessageActionState.js +45 -56
  609. package/dist/states/MessageActionState/index.js +2 -2
  610. package/dist/states/MessageInputState/MessageInputState.js +90 -139
  611. package/dist/states/MessageInputState/index.js +4 -4
  612. package/dist/states/MessageInputState/type.js +2 -10
  613. package/dist/states/MessageInputState/utils.js +20 -21
  614. package/dist/states/MessageListState/MessageListState.js +65 -89
  615. package/dist/states/MessageListState/index.js +2 -2
  616. package/dist/states/RoomState.js +223 -332
  617. package/dist/states/SearchState.d.ts +2 -2
  618. package/dist/states/SearchState.js +230 -356
  619. package/dist/states/SeatStore.js +140 -213
  620. package/dist/states/UserState/index.js +31 -51
  621. package/dist/states/UserState/store.js +95 -147
  622. package/dist/states/UserState/userEventManager.js +85 -134
  623. package/dist/states/UserState/userManager.js +184 -232
  624. package/dist/states/VideoMixerState.js +181 -228
  625. package/dist/statistical/const.d.ts +4 -0
  626. package/dist/statistical/const.js +4 -0
  627. package/dist/statistical/index.d.ts +2 -0
  628. package/dist/statistical/index.js +6 -0
  629. package/dist/statistical/statistical.d.ts +10 -0
  630. package/dist/statistical/statistical.js +19 -0
  631. package/dist/styles/index.css +1 -13144
  632. package/dist/types/battle.d.ts +11 -0
  633. package/dist/types/battle.js +1 -0
  634. package/dist/types/call.d.ts +55 -0
  635. package/dist/types/call.js +4 -0
  636. package/dist/types/chatSetting.d.ts +1 -0
  637. package/dist/types/chatSetting.js +6 -0
  638. package/dist/types/coGuest.js +2 -8
  639. package/dist/types/coHost.d.ts +44 -4
  640. package/dist/types/coHost.js +4 -8
  641. package/dist/types/contact.js +3 -17
  642. package/dist/types/conversation.js +6 -36
  643. package/dist/types/device.d.ts +4 -0
  644. package/dist/types/device.js +8 -45
  645. package/dist/types/engine.d.ts +23 -7
  646. package/dist/types/engine.js +5 -23
  647. package/dist/types/index.d.ts +9 -5
  648. package/dist/types/index.js +92 -80
  649. package/dist/types/live.js +4 -21
  650. package/dist/types/message.js +4 -29
  651. package/dist/types/monitor.js +2 -6
  652. package/dist/types/room.js +3 -16
  653. package/dist/types/search.js +9 -15
  654. package/dist/types/seat.d.ts +4 -4
  655. package/dist/types/stream.js +3 -14
  656. package/dist/types/types.js +32 -329
  657. package/dist/types/user.d.ts +0 -3
  658. package/dist/types/user.js +8 -65
  659. package/dist/useId-CtirfF0W.js +12 -0
  660. package/dist/utils/call.d.ts +6 -2
  661. package/dist/utils/call.js +126 -11
  662. package/dist/utils/copyText.js +20 -33
  663. package/dist/utils/documentLink.js +2 -2
  664. package/dist/utils/domOperation.js +99 -122
  665. package/dist/utils/downFile.js +11 -19
  666. package/dist/utils/emoji.js +24 -31
  667. package/dist/utils/enableSampleTaskStatus.js +5 -8
  668. package/dist/utils/env.js +8 -13
  669. package/dist/utils/environment.js +14 -18
  670. package/dist/utils/index.js +36 -36
  671. package/dist/utils/json.js +34 -58
  672. package/dist/utils/lodash.js +63 -109
  673. package/dist/utils/riseInput.js +19 -36
  674. package/dist/utils/time.js +640 -934
  675. package/dist/utils/type-check.js +21 -46
  676. package/dist/utils/utils.js +131 -235
  677. package/dist/utils-DaB7eSu5.js +48 -0
  678. package/package.json +5 -4
  679. package/src/chat/index.ts +27 -0
  680. package/src/chat/server.ts +5 -0
  681. package/src/components/BarrageInput/TextEditor/Editor.scss +2 -2
  682. package/src/components/BarrageList/Message/TextMessage/TextMessage.vue +1 -1
  683. package/src/components/ChatSetting/ChatSetting.vue +3 -3
  684. package/src/components/ChatSetting/GroupChatSetting/GroupActions/GroupActions.vue +3 -0
  685. package/src/components/ChatSetting/GroupChatSetting/GroupChatSetting.vue +1 -0
  686. package/src/components/ChatSetting/GroupChatSetting/GroupManagement/GroupManagement.vue +1 -0
  687. package/src/components/CoGuestPanel/CoGuestPanel.vue +2 -1
  688. package/src/components/CoHostPanel/BattlePanel.vue +271 -0
  689. package/src/components/CoHostPanel/CoHostPanel.vue +218 -0
  690. package/src/components/CoHostPanel/ConfigSettingPanel.vue +264 -0
  691. package/src/components/CoHostPanel/ConnectionPanel.vue +549 -0
  692. package/src/components/CoHostPanel/RecommendHostList.vue +306 -0
  693. package/src/components/CoHostPanel/UserList.vue +93 -0
  694. package/src/components/CoHostPanel/i18n/en-US/index.ts +78 -0
  695. package/src/components/CoHostPanel/i18n/index.ts +4 -0
  696. package/src/components/CoHostPanel/i18n/zh-CN/index.ts +79 -0
  697. package/src/components/CoHostPanel/index.ts +7 -0
  698. package/src/components/ContactList/ContactInfo/GroupInfo/GroupInfo.vue +1 -0
  699. package/src/components/ConversationList/ConversationCreate/ConversationCreate.vue +2 -1
  700. package/src/components/ConversationList/ConversationPreview/ConversationPreviewTimestamp.vue +1 -1
  701. package/src/components/ConversationList/ConversationSearch/ConversationSearch.vue +1 -0
  702. package/src/components/LiveCoreView/CoreViewDecorate/BattleDecorate.vue +420 -0
  703. package/src/components/LiveCoreView/CoreViewDecorate/BattleUserDecorate.vue +141 -0
  704. package/src/components/LiveCoreView/CoreViewDecorate/CoHostDecorate.vue +116 -0
  705. package/src/components/LiveCoreView/CoreViewDecorate/LiveCoreDecorate.vue +70 -0
  706. package/src/components/LiveCoreView/PlayerControl/MultiResolution.vue +130 -0
  707. package/src/components/LiveCoreView/PlayerControl/PlayerControl.vue +10 -8
  708. package/src/components/LiveCoreView/PlayerControl/PlayerControlState.ts +117 -1
  709. package/src/components/LiveCoreView/assets/img/defeat.png +0 -0
  710. package/src/components/LiveCoreView/assets/img/draw.png +0 -0
  711. package/src/components/LiveCoreView/assets/img/victory.png +0 -0
  712. package/src/components/LiveCoreView/assets/svg/BattleOrdinaryBadge.svg +20 -0
  713. package/src/components/LiveCoreView/assets/svg/BattleTopBadge.svg +16 -0
  714. package/src/components/LiveCoreView/assets/svg/blueBkg.svg +9 -0
  715. package/src/components/LiveCoreView/assets/svg/redBkg.svg +9 -0
  716. package/src/components/LiveCoreView/assets/svg/s.svg +17 -0
  717. package/src/components/LiveCoreView/assets/svg/v.svg +17 -0
  718. package/src/components/LiveCoreView/i18n/en-US/index.ts +6 -0
  719. package/src/components/LiveCoreView/i18n/zh-CN/index.ts +6 -0
  720. package/src/components/LiveCoreView/index.vue +4 -1
  721. package/src/components/LiveList/LiveList.vue +61 -106
  722. package/src/components/LiveList/LiveListH5.vue +1 -1
  723. package/src/components/LiveList/i18n/en-US/index.ts +1 -1
  724. package/src/components/LiveList/i18n/zh-CN/index.ts +1 -1
  725. package/src/components/MessageInput/AttachmentPicker/AttachmentPicker.vue +10 -8
  726. package/src/components/MessageInput/AttachmentPicker/FilePicker.vue +59 -31
  727. package/src/components/MessageInput/AttachmentPicker/ImagePicker.vue +58 -31
  728. package/src/components/MessageInput/AttachmentPicker/VideoPicker.vue +58 -31
  729. package/src/components/MessageInput/AudioCallPicker/AudioCallPicker.vue +240 -0
  730. package/src/components/MessageInput/AudioCallPicker/index.ts +3 -0
  731. package/src/components/MessageInput/EmojiPicker/EmojiPicker.vue +107 -18
  732. package/src/components/MessageInput/MessageInput.module.scss +1 -1
  733. package/src/components/MessageInput/MessageInput.vue +6 -2
  734. package/src/components/MessageInput/VideoCallPicker/VideoCallPicker.vue +246 -0
  735. package/src/components/MessageInput/VideoCallPicker/index.ts +3 -0
  736. package/src/components/MessageInput/i18n/en-US.ts +4 -0
  737. package/src/components/MessageInput/index.ts +10 -4
  738. package/src/components/MessageInput/types.d.ts +3 -1
  739. package/src/components/MessageList/Message/CustomMessage/CallMessage/CallMessage.vue +67 -0
  740. package/src/components/MessageList/Message/CustomMessage/CallMessage/index.ts +3 -0
  741. package/src/components/MessageList/Message/CustomMessage/CustomMessage.vue +59 -2
  742. package/src/components/MessageList/Message/CustomMessage/index.ts +1 -1
  743. package/src/components/MessageList/Message/GroupTipMessage/GroupTipMessage.vue +9 -10
  744. package/src/components/MessageList/Message/GroupTipMessage/resolveGroupTipMessage.ts +1 -1
  745. package/src/components/MessageList/Message/MessageLayout/MessageActionDropdown/MessageActionDropdown.vue +1 -1
  746. package/src/components/MessageList/Message/MessageLayout/MessageBubble/MessageBubble.vue +1 -1
  747. package/src/components/MessageList/Message/MessageLayout/MessageLayout.vue +30 -18
  748. package/src/components/MessageList/Message/RecalledMessage/RecalledMessage.vue +10 -18
  749. package/src/components/MessageList/i18n/en-US.ts +32 -1
  750. package/src/components/MessageList/i18n/index.ts +4 -4
  751. package/src/components/MessageList/i18n/zh-CN.ts +32 -1
  752. package/src/components/MessageList/index.ts +2 -2
  753. package/src/components/Search/SearchResults/SearchResults.scss +1 -0
  754. package/src/components/UserPicker/UserPicker.vue +0 -2
  755. package/src/hooks/index.ts +1 -2
  756. package/src/hooks/useMessageActions.ts +9 -9
  757. package/src/index.ts +2 -1
  758. package/src/rtc/index.ts +5 -0
  759. package/src/statistical/const.ts +5 -0
  760. package/src/statistical/index.ts +2 -0
  761. package/src/statistical/statistical.ts +23 -0
  762. package/src/types/battle.ts +12 -0
  763. package/src/types/call.ts +62 -0
  764. package/src/types/chatSetting.ts +5 -0
  765. package/src/types/coHost.ts +46 -4
  766. package/src/types/device.ts +5 -0
  767. package/src/types/engine.ts +45 -21
  768. package/src/types/index.ts +12 -5
  769. package/src/types/seat.ts +5 -5
  770. package/src/types/user.ts +0 -4
  771. package/src/utils/call.ts +233 -5
  772. package/src/utils/time.ts +1 -1
  773. package/dist/AttachmentPicker.module-BesmtGyl.js +0 -11
  774. package/dist/AudioRequestDialog.vue_vue_type_script_setup_true_lang-BmX-qsat.js +0 -108
  775. package/dist/DialogPortal-DWeT-J6v.js +0 -496
  776. package/dist/FilePicker.vue_vue_type_script_setup_true_lang-CdJ4DUzE.js +0 -76
  777. package/dist/ImagePicker.vue_vue_type_script_setup_true_lang-CbNUofpK.js +0 -76
  778. package/dist/MaterialRenameDialog.vue_vue_type_script_setup_true_lang-CVh4Regz.js +0 -43
  779. package/dist/MessageInput.vue_vue_type_script_setup_true_lang-wUJPjWbx.js +0 -128
  780. package/dist/PopoverTrigger-BKOIHfdS.js +0 -679
  781. package/dist/PopperContent-DtL7HVWz.js +0 -2227
  782. package/dist/Teleport-CMvGsENT.js +0 -1365
  783. package/dist/VideoPicker.vue_vue_type_script_setup_true_lang-CmxjbNDJ.js +0 -76
  784. package/dist/VideoRequestDialog.vue_vue_type_script_setup_true_lang-CnE-LwNh.js +0 -108
  785. package/dist/_commonjsHelpers-CUmg6egw.js +0 -6
  786. package/dist/_plugin-vue_export-helper-1tPrXgE0.js +0 -10
  787. package/dist/index-BF6QB9jF.js +0 -63
  788. package/dist/index-CX1Zs9En.js +0 -44
  789. package/dist/index-DRcLhqhU.js +0 -38
  790. package/dist/index-ex2Jv3Tj.js +0 -7655
  791. package/dist/index-t9cbWbGG.js +0 -15913
  792. package/dist/index.vue_vue_type_script_setup_true_lang-EcKm3pYY.js +0 -36
  793. package/dist/states/CoHostState.d.ts +0 -22
  794. package/dist/states/CoHostState.js +0 -178
  795. package/dist/useId-CsgLY8y3.js +0 -13
  796. package/dist/utils-KP1QpeUS.js +0 -59
  797. package/src/components/MessageInput/EmojiPicker/EmojiPicker.module.scss +0 -28
@@ -1,25 +1,19 @@
1
1
  <template>
2
2
  <View>
3
- <template v-if="label">
4
- <button
5
- :class="[styles['attachment-picker__item'], className]"
6
- :style="style"
7
- @click="handleButtonClick"
8
- >
9
- <IconImage
10
- :size="iconSize"
11
- :class="styles['attachment-picker__item-icon']"
12
- />
13
- <div>{{ label }}</div>
14
- </button>
15
- </template>
16
- <template v-else>
17
- <IconImage
18
- :size="iconSize"
19
- :class="styles['attachment-picker__item-icon']"
20
- @click="handleButtonClick"
21
- />
22
- </template>
3
+ <div @click="handleButtonClick">
4
+ <slot>
5
+ <div
6
+ :class="cs(styles['image-picker__button'], {
7
+ [styles['disabled']]: props.disabled,
8
+ })"
9
+ >
10
+ <IconImage
11
+ :size="props.iconSize"
12
+ :class="cs(styles['image-picker__icon'])"
13
+ />
14
+ </div>
15
+ </slot>
16
+ </div>
23
17
  <input
24
18
  ref="fileInputRef"
25
19
  type="file"
@@ -31,11 +25,11 @@
31
25
  </template>
32
26
 
33
27
  <script setup lang="ts">
34
- import { ref } from 'vue';
28
+ import { ref, useCssModule } from 'vue';
35
29
  import { IconImage } from '@tencentcloud/uikit-base-component-vue3';
36
- import { MessageContentType, useMessageInputState } from '../../../states/MessageInputState';
30
+ import cs from 'classnames';
37
31
  import { View } from '../../../baseComp/View';
38
- import styles from './AttachmentPicker.module.scss';
32
+ import { MessageContentType, useMessageInputState } from '../../../states/MessageInputState';
39
33
 
40
34
  const PICKER_CONSTANTS = {
41
35
  ACCEPT_TYPE: '.jpg,.jpeg,.gif,.png,.bmp,.webp',
@@ -44,23 +38,24 @@ const PICKER_CONSTANTS = {
44
38
  interface Props {
45
39
  label?: string;
46
40
  iconSize?: number;
47
- onClose?: () => void;
48
- className?: string;
49
- style?: Record<string, string>;
41
+ disabled?: boolean;
50
42
  }
51
43
 
52
44
  const props = withDefaults(defineProps<Props>(), {
53
45
  label: '',
54
- className: '',
55
- style: undefined,
56
- onClose: () => {},
57
- iconSize: 24,
46
+ disabled: false,
47
+ iconSize: 20,
58
48
  });
59
49
 
50
+ const styles = useCssModule();
60
51
  const { sendMessage } = useMessageInputState();
61
52
  const fileInputRef = ref<HTMLInputElement | null>(null);
62
53
 
63
54
  function handleButtonClick() {
55
+ if (props.disabled) {
56
+ return;
57
+ }
58
+
64
59
  fileInputRef.value?.click();
65
60
  }
66
61
 
@@ -73,6 +68,38 @@ function handleFileInput(e: Event) {
73
68
 
74
69
  sendMessage([{ type: MessageContentType.IMAGE, content: file }]);
75
70
  target.value = '';
76
- props.onClose?.();
77
71
  }
78
72
  </script>
73
+
74
+ <style lang="scss" module>
75
+ .image-picker {
76
+ &__button {
77
+ display: flex;
78
+ align-items: center;
79
+ justify-content: center;
80
+ cursor: pointer;
81
+ padding: 4px 6px;
82
+ transition: background-color 0.5s ease;
83
+ border-radius: 4px;
84
+
85
+ &:hover {
86
+ background-color: var(--button-color-secondary-hover);
87
+ }
88
+
89
+ &:active {
90
+ background-color: var(--button-color-secondary-active);
91
+ }
92
+
93
+ &.disabled {
94
+ opacity: 0.5;
95
+ cursor: not-allowed;
96
+ user-select: none;
97
+ pointer-events: none;
98
+ }
99
+ }
100
+
101
+ &__icon {
102
+ color: var(--text-color-primary);
103
+ }
104
+ }
105
+ </style>
@@ -1,25 +1,19 @@
1
1
  <template>
2
2
  <View>
3
- <template v-if="label">
4
- <button
5
- :class="[styles['attachment-picker__item'], className]"
6
- :style="style"
7
- @click="handleButtonClick"
8
- >
9
- <IconVideo
10
- :size="iconSize"
11
- :class="styles['attachment-picker__item-icon']"
12
- />
13
- <div>{{ label }}</div>
14
- </button>
15
- </template>
16
- <template v-else>
17
- <IconVideo
18
- :size="iconSize"
19
- :class="styles['attachment-picker__item-icon']"
20
- @click="handleButtonClick"
21
- />
22
- </template>
3
+ <div @click="handleButtonClick">
4
+ <slot>
5
+ <div
6
+ :class="cs(styles['video-picker__button'], {
7
+ [styles['disabled']]: props.disabled,
8
+ })"
9
+ >
10
+ <IconVideo
11
+ :size="props.iconSize"
12
+ :class="cs(styles['video-picker__icon'])"
13
+ />
14
+ </div>
15
+ </slot>
16
+ </div>
23
17
  <input
24
18
  ref="fileInputRef"
25
19
  type="file"
@@ -31,11 +25,11 @@
31
25
  </template>
32
26
 
33
27
  <script setup lang="ts">
34
- import { ref } from 'vue';
28
+ import { ref, useCssModule } from 'vue';
35
29
  import { IconVideo } from '@tencentcloud/uikit-base-component-vue3';
36
- import { MessageContentType, useMessageInputState } from '../../../states/MessageInputState';
30
+ import cs from 'classnames';
37
31
  import { View } from '../../../baseComp/View';
38
- import styles from './AttachmentPicker.module.scss';
32
+ import { MessageContentType, useMessageInputState } from '../../../states/MessageInputState';
39
33
 
40
34
  const PICKER_CONSTANTS = {
41
35
  ACCEPT_TYPE: '.mp4,.mov,.qt',
@@ -44,23 +38,24 @@ const PICKER_CONSTANTS = {
44
38
  interface Props {
45
39
  label?: string;
46
40
  iconSize?: number;
47
- onClose?: () => void;
48
- className?: string;
49
- style?: Record<string, string>;
41
+ disabled?: boolean;
50
42
  }
51
43
 
52
44
  const props = withDefaults(defineProps<Props>(), {
53
45
  label: '',
54
- className: '',
55
- style: undefined,
56
- onClose: () => {},
57
- iconSize: 24,
46
+ disabled: false,
47
+ iconSize: 20,
58
48
  });
59
49
 
50
+ const styles = useCssModule();
60
51
  const { sendMessage } = useMessageInputState();
61
52
  const fileInputRef = ref<HTMLInputElement | null>(null);
62
53
 
63
54
  function handleButtonClick() {
55
+ if (props.disabled) {
56
+ return;
57
+ }
58
+
64
59
  fileInputRef.value?.click();
65
60
  }
66
61
 
@@ -73,6 +68,38 @@ function handleFileInput(e: Event) {
73
68
 
74
69
  sendMessage([{ type: MessageContentType.VIDEO, content: file }]);
75
70
  target.value = '';
76
- props.onClose?.();
77
71
  }
78
72
  </script>
73
+
74
+ <style lang="scss" module>
75
+ .video-picker {
76
+ &__button {
77
+ display: flex;
78
+ align-items: center;
79
+ justify-content: center;
80
+ cursor: pointer;
81
+ padding: 4px 6px;
82
+ transition: background-color 0.5s ease;
83
+ border-radius: 4px;
84
+
85
+ &:hover {
86
+ background-color: var(--button-color-secondary-hover);
87
+ }
88
+
89
+ &:active {
90
+ background-color: var(--button-color-secondary-active);
91
+ }
92
+
93
+ &.disabled {
94
+ opacity: 0.5;
95
+ cursor: not-allowed;
96
+ user-select: none;
97
+ pointer-events: none;
98
+ }
99
+ }
100
+
101
+ &__icon {
102
+ color: var(--text-color-primary);
103
+ }
104
+ }
105
+ </style>
@@ -0,0 +1,240 @@
1
+ <template>
2
+ <View>
3
+ <div
4
+ :class="cs(styles['audio-call-picker__button'], {
5
+ [styles['disabled']]: props.disabled,
6
+ })"
7
+ @click="handleAudioCallClick"
8
+ >
9
+ <slot>
10
+ <IconCall1
11
+ :size="props.iconSize"
12
+ :class="styles['audio-call-picker__icon']"
13
+ />
14
+ </slot>
15
+ </div>
16
+
17
+ <TUIDialog
18
+ :visible="isGroupCallDialogVisible"
19
+ :title="t('MessageInput.select_call_members')"
20
+ :cancelText="t('MessageInput.cancel')"
21
+ :cancel="handleCloseGroupCallDialog"
22
+ :close="handleCloseGroupCallDialog"
23
+ :confirmText="t('MessageInput.initiate_call')"
24
+ :confirm="handleConfirmGroupCall"
25
+ :customClasses="['group-call-dialog']"
26
+ appendTo="body"
27
+ >
28
+ <UserPicker
29
+ ref="groupMemberPickerRef"
30
+ display-mode="list"
31
+ :data-source="groupMemberOptions"
32
+ :max-count="MAX_GROUP_CALL_MEMBERS"
33
+ :min-count="MIN_GROUP_CALL_MEMBERS"
34
+ class="group-member-picker"
35
+ style="width: 100%;"
36
+ @reach-end="handleLoadMoreGroupMembers"
37
+ />
38
+ </TUIDialog>
39
+ </View>
40
+ </template>
41
+
42
+ <script setup lang="ts">
43
+ import { computed, ref, useCssModule } from 'vue';
44
+ import {
45
+ IconCall1,
46
+ TUIDialog,
47
+ useUIKit,
48
+ } from '@tencentcloud/uikit-base-component-vue3';
49
+ import cs from 'classnames';
50
+ import { View } from '../../../baseComp/View';
51
+ import { useConversationListState } from '../../../states/ConversationListState';
52
+ import { useGroupSettingState } from '../../../states/GroupSettingState';
53
+ import { ConversationType } from '../../../types/engine';
54
+ import { startCall } from '../../../utils/call';
55
+ import { UserPicker } from '../../UserPicker';
56
+
57
+ interface AudioCallPickerProps {
58
+ label?: string;
59
+ iconSize?: number;
60
+ disabled?: boolean;
61
+ }
62
+
63
+ const AUDIO_CALL_TYPE = 1;
64
+ const MEMBER_PAGE_SIZE = 80;
65
+ const MAX_GROUP_CALL_MEMBERS = 9;
66
+ const MIN_GROUP_CALL_MEMBERS = 1;
67
+
68
+ const props = withDefaults(defineProps<AudioCallPickerProps>(), {
69
+ label: '',
70
+ iconSize: 20,
71
+ disabled: false,
72
+ });
73
+
74
+ const styles = useCssModule();
75
+ const { t } = useUIKit();
76
+ const { activeConversation } = useConversationListState();
77
+ const { allMembers, getGroupMemberList, memberCount } = useGroupSettingState();
78
+
79
+ const isGroupCallDialogVisible = ref(false);
80
+ const groupMemberPickerRef = ref();
81
+
82
+ const isC2CConversation = computed(() =>
83
+ activeConversation.value?.type === ConversationType.C2C,
84
+ );
85
+
86
+ const groupMemberOptions = computed(() =>
87
+ allMembers.value?.map((member: any) => ({
88
+ key: member.userID,
89
+ label: member.nick || member.userID,
90
+ avatarUrl: member.avatar,
91
+ })) ?? [],
92
+ );
93
+
94
+ const canStartCall = computed(() => {
95
+ if (!activeConversation.value || props.disabled) {
96
+ return false;
97
+ }
98
+
99
+ // TODO: add more call permission check logic
100
+ return true;
101
+ });
102
+
103
+ function initiatePrivateCall(): void {
104
+ const peerUserId = activeConversation.value?.userProfile?.userID;
105
+ if (!peerUserId) {
106
+ console.warn('No peer user ID found for private call');
107
+ return;
108
+ }
109
+
110
+ try {
111
+ startCall({
112
+ userIDList: [peerUserId],
113
+ chatGroupID: undefined,
114
+ type: AUDIO_CALL_TYPE,
115
+ });
116
+ } catch (error) {
117
+ console.error('Failed to start private audio call:', error);
118
+ }
119
+ }
120
+
121
+ function loadMoreGroupMembers(): void {
122
+ if (activeConversation.value?.type !== ConversationType.GROUP) {
123
+ return;
124
+ }
125
+
126
+ const currentMemberCount = allMembers.value?.length || 0;
127
+ const totalMemberCount = memberCount.value || 0;
128
+
129
+ if (currentMemberCount < totalMemberCount) {
130
+ getGroupMemberList({
131
+ count: MEMBER_PAGE_SIZE,
132
+ offset: currentMemberCount,
133
+ });
134
+ }
135
+ }
136
+
137
+ function showGroupCallDialog(): void {
138
+ loadMoreGroupMembers();
139
+ isGroupCallDialogVisible.value = true;
140
+ }
141
+
142
+ function handleCloseGroupCallDialog() {
143
+ isGroupCallDialogVisible.value = false;
144
+ }
145
+
146
+ function initiateGroupCall(): void {
147
+ const currentGroupId = activeConversation.value?.groupProfile?.groupID;
148
+ if (!groupMemberPickerRef.value || !currentGroupId) {
149
+ console.warn('Missing group information for group call');
150
+ return;
151
+ }
152
+
153
+ const selectedMembers = groupMemberPickerRef.value.getSelectedItems();
154
+ if (!Array.isArray(selectedMembers) || selectedMembers.length === 0) {
155
+ console.warn('No members selected for group call');
156
+ return;
157
+ }
158
+
159
+ const selectedUserIds = selectedMembers.map((member: any) => member.key);
160
+
161
+ try {
162
+ startCall({
163
+ userIDList: selectedUserIds,
164
+ chatGroupID: currentGroupId,
165
+ type: AUDIO_CALL_TYPE,
166
+ });
167
+
168
+ handleCloseGroupCallDialog();
169
+ } catch (error) {
170
+ console.error('Failed to start group audio call:', error);
171
+ }
172
+ }
173
+
174
+ function handleAudioCallClick() {
175
+ if (!canStartCall.value) {
176
+ console.warn('Cannot start audio call');
177
+ return;
178
+ }
179
+
180
+ if (isC2CConversation.value) {
181
+ initiatePrivateCall();
182
+ } else {
183
+ showGroupCallDialog();
184
+ }
185
+ }
186
+
187
+ const handleLoadMoreGroupMembers = () => {
188
+ if (activeConversation.value?.type === ConversationType.GROUP) {
189
+ loadMoreGroupMembers();
190
+ }
191
+ };
192
+
193
+ const handleConfirmGroupCall = () => initiateGroupCall();
194
+ </script>
195
+
196
+ <style lang="scss" module>
197
+ .audio-call-picker {
198
+ &__button {
199
+ display: flex;
200
+ align-items: center;
201
+ justify-content: center;
202
+ cursor: pointer;
203
+ padding: 4px 6px;
204
+ transition: background-color 0.5s ease;
205
+ border-radius: 4px;
206
+
207
+ &:hover {
208
+ background-color: var(--button-color-secondary-hover);
209
+ }
210
+
211
+ &:active {
212
+ background-color: var(--button-color-secondary-active);
213
+ }
214
+
215
+ &.disabled {
216
+ opacity: 0.5;
217
+ cursor: not-allowed;
218
+ user-select: none;
219
+ pointer-events: none;
220
+ }
221
+ }
222
+
223
+ &__icon {
224
+ color: var(--text-color-primary);
225
+ transition: color 0.2s ease;
226
+ }
227
+ }
228
+ </style>
229
+
230
+ <style>
231
+ .group-call-dialog {
232
+ background: white;
233
+ border-radius: 8px;
234
+ max-width: 500px;
235
+ max-height: 70vh;
236
+ display: flex;
237
+ flex-direction: column;
238
+ box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
239
+ }
240
+ </style>
@@ -0,0 +1,3 @@
1
+ import AudioCallPicker from './AudioCallPicker.vue';
2
+
3
+ export { AudioCallPicker };
@@ -1,12 +1,32 @@
1
1
  <template>
2
2
  <div>
3
- <PopoverRoot>
4
- <PopoverTrigger as="span" :style="triggerStyle" :class="[props.disabled && 'disabled']">
5
- <IconEmoji :class="styles['emoji-picker__icon']" size="24" />
3
+ <PopoverRoot :open="isOpen" @update:open="handleOpenChange">
4
+ <PopoverTrigger
5
+ as="div"
6
+ :disabled="props.disabled"
7
+ >
8
+ <div
9
+ data-test="test"
10
+ :class="cs(
11
+ styles['emoji-picker__button'],
12
+ {
13
+ [styles['disabled']]: props.disabled,
14
+ }
15
+ )"
16
+ v-bind="$attrs"
17
+ >
18
+ <slot>
19
+ <IconEmoji :class="styles['emoji-picker__icon']" :size="props.iconSize" />
20
+ </slot>
21
+ </div>
6
22
  </PopoverTrigger>
7
23
  <PopoverPortal>
8
- <PopoverContent side="top" align="start" :side-offset="5">
9
- <div class="flex flex-col gap-2.5">
24
+ <PopoverContent
25
+ side="top"
26
+ align="start"
27
+ :side-offset="5"
28
+ >
29
+ <div>
10
30
  <div :class="styles['emoji-picker__list']">
11
31
  <div
12
32
  v-for="emojiKey in Object.keys(emojiUrlMap)"
@@ -18,7 +38,7 @@
18
38
  :class="styles['emoji-picker__list-item']"
19
39
  :src="emojiBaseUrl + emojiUrlMap[emojiKey]"
20
40
  :alt="t(`Emoji.${emojiKey}`)"
21
- />
41
+ >
22
42
  </div>
23
43
  </div>
24
44
  </div>
@@ -29,29 +49,52 @@
29
49
  </template>
30
50
 
31
51
  <script setup lang="ts">
32
- import { onMounted, defineProps } from 'vue';
52
+ import { onMounted, defineProps, useCssModule, ref } from 'vue';
33
53
  import { useUIKit, IconEmoji } from '@tencentcloud/uikit-base-component-vue3';
54
+ import cs from 'classnames';
34
55
  import { PopoverContent, PopoverPortal, PopoverRoot, PopoverTrigger } from 'reka-ui';
35
56
  import { emojiUrlMap, emojiBaseUrl } from '../../../constants/emoji';
36
- import { transformTextWithEmojiKeyToName } from '../../../utils/emoji';
37
57
  import { useMessageInputState, MessageContentType } from '../../../states/MessageInputState';
38
- import styles from './EmojiPicker.module.scss';
58
+ import { transformTextWithEmojiKeyToName } from '../../../utils/emoji';
39
59
 
40
- const props = defineProps<{
41
- triggerStyle?: Record<string, any>;
60
+ defineOptions({
61
+ name: 'EmojiPicker',
62
+ inheritAttrs: false,
63
+ });
64
+
65
+ interface EmojiPickerProps {
66
+ label?: string;
67
+ iconSize?: number;
42
68
  disabled?: boolean;
43
- }>();
69
+ }
70
+
71
+ const props = withDefaults(defineProps<EmojiPickerProps>(), {
72
+ label: '',
73
+ iconSize: 20,
74
+ disabled: false,
75
+ });
76
+
77
+ const isOpen = ref(false);
78
+
79
+ const styles = useCssModule();
44
80
  const { t } = useUIKit();
45
81
  const { insertContent } = useMessageInputState();
46
82
 
47
83
  // Image preload
48
84
  onMounted(() => {
49
- Object.values(emojiUrlMap).forEach(url => {
85
+ Object.values(emojiUrlMap).forEach((url) => {
50
86
  const img = new Image();
51
87
  img.src = emojiBaseUrl + url;
52
88
  });
53
89
  });
54
90
 
91
+ const handleOpenChange = (open: boolean) => {
92
+ // only allow to change the state when the component is not disabled
93
+ if (!props.disabled) {
94
+ isOpen.value = open;
95
+ }
96
+ };
97
+
55
98
  function insertEmojiToInput(emojiKey: string) {
56
99
  if (emojiKey) {
57
100
  insertContent([
@@ -68,10 +111,56 @@ function insertEmojiToInput(emojiKey: string) {
68
111
  }
69
112
  </script>
70
113
 
71
- <style lang="scss" scoped>
72
- .disabled {
73
- cursor: not-allowed;
74
- user-select: none;
75
- pointer-events: none;
114
+ <style lang="scss" module>
115
+ .emoji-picker {
116
+ &__button {
117
+ display: flex;
118
+ align-items: center;
119
+ justify-content: center;
120
+ cursor: pointer;
121
+ padding: 4px 6px;
122
+ transition: background-color 0.5s ease;
123
+ border-radius: 4px;
124
+
125
+ &:hover {
126
+ background-color: var(--button-color-secondary-hover);
127
+ }
128
+
129
+ &:active {
130
+ background-color: var(--button-color-secondary-active);
131
+ }
132
+
133
+ &.disabled {
134
+ opacity: 0.5;
135
+ cursor: not-allowed;
136
+ user-select: none;
137
+ pointer-events: none;
138
+ }
139
+ }
140
+
141
+ &__icon {
142
+ color: var(--text-color-primary);
143
+ }
144
+
145
+ &__list {
146
+ display: flex;
147
+ flex-flow: row wrap;
148
+ gap: 8px;
149
+ width: 310px;
150
+ border-radius: 16px;
151
+ padding: 16px;
152
+ margin-bottom: 10px;
153
+ background-color: var(--dropdown-color-default);
154
+ box-shadow: 0 0 10px 0 var(--shadow-color);
155
+
156
+ &-item {
157
+ display: flex;
158
+ align-items: center;
159
+ justify-content: center;
160
+ width: 20px;
161
+ height: 20px;
162
+ cursor: pointer;
163
+ }
164
+ }
76
165
  }
77
166
  </style>
@@ -13,7 +13,7 @@
13
13
  flex-direction: row;
14
14
  align-items: center;
15
15
  color: var(--text-color-secondary);
16
- gap: 8px;
16
+ gap: 2px;
17
17
  }
18
18
 
19
19
  &__wrapper {