@ndscnj/roomkit-web-vue3 25.11.1916 → 25.12.2316
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.
- package/.vscode/settings.json +2 -0
- package/es/assets/imgs/black-logo.png.mjs +1 -1
- package/es/assets/imgs/white-logo.png.mjs +1 -1
- package/es/components/RoomFooter/index/indexPC.vue.mjs +1 -1
- package/es/components/RoomFooter/index/indexPC.vue2.mjs +8 -3
- package/es/components/RoomFooter/voteControl.vue.d.ts +15 -0
- package/es/components/RoomFooter/voteControl.vue.mjs +7 -0
- package/es/components/RoomFooter/voteControl.vue2.mjs +60 -0
- package/es/components/RoomInvite/useRoomInviteHooks.d.ts +1 -1
- package/es/components/RoomSidebar/indexPC.vue.mjs +6 -4
- package/es/components/RoomSidebar/useSideBarHooks.d.ts +1 -1
- package/es/components/RoomSidebar/useSideBarHooks.mjs +3 -0
- package/es/components/RoomVote/index.d.ts +6 -0
- package/es/components/RoomVote/useRoomMoreHooks.d.ts +13 -0
- package/es/conference.vue.d.ts +2 -0
- package/es/conference.vue.mjs +1 -1
- package/es/conference.vue2.mjs +7 -2
- package/es/index.mjs +31 -13
- package/es/locales/en-US.d.ts +1 -0
- package/es/locales/en-US.mjs +1 -0
- package/es/locales/zh-CN.d.ts +1 -0
- package/es/locales/zh-CN.mjs +1 -0
- package/es/stores/basic.d.ts +1 -1
- package/lib/assets/imgs/black-logo.png.js +1 -1
- package/lib/assets/imgs/white-logo.png.js +1 -1
- package/lib/components/RoomFooter/index/indexPC.vue.js +1 -1
- package/lib/components/RoomFooter/index/indexPC.vue2.js +8 -3
- package/lib/components/RoomFooter/voteControl.vue.d.ts +15 -0
- package/lib/components/RoomFooter/voteControl.vue.js +7 -0
- package/lib/components/RoomFooter/voteControl.vue2.js +60 -0
- package/lib/components/RoomInvite/useRoomInviteHooks.d.ts +1 -1
- package/lib/components/RoomSidebar/indexPC.vue.js +5 -3
- package/lib/components/RoomSidebar/useSideBarHooks.d.ts +1 -1
- package/lib/components/RoomSidebar/useSideBarHooks.js +3 -0
- package/lib/components/RoomVote/index.d.ts +6 -0
- package/lib/components/RoomVote/useRoomMoreHooks.d.ts +13 -0
- package/lib/conference.vue.d.ts +2 -0
- package/lib/conference.vue.js +1 -1
- package/lib/conference.vue2.js +7 -2
- package/lib/index.js +31 -13
- package/lib/locales/en-US.d.ts +1 -0
- package/lib/locales/en-US.js +1 -0
- package/lib/locales/zh-CN.d.ts +1 -0
- package/lib/locales/zh-CN.js +1 -0
- package/lib/stores/basic.d.ts +1 -1
- package/package.json +1 -1
- package/src/TUIRoom/assets/imgs/black-logo.png +0 -0
- package/src/TUIRoom/assets/imgs/white-logo.png +0 -0
- package/src/TUIRoom/components/RoomFooter/index/indexPC.vue +5 -1
- package/src/TUIRoom/components/RoomFooter/voteControl.vue +65 -0
- package/src/TUIRoom/components/RoomSidebar/indexPC.vue +1 -0
- package/src/TUIRoom/components/RoomSidebar/useSideBarHooks.ts +3 -0
- package/src/TUIRoom/components/RoomVote/index.ts +7 -0
- package/src/TUIRoom/components/RoomVote/indexH5.vue +141 -0
- package/src/TUIRoom/components/RoomVote/indexPC.vue +106 -0
- package/src/TUIRoom/components/RoomVote/useRoomMoreHooks.ts +47 -0
- package/src/TUIRoom/conference.vue +5 -0
- package/src/TUIRoom/locales/en-US.ts +1 -0
- package/src/TUIRoom/locales/zh-CN.ts +1 -0
- package/src/TUIRoom/stores/basic.ts +1 -0
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
|
|
3
|
-
const _imports_1 = "";
|
|
3
|
+
const _imports_1 = "";
|
|
4
4
|
exports.default = _imports_1;
|
|
@@ -3,5 +3,5 @@ Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toString
|
|
|
3
3
|
const indexPC_vue_vue_type_script_setup_true_lang = require("./indexPC.vue2.js");
|
|
4
4
|
;/* empty css */
|
|
5
5
|
const _pluginVue_exportHelper = require("../../../_virtual/_plugin-vue_export-helper.js");
|
|
6
|
-
const indexPc = /* @__PURE__ */ _pluginVue_exportHelper.default(indexPC_vue_vue_type_script_setup_true_lang.default, [["__scopeId", "data-v-
|
|
6
|
+
const indexPc = /* @__PURE__ */ _pluginVue_exportHelper.default(indexPC_vue_vue_type_script_setup_true_lang.default, [["__scopeId", "data-v-28ae2921"]]);
|
|
7
7
|
exports.default = indexPc;
|
|
@@ -67,6 +67,7 @@ const VirtualBackground = require("../VirtualBackground.vue.js");
|
|
|
67
67
|
const AIControl = require("../AIControl.vue.js");
|
|
68
68
|
const BasicBeauty = require("../BasicBeauty.vue.js");
|
|
69
69
|
const useMitt = require("../../../hooks/useMitt.js");
|
|
70
|
+
const voteControl = require("../voteControl.vue.js");
|
|
70
71
|
const useRoomFooterHooks = require("./useRoomFooterHooks.js");
|
|
71
72
|
const _hoisted_1 = { class: "footer-container" };
|
|
72
73
|
const _hoisted_2 = { class: "left-container" };
|
|
@@ -132,17 +133,21 @@ const _sfc_main = /* @__PURE__ */ Vue.defineComponent({
|
|
|
132
133
|
class: "center-container-item",
|
|
133
134
|
onClick: _cache[9] || (_cache[9] = ($event) => handleControlClick("MasterApplyControl"))
|
|
134
135
|
})) : Vue.createCommentVNode("", true),
|
|
136
|
+
Vue.createVNode(voteControl.default, {
|
|
137
|
+
class: "center-container-item",
|
|
138
|
+
onClick: _cache[10] || (_cache[10] = ($event) => handleControlClick("voteControl"))
|
|
139
|
+
}),
|
|
135
140
|
Vue.createVNode(Vue.unref(index$1.default), {
|
|
136
141
|
class: "center-container-item",
|
|
137
|
-
onClick: _cache[
|
|
142
|
+
onClick: _cache[11] || (_cache[11] = ($event) => handleControlClick("moreControl"))
|
|
138
143
|
}),
|
|
139
144
|
Vue.createVNode(AIControl.default, {
|
|
140
145
|
class: "center-container-item",
|
|
141
|
-
onClick: _cache[
|
|
146
|
+
onClick: _cache[12] || (_cache[12] = ($event) => handleControlClick("AIControl"))
|
|
142
147
|
}),
|
|
143
148
|
Vue.createVNode(SettingControl_vue_vue_type_script_setup_true_lang.default, {
|
|
144
149
|
class: "center-container-item",
|
|
145
|
-
onClick: _cache[
|
|
150
|
+
onClick: _cache[13] || (_cache[13] = ($event) => handleControlClick("settingControl"))
|
|
146
151
|
}),
|
|
147
152
|
Vue.createVNode(VirtualBackground.default, { class: "center-container-item" }),
|
|
148
153
|
!Vue.unref(environment.isElectron) ? (Vue.openBlock(), Vue.createBlock(BasicBeauty.default, {
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
declare function __VLS_template(): {
|
|
2
|
+
default?(_: {}): any;
|
|
3
|
+
};
|
|
4
|
+
declare const __VLS_component: import('vue').DefineComponent<{}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {
|
|
5
|
+
"on-vote": (...args: any[]) => void;
|
|
6
|
+
}, string, import('vue').PublicProps, Readonly<{}> & Readonly<{
|
|
7
|
+
"onOn-vote"?: ((...args: any[]) => any) | undefined;
|
|
8
|
+
}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any>;
|
|
9
|
+
declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, ReturnType<typeof __VLS_template>>;
|
|
10
|
+
export default _default;
|
|
11
|
+
type __VLS_WithTemplateSlots<T, S> = T & {
|
|
12
|
+
new (): {
|
|
13
|
+
$slots: S;
|
|
14
|
+
};
|
|
15
|
+
};
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
|
|
3
|
+
const voteControl_vue_vue_type_script_setup_true_lang = require("./voteControl.vue2.js");
|
|
4
|
+
;/* empty css */
|
|
5
|
+
const _pluginVue_exportHelper = require("../../_virtual/_plugin-vue_export-helper.js");
|
|
6
|
+
const voteControl = /* @__PURE__ */ _pluginVue_exportHelper.default(voteControl_vue_vue_type_script_setup_true_lang.default, [["__scopeId", "data-v-7493ac70"]]);
|
|
7
|
+
exports.default = voteControl;
|
|
@@ -0,0 +1,60 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
|
|
3
|
+
const Vue = require("vue");
|
|
4
|
+
require("../../services/main.js");
|
|
5
|
+
const roomService = require("../../services/roomService.js");
|
|
6
|
+
const index = require("../../locales/index.js");
|
|
7
|
+
require("@tencentcloud/tuiroom-engine-js");
|
|
8
|
+
require("../../utils/environment.js");
|
|
9
|
+
require("mitt");
|
|
10
|
+
require("../../services/manager/roomActionManager.js");
|
|
11
|
+
require("@tencentcloud/tui-core");
|
|
12
|
+
const _hoisted_1 = { class: "more-container" };
|
|
13
|
+
const _hoisted_2 = {
|
|
14
|
+
key: 0,
|
|
15
|
+
class: "tool-box"
|
|
16
|
+
};
|
|
17
|
+
const _sfc_main = /* @__PURE__ */ Vue.defineComponent({
|
|
18
|
+
__name: "voteControl",
|
|
19
|
+
emits: ["on-vote"],
|
|
20
|
+
setup(__props, { emit: __emit }) {
|
|
21
|
+
const { basicStore } = roomService.roomService;
|
|
22
|
+
const isSidebarOpen = Vue.computed(() => basicStore.isSidebarOpen);
|
|
23
|
+
const sidebarName = Vue.computed(() => basicStore.sidebarName);
|
|
24
|
+
const { t } = index.useI18n();
|
|
25
|
+
const showToolBox = Vue.ref(false);
|
|
26
|
+
Vue.watch(isSidebarOpen, (newValue) => {
|
|
27
|
+
showToolBox.value = newValue && false;
|
|
28
|
+
});
|
|
29
|
+
const emit = __emit;
|
|
30
|
+
function toggleToolBox() {
|
|
31
|
+
showToolBox.value = !showToolBox.value;
|
|
32
|
+
emit("on-vote", {
|
|
33
|
+
name: "onVote",
|
|
34
|
+
visible: showToolBox.value
|
|
35
|
+
});
|
|
36
|
+
}
|
|
37
|
+
return (_ctx, _cache) => {
|
|
38
|
+
const _component_IconAIIcon = Vue.resolveComponent("IconAIIcon");
|
|
39
|
+
const _component_icon_button = Vue.resolveComponent("icon-button");
|
|
40
|
+
return Vue.openBlock(), Vue.createElementBlock("div", _hoisted_1, [
|
|
41
|
+
Vue.createVNode(_component_icon_button, {
|
|
42
|
+
"is-active": sidebarName.value === "vote",
|
|
43
|
+
title: Vue.unref(t)("Vote"),
|
|
44
|
+
onClickIcon: toggleToolBox
|
|
45
|
+
}, {
|
|
46
|
+
default: Vue.withCtx(() => [
|
|
47
|
+
Vue.createVNode(_component_IconAIIcon, { size: "24" })
|
|
48
|
+
]),
|
|
49
|
+
_: 1
|
|
50
|
+
}, 8, ["is-active", "title"]),
|
|
51
|
+
_cache[1] || (_cache[1] = Vue.createTextVNode(" 测试 ", -1)),
|
|
52
|
+
!isSidebarOpen.value && showToolBox.value ? (Vue.openBlock(), Vue.createElementBlock("div", _hoisted_2, [
|
|
53
|
+
_cache[0] || (_cache[0] = Vue.createTextVNode(" 123 ", -1)),
|
|
54
|
+
Vue.renderSlot(_ctx.$slots, "default", {}, void 0, true)
|
|
55
|
+
])) : Vue.createCommentVNode("", true)
|
|
56
|
+
]);
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
});
|
|
60
|
+
exports.default = _sfc_main;
|
|
@@ -76,5 +76,5 @@ export default function useRoomInvite(): {
|
|
|
76
76
|
isVisible: boolean;
|
|
77
77
|
}[]>;
|
|
78
78
|
copyRoomIdAndRoomLink: () => void;
|
|
79
|
-
sidebarName: import('vue').Ref<"" | "chat" | "invite" | "manage-member" | "more" | "transfer-leave" | "apply" | "aiTranscription", "" | "chat" | "invite" | "manage-member" | "more" | "transfer-leave" | "apply" | "aiTranscription">;
|
|
79
|
+
sidebarName: import('vue').Ref<"" | "chat" | "invite" | "manage-member" | "more" | "transfer-leave" | "apply" | "aiTranscription" | "vote", "" | "chat" | "invite" | "manage-member" | "more" | "transfer-leave" | "apply" | "aiTranscription" | "vote">;
|
|
80
80
|
};
|
|
@@ -13,6 +13,7 @@ const _sfc_main = /* @__PURE__ */ Vue.defineComponent({
|
|
|
13
13
|
setup(__props) {
|
|
14
14
|
const { isSidebarOpen, title, handleClose, sidebarName } = useSideBarHooks.default();
|
|
15
15
|
return (_ctx, _cache) => {
|
|
16
|
+
const _component_room_vote = Vue.resolveComponent("room-vote");
|
|
16
17
|
return Vue.openBlock(), Vue.createElementBlock("div", _hoisted_1, [
|
|
17
18
|
Vue.createVNode(Drawer.default, {
|
|
18
19
|
modelValue: Vue.unref(isSidebarOpen),
|
|
@@ -24,9 +25,10 @@ const _sfc_main = /* @__PURE__ */ Vue.defineComponent({
|
|
|
24
25
|
}, {
|
|
25
26
|
default: Vue.withCtx(() => [
|
|
26
27
|
Vue.unref(sidebarName) == "chat" ? (Vue.openBlock(), Vue.createBlock(Vue.unref(index.default), { key: 0 })) : Vue.createCommentVNode("", true),
|
|
27
|
-
Vue.unref(sidebarName) == "
|
|
28
|
-
Vue.unref(sidebarName) == "
|
|
29
|
-
Vue.unref(sidebarName) == "
|
|
28
|
+
Vue.unref(sidebarName) == "vote" ? (Vue.openBlock(), Vue.createBlock(_component_room_vote, { key: 1 })) : Vue.createCommentVNode("", true),
|
|
29
|
+
Vue.unref(sidebarName) == "more" ? (Vue.openBlock(), Vue.createBlock(Vue.unref(index$1.default), { key: 2 })) : Vue.createCommentVNode("", true),
|
|
30
|
+
Vue.unref(sidebarName) == "manage-member" ? (Vue.openBlock(), Vue.createBlock(Vue.unref(index$2.default), { key: 3 })) : Vue.createCommentVNode("", true),
|
|
31
|
+
Vue.unref(sidebarName) == "aiTranscription" ? (Vue.openBlock(), Vue.createBlock(AITranscription.default, { key: 4 })) : Vue.createCommentVNode("", true)
|
|
30
32
|
]),
|
|
31
33
|
_: 1
|
|
32
34
|
}, 8, ["modelValue", "title", "before-close"])
|
|
@@ -2,7 +2,7 @@ export default function useSideBar(): {
|
|
|
2
2
|
t: any;
|
|
3
3
|
isSidebarOpen: import('vue').Ref<boolean, boolean>;
|
|
4
4
|
title: import('vue').ComputedRef<string>;
|
|
5
|
-
sidebarName: import('vue').Ref<"" | "chat" | "invite" | "manage-member" | "more" | "transfer-leave" | "apply" | "aiTranscription", "" | "chat" | "invite" | "manage-member" | "more" | "transfer-leave" | "apply" | "aiTranscription">;
|
|
5
|
+
sidebarName: import('vue').Ref<"" | "chat" | "invite" | "manage-member" | "more" | "transfer-leave" | "apply" | "aiTranscription" | "vote", "" | "chat" | "invite" | "manage-member" | "more" | "transfer-leave" | "apply" | "aiTranscription" | "vote">;
|
|
6
6
|
handleClose: (done: any) => void;
|
|
7
7
|
showSideBar: import('vue').ComputedRef<boolean>;
|
|
8
8
|
};
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
declare const Index: import('vue').DefineComponent<{}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {
|
|
2
|
+
"on-close-contact": (...args: any[]) => void;
|
|
3
|
+
}, string, import('vue').PublicProps, Readonly<{}> & Readonly<{
|
|
4
|
+
"onOn-close-contact"?: ((...args: any[]) => any) | undefined;
|
|
5
|
+
}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any> | import('vue').DefineComponent<{}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any>;
|
|
6
|
+
export default Index;
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
export default function useRoomMoreHooks(): {
|
|
2
|
+
t: any;
|
|
3
|
+
onCopy: (value: string | number) => Promise<void>;
|
|
4
|
+
contactContentList: {
|
|
5
|
+
id: number;
|
|
6
|
+
title: string;
|
|
7
|
+
content: string;
|
|
8
|
+
copyLink: string;
|
|
9
|
+
}[];
|
|
10
|
+
email: string;
|
|
11
|
+
handleClick: () => void;
|
|
12
|
+
isZH: import('vue').ComputedRef<boolean>;
|
|
13
|
+
};
|
package/lib/conference.vue.d.ts
CHANGED
|
@@ -27,6 +27,7 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
|
|
|
27
27
|
resetStore: typeof resetStore;
|
|
28
28
|
t: any;
|
|
29
29
|
}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {
|
|
30
|
+
"on-vote": (...args: any[]) => void;
|
|
30
31
|
"on-log-out": (...args: any[]) => void;
|
|
31
32
|
"on-create-room": (...args: any[]) => void;
|
|
32
33
|
"on-enter-room": (...args: any[]) => void;
|
|
@@ -40,6 +41,7 @@ declare const _default: import('vue').DefineComponent<import('vue').ExtractPropT
|
|
|
40
41
|
}>, {
|
|
41
42
|
displayMode: string;
|
|
42
43
|
}>>> & Readonly<{
|
|
44
|
+
"onOn-vote"?: ((...args: any[]) => any) | undefined;
|
|
43
45
|
"onOn-log-out"?: ((...args: any[]) => any) | undefined;
|
|
44
46
|
"onOn-create-room"?: ((...args: any[]) => any) | undefined;
|
|
45
47
|
"onOn-enter-room"?: ((...args: any[]) => any) | undefined;
|
package/lib/conference.vue.js
CHANGED
|
@@ -4,5 +4,5 @@ const conference_vue_vue_type_script_setup_true_lang = require("./conference.vue
|
|
|
4
4
|
;/* empty css */
|
|
5
5
|
;/* empty css */
|
|
6
6
|
const _pluginVue_exportHelper = require("./_virtual/_plugin-vue_export-helper.js");
|
|
7
|
-
const ConferenceMainView = /* @__PURE__ */ _pluginVue_exportHelper.default(conference_vue_vue_type_script_setup_true_lang.default, [["__scopeId", "data-v-
|
|
7
|
+
const ConferenceMainView = /* @__PURE__ */ _pluginVue_exportHelper.default(conference_vue_vue_type_script_setup_true_lang.default, [["__scopeId", "data-v-dc8a7460"]]);
|
|
8
8
|
exports.default = ConferenceMainView;
|
package/lib/conference.vue2.js
CHANGED
|
@@ -40,7 +40,8 @@ const _sfc_main = /* @__PURE__ */ Vue.defineComponent({
|
|
|
40
40
|
"on-destroy-room",
|
|
41
41
|
"on-kicked-out-of-room",
|
|
42
42
|
"on-kicked-off-line",
|
|
43
|
-
"on-userSig-expired"
|
|
43
|
+
"on-userSig-expired",
|
|
44
|
+
"on-vote"
|
|
44
45
|
],
|
|
45
46
|
setup(__props, { expose: __expose, emit: __emit }) {
|
|
46
47
|
const { theme } = uikitBaseComponentVue3.useUIKit();
|
|
@@ -217,6 +218,9 @@ const _sfc_main = /* @__PURE__ */ Vue.defineComponent({
|
|
|
217
218
|
function resetStore() {
|
|
218
219
|
roomService.roomService.resetStore();
|
|
219
220
|
}
|
|
221
|
+
const onVote = (data) => {
|
|
222
|
+
emit("on-vote", { code: data.visible, message: "vote" });
|
|
223
|
+
};
|
|
220
224
|
const onStartRoom = () => {
|
|
221
225
|
isShowLoading.value = false;
|
|
222
226
|
emit("on-create-room", { code: 0, message: "create room" });
|
|
@@ -269,7 +273,8 @@ const _sfc_main = /* @__PURE__ */ Vue.defineComponent({
|
|
|
269
273
|
]),
|
|
270
274
|
Vue.withDirectives(Vue.createVNode(Vue.unref(index$2.default), {
|
|
271
275
|
class: "footer",
|
|
272
|
-
onShowOverlay: handleShowOverlay
|
|
276
|
+
onShowOverlay: handleShowOverlay,
|
|
277
|
+
onOnVote: onVote
|
|
273
278
|
}, null, 512), [
|
|
274
279
|
[Vue.vShow, Vue.unref(showRoomTool)]
|
|
275
280
|
]),
|
package/lib/index.js
CHANGED
|
@@ -3928,7 +3928,25 @@ to {
|
|
|
3928
3928
|
}
|
|
3929
3929
|
.footer .mirror-container .mirror-text[data-v-21a63691] {
|
|
3930
3930
|
margin-left: 4px;
|
|
3931
|
-
}.
|
|
3931
|
+
}.more-container[data-v-7493ac70] {
|
|
3932
|
+
padding: 20px;
|
|
3933
|
+
}
|
|
3934
|
+
.more-container .more-title[data-v-7493ac70] {
|
|
3935
|
+
display: flex;
|
|
3936
|
+
align-items: center;
|
|
3937
|
+
}
|
|
3938
|
+
.more-container .more-title .email-icon[data-v-7493ac70] {
|
|
3939
|
+
color: var(--uikit-color-gray-7);
|
|
3940
|
+
}
|
|
3941
|
+
.more-container .more-title .more-notice[data-v-7493ac70] {
|
|
3942
|
+
width: 100%;
|
|
3943
|
+
height: 22px;
|
|
3944
|
+
padding-left: 8px;
|
|
3945
|
+
font-size: 14px;
|
|
3946
|
+
font-weight: 400;
|
|
3947
|
+
line-height: 22px;
|
|
3948
|
+
color: var(--text-color-primary);
|
|
3949
|
+
}.footer-container[data-v-28ae2921] {
|
|
3932
3950
|
position: absolute;
|
|
3933
3951
|
bottom: 0;
|
|
3934
3952
|
display: flex;
|
|
@@ -3942,25 +3960,25 @@ to {
|
|
|
3942
3960
|
background-color: var(--bg-color-topbar);
|
|
3943
3961
|
box-shadow: 0 -8px 30px var(--uikit-color-black-8);
|
|
3944
3962
|
}
|
|
3945
|
-
.footer-container .left-container[data-v-
|
|
3963
|
+
.footer-container .left-container[data-v-28ae2921] {
|
|
3946
3964
|
display: flex;
|
|
3947
3965
|
align-items: center;
|
|
3948
3966
|
height: 100%;
|
|
3949
3967
|
}
|
|
3950
|
-
.footer-container .left-container .left-container-item[data-v-
|
|
3968
|
+
.footer-container .left-container .left-container-item[data-v-28ae2921]:not(:first-child) {
|
|
3951
3969
|
margin-left: 1rem;
|
|
3952
3970
|
}
|
|
3953
|
-
.footer-container .center-container[data-v-
|
|
3971
|
+
.footer-container .center-container[data-v-28ae2921] {
|
|
3954
3972
|
position: relative;
|
|
3955
3973
|
display: flex;
|
|
3956
3974
|
align-items: center;
|
|
3957
3975
|
height: 100%;
|
|
3958
3976
|
margin: 0 auto;
|
|
3959
3977
|
}
|
|
3960
|
-
.footer-container .center-container .center-container-item[data-v-
|
|
3978
|
+
.footer-container .center-container .center-container-item[data-v-28ae2921]:not(:first-child) {
|
|
3961
3979
|
margin-left: 16px;
|
|
3962
3980
|
}
|
|
3963
|
-
.footer-container .right-container[data-v-
|
|
3981
|
+
.footer-container .right-container[data-v-28ae2921] {
|
|
3964
3982
|
display: flex;
|
|
3965
3983
|
align-items: center;
|
|
3966
3984
|
height: 100%;
|
|
@@ -8977,7 +8995,7 @@ body, html {
|
|
|
8977
8995
|
}
|
|
8978
8996
|
.tui-room :not([class|=el]) {
|
|
8979
8997
|
transition: background-color 0.3s, color 0.3s, box-shadow 0.3s;
|
|
8980
|
-
}.tui-room[data-v-
|
|
8998
|
+
}.tui-room[data-v-dc8a7460] {
|
|
8981
8999
|
position: relative;
|
|
8982
9000
|
display: flex;
|
|
8983
9001
|
flex-direction: column;
|
|
@@ -8989,7 +9007,7 @@ body, html {
|
|
|
8989
9007
|
text-align: left;
|
|
8990
9008
|
background-color: var(--bg-color-topbar);
|
|
8991
9009
|
}
|
|
8992
|
-
.tui-room .header[data-v-
|
|
9010
|
+
.tui-room .header[data-v-dc8a7460] {
|
|
8993
9011
|
position: absolute;
|
|
8994
9012
|
top: 0;
|
|
8995
9013
|
left: 0;
|
|
@@ -9000,20 +9018,20 @@ body, html {
|
|
|
9000
9018
|
border-bottom: 1px solid var(--stroke-color-primary);
|
|
9001
9019
|
box-shadow: 0 1px 0 var(--uikit-color-black-8);
|
|
9002
9020
|
}
|
|
9003
|
-
.tui-room .content[data-v-
|
|
9021
|
+
.tui-room .content[data-v-dc8a7460] {
|
|
9004
9022
|
position: absolute;
|
|
9005
9023
|
top: 0;
|
|
9006
9024
|
width: 100%;
|
|
9007
9025
|
height: 100%;
|
|
9008
9026
|
background-color: var(--bg-color-topbar);
|
|
9009
9027
|
}
|
|
9010
|
-
.tui-room.tui-room-h5[data-v-
|
|
9028
|
+
.tui-room.tui-room-h5[data-v-dc8a7460] {
|
|
9011
9029
|
width: 100%;
|
|
9012
9030
|
min-width: 350px;
|
|
9013
9031
|
height: 100%;
|
|
9014
9032
|
min-height: 525px;
|
|
9015
9033
|
}
|
|
9016
|
-
#roomContainer.chat-room[data-v-
|
|
9034
|
+
#roomContainer.chat-room[data-v-dc8a7460] {
|
|
9017
9035
|
position: absolute;
|
|
9018
9036
|
top: 0;
|
|
9019
9037
|
right: 0;
|
|
@@ -9025,8 +9043,8 @@ body, html {
|
|
|
9025
9043
|
margin: auto;
|
|
9026
9044
|
border-radius: 10px;
|
|
9027
9045
|
}
|
|
9028
|
-
#roomContainer.tui-room-h5[data-v-
|
|
9029
|
-
#roomContainer .chat-room[data-v-
|
|
9046
|
+
#roomContainer.tui-room-h5[data-v-dc8a7460],
|
|
9047
|
+
#roomContainer .chat-room[data-v-dc8a7460] {
|
|
9030
9048
|
width: 100%;
|
|
9031
9049
|
height: 100%;
|
|
9032
9050
|
}.user-info-container[data-v-9e9aff53] {
|
package/lib/locales/en-US.d.ts
CHANGED
package/lib/locales/en-US.js
CHANGED
package/lib/locales/zh-CN.d.ts
CHANGED
package/lib/locales/zh-CN.js
CHANGED
package/lib/stores/basic.d.ts
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { LAYOUT } from '../constants/render';
|
|
2
2
|
import { TUINetwork } from '../../../node_modules/@tencentcloud/tuiroom-engine-js';
|
|
3
3
|
|
|
4
|
-
type SideBarType = 'chat' | 'invite' | 'manage-member' | 'more' | 'transfer-leave' | 'apply' | 'aiTranscription' | '';
|
|
4
|
+
type SideBarType = 'chat' | 'invite' | 'manage-member' | 'more' | 'transfer-leave' | 'apply' | 'aiTranscription' | 'vote' | '';
|
|
5
5
|
type SceneType = 'chat' | 'default';
|
|
6
6
|
interface BasicState {
|
|
7
7
|
sdkAppId: number;
|
package/package.json
CHANGED
|
Binary file
|
|
Binary file
|
|
@@ -51,6 +51,10 @@
|
|
|
51
51
|
class="center-container-item"
|
|
52
52
|
@click="handleControlClick('MasterApplyControl')"
|
|
53
53
|
/>
|
|
54
|
+
<voteControl
|
|
55
|
+
class="center-container-item"
|
|
56
|
+
@click="handleControlClick('voteControl')"
|
|
57
|
+
/>
|
|
54
58
|
<more-control
|
|
55
59
|
class="center-container-item"
|
|
56
60
|
@click="handleControlClick('moreControl')"
|
|
@@ -93,7 +97,7 @@ import VirtualBackground from '../VirtualBackground.vue';
|
|
|
93
97
|
import AIControl from '../AIControl.vue';
|
|
94
98
|
import BasicBeauty from '../BasicBeauty.vue';
|
|
95
99
|
import bus from '../../../hooks/useMitt';
|
|
96
|
-
|
|
100
|
+
import voteControl from '../voteControl.vue';
|
|
97
101
|
import useRoomFooter from './useRoomFooterHooks';
|
|
98
102
|
import { isElectron } from '../../../utils/environment';
|
|
99
103
|
const { roomStore, isMaster, isAdmin, isAudience } = useRoomFooter();
|
|
@@ -0,0 +1,65 @@
|
|
|
1
|
+
<template>
|
|
2
|
+
<div class="more-container">
|
|
3
|
+
<icon-button
|
|
4
|
+
:is-active="sidebarName === 'vote'"
|
|
5
|
+
:title="t('Vote')"
|
|
6
|
+
@click-icon="toggleToolBox"
|
|
7
|
+
>
|
|
8
|
+
<IconAIIcon size="24" />
|
|
9
|
+
</icon-button>
|
|
10
|
+
测试
|
|
11
|
+
<div class="tool-box" v-if="!isSidebarOpen && showToolBox">
|
|
12
|
+
123
|
|
13
|
+
<slot></slot>
|
|
14
|
+
</div>
|
|
15
|
+
</div>
|
|
16
|
+
</template>
|
|
17
|
+
|
|
18
|
+
<script setup lang="ts">
|
|
19
|
+
import { roomService } from '../../services';
|
|
20
|
+
import { defineEmits, ref,computed,watch } from 'vue';
|
|
21
|
+
import { useI18n } from '../../locales';
|
|
22
|
+
const { basicStore } = roomService;
|
|
23
|
+
const isSidebarOpen = computed(() => basicStore.isSidebarOpen);
|
|
24
|
+
const sidebarName = computed(() => basicStore.sidebarName);
|
|
25
|
+
const { t } = useI18n();
|
|
26
|
+
const showToolBox = ref(false);
|
|
27
|
+
watch(isSidebarOpen, newValue => {
|
|
28
|
+
showToolBox.value = newValue && false;
|
|
29
|
+
});
|
|
30
|
+
const emit = defineEmits(['on-vote']);
|
|
31
|
+
function toggleToolBox() {
|
|
32
|
+
showToolBox.value = !showToolBox.value;
|
|
33
|
+
emit('on-vote', {
|
|
34
|
+
name: 'onVote',
|
|
35
|
+
visible: showToolBox.value,
|
|
36
|
+
});
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
</script>
|
|
40
|
+
|
|
41
|
+
<style lang="scss" scoped>
|
|
42
|
+
.more-container {
|
|
43
|
+
padding: 20px;
|
|
44
|
+
|
|
45
|
+
.more-title {
|
|
46
|
+
display: flex;
|
|
47
|
+
align-items: center;
|
|
48
|
+
|
|
49
|
+
.email-icon {
|
|
50
|
+
color: var(--uikit-color-gray-7);
|
|
51
|
+
}
|
|
52
|
+
|
|
53
|
+
.more-notice {
|
|
54
|
+
width: 100%;
|
|
55
|
+
height: 22px;
|
|
56
|
+
padding-left: 8px;
|
|
57
|
+
font-size: 14px;
|
|
58
|
+
font-weight: 400;
|
|
59
|
+
line-height: 22px;
|
|
60
|
+
color: var(--text-color-primary);
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
|
|
64
|
+
}
|
|
65
|
+
</style>
|
|
@@ -8,6 +8,7 @@
|
|
|
8
8
|
:size="400"
|
|
9
9
|
>
|
|
10
10
|
<chat v-if="sidebarName == 'chat'" />
|
|
11
|
+
<room-vote v-if="sidebarName == 'vote'" />
|
|
11
12
|
<room-more v-if="sidebarName == 'more'" />
|
|
12
13
|
<manage-member v-if="sidebarName == 'manage-member'" />
|
|
13
14
|
<AITranscription v-if="sidebarName == 'aiTranscription'" />
|