@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,
42 lines (41 loc) • 1.82 kB
JavaScript
;
Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
const Vue = require("vue");
const MemberInfo = require("../MemberItemCommon/MemberInfo.vue.js");
const index = require("../MemberControl/index.js");
const useMemberItemHooks = require("./useMemberItemHooks.js");
const _sfc_main = /* @__PURE__ */ Vue.defineComponent({
__name: "indexPC",
props: {
userInfo: {}
},
setup(__props) {
const props = __props;
const { isMemberControlAccessible, openMemberControl, closeMemberControl } = useMemberItemHooks.default(props.userInfo);
const showMemberControl = Vue.ref(false);
Vue.watch(isMemberControlAccessible, (accessible) => {
showMemberControl.value = accessible;
});
return (_ctx, _cache) => {
return Vue.openBlock(), Vue.createElementBlock("div", {
class: "member-item-container",
onMouseenter: _cache[0] || (_cache[0] = //@ts-ignore
(...args) => Vue.unref(openMemberControl) && Vue.unref(openMemberControl)(...args)),
onMouseleave: _cache[1] || (_cache[1] = //@ts-ignore
(...args) => Vue.unref(closeMemberControl) && Vue.unref(closeMemberControl)(...args))
}, [
Vue.createVNode(MemberInfo.default, {
"user-info": props.userInfo,
"show-state-icon": props.userInfo.isInRoom && !showMemberControl.value
}, null, 8, ["user-info", "show-state-icon"]),
Vue.withDirectives(Vue.createVNode(Vue.unref(index.default), {
"show-member-control": showMemberControl.value,
"user-info": props.userInfo
}, null, 8, ["show-member-control", "user-info"]), [
[Vue.vShow, showMemberControl.value && props.userInfo.isInRoom]
])
], 32);
};
}
});
exports.default = _sfc_main;