@tencentcloud/roomkit-web-vue3
Version:
<h1 align="center"> TUIRoomKit</h1> Conference (TUIRoomKit) is a product suitable for multi-person audio and video conversation scenarios such as business meetings, webinars, and online education. By integrating this product, you can add room management,
101 lines (100 loc) • 4.27 kB
JavaScript
import { defineComponent, ref, computed, createElementBlock, openBlock, createVNode, createBlock, createCommentVNode, withDirectives, unref, vShow } from "vue";
import UserInfoComp from "./UserInfo/index.vue2.mjs";
import UserInvite from "./UserInvite/index.vue2.mjs";
import UserAction from "./UserAction/index.mjs";
import "../../../components/common/base/IconButton.vue2.mjs";
/* empty css */
import "@tencentcloud/uikit-base-component-vue3";
import "../../../stores/room.mjs";
import "pinia";
import "../../../utils/environment.mjs";
/* empty css */
import "../../../hooks/useZIndex.mjs";
import "../../../services/main.mjs";
import "../../../services/roomService.mjs";
import "../../../locales/index.mjs";
import "@tencentcloud/tuiroom-engine-js";
import "mitt";
import "../../../services/manager/roomActionManager.mjs";
import "@tencentcloud/tui-core";
/* empty css */
/* empty css */
/* empty css */
/* empty css */
/* empty css */
import "../../hooks/useAudioDeviceState/index.mjs";
/* empty css */
/* empty css */
/* empty css */
import "../../../stores/basic.mjs";
/* empty css */
/* empty css */
/* empty css */
import "../../../hooks/useRoomEngine.mjs";
import "../../hooks/useVideoDeviceState/index.mjs";
/* empty css */
/* empty css */
import useUserState from "../../hooks/useUserState/index.mjs";
/* empty css */
import "../../hooks/useFreeBeautyState/index.mjs";
/* empty css */
/* empty css */
/* empty css */
/* empty css */
/* empty css */
/* empty css */
/* empty css */
/* empty css */
/* empty css */
/* empty css */
/* empty css */
/* empty css */
/* empty css */
/* empty css */
/* empty css */
/* empty css */
const _sfc_main = /* @__PURE__ */ defineComponent({
__name: "indexPC",
props: {
userInfo: {}
},
setup(__props) {
const props = __props;
const isMouseHover = ref(false);
function handleMouseEnter() {
isMouseHover.value = true;
}
function handleMouseLeave() {
isMouseHover.value = false;
}
const { useUserActions } = useUserState();
const userActions = useUserActions({ userInfo: props.userInfo });
const showUserAction = computed(
() => isMouseHover.value && props.userInfo.isInRoom && (userActions == null ? void 0 : userActions.length) > 0
);
return (_ctx, _cache) => {
return openBlock(), createElementBlock("div", {
class: "member-item-container",
onMouseenter: handleMouseEnter,
onMouseleave: handleMouseLeave
}, [
createVNode(UserInfoComp, {
"user-info": props.userInfo,
"show-state-icon": props.userInfo.isInRoom && !showUserAction.value
}, null, 8, ["user-info", "show-state-icon"]),
!_ctx.userInfo.isInRoom ? (openBlock(), createBlock(UserInvite, {
key: 0,
"user-info": props.userInfo
}, null, 8, ["user-info"])) : createCommentVNode("", true),
withDirectives(createVNode(unref(UserAction), {
"user-info": props.userInfo
}, null, 8, ["user-info"]), [
[vShow, showUserAction.value]
])
], 32);
};
}
});
export {
_sfc_main as default
};