@ndscnj/roomkit-web-vue3 25.12.24165 → 25.12.24166
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/es/assets/imgs/vote-icon.png.mjs +4 -0
- package/es/components/RoomFooter/VoteControl/MoreControlH5.vue.d.ts +2 -2
- package/es/components/RoomFooter/VoteControl/MoreControlH5.vue.mjs +1 -1
- package/es/components/RoomFooter/VoteControl/MoreControlH5.vue2.mjs +32 -76
- package/es/components/RoomFooter/VoteControl/MoreControlPC.vue.mjs +5 -53
- package/es/components/RoomFooter/VoteControl/MoreControlPC.vue2.mjs +58 -1
- package/es/components/RoomFooter/VoteControl/index.d.ts +0 -4
- package/es/components/RoomFooter/VoteControl/index.mjs +2 -2
- package/es/components/RoomSidebar/indexPC.vue.d.ts +1 -0
- package/es/components/RoomSidebar/indexPC.vue.mjs +3 -0
- package/es/components/RoomVote/index.d.ts +17 -5
- package/es/components/RoomVote/indexH5.vue.d.ts +10 -5
- package/es/components/RoomVote/indexH5.vue.mjs +9 -2
- package/es/conference.vue.d.ts +1 -0
- package/es/conference.vue.mjs +1 -1
- package/es/conference.vue2.mjs +4 -6
- package/es/index.mjs +59 -116
- package/lib/assets/imgs/vote-icon.png.js +4 -0
- package/lib/components/Chat/index/indexH5.vue.js +1 -1
- package/lib/components/ManageMember/MemberItem/indexH5.vue.js +1 -1
- package/lib/components/ManageMember/indexH5.vue.js +1 -1
- package/lib/components/RoomFooter/VoteControl/MoreControlH5.vue.d.ts +2 -2
- package/lib/components/RoomFooter/VoteControl/MoreControlH5.vue.js +1 -1
- package/lib/components/RoomFooter/VoteControl/MoreControlH5.vue2.js +30 -74
- package/lib/components/RoomFooter/VoteControl/MoreControlPC.vue.js +5 -53
- package/lib/components/RoomFooter/VoteControl/MoreControlPC.vue2.js +59 -2
- package/lib/components/RoomFooter/VoteControl/index.d.ts +0 -4
- package/lib/components/RoomFooter/VoteControl/index.js +2 -2
- package/lib/components/RoomFooter/index/indexH5.vue.js +1 -1
- package/lib/components/RoomInvite/indexH5.vue.js +1 -1
- package/lib/components/RoomMore/indexH5.vue.js +1 -1
- package/lib/components/RoomSidebar/indexH5.vue.js +1 -1
- package/lib/components/RoomSidebar/indexPC.vue.d.ts +1 -0
- package/lib/components/RoomSidebar/indexPC.vue.js +3 -0
- package/lib/components/RoomVote/index.d.ts +17 -5
- package/lib/components/RoomVote/indexH5.vue.d.ts +10 -5
- package/lib/components/RoomVote/indexH5.vue.js +9 -2
- package/lib/conference.vue.d.ts +1 -0
- package/lib/conference.vue.js +1 -1
- package/lib/conference.vue2.js +4 -6
- package/lib/index.js +59 -116
- package/package.json +1 -1
- package/src/TUIRoom/components/RoomFooter/VoteControl/MoreControlH5.vue +27 -108
- package/src/TUIRoom/components/RoomFooter/VoteControl/MoreControlPC.vue +7 -1
- package/src/TUIRoom/components/RoomSidebar/indexPC.vue +3 -0
- package/src/TUIRoom/components/RoomVote/indexH5.vue +61 -118
- package/src/TUIRoom/conference.vue +3 -3
- package/es/components/RoomVote/indexH5.vue2.mjs +0 -51
- package/es/components/RoomVote/useRoomMoreHooks.mjs +0 -43
- package/lib/components/RoomVote/indexH5.vue2.js +0 -51
- package/lib/components/RoomVote/useRoomMoreHooks.js +0 -43
|
@@ -1,8 +1,20 @@
|
|
|
1
|
-
declare const Index:
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
1
|
+
declare const Index: ({
|
|
2
|
+
new (...args: any[]): import('vue').CreateComponentPublicInstanceWithMixins<Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, import('vue').PublicProps, {}, true, {}, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, {}, any, import('vue').ComponentProvideOptions, {
|
|
3
|
+
P: {};
|
|
4
|
+
B: {};
|
|
5
|
+
D: {};
|
|
6
|
+
C: {};
|
|
7
|
+
M: {};
|
|
8
|
+
Defaults: {};
|
|
9
|
+
}, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, {}>;
|
|
10
|
+
__isFragment?: never;
|
|
11
|
+
__isTeleport?: never;
|
|
12
|
+
__isSuspense?: never;
|
|
13
|
+
} & import('vue').ComponentOptionsBase<Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, {}, {}, string, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, import('vue').ComponentProvideOptions> & import('vue').VNodeProps & import('vue').AllowedComponentProps & import('vue').ComponentCustomProps & (new () => {
|
|
14
|
+
$slots: {
|
|
15
|
+
contentH5?(_: {}): any;
|
|
16
|
+
};
|
|
17
|
+
})) | ({
|
|
6
18
|
new (...args: any[]): import('vue').CreateComponentPublicInstanceWithMixins<Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, import('vue').PublicProps, {}, true, {}, {}, import('vue').GlobalComponents, import('vue').GlobalDirectives, string, {}, any, import('vue').ComponentProvideOptions, {
|
|
7
19
|
P: {};
|
|
8
20
|
B: {};
|
|
@@ -1,6 +1,11 @@
|
|
|
1
|
-
declare
|
|
2
|
-
|
|
3
|
-
}
|
|
4
|
-
|
|
5
|
-
|
|
1
|
+
declare function __VLS_template(): {
|
|
2
|
+
contentH5?(_: {}): any;
|
|
3
|
+
};
|
|
4
|
+
declare const __VLS_component: import('vue').DefineComponent<{}, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {}, string, import('vue').PublicProps, Readonly<{}> & Readonly<{}>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, true, {}, any>;
|
|
5
|
+
declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, ReturnType<typeof __VLS_template>>;
|
|
6
6
|
export default _default;
|
|
7
|
+
type __VLS_WithTemplateSlots<T, S> = T & {
|
|
8
|
+
new (): {
|
|
9
|
+
$slots: S;
|
|
10
|
+
};
|
|
11
|
+
};
|
|
@@ -1,7 +1,14 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperties(exports, { __esModule: { value: true }, [Symbol.toStringTag]: { value: "Module" } });
|
|
3
|
-
const
|
|
3
|
+
const Vue = require("vue");
|
|
4
4
|
;/* empty css */
|
|
5
5
|
const _pluginVue_exportHelper = require("../../_virtual/_plugin-vue_export-helper.js");
|
|
6
|
-
const
|
|
6
|
+
const _sfc_main = {};
|
|
7
|
+
const _hoisted_1 = { class: "more-container" };
|
|
8
|
+
function _sfc_render(_ctx, _cache) {
|
|
9
|
+
return Vue.openBlock(), Vue.createElementBlock("div", _hoisted_1, [
|
|
10
|
+
Vue.renderSlot(_ctx.$slots, "contentH5", {}, void 0, true)
|
|
11
|
+
]);
|
|
12
|
+
}
|
|
13
|
+
const indexH5 = /* @__PURE__ */ _pluginVue_exportHelper.default(_sfc_main, [["render", _sfc_render], ["__scopeId", "data-v-6c9f3c67"]]);
|
|
7
14
|
exports.default = indexH5;
|
package/lib/conference.vue.d.ts
CHANGED
|
@@ -16,6 +16,7 @@ declare function enterRoom(options: {
|
|
|
16
16
|
declare function resetStore(): void;
|
|
17
17
|
declare function __VLS_template(): {
|
|
18
18
|
content?(_: {}): any;
|
|
19
|
+
contentH5?(_: {}): any;
|
|
19
20
|
};
|
|
20
21
|
declare const __VLS_component: import('vue').DefineComponent<import('vue').ExtractPropTypes<__VLS_WithDefaults<__VLS_TypePropsToRuntimeProps<{
|
|
21
22
|
displayMode: "permanent" | "wake-up";
|
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-5135c8c9"]]);
|
|
8
8
|
exports.default = ConferenceMainView;
|
package/lib/conference.vue2.js
CHANGED
|
@@ -276,18 +276,16 @@ const _sfc_main = /* @__PURE__ */ Vue.defineComponent({
|
|
|
276
276
|
class: "footer",
|
|
277
277
|
onShowOverlay: handleShowOverlay,
|
|
278
278
|
onOnVote: onVote
|
|
279
|
-
},
|
|
280
|
-
content: Vue.withCtx(() => [
|
|
281
|
-
Vue.renderSlot(_ctx.$slots, "content", {}, void 0, true)
|
|
282
|
-
]),
|
|
283
|
-
_: 3
|
|
284
|
-
}, 512), [
|
|
279
|
+
}, null, 512), [
|
|
285
280
|
[Vue.vShow, Vue.unref(showRoomTool)]
|
|
286
281
|
]),
|
|
287
282
|
Vue.createVNode(Vue.unref(index$3.default), { onOnVote: onVote }, {
|
|
288
283
|
content: Vue.withCtx(() => [
|
|
289
284
|
Vue.renderSlot(_ctx.$slots, "content", {}, void 0, true)
|
|
290
285
|
]),
|
|
286
|
+
contentH5: Vue.withCtx(() => [
|
|
287
|
+
Vue.renderSlot(_ctx.$slots, "contentH5", {}, void 0, true)
|
|
288
|
+
]),
|
|
291
289
|
_: 3
|
|
292
290
|
}),
|
|
293
291
|
Vue.createVNode(index$4.default),
|
package/lib/index.js
CHANGED
|
@@ -3928,44 +3928,12 @@ to {
|
|
|
3928
3928
|
}
|
|
3929
3929
|
.footer .mirror-container .mirror-text[data-v-21a63691] {
|
|
3930
3930
|
margin-left: 4px;
|
|
3931
|
-
}.
|
|
3932
|
-
|
|
3933
|
-
|
|
3934
|
-
|
|
3935
|
-
width:
|
|
3936
|
-
height:
|
|
3937
|
-
padding: 10px;
|
|
3938
|
-
border-radius: 13px;
|
|
3939
|
-
animation-name: popup-c413959d;
|
|
3940
|
-
animation-duration: 200ms;
|
|
3941
|
-
background-color: var(--bg-color-operate);
|
|
3942
|
-
}
|
|
3943
|
-
@keyframes popup-c413959d {
|
|
3944
|
-
from {
|
|
3945
|
-
bottom: 0;
|
|
3946
|
-
}
|
|
3947
|
-
to {
|
|
3948
|
-
bottom: 15px;
|
|
3949
|
-
}
|
|
3950
|
-
}
|
|
3951
|
-
.control-compent[data-v-c413959d] {
|
|
3952
|
-
display: flex;
|
|
3953
|
-
}
|
|
3954
|
-
.close[data-v-c413959d] {
|
|
3955
|
-
position: relative;
|
|
3956
|
-
top: 10%;
|
|
3957
|
-
display: flex;
|
|
3958
|
-
align-items: center;
|
|
3959
|
-
justify-content: center;
|
|
3960
|
-
width: 100%;
|
|
3961
|
-
padding: 10px;
|
|
3962
|
-
font-style: normal;
|
|
3963
|
-
font-weight: 400;
|
|
3964
|
-
line-height: 24px;
|
|
3965
|
-
text-align: center;
|
|
3966
|
-
border-radius: 8px;
|
|
3967
|
-
color: var(--text-color-primary);
|
|
3968
|
-
background-color: var(--button-color-secondary-default);
|
|
3931
|
+
}.ndsc-img-box[data-v-2d633075] {
|
|
3932
|
+
width: 50px;
|
|
3933
|
+
height: 50px;
|
|
3934
|
+
}.ndsc-img-box[data-v-9e42a812] {
|
|
3935
|
+
width: 50px;
|
|
3936
|
+
height: 50px;
|
|
3969
3937
|
}.footer-container[data-v-4afcea78] {
|
|
3970
3938
|
position: absolute;
|
|
3971
3939
|
bottom: 0;
|
|
@@ -4986,95 +4954,70 @@ to {
|
|
|
4986
4954
|
right: 0;
|
|
4987
4955
|
z-index: 101;
|
|
4988
4956
|
height: 100%;
|
|
4989
|
-
}
|
|
4990
|
-
padding
|
|
4991
|
-
font-size: 12px;
|
|
4992
|
-
font-weight: 500;
|
|
4993
|
-
line-height: 17px;
|
|
4957
|
+
}.more-container[data-v-6c9f3c67] {
|
|
4958
|
+
padding: 20px;
|
|
4994
4959
|
}
|
|
4995
|
-
.
|
|
4996
|
-
position: fixed;
|
|
4997
|
-
bottom: 0;
|
|
4960
|
+
.more-container .more-title[data-v-6c9f3c67] {
|
|
4998
4961
|
display: flex;
|
|
4999
|
-
|
|
5000
|
-
width: 100%;
|
|
5001
|
-
padding-bottom: 4vh;
|
|
5002
|
-
border-radius: 15px 15px 0 0;
|
|
5003
|
-
animation-name: popup-939000cb;
|
|
5004
|
-
animation-duration: 200ms;
|
|
5005
|
-
background-color: var(--bg-color-operate);
|
|
5006
|
-
}
|
|
5007
|
-
@keyframes popup-939000cb {
|
|
5008
|
-
from {
|
|
5009
|
-
transform: scaleY(0);
|
|
5010
|
-
transform-origin: bottom;
|
|
5011
|
-
}
|
|
5012
|
-
to {
|
|
5013
|
-
transform: scaleY(1);
|
|
5014
|
-
transform-origin: bottom;
|
|
4962
|
+
align-items: center;
|
|
5015
4963
|
}
|
|
4964
|
+
.more-container .more-title .email-icon[data-v-6c9f3c67] {
|
|
4965
|
+
color: var(--uikit-color-gray-7);
|
|
5016
4966
|
}
|
|
5017
|
-
.
|
|
5018
|
-
|
|
5019
|
-
|
|
5020
|
-
|
|
5021
|
-
|
|
5022
|
-
font-
|
|
5023
|
-
|
|
5024
|
-
font-style: normal;
|
|
5025
|
-
font-weight: 500;
|
|
5026
|
-
line-height: 24px;
|
|
4967
|
+
.more-container .more-title .more-notice[data-v-6c9f3c67] {
|
|
4968
|
+
width: 100%;
|
|
4969
|
+
height: 22px;
|
|
4970
|
+
padding-left: 8px;
|
|
4971
|
+
font-size: 14px;
|
|
4972
|
+
font-weight: 400;
|
|
4973
|
+
line-height: 22px;
|
|
5027
4974
|
color: var(--text-color-primary);
|
|
5028
4975
|
}
|
|
5029
|
-
.
|
|
4976
|
+
.more-container .more-item[data-v-6c9f3c67] {
|
|
4977
|
+
position: relative;
|
|
5030
4978
|
display: flex;
|
|
5031
|
-
flex-direction:
|
|
5032
|
-
align-items: center;
|
|
5033
|
-
width: 90%;
|
|
5034
|
-
height: 15%;
|
|
5035
|
-
padding: 0 0 0 25px;
|
|
5036
|
-
margin-bottom: 10px;
|
|
4979
|
+
flex-direction: column;
|
|
5037
4980
|
}
|
|
5038
|
-
.
|
|
5039
|
-
|
|
5040
|
-
|
|
5041
|
-
|
|
4981
|
+
.more-container .more-item[data-v-6c9f3c67]:not(:first-child) {
|
|
4982
|
+
margin-top: 20px;
|
|
4983
|
+
}
|
|
4984
|
+
.more-container .more-item:not(:first-child) .item-title[data-v-6c9f3c67] {
|
|
4985
|
+
width: 100%;
|
|
4986
|
+
padding-bottom: 8px;
|
|
5042
4987
|
font-size: 14px;
|
|
5043
|
-
font-style: normal;
|
|
5044
4988
|
font-weight: 400;
|
|
5045
|
-
line-height:
|
|
5046
|
-
white-space: nowrap;
|
|
4989
|
+
line-height: 22px;
|
|
5047
4990
|
color: var(--text-color-primary);
|
|
5048
4991
|
}
|
|
5049
|
-
.
|
|
5050
|
-
|
|
4992
|
+
.more-container .more-item:not(:first-child) .more-content[data-v-6c9f3c67] {
|
|
4993
|
+
position: relative;
|
|
4994
|
+
box-sizing: border-box;
|
|
4995
|
+
display: inline-block;
|
|
4996
|
+
flex: 1;
|
|
4997
|
+
height: 42px;
|
|
4998
|
+
padding: 10px 30px 10px 16px;
|
|
5051
4999
|
overflow: hidden;
|
|
5052
5000
|
font-size: 14px;
|
|
5001
|
+
font-weight: 500;
|
|
5002
|
+
line-height: 22px;
|
|
5053
5003
|
text-overflow: ellipsis;
|
|
5054
5004
|
white-space: nowrap;
|
|
5055
|
-
|
|
5056
|
-
|
|
5057
|
-
|
|
5058
|
-
|
|
5059
|
-
|
|
5060
|
-
|
|
5061
|
-
font-size: 12px;
|
|
5062
|
-
font-style: normal;
|
|
5063
|
-
font-weight: 400;
|
|
5064
|
-
line-height: 17px;
|
|
5065
|
-
text-align: center;
|
|
5066
|
-
color: var(--text-color-secondary);
|
|
5005
|
+
border-radius: 8px;
|
|
5006
|
+
outline: none;
|
|
5007
|
+
transition: border-color 0.2s cubic-bezier(0.645, 0.045, 0.355, 1);
|
|
5008
|
+
color: var(--text-color-primary);
|
|
5009
|
+
background-color: var(--bg-color-input);
|
|
5010
|
+
border: 1px solid var(--stroke-color-module);
|
|
5067
5011
|
}
|
|
5068
|
-
.
|
|
5069
|
-
|
|
5012
|
+
.more-container .more-item:not(:first-child) .copy-icon[data-v-6c9f3c67] {
|
|
5013
|
+
position: absolute;
|
|
5014
|
+
top: 45px;
|
|
5015
|
+
right: 10px;
|
|
5016
|
+
display: flex;
|
|
5017
|
+
align-items: center;
|
|
5018
|
+
justify-content: center;
|
|
5019
|
+
cursor: pointer;
|
|
5070
5020
|
color: var(--text-color-link);
|
|
5071
|
-
}
|
|
5072
|
-
.cancel[data-v-939000cb] {
|
|
5073
|
-
flex: 1;
|
|
5074
|
-
padding-right: 30px;
|
|
5075
|
-
font-size: 16px;
|
|
5076
|
-
font-weight: 400;
|
|
5077
|
-
text-align: end;
|
|
5078
5021
|
}.more-container[data-v-41107c5f] {
|
|
5079
5022
|
padding: 20px;
|
|
5080
5023
|
}
|
|
@@ -9168,7 +9111,7 @@ body, html {
|
|
|
9168
9111
|
}
|
|
9169
9112
|
.tui-room :not([class|=el]) {
|
|
9170
9113
|
transition: background-color 0.3s, color 0.3s, box-shadow 0.3s;
|
|
9171
|
-
}.tui-room[data-v-
|
|
9114
|
+
}.tui-room[data-v-5135c8c9] {
|
|
9172
9115
|
position: relative;
|
|
9173
9116
|
display: flex;
|
|
9174
9117
|
flex-direction: column;
|
|
@@ -9180,7 +9123,7 @@ body, html {
|
|
|
9180
9123
|
text-align: left;
|
|
9181
9124
|
background-color: var(--bg-color-topbar);
|
|
9182
9125
|
}
|
|
9183
|
-
.tui-room .header[data-v-
|
|
9126
|
+
.tui-room .header[data-v-5135c8c9] {
|
|
9184
9127
|
position: absolute;
|
|
9185
9128
|
top: 0;
|
|
9186
9129
|
left: 0;
|
|
@@ -9191,20 +9134,20 @@ body, html {
|
|
|
9191
9134
|
border-bottom: 1px solid var(--stroke-color-primary);
|
|
9192
9135
|
box-shadow: 0 1px 0 var(--uikit-color-black-8);
|
|
9193
9136
|
}
|
|
9194
|
-
.tui-room .content[data-v-
|
|
9137
|
+
.tui-room .content[data-v-5135c8c9] {
|
|
9195
9138
|
position: absolute;
|
|
9196
9139
|
top: 0;
|
|
9197
9140
|
width: 100%;
|
|
9198
9141
|
height: 100%;
|
|
9199
9142
|
background-color: var(--bg-color-topbar);
|
|
9200
9143
|
}
|
|
9201
|
-
.tui-room.tui-room-h5[data-v-
|
|
9144
|
+
.tui-room.tui-room-h5[data-v-5135c8c9] {
|
|
9202
9145
|
width: 100%;
|
|
9203
9146
|
min-width: 350px;
|
|
9204
9147
|
height: 100%;
|
|
9205
9148
|
min-height: 525px;
|
|
9206
9149
|
}
|
|
9207
|
-
#roomContainer.chat-room[data-v-
|
|
9150
|
+
#roomContainer.chat-room[data-v-5135c8c9] {
|
|
9208
9151
|
position: absolute;
|
|
9209
9152
|
top: 0;
|
|
9210
9153
|
right: 0;
|
|
@@ -9216,8 +9159,8 @@ body, html {
|
|
|
9216
9159
|
margin: auto;
|
|
9217
9160
|
border-radius: 10px;
|
|
9218
9161
|
}
|
|
9219
|
-
#roomContainer.tui-room-h5[data-v-
|
|
9220
|
-
#roomContainer .chat-room[data-v-
|
|
9162
|
+
#roomContainer.tui-room-h5[data-v-5135c8c9],
|
|
9163
|
+
#roomContainer .chat-room[data-v-5135c8c9] {
|
|
9221
9164
|
width: 100%;
|
|
9222
9165
|
height: 100%;
|
|
9223
9166
|
}.user-info-container[data-v-9e9aff53] {
|
package/package.json
CHANGED
|
@@ -1,122 +1,41 @@
|
|
|
1
1
|
<template>
|
|
2
|
-
<div>
|
|
3
|
-
<
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
</div>
|
|
12
|
-
<div v-if="showMoreContent" ref="moreContentRef" class="show-more-content">
|
|
13
|
-
<div class="control-compent">
|
|
14
|
-
<chat-control
|
|
15
|
-
v-if="roomStore.isSpeakAfterTakingSeatMode"
|
|
16
|
-
@click="handleControlClick('chatControl')"
|
|
17
|
-
/>
|
|
18
|
-
<contact-control @click="handleControlClick('contactControl')" />
|
|
19
|
-
<invite-control
|
|
20
|
-
@show-overlay="handleShowOverlay"
|
|
21
|
-
@click="handleControlClick('inviteControl')"
|
|
22
|
-
/>
|
|
23
|
-
</div>
|
|
24
|
-
<div v-tap="handleCancelControl" class="close">{{ t('Cancel') }}</div>
|
|
25
|
-
</div>
|
|
2
|
+
<div v-if="moreControlConfig.visible" class="more-control-container">
|
|
3
|
+
<icon-button
|
|
4
|
+
:is-active="sidebarName === 'vote'"
|
|
5
|
+
:title="t('Vote')"
|
|
6
|
+
@click-icon="toggleMoreSidebar"
|
|
7
|
+
>
|
|
8
|
+
<IconMore size="24" />
|
|
9
|
+
<img class="ndsc-img-box" src="../../../assets/imgs/vote-icon.png" alt=""/>
|
|
10
|
+
</icon-button>
|
|
26
11
|
</div>
|
|
27
12
|
</template>
|
|
28
13
|
<script setup lang="ts">
|
|
29
|
-
import {
|
|
30
|
-
import { IconExtension } from '@tencentcloud/uikit-base-component-vue3';
|
|
14
|
+
import { IconMore } from '@tencentcloud/uikit-base-component-vue3';
|
|
31
15
|
import IconButton from '../../common/base/IconButton.vue';
|
|
32
16
|
import userMoreControl from './useMoreControlHooks';
|
|
33
|
-
import ChatControl from '../ChatControl.vue';
|
|
34
|
-
import InviteControl from '../InviteControl.vue';
|
|
35
|
-
import ContactControl from '../ContactControl.vue';
|
|
36
|
-
import { useRoomStore } from '../../../stores/room';
|
|
37
|
-
import bus from '../../../hooks/useMitt';
|
|
38
|
-
import vTap from '../../../directives/vTap';
|
|
39
17
|
import { roomService } from '../../../services';
|
|
40
|
-
|
|
18
|
+
import { defineEmits} from 'vue';
|
|
41
19
|
const moreControlConfig = roomService.getComponentConfig('MoreControl');
|
|
42
|
-
const
|
|
43
|
-
const
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
showMoreContent.value = true;
|
|
50
|
-
}
|
|
51
|
-
|
|
52
|
-
function handleCancelControl() {
|
|
53
|
-
showMoreContent.value = false;
|
|
54
|
-
}
|
|
55
|
-
function handleControlClick(name: string) {
|
|
56
|
-
bus.emit('experience-communication', name);
|
|
57
|
-
}
|
|
58
|
-
|
|
59
|
-
function handleShowOverlay(data: { name: string; visible: boolean }) {
|
|
60
|
-
showMoreContent.value = false;
|
|
61
|
-
emit('show-overlay', data);
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
function handleDocumentClick(event: MouseEvent) {
|
|
65
|
-
if (showMoreContent.value && !moreContentRef.value.contains(event.target)) {
|
|
66
|
-
showMoreContent.value = false;
|
|
20
|
+
const { t, basicStore, sidebarName } = userMoreControl();
|
|
21
|
+
const emit = defineEmits(['on-vote']);
|
|
22
|
+
function toggleMoreSidebar() {
|
|
23
|
+
if (basicStore.setSidebarOpenStatus && basicStore.sidebarName === 'vote') {
|
|
24
|
+
basicStore.setSidebarOpenStatus(false);
|
|
25
|
+
basicStore.setSidebarName('');
|
|
26
|
+
return;
|
|
67
27
|
}
|
|
28
|
+
basicStore.setSidebarOpenStatus(true);
|
|
29
|
+
basicStore.setSidebarName('vote');
|
|
30
|
+
emit('on-vote', {
|
|
31
|
+
name: 'onVote',
|
|
32
|
+
visible:basicStore.isSidebarOpen,
|
|
33
|
+
});
|
|
68
34
|
}
|
|
69
|
-
|
|
70
|
-
onMounted(() => {
|
|
71
|
-
document?.addEventListener('click', handleDocumentClick, true);
|
|
72
|
-
});
|
|
73
|
-
|
|
74
|
-
onUnmounted(() => {
|
|
75
|
-
document?.removeEventListener('click', handleDocumentClick, true);
|
|
76
|
-
});
|
|
77
35
|
</script>
|
|
78
36
|
<style lang="scss" scoped>
|
|
79
|
-
.
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
left: 5%;
|
|
83
|
-
width: 90%;
|
|
84
|
-
height: 17vh;
|
|
85
|
-
padding: 10px;
|
|
86
|
-
border-radius: 13px;
|
|
87
|
-
animation-name: popup;
|
|
88
|
-
animation-duration: 200ms;
|
|
89
|
-
background-color: var(--bg-color-operate);
|
|
90
|
-
}
|
|
91
|
-
|
|
92
|
-
@keyframes popup {
|
|
93
|
-
from {
|
|
94
|
-
bottom: 0;
|
|
95
|
-
}
|
|
96
|
-
|
|
97
|
-
to {
|
|
98
|
-
bottom: 15px;
|
|
99
|
-
}
|
|
100
|
-
}
|
|
101
|
-
|
|
102
|
-
.control-compent {
|
|
103
|
-
display: flex;
|
|
104
|
-
}
|
|
105
|
-
|
|
106
|
-
.close {
|
|
107
|
-
position: relative;
|
|
108
|
-
top: 10%;
|
|
109
|
-
display: flex;
|
|
110
|
-
align-items: center;
|
|
111
|
-
justify-content: center;
|
|
112
|
-
width: 100%;
|
|
113
|
-
padding: 10px;
|
|
114
|
-
font-style: normal;
|
|
115
|
-
font-weight: 400;
|
|
116
|
-
line-height: 24px;
|
|
117
|
-
text-align: center;
|
|
118
|
-
border-radius: 8px;
|
|
119
|
-
color: var(--text-color-primary);
|
|
120
|
-
background-color: var(--button-color-secondary-default);
|
|
37
|
+
.ndsc-img-box{
|
|
38
|
+
width: 50px;
|
|
39
|
+
height: 50px
|
|
121
40
|
}
|
|
122
41
|
</style>
|
|
@@ -6,6 +6,7 @@
|
|
|
6
6
|
@click-icon="toggleMoreSidebar"
|
|
7
7
|
>
|
|
8
8
|
<IconMore size="24" />
|
|
9
|
+
<img class="ndsc-img-box" src="../../../assets/imgs/vote-icon.png" alt=""/>
|
|
9
10
|
</icon-button>
|
|
10
11
|
</div>
|
|
11
12
|
</template>
|
|
@@ -32,4 +33,9 @@ function toggleMoreSidebar() {
|
|
|
32
33
|
});
|
|
33
34
|
}
|
|
34
35
|
</script>
|
|
35
|
-
<style lang="scss" scoped
|
|
36
|
+
<style lang="scss" scoped>
|
|
37
|
+
.ndsc-img-box{
|
|
38
|
+
width: 50px;
|
|
39
|
+
height: 50px
|
|
40
|
+
}
|
|
41
|
+
</style>
|
|
@@ -12,6 +12,9 @@
|
|
|
12
12
|
<template #content>
|
|
13
13
|
<slot name="content"></slot>
|
|
14
14
|
</template>
|
|
15
|
+
<template #contentH5>
|
|
16
|
+
<slot name="contentH5"></slot>
|
|
17
|
+
</template>
|
|
15
18
|
</room-vote>
|
|
16
19
|
<room-more v-if="sidebarName == 'more'" />
|
|
17
20
|
<manage-member v-if="sidebarName == 'manage-member'" />
|