UNPKG

@tencentcloud/roomkit-electron-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,

239 lines (238 loc) 10.2 kB
"use strict"; Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } }); const Vue = require("vue"); const pinia = require("pinia"); const index = require("./MemberItem/index.vue.js"); const SvgIcon = require("../common/base/SvgIcon.vue.js"); const SearchIcon = require("../common/icons/SearchIcon.vue.js"); const ApplyTipsIcon = require("../common/icons/ApplyTipsIcon.vue.js"); const index$1 = require("../common/base/Dialog/index.vue.js"); const room = require("../../stores/room.js"); const useIndexHooks = require("./useIndexHooks.js"); const Button = require("../common/base/Button.vue.js"); const ArrowUpIcon = require("../common/icons/ArrowUpIcon.vue.js"); const vClickOutside = require("../../directives/vClickOutside.js"); const room$1 = require("../../constants/room.js"); const _hoisted_1 = { class: "manage-member-container" }; const _hoisted_2 = { class: "manage-member-header" }; const _hoisted_3 = { class: "search-container" }; const _hoisted_4 = ["placeholder"]; const _hoisted_5 = { class: "apply-count" }; const _hoisted_6 = { class: "user-status" }; const _hoisted_7 = ["onClick"]; const _hoisted_8 = { class: "apply-staged" }; const _hoisted_9 = { key: 0, class: "apply-on-stage-info" }; const _hoisted_10 = { class: "apply-info" }; const _hoisted_11 = { id: "memberListContainer", class: "member-list-container" }; const _hoisted_12 = { key: 1, class: "global-setting" }; const _hoisted_13 = { class: "more-container" }; const _hoisted_14 = { class: "drop-down" }; const _hoisted_15 = ["onClick"]; const _hoisted_16 = { class: "operate-text" }; const _hoisted_17 = { key: 2, class: "global-setting" }; const _sfc_main = /* @__PURE__ */ Vue.defineComponent({ __name: "index", setup(__props) { const roomStore = room.useRoomStore(); const { applyToAnchorList, isGeneralUser } = pinia.storeToRefs(roomStore); const { t, searchText, showApplyUserList, showManageAllUserDialog, dialogTitle, dialogContent, toggleManageAllMember, doToggleManageAllMember, ManageControlType, handleToggleStaged, applyToAnchorUserContent, audioManageInfo, videoManageInfo, toggleClickMoreBtn, showMoreControl, moreControlList, userStatusList, currentActiveTabName, filteredUserStatusList, handleCallAllInvitee } = useIndexHooks.default(); const handleShowMoreControl = () => { if (showMoreControl.value) { showMoreControl.value = false; } }; return (_ctx, _cache) => { return Vue.openBlock(), Vue.createElementBlock("div", _hoisted_1, [ Vue.createElementVNode("div", _hoisted_2, [ Vue.createElementVNode("div", _hoisted_3, [ Vue.createVNode(SvgIcon.default, { icon: SearchIcon.default }), Vue.withDirectives(Vue.createElementVNode("input", { "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => Vue.isRef(searchText) ? searchText.value = $event : null), class: "search-input", placeholder: Vue.unref(t)("Search Member") }, null, 8, _hoisted_4), [ [Vue.vModelText, Vue.unref(searchText)] ]) ]) ]), Vue.createElementVNode("div", _hoisted_5, [ Vue.createElementVNode("div", _hoisted_6, [ (Vue.openBlock(true), Vue.createElementBlock(Vue.Fragment, null, Vue.renderList(Vue.unref(userStatusList), (item, index2) => { return Vue.openBlock(), Vue.createElementBlock("div", { class: Vue.normalizeClass([ "user-status-container", { "apply-count-active": item.status === Vue.unref(currentActiveTabName) } ]), key: index2, onClick: ($event) => Vue.unref(handleToggleStaged)(item) }, [ Vue.createElementVNode("span", _hoisted_8, Vue.toDisplayString(item.title), 1) ], 10, _hoisted_7); }), 128)) ]) ]), Vue.unref(applyToAnchorList).length > 0 && !Vue.unref(isGeneralUser) ? (Vue.openBlock(), Vue.createElementBlock("div", _hoisted_9, [ Vue.createVNode(SvgIcon.default, { icon: ApplyTipsIcon.default, class: "apply-icon" }), Vue.createElementVNode("div", _hoisted_10, Vue.toDisplayString(Vue.unref(applyToAnchorUserContent)), 1), Vue.createElementVNode("div", { class: "apply-check", onClick: _cache[1] || (_cache[1] = //@ts-ignore (...args) => Vue.unref(showApplyUserList) && Vue.unref(showApplyUserList)(...args)) }, Vue.toDisplayString(Vue.unref(t)("Check")), 1) ])) : Vue.createCommentVNode("", true), Vue.createElementVNode("div", _hoisted_11, [ (Vue.openBlock(true), Vue.createElementBlock(Vue.Fragment, null, Vue.renderList(Vue.unref(filteredUserStatusList), (userInfo) => { return Vue.openBlock(), Vue.createBlock(index.default, { key: userInfo.userId, "user-info": userInfo }, null, 8, ["user-info"]); }), 128)) ]), !Vue.unref(isGeneralUser) && Vue.unref(currentActiveTabName) !== Vue.unref(room$1.USERS_STATUS).NOT_ENTER ? (Vue.openBlock(), Vue.createElementBlock("div", _hoisted_12, [ Vue.createVNode(Button.default, { class: "button", size: "default", onClick: _cache[2] || (_cache[2] = ($event) => Vue.unref(toggleManageAllMember)(Vue.unref(ManageControlType).AUDIO)) }, { default: Vue.withCtx(() => [ Vue.createTextVNode(Vue.toDisplayString(Vue.unref(audioManageInfo)), 1) ]), _: 1 }), Vue.createVNode(Button.default, { class: "button", size: "default", onClick: _cache[3] || (_cache[3] = ($event) => Vue.unref(toggleManageAllMember)(Vue.unref(ManageControlType).VIDEO)) }, { default: Vue.withCtx(() => [ Vue.createTextVNode(Vue.toDisplayString(Vue.unref(videoManageInfo)), 1) ]), _: 1 }), Vue.withDirectives((Vue.openBlock(), Vue.createElementBlock("div", _hoisted_13, [ Vue.createVNode(Button.default, { class: "button", size: "default", onClick: Vue.unref(toggleClickMoreBtn) }, { default: Vue.withCtx(() => [ Vue.createTextVNode(Vue.toDisplayString(Vue.unref(t)("More")) + " ", 1), Vue.createVNode(SvgIcon.default, { size: "12", class: Vue.normalizeClass(["more-arrow", Vue.unref(showMoreControl) ? "up" : "down"]), icon: ArrowUpIcon.default }, null, 8, ["class"]) ]), _: 1 }, 8, ["onClick"]), Vue.withDirectives(Vue.createElementVNode("div", _hoisted_14, [ (Vue.openBlock(true), Vue.createElementBlock(Vue.Fragment, null, Vue.renderList(Vue.unref(moreControlList), (item) => { return Vue.openBlock(), Vue.createElementBlock("div", { key: item.type, class: "user-operate-item", onClick: ($event) => item.func(item.type) }, [ Vue.createVNode(SvgIcon.default, { icon: item.icon }, null, 8, ["icon"]), Vue.createElementVNode("span", _hoisted_16, Vue.toDisplayString(item.title), 1) ], 8, _hoisted_15); }), 128)) ], 512), [ [Vue.vShow, Vue.unref(showMoreControl)] ]) ])), [ [Vue.unref(vClickOutside.default), handleShowMoreControl] ]) ])) : Vue.createCommentVNode("", true), Vue.unref(currentActiveTabName) === Vue.unref(room$1.USERS_STATUS).NOT_ENTER ? (Vue.openBlock(), Vue.createElementBlock("div", _hoisted_17, [ Vue.unref(filteredUserStatusList).length > 0 ? (Vue.openBlock(), Vue.createBlock(Button.default, { key: 0, class: "button-bottom", size: "default", onClick: Vue.unref(handleCallAllInvitee) }, { default: Vue.withCtx(() => [ Vue.createTextVNode(Vue.toDisplayString(Vue.unref(t)("Call all")), 1) ]), _: 1 }, 8, ["onClick"])) : Vue.createCommentVNode("", true) ])) : Vue.createCommentVNode("", true), Vue.createVNode(index$1.default, { modelValue: Vue.unref(showManageAllUserDialog), "onUpdate:modelValue": _cache[5] || (_cache[5] = ($event) => Vue.isRef(showManageAllUserDialog) ? showManageAllUserDialog.value = $event : null), title: Vue.unref(dialogTitle), width: "480px", modal: true, "append-to-room-container": true }, { footer: Vue.withCtx(() => [ Vue.createVNode(Button.default, { size: "default", onClick: Vue.unref(doToggleManageAllMember) }, { default: Vue.withCtx(() => [ Vue.createTextVNode(Vue.toDisplayString(Vue.unref(t)("Confirm")), 1) ]), _: 1 }, 8, ["onClick"]), Vue.createVNode(Button.default, { class: "cancel-button", size: "default", type: "primary", onClick: _cache[4] || (_cache[4] = ($event) => showManageAllUserDialog.value = false) }, { default: Vue.withCtx(() => [ Vue.createTextVNode(Vue.toDisplayString(Vue.unref(t)("Cancel")), 1) ]), _: 1 }) ]), default: Vue.withCtx(() => [ Vue.createElementVNode("span", null, Vue.toDisplayString(Vue.unref(dialogContent)), 1) ]), _: 1 }, 8, ["modelValue", "title"]) ]); }; } }); exports.default = _sfc_main;