@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,
69 lines (68 loc) • 2.82 kB
JavaScript
Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
const Vue = require("vue");
const IconButton = require("../common/base/IconButton.vue.js");
const uikitBaseComponentVue3 = require("@tencentcloud/uikit-base-component-vue3");
const basic = require("../../stores/basic.js");
const chat = require("../../stores/chat.js");
const pinia = require("pinia");
const index = require("../../locales/index.js");
const Badge = require("../common/base/Badge.vue.js");
require("../../services/main.js");
const roomService = require("../../services/roomService.js");
require("@tencentcloud/tuiroom-engine-js");
require("../../utils/environment.js");
require("mitt");
require("../../services/manager/roomActionManager.js");
require("@tencentcloud/tui-core");
const dataReportManager = require("../../services/manager/dataReportManager.js");
const _hoisted_1 = {
key: 0,
class: "chat-control-container"
};
const _sfc_main = /* @__PURE__ */ Vue.defineComponent({
__name: "ChatControl",
setup(__props) {
const { t } = index.useI18n();
const chatControlConfig = roomService.roomService.getComponentConfig("ChatControl");
const basicStore = basic.useBasicStore();
const chatStore = chat.useChatStore();
const { sidebarName } = pinia.storeToRefs(basicStore);
async function toggleChatSidebar() {
if (basicStore.isSidebarOpen && basicStore.sidebarName === "chat") {
basicStore.setSidebarOpenStatus(false);
basicStore.setSidebarName("");
return;
}
basicStore.setSidebarOpenStatus(true);
basicStore.setSidebarName("chat");
chatStore.updateUnReadCount(0);
roomService.roomService.dataReportManager.reportCount(dataReportManager.MetricsKey.openChat);
roomService.roomService.trackingManager.sendMessage("experience-chat");
}
return (_ctx, _cache) => {
return Vue.unref(chatControlConfig).visible ? (Vue.openBlock(), Vue.createElementBlock("div", _hoisted_1, [
Vue.createVNode(Badge.default, {
hidden: Vue.unref(chatStore).unReadCount === 0,
value: Vue.unref(chatStore).unReadCount,
max: 10
}, {
default: Vue.withCtx(() => [
Vue.createVNode(IconButton.default, {
title: Vue.unref(t)("Chat"),
"is-active": Vue.unref(sidebarName) === "chat",
onClickIcon: toggleChatSidebar
}, {
default: Vue.withCtx(() => [
Vue.createVNode(Vue.unref(uikitBaseComponentVue3.IconChat), { size: "24" })
]),
_: 1
}, 8, ["title", "is-active"])
]),
_: 1
}, 8, ["hidden", "value"])
])) : Vue.createCommentVNode("", true);
};
}
});
exports.default = _sfc_main;
;