jiuyiUniapp/jiuyi/node_modules/@tencentcloud/call-uikit-vue2.6/tuicall-uikit-vue2.es.js

10927 lines
591 KiB
JavaScript
Raw Normal View History

2024-12-18 15:46:27 +08:00
(function(){"use strict";try{if(typeof document<"u"){var t=document.createElement("style");t.appendChild(document.createTextNode(".tk-justify-start{justify-content:flex-start}.tk-justify-center{justify-content:center}.tk-justify-end{justify-content:flex-end}.tk-justify-space-between{justify-content:space-between}.tk-justify-space-around{justify-content:space-around}.tk-justify-space-evenly{justify-content:space-evenly}.tk-align-center{align-items:center}.tk-align-start{align-items:flex-start}.tk-align-end{align-items:flex-end}.tk-align-stretch{align-items:stretch}.tk-align-baseline{align-items:baseline}.tk-blur{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.tk-round{border-radius:20px}.tk-circle{border-radius:100%}.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-justify-start{justify-content:flex-start}.tk-justify-center{justify-content:center}.tk-justify-end{justify-content:flex-end}.tk-justify-space-between{justify-content:space-between}.tk-justify-space-around{justify-content:space-around}.tk-justify-space-evenly{justify-content:space-evenly}.tk-align-center{align-items:center}.tk-align-start{align-items:flex-start}.tk-align-end{align-items:flex-end}.tk-align-stretch{align-items:stretch}.tk-align-baseline{align-items:baseline}.tk-blur{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.tk-round{border-radius:20px}.tk-circle{border-radius:100%}.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-justify-start{justify-content:flex-start}.tk-justify-center{justify-content:center}.tk-justify-end{justify-content:flex-end}.tk-justify-space-between{justify-content:space-between}.tk-justify-space-around{justify-content:space-around}.tk-justify-space-evenly{justify-content:space-evenly}.tk-align-center{align-items:center}.tk-align-start{align-items:flex-start}.tk-align-end{align-items:flex-end}.tk-align-stretch{align-items:stretch}.tk-align-baseline{align-items:baseline}.tk-blur{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.tk-round{border-radius:20px}.tk-circle{border-radius:100%}.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-justify-start{justify-content:flex-start}.tk-justify-center{justify-content:center}.tk-justify-end{justify-content:flex-end}.tk-justify-space-between{justify-content:space-between}.tk-justify-space-around{justify-content:space-around}.tk-justify-space-evenly{justify-content:space-evenly}.tk-align-center{align-items:center}.tk-align-start{align-items:flex-start}.tk-align-end{align-items:flex-end}.tk-align-stretch{align-items:stretch}.tk-align-baseline{align-items:baseline}.tk-blur{backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.tk-round{border-radius:20px}.tk-circle{border-radius:100%}.tk-loading{display:flex;align-items:center;flex-direction:column}.tk-loading .tk-loading_text{margin:10px}.tk-justify-start{justify-content:fle
import { TUICallEvent as f, TUICallEngine as wl } from "tuicall-engine-webrtc";
import { TUICore as HA, TUIConstants as H, TUILogin as Ol } from "@tencentcloud/tui-core";
import ma from "@tencentcloud/chat";
import Xt from "vue";
import { inject as NA, ref as I, onMounted as aA, onUnmounted as tA, toRefs as z, watch as J, computed as p, provide as gA, watchEffect as QA, toRef as wt, unref as xl, nextTick as Vl, reactive as Ye } from "@vue/composition-api";
var c = /* @__PURE__ */ ((A) => (A.CALL = "call", A.CUSTOM = "custom", A))(c || {}), F = /* @__PURE__ */ ((A) => (A[A.UNKNOWN = 0] = "UNKNOWN", A[A.AUDIO = 1] = "AUDIO", A[A.VIDEO = 2] = "VIDEO", A))(F || {}), K = /* @__PURE__ */ ((A) => (A.UNKNOWN = "unknown", A.CALLEE = "callee", A.CALLER = "caller", A))(K || {}), U = /* @__PURE__ */ ((A) => (A.IDLE = "idle", A.CALLING = "calling", A.CONNECTED = "connected", A))(U || {}), ne = /* @__PURE__ */ ((A) => (A.CONTAIN = "contain", A.COVER = "cover", A.FILL = "fill", A))(ne || {}), oe = /* @__PURE__ */ ((A) => (A.RESOLUTION_480P = "480p", A.RESOLUTION_720P = "720p", A.RESOLUTION_1080P = "1080p", A))(oe || {}), lo = /* @__PURE__ */ ((A) => (A.EN = "en", A["ZH-CN"] = "zh-cn", A.JA_JP = "ja_JP", A))(lo || {});
const nA = {
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"
}, bl = {
unknown: 0,
audio: 1,
video: 2
};
var Ae = /* @__PURE__ */ ((A) => (A.EAR = "ear", A.SPEAKER = "speaker", A))(Ae || {}), oA = /* @__PURE__ */ ((A) => (A.MICROPHONE = "microphone", A.CAMERA = "camera", A.SPEAKER = "speaker", A))(oA || {}), le = /* @__PURE__ */ ((A) => (A[A.FRONT = 0] = "FRONT", A[A.BACK = 1] = "BACK", A))(le || {}), zA = /* @__PURE__ */ ((A) => (A.Camera = "camera", A.Microphone = "microphone", A.SwitchCamera = "switchCamera", A.InviteUser = "inviteUser", A))(zA || {}), JA = /* @__PURE__ */ ((A) => (A.Open = "open", A.Close = "close", A))(JA || {}), At = /* @__PURE__ */ ((A) => (A.LOCAL = "local", A.REMOTE = "remote", A))(At || {}), et = /* @__PURE__ */ ((A) => (A.LocalInLargeView = "local", A.RemoteInLargeView = "remote", A))(et || {}), XA = /* @__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))(XA || {});
const ja = {
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
}, Bl = {
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 io = /* @__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))(io || {});
const Ke = {
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"
}, Fl = {
INNER_ATTR_KIT_INFO: "inner_attr_kit_info"
}, Rl = {
INITIAL_PUSHER: "initialPusher",
NEW_PUSHER: "newPusher"
}, o = {
PREFIX: "\u3010CallService\u3011",
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",
...Rl,
...Ke,
...Fl
}, kl = "https://web.sdk.qcloud.com/component/TUIKit/assets/call.png", Pl = "https://web.sdk.qcloud.com/component/TUIKit/assets/call-video-reverse.svg", va = 2147483647, Wl = 3, Gl = 4;
var Rt = /* @__PURE__ */ ((A) => (A.MAC = "mac", A.WIN = "win", A))(Rt || {}), _t = /* @__PURE__ */ ((A) => (A[A.TUI_CALL_KIT = 14] = "TUI_CALL_KIT", A[A.TIM_CALL_KIT = 15] = "TIM_CALL_KIT", A))(_t || {}), kt = /* @__PURE__ */ ((A) => (A[A.NUMBER_ROOM_ID = 1] = "NUMBER_ROOM_ID", A[A.STRING_ROOM_ID = 2] = "STRING_ROOM_ID", A))(kt || {});
async function Ql(A) {
if (!A)
return !1;
try {
const t = await new Promise((e, a) => {
const n = new XMLHttpRequest();
n.open("HEAD", A, !0), n.onload = () => e(n), n.onerror = () => a(n), n.send();
});
return t.status === 200 && t.getResponseHeader("Content-Type") === "audio/mpeg";
} catch (t) {
return console.warn(t), !1;
}
}
function tt(A) {
if (typeof A != "object" || A === null)
return A;
let t = Array.isArray(A) ? [] : {};
for (let e in A)
A.hasOwnProperty(e) && (t[e] = tt(A[e]));
return t;
}
const Zl = {
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",
"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.",
"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",
"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"
}, Yl = {
hangup: "\u6302\u65AD",
reject: "\u62D2\u7EDD",
accept: "\u63A5\u53D7",
camera: "\u6444\u50CF\u5934",
microphone: "\u9EA6\u514B\u98CE",
speaker: "\u626C\u58F0\u5668",
"open camera": "\u6253\u5F00\u6444\u50CF\u5934",
"close camera": "\u5173\u95ED\u6444\u50CF\u5934",
"open microphone": "\u6253\u5F00\u9EA6\u514B\u98CE",
"close microphone": "\u5173\u95ED\u9EA6\u514B\u98CE",
"video-to-audio": "\u8F6C\u8BED\u97F3\u901A\u8BDD",
"virtual-background": "\u6A21\u7CCA\u80CC\u666F",
"other side reject call": "\u5BF9\u65B9\u5DF2\u62D2\u7EDD",
"reject call": "\u62D2\u7EDD\u901A\u8BDD",
cancel: "\u53D6\u6D88\u901A\u8BDD",
"other side line busy": "\u5BF9\u65B9\u5FD9\u7EBF",
"in busy": "\u6B63\u5728\u5FD9",
"call timeout": "\u547C\u53EB\u8D85\u65F6",
"end call": "\u7ED3\u675F\u901A\u8BDD",
"caller calling message": "\u7B49\u5F85\u5BF9\u65B9\u63A5\u53D7\u9080\u8BF7",
"callee calling video message": "\u9080\u8BF7\u4F60\u89C6\u9891\u901A\u8BDD",
"callee calling audio message": "\u9080\u8BF7\u4F60\u8BED\u97F3\u901A\u8BDD",
"no microphone access": "\u6CA1\u6709\u9EA6\u514B\u98CE\u6743\u9650",
"no camera access": "\u6CA1\u6709\u6444\u50CF\u5934\u6743\u9650",
"invite member": "\u9080\u8BF7\u6210\u5458",
"Invited group call": "\u9080\u8BF7\u4F60\u52A0\u5165\u591A\u4EBA\u901A\u8BDD",
"Those involved": "\u53C2\u4E0E\u901A\u8BDD\u7684\u6709\uFF1A",
waiting: "\u7B49\u5F85\u63A5\u542C...",
me: "(\u6211)",
"browser-authorization": "\u6D4F\u89C8\u5668\u6388\u6743",
"mac-privacy": "\u7CFB\u7EDF\u504F\u597D\u8BBE\u7F6E -> \u5B89\u5168\u4E0E\u9690\u79C1 -> \u9690\u79C1",
"win-privacy": "\u8BBE\u7F6E -> \u9690\u79C1\u548C\u5B89\u5168\u6027 -> \u5E94\u7528\u6743\u9650",
"mac-preferences": "\u6253\u5F00\u7CFB\u7EDF\u504F\u597D\u8BBE\u7F6E",
"win-preferences": "\u6253\u5F00\u7CFB\u7EDF\u8BBE\u7F6E",
"Please enter userID": "\u8BF7\u8F93\u5165 userID",
"View more": "\u67E5\u770B\u66F4\u591A",
"people selected": "\u4EBA\u5DF2\u9009\u4E2D",
"Select all": "\u5168\u9009",
Cancel: "\u53D6\u6D88",
Done: "\u5B8C\u6210",
"exist group call": "\u5F53\u524D\u7FA4\u7EC4\u4E2D\u5DF2\u7ECF\u5B58\u5728\u7FA4\u7EC4\u901A\u8BDD",
"camera enabled": "\u6444\u50CF\u5934\u5DF2\u5F00",
"camera disabled": "\u6444\u50CF\u5934\u5DF2\u5173",
"microphone enabled": "\u9EA6\u514B\u98CE\u5DF2\u5F00",
"microphone disabled": "\u9EA6\u514B\u98CE\u5DF2\u5173",
"speaker enabled": "\u626C\u58F0\u5668\u5DF2\u5F00",
"speaker disabled": "\u626C\u58F0\u5668\u5DF2\u5173",
"open speaker": "\u5F00\u542F\u626C\u58F0\u5668",
"close speaker": "\u5173\u95ED\u626C\u58F0\u5668",
"wait to be called": "\u7B49\u5F85\u63A5\u542C",
answered: "\u5DF2\u63A5\u901A",
"people in the call": "\u4EBA\u53C2\u4E0E\u901A\u8BDD",
"failed to obtain speakers": "\u65E0\u6CD5\u83B7\u53D6\u626C\u58F0\u5668",
"you have a new call": "\u60A8\u6709\u4E00\u4E2A\u65B0\u7684\u901A\u8BDD",
"switch camera": "\u7FFB\u8F6C",
join: "\u52A0\u5165",
"people on the call": "\u4EBA\u6B63\u5728\u901A\u8BDD",
"Supports a maximum of 9 people for simultaneous calls": "\u6700\u591A\u652F\u63019\u4EBA\u540C\u65F6\u901A\u8BDD",
you: "(\u4F60)",
"The network is poor during your current call": "\u5F53\u524D\u901A\u8BDD\u4F60\u7684\u7F51\u7EDC\u4E0D\u4F73",
"The other user network is poor during the current call": "\u5F53\u524D\u901A\u8BDD\u5BF9\u65B9\u7F51\u7EDC\u4E0D\u4F73",
"TUICallKit init is not complete": "TUICallKit \u521D\u59CB\u5316\u767B\u5F55\u672A\u5B8C\u6210\uFF0C\u9700\u8981\u5728 init \u5B8C\u6210\u540E\u4F7F\u7528\u6B64 API",
"Video call": "\u53D1\u8D77\u89C6\u9891\u901A\u8BDD",
"Voice call": "\u53D1\u8D77\u8BED\u97F3\u901A\u8BDD",
"Call End": "\u901A\u8BDD\u7ED3\u675F",
"Switch voice call": "\u5207\u6362\u8BED\u97F3\u901A\u8BDD",
"Switch video call": "\u5207\u6362\u89C6\u9891\u901A\u8BDD",
"Call duration": "\u901A\u8BDD\u65F6\u957F",
"Call Cancel": "\u5DF2\u53D6\u6D88",
"Other Side Cancel": "\u5BF9\u65B9\u5DF2\u53D6\u6D88",
Decline: "\u5DF2\u62D2\u7EDD",
"Other Side Decline": "\u5BF9\u65B9\u5DF2\u62D2\u7EDD",
"No answer": "\u8D85\u65F6\u65E0\u5E94\u7B54",
"Other Side No Answer": "\u5BF9\u65B9\u65E0\u5E94\u7B54",
Answered: "\u5DF2\u63A5\u542C",
"Other Side Line Busy": "\u5BF9\u65B9\u5FD9\u7EBF\u4E2D",
"Line Busy": "\u5FD9\u7EBF\u65E0\u5E94\u7B54",
timeout: "\u8D85\u65F6",
"kick out": "\u88AB\u8E22",
call: "\u901A\u8BDD",
"video-call": "\u89C6\u9891\u901A\u8BDD",
"audio-call": "\u97F3\u9891\u901A\u8BDD",
search: "\u641C\u7D22",
"search-result": "\u641C\u7D22\u7ED3\u679C",
"Wechat scan right QR code": "\u5FAE\u4FE1\u626B\u53F3\u4E8C\u7EF4\u7801",
"Use-phone-and-computer": "\u7528\u624B\u673A\u4E0E\u7535\u8111\u4E92\u6253\u4F53\u9A8C\u89C6\u9891\u901A\u8BDD",
"Scan the QR code above": "\u626B\u63CF\u4E0A\u65B9\u4E8C\u7EF4\u7801",
"no-user": "\u672A\u641C\u7D22\u5230\u7528\u6237",
"member-not-added": "\u672A\u6DFB\u52A0\u6210\u5458",
"not-login": "\u672A\u767B\u5F55",
"login-status-expire": "\u767B\u5F55\u72B6\u6001\u5DF2\u5931\u6548\uFF0C\u8BF7\u5237\u65B0\u7F51\u9875\u91CD\u8BD5",
"experience-multi-call": "\u4F53\u9A8C\u591A\u4EBA\u901A\u8BDD\u8BF7\u4E0B\u8F7D\u5168\u529F\u80FDdemo:",
"not-support-multi-call": "\u591A\u4EBA\u901A\u8BDD\u63A5\u53E3\u672A\u5F00\u653E",
"input-phone-userID": "\u8BF7\u8F93\u5165\u624B\u673A\u53F7/\u7528\u6237ID",
userID: "\u7528\u6237ID",
"already-enter": "\u5DF2\u7ECF\u8FDB\u5165\u5F53\u524D\u901A\u8BDD",
"image-resolution": "\u5206\u8FA8\u7387",
"default-image-resolution": "\u9ED8\u8BA4\u5206\u8FA8\u7387",
"invited-person": "\u6DFB\u52A0\u6210\u5458",
"be-rejected": "\u5BF9\u65B9\u5DF2\u62D2\u7EDD\uFF0C",
"be-no-response": "\u5BF9\u65B9\u65E0\u5E94\u7B54\uFF0C",
"be-line-busy": "\u5BF9\u65B9\u5FD9\u7EBF\u4E2D\uFF0C",
"be-canceled": "\u5BF9\u65B9\u5DF2\u53D6\u6D88",
"voice-call-end": "\u8BED\u97F3\u901A\u8BDD\u7ED3\u675F",
"video-call-end": "\u89C6\u9891\u901A\u8BDD\u7ED3\u675F",
"method-call-failed": "\u540C\u6B65\u64CD\u4F5C\u5931\u8D25",
"failed-to-obtain-permission": "\u6743\u9650\u83B7\u53D6\u5931\u8D25",
"environment-detection-failed": "\u73AF\u5883\u68C0\u6D4B\u5931\u8D25",
"switchToAudioCall-call-failed": "\u5207\u8BED\u97F3\u8C03\u7528\u5931\u8D25",
"switchToVideoCall-call-failed": "\u5207\u89C6\u9891\u8C03\u7528\u5931\u8D25",
"microphone-unavailable": "\u6CA1\u6709\u53EF\u7528\u7684\u9EA6\u514B\u98CE\u8BBE\u5907",
"camera-unavailable": "\u6CA1\u6709\u53EF\u7528\u7684\u6444\u50CF\u5934\u8BBE\u5907",
"ban-device": "\u7528\u6237\u7981\u6B62\u4F7F\u7528\u8BBE\u5907",
"not-supported-webrtc": "\u5F53\u524D\u73AF\u5883\u4E0D\u652F\u6301 WebRTC",
"blacklist-user-tips": "\u53D1\u8D77\u901A\u8BDD\u5931\u8D25\uFF0C\u88AB\u5BF9\u65B9\u62C9\u5165\u9ED1\u540D\u5355\uFF0C\u7981\u6B62\u53D1\u8D77\uFF01",
"is-already-calling": "TUICallKit \u5DF2\u5728\u901A\u8BDD\u72B6\u6001",
"need-init": "TUICallKit \u53D1\u8D77\u901A\u8BDD\u524D\u9700\u4FDD\u8BC1 TUICallKitServer.init() \u65B9\u6CD5\u6267\u884C\u6210\u529F",
"can't call yourself": "\u4E0D\u80FD\u547C\u53EB\u81EA\u5DF1",
"accept-error": "\u63A5\u901A\u5931\u8D25",
"accept-device-error": "\u63A5\u901A\u5931\u8D25\uFF0C\u901A\u8BDD\u8BBE\u5907\u83B7\u53D6\u5931\u8D25",
"call-error": "\u53D1\u8D77\u901A\u8BDD\u5931\u8D25"
}, Xl = {
hangup: "\u901A\u8A71\u7D42\u4E86",
reject: "\u62D2\u5426",
accept: "\u5FDC\u7B54",
camera: "\u30AB\u30E1\u30E9",
microphone: "\u30DE\u30A4\u30AF",
speaker: "\u30B9\u30D4\u30FC\u30AB\u30FC",
"virtual-background": "\u30DC\u30B1\u80CC\u666F",
"other side reject call": "\u901A\u8A71\u304C\u62D2\u5426\u3055\u308C\u307E\u3057\u305F",
"reject call": "\u901A\u8A71\u62D2\u5426",
cancel: "\u901A\u8A71\u3092\u30AD\u30E3\u30F3\u30BB\u30EB",
"other side line busy": "\u76F8\u624B\u304C\u901A\u8A71\u4E2D\u3067\u3059",
"in busy": "\u901A\u8A71\u4E2D",
"call timeout": "\u547C\u3073\u51FA\u3057\u30BF\u30A4\u30E0\u30A2\u30A6\u30C8",
"end call": "\u901A\u8A71\u7D42\u4E86",
"caller calling message": "\u5FDC\u7B54\u3092\u5F85\u3063\u3066\u3044\u307E\u3059",
"callee calling video message": "\u30D3\u30C7\u30AA\u901A\u8A71\u306B\u62DB\u5F85\u3055\u308C\u307E\u3057\u305F",
"callee calling audio message": "\u97F3\u58F0\u901A\u8A71\u306B\u62DB\u5F85\u3055\u308C\u307E\u3057\u305F",
"no microphone access": "\u30DE\u30A4\u30AF\u306B\u30A2\u30AF\u30BB\u30B9\u3067\u304D\u307E\u305B\u3093",
"no camera access": "\u30AB\u30E1\u30E9\u306B\u30A2\u30AF\u30BB\u30B9\u3067\u304D\u307E\u305B\u3093",
"invite member": "\u30E1\u30F3\u30D0\u30FC\u3092\u62DB\u5F85\u3059\u308B",
"browser-authorization": "\u30D6\u30E9\u30A6\u30B6\u8A8D\u8A3C",
"mac-privacy": "\u30B7\u30B9\u30C6\u30E0\u74B0\u5883\u8A2D\u5B9A -> \u30BB\u30AD\u30E5\u30EA\u30C6\u30A3\u3068\u30D7\u30E9\u30A4\u30D0\u30B7\u30FC ->\u30D7\u30E9\u30A4\u30D0\u30B7\u30FC",
"win-privacy": "\u8A2D\u5B9A -> \u30BB\u30AD\u30E5\u30EA\u30C6\u30A3\u3068\u30D7\u30E9\u30A4\u30D0\u30B7\u30FC ->\u30A2\u30D7\u30EA\u306E\u30A2\u30AF\u30BB\u30B9\u8A31\u53EF",
"mac-preferences": "\u30B7\u30B9\u30C6\u30E0\u74B0\u5883\u8A2D\u5B9A\u3092\u958B\u304F",
"win-preferences": "\u30B7\u30B9\u30C6\u30E0\u8A2D\u5B9A\u3092\u958B\u304F",
"Please enter userID": "\u30E6\u30FC\u30B6\u30FCID\u3092\u5165\u529B\u3057\u3066\u304F\u3060\u3055\u3044",
"View more": "\u3082\u3063\u3068\u898B\u308B",
"people selected": "\u4EBA\u304C\u9078\u629E\u3055\u308C\u307E\u3057\u305F",
"Select all": "\u3059\u3079\u3066\u9078\u629E",
Cancel: "\u30AD\u30E3\u30F3\u30BB\u30EB",
Done: "\u5B8C\u4E86",
"exist group call": "\u73FE\u5728\u306E\u30B0\u30EB\u30FC\u30D7\u306B\u306F\u65E2\u306B\u30B0\u30EB\u30FC\u30D7\u901A\u8A71\u304C\u5B58\u5728\u3057\u3066\u3044\u307E\u3059",
"Video call": "\u30D3\u30C7\u30AA\u901A\u8A71\u3092\u958B\u59CB",
"Voice call": "\u97F3\u58F0\u901A\u8A71\u3092\u958B\u59CB",
"Call End": "\u901A\u8A71\u7D42\u4E86",
"Switch audio call": "\u97F3\u58F0\u901A\u8A71\u306B\u5207\u308A\u66FF\u3048\u308B",
"Switch video call": "\u30D3\u30C7\u30AA\u901A\u8A71\u306B\u5207\u308A\u66FF\u3048\u308B",
"Call duration": "\u901A\u8A71\u6642\u9593",
"Call Cancel": "\u901A\u8A71\u3092\u30AD\u30E3\u30F3\u30BB\u30EB\u3059\u308B",
"Other Side Cancel": "\u76F8\u624B\u304C\u30AD\u30E3\u30F3\u30BB\u30EB\u3057\u307E\u3057\u305F",
Decline: "\u901A\u8A71\u3092\u62D2\u5426\u3059\u308B",
"Other Side Decline": "\u76F8\u624B\u304C\u62D2\u5426\u3057\u307E\u3057\u305F",
"No answer": "\u7121\u5FDC\u7B54",
"Other Side No Answer": "\u76F8\u624B\u304B\u3089\u306E\u8FD4\u7B54\u306F\u3042\u308A\u307E\u305B\u3093",
Answered: "\u5FDC\u7B54\u3057\u307E\u3057\u305F",
"Other Side Line Busy": "\u76F8\u624B\u306F\u73FE\u5728\u5FD9\u3057\u304F\u3066\u5BFE\u5FDC\u3067\u304D\u307E\u305B\u3093",
"Line Busy": "\u5FD9\u3057\u3044\u306E\u3067\u5FDC\u7B54\u3067\u304D\u307E\u305B\u3093",
"open camera": "\u30AA\u30FC\u30D7\u30F3\u30AB\u30E1\u30E9",
"close camera": "\u30AB\u30E1\u30E9\u3092\u9589\u3058\u308B",
"open microphone": "\u30AA\u30FC\u30D7\u30F3\u30DE\u30A4\u30AF",
"close microphone": "\u30DE\u30A4\u30AF\u3092\u9589\u3058\u308B",
"camera enabled": "\u30AB\u30E1\u30E9\u30AA\u30F3",
"camera disabled": "\u30AB\u30E1\u30E9\u30AA\u30D5",
"microphone enabled": "\u30DE\u30A4\u30AF\u30AA\u30F3",
"microphone disabled": "\u30DE\u30A4\u30AF\u30AA\u30D5",
"speaker enabled": "\u30B9\u30D4\u30FC\u30AB\u30FC\u30AA\u30F3",
"speaker disabled": "\u30B9\u30D4\u30FC\u30AB\u30FC\u30AA\u30D5",
"open speaker": "\u30B9\u30D4\u30FC\u30AB\u30FC\u3092\u30AA\u30F3\u306B\u3059\u308B",
"close speaker": "\u30B9\u30D4\u30FC\u30AB\u30FC\u306E\u96FB\u6E90\u3092\u5207\u308A\u307E\u3059",
"wait to be called": "\u5F85\u6A5F\u4E2D",
answered: "\u63A5\u7D9A\u6E08\u307F",
"people in the call": "\u901A\u8A71\u306B\u53C2\u52A0\u3057\u3066\u3044\u308B\u4EBA\u305F\u3061",
"failed to obtain speakers": "\u30B9\u30D4\u30FC\u30AB\u30FC\u304C\u898B\u3064\u304B\u308A\u307E\u305B\u3093",
"you have a new call": "\u65B0\u3057\u3044\u901A\u8A71\u304C\u3042\u308A\u307E\u3059",
"switch camera": "\u5207\u308A\u66FF\u3048",
join: "\u53C2\u52A0\u3059\u308B",
"people on the call": "\u4EBA\u304C\u901A\u8A71\u4E2D\u3067\u3059",
"Supports a maximum of 9 people for simultaneous calls": "\u6700\u5927\u30679\u4EBA\u307E\u3067\u540C\u6642\u901A\u8A71\u304C\u53EF\u80FD\u3067\u3059",
you: "(\u3042\u306A\u305F)",
"The network is poor during your current call": "\u73FE\u5728\u306E\u901A\u8A71\u3067\u3001\u3042\u306A\u305F\u306E\u30CD\u30C3\u30C8\u30EF\u30FC\u30AF\u306F\u4E0D\u826F\u3067\u3059",
"The other user network is poor during the current call": "\u73FE\u5728\u306E\u901A\u8A71\u3067\u3001\u76F8\u624B\u5074\u306E\u30CD\u30C3\u30C8\u30EF\u30FC\u30AF\u304C\u4E0D\u826F\u3067\u3059",
"TUICallKit init is not complete": "TUICallKit\u306E\u521D\u671F\u5316\u30ED\u30B0\u30A4\u30F3\u304C\u5B8C\u4E86\u3057\u3066\u3044\u307E\u305B\u3093\u3002init \u304C\u5B8C\u4E86\u3057\u305F\u5F8C\u306B\u3053\u306EAPI\u3092\u4F7F\u7528\u3059\u308B\u5FC5\u8981\u304C\u3042\u308A\u307E\u3059\u3002",
timeout: "\u30BF\u30A4\u30E0\u30A2\u30A6\u30C8",
"kick out": "\u30AD\u30C3\u30AF\u30A2\u30A6\u30C8\u3055\u308C\u307E\u3057\u305F",
"Invited group call": "\u30B0\u30EB\u30FC\u30D7\u901A\u8A71\u306B\u62DB\u5F85\u3055\u308C\u307E\u3057\u305F\u3002",
"Those involved": "\u53C2\u52A0\u8005\uFF1A",
call: "\u901A\u8A71",
"video-call": "\u30D3\u30C7\u30AA\u901A\u8A71",
"audio-call": "\u97F3\u58F0\u901A\u8A71",
search: "\u691C\u7D22",
"search-result": "\u691C\u7D22\u7D50\u679C",
"Wechat scan right QR code": "WeChat\u3067\u53F3\u5074\u306B\u3042\u308BQR\u30B3\u30FC\u30C9\u3092\u8AAD\u307F\u53D6\u308A\u307E\u3059\u3002",
"Use-phone-and-computer": "\u643A\u5E2F\u96FB\u8A71\u3068\u30B3\u30F3\u30D4\u30E5\u30FC\u30BF\u3092\u4F7F\u7528\u3057\u3066\u30D3\u30C7\u30AA\u901A\u8A71\u3092\u4F53\u9A13\u3057\u3066\u304F\u3060\u3055\u3044",
"Scan the QR code above": "\u4E0A\u306EQR\u30B3\u30FC\u30C9\u3092\u8AAD\u307F\u53D6\u308A\u307E\u3059\u3002",
"no-user": "\u30E6\u30FC\u30B6\u30FC\u304C\u898B\u3064\u304B\u308A\u307E\u305B\u3093\u3067\u3057\u305F",
"member-not-added": "\u30E1\u30F3\u30D0\u30FC\u304C\u8FFD\u52A0\u3055\u308C\u3066\u3044\u307E\u305B\u3093",
"not-login": "\u30ED\u30B0\u30A4\u30F3\u3057\u3066\u3044\u307E\u305B\u3093",
"login-status-expire": "\u30ED\u30B0\u30A4\u30F3\u306E\u6709\u52B9\u671F\u9650\u304C\u904E\u304E\u3066\u3044\u307E\u3059\u3002\u30DA\u30FC\u30B8\u3092\u66F4\u65B0\u3057\u3066\u3082\u3046\u4E00\u5EA6\u304A\u8A66\u3057\u304F\u3060\u3055\u3044",
"experience-multi-call": "\u8907\u6570\u4EBA\u3067\u540C\u6642\u306B\u97F3\u58F0\u901A\u8A71\u3067\u304D\u308B\u30B0\u30EB\u30FC\u30D7\u901A\u8A71\u6A5F\u80FD\u3092\u4F53\u9A13\u3059\u308B\u306B\u306F\u3001\u5168\u6A5F\u80FD\u306E\u30C7\u30E2\u3092\u30C0\u30A6\u30F3\u30ED\u30FC\u30C9\u3057\u3066\u304F\u3060\u3055\u3044",
"not-support-multi-call": "\u30B0\u30EB\u30FC\u30D7\u901A\u8A71\u30A4\u30F3\u30BF\u30FC\u30D5\u30A7\u30A4\u30B9\u304C\u958B\u3044\u3066\u3044\u307E\u305B\u3093",
"input-phone-userID": "\u643A\u5E2F\u96FB\u8A71\u756A\u53F7/\u30E6\u30FC\u30B6\u30FCID\u3092\u5165\u529B\u3057\u3066\u304F\u3060\u3055\u3044",
userID: "\u30E6\u30FC\u30B6\u30FCID",
"already-enter": "\u3059\u3067\u306B\u901A\u8A71\u306B\u53C2\u52A0\u3057\u3066\u3044\u307E\u3059",
waiting: "\u5FDC\u7B54\u3092\u5F85\u3063\u3066\u3044\u307E\u3059...",
"camera-opened": "\u30AB\u30E1\u30E9\u304C\u30AA\u30F3\u306B\u306A\u3063\u3066\u3044\u307E\u3059",
"camera-closed": "\u30AB\u30E1\u30E9\u304C\u30AA\u30D5\u306B\u306A\u3063\u3066\u3044\u307E\u3059",
"microphone-opened": "\u30DE\u30A4\u30AF\u304C\u30AA\u30F3\u306B\u306A\u3063\u3066\u3044\u307E\u3059",
"microphone-closed": "\u30DE\u30A4\u30AF\u304C\u30AA\u30D5\u306B\u306A\u3063\u3066\u3044\u307E\u3059",
"image-resolution": "\u89E3\u50CF\u5EA6",
"default-image-resolution": "\u30C7\u30D5\u30A9\u30EB\u30C8\u89E3\u50CF\u5EA6",
"invited-person": "\u30E1\u30F3\u30D0\u30FC\u3092\u62DB\u5F85",
"video-to-audio": "\u97F3\u58F0\u901A\u8A71\u306B\u5207\u308A\u66FF\u3048\u307E\u3059",
me: "(\u81EA\u5206)",
"be-rejected": "\u901A\u8A71\u304C\u62D2\u5426\u3055\u308C\u307E\u3057\u305F, ",
"be-no-response": "\u5FDC\u7B54\u306A\u3057, ",
"be-line-busy": "\u76F8\u624B\u304C\u901A\u8A71\u4E2D\u3067\u3059, ",
"be-canceled": "\u76F8\u624B\u304C\u901A\u8A71\u3092\u30AD\u30E3\u30F3\u30BB\u30EB\u3057\u307E\u3057\u305F",
"voice-call-end": "\u97F3\u58F0\u901A\u8A71\u304C\u7D42\u4E86\u3057\u307E\u3057\u305F",
"video-call-end": "\u30D3\u30C7\u30AA\u901A\u8A71\u304C\u7D42\u4E86\u3057\u307E\u3057\u305F",
"method-call-failed": "\u64CD\u4F5C\u306E\u540C\u671F\u306B\u5931\u6557\u3057\u307E\u3057\u305F",
"failed-to-obtain-permission": "\u6A29\u9650\u306E\u53D6\u5F97\u306B\u5931\u6557\u3057\u307E\u3057\u305F",
"environment-detection-failed": "\u74B0\u5883\u306E\u691C\u51FA\u306B\u5931\u6557\u3057\u307E\u3057\u305F",
"switchToAudioCall-call-failed": "\u97F3\u58F0\u901A\u8A71\u306B\u5207\u308A\u66FF\u3048\u308B\u3053\u3068\u306F\u3067\u304D\u307E\u305B\u3093",
"switchToVideoCall-call-failed": "\u30D3\u30C7\u30AA\u901A\u8A71\u306B\u5207\u308A\u66FF\u3048\u308B\u3053\u3068\u306F\u3067\u304D\u307E\u305B\u3093",
"microphone-unavailable": "\u4F7F\u7528\u3067\u304D\u308B\u30DE\u30A4\u30AF\u304C\u3042\u308A\u307E\u305B\u3093",
"camera-unavailable": "\u4F7F\u7528\u3067\u304D\u308B\u30AB\u30E1\u30E9\u304C\u3042\u308A\u307E\u305B\u3093",
"ban-device": "\u30C7\u30D0\u30A4\u30B9\u3078\u306E\u30A2\u30AF\u30BB\u30B9\u304C\u62D2\u5426\u3055\u308C\u307E\u3057\u305F",
"not-supported-webrtc": "\u73FE\u5728\u306E\u74B0\u5883\u306FWebRTC\u3092\u30B5\u30DD\u30FC\u30C8\u3057\u3066\u3044\u307E\u305B\u3093",
"blacklist-user-tips": "\u30E6\u30FC\u30B6\u30FC\u306F\u30D6\u30E9\u30C3\u30AF\u30EA\u30B9\u30C8\u306B\u767B\u9332\u3055\u308C\u3001\u901A\u8A71\u304C\u958B\u59CB\u3067\u304D\u307E\u305B\u3093\u3067\u3057\u305F",
"is-already-calling": "TUICallKit \u306F\u3059\u3067\u306B\u901A\u8A71\u4E2D\u3067\u3059",
"need-init": "TUICallKit\u3067\u901A\u8A71\u3092\u958B\u59CB\u3059\u308B\u524D\u306B\u3001TUICallKitServer.init() \u30E1\u30BD\u30C3\u30C9\u304C\u6B63\u5E38\u306B\u5B9F\u884C\u3055\u308C\u305F\u3053\u3068\u3092\u78BA\u8A8D\u3057\u3066\u304F\u3060\u3055\u3044\u3002",
"can't call yourself": "\u81EA\u5206\u306B\u96FB\u8A71\u3092\u304B\u3051\u308B\u3053\u3068\u304C\u3067\u304D\u307E\u305B\u3093",
"accept-error": "\u63A5\u7D9A\u3067\u304D\u307E\u305B\u3093\u3067\u3057\u305F",
"accept-device-error": "\u63A5\u7D9A\u3067\u304D\u307E\u305B\u3093\u3067\u3057\u305F\u3002\u767A\u4FE1\u5074\u30C7\u30D0\u30A4\u30B9\u3092\u8A8D\u8A3C\u3067\u304D\u307E\u305B\u3093",
"call-error": "\u901A\u8A71\u304C\u958B\u59CB\u3067\u304D\u307E\u305B\u3093\u3067\u3057\u305F"
}, sA = {
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"
}, fa = {
en: Zl,
"zh-cn": Yl,
ja_JP: Xl
};
function v(A) {
var a;
const t = d.getData(c.CALL, o.LANGUAGE);
for (const n in fa)
if (n === t) {
const l = fa[n];
for (const i in l)
if (i === A)
return l[i];
}
const e = (a = A.en) == null ? void 0 : a.key;
return console.error(`${o.PREFIX}translation is not found: ${A}.`), e;
}
const at = typeof wx < "u" && typeof wx.getSystemInfoSync == "function" && Boolean(wx.getSystemInfoSync().fontSizeSetting), so = typeof uni < "u" && typeof uni > "u", La = at || so, uo = typeof uni < "u", co = function() {
return (typeof uni < "u" || typeof window < "u") && !La;
}(), _l = function() {
return at ? wx : uo ? uni : window;
}(), wA = co && window && window.navigator && window.navigator.userAgent || "", ql = /Android/i.test(wA), Jl = /(?:Windows Phone)/.test(wA), Hl = /(?:SymbianOS)/.test(wA), Kl = /iPad/i.test(wA) || /iPhone/i.test(wA) || /iPod/i.test(wA), ro = ql || Jl || Hl || Kl, qt = co && !ro, $l = qt && wA.includes("Windows NT"), Ai = qt && wA.includes("Mac");
class kA {
constructor() {
this.global = _l, 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();
}
static getInstance() {
return kA.instance || (kA.instance = new kA()), kA.instance;
}
initEnv() {
this.isPC = qt, this.isH5 = ro, this.isWeChat = at, this.isApp = so && !at, this.isUniPlatform = uo, this.isWIN = $l, this.isMAC = Ai;
}
initOfficial(t) {
this.isOfficial = t === 1400187352 || t === 1400188366;
}
}
const Et = function(A) {
return typeof A === o.UNDEFINED;
}, Mo = function(A) {
if (typeof A !== o.OBJECT || A === null)
return !1;
const t = Object.getPrototypeOf(A);
if (t === null)
return !0;
let e = t;
for (; Object.getPrototypeOf(e) !== null; )
e = Object.getPrototypeOf(e);
return t === e;
}, Io = function(A) {
return typeof Array.isArray === o.FUNCTION ? Array.isArray(A) : Object.prototype.toString.call(A).match(/^\[object (.*)\]$/)[1].toLowerCase() === o.ARRAY;
}, Pt = function(A) {
return typeof A === o.STRING;
}, ei = function(A) {
return typeof A === o.BOOLEAN;
}, go = function(A) {
return A !== null && (typeof A === o.NUMBER && !isNaN(A - 0) || typeof A === o.OBJECT && A.constructor === Number);
};
function No(A) {
const t = Math.floor(A / 3600), e = Math.floor(A % 3600 / 60), a = Math.floor(A % 60);
let n = t > 9 ? `${t}` : `0${t}`;
return n += e > 9 ? `:${e}` : `:0${e}`, n += a > 9 ? `:${a}` : `:0${a}`, n;
}
function ti(A) {
if (typeof A === o.STRING)
try {
return !!JSON.parse(A);
} catch (t) {
return console.debug(t), !1;
}
return !1;
}
const Xe = function(A) {
return !A || !ti(A) ? A : JSON.parse(A);
};
function Ua(A) {
return (A == null ? void 0 : A.message.indexOf("is ongoing, please avoid repeated calls")) !== -1;
}
function ai(A) {
const { message: t } = A;
return t.indexOf("NotAllowedError: Permission denied") !== -1;
}
function Ot() {
return Date.now();
}
const $e = function(A) {
return typeof A === o.FUNCTION;
}, ni = () => {
if (kA.getInstance().isWeChat)
return "zh-cn";
const A = ((navigator == null ? void 0 : navigator.language) || (navigator == null ? void 0 : navigator.userLanguage) || "").substr(0, 2);
let t = "en";
switch (A) {
case "zh":
t = "zh-cn";
break;
case "ja":
t = "ja_JP";
break;
default:
t = "en";
}
return t;
}, oi = function(A) {
return Object.prototype.toString.call(A).match(/^\[object (.*)\]$/)[1].toLowerCase();
};
function li(A, t, e) {
if (!A.hasOwnProperty(t))
return A;
const a = {};
return Object.keys(A).forEach((n) => {
n === t ? a[e] = A[n] : a[n] = A[n];
}), a;
}
const ii = "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 si {
constructor() {
this._bellContext = null, this._isMuteBell = !1, this._calleeBellFilePath = za, this._callRole = K.UNKNOWN, this._callStatus = U.IDLE, this._bellContext = new Audio(), this._bellContext.loop = !0;
}
setBellSrc() {
try {
let t = ii;
this._callRole === K.CALLEE && (t = this._calleeBellFilePath || za), this._bellContext.src = t;
} catch (t) {
console.warn(`${o.PREFIX}Failed to setBellSrc, ${t}`);
}
}
setBellProperties(t) {
this._callRole = t.callRole || this._callRole, this._callStatus = t.callStatus || this._callStatus, this._calleeBellFilePath = t.calleeBellFilePath || this._calleeBellFilePath, this._isMuteBell = Et(t.isMuteBell) ? this._isMuteBell : t.isMuteBell;
}
async play() {
try {
if (this._callStatus !== U.CALLING)
return;
this.setBellSrc(), this._callRole === K.CALLEE && !this._isMuteBell && await this._bellContext.play(), this._callRole === K.CALLER && await this._bellContext.play();
} catch (t) {
console.warn(`${o.PREFIX}Failed to play audio file, ${t}`);
}
}
async stop() {
try {
await this._bellContext.pause();
} catch (t) {
console.warn(`${o.PREFIX}Failed to stop audio file, ${t}`);
}
}
async setBellMute(t) {
this._callStatus !== U.CALLING && this._callRole !== K.CALLEE || (t ? await this.stop() : await this.play());
}
destroy() {
try {
this._isMuteBell = !1, this._calleeBellFilePath = "", this._callRole = K.UNKNOWN, this._callStatus = U.IDLE, this._bellContext.pause(), this._bellContext = null;
} catch (t) {
console.warn(`${o.PREFIX}Failed to destroy, ${t}`);
}
}
}
function $() {
return function(A, t, e) {
const a = e.value, n = /* @__PURE__ */ new Set();
return e.value = async function(...l) {
var i, u;
if (n.has(this)) {
console.warn(`${o.PREFIX}previous ${t}() is ongoing, please avoid repeated calls`), (u = (i = this == null ? void 0 : this.getTUICallEngineInstance()) == null ? void 0 : i.reportLog) == null || u.call(i, {
name: "TUICallKit.avoidRepeatedCall.fail",
data: { name: t },
error: `previous ${t}() is ongoing`
});
return;
}
try {
n.add(this);
const s = await a.apply(this, l);
return n.delete(this), s;
} catch (s) {
throw n.delete(this), s;
}
}, e;
};
}
const KA = o.PREFIX + "API";
function cA(A) {
return function(t, e, a) {
let n = a.value;
return a.value = function(...l) {
return ui.call(this, A, l, e), n.apply(this, l);
}, a;
};
}
function ui(A, t, e) {
try {
if (t[0].SDKAppID || (A = li(A, "SDKAppID", "sdkAppID")), Io(A))
for (let a = 0; a < A.length; a++)
wa.call(this, {
...A[a],
value: t[a],
name: e
});
else
for (const a in A)
A.hasOwnProperty(a) && wa.call(this, {
...A[a],
value: t[0][a],
name: e,
key: a
});
} catch (a) {
throw console.error(a), a;
}
}
function wa({ required: A, rules: t, range: e, value: a, allowEmpty: n, name: l, key: i }) {
if (Et(a)) {
if (A)
throw new Error(`${KA}<${l}>: ${i} is required.`);
return;
}
const u = t.some((r) => r === oi(a));
let s = "";
if (!u) {
for (let r = 0; r < t.length; r++) {
let M = t[r];
M = M.replace(M[0], M[0].toUpperCase()), s += `${M}/`;
}
throw s = s.substring(0, s.length - 1), new Error(`${KA}<${l}>: ${i} must be ${s}, current ${i} is ${typeof a}.`);
}
if (n === !1 && Pt(a) && a.trim() === "")
throw new Error(`${KA}<${l}>: ${i} is blank.`);
if (Io(e) && e && e.indexOf(a) === -1)
throw new Error(`${KA}<${l}>: ${i} error, only be ${e}, current ${i} is ${a}.`);
if (Pt(e) && e.indexOf("~") !== -1) {
const r = e.split("~");
if (a < +r[0] || a > +r[1] || go(a) && Number.isNaN(a))
throw new Error(`${KA}<${l}>: ${i} error, only be ${e}, current ${i} is ${a}.`);
}
}
const rA = {
init: {
SDKAppID: {
required: !0,
rules: [o.NUMBER],
allowEmpty: !1
},
userID: {
required: !0,
rules: [o.STRING],
allowEmpty: !1
},
userSig: {
required: !0,
rules: [o.STRING],
allowEmpty: !1
},
tim: {
required: !1,
rules: [o.OBJECT]
}
},
call: {
userID: {
required: !0,
rules: [o.STRING],
allowEmpty: !1
},
type: {
required: !0,
rules: [o.NUMBER],
range: [1, 2],
allowEmpty: !1
},
roomID: {
required: !1,
rules: [o.NUMBER],
range: `0~${va}`,
allowEmpty: !1
},
strRoomID: {
required: !1,
rules: [o.STRING],
allowEmpty: !0
},
userData: {
required: !1,
rules: [o.STRING],
allowEmpty: !1
},
timeout: {
required: !1,
rules: [o.NUMBER],
allowEmpty: !1
}
},
groupCall: {
userIDList: {
required: !0,
rules: [o.ARRAY],
allowEmpty: !1
},
type: {
required: !0,
rules: [o.NUMBER],
range: [1, 2],
allowEmpty: !1
},
groupID: {
required: !0,
rules: [o.STRING],
allowEmpty: !1
},
roomID: {
required: !1,
rules: [o.NUMBER],
range: `0~${va}`,
allowEmpty: !1
},
strRoomID: {
required: !1,
rules: [o.STRING],
allowEmpty: !0
},
timeout: {
required: !1,
rules: [o.NUMBER],
allowEmpty: !1
},
userData: {
required: !1,
rules: [o.STRING],
allowEmpty: !1
},
offlinePushInfo: {
required: !1,
rules: [o.OBJECT],
allowEmpty: !1
}
},
joinInGroupCall: {
type: {
required: !0,
rules: [o.NUMBER],
range: [1, 2],
allowEmpty: !1
},
groupID: {
required: !0,
rules: [o.STRING],
allowEmpty: !1
},
roomID: {
required: !0,
rules: [o.NUMBER],
allowEmpty: !1
},
strRoomID: {
required: !1,
rules: [o.STRING],
allowEmpty: !0
}
},
inviteUser: {
userIDList: {
required: !0,
rules: [o.ARRAY],
allowEmpty: !1
}
},
setSelfInfo: {
nickName: {
required: !1,
rules: [o.STRING],
allowEmpty: !1
},
avatar: {
required: !1,
rules: [o.STRING],
allowEmpty: !1
}
},
enableFloatWindow: [
{
key: "enable",
required: !1,
rules: [o.BOOLEAN],
allowEmpty: !1
}
],
enableAIVoice: [
{
key: "enable",
required: !0,
rules: [o.BOOLEAN],
allowEmpty: !1
}
],
enableMuteMode: [
{
key: "enable",
required: !0,
rules: [o.BOOLEAN],
allowEmpty: !1
}
],
setCallingBell: [
{
key: "filePath",
required: !1,
rules: [o.STRING],
allowEmpty: !0
}
],
setLanguage: [
{
key: "language",
required: !0,
rules: [o.STRING],
allowEmpty: !1
}
],
setVideoDisplayMode: [
{
key: "displayMode",
required: !0,
rules: [o.STRING],
range: [ne.CONTAIN, ne.COVER, ne.FILL],
allowEmpty: !1
}
],
setVideoResolution: [
{
key: "resolution",
required: !0,
rules: [o.STRING],
range: [oe.RESOLUTION_1080P, oe.RESOLUTION_480P, oe.RESOLUTION_720P],
allowEmpty: !1
}
]
};
function ht(A) {
return function(t, e, a) {
let n = a.value;
return a.value = function(...l) {
return ci.call(this, A, l, e), n.apply(this, l);
}, a;
};
}
function ci(A) {
if ((A == null ? void 0 : A.engineInstance) && !this._tuiCallEngine) {
const t = `${o.PREFIX} ${v("TUICallKit init is not complete")}`;
throw console.error(t), t;
}
}
class ri {
constructor() {
this.defaultStore = {
callStatus: U.IDLE,
callRole: K.UNKNOWN,
callMediaType: F.UNKNOWN,
localUserInfo: { userId: "" },
localUserInfoExcludeVolume: { userId: "" },
remoteUserInfoList: [],
remoteUserInfoExcludeVolumeList: [],
callerUserInfo: { userId: "" },
isGroup: !1,
callDuration: "00:00:00",
callTips: "",
toastInfo: { text: "" },
isMinimized: !1,
enableFloatWindow: !1,
bigScreenUserId: "",
language: ni(),
isClickable: !1,
deviceList: { cameraList: [], microphoneList: [], currentCamera: {}, currentMicrophone: {} },
showPermissionTip: !1,
netWorkQualityList: [],
isMuteSpeaker: !1,
groupID: "",
roomID: 0,
roomIdType: 0,
cameraPosition: le.FRONT,
groupCallMembers: [],
displayMode: ne.COVER,
videoResolution: oe.RESOLUTION_480P,
showSelectUser: !1,
pusher: {},
player: [],
isEarPhone: !1,
pusherId: o.INITIAL_PUSHER,
isShowEnableVirtualBackground: !1,
enableVirtualBackground: !1,
customUIConfig: {
button: {},
viewBackground: {},
layoutMode: et.RemoteInLargeView
}
}, this.store = tt(this.defaultStore), this.prevStore = tt(this.defaultStore);
}
update(t, e) {
switch (t) {
case o.CALL_TIPS:
const a = this.getData(t);
this.prevStore[t] = a;
default:
this.store[t] = e;
}
}
getPrevData(t) {
return t ? this.prevStore[t] : this.prevStore;
}
getData(t) {
return t ? this.store[t] : this.store;
}
reset(t = []) {
t.length === 0 && (t = Object.keys(this.store));
const e = t.reduce((a, n) => ({ ...a, [n]: this.defaultStore[n] }), {});
this.store = {
...this.defaultStore,
...this.store,
...e
};
}
}
class yA {
constructor() {
this.timerId = -1, this.storeMap = {
[c.CALL]: new ri()
}, this.task = {};
}
static getInstance() {
return yA.instance || (yA.instance = new yA()), yA.instance;
}
watch(t, e, a) {
this.task[t] || (this.task[t] = {});
const n = this.task[t];
Object.keys(e).forEach((l) => {
const i = e[l];
n[l] || (n[l] = /* @__PURE__ */ new Map()), n[l].set(i, 1);
const { notifyRangeWhenWatch: u } = a || {};
if (u === o.ALL && this.notify(t, l), u === o.MYSELF) {
const s = this.getData(t, l);
i.call(this, s);
}
});
}
unwatch(t, e) {
if (!this.task[t])
return;
const a = this.task[t];
Object.keys(e).forEach((n) => {
a[n].delete(e[n]);
});
}
update(t, e, a) {
var n;
(Pt(a) || go(a) || ei(a)) && this.storeMap[t].store[e] === a || ((n = this.storeMap[t]) == null || n.update(e, a), this.notify(t, e));
}
getPrevData(t, e) {
var a;
return (a = this.storeMap[t]) == null ? void 0 : a.getPrevData(e);
}
getData(t, e) {
var a;
return (a = this.storeMap[t]) == null ? void 0 : a.getData(e);
}
notify(t, e) {
if (!this.task[t])
return;
const a = this.task[t];
if (a[e]) {
const n = a[e], l = this.getData(t, e);
for (const [i] of n.entries())
i.call(this, l);
}
}
reset(t, e = [], a = !1) {
if (t in this.storeMap) {
const n = this.storeMap[t];
e.length === 0 && (e = Object.keys(n == null ? void 0 : n.store)), n.reset(e), a && e.forEach((l) => {
this.notify(t, l);
});
}
}
updateStore(t, e) {
const a = e || c.CALL;
Object.keys(t).forEach((n) => {
this.update(a, n, t[n]);
});
}
}
const W = yA.getInstance();
function Wt(A, t) {
const e = {
userId: A,
nick: "",
avatar: "",
remark: "",
displayUserInfo: "",
isAudioAvailable: !1,
isVideoAvailable: !1,
isEnter: !1,
domId: t || A
};
return t ? e : { ...e, isEnter: !1 };
}
async function Mi(A, t) {
var a, n, l, i, u;
let e = Wt(A, o.LOCAL_VIDEO);
try {
if (!t)
return e;
const s = await t.getMyProfile(), r = W == null ? void 0 : W.getData(c.CALL, o.LOCAL_USER_INFO);
return (s == null ? void 0 : s.code) === 0 && (e = {
...e,
...r,
userId: (a = s == null ? void 0 : s.data) == null ? void 0 : a.userID,
nick: (n = s == null ? void 0 : s.data) == null ? void 0 : n.nick,
avatar: (l = s == null ? void 0 : s.data) == null ? void 0 : l.avatar,
displayUserInfo: ((i = s == null ? void 0 : s.data) == null ? void 0 : i.nick) || ((u = s == null ? void 0 : s.data) == null ? void 0 : u.userID)
}), e;
} catch (s) {
return console.error(`${o.PREFIX}getMyProfile failed, error: ${s}.`), e;
}
}
async function ie(A, t) {
let e = A.map((a) => Wt(a));
try {
if (!t)
return e;
const a = await t.getFriendProfile({ userIDList: A });
if (a.code === 0) {
const { friendList: n = [], failureUserIDList: l = [] } = a.data;
let i = l.map((M) => M.userID);
if (l.length > 0) {
const M = await t.getUserProfile({ userIDList: l.map((D) => D.userID) });
(M == null ? void 0 : M.code) === 0 && (i = (M == null ? void 0 : M.data) || []);
}
const u = W == null ? void 0 : W.getData(c.CALL, o.REMOTE_USER_INFO_LIST), s = n.map((M) => M.userID), r = i.map((M) => M.userID);
e = A.map((M) => {
var L, m, k, _, Z, b, P;
const D = Wt(M), g = s.indexOf(M), N = r.indexOf(M);
let y = "", T = "", C = "", E = "";
g !== -1 && (y = ((L = n[g]) == null ? void 0 : L.remark) || "", T = ((k = (m = n[g]) == null ? void 0 : m.profile) == null ? void 0 : k.nick) || "", C = y || T || D.userId || "", E = ((Z = (_ = n[g]) == null ? void 0 : _.profile) == null ? void 0 : Z.avatar) || ""), N !== -1 && (T = ((b = i[N]) == null ? void 0 : b.nick) || "", C = T || D.userId || "", E = ((P = i[N]) == null ? void 0 : P.avatar) || "");
const w = u.find((AA) => AA.userId === M) || {};
return { ...D, ...w, remark: y, nick: T, displayUserInfo: C, avatar: E };
});
}
return e;
} catch (a) {
return console.error(`${o.PREFIX}getRemoteUserProfile failed, error: ${a}.`), e;
}
}
function vA(A, t, e) {
const a = W.getData(c.CALL, o.IS_GROUP);
let n = `${v(A)}`;
return a && (n = t ? `${t} ${n}` : n, n = e ? `${n} ${e}` : n), n;
}
function _e() {
const A = W.getData(c.CALL, o.CALL_STATUS);
if (A === U.IDLE)
return nA.IDLE;
const t = W.getData(c.CALL, o.IS_GROUP);
if (A === U.CALLING)
return t ? nA.DIALING_GROUP : nA.DIALING_C2C;
const e = W.getData(c.CALL, o.CALL_MEDIA_TYPE);
return t ? e === F.AUDIO ? nA.CALLING_GROUP_AUDIO : nA.CALLING_GROUP_VIDEO : e === F.AUDIO ? nA.CALLING_C2C_AUDIO : nA.CALLING_C2C_VIDEO;
}
async function di(A, t, e, a) {
let n = [];
try {
const l = await t.getGroupMemberList({ groupID: A, count: e, offset: a });
if (l.code === 0)
return l.data.memberList || n;
} catch (l) {
return console.error(`${o.PREFIX}getGroupMember failed, error: ${l}.`), n;
}
}
async function Ii(A, t) {
let e = {};
try {
return (await t.getGroupProfile({ groupID: A })).data.group || e;
} catch (a) {
return console.warn(`${o.PREFIX}getGroupProfile failed, error: ${a}.`), e;
}
}
function po(A, t) {
A === 0 && t ? (W.update(c.CALL, o.ROOM_ID, t), W.update(c.CALL, o.ROOM_ID_TYPE, kt.STRING_ROOM_ID)) : (W.update(c.CALL, o.ROOM_ID, A), W.update(c.CALL, o.ROOM_ID_TYPE, kt.NUMBER_ROOM_ID));
}
function DA(A) {
return A || {};
}
function xt(A) {
if (A.length === 0)
return;
let t = W.getData(c.CALL, o.REMOTE_USER_INFO_LIST);
A.forEach((e) => {
t = t.filter((a) => a.userId !== e);
}), W.update(c.CALL, o.REMOTE_USER_INFO_LIST, t), W.update(c.CALL, o.REMOTE_USER_INFO_EXCLUDE_VOLUMN_LIST, t);
}
function Vt(A) {
A == null || A.getDeviceList("speaker").then((e) => {
const a = W.getData(c.CALL, o.DEVICE_LIST), n = (e == null ? void 0 : e[0]) || {};
W.update(
c.CALL,
o.DEVICE_LIST,
{ ...a, speakerList: e, currentSpeaker: n }
);
}).catch((e) => {
console.error(`${o.PREFIX}updateSpeakerList failed, error: ${JSON.stringify(e)}.`);
}), W.getData(c.CALL, o.CALL_MEDIA_TYPE) === F.VIDEO && (A == null || A.getDeviceList("camera").then((e) => {
const a = W.getData(c.CALL, o.DEVICE_LIST), n = (e == null ? void 0 : e[0]) || {};
W.update(
c.CALL,
o.DEVICE_LIST,
{ ...a, cameraList: e, currentCamera: n }
);
}).catch((e) => {
console.error(`${o.PREFIX}updateCameraList failed, error: ${e}.`);
})), A == null || A.getDeviceList("microphones").then((e) => {
const a = W.getData(c.CALL, o.DEVICE_LIST), n = (e == null ? void 0 : e[0]) || {};
W.update(
c.CALL,
o.DEVICE_LIST,
{ ...a, microphoneList: e, currentMicrophone: n }
);
}).catch((e) => {
console.error(`${o.PREFIX}updateMicrophoneList failed, error: ${e}.`);
});
}
function bt(A, t, e) {
if (ai(A)) {
let a = "";
t === F.AUDIO && (a = vA(sA.NO_MICROPHONE_DEVICE_PERMISSION)), t === F.VIDEO && (a = vA(sA.NO_CAMERA_DEVICE_PERMISSION));
const n = e == null ? void 0 : e.getDevicePermission();
n != null && n.audio || W.update(c.CALL, o.SHOW_PERMISSION_TIP, !0), a && W.update(c.CALL, o.TOAST_INFO, { text: a, type: o.ERROR }), console.error(`${o.PREFIX}call failed, error: ${A.message}.`);
}
}
function FA(A, t) {
let e = W.getData(c.CALL, o.LOCAL_USER_INFO);
t === o.AUDIO && (e = { ...e, isAudioAvailable: A }), t === o.VIDEO && (e = { ...e, isVideoAvailable: A }), W.update(c.CALL, o.LOCAL_USER_INFO, e), W.update(c.CALL, o.LOCAL_USER_INFO_EXCLUDE_VOLUMN, e);
}
class nt {
static generateTaskID() {
return this.currentTaskID++;
}
static run(t = o.TIMEOUT, e, a) {
t === o.INTERVAL ? a = { delay: 2e3, count: 0, backgroundTask: !0, ...a } : a = { delay: 2e3, count: 0, backgroundTask: !0, ...a }, Mo(e) && (a = { ...a, ...e }), $e(t) && (e = t, t = o.TIMEOUT);
const n = {
taskID: this.generateTaskID(),
loopCount: 0,
intervalID: null,
timeoutID: null,
taskName: t,
callback: e,
...a
};
return this.taskMap.set(n.taskID, n), t === o.INTERNAL ? this.interval(n) : this.timeout(n), n.taskID;
}
static interval(t) {
const e = () => {
t.callback(), t.loopCount += 1, this.isBreakLoop(t);
};
return t.intervalID = setInterval(e, t.delay);
}
static timeout(t) {
const e = () => {
if (t.callback(), t.loopCount += 1, !this.isBreakLoop(t))
return t.timeoutID = setTimeout(e, t.delay);
};
return t.timeoutID = setTimeout(e, t.delay);
}
static hasTask(t) {
return this.taskMap.has(t);
}
static clearTask(t) {
if (!this.taskMap.has(t))
return !0;
const { intervalID: e, timeoutID: a, onVisibilitychange: n } = this.taskMap.get(t);
return e && clearInterval(e), a && clearTimeout(a), n && document.removeEventListener("visibilitychange", n), this.taskMap.delete(t), !0;
}
static isBreakLoop(t) {
return this.taskMap.has(t.taskID) ? t.count !== 0 && t.loopCount >= t.count ? (this.clearTask(t.taskID), !0) : !1 : !0;
}
}
nt.taskMap = /* @__PURE__ */ new Map();
nt.currentTaskID = 1;
const gi = 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 (Mo(A)) {
for (const t in A)
if (Object.prototype.hasOwnProperty.call(A, t))
return !1;
return !0;
}
return !1;
}, Bt = "_local_user_id";
class PA {
constructor() {
this._viewConfig = {
viewBackground: {
local: {},
remote: {}
}
}, this._isSetViewBackgroundConfig = { remote: !1, local: !1 }, this._tuiCallEngine = null, this._tuiStore = null;
}
static getInstance() {
return PA.instance || (PA.instance = new PA()), PA.instance;
}
_updateViewBackground() {
var a, n, l;
const t = (a = this._tuiStore) == null ? void 0 : a.getData(c.CALL, o.CUSTOM_UI_CONFIG), { userId: e } = (n = this._tuiStore) == null ? void 0 : n.getData(c.CALL, o.LOCAL_USER_INFO);
Object.keys(this._viewConfig.viewBackground.remote).includes(e) && delete this._viewConfig.viewBackground.remote[e], (l = this._tuiStore) == null || l.update(
c.CALL,
o.CUSTOM_UI_CONFIG,
{
...t,
viewBackground: {
...this._viewConfig.viewBackground.remote,
...this._viewConfig.viewBackground.local
}
}
);
}
setEngineInstance(t) {
this._tuiCallEngine = t;
}
setTUIStore(t) {
this._tuiStore = t;
}
updateViewBackgroundUserId(t) {
var e, a;
if (t === "local") {
const { userId: n } = (e = this._tuiStore) == null ? void 0 : e.getData(c.CALL, o.LOCAL_USER_INFO);
if (Object.keys(this._viewConfig.viewBackground.remote).includes(n) && (delete this._viewConfig.viewBackground.remote[n], this._updateViewBackground()), !this._isSetViewBackgroundConfig.local)
return;
const l = this._viewConfig.viewBackground.local, i = l[n] || l[Bt];
l[n] = l[Bt], this._viewConfig.viewBackground.local = { [n]: i }, this._updateViewBackground();
} else {
let n = this._viewConfig.viewBackground.remote;
this._isSetViewBackgroundConfig.remote && Object.keys(n).includes("*") && (((a = this._tuiStore) == null ? void 0 : a.getData(c.CALL, o.REMOTE_USER_INFO_LIST)).map((u) => u.userId).forEach((u) => {
Object.keys(n).includes(u) || (n[u] = n["*"]);
}), this._viewConfig.viewBackground.remote = n, this._updateViewBackground());
}
}
hideFeatureButton(t) {
var a, n, l, i, u;
(n = (a = this._tuiCallEngine) == null ? void 0 : a.reportLog) == null || n.call(a, {
name: "TUICallKit.hideFeatureButton.start",
data: { buttonName: t }
});
const e = (l = this._tuiStore) == null ? void 0 : l.getData(c.CALL, o.CUSTOM_UI_CONFIG);
(u = this._tuiStore) == null || u.update(
c.CALL,
o.CUSTOM_UI_CONFIG,
{
...e,
button: {
...e.button,
[t]: { ...((i = e.button) == null ? void 0 : i[t]) || {}, show: !1 }
}
}
);
}
setLocalViewBackgroundImage(t) {
var a, n, l;
(n = (a = this._tuiCallEngine) == null ? void 0 : a.reportLog) == null || n.call(a, {
name: "TUICallKit.setLocalViewBackgroundImage.start",
data: { url: t }
}), this._isSetViewBackgroundConfig.local = !0;
let { userId: e } = (l = this._tuiStore) == null ? void 0 : l.getData(c.CALL, o.LOCAL_USER_INFO);
gi(e) && (e = Bt), this._viewConfig.viewBackground.local = { [e]: t }, this._updateViewBackground();
}
setRemoteViewBackgroundImage(t, e) {
var a, n;
(n = (a = this._tuiCallEngine) == null ? void 0 : a.reportLog) == null || n.call(a, {
name: "TUICallKit.setRemoteViewBackgroundImage.start",
data: { userId: t, url: e }
}), this._isSetViewBackgroundConfig.remote = !0, t === "*" && (this._viewConfig.viewBackground.remote = {}), this._viewConfig.viewBackground.remote[t] = e, this._updateViewBackground();
}
setLayoutMode(t) {
var a, n;
(n = (a = this._tuiCallEngine) == null ? void 0 : a.reportLog) == null || n.call(a, {
name: "TUICallKit.setLayoutMode.start",
data: { layoutMode: t }
});
const e = this._tuiStore.getData(c.CALL, o.CUSTOM_UI_CONFIG);
this._tuiStore.update(
c.CALL,
o.CUSTOM_UI_CONFIG,
{
...e,
layoutMode: t
}
);
}
setCameraDefaultState(t) {
var a, n;
(n = (a = this._tuiCallEngine) == null ? void 0 : a.reportLog) == null || n.call(a, {
name: "TUICallKit.setCameraDefaultState.start",
data: { isOpen: t }
});
const e = tt(this._tuiStore.getData(c.CALL, o.CUSTOM_UI_CONFIG));
Object.keys(e.button).includes(zA.Camera) || (e.button[zA.Camera] = {}), e.button[zA.Camera].state = t ? JA.Open : JA.Close, this._tuiStore.update(c.CALL, o.CUSTOM_UI_CONFIG, e);
}
}
const qe = yA.getInstance(), TA = {
audioCall: () => v("Voice call"),
videoCall: () => v("Video call"),
switchToAudio: () => v("Switch audio call"),
switchToVideo: () => v("Switch video call"),
hangup: ({ callDuration: A }) => `${v("Call duration")}\uFF1A${A}`
};
class qA {
constructor(t) {
var e, a, n;
this._callService = t.callService, HA.registerEvent(H.TUILogin.EVENT.LOGIN_STATE_CHANGED, H.TUILogin.EVENT_SUB_KEY.USER_LOGIN_SUCCESS, this), (e = H.TUIChat) != null && e.EVENT && HA.registerEvent((a = H.TUIChat.EVENT) == null ? void 0 : a.CHAT_STATE_CHANGED, (n = H.TUIChat.EVENT_SUB_KEY) == null ? void 0 : n.CHAT_OPENED, this), HA.registerService(H.TUICalling.SERVICE.NAME, this), HA.registerExtension(H.TUIChat.EXTENSION.INPUT_MORE.EXT_ID, this);
}
static getInstance(t) {
return qA.instance || (qA.instance = new qA(t)), qA.instance;
}
callTUIService(t) {
const { message: e } = t || {};
HA.callService({
serviceName: H.TUIChat.SERVICE.NAME,
method: H.TUIChat.SERVICE.METHOD.UPDATE_MESSAGE_LIST,
params: { message: e }
});
}
onGetExtension(t, e) {
var a, n;
if (t === H.TUIChat.EXTENSION.INPUT_MORE.EXT_ID) {
if ((n = (a = this._callService.getTUICallEngineInstance()) == null ? void 0 : a.reportLog) == null || n.call(a, { name: "TUICallKit.onGetExtension", data: { extensionID: t, params: e } }), Et(e))
return [];
if ([H.TUIChat.TYPE.ROOM, H.TUIChat.TYPE.CUSTOMER_SERVICE].includes(e.chatType))
return [];
let l = [];
const i = {
weight: 1e3,
text: "\u8BED\u97F3\u901A\u8BDD",
icon: kl,
data: {
name: "voiceCall"
},
listener: {
onClicked: async (s) => await this._handleTUICoreOnClick(s, s.type || F.AUDIO)
}
}, u = {
weight: 900,
text: "\u89C6\u9891\u901A\u8BDD",
icon: Pl,
data: {
name: "videoCall"
},
listener: {
onClicked: async (s) => await this._handleTUICoreOnClick(s, s.type || F.VIDEO)
}
};
return e != null && e.chatType ? l = [i, u] : (!(e != null && e.filterVoice) && l.push(i), !(e != null && e.filterVideo) && l.push(u)), l;
}
}
async onCall(t, e) {
t === H.TUICalling.SERVICE.METHOD.START_CALL && await this._handleTUICoreOnClick(e, e.type);
}
async onNotifyEvent(t, e, a) {
var n, l, i, u, s, r, M, D;
try {
if (t === H.TUILogin.EVENT.LOGIN_STATE_CHANGED)
if (e === H.TUILogin.EVENT_SUB_KEY.USER_LOGIN_SUCCESS) {
const { chat: g, userID: N, userSig: y, SDKAppID: T } = Ol.getContext();
await ((n = this._callService) == null ? void 0 : n.init({ tim: g, userID: N, userSig: y, sdkAppID: T, isFromChat: !0, component: _t.TIM_CALL_KIT })), (l = this._callService) == null || l.setIsFromChat(!0), (i = this._callService) == null || i.setLogLevel(io.NORMAL), this._addListenChatEvent();
} else
e === H.TUILogin.EVENT_SUB_KEY.USER_LOGOUT_SUCCESS && (this._removeListenChatEvent(), await ((u = this._callService) == null ? void 0 : u.destroyed()));
if (((s = H.TUIChat) == null ? void 0 : s.EVENT) && t === H.TUIChat.EVENT.CHAT_STATE_CHANGED && e === H.TUIChat.EVENT_SUB_KEY.CHAT_OPENED) {
if ((r = this._callService) == null || r.setCurrentGroupId((a == null ? void 0 : a.groupID) || ""), qe.getData(c.CALL, o.CALL_STATUS) !== U.IDLE)
return;
const g = (M = this._callService) == null ? void 0 : M.getCurrentGroupId(), N = g ? await this.getGroupAttributes((D = this._callService) == null ? void 0 : D.getTim(), g) : {};
await this.updateStoreBasedOnGroupAttributes(N);
}
} catch (g) {
console.error(`${o.PREFIX}TUICore onNotifyEvent failed, error: ${g}.`);
}
}
async updateStoreBasedOnGroupAttributes(t) {
var e, a, n, l;
(n = (a = (e = this._callService) == null ? void 0 : e.getTUICallEngineInstance()) == null ? void 0 : a.reportLog) == null || n.call(a, {
name: "TUICallKit.getJoinGroupCallInfo.success",
data: { groupAttributes: t }
});
try {
const {
group_id: i = "",
room_id: u = 0,
room_id_type: s = 0,
call_media_type: r = o.UNKNOWN,
user_list: M
} = t[o.INNER_ATTR_KIT_INFO] ? JSON.parse(t[o.INNER_ATTR_KIT_INFO]) : {};
let D = (M || []).map((N) => N.userid);
D = D.length && await ie(D, (l = this._callService) == null ? void 0 : l.getTim());
const g = {
[o.GROUP_ID]: i,
[o.GROUP_CALL_MEMBERS]: D,
[o.ROOM_ID]: u,
[o.CALL_MEDIA_TYPE]: bl[r],
[o.ROOM_ID_TYPE]: s
};
qe.updateStore(g, c.CALL);
} catch (i) {
console.warn(`${o.PREFIX}updateStoreBasedOnGroupAttributes fail, error: ${i}`);
}
}
async getGroupAttributes(t, e) {
if (!e)
return {};
try {
const { data: a } = await t.getGroupAttributes({
groupID: e,
keyList: []
});
return (a == null ? void 0 : a.groupAttributes) || {};
} catch (a) {
return console.warn(`${o.PREFIX}getGroupAttributes fail: ${a}`), {};
}
}
isLineBusy(t) {
var n;
const e = Xe(t.payload.data), a = Xe(e == null ? void 0 : e.data);
return (a == null ? void 0 : a.line_busy) === "line_busy" || (a == null ? void 0 : a.line_busy) === "" || ((n = a == null ? void 0 : a.data) == null ? void 0 : n.message) === "lineBusy";
}
async getCallKitMessage(t, e) {
var g, N, y, T;
const a = Xe(t.payload.data);
if ((a == null ? void 0 : a.businessID) !== 1)
return {};
let n = "";
const l = Xe(a == null ? void 0 : a.data), i = l.call_type, u = a.inviteeList, s = (g = l == null ? void 0 : l.data) == null ? void 0 : g.inviter, r = qe.getData(c.CALL, o.LOCAL_USER_INFO).userId, M = s === r, D = (N = l == null ? void 0 : l.data) == null ? void 0 : N.cmd;
switch (a == null ? void 0 : a.actionType) {
case XA.INVITE: {
n = TA[D]({ callDuration: No(l == null ? void 0 : l.call_end) });
break;
}
case XA.CANCEL_INVITE:
n = v(M ? "Call Cancel" : "Other Side Cancel");
break;
case XA.ACCEPT_INVITE:
["switchToAudio", "switchToVideo"].includes(D) ? n = (y = TA == null ? void 0 : TA[D]) == null ? void 0 : y.call(TA) : n = v("Answered");
break;
case XA.REJECT_INVITE:
this.isLineBusy(t) ? n = v(M ? "Line Busy" : "Other Side Line Busy") : n = v(M ? "Other Side Decline" : "Decline");
break;
case XA.INVITE_TIMEOUT:
["switchToAudio", "switchToVideo"].includes(D) ? n = (T = TA == null ? void 0 : TA[D]) == null ? void 0 : T.call(TA) : n = v(M ? "Other Side No Answer" : "No answer");
break;
}
return { messageCardContent: n, callMediaType: i, inviteeList: u };
}
_addListenChatEvent() {
var t, e;
if (!((t = this._callService) != null && t.getTim())) {
console.warn(`${o.PREFIX}add tim event listener failed, tim is empty.`);
return;
}
(e = this._callService) == null || e.getTim().on(ma.EVENT.GROUP_ATTRIBUTES_UPDATED, this._handleGroupAttributesUpdated, this);
}
_removeListenChatEvent() {
var t, e;
if (!((t = this._callService) != null && t.getTim())) {
console.warn(`${o.PREFIX}remove tim event listener failed, tim is empty.`);
return;
}
(e = this._callService) == null || e.getTim().off(ma.EVENT.GROUP_ATTRIBUTES_UPDATED, this._handleGroupAttributesUpdated, this);
}
async _handleTUICoreOnClick(t, e) {
var a, n;
try {
const { groupID: l, userIDList: i = [], ...u } = t;
l ? await ((a = this._callService) == null ? void 0 : a.groupCall({ groupID: l, userIDList: i, type: e, ...u })) : i.length === 1 && await ((n = this._callService) == null ? void 0 : n.call({ userID: i[0], type: e, ...u }));
} catch (l) {
console.debug(l);
}
}
async _handleGroupAttributesUpdated(t) {
var l;
if (qe.getData(c.CALL, o.CALL_STATUS) !== U.IDLE)
return;
const e = (t == null ? void 0 : t.data) || {}, { groupID: a = "", groupAttributes: n = {} } = e;
a === ((l = this._callService) == null ? void 0 : l.getCurrentGroupId()) && await this.updateStoreBasedOnGroupAttributes(n);
}
}
const Ni = 0, pi = 1, Oa = 2;
function Di({ retryFunction: A, settings: t, onError: e, onRetrying: a, onRetryFailed: n, context: l }) {
return function(...i) {
const u = t.retries || 5;
let s = 0, r = -1, M = Ni;
const D = async (g, N) => {
const y = l || this;
try {
const T = await A.apply(y, i);
s = 0, g(T);
} catch (T) {
const C = () => {
clearTimeout(r), s = 0, M = Oa, N(T);
}, E = () => {
M !== Oa && s < u ? (s++, M = pi, $e(a) && a.call(y, s, C), r = setTimeout(
() => {
r = -1, D(g, N);
},
Et(t.timeout) ? 1e3 : t.timeout
)) : (C(), $e(n) && n.call(y, T));
};
$e(e) ? e.call(y, T, E, N, i) : E();
}
};
return new Promise(D);
};
}
function Ti(A) {
return function(t, e, a) {
const { retries: n = 5, timeout: l = 2e3, onError: i, onRetrying: u, onRetryFailed: s } = A, r = Di({
retryFunction: a.value,
settings: { retries: n, timeout: l },
onError: i,
onRetrying: u,
onRetryFailed: s,
context: null
});
return a.value = function(...M) {
return r.apply(this, M);
}, a;
};
}
var Ci = Object.defineProperty, yi = Object.getOwnPropertyDescriptor, Si = (A, t, e, a) => {
for (var n = a > 1 ? void 0 : a ? yi(t, e) : t, l = A.length - 1, i; l >= 0; l--)
(i = A[l]) && (n = (a ? i(t, e, n) : i(n)) || n);
return a && n && Ci(t, e, n), n;
};
const V = yA.getInstance(), Ei = PA.getInstance(), ee = class {
constructor(A) {
this._callService = A.callService;
}
static getInstance(A) {
return ee.instance || (ee.instance = new ee(A)), ee.instance;
}
addListenTuiCallEngineEvent() {
var t;
const A = (t = this._callService) == null ? void 0 : t.getTUICallEngineInstance();
if (!A) {
console.warn(`${o.PREFIX}add engine event listener failed, engine is empty.`);
return;
}
A.on(f.ERROR, this._handleError, this), A.on(f.INVITED, this._handleNewInvitationReceived, this), A.on(f.USER_ACCEPT, this._handleUserAccept, this), A.on(f.USER_ENTER, this._handleUserEnter, this), A.on(f.USER_LEAVE, this._handleUserLeave, this), A.on(f.REJECT, this._handleInviteeReject, this), A.on(f.NO_RESP, this._handleNoResponse, this), A.on(f.LINE_BUSY, this._handleLineBusy, this), A.on(f.CALLING_CANCEL, this._handleCallingCancel, this), A.on(f.SDK_READY, this._handleSDKReady, this), A.on(f.KICKED_OUT, this._handleKickedOut, this), A.on(f.MESSAGE_SENT_BY_ME, this._messageSentByMe, this), f.CALL_MESSAGE && A.on(f.CALL_MESSAGE, this._handleCallMessage, this), f.ON_USER_NETWORK_QUALITY_CHANGED && A.on(f.ON_USER_NETWORK_QUALITY_CHANGED, this._handleNetworkQuality, this), A.on(f.CALLING_END, this._handleCallingEnd, this), A.on(f.CALL_TYPE_CHANGED, this._handleCallTypeChange, this), A.on(f.USER_VIDEO_AVAILABLE, this._handleUserVideoAvailable, this), A.on(f.USER_AUDIO_AVAILABLE, this._handleUserAudioAvailable, this), A.on(f.USER_VOICE_VOLUME, this._handleUserVoiceVolume, this), A.on(f.DEVICED_UPDATED, this._handleDeviceUpdate, this);
}
removeListenTuiCallEngineEvent() {
var t;
const A = (t = this._callService) == null ? void 0 : t.getTUICallEngineInstance();
A.off(f.ERROR, this._handleError, this), A.off(f.INVITED, this._handleNewInvitationReceived, this), A.off(f.USER_ACCEPT, this._handleUserAccept, this), A.off(f.USER_ENTER, this._handleUserEnter, this), A.off(f.USER_LEAVE, this._handleUserLeave, this), A.off(f.REJECT, this._handleInviteeReject, this), A.off(f.NO_RESP, this._handleNoResponse, this), A.off(f.LINE_BUSY, this._handleLineBusy, this), A.off(f.CALLING_CANCEL, this._handleCallingCancel, this), A.off(f.SDK_READY, this._handleSDKReady, this), A.off(f.KICKED_OUT, this._handleKickedOut, this), A.off(f.MESSAGE_SENT_BY_ME, this._messageSentByMe, this), f.ON_USER_NETWORK_QUALITY_CHANGED && A.off(f.ON_USER_NETWORK_QUALITY_CHANGED, this._handleNetworkQuality, this), A.off(f.CALLING_END, this._handleCallingEnd, this), A.off(f.CALL_TYPE_CHANGED, this._handleCallTypeChange, this), A.off(f.USER_VIDEO_AVAILABLE, this._handleUserVideoAvailable, this), A.off(f.USER_AUDIO_AVAILABLE, this._handleUserAudioAvailable, this), A.off(f.USER_VOICE_VOLUME, this._handleUserVoiceVolume, this), A.off(f.DEVICED_UPDATED, this._handleDeviceUpdate, this);
}
_callerChangeToConnected() {
var e;
const A = V.getData(c.CALL, o.CALL_ROLE);
V.getData(c.CALL, o.CALL_STATUS) === U.CALLING && A === K.CALLER && (V.update(c.CALL, o.CALL_STATUS, U.CONNECTED), (e = this._callService) == null || e.startTimer());
}
_unNormalEventsManager(A, t) {
var n;
console.log(`${o.PREFIX}${t} event data: ${JSON.stringify(A)}.`);
const e = V.getData(c.CALL, o.IS_GROUP), a = V.getData(c.CALL, o.REMOTE_USER_INFO_LIST);
switch (t) {
case f.REJECT:
case f.LINE_BUSY: {
const { userID: l } = DA(A);
let i = t === f.REJECT ? sA.OTHER_SIDE_REJECT_CALL : sA.OTHER_SIDE_LINE_BUSY, u = vA(i);
if (e) {
const s = (a.find((r) => r.userId === l) || {}).displayUserInfo || l;
i = t === f.REJECT ? sA.REJECT_CALL : sA.IN_BUSY, u = vA(i, s);
}
V.update(c.CALL, o.TOAST_INFO, { text: u }), l && xt([l]);
break;
}
case f.NO_RESP: {
const { userIDList: l = [] } = DA(A), i = e ? sA.TIMEOUT : sA.CALL_TIMEOUT, u = l.map((r) => (a.find((D) => D.userId === r) || {}).displayUserInfo || r), s = e ? vA(i, u.join()) : vA(i);
V.update(c.CALL, o.TOAST_INFO, { text: s }), l.length > 0 && xt(l);
break;
}
case f.CALLING_CANCEL: {
(n = this._callService) == null || n._resetCallStore();
break;
}
}
}
_handleError(A) {
var l;
const { code: t, message: e } = A || {}, a = Object.values(ja).indexOf(t);
let n = "";
if (a !== -1) {
const i = Object.keys(ja)[a];
n = v(Bl[i]), n && V.update(c.CALL, o.TOAST_INFO, { text: n, type: o.ERROR });
}
(l = this._callService) == null || l.executeExternalAfterCalling(), console.error(`${o.PREFIX}_handleError, errorCode: ${t}; errorMessage: ${n || e}.`);
}
async _handleNewInvitationReceived(A) {
var C, E, w, L;
console.log(`${o.PREFIX}onCallReceived event data: ${JSON.stringify(A)}.`);
const { sponsor: t = "", isFromGroup: e, callMediaType: a, inviteData: n = {}, calleeIdList: l = [], groupID: i = "", roomID: u, strRoomID: s } = DA(A), r = V.getData(c.CALL, o.LOCAL_USER_INFO), M = [t, ...l.filter((m) => m !== r.userId)], D = a || n.callType, g = D === F.AUDIO ? sA.CALLEE_CALLING_AUDIO_MSG : sA.CALLEE_CALLING_VIDEO_MSG;
let N = {
[o.CALL_ROLE]: K.CALLEE,
[o.IS_GROUP]: e,
[o.CALL_STATUS]: U.CALLING,
[o.CALL_MEDIA_TYPE]: D,
[o.CALL_TIPS]: v(g),
[o.CALLER_USER_INFO]: { userId: t },
[o.GROUP_ID]: i
};
po(u, s), V.updateStore(N, c.CALL), (C = this._callService) == null || C.executeExternalBeforeCalling(), (E = this._callService) != null && E.statusChanged && ((w = this._callService) == null || w.statusChanged({ oldStatus: nA.IDLE, newStatus: nA.BE_INVITED }));
const y = await ie(M, (L = this._callService) == null ? void 0 : L.getTim()), [T] = y.filter((m) => m.userId === t);
y.length > 0 && V.updateStore({
[o.REMOTE_USER_INFO_LIST]: y,
[o.REMOTE_USER_INFO_EXCLUDE_VOLUMN_LIST]: y,
[o.CALLER_USER_INFO]: {
userId: t,
nick: (T == null ? void 0 : T.nick) || "",
avatar: (T == null ? void 0 : T.avatar) || "",
displayUserInfo: (T == null ? void 0 : T.remark) || (T == null ? void 0 : T.nick) || t
}
}, c.CALL);
}
_handleUserAccept(A) {
this._callerChangeToConnected(), V.update(c.CALL, o.TOAST_INFO, v("answered")), console.log(`${o.PREFIX}accept event data: ${JSON.stringify(A)}.`);
}
async _handleUserEnter(A) {
var l;
this._callerChangeToConnected();
const { userID: t, data: e } = DA(A);
let a = V.getData(c.CALL, o.REMOTE_USER_INFO_LIST);
if (!a.find((i) => (i == null ? void 0 : i.userId) === t)) {
a.push({ userId: t }), a.length > 0 && (V.update(c.CALL, o.REMOTE_USER_INFO_LIST, a), V.update(c.CALL, o.REMOTE_USER_INFO_EXCLUDE_VOLUMN_LIST, a));
const [i] = await ie([t], (l = this._callService) == null ? void 0 : l.getTim());
a = V.getData(c.CALL, o.REMOTE_USER_INFO_LIST), a.forEach((u) => {
(u == null ? void 0 : u.userId) === t && (u = Object.assign(u, i));
});
}
a = a.map((i) => (i.userId === t && (i.isEnter = !0), i)), a.length > 0 && (V.update(c.CALL, o.REMOTE_USER_INFO_LIST, a), V.update(c.CALL, o.REMOTE_USER_INFO_EXCLUDE_VOLUMN_LIST, a), Ei.updateViewBackgroundUserId("remote")), console.log(`${o.PREFIX}userEnter event data: ${JSON.stringify(A)}.`);
}
_handleUserLeave(A) {
console.log(`${o.PREFIX}userLeave event data: ${JSON.stringify(A)}.`);
const { data: t, userID: e } = DA(A);
if (V.getData(c.CALL, o.IS_GROUP)) {
const n = (V.getData(c.CALL, o.REMOTE_USER_INFO_LIST).find((i) => i.userId === e) || {}).displayUserInfo || e, l = vA(sA.END_CALL, n);
V.update(c.CALL, o.TOAST_INFO, { text: l });
}
e && xt([e]);
}
_handleInviteeReject(A) {
this._unNormalEventsManager(A, f.REJECT);
}
_handleNoResponse(A) {
this._unNormalEventsManager(A, f.NO_RESP);
}
_handleLineBusy(A) {
this._unNormalEventsManager(A, f.LINE_BUSY);
}
_handleCallingCancel(A) {
var t;
(t = this._callService) == null || t.executeExternalAfterCalling(), this._unNormalEventsManager(A, f.CALLING_CANCEL);
}
_handleCallingEnd(A) {
var t, e;
console.log(`${o.PREFIX}callEnd event data: ${JSON.stringify(A)}.`), (t = this._callService) == null || t.executeExternalAfterCalling(), (e = this._callService) == null || e._resetCallStore();
}
async _handleSDKReady(A) {
var e, a, n;
let t = V.getData(c.CALL, o.LOCAL_USER_INFO);
t = await Mi(t.userId, (e = this._callService) == null ? void 0 : e.getTim()), (n = this._callService) == null || n.setDefaultOfflinePushInfo({ ...(a = this._callService) == null ? void 0 : a.getDefaultOfflinePushInfo(), title: t == null ? void 0 : t.displayUserInfo }), V.update(c.CALL, o.LOCAL_USER_INFO, t), V.update(c.CALL, o.LOCAL_USER_INFO_EXCLUDE_VOLUMN, t);
}
_handleKickedOut(A) {
var t, e, a;
console.log(`${o.PREFIX}kickOut event data: ${JSON.stringify(A)}.`), (t = this._callService) != null && t.kickedOut && ((e = this._callService) == null || e.kickedOut(A)), V.update(c.CALL, o.CALL_TIPS, vA(sA.KICK_OUT)), (a = this._callService) == null || a._resetCallStore();
}
_messageSentByMe(A) {
var e, a;
const t = A == null ? void 0 : A.data;
(e = this._callService) != null && e.onMessageSentByMe && ((a = this._callService) == null || a.onMessageSentByMe(t));
}
_handleCallMessage(A) {
const t = DA(A);
this._callService._chatCombine.callTUIService({ message: t });
}
_handleCallTypeChange(A) {
const { newCallType: t, type: e } = DA(A);
V.update(c.CALL, o.CALL_MEDIA_TYPE, t || e);
}
_handleNetworkQuality(A) {
const { networkQualityList: t = [] } = DA(A);
V.update(c.CALL, o.NETWORK_STATUS, t);
const e = V.getData(c.CALL, o.IS_GROUP), a = V.getData(c.CALL, o.LOCAL_USER_INFO);
if (V.getData(c.CALL, o.REMOTE_USER_INFO_LIST), !e && t.find((l) => (a == null ? void 0 : a.userId) === (l == null ? void 0 : l.userId) && (l == null ? void 0 : l.quality) >= Gl)) {
V.update(c.CALL, o.CALL_TIPS, v(sA.LOCAL_NETWORK_IS_POOR));
return;
}
}
async _startRemoteView(A) {
var t;
if (!A) {
console.warn(`${o.PREFIX}_startRemoteView userID is empty`);
return;
}
if (!document.getElementById(A))
return console.warn(`${o.PREFIX}_startRemoteView can't find HTMLElement sid: ${A}`), Promise.reject();
try {
const e = V.getData(c.CALL, o.DISPLAY_MODE);
await ((t = this._callService) == null ? void 0 : t.getTUICallEngineInstance().startRemoteView({ userID: A, videoViewDomID: A, options: { objectFit: e } }));
} catch (e) {
return console.error(`${o.PREFIX}_startRemoteView error: ${e}.`), Promise.reject(e);
}
}
_setRemoteUserInfoAudioVideoAvailable(A, t, e) {
let a = V.getData(c.CALL, o.REMOTE_USER_INFO_LIST);
a = a.map((n) => {
if (n.userId === e) {
if (t === o.AUDIO)
return { ...n, isAudioAvailable: A };
if (t === o.VIDEO)
return { ...n, isVideoAvailable: A };
}
return n;
}), a.length > 0 && (V.update(c.CALL, o.REMOTE_USER_INFO_LIST, a), V.update(c.CALL, o.REMOTE_USER_INFO_EXCLUDE_VOLUMN_LIST, a));
}
async _handleUserVideoAvailable(A) {
const { userID: t, isVideoAvailable: e } = DA(A);
console.log(`${o.PREFIX}_handleUserVideoAvailable event data: ${JSON.stringify(A)}.`);
try {
e && await this._startRemoteView(t);
} catch (a) {
console.error(`${o.PREFIX}_startRemoteView failed, error: ${a}.`);
}
this._setRemoteUserInfoAudioVideoAvailable(e, o.VIDEO, t);
}
_handleUserAudioAvailable(A) {
const { userID: t, isAudioAvailable: e } = DA(A);
console.log(`${o.PREFIX}_handleUserAudioAvailable event data: ${JSON.stringify(A)}.`), this._setRemoteUserInfoAudioVideoAvailable(e, o.AUDIO, t);
}
_handleUserVoiceVolume(A) {
try {
const { volumeMap: t } = DA(A);
if ((t || []).length === 0)
return;
const e = V.getData(c.CALL, o.LOCAL_USER_INFO);
let a = V.getData(c.CALL, o.REMOTE_USER_INFO_LIST);
const [n] = t.filter((u) => u.userId === e.userId), l = t.reduce((u, s) => s.userId !== e.userId ? { ...u, [s.userId]: s.audioVolume } : u, {});
e.volume = n.audioVolume, a = a.map((u) => ({ ...u, volume: l[u.userId] }));
const i = {
[o.LOCAL_USER_INFO]: e,
[o.REMOTE_USER_INFO_LIST]: a
};
V.updateStore(i, c.CALL);
} catch (t) {
console.debug(t);
}
}
_handleDeviceUpdate(A) {
const { cameraList: t, microphoneList: e, speakerList: a, currentCamera: n, currentMicrophone: l, currentSpeaker: i } = A;
V.update(c.CALL, o.DEVICE_LIST, { cameraList: t, microphoneList: e, speakerList: a, currentCamera: n, currentMicrophone: l, currentSpeaker: i });
}
};
let Do = ee;
Si([
Ti({
retries: 5,
timeout: 200,
onRetrying(A) {
console.warn(`${o.PREFIX}_startRemoteView, retrying [${A}]`);
}
})
], Do.prototype, "_startRemoteView", 1);
var hi = Object.defineProperty, mi = Object.getOwnPropertyDescriptor, Q = (A, t, e, a) => {
for (var n = a > 1 ? void 0 : a ? mi(t, e) : t, l = A.length - 1, i; l >= 0; l--)
(i = A[l]) && (n = (a ? i(t, e, n) : i(n)) || n);
return a && n && hi(t, e, n), n;
};
const j = kA.getInstance(), d = yA.getInstance(), mA = PA.getInstance();
mA.setTUIStore(d);
const xa = "3.3.7", ji = "vue2.6", te = class {
constructor() {
this._tim = null, this._TUICore = null, this._timerId = -1, this._startTimeStamp = Ot(), 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 t, e, a, n;
try {
const l = {
callRole: d.getData(c.CALL, o.CALL_ROLE),
callStatus: d.getData(c.CALL, o.CALL_STATUS)
};
if (this._bellContext.setBellProperties(l), A === U.CALLING)
await ((t = this == null ? void 0 : this._bellContext) == null ? void 0 : t.play());
else {
if (A === U.CONNECTED) {
const i = d.getData(c.CALL, o.IS_GROUP), u = d.getData(c.CALL, o.CALL_MEDIA_TYPE), s = d.getData(c.CALL, o.REMOTE_USER_INFO_LIST), r = i ? nA.DIALING_GROUP : nA.DIALING_C2C;
d.update(c.CALL, o.CALL_TIPS, ""), this.statusChanged && this.statusChanged({ oldStatus: r, newStatus: _e() }), !i && u === F.VIDEO && this.switchScreen(s[0].domId);
}
if (A === U.IDLE && this._isFromChat) {
const i = this._currentGroupId ? await ((e = this._chatCombine) == null ? void 0 : e.getGroupAttributes(this._tim, this._currentGroupId)) : {};
await ((a = this._chatCombine) == null ? void 0 : a.updateStoreBasedOnGroupAttributes(i, d, this));
}
await ((n = this == null ? void 0 : this._bellContext) == null ? void 0 : n.stop());
}
} catch (l) {
console.warn(`${o.PREFIX}handleCallStatusChange, ${l}.`);
}
}, console.log(`${o.PREFIX}version: ${xa}`), this._watchTUIStore(), this._engineEventHandler = Do.getInstance({ callService: this }), this._chatCombine = qA.getInstance({ callService: this });
}
static getInstance() {
return te.instance || (te.instance = new te()), te.instance;
}
async init(A) {
var t, e;
try {
if (this._tuiCallEngine)
return;
let { userID: a, tim: n, userSig: l, sdkAppID: i, SDKAppID: u, isFromChat: s, component: r = _t.TUI_CALL_KIT } = A;
this._TUICore && (i = this._TUICore.SDKAppID, n = this._TUICore.tim), this._tim = n, console.log(`${o.PREFIX}init sdkAppId: ${i || u}, userId: ${a}`), this._tuiCallEngine = wl.createInstance({
tim: n,
SDKAppID: i || u,
frameWork: ji,
language: 5,
callkitVersion: xa,
chat: s || !1,
component: r
}), mA.setEngineInstance(this._tuiCallEngine), this._addListenTuiCallEngineEvent(), this._bellContext = new si(), d.update(c.CALL, o.LOCAL_USER_INFO, { userId: a }), d.update(c.CALL, o.LOCAL_USER_INFO_EXCLUDE_VOLUMN, { userId: a }), mA.updateViewBackgroundUserId("local"), await this._tuiCallEngine.login({ userID: a, userSig: l, assetsPath: "" });
const M = d.getData(c.CALL, o.CUSTOM_UI_CONFIG);
(e = (t = this._tuiCallEngine) == null ? void 0 : t.reportLog) == null || e.call(t, {
name: "TUICallkit.init",
data: {
uiConfig: M
}
});
} catch (a) {
throw console.error(`${o.PREFIX}init failed, error: ${a}.`), a;
}
}
async destroyed() {
var A;
try {
const t = d.getData(c.CALL, o.CALL_STATUS);
if (t !== U.IDLE)
throw new Error(`please destroyed when status is idle, current status: ${t}`);
this._tuiCallEngine && (this._removeListenTuiCallEngineEvent(), await this._tuiCallEngine.destroyInstance(), this._tuiCallEngine = null), (A = this._bellContext) == null || A.destroy(), this._bellContext = null;
} catch (t) {
throw console.error(`${o.PREFIX}destroyed failed, error: ${t}.`), t;
}
}
async call(A) {
if (d.getData(c.CALL, o.CALL_STATUS) === U.IDLE)
try {
const { type: t, userID: e, offlinePushInfo: a } = A;
if (d.getData(c.CALL, o.CALL_STATUS) !== U.IDLE)
return;
await this._updateCallStoreBeforeCall(t, [{ userId: e }]), this.executeExternalBeforeCalling(), A.offlinePushInfo = { ...this._defaultOfflinePushInfo, ...a };
const n = await this._tuiCallEngine.call(A);
await this._updateCallStoreAfterCall([e], n);
} catch (t) {
this._handleCallError(t, "call");
}
}
async groupCall(A) {
if (d.getData(c.CALL, o.CALL_STATUS) === U.IDLE)
try {
const { userIDList: t, type: e, groupID: a, offlinePushInfo: n } = A;
if (d.getData(c.CALL, o.CALL_STATUS) !== U.IDLE)
return;
const l = t.map((u) => ({ userId: u }));
await this._updateCallStoreBeforeCall(e, l, a), this.executeExternalBeforeCalling(), A.offlinePushInfo = { ...this._defaultOfflinePushInfo, ...n };
const i = await this._tuiCallEngine.groupCall(A);
await this._updateCallStoreAfterCall(t, i);
} catch (t) {
this._handleCallError(t, "groupCall");
}
}
async inviteUser(A) {
if (d.getData(c.CALL, o.CALL_STATUS) !== U.IDLE)
try {
const { userIDList: t } = A;
let e = await ie(t, this.getTim());
const a = d.getData(c.CALL, o.REMOTE_USER_INFO_LIST);
d.update(c.CALL, o.REMOTE_USER_INFO_LIST, [...a, ...e]), d.update(c.CALL, o.REMOTE_USER_INFO_EXCLUDE_VOLUMN_LIST, [...a, ...e]), this._tuiCallEngine && await this._tuiCallEngine.inviteUser(A);
} catch (t) {
throw console.error(`${o.PREFIX}inviteUser failed, error: ${t}.`), this._resetCallStore(), t;
}
}
async joinInGroupCall(A) {
if (d.getData(c.CALL, o.CALL_STATUS) !== U.CONNECTED)
try {
const t = {
[o.CALL_ROLE]: K.CALLEE,
[o.IS_GROUP]: !0,
[o.CALL_STATUS]: U.CONNECTED,
[o.CALL_MEDIA_TYPE]: A.type,
[o.GROUP_ID]: A.groupID,
[o.ROOM_ID]: A.roomID
};
d.updateStore(t, c.CALL);
const e = await this._tuiCallEngine.joinInGroupCall(A), a = this._getFeatureButtonDefaultState(zA.Camera) === JA.Close;
A.type === F.VIDEO && !a && await this.openCamera(o.LOCAL_VIDEO), d.update(c.CALL, o.IS_CLICKABLE, !0), this.startTimer(), Vt(this._tuiCallEngine), await this._tuiCallEngine.setVideoQuality(d.getData(c.CALL, o.VIDEO_RESOLUTION));
const n = d.getData(c.CALL, o.LOCAL_USER_INFO);
d.update(c.CALL, o.LOCAL_USER_INFO, { ...n, isEnter: !0 }), d.update(c.CALL, o.LOCAL_USER_INFO_EXCLUDE_VOLUMN, { ...n, isEnter: !0 }), FA(!0, o.AUDIO);
} catch (t) {
this._handleCallError(t, "joinInGroupCall");
}
}
getTUICallEngineInstance() {
return (this == null ? void 0 : this._tuiCallEngine) || null;
}
setLogLevel(A) {
var t;
(t = this == null ? void 0 : this._tuiCallEngine) == null || t.setLogLevel(A);
}
setLanguage(A) {
A && Object.values(lo).includes(A) && d.update(c.CALL, o.LANGUAGE, A);
}
enableFloatWindow(A) {
d.update(c.CALL, o.ENABLE_FLOAT_WINDOW, A);
}
async setSelfInfo(A) {
const { nickName: t, avatar: e } = A;
try {
await this._tuiCallEngine.setSelfInfo({ nickName: t, avatar: e });
} catch (a) {
console.error(`${o.PREFIX}setSelfInfo failed, error: ${a}.`);
}
}
async enableVirtualBackground(A) {
d.update(c.CALL, o.IS_SHOW_ENABLE_VIRTUAL_BACKGROUND, A);
}
async enableAIVoice(A) {
try {
await this._tuiCallEngine.enableAIVoice(A), console.log(`${o.PREFIX}enableAIVoice: ${A}.`);
} catch (t) {
throw console.error(`${o.PREFIX}enableAIVoice failed, error: ${t}.`), t;
}
}
async setCallingBell(A) {
let t = !0;
if (t = await Ql(A), !t) {
console.warn(`${o.PREFIX}setCallingBell failed, filePath: ${A}.`);
return;
}
const e = { calleeBellFilePath: A };
this._bellContext.setBellProperties(e);
}
async enableMuteMode(A) {
try {
const t = { isMuteBell: A };
this._bellContext.setBellProperties(t), await this._bellContext.setBellMute(A);
} catch (t) {
console.warn(`${o.PREFIX}enableMuteMode failed, error: ${t}.`);
}
}
hideFeatureButton(A) {
mA.hideFeatureButton(A);
}
setLocalViewBackgroundImage(A) {
mA.setLocalViewBackgroundImage(A);
}
setRemoteViewBackgroundImage(A, t) {
mA.setRemoteViewBackgroundImage(A, t);
}
setLayoutMode(A) {
mA.setLayoutMode(A);
}
setCameraDefaultState(A) {
mA.setCameraDefaultState(A);
}
async accept() {
var t, e, a, n, l, i;
const A = d.getData(c.CALL, o.CALL_STATUS);
if ((e = (t = this._tuiCallEngine) == null ? void 0 : t.reportLog) == null || e.call(t, {
name: "TUICallKit.accept.start",
data: { callStatus: A }
}), A !== U.CONNECTED)
try {
d.update(c.CALL, o.CALL_STATUS, U.CONNECTED), Vt(this._tuiCallEngine);
const u = await this._tuiCallEngine.accept();
if (u) {
(n = this._chatCombine) == null || n.callTUIService({ message: (a = u == null ? void 0 : u.data) == null ? void 0 : a.message }), d.update(c.CALL, o.IS_CLICKABLE, !0), this.startTimer();
const s = d.getData(c.CALL, o.CALL_MEDIA_TYPE), r = this._getFeatureButtonDefaultState(zA.Camera) === JA.Close;
s === F.VIDEO && !r && await this.openCamera(o.LOCAL_VIDEO), await this._tuiCallEngine.setVideoQuality(d.getData(c.CALL, o.VIDEO_RESOLUTION));
const M = d.getData(c.CALL, o.LOCAL_USER_INFO);
d.update(c.CALL, o.LOCAL_USER_INFO, { ...M, isEnter: !0 }), d.update(c.CALL, o.LOCAL_USER_INFO_EXCLUDE_VOLUMN, { ...M, isEnter: !0 }), FA(!0, o.AUDIO);
}
} catch (u) {
if ((i = (l = this._tuiCallEngine) == null ? void 0 : l.reportLog) == null || i.call(l, {
name: "TUICallKit.accept.fail",
level: "error",
error: u
}), Ua(u))
return;
bt(u, F.AUDIO, this._tuiCallEngine), this._resetCallStore();
}
}
async hangup() {
if (d.getData(c.CALL, o.CALL_STATUS) !== U.IDLE) {
try {
const A = await this._tuiCallEngine.hangup();
A == null || A.forEach((t) => {
var e, a;
(t == null ? void 0 : t.code) === 0 && ((a = this._chatCombine) == null || a.callTUIService({ message: (e = t == null ? void 0 : t.data) == null ? void 0 : e.message }));
});
} catch (A) {
console.debug(A);
}
this._resetCallStore();
}
}
async reject() {
var A, t;
if (d.getData(c.CALL, o.CALL_STATUS) !== U.IDLE) {
try {
const e = await this._tuiCallEngine.reject();
(e == null ? void 0 : e.code) === 0 && ((t = this._chatCombine) == null || t.callTUIService({ message: (A = e == null ? void 0 : e.data) == null ? void 0 : A.message }));
} catch (e) {
console.debug(e);
}
this._resetCallStore();
}
}
async openCamera(A) {
try {
await this._tuiCallEngine.openCamera(A), FA(!0, o.VIDEO);
} catch (t) {
bt(t, F.VIDEO, this._tuiCallEngine), console.error(`${o.PREFIX}openCamera error: ${t}.`);
}
}
async closeCamera() {
try {
await this._tuiCallEngine.closeCamera(), FA(!1, o.VIDEO);
} catch (A) {
console.error(`${o.PREFIX}closeCamera error: ${A}.`);
}
}
async openMicrophone() {
try {
await this._tuiCallEngine.openMicrophone(), FA(!0, o.AUDIO);
} catch (A) {
console.error(`${o.PREFIX}openMicrophone failed, error: ${A}.`);
}
}
async closeMicrophone() {
try {
await this._tuiCallEngine.closeMicrophone(), FA(!1, o.AUDIO);
} catch (A) {
console.error(`${o.PREFIX}closeMicrophone failed, error: ${A}.`);
}
}
unMuteSpeaker() {
var A, t;
try {
const e = (t = (A = this._tuiCallEngine) == null ? void 0 : A.getTRTCCloudInstance) == null ? void 0 : t.call(A);
e && (e.muteAllRemoteAudio(!1), d.update(c.CALL, o.IS_MUTE_SPEAKER, !1));
} catch (e) {
console.error(`${o.PREFIX}unMuteSpeaker failed, error: ${e}.`);
}
}
muteSpeaker() {
var A, t;
try {
const e = (t = (A = this._tuiCallEngine) == null ? void 0 : A.getTRTCCloudInstance) == null ? void 0 : t.call(A);
e && (e.muteAllRemoteAudio(!0), d.update(c.CALL, o.IS_MUTE_SPEAKER, !0));
} catch (e) {
console.error(`${o.PREFIX}muteSpeaker failed, error: ${e}.`);
}
}
switchScreen(A) {
!A || d.update(c.CALL, o.BIG_SCREEN_USER_ID, A);
}
async switchCallMediaType() {
var A, t;
try {
const e = d.getData(c.CALL, o.CALL_MEDIA_TYPE);
if (e === F.AUDIO) {
console.warn(`${o.PREFIX}switchCallMediaType failed, ${e} not support.`);
return;
}
const a = await this._tuiCallEngine.switchCallMediaType(F.AUDIO);
(a == null ? void 0 : a.code) === 0 && ((t = this._chatCombine) == null || t.callTUIService({ message: (A = a == null ? void 0 : a.data) == null ? void 0 : A.message })), d.update(c.CALL, o.CALL_MEDIA_TYPE, F.AUDIO);
const l = d.getData(c.CALL, o.IS_GROUP) ? nA.CALLING_GROUP_VIDEO : nA.CALLING_C2C_VIDEO, i = _e();
this.statusChanged && this.statusChanged({ oldStatus: l, newStatus: i });
} catch (e) {
console.error(`${o.PREFIX}switchCallMediaType failed, error: ${e}.`);
}
}
async switchCamera() {
const t = d.getData(c.CALL, o.CAMERA_POSITION) === le.BACK ? le.FRONT : le.BACK;
try {
await this._tuiCallEngine.switchCamera(t), d.update(c.CALL, o.CAMERA_POSITION, t);
} catch (e) {
console.error(`${o.PREFIX}_switchCamera failed, error: ${e}.`);
}
}
async setBlurBackground(A) {
try {
await this._tuiCallEngine.setBlurBackground(A ? Wl : 0), d.update(c.CALL, o.ENABLE_VIRTUAL_BACKGROUND, A);
} catch (t) {
console.error(`${o.PREFIX}_setBlurBackground failed, error: ${t}.`);
}
}
async switchDevice(A) {
try {
await this._tuiCallEngine.switchDevice(A);
} catch (t) {
console.error(`${o.PREFIX}_switchDevice failed, error: ${t}.`);
}
}
async getDeviceList(A) {
try {
return await this._tuiCallEngine.getDeviceList(A);
} catch (t) {
this._handleCallError(t, "call");
}
}
_addListenTuiCallEngineEvent() {
this._engineEventHandler.addListenTuiCallEngineEvent();
}
_removeListenTuiCallEngineEvent() {
this._engineEventHandler.removeListenTuiCallEngineEvent();
}
setCallback(A) {
const { beforeCalling: t, afterCalling: e, onMinimized: a, onMessageSentByMe: n, kickedOut: l, statusChanged: i } = A;
t && (this.beforeCalling = t), e && (this.afterCalling = e), a && (this.onMinimized = a), n && (this.onMessageSentByMe = n), l && (this.kickedOut = l), i && (this.statusChanged = i);
}
toggleMinimize() {
const A = d.getData(c.CALL, o.IS_MINIMIZED);
d.update(c.CALL, o.IS_MINIMIZED, !A), console.log(`${o.PREFIX}toggleMinimize: ${A} -> ${!A}.`), this.onMinimized && this.onMinimized(A, !A);
}
executeExternalBeforeCalling() {
this.beforeCalling && this.beforeCalling();
}
executeExternalAfterCalling() {
this.afterCalling && this.afterCalling();
}
setVideoDisplayMode(A) {
d.update(c.CALL, o.DISPLAY_MODE, A);
}
async setVideoResolution(A) {
var t;
try {
if (!A)
return;
d.update(c.CALL, o.VIDEO_RESOLUTION, A), await ((t = this._tuiCallEngine) == null ? void 0 : t.setVideoQuality(A));
} catch (e) {
console.warn(`${o.PREFIX}setVideoResolution failed, error: ${e}.`);
}
}
startTimer() {
this._timerId === -1 && (this._startTimeStamp = Ot(), this._timerId = nt.run(o.TIMEOUT, this._updateCallDuration.bind(this), { delay: 1e3 }));
}
_handleCallError(A, t) {
if (this._permissionCheckTimer && clearInterval(this._permissionCheckTimer), !Ua(A))
throw bt(A, F.AUDIO, this._tuiCallEngine), console.error(`${o.PREFIX}${t} failed, error: ${A}.`), this._resetCallStore(), A;
}
async _updateCallStoreBeforeCall(A, t, e) {
const a = e || d.getData(c.CALL, o.IS_MINIMIZED) ? sA.CALLER_GROUP_CALLING_MSG : sA.CALLER_CALLING_MSG;
let n = {
[o.CALL_MEDIA_TYPE]: A,
[o.CALL_ROLE]: K.CALLER,
[o.REMOTE_USER_INFO_LIST]: t,
[o.REMOTE_USER_INFO_EXCLUDE_VOLUMN_LIST]: t,
[o.IS_GROUP]: !!e,
[o.CALL_TIPS]: v(a),
[o.GROUP_ID]: e
};
d.updateStore({ ...n, [o.CALL_STATUS]: U.CALLING }, c.CALL), this.statusChanged && this.statusChanged({
oldStatus: nA.IDLE,
newStatus: e ? nA.DIALING_GROUP : nA.DIALING_C2C
}), Vt(this._tuiCallEngine);
const l = await ie(t.map((i) => i.userId), this.getTim());
l.length > 0 && (d.update(c.CALL, o.REMOTE_USER_INFO_LIST, l), d.update(c.CALL, o.REMOTE_USER_INFO_EXCLUDE_VOLUMN_LIST, l));
}
async _updateCallStoreAfterCall(A, t) {
var e, a;
if (t) {
d.update(c.CALL, o.IS_CLICKABLE, !0), po(t == null ? void 0 : t.roomID, t == null ? void 0 : t.strRoomID);
const n = d.getData(c.CALL, o.CALL_MEDIA_TYPE);
if (t.code === 0) {
(a = this._chatCombine) == null || a.callTUIService({ message: (e = t == null ? void 0 : t.data) == null ? void 0 : e.message });
try {
await this._tuiCallEngine.setVideoQuality(d.getData(c.CALL, o.VIDEO_RESOLUTION));
} catch (u) {
console.warn(`${o.PREFIX}setVideoQuality failed, error: ${u}.`);
}
} else {
this._resetCallStore();
return;
}
const l = this._getFeatureButtonDefaultState(zA.Camera) === JA.Close;
n === F.VIDEO && !l && await this.openCamera(o.LOCAL_VIDEO);
const i = d.getData(c.CALL, o.LOCAL_USER_INFO);
d.update(c.CALL, o.LOCAL_USER_INFO, { ...i, isEnter: !0 }), d.update(c.CALL, o.LOCAL_USER_INFO_EXCLUDE_VOLUMN, { ...i, isEnter: !0 }), FA(!0, o.AUDIO);
} else
this._permissionCheckTimer && clearInterval(this._permissionCheckTimer), this._permissionCheckTimer = null, this._resetCallStore();
}
_getFeatureButtonDefaultState(A) {
var e;
const { button: t } = d.getData(c.CALL, o.CUSTOM_UI_CONFIG);
return (e = t == null ? void 0 : t[A]) == null ? void 0 : e.state;
}
_updateCallDuration() {
const A = Math.round((Ot() - this._startTimeStamp) / 1e3), t = No(A);
d.update(c.CALL, o.CALL_DURATION, t);
}
_stopTimer() {
this._timerId !== -1 && (nt.clearTask(this._timerId), this._timerId = -1);
}
_resetCallStore() {
const A = _e();
this._stopTimer();
let t = Object.keys(Ke).filter((n) => {
switch (Ke[n]) {
case o.CALL_STATUS:
case o.LANGUAGE:
case o.IS_GROUP:
case o.DISPLAY_MODE:
case o.VIDEO_RESOLUTION:
case o.ENABLE_FLOAT_WINDOW:
case o.LOCAL_USER_INFO:
case o.IS_SHOW_ENABLE_VIRTUAL_BACKGROUND:
case o.LOCAL_USER_INFO_EXCLUDE_VOLUMN:
return !1;
default:
return !0;
}
});
t = t.map((n) => Ke[n]), d.reset(c.CALL, t), d.getData(c.CALL, o.CALL_STATUS) !== U.IDLE && d.reset(c.CALL, [o.CALL_STATUS], !0), d.reset(c.CALL, [o.IS_MINIMIZED], !0), d.reset(c.CALL, [o.IS_EAR_PHONE], !0), d.reset(c.CALL, [o.ENABLE_VIRTUAL_BACKGROUND], !0), d.reset(c.CALL, [o.IS_MUTE_SPEAKER], !0), d.update(c.CALL, o.LOCAL_USER_INFO, {
...d.getData(c.CALL, o.LOCAL_USER_INFO),
isVideoAvailable: !1,
isAudioAvailable: !1
}), d.update(c.CALL, o.LOCAL_USER_INFO_EXCLUDE_VOLUMN, {
...d.getData(c.CALL, o.LOCAL_USER_INFO_EXCLUDE_VOLUMN),
isVideoAvailable: !1,
isAudioAvailable: !1
}), d.update(c.CALL, o.REMOTE_USER_INFO_LIST, []), d.update(c.CALL, o.REMOTE_USER_INFO_EXCLUDE_VOLUMN_LIST, []);
const a = _e();
A !== a && this.statusChanged && this.statusChanged({ oldStatus: A, newStatus: a });
}
async getGroupMemberList(A, t) {
const e = d.getData(c.CALL, o.GROUP_ID);
return await di(e, this.getTim(), A, t);
}
async getGroupProfile() {
const A = d.getData(c.CALL, o.GROUP_ID);
return await Ii(A, this.getTim());
}
_watchTUIStore() {
d == null || d.watch(c.CALL, {
[o.CALL_STATUS]: this._handleCallStatusChange
});
}
_unwatchTUIStore() {
d == null || d.unwatch(c.CALL, {
[o.CALL_STATUS]: this._handleCallStatusChange
});
}
bindTUICore(A) {
this._TUICore = A;
}
getTim() {
var A, t;
return this._tim ? this._tim : this._tuiCallEngine ? ((A = this._tuiCallEngine) == null ? void 0 : A.tim) || ((t = this._tuiCallEngine) == null ? void 0 : t.getTim()) : (console.warn(`${o.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());
}
};
let G = te;
Q([
$(),
cA(rA.init)
], G.prototype, "init", 1);
Q([
$(),
cA(rA.call),
ht({ engineInstance: !0 })
], G.prototype, "call", 1);
Q([
$(),
cA(rA.groupCall),
ht({ engineInstance: !0 })
], G.prototype, "groupCall", 1);
Q([
$(),
cA(rA.inviteUser),
ht({ engineInstance: !0 })
], G.prototype, "inviteUser", 1);
Q([
$(),
cA(rA.joinInGroupCall),
ht({ engineInstance: !0 })
], G.prototype, "joinInGroupCall", 1);
Q([
cA(rA.setLanguage)
], G.prototype, "setLanguage", 1);
Q([
cA(rA.enableFloatWindow)
], G.prototype, "enableFloatWindow", 1);
Q([
cA(rA.setSelfInfo)
], G.prototype, "setSelfInfo", 1);
Q([
cA(rA.enableAIVoice)
], G.prototype, "enableAIVoice", 1);
Q([
cA(rA.setCallingBell)
], G.prototype, "setCallingBell", 1);
Q([
cA(rA.enableMuteMode)
], G.prototype, "enableMuteMode", 1);
Q([
$()
], G.prototype, "accept", 1);
Q([
$()
], G.prototype, "hangup", 1);
Q([
$()
], G.prototype, "reject", 1);
Q([
$()
], G.prototype, "openCamera", 1);
Q([
$()
], G.prototype, "closeCamera", 1);
Q([
$()
], G.prototype, "openMicrophone", 1);
Q([
$()
], G.prototype, "closeMicrophone", 1);
Q([
$()
], G.prototype, "unMuteSpeaker", 1);
Q([
$()
], G.prototype, "muteSpeaker", 1);
Q([
$()
], G.prototype, "switchScreen", 1);
Q([
$()
], G.prototype, "switchCallMediaType", 1);
Q([
$()
], G.prototype, "switchCamera", 1);
Q([
$()
], G.prototype, "setBlurBackground", 1);
Q([
$()
], G.prototype, "switchDevice", 1);
Q([
cA(rA.setVideoDisplayMode)
], G.prototype, "setVideoDisplayMode", 1);
Q([
cA(rA.setVideoResolution)
], G.prototype, "setVideoResolution", 1);
const O = G.getInstance(), Ft = Xt.version, To = "CallInfoContextKey", Co = "CallerUserInfoContextKey", yo = "UserInfoExcludeVolumeContextKey", So = "FocusContextKey", Eo = "ButtonPanelContextKey", ho = "FloatWindowContextKey", mo = "IsClickableContextKey", jo = "PopoverContextKey", vo = "CustomUIConfigContextKey";
function vi() {
return NA(Co);
}
function q() {
return NA(To);
}
function mt(A) {
const t = I([]), e = I(""), a = (l) => {
var i, u, s;
switch (A) {
case oA.CAMERA:
t.value = (l == null ? void 0 : l.cameraList) || [], e.value = ((i = l == null ? void 0 : l.currentCamera) == null ? void 0 : i.deviceId) || "";
break;
case oA.MICROPHONE:
t.value = (l == null ? void 0 : l.microphoneList) || [], e.value = ((u = l == null ? void 0 : l.currentMicrophone) == null ? void 0 : u.deviceId) || "";
break;
case oA.SPEAKER:
t.value = (l == null ? void 0 : l.speakerList) || [], e.value = ((s = l == null ? void 0 : l.currentSpeaker) == null ? void 0 : s.deviceId) || "";
break;
}
}, n = (l) => {
e.value = l;
};
return aA(() => {
d.watch(
c.CALL,
{
[o.DEVICE_LIST]: a
},
{
notifyRangeWhenWatch: o.MYSELF
}
);
}), tA(() => {
d.unwatch(c.CALL, {
[o.DEVICE_LIST]: a
});
}), [{ deviceList: t, currentDeviceId: e }, { updateCurrentDeviceId: n }];
}
const Va = (A) => typeof A == "object" && A !== null, fo = (A, t) => {
if (!Va(A) || !Va(t))
return A === t;
if (A === t)
return !0;
const e = Object.keys(A), a = Object.keys(t);
if (e.length !== a.length)
return !1;
for (let n in A)
if (!fo(A[n], t[n]))
return !1;
return !0;
};
function fi(A) {
const t = document.getElementById(A);
!document.fullscreenElement && t ? t.requestFullscreen().catch((e) => {
console.error(`Error attempting to enable fullscreen mode: ${e.message} (${e.name})`);
}) : document.exitFullscreen();
}
function jt(A) {
if (typeof A != "object" || A === null)
return A;
let t = Array.isArray(A) ? [] : {};
for (let e in A)
A.hasOwnProperty(e) && (t[e] = jt(A[e]));
return t;
}
const Li = 500;
function Jt(A, t) {
if (typeof A != "function" || t != null && typeof t != "function")
throw new TypeError("Expected a function");
const e = function(...a) {
const n = t ? t.apply(this, a) : a[0], l = e.cache;
if (l.has(n))
return l.get(n);
const i = A.apply(this, a);
return e.cache = l.set(n, i) || l, i;
};
return e.cache = new (Jt.Cache || Map)(), e;
}
Jt.Cache = Map;
function Ui(A) {
const t = Jt(A, (e) => {
const { cache: a } = t;
return a.size === Li && a.clear(), e;
});
return t;
}
const zi = ".".charCodeAt(0), wi = /\\(\\)?/g, Oi = RegExp(
`[^.[\\]]+|\\[(?:([^"'][^[]*)|(["'])((?:(?!\\2)[^\\\\]|\\\\.)*?)\\2)\\]|(?=(?:\\.|\\[\\])(?:\\.|\\[\\]|$))`,
"g"
), Lo = Ui((A) => {
const t = [];
return A.charCodeAt(0) === zi && t.push(""), A.replace(Oi, (e, a, n, l) => {
let i = e;
n ? i = l.replace(wi, "$1") : a && (i = a.trim()), t.push(i);
}), t;
});
function RA(A, t, e) {
if (typeof A != "object" || !t)
return;
const a = Lo(t);
let n = A;
for (let l = 0; l < a.length; l++) {
if (n == null)
return;
const i = a[l];
l !== a.length - 1 ? n = n == null ? void 0 : n[i] : Object.assign(n, { [i]: e });
}
}
function $A(A, t, e) {
if (typeof A != "object")
return;
const a = Lo(t);
let n = A;
for (let l = 0; l < a.length; l++) {
if (n == null)
return;
const i = a[l];
l !== a.length - 1 ? n = n == null ? void 0 : n[i] : Array.isArray(n) && n.splice(i, 0, e);
}
}
function xi(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 Gt(A, t, e, a, n) {
Object.keys(A).forEach((l) => {
const i = A[l], u = xi(e) ? l : `${e}.${l}`;
if (typeof i == "object")
if (Array.isArray(i))
for (let s = 0; s < i.length; s++) {
const r = `${u}.${s}`;
Gt(i[s], t, r, a, n);
}
else
Gt(i, t, u, a, n);
else if (t(i)) {
const s = typeof n == "function" ? n({ key: i, value: u }) : u;
a.push(s);
}
});
}
function Uo() {
const A = I(), t = I(d.getData(c.CALL, o.REMOTE_USER_INFO_LIST)), e = (l) => {
(j.isWeChat ? l.enableMic : l.isAudioAvailable) && (A.value = { ...A.value, localVideo: l.volume });
}, a = (l) => {
const i = {};
(l.length !== t.value.length || !fo(l, t.value)) && (t.value = l, t.value.forEach((u) => {
if (j.isWeChat ? u.hasAudio : u.isAudioAvailable) {
const r = j.isWeChat ? u.userID : u.domId;
i[r] = u.volume;
}
}), A.value = { ...A.value, ...i });
};
let n = {
[o.LOCAL_USER_INFO]: e,
[o.REMOTE_USER_INFO_LIST]: a
};
return j.isUniPlatform && (n = {
[o.PUSHER]: e,
[o.PLAYER]: a
}), aA(() => {
d.watch(
c.CALL,
n,
{
notifyRangeWhenWatch: o.MYSELF
}
);
}), tA(() => {
d.unwatch(c.CALL, n);
}), A;
}
function Vi() {
const A = I(""), t = I(!0), e = I(0), a = (l) => {
e.value = 0, A.value = l;
}, n = (l) => {
let i = l;
typeof i == "object" && (i = l == null ? void 0 : l.text), i && (e.value = 2e3, A.value = i);
};
return aA(() => {
d.watch(
c.CALL,
{
[o.CALL_TIPS]: a
},
{
notifyRangeWhenWatch: o.MYSELF
}
), d.watch(
c.CALL,
{
[o.TOAST_INFO]: n
}
);
}), tA(() => {
d.unwatch(
c.CALL,
{
[o.CALL_TIPS]: a,
[o.TOAST_INFO]: n
}
);
}), { tip: A, show: t, duration: e };
}
function bi() {
const A = I(d.getData(c.CALL, o.NETWORK_STATUS)), t = (e) => {
A.value = e;
};
return aA(() => {
d.watch(
c.CALL,
{
[o.NETWORK_STATUS]: t
},
{
notifyRangeWhenWatch: o.MYSELF
}
);
}), tA(() => {
d.unwatch(c.CALL, {
[o.NETWORK_STATUS]: t
});
}), { netWorkQualityList: A };
}
function zo() {
const A = I(d.getData(c.CALL, o.PLAYER)), t = (a) => {
A.value = a == null ? void 0 : a.map((n) => {
const { userID: l, hasVideo: i, hasAudio: u } = n;
return { userID: l, hasVideo: i, hasAudio: u };
});
}, e = {
[o.PLAYER]: t
};
return aA(() => {
d.watch(
c.CALL,
e,
{ notifyRangeWhenWatch: o.MYSELF }
);
}), tA(() => {
d.unwatch(c.CALL, e);
}), A;
}
function MA() {
return NA(yo);
}
function Ht() {
const A = I(d.getData(c.CALL, o.CALL_DURATION)), t = (e) => {
A.value = e;
};
return aA(() => {
d.watch(
c.CALL,
{
[o.CALL_DURATION]: t
},
{
notifyRangeWhenWatch: o.MYSELF
}
);
}), tA(() => {
d.unwatch(
c.CALL,
{
[o.CALL_DURATION]: t
}
);
}), { callDuration: A };
}
function We() {
return NA(Eo, { status: I("open") });
}
function wo() {
return NA(So, I("open"));
}
function CA() {
return NA(ho);
}
function Bi() {
return NA(mo);
}
function vt() {
return NA(jo);
}
const Fi = (A, t) => {
const e = [{
i: 0,
x: 0,
y: 0,
w: t,
h: t
}];
for (let a = 1; a < A; a++) {
const n = e[a - 1].x + t === 12;
e[a] = {
i: a,
x: e[a - 1].x + t === 12 ? 0 : e[a - 1].x + t,
y: e[a - 1].y + (n ? t : 0),
w: t,
h: t
};
}
return A === 3 && (e[A - 1].x += 3), A > 3 && j.isPC && A % 3 === 2 && (e[A - 1].x += 2, e[A - 2].x += 2), e;
};
function Ri(A, t) {
const { isFloatWindow: e } = z(CA()), a = I();
return J([A, t, e], () => {
if (e.value) {
const r = [];
for (let M = 0; M < t.value; M++)
r[M] = {
i: M,
x: 0,
y: 0,
w: 12,
h: 12
};
a.value = r;
return;
}
const n = Object.keys(Array.from({ length: t.value })), l = t.value <= 4 ? 6 : 4, i = Fi(t.value, l);
a.value = i;
let u, s;
if (A.value !== null) {
if (n.length < 5) {
const r = n.concat();
r.splice(A.value, 1), r.unshift(A.value);
} else
s = A.value % 3, u = Math.floor(A.value / 3);
if (n.length < 5) {
const r = i.findIndex((M) => M.i === A.value);
if (r !== -1) {
const M = i[0];
i[0] = i[r], i[r] = M;
for (let D = 0; D < i.length; D++) {
const g = i[D];
D === 0 ? (g.w += 6, g.h += 6, g.x = 0, g.y = 0) : (g.x = (D - 1) * 4, g.y = 12, g.w = 4, g.h = 4);
}
}
} else {
let r;
s === 0 ? (i[A.value + 1] && (i[A.value + 1].x += 4), i[A.value + 2] && (i[A.value + 2].y += 4), r = {
i: A.value,
x: 0,
y: u * 4,
w: 8,
h: 8
}) : s === 2 ? (r = {
i: A.value,
x: 4,
y: u * 4,
w: 8,
h: 8
}, i[A.value - 1].x = 0, i[A.value - 1].y += 4) : s === 1 && (r = {
i: A.value,
x: 4,
y: u * 4,
w: 8,
h: 8
}, i[A.value + 1] && (i[A.value + 1].x = 0, i[A.value + 1].y += 4));
const M = 3 - s;
for (let D = A.value + M; D < i.length; D++) {
const g = i[D];
g.y += 4;
}
i[A.value] = r;
}
a.value = i;
}
}, {
immediate: !0
}), a;
}
function Ge() {
return NA(vo);
}
const ki = {
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: {} }
]]
}, Pi = {
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" }
]
]
}
}
}, Wi = {
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" }
]
]
}
}
}, ba = {
pc: Wi,
mobile: Pi
};
function Oo(A) {
const t = jt(A);
return RA(t, "mobile.singleCall.video", ki), $A(t, "pc.singleCall.video.calling[0][2]", { name: "virtualBackground", props: {} }), $A(t, "pc.singleCall.video.accept[0][1]", { name: "virtualBackground", props: {} }), $A(t, "pc.singleCall.video.connected[0][3]", { name: "virtualBackground", props: {} }), $A(t, "pc.groupCall.video.calling[0][3]", { name: "virtualBackground", props: {} }), $A(t, "pc.groupCall.video.connected[0][4]", { name: "virtualBackground", props: {} }), t;
}
function Gi(A, t, e) {
let a = jt(A);
return t ? (RA(a, "mobile.singleCall.video.connected[1][2].props.show", !0), e && Oo(a)) : (RA(a, "mobile.singleCall.video.connected[1][2].props.show", !1), e && (RA(a, "mobile.singleCall.video.connected[1][0].props.show", !1), RA(a, "pc.singleCall.video.connected[0][3].props.show", !1), RA(a, "pc.groupCall.video.connected[0][4].props.show", !1))), a;
}
function Qi() {
const { isShowEnableVirtualBackground: A, callStatus: t } = z(q()), e = Ge(), { localUserInfoExcludeVolume: a } = z(MA()), n = p(() => (a == null ? void 0 : a.value.isVideoAvailable) || !1), l = p(() => A.value && !j.isH5), i = I([]);
return J([e, A, n], () => {
let u = jt(ba);
l.value && (u = Oo(ba)), t.value === U.CONNECTED && (u = Gi(u, n.value, l.value));
const { button: s } = e.value, r = [];
function M(g) {
return Object.keys(s).includes(g);
}
function D({ key: g, value: N }) {
var w;
const y = N.split(".");
let T = y.slice(0, y.length - 1);
const C = y.slice(0, y.length - 2);
if (C[C.length - 1] === "0")
for (let L = 0; L < 3; L++) {
let m = C.slice();
m.push(L), m.push("customStyle"), m.push("justifyContent"), m = m.join("."), r.push({ path: m, value: "center" });
}
return T.push("props"), T.push("show"), T = T.join("."), {
path: T,
value: (w = s == null ? void 0 : s[g]) == null ? void 0 : w.show
};
}
Gt(u, M, "", r, D), r == null || r.forEach((g) => {
RA(u, g.path, g.value);
}), i.value = u;
}, {
immediate: !0
}), i;
}
function xo() {
const A = Ge(), t = I(A.value.viewBackground);
return J(A, () => {
t.value = A.value.viewBackground;
}), t;
}
function Zi() {
const A = I(d.getData(c.CALL, o.ROOM_ID)), t = I(d.getData(c.CALL, o.ROOM_ID_TYPE)), e = I(d.getData(c.CALL, o.GROUP_ID)), a = I(d.getData(c.CALL, o.CALL_MEDIA_TYPE)), n = I(d.getData(c.CALL, o.GROUP_CALL_MEMBERS)), l = I(d.getData(c.CALL, o.CALL_STATUS)), i = (N) => {
A.value = N;
}, u = (N) => {
e.value = N;
}, s = (N) => {
a.value = N;
}, r = (N) => {
n.value = N;
}, M = (N) => {
l.value = N;
}, D = (N) => {
t.value = N;
}, g = {
[o.ROOM_ID]: i,
[o.GROUP_ID]: u,
[o.CALL_MEDIA_TYPE]: s,
[o.GROUP_CALL_MEMBERS]: r,
[o.CALL_STATUS]: M,
[o.ROOM_ID_TYPE]: D
};
return aA(() => {
d.watch(
c.CALL,
g,
{
notifyRangeWhenWatch: o.MYSELF
}
);
}), tA(() => {
d.unwatch(c.CALL, g);
}), {
roomId: A,
roomIdType: t,
groupId: e,
callMediaType: a,
groupCallMembers: n,
callStatus: l
};
}
const Yi = {
customStyle: {
type: Object
},
customClass: {
type: String
}
}, Xi = ["start", "center", "end", "space-around", "space-between", "space-evenly"], _i = ["top", "middle", "bottom"], qi = {
gutter: {
type: Number,
default: 0
},
justify: {
type: String,
values: Xi,
default: "start"
},
align: {
type: String,
values: _i,
default: "top"
},
customStyle: {
type: Object,
default: () => {
}
}
};
function X(...A) {
const t = [], e = {}.hasOwnProperty;
for (let a = 0; a < A.length; a++) {
const n = A[a];
if (!n)
continue;
const l = typeof n;
if (l === "string" || l === "number")
t.push(n);
else if (Array.isArray(n)) {
if (n.length) {
const i = X.apply(null, n);
i && t.push(i);
}
} else if (l === "object") {
if (n.toString !== Object.prototype.toString && !n.toString.toString().includes("[native code]")) {
t.push(n.toString());
continue;
}
for (const i in n)
e.call(n, i) && n[i] && t.push(i);
}
}
return t.join(" ");
}
const se = typeof wx < "u" && typeof wx.getSystemInfoSync == "function" && Boolean(wx.getSystemInfoSync().fontSizeSetting), Ji = typeof uni < "u" && typeof uni > "u", Qt = se || Ji, Hi = typeof uni < "u", Vo = function() {
return (typeof uni < "u" || typeof window < "u") && !Qt;
}();
(function() {
return se ? wx : Hi ? uni : window;
})();
const OA = Vo && window && window.navigator && window.navigator.userAgent || "", Ki = /Android/i.test(OA), $i = /(?:Windows Phone)/.test(OA), As = /(?:SymbianOS)/.test(OA), es = /iPad/i.test(OA) || /iPhone/i.test(OA) || /iPod/i.test(OA), bo = Ki || $i || As || es, WA = Vo && !bo;
WA && OA.includes("Windows NT");
WA && OA.includes("Mac");
function ot(A) {
const t = {};
for (const e in A)
Object.prototype.hasOwnProperty.call(A, e) && A[e] !== void 0 && (t[e] = A[e]);
return t;
}
function ts() {
let A = "unknow";
return typeof Ft == "string" && (A = Ft.split(".")[0]), { version: Ft, majorVersion: A };
}
function Ba(A, t) {
const { key: e, value: a } = t;
return A.find((n) => n[e] === a);
}
const Bo = "RowContextKey", x = "tk", ae = {
SUCCESS: "success",
INFO: "info",
WARNING: "warning",
ERROR: "error"
}, Kt = {
options: {
virtualHost: !0
}
};
Kt.props = qi;
Kt.setup = (A, t) => {
const e = A, a = p(() => e.gutter);
return gA(Bo, {
gutter: a
}), {
classname: X([`${x}-row`, `${x}-justify-${e.justify}`, `${x}-align-${e.align}`])
};
};
var as = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
class: A.classname,
style: [A.customStyle]
}, [A._t("default")], 2);
}, ns = [];
function S(A, t, e, a, n, l, i, u) {
var s = typeof A == "function" ? A.options : A;
t && (s.render = t, s.staticRenderFns = e, s._compiled = !0), a && (s.functional = !0), l && (s._scopeId = "data-v-" + l);
var r;
if (i ? (r = function(g) {
g = g || this.$vnode && this.$vnode.ssrContext || this.parent && this.parent.$vnode && this.parent.$vnode.ssrContext, !g && typeof __VUE_SSR_CONTEXT__ < "u" && (g = __VUE_SSR_CONTEXT__), n && n.call(this, g), g && g._registeredComponents && g._registeredComponents.add(i);
}, s._ssrRegister = r) : n && (r = u ? function() {
n.call(
this,
(s.functional ? this.parent : this).$root.$options.shadowRoot
);
} : n), r)
if (s.functional) {
s._injectStyles = r;
var M = s.render;
s.render = function(N, y) {
return r.call(y), M(N, y);
};
} else {
var D = s.beforeCreate;
s.beforeCreate = D ? [].concat(D, r) : [r];
}
return {
exports: A,
options: s
};
}
const Fa = {};
var os = /* @__PURE__ */ S(
Kt,
as,
ns,
!1,
ls,
null,
null,
null
);
function ls(A) {
for (let t in Fa)
this[t] = Fa[t];
}
const $t = /* @__PURE__ */ function() {
return os.exports;
}(), is = ["start", "center", "end", "space-around", "space-between", "space-evenly"], ss = ["top", "middle", "bottom"], us = {
span: {
type: Number,
default: 24
},
justify: {
type: String,
values: is,
default: "start"
},
align: {
type: String,
values: ss,
default: "middle"
},
offset: {
type: Number,
default: 0
}
}, Aa = {
options: {
virtualHost: !0
}
};
Aa.props = us;
Aa.setup = (A, t) => {
const e = A, {
gutter: a
} = NA(Bo, {
gutter: p(() => 0)
}), n = X([`${x}-col`, `${x}-justify-${e.justify}`, `${x}-align-${e.align}`]), l = p(() => `${e.span / 24 * 100}%`), i = p(() => `${e.offset / 24 * 100}%`), u = p(() => `${a.value / 2}px`);
return {
classname: n,
width: l,
marginLeft: i,
paddingLeft: u,
paddingRight: u
};
};
var cs = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
class: A.classname,
style: {
width: A.width,
marginLeft: A.marginLeft,
paddingLeft: A.paddingLeft,
paddingRight: A.paddingRight
}
}, [A._t("default")], 2);
}, rs = [];
const Ra = {};
var Ms = /* @__PURE__ */ S(
Aa,
cs,
rs,
!1,
ds,
null,
null,
null
);
function ds(A) {
for (let t in Ra)
this[t] = Ra[t];
}
const ea = /* @__PURE__ */ function() {
return Ms.exports;
}(), Is = {
width: {
type: String,
default: "40px"
},
height: {
type: String,
default: "40px"
},
color: {
type: String
}
}, ta = {
options: {
virtualHost: !0
}
};
ta.props = Is;
ta.setup = (A, t) => {
const e = A, a = `${x}-loading_dot-container`, n = `${x}-loading_dot`, l = p(() => ({
width: e.width,
height: e.height
})), i = p(() => {
const u = {};
return e.color && (u.backgroundColor = e.color), u;
});
return {
dotContainerClassName: a,
dotClassName: n,
dotContainerStyle: l,
dotStyle: i
};
};
var gs = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
class: A.dotContainerClassName,
style: [A.dotContainerStyle]
}, [e("div", {
class: A.dotClassName,
style: [A.dotStyle]
}), e("div", {
class: A.dotClassName,
style: [A.dotStyle]
}), e("div", {
class: A.dotClassName,
style: [A.dotStyle]
})]);
}, Ns = [];
const ka = {};
var ps = /* @__PURE__ */ S(
ta,
gs,
Ns,
!1,
Ds,
null,
null,
null
);
function Ds(A) {
for (let t in ka)
this[t] = ka[t];
}
const Ts = /* @__PURE__ */ function() {
return ps.exports;
}(), Cs = {
width: {
type: String,
default: "40px"
},
height: {
type: String,
default: "40px"
},
color: {
type: String
}
}, aa = {
options: {
virtualHost: !0
}
};
aa.props = Cs;
aa.setup = (A, t) => {
const e = A, a = p(() => {
const l = {
width: e.width,
height: e.height
};
return e.color && (l["--tk-loading-primary-color"] = e.color), l;
}), n = `${x}-loading_circle-container`;
return {
circleContainerStyle: a,
circleContainerClassName: n
};
};
var ys = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
class: A.circleContainerClassName,
style: [A.circleContainerStyle]
});
}, Ss = [];
const Pa = {};
var Es = /* @__PURE__ */ S(
aa,
ys,
Ss,
!1,
hs,
null,
null,
null
);
function hs(A) {
for (let t in Pa)
this[t] = Pa[t];
}
const ms = /* @__PURE__ */ function() {
return Es.exports;
}(), js = ["circle", "dot"], vs = ["row", "column"], fs = {
mode: {
type: String,
values: js,
default: "circle"
},
loadingWidth: {
type: String,
default: "40px"
},
loadingHeight: {
type: String,
default: "40px"
},
color: {
type: String
},
text: {
type: String
},
layout: {
type: String,
values: vs,
default: "column"
}
}, ue = {
options: {
virtualHost: !0
}
};
ue.props = fs;
ue.setup = (A, t) => {
const e = A, a = `${x}-loading ${x}-loading--${e.mode}`, n = `${x}-loading_text`, l = p(() => ({
flexDirection: e.layout
}));
return {
loadingContainerClassName: a,
loadingTextClassName: n,
loadingContainerStyle: l
};
};
ue.components = Object.assign({
LoadingDot: Ts,
LoadingCircle: ms
}, ue.components);
var Ls = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
class: A.loadingContainerClassName,
style: [A.loadingContainerStyle]
}, [A.mode === "dot" ? e("LoadingDot", {
attrs: {
width: A.loadingWidth,
height: A.loadingHeight,
color: A.color
}
}) : e("LoadingCircle", {
attrs: {
width: A.loadingWidth,
height: A.loadingHeight,
color: A.color
}
}), A.text ? e("div", {
class: A.loadingTextClassName
}, [A._v(A._s(A.text))]) : A._e()], 1);
}, Us = [];
const Wa = {};
var zs = /* @__PURE__ */ S(
ue,
Ls,
Us,
!1,
ws,
null,
null,
null
);
function ws(A) {
for (let t in Wa)
this[t] = Wa[t];
}
const na = /* @__PURE__ */ function() {
return zs.exports;
}(), Os = {
src: {
type: String
},
size: {
type: Number,
default: 20
}
}, xs = ["fill", "contain", "cover"], Ga = {
fill: "scaleToFill",
contain: "aspectFit",
cover: "aspectFill"
}, Vs = {
width: {
type: String,
default: "320px"
},
height: {
type: String,
default: "240px"
},
src: {
type: String
},
fit: {
type: String,
values: xs,
default: "fill"
},
customStyle: {
type: Object
},
defaultSrc: {
type: String
}
}, oa = {
options: {
virtualHost: !0
}
};
oa.props = Vs;
oa.setup = (A, t) => {
const e = A, a = t.emit, n = I(!1), l = I(e.src);
J(() => e.src, () => {
n.value = !1, l.value = e.src;
});
const i = p(() => X([`${x}-image`])), u = p(() => ({
width: e.width,
height: e.height,
...e.customStyle
})), s = p(() => X([`${x}-image_inner`])), r = p(() => se ? Ga[e.fit] || Ga.cover : e.fit);
function M(D) {
n.value = !0, l.value = e.defaultSrc, a("error", D);
}
return {
IN_WX_MINI_APP: se,
hasLoadError: n,
imgSrc: l,
classname: i,
imgStyle: u,
imageClassName: s,
objectFit: r,
handleError: M
};
};
var bs = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
class: A.classname,
style: [A.imgStyle]
}, [A.hasLoadError && !A.defaultSrc ? [A._t("error")] : [A.IN_WX_MINI_APP ? A._e() : e("img", {
class: A.imageClassName,
style: {
objectFit: A.objectFit
},
attrs: {
src: A.imgSrc
},
on: {
error: A.handleError
}
}), A.IN_WX_MINI_APP ? e("image", {
class: A.imageClassName,
attrs: {
src: A.imgSrc,
mode: A.objectFit
},
on: {
error: A.handleError
}
}) : A._e()]], 2);
}, Bs = [];
const Qa = {};
var Fs = /* @__PURE__ */ S(
oa,
bs,
Bs,
!1,
Rs,
null,
null,
null
);
function Rs(A) {
for (let t in Qa)
this[t] = Qa[t];
}
const SA = /* @__PURE__ */ function() {
return Fs.exports;
}(), ce = {
options: {
virtualHost: !0
}
};
ce.props = Os;
ce.setup = (A, t) => {
const e = A, a = p(() => `${e.size}px`), n = p(() => `${e.size}px`);
return {
width: a,
height: n
};
};
ce.components = Object.assign({
TKImage: SA
}, ce.components);
var ks = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("TKImage", {
attrs: {
src: A.src,
width: A.width,
height: A.height
}
});
}, Ps = [];
const Za = {};
var Ws = /* @__PURE__ */ S(
ce,
ks,
Ps,
!1,
Gs,
null,
null,
null
);
function Gs(A) {
for (let t in Za)
this[t] = Za[t];
}
const ft = /* @__PURE__ */ function() {
return Ws.exports;
}(), Qs = ["small", "middle", "large"], Zs = ["row", "column"], Ys = ["circle", "round"], Xs = {
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: Qs,
default: "middle"
},
width: {
type: String
},
height: {
type: String
},
color: {
type: String
},
direction: {
type: String,
values: Zs,
default: "row"
},
shape: {
type: String,
values: Ys
},
buttonStyle: {
type: Object
},
buttonTextStyle: {
type: Object
}
}, re = {
options: {
virtualHost: !0
}
};
re.props = Xs;
re.setup = (A, t) => {
const e = A, a = `${x}-button--content`, n = p(() => ({
width: e.width,
height: e.height,
backgroundColor: e.color,
flexDirection: e.direction,
cursor: WA ? "pointer" : "auto",
...e.buttonStyle
})), l = X([`${x}-button`, {
[`${x}-${e.shape}`]: e.shape
}, `${x}-button--${e.size}`]), i = t.emit;
return {
buttonTextClassName: a,
style: n,
buttonClassName: l,
handleClick: (s) => {
!e.loading && i("click", s);
}
};
};
re.components = Object.assign({
Loading: na,
Icon: ft
}, re.components);
var _s = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
class: A.buttonClassName,
style: [A.style],
on: {
click: A.handleClick
}
}, [A.loading ? e("Loading", {
attrs: {
loadingWidth: A.loadingWidth,
loadingHeight: A.loadingHeight,
color: A.loadingColor
}
}) : A._e(), A.iconSrc && !A.loading ? e("Icon", {
attrs: {
size: A.iconSize,
src: A.iconSrc
}
}) : A._e(), A.text ? e("div", {
class: A.buttonTextClassName,
style: [A.buttonTextStyle]
}, [A._v(" " + A._s(A.text) + " ")]) : A._e()], 1);
}, qs = [];
const Ya = {};
var Js = /* @__PURE__ */ S(
re,
_s,
qs,
!1,
Hs,
null,
null,
null
);
function Hs(A) {
for (let t in Ya)
this[t] = Ya[t];
}
const pA = /* @__PURE__ */ function() {
return Js.exports;
}(), Zt = "", Fo = "", Ro = "
let Qo = au, Zo = nu;
eA || (Qo = eu, Zo = tu);
const R = {
width: eA ? "60px" : "40px",
height: eA ? "60px" : "40px",
shape: "circle",
iconSize: eA ? 30 : 20,
showText: !0,
textColor: "#D5E0F2",
textSize: "12px",
textStyle: {
marginTop: "5px"
}
}, h = {
accept: {
basicConfig: {
...R,
color: "#51C271",
iconSrc: $s
},
loadingConfig: {
...R,
color: "#51C271",
loadingWidth: eA ? "30px" : "20px",
loadingHeight: eA ? "30px" : "20px"
}
},
hangup: {
basicConfig: {
...R,
color: "#ED4651",
iconSrc: Zt
},
loadingConfig: {
...R,
color: "#ED4651",
loadingWidth: eA ? "30px" : "20px",
loadingHeight: eA ? "30px" : "20px"
}
},
reject: {
basicConfig: {
...R,
color: "#ED4651",
iconSrc: Zt
}
},
camera: {
basicConfig: {
...R,
color: "#FFFFFF",
iconSrc: Fo,
shape: "circle"
},
closedConfig: {
...R,
color: "#6b758a4d",
iconSrc: Ro
},
loadingConfig: {
...R,
color: "#6b758a4d",
loadingWidth: eA ? "30px" : "20px",
loadingHeight: eA ? "30px" : "20px"
}
},
microphone: {
basicConfig: {
...R,
color: "#FFFFFF",
iconSrc: ko
},
closedConfig: {
...R,
color: "#6b758a4d",
iconSrc: Po
}
},
speaker: {
basicConfig: {
...R,
color: "#FFFFFF",
iconSrc: Wo
},
closedConfig: {
...R,
color: "#6b758a4d",
iconSrc: Go
}
},
fullScreen: {
basicConfig: {
iconSize: 20,
iconSrc: Au
}
},
minimize: {
basicConfig: {
iconSize: eA ? 24 : 20,
iconSrc: Qo
}
},
switchCamera: {
basicConfig: {
...R,
color: "transparent",
iconSrc: fA,
shape: "circle"
}
},
inviteUser: {
basicConfig: {
...R,
color: eA ? "" : "#6b758a4d",
width: eA ? "24px" : "40px",
height: eA ? "24px" : "40px",
shape: eA ? "" : "circle",
iconSize: eA ? 24 : 20,
iconSrc: Zo
}
},
toggleButtonPanel: {
basicConfig: {
color: "transparent",
width: "40px",
height: "40px",
shape: "circle",
iconSize: 40,
iconSrc: ou
}
},
virtualBackground: {
basicConfig: {
...R,
color: "#6b758a4d",
iconSrc: UA,
shape: "circle"
},
closedConfig: {
...R,
color: "#FFFFFF",
iconSrc: Yt
},
loadingConfig: {
...R,
color: "#6b758a4d",
loadingWidth: eA ? "30px" : "20px",
loadingHeight: eA ? "30px" : "20px"
},
disableConfig: {
...R,
color: "#6b758a4d",
iconSrc: UA,
buttonStyle: {
opacity: 0.6
}
}
}
}, jA = {
singleCall: {
video: {
calling: {
...h,
switchCamera: {
basicConfig: {
...R,
color: "#6b758a4d",
iconSrc: fA,
shape: "circle",
showText: !0
},
disableConfig: {
...R,
color: "#6b758a4d",
iconSrc: fA,
shape: "circle",
showText: !0,
buttonStyle: {
opacity: 0.6
}
}
},
hangup: {
basicConfig: {
...h.hangup.basicConfig
},
loadingConfig: {
...h.hangup.loadingConfig
}
},
reject: {
basicConfig: {
...h.reject.basicConfig,
showText: !1
}
}
},
accept: {
...h,
switchCamera: {
basicConfig: {
...R,
color: "#6b758a4d",
iconSrc: fA,
shape: "circle"
},
disableConfig: {
...R,
color: "#6b758a4d",
iconSrc: fA,
shape: "circle",
showText: !0,
buttonStyle: {
opacity: 0.6
}
}
},
accept: {
basicConfig: {
...h.accept.basicConfig,
showText: !1
},
loadingConfig: {
...h.accept.loadingConfig,
showText: !1
}
},
reject: {
basicConfig: {
...h.reject.basicConfig,
showText: !1
}
}
},
connected: {
...h,
virtualBackground: {
basicConfig: {
...R,
color: "transparent",
iconSrc: UA,
shape: "circle",
showText: !1
},
closedConfig: {
...R,
color: "transparent",
iconSrc: UA,
showText: !1
},
disableConfig: {
...R,
color: "transparent",
iconSrc: UA,
showText: !1,
buttonStyle: {
opacity: 0.6
}
}
},
hangup: {
basicConfig: {
...h.hangup.basicConfig,
showText: !1
},
loadingConfig: {
...h.hangup.loadingConfig,
showText: !1
}
},
switchCamera: {
basicConfig: {
...h.switchCamera.basicConfig,
showText: !1
},
disableConfig: {
...h.switchCamera.basicConfig,
showText: !1,
buttonStyle: {
opacity: 0.6
}
}
}
}
},
audio: {
calling: h,
accept: h,
connected: h
}
},
groupCall: {
video: {
calling: {
...h,
switchCamera: {
basicConfig: {
...R,
color: "#6b758a4d",
iconSrc: fA,
shape: "circle"
}
},
hangup: {
basicConfig: {
...h.hangup.basicConfig,
showText: !1
},
loadingConfig: {
...h.hangup.loadingConfig,
showText: !1
}
},
accept: {
basicConfig: {
...h.accept.basicConfig,
showText: !1
},
loadingConfig: {
...h.accept.loadingConfig,
showText: !1
}
},
reject: {
basicConfig: {
...h.reject.basicConfig,
showText: !1
}
}
},
accept: {
...h,
hangup: {
basicConfig: {
...h.hangup.basicConfig,
showText: !1
},
loadingConfig: {
...h.hangup.loadingConfig,
showText: !1
}
},
accept: {
basicConfig: {
...h.accept.basicConfig,
showText: !1
},
loadingConfig: {
...h.accept.loadingConfig,
showText: !1
}
},
reject: {
basicConfig: {
...h.reject.basicConfig,
showText: !1
}
}
},
connected: {
...h,
virtualBackground: {
basicConfig: {
...R,
color: "transparent",
iconSrc: UA,
shape: "circle",
showText: !1
},
closedConfig: {
...R,
color: "transparent",
iconSrc: Yt,
showText: !1
}
},
hangup: {
basicConfig: {
...h.hangup.basicConfig,
showText: !1
},
loadingConfig: {
...h.hangup.loadingConfig,
showText: !1
}
}
}
},
audio: {
calling: {
...h,
switchCamera: {
basicConfig: {
...R,
color: "#6b758a4d",
iconSrc: fA,
shape: "circle"
}
},
hangup: {
basicConfig: {
...h.hangup.basicConfig,
showText: !1
},
loadingConfig: {
...h.hangup.loadingConfig,
showText: !1
}
},
accept: {
basicConfig: {
...h.accept.basicConfig,
showText: !1
},
loadingConfig: {
...h.accept.loadingConfig,
showText: !1
}
},
reject: {
basicConfig: {
...h.reject.basicConfig,
showText: !1
}
}
},
accept: {
...h,
hangup: {
basicConfig: {
...h.hangup.basicConfig,
showText: !1
},
loadingConfig: {
...h.hangup.loadingConfig,
showText: !1
}
},
accept: {
basicConfig: {
...h.accept.basicConfig,
showText: !1
},
loadingConfig: {
...h.accept.loadingConfig,
showText: !1
}
},
reject: {
basicConfig: {
...h.reject.basicConfig,
showText: !1
}
}
},
connected: {
...h,
hangup: {
basicConfig: {
...h.hangup.basicConfig,
showText: !1
},
loadingConfig: {
...h.hangup.loadingConfig,
showText: !1
}
},
virtualBackground: {
basicConfig: {
...R,
color: "transparent",
iconSrc: UA,
shape: "circle"
},
closedConfig: {
...R,
color: "transparent",
iconSrc: Yt
}
}
}
}
}
}, lu = {
singleCall: {
video: {
calling: h,
accept: h,
connected: h
},
audio: {
calling: h,
accept: h,
connected: h
}
},
groupCall: {
video: {
calling: h,
accept: h,
connected: h
},
audio: {
calling: h,
accept: h,
connected: h
}
}
}, iu = {
pc: lu,
mobile: jA
}, hA = {
width: "40px",
height: "40px",
shape: "circle",
iconSize: 20,
textColor: "#D5E0F2"
}, Je = {
microphone: {
basicConfig: {
...hA,
color: "#FFFFFF",
iconSrc: ko
},
closedConfig: {
...hA,
color: "#6b758a4d",
iconSrc: Po
}
},
speaker: {
basicConfig: {
...hA,
color: "#FFFFFF",
iconSrc: Wo
},
closedConfig: {
...hA,
color: "#6b758a4d",
iconSrc: Go
}
},
camera: {
basicConfig: {
...hA,
color: "#FFFFFF",
iconSrc: Fo
},
closedConfig: {
...hA,
color: "#6b758a4d",
iconSrc: Ro
}
},
hangup: {
basicConfig: {
...hA,
color: "#ED4651",
iconSrc: Zt
},
loadingConfig: {
...hA,
color: "#ED4651",
loadingWidth: "20px",
loadingHeight: "20px"
}
},
toggleButtonPanel: {
basicConfig: {
color: "transparent",
width: "40px",
height: "40px",
shape: "circle",
iconSize: 40,
iconSrc: Ks
}
}
}, su = {
mobile: {
...jA,
groupCall: {
video: {
...jA.groupCall.video,
calling: {
...jA.groupCall.video.calling,
...Je
},
connected: {
...jA.groupCall.video.connected,
...Je
}
},
audio: {
...jA.groupCall.audio,
calling: {
...jA.groupCall.audio.calling,
...Je
},
connected: {
...jA.groupCall.audio.connected,
...Je
}
}
}
}
}, uA = (A, t) => {
var r;
const e = j.isPC ? "pc" : "mobile", { status: a } = We(), { callStatus: n, callRole: l, isGroupCall: i, callType: u } = z(q()), s = I((r = h == null ? void 0 : h[A]) == null ? void 0 : r[t.value]);
return J(
[t, a, n, i, u],
() => {
var y, T, C, E, w;
const M = i.value ? "groupCall" : "singleCall", D = u.value === F.AUDIO ? "audio" : "video";
let g = "";
n.value === U.CALLING ? g = l.value === K.CALLER ? "calling" : "accept" : n.value === U.CONNECTED && (g = "connected");
let N = iu;
a.value === "close" && (N = su), s.value = ((w = (E = (C = (T = (y = N == null ? void 0 : N[e]) == null ? void 0 : y[M]) == null ? void 0 : T[D]) == null ? void 0 : C[g]) == null ? void 0 : E[A]) == null ? void 0 : w[t.value]) || {};
},
{ immediate: !0 }
), s;
}, lt = {
options: {
virtualHost: !0
}
};
lt.setup = (A, t) => ({
config: uA("minimize", I("basicConfig")),
handleClick: async () => {
if (document != null && document.fullscreenElement)
try {
document == null || document.exitFullscreen();
} catch (n) {
console.debug(n);
}
await O.toggleMinimize();
}
});
lt.components = Object.assign({
Button: pA
}, lt.components);
var uu = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("Button", {
attrs: {
iconSrc: A.config.iconSrc,
iconSize: A.config.iconSize
},
on: {
click: A.handleClick
}
});
}, cu = [];
const Xa = {};
var ru = /* @__PURE__ */ S(
lt,
uu,
cu,
!1,
Mu,
"71774dda",
null,
null
);
function Mu(A) {
for (let t in Xa)
this[t] = Xa[t];
}
const du = /* @__PURE__ */ function() {
return ru.exports;
}(), it = {
options: {
virtualHost: !0
}
};
it.setup = (A, t) => ({
config: uA("fullScreen", I("basicConfig")),
handleClick: async () => {
await fi("tuicallkit-id");
}
});
it.components = Object.assign({
Button: pA
}, it.components);
var Iu = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("Button", {
attrs: {
iconSrc: A.config.iconSrc,
iconSize: A.config.iconSize
},
on: {
click: A.handleClick
}
});
}, gu = [];
const _a = {};
var Nu = /* @__PURE__ */ S(
it,
Iu,
gu,
!1,
pu,
"224de994",
null,
null
);
function pu(A) {
for (let t in _a)
this[t] = _a[t];
}
const Du = /* @__PURE__ */ function() {
return Nu.exports;
}(), Tu = {
width: {
type: String
},
color: {
type: String
},
size: {
type: String
},
weight: {
type: Number
},
truncated: {
type: Boolean,
default: !1
},
lineClamp: {
type: Number
},
textStyle: {
type: Object
}
}, la = {
options: {
virtualHost: !0
}
};
la.props = Tu;
la.setup = (A, t) => {
const e = A, a = t.emit, n = X([`${x}-text`, {
[`${x}-text--line-clamp`]: e.lineClamp
}]), l = p(() => ot({
maxWidth: e.width,
fontSize: e.size,
fontWeight: e.weight,
color: e.color,
textOverflow: e.truncated ? "ellipsis" : "auto",
"-webkit-line-clamp": e.lineClamp,
...e.textStyle
}));
return {
textClassName: n,
style: l,
handleClick: () => {
a("click");
}
};
};
var Cu = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("span", {
class: A.textClassName,
style: [A.style],
on: {
click: A.handleClick
}
}, [A._t("default")], 2);
}, yu = [];
const qa = {};
var Su = /* @__PURE__ */ S(
la,
Cu,
yu,
!1,
Eu,
null,
null,
null
);
function Eu(A) {
for (let t in qa)
this[t] = qa[t];
}
const lA = /* @__PURE__ */ function() {
return Su.exports;
}(), EA = {
width: {
type: String
},
height: {
type: String
},
showText: {
type: Boolean,
default: !0
},
iconSize: {
type: String
}
}, Me = {
options: {
virtualHost: !0
}
};
Me.props = EA;
Me.setup = (A, t) => {
const e = A, a = uA("inviteUser", I("basicConfig"));
return {
t: v,
props: e,
config: a,
handleClick: async () => {
d.update(c.CALL, o.SHOW_SELECT_USER, !0);
}
};
};
Me.components = Object.assign({
Button: pA,
TKText: lA
}, Me.components);
var hu = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
staticClass: "btn-content"
}, [e("Button", {
attrs: {
iconSrc: A.config.iconSrc,
color: A.config.color,
iconSize: A.config.iconSize,
width: A.props.width || A.config.width,
height: A.props.height || A.config.height,
shape: A.config.shape
},
on: {
click: A.handleClick
}
}), A.showText ? e("TKText", {
attrs: {
textStyle: A.config.textStyle,
color: A.config.textColor,
size: A.config.textSize
}
}, [A._v(" " + A._s(A.t("invite member")) + " ")]) : A._e()], 1);
}, mu = [];
const Ja = {};
var ju = /* @__PURE__ */ S(
Me,
hu,
mu,
!1,
vu,
"234c87f7",
null,
null
);
function vu(A) {
for (let t in Ja)
this[t] = Ja[t];
}
const Yo = /* @__PURE__ */ function() {
return ju.exports;
}(), fu = {
color: {
type: String,
default: "#FFF"
},
callDuration: {
type: String,
default: ""
},
fontSize: {
type: String,
default: "16px"
}
}, ia = {
options: {
virtualHost: !0
}
};
ia.props = fu;
ia.setup = (A, t) => {
const e = A;
return {
timerStyle: p(() => ({
color: e.color,
fontSize: e.fontSize
}))
};
};
var Lu = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("span", {
style: [A.timerStyle]
}, [A._v(A._s(A.callDuration))]);
}, Uu = [];
const Ha = {};
var zu = /* @__PURE__ */ S(
ia,
Lu,
Uu,
!1,
wu,
null,
null,
null
);
function wu(A) {
for (let t in Ha)
this[t] = Ha[t];
}
const sa = /* @__PURE__ */ function() {
return zu.exports;
}(), de = {
options: {
virtualHost: !0
}
};
de.props = Yi;
de.setup = (A, t) => {
const e = j.isPC, {
callStatus: a,
isGroupCall: n,
callRole: l,
allowedFullScreen: i
} = z(q()), {
callDuration: u
} = Ht(), s = Ge(), r = p(() => a.value === U.CONNECTED), M = I(d.getData(c.CALL, o.ENABLE_FLOAT_WINDOW)), D = p(() => {
var y, T;
return !n.value || ((T = (y = s.value.button) == null ? void 0 : y[zA.InviteUser]) == null ? void 0 : T.show) === !1 ? !1 : a.value === U.CALLING ? l.value === K.CALLER : !0;
});
function g(y) {
M.value = y;
}
const N = {
[o.ENABLE_FLOAT_WINDOW]: g
};
return aA(() => {
d.watch(c.CALL, N, {
notifyRangeWhenWatch: o.MYSELF
});
}), tA(() => {
d.unwatch(c.CALL, {
...N
});
}), {
isPC: e,
allowedFullScreen: i,
callDuration: u,
showTimer: r,
showMinimize: M,
showInviteUser: D
};
};
de.components = Object.assign({
Row: $t,
Col: ea,
Timer: sa,
Minimize: du,
FullScreen: Du,
InviteUser: Yo
}, de.components);
var Ou = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
staticClass: "top-bar-container",
style: A.customStyle
}, [A.isPC ? e("Row", [e("Col", {
attrs: {
span: 8
}
}), e("Col", {
attrs: {
span: 8,
justify: "center",
align: "center"
}
}, [A.showTimer ? e("Timer", {
attrs: {
"call-duration": A.callDuration
}
}) : A._e()], 1), e("Col", {
attrs: {
span: 8,
justify: "end",
align: "center"
}
}, [e("Row", [e("Col", {
attrs: {
span: 18
}
}), e("Col", {
attrs: {
span: 3,
justify: "center"
}
}, [A.showMinimize ? e("Minimize") : A._e()], 1), e("Col", {
attrs: {
span: 3,
justify: "center"
}
}, [A.allowedFullScreen ? e("FullScreen") : A._e()], 1)], 1)], 1)], 1) : A._e(), A.isPC ? A._e() : e("Row", [e("Col", {
attrs: {
span: 8,
align: "center"
}
}, [e("Row", [e("Col", {
attrs: {
span: 8,
justify: "center"
}
}, [!A.isPC && A.showMinimize ? e("Minimize") : A._e()], 1), e("Col", {
attrs: {
span: 16
}
})], 1)], 1), e("Col", {
attrs: {
span: 8,
justify: "center",
align: "center"
}
}, [A.showTimer ? e("Timer", {
attrs: {
"call-duration": A.callDuration
}
}) : A._e()], 1), e("Col", {
attrs: {
span: 8,
justify: "end",
align: "center"
}
}, [e("Row", [e("Col", {
attrs: {
span: 16
}
}), e("Col", {
attrs: {
span: 8,
justify: "center"
}
}, [A.showInviteUser ? e("InviteUser", {
attrs: {
"show-text": A.isPC
}
}) : A._e()], 1)], 1)], 1)], 1)], 1);
}, xu = [];
const Ka = {};
var Vu = /* @__PURE__ */ S(
de,
Ou,
xu,
!1,
bu,
"2bcaf4e1",
null,
null
);
function bu(A) {
for (let t in Ka)
this[t] = Ka[t];
}
const Xo = /* @__PURE__ */ function() {
return Vu.exports;
}(), Bu = {
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
}
}, Ie = {
options: {
virtualHost: !0
}
};
Ie.props = Bu;
Ie.setup = (A, t) => {
const e = A, a = t.emit, n = X([`${x}-overlay`, e.customClass]), l = `${x}-overlay_mask-container`, i = p(() => X([`${x}-overlay_mask`, {
[`${x}-blur`]: e.blur
}])), u = `${x}-overlay_slot`, s = p(() => ({
zIndex: e.zIndex,
...e.customStyle
})), r = p(() => ({
backgroundColor: e.bgColor,
...e.customMaskStyle
}));
function M() {
a("click");
}
return {
overlayContainerClassName: n,
maskContainerClassName: l,
maskClassName: i,
slotClassName: u,
overlayStyle: s,
maskStyle: r,
handleClick: M,
handleError: (g) => {
a("error", g);
}
};
};
Ie.components = Object.assign({
TKImage: SA
}, Ie.components);
var Fu = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return A.show ? e("div", {
class: A.overlayContainerClassName,
style: [A.overlayStyle],
on: {
click: A.handleClick
}
}, [e("div", {
class: A.maskContainerClassName
}, [A.showMask ? e("div", {
class: A.maskClassName,
style: [A.maskStyle]
}) : A._e(), A.showBackgroundImage ? e("TKImage", {
attrs: {
fit: A.fit,
src: A.bgImage,
width: "100%",
height: "100%",
defaultSrc: A.defaultSrc
},
on: {
error: A.handleError
}
}) : A._e()], 1), e("div", {
class: A.slotClassName
}, [A._t("default")], 2)]) : A._e();
}, Ru = [];
const $a = {};
var ku = /* @__PURE__ */ S(
Ie,
Fu,
Ru,
!1,
Pu,
null,
null,
null
);
function Pu(A) {
for (let t in $a)
this[t] = $a[t];
}
const _o = /* @__PURE__ */ function() {
return ku.exports;
}(), Wu = ["fill", "contain", "cover"], Gu = ["circle", "square"], Qu = {
icon: {
type: String
},
size: {
type: [Number, String],
default: 100
},
shape: {
type: String,
values: Gu,
default: "square"
},
src: {
type: String
},
defaultSrc: {
type: String
},
text: {
type: String
},
fit: {
type: String,
values: Wu,
default: "cover"
},
customClass: {
type: String
}
}, ge = {
options: {
virtualHost: !0
}
};
ge.props = Qu;
ge.setup = (A, t) => {
const e = A, a = I("");
J(() => e.src, () => {
a.value = e.src;
}, {
immediate: !0
});
const n = p(() => X([`${x}-avatar`, `${x}-avatar--${e.shape}`, `${x}-avatar--${e.size}`, e.customClass])), l = p(() => typeof e.size == "number" ? `${e.size}px` : e.size), i = p(() => typeof e.size == "number" ? `${e.size}px` : e.size), u = p(() => ({
width: l.value,
height: i.value
}));
function s(r) {
console.error(r), e.defaultSrc && (a.value = e.defaultSrc);
}
return {
avatarSrc: a,
classname: n,
width: l,
height: i,
avatarStyle: u,
handleError: s
};
};
ge.components = Object.assign({
TKImage: SA
}, ge.components);
var Zu = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
class: A.classname,
style: [A.avatarStyle]
}, [A.avatarSrc ? e("TKImage", {
attrs: {
fit: A.fit,
width: A.width,
height: A.height,
src: A.avatarSrc
},
on: {
error: A.handleError
}
}) : A._t("default")], 2);
}, Yu = [];
const An = {};
var Xu = /* @__PURE__ */ S(
ge,
Zu,
Yu,
!1,
_u,
null,
null,
null
);
function _u(A) {
for (let t in An)
this[t] = An[t];
}
const qo = /* @__PURE__ */ function() {
return Xu.exports;
}(), qu = "", Ju = "", Hu = {
isMuted: {
type: Boolean,
default: !1
},
volume: {
type: Number,
default: 0
}
}, Ne = {
options: {
virtualHost: !0
}
};
Ne.props = Hu;
Ne.setup = (A, t) => {
const e = A, a = p(() => e.isMuted ? Ju : qu), n = p(() => e.isMuted || !e.volume ? "" : `height: ${e.volume * 4}%`);
return {
iconSrc: a,
volumeLevelStyle: n
};
};
Ne.components = Object.assign({
Icon: ft
}, Ne.components);
var Ku = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
staticClass: "mic-container"
}, [e("div", {
staticClass: "mic-level-container"
}, [e("div", {
staticClass: "mic-level",
style: A.volumeLevelStyle
})]), e("Icon", {
attrs: {
src: A.iconSrc
}
})], 1);
}, $u = [];
const en = {};
var Ac = /* @__PURE__ */ S(
Ne,
Ku,
$u,
!1,
ec,
"3cbc030b",
null,
null
);
function ec(A) {
for (let t in en)
this[t] = en[t];
}
const Jo = /* @__PURE__ */ function() {
return Ac.exports;
}(), GA = "", tc = {
showOverlayStream: {
type: Boolean,
default: !0
},
customClass: {
type: String
},
customStyle: {
type: Object
},
isSmallWindow: {
type: Boolean,
default: !1
},
tip: {
type: String,
default: null
},
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: GA
},
overlayZIndex: {
type: Number
},
customOverlayClass: {
type: String
},
fit: {
type: String
},
showLoading: {
type: Boolean,
default: !1
},
showAvatar: {
type: Boolean,
default: !0
},
avatar: {
type: String,
default: GA
},
showUserName: {
type: Boolean,
default: !0
},
username: {
type: String
},
color: {
type: String,
default: "#FFF"
},
showMicVolume: {
type: Boolean,
default: !1
},
isMuted: {
type: Boolean,
default: !1
},
volume: {
type: Number,
default: 0
},
showTip: {
type: Boolean,
default: !0
}
}, pe = {
options: {
virtualHost: !0
}
};
pe.props = tc;
pe.setup = (A, t) => {
const e = t.emit, a = A, n = I(100), {
isFloatWindow: l
} = z(CA()), i = j.isPC ? "40px" : "20px";
J([() => a.isSmallWindow, l], () => {
l.value ? n.value = a.isSmallWindow ? 20 : 40 : n.value = a.isSmallWindow ? 40 : 100;
}, {
immediate: !0
});
const u = p(() => X(["overlay-stream-container", {
pc: j.isPC,
mobile: !j.isPC,
float: l.value
}]));
return {
defaultAvatarSrc: GA,
avatarSize: n,
fontSize: i,
overlayStreamClassName: u,
handleError: (r) => {
e("error", r);
}
};
};
pe.components = Object.assign({
Overlay: _o,
Loading: na,
Avatar: qo,
TKText: lA,
MicrophoneVolume: Jo
}, pe.components);
var ac = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return A.showOverlayStream ? e("div", {
class: A.overlayStreamClassName,
style: [A.customStyle]
}, [e("Overlay", {
attrs: {
show: A.showOverlay,
"show-background-image": A.showBackgroundImage,
"show-mask": A.showMask,
blur: A.blur,
zIndex: A.overlayZIndex,
bgColor: A.bgColor,
bgImage: A.bgImage || A.defaultAvatarSrc,
fit: A.fit,
defaultSrc: A.defaultAvatarSrc,
customStyle: {
position: "absolute",
width: "100%",
height: "100%"
},
"custom-mask-style": {
"backdrop-filter": "blur(12px)",
"-webkit-backdrop-filter": "blur(12px)"
},
customClass: A.customOverlayClass
},
on: {
error: A.handleError
}
}, [e("div", {
staticClass: "overlay-stream-content-container"
}, [e("div", {
staticClass: "overlay-stream-content"
}, [A.showLoading ? e("Loading", {
attrs: {
mode: "dot"
}
}) : A._e(), e("div", {
staticClass: "overlay-stream-avatar"
}, [A.showAvatar ? e("Avatar", {
attrs: {
src: A.avatar || A.defaultAvatarSrc,
size: A.avatarSize
}
}) : A._e()], 1), e("div", {
staticClass: "overlay-stream-info"
}, [A.showUserName ? e("TKText", {
attrs: {
truncated: !0,
size: A.fontSize,
color: A.color,
width: "200px",
weight: 500
}
}, [A._v(" " + A._s(A.username) + " ")]) : A._e(), A.showMicVolume ? e("MicrophoneVolume", {
attrs: {
isMuted: A.isMuted,
volume: A.volume
}
}) : A._e()], 1), e("div", {
staticClass: "overlay-stream-tip"
}, [A.showTip && A.tip ? e("div", [A._v(A._s(A.tip))]) : A._e()])], 1), A._t("default")], 2)])], 1) : A._e();
}, nc = [];
const tn = {};
var oc = /* @__PURE__ */ S(
pe,
ac,
nc,
!1,
lc,
"01ddfaf4",
null,
null
);
function lc(A) {
for (let t in tn)
this[t] = tn[t];
}
const Ho = /* @__PURE__ */ function() {
return oc.exports;
}(), st = {};
st.setup = (A, t) => {
const {
localUserInfoExcludeVolume: e,
remoteUserListExcludeVolume: a
} = z(MA()), {
callerUserInfo: n
} = z(vi()), {
isGroupCall: l
} = z(q()), i = xo(), u = p(() => {
var C, E;
return l.value ? n.value.displayUserInfo : (E = (C = a.value) == null ? void 0 : C[0]) == null ? void 0 : E.displayUserInfo;
}), s = p(() => {
var C, E;
return l.value ? n.value.avatar : (E = (C = a.value) == null ? void 0 : C[0]) == null ? void 0 : E.avatar;
}), r = p(() => l.value ? !0 : !e.value.isVideoAvailable), M = p(() => l.value ? v("Invited group call") : null), D = p(() => {
var C, E;
return l.value ? i.value[n.value.userId] || s.value : i.value[(E = (C = a.value) == null ? void 0 : C[0]) == null ? void 0 : E.userId] || s.value;
}), g = I(!1), N = I("fill");
let y = I(!1);
return QA(() => {
var C, E, w, L;
if (y.value) {
g.value = l.value ? !0 : !e.value.isVideoAvailable, N.value = "cover";
return;
}
l.value ? (g.value = !i.value[n.value.userId], N.value = i.value[n.value.userId] ? "fill" : "cover") : (g.value = !e.value.isVideoAvailable && !i.value[(E = (C = a.value) == null ? void 0 : C[0]) == null ? void 0 : E.userId], N.value = i.value[(L = (w = a.value) == null ? void 0 : w[0]) == null ? void 0 : L.userId] ? "fill" : "cover");
}), {
TUIGlobal: j,
t: v,
defaultAvatarSrc: GA,
remoteUserListExcludeVolume: a,
isGroupCall: l,
username: u,
avatar: s,
showBackgroundImage: r,
tip: M,
bgImage: D,
showMask: g,
fit: N,
handleError: () => {
y.value = !0;
}
};
};
st.components = Object.assign({
OverlayStream: Ho,
TKText: lA,
Avatar: qo
}, st.components);
var ic = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
staticClass: "waiting-container"
}, [e("OverlayStream", {
attrs: {
username: A.username,
avatar: A.avatar,
"bg-image": A.bgImage,
"show-avatar": !A.TUIGlobal.isPC,
"show-loading": !1,
"bg-color": "#22262ed9",
"show-mask": A.showMask,
"show-background-image": A.showBackgroundImage,
tip: A.tip,
fit: A.fit
},
on: {
error: A.handleError
}
}, [!A.TUIGlobal.isPC && A.isGroupCall ? e("div", {
staticClass: "groupcall-info"
}, [e("div", {
staticClass: "tip"
}, [e("TKText", {
attrs: {
color: "#FFF"
}
}, [A._v(A._s(A.remoteUserListExcludeVolume.length) + A._s(A.t("people in the call")))])], 1), e("div", {
staticClass: "avatar-group"
}, A._l(A.remoteUserListExcludeVolume, function(a) {
return e("div", {
staticClass: "avatar-item"
}, [e("Avatar", {
attrs: {
size: "100%",
src: a.avatar || A.defaultAvatarSrc
}
})], 1);
}), 0)]) : A._e()])], 1);
}, sc = [];
const an = {};
var uc = /* @__PURE__ */ S(
st,
ic,
sc,
!1,
cc,
"a1a05f80",
null,
null
);
function cc(A) {
for (let t in an)
this[t] = an[t];
}
const Ko = /* @__PURE__ */ function() {
return uc.exports;
}(), rc = {
bigWindow: {
type: String
},
showSmallWindow: {
type: Boolean,
default: !0
},
smallWindowWidth: {
type: String,
default: "30%"
},
smallWindowHeight: {
type: String,
default: "30%"
}
}, $o = "ToggleWindowContextKey", ua = {
options: {
virtualHost: !0
}
};
ua.props = rc;
ua.setup = (A, t) => {
const e = A, a = t.emit, n = I(e.bigWindow), l = `${x}-toggle-window`, i = (u) => {
n.value = u, a("toggle", u);
};
return J(() => e.bigWindow, () => {
n.value = e.bigWindow;
}), gA($o, {
bigWindow: n,
toggleWindow: i,
smallWindowWidth: wt(e, "smallWindowWidth"),
smallWindowHeight: wt(e, "smallWindowHeight"),
showSmallWindow: wt(e, "showSmallWindow")
}), {
toggleWindowContainerClassName: l
};
};
var Mc = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
class: A.toggleWindowContainerClassName
}, [A._t("default")], 2);
}, dc = [];
const nn = {};
var Ic = /* @__PURE__ */ S(
ua,
Mc,
dc,
!1,
gc,
null,
null,
null
);
function gc(A) {
for (let t in nn)
this[t] = nn[t];
}
const Nc = /* @__PURE__ */ function() {
return Ic.exports;
}(), ca = {
options: {
virtualHost: !0
}
};
ca.props = ["disabled"];
ca.setup = (A, t) => ({});
var pc = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("root-portal", {
attrs: {
enable: !A.disabled
}
}, [A._t("default")], 2);
}, Dc = [];
const on = {};
var Tc = /* @__PURE__ */ S(
ca,
pc,
Dc,
!1,
Cc,
null,
null,
null
);
function Cc(A) {
for (let t in on)
this[t] = on[t];
}
const yc = /* @__PURE__ */ function() {
return Tc.exports;
}(), Sc = {
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, t;
this.disabled ? (t = document.querySelector(this.source)) == null || t.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 (t) {
console.debug(t);
}
}
};
var Ec = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", [A._t("default")], 2);
}, hc = [];
const ln = {};
var mc = /* @__PURE__ */ S(
Sc,
Ec,
hc,
!1,
jc,
null,
null,
null
);
function jc(A) {
for (let t in ln)
this[t] = ln[t];
}
const vc = /* @__PURE__ */ function() {
return mc.exports;
}(), Al = {
options: {
virtualHost: !0
}
};
Al.props = ["disabled", "to"];
var fc = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("Teleport", {
attrs: {
disabled: A.disabled,
to: A.to
}
}, [A._t("default")], 2);
}, Lc = [];
const sn = {};
var Uc = /* @__PURE__ */ S(
Al,
fc,
Lc,
!1,
zc,
null,
null,
null
);
function zc(A) {
for (let t in sn)
this[t] = sn[t];
}
const wc = /* @__PURE__ */ function() {
return Uc.exports;
}(), Oc = {
disabled: {
type: Boolean,
default: !1
},
to: {
type: String,
default: "body"
},
source: {
type: String,
default: "body"
}
}, De = {};
De.props = Oc;
De.setup = (A, t) => {
const {
majorVersion: e
} = ts(), a = p(() => e === "3"), n = p(() => e === "2");
return {
IN_MINI_APP: Qt,
isVue3: a,
isVue2: n
};
};
De.components = Object.assign({
PortalMini: yc,
PortalVue2: vc,
PortalVue3: wc
}, De.components);
var xc = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", [A.IN_MINI_APP ? e("PortalMini", {
attrs: {
disabled: A.disabled
}
}, [A._t("default")], 2) : A.isVue2 ? e("PortalVue2", {
attrs: {
disabled: A.disabled,
to: A.to,
source: A.source
}
}, [A._t("default")], 2) : e("PortalVue3", {
attrs: {
disabled: A.disabled,
to: A.to
}
}, [A._t("default")], 2)], 1);
}, Vc = [];
const un = {};
var bc = /* @__PURE__ */ S(
De,
xc,
Vc,
!1,
Bc,
null,
null,
null
);
function Bc(A) {
for (let t in un)
this[t] = un[t];
}
const el = /* @__PURE__ */ function() {
return bc.exports;
}(), Fc = {
value: {
type: String
}
}, ra = {
options: {
virtualHost: !0
}
};
ra.props = Fc;
ra.setup = (A, t) => {
const e = A, {
bigWindow: a,
toggleWindow: n,
smallWindowWidth: l,
smallWindowHeight: i,
showSmallWindow: u
} = NA($o), s = p(() => X([`${x}-toggle-window-item`, `${x}-toggle-window-item--${a.value === e.value ? "big" : "small"}`, {
pc: WA,
mobile: !WA
}])), r = p(() => {
let M = {};
return a.value !== e.value && (M = {
width: l.value,
height: i.value
}, u.value ? M.visibility = "" : M.visibility = "hidden"), M;
});
return {
toggleWindow: n,
classname: s,
windowItemStyle: r
};
};
var Rc = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
class: A.classname,
style: [A.windowItemStyle],
on: {
click: function() {
return A.toggleWindow(A.value);
}
}
}, [A._t("default")], 2);
}, kc = [];
const cn = {};
var Pc = /* @__PURE__ */ S(
ra,
Rc,
kc,
!1,
Wc,
null,
null,
null
);
function Wc(A) {
for (let t in cn)
this[t] = cn[t];
}
const Gc = /* @__PURE__ */ function() {
return Pc.exports;
}(), Ma = {
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
}
}, tl = "
options: {
virtualHost: !0
}
};
Te.props = Ma;
Te.setup = (A, t) => ({
networkSrc: tl,
t: v
});
Te.components = Object.assign({
Row: $t,
Col: ea,
MicrophoneVolume: Jo,
TKText: lA,
TKImage: SA
}, Te.components);
var Qc = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("Row", [e("Col", {
attrs: {
span: 12,
justify: "start",
align: "center"
}
}, [e("div", {
staticClass: "stream-userInfo"
}, [e("MicrophoneVolume", {
staticClass: "mic-volume",
attrs: {
"is-muted": A.isMuted,
volume: A.volume
}
}), e("div", {
staticClass: "nickname"
}, [e("TKText", {
attrs: {
color: "#fff",
truncated: !0,
width: "80px",
size: "14px"
}
}, [A._v(A._s(A.nickName))]), e("TKText", {
directives: [{
name: "show",
rawName: "v-show",
value: A.isSelf,
expression: "isSelf"
}],
attrs: {
color: "#fff",
size: "14px"
}
}, [A._v(A._s(A.t("me")))])], 1)], 1)]), e("Col", {
attrs: {
span: 12,
justify: "center"
}
}, [A.showNetWorkStatus ? e("div", [e("TKImage", {
attrs: {
width: "24px",
height: "24px",
src: A.networkSrc
}
})], 1) : A._e()])], 1);
}, Zc = [];
const rn = {};
var Yc = /* @__PURE__ */ S(
Te,
Qc,
Zc,
!1,
Xc,
"2f962e88",
null,
null
);
function Xc(A) {
for (let t in rn)
this[t] = rn[t];
}
const _c = /* @__PURE__ */ function() {
return Yc.exports;
}(), qc = "", Jc = "
options: {
virtualHost: !0
}
};
Ce.props = Ma;
Ce.setup = (A, t) => {
const {
enableVirtualBackground: e
} = z(q());
return {
MicOnH5: qc,
MicOffH5: Jc,
SwitchCameraSrc: fA,
VirtualBackgroundOpenSrc: UA,
networkSrc: tl,
switchCamera: async () => {
await O.switchCamera();
},
setBlurBackground: async () => {
await O.setBlurBackground(!e.value);
}
};
};
Ce.components = Object.assign({
Row: $t,
Col: ea,
TKText: lA,
Icon: ft,
TKImage: SA
}, Ce.components);
var Hc = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("Row", {
attrs: {
"custom-style": {
padding: "2px 5px"
}
}
}, [e("Col", {
attrs: {
span: 12,
justify: "start",
align: "center"
}
}, [A.showNickName ? e("TKText", {
attrs: {
width: "100px",
truncated: !0,
color: "#FFF"
}
}, [A._v(" " + A._s(A.nickName) + " ")]) : A._e(), e("div", {
directives: [{
name: "show",
rawName: "v-show",
value: !A.isMuted && A.volume,
expression: "!isMuted && volume"
}]
}, [e("Icon", {
attrs: {
size: 24,
src: A.MicOnH5
}
})], 1), e("div", {
directives: [{
name: "show",
rawName: "v-show",
value: A.isMuted,
expression: "isMuted"
}]
}, [e("Icon", {
attrs: {
size: 24,
src: A.MicOffH5
}
})], 1)], 1), e("Col", {
attrs: {
span: 12,
justify: "end",
align: "center"
}
}, [A.showNetWorkStatus ? e("div", [e("TKImage", {
attrs: {
width: "24px",
height: "24px",
src: A.networkSrc
}
})], 1) : A._e(), A.showSwitchCameraButton ? e("div", {
staticClass: "switch-camera stream-icon",
on: {
click: function(a) {
return a.stopPropagation(), A.switchCamera.apply(null, arguments);
}
}
}, [e("TKImage", {
attrs: {
width: "15px",
height: "15px",
src: A.SwitchCameraSrc
}
})], 1) : A._e(), A.showVirtualBackgroundButton ? e("div", {
staticClass: "stream-icon",
on: {
click: function(a) {
return a.stopPropagation(), A.setBlurBackground.apply(null, arguments);
}
}
}, [e("TKImage", {
attrs: {
width: "15px",
height: "15px",
src: A.VirtualBackgroundOpenSrc
}
})], 1) : A._e()])], 1);
}, Kc = [];
const Mn = {};
var $c = /* @__PURE__ */ S(
Ce,
Hc,
Kc,
!1,
Ar,
"68708842",
null,
null
);
function Ar(A) {
for (let t in Mn)
this[t] = Mn[t];
}
const er = /* @__PURE__ */ function() {
return $c.exports;
}(), ye = {
options: {
virtualHost: !0
}
};
ye.props = Ma;
ye.setup = (A, t) => {
const {
isGroupCall: e
} = q(), a = j.isPC;
return {
isGroupCall: e,
isPC: a
};
};
ye.components = Object.assign({
StreamInfoPC: _c,
StreamInfoMobile: er
}, ye.components);
var tr = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", [A.isPC ? e("StreamInfoPC", {
attrs: {
nickName: A.nickName,
isSelf: A.isSelf,
isMuted: A.isMuted,
volume: A.volume,
showNetWorkStatus: A.showNetWorkStatus
}
}) : A._e(), A.isGroupCall && !A.isPC ? e("StreamInfoMobile", {
attrs: {
showSwitchCameraButton: A.showSwitchCameraButton,
showVirtualBackgroundButton: A.showVirtualBackgroundButton,
showNetWorkStatus: A.showNetWorkStatus,
nickName: A.nickName,
showNickName: A.showNickName,
isSelf: A.isSelf,
isMuted: A.isMuted,
volume: A.volume
}
}) : A._e()], 1);
}, ar = [];
const dn = {};
var nr = /* @__PURE__ */ S(
ye,
tr,
ar,
!1,
or,
null,
null,
null
);
function or(A) {
for (let t in dn)
this[t] = dn[t];
}
const al = /* @__PURE__ */ function() {
return nr.exports;
}(), lr = {
show: {
type: Boolean,
default: !0
},
domId: {
type: String
},
loading: {
type: Boolean
},
showStreamInfo: {
type: Boolean
},
showAudioStream: {
type: Boolean
}
}, da = {
options: {
virtualHost: !0
}
};
da.props = lr;
da.setup = (A, t) => {
const e = I(d.getData(c.CALL, o.PUSHER_ID)), a = X(["stream-info-container", {
mobile: !j.isPC
}]), n = (i) => {
e.value = i;
}, l = {
[o.PUSHER_ID]: n
};
return aA(() => {
d.watch(c.CALL, l, {
notifyRangeWhenWatch: o.MYSELF
});
}), tA(() => {
d.unwatch(c.CALL, l);
}), {
streamInfoContainerClassName: a
};
};
var ir = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
directives: [{
name: "show",
rawName: "v-show",
value: A.show,
expression: "show"
}],
staticClass: "pusher-container",
attrs: {
id: A.domId
}
}, [e("div", {
directives: [{
name: "show",
rawName: "v-show",
value: A.showAudioStream,
expression: "showAudioStream"
}],
staticClass: "audio-stream-container"
}, [A._t("audio-stream")], 2), A._t("loading"), e("div", {
class: A.streamInfoContainerClassName
}, [A._t("stream-info")], 2)], 2);
}, sr = [];
const In = {};
var ur = /* @__PURE__ */ S(
da,
ir,
sr,
!1,
cr,
"71047565",
null,
null
);
function cr(A) {
for (let t in In)
this[t] = In[t];
}
const nl = /* @__PURE__ */ function() {
return ur.exports;
}(), Ia = {
options: {
virtualHost: !0
}
};
Ia.props = {
remoteClass: {
type: String,
required: !0
},
domId: {
type: String
}
};
Ia.setup = (A, t) => {
const e = I(d.getData(c.CALL, o.PLAYER)), a = I(d.getData(c.CALL, o.CALL_STATUS)), n = I(d.getData(c.CALL, o.IS_EAR_PHONE) ? Ae.EAR : Ae.SPEAKER), l = A, i = (T) => {
e.value = JSON.parse(JSON.stringify(T));
}, u = p(() => {
var T;
return (T = e.value) == null ? void 0 : T.find((C) => (C == null ? void 0 : C.userID) === l.domId);
}), s = (T) => {
a.value = T;
}, r = (T) => {
n.value = T ? Ae.EAR : Ae.SPEAKER;
}, M = {
[o.PLAYER]: i,
[o.CALL_STATUS]: s,
[o.IS_EAR_PHONE]: r
};
aA(() => {
d.watch(c.CALL, M, {
notifyRangeWhenWatch: o.MYSELF
});
}), tA(() => {
d.unwatch(c.CALL, M);
});
function D(T) {
O._tuiCallEngine._playerStateChange(T);
}
function g(T) {
}
function N(T) {
O._tuiCallEngine._playNetStatus(T);
}
function y(T) {
O._tuiCallEngine._playerAudioVolumeNotify(T);
}
return {
soundMode: n,
item: u,
playerStateChange: D,
playerFullscreenChange: g,
playNetStatus: N,
playerAudioVolumeNotify: y
};
};
var rr = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
class: A.remoteClass
}, [A.item && (A.item.hasAudio || A.item.hasVideo) ? e("live-player", {
staticClass: "stream",
attrs: {
id: A.item.id,
"data-userid": A.item.userID,
"data-streamid": A.item.streamID,
"data-streamtype": A.item.streamType,
src: A.item.src,
mode: "RTC",
autoplay: A.item.autoplay,
"mute-audio": A.item.muteAudio,
"mute-video": A.item.muteVideo,
orientation: A.item.orientation,
"object-fit": A.item.objectFit,
"background-mute": A.item.enableBackgroundMute,
"min-cache": A.item.minCache,
"max-cache": A.item.maxCache,
"sound-mode": A.soundMode,
"enable-recv-message": A.item.enableRecvMessage,
"auto-pause-if-navigate": A.item.autoPauseIfNavigate,
"auto-pause-if-open-native": A.item.autoPauseIfOpenNative
},
on: {
statechange: A.playerStateChange,
fullscreenchange: A.playerFullscreenChange,
netstatus: A.playNetStatus,
audiovolumenotify: A.playerAudioVolumeNotify
}
}) : A._e()], 1);
}, Mr = [];
const gn = {};
var dr = /* @__PURE__ */ S(
Ia,
rr,
Mr,
!1,
Ir,
"34819670",
null,
null
);
function Ir(A) {
for (let t in gn)
this[t] = gn[t];
}
const gr = /* @__PURE__ */ function() {
return dr.exports;
}(), Nr = {
show: {
type: Boolean,
default: !0
},
domId: {
type: String
},
loading: {
type: Boolean
},
showStreamInfo: {
type: Boolean
},
showAudioStream: {
type: Boolean
}
}, Se = {
options: {
virtualHost: !0
}
};
Se.props = Nr;
Se.setup = (A, t) => {
const e = X(["stream-info-container", {
mobile: !j.isPC
}]);
return {
TUIGlobal: j,
streamInfoContainerClassName: e
};
};
Se.components = Object.assign({
WXPlayer: gr
}, Se.components);
var pr = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
directives: [{
name: "show",
rawName: "v-show",
value: A.show,
expression: "show"
}],
staticClass: "player-container",
attrs: {
id: A.domId
}
}, [e("div", {
directives: [{
name: "show",
rawName: "v-show",
value: A.showAudioStream,
expression: "showAudioStream"
}],
staticClass: "audio-stream-container"
}, [A._t("audio-stream")], 2), A._t("loading"), e("div", {
class: A.streamInfoContainerClassName
}, [A._t("stream-info")], 2), A.TUIGlobal.isWeChat ? e("WXPlayer", {
attrs: {
"dom-id": A.domId,
remoteClass: "small-view"
}
}) : A._e()], 2);
}, Dr = [];
const Nn = {};
var Tr = /* @__PURE__ */ S(
Se,
pr,
Dr,
!1,
Cr,
"91fc5e7a",
null,
null
);
function Cr(A) {
for (let t in Nn)
this[t] = Nn[t];
}
const ol = /* @__PURE__ */ function() {
return Tr.exports;
}(), yr = {
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
}
}, Ee = {
options: {
virtualHost: !0
}
};
Ee.props = yr;
Ee.setup = (A, t) => {
const e = A, a = xo(), {
callType: n,
isGroupCall: l
} = z(q()), {
isFloatWindow: i
} = z(CA()), u = p(() => !l.value && !j.isPC), s = p(() => l.value ? j.isPC : n.value === F.AUDIO), r = p(() => !l.value && j.isPC && n.value === F.AUDIO), M = p(() => ({
zIndex: 1
})), D = p(() => a.value[e.userId] || e.avatar), g = I(!a.value[e.userId]), N = I(a.value[e.userId] ? "fill" : "cover");
return J([() => e.userId, a], () => {
a.value[e.userId] ? (N.value = "fill", g.value = !1) : (N.value = "cover", g.value = !0);
}, {
immediate: !0
}), {
isGroupCall: l,
isFloatWindow: i,
showAvatar: u,
showUserName: s,
showMicVolume: r,
audioStreamStyle: M,
bgImage: D,
showViewMask: g,
fit: N,
handleError: () => {
g.value = !0, N.value = "cover";
}
};
};
Ee.components = Object.assign({
OverlayStream: Ho
}, Ee.components);
var Sr = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("OverlayStream", {
attrs: {
avatar: A.avatar,
"bg-image": A.bgImage,
"show-avatar": A.showAvatar,
username: A.username,
"show-user-name": A.showUserName,
"show-mask": !A.isGroupCall && A.showViewMask,
fit: A.fit,
blur: !A.isGroupCall,
"show-mic-volume": A.showMicVolume,
"show-tip": !A.isGroupCall && !A.isFloatWindow,
"custom-style": A.audioStreamStyle,
"is-small-window": A.isSmallWindow,
"is-muted": A.isMuted,
volume: A.volume,
"bg-color": "rgba(0, 0, 0, 0.5)"
},
on: {
error: A.handleError
}
});
}, Er = [];
const pn = {};
var hr = /* @__PURE__ */ S(
Ee,
Sr,
Er,
!1,
mr,
null,
null,
null
);
function mr(A) {
for (let t in pn)
this[t] = pn[t];
}
const ll = /* @__PURE__ */ function() {
return hr.exports;
}(), jr = "", vr = "", fr = "", Lr = "data:im
options: {
virtualHost: !0
}
};
il.setup = (A, t) => {
const {
localUserInfoExcludeVolume: e
} = z(MA()), {
callRole: a,
callStatus: n
} = z(q()), {
isFloatWindow: l
} = z(CA());
function i() {
O.toggleMinimize();
}
async function u() {
a.value === K.CALLEE && n.value === U.CALLING ? await O.reject() : await O.hangup();
}
async function s() {
e.value.isAudioAvailable ? await O.closeMicrophone() : await O.openMicrophone();
}
return {
FloatCallEnd: jr,
FloatMicrophoneSVG: vr,
FloatMicrophoneClosedSVG: fr,
FloatFullScreenSVG: Lr,
localUserInfo: e,
isFloatWindow: l,
toggleMinimize: i,
hangup: u,
toggleMicrophone: s
};
};
var Ur = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
staticClass: "float-window-container"
}, [e("div", {
directives: [{
name: "show",
rawName: "v-show",
value: A.isFloatWindow,
expression: "isFloatWindow"
}],
staticClass: "float-control-panel"
}, [e("div", {
staticClass: "float-control-item-icon"
}, [e("div", {
staticClass: "float-control-item-icon-container",
on: {
click: A.hangup
}
}, [e("img", {
attrs: {
src: A.FloatCallEnd
}
})])]), e("div", {
directives: [{
name: "show",
rawName: "v-show",
value: A.isFloatWindow,
expression: "isFloatWindow"
}],
staticClass: "float-control-item-icon"
}, [e("div", {
staticClass: "float-control-item-icon-container",
on: {
click: A.toggleMicrophone
}
}, [A.localUserInfo.isAudioAvailable ? e("img", {
attrs: {
src: A.FloatMicrophoneSVG
}
}) : e("img", {
attrs: {
src: A.FloatMicrophoneClosedSVG
}
})])]), e("div", {
directives: [{
name: "show",
rawName: "v-show",
value: A.isFloatWindow,
expression: "isFloatWindow"
}],
staticClass: "float-control-item-icon"
}, [e("div", {
staticClass: "float-control-item-icon-container",
on: {
click: A.toggleMinimize
}
}, [e("img", {
attrs: {
src: A.FloatFullScreenSVG
}
})])])]), e("div", {
directives: [{
name: "show",
rawName: "v-show",
value: !A.isFloatWindow,
expression: "!isFloatWindow"
}]
}, [A._t("default")], 2)]);
}, zr = [];
const Dn = {};
var wr = /* @__PURE__ */ S(
il,
Ur,
zr,
!1,
Or,
"4df5fc21",
null,
null
);
function Or(A) {
for (let t in Dn)
this[t] = Dn[t];
}
const xr = /* @__PURE__ */ function() {
return wr.exports;
}(), sl = "", ut = {
options: {
virtualHost: !0
}
};
ut.setup = (A, t) => {
const {
callType: e,
callStatus: a
} = z(q()), {
isFloatWindow: n
} = z(CA()), {
callDuration: l
} = Ht(), i = p(() => X(["float-window-container", {
"singlecall-video-float": e.value === F.VIDEO && n.value,
"singlecall-audio-float": e.value === F.AUDIO && n.value
}]));
function u() {
n.value && O.toggleMinimize();
}
return {
CallMediaType: F,
CallStatus: U,
t: v,
earphoneSrc: sl,
callType: e,
callStatus: a,
isFloatWindow: n,
callDuration: l,
floatWindowClassName: i,
closeFloatWindow: u
};
};
ut.components = Object.assign({
TKText: lA,
TKImage: SA,
Timer: sa
}, ut.components);
var Vr = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
class: A.floatWindowClassName
}, [e("div", {
directives: [{
name: "show",
rawName: "v-show",
value: !(A.isFloatWindow && A.callType === A.CallMediaType.AUDIO),
expression: "!(isFloatWindow && callType === CallMediaType.AUDIO)"
}],
staticClass: "singlecall-video-float-content",
on: {
click: A.closeFloatWindow
}
}, [A._t("default"), e("div", {
staticClass: "float-window-tip-container"
}, [A.callStatus === A.CallStatus.CALLING && A.isFloatWindow ? e("TKText", {
attrs: {
color: "#FFF",
size: "12px"
}
}, [A._v(A._s(A.t("wait to be called")))]) : A._e()], 1)], 2), e("div", {
directives: [{
name: "show",
rawName: "v-show",
value: A.isFloatWindow && A.callType === A.CallMediaType.AUDIO,
expression: "isFloatWindow && callType === CallMediaType.AUDIO"
}],
staticClass: "singlecall-audio-float-content",
on: {
click: A.closeFloatWindow
}
}, [e("TKImage", {
attrs: {
width: "36px",
height: "36px",
src: A.earphoneSrc
}
}), A.callStatus === A.CallStatus.CONNECTED ? e("Timer", {
attrs: {
fontSize: "12px",
callDuration: A.callDuration,
color: "#12b969"
}
}) : A._e(), A.callStatus === A.CallStatus.CALLING && A.isFloatWindow ? e("TKText", {
attrs: {
color: "#12b969",
size: "12px"
}
}, [A._v(A._s(A.t("wait to be called")))]) : A._e()], 1)]);
}, br = [];
const Tn = {};
var Br = /* @__PURE__ */ S(
ut,
Vr,
br,
!1,
Fr,
"73a848fe",
null,
null
);
function Fr(A) {
for (let t in Tn)
this[t] = Tn[t];
}
const Rr = /* @__PURE__ */ function() {
return Br.exports;
}(), kr = "", Pr = "", Wr = "", Gr = "
options: {
virtualHost: !0
}
};
ct.setup = (A, t) => {
const {
isFloatWindow: e
} = z(CA()), {
callDuration: a
} = Ht(), {
localUserInfoExcludeVolume: n
} = z(MA()), {
callStatus: l
} = z(q()), i = p(() => n.value.isAudioAvailable ? kr : Wr), u = p(() => n.value.isVideoAvailable ? Pr : Gr), s = p(() => X(["groupcall-video-float", {
"not-float": !e.value,
float: e.value
}]));
function r() {
e.value && O.toggleMinimize();
}
return {
CallStatus: U,
t: v,
earphoneSrc: sl,
isFloatWindow: e,
callDuration: a,
callStatus: l,
microphoneSrc: i,
cameraSrc: u,
floatWindowClassName: s,
closeFloatWindow: r
};
};
ct.components = Object.assign({
TKImage: SA,
Timer: sa,
TKText: lA
}, ct.components);
var Qr = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
class: A.floatWindowClassName
}, [A.isFloatWindow ? e("div", {
staticClass: "click-container",
on: {
"!click": function(a) {
return a.stopPropagation(), A.closeFloatWindow.apply(null, arguments);
}
}
}) : A._e(), e("div", {
staticClass: "stream-container"
}, [e("div", {
staticClass: "video"
}, [A._t("default")], 2), e("div", {
directives: [{
name: "show",
rawName: "v-show",
value: A.isFloatWindow,
expression: "isFloatWindow"
}],
staticClass: "audio"
}, [e("TKImage", {
attrs: {
width: "36px",
height: "36px",
src: A.earphoneSrc
}
}), A.callStatus === A.CallStatus.CONNECTED ? e("Timer", {
attrs: {
fontSize: "12px",
callDuration: A.callDuration,
color: "#12b969"
}
}) : A._e(), A.callStatus === A.CallStatus.CALLING ? e("TKText", {
attrs: {
size: "12px",
color: "#12b969"
}
}, [A._v(A._s(A.t("wait to be called")))]) : A._e()], 1)]), e("div", {
directives: [{
name: "show",
rawName: "v-show",
value: A.isFloatWindow,
expression: "isFloatWindow"
}],
staticClass: "device-status"
}, [e("TKImage", {
attrs: {
width: "16px",
height: "16px",
src: A.microphoneSrc
}
}), e("TKImage", {
attrs: {
width: "16px",
height: "16px",
src: A.cameraSrc
}
})], 1)]);
}, Zr = [];
const Cn = {};
var Yr = /* @__PURE__ */ S(
ct,
Qr,
Zr,
!1,
Xr,
"04a48581",
null,
null
);
function Xr(A) {
for (let t in Cn)
this[t] = Cn[t];
}
const _r = /* @__PURE__ */ function() {
return Yr.exports;
}(), rt = {
options: {
virtualHost: !0
}
};
rt.setup = (A, t) => {
const {
isGroupCall: e
} = z(q());
return {
isGroupCall: e
};
};
rt.components = Object.assign({
FloatWindowSingleCall: Rr,
FloatWindowGroupCall: _r
}, rt.components);
var qr = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
attrs: {
id: "float-window-id"
}
}, [A.isGroupCall ? e("FloatWindowGroupCall", [A._t("default")], 2) : e("FloatWindowSingleCall", [A._t("default")], 2)], 1);
}, Jr = [];
const yn = {};
var Hr = /* @__PURE__ */ S(
rt,
qr,
Jr,
!1,
Kr,
null,
null,
null
);
function Kr(A) {
for (let t in yn)
this[t] = yn[t];
}
const $r = /* @__PURE__ */ function() {
return Hr.exports;
}(), Mt = {
options: {
virtualHost: !0
}
};
Mt.setup = (A, t) => {
const {
isFloatWindow: e
} = z(CA()), a = p(() => X(["float-window-container", {
float: e.value,
"not-float": !e.value,
pc: j.isPC,
mobile: !j.isPC
}]));
return {
TUIGlobal: j,
floatWindowContainerClassName: a
};
};
Mt.components = Object.assign({
FloatWindowPC: xr,
FloatWindowMobile: $r
}, Mt.components);
var AM = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
class: A.floatWindowContainerClassName
}, [A.TUIGlobal.isPC ? e("FloatWindowPC", [A._t("default")], 2) : A._e(), A.TUIGlobal.isPC ? A._e() : e("FloatWindowMobile", [A._t("default")], 2)], 1);
}, eM = [];
const Sn = {};
var tM = /* @__PURE__ */ S(
Mt,
AM,
eM,
!1,
aM,
"59a0c3c2",
null,
null
);
function aM(A) {
for (let t in Sn)
this[t] = Sn[t];
}
const ul = /* @__PURE__ */ function() {
return tM.exports;
}();
function nM() {
const A = Ge(), { callStatus: t } = z(q()), e = I(At.LOCAL), { remoteUserListExcludeVolume: a } = z(MA());
return J([a, A, t], () => {
var i, u, s, r;
if (t.value === U.CALLING)
return;
const n = [et.RemoteInLargeView, et.LocalInLargeView], l = (i = A.value) == null ? void 0 : i.layoutMode;
if (n.includes(l)) {
e.value = (u = A.value) == null ? void 0 : u.layoutMode;
return;
}
(r = (s = a.value) == null ? void 0 : s[0]) != null && r.isEnter && (e.value = At.REMOTE);
}, {
immediate: !0
}), e;
}
const dt = {
options: {
virtualHost: !0
}
};
dt.setup = (A, t) => {
const e = nM(), a = I(!0), {
isFloatWindow: n
} = z(CA()), {
localUserInfoExcludeVolume: l,
remoteUserListExcludeVolume: i
} = z(MA()), u = Uo(), {
callType: s,
callStatus: r
} = z(q()), M = zo(), D = p(() => {
var C, E, w, L;
return j.isWeChat ? (E = (C = M.value) == null ? void 0 : C.find((m) => {
var k, _;
return (m == null ? void 0 : m.userID) === ((_ = (k = i.value) == null ? void 0 : k[0]) == null ? void 0 : _.userId);
})) == null ? void 0 : E.hasVideo : (L = (w = i.value) == null ? void 0 : w[0]) == null ? void 0 : L.isVideoAvailable;
}), g = p(() => {
var C, E;
return (E = (C = i.value) == null ? void 0 : C[0]) == null ? void 0 : E.domId;
}), N = p(() => {
var C, E, w;
return (w = u.value) == null ? void 0 : w[(E = (C = i.value) == null ? void 0 : C[0]) == null ? void 0 : E.domId];
});
J([s, r], () => {
s.value === F.AUDIO || r.value === U.CALLING ? a.value = !1 : a.value = !0;
}, {
immediate: !0
});
const y = p(() => X(["singlecall-media-container", {
mobile: !j.isPC,
pc: j.isPC,
float: n.value
}]));
function T(C) {
e.value = C;
}
return {
CallMediaType: F,
ViewName: At,
largeViewName: e,
showSmallWindow: a,
isFloatWindow: n,
localUserInfoExcludeVolume: l,
remoteUserListExcludeVolume: i,
volumeMap: u,
callType: s,
isPusherVideoAvailable: D,
playerDomId: g,
remoteStreamVolume: N,
singleMediaContainerClassName: y,
handleToggle: T
};
};
dt.components = Object.assign({
Portal: el,
FloatWindow: ul,
ToggleWindow: Nc,
ToggleWindowItem: Gc,
Pusher: nl,
AudioStream: ll,
TKStreamInfo: al,
Player: ol
}, dt.components);
var oM = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("Portal", {
attrs: {
id: "source",
disabled: !A.isFloatWindow,
source: "#source",
to: "body"
}
}, [e("FloatWindow", [e("div", {
class: A.singleMediaContainerClassName
}, [e("ToggleWindow", {
attrs: {
"big-window": A.largeViewName,
"show-small-window": A.showSmallWindow
},
on: {
toggle: A.handleToggle
}
}, [e("ToggleWindowItem", {
key: A.ViewName.LOCAL,
attrs: {
value: A.ViewName.LOCAL
}
}, [e("Pusher", {
attrs: {
domId: A.localUserInfoExcludeVolume.domId,
"show-audio-stream": !A.localUserInfoExcludeVolume.isVideoAvailable
},
scopedSlots: A._u([{
key: "audio-stream",
fn: function() {
return [e("AudioStream", {
attrs: {
userId: A.localUserInfoExcludeVolume.userId,
username: A.localUserInfoExcludeVolume.displayUserInfo,
avatar: A.localUserInfoExcludeVolume.avatar,
"is-video-available": A.localUserInfoExcludeVolume.isVideoAvailable,
"is-small-window": A.largeViewName !== A.ViewName.LOCAL,
"is-muted": !A.localUserInfoExcludeVolume.isAudioAvailable,
volume: A.volumeMap && A.volumeMap[A.localUserInfoExcludeVolume.domId]
}
})];
},
proxy: !0
}, {
key: "stream-info",
fn: function() {
return [A.callType === A.CallMediaType.VIDEO ? e("TKStreamInfo", {
attrs: {
"nick-name": A.localUserInfoExcludeVolume.displayUserInfo,
"is-self": !0,
"is-muted": !A.localUserInfoExcludeVolume.isAudioAvailable,
volume: A.volumeMap && A.volumeMap[A.localUserInfoExcludeVolume.domId]
}
}) : A._e()];
},
proxy: !0
}])
})], 1), e("ToggleWindowItem", {
key: A.ViewName.REMOTE,
attrs: {
value: A.ViewName.REMOTE
}
}, [e("Player", {
attrs: {
"dom-id": A.playerDomId,
"show-audio-stream": !A.isPusherVideoAvailable
},
scopedSlots: A._u([{
key: "audio-stream",
fn: function() {
return [e("AudioStream", {
attrs: {
userId: A.remoteUserListExcludeVolume[0] && A.remoteUserListExcludeVolume[0].userId,
username: A.remoteUserListExcludeVolume[0] && A.remoteUserListExcludeVolume[0].displayUserInfo,
avatar: A.remoteUserListExcludeVolume[0] && A.remoteUserListExcludeVolume[0].avatar,
"is-video-available": A.isPusherVideoAvailable,
"is-small-window": A.largeViewName !== A.ViewName.REMOTE,
"is-muted": A.remoteUserListExcludeVolume[0] && !A.remoteUserListExcludeVolume[0].isAudioAvailable,
volume: A.remoteStreamVolume
}
})];
},
proxy: !0
}, {
key: "stream-info",
fn: function() {
return [A.callType === A.CallMediaType.VIDEO ? e("TKStreamInfo", {
attrs: {
"nick-name": A.remoteUserListExcludeVolume[0] && A.remoteUserListExcludeVolume[0].displayUserInfo,
"is-muted": A.remoteUserListExcludeVolume[0] && !A.remoteUserListExcludeVolume[0].isAudioAvailable,
volume: A.remoteStreamVolume
}
}) : A._e()];
},
proxy: !0
}])
})], 1)], 1)], 1)])], 1);
}, lM = [];
const En = {};
var iM = /* @__PURE__ */ S(
dt,
oM,
lM,
!1,
sM,
"5ca72ad0",
null,
null
);
function sM(A) {
for (let t in En)
this[t] = En[t];
}
const uM = /* @__PURE__ */ function() {
return iM.exports;
}(), cM = [ae.SUCCESS, ae.INFO, ae.WARNING, ae.ERROR], _A = {
isShow: {
type: Boolean,
default: !1
},
message: {
type: String,
default: ""
},
type: {
type: String,
values: cM,
default: ae.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
}
};
function rM(A, t) {
const e = I((A == null ? void 0 : A.message) || _A.message.default), a = I((A == null ? void 0 : A.duration) || _A.duration.default), n = I((A == null ? void 0 : A.type) || _A.type.default), l = I((A == null ? void 0 : A.offset) || _A.offset.default), i = I((A == null ? void 0 : A.showClose) || _A.showClose.default), u = I(!1);
let s = -1;
const r = (g) => {
s > -1 && (clearTimeout(s), s = -1), u.value = !0, D(g || {}), a.value && (s = setTimeout(() => {
M();
}, a.value));
}, M = () => {
u.value = !1, s > -1 && (clearTimeout(s), s = -1);
}, D = (g) => {
const {
message: N = e.value,
type: y = n.value,
offset: T = l.value,
duration: C = a.value,
showClose: E = i.value
} = g;
a.value = (A == null ? void 0 : A.duration) === 0 ? A == null ? void 0 : A.duration : C, e.value = N, n.value = y, l.value = T, i.value = E;
};
return J(
() => A == null ? void 0 : A.isShow,
(g) => {
g && r();
},
{ immediate: !0 }
), J(u, (g) => {
g || t("onClose");
}), {
messageContent: e,
messageDuration: a,
messageType: n,
messageOffset: l,
isShowCloseIcon: i,
visible: u,
show: r,
close: M
};
}
const MM = "", dM = "", IM = "", gM = "", NM = "", he = {
options: {
virtualHost: !0
}
};
he.props = _A;
he.setup = (A, t) => {
const e = A, a = t.emit, {
messageContent: n,
messageType: l,
messageOffset: i,
isShowCloseIcon: u,
visible: s,
show: r,
close: M
} = rM(e, a), D = p(() => X([`${x}-message`, `${x}-message--${l.value}`, e.customClass])), g = p(() => X([`${x}-message_icon`])), N = p(() => X([`${x}-message_close`])), y = p(() => `${i.value}px`), T = p(() => ({
top: y.value,
...e.customStyle
}));
return Object.assign({
CloseSrc: NM,
messageContent: n,
messageType: l,
isShowCloseIcon: u,
visible: s,
close: M,
messageClassName: D,
typeIconClassName: g,
closeIconClassName: N,
messageStyle: T,
IconSrcMap: {
info: gM,
waring: IM,
success: dM,
error: MM
}
}, {
show: r,
close: M
});
};
he.components = Object.assign({
Icon: ft
}, he.components);
var pM = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return A.visible ? e("div", {
class: A.messageClassName,
style: [A.messageStyle]
}, [e("div", {
directives: [{
name: "show",
rawName: "v-show",
value: A.showIcon,
expression: "showIcon"
}],
class: A.typeIconClassName
}, [e("Icon", {
attrs: {
src: A.IconSrcMap[A.messageType]
}
})], 1), e("span", [A._v(A._s(A.messageContent))]), e("div", {
directives: [{
name: "show",
rawName: "v-show",
value: A.isShowCloseIcon,
expression: "isShowCloseIcon"
}],
class: A.closeIconClassName,
on: {
click: A.close
}
}, [e("Icon", {
attrs: {
src: A.CloseSrc
}
})], 1)]) : A._e();
}, DM = [];
const hn = {};
var TM = /* @__PURE__ */ S(
he,
pM,
DM,
!1,
CM,
null,
null,
null
);
function CM(A) {
for (let t in hn)
this[t] = hn[t];
}
const cl = /* @__PURE__ */ function() {
return TM.exports;
}(), yM = {
customClass: {
type: String
}
}, me = {
options: {
virtualHost: !0,
styleIsolation: "shared"
}
};
me.props = yM;
me.setup = (A, t) => {
const {
isFloatWindow: e
} = z(CA()), {
tip: a,
duration: n
} = Vi(), {
isGroupCall: l
} = z(q()), i = I(null), u = A, s = j.isPC, r = p(() => [u.customClass]), M = p(() => ot({
color: "white",
background: "none",
position: "absolute",
"z-index": 4,
"align-items": "center",
left: "50%",
top: `${s ? "60%" : "70%"}`,
transform: "translate(-50%, -50%)",
"font-size": e.value ? "12px" : void 0
})), D = p(() => ot({
color: "white",
background: "none",
position: "static",
transform: "none",
"font-size": e.value ? "12px" : void 0
})), g = p(() => l.value ? D.value : M.value);
return J(a, () => {
var N;
(N = i.value) == null || N.show({
message: a.value,
duration: n.value,
offset: 0
});
}), {
message: i,
tipClassName: r,
customStyle: g
};
};
me.components = Object.assign({
Message: cl
}, me.components);
var SM = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", [e("Message", {
ref: "message",
class: A.tipClassName,
attrs: {
showIcon: !1,
customStyle: A.customStyle
}
})], 1);
}, EM = [];
const mn = {};
var hM = /* @__PURE__ */ S(
me,
SM,
EM,
!1,
mM,
null,
null,
null
);
function mM(A) {
for (let t in mn)
this[t] = mn[t];
}
const rl = /* @__PURE__ */ function() {
return hM.exports;
}(), jM = ["%", "vw"], vM = {
length: {
type: Number,
default: 0
},
unit: {
type: String,
values: jM,
default: "%"
},
enableFocus: {
type: Boolean,
default: !1
},
layout: {
type: Array
},
focus: {
type: [String, Number]
}
}, Ml = "GridContextKey", ga = {
options: {
virtualHost: !0
}
};
ga.props = vM;
ga.setup = (A, t) => {
const e = A, a = I(e.focus), n = I(e.layout), l = I(e.unit), i = t.emit;
function u(s) {
i("toggle", s);
}
return J(() => e.focus, () => a.value = e.focus), J(() => e.layout, () => n.value = e.layout), J(() => e.unit, () => l.value = e.unit), gA(Ml, {
layout: n,
enableFocus: e.enableFocus,
handleFocusChange: u,
focus: a,
unit: l
}), {};
};
var fM = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
style: {
height: "100%"
}
}, [A._t("default")], 2);
}, LM = [];
const jn = {};
var UM = /* @__PURE__ */ S(
ga,
fM,
LM,
!1,
zM,
null,
null,
null
);
function zM(A) {
for (let t in jn)
this[t] = jn[t];
}
const dl = /* @__PURE__ */ function() {
return UM.exports;
}(), Na = {
options: {
virtualHost: !0
}
};
Na.props = ["index", "height", "customStyle"];
Na.setup = (A, t) => {
const e = A, {
layout: a,
enableFocus: n,
handleFocusChange: l,
focus: i,
unit: u
} = NA(Ml), s = 100 / 12, r = s, M = I({}), D = X([`${x}-grid-item`, {
pc: WA,
mobile: !WA,
h5: bo
}]), g = () => {
const y = String(e.index) === String(i.value) ? null : e.index;
n && l(y);
}, N = p(() => !!Ba(a.value, {
key: "i",
value: e.index
}));
return QA(() => {
const y = Ba(a.value, {
key: "i",
value: e.index
});
if (!y)
return;
const {
x: T,
y: C,
w: E,
h: w,
customStyle: L,
customProps: m
} = y;
M.value = {
width: E * s + u.value,
height: e.height || w * r + u.value,
left: T * s + u.value,
top: C * r + u.value,
position: "absolute",
visibility: (m == null ? void 0 : m.show) === !1 ? "hidden" : "",
...e.customStyle,
...L
};
}), tA(() => {
String(e.index) === String(i.value) && n && l(null);
}), {
style: M,
gridItemClassName: D,
handleClick: g,
show: N
};
};
var wM = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return A.show ? e("div", {
class: A.gridItemClassName,
style: [A.style],
on: {
click: A.handleClick
}
}, [A._t("default")], 2) : A._e();
}, OM = [];
const vn = {};
var xM = /* @__PURE__ */ S(
Na,
wM,
OM,
!1,
VM,
null,
null,
null
);
function VM(A) {
for (let t in vn)
this[t] = vn[t];
}
const Il = /* @__PURE__ */ function() {
return xM.exports;
}();
function bM() {
const A = I([]), t = I([]), { callStatus: e, isGroupCall: a, callType: n, callRole: l } = z(q()), { status: i } = We() || {}, u = Qi();
return J(
[e, a, n, l, i, u],
() => {
var E, w, L;
let s = u.value;
const r = j.isPC ? "pc" : "mobile", M = a.value ? "groupCall" : "singleCall", D = n.value === F.AUDIO ? "audio" : "video";
let g = e.value === U.CALLING ? l.value === K.CALLER ? "calling" : "accept" : e.value;
a && (i == null ? void 0 : i.value) === "close" && (g = "close_" + g);
const N = ((L = (w = (E = s == null ? void 0 : s[r]) == null ? void 0 : E[M]) == null ? void 0 : w[D]) == null ? void 0 : L[g]) || [];
t.value = N;
const y = [];
let T = 0;
for (let m = 0; m < N.length; m++) {
const k = m === 0 ? N[m].filter((b) => {
var P;
return ((P = b == null ? void 0 : b.props) == null ? void 0 : P.show) !== !1;
}) : N[m];
N[m] = k;
const _ = 12 / k.length, Z = 3;
for (let b = 0; b < k.length; b++)
y[T++] = {
i: k[b].name,
x: b * _,
y: m * _,
w: _,
h: Z,
customStyle: k[b].customStyle,
customProps: k[b].props
};
}
T = 0;
let C = [];
for (let m = 0; m < N.flat().length; m++)
C[m] = y[T++];
C = C.filter((m) => m.i), A.value = C;
},
{
immediate: !0
}
), { layout: A, config: t };
}
function BM(...A) {
let t = window == null ? void 0 : window.document, e = "", a = () => {
}, n = {};
if (typeof A[0] == "string" ? [e, a, n] = A : [t, e, a, n] = A, !!t)
return t == null || t.addEventListener(e, a, n), () => {
t == null || t.removeEventListener(e, a, n);
};
}
function FM(A, t) {
let e = () => {
};
aA(() => {
e = BM("click", (n) => {
const l = A.map((s) => xl(s)), i = n.composedPath(), u = [];
for (let s = 0; s < l.length; s++)
u[s] = i.includes(l[s]);
u.every((s) => !s) && t();
}, { passive: !0 });
}), tA(() => {
e == null || e();
});
}
const RM = (A, t, e, a, n) => {
const l = e.isShowArrow ? e.arrowSize : 0, i = `${A.width / 2 - t.width / 2}px`, u = `${A.height / 2 - t.height / 2}px`, s = `${l}px solid ${e.color}`, r = { ...a }, M = { ...n };
switch (e.placement) {
case "top":
r.left = i, r.top = `-${t.height + l + e.arrowDistance}px`, M.borderTop = s, M.left = `${A.width / 2 - l / 2}px`, M.top = `-${l + e.arrowDistance}px`;
break;
case "bottom":
r.left = i, r.top = `${A.height + l + e.arrowDistance}px`, M.borderBottom = s, M.left = `${A.width / 2 - l / 2}px`, M.top = `${A.height + e.arrowDistance - l}px`;
break;
case "left":
r.left = `-${t.width + l + e.arrowDistance}px`, r.top = u, M.borderLeft = s, M.left = `-${l * 2 - e.arrowDistance}px`, M.top = `${A.height / 2 - l / 2}px`;
break;
case "right":
r.left = `${A.width + l + e.arrowDistance}px`, r.top = u, M.borderRight = s, M.left = `${A.width + l * 2 - e.arrowDistance}px`, M.top = `${A.height / 2 - l / 2}px`;
break;
}
return {
finalContentStyle: r,
finalArrowStyle: M
};
}, kM = ["click", "hover"], PM = ["top", "bottom", "left", "right"], gl = {
trigger: {
type: String,
values: kM,
default: "click"
},
placement: {
type: String,
values: PM,
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
}
}, pa = {
options: {
virtualHost: !0
}
};
pa.props = gl;
pa.setup = (A, t) => {
const e = A, a = `${x}-popover`, n = `${x}-popover_content`, l = `${x}-popover_arrow`, i = `${x}-popover_trigger`, u = I(), s = I(), r = I(), M = I(!1), D = I(null), g = p(() => M.value && e.isShowArrow && e.show), N = ot({
left: "0px",
top: "0px",
backgroundColor: e.color
}), y = I(N), T = `${e.arrowSize}px solid transparent`, C = {
borderLeft: T,
borderRight: T,
borderTop: T,
borderBottom: T,
top: "0px",
left: "0px"
}, E = I(C), w = t.emit, L = () => {
Vl(() => {
var xA, VA, bA, YA;
if (!M.value || !e.show)
return;
const b = (VA = (xA = s.value).getBoundingClientRect) == null ? void 0 : VA.call(xA), P = (YA = (bA = r.value).getBoundingClientRect) == null ? void 0 : YA.call(bA), {
finalContentStyle: AA,
finalArrowStyle: ZA
} = RM(b, P, e, N, C);
y.value = {
...N,
...AA
}, E.value = {
...C,
...ZA
};
});
}, m = () => {
clearTimeout(D.value);
}, k = () => {
e.trigger === "click" && (M.value = !M.value, L());
}, _ = () => {
e.trigger === "hover" && (w("hover"), m(), M.value = !0, L());
}, Z = () => {
e.trigger === "hover" && (D.value = setTimeout(() => {
M.value = !1, L();
}, 1e3));
};
return FM([u], () => {
M.value = !1;
}), {
popoverClassName: a,
popoverContentClassName: n,
popoverArrowClassName: l,
popoverTriggerClassName: i,
popoverRef: u,
triggerRef: s,
contentRef: r,
visible: M,
showArrow: g,
contentStyle: y,
arrowStyle: E,
clearTimer: m,
handleClick: k,
handleMouseEnter: _,
handleMouseLeave: Z
};
};
var WM = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
ref: "popoverRef",
class: A.popoverClassName
}, [A.visible && A.show ? e("div", {
ref: "contentRef",
class: A.popoverContentClassName,
style: [A.contentStyle],
on: {
mouseenter: A.clearTimer,
mouseleave: A.handleMouseLeave
}
}, [A._t("content")], 2) : A._e(), A.showArrow ? e("div", {
class: A.popoverArrowClassName,
style: [A.arrowStyle]
}) : A._e(), e("div", {
ref: "triggerRef",
class: A.popoverTriggerClassName,
on: {
click: A.handleClick,
mouseenter: A.handleMouseEnter,
mouseleave: A.handleMouseLeave
}
}, [A._t("trigger")], 2)]);
}, GM = [];
const fn = {};
var QM = /* @__PURE__ */ S(
pa,
WM,
GM,
!1,
ZM,
null,
null,
null
);
function ZM(A) {
for (let t in fn)
this[t] = fn[t];
}
const YM = /* @__PURE__ */ function() {
return QM.exports;
}(), XM = {
options: {
virtualHost: !0
}
};
var _M = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div");
}, qM = [];
const Ln = {};
var JM = /* @__PURE__ */ S(
XM,
_M,
qM,
!1,
HM,
null,
null,
null
);
function HM(A) {
for (let t in Ln)
this[t] = Ln[t];
}
const KM = /* @__PURE__ */ function() {
return JM.exports;
}(), je = {
options: {
virtualHost: !0
}
};
je.props = gl;
je.setup = (A, t) => {
const e = t.emit;
return {
IN_WX_MINI_APP: se,
handleHover: () => {
e("hover");
}
};
};
je.components = Object.assign({
PopoverWeb: YM,
PopoverWx: KM
}, je.components);
var $M = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return A.IN_WX_MINI_APP ? A._e() : e("PopoverWeb", A._b({
on: {
hover: A.handleHover
},
scopedSlots: A._u([{
key: "trigger",
fn: function() {
return [A._t("trigger")];
},
proxy: !0
}, {
key: "content",
fn: function() {
return [A._t("content")];
},
proxy: !0
}], null, !0)
}, "PopoverWeb", A.$props, !1));
}, Ad = [];
const Un = {};
var ed = /* @__PURE__ */ S(
je,
$M,
Ad,
!1,
td,
null,
null,
null
);
function td(A) {
for (let t in Un)
this[t] = Un[t];
}
const Da = /* @__PURE__ */ function() {
return ed.exports;
}(), ad = {
deviceType: {
type: String
},
isShowControlBtn: {
type: Boolean,
default: !1
}
}, ve = {
options: {
virtualHost: !0
}
};
ve.props = ad;
ve.setup = (A, t) => {
const e = A, [{
deviceList: a,
currentDeviceId: n
}, {
updateCurrentDeviceId: l
}] = mt(e.deviceType), {
localUserInfoExcludeVolume: i
} = z(MA()), {
isMuteSpeaker: u
} = z(q()), s = vt(), r = async (N) => {
try {
g(), await O.switchDevice({
deviceType: e.deviceType,
deviceId: N
}), l(N);
} catch (y) {
console.debug(y);
}
}, M = async () => {
var N, y;
g(), e.deviceType === oA.CAMERA && ((N = i.value) != null && N.isVideoAvailable ? await O.closeCamera() : await O.openCamera("localVideo")), e.deviceType === oA.MICROPHONE && ((y = i.value) != null && y.isAudioAvailable ? await O.closeMicrophone() : await O.openMicrophone()), e.deviceType === oA.SPEAKER && (u.value ? await O.unMuteSpeaker() : await O.muteSpeaker());
}, D = p(() => {
var N;
if (e.deviceType === oA.CAMERA)
return i != null && i.value.isVideoAvailable ? v("close camera") : v("open camera");
if (e.deviceType === oA.MICROPHONE)
return (N = i == null ? void 0 : i.value) != null && N.isAudioAvailable ? v("close microphone") : v("open microphone");
if (e.deviceType === oA.SPEAKER)
return u.value ? v("open speaker") : v("close speaker");
}), g = () => {
s.value = "close";
};
return {
deviceList: a,
currentDeviceId: n,
handleClickDeviceItem: r,
switchStatus: M,
deviceText: D
};
};
ve.components = Object.assign({
TKText: lA
}, ve.components);
var nd = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
staticClass: "device-selector-container"
}, [e("div", {
staticClass: "scroll-container"
}, [e("div", {
staticClass: "scroll-content"
}, A._l(A.deviceList, function(a) {
return e("div", {
key: a.deviceId
}, [e("TKText", {
staticClass: "device-item",
class: {
select: A.currentDeviceId === a.deviceId
},
attrs: {
width: "100%",
color: "#ffff",
truncated: !0,
size: "14px"
},
on: {
click: function() {
return A.handleClickDeviceItem(a.deviceId);
}
}
}, [A._v(" " + A._s(a.label) + " ")])], 1);
}), 0)]), e("div", {
staticClass: "control-item"
}), A.isShowControlBtn ? e("TKText", {
staticClass: "device-item",
attrs: {
width: "100%",
color: "#ffff",
truncated: !0,
size: "14px"
},
on: {
click: A.switchStatus
}
}, [A._v(" " + A._s(A.deviceText) + " ")]) : A._e()], 1);
}, od = [];
const zn = {};
var ld = /* @__PURE__ */ S(
ve,
nd,
od,
!1,
id,
"a65fe216",
null,
null
);
function id(A) {
for (let t in zn)
this[t] = zn[t];
}
const Ta = /* @__PURE__ */ function() {
return ld.exports;
}(), fe = {
options: {
virtualHost: !0
}
};
fe.props = EA;
fe.setup = (A, t) => {
const e = A, a = I(!0), n = j.isPC, {
localUserInfoExcludeVolume: l
} = z(MA()), i = I(l == null ? void 0 : l.value.isVideoAvailable), u = p(() => l == null ? void 0 : l.value.isVideoAvailable), s = vt(), [{
deviceList: r
}] = mt(oA.CAMERA), M = p(() => {
var C;
return ((C = r.value) == null ? void 0 : C.length) > 0 && s.value === "camera";
}), D = p(() => a.value ? u.value ? "basicConfig" : "closedConfig" : "loadingConfig"), g = p(() => l != null && l.value.isVideoAvailable ? v("camera enabled") : v("camera disabled")), N = uA("camera", D);
return {
DeviceType: oA,
props: e,
clickAble: a,
isPC: n,
isShowPopover: M,
btnText: g,
config: N,
handleClick: async () => {
a.value = !1, i.value = !u.value, u.value ? await O.closeCamera() : await O.openCamera("localVideo"), a.value = !0;
},
handleMouseEnter: () => {
s.value = "camera";
}
};
};
fe.components = Object.assign({
Popover: Da,
DeviceSelect: Ta,
Button: pA,
TKText: lA
}, fe.components);
var sd = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
staticClass: "btn-content"
}, [A.isPC ? e("Popover", {
attrs: {
color: "rgba(107, 117, 138, 0.5)",
show: A.isShowPopover,
trigger: "hover"
},
on: {
hover: A.handleMouseEnter
},
scopedSlots: A._u([{
key: "content",
fn: function() {
return [e("DeviceSelect", {
attrs: {
isShowControlBtn: !0,
deviceType: A.DeviceType.CAMERA
}
})];
},
proxy: !0
}, {
key: "trigger",
fn: function() {
return [e("Button", {
attrs: {
loading: !A.clickAble,
iconSrc: A.config.iconSrc,
color: A.config.color,
iconSize: A.config.iconSize,
width: A.props.width || A.config.width,
height: A.props.height || A.config.height,
loadingWidth: A.config.loadingWidth,
loadingHeight: A.config.loadingHeight,
shape: A.config.shape
},
on: {
click: A.handleClick
}
})];
},
proxy: !0
}], null, !1, 2755011860)
}) : A._e(), A.isPC ? A._e() : e("Button", {
attrs: {
loading: !A.clickAble,
iconSrc: A.config.iconSrc,
color: A.config.color,
iconSize: A.props.iconSize || A.config.iconSize,
width: A.props.width || A.config.width,
height: A.props.height || A.config.height,
loadingWidth: A.config.loadingWidth,
loadingHeight: A.config.loadingHeight,
shape: "circle"
},
on: {
click: A.handleClick
}
}), A.config.showText ? e("TKText", {
attrs: {
textStyle: A.config.textStyle,
color: A.config.textColor,
size: A.config.textSize
}
}, [A._v(" " + A._s(A.btnText) + " ")]) : A._e()], 1);
}, ud = [];
const wn = {};
var cd = /* @__PURE__ */ S(
fe,
sd,
ud,
!1,
rd,
"d26f6462",
null,
null
);
function rd(A) {
for (let t in wn)
this[t] = wn[t];
}
const Md = /* @__PURE__ */ function() {
return cd.exports;
}(), Le = {
options: {
virtualHost: !0
}
};
Le.props = EA;
Le.setup = (A, t) => {
const e = A, a = Bi(), n = p(() => a.value ? "basicConfig" : "loadingConfig"), l = uA("hangup", n);
return {
t: v,
props: e,
isClickable: a,
config: l,
handleClick: async () => {
await O.hangup();
}
};
};
Le.components = Object.assign({
Button: pA,
TKText: lA
}, Le.components);
var dd = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
staticClass: "btn-content"
}, [e("Button", {
attrs: {
loading: !A.isClickable,
loadingWidth: A.config.loadingWidth,
loadingHeight: A.config.loadingHeight,
iconSrc: A.config.iconSrc,
color: A.config.color,
iconSize: A.props.iconSize || A.config.iconSize,
width: A.props.width || A.config.width,
height: A.props.height || A.config.height,
shape: A.config.shape
},
on: {
click: A.handleClick
}
}), A.config.showText ? e("TKText", {
attrs: {
textStyle: A.config.textStyle,
color: A.config.textColor,
size: A.config.textSize
}
}, [A._v(" " + A._s(A.t("hangup")) + " ")]) : A._e()], 1);
}, Id = [];
const On = {};
var gd = /* @__PURE__ */ S(
Le,
dd,
Id,
!1,
Nd,
"954e61cc",
null,
null
);
function Nd(A) {
for (let t in On)
this[t] = On[t];
}
const pd = /* @__PURE__ */ function() {
return gd.exports;
}(), Ue = {
options: {
virtualHost: !0
}
};
Ue.props = EA;
Ue.setup = (A, t) => {
const e = I(!0), a = A, n = p(() => e.value ? "basicConfig" : "loadingConfig"), l = uA("accept", n);
return {
t: v,
clickAble: e,
props: a,
config: l,
handleClick: async () => {
e.value = !1, await O.accept(), e.value = !0;
}
};
};
Ue.components = Object.assign({
Button: pA,
TKText: lA
}, Ue.components);
var Dd = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
staticClass: "btn-content"
}, [e("Button", {
attrs: {
iconSrc: A.config.iconSrc,
color: A.config.color,
iconSize: A.props.iconSize || A.config.iconSize,
width: A.props.width || A.config.width,
height: A.props.height || A.config.height,
shape: A.config.shape,
loading: !A.clickAble,
loadingWidth: A.config.loadingWidth,
loadingHeight: A.config.loadingHeight
},
on: {
click: A.handleClick
}
}), A.config.showText ? e("TKText", {
attrs: {
textStyle: A.config.textStyle,
color: A.config.textColor,
size: A.config.textSize
}
}, [A._v(" " + A._s(A.t("accept")) + " ")]) : A._e()], 1);
}, Td = [];
const xn = {};
var Cd = /* @__PURE__ */ S(
Ue,
Dd,
Td,
!1,
yd,
"1ec25bac",
null,
null
);
function yd(A) {
for (let t in xn)
this[t] = xn[t];
}
const Sd = /* @__PURE__ */ function() {
return Cd.exports;
}(), ze = {
options: {
virtualHost: !0
}
};
ze.props = EA;
ze.setup = (A, t) => {
const e = j.isPC, a = I(!0), {
localUserInfoExcludeVolume: n
} = z(MA()), l = vt(), [{
deviceList: i
}] = mt(oA.MICROPHONE), u = p(() => {
var N;
return ((N = i.value) == null ? void 0 : N.length) > 0 && l.value === "microphone";
}), s = p(() => a.value ? n != null && n.value.isAudioAvailable ? "basicConfig" : "closedConfig" : "loadingConfig"), r = uA("microphone", s), M = p(() => n != null && n.value.isAudioAvailable ? v("microphone enabled") : v("microphone disabled"));
return {
DeviceType: oA,
isPC: e,
clickAble: a,
isShowPopover: u,
config: r,
btnText: M,
handleClick: async () => {
n != null && n.value.isAudioAvailable ? await O.closeMicrophone() : await O.openMicrophone();
},
handleMouseEnter: () => {
l.value = "microphone";
}
};
};
ze.components = Object.assign({
Popover: Da,
DeviceSelect: Ta,
Button: pA,
TKText: lA
}, ze.components);
var Ed = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
staticClass: "btn-content"
}, [A.isPC ? e("Popover", {
attrs: {
color: "rgba(107, 117, 138, 0.5)",
show: A.isShowPopover,
trigger: "hover"
},
on: {
hover: A.handleMouseEnter
},
scopedSlots: A._u([{
key: "content",
fn: function() {
return [e("DeviceSelect", {
attrs: {
isShowControlBtn: !0,
deviceType: A.DeviceType.MICROPHONE
}
})];
},
proxy: !0
}, {
key: "trigger",
fn: function() {
return [e("Button", {
attrs: {
loading: !A.clickAble,
iconSrc: A.config.iconSrc,
color: A.config.color,
iconSize: A.config.iconSize,
width: A.config.width,
height: A.config.height,
loadingWidth: A.config.loadingWidth,
loadingHeight: A.config.loadingHeight,
shape: A.config.shape
},
on: {
click: A.handleClick
}
})];
},
proxy: !0
}], null, !1, 922566162)
}) : A._e(), A.isPC ? A._e() : e("Button", {
attrs: {
loading: !A.clickAble,
iconSrc: A.config.iconSrc,
color: A.config.color,
iconSize: A.config.iconSize,
width: A.config.width,
height: A.config.height,
loadingWidth: A.config.loadingWidth,
loadingHeight: A.config.loadingHeight,
shape: A.config.shape
},
on: {
click: A.handleClick
}
}), A.config.showText ? e("TKText", {
attrs: {
textStyle: A.config.textStyle,
color: A.config.textColor,
size: A.config.textSize
}
}, [A._v(" " + A._s(A.btnText) + " ")]) : A._e()], 1);
}, hd = [];
const Vn = {};
var md = /* @__PURE__ */ S(
ze,
Ed,
hd,
!1,
jd,
"b3b557d8",
null,
null
);
function jd(A) {
for (let t in Vn)
this[t] = Vn[t];
}
const vd = /* @__PURE__ */ function() {
return md.exports;
}(), we = {
options: {
virtualHost: !0
}
};
we.props = EA;
we.setup = (A, t) => {
const e = A, a = uA("reject", I("basicConfig"));
return {
t: v,
props: e,
config: a,
handleClick: async () => {
await O.reject();
}
};
};
we.components = Object.assign({
Button: pA,
TKText: lA
}, we.components);
var fd = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
staticClass: "btn-content"
}, [e("Button", {
attrs: {
iconSrc: A.config.iconSrc,
color: A.config.color,
iconSize: A.config.iconSize,
width: A.props.width || A.config.width,
height: A.props.height || A.config.height,
shape: A.config.shape
},
on: {
click: A.handleClick
}
}), A.config.showText ? e("TKText", {
attrs: {
textStyle: A.config.textStyle,
color: A.config.textColor,
size: A.config.textSize
}
}, [A._v(" " + A._s(A.t("reject")) + " ")]) : A._e()], 1);
}, Ld = [];
const bn = {};
var Ud = /* @__PURE__ */ S(
we,
fd,
Ld,
!1,
zd,
"f6fe7678",
null,
null
);
function zd(A) {
for (let t in bn)
this[t] = bn[t];
}
const wd = /* @__PURE__ */ function() {
return Ud.exports;
}(), Oe = {
options: {
virtualHost: !0
}
};
Oe.props = EA;
Oe.setup = (A, t) => {
const e = j.isWeChat, a = j.isPC, n = A, {
isEarPhone: l,
isMuteSpeaker: i
} = z(q()), u = vt(), s = p(() => l.value ? "closedConfig" : "basicConfig"), r = p(() => i.value ? "closedConfig" : "basicConfig"), [{
deviceList: M,
currentDeviceId: D
}] = mt(oA.SPEAKER), g = p(() => {
var E;
return ((E = M.value) == null ? void 0 : E.length) > 0 && u.value === "speaker" && a;
}), N = e ? uA("speaker", s) : uA("speaker", r);
return p(() => l.value ? v("speaker disabled") : v("speaker enabled")), {
DeviceType: oA,
props: n,
isShowPopover: g,
config: N,
handleClick: async () => {
i.value ? await O.unMuteSpeaker() : await O.muteSpeaker();
},
getButtonText: () => {
if (a) {
const E = M.value.find((w) => w.deviceId === D.value);
return E ? E.label : v("speaker enabled");
} else
return i.value ? v("speaker disabled") : v("speaker enabled");
},
handleMouseEnter: () => {
u.value = "speaker";
}
};
};
Oe.components = Object.assign({
Popover: Da,
DeviceSelect: Ta,
Button: pA,
TKText: lA
}, Oe.components);
var Od = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
staticClass: "btn-content"
}, [e("Popover", {
attrs: {
color: "rgba(107, 117, 138, 0.5)",
show: A.isShowPopover,
trigger: "hover"
},
on: {
hover: A.handleMouseEnter
},
scopedSlots: A._u([{
key: "content",
fn: function() {
return [e("DeviceSelect", {
attrs: {
isShowControlBtn: !0,
deviceType: A.DeviceType.SPEAKER
}
})];
},
proxy: !0
}, {
key: "trigger",
fn: function() {
return [e("Button", {
attrs: {
iconSrc: A.config.iconSrc,
color: A.config.color,
iconSize: A.props.iconSize || A.config.iconSize,
width: A.props.width || A.config.width,
height: A.props.height || A.config.height,
shape: A.config.shape
},
on: {
click: A.handleClick
}
})];
},
proxy: !0
}])
}), A.config.showText ? e("TKText", {
attrs: {
width: "60px",
truncated: !0,
textStyle: A.config.textStyle,
color: A.config.textColor,
size: A.config.textSize,
lineClamp: 2
}
}, [A._v(" " + A._s(A.getButtonText()) + " ")]) : A._e()], 1);
}, xd = [];
const Bn = {};
var Vd = /* @__PURE__ */ S(
Oe,
Od,
xd,
!1,
bd,
"1553de06",
null,
null
);
function bd(A) {
for (let t in Bn)
this[t] = Bn[t];
}
const Bd = /* @__PURE__ */ function() {
return Vd.exports;
}(), It = {
options: {
virtualHost: !0
}
};
It.setup = (A, t) => {
const {
localUserInfoExcludeVolume: e
} = z(MA()), a = p(() => e == null ? void 0 : e.value.isVideoAvailable), n = p(() => a.value ? "basicConfig" : "disableConfig"), l = uA("switchCamera", n);
return {
t: v,
config: l,
handleClick: async () => {
!a.value || await O.switchCamera();
}
};
};
It.components = Object.assign({
Button: pA,
TKText: lA
}, It.components);
var Fd = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
staticClass: "btn-content"
}, [e("Button", {
attrs: {
iconSrc: A.config.iconSrc,
iconSize: A.config.iconSize,
color: A.config.color,
width: A.config.width,
height: A.config.height,
buttonStyle: A.config.buttonStyle,
shape: "circle"
},
on: {
click: A.handleClick
}
}), A.config.showText ? e("TKText", {
attrs: {
textStyle: A.config.textStyle,
color: A.config.textColor,
size: A.config.textSize
}
}, [A._v(" " + A._s(A.t("switch camera")) + " ")]) : A._e()], 1);
}, Rd = [];
const Fn = {};
var kd = /* @__PURE__ */ S(
It,
Fd,
Rd,
!1,
Pd,
"b9be9094",
null,
null
);
function Pd(A) {
for (let t in Fn)
this[t] = Fn[t];
}
const Wd = /* @__PURE__ */ function() {
return kd.exports;
}(), xe = {
options: {
virtualHost: !0
}
};
xe.props = EA;
xe.setup = (A, t) => {
const e = A, a = I(!0), {
localUserInfoExcludeVolume: n
} = z(MA()), l = p(() => n == null ? void 0 : n.value.isVideoAvailable), {
enableVirtualBackground: i
} = z(q()), u = p(() => a.value ? i.value ? "closedConfig" : l.value ? "basicConfig" : "disableConfig" : "loadingConfig"), s = uA("virtualBackground", u);
return {
t: v,
props: e,
clickAble: a,
config: s,
handleClick: async () => {
!l.value || (a.value = !1, await O.setBlurBackground(!i.value), a.value = !0);
}
};
};
xe.components = Object.assign({
Button: pA,
TKText: lA
}, xe.components);
var Gd = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
staticClass: "btn-content"
}, [e("Button", {
attrs: {
loading: !A.clickAble,
iconSrc: A.config.iconSrc,
color: A.config.color,
iconSize: A.props.iconSize || A.config.iconSize,
width: A.props.width || A.config.width,
height: A.props.height || A.config.height,
shape: A.config.shape,
loadingWidth: A.config.loadingWidth,
loadingHeight: A.config.loadingHeight,
buttonStyle: A.config.buttonStyle
},
on: {
click: A.handleClick
}
}), A.config.showText ? e("TKText", {
attrs: {
width: "70px",
lineClamp: 2,
textStyle: A.config.textStyle,
color: A.config.textColor,
size: A.config.textSize
}
}, [A._v(" " + A._s(A.t("virtual-background")) + " ")]) : A._e()], 1);
}, Qd = [];
const Rn = {};
var Zd = /* @__PURE__ */ S(
xe,
Gd,
Qd,
!1,
Yd,
"6288f616",
null,
null
);
function Yd(A) {
for (let t in Rn)
this[t] = Rn[t];
}
const Xd = /* @__PURE__ */ function() {
return Zd.exports;
}(), Ve = {
options: {
virtualHost: !0
}
};
Ve.props = EA;
Ve.setup = (A, t) => {
const {
status: e
} = We(), a = A, n = uA("toggleButtonPanel", I("basicConfig"));
return {
props: a,
config: n,
handleClick: async () => {
e.value = e.value === "close" ? "open" : "close";
}
};
};
Ve.components = Object.assign({
Button: pA
}, Ve.components);
var _d = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
staticClass: "btn-content"
}, [e("Button", {
attrs: {
iconSrc: A.config.iconSrc,
color: A.config.color,
iconSize: A.props.iconSize || A.config.iconSize,
width: A.props.width || A.config.width,
height: A.props.height || A.config.height,
shape: A.config.shape
},
on: {
click: A.handleClick
}
})], 1);
}, qd = [];
const kn = {};
var Jd = /* @__PURE__ */ S(
Ve,
_d,
qd,
!1,
Hd,
"dd0c1858",
null,
null
);
function Hd(A) {
for (let t in kn)
this[t] = kn[t];
}
const Kd = /* @__PURE__ */ function() {
return Jd.exports;
}(), gt = {
options: {
virtualHost: !0
}
};
gt.setup = (A, t) => {
const e = I(null), a = I({}), {
isGroupCall: n
} = z(q()), {
status: l
} = We() || {}, i = I(!1), u = I(!1), s = I(""), r = wo();
QA(() => {
i.value || (n.value && !j.isPC && r.value !== null ? i.value = !0 : i.value = !1);
});
const M = p(() => X(["button-panel-container", {
pc: j.isPC,
mobile: !j.isPC,
h5: j.isH5,
groupCall: n.value,
singleCall: !n.value,
close: (l == null ? void 0 : l.value) === "close",
open: (l == null ? void 0 : l.value) === "open",
showBackGround: i.value
}])), D = X(["toggle-button-container", {
h5: j.isH5
}]), g = j.isH5 ? {
transitionProperty: "width,height,left,top",
transitionDuration: "0.3s",
transitionTimingFunction: "ease-in"
} : {};
function N(w) {
e.value = w;
}
const {
layout: y,
config: T
} = bM();
J(T, () => {
const w = {}, L = T.value.flat();
for (let m of L) {
const {
name: k,
props: _ = {}
} = m;
_.showText !== !1 && (_.showText = !0), w[k] = _;
}
a.value = w;
}, {
immediate: !0
});
function C(w) {
u.value = w;
}
const E = {
[o.IS_CLICKABLE]: C
};
return aA(() => {
d.watch(c.CALL, E, {
notifyRangeWhenWatch: o.MYSELF
});
}), tA(() => {
d.unwatch(c.CALL, E);
}), gA(mo, u), gA(jo, s), {
focus: e,
showButtonPanelBackground: i,
buttonPanelClassName: M,
toggleButtonContainerClassName: D,
customStyle: g,
handleToggle: N,
layout: y
};
};
gt.components = Object.assign({
Grid: dl,
GridItem: Il,
Accept: Sd,
Reject: wd,
Microphone: vd,
Hangup: pd,
Speaker: Bd,
TKCamera: Md,
VirtualBackground: Xd,
SwitchCamera: Wd,
InviteUser: Yo,
ToggleButtonPanel: Kd
}, gt.components);
var $d = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
class: A.buttonPanelClassName
}, [e("div", {
staticClass: "button-group"
}, [e("Grid", {
attrs: {
unit: "%",
layout: A.layout,
focus: A.focus
},
on: {
toggle: A.handleToggle
}
}, [e("GridItem", {
attrs: {
index: "accept",
height: "auto",
customStyle: A.customStyle
}
}, [e("Accept")], 1), e("GridItem", {
attrs: {
index: "reject",
height: "auto",
customStyle: A.customStyle
}
}, [e("Reject")], 1), e("GridItem", {
attrs: {
index: "microphone",
height: "auto",
customStyle: A.customStyle
}
}, [e("Microphone")], 1), e("GridItem", {
attrs: {
index: "hangup",
height: "auto",
customStyle: A.customStyle
}
}, [e("Hangup")], 1), e("GridItem", {
attrs: {
index: "speaker",
height: "auto",
customStyle: A.customStyle
}
}, [e("Speaker")], 1), e("GridItem", {
attrs: {
index: "camera",
height: "auto",
customStyle: A.customStyle
}
}, [e("TKCamera")], 1), e("GridItem", {
attrs: {
index: "virtualBackground",
height: "auto",
customStyle: A.customStyle
}
}, [e("VirtualBackground")], 1), e("GridItem", {
attrs: {
index: "switchCamera",
height: "auto",
customStyle: A.customStyle
}
}, [e("SwitchCamera")], 1), e("GridItem", {
attrs: {
index: "inviteUser",
height: "auto",
customStyle: A.customStyle
}
}, [e("InviteUser")], 1)], 1)], 1), A.showButtonPanelBackground ? e("div", {
class: A.toggleButtonContainerClassName
}, [e("ToggleButtonPanel")], 1) : A._e()]);
}, AI = [];
const Pn = {};
var eI = /* @__PURE__ */ S(
gt,
$d,
AI,
!1,
tI,
"26c8cb08",
null,
null
);
function tI(A) {
for (let t in Pn)
this[t] = Pn[t];
}
const Nl = /* @__PURE__ */ function() {
return eI.exports;
}(), Nt = {};
Nt.setup = (A, t) => {
const {
callStatus: e
} = z(q());
return {
CallStatus: U,
callStatus: e
};
};
Nt.components = Object.assign({
TopBar: Xo,
Waiting: Ko,
MediaContainer: uM,
Tip: rl,
ButtonPanel: Nl
}, Nt.components);
var aI = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
staticClass: "singlecall-container"
}, [e("TopBar"), A.callStatus === A.CallStatus.CALLING ? e("Waiting") : A._e(), e("MediaContainer"), e("Tip"), e("ButtonPanel")], 1);
}, nI = [];
const Wn = {};
var oI = /* @__PURE__ */ S(
Nt,
aI,
nI,
!1,
lI,
"221760b8",
null,
null
);
function lI(A) {
for (let t in Wn)
this[t] = Wn[t];
}
const iI = /* @__PURE__ */ function() {
return oI.exports;
}(), pt = {};
pt.setup = (A, t) => ({});
pt.components = Object.assign({
Loading: na
}, pt.components);
var sI = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
staticClass: "stream-loading-container"
}, [e("Loading", {
attrs: {
mode: "dot",
color: "#FFF",
loadingWidth: "50px",
loadingHeight: "50px"
}
})], 1);
}, uI = [];
const Gn = {};
var cI = /* @__PURE__ */ S(
pt,
sI,
uI,
!1,
rI,
"b3ff0e0c",
null,
null
);
function rI(A) {
for (let t in Gn)
this[t] = Gn[t];
}
const MI = /* @__PURE__ */ function() {
return cI.exports;
}(), Dt = {
options: {
virtualHost: !0
}
};
Dt.setup = (A, t) => {
const e = I("local"), a = I(null), n = I(!1);
Ge();
const {
localUserInfoExcludeVolume: l,
remoteUserListExcludeVolume: i
} = z(MA()), {
callStatus: u,
callType: s,
isShowEnableVirtualBackground: r,
callRole: M
} = z(q()), {
netWorkQualityList: D
} = bi(), g = p(() => i.value.length + 1), N = zo(), y = Ri(a, g), T = Uo(), {
isFloatWindow: C
} = z(CA()), E = wo(), {
status: w
} = We() || {}, L = !j.isPC, m = p(() => String(a.value) === "0"), k = p(() => !j.isPC && m.value && l.value.isVideoAvailable), _ = p(() => k.value), Z = p(() => k.value && r.value && j.isWeChat), b = p(() => j.isPC || m.value), P = p(() => j.isPC || C.value ? "%" : "vw"), AA = p(() => [l.value, ...i.value].map((Y) => {
var iA;
if (C.value) {
if (((iA = T.value) == null ? void 0 : iA[Y.domId]) >= 10)
return Y.domId;
} else
return Y.domId;
})), ZA = p(() => !(M.value === K.CALLEE && u.value === U.CALLING && !C.value)), xA = p(() => {
let Y = "";
return M.value === K.CALLEE && u.value === U.CALLING && !C.value && (Y = "hidden"), {
visibility: Y
};
});
function VA(Y) {
a.value = Y, E.value = Y, w.value = Y !== null ? "close" : "open";
}
function bA(Y) {
var iA, dA;
return j.isWeChat ? !((dA = (iA = N.value) == null ? void 0 : iA.find((BA) => BA.userID === Y.userId)) != null && dA.hasVideo) : !Y.isVideoAvailable;
}
function YA(Y) {
var iA, dA;
return j.isWeChat ? !((dA = (iA = N.value) == null ? void 0 : iA.find((BA) => BA.userID === Y.userId)) != null && dA.hasAudio) : !Y.isAudioAvailable;
}
function Ut(Y) {
if (!D.value)
return;
const iA = Y !== l.value.userId;
if (!j.isWeChat && iA)
return;
const dA = D.value.find((BA) => BA.userId === Y);
return dA && (dA == null ? void 0 : dA.quality) >= 4;
}
J([i, s], () => {
var Y, iA;
(iA = (Y = i.value) == null ? void 0 : Y[0]) != null && iA.isEnter && (e.value = "remote"), s.value === F.AUDIO ? n.value = !1 : n.value = !0;
});
const Qe = p(() => X(["groupcall-media-container", {
mobile: !j.isPC,
pc: j.isPC,
"two-layout": g.value === 2 && a.value === null,
float: C.value
}])), Ze = p(() => u.value === U.CALLING && (s.value === F.AUDIO && !l.value.isAudioAvailable || s.value === F.VIDEO && !l.value.isVideoAvailable));
return {
TUIGlobal: j,
focus: a,
localUserInfoExcludeVolume: l,
remoteUserListExcludeVolume: i,
streamLength: g,
layout: y,
volumeMap: T,
isFloatWindow: C,
enableFocus: L,
showSwitchCameraButton: _,
showVirtualBackgroundButton: Z,
showNickName: b,
unit: P,
visibleStreamIdList: AA,
showStream: ZA,
mediaContainerStyle: xA,
changeFocus: VA,
isShowAudioStream: bA,
isMute: YA,
isShowNetWork: Ut,
groupMediaContainerClassName: Qe,
isPusherLoading: Ze
};
};
Dt.components = Object.assign({
Portal: el,
FloatWindow: ul,
Grid: dl,
GridItem: Il,
Pusher: nl,
AudioStream: ll,
StreamLoading: MI,
TKStreamInfo: al,
Player: ol
}, Dt.components);
var dI = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("Portal", {
attrs: {
id: "source",
disabled: !A.isFloatWindow,
source: "#source",
to: "body"
}
}, [e("FloatWindow", [e("div", {
class: A.groupMediaContainerClassName,
style: [A.mediaContainerStyle]
}, [e("Grid", {
attrs: {
unit: A.unit,
"enable-focus": A.enableFocus,
focus: A.focus,
length: A.streamLength,
layout: A.layout
},
on: {
toggle: A.changeFocus
}
}, [e("GridItem", {
key: A.localUserInfoExcludeVolume.userId,
attrs: {
index: 0
}
}, [e("Pusher", {
attrs: {
domId: A.localUserInfoExcludeVolume.domId,
"show-audio-stream": !A.localUserInfoExcludeVolume.isVideoAvailable,
show: A.visibleStreamIdList.includes(A.localUserInfoExcludeVolume.domId) && A.showStream
},
scopedSlots: A._u([{
key: "audio-stream",
fn: function() {
return [e("AudioStream", {
attrs: {
"user-id": A.localUserInfoExcludeVolume.userId,
username: A.localUserInfoExcludeVolume.displayUserInfo,
avatar: A.localUserInfoExcludeVolume.avatar,
"is-video-available": A.localUserInfoExcludeVolume.isVideoAvailable
}
})];
},
proxy: !0
}, {
key: "loading",
fn: function() {
return [A.isPusherLoading ? e("StreamLoading") : A._e()];
},
proxy: !0
}, {
key: "stream-info",
fn: function() {
return [A.isFloatWindow ? A._e() : e("TKStreamInfo", {
attrs: {
"is-self": !0,
"show-nick-name": A.showNickName,
showSwitchCameraButton: A.showSwitchCameraButton,
showVirtualBackgroundButton: A.showVirtualBackgroundButton,
showNetWorkStatus: A.isShowNetWork(A.localUserInfoExcludeVolume.userId),
nickName: A.localUserInfoExcludeVolume.displayUserInfo,
isMuted: !A.localUserInfoExcludeVolume.isAudioAvailable,
volume: A.volumeMap && A.volumeMap[A.localUserInfoExcludeVolume.domId]
}
})];
},
proxy: !0
}])
})], 1), A._l(A.remoteUserListExcludeVolume, function(a, n) {
return e("GridItem", {
key: a.userId,
attrs: {
index: n + 1
}
}, [e("Player", {
attrs: {
domId: a.domId,
"show-audio-stream": A.isShowAudioStream(a),
show: A.visibleStreamIdList.includes(a.domId) && A.showStream
},
scopedSlots: A._u([{
key: "audio-stream",
fn: function() {
return [e("AudioStream", {
attrs: {
"user-id": a.userId,
username: a.displayUserInfo,
avatar: a.avatar
}
})];
},
proxy: !0
}, {
key: "loading",
fn: function() {
return [a.isEnter ? A._e() : e("StreamLoading")];
},
proxy: !0
}, {
key: "stream-info",
fn: function() {
return [A.isFloatWindow ? A._e() : e("TKStreamInfo", {
attrs: {
"show-nick-name": A.TUIGlobal.isPC || String(A.focus) === String(n + 1),
"show-control-button": !1,
showNetWorkStatus: A.isShowNetWork(a.userId),
nickName: a.displayUserInfo,
"is-muted": A.isMute(a),
volume: A.volumeMap && A.volumeMap[a.domId]
}
})];
},
proxy: !0
}], null, !0)
})], 1);
})], 2)], 1)])], 1);
}, II = [];
const Qn = {};
var gI = /* @__PURE__ */ S(
Dt,
dI,
II,
!1,
NI,
"4c7859ad",
null,
null
);
function NI(A) {
for (let t in Qn)
this[t] = Qn[t];
}
const pI = /* @__PURE__ */ function() {
return gI.exports;
}(), Ca = {};
Ca.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
}
};
Ca.setup = (A, t) => {
const e = {
OUTSIDE: "outside",
INSIDE: "inside"
}, a = A, n = I(!0), l = I(!0), i = I(!0), u = I("");
QA(() => {
u.value = a.title, n.value = a.isHeaderShow, l.value = a.isFooterShow, i.value = a.background;
});
const s = t.emit, r = (g) => {
g === e.OUTSIDE && M();
}, M = () => {
s("update:moduleValue", !1);
};
return {
t: v,
clickType: e,
props: a,
isHeaderShowDialog: n,
isFooterShowDialog: l,
backgroundDialog: i,
showTitle: u,
toggleView: r,
close: M,
submit: () => {
s("submit"), M();
}
};
};
var DI = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return A.moduleValue ? e("div", {
staticClass: "dialog",
class: [A.props.isH5 ? "dialog-h5" : "", A.center ? "center" : ""],
on: {
click: function(a) {
return a.stopPropagation(), a.preventDefault(), A.toggleView(A.clickType.OUTSIDE);
}
}
}, [e("main", {
staticClass: "dialog-main",
class: [A.backgroundDialog ? "" : "dialog-main-back"],
on: {
click: function(a) {
return a.stopPropagation(), a.preventDefault(), A.toggleView(A.clickType.INSIDE);
}
}
}, [A.isHeaderShowDialog ? e("header", {
staticClass: "dialog-main-header"
}, [e("h1", {
staticClass: "dialog-main-title"
}, [A._v(A._s(A.showTitle))]), e("i", {
staticClass: "icon icon-close",
on: {
click: A.close
}
})]) : A._e(), e("div", {
staticClass: "dialog-main-content",
class: [A.props.isH5 ? "dialog-main-content-uniapp" : ""]
}, [A._t("default")], 2), A.isFooterShowDialog ? e("footer", {
staticClass: "dialog-main-footer"
}, [e("button", {
staticClass: "btn btn-cancel",
on: {
click: A.close
}
}, [A._v(A._s(A.t("Cancel")))]), e("button", {
staticClass: "btn btn-default",
on: {
click: A.submit
}
}, [A._v(A._s(A.t("Done")))])]) : A._e()])]) : A._e();
}, TI = [];
const Zn = {};
var CI = /* @__PURE__ */ S(
Ca,
DI,
TI,
!1,
yI,
"5c01d70e",
null,
null
);
function yI(A) {
for (let t in Zn)
this[t] = Zn[t];
}
const SI = /* @__PURE__ */ function() {
return CI.exports;
}(), ya = {};
ya.props = {
file: {
type: String,
default: ""
},
width: {
type: String,
default: "20px"
},
height: {
type: String,
default: "20px"
},
isApp: {
type: Boolean,
default: !1
}
};
ya.setup = (A, t) => {
const e = t.emit;
return {
props: A,
handlerImgClick: () => {
e("click");
}
};
};
var EI = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
staticClass: "icon",
on: {
click: A.handlerImgClick
}
}, [A.props.isApp ? e("image", {
staticClass: "icon",
style: {
width: A.props.width,
height: A.props.height
},
attrs: {
src: A.props.file
}
}) : e("img", {
staticClass: "icon",
style: {
width: A.props.width,
height: A.props.height
},
attrs: {
src: A.props.file
}
})]);
}, hI = [];
const Yn = {};
var mI = /* @__PURE__ */ S(
ya,
EI,
hI,
!1,
jI,
"c4142a3c",
null,
null
);
function jI(A) {
for (let t in Yn)
this[t] = Yn[t];
}
const vI = /* @__PURE__ */ function() {
return mI.exports;
}(), fI = "", LI = "
be.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
}
};
be.setup = (A, t) => {
const e = A, a = t.emit, n = I(""), l = I([]), i = I(0), u = I([]), s = I(!0), r = I(!1), M = I(""), D = I("");
QA(() => {
const {
list: L,
isCustomItem: m,
isSearch: k,
title: _,
total: Z,
selectedList: b
} = e;
if (m)
for (let P = 0; P < L.length; P++)
L[P].conversationID.indexOf("@TIM#SYSTEM") > -1 && L.splice(P, 1), l.value = L;
else
l.value = L;
i.value = Z || L.length, u.value = b && b.length > 0 ? b : u.value, s.value = k, r.value = m, M.value = _, n.value = e.type;
});
const g = p(() => l.value.filter((L) => !L.isDisabled));
return {
t: v,
selectedIcon: fI,
backIcon: LI,
cancelIcon: UI,
props: e,
transferList: l,
transferTotal: i,
transferSelectedList: u,
isTransferSearch: s,
isTransferCustomItem: r,
transferTitle: M,
searchValue: D,
optional: g,
handleInput: (L) => {
D.value = L.target.value, a("search", L.target.value);
},
selected: (L) => {
if (L.isDisabled)
return;
let m = u.value;
const k = m.indexOf(L);
if (k > -1)
return u.value.splice(k, 1);
e.isRadio && (m = []), m.push(L), u.value = m;
},
selectedAll: () => {
u.value.length === g.value.length ? u.value = [] : u.value = [...g.value];
},
submit: () => {
a("submit", u.value), D.value = "";
},
cancel: () => {
a("cancel"), D.value = "";
},
getMore: () => {
a("getMore");
}
};
};
be.components = Object.assign({
TIcon: vI
}, be.components);
var zI = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
staticClass: "transfer",
class: [A.props.isH5 ? "transfer-h5" : ""]
}, [A.props.isH5 ? e("header", {
staticClass: "transfer-header transfer-h5-header",
on: {
click: A.cancel
}
}, [e("TIcon", {
staticClass: "icon",
attrs: {
file: A.backIcon,
width: "18px",
height: "18px"
}
}), e("span", {
staticClass: "title"
}, [A._v(A._s(A.transferTitle))]), e("span", {
staticClass: "space"
})], 1) : A._e(), e("main", {
staticClass: "main"
}, [e("div", {
staticClass: "left"
}, [e("header", {
staticClass: "transfer-header"
}, [!A.props.isH5 && A.isTransferSearch ? e("input", {
class: [A.props.isH5 ? "left-uniapp-input" : ""],
attrs: {
type: "text",
placeholder: A.t("Please enter userID"),
enterkeyhint: "search"
},
domProps: {
value: A.searchValue
},
on: {
keyup: function(a) {
return !a.type.indexOf("key") && A._k(a.keyCode, "enter", 13, a.key, "Enter") ? null : A.handleInput.apply(null, arguments);
}
}
}) : A._e(), A.props.isH5 && A.isTransferSearch ? e("input", {
class: [A.props.isH5 ? "left-uniapp-input" : ""],
attrs: {
type: "text",
placeholder: A.t("Please enter userID"),
enterkeyhint: "search"
},
domProps: {
value: A.searchValue
},
on: {
blur: A.handleInput,
confirm: A.handleInput
}
}) : A._e()]), e("main", {
staticClass: "transfer-left-main"
}, [e("ul", {
staticClass: "transfer-list"
}, [A.optional.length > 1 && !A.isRadio ? e("li", {
staticClass: "transfer-list-item",
on: {
click: A.selectedAll
}
}, [A.transferSelectedList.length === A.optional.length ? e("TIcon", {
attrs: {
file: A.selectedIcon,
width: "18px",
height: "18px"
}
}) : e("i", {
staticClass: "icon-unselected"
}), e("span", {
staticClass: "select-all"
}, [A._v(A._s(A.t("Select all")))])], 1) : A._e(), A._l(A.transferList, function(a) {
return e("li", {
key: a.userID,
staticClass: "transfer-list-item",
on: {
click: function(n) {
return A.selected(a);
}
}
}, [A.transferSelectedList.indexOf(a) > -1 ? e("TIcon", {
class: [a.isDisabled && "disabled"],
attrs: {
file: A.selectedIcon,
width: "18px",
height: "18px"
}
}) : e("i", {
class: [a.isDisabled && "disabled", "icon-unselected"]
}), A.isTransferCustomItem ? [A._t("left", null, {
data: a
})] : [e("img", {
staticClass: "avatar",
attrs: {
src: a.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'"
}
}), e("span", {
staticClass: "name"
}, [A._v(A._s(a.nick || a.userID))]), a.isDisabled ? e("span") : A._e()]], 2);
}), A.transferTotal > A.transferList.length ? e("li", {
staticClass: "transfer-list-item more",
on: {
click: A.getMore
}
}, [A._v(" " + A._s(A.t("View more")) + " ")]) : A._e()], 2)])]), e("div", {
staticClass: "right"
}, [A.props.isH5 ? A._e() : e("header", {
staticClass: "transfer-header"
}, [A._v(" " + A._s(A.transferTitle) + " ")]), A.resultShow ? e("ul", {
staticClass: "transfer-list"
}, [A.transferSelectedList.length > 0 && !A.props.isH5 ? e("p", {
staticClass: "transfer-text"
}, [A._v(" " + A._s(A.transferSelectedList.length) + " " + A._s(A.t("people selected")) + " ")]) : A._e(), A._l(A.transferSelectedList, function(a, n) {
return e("li", {
key: n,
staticClass: "transfer-list-item space-between"
}, [e("aside", {
staticClass: "transfer-list-item-content"
}, [A.isTransferCustomItem ? [A._t("right", null, {
data: a
})] : [e("img", {
staticClass: "avatar",
attrs: {
src: a.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'"
}
}), A.props.isH5 ? A._e() : e("span", {
staticClass: "name"
}, [A._v(A._s(a.nick || a.userID))])]], 2), A.props.isH5 ? A._e() : e("span", {
on: {
click: function(l) {
return A.selected(a);
}
}
}, [e("TIcon", {
attrs: {
file: A.cancelIcon,
width: "18px",
height: "18px"
}
})], 1)]);
})], 2) : A._e(), e("footer", {
staticClass: "transfer-right-footer"
}, [e("button", {
staticClass: "btn btn-cancel",
on: {
click: A.cancel
}
}, [A._v(A._s(A.t("Cancel")))]), A.transferSelectedList.length > 0 ? e("button", {
staticClass: "btn",
on: {
click: A.submit
}
}, [A._v(" " + A._s(A.t("Done")) + " ")]) : e("button", {
staticClass: "btn btn-no",
on: {
click: A.submit
}
}, [A._v(A._s(A.t("Done")))])])])])]);
}, wI = [];
const Xn = {};
var OI = /* @__PURE__ */ S(
be,
zI,
wI,
!1,
xI,
"f41767b6",
null,
null
);
function xI(A) {
for (let t in Xn)
this[t] = Xn[t];
}
const VI = /* @__PURE__ */ function() {
return OI.exports;
}(), Be = {};
Be.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
}
};
Be.setup = (A, t) => {
const e = t.emit, a = A, n = I(!1);
return QA(() => {
n.value = a.isShow;
}), {
props: a,
dialogVisible: n,
reset: () => {
n.value = !n.value, e("complete", []), e("update:isShow", n.value);
},
submit: (r) => {
e("complete", r);
},
handleSearchUser: (r) => {
e("search", r);
},
handleGetMore: () => {
e("getMore");
}
};
};
Be.components = Object.assign({
TDialog: SI,
TTransfer: VI
}, Be.components);
var bI = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("TDialog", {
attrs: {
moduleValue: A.dialogVisible,
isH5: !A.isPC,
isHeaderShow: !1,
isFooterShow: !1,
background: !1
},
on: {
"update:moduleValue": A.reset
}
}, [e("TTransfer", {
attrs: {
isSearch: A.props.isNeedSearch,
title: A.props.title,
list: A.props.userList,
isH5: !A.isPC,
isRadio: A.props.isRadio,
total: A.props.total
},
on: {
getMore: A.handleGetMore,
search: A.handleSearchUser,
submit: A.submit,
cancel: A.reset
}
})], 1);
}, BI = [];
const _n = {};
var FI = /* @__PURE__ */ S(
Be,
bI,
BI,
!1,
RI,
null,
null,
null
);
function RI(A) {
for (let t in _n)
this[t] = _n[t];
}
const kI = /* @__PURE__ */ function() {
return FI.exports;
}(), Tt = {
options: {
virtualHost: !0
}
};
Tt.setup = (A, t) => ({
defaultAvatarSrc: GA
});
Tt.components = Object.assign({
Overlay: _o
}, Tt.components);
var PI = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("Overlay", {
attrs: {
bgColor: "#22262ed9",
bgImage: A.defaultAvatarSrc,
customStyle: {
position: "absolute",
zIndex: 0
}
}
});
}, WI = [];
const qn = {};
var GI = /* @__PURE__ */ S(
Tt,
PI,
WI,
!1,
QI,
null,
null,
null
);
function QI(A) {
for (let t in qn)
this[t] = qn[t];
}
const ZI = /* @__PURE__ */ function() {
return GI.exports;
}(), Ct = {};
Ct.setup = (A, t) => {
const e = I(null), a = I("open"), n = I(!1), l = I(0), i = I([]), u = I([]), s = I(0), r = 30, M = e, D = {
status: a
}, {
callRole: g,
callStatus: N
} = z(q()), {
isFloatWindow: y
} = z(CA()), {
localUserInfoExcludeVolume: T,
remoteUserListExcludeVolume: C
} = z(MA()), E = async (b) => {
if (n.value = b, n.value) {
await m();
const P = await O.getGroupProfile();
l.value = P.memberCount;
}
}, w = () => {
n.value = !1, d.update(c.CALL, o.SHOW_SELECT_USER, !1), s.value = 0, i.value = [];
}, L = async () => {
s.value += r, await m();
}, m = async () => {
const b = await O.getGroupMemberList(r, s.value), P = [...C.value, T.value].map((AA) => AA.userId);
i.value.push(...b), i.value = i.value.map((AA) => (P.includes(AA.userID) && (AA = {
...AA,
isDisabled: !0
}), AA)), u.value = i.value;
}, k = async (b) => {
try {
if (b.length <= 0)
return;
n.value = !1, d.update(c.CALL, o.SHOW_SELECT_USER, !1), s.value = 0;
const P = b.map((AA) => AA.userID);
await O.inviteUser({
userIDList: P
}), i.value = [];
} catch (P) {
console.debug(P);
}
}, _ = (b) => {
b ? i.value = i.value.filter((P) => P.userID.includes(b) || P.nick.includes(b)) : i.value = u.value;
}, Z = {
[o.SHOW_SELECT_USER]: E
};
return aA(() => {
d.watch(c.CALL, Z, {
notifyRangeWhenWatch: o.MYSELF
});
}), tA(() => {
d.unwatch(c.CALL, Z);
}), D.status = I("open"), M.value = null, gA(Eo, D), gA(So, M), {
CallRole: K,
CallStatus: U,
TUIGlobal: j,
showSelectUser: n,
memberCount: l,
groupMemberList: i,
callRole: g,
callStatus: N,
isFloatWindow: y,
handleCancel: w,
getMoreMemberList: L,
handleSelectedResult: k,
handleSearch: _
};
};
Ct.components = Object.assign({
TopBar: Xo,
Waiting: Ko,
MediaContainer: pI,
Tip: rl,
ButtonPanel: Nl,
BackGround: ZI,
SelectUser: kI
}, Ct.components);
var YI = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
staticClass: "groupcall-container"
}, [e("TopBar"), A.callStatus === A.CallStatus.CALLING && A.callRole === A.CallRole.CALLEE && !A.isFloatWindow ? e("Waiting") : A._e(), e("MediaContainer"), e("Tip"), e("ButtonPanel"), e("BackGround"), e("SelectUser", {
attrs: {
isShow: A.showSelectUser,
isNeedSearch: !0,
userList: A.groupMemberList,
isPC: A.TUIGlobal.isPC,
total: A.memberCount
},
on: {
getMore: A.getMoreMemberList,
complete: A.handleSelectedResult,
search: A.handleSearch,
"update:isShow": A.handleCancel
}
})], 1);
}, XI = [];
const Jn = {};
var _I = /* @__PURE__ */ S(
Ct,
YI,
XI,
!1,
qI,
"487ae8a3",
null,
null
);
function qI(A) {
for (let t in Jn)
this[t] = Jn[t];
}
const JI = /* @__PURE__ */ function() {
return _I.exports;
}();
var HI = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("svg", {
attrs: {
viewBox: "0 0 1024 1024",
xmlns: "http://www.w3.org/2000/svg",
"data-v-ea893728": ""
}
}, [e("path", {
attrs: {
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"
}
})]);
}, KI = [];
const $I = {}, Hn = {};
var Ag = /* @__PURE__ */ S(
$I,
HI,
KI,
!1,
eg,
null,
null,
null
);
function eg(A) {
for (let t in Hn)
this[t] = Hn[t];
}
const tg = /* @__PURE__ */ function() {
return Ag.exports;
}(), Kn = "
Fe.props = {
platform: {
key: "platform",
required: !0,
type: null
},
language: {
key: "language",
required: !0,
type: String
}
};
Fe.setup = (A, t) => {
const e = {
mac: {
"zh-cn": Kn,
en: ag
},
win: {
"zh-cn": ng,
en: og
}
}, a = A, n = p(() => a.platform === "mac" ? "mac-privacy" : "win-privacy"), l = p(() => a.platform === "mac" ? "mac-preferences" : "win-preferences"), i = I(Kn), u = I(!0), s = (M) => {
M && j.isPC && (u.value = !0);
}, r = () => {
u.value = !1;
};
return J(() => a.language, () => {
i.value = e[a.platform][a.language];
}, {
immediate: !0
}), aA(() => {
d.watch(c.CALL, {
[o.SHOW_PERMISSION_TIP]: s
}, {
notifyRangeWhenWatch: o.MYSELF
});
}), tA(() => {
d.unwatch(c.CALL, {
[o.SHOW_PERMISSION_TIP]: s
});
}), {
t: v,
privacy: n,
preferences: l,
permitPng: i,
showModal: u,
handleClose: r
};
};
Fe.components = Object.assign({
CloseIcon: tg
}, Fe.components);
var lg = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return A.showModal ? e("div", {
staticClass: "card"
}, [e("div", {
staticClass: "card-body"
}, [e("div", {
staticClass: "close",
on: {
click: A.handleClose
}
}, [e("CloseIcon")], 1), e("div", {
staticClass: "card-wrapper"
}, [e("div", {
staticClass: "title"
}, [A._v(A._s(A.t("browser-authorization")))]), e("div", {
staticClass: "button"
}, [A._v(A._s(A.t(A.preferences)))]), e("div", {
staticClass: "allow"
}, [A._v(A._s(A.t(A.privacy)))]), e("div", {
staticClass: "image-wrapper"
}, [e("img", {
staticClass: "image",
attrs: {
src: A.permitPng,
alt: "system permit"
}
})])])])]) : A._e();
}, ig = [];
const $n = {};
var sg = /* @__PURE__ */ S(
Fe,
lg,
ig,
!1,
ug,
"ee5a0fe8",
null,
null
);
function ug(A) {
for (let t in $n)
this[t] = $n[t];
}
const cg = /* @__PURE__ */ function() {
return sg.exports;
}(), yt = {};
yt.setup = (A, t) => {
const e = p(() => j.isMAC ? Rt.MAC : Rt.WIN), a = I(d.getData(c.CALL, o.LANGUAGE)), n = (l) => a.value = l;
return aA(() => {
d.watch(c.CALL, {
[o.LANGUAGE]: n
}, {
notifyRangeWhenWatch: o.MYSELF
});
}), tA(() => {
d.unwatch(c.CALL, {
[o.LANGUAGE]: n
});
}), {
platform: e,
language: a
};
};
yt.components = Object.assign({
SystemPermitTip: cg
}, yt.components);
var rg = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
staticClass: "tip"
}, [e("div", {
staticClass: "card"
}, [e("SystemPermitTip", {
attrs: {
platform: A.platform,
language: A.language
}
})], 1)]);
}, Mg = [];
const Ao = {};
var dg = /* @__PURE__ */ S(
yt,
rg,
Mg,
!1,
Ig,
"ff1df20c",
null,
null
);
function Ig(A) {
for (let t in Ao)
this[t] = Ao[t];
}
const gg = /* @__PURE__ */ function() {
return dg.exports;
}(), pl = {};
let He = null, Ng = 1;
const pg = () => {
const A = document.body;
He && (A.removeChild(He.$el), He.$destroy());
const t = Xt.extend(gg), e = new t({
propsData: {
index: `toast-item-${Ng++}`,
destroy() {
A.removeChild(e.$el), e.$destroy();
}
}
});
e.$mount(), A.appendChild(e.$el), He = e;
};
pl.show = () => pg();
const Sa = {};
Sa.props = {
type: {
key: "type",
required: !0,
type: null
},
duration: {
key: "duration",
required: !1,
type: Number
},
message: {
key: "message",
required: !0,
type: String
},
index: {
key: "index",
required: !0,
type: String
},
showClose: {
key: "showClose",
required: !1,
type: Boolean
},
destroy: {
key: "destroy",
required: !0,
type: Function
},
close: {
key: "close",
required: !0,
type: Function
}
};
Sa.setup = (A, t) => {
const e = A, a = I(!1), n = I(null), l = p(() => `toast-container ${e.type}`), i = () => {
e.destroy();
}, u = () => {
e.close(), a.value = !1;
}, s = () => {
n.value && clearTimeout(n.value), e.duration && (n.value = setTimeout(() => {
u();
}, e.duration));
};
return aA(() => {
a.value = !0, s();
}), tA(() => {
n.value && clearTimeout(n.value);
}), {
isShow: a,
toastClass: l,
handleAfterLeave: i,
handleClose: u
};
};
var Dg = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("Transition", {
attrs: {
name: "slide-up"
},
on: {
"after-leave": A.handleAfterLeave
}
}, [e("div", {
directives: [{
name: "show",
rawName: "v-show",
value: A.isShow,
expression: "isShow"
}],
key: A.index,
class: A.toastClass
}, [e("div", {
staticClass: "toast-content"
}, [A._v(A._s(A.message))]), e("i", {
directives: [{
name: "show",
rawName: "v-show",
value: A.showClose,
expression: "showClose"
}],
staticClass: "toast-close-icon",
on: {
click: A.handleClose
}
})])]);
}, Tg = [];
const eo = {};
var Cg = /* @__PURE__ */ S(
Sa,
Dg,
Tg,
!1,
yg,
"1a36ce82",
null,
null
);
function yg(A) {
for (let t in eo)
this[t] = eo[t];
}
const Sg = /* @__PURE__ */ function() {
return Cg.exports;
}(), LA = {}, IA = [];
let Eg = 1;
function hg() {
var t, e, a;
const A = IA.length;
return A > 0 ? (a = (e = (t = IA[A - 1]) == null ? void 0 : t.$el) == null ? void 0 : e.style) == null ? void 0 : a.top : "30px";
}
function mg() {
var t, e;
const A = IA.length;
return A > 0 ? (e = (t = IA[A - 1]) == null ? void 0 : t.$el) == null ? void 0 : e.offsetHeight : 0;
}
const Dl = (A) => {
const t = document.body, { type: e, duration: a = 3e3, message: n, showClose: l = !1, onClose: i } = A, u = Xt.extend(Sg), s = new u({
propsData: {
type: e,
duration: a,
message: n,
showClose: l,
index: `toast-item-${Eg++}`,
close() {
var N, y, T, C;
const D = IA.findIndex((E) => E === s);
console.log((y = (N = IA[D]) == null ? void 0 : N.$el) == null ? void 0 : y.offsetHeight);
const g = parseInt((C = (T = IA[D]) == null ? void 0 : T.$el) == null ? void 0 : C.offsetHeight) + 20;
for (let E = 0; E < IA.length; E++)
E < D || (IA[E].$el.style.top = parseInt(IA[E].$el.style.top) - g + "px");
IA.splice(D, 1);
},
destroy() {
t.removeChild(s.$el), s.$destroy();
}
}
});
s.$mount(), t.appendChild(s.$el);
const r = hg(), M = mg();
s.$el.style.top = parseInt(r) + parseInt(M) + 20 + "px", IA.push(s);
};
["info", "waring", "error", "success"].forEach((A) => {
let t = {};
LA[A] = (e) => {
typeof e == "string" ? t.message = e : t = e, Dl({ type: A, ...t });
};
});
LA.show = (A) => {
let t = {};
return typeof A == "string" ? (t.message = A, t.type = "info") : t = A, Dl({ type: "info", ...t });
};
const Re = {};
Re.props = {
beforeCalling: {
key: "beforeCalling",
required: !1,
type: Function
},
afterCalling: {
key: "afterCalling",
required: !1,
type: Function
},
onMinimized: {
key: "onMinimized",
required: !1,
type: Function
},
onMessageSentByMe: {
key: "onMessageSentByMe",
required: !1,
type: Function
},
kickedOut: {
key: "kickedOut",
required: !1,
type: Function
},
statusChanged: {
key: "statusChanged",
required: !1,
type: Function
},
allowedMinimized: {
key: "allowedMinimized",
required: !1,
type: Boolean,
default: !1
},
allowedFullScreen: {
key: "allowedFullScreen",
required: !1,
type: Boolean,
default: !0
},
videoDisplayMode: {
key: "videoDisplayMode",
required: !1,
type: String,
default: "cover"
},
videoResolution: {
key: "videoResolution",
required: !1,
type: String,
default: "480p"
}
};
Re.setup = (A, t) => {
const e = !j.isPC, a = e ? "TUICallKit-mobile transition-animation" : "TUICallKit-desktop", n = I(""), l = I(""), i = I(""), u = I(!1), s = A, r = I(d.getData(c.CALL, o.CALL_STATUS)), M = I(d.getData(c.CALL, o.CALL_ROLE)), D = I(d.getData(c.CALL, o.CALL_MEDIA_TYPE)), g = I(d.getData(c.CALL, o.IS_GROUP)), N = I(d.getData(c.CALL, o.IS_EAR_PHONE)), y = I(null), T = I(d.getData(c.CALL, o.LOCAL_USER_INFO_EXCLUDE_VOLUMN)), C = I(d.getData(c.CALL, o.REMOTE_USER_INFO_EXCLUDE_VOLUMN_LIST)), E = I(d.getData(c.CALL, o.CALLER_USER_INFO)), w = I(d.getData(c.CALL, o.IS_MINIMIZED)), L = I(d.getData(c.CALL, o.ENABLE_VIRTUAL_BACKGROUND)), m = I(d.getData(c.CALL, o.IS_SHOW_ENABLE_VIRTUAL_BACKGROUND)), k = I(d.getData(c.CALL, o.CUSTOM_UI_CONFIG)), _ = I(d.getData(c.CALL, o.IS_MUTE_SPEAKER)), Z = Ye({
callStatus: r,
callRole: M,
callType: D,
isGroupCall: g,
isEarPhone: N,
focusElement: y,
allowedFullScreen: s.allowedFullScreen,
enableVirtualBackground: L,
isShowEnableVirtualBackground: m,
isMuteSpeaker: _
}), b = Ye({
callerUserInfo: E
}), P = Ye({
localUserInfoExcludeVolume: T,
remoteUserListExcludeVolume: C
}), AA = Ye({
isFloatWindow: w
}), {
beforeCalling: ZA,
afterCalling: xA,
onMinimized: VA,
onMessageSentByMe: bA,
videoDisplayMode: YA,
videoResolution: Ut,
kickedOut: Qe,
statusChanged: Ze,
allowedMinimized: Y
} = z(s), iA = (B) => {
Z.callStatus = B;
}, dA = (B) => {
Z.isGroupCall = B;
}, BA = (B) => {
B.text && zl(B.text, B.type || "info");
}, Cl = (B) => {
Z.callType = B, e && u.value && (i.value = "miniMized-mobile-audio", l.value = ""), e && !u.value && (l.value = "mobile-audio");
}, Ea = (B) => {
AA.isFloatWindow = B, B ? e ? Z.callType === F.AUDIO ? l.value = "miniMized-mobile-audio" : i.value = "miniMized-mobile-video" : n.value = "miniMized" : (l.value = "mobile-audio", n.value = "", i.value = "");
}, yl = (B) => {
if (B && j.isPC)
try {
pl.show();
} catch (zt) {
console.debug(zt);
}
}, Sl = (B) => {
Z.callRole = B;
}, El = (B) => {
P.localUserInfoExcludeVolume = B;
}, hl = (B) => {
P.remoteUserListExcludeVolume = B;
}, ml = (B) => {
b.callerUserInfo = B;
}, jl = (B) => {
Z.isEarPhone = B;
}, vl = (B) => {
Z.enableVirtualBackground = B;
}, fl = (B) => {
Z.isShowEnableVirtualBackground = B;
}, Ll = (B) => {
k.value = B;
}, Ul = (B) => {
Z.isMuteSpeaker = B;
};
QA(() => {
O.setCallback({
beforeCalling: ZA && ZA.value,
afterCalling: xA && xA.value,
onMinimized: VA && VA.value,
onMessageSentByMe: bA && bA.value,
kickedOut: Qe && Qe.value,
statusChanged: Ze && Ze.value
});
});
const ha = {
[o.CALL_STATUS]: iA,
[o.IS_GROUP]: dA,
[o.TOAST_INFO]: BA,
[o.CALL_MEDIA_TYPE]: Cl,
[o.SHOW_PERMISSION_TIP]: yl,
[o.CALL_ROLE]: Sl,
[o.LOCAL_USER_INFO_EXCLUDE_VOLUMN]: El,
[o.REMOTE_USER_INFO_EXCLUDE_VOLUMN_LIST]: hl,
[o.CALLER_USER_INFO]: ml,
[o.IS_EAR_PHONE]: jl,
[o.ENABLE_VIRTUAL_BACKGROUND]: vl,
[o.IS_SHOW_ENABLE_VIRTUAL_BACKGROUND]: fl,
[o.CUSTOM_UI_CONFIG]: Ll,
[o.IS_MUTE_SPEAKER]: Ul
};
aA(() => {
Y.value && O.enableFloatWindow(Y.value), O.setVideoDisplayMode(YA.value), O.setVideoResolution(Ut.value), d.watch(c.CALL, ha, {
notifyRangeWhenWatch: o.MYSELF
}), d.watch(c.CALL, {
[o.IS_MINIMIZED]: Ea
});
});
function zl(B, zt) {
switch (zt) {
case "info":
LA == null || LA.info(B);
break;
case "error":
LA == null || LA.error(B);
break;
}
}
return tA(async () => {
d.unwatch(c.CALL, {
...ha,
[o.IS_MINIMIZED]: Ea
});
}), gA(To, Z), gA(Co, b), gA(yo, P), gA(ho, AA), gA(vo, k), {
CallStatus: U,
bodyStyle: a,
miniMizedDeskStyle: n,
mobileAudioStyle: l,
mobileVideoStyle: i,
callInfoContextValue: Z,
floatWindowContextValue: AA
};
};
Re.components = Object.assign({
SingleCall: iI,
GroupCall: JI
}, Re.components);
var jg = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return A.callInfoContextValue.callStatus !== A.CallStatus.IDLE ? e("div", {
class: [A.bodyStyle, A.miniMizedDeskStyle, A.mobileVideoStyle, A.mobileAudioStyle],
style: [{
visibility: A.floatWindowContextValue.isFloatWindow ? "hidden" : ""
}],
attrs: {
id: "tuicallkit-id"
}
}, [A.callInfoContextValue.isGroupCall ? e("GroupCall", {
staticClass: "singCall"
}) : e("SingleCall", {
staticClass: "singCall"
})], 1) : A._e();
}, vg = [];
const to = {};
var fg = /* @__PURE__ */ S(
Re,
jg,
vg,
!1,
Lg,
null,
null,
null
);
function Lg(A) {
for (let t in to)
this[t] = to[t];
}
const Lt = /* @__PURE__ */ function() {
return fg.exports;
}(), Tl = "", ke = {};
ke.props = {
userListInfo: {
type: Array,
default: []
}
};
ke.setup = (A, t) => {
const e = t.emit, a = I(!1);
return {
t: v,
CallIcon: Tl,
defaultAvatarSrc: GA,
isShowContent: a,
handleJoinGroup: () => {
e("joinGroupCall"), a.value = !1;
},
handleClick: () => {
a.value = !a.value;
}
};
};
ke.components = Object.assign({
TKImage: SA
}, ke.components);
var Ug = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
staticClass: "banner-pc"
}, [e("div", {
staticClass: "top",
on: {
click: A.handleClick
}
}, [e("TKImage", {
staticClass: "call-icon",
attrs: {
src: A.CallIcon,
width: "16px",
height: "16px"
}
}), e("span", {
staticClass: "text"
}, [A._v(" " + A._s(A.userListInfo.length) + " " + A._s(A.t("people on the call")) + " ")])], 1), e("div", {
directives: [{
name: "show",
rawName: "v-show",
value: A.isShowContent,
expression: "isShowContent"
}],
staticClass: "content"
}, [e("div", {
staticClass: "content-arrows"
}), e("div", {
staticClass: "avatar-box"
}, A._l(A.userListInfo, function(a) {
return e("TKImage", {
staticClass: "avatar",
attrs: {
src: a == null ? void 0 : a.avatar,
defaultSrc: A.defaultAvatarSrc,
fit: "cover",
width: "32px",
height: "32px"
}
});
}), 1), e("div", {
staticClass: "btn",
on: {
click: A.handleJoinGroup
}
}, [A._v(A._s(A.t("join")))])])]);
}, zg = [];
const ao = {};
var wg = /* @__PURE__ */ S(
ke,
Ug,
zg,
!1,
Og,
null,
null,
null
);
function Og(A) {
for (let t in ao)
this[t] = ao[t];
}
const xg = /* @__PURE__ */ function() {
return wg.exports;
}(), Vg = "", Pe = {};
Pe.props = {
userListInfo: {
type: Array,
default: []
}
};
Pe.setup = (A, t) => {
const e = I({
margin: "8px 10px 8px 0px"
}), a = I({
margin: "6px",
borderRadius: "4px"
}), n = I(!1), l = t.emit;
return {
t: v,
CallIcon: Tl,
ArrowsIcon: Vg,
defaultAvatarSrc: GA,
CallIconStyle: e,
avatarImgStyle: a,
isShowContent: n,
handleJoinGroup: () => {
l("joinGroupCall"), n.value = !1;
},
handleClick: () => {
n.value = !n.value;
}
};
};
Pe.components = Object.assign({
TKImage: SA
}, Pe.components);
var bg = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
staticClass: "banner-h5"
}, [e("div", {
staticClass: "top",
on: {
click: A.handleClick
}
}, [e("div", {
staticClass: "left"
}, [e("TKImage", {
staticClass: "call-icon",
attrs: {
src: A.CallIcon,
width: "16px",
height: "16px",
customStyle: A.CallIconStyle
}
}), e("span", {
staticClass: "text"
}, [A._v(" " + A._s(A.userListInfo.length) + " " + A._s(A.t("people on the call")) + " ")])], 1), e("TKImage", {
attrs: {
src: A.ArrowsIcon,
width: "9px",
height: "9px"
}
})], 1), e("div", {
directives: [{
name: "show",
rawName: "v-show",
value: A.isShowContent,
expression: "isShowContent"
}],
staticClass: "content-box"
}, [e("div", {
staticClass: "content"
}, [e("div", {
staticClass: "avatar-box"
}, A._l(A.userListInfo, function(a) {
return e("TKImage", {
attrs: {
src: a == null ? void 0 : a.avatar,
customStyle: A.avatarImgStyle,
defaultSrc: A.defaultAvatarSrc,
fit: "cover",
width: "50px",
height: "50px"
}
});
}), 1), e("div", {
staticClass: "btn",
on: {
click: function(a) {
return a.stopPropagation(), A.handleJoinGroup.apply(null, arguments);
}
}
}, [A._v(A._s(A.t("join")))])])])]);
}, Bg = [];
const no = {};
var Fg = /* @__PURE__ */ S(
Pe,
bg,
Bg,
!1,
Rg,
null,
null,
null
);
function Rg(A) {
for (let t in no)
this[t] = no[t];
}
const kg = /* @__PURE__ */ function() {
return Fg.exports;
}(), St = {};
St.setup = (A, t) => {
const e = I(j.isPC), a = I(null), {
groupId: n,
roomId: l,
roomIdType: i,
callMediaType: u,
groupCallMembers: s,
callStatus: r
} = z(Zi()), M = p(() => n && (r == null ? void 0 : r.value) === U.IDLE && s.value.length);
return {
isPC: e,
message: a,
groupCallMembers: s,
isShow: M,
handleClick: async () => {
if (s.value.length > 9) {
a.value.show({
message: "Supports a maximum of 9 people for simultaneous calls",
type: "success"
});
return;
}
const g = {
type: u.value,
groupID: n.value,
roomID: i.value === 1 ? Number(l.value) : 0,
strRoomID: String(l.value)
};
try {
await O.joinInGroupCall(g);
} catch (N) {
console.error(`${o.PREFIX}joinInGroupCall fail: ${N}`);
}
}
};
};
St.components = Object.assign({
JoinGroupCardPC: xg,
JoinGroupCardMobile: kg,
Message: cl
}, St.components);
var Pg = function() {
var A = this, t = A.$createElement, e = A._self._c || t;
return e("div", {
directives: [{
name: "show",
rawName: "v-show",
value: A.isShow,
expression: "isShow"
}]
}, [A.isPC ? e("JoinGroupCardPC", {
attrs: {
userListInfo: A.groupCallMembers
},
on: {
joinGroupCall: A.handleClick
}
}) : e("JoinGroupCardMobile", {
attrs: {
userListInfo: A.groupCallMembers
},
on: {
joinGroupCall: A.handleClick
}
}), e("Message", {
ref: "message"
})], 1);
}, Wg = [];
const oo = {};
var Gg = /* @__PURE__ */ S(
St,
Pg,
Wg,
!1,
Qg,
null,
null,
null
);
function Qg(A) {
for (let t in oo)
this[t] = oo[t];
}
const Zg = /* @__PURE__ */ function() {
return Gg.exports;
}(), Yg = (A) => (A.component("TUICallKit", { server: O }), O.bindTUICore(A), Lt), Xg = (A) => {
A.component("TUICallKit", Lt).component("JoinGroupCard", Zg), console.log("TUICallKit&mini installed", A);
};
Lt.plugin = Yg;
Lt.install = Xg;
const $g = {
AUDIO_CALL: 1,
VIDEO_CALL: 2
}, AN = "3.3.7";
export {
F as CallMediaType,
K as CallRole,
zA as FeatureButton,
Zg as JoinGroupCard,
et as LayoutMode,
o as NAME,
nA as STATUS,
c as StoreName,
Lt as TUICallKit,
O as TUICallKitServer,
$g as TUICallType,
j as TUIGlobal,
d as TUIStore,
AN as Version,
ne as VideoDisplayMode,
oe as VideoResolution,
Xg as install,
Yg as plugin,
v as t,
mA as uiDesign
};