@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.
Files changed (60) hide show
  1. package/.vscode/settings.json +2 -0
  2. package/es/assets/imgs/black-logo.png.mjs +1 -1
  3. package/es/assets/imgs/white-logo.png.mjs +1 -1
  4. package/es/components/RoomFooter/index/indexPC.vue.mjs +1 -1
  5. package/es/components/RoomFooter/index/indexPC.vue2.mjs +8 -3
  6. package/es/components/RoomFooter/voteControl.vue.d.ts +15 -0
  7. package/es/components/RoomFooter/voteControl.vue.mjs +7 -0
  8. package/es/components/RoomFooter/voteControl.vue2.mjs +60 -0
  9. package/es/components/RoomInvite/useRoomInviteHooks.d.ts +1 -1
  10. package/es/components/RoomSidebar/indexPC.vue.mjs +6 -4
  11. package/es/components/RoomSidebar/useSideBarHooks.d.ts +1 -1
  12. package/es/components/RoomSidebar/useSideBarHooks.mjs +3 -0
  13. package/es/components/RoomVote/index.d.ts +6 -0
  14. package/es/components/RoomVote/useRoomMoreHooks.d.ts +13 -0
  15. package/es/conference.vue.d.ts +2 -0
  16. package/es/conference.vue.mjs +1 -1
  17. package/es/conference.vue2.mjs +7 -2
  18. package/es/index.mjs +31 -13
  19. package/es/locales/en-US.d.ts +1 -0
  20. package/es/locales/en-US.mjs +1 -0
  21. package/es/locales/zh-CN.d.ts +1 -0
  22. package/es/locales/zh-CN.mjs +1 -0
  23. package/es/stores/basic.d.ts +1 -1
  24. package/lib/assets/imgs/black-logo.png.js +1 -1
  25. package/lib/assets/imgs/white-logo.png.js +1 -1
  26. package/lib/components/RoomFooter/index/indexPC.vue.js +1 -1
  27. package/lib/components/RoomFooter/index/indexPC.vue2.js +8 -3
  28. package/lib/components/RoomFooter/voteControl.vue.d.ts +15 -0
  29. package/lib/components/RoomFooter/voteControl.vue.js +7 -0
  30. package/lib/components/RoomFooter/voteControl.vue2.js +60 -0
  31. package/lib/components/RoomInvite/useRoomInviteHooks.d.ts +1 -1
  32. package/lib/components/RoomSidebar/indexPC.vue.js +5 -3
  33. package/lib/components/RoomSidebar/useSideBarHooks.d.ts +1 -1
  34. package/lib/components/RoomSidebar/useSideBarHooks.js +3 -0
  35. package/lib/components/RoomVote/index.d.ts +6 -0
  36. package/lib/components/RoomVote/useRoomMoreHooks.d.ts +13 -0
  37. package/lib/conference.vue.d.ts +2 -0
  38. package/lib/conference.vue.js +1 -1
  39. package/lib/conference.vue2.js +7 -2
  40. package/lib/index.js +31 -13
  41. package/lib/locales/en-US.d.ts +1 -0
  42. package/lib/locales/en-US.js +1 -0
  43. package/lib/locales/zh-CN.d.ts +1 -0
  44. package/lib/locales/zh-CN.js +1 -0
  45. package/lib/stores/basic.d.ts +1 -1
  46. package/package.json +1 -1
  47. package/src/TUIRoom/assets/imgs/black-logo.png +0 -0
  48. package/src/TUIRoom/assets/imgs/white-logo.png +0 -0
  49. package/src/TUIRoom/components/RoomFooter/index/indexPC.vue +5 -1
  50. package/src/TUIRoom/components/RoomFooter/voteControl.vue +65 -0
  51. package/src/TUIRoom/components/RoomSidebar/indexPC.vue +1 -0
  52. package/src/TUIRoom/components/RoomSidebar/useSideBarHooks.ts +3 -0
  53. package/src/TUIRoom/components/RoomVote/index.ts +7 -0
  54. package/src/TUIRoom/components/RoomVote/indexH5.vue +141 -0
  55. package/src/TUIRoom/components/RoomVote/indexPC.vue +106 -0
  56. package/src/TUIRoom/components/RoomVote/useRoomMoreHooks.ts +47 -0
  57. package/src/TUIRoom/conference.vue +5 -0
  58. package/src/TUIRoom/locales/en-US.ts +1 -0
  59. package/src/TUIRoom/locales/zh-CN.ts +1 -0
  60. 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-203d11fc"]]);
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[10] || (_cache[10] = ($event) => handleControlClick("moreControl"))
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[11] || (_cache[11] = ($event) => handleControlClick("AIControl"))
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[12] || (_cache[12] = ($event) => handleControlClick("settingControl"))
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) == "more" ? (Vue.openBlock(), Vue.createBlock(Vue.unref(index$1.default), { key: 1 })) : Vue.createCommentVNode("", true),
28
- Vue.unref(sidebarName) == "manage-member" ? (Vue.openBlock(), Vue.createBlock(Vue.unref(index$2.default), { key: 2 })) : Vue.createCommentVNode("", true),
29
- Vue.unref(sidebarName) == "aiTranscription" ? (Vue.openBlock(), Vue.createBlock(AITranscription.default, { key: 3 })) : Vue.createCommentVNode("", true)
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
  };
@@ -30,6 +30,9 @@ function useSideBar() {
30
30
  case "invite":
31
31
  sidebarTitle = t("Invite");
32
32
  break;
33
+ case "vote":
34
+ sidebarTitle = `${t("Vote")}`;
35
+ break;
33
36
  case "more":
34
37
  sidebarTitle = t("More");
35
38
  break;
@@ -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
+ };
@@ -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;
@@ -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-c5f5a591"]]);
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;
@@ -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
- }.footer-container[data-v-203d11fc] {
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-203d11fc] {
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-203d11fc]:not(:first-child) {
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-203d11fc] {
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-203d11fc]:not(:first-child) {
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-203d11fc] {
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-c5f5a591] {
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-c5f5a591] {
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-c5f5a591] {
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-c5f5a591] {
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-c5f5a591] {
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-c5f5a591],
9029
- #roomContainer .chat-room[data-v-c5f5a591] {
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] {
@@ -63,6 +63,7 @@ declare const _default: {
63
63
  RoomOwner: string;
64
64
  Me: string;
65
65
  me: string;
66
+ Vote: string;
66
67
  More: string;
67
68
  'AI Assistant': string;
68
69
  'AI real-time conference content': string;
@@ -65,6 +65,7 @@ const EN = {
65
65
  RoomOwner: "RoomOwner",
66
66
  Me: "Me",
67
67
  me: "me",
68
+ "Vote": "Vote",
68
69
  More: "More",
69
70
  "AI Assistant": "AI Assistant",
70
71
  "AI real-time conference content": "AI real-time conference content",
@@ -60,6 +60,7 @@ declare const _default: {
60
60
  me: string;
61
61
  Admin: string;
62
62
  RoomOwner: string;
63
+ Vote: string;
63
64
  More: string;
64
65
  'AI Assistant': string;
65
66
  'AI real-time conference content': string;
@@ -62,6 +62,7 @@ const ZH = {
62
62
  me: "我",
63
63
  Admin: "管理员",
64
64
  RoomOwner: "主持人",
65
+ Vote: "表决",
65
66
  More: "更多",
66
67
  "AI Assistant": "AI 助手",
67
68
  "AI real-time conference content": "AI 实时会议内容",
@@ -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
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ndscnj/roomkit-web-vue3",
3
- "version": "25.11.1916",
3
+ "version": "25.12.2316",
4
4
  "main": "./lib/index.js",
5
5
  "module": "./es/index.mjs",
6
6
  "types": "./es/index.d.ts",
@@ -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'" />
@@ -31,6 +31,9 @@ export default function useSideBar() {
31
31
  case 'invite':
32
32
  sidebarTitle = t('Invite');
33
33
  break;
34
+ case 'vote':
35
+ sidebarTitle = `${t('Vote')}`;
36
+ break;
34
37
  case 'more':
35
38
  sidebarTitle = t('More');
36
39
  break;
@@ -0,0 +1,7 @@
1
+ import indexH5 from './indexH5.vue';
2
+ import indexPC from './indexPC.vue';
3
+ import { isMobile } from '../../utils/environment';
4
+
5
+ const Index = isMobile ? indexH5 : indexPC;
6
+
7
+ export default Index;