8895 lines
564 KiB
JavaScript
8895 lines
564 KiB
JavaScript
|
(function(){"use strict";try{if(typeof document!="undefined"){var t=document.createElement("style");t.appendChild(document.createTextNode(".tk-row{display:flex;flex-wrap:wrap;position:relative;box-sizing:border-box;width:100%}.tk-col{display:flex;flex-wrap:wrap;position:relative;box-sizing:border-box}.tk-loading_dot-container{display:flex;justify-content:space-between;align-items:center;height:100%}.tk-loading_dot-container .tk-loading_dot:nth-child(1){opacity:0;animation-duration:.8s;animation-delay:0s;animation-play-state:running}.tk-loading_dot-container .tk-loading_dot:nth-child(2){opacity:.083;animation-duration:.8s;animation-delay:.2666666667s;animation-play-state:running}.tk-loading_dot-container .tk-loading_dot:nth-child(3){opacity:.1667;animation-duration:.8s;animation-delay:.5333333333s;animation-play-state:running}.tk-loading_dot-container .tk-loading_dot{width:20%;height:20%;border-radius:50%;background-color:#fff;animation-duration:1.8s;animation-name:dotting;animation-timing-function:linear;animation-iteration-count:infinite;animation-fill-mode:both}@keyframes dotting{0%{opacity:.15}1%{opacity:.8}33%{opacity:.8}34%{opacity:.15}to{opacity:.15}}.tk-loading_circle-container{height:100%;border:2px solid;border-radius:50%;border-top-color:transparent;border-right-color:transparent;border-bottom-color:#fff;border-left-color:#fff;background:0 0;vertical-align:middle;box-sizing:border-box;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.tk-loading{display:flex;align-items:center;flex-direction:column}.tk-loading .tk-loading_text{margin:10px}.tk-image{position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;vertical-align:middle;width:300px;height:225px}.tk-image .tk-image_inner{width:100%;height:100%}.tk-button{display:inline-flex;align-items:center;justify-content:center}.tk-button.tk-button--small{height:24px}.tk-button.tk-button--middle{height:32px}.tk-button.tk-button--large{height:40px}.tk-button .tk-button--content{color:#606266;font-size:14px;font-weight:500}.tk-button.tk-circle.tk-button--small{width:24px}.tk-button.tk-circle.tk-button--default{width:32px}.tk-button.tk-circle.tk-button--large{width:40px}.btn-content[data-v-135d060f],.btn-content[data-v-f92abf93]{display:flex;flex-direction:column;align-items:center}.tk-text{display:inline-block;overflow:hidden;text-align:center;line-height:normal;white-space:nowrap;font-weight:400;font-size:14px;color:#303133}.tk-text.tk-text--line-clamp{display:-webkit-inline-box;-webkit-box-orient:vertical;white-space:normal}.btn-content[data-v-4c3a35f0]{display:flex;flex-direction:column;align-items:center}.top-bar-container[data-v-b040a138]{position:absolute;z-index:2;width:100%;height:5.8%;display:flex;align-items:center}.tk-overlay{position:fixed;left:0;top:0;bottom:0;width:100%}.tk-overlay .tk-overlay_mask-container{width:100%;height:100%;z-index:0;position:absolute}.tk-overlay .tk-overlay_mask{position:absolute;left:0;top:0;right:0;bottom:0;background-color:#00000080;z-index:1}.tk-overlay .tk-overlay_slot{position:absolute;left:0;right:0;top:0;bottom:0;z-index:1;display:flex;justify-content:center}.tk-avatar{display:inline-flex;justify-content:center;align-items:center;box-sizing:border-box;text-align:center;overflow:hidden;color:#fff;background:#c0c4cc;width:40px;height:40px;font-size:14px}.tk-avatar.tk-avatar--square{border-radius:4px}.tk-avatar.tk-avatar--circle{border-radius:100%}.tk-avatar .tk-avatar_img,.tk-avatar .tk-avatar_image{width:100%;height:100%}.mic-container[data-v-ea062939]{position:relative;width:24px;height:24px}.mic-container .mic-level-container[data-v-ea062939]{position:absolute;left:6px;width:8px;height:14px;display:flex;flex-wrap:wrap;border-radius:4px;overflow:hidden;flex-direction:column-reverse;justify-content:space-between}.mic-container .mic-level-container .mic-level[data-v-ea062939]{width:100%;background-color:#27c39f;transition:height .2s}.overlay-stream-container.mobile .overlay-stream-content-container[data-v-34807212]{width:100%;top:26%;position:
|
|||
|
import { TUICallEvent as R, TUICallEngine as ho } from "tuicall-engine-webrtc";
|
|||
|
import { TUICore as ye, TUIConstants as dA, TUILogin as Lo } from "@tencentcloud/tui-core";
|
|||
|
import Vt from "@tencentcloud/chat";
|
|||
|
import { inject as VA, ref as p, onMounted as CA, onUnmounted as DA, toRefs as G, watch as uA, computed as S, version as st, defineComponent as f, provide as OA, openBlock as d, createElementBlock as y, normalizeClass as k, unref as l, normalizeStyle as eA, renderSlot as q, createElementVNode as L, createBlock as U, toDisplayString as W, createCommentVNode as z, Fragment as RA, createVNode as C, withCtx as E, createTextVNode as NA, watchEffect as ue, renderList as ce, toRef as ct, resolveComponent as ea, Teleport as Eo, withDirectives as sA, vShow as cA, withModifiers as pe, nextTick as mo, mergeProps as bt, normalizeProps as zo, withKeys as Uo, render as Ue, Transition as fo, reactive as Be } from "vue";
|
|||
|
var u = /* @__PURE__ */ ((a) => (a.CALL = "call", a.CUSTOM = "custom", a))(u || {}), _ = /* @__PURE__ */ ((a) => (a[a.UNKNOWN = 0] = "UNKNOWN", a[a.AUDIO = 1] = "AUDIO", a[a.VIDEO = 2] = "VIDEO", a))(_ || {}), IA = /* @__PURE__ */ ((a) => (a.UNKNOWN = "unknown", a.CALLEE = "callee", a.CALLER = "caller", a))(IA || {}), P = /* @__PURE__ */ ((a) => (a.IDLE = "idle", a.CALLING = "calling", a.CONNECTED = "connected", a))(P || {}), fe = /* @__PURE__ */ ((a) => (a.CONTAIN = "contain", a.COVER = "cover", a.FILL = "fill", a))(fe || {}), ve = /* @__PURE__ */ ((a) => (a.RESOLUTION_480P = "480p", a.RESOLUTION_720P = "720p", a.RESOLUTION_1080P = "1080p", a))(ve || {}), ta = /* @__PURE__ */ ((a) => (a.EN = "en", a["ZH-CN"] = "zh-cn", a.JA_JP = "ja_JP", a))(ta || {});
|
|||
|
const jA = {
|
|||
|
IDLE: "idle",
|
|||
|
BE_INVITED: "be-invited",
|
|||
|
DIALING_C2C: "dialing-c2c",
|
|||
|
DIALING_GROUP: "dialing-group",
|
|||
|
CALLING_C2C_AUDIO: "calling-c2c-audio",
|
|||
|
CALLING_C2C_VIDEO: "calling-c2c-video",
|
|||
|
CALLING_GROUP_AUDIO: "calling-group-audio",
|
|||
|
CALLING_GROUP_VIDEO: "calling-group-video"
|
|||
|
}, vo = {
|
|||
|
unknown: 0,
|
|||
|
audio: 1,
|
|||
|
video: 2
|
|||
|
/* VIDEO */
|
|||
|
};
|
|||
|
var je = /* @__PURE__ */ ((a) => (a.EAR = "ear", a.SPEAKER = "speaker", a))(je || {}), hA = /* @__PURE__ */ ((a) => (a.MICROPHONE = "microphone", a.CAMERA = "camera", a.SPEAKER = "speaker", a))(hA || {}), we = /* @__PURE__ */ ((a) => (a[a.FRONT = 0] = "FRONT", a[a.BACK = 1] = "BACK", a))(we || {}), _A = /* @__PURE__ */ ((a) => (a.Camera = "camera", a.Microphone = "microphone", a.SwitchCamera = "switchCamera", a.InviteUser = "inviteUser", a))(_A || {}), Te = /* @__PURE__ */ ((a) => (a.Open = "open", a.Close = "close", a))(Te || {}), GA = /* @__PURE__ */ ((a) => (a.LOCAL = "local", a.REMOTE = "remote", a))(GA || {}), Xe = /* @__PURE__ */ ((a) => (a.LocalInLargeView = "local", a.RemoteInLargeView = "remote", a))(Xe || {}), Ie = /* @__PURE__ */ ((a) => (a[a.INVITE = 1] = "INVITE", a[a.CANCEL_INVITE = 2] = "CANCEL_INVITE", a[a.ACCEPT_INVITE = 3] = "ACCEPT_INVITE", a[a.REJECT_INVITE = 4] = "REJECT_INVITE", a[a.INVITE_TIMEOUT = 5] = "INVITE_TIMEOUT", a))(Ie || {});
|
|||
|
const xt = {
|
|||
|
SWITCH_TO_AUDIO_CALL_FAILED: 60001,
|
|||
|
SWITCH_TO_VIDEO_CALL_FAILED: 60002,
|
|||
|
MICROPHONE_UNAVAILABLE: 60003,
|
|||
|
CAMERA_UNAVAILABLE: 60004,
|
|||
|
BAN_DEVICE: 60005,
|
|||
|
NOT_SUPPORTED_WEBRTC: 60006,
|
|||
|
ERROR_BLACKLIST: 20007
|
|||
|
}, wo = {
|
|||
|
SWITCH_TO_AUDIO_CALL_FAILED: "switchToAudioCall-call-failed",
|
|||
|
SWITCH_TO_VIDEO_CALL_FAILED: "switchToVideoCall-call-failed",
|
|||
|
MICROPHONE_UNAVAILABLE: "microphone-unavailable",
|
|||
|
CAMERA_UNAVAILABLE: "camera-unavailable",
|
|||
|
BAN_DEVICE: "ban-device",
|
|||
|
NOT_SUPPORTED_WEBRTC: "not-supported-webrtc",
|
|||
|
ERROR_BLACKLIST: "blacklist-user-tips"
|
|||
|
};
|
|||
|
var aa = /* @__PURE__ */ ((a) => (a[a.NORMAL = 0] = "NORMAL", a[a.RELEASE = 1] = "RELEASE", a[a.WARNING = 2] = "WARNING", a[a.ERROR = 3] = "ERROR", a[a.NONE = 4] = "NONE", a))(aa || {});
|
|||
|
const Fe = {
|
|||
|
CALL_STATUS: "callStatus",
|
|||
|
CALL_ROLE: "callRole",
|
|||
|
CALL_MEDIA_TYPE: "callMediaType",
|
|||
|
LOCAL_USER_INFO: "localUserInfo",
|
|||
|
LOCAL_USER_INFO_EXCLUDE_VOLUMN: "localUserInfoExcludeVolume",
|
|||
|
REMOTE_USER_INFO_LIST: "remoteUserInfoList",
|
|||
|
REMOTE_USER_INFO_EXCLUDE_VOLUMN_LIST: "remoteUserInfoExcludeVolumeList",
|
|||
|
CALLER_USER_INFO: "callerUserInfo",
|
|||
|
IS_GROUP: "isGroup",
|
|||
|
CALL_DURATION: "callDuration",
|
|||
|
CALL_TIPS: "callTips",
|
|||
|
TOAST_INFO: "toastInfo",
|
|||
|
IS_MINIMIZED: "isMinimized",
|
|||
|
ENABLE_FLOAT_WINDOW: "enableFloatWindow",
|
|||
|
BIG_SCREEN_USER_ID: "bigScreenUserId",
|
|||
|
LANGUAGE: "language",
|
|||
|
IS_CLICKABLE: "isClickable",
|
|||
|
DISPLAY_MODE: "displayMode",
|
|||
|
VIDEO_RESOLUTION: "videoResolution",
|
|||
|
PUSHER: "pusher",
|
|||
|
PLAYER: "player",
|
|||
|
IS_EAR_PHONE: "isEarPhone",
|
|||
|
IS_MUTE_SPEAKER: "isMuteSpeaker",
|
|||
|
SHOW_PERMISSION_TIP: "SHOW_PERMISSION_TIP",
|
|||
|
NETWORK_STATUS: "NetWorkStatus",
|
|||
|
GROUP_ID: "groupID",
|
|||
|
ROOM_ID: "roomID",
|
|||
|
ROOM_ID_TYPE: "roomIdType",
|
|||
|
SHOW_SELECT_USER: "showSelectUser",
|
|||
|
IS_SHOW_ENABLE_VIRTUAL_BACKGROUND: "isShowEnableVirtualBackground",
|
|||
|
ENABLE_VIRTUAL_BACKGROUND: "enableVirtualBackground",
|
|||
|
GROUP_CALL_MEMBERS: "groupCallMembers",
|
|||
|
PUSHER_ID: "pusherId"
|
|||
|
}, Oo = {
|
|||
|
INNER_ATTR_KIT_INFO: "inner_attr_kit_info"
|
|||
|
}, Vo = {
|
|||
|
INITIAL_PUSHER: "initialPusher",
|
|||
|
NEW_PUSHER: "newPusher"
|
|||
|
}, i = {
|
|||
|
PREFIX: "【CallService】",
|
|||
|
AUDIO: "audio",
|
|||
|
VIDEO: "video",
|
|||
|
LOCAL_VIDEO: "localVideo",
|
|||
|
ERROR: "error",
|
|||
|
TIMEOUT: "timeout",
|
|||
|
RAF: "raf",
|
|||
|
INTERVAL: "interval",
|
|||
|
DEFAULT: "default",
|
|||
|
BOOLEAN: "boolean",
|
|||
|
STRING: "string",
|
|||
|
NUMBER: "number",
|
|||
|
OBJECT: "object",
|
|||
|
ARRAY: "array",
|
|||
|
FUNCTION: "function",
|
|||
|
UNDEFINED: "undefined",
|
|||
|
UNKNOWN: "unknown",
|
|||
|
ALL: "all",
|
|||
|
MYSELF: "myself",
|
|||
|
DEVICE_LIST: "deviceList",
|
|||
|
CAMERA_POSITION: "cameraPosition",
|
|||
|
CUSTOM_UI_CONFIG: "customUIConfig",
|
|||
|
...Vo,
|
|||
|
...Fe,
|
|||
|
...Oo
|
|||
|
}, bo = "https://web.sdk.qcloud.com/component/TUIKit/assets/call.png", xo = "https://web.sdk.qcloud.com/component/TUIKit/assets/call-video-reverse.svg", kt = 2147483647, ko = 3, Ro = 4;
|
|||
|
var gt = /* @__PURE__ */ ((a) => (a.MAC = "mac", a.WIN = "win", a))(gt || {}), ht = /* @__PURE__ */ ((a) => (a[a.TUI_CALL_KIT = 14] = "TUI_CALL_KIT", a[a.TIM_CALL_KIT = 15] = "TIM_CALL_KIT", a))(ht || {}), Tt = /* @__PURE__ */ ((a) => (a[a.NUMBER_ROOM_ID = 1] = "NUMBER_ROOM_ID", a[a.STRING_ROOM_ID = 2] = "STRING_ROOM_ID", a))(Tt || {});
|
|||
|
async function Bo(a) {
|
|||
|
if (!a)
|
|||
|
return !1;
|
|||
|
try {
|
|||
|
const A = await new Promise((e, t) => {
|
|||
|
const o = new XMLHttpRequest();
|
|||
|
o.open("HEAD", a, !0), o.onload = () => e(o), o.onerror = () => t(o), o.send();
|
|||
|
});
|
|||
|
return A.status === 200 && A.getResponseHeader("Content-Type") === "audio/mpeg";
|
|||
|
} catch (A) {
|
|||
|
return console.warn(A), !1;
|
|||
|
}
|
|||
|
}
|
|||
|
function qe(a) {
|
|||
|
if (typeof a != "object" || a === null)
|
|||
|
return a;
|
|||
|
let A = Array.isArray(a) ? [] : {};
|
|||
|
for (let e in a)
|
|||
|
a.hasOwnProperty(e) && (A[e] = qe(a[e]));
|
|||
|
return A;
|
|||
|
}
|
|||
|
const Po = {
|
|||
|
// 按钮文案
|
|||
|
hangup: "Hang up",
|
|||
|
reject: "Decline",
|
|||
|
accept: "Accept",
|
|||
|
camera: "Camera",
|
|||
|
microphone: "Microphone",
|
|||
|
speaker: "speaker",
|
|||
|
"open camera": "Open Camera",
|
|||
|
"close camera": "Close Camera",
|
|||
|
"open microphone": "Open Microphone",
|
|||
|
"close microphone": "Close Microphone",
|
|||
|
"video-to-audio": "Switch to audio",
|
|||
|
"virtual-background": "Blur Background",
|
|||
|
// 通话结果
|
|||
|
"other side reject call": "other side reject call",
|
|||
|
"reject call": "Reject Call",
|
|||
|
cancel: "Cancel Call",
|
|||
|
"other side line busy": "other side line busy",
|
|||
|
"in busy": "in busy",
|
|||
|
"call timeout": "call timeout",
|
|||
|
"no response from the other side": "no response from the other side",
|
|||
|
"end call": "end call",
|
|||
|
// 通话提示语
|
|||
|
"caller calling message": "Awaiting response",
|
|||
|
"callee calling video message": "invites you to a video call",
|
|||
|
"callee calling audio message": "invites you to a voice call",
|
|||
|
"no microphone access": "no microphone access",
|
|||
|
"no camera access": "no camera access",
|
|||
|
"invite member": "Invite Member",
|
|||
|
"Invited group call": "invites you to a group call",
|
|||
|
waiting: "Calling...",
|
|||
|
me: "(me)",
|
|||
|
// 弹出层文案
|
|||
|
"browser-authorization": "Browser authorization",
|
|||
|
"mac-privacy": "System Preferences -> Security and Privacy -> Privacy",
|
|||
|
"win-privacy": "Setting -> Privacy and Security -> App permissions",
|
|||
|
"mac-preferences": "Open System Preferences",
|
|||
|
"win-preferences": "Open Setting",
|
|||
|
"Please enter userID": "Please enter userID",
|
|||
|
"View more": "View more",
|
|||
|
"people selected": "people selected",
|
|||
|
"Select all": "Select all",
|
|||
|
Cancel: "Cancel",
|
|||
|
Done: "Done",
|
|||
|
"exist group call": "A group call already exists in the current group",
|
|||
|
// UI3.0 新增
|
|||
|
"camera enabled": "Camera On",
|
|||
|
"camera disabled": "Camera Off",
|
|||
|
"microphone enabled": "Unmuted",
|
|||
|
"microphone disabled": "Muted",
|
|||
|
"speaker enabled": "Speaker On",
|
|||
|
"speaker disabled": "Speaker Off",
|
|||
|
"open speaker": "Turn on speaker",
|
|||
|
"close speaker": "Turn off speaker",
|
|||
|
"wait to be called": "Waiting",
|
|||
|
answered: "Connected",
|
|||
|
"people in the call": " other(s) in the call",
|
|||
|
"failed to obtain speakers": "failed to obtain speakers",
|
|||
|
"you have a new call": "You have a new call",
|
|||
|
"switch camera": "Switch",
|
|||
|
join: "Join",
|
|||
|
"people on the call": "people on the call",
|
|||
|
"Supports a maximum of 9 people for simultaneous calls": "Supports a maximum of 9 people for simultaneous calls",
|
|||
|
you: "(you)",
|
|||
|
"The network is poor during your current call": "The network is poor during your current call",
|
|||
|
"The other user network is poor during the current call": "The other party's network is poor during the current call",
|
|||
|
"TUICallKit init is not complete": "TUICallKit init is not complete. You need to use this API after the init API is finished.",
|
|||
|
// combine chat
|
|||
|
"Video call": "Video call",
|
|||
|
"Voice call": "Voice call",
|
|||
|
"Call End": "Call End",
|
|||
|
"Switch voice call": "Switch voice call",
|
|||
|
"Switch video call": "Switch video call",
|
|||
|
"Call duration": "Duration",
|
|||
|
"Call Cancel": "Canceled",
|
|||
|
"Other Side Cancel": "Call canceled by caller",
|
|||
|
Decline: "Declined",
|
|||
|
"Other Side Decline": "Call declined by user",
|
|||
|
"No answer": "Call not answered",
|
|||
|
"Other Side No Answer": "Call wasn't answered",
|
|||
|
Answered: "Answered",
|
|||
|
"Other Side Line Busy": "Line busy",
|
|||
|
"Line Busy": "Line busy. Call not received.",
|
|||
|
// 待废弃文案
|
|||
|
"Those involved": "Those involved in the call are",
|
|||
|
call: "call",
|
|||
|
"video-call": "video call",
|
|||
|
"audio-call": "audio call",
|
|||
|
search: "search",
|
|||
|
"search-result": "search result",
|
|||
|
"no-user": "user not found",
|
|||
|
"member-not-added": "member not added",
|
|||
|
"input-phone-userID": "phone number or userID",
|
|||
|
"not-login": "not logged in",
|
|||
|
"login-status-expire": "login status is invalid, please refresh the page and try again",
|
|||
|
"experience-multi-call": "experience multi-person calls, please download the full-featured demo: ",
|
|||
|
"not-support-multi-call": "multi-person call interface is not open",
|
|||
|
userID: "userID",
|
|||
|
"already-enter": "entered the call",
|
|||
|
"camera-opened": "Camera on",
|
|||
|
"camera-closed": "Camera off",
|
|||
|
"microphone-opened": "Mic on",
|
|||
|
"microphone-closed": "Mic off",
|
|||
|
timeout: "timeout",
|
|||
|
"kick out": "kick out",
|
|||
|
"image-resolution": "Resolution",
|
|||
|
"default-image-resolution": "Default",
|
|||
|
"invited-person": "Invite",
|
|||
|
"be-rejected": "Call declined, ",
|
|||
|
"be-no-response": "No response, ",
|
|||
|
"be-line-busy": "Line busy, ",
|
|||
|
"be-canceled": "The call is canceled, ",
|
|||
|
"voice-call-end": "Voice call ended",
|
|||
|
"video-call-end": "Video call ended",
|
|||
|
"method-call-failed": "Failed to sync the operation",
|
|||
|
"failed-to-obtain-permission": "Failed to obtain permissions",
|
|||
|
"environment-detection-failed": "Failed to check the environment",
|
|||
|
"switchToAudioCall-call-failed": "switch to audio call method failed",
|
|||
|
"switchToVideoCall-call-failed": "switch to video call method failed",
|
|||
|
"microphone-unavailable": "No mic found",
|
|||
|
"camera-unavailable": "No camera found",
|
|||
|
"ban-device": "Device access denied",
|
|||
|
"not-supported-webrtc": "Your current environment does not support WebRTC",
|
|||
|
"blacklist-user-tips": "The identifier is in blacklist. Failed to send this message!",
|
|||
|
"is-already-calling": "TUICallKit is already on a call",
|
|||
|
"need-init": "Before initiating a call with TUICallKit, ensure that the TUICallKitServer.init() method has executed successfully. ",
|
|||
|
"can't call yourself": "Can't call yourself",
|
|||
|
// eslint-disable-line
|
|||
|
"Use-phone-and-computer": "Use your mobile phone and computer to experience video calls",
|
|||
|
"Wechat scan right QR code": "Wechat scan right QR code",
|
|||
|
"Scan the QR code above": "Scan the QR code above",
|
|||
|
"accept-error": "Accept failed",
|
|||
|
"accept-device-error": "Accept failed, unable to auth calling device",
|
|||
|
"call-error": "Start call failed"
|
|||
|
}, Wo = {
|
|||
|
// 按钮文案
|
|||
|
hangup: "挂断",
|
|||
|
reject: "拒绝",
|
|||
|
accept: "接受",
|
|||
|
camera: "摄像头",
|
|||
|
microphone: "麦克风",
|
|||
|
speaker: "扬声器",
|
|||
|
"open camera": "打开摄像头",
|
|||
|
"close camera": "关闭摄像头",
|
|||
|
"open microphone": "打开麦克风",
|
|||
|
"close microphone": "关闭麦克风",
|
|||
|
"video-to-audio": "转语音通话",
|
|||
|
"virtual-background": "模糊背景",
|
|||
|
// 通话结果
|
|||
|
"other side reject call": "对方已拒绝",
|
|||
|
"reject call": "拒绝通话",
|
|||
|
cancel: "取消通话",
|
|||
|
"other side line busy": "对方忙线",
|
|||
|
"in busy": "正在忙",
|
|||
|
"call timeout": "呼叫超时",
|
|||
|
"end call": "结束通话",
|
|||
|
// 通话提示语
|
|||
|
"caller calling message": "等待对方接受邀请",
|
|||
|
"callee calling video message": "邀请你视频通话",
|
|||
|
"callee calling audio message": "邀请你语音通话",
|
|||
|
"no microphone access": "没有麦克风权限",
|
|||
|
"no camera access": "没有摄像头权限",
|
|||
|
"invite member": "邀请成员",
|
|||
|
"Invited group call": "邀请你加入多人通话",
|
|||
|
"Those involved": "参与通话的有:",
|
|||
|
waiting: "等待接听...",
|
|||
|
me: "(我)",
|
|||
|
// 弹出层文案
|
|||
|
"browser-authorization": "浏览器授权",
|
|||
|
"mac-privacy": "系统偏好设置 -> 安全与隐私 -> 隐私",
|
|||
|
"win-privacy": "设置 -> 隐私和安全性 -> 应用权限",
|
|||
|
"mac-preferences": "打开系统偏好设置",
|
|||
|
"win-preferences": "打开系统设置",
|
|||
|
"Please enter userID": "请输入 userID",
|
|||
|
"View more": "查看更多",
|
|||
|
"people selected": "人已选中",
|
|||
|
"Select all": "全选",
|
|||
|
Cancel: "取消",
|
|||
|
Done: "完成",
|
|||
|
"exist group call": "当前群组中已经存在群组通话",
|
|||
|
// UI3.0 新增
|
|||
|
"camera enabled": "摄像头已开",
|
|||
|
"camera disabled": "摄像头已关",
|
|||
|
"microphone enabled": "麦克风已开",
|
|||
|
"microphone disabled": "麦克风已关",
|
|||
|
"speaker enabled": "扬声器已开",
|
|||
|
"speaker disabled": "扬声器已关",
|
|||
|
"open speaker": "开启扬声器",
|
|||
|
"close speaker": "关闭扬声器",
|
|||
|
"wait to be called": "等待接听",
|
|||
|
answered: "已接通",
|
|||
|
"people in the call": "人参与通话",
|
|||
|
"failed to obtain speakers": "无法获取扬声器",
|
|||
|
"you have a new call": "您有一个新的通话",
|
|||
|
"switch camera": "翻转",
|
|||
|
join: "加入",
|
|||
|
"people on the call": "人正在通话",
|
|||
|
"Supports a maximum of 9 people for simultaneous calls": "最多支持9人同时通话",
|
|||
|
you: "(你)",
|
|||
|
"The network is poor during your current call": "当前通话你的网络不佳",
|
|||
|
"The other user network is poor during the current call": "当前通话对方网络不佳",
|
|||
|
"TUICallKit init is not complete": "TUICallKit 初始化登录未完成,需要在 init 完成后使用此 API",
|
|||
|
// combine chat
|
|||
|
"Video call": "发起视频通话",
|
|||
|
"Voice call": "发起语音通话",
|
|||
|
"Call End": "通话结束",
|
|||
|
"Switch voice call": "切换语音通话",
|
|||
|
"Switch video call": "切换视频通话",
|
|||
|
"Call duration": "通话时长",
|
|||
|
"Call Cancel": "已取消",
|
|||
|
"Other Side Cancel": "对方已取消",
|
|||
|
Decline: "已拒绝",
|
|||
|
"Other Side Decline": "对方已拒绝",
|
|||
|
"No answer": "超时无应答",
|
|||
|
"Other Side No Answer": "对方无应答",
|
|||
|
Answered: "已接听",
|
|||
|
"Other Side Line Busy": "对方忙线中",
|
|||
|
"Line Busy": "忙线无应答",
|
|||
|
// 待废弃文案
|
|||
|
timeout: "超时",
|
|||
|
"kick out": "被踢",
|
|||
|
call: "通话",
|
|||
|
"video-call": "视频通话",
|
|||
|
"audio-call": "音频通话",
|
|||
|
search: "搜索",
|
|||
|
"search-result": "搜索结果",
|
|||
|
"Wechat scan right QR code": "微信扫右二维码",
|
|||
|
"Use-phone-and-computer": "用手机与电脑互打体验视频通话",
|
|||
|
"Scan the QR code above": "扫描上方二维码",
|
|||
|
"no-user": "未搜索到用户",
|
|||
|
"member-not-added": "未添加成员",
|
|||
|
"not-login": "未登录",
|
|||
|
"login-status-expire": "登录状态已失效,请刷新网页重试",
|
|||
|
"experience-multi-call": "体验多人通话请下载全功能demo:",
|
|||
|
"not-support-multi-call": "多人通话接口未开放",
|
|||
|
"input-phone-userID": "请输入手机号/用户ID",
|
|||
|
userID: "用户ID",
|
|||
|
"already-enter": "已经进入当前通话",
|
|||
|
"image-resolution": "分辨率",
|
|||
|
"default-image-resolution": "默认分辨率",
|
|||
|
"invited-person": "添加成员",
|
|||
|
"be-rejected": "对方已拒绝,",
|
|||
|
"be-no-response": "对方无应答,",
|
|||
|
"be-line-busy": "对方忙线中,",
|
|||
|
"be-canceled": "对方已取消",
|
|||
|
"voice-call-end": "语音通话结束",
|
|||
|
"video-call-end": "视频通话结束",
|
|||
|
"method-call-failed": "同步操作失败",
|
|||
|
"failed-to-obtain-permission": "权限获取失败",
|
|||
|
"environment-detection-failed": "环境检测失败",
|
|||
|
"switchToAudioCall-call-failed": "切语音调用失败",
|
|||
|
"switchToVideoCall-call-failed": "切视频调用失败",
|
|||
|
"microphone-unavailable": "没有可用的麦克风设备",
|
|||
|
"camera-unavailable": "没有可用的摄像头设备",
|
|||
|
"ban-device": "用户禁止使用设备",
|
|||
|
"not-supported-webrtc": "当前环境不支持 WebRTC",
|
|||
|
"blacklist-user-tips": "发起通话失败,被对方拉入黑名单,禁止发起!",
|
|||
|
"is-already-calling": "TUICallKit 已在通话状态",
|
|||
|
"need-init": "TUICallKit 发起通话前需保证 TUICallKitServer.init() 方法执行成功",
|
|||
|
"can't call yourself": "不能呼叫自己",
|
|||
|
// eslint-disable-line
|
|||
|
"accept-error": "接通失败",
|
|||
|
"accept-device-error": "接通失败,通话设备获取失败",
|
|||
|
"call-error": "发起通话失败"
|
|||
|
}, Go = {
|
|||
|
// 按钮文案
|
|||
|
hangup: "通話終了",
|
|||
|
reject: "拒否",
|
|||
|
accept: "応答",
|
|||
|
camera: "カメラ",
|
|||
|
microphone: "マイク",
|
|||
|
speaker: "スピーカー",
|
|||
|
"virtual-background": "ボケ背景",
|
|||
|
// 通话结果
|
|||
|
"other side reject call": "通話が拒否されました",
|
|||
|
"reject call": "通話拒否",
|
|||
|
cancel: "通話をキャンセル",
|
|||
|
"other side line busy": "相手が通話中です",
|
|||
|
"in busy": "通話中",
|
|||
|
"call timeout": "呼び出しタイムアウト",
|
|||
|
"end call": "通話終了",
|
|||
|
// 通话提示语
|
|||
|
"caller calling message": "応答を待っています",
|
|||
|
"callee calling video message": "ビデオ通話に招待されました",
|
|||
|
"callee calling audio message": "音声通話に招待されました",
|
|||
|
"no microphone access": "マイクにアクセスできません",
|
|||
|
"no camera access": "カメラにアクセスできません",
|
|||
|
"invite member": "メンバーを招待する",
|
|||
|
// 弹出层文案
|
|||
|
"browser-authorization": "ブラウザ認証",
|
|||
|
"mac-privacy": "システム環境設定 -> セキュリティとプライバシー ->プライバシー",
|
|||
|
"win-privacy": "設定 -> セキュリティとプライバシー ->アプリのアクセス許可",
|
|||
|
"mac-preferences": "システム環境設定を開く",
|
|||
|
"win-preferences": "システム設定を開く",
|
|||
|
"Please enter userID": "ユーザーIDを入力してください",
|
|||
|
"View more": "もっと見る",
|
|||
|
"people selected": "人が選択されました",
|
|||
|
"Select all": "すべて選択",
|
|||
|
Cancel: "キャンセル",
|
|||
|
Done: "完了",
|
|||
|
"exist group call": "現在のグループには既にグループ通話が存在しています",
|
|||
|
// combine chat
|
|||
|
"Video call": "ビデオ通話を開始",
|
|||
|
"Voice call": "音声通話を開始",
|
|||
|
"Call End": "通話終了",
|
|||
|
"Switch audio call": "音声通話に切り替える",
|
|||
|
"Switch video call": "ビデオ通話に切り替える",
|
|||
|
"Call duration": "通話時間",
|
|||
|
"Call Cancel": "通話をキャンセルする",
|
|||
|
"Other Side Cancel": "相手がキャンセルしました",
|
|||
|
Decline: "通話を拒否する",
|
|||
|
"Other Side Decline": "相手が拒否しました",
|
|||
|
"No answer": "無応答",
|
|||
|
"Other Side No Answer": "相手からの返答はありません",
|
|||
|
Answered: "応答しました",
|
|||
|
"Other Side Line Busy": "相手は現在忙しくて対応できません",
|
|||
|
"Line Busy": "忙しいので応答できません",
|
|||
|
// UI3.0文案
|
|||
|
"open camera": "オープンカメラ",
|
|||
|
"close camera": "カメラを閉じる",
|
|||
|
"open microphone": "オープンマイク",
|
|||
|
"close microphone": "マイクを閉じる",
|
|||
|
"camera enabled": "カメラオン",
|
|||
|
"camera disabled": "カメラオフ",
|
|||
|
"microphone enabled": "マイクオン",
|
|||
|
"microphone disabled": "マイクオフ",
|
|||
|
"speaker enabled": "スピーカーオン",
|
|||
|
"speaker disabled": "スピーカーオフ",
|
|||
|
"open speaker": "スピーカーをオンにする",
|
|||
|
"close speaker": "スピーカーの電源を切ります",
|
|||
|
"wait to be called": "待機中",
|
|||
|
answered: "接続済み",
|
|||
|
"people in the call": "通話に参加している人たち",
|
|||
|
"failed to obtain speakers": "スピーカーが見つかりません",
|
|||
|
"you have a new call": "新しい通話があります",
|
|||
|
"switch camera": "切り替え",
|
|||
|
join: "参加する",
|
|||
|
"people on the call": "人が通話中です",
|
|||
|
"Supports a maximum of 9 people for simultaneous calls": "最大で9人まで同時通話が可能です",
|
|||
|
you: "(あなた)",
|
|||
|
"The network is poor during your current call": "現在の通話で、あなたのネットワークは不良です",
|
|||
|
"The other user network is poor during the current call": "現在の通話で、相手側のネットワークが不良です",
|
|||
|
"TUICallKit init is not complete": "TUICallKitの初期化ログインが完了していません。init が完了した後にこのAPIを使用する必要があります。",
|
|||
|
// 待废弃文案
|
|||
|
timeout: "タイムアウト",
|
|||
|
"kick out": "キックアウトされました",
|
|||
|
"Invited group call": "グループ通話に招待されました。",
|
|||
|
"Those involved": "参加者:",
|
|||
|
call: "通話",
|
|||
|
"video-call": "ビデオ通話",
|
|||
|
"audio-call": "音声通話",
|
|||
|
search: "検索",
|
|||
|
"search-result": "検索結果",
|
|||
|
"Wechat scan right QR code": "WeChatで右側にあるQRコードを読み取ります。",
|
|||
|
"Use-phone-and-computer": "携帯電話とコンピュータを使用してビデオ通話を体験してください",
|
|||
|
"Scan the QR code above": "上のQRコードを読み取ります。",
|
|||
|
"no-user": "ユーザーが見つかりませんでした",
|
|||
|
"member-not-added": "メンバーが追加されていません",
|
|||
|
"not-login": "ログインしていません",
|
|||
|
"login-status-expire": "ログインの有効期限が過ぎています。ページを更新してもう一度お試しください",
|
|||
|
"experience-multi-call": "複数人で同時に音声通話できるグループ通話機能を体験するには、全機能のデモをダウンロードしてください",
|
|||
|
"not-support-multi-call": "グループ通話インターフェイスが開いていません",
|
|||
|
"input-phone-userID": "携帯電話番号/ユーザーIDを入力してください",
|
|||
|
userID: "ユーザーID",
|
|||
|
"already-enter": "すでに通話に参加しています",
|
|||
|
waiting: "応答を待っています...",
|
|||
|
"camera-opened": "カメラがオンになっています",
|
|||
|
"camera-closed": "カメラがオフになっています",
|
|||
|
"microphone-opened": "マイクがオンになっています",
|
|||
|
"microphone-closed": "マイクがオフになっています",
|
|||
|
"image-resolution": "解像度",
|
|||
|
"default-image-resolution": "デフォルト解像度",
|
|||
|
"invited-person": "メンバーを招待",
|
|||
|
"video-to-audio": "音声通話に切り替えます",
|
|||
|
me: "(自分)",
|
|||
|
"be-rejected": "通話が拒否されました, ",
|
|||
|
"be-no-response": "応答なし, ",
|
|||
|
"be-line-busy": "相手が通話中です, ",
|
|||
|
"be-canceled": "相手が通話をキャンセルしました",
|
|||
|
"voice-call-end": "音声通話が終了しました",
|
|||
|
"video-call-end": "ビデオ通話が終了しました",
|
|||
|
"method-call-failed": "操作の同期に失敗しました",
|
|||
|
"failed-to-obtain-permission": "権限の取得に失敗しました",
|
|||
|
"environment-detection-failed": "環境の検出に失敗しました",
|
|||
|
"switchToAudioCall-call-failed": "音声通話に切り替えることはできません",
|
|||
|
"switchToVideoCall-call-failed": "ビデオ通話に切り替えることはできません",
|
|||
|
"microphone-unavailable": "使用できるマイクがありません",
|
|||
|
"camera-unavailable": "使用できるカメラがありません",
|
|||
|
"ban-device": "デバイスへのアクセスが拒否されました",
|
|||
|
"not-supported-webrtc": "現在の環境はWebRTCをサポートしていません",
|
|||
|
"blacklist-user-tips": "ユーザーはブラックリストに登録され、通話が開始できませんでした",
|
|||
|
"is-already-calling": "TUICallKit はすでに通話中です",
|
|||
|
"need-init": "TUICallKitで通話を開始する前に、TUICallKitServer.init() メソッドが正常に実行されたことを確認してください。",
|
|||
|
"can't call yourself": "自分に電話をかけることができません",
|
|||
|
"accept-error": "接続できませんでした",
|
|||
|
"accept-device-error": "接続できませんでした。発信側デバイスを認証できません",
|
|||
|
"call-error": "通話が開始できませんでした"
|
|||
|
}, EA = {
|
|||
|
OTHER_SIDE: "other side",
|
|||
|
CANCEL: "cancel",
|
|||
|
OTHER_SIDE_REJECT_CALL: "other side reject call",
|
|||
|
REJECT_CALL: "reject call",
|
|||
|
OTHER_SIDE_LINE_BUSY: "other side line busy",
|
|||
|
IN_BUSY: "in busy",
|
|||
|
CALL_TIMEOUT: "call timeout",
|
|||
|
END_CALL: "end call",
|
|||
|
TIMEOUT: "timeout",
|
|||
|
KICK_OUT: "kick out",
|
|||
|
CALLER_CALLING_MSG: "caller calling message",
|
|||
|
CALLER_GROUP_CALLING_MSG: "wait to be called",
|
|||
|
CALLEE_CALLING_VIDEO_MSG: "callee calling video message",
|
|||
|
CALLEE_CALLING_AUDIO_MSG: "callee calling audio message",
|
|||
|
NO_MICROPHONE_DEVICE_PERMISSION: "no microphone access",
|
|||
|
NO_CAMERA_DEVICE_PERMISSION: "no camera access",
|
|||
|
EXIST_GROUP_CALL: "exist group call",
|
|||
|
LOCAL_NETWORK_IS_POOR: "The network is poor during your current call",
|
|||
|
REMOTE_NETWORK_IS_POOR: "The other user network is poor during the current call"
|
|||
|
}, Rt = {
|
|||
|
en: Po,
|
|||
|
"zh-cn": Wo,
|
|||
|
ja_JP: Go
|
|||
|
};
|
|||
|
function v(a) {
|
|||
|
var t;
|
|||
|
const A = g.getData(u.CALL, i.LANGUAGE);
|
|||
|
for (const o in Rt)
|
|||
|
if (o === A) {
|
|||
|
const n = Rt[o];
|
|||
|
for (const s in n)
|
|||
|
if (s === a)
|
|||
|
return n[s];
|
|||
|
}
|
|||
|
const e = (t = a.en) == null ? void 0 : t.key;
|
|||
|
return console.error(`${i.PREFIX}translation is not found: ${a}.`), e;
|
|||
|
}
|
|||
|
const Je = typeof wx < "u" && typeof wx.getSystemInfoSync == "function" && !!wx.getSystemInfoSync().fontSizeSetting, oa = typeof uni < "u" && typeof uni > "u", Bt = Je || oa, la = typeof uni < "u", na = function() {
|
|||
|
return (typeof uni < "u" || typeof window < "u") && !Bt;
|
|||
|
}(), Qo = function() {
|
|||
|
return Je ? wx : la ? uni : window;
|
|||
|
}(), $A = na && window && window.navigator && window.navigator.userAgent || "", Zo = /Android/i.test($A), Fo = /(?:Windows Phone)/.test($A), Yo = /(?:SymbianOS)/.test($A), Xo = /iPad/i.test($A) || /iPhone/i.test($A) || /iPod/i.test($A), ia = Zo || Fo || Yo || Xo, Lt = na && !ia, qo = Lt && $A.includes("Windows NT"), Jo = Lt && $A.includes("Mac");
|
|||
|
let sa = class he {
|
|||
|
constructor() {
|
|||
|
this.global = Qo, this.isPC = !1, this.isH5 = !1, this.isWeChat = !1, this.isApp = !1, this.isUniPlatform = !1, this.isOfficial = !1, this.isWIN = !1, this.isMAC = !1, this.initEnv();
|
|||
|
}
|
|||
|
/**
|
|||
|
* 获取 TUIGlobal 实例
|
|||
|
* @returns {TUIGlobal}
|
|||
|
*/
|
|||
|
static getInstance() {
|
|||
|
return he.instance || (he.instance = new he()), he.instance;
|
|||
|
}
|
|||
|
initEnv() {
|
|||
|
this.isPC = Lt, this.isH5 = ia, this.isWeChat = Je, this.isApp = oa && !Je, this.isUniPlatform = la, this.isWIN = qo, this.isMAC = Jo;
|
|||
|
}
|
|||
|
initOfficial(A) {
|
|||
|
this.isOfficial = A === 1400187352 || A === 1400188366;
|
|||
|
}
|
|||
|
};
|
|||
|
const et = function(a) {
|
|||
|
return typeof a === i.UNDEFINED;
|
|||
|
}, ca = function(a) {
|
|||
|
if (typeof a !== i.OBJECT || a === null)
|
|||
|
return !1;
|
|||
|
const A = Object.getPrototypeOf(a);
|
|||
|
if (A === null)
|
|||
|
return !0;
|
|||
|
let e = A;
|
|||
|
for (; Object.getPrototypeOf(e) !== null; )
|
|||
|
e = Object.getPrototypeOf(e);
|
|||
|
return A === e;
|
|||
|
}, ra = function(a) {
|
|||
|
return typeof Array.isArray === i.FUNCTION ? Array.isArray(a) : Object.prototype.toString.call(a).match(/^\[object (.*)\]$/)[1].toLowerCase() === i.ARRAY;
|
|||
|
}, pt = function(a) {
|
|||
|
return typeof a === i.STRING;
|
|||
|
}, Ho = function(a) {
|
|||
|
return typeof a === i.BOOLEAN;
|
|||
|
}, ua = function(a) {
|
|||
|
return (
|
|||
|
// eslint-disable-next-line
|
|||
|
a !== null && (typeof a === i.NUMBER && !isNaN(a - 0) || typeof a === i.OBJECT && a.constructor === Number)
|
|||
|
);
|
|||
|
};
|
|||
|
function Ma(a) {
|
|||
|
const A = Math.floor(a / 3600), e = Math.floor(a % 3600 / 60), t = Math.floor(a % 60);
|
|||
|
let o = A > 9 ? `${A}` : `0${A}`;
|
|||
|
return o += e > 9 ? `:${e}` : `:0${e}`, o += t > 9 ? `:${t}` : `:0${t}`, o;
|
|||
|
}
|
|||
|
function Ko(a) {
|
|||
|
if (typeof a === i.STRING)
|
|||
|
try {
|
|||
|
return !!JSON.parse(a);
|
|||
|
} catch (A) {
|
|||
|
return console.debug(A), !1;
|
|||
|
}
|
|||
|
return !1;
|
|||
|
}
|
|||
|
const Pe = function(a) {
|
|||
|
return !a || !Ko(a) ? a : JSON.parse(a);
|
|||
|
};
|
|||
|
function Pt(a) {
|
|||
|
return (a == null ? void 0 : a.message.indexOf("is ongoing, please avoid repeated calls")) !== -1;
|
|||
|
}
|
|||
|
function _o(a) {
|
|||
|
const { message: A } = a;
|
|||
|
return A.indexOf("NotAllowedError: Permission denied") !== -1;
|
|||
|
}
|
|||
|
function rt() {
|
|||
|
return Date.now();
|
|||
|
}
|
|||
|
const Ye = function(a) {
|
|||
|
return typeof a === i.FUNCTION;
|
|||
|
}, $o = () => {
|
|||
|
if (sa.getInstance().isWeChat)
|
|||
|
return "zh-cn";
|
|||
|
const a = ((navigator == null ? void 0 : navigator.language) || (navigator == null ? void 0 : navigator.userLanguage) || "").substr(0, 2);
|
|||
|
let A = "en";
|
|||
|
switch (a) {
|
|||
|
case "zh":
|
|||
|
A = "zh-cn";
|
|||
|
break;
|
|||
|
case "ja":
|
|||
|
A = "ja_JP";
|
|||
|
break;
|
|||
|
default:
|
|||
|
A = "en";
|
|||
|
}
|
|||
|
return A;
|
|||
|
}, Al = function(a) {
|
|||
|
return Object.prototype.toString.call(a).match(/^\[object (.*)\]$/)[1].toLowerCase();
|
|||
|
};
|
|||
|
function el(a, A, e) {
|
|||
|
if (!a.hasOwnProperty(A))
|
|||
|
return a;
|
|||
|
const t = {};
|
|||
|
return Object.keys(a).forEach((o) => {
|
|||
|
o === A ? t[e] = a[o] : t[o] = a[o];
|
|||
|
}), t;
|
|||
|
}
|
|||
|
const tl = "data:audio/mpeg;base64,SUQzAwAAAAAAGFRYWFgAAAAOAAAAVFhYWABpc29taXNvMv/zNGQAAqwAvnihCAADQAF4CUAQAFYAg3Lh8u+XUD5///wx//wQOAhKAgb/////xOoH4g8Hz4Pq8RoAbdTgMsMt9hcb990EP//zNGQQBPDjEgDItAAFWcIoAYoQAN9P/03QQ//umn//91SXL5uXP+pf8WYTvzgJPAQ+p/7f///1//6f///WH///F4BtJhNFkP/zNGQGA/jjNADHiAAEQDJcAYkQAGWrn6vw6ljfPtj/////////9Pv9sL/mL/QezSepgwrimv07//////y3u602OiyhOYb+LP/zNGQIBKTBKADoCACDoCZMAckAAKHKCUIAFsqGZXtSZ/////////Sn/Vy3nVUOJBqSX2UAkQxBddzv//////yq3lcgaTmTQ//zNGQHA9SrJgA8AliD4C5IAApYAKh3FKlMunKHm8H/2//77vkdqB2xfsXaHiDKBGtFKqONF3/////Z9VXClT5ND+syHkjBq//zNGQLBITJIAA8AmQEiDI4AAjSAGa1Vffm3ff/1/0//11tvZpAaIw3dBiIrjJgHQrGVWmdBU1f/////oDqEKrV1OpBUTjQtv/zNGQHAsjDKAAwAl4D0Co8AAmCBHIQNtld6fm0+/VigZzuMnGZlkAMLMJFv/////33UIWeFQkKsaceBsangecHzYXKI//////zNGQUA4QjKAA3CAID8CpEABMCBPfuStx4FQVHYMgKcO6jIJh//////9uIlspQkGQ2YyZscAV83Bv/////ncL6BEiWHyA2K//zNEQbAogfJgAx5hAEwDJcCAsEBtICgF3/////WJaIuuqMCCVGucgkrtwiwBO//////pW4YFRWQhaRRhZZnVwGhf////+ocv/zNEQmApgVJAANjwAFkC5YCApeAolD4kQb+EQJYNKwLWGmc6sqMBwJvf////6tDEOWDgFJk1VywKMGoM2f////+N1JmgJuPv/zNGQuA4AbJAAl5hIDwC48AAIGBEho7wTL5b6kSO7IUAA5uDABYNNjGDBSJEN//////xtQsszVy27IcWBbQkLgzv7YmZYW///zNGQ2AqzFNAgcA1+D8CZIAAhMAP/3/rozCAsBjIqCY/DBWMfQZp1f/////0F6phXSNisgAJjo6icT2vpvM/Vf9v///97eu//zNGRDA4gdJgBhghIDwCZAABGMAFVWERbCdaMYNCKs///2f//QMOBhFBEL+ykPDBIJgp1sjvOMAd/////1OEsNl3MST2Q0Yf/zNGRKA2DJKAAsBWYD8Co8AAmEBLDHj+M/IhcksnAgg6G+qLIYz5etEeeW8HZsorBzgkAa1AWMPfu/////LaYPuAABp7iKXP/zNGRSA3glKgQJ6QACOCZMAAmGAYUAPF9exl35wz/9DIK2KUmQgYlTwgEEWkm3f////6IVoMJPBkKdWoQnDLurGiesVhdx6f/zNGRgAqizNAQsA20D4B5QAAmEAP/+vjlaZ1RwqBVMJYhaM4sYnFlVf/////6qAEghRzo0nRKQQRlI/EAPkCE6srVAiTUt/f/zNGRuAwCzQMwkAmwDsCpUAAmEAD3e5qf+yS5UwJFzQ145RxpgyI1QrkYnFjlaFdmklTcdAYL/rpcl7an3N18alNr+8+Tjqf/zNGR6BAjHKgQ8AmoDUDZUAADGBHMxO4R8koQnxNohhQoHS/XVF40p6jdPQ7qEIfuLKpUDOmf////2TGDwwTzkh0sePBMWCv/zNGR/BGwnMDxhhhIDyEJQAHpMISk//////0K1gsLiN1WF6ShLE4o14ccxglb//9P/4q5FQOpJkMGwZxhY7oDQW//////sWv/zNGR/A8zBKgRkA22CsC5QABvEAaoDMZE4OYXHboRqlgfr85KzbMjSIgKRUEILJNuHBYDoH//////qgPyBJdUEsYVyTSAteP/zNGSIAzQjLAQ9gxIDwDZMAAmKBLmvo0L///b/2iiK48qOD4gBjCxhQ7AbaCjzm/////+utNUXkYSLUD1SBQS8MECruBT57f/zNGSSA6AhJgAl5gQD0DZIABDGBN5qjnO4MkB4hZ7dh4ffb/////8g+xYWYFUYeDYyhC18k+tOcH4z9f9slvls1HAAcxB95//zNGSYAri9MAgwA16D0CJIADpGANGJmAqH6X//////V13vmwnBdjKbx6RrmMrau4F7wPrWv/p//76f+k81B8eKBCgyNya5jf/zNGSmA9AjJAA97AID6DZEACjEBIYDAEG3//////y7mAIq1aOwiF0rtiCEZJNHhm85SBFNJn63f//b8hnQytnEhqioQHLMDP/zNGSqAwy/KgQ8Al6DoCpAAApCBK3qJ6KDBVDgKb/////8c2bq7lAgjFKFNzoDGD2f6DnQpO1rBdGPZq/////t/X/jKy3bUv/zNGS2A2DBKAQ8A2yDqC5EAAMGBBNFy1AzuLARQspDWGjQiDQGf//6avV6pGJBLsfDuI/14WvXP9v///T7IkQkctXkHygJAf/zNGS/BIzLJgA8B2YD4CJQAAhKAHBkdgIRgDqoaE/////9QxgQTKqB+vY/RzDLHYYoY0Y0Xj30gb+zdF///5/2R//z9La1HP/zNGS+BMTHIAAwBWaDyCZAAAhMAD9/SSaHQTkQS2EGSh02NjgJZbYoOt//9yv/8/SlAVEdCjJAdiSKMLieMEgRojWdrsPvhP/zNGS7BUzJHgBh4hYC+CZAAAGMAJbWjunv1dnJf7va5R0APyBgh0RKxyBAj////7E+vUryN6fWmQZjSKkWZIC6sb+aU/Ohk//zNES3A1y5IgA8AliF6DpIABMGBJf//8ZkvsiuL/fvOBkwbBoLBjMY+qgy8Irx3Co4gCeyz//7v/8vftKVDjBg3fp8qFcj1f/zNGS3BOTJIgA8KF4FoD40ABJMBIl0NQ+MxtVQRi20lr36O0rSbvflAUFCIUaRQdNtE5j+LeXB7TUNPFjP/+hav/2LjkHX4//zNGSsBDglJDg95iAD6CZAAAiMAFUAkEkY1LkZoHjlPbtusbU/vCkLlJ480wHkKcof9//UhWSZfAmf5ovuC6XqRor/2dmBIv/zNGStBaTDGgA8I1yD0DI4AADEBAALgw4c8ByDxLPorWktBluaGYNjx0HnzMPFj///95hxUHn/4eQcxif/+Pk0BwAsZ+nw+v/zNGSjBSAdIDiniAAFECo0AUYQANZQWuOefHOA9WA39Khw2NjPM0C+khp7n//////vN2P87mF5r2c6F607H8ZeEyB6CZZV7P/zNGSYB6C9NGTMNAAJ6XZUAY04AIg84IPMLROUTmsw/7hJxOjVupv+kI+3/30oWQecIbC042klckMcsgOSKovRrkbhKj0HUf/zNGRmB5i7VADpmAAFCDqUKc0QAOKmnvZmHi4Ye/VFxY8eaKC2EntAYFAHH4AoHK/UjViBLV//63AJjdI0XtwGkifICyqmi//zNGRIBSw7btwFgyMD6ALqWAhETu2ZOWicEhAiswV/hPFBGEqauoaRW3V54HwcFxIkk6KAAcADyHB0AIv/9dYcMzfqHQ111v/zNGRCBcxXZSwV4yID0Iq6YAGEQckgAG2n4fkUQuw23aCbLDMdqFwtlXh63MmhYuoS17LCLjXNAUUAfACgdZy78phH///11f/zNGQ3BOQxfywBJgcDwALuWAAEAmgxd7v9LaPcBg1L81hTvD0CHIluDY0XFot+LevrYw7WIAQBcKdMOj136pAOA48FlaCiKP/zNGQzA/wdi3wgJhED2DKmQABUAFsyYl7gxBmYOtXykChn+aEhu72l/8Ysza/SIQAB6KABLXByn9drV1/Q3Z+v+1to0Exr8//zNGQ2A5wvYMQLAiADwDKyWABOAOAYUtUAgZPn19TSzma6m/p90nQUCACboP6YFq/o98Z4CSkYi23WySBvXAHAVZ1SRY5U1//zNGQ9A8AbiywIJhEDgIq9wBAGacvvqgOV6a1LfZXW/iMWDACgS2qwzv9VuB2ttwgg0C3bhahyHlma
|
|||
|
class al {
|
|||
|
constructor() {
|
|||
|
this._bellContext = null, this._isMuteBell = !1, this._calleeBellFilePath = Wt, this._callRole = IA.UNKNOWN, this._callStatus = P.IDLE, this._bellContext = new Audio(), this._bellContext.loop = !0;
|
|||
|
}
|
|||
|
setBellSrc() {
|
|||
|
try {
|
|||
|
let A = tl;
|
|||
|
this._callRole === IA.CALLEE && (A = this._calleeBellFilePath || Wt), this._bellContext.src = A;
|
|||
|
} catch (A) {
|
|||
|
console.warn(`${i.PREFIX}Failed to setBellSrc, ${A}`);
|
|||
|
}
|
|||
|
}
|
|||
|
setBellProperties(A) {
|
|||
|
this._callRole = A.callRole || this._callRole, this._callStatus = A.callStatus || this._callStatus, this._calleeBellFilePath = A.calleeBellFilePath || this._calleeBellFilePath, this._isMuteBell = et(A.isMuteBell) ? this._isMuteBell : A.isMuteBell;
|
|||
|
}
|
|||
|
async play() {
|
|||
|
try {
|
|||
|
if (this._callStatus !== P.CALLING)
|
|||
|
return;
|
|||
|
this.setBellSrc(), this._callRole === IA.CALLEE && !this._isMuteBell && await this._bellContext.play(), this._callRole === IA.CALLER && await this._bellContext.play();
|
|||
|
} catch (A) {
|
|||
|
console.warn(`${i.PREFIX}Failed to play audio file, ${A}`);
|
|||
|
}
|
|||
|
}
|
|||
|
async stop() {
|
|||
|
try {
|
|||
|
await this._bellContext.pause();
|
|||
|
} catch (A) {
|
|||
|
console.warn(`${i.PREFIX}Failed to stop audio file, ${A}`);
|
|||
|
}
|
|||
|
}
|
|||
|
async setBellMute(A) {
|
|||
|
this._callStatus !== P.CALLING && this._callRole !== IA.CALLEE || (A ? await this.stop() : await this.play());
|
|||
|
}
|
|||
|
destroy() {
|
|||
|
try {
|
|||
|
this._isMuteBell = !1, this._calleeBellFilePath = "", this._callRole = IA.UNKNOWN, this._callStatus = P.IDLE, this._bellContext.pause(), this._bellContext = null;
|
|||
|
} catch (A) {
|
|||
|
console.warn(`${i.PREFIX}Failed to destroy, ${A}`);
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
function TA() {
|
|||
|
return function(a, A, e) {
|
|||
|
const t = e.value, o = /* @__PURE__ */ new Set();
|
|||
|
return e.value = async function(...n) {
|
|||
|
var s, r;
|
|||
|
if (o.has(this)) {
|
|||
|
console.warn(`${i.PREFIX}previous ${A}() is ongoing, please avoid repeated calls`), (r = (s = this == null ? void 0 : this.getTUICallEngineInstance()) == null ? void 0 : s.reportLog) == null || r.call(s, {
|
|||
|
name: "TUICallKit.avoidRepeatedCall.fail",
|
|||
|
data: { name: A },
|
|||
|
error: `previous ${A}() is ongoing`
|
|||
|
});
|
|||
|
return;
|
|||
|
}
|
|||
|
try {
|
|||
|
o.add(this);
|
|||
|
const c = await t.apply(this, n);
|
|||
|
return o.delete(this), c;
|
|||
|
} catch (c) {
|
|||
|
throw o.delete(this), c;
|
|||
|
}
|
|||
|
}, e;
|
|||
|
};
|
|||
|
}
|
|||
|
const Ce = i.PREFIX + "API";
|
|||
|
function UA(a) {
|
|||
|
return function(A, e, t) {
|
|||
|
let o = t.value;
|
|||
|
return t.value = function(...n) {
|
|||
|
return ol.call(this, a, n, e), o.apply(this, n);
|
|||
|
}, t;
|
|||
|
};
|
|||
|
}
|
|||
|
function ol(a, A, e) {
|
|||
|
try {
|
|||
|
if (A[0].SDKAppID || (a = el(a, "SDKAppID", "sdkAppID")), ra(a))
|
|||
|
for (let t = 0; t < a.length; t++)
|
|||
|
Gt.call(this, {
|
|||
|
...a[t],
|
|||
|
value: A[t],
|
|||
|
name: e
|
|||
|
});
|
|||
|
else
|
|||
|
for (const t in a)
|
|||
|
a.hasOwnProperty(t) && Gt.call(this, {
|
|||
|
...a[t],
|
|||
|
value: A[0][t],
|
|||
|
name: e,
|
|||
|
key: t
|
|||
|
});
|
|||
|
} catch (t) {
|
|||
|
throw console.error(t), t;
|
|||
|
}
|
|||
|
}
|
|||
|
function Gt({ required: a, rules: A, range: e, value: t, allowEmpty: o, name: n, key: s }) {
|
|||
|
if (et(t)) {
|
|||
|
if (a)
|
|||
|
throw new Error(`${Ce}<${n}>: ${s} is required.`);
|
|||
|
return;
|
|||
|
}
|
|||
|
const r = A.some((M) => M === Al(t));
|
|||
|
let c = "";
|
|||
|
if (!r) {
|
|||
|
for (let M = 0; M < A.length; M++) {
|
|||
|
let N = A[M];
|
|||
|
N = N.replace(N[0], N[0].toUpperCase()), c += `${N}/`;
|
|||
|
}
|
|||
|
throw c = c.substring(0, c.length - 1), new Error(`${Ce}<${n}>: ${s} must be ${c}, current ${s} is ${typeof t}.`);
|
|||
|
}
|
|||
|
if (o === !1 && pt(t) && t.trim() === "")
|
|||
|
throw new Error(`${Ce}<${n}>: ${s} is blank.`);
|
|||
|
if (ra(e) && e && e.indexOf(t) === -1)
|
|||
|
throw new Error(`${Ce}<${n}>: ${s} error, only be ${e}, current ${s} is ${t}.`);
|
|||
|
if (pt(e) && e.indexOf("~") !== -1) {
|
|||
|
const M = e.split("~");
|
|||
|
if (t < +M[0] || t > +M[1] || ua(t) && Number.isNaN(t))
|
|||
|
throw new Error(`${Ce}<${n}>: ${s} error, only be ${e}, current ${s} is ${t}.`);
|
|||
|
}
|
|||
|
}
|
|||
|
const fA = {
|
|||
|
init: {
|
|||
|
SDKAppID: {
|
|||
|
required: !0,
|
|||
|
rules: [i.NUMBER],
|
|||
|
allowEmpty: !1
|
|||
|
},
|
|||
|
userID: {
|
|||
|
required: !0,
|
|||
|
rules: [i.STRING],
|
|||
|
allowEmpty: !1
|
|||
|
},
|
|||
|
userSig: {
|
|||
|
required: !0,
|
|||
|
rules: [i.STRING],
|
|||
|
allowEmpty: !1
|
|||
|
},
|
|||
|
tim: {
|
|||
|
required: !1,
|
|||
|
rules: [i.OBJECT]
|
|||
|
}
|
|||
|
},
|
|||
|
call: {
|
|||
|
userID: {
|
|||
|
required: !0,
|
|||
|
rules: [i.STRING],
|
|||
|
allowEmpty: !1
|
|||
|
},
|
|||
|
type: {
|
|||
|
required: !0,
|
|||
|
rules: [i.NUMBER],
|
|||
|
range: [1, 2],
|
|||
|
allowEmpty: !1
|
|||
|
},
|
|||
|
roomID: {
|
|||
|
required: !1,
|
|||
|
rules: [i.NUMBER],
|
|||
|
// 仅支持数字房间号, 后续会支持字符串房间号
|
|||
|
range: `0~${kt}`,
|
|||
|
allowEmpty: !1
|
|||
|
},
|
|||
|
strRoomID: {
|
|||
|
required: !1,
|
|||
|
rules: [i.STRING],
|
|||
|
allowEmpty: !0
|
|||
|
},
|
|||
|
userData: {
|
|||
|
required: !1,
|
|||
|
rules: [i.STRING],
|
|||
|
allowEmpty: !1
|
|||
|
},
|
|||
|
timeout: {
|
|||
|
required: !1,
|
|||
|
rules: [i.NUMBER],
|
|||
|
allowEmpty: !1
|
|||
|
}
|
|||
|
},
|
|||
|
groupCall: {
|
|||
|
userIDList: {
|
|||
|
required: !0,
|
|||
|
rules: [i.ARRAY],
|
|||
|
allowEmpty: !1
|
|||
|
},
|
|||
|
type: {
|
|||
|
required: !0,
|
|||
|
rules: [i.NUMBER],
|
|||
|
range: [1, 2],
|
|||
|
allowEmpty: !1
|
|||
|
},
|
|||
|
groupID: {
|
|||
|
required: !0,
|
|||
|
rules: [i.STRING],
|
|||
|
allowEmpty: !1
|
|||
|
},
|
|||
|
roomID: {
|
|||
|
required: !1,
|
|||
|
rules: [i.NUMBER],
|
|||
|
// 仅支持数字房间号, 后续会支持字符串房间号
|
|||
|
range: `0~${kt}`,
|
|||
|
allowEmpty: !1
|
|||
|
},
|
|||
|
strRoomID: {
|
|||
|
required: !1,
|
|||
|
rules: [i.STRING],
|
|||
|
allowEmpty: !0
|
|||
|
},
|
|||
|
timeout: {
|
|||
|
required: !1,
|
|||
|
rules: [i.NUMBER],
|
|||
|
allowEmpty: !1
|
|||
|
},
|
|||
|
userData: {
|
|||
|
required: !1,
|
|||
|
rules: [i.STRING],
|
|||
|
allowEmpty: !1
|
|||
|
},
|
|||
|
offlinePushInfo: {
|
|||
|
required: !1,
|
|||
|
rules: [i.OBJECT],
|
|||
|
allowEmpty: !1
|
|||
|
}
|
|||
|
},
|
|||
|
joinInGroupCall: {
|
|||
|
type: {
|
|||
|
required: !0,
|
|||
|
rules: [i.NUMBER],
|
|||
|
range: [1, 2],
|
|||
|
allowEmpty: !1
|
|||
|
},
|
|||
|
groupID: {
|
|||
|
required: !0,
|
|||
|
rules: [i.STRING],
|
|||
|
allowEmpty: !1
|
|||
|
},
|
|||
|
roomID: {
|
|||
|
required: !0,
|
|||
|
rules: [i.NUMBER],
|
|||
|
allowEmpty: !1
|
|||
|
},
|
|||
|
strRoomID: {
|
|||
|
required: !1,
|
|||
|
rules: [i.STRING],
|
|||
|
allowEmpty: !0
|
|||
|
}
|
|||
|
},
|
|||
|
inviteUser: {
|
|||
|
userIDList: {
|
|||
|
required: !0,
|
|||
|
rules: [i.ARRAY],
|
|||
|
allowEmpty: !1
|
|||
|
}
|
|||
|
},
|
|||
|
setSelfInfo: {
|
|||
|
nickName: {
|
|||
|
required: !1,
|
|||
|
rules: [i.STRING],
|
|||
|
allowEmpty: !1
|
|||
|
},
|
|||
|
avatar: {
|
|||
|
required: !1,
|
|||
|
rules: [i.STRING],
|
|||
|
allowEmpty: !1
|
|||
|
}
|
|||
|
},
|
|||
|
enableFloatWindow: [
|
|||
|
{
|
|||
|
key: "enable",
|
|||
|
required: !1,
|
|||
|
rules: [i.BOOLEAN],
|
|||
|
allowEmpty: !1
|
|||
|
}
|
|||
|
],
|
|||
|
enableAIVoice: [
|
|||
|
{
|
|||
|
key: "enable",
|
|||
|
required: !0,
|
|||
|
rules: [i.BOOLEAN],
|
|||
|
allowEmpty: !1
|
|||
|
}
|
|||
|
],
|
|||
|
enableMuteMode: [
|
|||
|
{
|
|||
|
key: "enable",
|
|||
|
required: !0,
|
|||
|
rules: [i.BOOLEAN],
|
|||
|
allowEmpty: !1
|
|||
|
}
|
|||
|
],
|
|||
|
setCallingBell: [
|
|||
|
{
|
|||
|
key: "filePath",
|
|||
|
required: !1,
|
|||
|
rules: [i.STRING],
|
|||
|
allowEmpty: !0
|
|||
|
}
|
|||
|
],
|
|||
|
setLanguage: [
|
|||
|
{
|
|||
|
key: "language",
|
|||
|
required: !0,
|
|||
|
rules: [i.STRING],
|
|||
|
allowEmpty: !1
|
|||
|
}
|
|||
|
],
|
|||
|
setVideoDisplayMode: [
|
|||
|
{
|
|||
|
key: "displayMode",
|
|||
|
required: !0,
|
|||
|
rules: [i.STRING],
|
|||
|
range: [fe.CONTAIN, fe.COVER, fe.FILL],
|
|||
|
allowEmpty: !1
|
|||
|
}
|
|||
|
],
|
|||
|
setVideoResolution: [
|
|||
|
{
|
|||
|
key: "resolution",
|
|||
|
required: !0,
|
|||
|
rules: [i.STRING],
|
|||
|
range: [ve.RESOLUTION_1080P, ve.RESOLUTION_480P, ve.RESOLUTION_720P],
|
|||
|
allowEmpty: !1
|
|||
|
}
|
|||
|
]
|
|||
|
};
|
|||
|
function tt(a) {
|
|||
|
return function(A, e, t) {
|
|||
|
let o = t.value;
|
|||
|
return t.value = function(...n) {
|
|||
|
return ll.call(this, a, n, e), o.apply(this, n);
|
|||
|
}, t;
|
|||
|
};
|
|||
|
}
|
|||
|
function ll(a) {
|
|||
|
if (a != null && a.engineInstance && !this._tuiCallEngine) {
|
|||
|
const A = `${i.PREFIX} ${v("TUICallKit init is not complete")}`;
|
|||
|
throw console.error(A), A;
|
|||
|
}
|
|||
|
}
|
|||
|
class nl {
|
|||
|
constructor() {
|
|||
|
this.defaultStore = {
|
|||
|
callStatus: P.IDLE,
|
|||
|
callRole: IA.UNKNOWN,
|
|||
|
callMediaType: _.UNKNOWN,
|
|||
|
localUserInfo: { userId: "" },
|
|||
|
localUserInfoExcludeVolume: { userId: "" },
|
|||
|
remoteUserInfoList: [],
|
|||
|
remoteUserInfoExcludeVolumeList: [],
|
|||
|
callerUserInfo: { userId: "" },
|
|||
|
isGroup: !1,
|
|||
|
callDuration: "00:00:00",
|
|||
|
// 通话时长
|
|||
|
callTips: "",
|
|||
|
// 通话提示的信息. 例如: '等待谁接听', 'xxx 拒绝通话', 'xxx 挂断通话'
|
|||
|
toastInfo: { text: "" },
|
|||
|
// 远端用户挂断、拒绝、超时、忙线等的 toast 提示信息
|
|||
|
isMinimized: !1,
|
|||
|
// 用来记录当前是否悬浮窗模式
|
|||
|
enableFloatWindow: !1,
|
|||
|
// 开启/关闭悬浮窗功能,设置为false,通话界面左上角的悬浮窗按钮会隐藏
|
|||
|
bigScreenUserId: "",
|
|||
|
// 当前大屏幕显示的 userID 用户
|
|||
|
language: $o(),
|
|||
|
// en, zh-cn
|
|||
|
isClickable: !1,
|
|||
|
// 是否可点击, 用于按钮增加 loading 效果,不可点击
|
|||
|
deviceList: { cameraList: [], microphoneList: [], currentCamera: {}, currentMicrophone: {} },
|
|||
|
showPermissionTip: !1,
|
|||
|
netWorkQualityList: [],
|
|||
|
// 显示网络状态差的提示
|
|||
|
isMuteSpeaker: !1,
|
|||
|
groupID: "",
|
|||
|
roomID: 0,
|
|||
|
roomIdType: 0,
|
|||
|
cameraPosition: we.FRONT,
|
|||
|
// 前置或后置,值为front, back
|
|||
|
groupCallMembers: [],
|
|||
|
// chat 群会话在的通话中的成员
|
|||
|
// TUICallKit 组件上的属性
|
|||
|
displayMode: fe.COVER,
|
|||
|
// 设置预览远端的画面显示模式
|
|||
|
videoResolution: ve.RESOLUTION_480P,
|
|||
|
showSelectUser: !1,
|
|||
|
// 小程序相关属性
|
|||
|
pusher: {},
|
|||
|
player: [],
|
|||
|
isEarPhone: !1,
|
|||
|
// 是否是听筒, 默认: false
|
|||
|
pusherId: i.INITIAL_PUSHER,
|
|||
|
// 重新渲染 live-Pusher 的标识位
|
|||
|
// 是否开启虚拟背景, 目前仅 web 支持
|
|||
|
isShowEnableVirtualBackground: !1,
|
|||
|
// 是否显示虚拟背景图标, 默认: false
|
|||
|
enableVirtualBackground: !1,
|
|||
|
// 是否开启虚拟背景, 默认: false
|
|||
|
// customUIConfig
|
|||
|
customUIConfig: {
|
|||
|
button: {},
|
|||
|
viewBackground: {},
|
|||
|
layoutMode: Xe.RemoteInLargeView
|
|||
|
}
|
|||
|
}, this.store = qe(this.defaultStore), this.prevStore = qe(this.defaultStore);
|
|||
|
}
|
|||
|
update(A, e) {
|
|||
|
switch (A) {
|
|||
|
case i.CALL_TIPS:
|
|||
|
const t = this.getData(A);
|
|||
|
this.prevStore[A] = t;
|
|||
|
default:
|
|||
|
this.store[A] = e;
|
|||
|
}
|
|||
|
}
|
|||
|
getPrevData(A) {
|
|||
|
return A ? this.prevStore[A] : this.prevStore;
|
|||
|
}
|
|||
|
getData(A) {
|
|||
|
return A ? this.store[A] : this.store;
|
|||
|
}
|
|||
|
// reset call store
|
|||
|
reset(A = []) {
|
|||
|
A.length === 0 && (A = Object.keys(this.store));
|
|||
|
const e = A.reduce((t, o) => ({ ...t, [o]: this.defaultStore[o] }), {});
|
|||
|
this.store = {
|
|||
|
...this.defaultStore,
|
|||
|
...this.store,
|
|||
|
...e
|
|||
|
};
|
|||
|
}
|
|||
|
}
|
|||
|
let at = class Le {
|
|||
|
constructor() {
|
|||
|
this.timerId = -1, this.storeMap = {
|
|||
|
[u.CALL]: new nl()
|
|||
|
}, this.task = {};
|
|||
|
}
|
|||
|
/**
|
|||
|
* 获取 TUIStore 实例
|
|||
|
* @returns {TUIStore}
|
|||
|
*/
|
|||
|
static getInstance() {
|
|||
|
return Le.instance || (Le.instance = new Le()), Le.instance;
|
|||
|
}
|
|||
|
/**
|
|||
|
* UI 组件注册监听回调
|
|||
|
* @param {StoreName} storeName store 名称
|
|||
|
* @param {IOptions} options 监听信息
|
|||
|
* @param {Object} params 扩展参数
|
|||
|
* @param {String} params.notifyRangeWhenWatch 注册时监听时的通知范围, 'all' - 通知所有注册该 key 的监听; 'myself' - 通知本次注册该 key 的监听; 默认不通知
|
|||
|
*/
|
|||
|
watch(A, e, t) {
|
|||
|
this.task[A] || (this.task[A] = {});
|
|||
|
const o = this.task[A];
|
|||
|
Object.keys(e).forEach((n) => {
|
|||
|
const s = e[n];
|
|||
|
o[n] || (o[n] = /* @__PURE__ */ new Map()), o[n].set(s, 1);
|
|||
|
const { notifyRangeWhenWatch: r } = t || {};
|
|||
|
if (r === i.ALL && this.notify(A, n), r === i.MYSELF) {
|
|||
|
const c = this.getData(A, n);
|
|||
|
s.call(this, c);
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
/**
|
|||
|
* UI 取消组件监听回调
|
|||
|
* @param {StoreName} storeName store 名称
|
|||
|
* @param {IOptions} options 监听信息,包含需要取消的回掉等
|
|||
|
*/
|
|||
|
unwatch(A, e) {
|
|||
|
if (!this.task[A])
|
|||
|
return;
|
|||
|
const t = this.task[A];
|
|||
|
Object.keys(e).forEach((o) => {
|
|||
|
t[o].delete(e[o]);
|
|||
|
});
|
|||
|
}
|
|||
|
/**
|
|||
|
* 通用 store 数据更新,messageList 的变更需要单独处理
|
|||
|
* @param {StoreName} storeName store 名称
|
|||
|
* @param {string} key 变更的 key
|
|||
|
* @param {unknown} data 变更的数据
|
|||
|
*/
|
|||
|
update(A, e, t) {
|
|||
|
var o;
|
|||
|
(pt(t) || ua(t) || Ho(t)) && this.storeMap[A].store[e] === t || ((o = this.storeMap[A]) == null || o.update(e, t), this.notify(A, e));
|
|||
|
}
|
|||
|
/**
|
|||
|
* 获取 Store 的上一个状态值
|
|||
|
* @param {StoreName} storeName store 名称
|
|||
|
* @param {string} key 待获取的 key
|
|||
|
* @returns {Any}
|
|||
|
*/
|
|||
|
getPrevData(A, e) {
|
|||
|
var t;
|
|||
|
return (t = this.storeMap[A]) == null ? void 0 : t.getPrevData(e);
|
|||
|
}
|
|||
|
/**
|
|||
|
* 获取 Store 数据
|
|||
|
* @param {StoreName} storeName store 名称
|
|||
|
* @param {string} key 待获取的 key
|
|||
|
* @returns {Any}
|
|||
|
*/
|
|||
|
getData(A, e) {
|
|||
|
var t;
|
|||
|
return (t = this.storeMap[A]) == null ? void 0 : t.getData(e);
|
|||
|
}
|
|||
|
/**
|
|||
|
* UI 组件注册监听回调
|
|||
|
* @param {StoreName} storeName store 名称
|
|||
|
* @param {string} key 变更的 key
|
|||
|
*/
|
|||
|
notify(A, e) {
|
|||
|
if (!this.task[A])
|
|||
|
return;
|
|||
|
const t = this.task[A];
|
|||
|
if (t[e]) {
|
|||
|
const o = t[e], n = this.getData(A, e);
|
|||
|
for (const [s] of o.entries())
|
|||
|
s.call(this, n);
|
|||
|
}
|
|||
|
}
|
|||
|
reset(A, e = [], t = !1) {
|
|||
|
if (A in this.storeMap) {
|
|||
|
const o = this.storeMap[A];
|
|||
|
e.length === 0 && (e = Object.keys(o == null ? void 0 : o.store)), o.reset(e), t && e.forEach((n) => {
|
|||
|
this.notify(A, n);
|
|||
|
});
|
|||
|
}
|
|||
|
}
|
|||
|
// 批量修改多个 key-value
|
|||
|
updateStore(A, e) {
|
|||
|
const t = e || u.CALL;
|
|||
|
Object.keys(A).forEach((o) => {
|
|||
|
this.update(t, o, A[o]);
|
|||
|
});
|
|||
|
}
|
|||
|
};
|
|||
|
const AA = at.getInstance();
|
|||
|
function Dt(a, A) {
|
|||
|
const e = {
|
|||
|
userId: a,
|
|||
|
nick: "",
|
|||
|
avatar: "",
|
|||
|
remark: "",
|
|||
|
displayUserInfo: "",
|
|||
|
isAudioAvailable: !1,
|
|||
|
isVideoAvailable: !1,
|
|||
|
isEnter: !1,
|
|||
|
domId: A || a
|
|||
|
};
|
|||
|
return A ? e : { ...e, isEnter: !1 };
|
|||
|
}
|
|||
|
async function il(a, A) {
|
|||
|
var t, o, n, s, r;
|
|||
|
let e = Dt(a, i.LOCAL_VIDEO);
|
|||
|
try {
|
|||
|
if (!A)
|
|||
|
return e;
|
|||
|
const c = await A.getMyProfile(), M = AA == null ? void 0 : AA.getData(u.CALL, i.LOCAL_USER_INFO);
|
|||
|
return (c == null ? void 0 : c.code) === 0 && (e = {
|
|||
|
...e,
|
|||
|
...M,
|
|||
|
userId: (t = c == null ? void 0 : c.data) == null ? void 0 : t.userID,
|
|||
|
nick: (o = c == null ? void 0 : c.data) == null ? void 0 : o.nick,
|
|||
|
avatar: (n = c == null ? void 0 : c.data) == null ? void 0 : n.avatar,
|
|||
|
displayUserInfo: ((s = c == null ? void 0 : c.data) == null ? void 0 : s.nick) || ((r = c == null ? void 0 : c.data) == null ? void 0 : r.userID)
|
|||
|
}), e;
|
|||
|
} catch (c) {
|
|||
|
return console.error(`${i.PREFIX}getMyProfile failed, error: ${c}.`), e;
|
|||
|
}
|
|||
|
}
|
|||
|
async function Oe(a, A) {
|
|||
|
let e = a.map((t) => Dt(t));
|
|||
|
try {
|
|||
|
if (!A)
|
|||
|
return e;
|
|||
|
const t = await A.getFriendProfile({ userIDList: a });
|
|||
|
if (t.code === 0) {
|
|||
|
const { friendList: o = [], failureUserIDList: n = [] } = t.data;
|
|||
|
let s = n.map((N) => N.userID);
|
|||
|
if (n.length > 0) {
|
|||
|
const N = await A.getUserProfile({ userIDList: n.map((T) => T.userID) });
|
|||
|
(N == null ? void 0 : N.code) === 0 && (s = (N == null ? void 0 : N.data) || []);
|
|||
|
}
|
|||
|
const r = AA == null ? void 0 : AA.getData(u.CALL, i.REMOTE_USER_INFO_LIST), c = o.map((N) => N.userID), M = s.map((N) => N.userID);
|
|||
|
e = a.map((N) => {
|
|||
|
var b, x, B, F, tA, J, MA;
|
|||
|
const T = Dt(N), I = c.indexOf(N), D = M.indexOf(N);
|
|||
|
let h = "", j = "", m = "", w = "";
|
|||
|
I !== -1 && (h = ((b = o[I]) == null ? void 0 : b.remark) || "", j = ((B = (x = o[I]) == null ? void 0 : x.profile) == null ? void 0 : B.nick) || "", m = h || j || T.userId || "", w = ((tA = (F = o[I]) == null ? void 0 : F.profile) == null ? void 0 : tA.avatar) || ""), D !== -1 && (j = ((J = s[D]) == null ? void 0 : J.nick) || "", m = j || T.userId || "", w = ((MA = s[D]) == null ? void 0 : MA.avatar) || "");
|
|||
|
const H = r.find((WA) => WA.userId === N) || {};
|
|||
|
return { ...T, ...H, remark: h, nick: j, displayUserInfo: m, avatar: w };
|
|||
|
});
|
|||
|
}
|
|||
|
return e;
|
|||
|
} catch (t) {
|
|||
|
return console.error(`${i.PREFIX}getRemoteUserProfile failed, error: ${t}.`), e;
|
|||
|
}
|
|||
|
}
|
|||
|
function qA(a, A, e) {
|
|||
|
const t = AA.getData(u.CALL, i.IS_GROUP);
|
|||
|
let o = `${v(a)}`;
|
|||
|
return t && (o = A ? `${A} ${o}` : o, o = e ? `${o} ${e}` : o), o;
|
|||
|
}
|
|||
|
function We() {
|
|||
|
const a = AA.getData(u.CALL, i.CALL_STATUS);
|
|||
|
if (a === P.IDLE)
|
|||
|
return jA.IDLE;
|
|||
|
const A = AA.getData(u.CALL, i.IS_GROUP);
|
|||
|
if (a === P.CALLING)
|
|||
|
return A ? jA.DIALING_GROUP : jA.DIALING_C2C;
|
|||
|
const e = AA.getData(u.CALL, i.CALL_MEDIA_TYPE);
|
|||
|
return A ? e === _.AUDIO ? jA.CALLING_GROUP_AUDIO : jA.CALLING_GROUP_VIDEO : e === _.AUDIO ? jA.CALLING_C2C_AUDIO : jA.CALLING_C2C_VIDEO;
|
|||
|
}
|
|||
|
async function sl(a, A, e, t) {
|
|||
|
let o = [];
|
|||
|
try {
|
|||
|
const n = await A.getGroupMemberList({ groupID: a, count: e, offset: t });
|
|||
|
if (n.code === 0)
|
|||
|
return n.data.memberList || o;
|
|||
|
} catch (n) {
|
|||
|
return console.error(`${i.PREFIX}getGroupMember failed, error: ${n}.`), o;
|
|||
|
}
|
|||
|
}
|
|||
|
async function cl(a, A) {
|
|||
|
let e = {};
|
|||
|
try {
|
|||
|
return (await A.getGroupProfile({ groupID: a })).data.group || e;
|
|||
|
} catch (t) {
|
|||
|
return console.warn(`${i.PREFIX}getGroupProfile failed, error: ${t}.`), e;
|
|||
|
}
|
|||
|
}
|
|||
|
function da(a, A) {
|
|||
|
a === 0 && A ? (AA.update(u.CALL, i.ROOM_ID, A), AA.update(u.CALL, i.ROOM_ID_TYPE, Tt.STRING_ROOM_ID)) : (AA.update(u.CALL, i.ROOM_ID, a), AA.update(u.CALL, i.ROOM_ID_TYPE, Tt.NUMBER_ROOM_ID));
|
|||
|
}
|
|||
|
function bA(a) {
|
|||
|
return a || {};
|
|||
|
}
|
|||
|
function ut(a) {
|
|||
|
if (a.length === 0)
|
|||
|
return;
|
|||
|
let A = AA.getData(u.CALL, i.REMOTE_USER_INFO_LIST);
|
|||
|
a.forEach((e) => {
|
|||
|
A = A.filter((t) => t.userId !== e);
|
|||
|
}), AA.update(u.CALL, i.REMOTE_USER_INFO_LIST, A), AA.update(u.CALL, i.REMOTE_USER_INFO_EXCLUDE_VOLUMN_LIST, A);
|
|||
|
}
|
|||
|
function Mt(a) {
|
|||
|
a == null || a.getDeviceList("speaker").then((e) => {
|
|||
|
const t = AA.getData(u.CALL, i.DEVICE_LIST), o = (e == null ? void 0 : e[0]) || {};
|
|||
|
AA.update(
|
|||
|
u.CALL,
|
|||
|
i.DEVICE_LIST,
|
|||
|
{ ...t, speakerList: e, currentSpeaker: o }
|
|||
|
);
|
|||
|
}).catch((e) => {
|
|||
|
console.error(`${i.PREFIX}updateSpeakerList failed, error: ${JSON.stringify(e)}.`);
|
|||
|
}), AA.getData(u.CALL, i.CALL_MEDIA_TYPE) === _.VIDEO && (a == null || a.getDeviceList("camera").then((e) => {
|
|||
|
const t = AA.getData(u.CALL, i.DEVICE_LIST), o = (e == null ? void 0 : e[0]) || {};
|
|||
|
AA.update(
|
|||
|
u.CALL,
|
|||
|
i.DEVICE_LIST,
|
|||
|
{ ...t, cameraList: e, currentCamera: o }
|
|||
|
);
|
|||
|
}).catch((e) => {
|
|||
|
console.error(`${i.PREFIX}updateCameraList failed, error: ${e}.`);
|
|||
|
})), a == null || a.getDeviceList("microphones").then((e) => {
|
|||
|
const t = AA.getData(u.CALL, i.DEVICE_LIST), o = (e == null ? void 0 : e[0]) || {};
|
|||
|
AA.update(
|
|||
|
u.CALL,
|
|||
|
i.DEVICE_LIST,
|
|||
|
{ ...t, microphoneList: e, currentMicrophone: o }
|
|||
|
);
|
|||
|
}).catch((e) => {
|
|||
|
console.error(`${i.PREFIX}updateMicrophoneList failed, error: ${e}.`);
|
|||
|
});
|
|||
|
}
|
|||
|
function dt(a, A, e) {
|
|||
|
if (_o(a)) {
|
|||
|
let t = "";
|
|||
|
A === _.AUDIO && (t = qA(EA.NO_MICROPHONE_DEVICE_PERMISSION)), A === _.VIDEO && (t = qA(EA.NO_CAMERA_DEVICE_PERMISSION));
|
|||
|
const o = e == null ? void 0 : e.getDevicePermission();
|
|||
|
o != null && o.audio || AA.update(u.CALL, i.SHOW_PERMISSION_TIP, !0), t && AA.update(u.CALL, i.TOAST_INFO, { text: t, type: i.ERROR }), console.error(`${i.PREFIX}call failed, error: ${a.message}.`);
|
|||
|
}
|
|||
|
}
|
|||
|
function oe(a, A) {
|
|||
|
let e = AA.getData(u.CALL, i.LOCAL_USER_INFO);
|
|||
|
A === i.AUDIO && (e = { ...e, isAudioAvailable: a }), A === i.VIDEO && (e = { ...e, isVideoAvailable: a }), AA.update(u.CALL, i.LOCAL_USER_INFO, e), AA.update(u.CALL, i.LOCAL_USER_INFO_EXCLUDE_VOLUMN, e);
|
|||
|
}
|
|||
|
class He {
|
|||
|
static generateTaskID() {
|
|||
|
return this.currentTaskID++;
|
|||
|
}
|
|||
|
/**
|
|||
|
*
|
|||
|
* @param {string} taskName 'interval' 'timeout'
|
|||
|
* @param {function} callback
|
|||
|
* @param {object} options include:
|
|||
|
* @param {number} options.delay millisecond
|
|||
|
* @param {number} options.count 定时器回调执行次数,0 无限次 or n次
|
|||
|
* @param {boolean} options.backgroundTask 在页面静默后是否继续执行定时器
|
|||
|
*/
|
|||
|
static run(A = i.TIMEOUT, e, t) {
|
|||
|
A === i.INTERVAL ? t = { delay: 2e3, count: 0, backgroundTask: !0, ...t } : t = { delay: 2e3, count: 0, backgroundTask: !0, ...t }, ca(e) && (t = { ...t, ...e }), Ye(A) && (e = A, A = i.TIMEOUT);
|
|||
|
const o = {
|
|||
|
taskID: this.generateTaskID(),
|
|||
|
loopCount: 0,
|
|||
|
intervalID: null,
|
|||
|
timeoutID: null,
|
|||
|
taskName: A,
|
|||
|
callback: e,
|
|||
|
...t
|
|||
|
};
|
|||
|
return this.taskMap.set(o.taskID, o), A === i.INTERNAL ? this.interval(o) : this.timeout(o), o.taskID;
|
|||
|
}
|
|||
|
/**
|
|||
|
* 定时循环执行回调函数
|
|||
|
* 可以指定循环的时间间隔
|
|||
|
* 可以指定循环次数
|
|||
|
* @param {object} taskItem
|
|||
|
* @param {function} callback
|
|||
|
* @param {*} delay
|
|||
|
* @param {*} count
|
|||
|
* @returns ID
|
|||
|
*/
|
|||
|
static interval(A) {
|
|||
|
const e = () => {
|
|||
|
A.callback(), A.loopCount += 1, this.isBreakLoop(A);
|
|||
|
};
|
|||
|
return A.intervalID = setInterval(e, A.delay);
|
|||
|
}
|
|||
|
/**
|
|||
|
* 延迟执行回调
|
|||
|
* count = 0,循环
|
|||
|
* count = n, 执行n次
|
|||
|
* @param {object} taskItem
|
|||
|
*
|
|||
|
*/
|
|||
|
static timeout(A) {
|
|||
|
const e = () => {
|
|||
|
if (A.callback(), A.loopCount += 1, !this.isBreakLoop(A))
|
|||
|
return A.timeoutID = setTimeout(e, A.delay);
|
|||
|
};
|
|||
|
return A.timeoutID = setTimeout(e, A.delay);
|
|||
|
}
|
|||
|
static hasTask(A) {
|
|||
|
return this.taskMap.has(A);
|
|||
|
}
|
|||
|
static clearTask(A) {
|
|||
|
if (!this.taskMap.has(A))
|
|||
|
return !0;
|
|||
|
const { intervalID: e, timeoutID: t, onVisibilitychange: o } = this.taskMap.get(A);
|
|||
|
return e && clearInterval(e), t && clearTimeout(t), o && document.removeEventListener("visibilitychange", o), this.taskMap.delete(A), !0;
|
|||
|
}
|
|||
|
/**
|
|||
|
* 1. 如果已移除出定时队列,退出当前任务
|
|||
|
* 2. 如果当前任务已满足次数限制,则退出当前任务
|
|||
|
* @param {object} taskItem
|
|||
|
* @returns
|
|||
|
*/
|
|||
|
static isBreakLoop(A) {
|
|||
|
return this.taskMap.has(A.taskID) ? A.count !== 0 && A.loopCount >= A.count ? (this.clearTask(A.taskID), !0) : !1 : !0;
|
|||
|
}
|
|||
|
}
|
|||
|
He.taskMap = /* @__PURE__ */ new Map();
|
|||
|
He.currentTaskID = 1;
|
|||
|
const rl = function(a) {
|
|||
|
if (a === null || typeof a > "u")
|
|||
|
return !0;
|
|||
|
if (typeof a == "boolean")
|
|||
|
return !1;
|
|||
|
if (typeof a == "number")
|
|||
|
return a === 0;
|
|||
|
if (typeof a == "string" || typeof a == "function" || Array.isArray(a))
|
|||
|
return a.length === 0;
|
|||
|
if (a instanceof Error)
|
|||
|
return a.message === "";
|
|||
|
if (ca(a)) {
|
|||
|
for (const A in a)
|
|||
|
if (Object.prototype.hasOwnProperty.call(a, A))
|
|||
|
return !1;
|
|||
|
return !0;
|
|||
|
}
|
|||
|
return !1;
|
|||
|
}, It = "_local_user_id";
|
|||
|
class ie {
|
|||
|
constructor() {
|
|||
|
this._viewConfig = {
|
|||
|
viewBackground: {
|
|||
|
local: {},
|
|||
|
remote: {}
|
|||
|
}
|
|||
|
}, this._isSetViewBackgroundConfig = { remote: !1, local: !1 }, this._tuiCallEngine = null, this._tuiStore = null;
|
|||
|
}
|
|||
|
static getInstance() {
|
|||
|
return ie.instance || (ie.instance = new ie()), ie.instance;
|
|||
|
}
|
|||
|
_updateViewBackground() {
|
|||
|
var t, o, n;
|
|||
|
const A = (t = this._tuiStore) == null ? void 0 : t.getData(u.CALL, i.CUSTOM_UI_CONFIG), { userId: e } = (o = this._tuiStore) == null ? void 0 : o.getData(u.CALL, i.LOCAL_USER_INFO);
|
|||
|
Object.keys(this._viewConfig.viewBackground.remote).includes(e) && delete this._viewConfig.viewBackground.remote[e], (n = this._tuiStore) == null || n.update(
|
|||
|
u.CALL,
|
|||
|
i.CUSTOM_UI_CONFIG,
|
|||
|
{
|
|||
|
...A,
|
|||
|
viewBackground: {
|
|||
|
...this._viewConfig.viewBackground.remote,
|
|||
|
...this._viewConfig.viewBackground.local
|
|||
|
}
|
|||
|
}
|
|||
|
);
|
|||
|
}
|
|||
|
setEngineInstance(A) {
|
|||
|
this._tuiCallEngine = A;
|
|||
|
}
|
|||
|
setTUIStore(A) {
|
|||
|
this._tuiStore = A;
|
|||
|
}
|
|||
|
updateViewBackgroundUserId(A) {
|
|||
|
var e, t;
|
|||
|
if (A === "local") {
|
|||
|
const { userId: o } = (e = this._tuiStore) == null ? void 0 : e.getData(u.CALL, i.LOCAL_USER_INFO);
|
|||
|
if (Object.keys(this._viewConfig.viewBackground.remote).includes(o) && (delete this._viewConfig.viewBackground.remote[o], this._updateViewBackground()), !this._isSetViewBackgroundConfig.local)
|
|||
|
return;
|
|||
|
const n = this._viewConfig.viewBackground.local, s = n[o] || n[It];
|
|||
|
n[o] = n[It], this._viewConfig.viewBackground.local = { [o]: s }, this._updateViewBackground();
|
|||
|
} else {
|
|||
|
let o = this._viewConfig.viewBackground.remote;
|
|||
|
this._isSetViewBackgroundConfig.remote && Object.keys(o).includes("*") && (((t = this._tuiStore) == null ? void 0 : t.getData(u.CALL, i.REMOTE_USER_INFO_LIST)).map((r) => r.userId).forEach((r) => {
|
|||
|
Object.keys(o).includes(r) || (o[r] = o["*"]);
|
|||
|
}), this._viewConfig.viewBackground.remote = o, this._updateViewBackground());
|
|||
|
}
|
|||
|
}
|
|||
|
hideFeatureButton(A) {
|
|||
|
var t, o, n, s, r;
|
|||
|
(o = (t = this._tuiCallEngine) == null ? void 0 : t.reportLog) == null || o.call(t, {
|
|||
|
name: "TUICallKit.hideFeatureButton.start",
|
|||
|
data: { buttonName: A }
|
|||
|
});
|
|||
|
const e = (n = this._tuiStore) == null ? void 0 : n.getData(u.CALL, i.CUSTOM_UI_CONFIG);
|
|||
|
(r = this._tuiStore) == null || r.update(
|
|||
|
u.CALL,
|
|||
|
i.CUSTOM_UI_CONFIG,
|
|||
|
{
|
|||
|
...e,
|
|||
|
button: {
|
|||
|
...e.button,
|
|||
|
[A]: { ...((s = e.button) == null ? void 0 : s[A]) || {}, show: !1 }
|
|||
|
}
|
|||
|
}
|
|||
|
);
|
|||
|
}
|
|||
|
setLocalViewBackgroundImage(A) {
|
|||
|
var t, o, n;
|
|||
|
(o = (t = this._tuiCallEngine) == null ? void 0 : t.reportLog) == null || o.call(t, {
|
|||
|
name: "TUICallKit.setLocalViewBackgroundImage.start",
|
|||
|
data: { url: A }
|
|||
|
}), this._isSetViewBackgroundConfig.local = !0;
|
|||
|
let { userId: e } = (n = this._tuiStore) == null ? void 0 : n.getData(u.CALL, i.LOCAL_USER_INFO);
|
|||
|
rl(e) && (e = It), this._viewConfig.viewBackground.local = { [e]: A }, this._updateViewBackground();
|
|||
|
}
|
|||
|
setRemoteViewBackgroundImage(A, e) {
|
|||
|
var t, o;
|
|||
|
(o = (t = this._tuiCallEngine) == null ? void 0 : t.reportLog) == null || o.call(t, {
|
|||
|
name: "TUICallKit.setRemoteViewBackgroundImage.start",
|
|||
|
data: { userId: A, url: e }
|
|||
|
}), this._isSetViewBackgroundConfig.remote = !0, A === "*" && (this._viewConfig.viewBackground.remote = {}), this._viewConfig.viewBackground.remote[A] = e, this._updateViewBackground();
|
|||
|
}
|
|||
|
setLayoutMode(A) {
|
|||
|
var t, o;
|
|||
|
(o = (t = this._tuiCallEngine) == null ? void 0 : t.reportLog) == null || o.call(t, {
|
|||
|
name: "TUICallKit.setLayoutMode.start",
|
|||
|
data: { layoutMode: A }
|
|||
|
});
|
|||
|
const e = this._tuiStore.getData(u.CALL, i.CUSTOM_UI_CONFIG);
|
|||
|
this._tuiStore.update(
|
|||
|
u.CALL,
|
|||
|
i.CUSTOM_UI_CONFIG,
|
|||
|
{
|
|||
|
...e,
|
|||
|
layoutMode: A
|
|||
|
}
|
|||
|
);
|
|||
|
}
|
|||
|
setCameraDefaultState(A) {
|
|||
|
var t, o;
|
|||
|
(o = (t = this._tuiCallEngine) == null ? void 0 : t.reportLog) == null || o.call(t, {
|
|||
|
name: "TUICallKit.setCameraDefaultState.start",
|
|||
|
data: { isOpen: A }
|
|||
|
});
|
|||
|
const e = qe(this._tuiStore.getData(u.CALL, i.CUSTOM_UI_CONFIG));
|
|||
|
Object.keys(e.button).includes(_A.Camera) || (e.button[_A.Camera] = {}), e.button[_A.Camera].state = A ? Te.Open : Te.Close, this._tuiStore.update(u.CALL, i.CUSTOM_UI_CONFIG, e);
|
|||
|
}
|
|||
|
}
|
|||
|
const Ge = at.getInstance(), xA = {
|
|||
|
audioCall: () => v("Voice call"),
|
|||
|
videoCall: () => v("Video call"),
|
|||
|
switchToAudio: () => v("Switch audio call"),
|
|||
|
switchToVideo: () => v("Switch video call"),
|
|||
|
hangup: ({ callDuration: a }) => `${v("Call duration")}:${a}`
|
|||
|
};
|
|||
|
class ge {
|
|||
|
constructor(A) {
|
|||
|
var e, t, o;
|
|||
|
this._callService = A.callService, ye.registerEvent(dA.TUILogin.EVENT.LOGIN_STATE_CHANGED, dA.TUILogin.EVENT_SUB_KEY.USER_LOGIN_SUCCESS, this), (e = dA.TUIChat) != null && e.EVENT && ye.registerEvent((t = dA.TUIChat.EVENT) == null ? void 0 : t.CHAT_STATE_CHANGED, (o = dA.TUIChat.EVENT_SUB_KEY) == null ? void 0 : o.CHAT_OPENED, this), ye.registerService(dA.TUICalling.SERVICE.NAME, this), ye.registerExtension(dA.TUIChat.EXTENSION.INPUT_MORE.EXT_ID, this);
|
|||
|
}
|
|||
|
static getInstance(A) {
|
|||
|
return ge.instance || (ge.instance = new ge(A)), ge.instance;
|
|||
|
}
|
|||
|
// ================ 【】 ================
|
|||
|
/**
|
|||
|
* message on screen
|
|||
|
* @param {Any} params Parameters for message up-screening
|
|||
|
*/
|
|||
|
callTUIService(A) {
|
|||
|
const { message: e } = A || {};
|
|||
|
ye.callService({
|
|||
|
serviceName: dA.TUIChat.SERVICE.NAME,
|
|||
|
method: dA.TUIChat.SERVICE.METHOD.UPDATE_MESSAGE_LIST,
|
|||
|
params: { message: e }
|
|||
|
});
|
|||
|
}
|
|||
|
/**
|
|||
|
* tuicore getExtension
|
|||
|
* @param {String} extensionID extension id
|
|||
|
* @param {Any} params tuicore pass parameters
|
|||
|
* @returns {Any[]} return extension
|
|||
|
*/
|
|||
|
onGetExtension(A, e) {
|
|||
|
var t, o;
|
|||
|
if (A === dA.TUIChat.EXTENSION.INPUT_MORE.EXT_ID) {
|
|||
|
if ((o = (t = this._callService.getTUICallEngineInstance()) == null ? void 0 : t.reportLog) == null || o.call(t, { name: "TUICallKit.onGetExtension", data: { extensionID: A, params: e } }), et(e))
|
|||
|
return [];
|
|||
|
if ([dA.TUIChat.TYPE.ROOM, dA.TUIChat.TYPE.CUSTOMER_SERVICE].includes(e.chatType))
|
|||
|
return [];
|
|||
|
let n = [];
|
|||
|
const s = {
|
|||
|
weight: 1e3,
|
|||
|
text: "语音通话",
|
|||
|
icon: bo,
|
|||
|
data: {
|
|||
|
name: "voiceCall"
|
|||
|
},
|
|||
|
listener: {
|
|||
|
onClicked: async (c) => await this._handleTUICoreOnClick(c, c.type || _.AUDIO)
|
|||
|
}
|
|||
|
}, r = {
|
|||
|
weight: 900,
|
|||
|
text: "视频通话",
|
|||
|
icon: xo,
|
|||
|
data: {
|
|||
|
name: "videoCall"
|
|||
|
},
|
|||
|
listener: {
|
|||
|
onClicked: async (c) => await this._handleTUICoreOnClick(c, c.type || _.VIDEO)
|
|||
|
}
|
|||
|
};
|
|||
|
return e != null && e.chatType ? n = [s, r] : (!(e != null && e.filterVoice) && n.push(s), !(e != null && e.filterVideo) && n.push(r)), n;
|
|||
|
}
|
|||
|
}
|
|||
|
async onCall(A, e) {
|
|||
|
A === dA.TUICalling.SERVICE.METHOD.START_CALL && await this._handleTUICoreOnClick(e, e.type);
|
|||
|
}
|
|||
|
/**
|
|||
|
* tuicore notify event manager
|
|||
|
* @param {String} eventName event name
|
|||
|
* @param {String} subKey sub key
|
|||
|
* @param {Any} options tuicore event parameters
|
|||
|
*/
|
|||
|
async onNotifyEvent(A, e, t) {
|
|||
|
var o, n, s, r, c, M, N, T;
|
|||
|
try {
|
|||
|
if (A === dA.TUILogin.EVENT.LOGIN_STATE_CHANGED)
|
|||
|
if (e === dA.TUILogin.EVENT_SUB_KEY.USER_LOGIN_SUCCESS) {
|
|||
|
const { chat: I, userID: D, userSig: h, SDKAppID: j } = Lo.getContext();
|
|||
|
await ((o = this._callService) == null ? void 0 : o.init({ tim: I, userID: D, userSig: h, sdkAppID: j, isFromChat: !0, component: ht.TIM_CALL_KIT })), (n = this._callService) == null || n.setIsFromChat(!0), (s = this._callService) == null || s.setLogLevel(aa.NORMAL), this._addListenChatEvent();
|
|||
|
} else
|
|||
|
e === dA.TUILogin.EVENT_SUB_KEY.USER_LOGOUT_SUCCESS && (this._removeListenChatEvent(), await ((r = this._callService) == null ? void 0 : r.destroyed()));
|
|||
|
if ((c = dA.TUIChat) != null && c.EVENT && A === dA.TUIChat.EVENT.CHAT_STATE_CHANGED && e === dA.TUIChat.EVENT_SUB_KEY.CHAT_OPENED) {
|
|||
|
if ((M = this._callService) == null || M.setCurrentGroupId((t == null ? void 0 : t.groupID) || ""), Ge.getData(u.CALL, i.CALL_STATUS) !== P.IDLE)
|
|||
|
return;
|
|||
|
const I = (N = this._callService) == null ? void 0 : N.getCurrentGroupId(), D = I ? await this.getGroupAttributes((T = this._callService) == null ? void 0 : T.getTim(), I) : {};
|
|||
|
await this.updateStoreBasedOnGroupAttributes(D);
|
|||
|
}
|
|||
|
} catch (I) {
|
|||
|
console.error(`${i.PREFIX}TUICore onNotifyEvent failed, error: ${I}.`);
|
|||
|
}
|
|||
|
}
|
|||
|
// Handling the chat+call scenario, data required for the joinInGroupCall API: update store / clear relevant store data
|
|||
|
async updateStoreBasedOnGroupAttributes(A) {
|
|||
|
var e, t, o, n;
|
|||
|
(o = (t = (e = this._callService) == null ? void 0 : e.getTUICallEngineInstance()) == null ? void 0 : t.reportLog) == null || o.call(t, {
|
|||
|
name: "TUICallKit.getJoinGroupCallInfo.success",
|
|||
|
data: { groupAttributes: A }
|
|||
|
});
|
|||
|
try {
|
|||
|
const {
|
|||
|
group_id: s = "",
|
|||
|
room_id: r = 0,
|
|||
|
room_id_type: c = 0,
|
|||
|
call_media_type: M = i.UNKNOWN,
|
|||
|
// @ts-ignore
|
|||
|
user_list: N
|
|||
|
// The default value of the user list returned by the background is null
|
|||
|
} = A[i.INNER_ATTR_KIT_INFO] ? JSON.parse(A[i.INNER_ATTR_KIT_INFO]) : {};
|
|||
|
let T = (N || []).map((D) => D.userid);
|
|||
|
T = T.length && await Oe(T, (n = this._callService) == null ? void 0 : n.getTim());
|
|||
|
const I = {
|
|||
|
[i.GROUP_ID]: s,
|
|||
|
[i.GROUP_CALL_MEMBERS]: T,
|
|||
|
[i.ROOM_ID]: r,
|
|||
|
[i.CALL_MEDIA_TYPE]: vo[M],
|
|||
|
[i.ROOM_ID_TYPE]: c
|
|||
|
};
|
|||
|
Ge.updateStore(I, u.CALL);
|
|||
|
} catch (s) {
|
|||
|
console.warn(`${i.PREFIX}updateStoreBasedOnGroupAttributes fail, error: ${s}`);
|
|||
|
}
|
|||
|
}
|
|||
|
// Get group attribute
|
|||
|
async getGroupAttributes(A, e) {
|
|||
|
if (!e)
|
|||
|
return {};
|
|||
|
try {
|
|||
|
const { data: t } = await A.getGroupAttributes({
|
|||
|
groupID: e,
|
|||
|
keyList: []
|
|||
|
});
|
|||
|
return (t == null ? void 0 : t.groupAttributes) || {};
|
|||
|
} catch (t) {
|
|||
|
return console.warn(`${i.PREFIX}getGroupAttributes fail: ${t}`), {};
|
|||
|
}
|
|||
|
}
|
|||
|
isLineBusy(A) {
|
|||
|
var o;
|
|||
|
const e = Pe(A.payload.data), t = Pe(e == null ? void 0 : e.data);
|
|||
|
return (t == null ? void 0 : t.line_busy) === "line_busy" || (t == null ? void 0 : t.line_busy) === "" || ((o = t == null ? void 0 : t.data) == null ? void 0 : o.message) === "lineBusy";
|
|||
|
}
|
|||
|
async getCallKitMessage(A, e) {
|
|||
|
var I, D, h, j;
|
|||
|
const t = Pe(A.payload.data);
|
|||
|
if ((t == null ? void 0 : t.businessID) !== 1)
|
|||
|
return {};
|
|||
|
let o = "";
|
|||
|
const n = Pe(t == null ? void 0 : t.data), s = n.call_type, r = t.inviteeList, c = (I = n == null ? void 0 : n.data) == null ? void 0 : I.inviter, M = Ge.getData(u.CALL, i.LOCAL_USER_INFO).userId, N = c === M, T = (D = n == null ? void 0 : n.data) == null ? void 0 : D.cmd;
|
|||
|
switch (t == null ? void 0 : t.actionType) {
|
|||
|
case Ie.INVITE: {
|
|||
|
o = xA[T]({ callDuration: Ma(n == null ? void 0 : n.call_end) });
|
|||
|
break;
|
|||
|
}
|
|||
|
case Ie.CANCEL_INVITE:
|
|||
|
o = v(N ? "Call Cancel" : "Other Side Cancel");
|
|||
|
break;
|
|||
|
case Ie.ACCEPT_INVITE:
|
|||
|
["switchToAudio", "switchToVideo"].includes(T) ? o = (h = xA == null ? void 0 : xA[T]) == null ? void 0 : h.call(xA) : o = v("Answered");
|
|||
|
break;
|
|||
|
case Ie.REJECT_INVITE:
|
|||
|
this.isLineBusy(A) ? o = v(N ? "Line Busy" : "Other Side Line Busy") : o = v(N ? "Other Side Decline" : "Decline");
|
|||
|
break;
|
|||
|
case Ie.INVITE_TIMEOUT:
|
|||
|
["switchToAudio", "switchToVideo"].includes(T) ? o = (j = xA == null ? void 0 : xA[T]) == null ? void 0 : j.call(xA) : o = v(N ? "Other Side No Answer" : "No answer");
|
|||
|
break;
|
|||
|
}
|
|||
|
return { messageCardContent: o, callMediaType: s, inviteeList: r };
|
|||
|
}
|
|||
|
// =========================【chat: event listening】=========================
|
|||
|
_addListenChatEvent() {
|
|||
|
var A, e;
|
|||
|
if (!((A = this._callService) != null && A.getTim())) {
|
|||
|
console.warn(`${i.PREFIX}add tim event listener failed, tim is empty.`);
|
|||
|
return;
|
|||
|
}
|
|||
|
(e = this._callService) == null || e.getTim().on(Vt.EVENT.GROUP_ATTRIBUTES_UPDATED, this._handleGroupAttributesUpdated, this);
|
|||
|
}
|
|||
|
_removeListenChatEvent() {
|
|||
|
var A, e;
|
|||
|
if (!((A = this._callService) != null && A.getTim())) {
|
|||
|
console.warn(`${i.PREFIX}remove tim event listener failed, tim is empty.`);
|
|||
|
return;
|
|||
|
}
|
|||
|
(e = this._callService) == null || e.getTim().off(Vt.EVENT.GROUP_ATTRIBUTES_UPDATED, this._handleGroupAttributesUpdated, this);
|
|||
|
}
|
|||
|
/**
|
|||
|
* chat start audio/video call via click
|
|||
|
* @param {Any} options Parameters passed in when clicking on an audio/video call from chat
|
|||
|
* @param {CallMediaType} type call media type. 0 - audio; 1 - video.
|
|||
|
*/
|
|||
|
async _handleTUICoreOnClick(A, e) {
|
|||
|
var t, o;
|
|||
|
try {
|
|||
|
const { groupID: n, userIDList: s = [], ...r } = A;
|
|||
|
n ? await ((t = this._callService) == null ? void 0 : t.groupCall({ groupID: n, userIDList: s, type: e, ...r })) : s.length === 1 && await ((o = this._callService) == null ? void 0 : o.call({ userID: s[0], type: e, ...r }));
|
|||
|
} catch (n) {
|
|||
|
console.debug(n);
|
|||
|
}
|
|||
|
}
|
|||
|
async _handleGroupAttributesUpdated(A) {
|
|||
|
var n;
|
|||
|
if (Ge.getData(u.CALL, i.CALL_STATUS) !== P.IDLE)
|
|||
|
return;
|
|||
|
const e = (A == null ? void 0 : A.data) || {}, { groupID: t = "", groupAttributes: o = {} } = e;
|
|||
|
t === ((n = this._callService) == null ? void 0 : n.getCurrentGroupId()) && await this.updateStoreBasedOnGroupAttributes(o);
|
|||
|
}
|
|||
|
}
|
|||
|
const ul = 0, Ml = 1, Qt = 2;
|
|||
|
function dl({ retryFunction: a, settings: A, onError: e, onRetrying: t, onRetryFailed: o, context: n }) {
|
|||
|
return function(...s) {
|
|||
|
const r = A.retries || 5;
|
|||
|
let c = 0, M = -1, N = ul;
|
|||
|
const T = async (I, D) => {
|
|||
|
const h = n || this;
|
|||
|
try {
|
|||
|
const j = await a.apply(h, s);
|
|||
|
c = 0, I(j);
|
|||
|
} catch (j) {
|
|||
|
const m = () => {
|
|||
|
clearTimeout(M), c = 0, N = Qt, D(j);
|
|||
|
}, w = () => {
|
|||
|
N !== Qt && c < r ? (c++, N = Ml, Ye(t) && t.call(h, c, m), M = setTimeout(
|
|||
|
() => {
|
|||
|
M = -1, T(I, D);
|
|||
|
},
|
|||
|
et(A.timeout) ? 1e3 : A.timeout
|
|||
|
)) : (m(), Ye(o) && o.call(h, j));
|
|||
|
};
|
|||
|
Ye(e) ? e.call(h, j, w, D, s) : w();
|
|||
|
}
|
|||
|
};
|
|||
|
return new Promise(T);
|
|||
|
};
|
|||
|
}
|
|||
|
function Il(a) {
|
|||
|
return function(A, e, t) {
|
|||
|
const { retries: o = 5, timeout: n = 2e3, onError: s, onRetrying: r, onRetryFailed: c } = a, M = dl({
|
|||
|
retryFunction: t.value,
|
|||
|
settings: { retries: o, timeout: n },
|
|||
|
onError: s,
|
|||
|
onRetrying: r,
|
|||
|
onRetryFailed: c,
|
|||
|
context: null
|
|||
|
});
|
|||
|
return t.value = function(...N) {
|
|||
|
return M.apply(this, N);
|
|||
|
}, t;
|
|||
|
};
|
|||
|
}
|
|||
|
var Nl = Object.defineProperty, gl = Object.getOwnPropertyDescriptor, Tl = (a, A, e, t) => {
|
|||
|
for (var o = t > 1 ? void 0 : t ? gl(A, e) : A, n = a.length - 1, s; n >= 0; n--)
|
|||
|
(s = a[n]) && (o = (t ? s(A, e, o) : s(o)) || o);
|
|||
|
return t && o && Nl(A, e, o), o;
|
|||
|
};
|
|||
|
const X = at.getInstance(), pl = ie.getInstance(), Ia = class Ee {
|
|||
|
constructor(A) {
|
|||
|
this._callService = A.callService;
|
|||
|
}
|
|||
|
static getInstance(A) {
|
|||
|
return Ee.instance || (Ee.instance = new Ee(A)), Ee.instance;
|
|||
|
}
|
|||
|
addListenTuiCallEngineEvent() {
|
|||
|
var e;
|
|||
|
const A = (e = this._callService) == null ? void 0 : e.getTUICallEngineInstance();
|
|||
|
if (!A) {
|
|||
|
console.warn(`${i.PREFIX}add engine event listener failed, engine is empty.`);
|
|||
|
return;
|
|||
|
}
|
|||
|
A.on(R.ERROR, this._handleError, this), A.on(R.INVITED, this._handleNewInvitationReceived, this), A.on(R.USER_ACCEPT, this._handleUserAccept, this), A.on(R.USER_ENTER, this._handleUserEnter, this), A.on(R.USER_LEAVE, this._handleUserLeave, this), A.on(R.REJECT, this._handleInviteeReject, this), A.on(R.NO_RESP, this._handleNoResponse, this), A.on(R.LINE_BUSY, this._handleLineBusy, this), A.on(R.CALLING_CANCEL, this._handleCallingCancel, this), A.on(R.SDK_READY, this._handleSDKReady, this), A.on(R.KICKED_OUT, this._handleKickedOut, this), A.on(R.MESSAGE_SENT_BY_ME, this._messageSentByMe, this), R.CALL_MESSAGE && A.on(R.CALL_MESSAGE, this._handleCallMessage, this), R.ON_USER_NETWORK_QUALITY_CHANGED && A.on(R.ON_USER_NETWORK_QUALITY_CHANGED, this._handleNetworkQuality, this), A.on(R.CALLING_END, this._handleCallingEnd, this), A.on(R.CALL_TYPE_CHANGED, this._handleCallTypeChange, this), A.on(R.USER_VIDEO_AVAILABLE, this._handleUserVideoAvailable, this), A.on(R.USER_AUDIO_AVAILABLE, this._handleUserAudioAvailable, this), A.on(R.USER_VOICE_VOLUME, this._handleUserVoiceVolume, this), A.on(R.DEVICED_UPDATED, this._handleDeviceUpdate, this);
|
|||
|
}
|
|||
|
removeListenTuiCallEngineEvent() {
|
|||
|
var e;
|
|||
|
const A = (e = this._callService) == null ? void 0 : e.getTUICallEngineInstance();
|
|||
|
A.off(R.ERROR, this._handleError, this), A.off(R.INVITED, this._handleNewInvitationReceived, this), A.off(R.USER_ACCEPT, this._handleUserAccept, this), A.off(R.USER_ENTER, this._handleUserEnter, this), A.off(R.USER_LEAVE, this._handleUserLeave, this), A.off(R.REJECT, this._handleInviteeReject, this), A.off(R.NO_RESP, this._handleNoResponse, this), A.off(R.LINE_BUSY, this._handleLineBusy, this), A.off(R.CALLING_CANCEL, this._handleCallingCancel, this), A.off(R.SDK_READY, this._handleSDKReady, this), A.off(R.KICKED_OUT, this._handleKickedOut, this), A.off(R.MESSAGE_SENT_BY_ME, this._messageSentByMe, this), R.ON_USER_NETWORK_QUALITY_CHANGED && A.off(R.ON_USER_NETWORK_QUALITY_CHANGED, this._handleNetworkQuality, this), A.off(R.CALLING_END, this._handleCallingEnd, this), A.off(R.CALL_TYPE_CHANGED, this._handleCallTypeChange, this), A.off(R.USER_VIDEO_AVAILABLE, this._handleUserVideoAvailable, this), A.off(R.USER_AUDIO_AVAILABLE, this._handleUserAudioAvailable, this), A.off(R.USER_VOICE_VOLUME, this._handleUserVoiceVolume, this), A.off(R.DEVICED_UPDATED, this._handleDeviceUpdate, this);
|
|||
|
}
|
|||
|
_callerChangeToConnected() {
|
|||
|
var t;
|
|||
|
const A = X.getData(u.CALL, i.CALL_ROLE);
|
|||
|
X.getData(u.CALL, i.CALL_STATUS) === P.CALLING && A === IA.CALLER && (X.update(u.CALL, i.CALL_STATUS, P.CONNECTED), (t = this._callService) == null || t.startTimer());
|
|||
|
}
|
|||
|
_unNormalEventsManager(A, e) {
|
|||
|
var n;
|
|||
|
console.log(`${i.PREFIX}${e} event data: ${JSON.stringify(A)}.`);
|
|||
|
const t = X.getData(u.CALL, i.IS_GROUP), o = X.getData(u.CALL, i.REMOTE_USER_INFO_LIST);
|
|||
|
switch (e) {
|
|||
|
case R.REJECT:
|
|||
|
case R.LINE_BUSY: {
|
|||
|
const { userID: s } = bA(A);
|
|||
|
let r = e === R.REJECT ? EA.OTHER_SIDE_REJECT_CALL : EA.OTHER_SIDE_LINE_BUSY, c = qA(r);
|
|||
|
if (t) {
|
|||
|
const M = (o.find((N) => N.userId === s) || {}).displayUserInfo || s;
|
|||
|
r = e === R.REJECT ? EA.REJECT_CALL : EA.IN_BUSY, c = qA(r, M);
|
|||
|
}
|
|||
|
X.update(u.CALL, i.TOAST_INFO, { text: c }), s && ut([s]);
|
|||
|
break;
|
|||
|
}
|
|||
|
case R.NO_RESP: {
|
|||
|
const { userIDList: s = [] } = bA(A), r = t ? EA.TIMEOUT : EA.CALL_TIMEOUT, c = s.map((N) => (o.find((I) => I.userId === N) || {}).displayUserInfo || N), M = t ? qA(r, c.join()) : qA(r);
|
|||
|
X.update(u.CALL, i.TOAST_INFO, { text: M }), s.length > 0 && ut(s);
|
|||
|
break;
|
|||
|
}
|
|||
|
case R.CALLING_CANCEL: {
|
|||
|
(n = this._callService) == null || n._resetCallStore();
|
|||
|
break;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
_handleError(A) {
|
|||
|
var s;
|
|||
|
const { code: e, message: t } = A || {}, o = Object.values(xt).indexOf(e);
|
|||
|
let n = "";
|
|||
|
if (o !== -1) {
|
|||
|
const r = Object.keys(xt)[o];
|
|||
|
n = v(wo[r]), n && X.update(u.CALL, i.TOAST_INFO, { text: n, type: i.ERROR });
|
|||
|
}
|
|||
|
(s = this._callService) == null || s.executeExternalAfterCalling(), console.error(`${i.PREFIX}_handleError, errorCode: ${e}; errorMessage: ${n || t}.`);
|
|||
|
}
|
|||
|
async _handleNewInvitationReceived(A) {
|
|||
|
var w, H, b, x;
|
|||
|
console.log(`${i.PREFIX}onCallReceived event data: ${JSON.stringify(A)}.`);
|
|||
|
const { sponsor: e = "", isFromGroup: t, callMediaType: o, inviteData: n = {}, calleeIdList: s = [], groupID: r = "", roomID: c, strRoomID: M } = bA(A), N = X.getData(u.CALL, i.LOCAL_USER_INFO), T = [e, ...s.filter((B) => B !== N.userId)], I = o || n.callType, D = I === _.AUDIO ? EA.CALLEE_CALLING_AUDIO_MSG : EA.CALLEE_CALLING_VIDEO_MSG;
|
|||
|
let h = {
|
|||
|
[i.CALL_ROLE]: IA.CALLEE,
|
|||
|
[i.IS_GROUP]: t,
|
|||
|
[i.CALL_STATUS]: P.CALLING,
|
|||
|
[i.CALL_MEDIA_TYPE]: I,
|
|||
|
[i.CALL_TIPS]: v(D),
|
|||
|
[i.CALLER_USER_INFO]: { userId: e },
|
|||
|
[i.GROUP_ID]: r
|
|||
|
};
|
|||
|
da(c, M), X.updateStore(h, u.CALL), (w = this._callService) == null || w.executeExternalBeforeCalling(), (H = this._callService) != null && H.statusChanged && ((b = this._callService) == null || b.statusChanged({ oldStatus: jA.IDLE, newStatus: jA.BE_INVITED }));
|
|||
|
const j = await Oe(T, (x = this._callService) == null ? void 0 : x.getTim()), [m] = j.filter((B) => B.userId === e);
|
|||
|
j.length > 0 && X.updateStore({
|
|||
|
[i.REMOTE_USER_INFO_LIST]: j,
|
|||
|
[i.REMOTE_USER_INFO_EXCLUDE_VOLUMN_LIST]: j,
|
|||
|
[i.CALLER_USER_INFO]: {
|
|||
|
userId: e,
|
|||
|
nick: (m == null ? void 0 : m.nick) || "",
|
|||
|
avatar: (m == null ? void 0 : m.avatar) || "",
|
|||
|
displayUserInfo: (m == null ? void 0 : m.remark) || (m == null ? void 0 : m.nick) || e
|
|||
|
}
|
|||
|
}, u.CALL);
|
|||
|
}
|
|||
|
_handleUserAccept(A) {
|
|||
|
this._callerChangeToConnected(), X.update(u.CALL, i.TOAST_INFO, v("answered")), console.log(`${i.PREFIX}accept event data: ${JSON.stringify(A)}.`);
|
|||
|
}
|
|||
|
async _handleUserEnter(A) {
|
|||
|
var s;
|
|||
|
this._callerChangeToConnected();
|
|||
|
const { userID: e, data: t } = bA(A);
|
|||
|
let o = X.getData(u.CALL, i.REMOTE_USER_INFO_LIST);
|
|||
|
if (!o.find((r) => (r == null ? void 0 : r.userId) === e)) {
|
|||
|
o.push({ userId: e }), o.length > 0 && (X.update(u.CALL, i.REMOTE_USER_INFO_LIST, o), X.update(u.CALL, i.REMOTE_USER_INFO_EXCLUDE_VOLUMN_LIST, o));
|
|||
|
const [r] = await Oe([e], (s = this._callService) == null ? void 0 : s.getTim());
|
|||
|
o = X.getData(u.CALL, i.REMOTE_USER_INFO_LIST), o.forEach((c) => {
|
|||
|
(c == null ? void 0 : c.userId) === e && (c = Object.assign(c, r));
|
|||
|
});
|
|||
|
}
|
|||
|
o = o.map((r) => (r.userId === e && (r.isEnter = !0), r)), o.length > 0 && (X.update(u.CALL, i.REMOTE_USER_INFO_LIST, o), X.update(u.CALL, i.REMOTE_USER_INFO_EXCLUDE_VOLUMN_LIST, o), pl.updateViewBackgroundUserId("remote")), console.log(`${i.PREFIX}userEnter event data: ${JSON.stringify(A)}.`);
|
|||
|
}
|
|||
|
_handleUserLeave(A) {
|
|||
|
console.log(`${i.PREFIX}userLeave event data: ${JSON.stringify(A)}.`);
|
|||
|
const { data: e, userID: t } = bA(A);
|
|||
|
if (X.getData(u.CALL, i.IS_GROUP)) {
|
|||
|
const n = (X.getData(u.CALL, i.REMOTE_USER_INFO_LIST).find((r) => r.userId === t) || {}).displayUserInfo || t, s = qA(EA.END_CALL, n);
|
|||
|
X.update(u.CALL, i.TOAST_INFO, { text: s });
|
|||
|
}
|
|||
|
t && ut([t]);
|
|||
|
}
|
|||
|
_handleInviteeReject(A) {
|
|||
|
this._unNormalEventsManager(A, R.REJECT);
|
|||
|
}
|
|||
|
_handleNoResponse(A) {
|
|||
|
this._unNormalEventsManager(A, R.NO_RESP);
|
|||
|
}
|
|||
|
_handleLineBusy(A) {
|
|||
|
this._unNormalEventsManager(A, R.LINE_BUSY);
|
|||
|
}
|
|||
|
_handleCallingCancel(A) {
|
|||
|
var e;
|
|||
|
(e = this._callService) == null || e.executeExternalAfterCalling(), this._unNormalEventsManager(A, R.CALLING_CANCEL);
|
|||
|
}
|
|||
|
_handleCallingEnd(A) {
|
|||
|
var e, t;
|
|||
|
console.log(`${i.PREFIX}callEnd event data: ${JSON.stringify(A)}.`), (e = this._callService) == null || e.executeExternalAfterCalling(), (t = this._callService) == null || t._resetCallStore();
|
|||
|
}
|
|||
|
// SDK_READY 后才能调用 tim 接口, 否则登录后立刻获取导致调用接口失败. v2.27.4+、v3 接口 login 后会抛出 SDK_READY
|
|||
|
async _handleSDKReady(A) {
|
|||
|
var t, o, n;
|
|||
|
let e = X.getData(u.CALL, i.LOCAL_USER_INFO);
|
|||
|
e = await il(e.userId, (t = this._callService) == null ? void 0 : t.getTim()), (n = this._callService) == null || n.setDefaultOfflinePushInfo({ ...(o = this._callService) == null ? void 0 : o.getDefaultOfflinePushInfo(), title: e == null ? void 0 : e.displayUserInfo }), X.update(u.CALL, i.LOCAL_USER_INFO, e), X.update(u.CALL, i.LOCAL_USER_INFO_EXCLUDE_VOLUMN, e);
|
|||
|
}
|
|||
|
_handleKickedOut(A) {
|
|||
|
var e, t, o;
|
|||
|
console.log(`${i.PREFIX}kickOut event data: ${JSON.stringify(A)}.`), (e = this._callService) != null && e.kickedOut && ((t = this._callService) == null || t.kickedOut(A)), X.update(u.CALL, i.CALL_TIPS, qA(EA.KICK_OUT)), (o = this._callService) == null || o._resetCallStore();
|
|||
|
}
|
|||
|
_messageSentByMe(A) {
|
|||
|
var t, o;
|
|||
|
const e = A == null ? void 0 : A.data;
|
|||
|
(t = this._callService) != null && t.onMessageSentByMe && ((o = this._callService) == null || o.onMessageSentByMe(e));
|
|||
|
}
|
|||
|
_handleCallMessage(A) {
|
|||
|
const e = bA(A);
|
|||
|
this._callService._chatCombine.callTUIService({ message: e });
|
|||
|
}
|
|||
|
_handleCallTypeChange(A) {
|
|||
|
const { newCallType: e, type: t } = bA(A);
|
|||
|
X.update(u.CALL, i.CALL_MEDIA_TYPE, e || t);
|
|||
|
}
|
|||
|
_handleNetworkQuality(A) {
|
|||
|
const { networkQualityList: e = [] } = bA(A);
|
|||
|
X.update(u.CALL, i.NETWORK_STATUS, e);
|
|||
|
const t = X.getData(u.CALL, i.IS_GROUP), o = X.getData(u.CALL, i.LOCAL_USER_INFO);
|
|||
|
if (X.getData(u.CALL, i.REMOTE_USER_INFO_LIST), !t && e.find((s) => (o == null ? void 0 : o.userId) === (s == null ? void 0 : s.userId) && (s == null ? void 0 : s.quality) >= Ro)) {
|
|||
|
X.update(u.CALL, i.CALL_TIPS, v(EA.LOCAL_NETWORK_IS_POOR));
|
|||
|
return;
|
|||
|
}
|
|||
|
}
|
|||
|
async _startRemoteView(A) {
|
|||
|
var e;
|
|||
|
if (!A) {
|
|||
|
console.warn(`${i.PREFIX}_startRemoteView userID is empty`);
|
|||
|
return;
|
|||
|
}
|
|||
|
if (!document.getElementById(A))
|
|||
|
return console.warn(`${i.PREFIX}_startRemoteView can't find HTMLElement sid: ${A}`), Promise.reject();
|
|||
|
try {
|
|||
|
const t = X.getData(u.CALL, i.DISPLAY_MODE);
|
|||
|
await ((e = this._callService) == null ? void 0 : e.getTUICallEngineInstance().startRemoteView({ userID: A, videoViewDomID: A, options: { objectFit: t } }));
|
|||
|
} catch (t) {
|
|||
|
return console.error(`${i.PREFIX}_startRemoteView error: ${t}.`), Promise.reject(t);
|
|||
|
}
|
|||
|
}
|
|||
|
_setRemoteUserInfoAudioVideoAvailable(A, e, t) {
|
|||
|
let o = X.getData(u.CALL, i.REMOTE_USER_INFO_LIST);
|
|||
|
o = o.map((n) => {
|
|||
|
if (n.userId === t) {
|
|||
|
if (e === i.AUDIO)
|
|||
|
return { ...n, isAudioAvailable: A };
|
|||
|
if (e === i.VIDEO)
|
|||
|
return { ...n, isVideoAvailable: A };
|
|||
|
}
|
|||
|
return n;
|
|||
|
}), o.length > 0 && (X.update(u.CALL, i.REMOTE_USER_INFO_LIST, o), X.update(u.CALL, i.REMOTE_USER_INFO_EXCLUDE_VOLUMN_LIST, o));
|
|||
|
}
|
|||
|
async _handleUserVideoAvailable(A) {
|
|||
|
const { userID: e, isVideoAvailable: t } = bA(A);
|
|||
|
console.log(`${i.PREFIX}_handleUserVideoAvailable event data: ${JSON.stringify(A)}.`);
|
|||
|
try {
|
|||
|
t && await this._startRemoteView(e);
|
|||
|
} catch (o) {
|
|||
|
console.error(`${i.PREFIX}_startRemoteView failed, error: ${o}.`);
|
|||
|
}
|
|||
|
this._setRemoteUserInfoAudioVideoAvailable(t, i.VIDEO, e);
|
|||
|
}
|
|||
|
_handleUserAudioAvailable(A) {
|
|||
|
const { userID: e, isAudioAvailable: t } = bA(A);
|
|||
|
console.log(`${i.PREFIX}_handleUserAudioAvailable event data: ${JSON.stringify(A)}.`), this._setRemoteUserInfoAudioVideoAvailable(t, i.AUDIO, e);
|
|||
|
}
|
|||
|
_handleUserVoiceVolume(A) {
|
|||
|
try {
|
|||
|
const { volumeMap: e } = bA(A);
|
|||
|
if ((e || []).length === 0)
|
|||
|
return;
|
|||
|
const t = X.getData(u.CALL, i.LOCAL_USER_INFO);
|
|||
|
let o = X.getData(u.CALL, i.REMOTE_USER_INFO_LIST);
|
|||
|
const [n] = e.filter((c) => c.userId === t.userId), s = e.reduce((c, M) => M.userId !== t.userId ? { ...c, [M.userId]: M.audioVolume } : c, {});
|
|||
|
t.volume = n.audioVolume, o = o.map((c) => ({ ...c, volume: s[c.userId] }));
|
|||
|
const r = {
|
|||
|
[i.LOCAL_USER_INFO]: t,
|
|||
|
[i.REMOTE_USER_INFO_LIST]: o
|
|||
|
};
|
|||
|
X.updateStore(r, u.CALL);
|
|||
|
} catch (e) {
|
|||
|
console.debug(e);
|
|||
|
}
|
|||
|
}
|
|||
|
_handleDeviceUpdate(A) {
|
|||
|
const { cameraList: e, microphoneList: t, speakerList: o, currentCamera: n, currentMicrophone: s, currentSpeaker: r } = A;
|
|||
|
X.update(u.CALL, i.DEVICE_LIST, { cameraList: e, microphoneList: t, speakerList: o, currentCamera: n, currentMicrophone: s, currentSpeaker: r });
|
|||
|
}
|
|||
|
};
|
|||
|
Tl([
|
|||
|
Il({
|
|||
|
retries: 5,
|
|||
|
timeout: 200,
|
|||
|
onRetrying(a) {
|
|||
|
console.warn(`${i.PREFIX}_startRemoteView, retrying [${a}]`);
|
|||
|
}
|
|||
|
})
|
|||
|
], Ia.prototype, "_startRemoteView", 1);
|
|||
|
let Dl = Ia;
|
|||
|
var yl = Object.defineProperty, Cl = Object.getOwnPropertyDescriptor, oA = (a, A, e, t) => {
|
|||
|
for (var o = t > 1 ? void 0 : t ? Cl(A, e) : A, n = a.length - 1, s; n >= 0; n--)
|
|||
|
(s = a[n]) && (o = (t ? s(A, e, o) : s(o)) || o);
|
|||
|
return t && o && yl(A, e, o), o;
|
|||
|
};
|
|||
|
const V = sa.getInstance(), g = at.getInstance(), YA = ie.getInstance();
|
|||
|
YA.setTUIStore(g);
|
|||
|
const Zt = "3.3.7", Sl = "vue3", aA = class me {
|
|||
|
constructor() {
|
|||
|
this._tim = null, this._TUICore = null, this._timerId = -1, this._startTimeStamp = rt(), this._bellContext = null, this._isFromChat = !1, this._currentGroupId = "", this._defaultOfflinePushInfo = {
|
|||
|
title: "",
|
|||
|
description: v("you have a new call")
|
|||
|
}, this._permissionCheckTimer = null, this._chatCombine = null, this._engineEventHandler = null, this._handleCallStatusChange = async (A) => {
|
|||
|
var e, t, o, n;
|
|||
|
try {
|
|||
|
const s = {
|
|||
|
callRole: g.getData(u.CALL, i.CALL_ROLE),
|
|||
|
callStatus: g.getData(u.CALL, i.CALL_STATUS)
|
|||
|
};
|
|||
|
if (this._bellContext.setBellProperties(s), A === P.CALLING)
|
|||
|
await ((e = this == null ? void 0 : this._bellContext) == null ? void 0 : e.play());
|
|||
|
else {
|
|||
|
if (A === P.CONNECTED) {
|
|||
|
const r = g.getData(u.CALL, i.IS_GROUP), c = g.getData(u.CALL, i.CALL_MEDIA_TYPE), M = g.getData(u.CALL, i.REMOTE_USER_INFO_LIST), N = r ? jA.DIALING_GROUP : jA.DIALING_C2C;
|
|||
|
g.update(u.CALL, i.CALL_TIPS, ""), this.statusChanged && this.statusChanged({ oldStatus: N, newStatus: We() }), !r && c === _.VIDEO && this.switchScreen(M[0].domId);
|
|||
|
}
|
|||
|
if (A === P.IDLE && this._isFromChat) {
|
|||
|
const r = this._currentGroupId ? await ((t = this._chatCombine) == null ? void 0 : t.getGroupAttributes(this._tim, this._currentGroupId)) : {};
|
|||
|
await ((o = this._chatCombine) == null ? void 0 : o.updateStoreBasedOnGroupAttributes(r, g, this));
|
|||
|
}
|
|||
|
await ((n = this == null ? void 0 : this._bellContext) == null ? void 0 : n.stop());
|
|||
|
}
|
|||
|
} catch (s) {
|
|||
|
console.warn(`${i.PREFIX}handleCallStatusChange, ${s}.`);
|
|||
|
}
|
|||
|
}, console.log(`${i.PREFIX}version: ${Zt}`), this._watchTUIStore(), this._engineEventHandler = Dl.getInstance({ callService: this }), this._chatCombine = ge.getInstance({ callService: this });
|
|||
|
}
|
|||
|
static getInstance() {
|
|||
|
return me.instance || (me.instance = new me()), me.instance;
|
|||
|
}
|
|||
|
async init(A) {
|
|||
|
var e, t;
|
|||
|
try {
|
|||
|
if (this._tuiCallEngine)
|
|||
|
return;
|
|||
|
let { userID: o, tim: n, userSig: s, sdkAppID: r, SDKAppID: c, isFromChat: M, component: N = ht.TUI_CALL_KIT } = A;
|
|||
|
this._TUICore && (r = this._TUICore.SDKAppID, n = this._TUICore.tim), this._tim = n, console.log(`${i.PREFIX}init sdkAppId: ${r || c}, userId: ${o}`), this._tuiCallEngine = ho.createInstance({
|
|||
|
tim: n,
|
|||
|
SDKAppID: r || c,
|
|||
|
// 兼容传入 SDKAppID 的问题
|
|||
|
// @ts-ignore
|
|||
|
frameWork: Sl,
|
|||
|
language: 6,
|
|||
|
callkitVersion: Zt,
|
|||
|
chat: M || !1,
|
|||
|
component: N
|
|||
|
}), YA.setEngineInstance(this._tuiCallEngine), this._addListenTuiCallEngineEvent(), this._bellContext = new al(), g.update(u.CALL, i.LOCAL_USER_INFO, { userId: o }), g.update(u.CALL, i.LOCAL_USER_INFO_EXCLUDE_VOLUMN, { userId: o }), YA.updateViewBackgroundUserId("local"), await this._tuiCallEngine.login({ userID: o, userSig: s, assetsPath: "" });
|
|||
|
const T = g.getData(u.CALL, i.CUSTOM_UI_CONFIG);
|
|||
|
(t = (e = this._tuiCallEngine) == null ? void 0 : e.reportLog) == null || t.call(e, {
|
|||
|
name: "TUICallkit.init",
|
|||
|
data: {
|
|||
|
uiConfig: T
|
|||
|
}
|
|||
|
});
|
|||
|
} catch (o) {
|
|||
|
throw console.error(`${i.PREFIX}init failed, error: ${o}.`), o;
|
|||
|
}
|
|||
|
}
|
|||
|
// component destroy
|
|||
|
async destroyed() {
|
|||
|
var A;
|
|||
|
try {
|
|||
|
const e = g.getData(u.CALL, i.CALL_STATUS);
|
|||
|
if (e !== P.IDLE)
|
|||
|
throw new Error(`please destroyed when status is idle, current status: ${e}`);
|
|||
|
this._tuiCallEngine && (this._removeListenTuiCallEngineEvent(), await this._tuiCallEngine.destroyInstance(), this._tuiCallEngine = null), (A = this._bellContext) == null || A.destroy(), this._bellContext = null;
|
|||
|
} catch (e) {
|
|||
|
throw console.error(`${i.PREFIX}destroyed failed, error: ${e}.`), e;
|
|||
|
}
|
|||
|
}
|
|||
|
async call(A) {
|
|||
|
if (g.getData(u.CALL, i.CALL_STATUS) === P.IDLE)
|
|||
|
try {
|
|||
|
const { type: e, userID: t, offlinePushInfo: o } = A;
|
|||
|
if (g.getData(u.CALL, i.CALL_STATUS) !== P.IDLE)
|
|||
|
return;
|
|||
|
await this._updateCallStoreBeforeCall(e, [{ userId: t }]), this.executeExternalBeforeCalling(), A.offlinePushInfo = { ...this._defaultOfflinePushInfo, ...o };
|
|||
|
const n = await this._tuiCallEngine.call(A);
|
|||
|
await this._updateCallStoreAfterCall([t], n);
|
|||
|
} catch (e) {
|
|||
|
this._handleCallError(e, "call");
|
|||
|
}
|
|||
|
}
|
|||
|
async groupCall(A) {
|
|||
|
if (g.getData(u.CALL, i.CALL_STATUS) === P.IDLE)
|
|||
|
try {
|
|||
|
const { userIDList: e, type: t, groupID: o, offlinePushInfo: n } = A;
|
|||
|
if (g.getData(u.CALL, i.CALL_STATUS) !== P.IDLE)
|
|||
|
return;
|
|||
|
const s = e.map((c) => ({ userId: c }));
|
|||
|
await this._updateCallStoreBeforeCall(t, s, o), this.executeExternalBeforeCalling(), A.offlinePushInfo = { ...this._defaultOfflinePushInfo, ...n };
|
|||
|
const r = await this._tuiCallEngine.groupCall(A);
|
|||
|
await this._updateCallStoreAfterCall(e, r);
|
|||
|
} catch (e) {
|
|||
|
this._handleCallError(e, "groupCall");
|
|||
|
}
|
|||
|
}
|
|||
|
async inviteUser(A) {
|
|||
|
if (g.getData(u.CALL, i.CALL_STATUS) !== P.IDLE)
|
|||
|
try {
|
|||
|
const { userIDList: e } = A;
|
|||
|
let t = await Oe(e, this.getTim());
|
|||
|
const o = g.getData(u.CALL, i.REMOTE_USER_INFO_LIST);
|
|||
|
g.update(u.CALL, i.REMOTE_USER_INFO_LIST, [...o, ...t]), g.update(u.CALL, i.REMOTE_USER_INFO_EXCLUDE_VOLUMN_LIST, [...o, ...t]), this._tuiCallEngine && await this._tuiCallEngine.inviteUser(A);
|
|||
|
} catch (e) {
|
|||
|
throw console.error(`${i.PREFIX}inviteUser failed, error: ${e}.`), this._resetCallStore(), e;
|
|||
|
}
|
|||
|
}
|
|||
|
async joinInGroupCall(A) {
|
|||
|
if (g.getData(u.CALL, i.CALL_STATUS) !== P.CONNECTED)
|
|||
|
try {
|
|||
|
const e = {
|
|||
|
[i.CALL_ROLE]: IA.CALLEE,
|
|||
|
[i.IS_GROUP]: !0,
|
|||
|
[i.CALL_STATUS]: P.CONNECTED,
|
|||
|
[i.CALL_MEDIA_TYPE]: A.type,
|
|||
|
[i.GROUP_ID]: A.groupID,
|
|||
|
[i.ROOM_ID]: A.roomID
|
|||
|
};
|
|||
|
g.updateStore(e, u.CALL);
|
|||
|
const t = await this._tuiCallEngine.joinInGroupCall(A), o = this._getFeatureButtonDefaultState(_A.Camera) === Te.Close;
|
|||
|
A.type === _.VIDEO && !o && await this.openCamera(i.LOCAL_VIDEO), g.update(u.CALL, i.IS_CLICKABLE, !0), this.startTimer(), Mt(this._tuiCallEngine), await this._tuiCallEngine.setVideoQuality(g.getData(u.CALL, i.VIDEO_RESOLUTION));
|
|||
|
const n = g.getData(u.CALL, i.LOCAL_USER_INFO);
|
|||
|
g.update(u.CALL, i.LOCAL_USER_INFO, { ...n, isEnter: !0 }), g.update(u.CALL, i.LOCAL_USER_INFO_EXCLUDE_VOLUMN, { ...n, isEnter: !0 }), oe(!0, i.AUDIO);
|
|||
|
} catch (e) {
|
|||
|
this._handleCallError(e, "joinInGroupCall");
|
|||
|
}
|
|||
|
}
|
|||
|
// ===============================【其它对外接口】===============================
|
|||
|
getTUICallEngineInstance() {
|
|||
|
return (this == null ? void 0 : this._tuiCallEngine) || null;
|
|||
|
}
|
|||
|
setLogLevel(A) {
|
|||
|
var e;
|
|||
|
(e = this == null ? void 0 : this._tuiCallEngine) == null || e.setLogLevel(A);
|
|||
|
}
|
|||
|
setLanguage(A) {
|
|||
|
A && Object.values(ta).includes(A) && g.update(u.CALL, i.LANGUAGE, A);
|
|||
|
}
|
|||
|
enableFloatWindow(A) {
|
|||
|
g.update(u.CALL, i.ENABLE_FLOAT_WINDOW, A);
|
|||
|
}
|
|||
|
async setSelfInfo(A) {
|
|||
|
const { nickName: e, avatar: t } = A;
|
|||
|
try {
|
|||
|
await this._tuiCallEngine.setSelfInfo({ nickName: e, avatar: t });
|
|||
|
} catch (o) {
|
|||
|
console.error(`${i.PREFIX}setSelfInfo failed, error: ${o}.`);
|
|||
|
}
|
|||
|
}
|
|||
|
async enableVirtualBackground(A) {
|
|||
|
g.update(u.CALL, i.IS_SHOW_ENABLE_VIRTUAL_BACKGROUND, A);
|
|||
|
}
|
|||
|
async enableAIVoice(A) {
|
|||
|
try {
|
|||
|
await this._tuiCallEngine.enableAIVoice(A), console.log(`${i.PREFIX}enableAIVoice: ${A}.`);
|
|||
|
} catch (e) {
|
|||
|
throw console.error(`${i.PREFIX}enableAIVoice failed, error: ${e}.`), e;
|
|||
|
}
|
|||
|
}
|
|||
|
async setCallingBell(A) {
|
|||
|
let e = !0;
|
|||
|
if (e = await Bo(A), !e) {
|
|||
|
console.warn(`${i.PREFIX}setCallingBell failed, filePath: ${A}.`);
|
|||
|
return;
|
|||
|
}
|
|||
|
const t = { calleeBellFilePath: A };
|
|||
|
this._bellContext.setBellProperties(t);
|
|||
|
}
|
|||
|
async enableMuteMode(A) {
|
|||
|
try {
|
|||
|
const e = { isMuteBell: A };
|
|||
|
this._bellContext.setBellProperties(e), await this._bellContext.setBellMute(A);
|
|||
|
} catch (e) {
|
|||
|
console.warn(`${i.PREFIX}enableMuteMode failed, error: ${e}.`);
|
|||
|
}
|
|||
|
}
|
|||
|
hideFeatureButton(A) {
|
|||
|
YA.hideFeatureButton(A);
|
|||
|
}
|
|||
|
setLocalViewBackgroundImage(A) {
|
|||
|
YA.setLocalViewBackgroundImage(A);
|
|||
|
}
|
|||
|
setRemoteViewBackgroundImage(A, e) {
|
|||
|
YA.setRemoteViewBackgroundImage(A, e);
|
|||
|
}
|
|||
|
setLayoutMode(A) {
|
|||
|
YA.setLayoutMode(A);
|
|||
|
}
|
|||
|
setCameraDefaultState(A) {
|
|||
|
YA.setCameraDefaultState(A);
|
|||
|
}
|
|||
|
async accept() {
|
|||
|
var e, t, o, n, s, r;
|
|||
|
const A = g.getData(u.CALL, i.CALL_STATUS);
|
|||
|
if ((t = (e = this._tuiCallEngine) == null ? void 0 : e.reportLog) == null || t.call(e, {
|
|||
|
name: "TUICallKit.accept.start",
|
|||
|
data: { callStatus: A }
|
|||
|
}), A !== P.CONNECTED)
|
|||
|
try {
|
|||
|
g.update(u.CALL, i.CALL_STATUS, P.CONNECTED), Mt(this._tuiCallEngine);
|
|||
|
const c = await this._tuiCallEngine.accept();
|
|||
|
if (c) {
|
|||
|
(n = this._chatCombine) == null || n.callTUIService({ message: (o = c == null ? void 0 : c.data) == null ? void 0 : o.message }), g.update(u.CALL, i.IS_CLICKABLE, !0), this.startTimer();
|
|||
|
const M = g.getData(u.CALL, i.CALL_MEDIA_TYPE), N = this._getFeatureButtonDefaultState(_A.Camera) === Te.Close;
|
|||
|
M === _.VIDEO && !N && await this.openCamera(i.LOCAL_VIDEO), await this._tuiCallEngine.setVideoQuality(g.getData(u.CALL, i.VIDEO_RESOLUTION));
|
|||
|
const T = g.getData(u.CALL, i.LOCAL_USER_INFO);
|
|||
|
g.update(u.CALL, i.LOCAL_USER_INFO, { ...T, isEnter: !0 }), g.update(u.CALL, i.LOCAL_USER_INFO_EXCLUDE_VOLUMN, { ...T, isEnter: !0 }), oe(!0, i.AUDIO);
|
|||
|
}
|
|||
|
} catch (c) {
|
|||
|
if ((r = (s = this._tuiCallEngine) == null ? void 0 : s.reportLog) == null || r.call(s, {
|
|||
|
name: "TUICallKit.accept.fail",
|
|||
|
level: "error",
|
|||
|
error: c
|
|||
|
}), Pt(c))
|
|||
|
return;
|
|||
|
dt(c, _.AUDIO, this._tuiCallEngine), this._resetCallStore();
|
|||
|
}
|
|||
|
}
|
|||
|
async hangup() {
|
|||
|
if (g.getData(u.CALL, i.CALL_STATUS) !== P.IDLE) {
|
|||
|
try {
|
|||
|
const A = await this._tuiCallEngine.hangup();
|
|||
|
A == null || A.forEach((e) => {
|
|||
|
var t, o;
|
|||
|
(e == null ? void 0 : e.code) === 0 && ((o = this._chatCombine) == null || o.callTUIService({ message: (t = e == null ? void 0 : e.data) == null ? void 0 : t.message }));
|
|||
|
});
|
|||
|
} catch (A) {
|
|||
|
console.debug(A);
|
|||
|
}
|
|||
|
this._resetCallStore();
|
|||
|
}
|
|||
|
}
|
|||
|
async reject() {
|
|||
|
var A, e;
|
|||
|
if (g.getData(u.CALL, i.CALL_STATUS) !== P.IDLE) {
|
|||
|
try {
|
|||
|
const t = await this._tuiCallEngine.reject();
|
|||
|
(t == null ? void 0 : t.code) === 0 && ((e = this._chatCombine) == null || e.callTUIService({ message: (A = t == null ? void 0 : t.data) == null ? void 0 : A.message }));
|
|||
|
} catch (t) {
|
|||
|
console.debug(t);
|
|||
|
}
|
|||
|
this._resetCallStore();
|
|||
|
}
|
|||
|
}
|
|||
|
async openCamera(A) {
|
|||
|
try {
|
|||
|
await this._tuiCallEngine.openCamera(A), oe(!0, i.VIDEO);
|
|||
|
} catch (e) {
|
|||
|
dt(e, _.VIDEO, this._tuiCallEngine), console.error(`${i.PREFIX}openCamera error: ${e}.`);
|
|||
|
}
|
|||
|
}
|
|||
|
async closeCamera() {
|
|||
|
try {
|
|||
|
await this._tuiCallEngine.closeCamera(), oe(!1, i.VIDEO);
|
|||
|
} catch (A) {
|
|||
|
console.error(`${i.PREFIX}closeCamera error: ${A}.`);
|
|||
|
}
|
|||
|
}
|
|||
|
async openMicrophone() {
|
|||
|
try {
|
|||
|
await this._tuiCallEngine.openMicrophone(), oe(!0, i.AUDIO);
|
|||
|
} catch (A) {
|
|||
|
console.error(`${i.PREFIX}openMicrophone failed, error: ${A}.`);
|
|||
|
}
|
|||
|
}
|
|||
|
async closeMicrophone() {
|
|||
|
try {
|
|||
|
await this._tuiCallEngine.closeMicrophone(), oe(!1, i.AUDIO);
|
|||
|
} catch (A) {
|
|||
|
console.error(`${i.PREFIX}closeMicrophone failed, error: ${A}.`);
|
|||
|
}
|
|||
|
}
|
|||
|
unMuteSpeaker() {
|
|||
|
var A, e;
|
|||
|
try {
|
|||
|
const t = (e = (A = this._tuiCallEngine) == null ? void 0 : A.getTRTCCloudInstance) == null ? void 0 : e.call(A);
|
|||
|
t && (t.muteAllRemoteAudio(!1), g.update(u.CALL, i.IS_MUTE_SPEAKER, !1));
|
|||
|
} catch (t) {
|
|||
|
console.error(`${i.PREFIX}unMuteSpeaker failed, error: ${t}.`);
|
|||
|
}
|
|||
|
}
|
|||
|
muteSpeaker() {
|
|||
|
var A, e;
|
|||
|
try {
|
|||
|
const t = (e = (A = this._tuiCallEngine) == null ? void 0 : A.getTRTCCloudInstance) == null ? void 0 : e.call(A);
|
|||
|
t && (t.muteAllRemoteAudio(!0), g.update(u.CALL, i.IS_MUTE_SPEAKER, !0));
|
|||
|
} catch (t) {
|
|||
|
console.error(`${i.PREFIX}muteSpeaker failed, error: ${t}.`);
|
|||
|
}
|
|||
|
}
|
|||
|
switchScreen(A) {
|
|||
|
A && g.update(u.CALL, i.BIG_SCREEN_USER_ID, A);
|
|||
|
}
|
|||
|
async switchCallMediaType() {
|
|||
|
var A, e;
|
|||
|
try {
|
|||
|
const t = g.getData(u.CALL, i.CALL_MEDIA_TYPE);
|
|||
|
if (t === _.AUDIO) {
|
|||
|
console.warn(`${i.PREFIX}switchCallMediaType failed, ${t} not support.`);
|
|||
|
return;
|
|||
|
}
|
|||
|
const o = await this._tuiCallEngine.switchCallMediaType(_.AUDIO);
|
|||
|
(o == null ? void 0 : o.code) === 0 && ((e = this._chatCombine) == null || e.callTUIService({ message: (A = o == null ? void 0 : o.data) == null ? void 0 : A.message })), g.update(u.CALL, i.CALL_MEDIA_TYPE, _.AUDIO);
|
|||
|
const s = g.getData(u.CALL, i.IS_GROUP) ? jA.CALLING_GROUP_VIDEO : jA.CALLING_C2C_VIDEO, r = We();
|
|||
|
this.statusChanged && this.statusChanged({ oldStatus: s, newStatus: r });
|
|||
|
} catch (t) {
|
|||
|
console.error(`${i.PREFIX}switchCallMediaType failed, error: ${t}.`);
|
|||
|
}
|
|||
|
}
|
|||
|
async switchCamera() {
|
|||
|
const e = g.getData(u.CALL, i.CAMERA_POSITION) === we.BACK ? we.FRONT : we.BACK;
|
|||
|
try {
|
|||
|
await this._tuiCallEngine.switchCamera(e), g.update(u.CALL, i.CAMERA_POSITION, e);
|
|||
|
} catch (t) {
|
|||
|
console.error(`${i.PREFIX}_switchCamera failed, error: ${t}.`);
|
|||
|
}
|
|||
|
}
|
|||
|
async setBlurBackground(A) {
|
|||
|
try {
|
|||
|
await this._tuiCallEngine.setBlurBackground(A ? ko : 0), g.update(u.CALL, i.ENABLE_VIRTUAL_BACKGROUND, A);
|
|||
|
} catch (e) {
|
|||
|
console.error(`${i.PREFIX}_setBlurBackground failed, error: ${e}.`);
|
|||
|
}
|
|||
|
}
|
|||
|
async switchDevice(A) {
|
|||
|
try {
|
|||
|
await this._tuiCallEngine.switchDevice(A);
|
|||
|
} catch (e) {
|
|||
|
console.error(`${i.PREFIX}_switchDevice failed, error: ${e}.`);
|
|||
|
}
|
|||
|
}
|
|||
|
async getDeviceList(A) {
|
|||
|
try {
|
|||
|
return await this._tuiCallEngine.getDeviceList(A);
|
|||
|
} catch (e) {
|
|||
|
this._handleCallError(e, "call");
|
|||
|
}
|
|||
|
}
|
|||
|
// ==========================【TUICallEngine 事件处理】==========================
|
|||
|
_addListenTuiCallEngineEvent() {
|
|||
|
this._engineEventHandler.addListenTuiCallEngineEvent();
|
|||
|
}
|
|||
|
_removeListenTuiCallEngineEvent() {
|
|||
|
this._engineEventHandler.removeListenTuiCallEngineEvent();
|
|||
|
}
|
|||
|
setCallback(A) {
|
|||
|
const { beforeCalling: e, afterCalling: t, onMinimized: o, onMessageSentByMe: n, kickedOut: s, statusChanged: r } = A;
|
|||
|
e && (this.beforeCalling = e), t && (this.afterCalling = t), o && (this.onMinimized = o), n && (this.onMessageSentByMe = n), s && (this.kickedOut = s), r && (this.statusChanged = r);
|
|||
|
}
|
|||
|
toggleMinimize() {
|
|||
|
const A = g.getData(u.CALL, i.IS_MINIMIZED);
|
|||
|
g.update(u.CALL, i.IS_MINIMIZED, !A), console.log(`${i.PREFIX}toggleMinimize: ${A} -> ${!A}.`), this.onMinimized && this.onMinimized(A, !A);
|
|||
|
}
|
|||
|
executeExternalBeforeCalling() {
|
|||
|
this.beforeCalling && this.beforeCalling();
|
|||
|
}
|
|||
|
executeExternalAfterCalling() {
|
|||
|
this.afterCalling && this.afterCalling();
|
|||
|
}
|
|||
|
setVideoDisplayMode(A) {
|
|||
|
g.update(u.CALL, i.DISPLAY_MODE, A);
|
|||
|
}
|
|||
|
async setVideoResolution(A) {
|
|||
|
var e;
|
|||
|
try {
|
|||
|
if (!A)
|
|||
|
return;
|
|||
|
g.update(u.CALL, i.VIDEO_RESOLUTION, A), await ((e = this._tuiCallEngine) == null ? void 0 : e.setVideoQuality(A));
|
|||
|
} catch (t) {
|
|||
|
console.warn(`${i.PREFIX}setVideoResolution failed, error: ${t}.`);
|
|||
|
}
|
|||
|
}
|
|||
|
// 通话时长更新
|
|||
|
startTimer() {
|
|||
|
this._timerId === -1 && (this._startTimeStamp = rt(), this._timerId = He.run(i.TIMEOUT, this._updateCallDuration.bind(this), { delay: 1e3 }));
|
|||
|
}
|
|||
|
// =========================【private methods for service use】=========================
|
|||
|
// 处理 “呼叫” 抛出的异常
|
|||
|
_handleCallError(A, e) {
|
|||
|
if (this._permissionCheckTimer && clearInterval(this._permissionCheckTimer), !Pt(A))
|
|||
|
throw dt(A, _.AUDIO, this._tuiCallEngine), console.error(`${i.PREFIX}${e} failed, error: ${A}.`), this._resetCallStore(), A;
|
|||
|
}
|
|||
|
async _updateCallStoreBeforeCall(A, e, t) {
|
|||
|
const o = t || g.getData(u.CALL, i.IS_MINIMIZED) ? EA.CALLER_GROUP_CALLING_MSG : EA.CALLER_CALLING_MSG;
|
|||
|
let n = {
|
|||
|
[i.CALL_MEDIA_TYPE]: A,
|
|||
|
[i.CALL_ROLE]: IA.CALLER,
|
|||
|
[i.REMOTE_USER_INFO_LIST]: e,
|
|||
|
[i.REMOTE_USER_INFO_EXCLUDE_VOLUMN_LIST]: e,
|
|||
|
[i.IS_GROUP]: !!t,
|
|||
|
[i.CALL_TIPS]: v(o),
|
|||
|
[i.GROUP_ID]: t
|
|||
|
};
|
|||
|
g.updateStore({ ...n, [i.CALL_STATUS]: P.CALLING }, u.CALL), this.statusChanged && this.statusChanged({
|
|||
|
oldStatus: jA.IDLE,
|
|||
|
newStatus: t ? jA.DIALING_GROUP : jA.DIALING_C2C
|
|||
|
}), Mt(this._tuiCallEngine);
|
|||
|
const s = await Oe(e.map((r) => r.userId), this.getTim());
|
|||
|
s.length > 0 && (g.update(u.CALL, i.REMOTE_USER_INFO_LIST, s), g.update(u.CALL, i.REMOTE_USER_INFO_EXCLUDE_VOLUMN_LIST, s));
|
|||
|
}
|
|||
|
async _updateCallStoreAfterCall(A, e) {
|
|||
|
var t, o;
|
|||
|
if (e) {
|
|||
|
g.update(u.CALL, i.IS_CLICKABLE, !0), da(e == null ? void 0 : e.roomID, e == null ? void 0 : e.strRoomID);
|
|||
|
const n = g.getData(u.CALL, i.CALL_MEDIA_TYPE);
|
|||
|
if (e.code === 0) {
|
|||
|
(o = this._chatCombine) == null || o.callTUIService({ message: (t = e == null ? void 0 : e.data) == null ? void 0 : t.message });
|
|||
|
try {
|
|||
|
await this._tuiCallEngine.setVideoQuality(g.getData(u.CALL, i.VIDEO_RESOLUTION));
|
|||
|
} catch (c) {
|
|||
|
console.warn(`${i.PREFIX}setVideoQuality failed, error: ${c}.`);
|
|||
|
}
|
|||
|
} else {
|
|||
|
this._resetCallStore();
|
|||
|
return;
|
|||
|
}
|
|||
|
const s = this._getFeatureButtonDefaultState(_A.Camera) === Te.Close;
|
|||
|
n === _.VIDEO && !s && await this.openCamera(i.LOCAL_VIDEO);
|
|||
|
const r = g.getData(u.CALL, i.LOCAL_USER_INFO);
|
|||
|
g.update(u.CALL, i.LOCAL_USER_INFO, { ...r, isEnter: !0 }), g.update(u.CALL, i.LOCAL_USER_INFO_EXCLUDE_VOLUMN, { ...r, isEnter: !0 }), oe(!0, i.AUDIO);
|
|||
|
} else
|
|||
|
this._permissionCheckTimer && clearInterval(this._permissionCheckTimer), this._permissionCheckTimer = null, this._resetCallStore();
|
|||
|
}
|
|||
|
_getFeatureButtonDefaultState(A) {
|
|||
|
var t;
|
|||
|
const { button: e } = g.getData(u.CALL, i.CUSTOM_UI_CONFIG);
|
|||
|
return (t = e == null ? void 0 : e[A]) == null ? void 0 : t.state;
|
|||
|
}
|
|||
|
_updateCallDuration() {
|
|||
|
const A = Math.round((rt() - this._startTimeStamp) / 1e3), e = Ma(A);
|
|||
|
g.update(u.CALL, i.CALL_DURATION, e);
|
|||
|
}
|
|||
|
_stopTimer() {
|
|||
|
this._timerId !== -1 && (He.clearTask(this._timerId), this._timerId = -1);
|
|||
|
}
|
|||
|
_resetCallStore() {
|
|||
|
const A = We();
|
|||
|
this._stopTimer();
|
|||
|
let e = Object.keys(Fe).filter((n) => {
|
|||
|
switch (Fe[n]) {
|
|||
|
case i.CALL_STATUS:
|
|||
|
case i.LANGUAGE:
|
|||
|
case i.IS_GROUP:
|
|||
|
case i.DISPLAY_MODE:
|
|||
|
case i.VIDEO_RESOLUTION:
|
|||
|
case i.ENABLE_FLOAT_WINDOW:
|
|||
|
case i.LOCAL_USER_INFO:
|
|||
|
case i.IS_SHOW_ENABLE_VIRTUAL_BACKGROUND:
|
|||
|
case i.LOCAL_USER_INFO_EXCLUDE_VOLUMN:
|
|||
|
return !1;
|
|||
|
default:
|
|||
|
return !0;
|
|||
|
}
|
|||
|
});
|
|||
|
e = e.map((n) => Fe[n]), g.reset(u.CALL, e), g.getData(u.CALL, i.CALL_STATUS) !== P.IDLE && g.reset(u.CALL, [i.CALL_STATUS], !0), g.reset(u.CALL, [i.IS_MINIMIZED], !0), g.reset(u.CALL, [i.IS_EAR_PHONE], !0), g.reset(u.CALL, [i.ENABLE_VIRTUAL_BACKGROUND], !0), g.reset(u.CALL, [i.IS_MUTE_SPEAKER], !0), g.update(u.CALL, i.LOCAL_USER_INFO, {
|
|||
|
...g.getData(u.CALL, i.LOCAL_USER_INFO),
|
|||
|
isVideoAvailable: !1,
|
|||
|
isAudioAvailable: !1
|
|||
|
}), g.update(u.CALL, i.LOCAL_USER_INFO_EXCLUDE_VOLUMN, {
|
|||
|
...g.getData(u.CALL, i.LOCAL_USER_INFO_EXCLUDE_VOLUMN),
|
|||
|
isVideoAvailable: !1,
|
|||
|
isAudioAvailable: !1
|
|||
|
}), g.update(u.CALL, i.REMOTE_USER_INFO_LIST, []), g.update(u.CALL, i.REMOTE_USER_INFO_EXCLUDE_VOLUMN_LIST, []);
|
|||
|
const o = We();
|
|||
|
A !== o && this.statusChanged && this.statusChanged({ oldStatus: A, newStatus: o });
|
|||
|
}
|
|||
|
// =========================【Calling the Chat SDK APi】=========================
|
|||
|
// 获取群成员
|
|||
|
async getGroupMemberList(A, e) {
|
|||
|
const t = g.getData(u.CALL, i.GROUP_ID);
|
|||
|
return await sl(t, this.getTim(), A, e);
|
|||
|
}
|
|||
|
// 获取群信息
|
|||
|
async getGroupProfile() {
|
|||
|
const A = g.getData(u.CALL, i.GROUP_ID);
|
|||
|
return await cl(A, this.getTim());
|
|||
|
}
|
|||
|
_watchTUIStore() {
|
|||
|
g == null || g.watch(u.CALL, {
|
|||
|
[i.CALL_STATUS]: this._handleCallStatusChange
|
|||
|
});
|
|||
|
}
|
|||
|
_unwatchTUIStore() {
|
|||
|
g == null || g.unwatch(u.CALL, {
|
|||
|
[i.CALL_STATUS]: this._handleCallStatusChange
|
|||
|
});
|
|||
|
}
|
|||
|
// =========================【融合 chat 】=========================
|
|||
|
bindTUICore(A) {
|
|||
|
this._TUICore = A;
|
|||
|
}
|
|||
|
// =========================【set、get methods】=========================
|
|||
|
getTim() {
|
|||
|
var A, e;
|
|||
|
return this._tim ? this._tim : this._tuiCallEngine ? ((A = this._tuiCallEngine) == null ? void 0 : A.tim) || ((e = this._tuiCallEngine) == null ? void 0 : e.getTim()) : (console.warn(`${i.PREFIX}getTim warning: _tuiCallEngine Instance is not available.`), null);
|
|||
|
}
|
|||
|
setIsFromChat(A) {
|
|||
|
this._isFromChat = A;
|
|||
|
}
|
|||
|
setCurrentGroupId(A) {
|
|||
|
this._currentGroupId = A;
|
|||
|
}
|
|||
|
getCurrentGroupId() {
|
|||
|
return this._currentGroupId;
|
|||
|
}
|
|||
|
setDefaultOfflinePushInfo(A) {
|
|||
|
this._defaultOfflinePushInfo = A;
|
|||
|
}
|
|||
|
getDefaultOfflinePushInfo() {
|
|||
|
return this._defaultOfflinePushInfo;
|
|||
|
}
|
|||
|
async getCallMessage(A) {
|
|||
|
return await this._chatCombine.getCallKitMessage(A, this.getTim());
|
|||
|
}
|
|||
|
};
|
|||
|
oA([
|
|||
|
TA(),
|
|||
|
UA(fA.init)
|
|||
|
], aA.prototype, "init", 1);
|
|||
|
oA([
|
|||
|
TA(),
|
|||
|
UA(fA.call),
|
|||
|
tt({ engineInstance: !0 })
|
|||
|
], aA.prototype, "call", 1);
|
|||
|
oA([
|
|||
|
TA(),
|
|||
|
UA(fA.groupCall),
|
|||
|
tt({ engineInstance: !0 })
|
|||
|
], aA.prototype, "groupCall", 1);
|
|||
|
oA([
|
|||
|
TA(),
|
|||
|
UA(fA.inviteUser),
|
|||
|
tt({ engineInstance: !0 })
|
|||
|
], aA.prototype, "inviteUser", 1);
|
|||
|
oA([
|
|||
|
TA(),
|
|||
|
UA(fA.joinInGroupCall),
|
|||
|
tt({ engineInstance: !0 })
|
|||
|
], aA.prototype, "joinInGroupCall", 1);
|
|||
|
oA([
|
|||
|
UA(fA.setLanguage)
|
|||
|
], aA.prototype, "setLanguage", 1);
|
|||
|
oA([
|
|||
|
UA(fA.enableFloatWindow)
|
|||
|
], aA.prototype, "enableFloatWindow", 1);
|
|||
|
oA([
|
|||
|
UA(fA.setSelfInfo)
|
|||
|
], aA.prototype, "setSelfInfo", 1);
|
|||
|
oA([
|
|||
|
UA(fA.enableAIVoice)
|
|||
|
], aA.prototype, "enableAIVoice", 1);
|
|||
|
oA([
|
|||
|
UA(fA.setCallingBell)
|
|||
|
], aA.prototype, "setCallingBell", 1);
|
|||
|
oA([
|
|||
|
UA(fA.enableMuteMode)
|
|||
|
], aA.prototype, "enableMuteMode", 1);
|
|||
|
oA([
|
|||
|
TA()
|
|||
|
], aA.prototype, "accept", 1);
|
|||
|
oA([
|
|||
|
TA()
|
|||
|
], aA.prototype, "hangup", 1);
|
|||
|
oA([
|
|||
|
TA()
|
|||
|
], aA.prototype, "reject", 1);
|
|||
|
oA([
|
|||
|
TA()
|
|||
|
], aA.prototype, "openCamera", 1);
|
|||
|
oA([
|
|||
|
TA()
|
|||
|
], aA.prototype, "closeCamera", 1);
|
|||
|
oA([
|
|||
|
TA()
|
|||
|
], aA.prototype, "openMicrophone", 1);
|
|||
|
oA([
|
|||
|
TA()
|
|||
|
], aA.prototype, "closeMicrophone", 1);
|
|||
|
oA([
|
|||
|
TA()
|
|||
|
], aA.prototype, "unMuteSpeaker", 1);
|
|||
|
oA([
|
|||
|
TA()
|
|||
|
], aA.prototype, "muteSpeaker", 1);
|
|||
|
oA([
|
|||
|
TA()
|
|||
|
], aA.prototype, "switchScreen", 1);
|
|||
|
oA([
|
|||
|
TA()
|
|||
|
], aA.prototype, "switchCallMediaType", 1);
|
|||
|
oA([
|
|||
|
TA()
|
|||
|
], aA.prototype, "switchCamera", 1);
|
|||
|
oA([
|
|||
|
TA()
|
|||
|
], aA.prototype, "setBlurBackground", 1);
|
|||
|
oA([
|
|||
|
TA()
|
|||
|
], aA.prototype, "switchDevice", 1);
|
|||
|
oA([
|
|||
|
UA(fA.setVideoDisplayMode)
|
|||
|
], aA.prototype, "setVideoDisplayMode", 1);
|
|||
|
oA([
|
|||
|
UA(fA.setVideoResolution)
|
|||
|
], aA.prototype, "setVideoResolution", 1);
|
|||
|
let jl = aA;
|
|||
|
const Q = jl.getInstance(), Na = "CallInfoContextKey", ga = "CallerUserInfoContextKey", Ta = "UserInfoExcludeVolumeContextKey", pa = "FocusContextKey", Da = "ButtonPanelContextKey", ya = "FloatWindowContextKey", Ca = "IsClickableContextKey", Sa = "PopoverContextKey", ja = "CustomUIConfigContextKey";
|
|||
|
function hl() {
|
|||
|
return VA(ga);
|
|||
|
}
|
|||
|
function rA() {
|
|||
|
return VA(Na);
|
|||
|
}
|
|||
|
function ot(a) {
|
|||
|
const A = p([]), e = p(""), t = (n) => {
|
|||
|
var s, r, c;
|
|||
|
switch (a) {
|
|||
|
case hA.CAMERA:
|
|||
|
A.value = (n == null ? void 0 : n.cameraList) || [], e.value = ((s = n == null ? void 0 : n.currentCamera) == null ? void 0 : s.deviceId) || "";
|
|||
|
break;
|
|||
|
case hA.MICROPHONE:
|
|||
|
A.value = (n == null ? void 0 : n.microphoneList) || [], e.value = ((r = n == null ? void 0 : n.currentMicrophone) == null ? void 0 : r.deviceId) || "";
|
|||
|
break;
|
|||
|
case hA.SPEAKER:
|
|||
|
A.value = (n == null ? void 0 : n.speakerList) || [], e.value = ((c = n == null ? void 0 : n.currentSpeaker) == null ? void 0 : c.deviceId) || "";
|
|||
|
break;
|
|||
|
}
|
|||
|
}, o = (n) => {
|
|||
|
e.value = n;
|
|||
|
};
|
|||
|
return CA(() => {
|
|||
|
g.watch(
|
|||
|
u.CALL,
|
|||
|
{
|
|||
|
[i.DEVICE_LIST]: t
|
|||
|
},
|
|||
|
{
|
|||
|
notifyRangeWhenWatch: i.MYSELF
|
|||
|
}
|
|||
|
);
|
|||
|
}), DA(() => {
|
|||
|
g.unwatch(u.CALL, {
|
|||
|
[i.DEVICE_LIST]: t
|
|||
|
});
|
|||
|
}), [{ deviceList: A, currentDeviceId: e }, { updateCurrentDeviceId: o }];
|
|||
|
}
|
|||
|
const Ft = (a) => typeof a == "object" && a !== null, ha = (a, A) => {
|
|||
|
if (!Ft(a) || !Ft(A))
|
|||
|
return a === A;
|
|||
|
if (a === A)
|
|||
|
return !0;
|
|||
|
const e = Object.keys(a), t = Object.keys(A);
|
|||
|
if (e.length !== t.length)
|
|||
|
return !1;
|
|||
|
for (let o in a)
|
|||
|
if (!ha(a[o], A[o]))
|
|||
|
return !1;
|
|||
|
return !0;
|
|||
|
};
|
|||
|
function Ll(a) {
|
|||
|
const A = document.getElementById(a);
|
|||
|
!document.fullscreenElement && A ? A.requestFullscreen().catch((e) => {
|
|||
|
console.error(`Error attempting to enable fullscreen mode: ${e.message} (${e.name})`);
|
|||
|
}) : document.exitFullscreen();
|
|||
|
}
|
|||
|
function lt(a) {
|
|||
|
if (typeof a != "object" || a === null)
|
|||
|
return a;
|
|||
|
let A = Array.isArray(a) ? [] : {};
|
|||
|
for (let e in a)
|
|||
|
a.hasOwnProperty(e) && (A[e] = lt(a[e]));
|
|||
|
return A;
|
|||
|
}
|
|||
|
const El = 500;
|
|||
|
function Et(a, A) {
|
|||
|
if (typeof a != "function" || A != null && typeof A != "function")
|
|||
|
throw new TypeError("Expected a function");
|
|||
|
const e = function(...t) {
|
|||
|
const o = A ? A.apply(this, t) : t[0], n = e.cache;
|
|||
|
if (n.has(o))
|
|||
|
return n.get(o);
|
|||
|
const s = a.apply(this, t);
|
|||
|
return e.cache = n.set(o, s) || n, s;
|
|||
|
};
|
|||
|
return e.cache = new (Et.Cache || Map)(), e;
|
|||
|
}
|
|||
|
Et.Cache = Map;
|
|||
|
function ml(a) {
|
|||
|
const A = Et(a, (e) => {
|
|||
|
const { cache: t } = A;
|
|||
|
return t.size === El && t.clear(), e;
|
|||
|
});
|
|||
|
return A;
|
|||
|
}
|
|||
|
const zl = ".".charCodeAt(0), Ul = /\\(\\)?/g, fl = RegExp(
|
|||
|
// Match anything that isn't a dot or bracket.
|
|||
|
`[^.[\\]]+|\\[(?:([^"'][^[]*)|(["'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|$))`,
|
|||
|
"g"
|
|||
|
), La = ml((a) => {
|
|||
|
const A = [];
|
|||
|
return a.charCodeAt(0) === zl && A.push(""), a.replace(fl, (e, t, o, n) => {
|
|||
|
let s = e;
|
|||
|
o ? s = n.replace(Ul, "$1") : t && (s = t.trim()), A.push(s);
|
|||
|
}), A;
|
|||
|
});
|
|||
|
function le(a, A, e) {
|
|||
|
if (typeof a != "object" || !A)
|
|||
|
return;
|
|||
|
const t = La(A);
|
|||
|
let o = a;
|
|||
|
for (let n = 0; n < t.length; n++) {
|
|||
|
if (o == null)
|
|||
|
return;
|
|||
|
const s = t[n];
|
|||
|
n !== t.length - 1 ? o = o == null ? void 0 : o[s] : Object.assign(o, { [s]: e });
|
|||
|
}
|
|||
|
}
|
|||
|
function Se(a, A, e) {
|
|||
|
if (typeof a != "object")
|
|||
|
return;
|
|||
|
const t = La(A);
|
|||
|
let o = a;
|
|||
|
for (let n = 0; n < t.length; n++) {
|
|||
|
if (o == null)
|
|||
|
return;
|
|||
|
const s = t[n];
|
|||
|
n !== t.length - 1 ? o = o == null ? void 0 : o[s] : Array.isArray(o) && o.splice(s, 0, e);
|
|||
|
}
|
|||
|
}
|
|||
|
function vl(a) {
|
|||
|
return a == null || typeof a == "string" && a.trim().length === 0 ? !0 : Array.isArray(a) || typeof a == "object" ? Object.keys(a).length === 0 : !1;
|
|||
|
}
|
|||
|
function yt(a, A, e, t, o) {
|
|||
|
Object.keys(a).forEach((n) => {
|
|||
|
const s = a[n], r = vl(e) ? n : `${e}.${n}`;
|
|||
|
if (typeof s == "object")
|
|||
|
if (Array.isArray(s))
|
|||
|
for (let c = 0; c < s.length; c++) {
|
|||
|
const M = `${r}.${c}`;
|
|||
|
yt(s[c], A, M, t, o);
|
|||
|
}
|
|||
|
else
|
|||
|
yt(s, A, r, t, o);
|
|||
|
else if (A(s)) {
|
|||
|
const c = typeof o == "function" ? o({ key: s, value: r }) : r;
|
|||
|
t.push(c);
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
function Ea() {
|
|||
|
const a = p(), A = p(g.getData(u.CALL, i.REMOTE_USER_INFO_LIST)), e = (n) => {
|
|||
|
(V.isWeChat ? n.enableMic : n.isAudioAvailable) && (a.value = { ...a.value, localVideo: n.volume });
|
|||
|
}, t = (n) => {
|
|||
|
const s = {};
|
|||
|
(n.length !== A.value.length || !ha(n, A.value)) && (A.value = n, A.value.forEach((r) => {
|
|||
|
if (V.isWeChat ? r.hasAudio : r.isAudioAvailable) {
|
|||
|
const M = V.isWeChat ? r.userID : r.domId;
|
|||
|
s[M] = r.volume;
|
|||
|
}
|
|||
|
}), a.value = { ...a.value, ...s });
|
|||
|
};
|
|||
|
let o = {
|
|||
|
[i.LOCAL_USER_INFO]: e,
|
|||
|
[i.REMOTE_USER_INFO_LIST]: t
|
|||
|
};
|
|||
|
return V.isUniPlatform && (o = {
|
|||
|
[i.PUSHER]: e,
|
|||
|
[i.PLAYER]: t
|
|||
|
}), CA(() => {
|
|||
|
g.watch(
|
|||
|
u.CALL,
|
|||
|
o,
|
|||
|
{
|
|||
|
notifyRangeWhenWatch: i.MYSELF
|
|||
|
}
|
|||
|
);
|
|||
|
}), DA(() => {
|
|||
|
g.unwatch(u.CALL, o);
|
|||
|
}), a;
|
|||
|
}
|
|||
|
function wl() {
|
|||
|
const a = p(""), A = p(!0), e = p(0), t = (n) => {
|
|||
|
e.value = 0, a.value = n;
|
|||
|
}, o = (n) => {
|
|||
|
let s = n;
|
|||
|
typeof s == "object" && (s = n == null ? void 0 : n.text), s && (e.value = 2e3, a.value = s);
|
|||
|
};
|
|||
|
return CA(() => {
|
|||
|
g.watch(
|
|||
|
u.CALL,
|
|||
|
{
|
|||
|
[i.CALL_TIPS]: t
|
|||
|
},
|
|||
|
{
|
|||
|
notifyRangeWhenWatch: i.MYSELF
|
|||
|
}
|
|||
|
), g.watch(
|
|||
|
u.CALL,
|
|||
|
{
|
|||
|
[i.TOAST_INFO]: o
|
|||
|
}
|
|||
|
);
|
|||
|
}), DA(() => {
|
|||
|
g.unwatch(
|
|||
|
u.CALL,
|
|||
|
{
|
|||
|
[i.CALL_TIPS]: t,
|
|||
|
[i.TOAST_INFO]: o
|
|||
|
}
|
|||
|
);
|
|||
|
}), { tip: a, show: A, duration: e };
|
|||
|
}
|
|||
|
function Ol() {
|
|||
|
const a = p(g.getData(u.CALL, i.NETWORK_STATUS)), A = (e) => {
|
|||
|
a.value = e;
|
|||
|
};
|
|||
|
return CA(() => {
|
|||
|
g.watch(
|
|||
|
u.CALL,
|
|||
|
{
|
|||
|
[i.NETWORK_STATUS]: A
|
|||
|
},
|
|||
|
{
|
|||
|
notifyRangeWhenWatch: i.MYSELF
|
|||
|
}
|
|||
|
);
|
|||
|
}), DA(() => {
|
|||
|
g.unwatch(u.CALL, {
|
|||
|
[i.NETWORK_STATUS]: A
|
|||
|
});
|
|||
|
}), { netWorkQualityList: a };
|
|||
|
}
|
|||
|
function ma() {
|
|||
|
const a = p(g.getData(u.CALL, i.PLAYER)), A = (t) => {
|
|||
|
a.value = t == null ? void 0 : t.map((o) => {
|
|||
|
const { userID: n, hasVideo: s, hasAudio: r } = o;
|
|||
|
return { userID: n, hasVideo: s, hasAudio: r };
|
|||
|
});
|
|||
|
}, e = {
|
|||
|
[i.PLAYER]: A
|
|||
|
};
|
|||
|
return CA(() => {
|
|||
|
g.watch(
|
|||
|
u.CALL,
|
|||
|
e,
|
|||
|
{ notifyRangeWhenWatch: i.MYSELF }
|
|||
|
);
|
|||
|
}), DA(() => {
|
|||
|
g.unwatch(u.CALL, e);
|
|||
|
}), a;
|
|||
|
}
|
|||
|
function vA() {
|
|||
|
return VA(Ta);
|
|||
|
}
|
|||
|
function mt() {
|
|||
|
const a = p(g.getData(u.CALL, i.CALL_DURATION)), A = (e) => {
|
|||
|
a.value = e;
|
|||
|
};
|
|||
|
return CA(() => {
|
|||
|
g.watch(
|
|||
|
u.CALL,
|
|||
|
{
|
|||
|
[i.CALL_DURATION]: A
|
|||
|
},
|
|||
|
{
|
|||
|
notifyRangeWhenWatch: i.MYSELF
|
|||
|
}
|
|||
|
);
|
|||
|
}), DA(() => {
|
|||
|
g.unwatch(
|
|||
|
u.CALL,
|
|||
|
{
|
|||
|
[i.CALL_DURATION]: A
|
|||
|
}
|
|||
|
);
|
|||
|
}), { callDuration: a };
|
|||
|
}
|
|||
|
function Ve() {
|
|||
|
return VA(Da, { status: p("open") });
|
|||
|
}
|
|||
|
function za() {
|
|||
|
return VA(pa, p("open"));
|
|||
|
}
|
|||
|
function BA() {
|
|||
|
return VA(ya);
|
|||
|
}
|
|||
|
function Vl() {
|
|||
|
return VA(Ca);
|
|||
|
}
|
|||
|
function nt() {
|
|||
|
return VA(Sa);
|
|||
|
}
|
|||
|
const bl = (a, A) => {
|
|||
|
const e = [{
|
|||
|
i: 0,
|
|||
|
x: 0,
|
|||
|
y: 0,
|
|||
|
w: A,
|
|||
|
h: A
|
|||
|
}];
|
|||
|
for (let t = 1; t < a; t++) {
|
|||
|
const o = e[t - 1].x + A === 12;
|
|||
|
e[t] = {
|
|||
|
i: t,
|
|||
|
x: e[t - 1].x + A === 12 ? 0 : e[t - 1].x + A,
|
|||
|
y: e[t - 1].y + (o ? A : 0),
|
|||
|
w: A,
|
|||
|
h: A
|
|||
|
};
|
|||
|
}
|
|||
|
return a === 3 && (e[a - 1].x += 3), a > 3 && V.isPC && a % 3 === 2 && (e[a - 1].x += 2, e[a - 2].x += 2), e;
|
|||
|
};
|
|||
|
function xl(a, A) {
|
|||
|
const { isFloatWindow: e } = G(BA()), t = p();
|
|||
|
return uA([a, A, e], () => {
|
|||
|
if (e.value) {
|
|||
|
const M = [];
|
|||
|
for (let N = 0; N < A.value; N++)
|
|||
|
M[N] = {
|
|||
|
i: N,
|
|||
|
x: 0,
|
|||
|
y: 0,
|
|||
|
w: 12,
|
|||
|
h: 12
|
|||
|
};
|
|||
|
t.value = M;
|
|||
|
return;
|
|||
|
}
|
|||
|
const o = Object.keys(Array.from({ length: A.value })), n = A.value <= 4 ? 6 : 4, s = bl(A.value, n);
|
|||
|
t.value = s;
|
|||
|
let r, c;
|
|||
|
if (a.value !== null) {
|
|||
|
if (o.length < 5) {
|
|||
|
const M = o.concat();
|
|||
|
M.splice(a.value, 1), M.unshift(a.value);
|
|||
|
} else
|
|||
|
c = a.value % 3, r = Math.floor(a.value / 3);
|
|||
|
if (o.length < 5) {
|
|||
|
const M = s.findIndex((N) => N.i === a.value);
|
|||
|
if (M !== -1) {
|
|||
|
const N = s[0];
|
|||
|
s[0] = s[M], s[M] = N;
|
|||
|
for (let T = 0; T < s.length; T++) {
|
|||
|
const I = s[T];
|
|||
|
T === 0 ? (I.w += 6, I.h += 6, I.x = 0, I.y = 0) : (I.x = (T - 1) * 4, I.y = 12, I.w = 4, I.h = 4);
|
|||
|
}
|
|||
|
}
|
|||
|
} else {
|
|||
|
let M;
|
|||
|
c === 0 ? (s[a.value + 1] && (s[a.value + 1].x += 4), s[a.value + 2] && (s[a.value + 2].y += 4), M = {
|
|||
|
i: a.value,
|
|||
|
x: 0,
|
|||
|
y: r * 4,
|
|||
|
w: 8,
|
|||
|
h: 8
|
|||
|
}) : c === 2 ? (M = {
|
|||
|
i: a.value,
|
|||
|
x: 4,
|
|||
|
y: r * 4,
|
|||
|
w: 8,
|
|||
|
h: 8
|
|||
|
}, s[a.value - 1].x = 0, s[a.value - 1].y += 4) : c === 1 && (M = {
|
|||
|
i: a.value,
|
|||
|
x: 4,
|
|||
|
y: r * 4,
|
|||
|
w: 8,
|
|||
|
h: 8
|
|||
|
}, s[a.value + 1] && (s[a.value + 1].x = 0, s[a.value + 1].y += 4));
|
|||
|
const N = 3 - c;
|
|||
|
for (let T = a.value + N; T < s.length; T++) {
|
|||
|
const I = s[T];
|
|||
|
I.y += 4;
|
|||
|
}
|
|||
|
s[a.value] = M;
|
|||
|
}
|
|||
|
t.value = s;
|
|||
|
}
|
|||
|
}, {
|
|||
|
immediate: !0
|
|||
|
}), t;
|
|||
|
}
|
|||
|
function be() {
|
|||
|
return VA(ja);
|
|||
|
}
|
|||
|
const kl = {
|
|||
|
calling: [[
|
|||
|
{ name: "switchCamera", customStyle: { justifyContent: "flex-start" }, props: {} },
|
|||
|
{ name: "virtualBackground" },
|
|||
|
{ name: "camera", customStyle: { justifyContent: "flex-end" }, props: {} }
|
|||
|
], [
|
|||
|
{},
|
|||
|
{ name: "hangup", customStyle: { paddingTop: "6vh" } },
|
|||
|
{}
|
|||
|
]],
|
|||
|
accept: [[
|
|||
|
{ name: "switchCamera", customStyle: { justifyContent: "flex-start" }, props: {} },
|
|||
|
{ name: "virtualBackground" },
|
|||
|
{ name: "camera", customStyle: { justifyContent: "flex-end" }, props: {} }
|
|||
|
], [
|
|||
|
{ name: "reject", customStyle: { paddingTop: "6vh", justifyContent: "center" } },
|
|||
|
{},
|
|||
|
{ name: "accept", customStyle: { paddingTop: "6vh", justifyContent: "center" } }
|
|||
|
]],
|
|||
|
connected: [[
|
|||
|
{ name: "microphone", customStyle: { justifyContent: "flex-start" }, props: {} },
|
|||
|
{ name: "speaker" },
|
|||
|
{ name: "camera", customStyle: { justifyContent: "flex-end" }, props: {} }
|
|||
|
], [
|
|||
|
{ name: "virtualBackground", customStyle: { justifyContent: "center", paddingTop: "6vh" }, props: {} },
|
|||
|
{ name: "hangup", customStyle: { paddingTop: "6vh" } },
|
|||
|
{ name: "switchCamera", customStyle: { justifyContent: "center", paddingTop: "6vh" }, props: {} }
|
|||
|
]]
|
|||
|
}, Rl = {
|
|||
|
singleCall: {
|
|||
|
video: {
|
|||
|
calling: [
|
|||
|
[],
|
|||
|
[
|
|||
|
{},
|
|||
|
{ name: "hangup" },
|
|||
|
{}
|
|||
|
]
|
|||
|
],
|
|||
|
accept: [
|
|||
|
[],
|
|||
|
[
|
|||
|
{ name: "reject", customStyle: { justifyContent: "flex-end" } },
|
|||
|
{},
|
|||
|
{ name: "accept", customStyle: { justifyContent: "flex-start" } }
|
|||
|
]
|
|||
|
],
|
|||
|
connected: [
|
|||
|
[
|
|||
|
{ name: "microphone", customStyle: { justifyContent: "flex-start" }, props: {} },
|
|||
|
{ name: "speaker" },
|
|||
|
{ name: "camera", customStyle: { justifyContent: "flex-end" }, props: {} }
|
|||
|
],
|
|||
|
[
|
|||
|
{},
|
|||
|
{ name: "hangup", customStyle: { paddingTop: "6vh" } },
|
|||
|
{ name: "switchCamera", customStyle: { justifyContent: "center", paddingTop: "6vh" }, props: {} }
|
|||
|
]
|
|||
|
]
|
|||
|
},
|
|||
|
audio: {
|
|||
|
calling: [
|
|||
|
[],
|
|||
|
[
|
|||
|
{},
|
|||
|
{ name: "hangup" },
|
|||
|
{}
|
|||
|
]
|
|||
|
],
|
|||
|
accept: [
|
|||
|
[],
|
|||
|
[
|
|||
|
{ name: "reject", customStyle: { justifyContent: "flex-end" } },
|
|||
|
{},
|
|||
|
{ name: "accept", customStyle: { justifyContent: "flex-start" } }
|
|||
|
]
|
|||
|
],
|
|||
|
connected: [
|
|||
|
[],
|
|||
|
[
|
|||
|
{ name: "microphone", customStyle: { justifyContent: "flex-start" }, props: {} },
|
|||
|
{ name: "hangup" },
|
|||
|
{ name: "speaker", customStyle: { justifyContent: "flex-end" } }
|
|||
|
]
|
|||
|
]
|
|||
|
}
|
|||
|
},
|
|||
|
groupCall: {
|
|||
|
video: {
|
|||
|
calling: [[
|
|||
|
{ name: "microphone", customStyle: { justifyContent: "flex-start" }, props: {} },
|
|||
|
{ name: "speaker" },
|
|||
|
{ name: "camera", customStyle: { justifyContent: "flex-end" }, props: {} }
|
|||
|
], [
|
|||
|
{},
|
|||
|
{ name: "hangup", customStyle: { paddingTop: "6vh" } },
|
|||
|
{}
|
|||
|
]],
|
|||
|
accept: [
|
|||
|
[],
|
|||
|
[
|
|||
|
{ name: "reject" },
|
|||
|
{ name: "accept" }
|
|||
|
]
|
|||
|
],
|
|||
|
connected: [
|
|||
|
[
|
|||
|
{ name: "microphone", customStyle: { justifyContent: "flex-start" }, props: {} },
|
|||
|
{ name: "speaker" },
|
|||
|
{ name: "camera", customStyle: { justifyContent: "flex-end" }, props: {} }
|
|||
|
],
|
|||
|
[
|
|||
|
{},
|
|||
|
{ name: "hangup", customStyle: { paddingTop: "6vh" } },
|
|||
|
{}
|
|||
|
]
|
|||
|
],
|
|||
|
close_calling: [
|
|||
|
[
|
|||
|
{ name: "microphone", props: {} },
|
|||
|
{ name: "speaker" },
|
|||
|
{ name: "camera", props: {} },
|
|||
|
{ name: "hangup" }
|
|||
|
]
|
|||
|
],
|
|||
|
close_connected: [
|
|||
|
[
|
|||
|
{ name: "microphone", props: {} },
|
|||
|
{ name: "speaker" },
|
|||
|
{ name: "camera", props: {} },
|
|||
|
{ name: "hangup" }
|
|||
|
]
|
|||
|
]
|
|||
|
},
|
|||
|
audio: {
|
|||
|
calling: [[
|
|||
|
{ name: "microphone", customStyle: { justifyContent: "flex-start" }, props: {} },
|
|||
|
{ name: "speaker" },
|
|||
|
{ name: "camera", customStyle: { justifyContent: "flex-end" }, props: {} }
|
|||
|
], [
|
|||
|
{},
|
|||
|
{ name: "hangup", customStyle: { paddingTop: "6vh" } },
|
|||
|
{}
|
|||
|
]],
|
|||
|
accept: [
|
|||
|
[],
|
|||
|
[
|
|||
|
{ name: "reject" },
|
|||
|
{ name: "accept" }
|
|||
|
]
|
|||
|
],
|
|||
|
connected: [
|
|||
|
[
|
|||
|
{ name: "microphone", customStyle: { justifyContent: "flex-start" }, props: {} },
|
|||
|
{ name: "speaker" },
|
|||
|
{ name: "camera", customStyle: { justifyContent: "flex-end" }, props: {} }
|
|||
|
],
|
|||
|
[
|
|||
|
{},
|
|||
|
{ name: "hangup", customStyle: { paddingTop: "6vh" } },
|
|||
|
{}
|
|||
|
]
|
|||
|
],
|
|||
|
close_calling: [
|
|||
|
[
|
|||
|
{ name: "microphone", props: {} },
|
|||
|
{ name: "speaker" },
|
|||
|
{ name: "camera", props: {} },
|
|||
|
{ name: "hangup" }
|
|||
|
]
|
|||
|
],
|
|||
|
close_connected: [
|
|||
|
[
|
|||
|
{ name: "microphone", props: {} },
|
|||
|
{ name: "speaker" },
|
|||
|
{ name: "camera", props: {} },
|
|||
|
{ name: "hangup" }
|
|||
|
]
|
|||
|
]
|
|||
|
}
|
|||
|
}
|
|||
|
}, Bl = {
|
|||
|
singleCall: {
|
|||
|
video: {
|
|||
|
calling: [
|
|||
|
[
|
|||
|
{ name: "camera", props: {} },
|
|||
|
{ name: "microphone", props: {} },
|
|||
|
{ name: "hangup" }
|
|||
|
]
|
|||
|
],
|
|||
|
accept: [
|
|||
|
[
|
|||
|
{ name: "camera", props: {} },
|
|||
|
{ name: "reject" },
|
|||
|
{ name: "accept" }
|
|||
|
]
|
|||
|
],
|
|||
|
connected: [
|
|||
|
[
|
|||
|
{ name: "camera", props: {} },
|
|||
|
{ name: "microphone", props: {} },
|
|||
|
{ name: "speaker" },
|
|||
|
{ name: "hangup" }
|
|||
|
]
|
|||
|
]
|
|||
|
},
|
|||
|
audio: {
|
|||
|
calling: [
|
|||
|
[
|
|||
|
{ name: "microphone", props: {} },
|
|||
|
{ name: "hangup" }
|
|||
|
]
|
|||
|
],
|
|||
|
accept: [
|
|||
|
[
|
|||
|
{ name: "reject" },
|
|||
|
{ name: "accept" }
|
|||
|
]
|
|||
|
],
|
|||
|
connected: [
|
|||
|
[
|
|||
|
{ name: "microphone", props: {} },
|
|||
|
{ name: "speaker" },
|
|||
|
{ name: "hangup" }
|
|||
|
]
|
|||
|
]
|
|||
|
}
|
|||
|
},
|
|||
|
groupCall: {
|
|||
|
video: {
|
|||
|
calling: [[
|
|||
|
{ name: "camera", props: {} },
|
|||
|
{ name: "microphone", props: {} },
|
|||
|
{ name: "inviteUser", props: {} },
|
|||
|
{ name: "hangup" }
|
|||
|
]],
|
|||
|
accept: [
|
|||
|
[
|
|||
|
{ name: "reject" },
|
|||
|
{ name: "accept" }
|
|||
|
]
|
|||
|
],
|
|||
|
connected: [
|
|||
|
[
|
|||
|
{ name: "camera", props: {} },
|
|||
|
{ name: "microphone", props: {} },
|
|||
|
{ name: "speaker" },
|
|||
|
{ name: "inviteUser", props: {} },
|
|||
|
{ name: "hangup" }
|
|||
|
]
|
|||
|
]
|
|||
|
},
|
|||
|
audio: {
|
|||
|
calling: [
|
|||
|
[
|
|||
|
{ name: "microphone", props: {} },
|
|||
|
{ name: "hangup" }
|
|||
|
]
|
|||
|
],
|
|||
|
accept: [
|
|||
|
[
|
|||
|
{ name: "reject" },
|
|||
|
{ name: "accept" }
|
|||
|
]
|
|||
|
],
|
|||
|
connected: [
|
|||
|
[
|
|||
|
{ name: "microphone", props: {} },
|
|||
|
{ name: "speaker" },
|
|||
|
{ name: "inviteUser", props: {} },
|
|||
|
{ name: "hangup" }
|
|||
|
]
|
|||
|
]
|
|||
|
}
|
|||
|
}
|
|||
|
}, Yt = {
|
|||
|
pc: Bl,
|
|||
|
mobile: Rl
|
|||
|
};
|
|||
|
function Ua(a) {
|
|||
|
const A = lt(a);
|
|||
|
return le(A, "mobile.singleCall.video", kl), Se(A, "pc.singleCall.video.calling[0][2]", { name: "virtualBackground", props: {} }), Se(A, "pc.singleCall.video.accept[0][1]", { name: "virtualBackground", props: {} }), Se(A, "pc.singleCall.video.connected[0][3]", { name: "virtualBackground", props: {} }), Se(A, "pc.groupCall.video.calling[0][3]", { name: "virtualBackground", props: {} }), Se(A, "pc.groupCall.video.connected[0][4]", { name: "virtualBackground", props: {} }), A;
|
|||
|
}
|
|||
|
function Pl(a, A, e) {
|
|||
|
let t = lt(a);
|
|||
|
return A ? (le(t, "mobile.singleCall.video.connected[1][2].props.show", !0), e && Ua(t)) : (le(t, "mobile.singleCall.video.connected[1][2].props.show", !1), e && (le(t, "mobile.singleCall.video.connected[1][0].props.show", !1), le(t, "pc.singleCall.video.connected[0][3].props.show", !1), le(t, "pc.groupCall.video.connected[0][4].props.show", !1))), t;
|
|||
|
}
|
|||
|
function Wl() {
|
|||
|
const { isShowEnableVirtualBackground: a, callStatus: A } = G(rA()), e = be(), { localUserInfoExcludeVolume: t } = G(vA()), o = S(() => (t == null ? void 0 : t.value.isVideoAvailable) || !1), n = S(() => a.value && !V.isH5), s = p([]);
|
|||
|
return uA([e, a, o], () => {
|
|||
|
let r = lt(Yt);
|
|||
|
n.value && (r = Ua(Yt)), A.value === P.CONNECTED && (r = Pl(r, o.value, n.value));
|
|||
|
const { button: c } = e.value, M = [];
|
|||
|
function N(I) {
|
|||
|
return Object.keys(c).includes(I);
|
|||
|
}
|
|||
|
function T({ key: I, value: D }) {
|
|||
|
var H;
|
|||
|
const h = D.split(".");
|
|||
|
let j = h.slice(0, h.length - 1);
|
|||
|
const m = h.slice(0, h.length - 2);
|
|||
|
if (m[m.length - 1] === "0")
|
|||
|
for (let b = 0; b < 3; b++) {
|
|||
|
let x = m.slice();
|
|||
|
x.push(b), x.push("customStyle"), x.push("justifyContent"), x = x.join("."), M.push({ path: x, value: "center" });
|
|||
|
}
|
|||
|
return j.push("props"), j.push("show"), j = j.join("."), {
|
|||
|
path: j,
|
|||
|
value: (H = c == null ? void 0 : c[I]) == null ? void 0 : H.show
|
|||
|
};
|
|||
|
}
|
|||
|
yt(r, N, "", M, T), M == null || M.forEach((I) => {
|
|||
|
le(r, I.path, I.value);
|
|||
|
}), s.value = r;
|
|||
|
}, {
|
|||
|
immediate: !0
|
|||
|
}), s;
|
|||
|
}
|
|||
|
function fa() {
|
|||
|
const a = be(), A = p(a.value.viewBackground);
|
|||
|
return uA(a, () => {
|
|||
|
A.value = a.value.viewBackground;
|
|||
|
}), A;
|
|||
|
}
|
|||
|
function Gl() {
|
|||
|
const a = p(g.getData(u.CALL, i.ROOM_ID)), A = p(g.getData(u.CALL, i.ROOM_ID_TYPE)), e = p(g.getData(u.CALL, i.GROUP_ID)), t = p(g.getData(u.CALL, i.CALL_MEDIA_TYPE)), o = p(g.getData(u.CALL, i.GROUP_CALL_MEMBERS)), n = p(g.getData(u.CALL, i.CALL_STATUS)), s = (D) => {
|
|||
|
a.value = D;
|
|||
|
}, r = (D) => {
|
|||
|
e.value = D;
|
|||
|
}, c = (D) => {
|
|||
|
t.value = D;
|
|||
|
}, M = (D) => {
|
|||
|
o.value = D;
|
|||
|
}, N = (D) => {
|
|||
|
n.value = D;
|
|||
|
}, T = (D) => {
|
|||
|
A.value = D;
|
|||
|
}, I = {
|
|||
|
[i.ROOM_ID]: s,
|
|||
|
[i.GROUP_ID]: r,
|
|||
|
[i.CALL_MEDIA_TYPE]: c,
|
|||
|
[i.GROUP_CALL_MEMBERS]: M,
|
|||
|
[i.CALL_STATUS]: N,
|
|||
|
[i.ROOM_ID_TYPE]: T
|
|||
|
};
|
|||
|
return CA(() => {
|
|||
|
g.watch(
|
|||
|
u.CALL,
|
|||
|
I,
|
|||
|
{
|
|||
|
notifyRangeWhenWatch: i.MYSELF
|
|||
|
}
|
|||
|
);
|
|||
|
}), DA(() => {
|
|||
|
g.unwatch(u.CALL, I);
|
|||
|
}), {
|
|||
|
roomId: a,
|
|||
|
roomIdType: A,
|
|||
|
groupId: e,
|
|||
|
callMediaType: t,
|
|||
|
groupCallMembers: o,
|
|||
|
callStatus: n
|
|||
|
};
|
|||
|
}
|
|||
|
const Ql = {
|
|||
|
customStyle: {
|
|||
|
type: Object
|
|||
|
},
|
|||
|
customClass: {
|
|||
|
type: String
|
|||
|
}
|
|||
|
}, Zl = ["start", "center", "end", "space-around", "space-between", "space-evenly"], Fl = ["top", "middle", "bottom"], Yl = {
|
|||
|
gutter: {
|
|||
|
type: Number,
|
|||
|
default: 0
|
|||
|
},
|
|||
|
justify: {
|
|||
|
type: String,
|
|||
|
values: Zl,
|
|||
|
default: "start"
|
|||
|
},
|
|||
|
align: {
|
|||
|
type: String,
|
|||
|
values: Fl,
|
|||
|
default: "top"
|
|||
|
},
|
|||
|
customStyle: {
|
|||
|
type: Object,
|
|||
|
default: () => {
|
|||
|
}
|
|||
|
}
|
|||
|
};
|
|||
|
function iA(...a) {
|
|||
|
const A = [], e = {}.hasOwnProperty;
|
|||
|
for (let t = 0; t < a.length; t++) {
|
|||
|
const o = a[t];
|
|||
|
if (!o)
|
|||
|
continue;
|
|||
|
const n = typeof o;
|
|||
|
if (n === "string" || n === "number")
|
|||
|
A.push(o);
|
|||
|
else if (Array.isArray(o)) {
|
|||
|
if (o.length) {
|
|||
|
const s = iA.apply(null, o);
|
|||
|
s && A.push(s);
|
|||
|
}
|
|||
|
} else if (n === "object") {
|
|||
|
if (o.toString !== Object.prototype.toString && !o.toString.toString().includes("[native code]")) {
|
|||
|
A.push(o.toString());
|
|||
|
continue;
|
|||
|
}
|
|||
|
for (const s in o)
|
|||
|
e.call(o, s) && o[s] && A.push(s);
|
|||
|
}
|
|||
|
}
|
|||
|
return A.join(" ");
|
|||
|
}
|
|||
|
const se = typeof wx < "u" && typeof wx.getSystemInfoSync == "function" && !!wx.getSystemInfoSync().fontSizeSetting, Xl = typeof uni < "u" && typeof uni > "u", Ct = se || Xl, ql = typeof uni < "u", va = function() {
|
|||
|
return (typeof uni < "u" || typeof window < "u") && !Ct;
|
|||
|
}();
|
|||
|
(function() {
|
|||
|
return se ? wx : ql ? uni : window;
|
|||
|
})();
|
|||
|
const Ae = va && window && window.navigator && window.navigator.userAgent || "", Jl = /Android/i.test(Ae), Hl = /(?:Windows Phone)/.test(Ae), Kl = /(?:SymbianOS)/.test(Ae), _l = /iPad/i.test(Ae) || /iPhone/i.test(Ae) || /iPod/i.test(Ae), wa = Jl || Hl || Kl || _l, re = va && !wa;
|
|||
|
re && Ae.includes("Windows NT");
|
|||
|
re && Ae.includes("Mac");
|
|||
|
function Ke(a) {
|
|||
|
const A = {};
|
|||
|
for (const e in a)
|
|||
|
Object.prototype.hasOwnProperty.call(a, e) && a[e] !== void 0 && (A[e] = a[e]);
|
|||
|
return A;
|
|||
|
}
|
|||
|
function $l() {
|
|||
|
let a = "unknow";
|
|||
|
return typeof st == "string" && (a = st.split(".")[0]), { version: st, majorVersion: a };
|
|||
|
}
|
|||
|
function Xt(a, A) {
|
|||
|
const { key: e, value: t } = A;
|
|||
|
return a.find((o) => o[e] === t);
|
|||
|
}
|
|||
|
const Oa = "RowContextKey", Y = "tk", ze = {
|
|||
|
SUCCESS: "success",
|
|||
|
INFO: "info",
|
|||
|
WARNING: "warning",
|
|||
|
ERROR: "error"
|
|||
|
}, An = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, ne = /* @__PURE__ */ f({
|
|||
|
...An,
|
|||
|
__name: "Row",
|
|||
|
props: Yl,
|
|||
|
setup(a) {
|
|||
|
const A = a, e = S(() => A.gutter);
|
|||
|
OA(Oa, {
|
|||
|
gutter: e
|
|||
|
});
|
|||
|
const t = iA([
|
|||
|
`${Y}-row`,
|
|||
|
`${Y}-justify-${A.justify}`,
|
|||
|
`${Y}-align-${A.align}`
|
|||
|
]);
|
|||
|
return (o, n) => (d(), y("div", {
|
|||
|
class: k(l(t)),
|
|||
|
style: eA([o.customStyle])
|
|||
|
}, [
|
|||
|
q(o.$slots, "default")
|
|||
|
], 6));
|
|||
|
}
|
|||
|
});
|
|||
|
const en = ["start", "center", "end", "space-around", "space-between", "space-evenly"], tn = ["top", "middle", "bottom"], an = {
|
|||
|
span: {
|
|||
|
type: Number,
|
|||
|
default: 24
|
|||
|
},
|
|||
|
justify: {
|
|||
|
type: String,
|
|||
|
values: en,
|
|||
|
default: "start"
|
|||
|
},
|
|||
|
align: {
|
|||
|
type: String,
|
|||
|
values: tn,
|
|||
|
default: "middle"
|
|||
|
},
|
|||
|
offset: {
|
|||
|
type: Number,
|
|||
|
default: 0
|
|||
|
}
|
|||
|
}, on = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, yA = /* @__PURE__ */ f({
|
|||
|
...on,
|
|||
|
__name: "Col",
|
|||
|
props: an,
|
|||
|
setup(a) {
|
|||
|
const A = a, { gutter: e } = VA(Oa, { gutter: S(() => 0) }), t = iA([
|
|||
|
`${Y}-col`,
|
|||
|
`${Y}-justify-${A.justify}`,
|
|||
|
`${Y}-align-${A.align}`
|
|||
|
]), o = S(() => `${A.span / 24 * 100}%`), n = S(() => `${A.offset / 24 * 100}%`), s = S(() => `${e.value / 2}px`), r = s;
|
|||
|
return (c, M) => (d(), y("div", {
|
|||
|
class: k(l(t)),
|
|||
|
style: eA({
|
|||
|
width: l(o),
|
|||
|
marginLeft: l(n),
|
|||
|
paddingLeft: l(s),
|
|||
|
paddingRight: l(r)
|
|||
|
})
|
|||
|
}, [
|
|||
|
q(c.$slots, "default")
|
|||
|
], 6));
|
|||
|
}
|
|||
|
});
|
|||
|
const ln = {
|
|||
|
width: {
|
|||
|
type: String,
|
|||
|
default: "40px"
|
|||
|
},
|
|||
|
height: {
|
|||
|
type: String,
|
|||
|
default: "40px"
|
|||
|
},
|
|||
|
color: {
|
|||
|
type: String
|
|||
|
}
|
|||
|
}, nn = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, sn = /* @__PURE__ */ f({
|
|||
|
...nn,
|
|||
|
__name: "Dot",
|
|||
|
props: ln,
|
|||
|
setup(a) {
|
|||
|
const A = a, e = `${Y}-loading_dot-container`, t = `${Y}-loading_dot`, o = S(() => ({
|
|||
|
width: A.width,
|
|||
|
height: A.height
|
|||
|
})), n = S(() => {
|
|||
|
const s = {};
|
|||
|
return A.color && (s.backgroundColor = A.color), s;
|
|||
|
});
|
|||
|
return (s, r) => (d(), y("div", {
|
|||
|
class: k(e),
|
|||
|
style: eA([l(o)])
|
|||
|
}, [
|
|||
|
L("div", {
|
|||
|
class: k(t),
|
|||
|
style: eA([l(n)])
|
|||
|
}, null, 4),
|
|||
|
L("div", {
|
|||
|
class: k(t),
|
|||
|
style: eA([l(n)])
|
|||
|
}, null, 4),
|
|||
|
L("div", {
|
|||
|
class: k(t),
|
|||
|
style: eA([l(n)])
|
|||
|
}, null, 4)
|
|||
|
], 4));
|
|||
|
}
|
|||
|
});
|
|||
|
const cn = {
|
|||
|
width: {
|
|||
|
type: String,
|
|||
|
default: "40px"
|
|||
|
},
|
|||
|
height: {
|
|||
|
type: String,
|
|||
|
default: "40px"
|
|||
|
},
|
|||
|
color: {
|
|||
|
type: String
|
|||
|
}
|
|||
|
}, rn = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, un = /* @__PURE__ */ f({
|
|||
|
...rn,
|
|||
|
__name: "Circle",
|
|||
|
props: cn,
|
|||
|
setup(a) {
|
|||
|
const A = a, e = S(() => {
|
|||
|
const o = {
|
|||
|
width: A.width,
|
|||
|
height: A.height
|
|||
|
};
|
|||
|
return A.color && (o["--tk-loading-primary-color"] = A.color), o;
|
|||
|
}), t = `${Y}-loading_circle-container`;
|
|||
|
return (o, n) => (d(), y("div", {
|
|||
|
class: k(t),
|
|||
|
style: eA([l(e)])
|
|||
|
}, null, 4));
|
|||
|
}
|
|||
|
});
|
|||
|
const Mn = ["circle", "dot"], dn = ["row", "column"], In = {
|
|||
|
mode: {
|
|||
|
type: String,
|
|||
|
values: Mn,
|
|||
|
default: "circle"
|
|||
|
},
|
|||
|
loadingWidth: {
|
|||
|
type: String,
|
|||
|
default: "40px"
|
|||
|
},
|
|||
|
loadingHeight: {
|
|||
|
type: String,
|
|||
|
default: "40px"
|
|||
|
},
|
|||
|
color: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
text: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
layout: {
|
|||
|
type: String,
|
|||
|
values: dn,
|
|||
|
default: "column"
|
|||
|
}
|
|||
|
}, Nn = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, zt = /* @__PURE__ */ f({
|
|||
|
...Nn,
|
|||
|
__name: "Loading",
|
|||
|
props: In,
|
|||
|
setup(a) {
|
|||
|
const A = a, e = `${Y}-loading ${Y}-loading--${A.mode}`, t = `${Y}-loading_text`, o = S(() => ({
|
|||
|
flexDirection: A.layout
|
|||
|
}));
|
|||
|
return (n, s) => (d(), y("div", {
|
|||
|
class: k(e),
|
|||
|
style: eA([l(o)])
|
|||
|
}, [
|
|||
|
n.mode === "dot" ? (d(), U(sn, {
|
|||
|
key: 0,
|
|||
|
width: n.loadingWidth,
|
|||
|
height: n.loadingHeight,
|
|||
|
color: n.color
|
|||
|
}, null, 8, ["width", "height", "color"])) : (d(), U(un, {
|
|||
|
key: 1,
|
|||
|
width: n.loadingWidth,
|
|||
|
height: n.loadingHeight,
|
|||
|
color: n.color
|
|||
|
}, null, 8, ["width", "height", "color"])),
|
|||
|
n.text ? (d(), y("div", {
|
|||
|
key: 2,
|
|||
|
class: k(t)
|
|||
|
}, W(n.text), 1)) : z("", !0)
|
|||
|
], 4));
|
|||
|
}
|
|||
|
});
|
|||
|
const gn = {
|
|||
|
src: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
size: {
|
|||
|
type: Number,
|
|||
|
default: 20
|
|||
|
}
|
|||
|
}, Tn = ["fill", "contain", "cover"], qt = {
|
|||
|
fill: "scaleToFill",
|
|||
|
contain: "aspectFit",
|
|||
|
cover: "aspectFill"
|
|||
|
}, pn = {
|
|||
|
width: {
|
|||
|
type: String,
|
|||
|
default: "320px"
|
|||
|
},
|
|||
|
height: {
|
|||
|
type: String,
|
|||
|
default: "240px"
|
|||
|
},
|
|||
|
src: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
fit: {
|
|||
|
type: String,
|
|||
|
values: Tn,
|
|||
|
default: "fill"
|
|||
|
},
|
|||
|
customStyle: {
|
|||
|
type: Object
|
|||
|
},
|
|||
|
defaultSrc: {
|
|||
|
type: String
|
|||
|
}
|
|||
|
}, Dn = {
|
|||
|
error: (a) => a
|
|||
|
}, yn = ["src"], Cn = ["src", "mode"], Sn = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, LA = /* @__PURE__ */ f({
|
|||
|
...Sn,
|
|||
|
__name: "TKImage",
|
|||
|
props: pn,
|
|||
|
emits: Dn,
|
|||
|
setup(a, { emit: A }) {
|
|||
|
const e = a, t = A, o = p(!1), n = p(e.src);
|
|||
|
uA(() => e.src, () => {
|
|||
|
o.value = !1, n.value = e.src;
|
|||
|
});
|
|||
|
const s = S(() => iA([`${Y}-image`])), r = S(() => ({
|
|||
|
width: e.width,
|
|||
|
height: e.height,
|
|||
|
...e.customStyle
|
|||
|
})), c = S(() => iA([
|
|||
|
`${Y}-image_inner`
|
|||
|
])), M = S(() => se ? qt[e.fit] || qt.cover : e.fit);
|
|||
|
function N(T) {
|
|||
|
o.value = !0, n.value = e.defaultSrc, t("error", T);
|
|||
|
}
|
|||
|
return (T, I) => (d(), y("div", {
|
|||
|
class: k(l(s)),
|
|||
|
style: eA([l(r)])
|
|||
|
}, [
|
|||
|
l(o) && !T.defaultSrc ? q(T.$slots, "error", { key: 0 }) : (d(), y(RA, { key: 1 }, [
|
|||
|
l(se) ? z("", !0) : (d(), y("img", {
|
|||
|
key: 0,
|
|||
|
class: k(l(c)),
|
|||
|
src: l(n),
|
|||
|
style: eA({ objectFit: l(M) }),
|
|||
|
onError: N
|
|||
|
}, null, 46, yn)),
|
|||
|
l(se) ? (d(), y("image", {
|
|||
|
key: 1,
|
|||
|
class: k(l(c)),
|
|||
|
src: l(n),
|
|||
|
mode: l(M),
|
|||
|
onError: N
|
|||
|
}, null, 42, Cn)) : z("", !0)
|
|||
|
], 64))
|
|||
|
], 6));
|
|||
|
}
|
|||
|
});
|
|||
|
const jn = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, De = /* @__PURE__ */ f({
|
|||
|
...jn,
|
|||
|
__name: "Icon",
|
|||
|
props: gn,
|
|||
|
setup(a) {
|
|||
|
const A = a, e = S(() => `${A.size}px`), t = S(() => `${A.size}px`);
|
|||
|
return (o, n) => (d(), U(LA, {
|
|||
|
src: o.src,
|
|||
|
width: l(e),
|
|||
|
height: l(t)
|
|||
|
}, null, 8, ["src", "width", "height"]));
|
|||
|
}
|
|||
|
}), hn = ["small", "middle", "large"], Ln = ["row", "column"], En = ["circle", "round"], mn = {
|
|||
|
iconSrc: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
iconSize: {
|
|||
|
type: Number
|
|||
|
},
|
|||
|
text: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
loading: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
},
|
|||
|
loadingColor: {
|
|||
|
type: String,
|
|||
|
default: "#fff"
|
|||
|
},
|
|||
|
loadingWidth: {
|
|||
|
type: String,
|
|||
|
default: "40px"
|
|||
|
},
|
|||
|
loadingHeight: {
|
|||
|
type: String,
|
|||
|
default: "40px"
|
|||
|
},
|
|||
|
size: {
|
|||
|
type: String,
|
|||
|
values: hn,
|
|||
|
default: "middle"
|
|||
|
},
|
|||
|
width: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
height: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
color: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
direction: {
|
|||
|
type: String,
|
|||
|
values: Ln,
|
|||
|
default: "row"
|
|||
|
},
|
|||
|
shape: {
|
|||
|
type: String,
|
|||
|
values: En
|
|||
|
},
|
|||
|
buttonStyle: {
|
|||
|
type: Object
|
|||
|
},
|
|||
|
buttonTextStyle: {
|
|||
|
type: Object
|
|||
|
}
|
|||
|
}, zn = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, mA = /* @__PURE__ */ f({
|
|||
|
...zn,
|
|||
|
__name: "Button",
|
|||
|
props: mn,
|
|||
|
emits: ["click"],
|
|||
|
setup(a, { emit: A }) {
|
|||
|
const e = a, t = `${Y}-button--content`, o = S(() => ({
|
|||
|
width: e.width,
|
|||
|
height: e.height,
|
|||
|
backgroundColor: e.color,
|
|||
|
flexDirection: e.direction,
|
|||
|
cursor: re ? "pointer" : "auto",
|
|||
|
...e.buttonStyle
|
|||
|
})), n = iA([
|
|||
|
`${Y}-button`,
|
|||
|
{ [`${Y}-${e.shape}`]: e.shape },
|
|||
|
`${Y}-button--${e.size}`
|
|||
|
]), s = A, r = (c) => {
|
|||
|
!e.loading && s("click", c);
|
|||
|
};
|
|||
|
return (c, M) => (d(), y("div", {
|
|||
|
style: eA([l(o)]),
|
|||
|
class: k(l(n)),
|
|||
|
onClick: r
|
|||
|
}, [
|
|||
|
c.loading ? (d(), U(zt, {
|
|||
|
key: 0,
|
|||
|
loadingWidth: c.loadingWidth,
|
|||
|
loadingHeight: c.loadingHeight,
|
|||
|
color: c.loadingColor
|
|||
|
}, null, 8, ["loadingWidth", "loadingHeight", "color"])) : z("", !0),
|
|||
|
c.iconSrc && !c.loading ? (d(), U(De, {
|
|||
|
key: 1,
|
|||
|
size: c.iconSize,
|
|||
|
src: c.iconSrc
|
|||
|
}, null, 8, ["size", "src"])) : z("", !0),
|
|||
|
c.text ? (d(), y("div", {
|
|||
|
key: 2,
|
|||
|
style: eA([c.buttonTextStyle]),
|
|||
|
class: k(t)
|
|||
|
}, W(c.text), 5)) : z("", !0)
|
|||
|
], 6));
|
|||
|
}
|
|||
|
});
|
|||
|
const St = "", Va = "", ba = "
|
|||
|
let Pa = Vn, Wa = bn;
|
|||
|
pA || (Pa = wn, Wa = On);
|
|||
|
const $ = {
|
|||
|
width: pA ? "60px" : "40px",
|
|||
|
height: pA ? "60px" : "40px",
|
|||
|
shape: "circle",
|
|||
|
iconSize: pA ? 30 : 20,
|
|||
|
showText: !0,
|
|||
|
textColor: "#D5E0F2",
|
|||
|
textSize: "12px",
|
|||
|
textStyle: {
|
|||
|
marginTop: "5px"
|
|||
|
}
|
|||
|
}, O = {
|
|||
|
accept: {
|
|||
|
basicConfig: {
|
|||
|
...$,
|
|||
|
color: "#51C271",
|
|||
|
iconSrc: fn
|
|||
|
},
|
|||
|
loadingConfig: {
|
|||
|
...$,
|
|||
|
color: "#51C271",
|
|||
|
loadingWidth: pA ? "30px" : "20px",
|
|||
|
loadingHeight: pA ? "30px" : "20px"
|
|||
|
}
|
|||
|
},
|
|||
|
hangup: {
|
|||
|
basicConfig: {
|
|||
|
...$,
|
|||
|
color: "#ED4651",
|
|||
|
iconSrc: St
|
|||
|
},
|
|||
|
loadingConfig: {
|
|||
|
...$,
|
|||
|
color: "#ED4651",
|
|||
|
loadingWidth: pA ? "30px" : "20px",
|
|||
|
loadingHeight: pA ? "30px" : "20px"
|
|||
|
}
|
|||
|
},
|
|||
|
reject: {
|
|||
|
basicConfig: {
|
|||
|
...$,
|
|||
|
color: "#ED4651",
|
|||
|
iconSrc: St
|
|||
|
}
|
|||
|
},
|
|||
|
camera: {
|
|||
|
basicConfig: {
|
|||
|
...$,
|
|||
|
color: "#FFFFFF",
|
|||
|
iconSrc: Va,
|
|||
|
shape: "circle"
|
|||
|
},
|
|||
|
closedConfig: {
|
|||
|
...$,
|
|||
|
color: "#6b758a4d",
|
|||
|
iconSrc: ba
|
|||
|
},
|
|||
|
loadingConfig: {
|
|||
|
...$,
|
|||
|
color: "#6b758a4d",
|
|||
|
loadingWidth: pA ? "30px" : "20px",
|
|||
|
loadingHeight: pA ? "30px" : "20px"
|
|||
|
}
|
|||
|
},
|
|||
|
microphone: {
|
|||
|
basicConfig: {
|
|||
|
...$,
|
|||
|
color: "#FFFFFF",
|
|||
|
iconSrc: xa
|
|||
|
},
|
|||
|
closedConfig: {
|
|||
|
...$,
|
|||
|
color: "#6b758a4d",
|
|||
|
iconSrc: ka
|
|||
|
}
|
|||
|
},
|
|||
|
speaker: {
|
|||
|
basicConfig: {
|
|||
|
...$,
|
|||
|
color: "#FFFFFF",
|
|||
|
iconSrc: Ra
|
|||
|
},
|
|||
|
closedConfig: {
|
|||
|
...$,
|
|||
|
color: "#6b758a4d",
|
|||
|
iconSrc: Ba
|
|||
|
}
|
|||
|
},
|
|||
|
fullScreen: {
|
|||
|
basicConfig: {
|
|||
|
iconSize: 20,
|
|||
|
iconSrc: vn
|
|||
|
}
|
|||
|
},
|
|||
|
minimize: {
|
|||
|
basicConfig: {
|
|||
|
iconSize: pA ? 24 : 20,
|
|||
|
iconSrc: Pa
|
|||
|
}
|
|||
|
},
|
|||
|
switchCamera: {
|
|||
|
basicConfig: {
|
|||
|
...$,
|
|||
|
color: "transparent",
|
|||
|
iconSrc: JA,
|
|||
|
shape: "circle"
|
|||
|
}
|
|||
|
},
|
|||
|
inviteUser: {
|
|||
|
basicConfig: {
|
|||
|
...$,
|
|||
|
color: pA ? "" : "#6b758a4d",
|
|||
|
width: pA ? "24px" : "40px",
|
|||
|
height: pA ? "24px" : "40px",
|
|||
|
shape: pA ? "" : "circle",
|
|||
|
iconSize: pA ? 24 : 20,
|
|||
|
iconSrc: Wa
|
|||
|
}
|
|||
|
},
|
|||
|
toggleButtonPanel: {
|
|||
|
basicConfig: {
|
|||
|
color: "transparent",
|
|||
|
width: "40px",
|
|||
|
height: "40px",
|
|||
|
shape: "circle",
|
|||
|
iconSize: 40,
|
|||
|
iconSrc: xn
|
|||
|
}
|
|||
|
},
|
|||
|
virtualBackground: {
|
|||
|
basicConfig: {
|
|||
|
...$,
|
|||
|
color: "#6b758a4d",
|
|||
|
iconSrc: KA,
|
|||
|
shape: "circle"
|
|||
|
},
|
|||
|
closedConfig: {
|
|||
|
...$,
|
|||
|
color: "#FFFFFF",
|
|||
|
iconSrc: jt
|
|||
|
},
|
|||
|
loadingConfig: {
|
|||
|
...$,
|
|||
|
color: "#6b758a4d",
|
|||
|
loadingWidth: pA ? "30px" : "20px",
|
|||
|
loadingHeight: pA ? "30px" : "20px"
|
|||
|
},
|
|||
|
disableConfig: {
|
|||
|
...$,
|
|||
|
color: "#6b758a4d",
|
|||
|
iconSrc: KA,
|
|||
|
buttonStyle: {
|
|||
|
opacity: 0.6
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}, XA = {
|
|||
|
singleCall: {
|
|||
|
video: {
|
|||
|
calling: {
|
|||
|
...O,
|
|||
|
switchCamera: {
|
|||
|
basicConfig: {
|
|||
|
...$,
|
|||
|
color: "#6b758a4d",
|
|||
|
iconSrc: JA,
|
|||
|
shape: "circle",
|
|||
|
showText: !0
|
|||
|
},
|
|||
|
disableConfig: {
|
|||
|
...$,
|
|||
|
color: "#6b758a4d",
|
|||
|
iconSrc: JA,
|
|||
|
shape: "circle",
|
|||
|
showText: !0,
|
|||
|
buttonStyle: {
|
|||
|
opacity: 0.6
|
|||
|
}
|
|||
|
}
|
|||
|
},
|
|||
|
hangup: {
|
|||
|
basicConfig: {
|
|||
|
...O.hangup.basicConfig
|
|||
|
},
|
|||
|
loadingConfig: {
|
|||
|
...O.hangup.loadingConfig
|
|||
|
}
|
|||
|
},
|
|||
|
reject: {
|
|||
|
basicConfig: {
|
|||
|
...O.reject.basicConfig,
|
|||
|
showText: !1
|
|||
|
}
|
|||
|
}
|
|||
|
},
|
|||
|
accept: {
|
|||
|
...O,
|
|||
|
switchCamera: {
|
|||
|
basicConfig: {
|
|||
|
...$,
|
|||
|
color: "#6b758a4d",
|
|||
|
iconSrc: JA,
|
|||
|
shape: "circle"
|
|||
|
},
|
|||
|
disableConfig: {
|
|||
|
...$,
|
|||
|
color: "#6b758a4d",
|
|||
|
iconSrc: JA,
|
|||
|
shape: "circle",
|
|||
|
showText: !0,
|
|||
|
buttonStyle: {
|
|||
|
opacity: 0.6
|
|||
|
}
|
|||
|
}
|
|||
|
},
|
|||
|
accept: {
|
|||
|
basicConfig: {
|
|||
|
...O.accept.basicConfig,
|
|||
|
showText: !1
|
|||
|
},
|
|||
|
loadingConfig: {
|
|||
|
...O.accept.loadingConfig,
|
|||
|
showText: !1
|
|||
|
}
|
|||
|
},
|
|||
|
reject: {
|
|||
|
basicConfig: {
|
|||
|
...O.reject.basicConfig,
|
|||
|
showText: !1
|
|||
|
}
|
|||
|
}
|
|||
|
},
|
|||
|
connected: {
|
|||
|
...O,
|
|||
|
virtualBackground: {
|
|||
|
basicConfig: {
|
|||
|
...$,
|
|||
|
color: "transparent",
|
|||
|
iconSrc: KA,
|
|||
|
shape: "circle",
|
|||
|
showText: !1
|
|||
|
},
|
|||
|
closedConfig: {
|
|||
|
...$,
|
|||
|
color: "transparent",
|
|||
|
iconSrc: KA,
|
|||
|
showText: !1
|
|||
|
},
|
|||
|
disableConfig: {
|
|||
|
...$,
|
|||
|
color: "transparent",
|
|||
|
iconSrc: KA,
|
|||
|
showText: !1,
|
|||
|
buttonStyle: {
|
|||
|
opacity: 0.6
|
|||
|
}
|
|||
|
}
|
|||
|
},
|
|||
|
hangup: {
|
|||
|
basicConfig: {
|
|||
|
...O.hangup.basicConfig,
|
|||
|
showText: !1
|
|||
|
},
|
|||
|
loadingConfig: {
|
|||
|
...O.hangup.loadingConfig,
|
|||
|
showText: !1
|
|||
|
}
|
|||
|
},
|
|||
|
switchCamera: {
|
|||
|
basicConfig: {
|
|||
|
...O.switchCamera.basicConfig,
|
|||
|
showText: !1
|
|||
|
},
|
|||
|
disableConfig: {
|
|||
|
...O.switchCamera.basicConfig,
|
|||
|
showText: !1,
|
|||
|
buttonStyle: {
|
|||
|
opacity: 0.6
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
},
|
|||
|
audio: {
|
|||
|
calling: O,
|
|||
|
accept: O,
|
|||
|
connected: O
|
|||
|
}
|
|||
|
},
|
|||
|
groupCall: {
|
|||
|
video: {
|
|||
|
calling: {
|
|||
|
...O,
|
|||
|
switchCamera: {
|
|||
|
basicConfig: {
|
|||
|
...$,
|
|||
|
color: "#6b758a4d",
|
|||
|
iconSrc: JA,
|
|||
|
shape: "circle"
|
|||
|
}
|
|||
|
},
|
|||
|
hangup: {
|
|||
|
basicConfig: {
|
|||
|
...O.hangup.basicConfig,
|
|||
|
showText: !1
|
|||
|
},
|
|||
|
loadingConfig: {
|
|||
|
...O.hangup.loadingConfig,
|
|||
|
showText: !1
|
|||
|
}
|
|||
|
},
|
|||
|
accept: {
|
|||
|
basicConfig: {
|
|||
|
...O.accept.basicConfig,
|
|||
|
showText: !1
|
|||
|
},
|
|||
|
loadingConfig: {
|
|||
|
...O.accept.loadingConfig,
|
|||
|
showText: !1
|
|||
|
}
|
|||
|
},
|
|||
|
reject: {
|
|||
|
basicConfig: {
|
|||
|
...O.reject.basicConfig,
|
|||
|
showText: !1
|
|||
|
}
|
|||
|
}
|
|||
|
},
|
|||
|
accept: {
|
|||
|
...O,
|
|||
|
hangup: {
|
|||
|
basicConfig: {
|
|||
|
...O.hangup.basicConfig,
|
|||
|
showText: !1
|
|||
|
},
|
|||
|
loadingConfig: {
|
|||
|
...O.hangup.loadingConfig,
|
|||
|
showText: !1
|
|||
|
}
|
|||
|
},
|
|||
|
accept: {
|
|||
|
basicConfig: {
|
|||
|
...O.accept.basicConfig,
|
|||
|
showText: !1
|
|||
|
},
|
|||
|
loadingConfig: {
|
|||
|
...O.accept.loadingConfig,
|
|||
|
showText: !1
|
|||
|
}
|
|||
|
},
|
|||
|
reject: {
|
|||
|
basicConfig: {
|
|||
|
...O.reject.basicConfig,
|
|||
|
showText: !1
|
|||
|
}
|
|||
|
}
|
|||
|
},
|
|||
|
connected: {
|
|||
|
...O,
|
|||
|
virtualBackground: {
|
|||
|
basicConfig: {
|
|||
|
...$,
|
|||
|
color: "transparent",
|
|||
|
iconSrc: KA,
|
|||
|
shape: "circle",
|
|||
|
showText: !1
|
|||
|
},
|
|||
|
closedConfig: {
|
|||
|
...$,
|
|||
|
color: "transparent",
|
|||
|
iconSrc: jt,
|
|||
|
showText: !1
|
|||
|
}
|
|||
|
},
|
|||
|
hangup: {
|
|||
|
basicConfig: {
|
|||
|
...O.hangup.basicConfig,
|
|||
|
showText: !1
|
|||
|
},
|
|||
|
loadingConfig: {
|
|||
|
...O.hangup.loadingConfig,
|
|||
|
showText: !1
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
},
|
|||
|
audio: {
|
|||
|
calling: {
|
|||
|
...O,
|
|||
|
switchCamera: {
|
|||
|
basicConfig: {
|
|||
|
...$,
|
|||
|
color: "#6b758a4d",
|
|||
|
iconSrc: JA,
|
|||
|
shape: "circle"
|
|||
|
}
|
|||
|
},
|
|||
|
hangup: {
|
|||
|
basicConfig: {
|
|||
|
...O.hangup.basicConfig,
|
|||
|
showText: !1
|
|||
|
},
|
|||
|
loadingConfig: {
|
|||
|
...O.hangup.loadingConfig,
|
|||
|
showText: !1
|
|||
|
}
|
|||
|
},
|
|||
|
accept: {
|
|||
|
basicConfig: {
|
|||
|
...O.accept.basicConfig,
|
|||
|
showText: !1
|
|||
|
},
|
|||
|
loadingConfig: {
|
|||
|
...O.accept.loadingConfig,
|
|||
|
showText: !1
|
|||
|
}
|
|||
|
},
|
|||
|
reject: {
|
|||
|
basicConfig: {
|
|||
|
...O.reject.basicConfig,
|
|||
|
showText: !1
|
|||
|
}
|
|||
|
}
|
|||
|
},
|
|||
|
accept: {
|
|||
|
...O,
|
|||
|
hangup: {
|
|||
|
basicConfig: {
|
|||
|
...O.hangup.basicConfig,
|
|||
|
showText: !1
|
|||
|
},
|
|||
|
loadingConfig: {
|
|||
|
...O.hangup.loadingConfig,
|
|||
|
showText: !1
|
|||
|
}
|
|||
|
},
|
|||
|
accept: {
|
|||
|
basicConfig: {
|
|||
|
...O.accept.basicConfig,
|
|||
|
showText: !1
|
|||
|
},
|
|||
|
loadingConfig: {
|
|||
|
...O.accept.loadingConfig,
|
|||
|
showText: !1
|
|||
|
}
|
|||
|
},
|
|||
|
reject: {
|
|||
|
basicConfig: {
|
|||
|
...O.reject.basicConfig,
|
|||
|
showText: !1
|
|||
|
}
|
|||
|
}
|
|||
|
},
|
|||
|
connected: {
|
|||
|
...O,
|
|||
|
hangup: {
|
|||
|
basicConfig: {
|
|||
|
...O.hangup.basicConfig,
|
|||
|
showText: !1
|
|||
|
},
|
|||
|
loadingConfig: {
|
|||
|
...O.hangup.loadingConfig,
|
|||
|
showText: !1
|
|||
|
}
|
|||
|
},
|
|||
|
virtualBackground: {
|
|||
|
basicConfig: {
|
|||
|
...$,
|
|||
|
color: "transparent",
|
|||
|
iconSrc: KA,
|
|||
|
shape: "circle"
|
|||
|
},
|
|||
|
closedConfig: {
|
|||
|
...$,
|
|||
|
color: "transparent",
|
|||
|
iconSrc: jt
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}, kn = {
|
|||
|
singleCall: {
|
|||
|
video: {
|
|||
|
calling: O,
|
|||
|
accept: O,
|
|||
|
connected: O
|
|||
|
},
|
|||
|
audio: {
|
|||
|
calling: O,
|
|||
|
accept: O,
|
|||
|
connected: O
|
|||
|
}
|
|||
|
},
|
|||
|
groupCall: {
|
|||
|
video: {
|
|||
|
calling: O,
|
|||
|
accept: O,
|
|||
|
connected: O
|
|||
|
},
|
|||
|
audio: {
|
|||
|
calling: O,
|
|||
|
accept: O,
|
|||
|
connected: O
|
|||
|
}
|
|||
|
}
|
|||
|
}, Rn = {
|
|||
|
pc: kn,
|
|||
|
mobile: XA
|
|||
|
}, FA = {
|
|||
|
width: "40px",
|
|||
|
height: "40px",
|
|||
|
shape: "circle",
|
|||
|
iconSize: 20,
|
|||
|
textColor: "#D5E0F2"
|
|||
|
}, Qe = {
|
|||
|
microphone: {
|
|||
|
basicConfig: {
|
|||
|
...FA,
|
|||
|
color: "#FFFFFF",
|
|||
|
iconSrc: xa
|
|||
|
},
|
|||
|
closedConfig: {
|
|||
|
...FA,
|
|||
|
color: "#6b758a4d",
|
|||
|
iconSrc: ka
|
|||
|
}
|
|||
|
},
|
|||
|
speaker: {
|
|||
|
basicConfig: {
|
|||
|
...FA,
|
|||
|
color: "#FFFFFF",
|
|||
|
iconSrc: Ra
|
|||
|
},
|
|||
|
closedConfig: {
|
|||
|
...FA,
|
|||
|
color: "#6b758a4d",
|
|||
|
iconSrc: Ba
|
|||
|
}
|
|||
|
},
|
|||
|
camera: {
|
|||
|
basicConfig: {
|
|||
|
...FA,
|
|||
|
color: "#FFFFFF",
|
|||
|
iconSrc: Va
|
|||
|
},
|
|||
|
closedConfig: {
|
|||
|
...FA,
|
|||
|
color: "#6b758a4d",
|
|||
|
iconSrc: ba
|
|||
|
}
|
|||
|
},
|
|||
|
hangup: {
|
|||
|
basicConfig: {
|
|||
|
...FA,
|
|||
|
color: "#ED4651",
|
|||
|
iconSrc: St
|
|||
|
},
|
|||
|
loadingConfig: {
|
|||
|
...FA,
|
|||
|
color: "#ED4651",
|
|||
|
loadingWidth: "20px",
|
|||
|
loadingHeight: "20px"
|
|||
|
}
|
|||
|
},
|
|||
|
toggleButtonPanel: {
|
|||
|
basicConfig: {
|
|||
|
color: "transparent",
|
|||
|
width: "40px",
|
|||
|
height: "40px",
|
|||
|
shape: "circle",
|
|||
|
iconSize: 40,
|
|||
|
iconSrc: Un
|
|||
|
}
|
|||
|
}
|
|||
|
}, Bn = {
|
|||
|
mobile: {
|
|||
|
...XA,
|
|||
|
groupCall: {
|
|||
|
video: {
|
|||
|
...XA.groupCall.video,
|
|||
|
calling: {
|
|||
|
...XA.groupCall.video.calling,
|
|||
|
...Qe
|
|||
|
},
|
|||
|
connected: {
|
|||
|
...XA.groupCall.video.connected,
|
|||
|
...Qe
|
|||
|
}
|
|||
|
},
|
|||
|
audio: {
|
|||
|
...XA.groupCall.audio,
|
|||
|
calling: {
|
|||
|
...XA.groupCall.audio.calling,
|
|||
|
...Qe
|
|||
|
},
|
|||
|
connected: {
|
|||
|
...XA.groupCall.audio.connected,
|
|||
|
...Qe
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}, zA = (a, A) => {
|
|||
|
var M;
|
|||
|
const e = V.isPC ? "pc" : "mobile", { status: t } = Ve(), { callStatus: o, callRole: n, isGroupCall: s, callType: r } = G(rA()), c = p((M = O == null ? void 0 : O[a]) == null ? void 0 : M[A.value]);
|
|||
|
return uA(
|
|||
|
[A, t, o, s, r],
|
|||
|
() => {
|
|||
|
var h, j, m, w, H;
|
|||
|
const N = s.value ? "groupCall" : "singleCall", T = r.value === _.AUDIO ? "audio" : "video";
|
|||
|
let I = "";
|
|||
|
o.value === P.CALLING ? I = n.value === IA.CALLER ? "calling" : "accept" : o.value === P.CONNECTED && (I = "connected");
|
|||
|
let D = Rn;
|
|||
|
t.value === "close" && (D = Bn), c.value = ((H = (w = (m = (j = (h = D == null ? void 0 : D[e]) == null ? void 0 : h[N]) == null ? void 0 : j[T]) == null ? void 0 : m[I]) == null ? void 0 : w[a]) == null ? void 0 : H[A.value]) || {};
|
|||
|
},
|
|||
|
{ immediate: !0 }
|
|||
|
), c;
|
|||
|
}, Pn = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, Wn = /* @__PURE__ */ f({
|
|||
|
...Pn,
|
|||
|
__name: "Minimize",
|
|||
|
setup(a) {
|
|||
|
const A = zA("minimize", p("basicConfig")), e = async () => {
|
|||
|
if (document != null && document.fullscreenElement)
|
|||
|
try {
|
|||
|
document == null || document.exitFullscreen();
|
|||
|
} catch (t) {
|
|||
|
console.debug(t);
|
|||
|
}
|
|||
|
await Q.toggleMinimize();
|
|||
|
};
|
|||
|
return (t, o) => (d(), U(mA, {
|
|||
|
iconSrc: l(A).iconSrc,
|
|||
|
iconSize: l(A).iconSize,
|
|||
|
onClick: e
|
|||
|
}, null, 8, ["iconSrc", "iconSize"]));
|
|||
|
}
|
|||
|
});
|
|||
|
const Z = (a, A) => {
|
|||
|
const e = a.__vccOpts || a;
|
|||
|
for (const [t, o] of A)
|
|||
|
e[t] = o;
|
|||
|
return e;
|
|||
|
}, Jt = /* @__PURE__ */ Z(Wn, [["__scopeId", "data-v-135d060f"]]), Gn = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, Qn = /* @__PURE__ */ f({
|
|||
|
...Gn,
|
|||
|
__name: "FullScreen",
|
|||
|
setup(a) {
|
|||
|
const A = zA("fullScreen", p("basicConfig")), e = async () => {
|
|||
|
await Ll("tuicallkit-id");
|
|||
|
};
|
|||
|
return (t, o) => (d(), U(mA, {
|
|||
|
iconSrc: l(A).iconSrc,
|
|||
|
iconSize: l(A).iconSize,
|
|||
|
onClick: e
|
|||
|
}, null, 8, ["iconSrc", "iconSize"]));
|
|||
|
}
|
|||
|
});
|
|||
|
const Zn = /* @__PURE__ */ Z(Qn, [["__scopeId", "data-v-f92abf93"]]), Fn = {
|
|||
|
width: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
color: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
size: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
weight: {
|
|||
|
type: Number
|
|||
|
},
|
|||
|
truncated: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
},
|
|||
|
lineClamp: {
|
|||
|
type: Number
|
|||
|
},
|
|||
|
textStyle: {
|
|||
|
type: Object
|
|||
|
}
|
|||
|
}, Yn = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, gA = /* @__PURE__ */ f({
|
|||
|
...Yn,
|
|||
|
__name: "TKText",
|
|||
|
props: Fn,
|
|||
|
emits: ["click"],
|
|||
|
setup(a, { emit: A }) {
|
|||
|
const e = a, t = A, o = iA([
|
|||
|
`${Y}-text`,
|
|||
|
{ [`${Y}-text--line-clamp`]: e.lineClamp }
|
|||
|
]), n = S(() => Ke({
|
|||
|
maxWidth: e.width,
|
|||
|
fontSize: e.size,
|
|||
|
fontWeight: e.weight,
|
|||
|
color: e.color,
|
|||
|
textOverflow: e.truncated ? "ellipsis" : "auto",
|
|||
|
"-webkit-line-clamp": e.lineClamp,
|
|||
|
...e.textStyle
|
|||
|
})), s = () => {
|
|||
|
t("click");
|
|||
|
};
|
|||
|
return (r, c) => (d(), y("span", {
|
|||
|
class: k(l(o)),
|
|||
|
style: eA([l(n)]),
|
|||
|
onClick: s
|
|||
|
}, [
|
|||
|
q(r.$slots, "default")
|
|||
|
], 6));
|
|||
|
}
|
|||
|
});
|
|||
|
const ZA = {
|
|||
|
width: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
height: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
showText: {
|
|||
|
type: Boolean,
|
|||
|
default: !0
|
|||
|
},
|
|||
|
iconSize: {
|
|||
|
type: String
|
|||
|
}
|
|||
|
}, Xn = { class: "btn-content" }, qn = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, Jn = /* @__PURE__ */ f({
|
|||
|
...qn,
|
|||
|
__name: "InviteUser",
|
|||
|
props: ZA,
|
|||
|
setup(a) {
|
|||
|
const A = a, e = zA("inviteUser", p("basicConfig")), t = async () => {
|
|||
|
g.update(u.CALL, i.SHOW_SELECT_USER, !0);
|
|||
|
};
|
|||
|
return (o, n) => (d(), y("div", Xn, [
|
|||
|
C(mA, {
|
|||
|
iconSrc: l(e).iconSrc,
|
|||
|
color: l(e).color,
|
|||
|
iconSize: l(e).iconSize,
|
|||
|
width: A.width || l(e).width,
|
|||
|
height: A.height || l(e).height,
|
|||
|
shape: l(e).shape,
|
|||
|
onClick: t
|
|||
|
}, null, 8, ["iconSrc", "color", "iconSize", "width", "height", "shape"]),
|
|||
|
o.showText ? (d(), U(gA, {
|
|||
|
key: 0,
|
|||
|
textStyle: l(e).textStyle,
|
|||
|
color: l(e).textColor,
|
|||
|
size: l(e).textSize
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
NA(W(l(v)("invite member")), 1)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["textStyle", "color", "size"])) : z("", !0)
|
|||
|
]));
|
|||
|
}
|
|||
|
});
|
|||
|
const Ga = /* @__PURE__ */ Z(Jn, [["__scopeId", "data-v-4c3a35f0"]]), Hn = {
|
|||
|
color: {
|
|||
|
type: String,
|
|||
|
default: "#FFF"
|
|||
|
},
|
|||
|
callDuration: {
|
|||
|
type: String,
|
|||
|
default: ""
|
|||
|
},
|
|||
|
fontSize: {
|
|||
|
type: String,
|
|||
|
default: "16px"
|
|||
|
}
|
|||
|
}, Kn = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, _e = /* @__PURE__ */ f({
|
|||
|
...Kn,
|
|||
|
__name: "Timer",
|
|||
|
props: Hn,
|
|||
|
setup(a) {
|
|||
|
const A = a, e = S(() => ({
|
|||
|
color: A.color,
|
|||
|
fontSize: A.fontSize
|
|||
|
}));
|
|||
|
return (t, o) => (d(), y("span", {
|
|||
|
style: eA([l(e)])
|
|||
|
}, W(t.callDuration), 5));
|
|||
|
}
|
|||
|
}), _n = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, $n = /* @__PURE__ */ f({
|
|||
|
..._n,
|
|||
|
__name: "TopBar",
|
|||
|
props: Ql,
|
|||
|
setup(a) {
|
|||
|
const A = V.isPC, { callStatus: e, isGroupCall: t, callRole: o, allowedFullScreen: n } = G(rA()), { callDuration: s } = mt(), r = be(), c = S(() => e.value === P.CONNECTED), M = p(g.getData(u.CALL, i.ENABLE_FLOAT_WINDOW)), N = S(() => {
|
|||
|
var D, h;
|
|||
|
return !t.value || ((h = (D = r.value.button) == null ? void 0 : D[_A.InviteUser]) == null ? void 0 : h.show) === !1 ? !1 : e.value === P.CALLING ? o.value === IA.CALLER : !0;
|
|||
|
});
|
|||
|
function T(D) {
|
|||
|
M.value = D;
|
|||
|
}
|
|||
|
const I = {
|
|||
|
[i.ENABLE_FLOAT_WINDOW]: T
|
|||
|
};
|
|||
|
return CA(() => {
|
|||
|
g.watch(
|
|||
|
u.CALL,
|
|||
|
I,
|
|||
|
{
|
|||
|
notifyRangeWhenWatch: i.MYSELF
|
|||
|
}
|
|||
|
);
|
|||
|
}), DA(() => {
|
|||
|
g.unwatch(u.CALL, {
|
|||
|
...I
|
|||
|
});
|
|||
|
}), (D, h) => (d(), y("div", {
|
|||
|
style: eA(D.customStyle),
|
|||
|
class: "top-bar-container"
|
|||
|
}, [
|
|||
|
l(A) ? (d(), U(ne, { key: 0 }, {
|
|||
|
default: E(() => [
|
|||
|
C(yA, { span: 8 }),
|
|||
|
C(yA, {
|
|||
|
span: 8,
|
|||
|
justify: "center",
|
|||
|
align: "center"
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
l(c) ? (d(), U(_e, {
|
|||
|
key: 0,
|
|||
|
"call-duration": l(s)
|
|||
|
}, null, 8, ["call-duration"])) : z("", !0)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}),
|
|||
|
C(yA, {
|
|||
|
span: 8,
|
|||
|
justify: "end",
|
|||
|
align: "center"
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
C(ne, null, {
|
|||
|
default: E(() => [
|
|||
|
C(yA, { span: 18 }),
|
|||
|
C(yA, {
|
|||
|
span: 3,
|
|||
|
justify: "center"
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
l(M) ? (d(), U(Jt, { key: 0 })) : z("", !0)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}),
|
|||
|
C(yA, {
|
|||
|
span: 3,
|
|||
|
justify: "center"
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
l(n) ? (d(), U(Zn, { key: 0 })) : z("", !0)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
})
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
})
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
})
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
})) : z("", !0),
|
|||
|
l(A) ? z("", !0) : (d(), U(ne, { key: 1 }, {
|
|||
|
default: E(() => [
|
|||
|
C(yA, {
|
|||
|
span: 8,
|
|||
|
align: "center"
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
C(ne, null, {
|
|||
|
default: E(() => [
|
|||
|
C(yA, {
|
|||
|
span: 8,
|
|||
|
justify: "center"
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
!l(A) && l(M) ? (d(), U(Jt, { key: 0 })) : z("", !0)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}),
|
|||
|
C(yA, { span: 16 })
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
})
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}),
|
|||
|
C(yA, {
|
|||
|
span: 8,
|
|||
|
justify: "center",
|
|||
|
align: "center"
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
l(c) ? (d(), U(_e, {
|
|||
|
key: 0,
|
|||
|
"call-duration": l(s)
|
|||
|
}, null, 8, ["call-duration"])) : z("", !0)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}),
|
|||
|
C(yA, {
|
|||
|
span: 8,
|
|||
|
justify: "end",
|
|||
|
align: "center"
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
C(ne, null, {
|
|||
|
default: E(() => [
|
|||
|
C(yA, { span: 16 }),
|
|||
|
C(yA, {
|
|||
|
span: 8,
|
|||
|
justify: "center"
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
l(N) ? (d(), U(Ga, {
|
|||
|
key: 0,
|
|||
|
"show-text": l(A)
|
|||
|
}, null, 8, ["show-text"])) : z("", !0)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
})
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
})
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
})
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}))
|
|||
|
], 4));
|
|||
|
}
|
|||
|
});
|
|||
|
const Qa = /* @__PURE__ */ Z($n, [["__scopeId", "data-v-b040a138"]]), Ai = {
|
|||
|
show: {
|
|||
|
type: Boolean,
|
|||
|
default: !0
|
|||
|
},
|
|||
|
showMask: {
|
|||
|
type: Boolean,
|
|||
|
default: !0
|
|||
|
},
|
|||
|
showBackgroundImage: {
|
|||
|
type: Boolean,
|
|||
|
default: !0
|
|||
|
},
|
|||
|
blur: {
|
|||
|
type: Boolean,
|
|||
|
default: !0
|
|||
|
},
|
|||
|
bgColor: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
bgImage: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
zIndex: {
|
|||
|
type: Number,
|
|||
|
default: 11e3
|
|||
|
},
|
|||
|
customClass: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
customStyle: {
|
|||
|
type: Object
|
|||
|
},
|
|||
|
customMaskStyle: {
|
|||
|
type: Object
|
|||
|
},
|
|||
|
fit: {
|
|||
|
type: String,
|
|||
|
default: "cover"
|
|||
|
},
|
|||
|
defaultSrc: {
|
|||
|
type: String
|
|||
|
}
|
|||
|
}, ei = ["click", "error"], ti = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, Za = /* @__PURE__ */ f({
|
|||
|
...ti,
|
|||
|
__name: "Overlay",
|
|||
|
props: Ai,
|
|||
|
emits: ei,
|
|||
|
setup(a, { emit: A }) {
|
|||
|
const e = a, t = A, o = iA([
|
|||
|
`${Y}-overlay`,
|
|||
|
e.customClass
|
|||
|
]), n = `${Y}-overlay_mask-container`, s = S(() => iA([
|
|||
|
`${Y}-overlay_mask`,
|
|||
|
{ [`${Y}-blur`]: e.blur }
|
|||
|
])), r = `${Y}-overlay_slot`, c = S(() => ({ zIndex: e.zIndex, ...e.customStyle })), M = S(() => ({
|
|||
|
backgroundColor: e.bgColor,
|
|||
|
...e.customMaskStyle
|
|||
|
}));
|
|||
|
function N() {
|
|||
|
t("click");
|
|||
|
}
|
|||
|
const T = (I) => {
|
|||
|
t("error", I);
|
|||
|
};
|
|||
|
return (I, D) => I.show ? (d(), y("div", {
|
|||
|
key: 0,
|
|||
|
class: k(l(o)),
|
|||
|
style: eA([l(c)]),
|
|||
|
onClick: N
|
|||
|
}, [
|
|||
|
L("div", {
|
|||
|
class: k(n)
|
|||
|
}, [
|
|||
|
I.showMask ? (d(), y("div", {
|
|||
|
key: 0,
|
|||
|
class: k(l(s)),
|
|||
|
style: eA([l(M)])
|
|||
|
}, null, 6)) : z("", !0),
|
|||
|
I.showBackgroundImage ? (d(), U(LA, {
|
|||
|
key: 1,
|
|||
|
fit: I.fit,
|
|||
|
src: I.bgImage,
|
|||
|
width: "100%",
|
|||
|
height: "100%",
|
|||
|
defaultSrc: I.defaultSrc,
|
|||
|
onError: T
|
|||
|
}, null, 8, ["fit", "src", "defaultSrc"])) : z("", !0)
|
|||
|
]),
|
|||
|
L("div", {
|
|||
|
class: k(r)
|
|||
|
}, [
|
|||
|
q(I.$slots, "default")
|
|||
|
])
|
|||
|
], 6)) : z("", !0);
|
|||
|
}
|
|||
|
});
|
|||
|
const ai = ["fill", "contain", "cover"], oi = ["circle", "square"], li = {
|
|||
|
icon: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
size: {
|
|||
|
type: [Number, String],
|
|||
|
default: 100
|
|||
|
},
|
|||
|
shape: {
|
|||
|
type: String,
|
|||
|
values: oi,
|
|||
|
default: "square"
|
|||
|
},
|
|||
|
src: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
defaultSrc: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
text: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
fit: {
|
|||
|
type: String,
|
|||
|
values: ai,
|
|||
|
default: "cover"
|
|||
|
},
|
|||
|
customClass: {
|
|||
|
type: String
|
|||
|
}
|
|||
|
}, ni = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, Fa = /* @__PURE__ */ f({
|
|||
|
...ni,
|
|||
|
__name: "Avatar",
|
|||
|
props: li,
|
|||
|
setup(a) {
|
|||
|
const A = a, e = p("");
|
|||
|
uA(() => A.src, () => {
|
|||
|
e.value = A.src;
|
|||
|
}, {
|
|||
|
immediate: !0
|
|||
|
});
|
|||
|
const t = S(() => iA([
|
|||
|
`${Y}-avatar`,
|
|||
|
`${Y}-avatar--${A.shape}`,
|
|||
|
`${Y}-avatar--${A.size}`,
|
|||
|
A.customClass
|
|||
|
])), o = S(() => typeof A.size == "number" ? `${A.size}px` : A.size), n = S(() => typeof A.size == "number" ? `${A.size}px` : A.size), s = S(() => ({ width: o.value, height: n.value }));
|
|||
|
function r(c) {
|
|||
|
console.error(c), A.defaultSrc && (e.value = A.defaultSrc);
|
|||
|
}
|
|||
|
return (c, M) => (d(), y("div", {
|
|||
|
class: k(l(t)),
|
|||
|
style: eA([l(s)])
|
|||
|
}, [
|
|||
|
l(e) ? (d(), U(LA, {
|
|||
|
key: 0,
|
|||
|
fit: c.fit,
|
|||
|
width: l(o),
|
|||
|
height: l(n),
|
|||
|
src: l(e),
|
|||
|
onError: r
|
|||
|
}, null, 8, ["fit", "width", "height", "src"])) : q(c.$slots, "default", { key: 1 })
|
|||
|
], 6));
|
|||
|
}
|
|||
|
});
|
|||
|
const ii = "", si = "", ci = {
|
|||
|
isMuted: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
},
|
|||
|
volume: {
|
|||
|
type: Number,
|
|||
|
default: 0
|
|||
|
}
|
|||
|
}, ri = { class: "mic-container" }, ui = { class: "mic-level-container" }, Mi = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, di = /* @__PURE__ */ f({
|
|||
|
...Mi,
|
|||
|
__name: "MicrophoneVolume",
|
|||
|
props: ci,
|
|||
|
setup(a) {
|
|||
|
const A = a, e = S(() => A.isMuted ? si : ii), t = S(() => A.isMuted || !A.volume ? "" : `height: ${A.volume * 4}%`);
|
|||
|
return (o, n) => (d(), y("div", ri, [
|
|||
|
L("div", ui, [
|
|||
|
L("div", {
|
|||
|
class: "mic-level",
|
|||
|
style: eA(l(t))
|
|||
|
}, null, 4)
|
|||
|
]),
|
|||
|
C(De, { src: l(e) }, null, 8, ["src"])
|
|||
|
]));
|
|||
|
}
|
|||
|
});
|
|||
|
const Ya = /* @__PURE__ */ Z(di, [["__scopeId", "data-v-ea062939"]]), QA = "", Ii = {
|
|||
|
// ============== OverlayStream 业务组件 =================
|
|||
|
showOverlayStream: {
|
|||
|
type: Boolean,
|
|||
|
default: !0
|
|||
|
},
|
|||
|
customClass: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
customStyle: {
|
|||
|
type: Object
|
|||
|
},
|
|||
|
isSmallWindow: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
},
|
|||
|
tip: {
|
|||
|
type: String,
|
|||
|
default: null
|
|||
|
},
|
|||
|
// ============== Overlay 基础组件 =================
|
|||
|
showOverlay: {
|
|||
|
type: Boolean,
|
|||
|
default: !0
|
|||
|
},
|
|||
|
showMask: {
|
|||
|
type: Boolean,
|
|||
|
default: !0
|
|||
|
},
|
|||
|
showBackgroundImage: {
|
|||
|
type: Boolean,
|
|||
|
default: !0
|
|||
|
},
|
|||
|
blur: {
|
|||
|
type: Boolean,
|
|||
|
default: !0
|
|||
|
},
|
|||
|
bgColor: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
bgImage: {
|
|||
|
type: String,
|
|||
|
default: QA
|
|||
|
},
|
|||
|
overlayZIndex: {
|
|||
|
type: Number
|
|||
|
},
|
|||
|
customOverlayClass: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
fit: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
// ============== Loading 基础组件 =================
|
|||
|
showLoading: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
},
|
|||
|
// ============== Avatar 基础组件 =================
|
|||
|
showAvatar: {
|
|||
|
type: Boolean,
|
|||
|
default: !0
|
|||
|
},
|
|||
|
avatar: {
|
|||
|
type: String,
|
|||
|
default: QA
|
|||
|
},
|
|||
|
// ============== Text(username) 基础组件 =================
|
|||
|
showUserName: {
|
|||
|
type: Boolean,
|
|||
|
default: !0
|
|||
|
},
|
|||
|
username: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
color: {
|
|||
|
type: String,
|
|||
|
default: "#FFF"
|
|||
|
},
|
|||
|
// ============== MicrophoneVolume 业务组件 =================
|
|||
|
showMicVolume: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
},
|
|||
|
isMuted: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
},
|
|||
|
volume: {
|
|||
|
type: Number,
|
|||
|
default: 0
|
|||
|
},
|
|||
|
// ============== Tip 业务组件 =================
|
|||
|
showTip: {
|
|||
|
type: Boolean,
|
|||
|
default: !0
|
|||
|
}
|
|||
|
}, Ni = ["error"], gi = { class: "overlay-stream-content-container" }, Ti = { class: "overlay-stream-content" }, pi = { class: "overlay-stream-avatar" }, Di = { class: "overlay-stream-info" }, yi = { class: "overlay-stream-tip" }, Ci = { key: 0 }, Si = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, ji = /* @__PURE__ */ f({
|
|||
|
...Si,
|
|||
|
__name: "OverlayStream",
|
|||
|
props: Ii,
|
|||
|
emits: Ni,
|
|||
|
setup(a, { emit: A }) {
|
|||
|
const e = A, t = a, o = p(100), { isFloatWindow: n } = G(BA()), s = V.isPC ? "40px" : "20px";
|
|||
|
uA([() => t.isSmallWindow, n], () => {
|
|||
|
n.value ? o.value = t.isSmallWindow ? 20 : 40 : o.value = t.isSmallWindow ? 40 : 100;
|
|||
|
}, {
|
|||
|
immediate: !0
|
|||
|
});
|
|||
|
const r = S(() => iA([
|
|||
|
"overlay-stream-container",
|
|||
|
{
|
|||
|
pc: V.isPC,
|
|||
|
mobile: !V.isPC,
|
|||
|
float: n.value
|
|||
|
}
|
|||
|
])), c = (M) => {
|
|||
|
e("error", M);
|
|||
|
};
|
|||
|
return (M, N) => M.showOverlayStream ? (d(), y("div", {
|
|||
|
key: 0,
|
|||
|
class: k(l(r)),
|
|||
|
style: eA([M.customStyle])
|
|||
|
}, [
|
|||
|
C(Za, {
|
|||
|
show: M.showOverlay,
|
|||
|
"show-background-image": M.showBackgroundImage,
|
|||
|
"show-mask": M.showMask,
|
|||
|
blur: M.blur,
|
|||
|
zIndex: M.overlayZIndex,
|
|||
|
bgColor: M.bgColor,
|
|||
|
bgImage: M.bgImage || l(QA),
|
|||
|
fit: M.fit,
|
|||
|
defaultSrc: l(QA),
|
|||
|
customStyle: { position: "absolute", width: "100%", height: "100%" },
|
|||
|
"custom-mask-style": { "backdrop-filter": "blur(12px)", "-webkit-backdrop-filter": "blur(12px)" },
|
|||
|
customClass: M.customOverlayClass,
|
|||
|
onError: c
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
L("div", gi, [
|
|||
|
L("div", Ti, [
|
|||
|
M.showLoading ? (d(), U(zt, {
|
|||
|
key: 0,
|
|||
|
mode: "dot"
|
|||
|
})) : z("", !0),
|
|||
|
L("div", pi, [
|
|||
|
M.showAvatar ? (d(), U(Fa, {
|
|||
|
key: 0,
|
|||
|
src: M.avatar || l(QA),
|
|||
|
size: l(o)
|
|||
|
}, null, 8, ["src", "size"])) : z("", !0)
|
|||
|
]),
|
|||
|
L("div", Di, [
|
|||
|
M.showUserName ? (d(), U(gA, {
|
|||
|
key: 0,
|
|||
|
truncated: !0,
|
|||
|
size: l(s),
|
|||
|
color: M.color,
|
|||
|
width: "200px",
|
|||
|
weight: 500
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
NA(W(M.username), 1)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["size", "color"])) : z("", !0),
|
|||
|
M.showMicVolume ? (d(), U(Ya, {
|
|||
|
key: 1,
|
|||
|
isMuted: M.isMuted,
|
|||
|
volume: M.volume
|
|||
|
}, null, 8, ["isMuted", "volume"])) : z("", !0)
|
|||
|
]),
|
|||
|
L("div", yi, [
|
|||
|
M.showTip && M.tip ? (d(), y("div", Ci, W(M.tip), 1)) : z("", !0)
|
|||
|
])
|
|||
|
]),
|
|||
|
q(M.$slots, "default", {}, void 0, !0)
|
|||
|
])
|
|||
|
]),
|
|||
|
_: 3
|
|||
|
}, 8, ["show", "show-background-image", "show-mask", "blur", "zIndex", "bgColor", "bgImage", "fit", "defaultSrc", "customClass"])
|
|||
|
], 6)) : z("", !0);
|
|||
|
}
|
|||
|
});
|
|||
|
const Xa = /* @__PURE__ */ Z(ji, [["__scopeId", "data-v-34807212"]]), hi = { class: "waiting-container" }, Li = {
|
|||
|
key: 0,
|
|||
|
class: "groupcall-info"
|
|||
|
}, Ei = { class: "tip" }, mi = { class: "avatar-group" }, zi = { class: "avatar-item" }, Ui = /* @__PURE__ */ f({
|
|||
|
__name: "Waiting",
|
|||
|
setup(a) {
|
|||
|
const { localUserInfoExcludeVolume: A, remoteUserListExcludeVolume: e } = G(vA()), { callerUserInfo: t } = G(hl()), { isGroupCall: o } = G(rA()), n = fa(), s = S(() => {
|
|||
|
var j, m;
|
|||
|
return o.value ? t.value.displayUserInfo : (m = (j = e.value) == null ? void 0 : j[0]) == null ? void 0 : m.displayUserInfo;
|
|||
|
}), r = S(() => {
|
|||
|
var j, m;
|
|||
|
return o.value ? t.value.avatar : (m = (j = e.value) == null ? void 0 : j[0]) == null ? void 0 : m.avatar;
|
|||
|
}), c = S(() => o.value ? !0 : !A.value.isVideoAvailable), M = S(() => o.value ? v("Invited group call") : null), N = S(() => {
|
|||
|
var j, m;
|
|||
|
return o.value ? n.value[t.value.userId] || r.value : n.value[(m = (j = e.value) == null ? void 0 : j[0]) == null ? void 0 : m.userId] || r.value;
|
|||
|
}), T = p(!1), I = p("fill");
|
|||
|
let D = p(!1);
|
|||
|
ue(() => {
|
|||
|
var j, m, w, H;
|
|||
|
if (D.value) {
|
|||
|
T.value = o.value ? !0 : !A.value.isVideoAvailable, I.value = "cover";
|
|||
|
return;
|
|||
|
}
|
|||
|
o.value ? (T.value = !n.value[t.value.userId], I.value = n.value[t.value.userId] ? "fill" : "cover") : (T.value = !A.value.isVideoAvailable && !n.value[(m = (j = e.value) == null ? void 0 : j[0]) == null ? void 0 : m.userId], I.value = n.value[(H = (w = e.value) == null ? void 0 : w[0]) == null ? void 0 : H.userId] ? "fill" : "cover");
|
|||
|
});
|
|||
|
const h = () => {
|
|||
|
D.value = !0;
|
|||
|
};
|
|||
|
return (j, m) => (d(), y("div", hi, [
|
|||
|
C(Xa, {
|
|||
|
username: l(s),
|
|||
|
avatar: l(r),
|
|||
|
"bg-image": l(N),
|
|||
|
"show-avatar": !l(V).isPC,
|
|||
|
"show-loading": !1,
|
|||
|
"bg-color": "#22262ed9",
|
|||
|
"show-mask": l(T),
|
|||
|
"show-background-image": l(c),
|
|||
|
tip: l(M),
|
|||
|
fit: l(I),
|
|||
|
onError: h
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
!l(V).isPC && l(o) ? (d(), y("div", Li, [
|
|||
|
L("div", Ei, [
|
|||
|
C(gA, { color: "#FFF" }, {
|
|||
|
default: E(() => [
|
|||
|
NA(W(l(e).length) + W(l(v)("people in the call")), 1)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
})
|
|||
|
]),
|
|||
|
L("div", mi, [
|
|||
|
(d(!0), y(RA, null, ce(l(e), (w) => (d(), y("div", zi, [
|
|||
|
C(Fa, {
|
|||
|
size: "100%",
|
|||
|
src: w.avatar || l(QA)
|
|||
|
}, null, 8, ["src"])
|
|||
|
]))), 256))
|
|||
|
])
|
|||
|
])) : z("", !0)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["username", "avatar", "bg-image", "show-avatar", "show-mask", "show-background-image", "tip", "fit"])
|
|||
|
]));
|
|||
|
}
|
|||
|
});
|
|||
|
const qa = /* @__PURE__ */ Z(Ui, [["__scopeId", "data-v-b3565c48"]]), fi = {
|
|||
|
bigWindow: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
showSmallWindow: {
|
|||
|
type: Boolean,
|
|||
|
default: !0
|
|||
|
},
|
|||
|
smallWindowWidth: {
|
|||
|
type: String,
|
|||
|
default: "30%"
|
|||
|
},
|
|||
|
smallWindowHeight: {
|
|||
|
type: String,
|
|||
|
default: "30%"
|
|||
|
}
|
|||
|
}, vi = ["toggle"], Ja = "ToggleWindowContextKey", wi = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, Oi = /* @__PURE__ */ f({
|
|||
|
...wi,
|
|||
|
__name: "ToggleWindow",
|
|||
|
props: fi,
|
|||
|
emits: vi,
|
|||
|
setup(a, { emit: A }) {
|
|||
|
const e = a, t = A, o = p(e.bigWindow), n = `${Y}-toggle-window`, s = (r) => {
|
|||
|
o.value = r, t("toggle", r);
|
|||
|
};
|
|||
|
return uA(() => e.bigWindow, () => {
|
|||
|
o.value = e.bigWindow;
|
|||
|
}), OA(Ja, {
|
|||
|
bigWindow: o,
|
|||
|
toggleWindow: s,
|
|||
|
smallWindowWidth: ct(e, "smallWindowWidth"),
|
|||
|
smallWindowHeight: ct(e, "smallWindowHeight"),
|
|||
|
showSmallWindow: ct(e, "showSmallWindow")
|
|||
|
}), (r, c) => (d(), y("div", {
|
|||
|
class: k(n)
|
|||
|
}, [
|
|||
|
q(r.$slots, "default")
|
|||
|
]));
|
|||
|
}
|
|||
|
});
|
|||
|
const Vi = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, bi = /* @__PURE__ */ f({
|
|||
|
...Vi,
|
|||
|
__name: "Portal",
|
|||
|
props: ["disabled"],
|
|||
|
setup(a) {
|
|||
|
return (A, e) => {
|
|||
|
const t = ea("root-portal");
|
|||
|
return d(), U(t, {
|
|||
|
enable: !a.disabled
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
q(A.$slots, "default")
|
|||
|
]),
|
|||
|
_: 3
|
|||
|
}, 8, ["enable"]);
|
|||
|
};
|
|||
|
}
|
|||
|
}), xi = {
|
|||
|
name: "teleport",
|
|||
|
props: {
|
|||
|
to: {
|
|||
|
type: String,
|
|||
|
required: !0
|
|||
|
},
|
|||
|
source: {
|
|||
|
type: String,
|
|||
|
required: !0
|
|||
|
},
|
|||
|
disabled: {
|
|||
|
type: Boolean,
|
|||
|
required: !0
|
|||
|
}
|
|||
|
},
|
|||
|
mounted() {
|
|||
|
if (this.disabled)
|
|||
|
return;
|
|||
|
const a = document.querySelector(this.to);
|
|||
|
a && a.appendChild(this.$el);
|
|||
|
},
|
|||
|
watch: {
|
|||
|
disabled: {
|
|||
|
immediate: !0,
|
|||
|
handler() {
|
|||
|
var a, A;
|
|||
|
this.disabled ? (A = document.querySelector(this.source)) == null || A.appendChild(this.$el) : (a = document.querySelector(this.to)) == null || a.appendChild(this.$el);
|
|||
|
}
|
|||
|
}
|
|||
|
},
|
|||
|
destroyed() {
|
|||
|
const a = document.querySelector(this.to);
|
|||
|
if (a)
|
|||
|
try {
|
|||
|
a.removeChild(this.$el);
|
|||
|
} catch (A) {
|
|||
|
console.debug(A);
|
|||
|
}
|
|||
|
}
|
|||
|
};
|
|||
|
function ki(a, A, e, t, o, n) {
|
|||
|
return d(), y("div", null, [
|
|||
|
q(a.$slots, "default")
|
|||
|
]);
|
|||
|
}
|
|||
|
const Ri = /* @__PURE__ */ Z(xi, [["render", ki]]), Bi = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, Pi = /* @__PURE__ */ f({
|
|||
|
...Bi,
|
|||
|
__name: "Portal",
|
|||
|
props: ["disabled", "to"],
|
|||
|
setup(a) {
|
|||
|
return (A, e) => (d(), U(Eo, {
|
|||
|
disabled: a.disabled,
|
|||
|
to: a.to
|
|||
|
}, [
|
|||
|
q(A.$slots, "default")
|
|||
|
], 8, ["disabled", "to"]));
|
|||
|
}
|
|||
|
}), Wi = {
|
|||
|
disabled: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
},
|
|||
|
to: {
|
|||
|
type: String,
|
|||
|
default: "body"
|
|||
|
},
|
|||
|
source: {
|
|||
|
type: String,
|
|||
|
default: "body"
|
|||
|
}
|
|||
|
}, Ha = /* @__PURE__ */ f({
|
|||
|
__name: "Portal",
|
|||
|
props: Wi,
|
|||
|
setup(a) {
|
|||
|
const { majorVersion: A } = $l();
|
|||
|
S(() => A === "3");
|
|||
|
const e = S(() => A === "2");
|
|||
|
return (t, o) => (d(), y("div", null, [
|
|||
|
l(Ct) ? (d(), U(bi, {
|
|||
|
key: 0,
|
|||
|
disabled: t.disabled
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
q(t.$slots, "default")
|
|||
|
]),
|
|||
|
_: 3
|
|||
|
}, 8, ["disabled"])) : l(e) ? (d(), U(Ri, {
|
|||
|
key: 1,
|
|||
|
disabled: t.disabled,
|
|||
|
to: t.to,
|
|||
|
source: t.source
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
q(t.$slots, "default")
|
|||
|
]),
|
|||
|
_: 3
|
|||
|
}, 8, ["disabled", "to", "source"])) : (d(), U(Pi, {
|
|||
|
key: 2,
|
|||
|
disabled: t.disabled,
|
|||
|
to: t.to
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
q(t.$slots, "default")
|
|||
|
]),
|
|||
|
_: 3
|
|||
|
}, 8, ["disabled", "to"]))
|
|||
|
]));
|
|||
|
}
|
|||
|
}), Gi = {
|
|||
|
value: {
|
|||
|
type: String
|
|||
|
}
|
|||
|
}, Qi = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, Ht = /* @__PURE__ */ f({
|
|||
|
...Qi,
|
|||
|
__name: "ToggleWindowItem",
|
|||
|
props: Gi,
|
|||
|
setup(a) {
|
|||
|
const A = a, {
|
|||
|
bigWindow: e,
|
|||
|
toggleWindow: t,
|
|||
|
smallWindowWidth: o,
|
|||
|
smallWindowHeight: n,
|
|||
|
showSmallWindow: s
|
|||
|
} = VA(Ja), r = S(() => iA([
|
|||
|
`${Y}-toggle-window-item`,
|
|||
|
`${Y}-toggle-window-item--${e.value === A.value ? "big" : "small"}`,
|
|||
|
{
|
|||
|
pc: re,
|
|||
|
mobile: !re
|
|||
|
}
|
|||
|
])), c = S(() => {
|
|||
|
let M = {};
|
|||
|
return e.value !== A.value && (M = { width: o.value, height: n.value }, s.value ? M.visibility = "" : M.visibility = "hidden"), M;
|
|||
|
});
|
|||
|
return (M, N) => (d(), y("div", {
|
|||
|
class: k(l(r)),
|
|||
|
style: eA([l(c)]),
|
|||
|
onClick: N[0] || (N[0] = () => l(t)(M.value))
|
|||
|
}, [
|
|||
|
q(M.$slots, "default")
|
|||
|
], 6));
|
|||
|
}
|
|||
|
});
|
|||
|
const Ut = {
|
|||
|
nickName: {
|
|||
|
type: String,
|
|||
|
default: ""
|
|||
|
},
|
|||
|
isSelf: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
},
|
|||
|
isMuted: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
},
|
|||
|
volume: {
|
|||
|
type: Number,
|
|||
|
default: 0
|
|||
|
},
|
|||
|
showNickName: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
},
|
|||
|
showSwitchCameraButton: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
},
|
|||
|
showVirtualBackgroundButton: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
},
|
|||
|
showNetWorkStatus: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
}
|
|||
|
}, Ka = "
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, qi = /* @__PURE__ */ f({
|
|||
|
...Xi,
|
|||
|
__name: "StreamInfoPC",
|
|||
|
props: Ut,
|
|||
|
setup(a) {
|
|||
|
return (A, e) => (d(), U(ne, null, {
|
|||
|
default: E(() => [
|
|||
|
C(yA, {
|
|||
|
span: 12,
|
|||
|
justify: "start",
|
|||
|
align: "center"
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
L("div", Zi, [
|
|||
|
C(Ya, {
|
|||
|
class: "mic-volume",
|
|||
|
"is-muted": A.isMuted,
|
|||
|
volume: A.volume
|
|||
|
}, null, 8, ["is-muted", "volume"]),
|
|||
|
L("div", Fi, [
|
|||
|
C(gA, {
|
|||
|
color: "#fff",
|
|||
|
truncated: !0,
|
|||
|
width: "80px",
|
|||
|
size: "14px"
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
NA(W(A.nickName), 1)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}),
|
|||
|
sA(C(gA, {
|
|||
|
color: "#fff",
|
|||
|
size: "14px"
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
NA(W(l(v)("me")), 1)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 512), [
|
|||
|
[cA, A.isSelf]
|
|||
|
])
|
|||
|
])
|
|||
|
])
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}),
|
|||
|
C(yA, {
|
|||
|
span: 12,
|
|||
|
justify: "center"
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
A.showNetWorkStatus ? (d(), y("div", Yi, [
|
|||
|
C(LA, {
|
|||
|
width: "24px",
|
|||
|
height: "24px",
|
|||
|
src: l(Ka)
|
|||
|
}, null, 8, ["src"])
|
|||
|
])) : z("", !0)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
})
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}));
|
|||
|
}
|
|||
|
});
|
|||
|
const Ji = /* @__PURE__ */ Z(qi, [["__scopeId", "data-v-4a815645"]]), Hi = "", Ki = "
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, As = /* @__PURE__ */ f({
|
|||
|
...$i,
|
|||
|
__name: "StreamInfoMobile",
|
|||
|
props: Ut,
|
|||
|
setup(a) {
|
|||
|
const { enableVirtualBackground: A } = G(rA()), e = async () => {
|
|||
|
await Q.switchCamera();
|
|||
|
}, t = async () => {
|
|||
|
await Q.setBlurBackground(!A.value);
|
|||
|
};
|
|||
|
return (o, n) => (d(), U(ne, { "custom-style": { padding: "2px 5px" } }, {
|
|||
|
default: E(() => [
|
|||
|
C(yA, {
|
|||
|
span: 12,
|
|||
|
justify: "start",
|
|||
|
align: "center"
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
o.showNickName ? (d(), U(gA, {
|
|||
|
key: 0,
|
|||
|
width: "100px",
|
|||
|
truncated: !0,
|
|||
|
color: "#FFF"
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
NA(W(o.nickName), 1)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
})) : z("", !0),
|
|||
|
sA(L("div", null, [
|
|||
|
C(De, {
|
|||
|
size: 24,
|
|||
|
src: l(Hi)
|
|||
|
}, null, 8, ["src"])
|
|||
|
], 512), [
|
|||
|
[cA, !o.isMuted && o.volume]
|
|||
|
]),
|
|||
|
sA(L("div", null, [
|
|||
|
C(De, {
|
|||
|
size: 24,
|
|||
|
src: l(Ki)
|
|||
|
}, null, 8, ["src"])
|
|||
|
], 512), [
|
|||
|
[cA, o.isMuted]
|
|||
|
])
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}),
|
|||
|
C(yA, {
|
|||
|
span: 12,
|
|||
|
justify: "end",
|
|||
|
align: "center"
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
o.showNetWorkStatus ? (d(), y("div", _i, [
|
|||
|
C(LA, {
|
|||
|
width: "24px",
|
|||
|
height: "24px",
|
|||
|
src: l(Ka)
|
|||
|
}, null, 8, ["src"])
|
|||
|
])) : z("", !0),
|
|||
|
o.showSwitchCameraButton ? (d(), y("div", {
|
|||
|
key: 1,
|
|||
|
class: "switch-camera stream-icon",
|
|||
|
onClick: pe(e, ["stop"])
|
|||
|
}, [
|
|||
|
C(LA, {
|
|||
|
width: "15px",
|
|||
|
height: "15px",
|
|||
|
src: l(JA)
|
|||
|
}, null, 8, ["src"])
|
|||
|
])) : z("", !0),
|
|||
|
o.showVirtualBackgroundButton ? (d(), y("div", {
|
|||
|
key: 2,
|
|||
|
class: "stream-icon",
|
|||
|
onClick: pe(t, ["stop"])
|
|||
|
}, [
|
|||
|
C(LA, {
|
|||
|
width: "15px",
|
|||
|
height: "15px",
|
|||
|
src: l(KA)
|
|||
|
}, null, 8, ["src"])
|
|||
|
])) : z("", !0)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
})
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}));
|
|||
|
}
|
|||
|
});
|
|||
|
const es = /* @__PURE__ */ Z(As, [["__scopeId", "data-v-04a5fe7d"]]), ts = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, $e = /* @__PURE__ */ f({
|
|||
|
...ts,
|
|||
|
__name: "TKStreamInfo",
|
|||
|
props: Ut,
|
|||
|
setup(a) {
|
|||
|
const { isGroupCall: A } = rA(), e = V.isPC;
|
|||
|
return (t, o) => (d(), y("div", null, [
|
|||
|
l(e) ? (d(), U(Ji, {
|
|||
|
key: 0,
|
|||
|
nickName: t.nickName,
|
|||
|
isSelf: t.isSelf,
|
|||
|
isMuted: t.isMuted,
|
|||
|
volume: t.volume,
|
|||
|
showNetWorkStatus: t.showNetWorkStatus
|
|||
|
}, null, 8, ["nickName", "isSelf", "isMuted", "volume", "showNetWorkStatus"])) : z("", !0),
|
|||
|
l(A) && !l(e) ? (d(), U(es, {
|
|||
|
key: 1,
|
|||
|
showSwitchCameraButton: t.showSwitchCameraButton,
|
|||
|
showVirtualBackgroundButton: t.showVirtualBackgroundButton,
|
|||
|
showNetWorkStatus: t.showNetWorkStatus,
|
|||
|
nickName: t.nickName,
|
|||
|
showNickName: t.showNickName,
|
|||
|
isSelf: t.isSelf,
|
|||
|
isMuted: t.isMuted,
|
|||
|
volume: t.volume
|
|||
|
}, null, 8, ["showSwitchCameraButton", "showVirtualBackgroundButton", "showNetWorkStatus", "nickName", "showNickName", "isSelf", "isMuted", "volume"])) : z("", !0)
|
|||
|
]));
|
|||
|
}
|
|||
|
}), as = {
|
|||
|
show: {
|
|||
|
type: Boolean,
|
|||
|
default: !0
|
|||
|
},
|
|||
|
domId: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
loading: {
|
|||
|
type: Boolean
|
|||
|
},
|
|||
|
showStreamInfo: {
|
|||
|
type: Boolean
|
|||
|
},
|
|||
|
showAudioStream: {
|
|||
|
type: Boolean
|
|||
|
}
|
|||
|
}, os = ["id"], ls = { class: "audio-stream-container" }, ns = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, is = /* @__PURE__ */ f({
|
|||
|
...ns,
|
|||
|
__name: "Pusher",
|
|||
|
props: as,
|
|||
|
setup(a) {
|
|||
|
const A = p(g.getData(u.CALL, i.PUSHER_ID)), e = iA([
|
|||
|
"stream-info-container",
|
|||
|
{ mobile: !V.isPC }
|
|||
|
]), t = (n) => {
|
|||
|
A.value = n;
|
|||
|
}, o = {
|
|||
|
[i.PUSHER_ID]: t
|
|||
|
};
|
|||
|
return CA(() => {
|
|||
|
g.watch(u.CALL, o, { notifyRangeWhenWatch: i.MYSELF });
|
|||
|
}), DA(() => {
|
|||
|
g.unwatch(u.CALL, o);
|
|||
|
}), (n, s) => sA((d(), y("div", {
|
|||
|
id: n.domId,
|
|||
|
class: "pusher-container"
|
|||
|
}, [
|
|||
|
sA(L("div", ls, [
|
|||
|
q(n.$slots, "audio-stream", {}, void 0, !0)
|
|||
|
], 512), [
|
|||
|
[cA, n.showAudioStream]
|
|||
|
]),
|
|||
|
q(n.$slots, "loading", {}, void 0, !0),
|
|||
|
L("div", {
|
|||
|
class: k(l(e))
|
|||
|
}, [
|
|||
|
q(n.$slots, "stream-info", {}, void 0, !0)
|
|||
|
], 2)
|
|||
|
], 8, os)), [
|
|||
|
[cA, n.show]
|
|||
|
]);
|
|||
|
}
|
|||
|
});
|
|||
|
const _a = /* @__PURE__ */ Z(is, [["__scopeId", "data-v-8cf5d7b3"]]), ss = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, cs = /* @__PURE__ */ f({
|
|||
|
...ss,
|
|||
|
__name: "weChatPlayer",
|
|||
|
props: {
|
|||
|
remoteClass: {
|
|||
|
type: String,
|
|||
|
required: !0
|
|||
|
},
|
|||
|
domId: {
|
|||
|
type: String
|
|||
|
}
|
|||
|
},
|
|||
|
setup(a) {
|
|||
|
const A = p(g.getData(u.CALL, i.PLAYER)), e = p(g.getData(u.CALL, i.CALL_STATUS)), t = p(g.getData(u.CALL, i.IS_EAR_PHONE) ? je.EAR : je.SPEAKER), o = a, n = (h) => {
|
|||
|
A.value = JSON.parse(JSON.stringify(h));
|
|||
|
}, s = S(() => {
|
|||
|
var h;
|
|||
|
return (h = A.value) == null ? void 0 : h.find((j) => (j == null ? void 0 : j.userID) === o.domId);
|
|||
|
}), r = (h) => {
|
|||
|
e.value = h;
|
|||
|
}, c = (h) => {
|
|||
|
t.value = h ? je.EAR : je.SPEAKER;
|
|||
|
}, M = {
|
|||
|
[i.PLAYER]: n,
|
|||
|
[i.CALL_STATUS]: r,
|
|||
|
[i.IS_EAR_PHONE]: c
|
|||
|
};
|
|||
|
CA(() => {
|
|||
|
g.watch(u.CALL, M, { notifyRangeWhenWatch: i.MYSELF });
|
|||
|
}), DA(() => {
|
|||
|
g.unwatch(u.CALL, M);
|
|||
|
});
|
|||
|
function N(h) {
|
|||
|
Q._tuiCallEngine._playerStateChange(h);
|
|||
|
}
|
|||
|
function T(h) {
|
|||
|
}
|
|||
|
function I(h) {
|
|||
|
Q._tuiCallEngine._playNetStatus(h);
|
|||
|
}
|
|||
|
function D(h) {
|
|||
|
Q._tuiCallEngine._playerAudioVolumeNotify(h);
|
|||
|
}
|
|||
|
return (h, j) => {
|
|||
|
const m = ea("live-player");
|
|||
|
return d(), y("div", {
|
|||
|
class: k(a.remoteClass)
|
|||
|
}, [
|
|||
|
l(s) && (l(s).hasAudio || l(s).hasVideo) ? (d(), U(m, {
|
|||
|
key: 0,
|
|||
|
class: "stream",
|
|||
|
id: l(s).id,
|
|||
|
"data-userid": l(s).userID,
|
|||
|
"data-streamid": l(s).streamID,
|
|||
|
"data-streamtype": l(s).streamType,
|
|||
|
src: l(s).src,
|
|||
|
mode: "RTC",
|
|||
|
autoplay: l(s).autoplay,
|
|||
|
"mute-audio": l(s).muteAudio,
|
|||
|
"mute-video": l(s).muteVideo,
|
|||
|
orientation: l(s).orientation,
|
|||
|
"object-fit": l(s).objectFit,
|
|||
|
"background-mute": l(s).enableBackgroundMute,
|
|||
|
"min-cache": l(s).minCache,
|
|||
|
"max-cache": l(s).maxCache,
|
|||
|
"sound-mode": l(t),
|
|||
|
"enable-recv-message": l(s).enableRecvMessage,
|
|||
|
"auto-pause-if-navigate": l(s).autoPauseIfNavigate,
|
|||
|
"auto-pause-if-open-native": l(s).autoPauseIfOpenNative,
|
|||
|
onStatechange: N,
|
|||
|
onFullscreenchange: T,
|
|||
|
onNetstatus: I,
|
|||
|
onAudiovolumenotify: D
|
|||
|
}, null, 8, ["id", "data-userid", "data-streamid", "data-streamtype", "src", "autoplay", "mute-audio", "mute-video", "orientation", "object-fit", "background-mute", "min-cache", "max-cache", "sound-mode", "enable-recv-message", "auto-pause-if-navigate", "auto-pause-if-open-native"])) : z("", !0)
|
|||
|
], 2);
|
|||
|
};
|
|||
|
}
|
|||
|
});
|
|||
|
const rs = /* @__PURE__ */ Z(cs, [["__scopeId", "data-v-b0aae39e"]]), us = {
|
|||
|
show: {
|
|||
|
type: Boolean,
|
|||
|
default: !0
|
|||
|
},
|
|||
|
domId: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
loading: {
|
|||
|
type: Boolean
|
|||
|
},
|
|||
|
showStreamInfo: {
|
|||
|
type: Boolean
|
|||
|
},
|
|||
|
showAudioStream: {
|
|||
|
type: Boolean
|
|||
|
}
|
|||
|
}, Ms = ["id"], ds = { class: "audio-stream-container" }, Is = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, Ns = /* @__PURE__ */ f({
|
|||
|
...Is,
|
|||
|
__name: "Player",
|
|||
|
props: us,
|
|||
|
setup(a) {
|
|||
|
const A = iA([
|
|||
|
"stream-info-container",
|
|||
|
{ mobile: !V.isPC }
|
|||
|
]);
|
|||
|
return (e, t) => sA((d(), y("div", {
|
|||
|
id: e.domId,
|
|||
|
class: "player-container"
|
|||
|
}, [
|
|||
|
sA(L("div", ds, [
|
|||
|
q(e.$slots, "audio-stream", {}, void 0, !0)
|
|||
|
], 512), [
|
|||
|
[cA, e.showAudioStream]
|
|||
|
]),
|
|||
|
q(e.$slots, "loading", {}, void 0, !0),
|
|||
|
L("div", {
|
|||
|
class: k(l(A))
|
|||
|
}, [
|
|||
|
q(e.$slots, "stream-info", {}, void 0, !0)
|
|||
|
], 2),
|
|||
|
l(V).isWeChat ? (d(), U(rs, {
|
|||
|
key: 0,
|
|||
|
"dom-id": e.domId,
|
|||
|
remoteClass: "small-view"
|
|||
|
}, null, 8, ["dom-id"])) : z("", !0)
|
|||
|
], 8, Ms)), [
|
|||
|
[cA, e.show]
|
|||
|
]);
|
|||
|
}
|
|||
|
});
|
|||
|
const $a = /* @__PURE__ */ Z(Ns, [["__scopeId", "data-v-8e509e0d"]]), gs = {
|
|||
|
avatar: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
username: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
isVideoAvailable: {
|
|||
|
type: Boolean
|
|||
|
},
|
|||
|
showStreamInfo: {
|
|||
|
type: Boolean
|
|||
|
},
|
|||
|
isSmallWindow: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
},
|
|||
|
isMuted: {
|
|||
|
type: Boolean,
|
|||
|
default: !0
|
|||
|
},
|
|||
|
volume: {
|
|||
|
type: Number,
|
|||
|
default: 0
|
|||
|
},
|
|||
|
userId: {
|
|||
|
type: String
|
|||
|
}
|
|||
|
}, Ts = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, At = /* @__PURE__ */ f({
|
|||
|
...Ts,
|
|||
|
__name: "AudioStream",
|
|||
|
props: gs,
|
|||
|
setup(a) {
|
|||
|
const A = a, e = fa(), { callType: t, isGroupCall: o } = G(rA()), { isFloatWindow: n } = G(BA()), s = S(() => !o.value && !V.isPC), r = S(() => o.value ? V.isPC : t.value === _.AUDIO), c = S(() => !o.value && V.isPC && t.value === _.AUDIO), M = S(() => ({ zIndex: 1 })), N = S(() => e.value[A.userId] || A.avatar), T = p(!e.value[A.userId]), I = p(e.value[A.userId] ? "fill" : "cover");
|
|||
|
uA([() => A.userId, e], () => {
|
|||
|
e.value[A.userId] ? (I.value = "fill", T.value = !1) : (I.value = "cover", T.value = !0);
|
|||
|
}, {
|
|||
|
immediate: !0
|
|||
|
});
|
|||
|
const D = () => {
|
|||
|
T.value = !0, I.value = "cover";
|
|||
|
};
|
|||
|
return (h, j) => (d(), U(Xa, {
|
|||
|
avatar: h.avatar,
|
|||
|
"bg-image": l(N),
|
|||
|
"show-avatar": l(s),
|
|||
|
username: h.username,
|
|||
|
"show-user-name": l(r),
|
|||
|
"show-mask": !l(o) && l(T),
|
|||
|
fit: l(I),
|
|||
|
blur: !l(o),
|
|||
|
"show-mic-volume": l(c),
|
|||
|
"show-tip": !l(o) && !l(n),
|
|||
|
"custom-style": l(M),
|
|||
|
"is-small-window": h.isSmallWindow,
|
|||
|
"is-muted": h.isMuted,
|
|||
|
volume: h.volume,
|
|||
|
"bg-color": "rgba(0, 0, 0, 0.5)",
|
|||
|
onError: D
|
|||
|
}, null, 8, ["avatar", "bg-image", "show-avatar", "username", "show-user-name", "show-mask", "fit", "blur", "show-mic-volume", "show-tip", "custom-style", "is-small-window", "is-muted", "volume"]));
|
|||
|
}
|
|||
|
}), ps = "", Ds = "", ys = "", Cs = "data:ima
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, ws = /* @__PURE__ */ f({
|
|||
|
...vs,
|
|||
|
__name: "FloatWindow",
|
|||
|
setup(a) {
|
|||
|
const { localUserInfoExcludeVolume: A } = G(vA()), { callRole: e, callStatus: t } = G(rA()), { isFloatWindow: o } = G(BA());
|
|||
|
function n() {
|
|||
|
Q.toggleMinimize();
|
|||
|
}
|
|||
|
async function s() {
|
|||
|
e.value === IA.CALLEE && t.value === P.CALLING ? await Q.reject() : await Q.hangup();
|
|||
|
}
|
|||
|
async function r() {
|
|||
|
A.value.isAudioAvailable ? await Q.closeMicrophone() : await Q.openMicrophone();
|
|||
|
}
|
|||
|
return (c, M) => (d(), y("div", Ss, [
|
|||
|
sA(L("div", js, [
|
|||
|
L("div", hs, [
|
|||
|
L("div", {
|
|||
|
class: "float-control-item-icon-container",
|
|||
|
onClick: s
|
|||
|
}, [
|
|||
|
L("img", { src: l(ps) }, null, 8, Ls)
|
|||
|
])
|
|||
|
]),
|
|||
|
sA(L("div", Es, [
|
|||
|
L("div", {
|
|||
|
class: "float-control-item-icon-container",
|
|||
|
onClick: r
|
|||
|
}, [
|
|||
|
l(A).isAudioAvailable ? (d(), y("img", {
|
|||
|
key: 0,
|
|||
|
src: l(Ds)
|
|||
|
}, null, 8, ms)) : (d(), y("img", {
|
|||
|
key: 1,
|
|||
|
src: l(ys)
|
|||
|
}, null, 8, zs))
|
|||
|
])
|
|||
|
], 512), [
|
|||
|
[cA, l(o)]
|
|||
|
]),
|
|||
|
sA(L("div", Us, [
|
|||
|
L("div", {
|
|||
|
class: "float-control-item-icon-container",
|
|||
|
onClick: n
|
|||
|
}, [
|
|||
|
L("img", { src: l(Cs) }, null, 8, fs)
|
|||
|
])
|
|||
|
], 512), [
|
|||
|
[cA, l(o)]
|
|||
|
])
|
|||
|
], 512), [
|
|||
|
[cA, l(o)]
|
|||
|
]),
|
|||
|
sA(L("div", null, [
|
|||
|
q(c.$slots, "default", {}, void 0, !0)
|
|||
|
], 512), [
|
|||
|
[cA, !l(o)]
|
|||
|
])
|
|||
|
]));
|
|||
|
}
|
|||
|
});
|
|||
|
const Os = /* @__PURE__ */ Z(ws, [["__scopeId", "data-v-63373c5d"]]), Ao = "", Vs = { class: "float-window-tip-container" }, bs = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, xs = /* @__PURE__ */ f({
|
|||
|
...bs,
|
|||
|
__name: "FloatWindowSingleCall",
|
|||
|
setup(a) {
|
|||
|
const { callType: A, callStatus: e } = G(rA()), { isFloatWindow: t } = G(BA()), { callDuration: o } = mt(), n = S(() => iA([
|
|||
|
"float-window-container",
|
|||
|
{
|
|||
|
"singlecall-video-float": A.value === _.VIDEO && t.value,
|
|||
|
"singlecall-audio-float": A.value === _.AUDIO && t.value
|
|||
|
}
|
|||
|
]));
|
|||
|
function s() {
|
|||
|
t.value && Q.toggleMinimize();
|
|||
|
}
|
|||
|
return (r, c) => (d(), y("div", {
|
|||
|
class: k(l(n))
|
|||
|
}, [
|
|||
|
sA(L("div", {
|
|||
|
class: "singlecall-video-float-content",
|
|||
|
onClick: s
|
|||
|
}, [
|
|||
|
q(r.$slots, "default", {}, void 0, !0),
|
|||
|
L("div", Vs, [
|
|||
|
l(e) === l(P).CALLING && l(t) ? (d(), U(gA, {
|
|||
|
key: 0,
|
|||
|
color: "#FFF",
|
|||
|
size: "12px"
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
NA(W(l(v)("wait to be called")), 1)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
})) : z("", !0)
|
|||
|
])
|
|||
|
], 512), [
|
|||
|
[cA, !(l(t) && l(A) === l(_).AUDIO)]
|
|||
|
]),
|
|||
|
sA(L("div", {
|
|||
|
class: "singlecall-audio-float-content",
|
|||
|
onClick: s
|
|||
|
}, [
|
|||
|
C(LA, {
|
|||
|
width: "36px",
|
|||
|
height: "36px",
|
|||
|
src: l(Ao)
|
|||
|
}, null, 8, ["src"]),
|
|||
|
l(e) === l(P).CONNECTED ? (d(), U(_e, {
|
|||
|
key: 0,
|
|||
|
fontSize: "12px",
|
|||
|
callDuration: l(o),
|
|||
|
color: "#12b969"
|
|||
|
}, null, 8, ["callDuration"])) : z("", !0),
|
|||
|
l(e) === l(P).CALLING && l(t) ? (d(), U(gA, {
|
|||
|
key: 1,
|
|||
|
color: "#12b969",
|
|||
|
size: "12px"
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
NA(W(l(v)("wait to be called")), 1)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
})) : z("", !0)
|
|||
|
], 512), [
|
|||
|
[cA, l(t) && l(A) === l(_).AUDIO]
|
|||
|
])
|
|||
|
], 2));
|
|||
|
}
|
|||
|
});
|
|||
|
const ks = /* @__PURE__ */ Z(xs, [["__scopeId", "data-v-381004f2"]]), Rs = "", Bs = "", Ps = "", Ws = "
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, Xs = /* @__PURE__ */ f({
|
|||
|
...Ys,
|
|||
|
__name: "FloatWindowGroupCall",
|
|||
|
setup(a) {
|
|||
|
const { isFloatWindow: A } = G(BA()), { callDuration: e } = mt(), { localUserInfoExcludeVolume: t } = G(vA()), { callStatus: o } = G(rA()), n = S(() => t.value.isAudioAvailable ? Rs : Ps), s = S(() => t.value.isVideoAvailable ? Bs : Ws), r = S(() => iA([
|
|||
|
"groupcall-video-float",
|
|||
|
{
|
|||
|
"not-float": !A.value,
|
|||
|
float: A.value
|
|||
|
}
|
|||
|
]));
|
|||
|
function c() {
|
|||
|
A.value && Q.toggleMinimize();
|
|||
|
}
|
|||
|
return (M, N) => (d(), y("div", {
|
|||
|
class: k(l(r))
|
|||
|
}, [
|
|||
|
l(A) ? (d(), y("div", {
|
|||
|
key: 0,
|
|||
|
class: "click-container",
|
|||
|
onClickCapture: pe(c, ["stop"])
|
|||
|
}, null, 32)) : z("", !0),
|
|||
|
L("div", Gs, [
|
|||
|
L("div", Qs, [
|
|||
|
q(M.$slots, "default", {}, void 0, !0)
|
|||
|
]),
|
|||
|
sA(L("div", Zs, [
|
|||
|
C(LA, {
|
|||
|
width: "36px",
|
|||
|
height: "36px",
|
|||
|
src: l(Ao)
|
|||
|
}, null, 8, ["src"]),
|
|||
|
l(o) === l(P).CONNECTED ? (d(), U(_e, {
|
|||
|
key: 0,
|
|||
|
fontSize: "12px",
|
|||
|
callDuration: l(e),
|
|||
|
color: "#12b969"
|
|||
|
}, null, 8, ["callDuration"])) : z("", !0),
|
|||
|
l(o) === l(P).CALLING ? (d(), U(gA, {
|
|||
|
key: 1,
|
|||
|
size: "12px",
|
|||
|
color: "#12b969"
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
NA(W(l(v)("wait to be called")), 1)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
})) : z("", !0)
|
|||
|
], 512), [
|
|||
|
[cA, l(A)]
|
|||
|
])
|
|||
|
]),
|
|||
|
sA(L("div", Fs, [
|
|||
|
C(LA, {
|
|||
|
width: "16px",
|
|||
|
height: "16px",
|
|||
|
src: l(n)
|
|||
|
}, null, 8, ["src"]),
|
|||
|
C(LA, {
|
|||
|
width: "16px",
|
|||
|
height: "16px",
|
|||
|
src: l(s)
|
|||
|
}, null, 8, ["src"])
|
|||
|
], 512), [
|
|||
|
[cA, l(A)]
|
|||
|
])
|
|||
|
], 2));
|
|||
|
}
|
|||
|
});
|
|||
|
const qs = /* @__PURE__ */ Z(Xs, [["__scopeId", "data-v-00e5113e"]]), Js = { id: "float-window-id" }, Hs = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, Ks = /* @__PURE__ */ f({
|
|||
|
...Hs,
|
|||
|
__name: "FloatWindow",
|
|||
|
setup(a) {
|
|||
|
const { isGroupCall: A } = G(rA());
|
|||
|
return (e, t) => (d(), y("div", Js, [
|
|||
|
l(A) ? (d(), U(qs, { key: 1 }, {
|
|||
|
default: E(() => [
|
|||
|
q(e.$slots, "default")
|
|||
|
]),
|
|||
|
_: 3
|
|||
|
})) : (d(), U(ks, { key: 0 }, {
|
|||
|
default: E(() => [
|
|||
|
q(e.$slots, "default")
|
|||
|
]),
|
|||
|
_: 3
|
|||
|
}))
|
|||
|
]));
|
|||
|
}
|
|||
|
}), _s = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, $s = /* @__PURE__ */ f({
|
|||
|
..._s,
|
|||
|
__name: "FloatWindow",
|
|||
|
setup(a) {
|
|||
|
const { isFloatWindow: A } = G(BA()), e = S(() => iA([
|
|||
|
"float-window-container",
|
|||
|
{
|
|||
|
float: A.value,
|
|||
|
"not-float": !A.value,
|
|||
|
pc: V.isPC,
|
|||
|
mobile: !V.isPC
|
|||
|
}
|
|||
|
]));
|
|||
|
return (t, o) => (d(), y("div", {
|
|||
|
class: k(l(e))
|
|||
|
}, [
|
|||
|
l(V).isPC ? (d(), U(Os, { key: 0 }, {
|
|||
|
default: E(() => [
|
|||
|
q(t.$slots, "default", {}, void 0, !0)
|
|||
|
]),
|
|||
|
_: 3
|
|||
|
})) : z("", !0),
|
|||
|
l(V).isPC ? z("", !0) : (d(), U(Ks, { key: 1 }, {
|
|||
|
default: E(() => [
|
|||
|
q(t.$slots, "default", {}, void 0, !0)
|
|||
|
]),
|
|||
|
_: 3
|
|||
|
}))
|
|||
|
], 2));
|
|||
|
}
|
|||
|
});
|
|||
|
const eo = /* @__PURE__ */ Z($s, [["__scopeId", "data-v-794f0a9b"]]);
|
|||
|
function Ac() {
|
|||
|
const a = be(), { callStatus: A } = G(rA()), e = p(GA.LOCAL), { remoteUserListExcludeVolume: t } = G(vA());
|
|||
|
return uA([t, a, A], () => {
|
|||
|
var s, r, c, M;
|
|||
|
if (A.value === P.CALLING)
|
|||
|
return;
|
|||
|
const o = [Xe.RemoteInLargeView, Xe.LocalInLargeView], n = (s = a.value) == null ? void 0 : s.layoutMode;
|
|||
|
if (o.includes(n)) {
|
|||
|
e.value = (r = a.value) == null ? void 0 : r.layoutMode;
|
|||
|
return;
|
|||
|
}
|
|||
|
(M = (c = t.value) == null ? void 0 : c[0]) != null && M.isEnter && (e.value = GA.REMOTE);
|
|||
|
}, {
|
|||
|
immediate: !0
|
|||
|
}), e;
|
|||
|
}
|
|||
|
const ec = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, tc = /* @__PURE__ */ f({
|
|||
|
...ec,
|
|||
|
__name: "MediaContainer",
|
|||
|
setup(a) {
|
|||
|
const A = Ac(), e = p(!0), { isFloatWindow: t } = G(BA()), { localUserInfoExcludeVolume: o, remoteUserListExcludeVolume: n } = G(vA()), s = Ea(), { callType: r, callStatus: c } = G(rA()), M = ma(), N = S(
|
|||
|
() => {
|
|||
|
var j, m, w, H;
|
|||
|
return V.isWeChat ? (m = (j = M.value) == null ? void 0 : j.find((b) => {
|
|||
|
var x, B;
|
|||
|
return (b == null ? void 0 : b.userID) === ((B = (x = n.value) == null ? void 0 : x[0]) == null ? void 0 : B.userId);
|
|||
|
})) == null ? void 0 : m.hasVideo : (H = (w = n.value) == null ? void 0 : w[0]) == null ? void 0 : H.isVideoAvailable;
|
|||
|
}
|
|||
|
), T = S(() => {
|
|||
|
var j, m;
|
|||
|
return (m = (j = n.value) == null ? void 0 : j[0]) == null ? void 0 : m.domId;
|
|||
|
}), I = S(() => {
|
|||
|
var j, m, w;
|
|||
|
return (w = s.value) == null ? void 0 : w[(m = (j = n.value) == null ? void 0 : j[0]) == null ? void 0 : m.domId];
|
|||
|
});
|
|||
|
uA([r, c], () => {
|
|||
|
r.value === _.AUDIO || c.value === P.CALLING ? e.value = !1 : e.value = !0;
|
|||
|
}, {
|
|||
|
immediate: !0
|
|||
|
});
|
|||
|
const D = S(() => iA([
|
|||
|
"singlecall-media-container",
|
|||
|
{
|
|||
|
mobile: !V.isPC,
|
|||
|
pc: V.isPC,
|
|||
|
float: t.value
|
|||
|
}
|
|||
|
]));
|
|||
|
function h(j) {
|
|||
|
A.value = j;
|
|||
|
}
|
|||
|
return (j, m) => (d(), U(Ha, {
|
|||
|
id: "source",
|
|||
|
disabled: !l(t),
|
|||
|
source: "#source",
|
|||
|
to: "body"
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
C(eo, null, {
|
|||
|
default: E(() => [
|
|||
|
L("div", {
|
|||
|
class: k(l(D))
|
|||
|
}, [
|
|||
|
C(Oi, {
|
|||
|
"big-window": l(A),
|
|||
|
"show-small-window": l(e),
|
|||
|
onToggle: h
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
(d(), U(Ht, {
|
|||
|
value: l(GA).LOCAL,
|
|||
|
key: l(GA).LOCAL
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
C(_a, {
|
|||
|
domId: l(o).domId,
|
|||
|
"show-audio-stream": !l(o).isVideoAvailable
|
|||
|
}, {
|
|||
|
"audio-stream": E(() => [
|
|||
|
C(At, {
|
|||
|
userId: l(o).userId,
|
|||
|
username: l(o).displayUserInfo,
|
|||
|
avatar: l(o).avatar,
|
|||
|
"is-video-available": l(o).isVideoAvailable,
|
|||
|
"is-small-window": l(A) !== l(GA).LOCAL,
|
|||
|
"is-muted": !l(o).isAudioAvailable,
|
|||
|
volume: l(s) && l(s)[l(o).domId]
|
|||
|
}, null, 8, ["userId", "username", "avatar", "is-video-available", "is-small-window", "is-muted", "volume"])
|
|||
|
]),
|
|||
|
"stream-info": E(() => [
|
|||
|
l(r) === l(_).VIDEO ? (d(), U($e, {
|
|||
|
key: 0,
|
|||
|
"nick-name": l(o).displayUserInfo,
|
|||
|
"is-self": !0,
|
|||
|
"is-muted": !l(o).isAudioAvailable,
|
|||
|
volume: l(s) && l(s)[l(o).domId]
|
|||
|
}, null, 8, ["nick-name", "is-muted", "volume"])) : z("", !0)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["domId", "show-audio-stream"])
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["value"])),
|
|||
|
(d(), U(Ht, {
|
|||
|
value: l(GA).REMOTE,
|
|||
|
key: l(GA).REMOTE
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
C($a, {
|
|||
|
"dom-id": l(T),
|
|||
|
"show-audio-stream": !l(N)
|
|||
|
}, {
|
|||
|
"audio-stream": E(() => [
|
|||
|
C(At, {
|
|||
|
userId: l(n)[0] && l(n)[0].userId,
|
|||
|
username: l(n)[0] && l(n)[0].displayUserInfo,
|
|||
|
avatar: l(n)[0] && l(n)[0].avatar,
|
|||
|
"is-video-available": l(N),
|
|||
|
"is-small-window": l(A) !== l(GA).REMOTE,
|
|||
|
"is-muted": l(n)[0] && !l(n)[0].isAudioAvailable,
|
|||
|
volume: l(I)
|
|||
|
}, null, 8, ["userId", "username", "avatar", "is-video-available", "is-small-window", "is-muted", "volume"])
|
|||
|
]),
|
|||
|
"stream-info": E(() => [
|
|||
|
l(r) === l(_).VIDEO ? (d(), U($e, {
|
|||
|
key: 0,
|
|||
|
"nick-name": l(n)[0] && l(n)[0].displayUserInfo,
|
|||
|
"is-muted": l(n)[0] && !l(n)[0].isAudioAvailable,
|
|||
|
volume: l(I)
|
|||
|
}, null, 8, ["nick-name", "is-muted", "volume"])) : z("", !0)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["dom-id", "show-audio-stream"])
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["value"]))
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["big-window", "show-small-window"])
|
|||
|
], 2)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
})
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["disabled"]));
|
|||
|
}
|
|||
|
});
|
|||
|
const ac = /* @__PURE__ */ Z(tc, [["__scopeId", "data-v-670a78d8"]]), oc = [ze.SUCCESS, ze.INFO, ze.WARNING, ze.ERROR], Ne = {
|
|||
|
isShow: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
},
|
|||
|
message: {
|
|||
|
type: String,
|
|||
|
default: ""
|
|||
|
},
|
|||
|
type: {
|
|||
|
type: String,
|
|||
|
values: oc,
|
|||
|
default: ze.INFO
|
|||
|
},
|
|||
|
duration: {
|
|||
|
type: Number,
|
|||
|
default: 3e3
|
|||
|
},
|
|||
|
offset: {
|
|||
|
type: Number,
|
|||
|
default: 16
|
|||
|
},
|
|||
|
showClose: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
},
|
|||
|
showIcon: {
|
|||
|
type: Boolean,
|
|||
|
default: !0
|
|||
|
},
|
|||
|
customClass: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
customStyle: {
|
|||
|
type: Object
|
|||
|
}
|
|||
|
}, lc = {
|
|||
|
onClose: null
|
|||
|
};
|
|||
|
function nc(a, A) {
|
|||
|
const e = p((a == null ? void 0 : a.message) || Ne.message.default), t = p((a == null ? void 0 : a.duration) || Ne.duration.default), o = p((a == null ? void 0 : a.type) || Ne.type.default), n = p((a == null ? void 0 : a.offset) || Ne.offset.default), s = p((a == null ? void 0 : a.showClose) || Ne.showClose.default), r = p(!1);
|
|||
|
let c = -1;
|
|||
|
const M = (I) => {
|
|||
|
c > -1 && (clearTimeout(c), c = -1), r.value = !0, T(I || {}), t.value && (c = setTimeout(() => {
|
|||
|
N();
|
|||
|
}, t.value));
|
|||
|
}, N = () => {
|
|||
|
r.value = !1, c > -1 && (clearTimeout(c), c = -1);
|
|||
|
}, T = (I) => {
|
|||
|
const {
|
|||
|
message: D = e.value,
|
|||
|
type: h = o.value,
|
|||
|
offset: j = n.value,
|
|||
|
duration: m = t.value,
|
|||
|
showClose: w = s.value
|
|||
|
} = I;
|
|||
|
t.value = (a == null ? void 0 : a.duration) === 0 ? a == null ? void 0 : a.duration : m, e.value = D, o.value = h, n.value = j, s.value = w;
|
|||
|
};
|
|||
|
return uA(
|
|||
|
() => a == null ? void 0 : a.isShow,
|
|||
|
(I) => {
|
|||
|
I && M();
|
|||
|
},
|
|||
|
{ immediate: !0 }
|
|||
|
), uA(r, (I) => {
|
|||
|
I || A("onClose");
|
|||
|
}), {
|
|||
|
messageContent: e,
|
|||
|
messageDuration: t,
|
|||
|
messageType: o,
|
|||
|
messageOffset: n,
|
|||
|
isShowCloseIcon: s,
|
|||
|
visible: r,
|
|||
|
show: M,
|
|||
|
close: N
|
|||
|
};
|
|||
|
}
|
|||
|
const ic = "", sc = "", cc = "", rc = "", uc = "", Mc = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, to = /* @__PURE__ */ f({
|
|||
|
...Mc,
|
|||
|
__name: "Message",
|
|||
|
props: Ne,
|
|||
|
emits: lc,
|
|||
|
setup(a, { expose: A, emit: e }) {
|
|||
|
const t = a, o = e, { messageContent: n, messageType: s, messageOffset: r, isShowCloseIcon: c, visible: M, show: N, close: T } = nc(t, o), I = S(() => iA([
|
|||
|
`${Y}-message`,
|
|||
|
`${Y}-message--${s.value}`,
|
|||
|
t.customClass
|
|||
|
])), D = S(() => iA([`${Y}-message_icon`])), h = S(() => iA([`${Y}-message_close`])), j = S(() => `${r.value}px`), m = S(() => ({ top: j.value, ...t.customStyle })), w = {
|
|||
|
info: rc,
|
|||
|
waring: cc,
|
|||
|
success: sc,
|
|||
|
error: ic
|
|||
|
};
|
|||
|
return A({
|
|||
|
show: N,
|
|||
|
close: T
|
|||
|
}), (H, b) => l(M) ? (d(), y("div", {
|
|||
|
key: 0,
|
|||
|
class: k(l(I)),
|
|||
|
style: eA([l(m)])
|
|||
|
}, [
|
|||
|
sA(L("div", {
|
|||
|
class: k(l(D))
|
|||
|
}, [
|
|||
|
C(De, {
|
|||
|
src: w[l(s)]
|
|||
|
}, null, 8, ["src"])
|
|||
|
], 2), [
|
|||
|
[cA, H.showIcon]
|
|||
|
]),
|
|||
|
L("span", null, W(l(n)), 1),
|
|||
|
sA(L("div", {
|
|||
|
class: k(l(h)),
|
|||
|
onClick: b[0] || (b[0] = //@ts-ignore
|
|||
|
(...x) => l(T) && l(T)(...x))
|
|||
|
}, [
|
|||
|
C(De, { src: l(uc) }, null, 8, ["src"])
|
|||
|
], 2), [
|
|||
|
[cA, l(c)]
|
|||
|
])
|
|||
|
], 6)) : z("", !0);
|
|||
|
}
|
|||
|
});
|
|||
|
const dc = {
|
|||
|
customClass: {
|
|||
|
type: String
|
|||
|
}
|
|||
|
}, Ic = {
|
|||
|
options: {
|
|||
|
virtualHost: !0,
|
|||
|
styleIsolation: "shared"
|
|||
|
}
|
|||
|
}, ao = /* @__PURE__ */ f({
|
|||
|
...Ic,
|
|||
|
__name: "Tip",
|
|||
|
props: dc,
|
|||
|
setup(a) {
|
|||
|
const { isFloatWindow: A } = G(BA()), { tip: e, duration: t } = wl(), { isGroupCall: o } = G(rA()), n = p(null), s = a, r = V.isPC, c = S(() => [s.customClass]), M = S(
|
|||
|
() => Ke({
|
|||
|
color: "white",
|
|||
|
background: "none",
|
|||
|
position: "absolute",
|
|||
|
"z-index": 4,
|
|||
|
"align-items": "center",
|
|||
|
left: "50%",
|
|||
|
top: `${r ? "60%" : "70%"}`,
|
|||
|
transform: "translate(-50%, -50%)",
|
|||
|
"font-size": A.value ? "12px" : void 0
|
|||
|
})
|
|||
|
), N = S(
|
|||
|
() => Ke({
|
|||
|
color: "white",
|
|||
|
background: "none",
|
|||
|
position: "static",
|
|||
|
transform: "none",
|
|||
|
"font-size": A.value ? "12px" : void 0
|
|||
|
})
|
|||
|
), T = S(() => o.value ? N.value : M.value);
|
|||
|
return uA(e, () => {
|
|||
|
var I;
|
|||
|
(I = n.value) == null || I.show({
|
|||
|
message: e.value,
|
|||
|
duration: t.value,
|
|||
|
offset: 0
|
|||
|
});
|
|||
|
}), (I, D) => (d(), y("div", null, [
|
|||
|
C(to, {
|
|||
|
showIcon: !1,
|
|||
|
class: k(l(c)),
|
|||
|
ref_key: "message",
|
|||
|
ref: n,
|
|||
|
customStyle: l(T)
|
|||
|
}, null, 8, ["class", "customStyle"])
|
|||
|
]));
|
|||
|
}
|
|||
|
}), Nc = ["%", "vw"], gc = {
|
|||
|
length: {
|
|||
|
type: Number,
|
|||
|
default: 0
|
|||
|
},
|
|||
|
unit: {
|
|||
|
type: String,
|
|||
|
values: Nc,
|
|||
|
default: "%"
|
|||
|
},
|
|||
|
enableFocus: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
},
|
|||
|
layout: {
|
|||
|
type: Array
|
|||
|
},
|
|||
|
focus: {
|
|||
|
type: [String, Number]
|
|||
|
}
|
|||
|
}, Tc = ["change", "toggle"], oo = "GridContextKey", pc = { style: { height: "100%" } }, Dc = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, lo = /* @__PURE__ */ f({
|
|||
|
...Dc,
|
|||
|
__name: "Grid",
|
|||
|
props: gc,
|
|||
|
emits: Tc,
|
|||
|
setup(a, { emit: A }) {
|
|||
|
const e = a, t = p(e.focus), o = p(e.layout), n = p(e.unit), s = A;
|
|||
|
function r(c) {
|
|||
|
s("toggle", c);
|
|||
|
}
|
|||
|
return uA(() => e.focus, () => t.value = e.focus), uA(() => e.layout, () => o.value = e.layout), uA(() => e.unit, () => n.value = e.unit), OA(oo, {
|
|||
|
layout: o,
|
|||
|
enableFocus: e.enableFocus,
|
|||
|
handleFocusChange: r,
|
|||
|
focus: t,
|
|||
|
unit: n
|
|||
|
}), (c, M) => (d(), y("div", pc, [
|
|||
|
q(c.$slots, "default")
|
|||
|
]));
|
|||
|
}
|
|||
|
}), yc = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, kA = /* @__PURE__ */ f({
|
|||
|
...yc,
|
|||
|
__name: "GridItem",
|
|||
|
props: ["index", "height", "customStyle"],
|
|||
|
setup(a) {
|
|||
|
const A = a, {
|
|||
|
layout: e,
|
|||
|
enableFocus: t,
|
|||
|
handleFocusChange: o,
|
|||
|
focus: n,
|
|||
|
unit: s
|
|||
|
} = VA(oo), r = 100 / 12, c = r, M = p({}), N = iA([
|
|||
|
`${Y}-grid-item`,
|
|||
|
{
|
|||
|
pc: re,
|
|||
|
mobile: !re,
|
|||
|
h5: wa
|
|||
|
}
|
|||
|
]), T = () => {
|
|||
|
const D = String(A.index) === String(n.value) ? null : A.index;
|
|||
|
t && o(D);
|
|||
|
}, I = S(() => !!Xt(e.value, { key: "i", value: A.index }));
|
|||
|
return ue(() => {
|
|||
|
const D = Xt(e.value, { key: "i", value: A.index });
|
|||
|
if (!D)
|
|||
|
return;
|
|||
|
const { x: h, y: j, w: m, h: w, customStyle: H, customProps: b } = D;
|
|||
|
M.value = {
|
|||
|
width: m * r + s.value,
|
|||
|
height: A.height || w * c + s.value,
|
|||
|
left: h * r + s.value,
|
|||
|
top: j * c + s.value,
|
|||
|
position: "absolute",
|
|||
|
visibility: (b == null ? void 0 : b.show) === !1 ? "hidden" : "",
|
|||
|
...A.customStyle,
|
|||
|
...H
|
|||
|
};
|
|||
|
}), DA(() => {
|
|||
|
String(A.index) === String(n.value) && t && o(null);
|
|||
|
}), (D, h) => l(I) ? (d(), y("div", {
|
|||
|
key: 0,
|
|||
|
class: k(l(N)),
|
|||
|
style: eA([l(M)]),
|
|||
|
onClick: T
|
|||
|
}, [
|
|||
|
q(D.$slots, "default")
|
|||
|
], 6)) : z("", !0);
|
|||
|
}
|
|||
|
});
|
|||
|
function Cc() {
|
|||
|
const a = p([]), A = p([]), { callStatus: e, isGroupCall: t, callType: o, callRole: n } = G(rA()), { status: s } = Ve() || {}, r = Wl();
|
|||
|
return uA(
|
|||
|
[e, t, o, n, s, r],
|
|||
|
() => {
|
|||
|
var w, H, b;
|
|||
|
let c = r.value;
|
|||
|
const M = V.isPC ? "pc" : "mobile", N = t.value ? "groupCall" : "singleCall", T = o.value === _.AUDIO ? "audio" : "video";
|
|||
|
let I = e.value === P.CALLING ? n.value === IA.CALLER ? "calling" : "accept" : e.value;
|
|||
|
t && (s == null ? void 0 : s.value) === "close" && (I = "close_" + I);
|
|||
|
const D = ((b = (H = (w = c == null ? void 0 : c[M]) == null ? void 0 : w[N]) == null ? void 0 : H[T]) == null ? void 0 : b[I]) || [];
|
|||
|
A.value = D;
|
|||
|
const h = [];
|
|||
|
let j = 0;
|
|||
|
for (let x = 0; x < D.length; x++) {
|
|||
|
const B = x === 0 ? D[x].filter((J) => {
|
|||
|
var MA;
|
|||
|
return ((MA = J == null ? void 0 : J.props) == null ? void 0 : MA.show) !== !1;
|
|||
|
}) : D[x];
|
|||
|
D[x] = B;
|
|||
|
const F = 12 / B.length, tA = 3;
|
|||
|
for (let J = 0; J < B.length; J++)
|
|||
|
h[j++] = {
|
|||
|
i: B[J].name,
|
|||
|
x: J * F,
|
|||
|
y: x * F,
|
|||
|
w: F,
|
|||
|
h: tA,
|
|||
|
// @ts-ignore
|
|||
|
customStyle: B[J].customStyle,
|
|||
|
customProps: B[J].props
|
|||
|
};
|
|||
|
}
|
|||
|
j = 0;
|
|||
|
let m = [];
|
|||
|
for (let x = 0; x < D.flat().length; x++)
|
|||
|
m[x] = h[j++];
|
|||
|
m = m.filter((x) => x.i), a.value = m;
|
|||
|
},
|
|||
|
{
|
|||
|
immediate: !0
|
|||
|
}
|
|||
|
), { layout: a, config: A };
|
|||
|
}
|
|||
|
function Sc(...a) {
|
|||
|
let A = window == null ? void 0 : window.document, e = "", t = () => {
|
|||
|
}, o = {};
|
|||
|
if (typeof a[0] == "string" ? [e, t, o] = a : [A, e, t, o] = a, !!A)
|
|||
|
return A == null || A.addEventListener(e, t, o), () => {
|
|||
|
A == null || A.removeEventListener(e, t, o);
|
|||
|
};
|
|||
|
}
|
|||
|
function jc(a, A) {
|
|||
|
let e = () => {
|
|||
|
};
|
|||
|
CA(() => {
|
|||
|
e = Sc("click", (o) => {
|
|||
|
const n = a.map((c) => l(c)), s = o.composedPath(), r = [];
|
|||
|
for (let c = 0; c < n.length; c++)
|
|||
|
r[c] = s.includes(n[c]);
|
|||
|
r.every((c) => !c) && A();
|
|||
|
}, { passive: !0 });
|
|||
|
}), DA(() => {
|
|||
|
e == null || e();
|
|||
|
});
|
|||
|
}
|
|||
|
const hc = (a, A, e, t, o) => {
|
|||
|
const n = e.isShowArrow ? e.arrowSize : 0, s = `${a.width / 2 - A.width / 2}px`, r = `${a.height / 2 - A.height / 2}px`, c = `${n}px solid ${e.color}`, M = { ...t }, N = { ...o };
|
|||
|
switch (e.placement) {
|
|||
|
case "top":
|
|||
|
M.left = s, M.top = `-${A.height + n + e.arrowDistance}px`, N.borderTop = c, N.left = `${a.width / 2 - n / 2}px`, N.top = `-${n + e.arrowDistance}px`;
|
|||
|
break;
|
|||
|
case "bottom":
|
|||
|
M.left = s, M.top = `${a.height + n + e.arrowDistance}px`, N.borderBottom = c, N.left = `${a.width / 2 - n / 2}px`, N.top = `${a.height + e.arrowDistance - n}px`;
|
|||
|
break;
|
|||
|
case "left":
|
|||
|
M.left = `-${A.width + n + e.arrowDistance}px`, M.top = r, N.borderLeft = c, N.left = `-${n * 2 - e.arrowDistance}px`, N.top = `${a.height / 2 - n / 2}px`;
|
|||
|
break;
|
|||
|
case "right":
|
|||
|
M.left = `${a.width + n + e.arrowDistance}px`, M.top = r, N.borderRight = c, N.left = `${a.width + n * 2 - e.arrowDistance}px`, N.top = `${a.height / 2 - n / 2}px`;
|
|||
|
break;
|
|||
|
}
|
|||
|
return {
|
|||
|
finalContentStyle: M,
|
|||
|
finalArrowStyle: N
|
|||
|
};
|
|||
|
}, Lc = ["click", "hover"], Ec = ["top", "bottom", "left", "right"], no = {
|
|||
|
trigger: {
|
|||
|
type: String,
|
|||
|
values: Lc,
|
|||
|
default: "click"
|
|||
|
},
|
|||
|
placement: {
|
|||
|
type: String,
|
|||
|
values: Ec,
|
|||
|
default: "top"
|
|||
|
},
|
|||
|
color: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
isShowArrow: {
|
|||
|
type: Boolean,
|
|||
|
default: !0
|
|||
|
},
|
|||
|
arrowSize: {
|
|||
|
type: Number,
|
|||
|
default: 5
|
|||
|
},
|
|||
|
arrowDistance: {
|
|||
|
type: Number,
|
|||
|
default: 5
|
|||
|
},
|
|||
|
show: {
|
|||
|
type: Boolean
|
|||
|
},
|
|||
|
autoClose: {
|
|||
|
type: Number,
|
|||
|
default: 300
|
|||
|
}
|
|||
|
}, mc = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, zc = /* @__PURE__ */ f({
|
|||
|
...mc,
|
|||
|
__name: "PopoverWeb",
|
|||
|
props: no,
|
|||
|
emits: ["hover"],
|
|||
|
setup(a, { emit: A }) {
|
|||
|
const e = a, t = `${Y}-popover`, o = `${Y}-popover_content`, n = `${Y}-popover_arrow`, s = `${Y}-popover_trigger`, r = p(), c = p(), M = p(), N = p(!1), T = p(null), I = S(() => N.value && e.isShowArrow && e.show), D = Ke({ left: "0px", top: "0px", backgroundColor: e.color }), h = p(D), j = `${e.arrowSize}px solid transparent`, m = {
|
|||
|
borderLeft: j,
|
|||
|
borderRight: j,
|
|||
|
borderTop: j,
|
|||
|
borderBottom: j,
|
|||
|
top: "0px",
|
|||
|
left: "0px"
|
|||
|
}, w = p(m), H = A, b = () => {
|
|||
|
mo(() => {
|
|||
|
var ee, te, de, ae;
|
|||
|
if (!N.value || !e.show)
|
|||
|
return;
|
|||
|
const J = (te = (ee = c.value).getBoundingClientRect) == null ? void 0 : te.call(ee), MA = (ae = (de = M.value).getBoundingClientRect) == null ? void 0 : ae.call(de), { finalContentStyle: WA, finalArrowStyle: Me } = hc(J, MA, e, D, m);
|
|||
|
h.value = { ...D, ...WA }, w.value = { ...m, ...Me };
|
|||
|
});
|
|||
|
}, x = () => {
|
|||
|
clearTimeout(T.value);
|
|||
|
}, B = () => {
|
|||
|
e.trigger === "click" && (N.value = !N.value, b());
|
|||
|
}, F = () => {
|
|||
|
e.trigger === "hover" && (H("hover"), x(), N.value = !0, b());
|
|||
|
}, tA = () => {
|
|||
|
e.trigger === "hover" && (T.value = setTimeout(() => {
|
|||
|
N.value = !1, b();
|
|||
|
}, 1e3));
|
|||
|
};
|
|||
|
return jc([r], () => {
|
|||
|
N.value = !1;
|
|||
|
}), (J, MA) => (d(), y("div", {
|
|||
|
class: k(t),
|
|||
|
ref_key: "popoverRef",
|
|||
|
ref: r
|
|||
|
}, [
|
|||
|
l(N) && J.show ? (d(), y("div", {
|
|||
|
key: 0,
|
|||
|
ref_key: "contentRef",
|
|||
|
ref: M,
|
|||
|
onMouseenter: x,
|
|||
|
onMouseleave: tA,
|
|||
|
class: k(o),
|
|||
|
style: eA([l(h)])
|
|||
|
}, [
|
|||
|
q(J.$slots, "content")
|
|||
|
], 36)) : z("", !0),
|
|||
|
l(I) ? (d(), y("div", {
|
|||
|
key: 1,
|
|||
|
style: eA([l(w)]),
|
|||
|
class: k(n)
|
|||
|
}, null, 4)) : z("", !0),
|
|||
|
L("div", {
|
|||
|
ref_key: "triggerRef",
|
|||
|
ref: c,
|
|||
|
class: k(s),
|
|||
|
onClick: B,
|
|||
|
onMouseenter: F,
|
|||
|
onMouseleave: tA
|
|||
|
}, [
|
|||
|
q(J.$slots, "trigger")
|
|||
|
], 544)
|
|||
|
], 512));
|
|||
|
}
|
|||
|
});
|
|||
|
const Uc = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
};
|
|||
|
function fc(a, A, e, t, o, n) {
|
|||
|
return null;
|
|||
|
}
|
|||
|
const vc = /* @__PURE__ */ Z(Uc, [["render", fc]]), wc = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, ft = /* @__PURE__ */ f({
|
|||
|
...wc,
|
|||
|
__name: "Popover",
|
|||
|
props: no,
|
|||
|
emits: ["hover"],
|
|||
|
setup(a, { emit: A }) {
|
|||
|
const e = A, t = () => {
|
|||
|
e("hover");
|
|||
|
};
|
|||
|
return (o, n) => (d(), y(RA, null, [
|
|||
|
l(se) ? z("", !0) : (d(), U(zc, bt({
|
|||
|
key: 0,
|
|||
|
onHover: t
|
|||
|
}, o.$props), {
|
|||
|
trigger: E(() => [
|
|||
|
q(o.$slots, "trigger")
|
|||
|
]),
|
|||
|
content: E(() => [
|
|||
|
q(o.$slots, "content")
|
|||
|
]),
|
|||
|
_: 3
|
|||
|
}, 16)),
|
|||
|
l(se) ? (d(), U(vc, zo(bt({ key: 1 }, o.$props)), {
|
|||
|
trigger: E(() => [
|
|||
|
q(o.$slots, "trigger")
|
|||
|
]),
|
|||
|
content: E(() => [
|
|||
|
q(o.$slots, "content")
|
|||
|
]),
|
|||
|
_: 3
|
|||
|
}, 16)) : z("", !0)
|
|||
|
], 64));
|
|||
|
}
|
|||
|
}), Oc = {
|
|||
|
deviceType: {
|
|||
|
type: String
|
|||
|
},
|
|||
|
isShowControlBtn: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
}
|
|||
|
}, Vc = { class: "device-selector-container" }, bc = { class: "scroll-container" }, xc = { class: "scroll-content" }, kc = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, Rc = /* @__PURE__ */ f({
|
|||
|
...kc,
|
|||
|
__name: "DeviceSelect",
|
|||
|
props: Oc,
|
|||
|
setup(a) {
|
|||
|
const A = a, [{ deviceList: e, currentDeviceId: t }, { updateCurrentDeviceId: o }] = ot(A.deviceType), { localUserInfoExcludeVolume: n } = G(vA()), { isMuteSpeaker: s } = G(rA()), r = nt(), c = async (I) => {
|
|||
|
try {
|
|||
|
T(), await Q.switchDevice({
|
|||
|
deviceType: A.deviceType,
|
|||
|
deviceId: I
|
|||
|
}), o(I);
|
|||
|
} catch (D) {
|
|||
|
console.debug(D);
|
|||
|
}
|
|||
|
}, M = async () => {
|
|||
|
var I, D;
|
|||
|
T(), A.deviceType === hA.CAMERA && ((I = n.value) != null && I.isVideoAvailable ? await Q.closeCamera() : await Q.openCamera("localVideo")), A.deviceType === hA.MICROPHONE && ((D = n.value) != null && D.isAudioAvailable ? await Q.closeMicrophone() : await Q.openMicrophone()), A.deviceType === hA.SPEAKER && (s.value ? await Q.unMuteSpeaker() : await Q.muteSpeaker());
|
|||
|
}, N = S(() => {
|
|||
|
var I;
|
|||
|
if (A.deviceType === hA.CAMERA)
|
|||
|
return n != null && n.value.isVideoAvailable ? v("close camera") : v("open camera");
|
|||
|
if (A.deviceType === hA.MICROPHONE)
|
|||
|
return (I = n == null ? void 0 : n.value) != null && I.isAudioAvailable ? v("close microphone") : v("open microphone");
|
|||
|
if (A.deviceType === hA.SPEAKER)
|
|||
|
return s.value ? v("open speaker") : v("close speaker");
|
|||
|
}), T = () => {
|
|||
|
r.value = "close";
|
|||
|
};
|
|||
|
return (I, D) => (d(), y("div", Vc, [
|
|||
|
L("div", bc, [
|
|||
|
L("div", xc, [
|
|||
|
(d(!0), y(RA, null, ce(l(e), (h) => (d(), y("div", {
|
|||
|
key: h.deviceId
|
|||
|
}, [
|
|||
|
C(gA, {
|
|||
|
width: "100%",
|
|||
|
color: "#ffff",
|
|||
|
truncated: !0,
|
|||
|
size: "14px",
|
|||
|
class: k(["device-item", { select: l(t) === h.deviceId }]),
|
|||
|
onClick: () => c(h.deviceId)
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
NA(W(h.label), 1)
|
|||
|
]),
|
|||
|
_: 2
|
|||
|
}, 1032, ["class", "onClick"])
|
|||
|
]))), 128))
|
|||
|
])
|
|||
|
]),
|
|||
|
D[0] || (D[0] = L("div", { class: "control-item" }, null, -1)),
|
|||
|
I.isShowControlBtn ? (d(), U(gA, {
|
|||
|
key: 0,
|
|||
|
width: "100%",
|
|||
|
color: "#ffff",
|
|||
|
truncated: !0,
|
|||
|
size: "14px",
|
|||
|
class: "device-item",
|
|||
|
onClick: M
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
NA(W(l(N)), 1)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
})) : z("", !0)
|
|||
|
]));
|
|||
|
}
|
|||
|
});
|
|||
|
const vt = /* @__PURE__ */ Z(Rc, [["__scopeId", "data-v-d176bcfa"]]), Bc = { class: "btn-content" }, Pc = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, Wc = /* @__PURE__ */ f({
|
|||
|
...Pc,
|
|||
|
__name: "Camera",
|
|||
|
props: ZA,
|
|||
|
setup(a) {
|
|||
|
const A = a, e = p(!0), t = V.isPC, { localUserInfoExcludeVolume: o } = G(vA()), n = p(o == null ? void 0 : o.value.isVideoAvailable), s = S(() => o == null ? void 0 : o.value.isVideoAvailable), r = nt(), [{ deviceList: c }] = ot(hA.CAMERA), M = S(() => {
|
|||
|
var j;
|
|||
|
return ((j = c.value) == null ? void 0 : j.length) > 0 && r.value === "camera";
|
|||
|
}), N = S(() => e.value ? s.value ? "basicConfig" : "closedConfig" : "loadingConfig"), T = S(() => o != null && o.value.isVideoAvailable ? v("camera enabled") : v("camera disabled")), I = zA("camera", N), D = async () => {
|
|||
|
e.value = !1, n.value = !s.value, s.value ? await Q.closeCamera() : await Q.openCamera("localVideo"), e.value = !0;
|
|||
|
}, h = () => {
|
|||
|
r.value = "camera";
|
|||
|
};
|
|||
|
return (j, m) => (d(), y("div", Bc, [
|
|||
|
l(t) ? (d(), U(ft, {
|
|||
|
key: 0,
|
|||
|
color: "rgba(107, 117, 138, 0.5)",
|
|||
|
show: l(M),
|
|||
|
onHover: h,
|
|||
|
trigger: "hover"
|
|||
|
}, {
|
|||
|
content: E(() => [
|
|||
|
C(vt, {
|
|||
|
isShowControlBtn: !0,
|
|||
|
deviceType: l(hA).CAMERA
|
|||
|
}, null, 8, ["deviceType"])
|
|||
|
]),
|
|||
|
trigger: E(() => [
|
|||
|
C(mA, {
|
|||
|
loading: !l(e),
|
|||
|
iconSrc: l(I).iconSrc,
|
|||
|
color: l(I).color,
|
|||
|
iconSize: l(I).iconSize,
|
|||
|
width: A.width || l(I).width,
|
|||
|
height: A.height || l(I).height,
|
|||
|
loadingWidth: l(I).loadingWidth,
|
|||
|
loadingHeight: l(I).loadingHeight,
|
|||
|
shape: l(I).shape,
|
|||
|
onClick: D
|
|||
|
}, null, 8, ["loading", "iconSrc", "color", "iconSize", "width", "height", "loadingWidth", "loadingHeight", "shape"])
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["show"])) : z("", !0),
|
|||
|
l(t) ? z("", !0) : (d(), U(mA, {
|
|||
|
key: 1,
|
|||
|
loading: !l(e),
|
|||
|
iconSrc: l(I).iconSrc,
|
|||
|
color: l(I).color,
|
|||
|
iconSize: A.iconSize || l(I).iconSize,
|
|||
|
width: A.width || l(I).width,
|
|||
|
height: A.height || l(I).height,
|
|||
|
loadingWidth: l(I).loadingWidth,
|
|||
|
loadingHeight: l(I).loadingHeight,
|
|||
|
shape: "circle",
|
|||
|
onClick: D
|
|||
|
}, null, 8, ["loading", "iconSrc", "color", "iconSize", "width", "height", "loadingWidth", "loadingHeight"])),
|
|||
|
l(I).showText ? (d(), U(gA, {
|
|||
|
key: 2,
|
|||
|
textStyle: l(I).textStyle,
|
|||
|
color: l(I).textColor,
|
|||
|
size: l(I).textSize
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
NA(W(l(T)), 1)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["textStyle", "color", "size"])) : z("", !0)
|
|||
|
]));
|
|||
|
}
|
|||
|
});
|
|||
|
const Gc = /* @__PURE__ */ Z(Wc, [["__scopeId", "data-v-01140bf2"]]), Qc = { class: "btn-content" }, Zc = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, Fc = /* @__PURE__ */ f({
|
|||
|
...Zc,
|
|||
|
__name: "Hangup",
|
|||
|
props: ZA,
|
|||
|
setup(a) {
|
|||
|
const A = a, e = Vl(), t = S(() => e.value ? "basicConfig" : "loadingConfig"), o = zA("hangup", t), n = async () => {
|
|||
|
await Q.hangup();
|
|||
|
};
|
|||
|
return (s, r) => (d(), y("div", Qc, [
|
|||
|
C(mA, {
|
|||
|
loading: !l(e),
|
|||
|
loadingWidth: l(o).loadingWidth,
|
|||
|
loadingHeight: l(o).loadingHeight,
|
|||
|
iconSrc: l(o).iconSrc,
|
|||
|
color: l(o).color,
|
|||
|
iconSize: A.iconSize || l(o).iconSize,
|
|||
|
width: A.width || l(o).width,
|
|||
|
height: A.height || l(o).height,
|
|||
|
shape: l(o).shape,
|
|||
|
onClick: n
|
|||
|
}, null, 8, ["loading", "loadingWidth", "loadingHeight", "iconSrc", "color", "iconSize", "width", "height", "shape"]),
|
|||
|
l(o).showText ? (d(), U(gA, {
|
|||
|
key: 0,
|
|||
|
textStyle: l(o).textStyle,
|
|||
|
color: l(o).textColor,
|
|||
|
size: l(o).textSize
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
NA(W(l(v)("hangup")), 1)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["textStyle", "color", "size"])) : z("", !0)
|
|||
|
]));
|
|||
|
}
|
|||
|
});
|
|||
|
const Yc = /* @__PURE__ */ Z(Fc, [["__scopeId", "data-v-3585d156"]]), Xc = { class: "btn-content" }, qc = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, Jc = /* @__PURE__ */ f({
|
|||
|
...qc,
|
|||
|
__name: "Accept",
|
|||
|
props: ZA,
|
|||
|
setup(a) {
|
|||
|
const A = p(!0), e = a, t = S(() => A.value ? "basicConfig" : "loadingConfig"), o = zA("accept", t), n = async () => {
|
|||
|
A.value = !1, await Q.accept(), A.value = !0;
|
|||
|
};
|
|||
|
return (s, r) => (d(), y("div", Xc, [
|
|||
|
C(mA, {
|
|||
|
iconSrc: l(o).iconSrc,
|
|||
|
color: l(o).color,
|
|||
|
iconSize: e.iconSize || l(o).iconSize,
|
|||
|
width: e.width || l(o).width,
|
|||
|
height: e.height || l(o).height,
|
|||
|
shape: l(o).shape,
|
|||
|
loading: !l(A),
|
|||
|
loadingWidth: l(o).loadingWidth,
|
|||
|
loadingHeight: l(o).loadingHeight,
|
|||
|
onClick: n
|
|||
|
}, null, 8, ["iconSrc", "color", "iconSize", "width", "height", "shape", "loading", "loadingWidth", "loadingHeight"]),
|
|||
|
l(o).showText ? (d(), U(gA, {
|
|||
|
key: 0,
|
|||
|
textStyle: l(o).textStyle,
|
|||
|
color: l(o).textColor,
|
|||
|
size: l(o).textSize
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
NA(W(l(v)("accept")), 1)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["textStyle", "color", "size"])) : z("", !0)
|
|||
|
]));
|
|||
|
}
|
|||
|
});
|
|||
|
const Hc = /* @__PURE__ */ Z(Jc, [["__scopeId", "data-v-c3da87f5"]]), Kc = { class: "btn-content" }, _c = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, $c = /* @__PURE__ */ f({
|
|||
|
..._c,
|
|||
|
__name: "Microphone",
|
|||
|
props: ZA,
|
|||
|
setup(a) {
|
|||
|
const A = V.isPC, e = p(!0), { localUserInfoExcludeVolume: t } = G(vA()), o = nt(), [{ deviceList: n }] = ot(hA.MICROPHONE), s = S(() => {
|
|||
|
var I;
|
|||
|
return ((I = n.value) == null ? void 0 : I.length) > 0 && o.value === "microphone";
|
|||
|
}), r = S(() => e.value ? t != null && t.value.isAudioAvailable ? "basicConfig" : "closedConfig" : "loadingConfig"), c = zA("microphone", r), M = S(() => t != null && t.value.isAudioAvailable ? v("microphone enabled") : v("microphone disabled")), N = async () => {
|
|||
|
t != null && t.value.isAudioAvailable ? await Q.closeMicrophone() : await Q.openMicrophone();
|
|||
|
}, T = () => {
|
|||
|
o.value = "microphone";
|
|||
|
};
|
|||
|
return (I, D) => (d(), y("div", Kc, [
|
|||
|
l(A) ? (d(), U(ft, {
|
|||
|
key: 0,
|
|||
|
color: "rgba(107, 117, 138, 0.5)",
|
|||
|
show: l(s),
|
|||
|
onHover: T,
|
|||
|
trigger: "hover"
|
|||
|
}, {
|
|||
|
content: E(() => [
|
|||
|
C(vt, {
|
|||
|
isShowControlBtn: !0,
|
|||
|
deviceType: l(hA).MICROPHONE
|
|||
|
}, null, 8, ["deviceType"])
|
|||
|
]),
|
|||
|
trigger: E(() => [
|
|||
|
C(mA, {
|
|||
|
loading: !l(e),
|
|||
|
iconSrc: l(c).iconSrc,
|
|||
|
color: l(c).color,
|
|||
|
iconSize: l(c).iconSize,
|
|||
|
width: l(c).width,
|
|||
|
height: l(c).height,
|
|||
|
loadingWidth: l(c).loadingWidth,
|
|||
|
loadingHeight: l(c).loadingHeight,
|
|||
|
shape: l(c).shape,
|
|||
|
onClick: N
|
|||
|
}, null, 8, ["loading", "iconSrc", "color", "iconSize", "width", "height", "loadingWidth", "loadingHeight", "shape"])
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["show"])) : z("", !0),
|
|||
|
l(A) ? z("", !0) : (d(), U(mA, {
|
|||
|
key: 1,
|
|||
|
loading: !l(e),
|
|||
|
iconSrc: l(c).iconSrc,
|
|||
|
color: l(c).color,
|
|||
|
iconSize: l(c).iconSize,
|
|||
|
width: l(c).width,
|
|||
|
height: l(c).height,
|
|||
|
loadingWidth: l(c).loadingWidth,
|
|||
|
loadingHeight: l(c).loadingHeight,
|
|||
|
shape: l(c).shape,
|
|||
|
onClick: N
|
|||
|
}, null, 8, ["loading", "iconSrc", "color", "iconSize", "width", "height", "loadingWidth", "loadingHeight", "shape"])),
|
|||
|
l(c).showText ? (d(), U(gA, {
|
|||
|
key: 2,
|
|||
|
textStyle: l(c).textStyle,
|
|||
|
color: l(c).textColor,
|
|||
|
size: l(c).textSize
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
NA(W(l(M)), 1)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["textStyle", "color", "size"])) : z("", !0)
|
|||
|
]));
|
|||
|
}
|
|||
|
});
|
|||
|
const Ar = /* @__PURE__ */ Z($c, [["__scopeId", "data-v-7902763b"]]), er = { class: "btn-content" }, tr = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, ar = /* @__PURE__ */ f({
|
|||
|
...tr,
|
|||
|
__name: "Reject",
|
|||
|
props: ZA,
|
|||
|
setup(a) {
|
|||
|
const A = a, e = zA("reject", p("basicConfig")), t = async () => {
|
|||
|
await Q.reject();
|
|||
|
};
|
|||
|
return (o, n) => (d(), y("div", er, [
|
|||
|
C(mA, {
|
|||
|
iconSrc: l(e).iconSrc,
|
|||
|
color: l(e).color,
|
|||
|
iconSize: l(e).iconSize,
|
|||
|
width: A.width || l(e).width,
|
|||
|
height: A.height || l(e).height,
|
|||
|
shape: l(e).shape,
|
|||
|
onClick: t
|
|||
|
}, null, 8, ["iconSrc", "color", "iconSize", "width", "height", "shape"]),
|
|||
|
l(e).showText ? (d(), U(gA, {
|
|||
|
key: 0,
|
|||
|
textStyle: l(e).textStyle,
|
|||
|
color: l(e).textColor,
|
|||
|
size: l(e).textSize
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
NA(W(l(v)("reject")), 1)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["textStyle", "color", "size"])) : z("", !0)
|
|||
|
]));
|
|||
|
}
|
|||
|
});
|
|||
|
const or = /* @__PURE__ */ Z(ar, [["__scopeId", "data-v-10a39409"]]), lr = { class: "btn-content" }, nr = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, ir = /* @__PURE__ */ f({
|
|||
|
...nr,
|
|||
|
__name: "Speaker",
|
|||
|
props: ZA,
|
|||
|
setup(a) {
|
|||
|
const A = V.isWeChat, e = V.isPC, t = a, { isEarPhone: o, isMuteSpeaker: n } = G(rA()), s = nt(), r = S(() => o.value ? "closedConfig" : "basicConfig"), c = S(() => n.value ? "closedConfig" : "basicConfig"), [{ deviceList: M, currentDeviceId: N }] = ot(hA.SPEAKER), T = S(() => {
|
|||
|
var m;
|
|||
|
return ((m = M.value) == null ? void 0 : m.length) > 0 && s.value === "speaker" && e;
|
|||
|
}), I = A ? zA("speaker", r) : zA("speaker", c);
|
|||
|
S(() => o.value ? v("speaker disabled") : v("speaker enabled"));
|
|||
|
const D = async () => {
|
|||
|
n.value ? await Q.unMuteSpeaker() : await Q.muteSpeaker();
|
|||
|
}, h = () => {
|
|||
|
if (e) {
|
|||
|
const m = M.value.find((w) => w.deviceId === N.value);
|
|||
|
return m ? m.label : v("speaker enabled");
|
|||
|
} else
|
|||
|
return n.value ? v("speaker disabled") : v("speaker enabled");
|
|||
|
}, j = () => {
|
|||
|
s.value = "speaker";
|
|||
|
};
|
|||
|
return (m, w) => (d(), y("div", lr, [
|
|||
|
C(ft, {
|
|||
|
color: "rgba(107, 117, 138, 0.5)",
|
|||
|
show: l(T),
|
|||
|
onHover: j,
|
|||
|
trigger: "hover"
|
|||
|
}, {
|
|||
|
content: E(() => [
|
|||
|
C(vt, {
|
|||
|
isShowControlBtn: !0,
|
|||
|
deviceType: l(hA).SPEAKER
|
|||
|
}, null, 8, ["deviceType"])
|
|||
|
]),
|
|||
|
trigger: E(() => [
|
|||
|
C(mA, {
|
|||
|
iconSrc: l(I).iconSrc,
|
|||
|
color: l(I).color,
|
|||
|
iconSize: t.iconSize || l(I).iconSize,
|
|||
|
width: t.width || l(I).width,
|
|||
|
height: t.height || l(I).height,
|
|||
|
shape: l(I).shape,
|
|||
|
onClick: D
|
|||
|
}, null, 8, ["iconSrc", "color", "iconSize", "width", "height", "shape"])
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["show"]),
|
|||
|
l(I).showText ? (d(), U(gA, {
|
|||
|
key: 0,
|
|||
|
width: "60px",
|
|||
|
truncated: !0,
|
|||
|
textStyle: l(I).textStyle,
|
|||
|
color: l(I).textColor,
|
|||
|
size: l(I).textSize,
|
|||
|
lineClamp: 2
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
NA(W(h()), 1)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["textStyle", "color", "size"])) : z("", !0)
|
|||
|
]));
|
|||
|
}
|
|||
|
});
|
|||
|
const sr = /* @__PURE__ */ Z(ir, [["__scopeId", "data-v-c825445a"]]), cr = { class: "btn-content" }, rr = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, ur = /* @__PURE__ */ f({
|
|||
|
...rr,
|
|||
|
__name: "SwitchCamera",
|
|||
|
setup(a) {
|
|||
|
const { localUserInfoExcludeVolume: A } = G(vA()), e = S(() => A == null ? void 0 : A.value.isVideoAvailable), t = S(() => e.value ? "basicConfig" : "disableConfig"), o = zA("switchCamera", t), n = async () => {
|
|||
|
e.value && await Q.switchCamera();
|
|||
|
};
|
|||
|
return (s, r) => (d(), y("div", cr, [
|
|||
|
C(mA, {
|
|||
|
iconSrc: l(o).iconSrc,
|
|||
|
iconSize: l(o).iconSize,
|
|||
|
color: l(o).color,
|
|||
|
width: l(o).width,
|
|||
|
height: l(o).height,
|
|||
|
buttonStyle: l(o).buttonStyle,
|
|||
|
shape: "circle",
|
|||
|
onClick: n
|
|||
|
}, null, 8, ["iconSrc", "iconSize", "color", "width", "height", "buttonStyle"]),
|
|||
|
l(o).showText ? (d(), U(gA, {
|
|||
|
key: 0,
|
|||
|
textStyle: l(o).textStyle,
|
|||
|
color: l(o).textColor,
|
|||
|
size: l(o).textSize
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
NA(W(l(v)("switch camera")), 1)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["textStyle", "color", "size"])) : z("", !0)
|
|||
|
]));
|
|||
|
}
|
|||
|
});
|
|||
|
const Mr = /* @__PURE__ */ Z(ur, [["__scopeId", "data-v-6eb55b3d"]]), dr = { class: "btn-content" }, Ir = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, Nr = /* @__PURE__ */ f({
|
|||
|
...Ir,
|
|||
|
__name: "VirtualBackground",
|
|||
|
props: ZA,
|
|||
|
setup(a) {
|
|||
|
const A = a, e = p(!0), { localUserInfoExcludeVolume: t } = G(vA()), o = S(() => t == null ? void 0 : t.value.isVideoAvailable), { enableVirtualBackground: n } = G(rA()), s = S(() => e.value ? n.value ? "closedConfig" : o.value ? "basicConfig" : "disableConfig" : "loadingConfig"), r = zA("virtualBackground", s), c = async () => {
|
|||
|
o.value && (e.value = !1, await Q.setBlurBackground(!n.value), e.value = !0);
|
|||
|
};
|
|||
|
return (M, N) => (d(), y("div", dr, [
|
|||
|
C(mA, {
|
|||
|
loading: !l(e),
|
|||
|
iconSrc: l(r).iconSrc,
|
|||
|
color: l(r).color,
|
|||
|
iconSize: A.iconSize || l(r).iconSize,
|
|||
|
width: A.width || l(r).width,
|
|||
|
height: A.height || l(r).height,
|
|||
|
shape: l(r).shape,
|
|||
|
loadingWidth: l(r).loadingWidth,
|
|||
|
loadingHeight: l(r).loadingHeight,
|
|||
|
buttonStyle: l(r).buttonStyle,
|
|||
|
onClick: c
|
|||
|
}, null, 8, ["loading", "iconSrc", "color", "iconSize", "width", "height", "shape", "loadingWidth", "loadingHeight", "buttonStyle"]),
|
|||
|
l(r).showText ? (d(), U(gA, {
|
|||
|
key: 0,
|
|||
|
width: "70px",
|
|||
|
lineClamp: 2,
|
|||
|
textStyle: l(r).textStyle,
|
|||
|
color: l(r).textColor,
|
|||
|
size: l(r).textSize
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
NA(W(l(v)("virtual-background")), 1)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["textStyle", "color", "size"])) : z("", !0)
|
|||
|
]));
|
|||
|
}
|
|||
|
});
|
|||
|
const gr = /* @__PURE__ */ Z(Nr, [["__scopeId", "data-v-57c7f51f"]]), Tr = { class: "btn-content" }, pr = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, Dr = /* @__PURE__ */ f({
|
|||
|
...pr,
|
|||
|
__name: "ToggleButtonPanel",
|
|||
|
props: ZA,
|
|||
|
setup(a) {
|
|||
|
const { status: A } = Ve(), e = a, t = zA("toggleButtonPanel", p("basicConfig")), o = async () => {
|
|||
|
A.value = A.value === "close" ? "open" : "close";
|
|||
|
};
|
|||
|
return (n, s) => (d(), y("div", Tr, [
|
|||
|
C(mA, {
|
|||
|
iconSrc: l(t).iconSrc,
|
|||
|
color: l(t).color,
|
|||
|
iconSize: e.iconSize || l(t).iconSize,
|
|||
|
width: e.width || l(t).width,
|
|||
|
height: e.height || l(t).height,
|
|||
|
shape: l(t).shape,
|
|||
|
onClick: o
|
|||
|
}, null, 8, ["iconSrc", "color", "iconSize", "width", "height", "shape"])
|
|||
|
]));
|
|||
|
}
|
|||
|
});
|
|||
|
const yr = /* @__PURE__ */ Z(Dr, [["__scopeId", "data-v-f7839a20"]]), Cr = { class: "button-group" }, Sr = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, jr = /* @__PURE__ */ f({
|
|||
|
...Sr,
|
|||
|
__name: "ButtonPanel",
|
|||
|
setup(a) {
|
|||
|
const A = p(null), e = p({}), { isGroupCall: t } = G(rA()), { status: o } = Ve() || {}, n = p(!1), s = p(!1), r = p(""), c = za();
|
|||
|
ue(() => {
|
|||
|
n.value || (t.value && !V.isPC && c.value !== null ? n.value = !0 : n.value = !1);
|
|||
|
});
|
|||
|
const M = S(() => iA([
|
|||
|
"button-panel-container",
|
|||
|
{
|
|||
|
pc: V.isPC,
|
|||
|
mobile: !V.isPC,
|
|||
|
h5: V.isH5,
|
|||
|
groupCall: t.value,
|
|||
|
singleCall: !t.value,
|
|||
|
close: (o == null ? void 0 : o.value) === "close",
|
|||
|
open: (o == null ? void 0 : o.value) === "open",
|
|||
|
showBackGround: n.value
|
|||
|
}
|
|||
|
])), N = iA([
|
|||
|
"toggle-button-container",
|
|||
|
{ h5: V.isH5 }
|
|||
|
]), T = V.isH5 ? {
|
|||
|
transitionProperty: "width,height,left,top",
|
|||
|
transitionDuration: "0.3s",
|
|||
|
transitionTimingFunction: "ease-in"
|
|||
|
} : {};
|
|||
|
function I(w) {
|
|||
|
A.value = w;
|
|||
|
}
|
|||
|
const { layout: D, config: h } = Cc();
|
|||
|
uA(h, () => {
|
|||
|
const w = {}, H = h.value.flat();
|
|||
|
for (let b of H) {
|
|||
|
const { name: x, props: B = {} } = b;
|
|||
|
B.showText !== !1 && (B.showText = !0), w[x] = B;
|
|||
|
}
|
|||
|
e.value = w;
|
|||
|
}, { immediate: !0 });
|
|||
|
function j(w) {
|
|||
|
s.value = w;
|
|||
|
}
|
|||
|
const m = {
|
|||
|
[i.IS_CLICKABLE]: j
|
|||
|
};
|
|||
|
return CA(() => {
|
|||
|
g.watch(
|
|||
|
u.CALL,
|
|||
|
m,
|
|||
|
{
|
|||
|
notifyRangeWhenWatch: i.MYSELF
|
|||
|
}
|
|||
|
);
|
|||
|
}), DA(() => {
|
|||
|
g.unwatch(u.CALL, m);
|
|||
|
}), OA(Ca, s), OA(Sa, r), (w, H) => (d(), y("div", {
|
|||
|
class: k(l(M))
|
|||
|
}, [
|
|||
|
L("div", Cr, [
|
|||
|
C(lo, {
|
|||
|
unit: "%",
|
|||
|
onToggle: I,
|
|||
|
layout: l(D),
|
|||
|
focus: l(A)
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
C(kA, {
|
|||
|
index: "accept",
|
|||
|
height: "auto",
|
|||
|
customStyle: l(T)
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
C(Hc)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["customStyle"]),
|
|||
|
C(kA, {
|
|||
|
index: "reject",
|
|||
|
height: "auto",
|
|||
|
customStyle: l(T)
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
C(or)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["customStyle"]),
|
|||
|
C(kA, {
|
|||
|
index: "microphone",
|
|||
|
height: "auto",
|
|||
|
customStyle: l(T)
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
C(Ar)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["customStyle"]),
|
|||
|
C(kA, {
|
|||
|
index: "hangup",
|
|||
|
height: "auto",
|
|||
|
customStyle: l(T)
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
C(Yc)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["customStyle"]),
|
|||
|
C(kA, {
|
|||
|
index: "speaker",
|
|||
|
height: "auto",
|
|||
|
customStyle: l(T)
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
C(sr)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["customStyle"]),
|
|||
|
C(kA, {
|
|||
|
index: "camera",
|
|||
|
height: "auto",
|
|||
|
customStyle: l(T)
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
C(Gc)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["customStyle"]),
|
|||
|
C(kA, {
|
|||
|
index: "virtualBackground",
|
|||
|
height: "auto",
|
|||
|
customStyle: l(T)
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
C(gr)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["customStyle"]),
|
|||
|
C(kA, {
|
|||
|
index: "switchCamera",
|
|||
|
height: "auto",
|
|||
|
customStyle: l(T)
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
C(Mr)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["customStyle"]),
|
|||
|
C(kA, {
|
|||
|
index: "inviteUser",
|
|||
|
height: "auto",
|
|||
|
customStyle: l(T)
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
C(Ga)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["customStyle"])
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["layout", "focus"])
|
|||
|
]),
|
|||
|
l(n) ? (d(), y("div", {
|
|||
|
key: 0,
|
|||
|
class: k(l(N))
|
|||
|
}, [
|
|||
|
C(yr)
|
|||
|
], 2)) : z("", !0)
|
|||
|
], 2));
|
|||
|
}
|
|||
|
});
|
|||
|
const io = /* @__PURE__ */ Z(jr, [["__scopeId", "data-v-6582c17d"]]), hr = { class: "singlecall-container" }, Lr = /* @__PURE__ */ f({
|
|||
|
__name: "SingleCall",
|
|||
|
setup(a) {
|
|||
|
const { callStatus: A } = G(rA());
|
|||
|
return (e, t) => (d(), y("div", hr, [
|
|||
|
C(Qa),
|
|||
|
l(A) === l(P).CALLING ? (d(), U(qa, { key: 0 })) : z("", !0),
|
|||
|
C(ac),
|
|||
|
C(ao),
|
|||
|
C(io)
|
|||
|
]));
|
|||
|
}
|
|||
|
});
|
|||
|
const Er = /* @__PURE__ */ Z(Lr, [["__scopeId", "data-v-317c1d41"]]), mr = { class: "stream-loading-container" }, zr = /* @__PURE__ */ f({
|
|||
|
__name: "StreamLoading",
|
|||
|
setup(a) {
|
|||
|
return (A, e) => (d(), y("div", mr, [
|
|||
|
C(zt, {
|
|||
|
mode: "dot",
|
|||
|
color: "#FFF",
|
|||
|
loadingWidth: "50px",
|
|||
|
loadingHeight: "50px"
|
|||
|
})
|
|||
|
]));
|
|||
|
}
|
|||
|
});
|
|||
|
const Kt = /* @__PURE__ */ Z(zr, [["__scopeId", "data-v-56b8bc56"]]), Ur = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, fr = /* @__PURE__ */ f({
|
|||
|
...Ur,
|
|||
|
__name: "MediaContainer",
|
|||
|
setup(a) {
|
|||
|
const A = p("local"), e = p(null), t = p(!1);
|
|||
|
be();
|
|||
|
const { localUserInfoExcludeVolume: o, remoteUserListExcludeVolume: n } = G(vA()), { callStatus: s, callType: r, isShowEnableVirtualBackground: c, callRole: M } = G(rA()), { netWorkQualityList: N } = Ol(), T = S(() => n.value.length + 1), I = ma(), D = xl(e, T), h = Ea(), { isFloatWindow: j } = G(BA()), m = za(), { status: w } = Ve() || {}, H = !V.isPC, b = S(() => String(e.value) === "0"), x = S(() => !V.isPC && b.value && o.value.isVideoAvailable), B = S(() => x.value), F = S(() => x.value && c.value && V.isWeChat), tA = S(() => V.isPC || b.value), J = S(() => V.isPC || j.value ? "%" : "vw"), MA = S(() => [o.value, ...n.value].map((lA) => {
|
|||
|
var SA;
|
|||
|
if (j.value) {
|
|||
|
if (((SA = h.value) == null ? void 0 : SA[lA.domId]) >= 10)
|
|||
|
return lA.domId;
|
|||
|
} else
|
|||
|
return lA.domId;
|
|||
|
})), WA = S(() => !(M.value === IA.CALLEE && s.value === P.CALLING && !j.value)), Me = S(() => {
|
|||
|
let lA = "";
|
|||
|
return M.value === IA.CALLEE && s.value === P.CALLING && !j.value && (lA = "hidden"), {
|
|||
|
visibility: lA
|
|||
|
};
|
|||
|
});
|
|||
|
function ee(lA) {
|
|||
|
e.value = lA, m.value = lA, w.value = lA !== null ? "close" : "open";
|
|||
|
}
|
|||
|
function te(lA) {
|
|||
|
var SA, nA;
|
|||
|
return V.isWeChat ? !((nA = (SA = I.value) == null ? void 0 : SA.find((PA) => PA.userID === lA.userId)) != null && nA.hasVideo) : !lA.isVideoAvailable;
|
|||
|
}
|
|||
|
function de(lA) {
|
|||
|
var SA, nA;
|
|||
|
return V.isWeChat ? !((nA = (SA = I.value) == null ? void 0 : SA.find((PA) => PA.userID === lA.userId)) != null && nA.hasAudio) : !lA.isAudioAvailable;
|
|||
|
}
|
|||
|
function ae(lA) {
|
|||
|
if (!N.value)
|
|||
|
return;
|
|||
|
const SA = lA !== o.value.userId;
|
|||
|
if (!V.isWeChat && SA)
|
|||
|
return;
|
|||
|
const nA = N.value.find((PA) => PA.userId === lA);
|
|||
|
return nA && (nA == null ? void 0 : nA.quality) >= 4;
|
|||
|
}
|
|||
|
uA([n, r], () => {
|
|||
|
var lA, SA;
|
|||
|
(SA = (lA = n.value) == null ? void 0 : lA[0]) != null && SA.isEnter && (A.value = "remote"), r.value === _.AUDIO ? t.value = !1 : t.value = !0;
|
|||
|
});
|
|||
|
const xe = S(() => iA([
|
|||
|
"groupcall-media-container",
|
|||
|
{
|
|||
|
mobile: !V.isPC,
|
|||
|
pc: V.isPC,
|
|||
|
"two-layout": T.value === 2 && e.value === null,
|
|||
|
float: j.value
|
|||
|
}
|
|||
|
])), ke = S(() => s.value === P.CALLING && (r.value === _.AUDIO && !o.value.isAudioAvailable || r.value === _.VIDEO && !o.value.isVideoAvailable));
|
|||
|
return (lA, SA) => (d(), U(Ha, {
|
|||
|
id: "source",
|
|||
|
disabled: !l(j),
|
|||
|
source: "#source",
|
|||
|
to: "body"
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
C(eo, null, {
|
|||
|
default: E(() => [
|
|||
|
L("div", {
|
|||
|
class: k(l(xe)),
|
|||
|
style: eA([l(Me)])
|
|||
|
}, [
|
|||
|
C(lo, {
|
|||
|
unit: l(J),
|
|||
|
"enable-focus": H,
|
|||
|
focus: l(e),
|
|||
|
length: l(T),
|
|||
|
layout: l(D),
|
|||
|
onToggle: ee
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
(d(), U(kA, {
|
|||
|
index: 0,
|
|||
|
key: l(o).userId
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
C(_a, {
|
|||
|
domId: l(o).domId,
|
|||
|
"show-audio-stream": !l(o).isVideoAvailable,
|
|||
|
show: l(MA).includes(l(o).domId) && l(WA)
|
|||
|
}, {
|
|||
|
"audio-stream": E(() => [
|
|||
|
C(At, {
|
|||
|
"user-id": l(o).userId,
|
|||
|
username: l(o).displayUserInfo,
|
|||
|
avatar: l(o).avatar,
|
|||
|
"is-video-available": l(o).isVideoAvailable
|
|||
|
}, null, 8, ["user-id", "username", "avatar", "is-video-available"])
|
|||
|
]),
|
|||
|
loading: E(() => [
|
|||
|
l(ke) ? (d(), U(Kt, { key: 0 })) : z("", !0)
|
|||
|
]),
|
|||
|
"stream-info": E(() => [
|
|||
|
l(j) ? z("", !0) : (d(), U($e, {
|
|||
|
key: 0,
|
|||
|
"is-self": !0,
|
|||
|
"show-nick-name": l(tA),
|
|||
|
showSwitchCameraButton: l(B),
|
|||
|
showVirtualBackgroundButton: l(F),
|
|||
|
showNetWorkStatus: ae(l(o).userId),
|
|||
|
nickName: l(o).displayUserInfo,
|
|||
|
isMuted: !l(o).isAudioAvailable,
|
|||
|
volume: l(h) && l(h)[l(o).domId]
|
|||
|
}, null, 8, ["show-nick-name", "showSwitchCameraButton", "showVirtualBackgroundButton", "showNetWorkStatus", "nickName", "isMuted", "volume"]))
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["domId", "show-audio-stream", "show"])
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
})),
|
|||
|
(d(!0), y(RA, null, ce(l(n), (nA, PA) => (d(), U(kA, {
|
|||
|
key: nA.userId,
|
|||
|
index: PA + 1
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
C($a, {
|
|||
|
domId: nA.domId,
|
|||
|
"show-audio-stream": te(nA),
|
|||
|
show: l(MA).includes(nA.domId) && l(WA)
|
|||
|
}, {
|
|||
|
"audio-stream": E(() => [
|
|||
|
C(At, {
|
|||
|
"user-id": nA.userId,
|
|||
|
username: nA.displayUserInfo,
|
|||
|
avatar: nA.avatar
|
|||
|
}, null, 8, ["user-id", "username", "avatar"])
|
|||
|
]),
|
|||
|
loading: E(() => [
|
|||
|
nA.isEnter ? z("", !0) : (d(), U(Kt, { key: 0 }))
|
|||
|
]),
|
|||
|
"stream-info": E(() => [
|
|||
|
l(j) ? z("", !0) : (d(), U($e, {
|
|||
|
key: 0,
|
|||
|
"show-nick-name": l(V).isPC || String(l(e)) === String(PA + 1),
|
|||
|
"show-control-button": !1,
|
|||
|
showNetWorkStatus: ae(nA.userId),
|
|||
|
nickName: nA.displayUserInfo,
|
|||
|
"is-muted": de(nA),
|
|||
|
volume: l(h) && l(h)[nA.domId]
|
|||
|
}, null, 8, ["show-nick-name", "showNetWorkStatus", "nickName", "is-muted", "volume"]))
|
|||
|
]),
|
|||
|
_: 2
|
|||
|
}, 1032, ["domId", "show-audio-stream", "show"])
|
|||
|
]),
|
|||
|
_: 2
|
|||
|
}, 1032, ["index"]))), 128))
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["unit", "focus", "length", "layout"])
|
|||
|
], 6)
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
})
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["disabled"]));
|
|||
|
}
|
|||
|
});
|
|||
|
const vr = /* @__PURE__ */ Z(fr, [["__scopeId", "data-v-0629f0d8"]]), wr = {
|
|||
|
key: 0,
|
|||
|
class: "dialog-main-header"
|
|||
|
}, Or = { class: "dialog-main-title" }, Vr = {
|
|||
|
key: 1,
|
|||
|
class: "dialog-main-footer"
|
|||
|
}, br = /* @__PURE__ */ f({
|
|||
|
__name: "TDialog",
|
|||
|
props: {
|
|||
|
moduleValue: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
},
|
|||
|
isHeaderShow: {
|
|||
|
type: Boolean,
|
|||
|
default: !0
|
|||
|
},
|
|||
|
isFooterShow: {
|
|||
|
type: Boolean,
|
|||
|
default: !0
|
|||
|
},
|
|||
|
background: {
|
|||
|
type: Boolean,
|
|||
|
default: !0
|
|||
|
},
|
|||
|
title: {
|
|||
|
type: String,
|
|||
|
default: ""
|
|||
|
},
|
|||
|
center: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
},
|
|||
|
isH5: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
}
|
|||
|
},
|
|||
|
emits: ["update:moduleValue", "submit"],
|
|||
|
setup(a, { emit: A }) {
|
|||
|
const e = {
|
|||
|
OUTSIDE: "outside",
|
|||
|
INSIDE: "inside"
|
|||
|
}, t = a, o = p(!0), n = p(!0), s = p(!0), r = p("");
|
|||
|
ue(() => {
|
|||
|
r.value = t.title, o.value = t.isHeaderShow, n.value = t.isFooterShow, s.value = t.background;
|
|||
|
});
|
|||
|
const c = A, M = (I) => {
|
|||
|
I === e.OUTSIDE && N();
|
|||
|
}, N = () => {
|
|||
|
c("update:moduleValue", !1);
|
|||
|
}, T = () => {
|
|||
|
c("submit"), N();
|
|||
|
};
|
|||
|
return (I, D) => a.moduleValue ? (d(), y("div", {
|
|||
|
key: 0,
|
|||
|
class: k(["dialog", [t.isH5 ? "dialog-h5" : "", a.center ? "center" : ""]]),
|
|||
|
onClick: D[1] || (D[1] = pe((h) => M(e.OUTSIDE), ["stop", "prevent"]))
|
|||
|
}, [
|
|||
|
L("main", {
|
|||
|
class: k(["dialog-main", [l(s) ? "" : "dialog-main-back"]]),
|
|||
|
onClick: D[0] || (D[0] = pe((h) => M(e.INSIDE), ["stop", "prevent"]))
|
|||
|
}, [
|
|||
|
l(o) ? (d(), y("header", wr, [
|
|||
|
L("h1", Or, W(l(r)), 1),
|
|||
|
L("i", {
|
|||
|
class: "icon icon-close",
|
|||
|
onClick: N
|
|||
|
})
|
|||
|
])) : z("", !0),
|
|||
|
L("div", {
|
|||
|
class: k(["dialog-main-content", [t.isH5 ? "dialog-main-content-uniapp" : ""]])
|
|||
|
}, [
|
|||
|
q(I.$slots, "default", {}, void 0, !0)
|
|||
|
], 2),
|
|||
|
l(n) ? (d(), y("footer", Vr, [
|
|||
|
L("button", {
|
|||
|
class: "btn btn-cancel",
|
|||
|
onClick: N
|
|||
|
}, W(l(v)("Cancel")), 1),
|
|||
|
L("button", {
|
|||
|
class: "btn btn-default",
|
|||
|
onClick: T
|
|||
|
}, W(l(v)("Done")), 1)
|
|||
|
])) : z("", !0)
|
|||
|
], 2)
|
|||
|
], 2)) : z("", !0);
|
|||
|
}
|
|||
|
});
|
|||
|
const xr = /* @__PURE__ */ Z(br, [["__scopeId", "data-v-7a89cdf3"]]), kr = ["src"], Rr = ["src"], Br = /* @__PURE__ */ f({
|
|||
|
__name: "TIcon",
|
|||
|
props: {
|
|||
|
file: {
|
|||
|
type: String,
|
|||
|
default: ""
|
|||
|
},
|
|||
|
width: {
|
|||
|
type: String,
|
|||
|
default: "20px"
|
|||
|
},
|
|||
|
height: {
|
|||
|
type: String,
|
|||
|
default: "20px"
|
|||
|
},
|
|||
|
isApp: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
}
|
|||
|
},
|
|||
|
emits: ["click"],
|
|||
|
setup(a, { emit: A }) {
|
|||
|
const e = A, t = a, o = () => {
|
|||
|
e("click");
|
|||
|
};
|
|||
|
return (n, s) => (d(), y("div", {
|
|||
|
class: "icon",
|
|||
|
onClick: o
|
|||
|
}, [
|
|||
|
t.isApp ? (d(), y("image", {
|
|||
|
key: 0,
|
|||
|
class: "icon",
|
|||
|
src: t.file,
|
|||
|
style: eA({ width: t.width, height: t.height })
|
|||
|
}, null, 12, kr)) : (d(), y("img", {
|
|||
|
key: 1,
|
|||
|
class: "icon",
|
|||
|
src: t.file,
|
|||
|
style: eA({ width: t.width, height: t.height })
|
|||
|
}, null, 12, Rr))
|
|||
|
]));
|
|||
|
}
|
|||
|
});
|
|||
|
const Ze = /* @__PURE__ */ Z(Br, [["__scopeId", "data-v-b989a330"]]), _t = "", Pr = "
|
|||
|
key: 1,
|
|||
|
class: "icon-unselected"
|
|||
|
}, Kr = { class: "select-all" }, _r = ["onClick"], $r = ["src"], Au = { class: "name" }, eu = { key: 0 }, tu = { class: "right" }, au = {
|
|||
|
key: 0,
|
|||
|
class: "transfer-header"
|
|||
|
}, ou = {
|
|||
|
key: 1,
|
|||
|
class: "transfer-list"
|
|||
|
}, lu = {
|
|||
|
key: 0,
|
|||
|
class: "transfer-text"
|
|||
|
}, nu = { class: "transfer-list-item-content" }, iu = ["src"], su = {
|
|||
|
key: 0,
|
|||
|
class: "name"
|
|||
|
}, cu = ["onClick"], ru = { class: "transfer-right-footer" }, uu = /* @__PURE__ */ f({
|
|||
|
__name: "TTransfer",
|
|||
|
props: {
|
|||
|
list: {
|
|||
|
type: Array,
|
|||
|
default: () => []
|
|||
|
},
|
|||
|
selectedList: {
|
|||
|
type: Array,
|
|||
|
default: () => []
|
|||
|
},
|
|||
|
isSearch: {
|
|||
|
type: Boolean,
|
|||
|
default: !0
|
|||
|
},
|
|||
|
isRadio: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
},
|
|||
|
isCustomItem: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
},
|
|||
|
title: {
|
|||
|
type: String,
|
|||
|
default: ""
|
|||
|
},
|
|||
|
type: {
|
|||
|
type: String,
|
|||
|
default: ""
|
|||
|
},
|
|||
|
resultShow: {
|
|||
|
type: Boolean,
|
|||
|
default: !0
|
|||
|
},
|
|||
|
total: {
|
|||
|
type: Number,
|
|||
|
default: 0
|
|||
|
},
|
|||
|
isH5: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
}
|
|||
|
},
|
|||
|
emits: ["search", "submit", "cancel", "getMore"],
|
|||
|
setup(a, { emit: A }) {
|
|||
|
const e = a, t = A, o = p(""), n = p([]), s = p(0), r = p([]), c = p(!0), M = p(!1), N = p(""), T = p("");
|
|||
|
ue(() => {
|
|||
|
const { list: b, isCustomItem: x, isSearch: B, title: F, total: tA, selectedList: J } = e;
|
|||
|
if (x)
|
|||
|
for (let MA = 0; MA < b.length; MA++)
|
|||
|
b[MA].conversationID.indexOf("@TIM#SYSTEM") > -1 && b.splice(MA, 1), n.value = b;
|
|||
|
else
|
|||
|
n.value = b;
|
|||
|
s.value = tA || b.length, r.value = J && J.length > 0 ? J : r.value, c.value = B, M.value = x, N.value = F, o.value = e.type;
|
|||
|
});
|
|||
|
const I = S(
|
|||
|
() => n.value.filter((b) => !b.isDisabled)
|
|||
|
), D = (b) => {
|
|||
|
T.value = b.target.value, t("search", b.target.value);
|
|||
|
}, h = (b) => {
|
|||
|
if (b.isDisabled)
|
|||
|
return;
|
|||
|
let x = r.value;
|
|||
|
const B = x.indexOf(b);
|
|||
|
if (B > -1)
|
|||
|
return r.value.splice(B, 1);
|
|||
|
e.isRadio && (x = []), x.push(b), r.value = x;
|
|||
|
}, j = () => {
|
|||
|
r.value.length === I.value.length ? r.value = [] : r.value = [...I.value];
|
|||
|
}, m = () => {
|
|||
|
t("submit", r.value), T.value = "";
|
|||
|
}, w = () => {
|
|||
|
t("cancel"), T.value = "";
|
|||
|
}, H = () => {
|
|||
|
t("getMore");
|
|||
|
};
|
|||
|
return (b, x) => (d(), y("div", {
|
|||
|
class: k(["transfer", [e.isH5 ? "transfer-h5" : ""]])
|
|||
|
}, [
|
|||
|
e.isH5 ? (d(), y("header", {
|
|||
|
key: 0,
|
|||
|
class: "transfer-header transfer-h5-header",
|
|||
|
onClick: w
|
|||
|
}, [
|
|||
|
C(Ze, {
|
|||
|
class: "icon",
|
|||
|
file: l(Pr),
|
|||
|
width: "18px",
|
|||
|
height: "18px"
|
|||
|
}, null, 8, ["file"]),
|
|||
|
L("span", Gr, W(l(N)), 1),
|
|||
|
x[0] || (x[0] = L("span", { class: "space" }, null, -1))
|
|||
|
])) : z("", !0),
|
|||
|
L("main", Qr, [
|
|||
|
L("div", Zr, [
|
|||
|
L("header", Fr, [
|
|||
|
!e.isH5 && l(c) ? (d(), y("input", {
|
|||
|
key: 0,
|
|||
|
type: "text",
|
|||
|
value: l(T),
|
|||
|
onKeyup: Uo(D, ["enter"]),
|
|||
|
placeholder: l(v)("Please enter userID"),
|
|||
|
enterkeyhint: "search",
|
|||
|
class: k([e.isH5 ? "left-uniapp-input" : ""])
|
|||
|
}, null, 42, Yr)) : z("", !0),
|
|||
|
e.isH5 && l(c) ? (d(), y("input", {
|
|||
|
key: 1,
|
|||
|
type: "text",
|
|||
|
onBlur: D,
|
|||
|
onConfirm: D,
|
|||
|
placeholder: l(v)("Please enter userID"),
|
|||
|
enterkeyhint: "search",
|
|||
|
value: l(T),
|
|||
|
class: k([e.isH5 ? "left-uniapp-input" : ""])
|
|||
|
}, null, 42, Xr)) : z("", !0)
|
|||
|
]),
|
|||
|
L("main", qr, [
|
|||
|
L("ul", Jr, [
|
|||
|
l(I).length > 1 && !a.isRadio ? (d(), y("li", {
|
|||
|
key: 0,
|
|||
|
class: "transfer-list-item",
|
|||
|
onClick: j
|
|||
|
}, [
|
|||
|
l(r).length === l(I).length ? (d(), U(Ze, {
|
|||
|
key: 0,
|
|||
|
file: l(_t),
|
|||
|
width: "18px",
|
|||
|
height: "18px"
|
|||
|
}, null, 8, ["file"])) : (d(), y("i", Hr)),
|
|||
|
L("span", Kr, W(l(v)("Select all")), 1)
|
|||
|
])) : z("", !0),
|
|||
|
(d(!0), y(RA, null, ce(l(n), (B) => (d(), y("li", {
|
|||
|
class: "transfer-list-item",
|
|||
|
key: B.userID,
|
|||
|
onClick: (F) => h(B)
|
|||
|
}, [
|
|||
|
l(r).indexOf(B) > -1 ? (d(), U(Ze, {
|
|||
|
key: 0,
|
|||
|
file: l(_t),
|
|||
|
class: k([B.isDisabled && "disabled"]),
|
|||
|
width: "18px",
|
|||
|
height: "18px"
|
|||
|
}, null, 8, ["file", "class"])) : (d(), y("i", {
|
|||
|
key: 1,
|
|||
|
class: k([B.isDisabled && "disabled", "icon-unselected"])
|
|||
|
}, null, 2)),
|
|||
|
l(M) ? q(b.$slots, "left", {
|
|||
|
key: 3,
|
|||
|
data: B
|
|||
|
}, void 0, !0) : (d(), y(RA, { key: 2 }, [
|
|||
|
L("img", {
|
|||
|
class: "avatar",
|
|||
|
src: B.avatar || "https://web.sdk.qcloud.com/component/TUIKit/assets/avatar_21.png",
|
|||
|
onerror: "this.src='https://web.sdk.qcloud.com/component/TUIKit/assets/avatar_21.png'"
|
|||
|
}, null, 8, $r),
|
|||
|
L("span", Au, W(B.nick || B.userID), 1),
|
|||
|
B.isDisabled ? (d(), y("span", eu)) : z("", !0)
|
|||
|
], 64))
|
|||
|
], 8, _r))), 128)),
|
|||
|
l(s) > l(n).length ? (d(), y("li", {
|
|||
|
key: 1,
|
|||
|
class: "transfer-list-item more",
|
|||
|
onClick: H
|
|||
|
}, W(l(v)("View more")), 1)) : z("", !0)
|
|||
|
])
|
|||
|
])
|
|||
|
]),
|
|||
|
L("div", tu, [
|
|||
|
e.isH5 ? z("", !0) : (d(), y("header", au, W(l(N)), 1)),
|
|||
|
a.resultShow ? (d(), y("ul", ou, [
|
|||
|
l(r).length > 0 && !e.isH5 ? (d(), y("p", lu, W(l(r).length) + " " + W(l(v)("people selected")), 1)) : z("", !0),
|
|||
|
(d(!0), y(RA, null, ce(l(r), (B, F) => (d(), y("li", {
|
|||
|
class: "transfer-list-item space-between",
|
|||
|
key: F
|
|||
|
}, [
|
|||
|
L("aside", nu, [
|
|||
|
l(M) ? q(b.$slots, "right", {
|
|||
|
key: 1,
|
|||
|
data: B
|
|||
|
}, void 0, !0) : (d(), y(RA, { key: 0 }, [
|
|||
|
L("img", {
|
|||
|
class: "avatar",
|
|||
|
src: B.avatar || "https://web.sdk.qcloud.com/component/TUIKit/assets/avatar_21.png",
|
|||
|
onerror: "this.src='https://web.sdk.qcloud.com/component/TUIKit/assets/avatar_21.png'"
|
|||
|
}, null, 8, iu),
|
|||
|
e.isH5 ? z("", !0) : (d(), y("span", su, W(B.nick || B.userID), 1))
|
|||
|
], 64))
|
|||
|
]),
|
|||
|
e.isH5 ? z("", !0) : (d(), y("span", {
|
|||
|
key: 0,
|
|||
|
onClick: (tA) => h(B)
|
|||
|
}, [
|
|||
|
C(Ze, {
|
|||
|
file: l(Wr),
|
|||
|
width: "18px",
|
|||
|
height: "18px"
|
|||
|
}, null, 8, ["file"])
|
|||
|
], 8, cu))
|
|||
|
]))), 128))
|
|||
|
])) : z("", !0),
|
|||
|
L("footer", ru, [
|
|||
|
L("button", {
|
|||
|
class: "btn btn-cancel",
|
|||
|
onClick: w
|
|||
|
}, W(l(v)("Cancel")), 1),
|
|||
|
l(r).length > 0 ? (d(), y("button", {
|
|||
|
key: 0,
|
|||
|
class: "btn",
|
|||
|
onClick: m
|
|||
|
}, W(l(v)("Done")), 1)) : (d(), y("button", {
|
|||
|
key: 1,
|
|||
|
class: "btn btn-no",
|
|||
|
onClick: m
|
|||
|
}, W(l(v)("Done")), 1))
|
|||
|
])
|
|||
|
])
|
|||
|
])
|
|||
|
], 2));
|
|||
|
}
|
|||
|
});
|
|||
|
const Mu = /* @__PURE__ */ Z(uu, [["__scopeId", "data-v-cd3a18ba"]]), du = /* @__PURE__ */ f({
|
|||
|
__name: "SelectUser",
|
|||
|
props: {
|
|||
|
isRadio: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
},
|
|||
|
isNeedSearch: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
},
|
|||
|
title: {
|
|||
|
type: String,
|
|||
|
default: ""
|
|||
|
},
|
|||
|
userList: {
|
|||
|
type: Array,
|
|||
|
default: () => []
|
|||
|
},
|
|||
|
total: {
|
|||
|
type: Number,
|
|||
|
default: 0
|
|||
|
},
|
|||
|
isShow: {
|
|||
|
type: Boolean,
|
|||
|
default: !1
|
|||
|
},
|
|||
|
isPC: {
|
|||
|
type: Boolean,
|
|||
|
default: !0
|
|||
|
}
|
|||
|
},
|
|||
|
emits: ["complete", "search", "getMore", "update:isShow"],
|
|||
|
setup(a, { emit: A }) {
|
|||
|
const e = A, t = a, o = p(!1);
|
|||
|
ue(() => {
|
|||
|
o.value = t.isShow;
|
|||
|
});
|
|||
|
const n = () => {
|
|||
|
o.value = !o.value, e("complete", []), e("update:isShow", o.value);
|
|||
|
}, s = (M) => {
|
|||
|
e("complete", M);
|
|||
|
}, r = (M) => {
|
|||
|
e("search", M);
|
|||
|
}, c = () => {
|
|||
|
e("getMore");
|
|||
|
};
|
|||
|
return (M, N) => (d(), U(xr, {
|
|||
|
moduleValue: l(o),
|
|||
|
isH5: !a.isPC,
|
|||
|
isHeaderShow: !1,
|
|||
|
isFooterShow: !1,
|
|||
|
background: !1,
|
|||
|
"onUpdate:moduleValue": n
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
C(Mu, {
|
|||
|
isSearch: t.isNeedSearch,
|
|||
|
title: t.title,
|
|||
|
list: t.userList,
|
|||
|
isH5: !a.isPC,
|
|||
|
isRadio: t.isRadio,
|
|||
|
total: t.total,
|
|||
|
onGetMore: c,
|
|||
|
onSearch: r,
|
|||
|
onSubmit: s,
|
|||
|
onCancel: n
|
|||
|
}, null, 8, ["isSearch", "title", "list", "isH5", "isRadio", "total"])
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}, 8, ["moduleValue", "isH5"]));
|
|||
|
}
|
|||
|
}), Iu = {
|
|||
|
options: {
|
|||
|
virtualHost: !0
|
|||
|
}
|
|||
|
}, Nu = /* @__PURE__ */ f({
|
|||
|
...Iu,
|
|||
|
__name: "BackGround",
|
|||
|
setup(a) {
|
|||
|
return (A, e) => (d(), U(Za, {
|
|||
|
bgColor: "#22262ed9",
|
|||
|
bgImage: l(QA),
|
|||
|
customStyle: { position: "absolute", zIndex: 0 }
|
|||
|
}, null, 8, ["bgImage"]));
|
|||
|
}
|
|||
|
}), gu = { class: "groupcall-container" }, $t = 30, Tu = /* @__PURE__ */ f({
|
|||
|
__name: "GroupCall",
|
|||
|
setup(a) {
|
|||
|
const A = p(null), e = p("open"), t = p(!1), o = p(0), n = p([]), s = p([]), r = p(0), c = A, M = { status: e }, { callRole: N, callStatus: T } = G(rA()), { isFloatWindow: I } = G(BA()), { localUserInfoExcludeVolume: D, remoteUserListExcludeVolume: h } = G(vA()), j = async (F) => {
|
|||
|
if (t.value = F, t.value) {
|
|||
|
await H();
|
|||
|
const tA = await Q.getGroupProfile();
|
|||
|
o.value = tA.memberCount;
|
|||
|
}
|
|||
|
}, m = () => {
|
|||
|
t.value = !1, g.update(u.CALL, i.SHOW_SELECT_USER, !1), r.value = 0, n.value = [];
|
|||
|
}, w = async () => {
|
|||
|
r.value += $t, await H();
|
|||
|
}, H = async () => {
|
|||
|
const F = await Q.getGroupMemberList($t, r.value), tA = [...h.value, D.value].map((J) => J.userId);
|
|||
|
n.value.push(...F), n.value = n.value.map((J) => (tA.includes(J.userID) && (J = { ...J, isDisabled: !0 }), J)), s.value = n.value;
|
|||
|
}, b = async (F) => {
|
|||
|
try {
|
|||
|
if (F.length <= 0)
|
|||
|
return;
|
|||
|
t.value = !1, g.update(u.CALL, i.SHOW_SELECT_USER, !1), r.value = 0;
|
|||
|
const tA = F.map((J) => J.userID);
|
|||
|
await Q.inviteUser({ userIDList: tA }), n.value = [];
|
|||
|
} catch (tA) {
|
|||
|
console.debug(tA);
|
|||
|
}
|
|||
|
}, x = (F) => {
|
|||
|
F ? n.value = n.value.filter((tA) => tA.userID.includes(F) || tA.nick.includes(F)) : n.value = s.value;
|
|||
|
}, B = {
|
|||
|
[i.SHOW_SELECT_USER]: j
|
|||
|
};
|
|||
|
return CA(() => {
|
|||
|
g.watch(u.CALL, B, { notifyRangeWhenWatch: i.MYSELF });
|
|||
|
}), DA(() => {
|
|||
|
g.unwatch(u.CALL, B);
|
|||
|
}), M.status = p("open"), c.value = null, OA(Da, M), OA(pa, c), (F, tA) => (d(), y("div", gu, [
|
|||
|
C(Qa),
|
|||
|
l(T) === l(P).CALLING && l(N) === l(IA).CALLEE && !l(I) ? (d(), U(qa, { key: 0 })) : z("", !0),
|
|||
|
C(vr),
|
|||
|
C(ao),
|
|||
|
C(io),
|
|||
|
C(Nu),
|
|||
|
C(du, {
|
|||
|
isShow: l(t),
|
|||
|
isNeedSearch: !0,
|
|||
|
userList: l(n),
|
|||
|
isPC: l(V).isPC,
|
|||
|
total: l(o),
|
|||
|
onGetMore: w,
|
|||
|
onComplete: b,
|
|||
|
onSearch: x,
|
|||
|
"onUpdate:isShow": m
|
|||
|
}, null, 8, ["isShow", "userList", "isPC", "total"])
|
|||
|
]));
|
|||
|
}
|
|||
|
});
|
|||
|
const pu = /* @__PURE__ */ Z(Tu, [["__scopeId", "data-v-8604f3c1"]]), Du = {}, yu = {
|
|||
|
viewBox: "0 0 1024 1024",
|
|||
|
xmlns: "http://www.w3.org/2000/svg",
|
|||
|
"data-v-ea893728": ""
|
|||
|
};
|
|||
|
function Cu(a, A) {
|
|||
|
return d(), y("svg", yu, A[0] || (A[0] = [
|
|||
|
L("path", {
|
|||
|
fill: "currentColor",
|
|||
|
d: "M764.288 214.592 512 466.88 259.712 214.592a31.936 31.936 0 0 0-45.12 45.12L466.752 512 214.528 764.224a31.936 31.936 0 1 0 45.12 45.184L512 557.184l252.288 252.288a31.936 31.936 0 0 0 45.12-45.12L557.12 512.064l252.288-252.352a31.936 31.936 0 1 0-45.12-45.184z"
|
|||
|
}, null, -1)
|
|||
|
]));
|
|||
|
}
|
|||
|
const Su = /* @__PURE__ */ Z(Du, [["render", Cu]]), Aa = "
|
|||
|
key: 0,
|
|||
|
class: "card"
|
|||
|
}, mu = { class: "card-body" }, zu = { class: "card-wrapper" }, Uu = { class: "title" }, fu = { class: "button" }, vu = { class: "allow" }, wu = { class: "image-wrapper" }, Ou = ["src"], Vu = /* @__PURE__ */ f({
|
|||
|
__name: "SystemPermitTip",
|
|||
|
props: {
|
|||
|
platform: {},
|
|||
|
language: {}
|
|||
|
},
|
|||
|
setup(a) {
|
|||
|
const A = {
|
|||
|
mac: {
|
|||
|
"zh-cn": Aa,
|
|||
|
en: ju
|
|||
|
},
|
|||
|
win: {
|
|||
|
"zh-cn": hu,
|
|||
|
en: Lu
|
|||
|
}
|
|||
|
}, e = a, t = S(() => e.platform === "mac" ? "mac-privacy" : "win-privacy"), o = S(() => e.platform === "mac" ? "mac-preferences" : "win-preferences"), n = p(Aa), s = p(!0), r = (M) => {
|
|||
|
M && V.isPC && (s.value = !0);
|
|||
|
}, c = () => {
|
|||
|
s.value = !1;
|
|||
|
};
|
|||
|
return uA(() => e.language, () => {
|
|||
|
n.value = A[e.platform][e.language];
|
|||
|
}, {
|
|||
|
immediate: !0
|
|||
|
}), CA(() => {
|
|||
|
g.watch(u.CALL, {
|
|||
|
[i.SHOW_PERMISSION_TIP]: r
|
|||
|
}, {
|
|||
|
notifyRangeWhenWatch: i.MYSELF
|
|||
|
});
|
|||
|
}), DA(() => {
|
|||
|
g.unwatch(u.CALL, {
|
|||
|
[i.SHOW_PERMISSION_TIP]: r
|
|||
|
});
|
|||
|
}), (M, N) => l(s) ? (d(), y("div", Eu, [
|
|||
|
L("div", mu, [
|
|||
|
L("div", {
|
|||
|
class: "close",
|
|||
|
onClick: c
|
|||
|
}, [
|
|||
|
C(Su)
|
|||
|
]),
|
|||
|
L("div", zu, [
|
|||
|
L("div", Uu, W(l(v)("browser-authorization")), 1),
|
|||
|
L("div", fu, W(l(v)(l(o))), 1),
|
|||
|
L("div", vu, W(l(v)(l(t))), 1),
|
|||
|
L("div", wu, [
|
|||
|
L("img", {
|
|||
|
src: l(n),
|
|||
|
class: "image",
|
|||
|
alt: "system permit"
|
|||
|
}, null, 8, Ou)
|
|||
|
])
|
|||
|
])
|
|||
|
])
|
|||
|
])) : z("", !0);
|
|||
|
}
|
|||
|
});
|
|||
|
const bu = /* @__PURE__ */ Z(Vu, [["__scopeId", "data-v-2ea845a3"]]), xu = { class: "tip" }, ku = { class: "card" }, Ru = /* @__PURE__ */ f({
|
|||
|
__name: "PermitTip",
|
|||
|
setup(a) {
|
|||
|
const A = S(() => V.isMAC ? gt.MAC : gt.WIN), e = p(g.getData(u.CALL, i.LANGUAGE)), t = (o) => e.value = o;
|
|||
|
return CA(() => {
|
|||
|
g.watch(u.CALL, {
|
|||
|
[i.LANGUAGE]: t
|
|||
|
}, {
|
|||
|
notifyRangeWhenWatch: i.MYSELF
|
|||
|
});
|
|||
|
}), DA(() => {
|
|||
|
g.unwatch(u.CALL, {
|
|||
|
[i.LANGUAGE]: t
|
|||
|
});
|
|||
|
}), (o, n) => (d(), y("div", xu, [
|
|||
|
L("div", ku, [
|
|||
|
C(bu, {
|
|||
|
platform: l(A),
|
|||
|
language: l(e)
|
|||
|
}, null, 8, ["platform", "language"])
|
|||
|
])
|
|||
|
]));
|
|||
|
}
|
|||
|
});
|
|||
|
const Bu = /* @__PURE__ */ Z(Ru, [["__scopeId", "data-v-cd63c32e"]]), so = {};
|
|||
|
let Nt = null, Pu = 1;
|
|||
|
const Wu = () => {
|
|||
|
const a = document.body, A = document.createElement("div");
|
|||
|
Nt && (a.removeChild(Nt.el), Ue(null, A));
|
|||
|
const e = C(Bu, {
|
|||
|
index: `permit-item-${Pu++}`,
|
|||
|
// eslint-disable-line
|
|||
|
destroy() {
|
|||
|
Ue(null, A);
|
|||
|
}
|
|||
|
});
|
|||
|
Ue(e, A), a.appendChild(A.firstElementChild), Nt = e;
|
|||
|
};
|
|||
|
so.show = () => Wu();
|
|||
|
const Gu = { class: "toast-content" }, Qu = /* @__PURE__ */ f({
|
|||
|
__name: "Toast",
|
|||
|
props: {
|
|||
|
type: {},
|
|||
|
duration: {},
|
|||
|
message: {},
|
|||
|
index: {},
|
|||
|
showClose: { type: Boolean },
|
|||
|
destroy: { type: Function },
|
|||
|
close: { type: Function }
|
|||
|
},
|
|||
|
setup(a) {
|
|||
|
const A = a, e = p(!1), t = p(null), o = S(() => `toast-container ${A.type}`), n = () => {
|
|||
|
A.destroy();
|
|||
|
}, s = () => {
|
|||
|
A.close(), e.value = !1;
|
|||
|
}, r = () => {
|
|||
|
t.value && clearTimeout(t.value), A.duration && (t.value = setTimeout(() => {
|
|||
|
s();
|
|||
|
}, A.duration));
|
|||
|
};
|
|||
|
return CA(() => {
|
|||
|
e.value = !0, r();
|
|||
|
}), DA(() => {
|
|||
|
t.value && clearTimeout(t.value);
|
|||
|
}), (c, M) => (d(), U(fo, {
|
|||
|
name: "slide-up",
|
|||
|
onAfterLeave: n
|
|||
|
}, {
|
|||
|
default: E(() => [
|
|||
|
sA((d(), y("div", {
|
|||
|
key: c.index,
|
|||
|
class: k(l(o))
|
|||
|
}, [
|
|||
|
L("div", Gu, W(c.message), 1),
|
|||
|
sA(L("i", {
|
|||
|
onClick: s,
|
|||
|
class: "toast-close-icon"
|
|||
|
}, null, 512), [
|
|||
|
[cA, c.showClose]
|
|||
|
])
|
|||
|
], 2)), [
|
|||
|
[cA, l(e)]
|
|||
|
])
|
|||
|
]),
|
|||
|
_: 1
|
|||
|
}));
|
|||
|
}
|
|||
|
});
|
|||
|
const Zu = /* @__PURE__ */ Z(Qu, [["__scopeId", "data-v-27fc22c5"]]), HA = {}, wA = [];
|
|||
|
let Fu = 1;
|
|||
|
function Yu() {
|
|||
|
var A, e, t;
|
|||
|
const a = wA.length;
|
|||
|
return a > 0 ? (t = (e = (A = wA[a - 1]) == null ? void 0 : A.el) == null ? void 0 : e.style) == null ? void 0 : t.top : "30px";
|
|||
|
}
|
|||
|
function Xu() {
|
|||
|
var A, e;
|
|||
|
const a = wA.length;
|
|||
|
return a > 0 ? (e = (A = wA[a - 1]) == null ? void 0 : A.el) == null ? void 0 : e.offsetHeight : 0;
|
|||
|
}
|
|||
|
const co = (a) => {
|
|||
|
const { type: A, duration: e = 3e3, message: t, showClose: o = !1, onClose: n } = a, s = document.body, r = document.createElement("div"), c = C(Zu, {
|
|||
|
type: A,
|
|||
|
duration: e,
|
|||
|
message: t,
|
|||
|
showClose: o,
|
|||
|
index: `toast-item-${Fu++}`,
|
|||
|
// eslint-disable-line
|
|||
|
close() {
|
|||
|
var D, h, j, m;
|
|||
|
const T = wA.findIndex((w) => w === c);
|
|||
|
console.log((h = (D = wA[T]) == null ? void 0 : D.el) == null ? void 0 : h.offsetHeight);
|
|||
|
const I = parseInt((m = (j = wA[T]) == null ? void 0 : j.el) == null ? void 0 : m.offsetHeight) + 20;
|
|||
|
for (let w = 0; w < wA.length; w++)
|
|||
|
w < T || (wA[w].el.style.top = parseInt(wA[w].el.style.top) - I + "px");
|
|||
|
wA.splice(T, 1);
|
|||
|
},
|
|||
|
destroy() {
|
|||
|
Ue(null, r);
|
|||
|
}
|
|||
|
});
|
|||
|
Ue(c, r), s.appendChild(r.firstElementChild);
|
|||
|
const M = Yu(), N = Xu();
|
|||
|
c.el.style.top = parseInt(M) + parseInt(N) + 20 + "px", wA.push(c);
|
|||
|
};
|
|||
|
["info", "waring", "error", "success"].forEach((a) => {
|
|||
|
let A = {};
|
|||
|
HA[a] = (e) => {
|
|||
|
typeof e == "string" ? A.message = e : A = e, co({ type: a, ...A });
|
|||
|
};
|
|||
|
});
|
|||
|
HA.show = (a) => {
|
|||
|
let A = {};
|
|||
|
return typeof a == "string" ? (A.message = a, A.type = "info") : A = a, co({ type: "info", ...A });
|
|||
|
};
|
|||
|
const it = /* @__PURE__ */ f({
|
|||
|
__name: "TUICallKit",
|
|||
|
props: {
|
|||
|
beforeCalling: {},
|
|||
|
afterCalling: {},
|
|||
|
onMinimized: {},
|
|||
|
onMessageSentByMe: {},
|
|||
|
kickedOut: {},
|
|||
|
statusChanged: {},
|
|||
|
allowedMinimized: { type: Boolean, default: !1 },
|
|||
|
allowedFullScreen: { type: Boolean, default: !0 },
|
|||
|
videoDisplayMode: { default: "cover" },
|
|||
|
videoResolution: { default: "480p" }
|
|||
|
},
|
|||
|
setup(a) {
|
|||
|
const A = !V.isPC, e = A ? "TUICallKit-mobile transition-animation" : "TUICallKit-desktop", t = p(""), o = p(""), n = p(""), s = p(!1), r = a, c = p(g.getData(u.CALL, i.CALL_STATUS)), M = p(g.getData(u.CALL, i.CALL_ROLE)), N = p(g.getData(u.CALL, i.CALL_MEDIA_TYPE)), T = p(g.getData(u.CALL, i.IS_GROUP)), I = p(g.getData(u.CALL, i.IS_EAR_PHONE)), D = p(null), h = p(g.getData(u.CALL, i.LOCAL_USER_INFO_EXCLUDE_VOLUMN)), j = p(g.getData(u.CALL, i.REMOTE_USER_INFO_EXCLUDE_VOLUMN_LIST)), m = p(g.getData(u.CALL, i.CALLER_USER_INFO)), w = p(g.getData(u.CALL, i.IS_MINIMIZED)), H = p(g.getData(u.CALL, i.ENABLE_VIRTUAL_BACKGROUND)), b = p(g.getData(u.CALL, i.IS_SHOW_ENABLE_VIRTUAL_BACKGROUND)), x = p(g.getData(u.CALL, i.CUSTOM_UI_CONFIG)), B = p(g.getData(u.CALL, i.IS_MUTE_SPEAKER)), F = Be({
|
|||
|
callStatus: c,
|
|||
|
callRole: M,
|
|||
|
callType: N,
|
|||
|
isGroupCall: T,
|
|||
|
isEarPhone: I,
|
|||
|
focusElement: D,
|
|||
|
allowedFullScreen: r.allowedFullScreen,
|
|||
|
enableVirtualBackground: H,
|
|||
|
isShowEnableVirtualBackground: b,
|
|||
|
isMuteSpeaker: B
|
|||
|
}), tA = Be({ callerUserInfo: m }), J = Be({
|
|||
|
localUserInfoExcludeVolume: h,
|
|||
|
remoteUserListExcludeVolume: j
|
|||
|
}), MA = Be({ isFloatWindow: w }), {
|
|||
|
beforeCalling: WA,
|
|||
|
afterCalling: Me,
|
|||
|
onMinimized: ee,
|
|||
|
onMessageSentByMe: te,
|
|||
|
videoDisplayMode: de,
|
|||
|
videoResolution: ae,
|
|||
|
kickedOut: xe,
|
|||
|
statusChanged: ke,
|
|||
|
allowedMinimized: lA
|
|||
|
} = G(r), SA = (K) => {
|
|||
|
F.callStatus = K;
|
|||
|
}, nA = (K) => {
|
|||
|
F.isGroupCall = K;
|
|||
|
}, PA = (K) => {
|
|||
|
K.text && jo(K.text, K.type || "info");
|
|||
|
}, uo = (K) => {
|
|||
|
F.callType = K, A && s.value && (n.value = "miniMized-mobile-audio", o.value = ""), A && !s.value && (o.value = "mobile-audio");
|
|||
|
}, wt = (K) => {
|
|||
|
MA.isFloatWindow = K, K ? A ? F.callType === _.AUDIO ? o.value = "miniMized-mobile-audio" : n.value = "miniMized-mobile-video" : t.value = "miniMized" : (o.value = "mobile-audio", t.value = "", n.value = "");
|
|||
|
}, Mo = (K) => {
|
|||
|
if (K && V.isPC)
|
|||
|
try {
|
|||
|
so.show();
|
|||
|
} catch (Re) {
|
|||
|
console.debug(Re);
|
|||
|
}
|
|||
|
}, Io = (K) => {
|
|||
|
F.callRole = K;
|
|||
|
}, No = (K) => {
|
|||
|
J.localUserInfoExcludeVolume = K;
|
|||
|
}, go = (K) => {
|
|||
|
J.remoteUserListExcludeVolume = K;
|
|||
|
}, To = (K) => {
|
|||
|
tA.callerUserInfo = K;
|
|||
|
}, po = (K) => {
|
|||
|
F.isEarPhone = K;
|
|||
|
}, Do = (K) => {
|
|||
|
F.enableVirtualBackground = K;
|
|||
|
}, yo = (K) => {
|
|||
|
F.isShowEnableVirtualBackground = K;
|
|||
|
}, Co = (K) => {
|
|||
|
x.value = K;
|
|||
|
}, So = (K) => {
|
|||
|
F.isMuteSpeaker = K;
|
|||
|
};
|
|||
|
ue(() => {
|
|||
|
Q.setCallback({
|
|||
|
beforeCalling: WA && WA.value,
|
|||
|
afterCalling: Me && Me.value,
|
|||
|
onMinimized: ee && ee.value,
|
|||
|
onMessageSentByMe: te && te.value,
|
|||
|
kickedOut: xe && xe.value,
|
|||
|
statusChanged: ke && ke.value
|
|||
|
});
|
|||
|
});
|
|||
|
const Ot = {
|
|||
|
[i.CALL_STATUS]: SA,
|
|||
|
[i.IS_GROUP]: nA,
|
|||
|
[i.TOAST_INFO]: PA,
|
|||
|
[i.CALL_MEDIA_TYPE]: uo,
|
|||
|
[i.SHOW_PERMISSION_TIP]: Mo,
|
|||
|
[i.CALL_ROLE]: Io,
|
|||
|
[i.LOCAL_USER_INFO_EXCLUDE_VOLUMN]: No,
|
|||
|
[i.REMOTE_USER_INFO_EXCLUDE_VOLUMN_LIST]: go,
|
|||
|
[i.CALLER_USER_INFO]: To,
|
|||
|
[i.IS_EAR_PHONE]: po,
|
|||
|
[i.ENABLE_VIRTUAL_BACKGROUND]: Do,
|
|||
|
[i.IS_SHOW_ENABLE_VIRTUAL_BACKGROUND]: yo,
|
|||
|
[i.CUSTOM_UI_CONFIG]: Co,
|
|||
|
[i.IS_MUTE_SPEAKER]: So
|
|||
|
};
|
|||
|
CA(() => {
|
|||
|
lA.value && Q.enableFloatWindow(lA.value), Q.setVideoDisplayMode(de.value), Q.setVideoResolution(ae.value), g.watch(
|
|||
|
u.CALL,
|
|||
|
Ot,
|
|||
|
{
|
|||
|
notifyRangeWhenWatch: i.MYSELF
|
|||
|
}
|
|||
|
), g.watch(u.CALL, {
|
|||
|
[i.IS_MINIMIZED]: wt
|
|||
|
});
|
|||
|
});
|
|||
|
function jo(K, Re) {
|
|||
|
switch (Re) {
|
|||
|
case "info":
|
|||
|
HA == null || HA.info(K);
|
|||
|
break;
|
|||
|
case "error":
|
|||
|
HA == null || HA.error(K);
|
|||
|
break;
|
|||
|
}
|
|||
|
}
|
|||
|
return DA(async () => {
|
|||
|
g.unwatch(u.CALL, {
|
|||
|
...Ot,
|
|||
|
[i.IS_MINIMIZED]: wt
|
|||
|
});
|
|||
|
}), OA(Na, F), OA(ga, tA), OA(Ta, J), OA(ya, MA), OA(ja, x), (K, Re) => l(F).callStatus !== l(P).IDLE ? (d(), y("div", {
|
|||
|
key: 0,
|
|||
|
style: eA([{ visibility: l(MA).isFloatWindow ? "hidden" : "" }]),
|
|||
|
id: "tuicallkit-id",
|
|||
|
class: k([l(e), l(t), l(n), l(o)])
|
|||
|
}, [
|
|||
|
l(F).isGroupCall ? (d(), U(pu, {
|
|||
|
key: 1,
|
|||
|
class: "singCall"
|
|||
|
})) : (d(), U(Er, {
|
|||
|
key: 0,
|
|||
|
class: "singCall"
|
|||
|
}))
|
|||
|
], 6)) : z("", !0);
|
|||
|
}
|
|||
|
});
|
|||
|
const ro = "", qu = { class: "banner-pc" }, Ju = { class: "text" }, Hu = { class: "content" }, Ku = { class: "avatar-box" }, _u = /* @__PURE__ */ f({
|
|||
|
__name: "JoinGroupCard",
|
|||
|
props: {
|
|||
|
userListInfo: {
|
|||
|
type: Array,
|
|||
|
default: []
|
|||
|
}
|
|||
|
},
|
|||
|
emits: ["joinGroupCall"],
|
|||
|
setup(a, { emit: A }) {
|
|||
|
const e = A, t = p(!1), o = () => {
|
|||
|
e("joinGroupCall"), t.value = !1;
|
|||
|
}, n = () => {
|
|||
|
t.value = !t.value;
|
|||
|
};
|
|||
|
return (s, r) => (d(), y("div", qu, [
|
|||
|
L("div", {
|
|||
|
class: "top",
|
|||
|
onClick: n
|
|||
|
}, [
|
|||
|
C(LA, {
|
|||
|
class: "call-icon",
|
|||
|
src: l(ro),
|
|||
|
width: "16px",
|
|||
|
height: "16px"
|
|||
|
}, null, 8, ["src"]),
|
|||
|
L("span", Ju, W(a.userListInfo.length) + " " + W(l(v)("people on the call")), 1)
|
|||
|
]),
|
|||
|
sA(L("div", Hu, [
|
|||
|
r[0] || (r[0] = L("div", { class: "content-arrows" }, null, -1)),
|
|||
|
L("div", Ku, [
|
|||
|
(d(!0), y(RA, null, ce(a.userListInfo, (c) => (d(), U(LA, {
|
|||
|
class: "avatar",
|
|||
|
src: c == null ? void 0 : c.avatar,
|
|||
|
defaultSrc: l(QA),
|
|||
|
fit: "cover",
|
|||
|
width: "32px",
|
|||
|
height: "32px"
|
|||
|
}, null, 8, ["src", "defaultSrc"]))), 256))
|
|||
|
]),
|
|||
|
L("div", {
|
|||
|
class: "btn",
|
|||
|
onClick: o
|
|||
|
}, W(l(v)("join")), 1)
|
|||
|
], 512), [
|
|||
|
[cA, l(t)]
|
|||
|
])
|
|||
|
]));
|
|||
|
}
|
|||
|
});
|
|||
|
const $u = "", AM = { class: "banner-h5" }, eM = { class: "left" }, tM = { class: "text" }, aM = { class: "content-box" }, oM = { class: "content" }, lM = { class: "avatar-box" }, nM = /* @__PURE__ */ f({
|
|||
|
__name: "JoinGroupCard",
|
|||
|
props: {
|
|||
|
userListInfo: {
|
|||
|
type: Array,
|
|||
|
default: []
|
|||
|
}
|
|||
|
},
|
|||
|
emits: ["joinGroupCall"],
|
|||
|
setup(a, { emit: A }) {
|
|||
|
const e = p({ margin: "8px 10px 8px 0px" }), t = p({
|
|||
|
margin: "6px",
|
|||
|
borderRadius: "4px"
|
|||
|
}), o = p(!1), n = A, s = () => {
|
|||
|
n("joinGroupCall"), o.value = !1;
|
|||
|
}, r = () => {
|
|||
|
o.value = !o.value;
|
|||
|
};
|
|||
|
return (c, M) => (d(), y("div", AM, [
|
|||
|
L("div", {
|
|||
|
class: "top",
|
|||
|
onClick: r
|
|||
|
}, [
|
|||
|
L("div", eM, [
|
|||
|
C(LA, {
|
|||
|
class: "call-icon",
|
|||
|
src: l(ro),
|
|||
|
width: "16px",
|
|||
|
height: "16px",
|
|||
|
customStyle: l(e)
|
|||
|
}, null, 8, ["src", "customStyle"]),
|
|||
|
L("span", tM, W(a.userListInfo.length) + " " + W(l(v)("people on the call")), 1)
|
|||
|
]),
|
|||
|
C(LA, {
|
|||
|
src: l($u),
|
|||
|
width: "9px",
|
|||
|
height: "9px"
|
|||
|
}, null, 8, ["src"])
|
|||
|
]),
|
|||
|
sA(L("div", aM, [
|
|||
|
L("div", oM, [
|
|||
|
L("div", lM, [
|
|||
|
(d(!0), y(RA, null, ce(a.userListInfo, (N) => (d(), U(LA, {
|
|||
|
src: N == null ? void 0 : N.avatar,
|
|||
|
customStyle: l(t),
|
|||
|
defaultSrc: l(QA),
|
|||
|
fit: "cover",
|
|||
|
width: "50px",
|
|||
|
height: "50px"
|
|||
|
}, null, 8, ["src", "customStyle", "defaultSrc"]))), 256))
|
|||
|
]),
|
|||
|
L("div", {
|
|||
|
class: "btn",
|
|||
|
onClick: pe(s, ["stop"])
|
|||
|
}, W(l(v)("join")), 1)
|
|||
|
])
|
|||
|
], 512), [
|
|||
|
[cA, l(o)]
|
|||
|
])
|
|||
|
]));
|
|||
|
}
|
|||
|
});
|
|||
|
const iM = /* @__PURE__ */ f({
|
|||
|
__name: "JoinGroupCard",
|
|||
|
setup(a) {
|
|||
|
const A = p(V.isPC), e = p(null), { groupId: t, roomId: o, roomIdType: n, callMediaType: s, groupCallMembers: r, callStatus: c } = G(Gl()), M = S(() => t && (c == null ? void 0 : c.value) === P.IDLE && r.value.length), N = async () => {
|
|||
|
if (r.value.length > 9) {
|
|||
|
e.value.show({
|
|||
|
message: "Supports a maximum of 9 people for simultaneous calls",
|
|||
|
type: "success"
|
|||
|
});
|
|||
|
return;
|
|||
|
}
|
|||
|
const T = {
|
|||
|
type: s.value,
|
|||
|
groupID: t.value,
|
|||
|
roomID: n.value === 1 ? Number(o.value) : 0,
|
|||
|
strRoomID: String(o.value)
|
|||
|
};
|
|||
|
try {
|
|||
|
await Q.joinInGroupCall(T);
|
|||
|
} catch (I) {
|
|||
|
console.error(`${i.PREFIX}joinInGroupCall fail: ${I}`);
|
|||
|
}
|
|||
|
};
|
|||
|
return (T, I) => sA((d(), y("div", null, [
|
|||
|
l(A) ? (d(), U(_u, {
|
|||
|
key: 0,
|
|||
|
userListInfo: l(r),
|
|||
|
onJoinGroupCall: N
|
|||
|
}, null, 8, ["userListInfo"])) : (d(), U(nM, {
|
|||
|
key: 1,
|
|||
|
userListInfo: l(r),
|
|||
|
onJoinGroupCall: N
|
|||
|
}, null, 8, ["userListInfo"])),
|
|||
|
C(to, {
|
|||
|
ref_key: "message",
|
|||
|
ref: e
|
|||
|
}, null, 512)
|
|||
|
], 512)), [
|
|||
|
[cA, l(M)]
|
|||
|
]);
|
|||
|
}
|
|||
|
}), sM = (a) => (a.component("TUICallKit", { server: Q }), Q.bindTUICore(a), it), cM = (a) => {
|
|||
|
a.component("TUICallKit", it).component("JoinGroupCard", iM), console.log("TUICallKit&mini installed", a);
|
|||
|
};
|
|||
|
it.plugin = sM;
|
|||
|
it.install = cM;
|
|||
|
const IM = {
|
|||
|
AUDIO_CALL: 1,
|
|||
|
VIDEO_CALL: 2
|
|||
|
}, NM = "3.3.7";
|
|||
|
export {
|
|||
|
_ as CallMediaType,
|
|||
|
IA as CallRole,
|
|||
|
_A as FeatureButton,
|
|||
|
iM as JoinGroupCard,
|
|||
|
Xe as LayoutMode,
|
|||
|
i as NAME,
|
|||
|
jA as STATUS,
|
|||
|
u as StoreName,
|
|||
|
it as TUICallKit,
|
|||
|
Q as TUICallKitServer,
|
|||
|
IM as TUICallType,
|
|||
|
V as TUIGlobal,
|
|||
|
g as TUIStore,
|
|||
|
NM as Version,
|
|||
|
fe as VideoDisplayMode,
|
|||
|
ve as VideoResolution,
|
|||
|
cM as install,
|
|||
|
sM as plugin,
|
|||
|
v as t,
|
|||
|
YA as uiDesign
|
|||
|
};
|