@nethesis/phone-island 0.18.6 → 0.18.7

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/App.js CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("./node_modules/tslib/tslib.es6.js"),n=require("react"),t=require("./components/Events.js"),i=require("./components/Socket.js"),s=require("./components/WebRTC.js"),a=require("./components/Island.js"),o=require("./components/RestAPI.js"),r=require("./utils/customHooks/useEventListener.js"),c=require("./utils/genericFunctions/eventDispatch.js"),u=require("./utils/genericFunctions/localStorage.js"),d=require("./store/index.js"),l=require("./services/user.js");require("./node_modules/react-redux/es/index.js"),require("./node_modules/@fortawesome/react-fontawesome/index.es.js"),require("./node_modules/i18next/dist/esm/i18next.js"),require("./node_modules/react-tooltip/dist/react-tooltip.min.mjs.js"),require("./components/TranscriptionView/TranscriptionView.js");var p=require("./node_modules/js-base64/base64.mjs.js"),v=require("./workers/wake_up.js"),h=require("./lib/i18n.js");require("./node_modules/react-tooltip/dist/react-tooltip.min.css.js");var f=require("./lib/webrtc/messages.js"),g=require("./lib/darkTheme.js"),m=require("./utils/genericFunctions/isEmpty.js"),w=require("./utils/genericFunctions/checkConnection.js"),I=require("./utils/genericFunctions/isBackCallVisible.js"),b=require("./lib/phone/trunk.js"),E=require("./lib/phone/call.js"),D=require("./node_modules/react-redux/es/components/Provider.js");function S(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}require("./node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js"),require("./node_modules/react-redux/node_modules/react-is/index.js"),require("./node_modules/react-redux/es/components/Context.js");var y=S(n),_=n.forwardRef((function(S,_){var k=S.dataConfig,L=S.showAlways,U=void 0!==L&&L,T=S.uaType,j=S.urlParamWithEvent,C=void 0!==j&&j,N=p.Base64.atob(k||"").split(":"),O=N[0],A=N[1],q=N[2],R=N[3],V=N[4],P=N[5],x=N[6],J=n.useState(!1),W=J[0],F=J[1],M=n.useState(!1),Q=M[0],z=M[1],H=n.useState(!1),$=H[0],B=H[1],G=n.useRef(0);n.useImperativeHandle(_,(function(){return{reset:function(){console.info("PhoneIsland: Performing full component reset"),F(!0)}}}),[]),n.useEffect((function(){var e=Date.now(),n=function(){if(!document.hidden){var n=Date.now(),t=n-e;setTimeout((function(){c.eventDispatch("phone-island-emergency-stop-ringtone",{})}),2e3),t>3e5&&(console.info("Tab inactive for long period, performing soft reconnection"),F(!0)),e=n}},t=new Worker(v.default,{type:"module"});return t.onmessage=function(n){"ping"===n.data&&(e=Date.now())},document.addEventListener("visibilitychange",n),function(){t.terminate(),document.removeEventListener("visibilitychange",n)}}),[]),n.useEffect((function(){$&&Q&&(F(!1),z(!1),B(!1))}),[$,Q]),n.useEffect((function(){var e=setInterval((function(){var e,n,t,i,s=d.store.getState().alerts.data,a=(null===(e=s.webrtc_down)||void 0===e?void 0:e.active)||!1,o=(null===(n=s.socket_down)||void 0===n?void 0:n.active)||!1,r=Date.now(),c=r-G.current,u=d.store.getState().webrtc.sipcall,l=d.store.getState().currentCall,p=l.accepted,v=l.outgoing,h=null===(i=null===(t=null==u?void 0:u.webrtcStuff)||void 0===t?void 0:t.pc)||void 0===i?void 0:i.iceConnectionState,f=p||v||"connected"===h||"completed"===h,g=navigator.onLine;if((a||o)&&!W&&c>1e4&&g){if(f)return void console.info("Alert detected but active call in progress - skipping automatic reload to let ICE recover",{timeSinceLastReload:Math.round(c/1e3)+"s",isWebRTCDown:a,isSocketDown:o,iceState:h,accepted:p,outgoing:v});console.info("Alert detected (webrtc_down or socket_down), triggering automatic reload",{timeSinceLastReload:Math.round(c/1e3)+"s",isWebRTCDown:a,isSocketDown:o}),G.current=r,F(!0)}}),1e3);return function(){return clearInterval(e)}}),[W]),r.useEventListener("phone-island-expand",(function(){d.store.dispatch.island.toggleIsOpen(!0),c.eventDispatch("phone-island-expanded",{})})),r.useEventListener("phone-island-compress",(function(){d.store.dispatch.island.toggleIsOpen(!1),c.eventDispatch("phone-island-compressed",{})})),r.useEventListener("phone-island-call-keypad-close",(function(){d.store.dispatch.island.setIslandView("call"),c.eventDispatch("phone-island-call-keypad-closed",{})})),r.useEventListener("phone-island-call-transfer-close",(function(){d.store.dispatch.island.setIslandView("call"),c.eventDispatch("phone-island-call-transfer-closed",{})})),r.useEventListener("phone-island-recording-close",(function(){d.store.dispatch.island.setIslandView(null),c.eventDispatch("phone-island-recording-closed",{})})),r.useEventListener("phone-island-audio-player-close",(function(){d.store.dispatch.island.setIslandView(null),c.eventDispatch("phone-island-audio-player-closed",{})})),r.useEventListener("phone-island-emergency-stop-ringtone",(function(){null===d.store.getState().island.view?(console.warn("Emergency stop ringtone triggered - phone island inactive"),d.store.dispatch.player.emergencyStopAudioPlayer(),c.eventDispatch("phone-island-emergency-stop-ringtone-completed",{})):console.log("Phone island is active, ringtone stop ignored")})),r.useEventListener("phone-island-detach",(function(e){f.detach(),c.eventDispatch("phone-island-detached",{})})),r.useEventListener("phone-island-reload-component",(function(e){(null==e?void 0:e.force)&&d.store.dispatch.island.setForceReload(!0),F(!0)})),r.useEventListener("phone-island-audio-input-change",(function(n){return e.__awaiter(void 0,void 0,void 0,(function(){var t;return e.__generator(this,(function(e){switch(e.label){case 0:return(t=n.deviceId)&&"default"!==t?[4,te(t)]:[3,3];case 1:return e.sent()?[3,3]:(console.warn("Audio input device ".concat(t," not available, falling back to default device")),[4,ie()]);case 2:t=e.sent(),e.label=3;case 3:return u.setJSONItem("phone-island-audio-input-device",{deviceId:t}),c.eventDispatch("phone-island-audio-input-changed",{}),t!==n.deviceId&&console.info("Audio input device changed from ".concat(n.deviceId," to ").concat(t," (fallback)")),[2]}}))}))})),r.useEventListener("phone-island-video-input-change",(function(n){return e.__awaiter(void 0,void 0,void 0,(function(){var t;return e.__generator(this,(function(e){switch(e.label){case 0:return(t=n.deviceId)&&"default"!==t?[4,se(t)]:[3,3];case 1:return e.sent()?[3,3]:(console.warn("Video input device ".concat(t," not available, falling back to default device")),[4,ae()]);case 2:t=e.sent(),e.label=3;case 3:return u.setJSONItem("phone-island-video-input-device",{deviceId:t}),c.eventDispatch("phone-island-video-input-changed",{}),t!==n.deviceId&&console.info("Video input device changed from ".concat(n.deviceId," to ").concat(t," (fallback)")),[2]}}))}))}));var K=n.useState(!0),X=K[0],Y=K[1],Z=n.useState(!0),ee=Z[0],ne=Z[1];n.useEffect((function(){X&&(h.initI18n(),e.__awaiter(void 0,void 0,void 0,(function(){var n,t,i,s;return e.__generator(this,(function(e){switch(e.label){case 0:return e.trys.push([0,2,,3]),[4,l.getParamUrl()];case 1:return n=e.sent(),t=(null==n?void 0:n.url)||"",i=t&&""!==t.trim(),d.store.dispatch.paramUrl.setParamUrl({url:t,onlyQueues:(null==n?void 0:n.only_queues)||!1,hasValidUrl:i}),[3,3];case 2:return s=e.sent(),console.error("Error fetching URL parameter:",s),d.store.dispatch.paramUrl.setParamUrl({url:"",onlyQueues:!1,hasValidUrl:!1}),[3,3];case 3:return[2]}}))})),Y(!1))}),[X]);var te=function(n){return e.__awaiter(void 0,void 0,void 0,(function(){var t,i;return e.__generator(this,(function(e){switch(e.label){case 0:return e.trys.push([0,2,,3]),navigator.mediaDevices&&navigator.mediaDevices.enumerateDevices?[4,navigator.mediaDevices.enumerateDevices()]:[2,!1];case 1:return t=e.sent(),[2,t.filter((function(e){return"audioinput"===e.kind})).some((function(e){return e.deviceId===n}))];case 2:return i=e.sent(),console.warn("Error checking audio input device availability:",i),[2,!1];case 3:return[2]}}))}))},ie=function(){return e.__awaiter(void 0,void 0,void 0,(function(){var n,t,i,s;return e.__generator(this,(function(e){switch(e.label){case 0:return e.trys.push([0,2,,3]),navigator.mediaDevices&&navigator.mediaDevices.enumerateDevices?[4,navigator.mediaDevices.enumerateDevices()]:[2,"default"];case 1:return n=e.sent(),t=n.filter((function(e){return"audioinput"===e.kind})),[2,(i=t.find((function(e){return"default"===e.deviceId||""===e.deviceId}))||t[0])?i.deviceId:"default"];case 2:return s=e.sent(),console.warn("Error getting default audio input device:",s),[2,"default"];case 3:return[2]}}))}))},se=function(n){return e.__awaiter(void 0,void 0,void 0,(function(){var t,i;return e.__generator(this,(function(e){switch(e.label){case 0:return e.trys.push([0,2,,3]),navigator.mediaDevices&&navigator.mediaDevices.enumerateDevices?[4,navigator.mediaDevices.enumerateDevices()]:[2,!1];case 1:return t=e.sent(),[2,t.filter((function(e){return"videoinput"===e.kind})).some((function(e){return e.deviceId===n}))];case 2:return i=e.sent(),console.warn("Error checking video input device availability:",i),[2,!1];case 3:return[2]}}))}))},ae=function(){return e.__awaiter(void 0,void 0,void 0,(function(){var n,t,i,s;return e.__generator(this,(function(e){switch(e.label){case 0:return e.trys.push([0,2,,3]),navigator.mediaDevices&&navigator.mediaDevices.enumerateDevices?[4,navigator.mediaDevices.enumerateDevices()]:[2,"default"];case 1:return n=e.sent(),t=n.filter((function(e){return"videoinput"===e.kind})),[2,(i=t.find((function(e){return"default"===e.deviceId||""===e.deviceId}))||t[0])?i.deviceId:"default"];case 2:return s=e.sent(),console.warn("Error getting default video input device:",s),[2,"default"];case 3:return[2]}}))}))};r.useEventListener("phone-island-audio-output-change",(function(n){e.__awaiter(void 0,void 0,void 0,(function(){var t,i,s,a,o,r,l,p,v;return e.__generator(this,(function(h){switch(h.label){case 0:return(null==(t=d.store.getState().player.remoteAudio)?void 0:t.current)?(i=n.deviceId)&&"default"!==i?[4,(f=i,e.__awaiter(void 0,void 0,void 0,(function(){var n;return e.__generator(this,(function(e){switch(e.label){case 0:return e.trys.push([0,2,,3]),navigator.mediaDevices&&navigator.mediaDevices.enumerateDevices?[4,navigator.mediaDevices.enumerateDevices()]:[2,!1];case 1:return[2,e.sent().filter((function(e){return"audiooutput"===e.kind})).some((function(e){return e.deviceId===f}))];case 2:return n=e.sent(),console.warn("Error checking device availability:",n),[2,!1];case 3:return[2]}}))})))]:[3,3]:(console.warn("Remote audio element not available"),[2]);case 1:return h.sent()?[3,3]:(console.warn("Audio output device ".concat(i," not available, falling back to default device")),[4,e.__awaiter(void 0,void 0,void 0,(function(){var n,t,i,s;return e.__generator(this,(function(e){switch(e.label){case 0:return e.trys.push([0,2,,3]),navigator.mediaDevices&&navigator.mediaDevices.enumerateDevices?[4,navigator.mediaDevices.enumerateDevices()]:[2,"default"];case 1:return n=e.sent(),t=n.filter((function(e){return"audiooutput"===e.kind})),[2,(i=t.find((function(e){return"default"===e.deviceId||""===e.deviceId}))||t[0])?i.deviceId:"default"];case 2:return s=e.sent(),console.warn("Error getting default device:",s),[2,"default"];case 3:return[2]}}))}))]);case 2:i=h.sent(),u.setJSONItem("phone-island-audio-output-device",{deviceId:i}),h.label=3;case 3:return h.trys.push([3,5,,15]),[4,t.current.setSinkId(i)];case 4:return h.sent(),console.info("Default audio output device changed successfully!"),u.setJSONItem("phone-island-audio-output-device",{deviceId:i}),c.eventDispatch("phone-island-audio-output-changed",{}),[3,15];case 5:s=h.sent(),console.log("Direct setSinkId failed, trying with temporary stream:",s),h.label=6;case 6:return h.trys.push([6,7,,14]),a=new(window.AudioContext||window.webkitAudioContext),o=a.createOscillator(),r=a.createGain(),o.frequency.setValueAtTime(440,a.currentTime),r.gain.setValueAtTime(0,a.currentTime),o.connect(r),l=a.createMediaStreamDestination(),r.connect(l),t.current.srcObject=l.stream,o.start(),setTimeout((function(){return e.__awaiter(void 0,void 0,void 0,(function(){var n,s;return e.__generator(this,(function(e){switch(e.label){case 0:return e.trys.push([0,2,,7]),[4,t.current.setSinkId(i)];case 1:return e.sent(),console.info("Default audio output device changed successfully with temporary stream!"),o.stop(),a.close(),t.current.srcObject=null,u.setJSONItem("phone-island-audio-output-device",{deviceId:i}),c.eventDispatch("phone-island-audio-output-changed",{}),[3,7];case 2:if(n=e.sent(),console.error("Final setSinkId attempt failed:",n),o.stop(),a.close(),t.current.srcObject=null,"default"===i)return[3,6];console.log("Trying fallback to default device"),e.label=3;case 3:return e.trys.push([3,5,,6]),[4,t.current.setSinkId("default")];case 4:return e.sent(),u.setJSONItem("phone-island-audio-output-device",{deviceId:"default"}),console.info("Fallback to default audio device successful"),[3,6];case 5:return s=e.sent(),console.error("Even default device failed:",s),[3,6];case 6:return u.setJSONItem("phone-island-audio-output-device",{deviceId:i}),c.eventDispatch("phone-island-audio-output-changed",{}),[3,7];case 7:return[2]}}))}))}),100),[3,14];case 7:if(p=h.sent(),console.error("Failed to create temporary audio stream:",p),"default"===i)return[3,12];h.label=8;case 8:return h.trys.push([8,10,,11]),[4,t.current.setSinkId("default")];case 9:return h.sent(),u.setJSONItem("phone-island-audio-output-device",{deviceId:"default"}),console.info("Emergency fallback to default audio device successful"),[3,11];case 10:return v=h.sent(),console.error("Emergency fallback to default device failed:",v),u.setJSONItem("phone-island-audio-output-device",{deviceId:i}),[3,11];case 11:return[3,13];case 12:u.setJSONItem("phone-island-audio-output-device",{deviceId:i}),h.label=13;case 13:return c.eventDispatch("phone-island-audio-output-changed",{}),[3,14];case 14:return[3,15];case 15:return[2]}var f}))}))})),r.useEventListener("phone-island-presence-change",(function(e){l.changeOperatorStatus(e),c.eventDispatch("phone-island-presence-changed",{})})),r.useEventListener("phone-island-view-changed",(function(e){var n=null==e?void 0:e.viewType;d.store.dispatch.island.setIslandView(n)}));var oe=d.store.getState().player.remoteAudio;n.useEffect((function(){var e;if(ee&&oe){var n=null===(e=u.getJSONItem("phone-island-audio-output-device"))||void 0===e?void 0:e.deviceId;c.eventDispatch("phone-island-audio-output-change",{deviceId:n}),ne(!1)}}),[ee,oe]),n.useEffect((function(){g.checkDarkTheme()}),[]),r.useEventListener("phone-island-theme-change",(function(e){g.setTheme(null==e?void 0:e.selectedTheme)})),r.useEventListener("phone-island-default-device-change",(function(e){d.store.dispatch.currentUser.updateCurrentDefaultDevice(null==e?void 0:e.deviceInformationObject),c.eventDispatch("phone-island-default-device-changed",{})})),r.useEventListener("phone-island-alert",(function(e){d.store.dispatch.alerts.setAlert(e.toString())})),r.useEventListener("phone-island-ringing-tone-list",(function(){var e=d.store.getState().ringtones.availableRingtones.map((function(e){return{name:e.name,displayName:e.displayName,base64Audio:e.base64Audio}}));c.eventDispatch("phone-island-ringing-tone-list-response",{ringtones:e})})),r.useEventListener("phone-island-ringing-tone-select",(function(e){(null==e?void 0:e.name)&&(u.setJSONItem("phone-island-selected-ringtone",{value:e.name}),d.store.dispatch.ringtones.setSelectedRingtone(e.name),c.eventDispatch("phone-island-ringing-tone-selected",{name:e.name}))})),r.useEventListener("phone-island-ringing-tone-output",(function(e){(null==e?void 0:e.deviceId)&&(u.setJSONItem("phone-island-ringtone-output-device",{value:e.deviceId}),d.store.dispatch.ringtones.setOutputDeviceId(e.deviceId),c.eventDispatch("phone-island-ringing-tone-output-changed",{deviceId:e.deviceId}))})),n.useEffect((function(){var e=u.getJSONItem("phone-island-selected-ringtone"),n=u.getJSONItem("phone-island-ringtone-output-device");(null==e?void 0:e.value)&&d.store.dispatch.ringtones.setSelectedRingtone(e.value),(null==n?void 0:n.value)&&d.store.dispatch.ringtones.setOutputDeviceId(n.value)}),[]),r.useEventListener("phone-island-check-connection",(function(){w.checkInternetConnection().then((function(e){e?c.eventDispatch("phone-island-internet-connected",{}):c.eventDispatch("phone-island-internet-disconnected",{})}))})),n.useEffect((function(){var e=setInterval((function(){w.checkInternetConnection().then((function(e){e?c.eventDispatch("phone-island-internet-connected",{}):c.eventDispatch("phone-island-internet-disconnected",{})}))}),5e3);return function(){return clearInterval(e)}}),[]),r.useEventListener("phone-island-main-presence",(function(e){var n,t,i,s,a=null===(n=d.store.getState().currentUser)||void 0===n?void 0:n.username,o=d.store.getState().currentUser,r=null==o?void 0:o.mainPresence;if(void 0!==a&&""!==a&&!m.isEmpty(e[a])&&void 0!==(null===(t=e[a])||void 0===t?void 0:t.mainPresence)){var u=null===(i=e[a])||void 0===i?void 0:i.mainPresence;d.store.dispatch.currentUser.updateMainPresence(null===(s=e[a])||void 0===s?void 0:s.mainPresence),"online"===u&&"online"!==r&&c.eventDispatch("phone-island-call-ended",{})}})),r.useEventListener("phone-island-call-status",(function(){var e=d.store.getState().currentCall;console.log("Call status debug informations: ",e)}));var re=function(e,n,t,i){var s=d.store.getState().paramUrl;if(null==s?void 0:s.hasValidUrl){var a=s.url||"";if(a){var o=d.store.getState().island.urlOpened,r=s.openParamUrlType;if(!o||"button"===r){var u=a;u.includes("$CALLER_NUMBER")&&e&&(u=u.replace(/\$CALLER_NUMBER/g,encodeURIComponent(e))),u.includes("$CALLER_NAME")&&n&&(u=u.replace(/\$CALLER_NAME/g,encodeURIComponent(n))),u.includes("$UNIQUEID")&&i&&(u=u.replace(/\$UNIQUEID/g,encodeURIComponent(i))),u.includes("$CALLED")&&t&&(u=u.replace(/\$CALLED/g,encodeURIComponent(t))),u.includes("{phone}")&&e&&(u=u.replace(/\{phone\}/g,encodeURIComponent(e)));var l=u.startsWith("http")?u:"https://".concat(u);if("mobile"===T||C)c.eventDispatch("phone-island-url-parameter-opened-external",{formattedUrl:l});else{var p=window.open("about:blank","_blank");p&&(p.location.href=l,d.store.dispatch.island.setUrlOpened(!0))}}}}};return r.useEventListener("phone-island-already-opened-external-page",(function(){d.store.dispatch.island.setUrlOpened(!0)})),r.useEventListener("phone-island-url-parameter-opened",(function(e){var n=d.store.getState().paramUrl;if(n.hasValidUrl&&!d.store.getState().island.urlOpened){var t=n.onlyQueues||!1,i=b.isFromTrunk(null==e?void 0:e.counterpartNum);d.store.dispatch.paramUrl.setThroughTrunk(i),"in"===(null==e?void 0:e.direction)&&(!0===t&&!0===(null==e?void 0:e.throughQueue)?re(null==e?void 0:e.counterpartNum,null==e?void 0:e.counterpartName,null==e?void 0:e.owner,null==e?void 0:e.uniqueId):!1!==t||!0!==i&&!0!==(null==e?void 0:e.throughQueue)||re(null==e?void 0:e.counterpartNum,null==e?void 0:e.counterpartName,null==e?void 0:e.owner,null==e?void 0:e.uniqueId))}})),r.useEventListener("phone-island-user-status",(function(){var e=d.store.getState().currentUser;console.log("User status debug informations: ",e)})),r.useEventListener("phone-island-all-users-status",(function(){var e=d.store.getState().users;console.log("Users status debug informations: ",e)})),r.useEventListener("phone-island-status",(function(){var e=d.store.getState().island;console.log("Phone island status debug informations: ",e)})),r.useEventListener("phone-island-webrtc-status",(function(){var e=d.store.getState().webrtc;console.log("Webrtc status debug informations: ",e)})),r.useEventListener("phone-island-player-status",(function(){var e=d.store.getState().player;console.log("Player status debug informations: ",e)})),r.useEventListener("phone-island-conference-status",(function(){var e=d.store.getState().conference;console.log("Webrtc status debug informations: ",e)})),r.useEventListener("phone-island-streaming-status",(function(){var e=d.store.getState().streaming;console.log("Streaming status debug informations: ",e)})),r.useEventListener("phone-island-paramurl-status",(function(){var e=d.store.getState().paramUrl;console.log("Paramurl status debug informations: ",e)})),r.useEventListener("phone-island-player-force-stop",(function(){d.store.dispatch.player.reset(),console.log("Audio player is interrupted")})),r.useEventListener("phone-island-stores-download",(function(){d.downloadStoresAsJSON(),c.eventDispatch("phone-island-stores-downloaded",{})})),r.useEventListener("phone-island-sideview-open",(function(){d.store.dispatch.island.toggleSideViewVisible(!0),d.store.dispatch.island.setUrlOpened(!1),c.eventDispatch("phone-island-sideview-opened",{})})),r.useEventListener("phone-island-sideview-close",(function(){d.store.dispatch.island.toggleSideViewVisible(!1),c.eventDispatch("phone-island-sideview-closed",{})})),r.useEventListener("phone-island-transcription-close",(function(){d.store.dispatch.island.toggleTranscriptionViewVisible(!1),c.eventDispatch("phone-island-stop-transcription",{}),c.eventDispatch("phone-island-transcription-closed",{})})),r.useEventListener("phone-island-transcription-open",(function(){c.eventDispatch("phone-island-start-transcription",{}),d.store.dispatch.island.toggleTranscriptionViewVisible(!0),c.eventDispatch("phone-island-transcription-opened",{})})),r.useEventListener("phone-island-transcription-close",(function(){d.store.dispatch.island.toggleTranscriptionViewVisible(!1),c.eventDispatch("phone-island-transcription-closed",{})})),r.useEventListener("phone-island-init-audio",(function(){var e=d.store.getState().currentCall,n=e.accepted,t=e.incoming,i=e.outgoing,s=e.incomingWebRTC,a=e.incomingSocket;if(n||t||i||s||a)console.log("[AUDIO-WARMUP] Skipping audio warm-up: active call in progress");else if(P&&"string"==typeof P&&0!==P.length){var o=d.store.getState().currentUser.featureCodes,r=null==o?void 0:o.audio_test,c=r&&"string"==typeof r&&r.length>0?r:"*41";console.log("[AUDIO-WARMUP] Starting audio warm-up test call",{codeToCall:c,SIP_HOST:P}),E.callNumber(c,P)}else console.warn("[AUDIO-WARMUP] Skipping audio warm-up: SIP_HOST not available",{SIP_HOST:P})})),r.useEventListener("phone-island-transcription-toggle",(function(){var e=!d.store.getState().island.transcriptionViewIsVisible;d.store.dispatch.island.toggleTranscriptionViewVisible(e),c.eventDispatch(e?"phone-island-transcription-opened":"phone-island-transcription-closed",{})})),r.useEventListener("phone-island-size-change",(function(n){var t=d.store.getState().island,i=t.sideViewIsVisible,s=t.transcriptionViewIsVisible,a=t.actionsExpanded,o=n.sizeInformation,r=e.__assign(e.__assign({},o),{right:i?"42px":"0px",top:I.isBackCallActive()?"40px":"0px",bottomTranscription:s&&a?"335px":s&&!a?"330px":"0px"});c.eventDispatch("phone-island-size-changed",{sizes:r})})),r.useEventListener("phone-island-call-ended",(function(){if("online"===d.store.getState().currentUser.mainPresence){c.eventDispatch("phone-island-size-change",{sizeInformation:{width:"0px",height:"0px"}}),c.eventDispatch("phone-island-sideview-close",{}),d.store.dispatch.island.handleResetIslandStore(),d.store.dispatch.paramUrl.setThroughTrunk(!1)}})),r.useEventListener("phone-island-conference-list-open",(function(){d.store.dispatch.island.toggleConferenceList(!0),c.eventDispatch("phone-island-conference-list-opened",{})})),r.useEventListener("phone-island-alert-removed",(function(e){var n=d.store.getState().alerts.status.activeAlertsCount,t=d.store.getState().island,i=t.view,s=t.previousView,a=d.store.getState().conference.isActive,o=d.store.getState().alerts.data,r=d.store.getState().currentCall,u=r.incoming,l=r.outgoing,p=r.accepted,v=null==e?void 0:e.type,h=r.incoming||r.outgoing||r.accepted||""!==r.conversationId;if(!(u||l||p||n>0||"player"===i||"recorder"===i||"physicalPhoneRecorder"===i||"waitingConference"===i&&a||"transfer"===i&&a||"settings"===i&&a||"settings"===i&&("recorder"===s||"player"===s)||"operatorBusy"===i&&!a)&&0===n&&(!v||o[v]&&!o[v].active)&&!h){c.eventDispatch("phone-island-size-change",{sizeInformation:{width:"0px",height:"0px"}}),c.eventDispatch("phone-island-sideview-close",{}),d.store.dispatch.island.handleResetIslandStore()}})),r.useEventListener("phone-island-conference-list-close",(function(){d.store.dispatch.island.toggleConferenceList(!1),c.eventDispatch("phone-island-conference-list-closed",{})})),r.useEventListener("phone-island-conversations",(function(e){var n,t=Object.keys(e)[0];if(t===(null===(n=d.store.getState().currentUser)||void 0===n?void 0:n.username)){var i=e[t].conversations,s=d.store.getState().paramUrl,a=d.store.getState().island.urlOpened;if(!s.hasValidUrl||a)return;if("answered"===s.openParamUrlType&&i&&Object.keys(i).length>0){var o=i[Object.keys(i)[0]];if((null==o?void 0:o.connected)&&"in"===(null==o?void 0:o.direction)){var r=s.onlyQueues||!1,c=b.isFromTrunk(o.counterpartNum);d.store.dispatch.paramUrl.setThroughTrunk(c),!0===r&&!0===(null==o?void 0:o.throughQueue)?re(o.counterpartNum,o.counterpartName,o.owner,o.uniqueId):!1!==r||!0!==c&&!0!==(null==o?void 0:o.throughQueue)||re(o.counterpartNum,o.counterpartName,o.owner,o.uniqueId)}}}})),y.default.createElement(y.default.Fragment,null,y.default.createElement(D.default,{store:d.store},R&&""!==R.trim()?y.default.createElement(s.WebRTC,{hostName:O,sipExten:R,sipSecret:V,sipHost:P,sipPort:x,reload:W,reloadedCallback:function(){return z(!0)},uaType:T},y.default.createElement(o.RestAPI,{hostName:O,username:A,authToken:q},y.default.createElement(i.Socket,{hostName:O,username:A,authToken:q,reload:W,reloadedCallback:function(){return B(!0)},uaType:T},y.default.createElement(t.Events,{sipHost:P},y.default.createElement(a.Island,{showAlways:U,uaType:T}))))):y.default.createElement(o.RestAPI,{hostName:O,username:A,authToken:q},y.default.createElement(i.Socket,{hostName:O,username:A,authToken:q,reload:W,reloadedCallback:function(){B(!0),z(!0)},uaType:T},y.default.createElement(t.Events,{sipHost:P},y.default.createElement(a.Island,{showAlways:U,uaType:T}))))))}));_.displayName="PhoneIslandComponent";var k=n.forwardRef((function(n,t){return y.default.createElement(_,e.__assign({},n,{ref:t}))}));k.displayName="PhoneIsland",exports.PhoneIsland=k;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("./node_modules/tslib/tslib.es6.js"),t=require("react"),n=require("./components/Events.js"),i=require("./components/Socket.js"),s=require("./components/WebRTC.js"),a=require("./components/Island.js"),o=require("./components/RestAPI.js"),r=require("./utils/customHooks/useEventListener.js"),c=require("./utils/genericFunctions/eventDispatch.js"),u=require("./utils/genericFunctions/localStorage.js"),d=require("./store/index.js"),l=require("./services/user.js");require("./node_modules/react-redux/es/index.js"),require("./node_modules/@fortawesome/react-fontawesome/index.es.js"),require("./node_modules/i18next/dist/esm/i18next.js"),require("./node_modules/react-tooltip/dist/react-tooltip.min.mjs.js"),require("./components/TranscriptionView/TranscriptionView.js");var p=require("./node_modules/js-base64/base64.mjs.js"),v=require("./workers/wake_up.js"),h=require("./lib/i18n.js");require("./node_modules/react-tooltip/dist/react-tooltip.min.css.js");var f=require("./lib/webrtc/messages.js"),g=require("./lib/darkTheme.js"),m=require("./utils/genericFunctions/isEmpty.js"),w=require("./utils/genericFunctions/checkConnection.js"),I=require("./utils/genericFunctions/isBackCallVisible.js"),b=require("./lib/phone/trunk.js"),E=require("./lib/phone/call.js"),D=require("./node_modules/react-redux/es/components/Provider.js");function S(e){return e&&"object"==typeof e&&"default"in e?e:{default:e}}require("./node_modules/hoist-non-react-statics/dist/hoist-non-react-statics.cjs.js"),require("./node_modules/react-redux/node_modules/react-is/index.js"),require("./node_modules/react-redux/es/components/Context.js");var y=S(t),_=t.forwardRef((function(S,_){var k=S.dataConfig,L=S.showAlways,U=void 0!==L&&L,T=S.uaType,j=S.urlParamWithEvent,C=void 0!==j&&j,N=p.Base64.atob(k||"").split(":"),O=N[0],A=N[1],q=N[2],R=N[3],V=N[4],P=N[5],x=N[6],J=t.useState(!1),W=J[0],F=J[1],M=t.useState(!1),Q=M[0],z=M[1],H=t.useState(!1),$=H[0],B=H[1],G=t.useRef(0);t.useImperativeHandle(_,(function(){return{reset:function(){console.info("PhoneIsland: Performing full component reset"),F(!0)}}}),[]),t.useEffect((function(){var e=Date.now(),t=function(){if(!document.hidden){var t=Date.now(),n=t-e;setTimeout((function(){c.eventDispatch("phone-island-emergency-stop-ringtone",{})}),2e3),n>3e5&&(console.info("Tab inactive for long period, performing soft reconnection"),F(!0)),e=t}},n=new Worker(v.default,{type:"module"});return n.onmessage=function(t){"ping"===t.data&&(e=Date.now())},document.addEventListener("visibilitychange",t),function(){n.terminate(),document.removeEventListener("visibilitychange",t)}}),[]),t.useEffect((function(){$&&Q&&(F(!1),z(!1),B(!1))}),[$,Q]),t.useEffect((function(){var e=setInterval((function(){var e,t,n,i,s=d.store.getState().alerts.data,a=(null===(e=s.webrtc_down)||void 0===e?void 0:e.active)||!1,o=(null===(t=s.socket_down)||void 0===t?void 0:t.active)||!1,r=Date.now(),c=r-G.current,u=d.store.getState().webrtc.sipcall,l=d.store.getState().currentCall,p=l.accepted,v=l.outgoing,h=null===(i=null===(n=null==u?void 0:u.webrtcStuff)||void 0===n?void 0:n.pc)||void 0===i?void 0:i.iceConnectionState,f=p||v||"connected"===h||"completed"===h,g=navigator.onLine;if((a||o)&&!W&&c>1e4&&g){if(f)return void console.info("Alert detected but active call in progress - skipping automatic reload to let ICE recover",{timeSinceLastReload:Math.round(c/1e3)+"s",isWebRTCDown:a,isSocketDown:o,iceState:h,accepted:p,outgoing:v});console.info("Alert detected (webrtc_down or socket_down), triggering automatic reload",{timeSinceLastReload:Math.round(c/1e3)+"s",isWebRTCDown:a,isSocketDown:o}),G.current=r,F(!0)}}),1e3);return function(){return clearInterval(e)}}),[W]),r.useEventListener("phone-island-expand",(function(){d.store.dispatch.island.toggleIsOpen(!0),c.eventDispatch("phone-island-expanded",{})})),r.useEventListener("phone-island-compress",(function(){d.store.dispatch.island.toggleIsOpen(!1),c.eventDispatch("phone-island-compressed",{})})),r.useEventListener("phone-island-call-keypad-close",(function(){d.store.dispatch.island.setIslandView("call"),c.eventDispatch("phone-island-call-keypad-closed",{})})),r.useEventListener("phone-island-call-transfer-close",(function(){d.store.dispatch.island.setIslandView("call"),c.eventDispatch("phone-island-call-transfer-closed",{})})),r.useEventListener("phone-island-recording-close",(function(){d.store.dispatch.island.setIslandView(null),c.eventDispatch("phone-island-recording-closed",{})})),r.useEventListener("phone-island-audio-player-close",(function(){d.store.dispatch.island.setIslandView(null),c.eventDispatch("phone-island-audio-player-closed",{})})),r.useEventListener("phone-island-emergency-stop-ringtone",(function(){null===d.store.getState().island.view?(console.warn("Emergency stop ringtone triggered - phone island inactive"),d.store.dispatch.player.emergencyStopAudioPlayer(),c.eventDispatch("phone-island-emergency-stop-ringtone-completed",{})):console.log("Phone island is active, ringtone stop ignored")})),r.useEventListener("phone-island-detach",(function(e){f.detach(),c.eventDispatch("phone-island-detached",{})})),r.useEventListener("phone-island-reload-component",(function(e){(null==e?void 0:e.force)&&d.store.dispatch.island.setForceReload(!0),F(!0)})),r.useEventListener("phone-island-audio-input-change",(function(t){return e.__awaiter(void 0,void 0,void 0,(function(){var n;return e.__generator(this,(function(e){switch(e.label){case 0:return(n=t.deviceId)&&"default"!==n?[4,ne(n)]:[3,3];case 1:return e.sent()?[3,3]:(console.warn("Audio input device ".concat(n," not available, falling back to default device")),[4,ie()]);case 2:n=e.sent(),e.label=3;case 3:return u.setJSONItem("phone-island-audio-input-device",{deviceId:n}),c.eventDispatch("phone-island-audio-input-changed",{}),n!==t.deviceId&&console.info("Audio input device changed from ".concat(t.deviceId," to ").concat(n," (fallback)")),[2]}}))}))})),r.useEventListener("phone-island-video-input-change",(function(t){return e.__awaiter(void 0,void 0,void 0,(function(){var n;return e.__generator(this,(function(e){switch(e.label){case 0:return(n=t.deviceId)&&"default"!==n?[4,se(n)]:[3,3];case 1:return e.sent()?[3,3]:(console.warn("Video input device ".concat(n," not available, falling back to default device")),[4,ae()]);case 2:n=e.sent(),e.label=3;case 3:return u.setJSONItem("phone-island-video-input-device",{deviceId:n}),c.eventDispatch("phone-island-video-input-changed",{}),n!==t.deviceId&&console.info("Video input device changed from ".concat(t.deviceId," to ").concat(n," (fallback)")),[2]}}))}))}));var K=t.useState(!0),X=K[0],Y=K[1],Z=t.useState(!0),ee=Z[0],te=Z[1];t.useEffect((function(){X&&(h.initI18n(),e.__awaiter(void 0,void 0,void 0,(function(){var t,n,i,s;return e.__generator(this,(function(e){switch(e.label){case 0:return e.trys.push([0,2,,3]),[4,l.getParamUrl()];case 1:return t=e.sent(),n=(null==t?void 0:t.url)||"",i=n&&""!==n.trim(),d.store.dispatch.paramUrl.setParamUrl({url:n,onlyQueues:(null==t?void 0:t.only_queues)||!1,hasValidUrl:i}),[3,3];case 2:return s=e.sent(),console.error("Error fetching URL parameter:",s),d.store.dispatch.paramUrl.setParamUrl({url:"",onlyQueues:!1,hasValidUrl:!1}),[3,3];case 3:return[2]}}))})),Y(!1))}),[X]);var ne=function(t){return e.__awaiter(void 0,void 0,void 0,(function(){var n,i;return e.__generator(this,(function(e){switch(e.label){case 0:return e.trys.push([0,2,,3]),navigator.mediaDevices&&navigator.mediaDevices.enumerateDevices?[4,navigator.mediaDevices.enumerateDevices()]:[2,!1];case 1:return n=e.sent(),[2,n.filter((function(e){return"audioinput"===e.kind})).some((function(e){return e.deviceId===t}))];case 2:return i=e.sent(),console.warn("Error checking audio input device availability:",i),[2,!1];case 3:return[2]}}))}))},ie=function(){return e.__awaiter(void 0,void 0,void 0,(function(){var t,n,i,s;return e.__generator(this,(function(e){switch(e.label){case 0:return e.trys.push([0,2,,3]),navigator.mediaDevices&&navigator.mediaDevices.enumerateDevices?[4,navigator.mediaDevices.enumerateDevices()]:[2,"default"];case 1:return t=e.sent(),n=t.filter((function(e){return"audioinput"===e.kind})),[2,(i=n.find((function(e){return"default"===e.deviceId||""===e.deviceId}))||n[0])?i.deviceId:"default"];case 2:return s=e.sent(),console.warn("Error getting default audio input device:",s),[2,"default"];case 3:return[2]}}))}))},se=function(t){return e.__awaiter(void 0,void 0,void 0,(function(){var n,i;return e.__generator(this,(function(e){switch(e.label){case 0:return e.trys.push([0,2,,3]),navigator.mediaDevices&&navigator.mediaDevices.enumerateDevices?[4,navigator.mediaDevices.enumerateDevices()]:[2,!1];case 1:return n=e.sent(),[2,n.filter((function(e){return"videoinput"===e.kind})).some((function(e){return e.deviceId===t}))];case 2:return i=e.sent(),console.warn("Error checking video input device availability:",i),[2,!1];case 3:return[2]}}))}))},ae=function(){return e.__awaiter(void 0,void 0,void 0,(function(){var t,n,i,s;return e.__generator(this,(function(e){switch(e.label){case 0:return e.trys.push([0,2,,3]),navigator.mediaDevices&&navigator.mediaDevices.enumerateDevices?[4,navigator.mediaDevices.enumerateDevices()]:[2,"default"];case 1:return t=e.sent(),n=t.filter((function(e){return"videoinput"===e.kind})),[2,(i=n.find((function(e){return"default"===e.deviceId||""===e.deviceId}))||n[0])?i.deviceId:"default"];case 2:return s=e.sent(),console.warn("Error getting default video input device:",s),[2,"default"];case 3:return[2]}}))}))};r.useEventListener("phone-island-audio-output-change",(function(t){e.__awaiter(void 0,void 0,void 0,(function(){var n,i,s,a,o,r,l,p,v;return e.__generator(this,(function(h){switch(h.label){case 0:return(null==(n=d.store.getState().player.remoteAudio)?void 0:n.current)?(i=t.deviceId)&&"default"!==i?[4,(f=i,e.__awaiter(void 0,void 0,void 0,(function(){var t;return e.__generator(this,(function(e){switch(e.label){case 0:return e.trys.push([0,2,,3]),navigator.mediaDevices&&navigator.mediaDevices.enumerateDevices?[4,navigator.mediaDevices.enumerateDevices()]:[2,!1];case 1:return[2,e.sent().filter((function(e){return"audiooutput"===e.kind})).some((function(e){return e.deviceId===f}))];case 2:return t=e.sent(),console.warn("Error checking device availability:",t),[2,!1];case 3:return[2]}}))})))]:[3,3]:(console.warn("Remote audio element not available"),[2]);case 1:return h.sent()?[3,3]:(console.warn("Audio output device ".concat(i," not available, falling back to default device")),[4,e.__awaiter(void 0,void 0,void 0,(function(){var t,n,i,s;return e.__generator(this,(function(e){switch(e.label){case 0:return e.trys.push([0,2,,3]),navigator.mediaDevices&&navigator.mediaDevices.enumerateDevices?[4,navigator.mediaDevices.enumerateDevices()]:[2,"default"];case 1:return t=e.sent(),n=t.filter((function(e){return"audiooutput"===e.kind})),[2,(i=n.find((function(e){return"default"===e.deviceId||""===e.deviceId}))||n[0])?i.deviceId:"default"];case 2:return s=e.sent(),console.warn("Error getting default device:",s),[2,"default"];case 3:return[2]}}))}))]);case 2:i=h.sent(),u.setJSONItem("phone-island-audio-output-device",{deviceId:i}),h.label=3;case 3:return h.trys.push([3,5,,15]),[4,n.current.setSinkId(i)];case 4:return h.sent(),console.info("Default audio output device changed successfully!"),u.setJSONItem("phone-island-audio-output-device",{deviceId:i}),c.eventDispatch("phone-island-audio-output-changed",{}),[3,15];case 5:s=h.sent(),console.log("Direct setSinkId failed, trying with temporary stream:",s),h.label=6;case 6:return h.trys.push([6,7,,14]),a=new(window.AudioContext||window.webkitAudioContext),o=a.createOscillator(),r=a.createGain(),o.frequency.setValueAtTime(440,a.currentTime),r.gain.setValueAtTime(0,a.currentTime),o.connect(r),l=a.createMediaStreamDestination(),r.connect(l),n.current.srcObject=l.stream,o.start(),setTimeout((function(){return e.__awaiter(void 0,void 0,void 0,(function(){var t,s;return e.__generator(this,(function(e){switch(e.label){case 0:return e.trys.push([0,2,,7]),[4,n.current.setSinkId(i)];case 1:return e.sent(),console.info("Default audio output device changed successfully with temporary stream!"),o.stop(),a.close(),n.current.srcObject=null,u.setJSONItem("phone-island-audio-output-device",{deviceId:i}),c.eventDispatch("phone-island-audio-output-changed",{}),[3,7];case 2:if(t=e.sent(),console.error("Final setSinkId attempt failed:",t),o.stop(),a.close(),n.current.srcObject=null,"default"===i)return[3,6];console.log("Trying fallback to default device"),e.label=3;case 3:return e.trys.push([3,5,,6]),[4,n.current.setSinkId("default")];case 4:return e.sent(),u.setJSONItem("phone-island-audio-output-device",{deviceId:"default"}),console.info("Fallback to default audio device successful"),[3,6];case 5:return s=e.sent(),console.error("Even default device failed:",s),[3,6];case 6:return u.setJSONItem("phone-island-audio-output-device",{deviceId:i}),c.eventDispatch("phone-island-audio-output-changed",{}),[3,7];case 7:return[2]}}))}))}),100),[3,14];case 7:if(p=h.sent(),console.error("Failed to create temporary audio stream:",p),"default"===i)return[3,12];h.label=8;case 8:return h.trys.push([8,10,,11]),[4,n.current.setSinkId("default")];case 9:return h.sent(),u.setJSONItem("phone-island-audio-output-device",{deviceId:"default"}),console.info("Emergency fallback to default audio device successful"),[3,11];case 10:return v=h.sent(),console.error("Emergency fallback to default device failed:",v),u.setJSONItem("phone-island-audio-output-device",{deviceId:i}),[3,11];case 11:return[3,13];case 12:u.setJSONItem("phone-island-audio-output-device",{deviceId:i}),h.label=13;case 13:return c.eventDispatch("phone-island-audio-output-changed",{}),[3,14];case 14:return[3,15];case 15:return[2]}var f}))}))})),r.useEventListener("phone-island-presence-change",(function(e){l.changeOperatorStatus(e),c.eventDispatch("phone-island-presence-changed",{})})),r.useEventListener("phone-island-view-changed",(function(e){var t=null==e?void 0:e.viewType;d.store.dispatch.island.setIslandView(t)}));var oe=d.store.getState().player.remoteAudio;t.useEffect((function(){var e;if(ee&&oe){var t=null===(e=u.getJSONItem("phone-island-audio-output-device"))||void 0===e?void 0:e.deviceId;c.eventDispatch("phone-island-audio-output-change",{deviceId:t}),te(!1)}}),[ee,oe]),t.useEffect((function(){g.checkDarkTheme()}),[]),r.useEventListener("phone-island-theme-change",(function(e){g.setTheme(null==e?void 0:e.selectedTheme)})),r.useEventListener("phone-island-default-device-change",(function(e){d.store.dispatch.currentUser.updateCurrentDefaultDevice(null==e?void 0:e.deviceInformationObject),c.eventDispatch("phone-island-default-device-changed",{})})),r.useEventListener("phone-island-alert",(function(e){d.store.dispatch.alerts.setAlert(e.toString())})),r.useEventListener("phone-island-ringing-tone-list",(function(){var e=d.store.getState().ringtones.availableRingtones.map((function(e){return{name:e.name,displayName:e.displayName,base64Audio:e.base64Audio}}));c.eventDispatch("phone-island-ringing-tone-list-response",{ringtones:e})})),r.useEventListener("phone-island-ringing-tone-select",(function(e){(null==e?void 0:e.name)&&(u.setJSONItem("phone-island-selected-ringtone",{value:e.name}),d.store.dispatch.ringtones.setSelectedRingtone(e.name),c.eventDispatch("phone-island-ringing-tone-selected",{name:e.name}))})),r.useEventListener("phone-island-ringing-tone-output",(function(e){(null==e?void 0:e.deviceId)&&(u.setJSONItem("phone-island-ringtone-output-device",{value:e.deviceId}),d.store.dispatch.ringtones.setOutputDeviceId(e.deviceId),c.eventDispatch("phone-island-ringing-tone-output-changed",{deviceId:e.deviceId}))})),t.useEffect((function(){var e=u.getJSONItem("phone-island-selected-ringtone"),t=u.getJSONItem("phone-island-ringtone-output-device");(null==e?void 0:e.value)&&d.store.dispatch.ringtones.setSelectedRingtone(e.value),(null==t?void 0:t.value)&&d.store.dispatch.ringtones.setOutputDeviceId(t.value)}),[]),r.useEventListener("phone-island-check-connection",(function(){w.checkInternetConnection().then((function(e){e?c.eventDispatch("phone-island-internet-connected",{}):c.eventDispatch("phone-island-internet-disconnected",{})}))})),t.useEffect((function(){var e=setInterval((function(){w.checkInternetConnection().then((function(e){e?c.eventDispatch("phone-island-internet-connected",{}):c.eventDispatch("phone-island-internet-disconnected",{})}))}),5e3);return function(){return clearInterval(e)}}),[]),r.useEventListener("phone-island-main-presence",(function(e){var t,n,i,s,a=null===(t=d.store.getState().currentUser)||void 0===t?void 0:t.username,o=d.store.getState().currentUser,r=null==o?void 0:o.mainPresence;if(void 0!==a&&""!==a&&!m.isEmpty(e[a])&&void 0!==(null===(n=e[a])||void 0===n?void 0:n.mainPresence)){var u=null===(i=e[a])||void 0===i?void 0:i.mainPresence;d.store.dispatch.currentUser.updateMainPresence(null===(s=e[a])||void 0===s?void 0:s.mainPresence),"online"===u&&"online"!==r&&c.eventDispatch("phone-island-call-ended",{})}})),r.useEventListener("phone-island-call-status",(function(){var e=d.store.getState().currentCall;console.log("Call status debug informations: ",e)}));var re=function(e,t,n,i,s){var a=d.store.getState().paramUrl;if(null==a?void 0:a.hasValidUrl){var o=a.url||"";if(o){var r=d.store.getState().island.urlOpened,u=a.openParamUrlType;if(!r||"button"===u){var l=o;l.includes("$CALLER_NUMBER")&&e&&(l=l.replace(/\$CALLER_NUMBER/g,encodeURIComponent(e))),l.includes("$CALLER_NAME")&&t&&(l=l.replace(/\$CALLER_NAME/g,encodeURIComponent(t))),l.includes("$UNIQUEID")&&i&&(l=l.replace(/\$UNIQUEID/g,encodeURIComponent(i))),l.includes("$CALLED")&&n&&(l=l.replace(/\$CALLED/g,encodeURIComponent(n))),l.includes("{phone}")&&e&&(l=l.replace(/\{phone\}/g,encodeURIComponent(e)));var p=l.startsWith("http")?l:"https://".concat(l);if("mobile"!==T&&!C&&s){var v=window.open("about:blank","_blank");v&&(v.location.href=p,d.store.dispatch.island.setUrlOpened(!0))}else c.eventDispatch("phone-island-url-parameter-opened-external",{formattedUrl:p})}}}};return r.useEventListener("phone-island-already-opened-external-page",(function(){d.store.dispatch.island.setUrlOpened(!0)})),r.useEventListener("phone-island-url-parameter-opened",(function(e){var t=d.store.getState().paramUrl;if(t.hasValidUrl&&!d.store.getState().island.urlOpened){var n=t.onlyQueues||!1,i=b.isFromTrunk(null==e?void 0:e.counterpartNum);d.store.dispatch.paramUrl.setThroughTrunk(i);var s=d.store.getState().currentUser.default_device,a=!("desktop"===T&&"nethlink"===(null==s?void 0:s.type));"in"===(null==e?void 0:e.direction)&&(!0===n&&!0===(null==e?void 0:e.throughQueue)?re(null==e?void 0:e.counterpartNum,null==e?void 0:e.counterpartName,null==e?void 0:e.owner,null==e?void 0:e.linkedId,a):!1!==n||!0!==i&&!0!==(null==e?void 0:e.throughQueue)||re(null==e?void 0:e.counterpartNum,null==e?void 0:e.counterpartName,null==e?void 0:e.owner,null==e?void 0:e.linkedId,a))}})),r.useEventListener("phone-island-user-status",(function(){var e=d.store.getState().currentUser;console.log("User status debug informations: ",e)})),r.useEventListener("phone-island-all-users-status",(function(){var e=d.store.getState().users;console.log("Users status debug informations: ",e)})),r.useEventListener("phone-island-status",(function(){var e=d.store.getState().island;console.log("Phone island status debug informations: ",e)})),r.useEventListener("phone-island-webrtc-status",(function(){var e=d.store.getState().webrtc;console.log("Webrtc status debug informations: ",e)})),r.useEventListener("phone-island-player-status",(function(){var e=d.store.getState().player;console.log("Player status debug informations: ",e)})),r.useEventListener("phone-island-conference-status",(function(){var e=d.store.getState().conference;console.log("Webrtc status debug informations: ",e)})),r.useEventListener("phone-island-streaming-status",(function(){var e=d.store.getState().streaming;console.log("Streaming status debug informations: ",e)})),r.useEventListener("phone-island-paramurl-status",(function(){var e=d.store.getState().paramUrl;console.log("Paramurl status debug informations: ",e)})),r.useEventListener("phone-island-player-force-stop",(function(){d.store.dispatch.player.reset(),console.log("Audio player is interrupted")})),r.useEventListener("phone-island-stores-download",(function(){d.downloadStoresAsJSON(),c.eventDispatch("phone-island-stores-downloaded",{})})),r.useEventListener("phone-island-sideview-open",(function(){d.store.dispatch.island.toggleSideViewVisible(!0),d.store.dispatch.island.setUrlOpened(!1),c.eventDispatch("phone-island-sideview-opened",{})})),r.useEventListener("phone-island-sideview-close",(function(){d.store.dispatch.island.toggleSideViewVisible(!1),c.eventDispatch("phone-island-sideview-closed",{})})),r.useEventListener("phone-island-transcription-close",(function(){d.store.dispatch.island.toggleTranscriptionViewVisible(!1),c.eventDispatch("phone-island-stop-transcription",{}),c.eventDispatch("phone-island-transcription-closed",{})})),r.useEventListener("phone-island-transcription-open",(function(){c.eventDispatch("phone-island-start-transcription",{}),d.store.dispatch.island.toggleTranscriptionViewVisible(!0),c.eventDispatch("phone-island-transcription-opened",{})})),r.useEventListener("phone-island-transcription-close",(function(){d.store.dispatch.island.toggleTranscriptionViewVisible(!1),c.eventDispatch("phone-island-transcription-closed",{})})),r.useEventListener("phone-island-init-audio",(function(){var e=d.store.getState().currentCall,t=e.accepted,n=e.incoming,i=e.outgoing,s=e.incomingWebRTC,a=e.incomingSocket;if(t||n||i||s||a)console.log("[AUDIO-WARMUP] Skipping audio warm-up: active call in progress");else if(P&&"string"==typeof P&&0!==P.length){var o=d.store.getState().currentUser.featureCodes,r=null==o?void 0:o.audio_test,c=r&&"string"==typeof r&&r.length>0?r:"*41";console.log("[AUDIO-WARMUP] Starting audio warm-up test call",{codeToCall:c,SIP_HOST:P}),E.callNumber(c,P)}else console.warn("[AUDIO-WARMUP] Skipping audio warm-up: SIP_HOST not available",{SIP_HOST:P})})),r.useEventListener("phone-island-transcription-toggle",(function(){var e=!d.store.getState().island.transcriptionViewIsVisible;d.store.dispatch.island.toggleTranscriptionViewVisible(e),c.eventDispatch(e?"phone-island-transcription-opened":"phone-island-transcription-closed",{})})),r.useEventListener("phone-island-size-change",(function(t){var n=d.store.getState().island,i=n.sideViewIsVisible,s=n.transcriptionViewIsVisible,a=n.actionsExpanded,o=t.sizeInformation,r=e.__assign(e.__assign({},o),{right:i?"42px":"0px",top:I.isBackCallActive()?"40px":"0px",bottomTranscription:s&&a?"335px":s&&!a?"330px":"0px"});c.eventDispatch("phone-island-size-changed",{sizes:r})})),r.useEventListener("phone-island-call-ended",(function(){if("online"===d.store.getState().currentUser.mainPresence){c.eventDispatch("phone-island-size-change",{sizeInformation:{width:"0px",height:"0px"}}),c.eventDispatch("phone-island-sideview-close",{}),d.store.dispatch.island.handleResetIslandStore(),d.store.dispatch.paramUrl.setThroughTrunk(!1)}})),r.useEventListener("phone-island-conference-list-open",(function(){d.store.dispatch.island.toggleConferenceList(!0),c.eventDispatch("phone-island-conference-list-opened",{})})),r.useEventListener("phone-island-alert-removed",(function(e){var t=d.store.getState().alerts.status.activeAlertsCount,n=d.store.getState().island,i=n.view,s=n.previousView,a=d.store.getState().conference.isActive,o=d.store.getState().alerts.data,r=d.store.getState().currentCall,u=r.incoming,l=r.outgoing,p=r.accepted,v=null==e?void 0:e.type,h=r.incoming||r.outgoing||r.accepted||""!==r.conversationId;if(!(u||l||p||t>0||"player"===i||"recorder"===i||"physicalPhoneRecorder"===i||"waitingConference"===i&&a||"transfer"===i&&a||"settings"===i&&a||"settings"===i&&("recorder"===s||"player"===s)||"operatorBusy"===i&&!a)&&0===t&&(!v||o[v]&&!o[v].active)&&!h){c.eventDispatch("phone-island-size-change",{sizeInformation:{width:"0px",height:"0px"}}),c.eventDispatch("phone-island-sideview-close",{}),d.store.dispatch.island.handleResetIslandStore()}})),r.useEventListener("phone-island-conference-list-close",(function(){d.store.dispatch.island.toggleConferenceList(!1),c.eventDispatch("phone-island-conference-list-closed",{})})),r.useEventListener("phone-island-conversations",(function(e){var t,n=Object.keys(e)[0];if(n===(null===(t=d.store.getState().currentUser)||void 0===t?void 0:t.username)){var i=e[n].conversations,s=d.store.getState().paramUrl,a=d.store.getState().island.urlOpened;if(!s.hasValidUrl||a)return;if("answered"===s.openParamUrlType&&i&&Object.keys(i).length>0){var o=i[Object.keys(i)[0]];if((null==o?void 0:o.connected)&&"in"===(null==o?void 0:o.direction)){var r=s.onlyQueues||!1,c=b.isFromTrunk(o.counterpartNum);d.store.dispatch.paramUrl.setThroughTrunk(c),!0===r&&!0===(null==o?void 0:o.throughQueue)?re(o.counterpartNum,o.counterpartName,o.owner,o.uniqueId):!1!==r||!0!==c&&!0!==(null==o?void 0:o.throughQueue)||re(o.counterpartNum,o.counterpartName,o.owner,o.uniqueId)}}}})),y.default.createElement(y.default.Fragment,null,y.default.createElement(D.default,{store:d.store},R&&""!==R.trim()?y.default.createElement(s.WebRTC,{hostName:O,sipExten:R,sipSecret:V,sipHost:P,sipPort:x,reload:W,reloadedCallback:function(){return z(!0)},uaType:T},y.default.createElement(o.RestAPI,{hostName:O,username:A,authToken:q},y.default.createElement(i.Socket,{hostName:O,username:A,authToken:q,reload:W,reloadedCallback:function(){return B(!0)},uaType:T},y.default.createElement(n.Events,{sipHost:P},y.default.createElement(a.Island,{showAlways:U,uaType:T}))))):y.default.createElement(o.RestAPI,{hostName:O,username:A,authToken:q},y.default.createElement(i.Socket,{hostName:O,username:A,authToken:q,reload:W,reloadedCallback:function(){B(!0),z(!0)},uaType:T},y.default.createElement(n.Events,{sipHost:P},y.default.createElement(a.Island,{showAlways:U,uaType:T}))))))}));_.displayName="PhoneIslandComponent";var k=t.forwardRef((function(t,n){return y.default.createElement(_,e.__assign({},t,{ref:n}))}));k.displayName="PhoneIsland",exports.PhoneIsland=k;
2
2
  //# sourceMappingURL=App.js.map
package/dist/App.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"App.js","sources":["../src/App.tsx"],"sourcesContent":["import React, { type FC, useState, useEffect, forwardRef, useImperativeHandle, useRef } from 'react'\nimport { Events, Socket, WebRTC, Island, RestAPI } from './components'\nimport { Provider } from 'react-redux'\nimport { store, downloadStoresAsJSON } from './store'\nimport { Base64 } from 'js-base64'\nimport wakeUpWorker from './workers/wake_up'\nimport { initI18n } from './lib/i18n'\n\nimport 'react-tooltip/dist/react-tooltip.css'\nimport { useEventListener, eventDispatch, setJSONItem, getJSONItem } from './utils'\nimport { detach } from './lib/webrtc/messages'\nimport { checkDarkTheme, setTheme } from './lib/darkTheme'\nimport { changeOperatorStatus } from './services/user'\nimport { getParamUrl } from './services/user'\nimport { isEmpty } from './utils/genericFunctions/isEmpty'\nimport { checkInternetConnection } from './utils/genericFunctions/checkConnection'\nimport { isBackCallActive } from './utils/genericFunctions/isBackCallVisible'\nimport { isFromTrunk } from './lib/user/extensions'\nimport { callNumber } from './lib/phone/call'\n\ninterface PhoneIslandProps {\n dataConfig: string\n showAlways?: boolean\n uaType: string\n urlParamWithEvent?: boolean\n}\n\ninterface DeviceInputOutputTypes {\n deviceId: string\n}\n\nexport interface PhoneIslandRef {\n reset: () => void\n}\n\nconst PhoneIslandComponent = forwardRef<PhoneIslandRef, PhoneIslandProps>(\n (\n {\n dataConfig,\n showAlways = false,\n uaType,\n urlParamWithEvent = false,\n }: PhoneIslandProps,\n ref,\n ) => {\n const CONFIG: string[] = Base64.atob(dataConfig || '').split(':')\n const HOST_NAME: string = CONFIG[0]\n const USERNAME: string = CONFIG[1]\n const AUTH_TOKEN: string = CONFIG[2]\n const SIP_EXTEN: string = CONFIG[3]\n const SIP_SECRET: string = CONFIG[4]\n const SIP_HOST: string = CONFIG[5]\n const SIP_PORT: string = CONFIG[6]\n\n // Initialize the state to manage the reload events\n const [reload, setReload] = useState<boolean>(false)\n const [reloadedWebRTC, setReloadedWebRTC] = useState<boolean>(false)\n const [reloadedSocket, setReloadedSocket] = useState<boolean>(false)\n\n // Cooldown to prevent reload loop when network is down\n const lastReloadTime = useRef<number>(0)\n const RELOAD_COOLDOWN = 10 * 1000 // 10 seconds between reload attempts\n\n // Expose reset method via imperativeHandle\n useImperativeHandle(\n ref,\n () => ({\n reset: () => {\n console.info('PhoneIsland: Performing full component reset')\n setReload(true)\n },\n }),\n [],\n )\n\n // Keepalive system to maintain tab active without heavy reload\n useEffect(() => {\n let lastActiveTime = Date.now()\n const INACTIVITY_THRESHOLD = 5 * 60 * 1000 // 5 minutes\n\n // Handle visibility change (tab becomes visible/hidden)\n const handleVisibilityChange = () => {\n if (!document.hidden) {\n const now = Date.now()\n const timeSinceLastActive = now - lastActiveTime\n // Trigger emergency stop ringtone after 2 seconds when tab becomes active again\n setTimeout(() => {\n eventDispatch('phone-island-emergency-stop-ringtone', {})\n }, 2000)\n\n // Only reload if tab was hidden for more than threshold\n if (timeSinceLastActive > INACTIVITY_THRESHOLD) {\n console.info('Tab inactive for long period, performing soft reconnection')\n setReload(true)\n }\n lastActiveTime = now\n }\n }\n\n // Lightweight worker for keepalive ping\n const worker = new Worker(wakeUpWorker, { type: 'module' })\n worker.onmessage = (event: MessageEvent<string>) => {\n if (event.data === 'ping') {\n // Simple ping to keep tab active - no action needed\n lastActiveTime = Date.now()\n }\n }\n\n // Listen for visibility changes\n document.addEventListener('visibilitychange', handleVisibilityChange)\n\n return () => {\n worker.terminate()\n document.removeEventListener('visibilitychange', handleVisibilityChange)\n }\n }, [])\n\n useEffect(() => {\n if (reloadedSocket && reloadedWebRTC) {\n setReload(false)\n setReloadedWebRTC(false)\n setReloadedSocket(false)\n }\n }, [reloadedSocket, reloadedWebRTC])\n\n // Monitor alerts and trigger automatic reload when webrtc_down or socket_down become active\n useEffect(() => {\n const checkInterval = setInterval(() => {\n const { data } = store.getState().alerts\n const isWebRTCDown = data.webrtc_down?.active || false\n const isSocketDown = data.socket_down?.active || false\n const now = Date.now()\n const timeSinceLastReload = now - lastReloadTime.current\n\n // Check if there's an active call - if so, don't reload automatically\n // WebRTC/ICE is designed to recover from brief network interruptions\n const { sipcall }: { sipcall: any } = store.getState().webrtc\n const { accepted, outgoing } = store.getState().currentCall\n const iceState = sipcall?.webrtcStuff?.pc?.iceConnectionState\n const hasActiveCall = accepted || outgoing || iceState === 'connected' || iceState === 'completed'\n\n // If either alert is active and we're not already reloading and cooldown has passed\n // Don't trigger reload if we're completely offline - wait for network to come back\n // Don't trigger reload if there's an active call - let ICE try to recover\n const isOnline = navigator.onLine\n if ((isWebRTCDown || isSocketDown) && !reload && timeSinceLastReload > RELOAD_COOLDOWN && isOnline) {\n if (hasActiveCall) {\n console.info('Alert detected but active call in progress - skipping automatic reload to let ICE recover', {\n timeSinceLastReload: Math.round(timeSinceLastReload / 1000) + 's',\n isWebRTCDown,\n isSocketDown,\n iceState,\n accepted,\n outgoing\n })\n // Don't reload - let ICE try to recover the call\n return\n }\n console.info('Alert detected (webrtc_down or socket_down), triggering automatic reload', {\n timeSinceLastReload: Math.round(timeSinceLastReload / 1000) + 's',\n isWebRTCDown,\n isSocketDown\n })\n lastReloadTime.current = now\n setReload(true)\n }\n }, 1000) // Check every second\n\n return () => clearInterval(checkInterval)\n }, [reload])\n\n useEventListener('phone-island-expand', () => {\n store.dispatch.island.toggleIsOpen(true)\n eventDispatch('phone-island-expanded', {})\n })\n useEventListener('phone-island-compress', () => {\n store.dispatch.island.toggleIsOpen(false)\n eventDispatch('phone-island-compressed', {})\n })\n\n useEventListener('phone-island-call-keypad-close', () => {\n store.dispatch.island.setIslandView('call')\n eventDispatch('phone-island-call-keypad-closed', {})\n })\n useEventListener('phone-island-call-transfer-close', () => {\n store.dispatch.island.setIslandView('call')\n eventDispatch('phone-island-call-transfer-closed', {})\n })\n useEventListener('phone-island-recording-close', () => {\n store.dispatch.island.setIslandView(null)\n eventDispatch('phone-island-recording-closed', {})\n })\n useEventListener('phone-island-audio-player-close', () => {\n store.dispatch.island.setIslandView(null)\n eventDispatch('phone-island-audio-player-closed', {})\n })\n\n useEventListener('phone-island-emergency-stop-ringtone', () => {\n const { view } = store.getState().island\n\n // If phone-island is active (view is not null), don't stop the ringtone\n if (view !== null) {\n console.log('Phone island is active, ringtone stop ignored')\n return\n }\n\n // Phone-island is not active (view is null), force stop ringtone\n console.warn('Emergency stop ringtone triggered - phone island inactive')\n store.dispatch.player.emergencyStopAudioPlayer()\n eventDispatch('phone-island-emergency-stop-ringtone-completed', {})\n })\n\n useEventListener('phone-island-detach', (data) => {\n detach()\n eventDispatch('phone-island-detached', {})\n })\n\n useEventListener('phone-island-reload-component', (data: any) => {\n if (data?.force) {\n store.dispatch.island.setForceReload(true)\n }\n setReload(true)\n })\n\n useEventListener('phone-island-audio-input-change', async (data: DeviceInputOutputTypes) => {\n let targetDeviceId = data.deviceId\n\n // Check if the requested device is available\n if (targetDeviceId && targetDeviceId !== 'default') {\n const isAvailable = await isAudioInputDeviceAvailable(targetDeviceId)\n\n if (!isAvailable) {\n console.warn(\n `Audio input device ${targetDeviceId} not available, falling back to default device`,\n )\n targetDeviceId = await getDefaultAudioInputDevice()\n }\n }\n\n // Save the final device choice\n setJSONItem('phone-island-audio-input-device', { deviceId: targetDeviceId })\n eventDispatch('phone-island-audio-input-changed', {})\n\n if (targetDeviceId !== data.deviceId) {\n console.info(\n `Audio input device changed from ${data.deviceId} to ${targetDeviceId} (fallback)`,\n )\n }\n })\n\n useEventListener('phone-island-video-input-change', async (data: DeviceInputOutputTypes) => {\n let targetDeviceId = data.deviceId\n\n // Check if the requested device is available\n if (targetDeviceId && targetDeviceId !== 'default') {\n const isAvailable = await isVideoInputDeviceAvailable(targetDeviceId)\n\n if (!isAvailable) {\n console.warn(\n `Video input device ${targetDeviceId} not available, falling back to default device`,\n )\n targetDeviceId = await getDefaultVideoInputDevice()\n }\n }\n\n // Save the final device choice\n setJSONItem('phone-island-video-input-device', { deviceId: targetDeviceId })\n eventDispatch('phone-island-video-input-changed', {})\n\n if (targetDeviceId !== data.deviceId) {\n console.info(\n `Video input device changed from ${data.deviceId} to ${targetDeviceId} (fallback)`,\n )\n }\n })\n\n const [firstRender, setFirstRender] = useState(true)\n const [firstAudioOutputInit, setFirstAudioOutputInit] = useState(true)\n\n // Initialize application on first render\n useEffect(() => {\n const initParamUrl = async () => {\n try {\n const paramUrlResponse: any = await getParamUrl()\n const url = paramUrlResponse?.url || ''\n const isValid = url && url.trim() !== ''\n\n // Save data inside the store\n store.dispatch.paramUrl.setParamUrl({\n url: url,\n onlyQueues: paramUrlResponse?.only_queues || false,\n hasValidUrl: isValid,\n })\n } catch (error) {\n console.error('Error fetching URL parameter:', error)\n store.dispatch.paramUrl.setParamUrl({\n url: '',\n onlyQueues: false,\n hasValidUrl: false,\n })\n }\n }\n\n if (firstRender) {\n // Initialize i18n\n initI18n()\n // Initialize param URL\n initParamUrl()\n setFirstRender(false)\n }\n }, [firstRender])\n\n // Helper function to check if an audio output device is available\n const isAudioOutputDeviceAvailable = async (deviceId: string): Promise<boolean> => {\n try {\n if (!navigator.mediaDevices || !navigator.mediaDevices.enumerateDevices) {\n return false\n }\n\n const devices = await navigator.mediaDevices.enumerateDevices()\n const audioOutputDevices = devices.filter((device) => device.kind === 'audiooutput')\n\n return audioOutputDevices.some((device) => device.deviceId === deviceId)\n } catch (err) {\n console.warn('Error checking device availability:', err)\n return false\n }\n }\n\n // Helper function to get default audio output device\n const getDefaultAudioOutputDevice = async (): Promise<string> => {\n try {\n if (!navigator.mediaDevices || !navigator.mediaDevices.enumerateDevices) {\n return 'default'\n }\n\n const devices = await navigator.mediaDevices.enumerateDevices()\n const audioOutputDevices = devices.filter((device) => device.kind === 'audiooutput')\n\n // Find the default device (usually has deviceId 'default' or is the first one)\n const defaultDevice =\n audioOutputDevices.find(\n (device) => device.deviceId === 'default' || device.deviceId === '',\n ) || audioOutputDevices[0]\n\n return defaultDevice ? defaultDevice.deviceId : 'default'\n } catch (err) {\n console.warn('Error getting default device:', err)\n return 'default'\n }\n }\n\n // Helper function to check if an audio input device is available\n const isAudioInputDeviceAvailable = async (deviceId: string): Promise<boolean> => {\n try {\n if (!navigator.mediaDevices || !navigator.mediaDevices.enumerateDevices) {\n return false\n }\n\n const devices = await navigator.mediaDevices.enumerateDevices()\n const audioInputDevices = devices.filter((device) => device.kind === 'audioinput')\n\n return audioInputDevices.some((device) => device.deviceId === deviceId)\n } catch (err) {\n console.warn('Error checking audio input device availability:', err)\n return false\n }\n }\n\n // Helper function to get default audio input device\n const getDefaultAudioInputDevice = async (): Promise<string> => {\n try {\n if (!navigator.mediaDevices || !navigator.mediaDevices.enumerateDevices) {\n return 'default'\n }\n\n const devices = await navigator.mediaDevices.enumerateDevices()\n const audioInputDevices = devices.filter((device) => device.kind === 'audioinput')\n\n // Find the default device (usually has deviceId 'default' or is the first one)\n const defaultDevice =\n audioInputDevices.find(\n (device) => device.deviceId === 'default' || device.deviceId === '',\n ) || audioInputDevices[0]\n\n return defaultDevice ? defaultDevice.deviceId : 'default'\n } catch (err) {\n console.warn('Error getting default audio input device:', err)\n return 'default'\n }\n }\n\n // Helper function to check if a video input device is available\n const isVideoInputDeviceAvailable = async (deviceId: string): Promise<boolean> => {\n try {\n if (!navigator.mediaDevices || !navigator.mediaDevices.enumerateDevices) {\n return false\n }\n\n const devices = await navigator.mediaDevices.enumerateDevices()\n const videoInputDevices = devices.filter((device) => device.kind === 'videoinput')\n\n return videoInputDevices.some((device) => device.deviceId === deviceId)\n } catch (err) {\n console.warn('Error checking video input device availability:', err)\n return false\n }\n }\n\n // Helper function to get default video input device\n const getDefaultVideoInputDevice = async (): Promise<string> => {\n try {\n if (!navigator.mediaDevices || !navigator.mediaDevices.enumerateDevices) {\n return 'default'\n }\n\n const devices = await navigator.mediaDevices.enumerateDevices()\n const videoInputDevices = devices.filter((device) => device.kind === 'videoinput')\n\n // Find the default device (usually has deviceId 'default' or is the first one)\n const defaultDevice =\n videoInputDevices.find(\n (device) => device.deviceId === 'default' || device.deviceId === '',\n ) || videoInputDevices[0]\n\n return defaultDevice ? defaultDevice.deviceId : 'default'\n } catch (err) {\n console.warn('Error getting default video input device:', err)\n return 'default'\n }\n }\n\n useEventListener('phone-island-audio-output-change', (data: DeviceInputOutputTypes) => {\n const trySetSinkId = async () => {\n const remoteAudioElement: any = store.getState().player.remoteAudio\n\n if (!remoteAudioElement?.current) {\n console.warn('Remote audio element not available')\n return\n }\n\n let targetDeviceId = data.deviceId\n\n // Check if the requested device is available\n if (targetDeviceId && targetDeviceId !== 'default') {\n const isAvailable = await isAudioOutputDeviceAvailable(targetDeviceId)\n\n if (!isAvailable) {\n console.warn(\n `Audio output device ${targetDeviceId} not available, falling back to default device`,\n )\n targetDeviceId = await getDefaultAudioOutputDevice()\n\n // Update localStorage with the fallback device\n setJSONItem('phone-island-audio-output-device', { deviceId: targetDeviceId })\n }\n }\n\n try {\n // Try to set sink ID directly first (works if audio element is already active)\n await remoteAudioElement.current.setSinkId(targetDeviceId)\n console.info('Default audio output device changed successfully!')\n\n // Save device to localStorage\n setJSONItem('phone-island-audio-output-device', { deviceId: targetDeviceId })\n eventDispatch('phone-island-audio-output-changed', {})\n } catch (err) {\n console.log('Direct setSinkId failed, trying with temporary stream:', err)\n\n try {\n // Create a temporary silent audio stream to activate the audio element\n const audioContext = new (window.AudioContext || (window as any).webkitAudioContext)()\n const oscillator = audioContext.createOscillator()\n const gainNode = audioContext.createGain()\n\n // Create silent audio\n oscillator.frequency.setValueAtTime(440, audioContext.currentTime)\n gainNode.gain.setValueAtTime(0, audioContext.currentTime) // Silent\n\n oscillator.connect(gainNode)\n\n // Get MediaStream from audio context\n const destination = audioContext.createMediaStreamDestination()\n gainNode.connect(destination)\n\n // Set the stream to the audio element\n remoteAudioElement.current.srcObject = destination.stream\n\n // Start the oscillator\n oscillator.start()\n\n // Try setSinkId again after a short delay\n setTimeout(async () => {\n try {\n await remoteAudioElement.current.setSinkId(targetDeviceId)\n console.info(\n 'Default audio output device changed successfully with temporary stream!',\n )\n\n // Clean up temporary stream\n oscillator.stop()\n audioContext.close()\n remoteAudioElement.current.srcObject = null\n\n // Save device to localStorage\n setJSONItem('phone-island-audio-output-device', { deviceId: targetDeviceId })\n eventDispatch('phone-island-audio-output-changed', {})\n } catch (finalErr) {\n console.error('Final setSinkId attempt failed:', finalErr)\n\n // Clean up on failure\n oscillator.stop()\n audioContext.close()\n remoteAudioElement.current.srcObject = null\n\n // If original device failed and we're not already using default, try default\n if (targetDeviceId !== 'default') {\n console.log('Trying fallback to default device')\n try {\n await remoteAudioElement.current.setSinkId('default')\n setJSONItem('phone-island-audio-output-device', { deviceId: 'default' })\n console.info('Fallback to default audio device successful')\n } catch (defaultErr) {\n console.error('Even default device failed:', defaultErr)\n }\n }\n\n // Save device preference anyway for future calls\n setJSONItem('phone-island-audio-output-device', { deviceId: targetDeviceId })\n eventDispatch('phone-island-audio-output-changed', {})\n }\n }, 100)\n } catch (streamErr) {\n console.error('Failed to create temporary audio stream:', streamErr)\n\n // Final fallback: try default device\n if (targetDeviceId !== 'default') {\n try {\n await remoteAudioElement.current.setSinkId('default')\n setJSONItem('phone-island-audio-output-device', { deviceId: 'default' })\n console.info('Emergency fallback to default audio device successful')\n } catch (defaultErr) {\n console.error('Emergency fallback to default device failed:', defaultErr)\n setJSONItem('phone-island-audio-output-device', { deviceId: targetDeviceId })\n }\n } else {\n setJSONItem('phone-island-audio-output-device', { deviceId: targetDeviceId })\n }\n\n eventDispatch('phone-island-audio-output-changed', {})\n }\n }\n }\n\n trySetSinkId()\n })\n\n // Listen for the operator status change\n useEventListener('phone-island-presence-change', (data: any) => {\n changeOperatorStatus(data)\n eventDispatch('phone-island-presence-changed', {})\n })\n\n useEventListener('phone-island-view-changed', (data) => {\n const viewType = data?.viewType\n store.dispatch.island.setIslandView(viewType)\n })\n\n const remoteAudioElement: any = store.getState().player.remoteAudio\n\n //get output device from localstorage\n useEffect(() => {\n if (firstAudioOutputInit && remoteAudioElement) {\n const defaultAudioOutputDevice: any = getJSONItem(\n `phone-island-audio-output-device`,\n )?.deviceId\n eventDispatch('phone-island-audio-output-change', {\n deviceId: defaultAudioOutputDevice,\n })\n setFirstAudioOutputInit(false)\n }\n }, [firstAudioOutputInit, remoteAudioElement])\n\n useEffect(() => {\n checkDarkTheme()\n }, [])\n\n useEventListener('phone-island-theme-change', (theme: any) => {\n setTheme(theme?.selectedTheme)\n })\n\n useEventListener('phone-island-default-device-change', (data) => {\n store.dispatch.currentUser.updateCurrentDefaultDevice(data?.deviceInformationObject)\n eventDispatch('phone-island-default-device-changed', {})\n })\n\n useEventListener('phone-island-alert', (alertType: any) => {\n store.dispatch.alerts.setAlert(alertType.toString())\n })\n\n // Ringtone management events\n useEventListener('phone-island-ringing-tone-list', () => {\n const ringtones = store.getState().ringtones.availableRingtones\n const ringtoneList = ringtones.map((r) => ({\n name: r.name,\n displayName: r.displayName,\n base64Audio: r.base64Audio,\n }))\n eventDispatch('phone-island-ringing-tone-list-response', { ringtones: ringtoneList })\n })\n\n useEventListener('phone-island-ringing-tone-select', (data: { name: string }) => {\n if (data?.name) {\n // Save to localStorage\n setJSONItem('phone-island-selected-ringtone', { value: data.name })\n // Update store\n store.dispatch.ringtones.setSelectedRingtone(data.name)\n eventDispatch('phone-island-ringing-tone-selected', { name: data.name })\n }\n })\n\n useEventListener('phone-island-ringing-tone-output', (data: { deviceId: string }) => {\n if (data?.deviceId) {\n // Save to localStorage\n setJSONItem('phone-island-ringtone-output-device', { value: data.deviceId })\n // Update store\n store.dispatch.ringtones.setOutputDeviceId(data.deviceId)\n eventDispatch('phone-island-ringing-tone-output-changed', { deviceId: data.deviceId })\n }\n })\n\n // Load ringtone preferences from localStorage on mount\n useEffect(() => {\n const savedRingtone = getJSONItem('phone-island-selected-ringtone')\n const savedOutputDevice = getJSONItem('phone-island-ringtone-output-device')\n\n if (savedRingtone?.value) {\n store.dispatch.ringtones.setSelectedRingtone(savedRingtone.value)\n }\n if (savedOutputDevice?.value) {\n store.dispatch.ringtones.setOutputDeviceId(savedOutputDevice.value)\n }\n }, [])\n\n // Manually check if internet connection is enabled or not\n useEventListener('phone-island-check-connection', () => {\n checkInternetConnection().then((internetIsActive) => {\n if (internetIsActive) {\n eventDispatch('phone-island-internet-connected', {})\n } else {\n eventDispatch('phone-island-internet-disconnected', {})\n }\n })\n })\n\n // Check internet connection every 5 seconds\n useEffect(() => {\n const intervalId = setInterval(() => {\n checkInternetConnection().then((internetIsActive) => {\n if (internetIsActive) {\n eventDispatch('phone-island-internet-connected', {})\n } else {\n eventDispatch('phone-island-internet-disconnected', {})\n }\n })\n }, 5000)\n\n return () => clearInterval(intervalId)\n }, [])\n\n useEventListener('phone-island-main-presence', (data: any) => {\n const currentUsernameInformation: any = store.getState().currentUser?.username\n const currentUserObject: any = store.getState().currentUser\n let mainPresenceValueBeforeUpdate = currentUserObject?.mainPresence\n if (\n currentUsernameInformation !== undefined &&\n currentUsernameInformation !== '' &&\n !isEmpty(data[currentUsernameInformation]) &&\n data[currentUsernameInformation]?.mainPresence !== undefined\n ) {\n let newMainPresenceValue = data[currentUsernameInformation]?.mainPresence\n store.dispatch.currentUser.updateMainPresence(data[currentUsernameInformation]?.mainPresence)\n let mainPresenceValueAfterUpdate = newMainPresenceValue\n if (mainPresenceValueAfterUpdate === 'online' && mainPresenceValueBeforeUpdate !== 'online') {\n eventDispatch('phone-island-call-ended', {})\n }\n }\n })\n\n useEventListener('phone-island-call-status', () => {\n const callInformation = store.getState().currentCall\n console.log('Call status debug informations: ', callInformation)\n })\n\n const openParameterizedUrl = (callerNum: any, callerName: any, called: any, uniqueId: any) => {\n const paramUrlInfo = store.getState().paramUrl\n\n if (!paramUrlInfo?.hasValidUrl) {\n return\n }\n\n const paramUrl = paramUrlInfo.url || ''\n\n if (!paramUrl) {\n return\n }\n\n const { urlOpened } = store.getState().island\n const openParamUrlType = paramUrlInfo.openParamUrlType\n\n if (urlOpened && openParamUrlType !== 'button') {\n return\n }\n\n let processedUrl = paramUrl\n\n if (processedUrl.includes('$CALLER_NUMBER') && callerNum) {\n processedUrl = processedUrl.replace(/\\$CALLER_NUMBER/g, encodeURIComponent(callerNum))\n }\n if (processedUrl.includes('$CALLER_NAME') && callerName) {\n processedUrl = processedUrl.replace(/\\$CALLER_NAME/g, encodeURIComponent(callerName))\n }\n if (processedUrl.includes('$UNIQUEID') && uniqueId) {\n processedUrl = processedUrl.replace(/\\$UNIQUEID/g, encodeURIComponent(uniqueId))\n }\n if (processedUrl.includes('$CALLED') && called) {\n processedUrl = processedUrl.replace(/\\$CALLED/g, encodeURIComponent(called))\n }\n if (processedUrl.includes('{phone}') && callerNum) {\n processedUrl = processedUrl.replace(/\\{phone\\}/g, encodeURIComponent(callerNum))\n }\n\n const formattedUrl = processedUrl.startsWith('http') ? processedUrl : `https://${processedUrl}`\n\n if (uaType !== 'mobile' && !urlParamWithEvent) {\n const newWindow = window.open('about:blank', '_blank')\n if (newWindow) {\n newWindow.location.href = formattedUrl\n store.dispatch.island.setUrlOpened(true)\n }\n } else {\n eventDispatch('phone-island-url-parameter-opened-external', { formattedUrl })\n }\n }\n\n useEventListener('phone-island-already-opened-external-page', () => {\n store.dispatch.island.setUrlOpened(true)\n })\n\n useEventListener('phone-island-url-parameter-opened', (data) => {\n const paramUrlInfo = store.getState().paramUrl\n\n if (!paramUrlInfo.hasValidUrl) {\n return\n }\n\n const { urlOpened } = store.getState().island\n if (urlOpened) {\n return\n }\n\n const onlyQueues = paramUrlInfo.onlyQueues || false\n const throughTrunk = isFromTrunk(data?.counterpartNum)\n store.dispatch.paramUrl.setThroughTrunk(throughTrunk)\n\n if (data?.direction === 'in') {\n if (onlyQueues === true && data?.throughQueue === true) {\n openParameterizedUrl(\n data?.counterpartNum,\n data?.counterpartName,\n data?.owner,\n data?.uniqueId,\n )\n } else if (onlyQueues === false && (throughTrunk === true || data?.throughQueue === true)) {\n openParameterizedUrl(\n data?.counterpartNum,\n data?.counterpartName,\n data?.owner,\n data?.uniqueId,\n )\n }\n }\n })\n\n useEventListener('phone-island-user-status', () => {\n const userInformation = store.getState().currentUser\n console.log('User status debug informations: ', userInformation)\n })\n\n useEventListener('phone-island-all-users-status', () => {\n const allUsersInformation = store.getState().users\n console.log('Users status debug informations: ', allUsersInformation)\n })\n\n useEventListener('phone-island-status', () => {\n const phoneIslandInformation = store.getState().island\n console.log('Phone island status debug informations: ', phoneIslandInformation)\n })\n\n useEventListener('phone-island-webrtc-status', () => {\n const webrtcInformation = store.getState().webrtc\n console.log('Webrtc status debug informations: ', webrtcInformation)\n })\n\n useEventListener('phone-island-player-status', () => {\n const playerInformation = store.getState().player\n console.log('Player status debug informations: ', playerInformation)\n })\n\n useEventListener('phone-island-conference-status', () => {\n const conferenceInformation = store.getState().conference\n console.log('Webrtc status debug informations: ', conferenceInformation)\n })\n\n useEventListener('phone-island-streaming-status', () => {\n const streamingInformation = store.getState().streaming\n console.log('Streaming status debug informations: ', streamingInformation)\n })\n\n useEventListener('phone-island-paramurl-status', () => {\n const paramurl = store.getState().paramUrl\n console.log('Paramurl status debug informations: ', paramurl)\n })\n\n useEventListener('phone-island-player-force-stop', () => {\n store.dispatch.player.reset()\n console.log('Audio player is interrupted')\n })\n\n // Download all stores as JSON file - for debugging and backup\n useEventListener('phone-island-stores-download', () => {\n downloadStoresAsJSON()\n eventDispatch('phone-island-stores-downloaded', {})\n })\n\n useEventListener('phone-island-sideview-open', () => {\n store.dispatch.island.toggleSideViewVisible(true)\n store.dispatch.island.setUrlOpened(false)\n eventDispatch('phone-island-sideview-opened', {})\n })\n\n useEventListener('phone-island-sideview-close', () => {\n store.dispatch.island.toggleSideViewVisible(false)\n eventDispatch('phone-island-sideview-closed', {})\n })\n\n useEventListener('phone-island-transcription-close', () => {\n store.dispatch.island.toggleTranscriptionViewVisible(false)\n eventDispatch('phone-island-stop-transcription', {})\n eventDispatch('phone-island-transcription-closed', {})\n })\n\n useEventListener('phone-island-transcription-open', () => {\n eventDispatch('phone-island-start-transcription', {})\n store.dispatch.island.toggleTranscriptionViewVisible(true)\n eventDispatch('phone-island-transcription-opened', {})\n })\n\n useEventListener('phone-island-transcription-close', () => {\n store.dispatch.island.toggleTranscriptionViewVisible(false)\n eventDispatch('phone-island-transcription-closed', {})\n })\n\n useEventListener('phone-island-init-audio', () => {\n // Check if there's an active call - don't interrupt it with audio warm-up\n const { accepted, incoming, outgoing, incomingWebRTC, incomingSocket } = store.getState().currentCall\n const hasActiveCall = accepted || incoming || outgoing || incomingWebRTC || incomingSocket\n\n if (hasActiveCall) {\n console.log('[AUDIO-WARMUP] Skipping audio warm-up: active call in progress')\n return\n }\n\n // Validate SIP_HOST before attempting call\n if (!SIP_HOST || typeof SIP_HOST !== 'string' || SIP_HOST.length === 0) {\n console.warn('[AUDIO-WARMUP] Skipping audio warm-up: SIP_HOST not available', { SIP_HOST })\n return\n }\n\n const { featureCodes } = store.getState().currentUser\n const audioTestCode = featureCodes?.audio_test\n // Always fallback to *41 if audio_test is not available\n const codeToCall = (audioTestCode && typeof audioTestCode === 'string' && audioTestCode.length > 0)\n ? audioTestCode\n : '*41'\n\n console.log('[AUDIO-WARMUP] Starting audio warm-up test call', { codeToCall, SIP_HOST })\n callNumber(codeToCall, SIP_HOST)\n })\n\n useEventListener('phone-island-transcription-toggle', () => {\n const { transcriptionViewIsVisible } = store.getState().island\n const newState = !transcriptionViewIsVisible\n store.dispatch.island.toggleTranscriptionViewVisible(newState)\n eventDispatch(\n newState ? 'phone-island-transcription-opened' : 'phone-island-transcription-closed',\n {},\n )\n })\n\n useEventListener('phone-island-size-change', (args: any) => {\n const { sideViewIsVisible, transcriptionViewIsVisible, actionsExpanded } =\n store.getState().island\n\n // Get current dimensions from args\n const { sizeInformation } = args\n\n // // Calculate extra row dimension ( side view and back call )\n const updatedSizeInformation = {\n ...sizeInformation,\n right: sideViewIsVisible ? '42px' : '0px',\n top: isBackCallActive() ? '40px' : '0px',\n bottomTranscription:\n transcriptionViewIsVisible && actionsExpanded\n ? '335px'\n : transcriptionViewIsVisible && !actionsExpanded\n ? '330px'\n : '0px',\n }\n eventDispatch('phone-island-size-changed', { sizes: updatedSizeInformation })\n })\n\n // Listen for the call end event and set the island size to 0\n useEventListener('phone-island-call-ended', () => {\n const { mainPresence } = store.getState().currentUser\n if (mainPresence === 'online') {\n const sizeInformation: any = {\n width: '0px',\n height: '0px',\n }\n eventDispatch('phone-island-size-change', { sizeInformation })\n eventDispatch('phone-island-sideview-close', {})\n store.dispatch.island.handleResetIslandStore()\n store.dispatch.paramUrl.setThroughTrunk(false)\n }\n })\n\n useEventListener('phone-island-conference-list-open', () => {\n store.dispatch.island.toggleConferenceList(true)\n eventDispatch('phone-island-conference-list-opened', {})\n })\n\n useEventListener('phone-island-alert-removed', (alertRemovedType) => {\n // Get current alerts status\n const { activeAlertsCount } = store.getState().alerts.status\n const { view, previousView } = store.getState().island\n const { isActive } = store.getState().conference\n const alertsData = store.getState().alerts.data\n const currentCall = store.getState().currentCall\n const { incoming, outgoing, accepted } = currentCall\n\n // Check if alert type was provided\n const alertType = alertRemovedType?.type\n\n // Check if user is in a call\n const isInCall =\n currentCall.incoming ||\n currentCall.outgoing ||\n currentCall.accepted ||\n currentCall.conversationId !== ''\n\n // Determine if the island should remain visible\n const shouldKeepVisible =\n incoming ||\n outgoing ||\n accepted ||\n activeAlertsCount > 0 ||\n view === 'player' ||\n view === 'recorder' ||\n view === 'physicalPhoneRecorder' ||\n (view === 'waitingConference' && isActive) ||\n (view === 'transfer' && isActive) ||\n (view === 'settings' && isActive) ||\n (view === 'settings' && (previousView === 'recorder' || previousView === 'player')) ||\n (view === 'operatorBusy' && !isActive)\n\n // Reset the island store only if:\n // 1. The island should not remain visible\n // 2. No more active alerts\n // 3. The specific alert is not active anymore\n // 4. User is not currently in a call\n if (\n !shouldKeepVisible &&\n activeAlertsCount === 0 &&\n (!alertType || (alertsData[alertType] && !alertsData[alertType].active)) &&\n !isInCall\n ) {\n const sizeInformation: any = {\n width: '0px',\n height: '0px',\n }\n eventDispatch('phone-island-size-change', { sizeInformation })\n eventDispatch('phone-island-sideview-close', {})\n store.dispatch.island.handleResetIslandStore()\n }\n })\n\n useEventListener('phone-island-conference-list-close', () => {\n store.dispatch.island.toggleConferenceList(false)\n eventDispatch('phone-island-conference-list-closed', {})\n })\n\n // Listen for conversations updates to handle 'answered' preference for parameterized URL\n useEventListener('phone-island-conversations', (data: any) => {\n // Get the current username (first key in the data object)\n const username = Object.keys(data)[0]\n const currentUsernameInformation: any = store.getState().currentUser?.username\n\n if (username === currentUsernameInformation) {\n const conversations = data[username].conversations\n const paramUrlInfo = store.getState().paramUrl\n const { urlOpened } = store.getState().island\n\n // Only proceed if URL is valid and not already opened\n if (!paramUrlInfo.hasValidUrl || urlOpened) {\n return\n }\n\n // Check if the openParamUrlType is set to 'answered'\n if (paramUrlInfo.openParamUrlType === 'answered') {\n // Check if there are any conversations\n if (conversations && Object.keys(conversations).length > 0) {\n // Get the first conversation (usually there's only one active call)\n const convId = Object.keys(conversations)[0]\n const conv = conversations[convId]\n\n // Check conditions: must be connected and incoming\n if (conv?.connected && conv?.direction === 'in') {\n const onlyQueues = paramUrlInfo.onlyQueues || false\n const calculatedThroughTrunk = isFromTrunk(conv.counterpartNum)\n // Update throughTrunk in paramUrl store\n store.dispatch.paramUrl.setThroughTrunk(calculatedThroughTrunk)\n\n // Check queue conditions based on preferences\n if (onlyQueues === true && conv?.throughQueue === true) {\n // Open URL only for queue calls when onlyQueues is true\n openParameterizedUrl(\n conv.counterpartNum,\n conv.counterpartName,\n conv.owner,\n conv.uniqueId,\n )\n } else if (\n onlyQueues === false &&\n (calculatedThroughTrunk === true || conv?.throughQueue === true)\n ) {\n // Open URL for both trunk and queue calls when onlyQueues is false\n openParameterizedUrl(\n conv.counterpartNum,\n conv.counterpartName,\n conv.owner,\n conv.uniqueId,\n )\n }\n }\n }\n }\n }\n })\n\n return (\n <>\n <Provider store={store}>\n {SIP_EXTEN && SIP_EXTEN.trim() !== '' ? (\n // Full stack with WebRTC when SIP extension is provided\n <WebRTC\n hostName={HOST_NAME}\n sipExten={SIP_EXTEN}\n sipSecret={SIP_SECRET}\n sipHost={SIP_HOST}\n sipPort={SIP_PORT}\n reload={reload}\n reloadedCallback={() => setReloadedWebRTC(true)}\n uaType={uaType}\n >\n <RestAPI hostName={HOST_NAME} username={USERNAME} authToken={AUTH_TOKEN}>\n <Socket\n hostName={HOST_NAME}\n username={USERNAME}\n authToken={AUTH_TOKEN}\n reload={reload}\n reloadedCallback={() => setReloadedSocket(true)}\n uaType={uaType}\n >\n <Events sipHost={SIP_HOST}>\n <Island showAlways={showAlways} uaType={uaType} />\n </Events>\n </Socket>\n </RestAPI>\n </WebRTC>\n ) : (\n // Minimal stack without WebRTC when no SIP extension\n <RestAPI hostName={HOST_NAME} username={USERNAME} authToken={AUTH_TOKEN}>\n <Socket\n hostName={HOST_NAME}\n username={USERNAME}\n authToken={AUTH_TOKEN}\n reload={reload}\n reloadedCallback={() => {\n setReloadedSocket(true)\n setReloadedWebRTC(true)\n }}\n uaType={uaType}\n >\n <Events sipHost={SIP_HOST}>\n <Island showAlways={showAlways} uaType={uaType} />\n </Events>\n </Socket>\n </RestAPI>\n )}\n </Provider>\n </>\n )\n})\n\nPhoneIslandComponent.displayName = 'PhoneIslandComponent'\n\nexport const PhoneIsland = forwardRef<PhoneIslandRef, PhoneIslandProps>(\n (props, ref) => <PhoneIslandComponent {...props} ref={ref} />,\n)\n\nPhoneIsland.displayName = 'PhoneIsland'\n"],"names":["PhoneIslandComponent","forwardRef","_a","ref","dataConfig","_b","showAlways","uaType","_c","urlParamWithEvent","CONFIG","Base64","atob","split","HOST_NAME","USERNAME","AUTH_TOKEN","SIP_EXTEN","SIP_SECRET","SIP_HOST","SIP_PORT","_d","useState","reload","setReload","_e","reloadedWebRTC","setReloadedWebRTC","_f","reloadedSocket","setReloadedSocket","lastReloadTime","useRef","useImperativeHandle","reset","console","info","useEffect","lastActiveTime","Date","now","handleVisibilityChange","document","hidden","timeSinceLastActive","setTimeout","eventDispatch","worker","Worker","wakeUpWorker","type","onmessage","event","data","addEventListener","terminate","removeEventListener","checkInterval","setInterval","store","getState","alerts","isWebRTCDown","webrtc_down","active","isSocketDown","socket_down","timeSinceLastReload","current","sipcall","webrtc","currentCall","accepted","outgoing","iceState","webrtcStuff","pc","iceConnectionState","hasActiveCall","isOnline","navigator","onLine","Math","round","clearInterval","useEventListener","dispatch","island","toggleIsOpen","setIslandView","view","warn","player","emergencyStopAudioPlayer","log","detach","force","setForceReload","__awaiter","targetDeviceId","deviceId","isAudioInputDeviceAvailable","sent","getDefaultAudioInputDevice","setJSONItem","concat","isVideoInputDeviceAvailable","getDefaultVideoInputDevice","_g","firstRender","setFirstRender","_h","firstAudioOutputInit","setFirstAudioOutputInit","initI18n","getParamUrl","paramUrlResponse","url","isValid","trim","paramUrl","setParamUrl","onlyQueues","only_queues","hasValidUrl","error","error_1","mediaDevices","enumerateDevices","devices","filter","device","kind","some","err_3","audioInputDevices","defaultDevice","find","err_4","err_5","videoInputDevices","err_6","remoteAudioElement","remoteAudio","err_1","audioOutputDevices","err_2","setSinkId","err_7","audioContext_1","window","AudioContext","webkitAudioContext","oscillator_1","createOscillator","gainNode","createGain","frequency","setValueAtTime","currentTime","gain","connect","destination","createMediaStreamDestination","srcObject","stream","start","stop","close","finalErr_1","defaultErr_2","streamErr_1","defaultErr_1","changeOperatorStatus","viewType","defaultAudioOutputDevice","getJSONItem","checkDarkTheme","theme","setTheme","selectedTheme","currentUser","updateCurrentDefaultDevice","deviceInformationObject","alertType","setAlert","toString","ringtoneList","ringtones","availableRingtones","map","r","name","displayName","base64Audio","value","setSelectedRingtone","setOutputDeviceId","savedRingtone","savedOutputDevice","checkInternetConnection","then","internetIsActive","intervalId","currentUsernameInformation","username","currentUserObject","mainPresenceValueBeforeUpdate","mainPresence","undefined","isEmpty","newMainPresenceValue","updateMainPresence","callInformation","openParameterizedUrl","callerNum","callerName","called","uniqueId","paramUrlInfo","urlOpened","openParamUrlType","processedUrl","includes","replace","encodeURIComponent","formattedUrl","startsWith","newWindow","open","location","href","setUrlOpened","throughTrunk","isFromTrunk","counterpartNum","setThroughTrunk","direction","throughQueue","counterpartName","owner","userInformation","allUsersInformation","users","phoneIslandInformation","webrtcInformation","playerInformation","conferenceInformation","conference","streamingInformation","streaming","paramurl","downloadStoresAsJSON","toggleSideViewVisible","toggleTranscriptionViewVisible","incoming","incomingWebRTC","incomingSocket","length","featureCodes","audioTestCode","audio_test","codeToCall","callNumber","newState","transcriptionViewIsVisible","args","sideViewIsVisible","actionsExpanded","sizeInformation","updatedSizeInformation","__assign","right","top","isBackCallActive","bottomTranscription","sizes","width","height","handleResetIslandStore","toggleConferenceList","alertRemovedType","activeAlertsCount","status","previousView","isActive","alertsData","isInCall","conversationId","Object","keys","conversations","conv","connected","calculatedThroughTrunk","React","createElement","Fragment","Provider","WebRTC","hostName","sipExten","sipSecret","sipHost","sipPort","reloadedCallback","RestAPI","authToken","Socket","Events","Island","PhoneIsland","props"],"mappings":"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"}
1
+ {"version":3,"file":"App.js","sources":["../src/App.tsx"],"sourcesContent":["import React, { type FC, useState, useEffect, forwardRef, useImperativeHandle, useRef } from 'react'\nimport { Events, Socket, WebRTC, Island, RestAPI } from './components'\nimport { Provider } from 'react-redux'\nimport { store, downloadStoresAsJSON } from './store'\nimport { Base64 } from 'js-base64'\nimport wakeUpWorker from './workers/wake_up'\nimport { initI18n } from './lib/i18n'\n\nimport 'react-tooltip/dist/react-tooltip.css'\nimport { useEventListener, eventDispatch, setJSONItem, getJSONItem } from './utils'\nimport { detach } from './lib/webrtc/messages'\nimport { checkDarkTheme, setTheme } from './lib/darkTheme'\nimport { changeOperatorStatus } from './services/user'\nimport { getParamUrl } from './services/user'\nimport { isEmpty } from './utils/genericFunctions/isEmpty'\nimport { checkInternetConnection } from './utils/genericFunctions/checkConnection'\nimport { isBackCallActive } from './utils/genericFunctions/isBackCallVisible'\nimport { isFromTrunk } from './lib/user/extensions'\nimport { callNumber } from './lib/phone/call'\n\ninterface PhoneIslandProps {\n dataConfig: string\n showAlways?: boolean\n uaType: string\n urlParamWithEvent?: boolean\n}\n\ninterface DeviceInputOutputTypes {\n deviceId: string\n}\n\nexport interface PhoneIslandRef {\n reset: () => void\n}\n\nconst PhoneIslandComponent = forwardRef<PhoneIslandRef, PhoneIslandProps>(\n (\n {\n dataConfig,\n showAlways = false,\n uaType,\n urlParamWithEvent = false,\n }: PhoneIslandProps,\n ref,\n ) => {\n const CONFIG: string[] = Base64.atob(dataConfig || '').split(':')\n const HOST_NAME: string = CONFIG[0]\n const USERNAME: string = CONFIG[1]\n const AUTH_TOKEN: string = CONFIG[2]\n const SIP_EXTEN: string = CONFIG[3]\n const SIP_SECRET: string = CONFIG[4]\n const SIP_HOST: string = CONFIG[5]\n const SIP_PORT: string = CONFIG[6]\n\n // Initialize the state to manage the reload events\n const [reload, setReload] = useState<boolean>(false)\n const [reloadedWebRTC, setReloadedWebRTC] = useState<boolean>(false)\n const [reloadedSocket, setReloadedSocket] = useState<boolean>(false)\n\n // Cooldown to prevent reload loop when network is down\n const lastReloadTime = useRef<number>(0)\n const RELOAD_COOLDOWN = 10 * 1000 // 10 seconds between reload attempts\n\n // Expose reset method via imperativeHandle\n useImperativeHandle(\n ref,\n () => ({\n reset: () => {\n console.info('PhoneIsland: Performing full component reset')\n setReload(true)\n },\n }),\n [],\n )\n\n // Keepalive system to maintain tab active without heavy reload\n useEffect(() => {\n let lastActiveTime = Date.now()\n const INACTIVITY_THRESHOLD = 5 * 60 * 1000 // 5 minutes\n\n // Handle visibility change (tab becomes visible/hidden)\n const handleVisibilityChange = () => {\n if (!document.hidden) {\n const now = Date.now()\n const timeSinceLastActive = now - lastActiveTime\n // Trigger emergency stop ringtone after 2 seconds when tab becomes active again\n setTimeout(() => {\n eventDispatch('phone-island-emergency-stop-ringtone', {})\n }, 2000)\n\n // Only reload if tab was hidden for more than threshold\n if (timeSinceLastActive > INACTIVITY_THRESHOLD) {\n console.info('Tab inactive for long period, performing soft reconnection')\n setReload(true)\n }\n lastActiveTime = now\n }\n }\n\n // Lightweight worker for keepalive ping\n const worker = new Worker(wakeUpWorker, { type: 'module' })\n worker.onmessage = (event: MessageEvent<string>) => {\n if (event.data === 'ping') {\n // Simple ping to keep tab active - no action needed\n lastActiveTime = Date.now()\n }\n }\n\n // Listen for visibility changes\n document.addEventListener('visibilitychange', handleVisibilityChange)\n\n return () => {\n worker.terminate()\n document.removeEventListener('visibilitychange', handleVisibilityChange)\n }\n }, [])\n\n useEffect(() => {\n if (reloadedSocket && reloadedWebRTC) {\n setReload(false)\n setReloadedWebRTC(false)\n setReloadedSocket(false)\n }\n }, [reloadedSocket, reloadedWebRTC])\n\n // Monitor alerts and trigger automatic reload when webrtc_down or socket_down become active\n useEffect(() => {\n const checkInterval = setInterval(() => {\n const { data } = store.getState().alerts\n const isWebRTCDown = data.webrtc_down?.active || false\n const isSocketDown = data.socket_down?.active || false\n const now = Date.now()\n const timeSinceLastReload = now - lastReloadTime.current\n\n // Check if there's an active call - if so, don't reload automatically\n // WebRTC/ICE is designed to recover from brief network interruptions\n const { sipcall }: { sipcall: any } = store.getState().webrtc\n const { accepted, outgoing } = store.getState().currentCall\n const iceState = sipcall?.webrtcStuff?.pc?.iceConnectionState\n const hasActiveCall = accepted || outgoing || iceState === 'connected' || iceState === 'completed'\n\n // If either alert is active and we're not already reloading and cooldown has passed\n // Don't trigger reload if we're completely offline - wait for network to come back\n // Don't trigger reload if there's an active call - let ICE try to recover\n const isOnline = navigator.onLine\n if ((isWebRTCDown || isSocketDown) && !reload && timeSinceLastReload > RELOAD_COOLDOWN && isOnline) {\n if (hasActiveCall) {\n console.info('Alert detected but active call in progress - skipping automatic reload to let ICE recover', {\n timeSinceLastReload: Math.round(timeSinceLastReload / 1000) + 's',\n isWebRTCDown,\n isSocketDown,\n iceState,\n accepted,\n outgoing\n })\n // Don't reload - let ICE try to recover the call\n return\n }\n console.info('Alert detected (webrtc_down or socket_down), triggering automatic reload', {\n timeSinceLastReload: Math.round(timeSinceLastReload / 1000) + 's',\n isWebRTCDown,\n isSocketDown\n })\n lastReloadTime.current = now\n setReload(true)\n }\n }, 1000) // Check every second\n\n return () => clearInterval(checkInterval)\n }, [reload])\n\n useEventListener('phone-island-expand', () => {\n store.dispatch.island.toggleIsOpen(true)\n eventDispatch('phone-island-expanded', {})\n })\n useEventListener('phone-island-compress', () => {\n store.dispatch.island.toggleIsOpen(false)\n eventDispatch('phone-island-compressed', {})\n })\n\n useEventListener('phone-island-call-keypad-close', () => {\n store.dispatch.island.setIslandView('call')\n eventDispatch('phone-island-call-keypad-closed', {})\n })\n useEventListener('phone-island-call-transfer-close', () => {\n store.dispatch.island.setIslandView('call')\n eventDispatch('phone-island-call-transfer-closed', {})\n })\n useEventListener('phone-island-recording-close', () => {\n store.dispatch.island.setIslandView(null)\n eventDispatch('phone-island-recording-closed', {})\n })\n useEventListener('phone-island-audio-player-close', () => {\n store.dispatch.island.setIslandView(null)\n eventDispatch('phone-island-audio-player-closed', {})\n })\n\n useEventListener('phone-island-emergency-stop-ringtone', () => {\n const { view } = store.getState().island\n\n // If phone-island is active (view is not null), don't stop the ringtone\n if (view !== null) {\n console.log('Phone island is active, ringtone stop ignored')\n return\n }\n\n // Phone-island is not active (view is null), force stop ringtone\n console.warn('Emergency stop ringtone triggered - phone island inactive')\n store.dispatch.player.emergencyStopAudioPlayer()\n eventDispatch('phone-island-emergency-stop-ringtone-completed', {})\n })\n\n useEventListener('phone-island-detach', (data) => {\n detach()\n eventDispatch('phone-island-detached', {})\n })\n\n useEventListener('phone-island-reload-component', (data: any) => {\n if (data?.force) {\n store.dispatch.island.setForceReload(true)\n }\n setReload(true)\n })\n\n useEventListener('phone-island-audio-input-change', async (data: DeviceInputOutputTypes) => {\n let targetDeviceId = data.deviceId\n\n // Check if the requested device is available\n if (targetDeviceId && targetDeviceId !== 'default') {\n const isAvailable = await isAudioInputDeviceAvailable(targetDeviceId)\n\n if (!isAvailable) {\n console.warn(\n `Audio input device ${targetDeviceId} not available, falling back to default device`,\n )\n targetDeviceId = await getDefaultAudioInputDevice()\n }\n }\n\n // Save the final device choice\n setJSONItem('phone-island-audio-input-device', { deviceId: targetDeviceId })\n eventDispatch('phone-island-audio-input-changed', {})\n\n if (targetDeviceId !== data.deviceId) {\n console.info(\n `Audio input device changed from ${data.deviceId} to ${targetDeviceId} (fallback)`,\n )\n }\n })\n\n useEventListener('phone-island-video-input-change', async (data: DeviceInputOutputTypes) => {\n let targetDeviceId = data.deviceId\n\n // Check if the requested device is available\n if (targetDeviceId && targetDeviceId !== 'default') {\n const isAvailable = await isVideoInputDeviceAvailable(targetDeviceId)\n\n if (!isAvailable) {\n console.warn(\n `Video input device ${targetDeviceId} not available, falling back to default device`,\n )\n targetDeviceId = await getDefaultVideoInputDevice()\n }\n }\n\n // Save the final device choice\n setJSONItem('phone-island-video-input-device', { deviceId: targetDeviceId })\n eventDispatch('phone-island-video-input-changed', {})\n\n if (targetDeviceId !== data.deviceId) {\n console.info(\n `Video input device changed from ${data.deviceId} to ${targetDeviceId} (fallback)`,\n )\n }\n })\n\n const [firstRender, setFirstRender] = useState(true)\n const [firstAudioOutputInit, setFirstAudioOutputInit] = useState(true)\n\n // Initialize application on first render\n useEffect(() => {\n const initParamUrl = async () => {\n try {\n const paramUrlResponse: any = await getParamUrl()\n const url = paramUrlResponse?.url || ''\n const isValid = url && url.trim() !== ''\n\n // Save data inside the store\n store.dispatch.paramUrl.setParamUrl({\n url: url,\n onlyQueues: paramUrlResponse?.only_queues || false,\n hasValidUrl: isValid,\n })\n } catch (error) {\n console.error('Error fetching URL parameter:', error)\n store.dispatch.paramUrl.setParamUrl({\n url: '',\n onlyQueues: false,\n hasValidUrl: false,\n })\n }\n }\n\n if (firstRender) {\n // Initialize i18n\n initI18n()\n // Initialize param URL\n initParamUrl()\n setFirstRender(false)\n }\n }, [firstRender])\n\n // Helper function to check if an audio output device is available\n const isAudioOutputDeviceAvailable = async (deviceId: string): Promise<boolean> => {\n try {\n if (!navigator.mediaDevices || !navigator.mediaDevices.enumerateDevices) {\n return false\n }\n\n const devices = await navigator.mediaDevices.enumerateDevices()\n const audioOutputDevices = devices.filter((device) => device.kind === 'audiooutput')\n\n return audioOutputDevices.some((device) => device.deviceId === deviceId)\n } catch (err) {\n console.warn('Error checking device availability:', err)\n return false\n }\n }\n\n // Helper function to get default audio output device\n const getDefaultAudioOutputDevice = async (): Promise<string> => {\n try {\n if (!navigator.mediaDevices || !navigator.mediaDevices.enumerateDevices) {\n return 'default'\n }\n\n const devices = await navigator.mediaDevices.enumerateDevices()\n const audioOutputDevices = devices.filter((device) => device.kind === 'audiooutput')\n\n // Find the default device (usually has deviceId 'default' or is the first one)\n const defaultDevice =\n audioOutputDevices.find(\n (device) => device.deviceId === 'default' || device.deviceId === '',\n ) || audioOutputDevices[0]\n\n return defaultDevice ? defaultDevice.deviceId : 'default'\n } catch (err) {\n console.warn('Error getting default device:', err)\n return 'default'\n }\n }\n\n // Helper function to check if an audio input device is available\n const isAudioInputDeviceAvailable = async (deviceId: string): Promise<boolean> => {\n try {\n if (!navigator.mediaDevices || !navigator.mediaDevices.enumerateDevices) {\n return false\n }\n\n const devices = await navigator.mediaDevices.enumerateDevices()\n const audioInputDevices = devices.filter((device) => device.kind === 'audioinput')\n\n return audioInputDevices.some((device) => device.deviceId === deviceId)\n } catch (err) {\n console.warn('Error checking audio input device availability:', err)\n return false\n }\n }\n\n // Helper function to get default audio input device\n const getDefaultAudioInputDevice = async (): Promise<string> => {\n try {\n if (!navigator.mediaDevices || !navigator.mediaDevices.enumerateDevices) {\n return 'default'\n }\n\n const devices = await navigator.mediaDevices.enumerateDevices()\n const audioInputDevices = devices.filter((device) => device.kind === 'audioinput')\n\n // Find the default device (usually has deviceId 'default' or is the first one)\n const defaultDevice =\n audioInputDevices.find(\n (device) => device.deviceId === 'default' || device.deviceId === '',\n ) || audioInputDevices[0]\n\n return defaultDevice ? defaultDevice.deviceId : 'default'\n } catch (err) {\n console.warn('Error getting default audio input device:', err)\n return 'default'\n }\n }\n\n // Helper function to check if a video input device is available\n const isVideoInputDeviceAvailable = async (deviceId: string): Promise<boolean> => {\n try {\n if (!navigator.mediaDevices || !navigator.mediaDevices.enumerateDevices) {\n return false\n }\n\n const devices = await navigator.mediaDevices.enumerateDevices()\n const videoInputDevices = devices.filter((device) => device.kind === 'videoinput')\n\n return videoInputDevices.some((device) => device.deviceId === deviceId)\n } catch (err) {\n console.warn('Error checking video input device availability:', err)\n return false\n }\n }\n\n // Helper function to get default video input device\n const getDefaultVideoInputDevice = async (): Promise<string> => {\n try {\n if (!navigator.mediaDevices || !navigator.mediaDevices.enumerateDevices) {\n return 'default'\n }\n\n const devices = await navigator.mediaDevices.enumerateDevices()\n const videoInputDevices = devices.filter((device) => device.kind === 'videoinput')\n\n // Find the default device (usually has deviceId 'default' or is the first one)\n const defaultDevice =\n videoInputDevices.find(\n (device) => device.deviceId === 'default' || device.deviceId === '',\n ) || videoInputDevices[0]\n\n return defaultDevice ? defaultDevice.deviceId : 'default'\n } catch (err) {\n console.warn('Error getting default video input device:', err)\n return 'default'\n }\n }\n\n useEventListener('phone-island-audio-output-change', (data: DeviceInputOutputTypes) => {\n const trySetSinkId = async () => {\n const remoteAudioElement: any = store.getState().player.remoteAudio\n\n if (!remoteAudioElement?.current) {\n console.warn('Remote audio element not available')\n return\n }\n\n let targetDeviceId = data.deviceId\n\n // Check if the requested device is available\n if (targetDeviceId && targetDeviceId !== 'default') {\n const isAvailable = await isAudioOutputDeviceAvailable(targetDeviceId)\n\n if (!isAvailable) {\n console.warn(\n `Audio output device ${targetDeviceId} not available, falling back to default device`,\n )\n targetDeviceId = await getDefaultAudioOutputDevice()\n\n // Update localStorage with the fallback device\n setJSONItem('phone-island-audio-output-device', { deviceId: targetDeviceId })\n }\n }\n\n try {\n // Try to set sink ID directly first (works if audio element is already active)\n await remoteAudioElement.current.setSinkId(targetDeviceId)\n console.info('Default audio output device changed successfully!')\n\n // Save device to localStorage\n setJSONItem('phone-island-audio-output-device', { deviceId: targetDeviceId })\n eventDispatch('phone-island-audio-output-changed', {})\n } catch (err) {\n console.log('Direct setSinkId failed, trying with temporary stream:', err)\n\n try {\n // Create a temporary silent audio stream to activate the audio element\n const audioContext = new (window.AudioContext || (window as any).webkitAudioContext)()\n const oscillator = audioContext.createOscillator()\n const gainNode = audioContext.createGain()\n\n // Create silent audio\n oscillator.frequency.setValueAtTime(440, audioContext.currentTime)\n gainNode.gain.setValueAtTime(0, audioContext.currentTime) // Silent\n\n oscillator.connect(gainNode)\n\n // Get MediaStream from audio context\n const destination = audioContext.createMediaStreamDestination()\n gainNode.connect(destination)\n\n // Set the stream to the audio element\n remoteAudioElement.current.srcObject = destination.stream\n\n // Start the oscillator\n oscillator.start()\n\n // Try setSinkId again after a short delay\n setTimeout(async () => {\n try {\n await remoteAudioElement.current.setSinkId(targetDeviceId)\n console.info(\n 'Default audio output device changed successfully with temporary stream!',\n )\n\n // Clean up temporary stream\n oscillator.stop()\n audioContext.close()\n remoteAudioElement.current.srcObject = null\n\n // Save device to localStorage\n setJSONItem('phone-island-audio-output-device', { deviceId: targetDeviceId })\n eventDispatch('phone-island-audio-output-changed', {})\n } catch (finalErr) {\n console.error('Final setSinkId attempt failed:', finalErr)\n\n // Clean up on failure\n oscillator.stop()\n audioContext.close()\n remoteAudioElement.current.srcObject = null\n\n // If original device failed and we're not already using default, try default\n if (targetDeviceId !== 'default') {\n console.log('Trying fallback to default device')\n try {\n await remoteAudioElement.current.setSinkId('default')\n setJSONItem('phone-island-audio-output-device', { deviceId: 'default' })\n console.info('Fallback to default audio device successful')\n } catch (defaultErr) {\n console.error('Even default device failed:', defaultErr)\n }\n }\n\n // Save device preference anyway for future calls\n setJSONItem('phone-island-audio-output-device', { deviceId: targetDeviceId })\n eventDispatch('phone-island-audio-output-changed', {})\n }\n }, 100)\n } catch (streamErr) {\n console.error('Failed to create temporary audio stream:', streamErr)\n\n // Final fallback: try default device\n if (targetDeviceId !== 'default') {\n try {\n await remoteAudioElement.current.setSinkId('default')\n setJSONItem('phone-island-audio-output-device', { deviceId: 'default' })\n console.info('Emergency fallback to default audio device successful')\n } catch (defaultErr) {\n console.error('Emergency fallback to default device failed:', defaultErr)\n setJSONItem('phone-island-audio-output-device', { deviceId: targetDeviceId })\n }\n } else {\n setJSONItem('phone-island-audio-output-device', { deviceId: targetDeviceId })\n }\n\n eventDispatch('phone-island-audio-output-changed', {})\n }\n }\n }\n\n trySetSinkId()\n })\n\n // Listen for the operator status change\n useEventListener('phone-island-presence-change', (data: any) => {\n changeOperatorStatus(data)\n eventDispatch('phone-island-presence-changed', {})\n })\n\n useEventListener('phone-island-view-changed', (data) => {\n const viewType = data?.viewType\n store.dispatch.island.setIslandView(viewType)\n })\n\n const remoteAudioElement: any = store.getState().player.remoteAudio\n\n //get output device from localstorage\n useEffect(() => {\n if (firstAudioOutputInit && remoteAudioElement) {\n const defaultAudioOutputDevice: any = getJSONItem(\n `phone-island-audio-output-device`,\n )?.deviceId\n eventDispatch('phone-island-audio-output-change', {\n deviceId: defaultAudioOutputDevice,\n })\n setFirstAudioOutputInit(false)\n }\n }, [firstAudioOutputInit, remoteAudioElement])\n\n useEffect(() => {\n checkDarkTheme()\n }, [])\n\n useEventListener('phone-island-theme-change', (theme: any) => {\n setTheme(theme?.selectedTheme)\n })\n\n useEventListener('phone-island-default-device-change', (data) => {\n store.dispatch.currentUser.updateCurrentDefaultDevice(data?.deviceInformationObject)\n eventDispatch('phone-island-default-device-changed', {})\n })\n\n useEventListener('phone-island-alert', (alertType: any) => {\n store.dispatch.alerts.setAlert(alertType.toString())\n })\n\n // Ringtone management events\n useEventListener('phone-island-ringing-tone-list', () => {\n const ringtones = store.getState().ringtones.availableRingtones\n const ringtoneList = ringtones.map((r) => ({\n name: r.name,\n displayName: r.displayName,\n base64Audio: r.base64Audio,\n }))\n eventDispatch('phone-island-ringing-tone-list-response', { ringtones: ringtoneList })\n })\n\n useEventListener('phone-island-ringing-tone-select', (data: { name: string }) => {\n if (data?.name) {\n // Save to localStorage\n setJSONItem('phone-island-selected-ringtone', { value: data.name })\n // Update store\n store.dispatch.ringtones.setSelectedRingtone(data.name)\n eventDispatch('phone-island-ringing-tone-selected', { name: data.name })\n }\n })\n\n useEventListener('phone-island-ringing-tone-output', (data: { deviceId: string }) => {\n if (data?.deviceId) {\n // Save to localStorage\n setJSONItem('phone-island-ringtone-output-device', { value: data.deviceId })\n // Update store\n store.dispatch.ringtones.setOutputDeviceId(data.deviceId)\n eventDispatch('phone-island-ringing-tone-output-changed', { deviceId: data.deviceId })\n }\n })\n\n // Load ringtone preferences from localStorage on mount\n useEffect(() => {\n const savedRingtone = getJSONItem('phone-island-selected-ringtone')\n const savedOutputDevice = getJSONItem('phone-island-ringtone-output-device')\n\n if (savedRingtone?.value) {\n store.dispatch.ringtones.setSelectedRingtone(savedRingtone.value)\n }\n if (savedOutputDevice?.value) {\n store.dispatch.ringtones.setOutputDeviceId(savedOutputDevice.value)\n }\n }, [])\n\n // Manually check if internet connection is enabled or not\n useEventListener('phone-island-check-connection', () => {\n checkInternetConnection().then((internetIsActive) => {\n if (internetIsActive) {\n eventDispatch('phone-island-internet-connected', {})\n } else {\n eventDispatch('phone-island-internet-disconnected', {})\n }\n })\n })\n\n // Check internet connection every 5 seconds\n useEffect(() => {\n const intervalId = setInterval(() => {\n checkInternetConnection().then((internetIsActive) => {\n if (internetIsActive) {\n eventDispatch('phone-island-internet-connected', {})\n } else {\n eventDispatch('phone-island-internet-disconnected', {})\n }\n })\n }, 5000)\n\n return () => clearInterval(intervalId)\n }, [])\n\n useEventListener('phone-island-main-presence', (data: any) => {\n const currentUsernameInformation: any = store.getState().currentUser?.username\n const currentUserObject: any = store.getState().currentUser\n let mainPresenceValueBeforeUpdate = currentUserObject?.mainPresence\n if (\n currentUsernameInformation !== undefined &&\n currentUsernameInformation !== '' &&\n !isEmpty(data[currentUsernameInformation]) &&\n data[currentUsernameInformation]?.mainPresence !== undefined\n ) {\n let newMainPresenceValue = data[currentUsernameInformation]?.mainPresence\n store.dispatch.currentUser.updateMainPresence(data[currentUsernameInformation]?.mainPresence)\n let mainPresenceValueAfterUpdate = newMainPresenceValue\n if (mainPresenceValueAfterUpdate === 'online' && mainPresenceValueBeforeUpdate !== 'online') {\n eventDispatch('phone-island-call-ended', {})\n }\n }\n })\n\n useEventListener('phone-island-call-status', () => {\n const callInformation = store.getState().currentCall\n console.log('Call status debug informations: ', callInformation)\n })\n\n const openParameterizedUrl = (callerNum: any, callerName: any, called: any, uniqueId: any, automatic?: any) => {\n const paramUrlInfo = store.getState().paramUrl\n\n if (!paramUrlInfo?.hasValidUrl) {\n return\n }\n\n const paramUrl = paramUrlInfo.url || ''\n\n if (!paramUrl) {\n return\n }\n\n const { urlOpened } = store.getState().island\n const openParamUrlType = paramUrlInfo.openParamUrlType\n\n if (urlOpened && openParamUrlType !== 'button') {\n return\n }\n\n let processedUrl = paramUrl\n\n if (processedUrl.includes('$CALLER_NUMBER') && callerNum) {\n processedUrl = processedUrl.replace(/\\$CALLER_NUMBER/g, encodeURIComponent(callerNum))\n }\n if (processedUrl.includes('$CALLER_NAME') && callerName) {\n processedUrl = processedUrl.replace(/\\$CALLER_NAME/g, encodeURIComponent(callerName))\n }\n if (processedUrl.includes('$UNIQUEID') && uniqueId) {\n processedUrl = processedUrl.replace(/\\$UNIQUEID/g, encodeURIComponent(uniqueId))\n }\n if (processedUrl.includes('$CALLED') && called) {\n processedUrl = processedUrl.replace(/\\$CALLED/g, encodeURIComponent(called))\n }\n if (processedUrl.includes('{phone}') && callerNum) {\n processedUrl = processedUrl.replace(/\\{phone\\}/g, encodeURIComponent(callerNum))\n }\n\n const formattedUrl = processedUrl.startsWith('http') ? processedUrl : `https://${processedUrl}`\n\n if (uaType !== 'mobile' && !urlParamWithEvent && automatic) {\n const newWindow = window.open('about:blank', '_blank')\n if (newWindow) {\n newWindow.location.href = formattedUrl\n store.dispatch.island.setUrlOpened(true)\n }\n } else {\n eventDispatch('phone-island-url-parameter-opened-external', { formattedUrl })\n }\n }\n\n useEventListener('phone-island-already-opened-external-page', () => {\n store.dispatch.island.setUrlOpened(true)\n })\n\n useEventListener('phone-island-url-parameter-opened', (data) => {\n const paramUrlInfo = store.getState().paramUrl\n\n if (!paramUrlInfo.hasValidUrl) {\n return\n }\n\n const { urlOpened } = store.getState().island\n if (urlOpened) {\n return\n }\n\n const onlyQueues = paramUrlInfo.onlyQueues || false\n const throughTrunk = isFromTrunk(data?.counterpartNum)\n store.dispatch.paramUrl.setThroughTrunk(throughTrunk)\n\n // Calculate automatic flag: false when desktop with nethlink device, true otherwise\n const { default_device } = store.getState().currentUser\n const automatic = !(uaType === 'desktop' && default_device?.type === 'nethlink')\n\n if (data?.direction === 'in') {\n if (onlyQueues === true && data?.throughQueue === true) {\n openParameterizedUrl(\n data?.counterpartNum,\n data?.counterpartName,\n data?.owner,\n data?.linkedId,\n automatic,\n )\n } else if (onlyQueues === false && (throughTrunk === true || data?.throughQueue === true)) {\n openParameterizedUrl(\n data?.counterpartNum,\n data?.counterpartName,\n data?.owner,\n data?.linkedId,\n automatic,\n )\n }\n }\n })\n\n useEventListener('phone-island-user-status', () => {\n const userInformation = store.getState().currentUser\n console.log('User status debug informations: ', userInformation)\n })\n\n useEventListener('phone-island-all-users-status', () => {\n const allUsersInformation = store.getState().users\n console.log('Users status debug informations: ', allUsersInformation)\n })\n\n useEventListener('phone-island-status', () => {\n const phoneIslandInformation = store.getState().island\n console.log('Phone island status debug informations: ', phoneIslandInformation)\n })\n\n useEventListener('phone-island-webrtc-status', () => {\n const webrtcInformation = store.getState().webrtc\n console.log('Webrtc status debug informations: ', webrtcInformation)\n })\n\n useEventListener('phone-island-player-status', () => {\n const playerInformation = store.getState().player\n console.log('Player status debug informations: ', playerInformation)\n })\n\n useEventListener('phone-island-conference-status', () => {\n const conferenceInformation = store.getState().conference\n console.log('Webrtc status debug informations: ', conferenceInformation)\n })\n\n useEventListener('phone-island-streaming-status', () => {\n const streamingInformation = store.getState().streaming\n console.log('Streaming status debug informations: ', streamingInformation)\n })\n\n useEventListener('phone-island-paramurl-status', () => {\n const paramurl = store.getState().paramUrl\n console.log('Paramurl status debug informations: ', paramurl)\n })\n\n useEventListener('phone-island-player-force-stop', () => {\n store.dispatch.player.reset()\n console.log('Audio player is interrupted')\n })\n\n // Download all stores as JSON file - for debugging and backup\n useEventListener('phone-island-stores-download', () => {\n downloadStoresAsJSON()\n eventDispatch('phone-island-stores-downloaded', {})\n })\n\n useEventListener('phone-island-sideview-open', () => {\n store.dispatch.island.toggleSideViewVisible(true)\n store.dispatch.island.setUrlOpened(false)\n eventDispatch('phone-island-sideview-opened', {})\n })\n\n useEventListener('phone-island-sideview-close', () => {\n store.dispatch.island.toggleSideViewVisible(false)\n eventDispatch('phone-island-sideview-closed', {})\n })\n\n useEventListener('phone-island-transcription-close', () => {\n store.dispatch.island.toggleTranscriptionViewVisible(false)\n eventDispatch('phone-island-stop-transcription', {})\n eventDispatch('phone-island-transcription-closed', {})\n })\n\n useEventListener('phone-island-transcription-open', () => {\n eventDispatch('phone-island-start-transcription', {})\n store.dispatch.island.toggleTranscriptionViewVisible(true)\n eventDispatch('phone-island-transcription-opened', {})\n })\n\n useEventListener('phone-island-transcription-close', () => {\n store.dispatch.island.toggleTranscriptionViewVisible(false)\n eventDispatch('phone-island-transcription-closed', {})\n })\n\n useEventListener('phone-island-init-audio', () => {\n // Check if there's an active call - don't interrupt it with audio warm-up\n const { accepted, incoming, outgoing, incomingWebRTC, incomingSocket } = store.getState().currentCall\n const hasActiveCall = accepted || incoming || outgoing || incomingWebRTC || incomingSocket\n\n if (hasActiveCall) {\n console.log('[AUDIO-WARMUP] Skipping audio warm-up: active call in progress')\n return\n }\n\n // Validate SIP_HOST before attempting call\n if (!SIP_HOST || typeof SIP_HOST !== 'string' || SIP_HOST.length === 0) {\n console.warn('[AUDIO-WARMUP] Skipping audio warm-up: SIP_HOST not available', { SIP_HOST })\n return\n }\n\n const { featureCodes } = store.getState().currentUser\n const audioTestCode = featureCodes?.audio_test\n // Always fallback to *41 if audio_test is not available\n const codeToCall = (audioTestCode && typeof audioTestCode === 'string' && audioTestCode.length > 0)\n ? audioTestCode\n : '*41'\n\n console.log('[AUDIO-WARMUP] Starting audio warm-up test call', { codeToCall, SIP_HOST })\n callNumber(codeToCall, SIP_HOST)\n })\n\n useEventListener('phone-island-transcription-toggle', () => {\n const { transcriptionViewIsVisible } = store.getState().island\n const newState = !transcriptionViewIsVisible\n store.dispatch.island.toggleTranscriptionViewVisible(newState)\n eventDispatch(\n newState ? 'phone-island-transcription-opened' : 'phone-island-transcription-closed',\n {},\n )\n })\n\n useEventListener('phone-island-size-change', (args: any) => {\n const { sideViewIsVisible, transcriptionViewIsVisible, actionsExpanded } =\n store.getState().island\n\n // Get current dimensions from args\n const { sizeInformation } = args\n\n // // Calculate extra row dimension ( side view and back call )\n const updatedSizeInformation = {\n ...sizeInformation,\n right: sideViewIsVisible ? '42px' : '0px',\n top: isBackCallActive() ? '40px' : '0px',\n bottomTranscription:\n transcriptionViewIsVisible && actionsExpanded\n ? '335px'\n : transcriptionViewIsVisible && !actionsExpanded\n ? '330px'\n : '0px',\n }\n eventDispatch('phone-island-size-changed', { sizes: updatedSizeInformation })\n })\n\n // Listen for the call end event and set the island size to 0\n useEventListener('phone-island-call-ended', () => {\n const { mainPresence } = store.getState().currentUser\n if (mainPresence === 'online') {\n const sizeInformation: any = {\n width: '0px',\n height: '0px',\n }\n eventDispatch('phone-island-size-change', { sizeInformation })\n eventDispatch('phone-island-sideview-close', {})\n store.dispatch.island.handleResetIslandStore()\n store.dispatch.paramUrl.setThroughTrunk(false)\n }\n })\n\n useEventListener('phone-island-conference-list-open', () => {\n store.dispatch.island.toggleConferenceList(true)\n eventDispatch('phone-island-conference-list-opened', {})\n })\n\n useEventListener('phone-island-alert-removed', (alertRemovedType) => {\n // Get current alerts status\n const { activeAlertsCount } = store.getState().alerts.status\n const { view, previousView } = store.getState().island\n const { isActive } = store.getState().conference\n const alertsData = store.getState().alerts.data\n const currentCall = store.getState().currentCall\n const { incoming, outgoing, accepted } = currentCall\n\n // Check if alert type was provided\n const alertType = alertRemovedType?.type\n\n // Check if user is in a call\n const isInCall =\n currentCall.incoming ||\n currentCall.outgoing ||\n currentCall.accepted ||\n currentCall.conversationId !== ''\n\n // Determine if the island should remain visible\n const shouldKeepVisible =\n incoming ||\n outgoing ||\n accepted ||\n activeAlertsCount > 0 ||\n view === 'player' ||\n view === 'recorder' ||\n view === 'physicalPhoneRecorder' ||\n (view === 'waitingConference' && isActive) ||\n (view === 'transfer' && isActive) ||\n (view === 'settings' && isActive) ||\n (view === 'settings' && (previousView === 'recorder' || previousView === 'player')) ||\n (view === 'operatorBusy' && !isActive)\n\n // Reset the island store only if:\n // 1. The island should not remain visible\n // 2. No more active alerts\n // 3. The specific alert is not active anymore\n // 4. User is not currently in a call\n if (\n !shouldKeepVisible &&\n activeAlertsCount === 0 &&\n (!alertType || (alertsData[alertType] && !alertsData[alertType].active)) &&\n !isInCall\n ) {\n const sizeInformation: any = {\n width: '0px',\n height: '0px',\n }\n eventDispatch('phone-island-size-change', { sizeInformation })\n eventDispatch('phone-island-sideview-close', {})\n store.dispatch.island.handleResetIslandStore()\n }\n })\n\n useEventListener('phone-island-conference-list-close', () => {\n store.dispatch.island.toggleConferenceList(false)\n eventDispatch('phone-island-conference-list-closed', {})\n })\n\n // Listen for conversations updates to handle 'answered' preference for parameterized URL\n useEventListener('phone-island-conversations', (data: any) => {\n // Get the current username (first key in the data object)\n const username = Object.keys(data)[0]\n const currentUsernameInformation: any = store.getState().currentUser?.username\n\n if (username === currentUsernameInformation) {\n const conversations = data[username].conversations\n const paramUrlInfo = store.getState().paramUrl\n const { urlOpened } = store.getState().island\n\n // Only proceed if URL is valid and not already opened\n if (!paramUrlInfo.hasValidUrl || urlOpened) {\n return\n }\n\n // Check if the openParamUrlType is set to 'answered'\n if (paramUrlInfo.openParamUrlType === 'answered') {\n // Check if there are any conversations\n if (conversations && Object.keys(conversations).length > 0) {\n // Get the first conversation (usually there's only one active call)\n const convId = Object.keys(conversations)[0]\n const conv = conversations[convId]\n\n // Check conditions: must be connected and incoming\n if (conv?.connected && conv?.direction === 'in') {\n const onlyQueues = paramUrlInfo.onlyQueues || false\n const calculatedThroughTrunk = isFromTrunk(conv.counterpartNum)\n // Update throughTrunk in paramUrl store\n store.dispatch.paramUrl.setThroughTrunk(calculatedThroughTrunk)\n\n // Check queue conditions based on preferences\n if (onlyQueues === true && conv?.throughQueue === true) {\n // Open URL only for queue calls when onlyQueues is true\n openParameterizedUrl(\n conv.counterpartNum,\n conv.counterpartName,\n conv.owner,\n conv.uniqueId,\n )\n } else if (\n onlyQueues === false &&\n (calculatedThroughTrunk === true || conv?.throughQueue === true)\n ) {\n // Open URL for both trunk and queue calls when onlyQueues is false\n openParameterizedUrl(\n conv.counterpartNum,\n conv.counterpartName,\n conv.owner,\n conv.uniqueId,\n )\n }\n }\n }\n }\n }\n })\n\n return (\n <>\n <Provider store={store}>\n {SIP_EXTEN && SIP_EXTEN.trim() !== '' ? (\n // Full stack with WebRTC when SIP extension is provided\n <WebRTC\n hostName={HOST_NAME}\n sipExten={SIP_EXTEN}\n sipSecret={SIP_SECRET}\n sipHost={SIP_HOST}\n sipPort={SIP_PORT}\n reload={reload}\n reloadedCallback={() => setReloadedWebRTC(true)}\n uaType={uaType}\n >\n <RestAPI hostName={HOST_NAME} username={USERNAME} authToken={AUTH_TOKEN}>\n <Socket\n hostName={HOST_NAME}\n username={USERNAME}\n authToken={AUTH_TOKEN}\n reload={reload}\n reloadedCallback={() => setReloadedSocket(true)}\n uaType={uaType}\n >\n <Events sipHost={SIP_HOST}>\n <Island showAlways={showAlways} uaType={uaType} />\n </Events>\n </Socket>\n </RestAPI>\n </WebRTC>\n ) : (\n // Minimal stack without WebRTC when no SIP extension\n <RestAPI hostName={HOST_NAME} username={USERNAME} authToken={AUTH_TOKEN}>\n <Socket\n hostName={HOST_NAME}\n username={USERNAME}\n authToken={AUTH_TOKEN}\n reload={reload}\n reloadedCallback={() => {\n setReloadedSocket(true)\n setReloadedWebRTC(true)\n }}\n uaType={uaType}\n >\n <Events sipHost={SIP_HOST}>\n <Island showAlways={showAlways} uaType={uaType} />\n </Events>\n </Socket>\n </RestAPI>\n )}\n </Provider>\n </>\n )\n})\n\nPhoneIslandComponent.displayName = 'PhoneIslandComponent'\n\nexport const PhoneIsland = forwardRef<PhoneIslandRef, PhoneIslandProps>(\n (props, ref) => <PhoneIslandComponent {...props} ref={ref} />,\n)\n\nPhoneIsland.displayName = 'PhoneIsland'\n"],"names":["PhoneIslandComponent","forwardRef","_a","ref","dataConfig","_b","showAlways","uaType","_c","urlParamWithEvent","CONFIG","Base64","atob","split","HOST_NAME","USERNAME","AUTH_TOKEN","SIP_EXTEN","SIP_SECRET","SIP_HOST","SIP_PORT","_d","useState","reload","setReload","_e","reloadedWebRTC","setReloadedWebRTC","_f","reloadedSocket","setReloadedSocket","lastReloadTime","useRef","useImperativeHandle","reset","console","info","useEffect","lastActiveTime","Date","now","handleVisibilityChange","document","hidden","timeSinceLastActive","setTimeout","eventDispatch","worker","Worker","wakeUpWorker","type","onmessage","event","data","addEventListener","terminate","removeEventListener","checkInterval","setInterval","store","getState","alerts","isWebRTCDown","webrtc_down","active","isSocketDown","socket_down","timeSinceLastReload","current","sipcall","webrtc","currentCall","accepted","outgoing","iceState","webrtcStuff","pc","iceConnectionState","hasActiveCall","isOnline","navigator","onLine","Math","round","clearInterval","useEventListener","dispatch","island","toggleIsOpen","setIslandView","view","warn","player","emergencyStopAudioPlayer","log","detach","force","setForceReload","__awaiter","targetDeviceId","deviceId","isAudioInputDeviceAvailable","sent","getDefaultAudioInputDevice","setJSONItem","concat","isVideoInputDeviceAvailable","getDefaultVideoInputDevice","_g","firstRender","setFirstRender","_h","firstAudioOutputInit","setFirstAudioOutputInit","initI18n","getParamUrl","paramUrlResponse","url","isValid","trim","paramUrl","setParamUrl","onlyQueues","only_queues","hasValidUrl","error","error_1","mediaDevices","enumerateDevices","devices","filter","device","kind","some","err_3","audioInputDevices","defaultDevice","find","err_4","err_5","videoInputDevices","err_6","remoteAudioElement","remoteAudio","err_1","audioOutputDevices","err_2","setSinkId","err_7","audioContext_1","window","AudioContext","webkitAudioContext","oscillator_1","createOscillator","gainNode","createGain","frequency","setValueAtTime","currentTime","gain","connect","destination","createMediaStreamDestination","srcObject","stream","start","stop","close","finalErr_1","defaultErr_2","streamErr_1","defaultErr_1","changeOperatorStatus","viewType","defaultAudioOutputDevice","getJSONItem","checkDarkTheme","theme","setTheme","selectedTheme","currentUser","updateCurrentDefaultDevice","deviceInformationObject","alertType","setAlert","toString","ringtoneList","ringtones","availableRingtones","map","r","name","displayName","base64Audio","value","setSelectedRingtone","setOutputDeviceId","savedRingtone","savedOutputDevice","checkInternetConnection","then","internetIsActive","intervalId","currentUsernameInformation","username","currentUserObject","mainPresenceValueBeforeUpdate","mainPresence","undefined","isEmpty","newMainPresenceValue","updateMainPresence","callInformation","openParameterizedUrl","callerNum","callerName","called","uniqueId","automatic","paramUrlInfo","urlOpened","openParamUrlType","processedUrl","includes","replace","encodeURIComponent","formattedUrl","startsWith","newWindow","open","location","href","setUrlOpened","throughTrunk","isFromTrunk","counterpartNum","setThroughTrunk","default_device","direction","throughQueue","counterpartName","owner","linkedId","userInformation","allUsersInformation","users","phoneIslandInformation","webrtcInformation","playerInformation","conferenceInformation","conference","streamingInformation","streaming","paramurl","downloadStoresAsJSON","toggleSideViewVisible","toggleTranscriptionViewVisible","incoming","incomingWebRTC","incomingSocket","length","featureCodes","audioTestCode","audio_test","codeToCall","callNumber","newState","transcriptionViewIsVisible","args","sideViewIsVisible","actionsExpanded","sizeInformation","updatedSizeInformation","__assign","right","top","isBackCallActive","bottomTranscription","sizes","width","height","handleResetIslandStore","toggleConferenceList","alertRemovedType","activeAlertsCount","status","previousView","isActive","alertsData","isInCall","conversationId","Object","keys","conversations","conv","connected","calculatedThroughTrunk","React","createElement","Fragment","Provider","WebRTC","hostName","sipExten","sipSecret","sipHost","sipPort","reloadedCallback","RestAPI","authToken","Socket","Events","Island","PhoneIsland","props"],"mappings":"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"}
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});exports.__exports={};
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.exports={};var e={get exports(){return exports.exports},set exports(e){exports.exports=e}};exports.__module=e;
2
2
  //# sourceMappingURL=index6.js.map
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0}),exports.exports={};var e={get exports(){return exports.exports},set exports(e){exports.exports=e}};exports.__module=e;
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});exports.__exports={};
2
2
  //# sourceMappingURL=index8.js.map
@@ -1,2 +1,2 @@
1
- "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("../../../node_modules/tslib/tslib.es6.js"),n=require("react");require("../../../node_modules/react-redux/es/index.js");var i=require("../../../store/index.js"),r=require("../../../utils/deviceUtils.js"),o=require("../../../lib/webrtc/janus.js"),t=require("../../../lib/phone/trunk.js"),u=require("../../../lib/devices/devices.js"),l=require("../../../utils/genericFunctions/eventDispatch.js"),s=require("../../../node_modules/react-redux/es/hooks/useDispatch.js"),a=require("../../../node_modules/react-redux/es/hooks/useSelector.js");exports.useSideViewLogic=function(c){var d,v,p,h,f,b,g,m,_=s.useDispatch(),S=a.useSelector((function(e){return e.currentUser})),j=a.useSelector((function(e){return e.users})),w=a.useSelector((function(e){return e.paramUrl})),V=i.store.select.mediaDevices.videoInputDevices(i.store.getState()),k=n.useRef(o.default),q=a.useSelector((function(e){return e.currentUser.conversations})),C=n.useState([]),D=C[0],T=C[1],U=n.useState(!0),y=U[0],x=U[1],O=n.useCallback((function(e){if(_.island.toggleSideViewVisible(!1),"openUrl"===e){var n=Object.values(q).find((function(e){return Object.keys(e).length>0})),i=n?Object.values(n)[0]:null;if((null==i?void 0:i.connected)&&"in"===(null==i?void 0:i.direction)){var r={counterpartNum:i.counterpartNum,counterpartName:i.counterpartName,owner:i.owner,uniqueId:i.uniqueId,throughQueue:i.throughQueue,throughTrunk:i.throughTrunk,direction:i.direction,connected:i.connected};l.eventDispatch("phone-island-url-parameter-opened",r)}}else null!==e&&_.island.setIslandView(e)}),[_.island,q]),Q=n.useCallback((function(){return e.__awaiter(void 0,void 0,void 0,(function(){var n;return e.__generator(this,(function(e){switch(e.label){case 0:return V.length>0?[4,u.checkWebCamPermission()]:[3,2];case 1:return n=e.sent(),x(n),[2,n];case 2:return x(!1),[2,!1]}}))}))}),[V.length]),I=n.useCallback((function(){return e.__awaiter(void 0,void 0,void 0,(function(){return e.__generator(this,(function(e){switch(e.label){case 0:return[4,Q()];case 1:return e.sent()&&(O("video"),i.store.dispatch.currentCall.updateCurrentCall({isLocalVideoEnabled:!0,isStartingVideoCall:!0})),[2]}}))}))}),[Q,O]),E=n.useCallback((function(){O("video"),i.store.dispatch.screenShare.update({isStartingScreenShare:!0})}),[O]),M=n.useMemo((function(){var e;return(null===(e=null==S?void 0:S.profile)||void 0===e?void 0:e.macro_permissions)||{}}),[null===(d=null==S?void 0:S.profile)||void 0===d?void 0:d.macro_permissions]),N=n.useMemo((function(){var e,n,i,r,o,t;return{canRecord:(null===(i=null===(n=null===(e=null==M?void 0:M.settings)||void 0===e?void 0:e.permissions)||void 0===n?void 0:n.recording)||void 0===i?void 0:i.value)||!1,canShareScreen:"safari"!==k.current.webRTCAdapter.browserDetails.browser&&((null===(t=null===(o=null===(r=null==M?void 0:M.nethvoice_cti)||void 0===r?void 0:r.permissions)||void 0===o?void 0:o.screen_sharing)||void 0===t?void 0:t.value)||!1),canSwitchDevice:(null==D?void 0:D.length)>0}}),[null===(h=null===(p=null===(v=null==M?void 0:M.settings)||void 0===v?void 0:v.permissions)||void 0===p?void 0:p.recording)||void 0===h?void 0:h.value,null===(g=null===(b=null===(f=null==M?void 0:M.nethvoice_cti)||void 0===f?void 0:f.permissions)||void 0===b?void 0:b.screen_sharing)||void 0===g?void 0:g.value,null==D?void 0:D.length,null===(m=null==S?void 0:S.default_device)||void 0===m?void 0:m.type,c]),P=n.useMemo((function(){var e=Object.values(q).find((function(e){return Object.keys(e).length>0})),n=e?Object.values(e)[0]:null;if("never"===w.openParamUrlType)return!1;if(!(null==n?void 0:n.connected)||"in"!==(null==n?void 0:n.direction))return!1;if("button"===w.openParamUrlType){if(w.onlyQueues&&(null==n?void 0:n.throughQueue))return!0;if(!w.onlyQueues&&(t.isFromTrunk(n.counterpartNum)||(null==n?void 0:n.throughQueue)))return!0}return!1}),[q,w.onlyQueues,w.openParamUrlType]);n.useEffect((function(){if(S&&j){var e=r.getAvailableDevices(S,j);T(e)}}),[S,j]);var A=n.useCallback((function(){_.island.toggleSideViewVisible(!1),setTimeout((function(){l.eventDispatch("phone-island-transcription-open",{})}),100)}),[_.island]),L=n.useMemo((function(){return(null==S?void 0:S.call_transcription_enabled)||!1}),[null==S?void 0:S.call_transcription_enabled]);return e.__assign(e.__assign({userInformation:S,availableDevices:D,videoInputDevices:V,isVideoCallButtonVisible:y,isUrlButtonEnabled:P,hasValidUrl:w.hasValidUrl,isTranscriptionEnabled:L},N),{goToVideoCall:I,goToScreenSharing:E,closeSideViewAndLaunchEvent:O,openTranscriptionView:A})};
1
+ "use strict";Object.defineProperty(exports,"__esModule",{value:!0});var e=require("../../../node_modules/tslib/tslib.es6.js"),i=require("react");require("../../../node_modules/react-redux/es/index.js");var n=require("../../../store/index.js"),r=require("../../../utils/deviceUtils.js"),o=require("../../../lib/webrtc/janus.js"),u=require("../../../lib/phone/trunk.js"),t=require("../../../lib/devices/devices.js"),l=require("../../../utils/genericFunctions/eventDispatch.js"),s=require("../../../node_modules/react-redux/es/hooks/useDispatch.js"),a=require("../../../node_modules/react-redux/es/hooks/useSelector.js");exports.useSideViewLogic=function(d){var c,v,p,h,f,b,g,m,_=s.useDispatch(),S=a.useSelector((function(e){return e.currentUser})),j=a.useSelector((function(e){return e.users})),w=a.useSelector((function(e){return e.paramUrl})),k=n.store.select.mediaDevices.videoInputDevices(n.store.getState()),V=i.useRef(o.default),q=a.useSelector((function(e){return e.currentUser.conversations})),C=i.useState([]),D=C[0],T=C[1],U=i.useState(!0),y=U[0],I=U[1],x=i.useCallback((function(e){if(_.island.toggleSideViewVisible(!1),"openUrl"===e){var i=Object.values(q).find((function(e){return Object.keys(e).length>0})),n=i?Object.values(i)[0]:null;if((null==n?void 0:n.connected)&&"in"===(null==n?void 0:n.direction)){var r={counterpartNum:n.counterpartNum,counterpartName:n.counterpartName,owner:n.owner,uniqueId:n.uniqueId,linkedId:n.linkedId,throughQueue:n.throughQueue,throughTrunk:n.throughTrunk,direction:n.direction,connected:n.connected};l.eventDispatch("phone-island-url-parameter-opened",r)}}else null!==e&&_.island.setIslandView(e)}),[_.island,q]),O=i.useCallback((function(){return e.__awaiter(void 0,void 0,void 0,(function(){var i;return e.__generator(this,(function(e){switch(e.label){case 0:return k.length>0?[4,t.checkWebCamPermission()]:[3,2];case 1:return i=e.sent(),I(i),[2,i];case 2:return I(!1),[2,!1]}}))}))}),[k.length]),Q=i.useCallback((function(){return e.__awaiter(void 0,void 0,void 0,(function(){return e.__generator(this,(function(e){switch(e.label){case 0:return[4,O()];case 1:return e.sent()&&(x("video"),n.store.dispatch.currentCall.updateCurrentCall({isLocalVideoEnabled:!0,isStartingVideoCall:!0})),[2]}}))}))}),[O,x]),E=i.useCallback((function(){x("video"),n.store.dispatch.screenShare.update({isStartingScreenShare:!0})}),[x]),M=i.useMemo((function(){var e;return(null===(e=null==S?void 0:S.profile)||void 0===e?void 0:e.macro_permissions)||{}}),[null===(c=null==S?void 0:S.profile)||void 0===c?void 0:c.macro_permissions]),N=i.useMemo((function(){var e,i,n,r,o,u,t,l,s;return{canRecord:(null===(n=null===(i=null===(e=null==M?void 0:M.settings)||void 0===e?void 0:e.permissions)||void 0===i?void 0:i.recording)||void 0===n?void 0:n.value)||!1,canShareScreen:"safari"!==(null===(u=null===(o=null===(r=null==V?void 0:V.current)||void 0===r?void 0:r.webRTCAdapter)||void 0===o?void 0:o.browserDetails)||void 0===u?void 0:u.browser)&&((null===(s=null===(l=null===(t=null==M?void 0:M.nethvoice_cti)||void 0===t?void 0:t.permissions)||void 0===l?void 0:l.screen_sharing)||void 0===s?void 0:s.value)||!1),canSwitchDevice:(null==D?void 0:D.length)>0}}),[null===(h=null===(p=null===(v=null==M?void 0:M.settings)||void 0===v?void 0:v.permissions)||void 0===p?void 0:p.recording)||void 0===h?void 0:h.value,null===(g=null===(b=null===(f=null==M?void 0:M.nethvoice_cti)||void 0===f?void 0:f.permissions)||void 0===b?void 0:b.screen_sharing)||void 0===g?void 0:g.value,null==D?void 0:D.length,null===(m=null==S?void 0:S.default_device)||void 0===m?void 0:m.type,d]),P=i.useMemo((function(){var e=Object.values(q).find((function(e){return Object.keys(e).length>0})),i=e?Object.values(e)[0]:null;if("never"===w.openParamUrlType)return!1;if(!(null==i?void 0:i.connected)||"in"!==(null==i?void 0:i.direction))return!1;if("button"===w.openParamUrlType){if(w.onlyQueues&&(null==i?void 0:i.throughQueue))return!0;if(!w.onlyQueues&&(u.isFromTrunk(i.counterpartNum)||(null==i?void 0:i.throughQueue)))return!0}return!1}),[q,w.onlyQueues,w.openParamUrlType]);i.useEffect((function(){if(S&&j){var e=r.getAvailableDevices(S,j);T(e)}}),[S,j]);var A=i.useCallback((function(){_.island.toggleSideViewVisible(!1),setTimeout((function(){l.eventDispatch("phone-island-transcription-open",{})}),100)}),[_.island]),L=i.useMemo((function(){return(null==S?void 0:S.call_transcription_enabled)||!1}),[null==S?void 0:S.call_transcription_enabled]);return e.__assign(e.__assign({userInformation:S,availableDevices:D,videoInputDevices:k,isVideoCallButtonVisible:y,isUrlButtonEnabled:P,hasValidUrl:w.hasValidUrl,isTranscriptionEnabled:L},N),{goToVideoCall:Q,goToScreenSharing:E,closeSideViewAndLaunchEvent:x,openTranscriptionView:A})};
2
2
  //# sourceMappingURL=useSideViewLogic.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"useSideViewLogic.js","sources":["../../../../src/components/SideView/hooks/useSideViewLogic.ts"],"sourcesContent":["import { useCallback, useEffect, useMemo, useRef, useState } from 'react'\nimport { useDispatch, useSelector } from 'react-redux'\nimport { Dispatch, RootState, store } from '../../../store'\nimport { getAvailableDevices } from '../../../utils/deviceUtils'\nimport JanusLib from '../../../lib/webrtc/janus.js'\nimport { isFromTrunk } from '../../../lib/user/extensions'\nimport { checkWebCamPermission } from '../../../lib/devices/devices'\nimport { eventDispatch } from '../../../utils'\n\nexport const useSideViewLogic = (uaType?: string) => {\n const dispatch = useDispatch<Dispatch>()\n const userInformation = useSelector((state: RootState) => state.currentUser)\n const allUsersInformation = useSelector((state: RootState) => state.users)\n const paramUrlData = useSelector((state: RootState) => state.paramUrl)\n const videoInputDevices = store.select.mediaDevices.videoInputDevices(store.getState())\n const janus = useRef<any>(JanusLib)\n const conversations = useSelector((state: RootState) => state.currentUser.conversations)\n\n const [availableDevices, setAvailableDevices] = useState([])\n const [isVideoCallButtonVisible, setIsVideoCallButtonVisible] = useState(true)\n\n const closeSideViewAndLaunchEvent = useCallback(\n (viewType: any) => {\n dispatch.island.toggleSideViewVisible(false)\n if (viewType === 'openUrl') {\n const activeConversation = Object.values(conversations).find(\n (conv) => Object.keys(conv).length > 0,\n )\n const conversationData = activeConversation ? Object.values(activeConversation)[0] : null\n\n if (conversationData?.connected && conversationData?.direction === 'in') {\n const eventData = {\n counterpartNum: conversationData.counterpartNum,\n counterpartName: conversationData.counterpartName,\n owner: conversationData.owner,\n uniqueId: conversationData.uniqueId,\n throughQueue: conversationData.throughQueue,\n throughTrunk: conversationData.throughTrunk,\n direction: conversationData.direction,\n connected: conversationData.connected,\n }\n eventDispatch('phone-island-url-parameter-opened', eventData)\n }\n } else if (viewType !== null) {\n dispatch.island.setIslandView(viewType)\n }\n },\n [dispatch.island, conversations],\n )\n\n const checkCameraPermission = useCallback(async () => {\n if (videoInputDevices.length > 0) {\n const isWebCamAccepted = await checkWebCamPermission()\n setIsVideoCallButtonVisible(isWebCamAccepted)\n return isWebCamAccepted\n } else {\n setIsVideoCallButtonVisible(false)\n return false\n }\n }, [videoInputDevices.length])\n\n const goToVideoCall = useCallback(async () => {\n const cameraPermission = await checkCameraPermission()\n if (cameraPermission) {\n closeSideViewAndLaunchEvent('video')\n store.dispatch.currentCall.updateCurrentCall({\n isLocalVideoEnabled: true,\n isStartingVideoCall: true,\n })\n }\n }, [checkCameraPermission, closeSideViewAndLaunchEvent])\n\n const goToScreenSharing = useCallback(() => {\n closeSideViewAndLaunchEvent('video')\n store.dispatch.screenShare.update({\n isStartingScreenShare: true,\n })\n }, [closeSideViewAndLaunchEvent])\n\n const permissions = useMemo(\n () => userInformation?.profile?.macro_permissions || {},\n [userInformation?.profile?.macro_permissions],\n )\n\n const userCapabilities = useMemo(\n () => ({\n canRecord: permissions?.settings?.permissions?.recording?.value || false,\n canShareScreen:\n janus.current.webRTCAdapter.browserDetails.browser !== 'safari' &&\n (permissions?.nethvoice_cti?.permissions?.screen_sharing?.value || false),\n canSwitchDevice: availableDevices?.length > 0,\n }),\n [\n permissions?.settings?.permissions?.recording?.value,\n permissions?.nethvoice_cti?.permissions?.screen_sharing?.value,\n availableDevices?.length,\n userInformation?.default_device?.type,\n uaType,\n ],\n )\n\n const isUrlButtonEnabled = useMemo(() => {\n const activeConversation = Object.values(conversations).find(\n (conv) => Object.keys(conv).length > 0,\n )\n const conversationData = activeConversation ? Object.values(activeConversation)[0] : null\n\n // If param url type is 'never', return false\n if (paramUrlData.openParamUrlType === 'never') {\n return false\n }\n\n if (!conversationData?.connected || conversationData?.direction !== 'in') {\n return false\n }\n\n // open param url type is set to 'button'\n if (paramUrlData.openParamUrlType === 'button') {\n if (paramUrlData.onlyQueues && conversationData?.throughQueue) {\n return true\n } else if (\n !paramUrlData.onlyQueues &&\n (isFromTrunk(conversationData.counterpartNum) || conversationData?.throughQueue)\n ) {\n return true\n }\n }\n\n return false\n }, [conversations, paramUrlData.onlyQueues, paramUrlData.openParamUrlType])\n\n useEffect(() => {\n if (userInformation && allUsersInformation) {\n const devices = getAvailableDevices(userInformation, allUsersInformation)\n setAvailableDevices(devices)\n }\n }, [userInformation, allUsersInformation])\n\n const openTranscriptionView = useCallback(() => {\n // Close SideView, collapse actions, and open TranscriptionView\n dispatch.island.toggleSideViewVisible(false)\n setTimeout(() => {\n eventDispatch('phone-island-transcription-open', {})\n }, 100)\n }, [dispatch.island])\n\n const isTranscriptionEnabled = useMemo(\n () => userInformation?.call_transcription_enabled || false,\n [userInformation?.call_transcription_enabled],\n )\n\n return {\n userInformation,\n availableDevices,\n videoInputDevices,\n isVideoCallButtonVisible,\n isUrlButtonEnabled,\n hasValidUrl: paramUrlData.hasValidUrl,\n isTranscriptionEnabled,\n ...userCapabilities,\n goToVideoCall,\n goToScreenSharing,\n closeSideViewAndLaunchEvent,\n openTranscriptionView,\n }\n}\n"],"names":["uaType","dispatch","useDispatch","userInformation","useSelector","state","currentUser","allUsersInformation","users","paramUrlData","paramUrl","videoInputDevices","store","select","mediaDevices","getState","janus","useRef","JanusLib","conversations","_j","useState","availableDevices","setAvailableDevices","_k","isVideoCallButtonVisible","setIsVideoCallButtonVisible","closeSideViewAndLaunchEvent","useCallback","viewType","island","toggleSideViewVisible","activeConversation","Object","values","find","conv","keys","length","conversationData","connected","direction","eventData","counterpartNum","counterpartName","owner","uniqueId","throughQueue","throughTrunk","eventDispatch","setIslandView","checkCameraPermission","__awaiter","checkWebCamPermission","isWebCamAccepted","_a","sent","goToVideoCall","currentCall","updateCurrentCall","isLocalVideoEnabled","isStartingVideoCall","goToScreenSharing","screenShare","update","isStartingScreenShare","permissions","useMemo","profile","macro_permissions","userCapabilities","canRecord","_c","settings","_b","recording","value","canShareScreen","current","webRTCAdapter","browserDetails","browser","_f","_e","nethvoice_cti","_d","screen_sharing","canSwitchDevice","_g","_h","default_device","type","isUrlButtonEnabled","openParamUrlType","onlyQueues","isFromTrunk","useEffect","devices","getAvailableDevices","openTranscriptionView","setTimeout","isTranscriptionEnabled","call_transcription_enabled","__assign","hasValidUrl"],"mappings":"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"}
1
+ {"version":3,"file":"useSideViewLogic.js","sources":["../../../../src/components/SideView/hooks/useSideViewLogic.ts"],"sourcesContent":["import { useCallback, useEffect, useMemo, useRef, useState } from 'react'\nimport { useDispatch, useSelector } from 'react-redux'\nimport { Dispatch, RootState, store } from '../../../store'\nimport { getAvailableDevices } from '../../../utils/deviceUtils'\nimport JanusLib from '../../../lib/webrtc/janus.js'\nimport { isFromTrunk } from '../../../lib/user/extensions'\nimport { checkWebCamPermission } from '../../../lib/devices/devices'\nimport { eventDispatch } from '../../../utils'\n\nexport const useSideViewLogic = (uaType?: string) => {\n const dispatch = useDispatch<Dispatch>()\n const userInformation = useSelector((state: RootState) => state.currentUser)\n const allUsersInformation = useSelector((state: RootState) => state.users)\n const paramUrlData = useSelector((state: RootState) => state.paramUrl)\n const videoInputDevices = store.select.mediaDevices.videoInputDevices(store.getState())\n const janus = useRef<any>(JanusLib)\n const conversations = useSelector((state: RootState) => state.currentUser.conversations)\n\n const [availableDevices, setAvailableDevices] = useState([])\n const [isVideoCallButtonVisible, setIsVideoCallButtonVisible] = useState(true)\n\n const closeSideViewAndLaunchEvent = useCallback(\n (viewType: any) => {\n dispatch.island.toggleSideViewVisible(false)\n if (viewType === 'openUrl') {\n const activeConversation = Object.values(conversations).find(\n (conv) => Object.keys(conv).length > 0,\n )\n const conversationData = activeConversation ? Object.values(activeConversation)[0] : null\n\n if (conversationData?.connected && conversationData?.direction === 'in') {\n const eventData = {\n counterpartNum: conversationData.counterpartNum,\n counterpartName: conversationData.counterpartName,\n owner: conversationData.owner,\n uniqueId: conversationData.uniqueId,\n linkedId: conversationData.linkedId,\n throughQueue: conversationData.throughQueue,\n throughTrunk: conversationData.throughTrunk,\n direction: conversationData.direction,\n connected: conversationData.connected,\n }\n eventDispatch('phone-island-url-parameter-opened', eventData)\n }\n } else if (viewType !== null) {\n dispatch.island.setIslandView(viewType)\n }\n },\n [dispatch.island, conversations],\n )\n\n const checkCameraPermission = useCallback(async () => {\n if (videoInputDevices.length > 0) {\n const isWebCamAccepted = await checkWebCamPermission()\n setIsVideoCallButtonVisible(isWebCamAccepted)\n return isWebCamAccepted\n } else {\n setIsVideoCallButtonVisible(false)\n return false\n }\n }, [videoInputDevices.length])\n\n const goToVideoCall = useCallback(async () => {\n const cameraPermission = await checkCameraPermission()\n if (cameraPermission) {\n closeSideViewAndLaunchEvent('video')\n store.dispatch.currentCall.updateCurrentCall({\n isLocalVideoEnabled: true,\n isStartingVideoCall: true,\n })\n }\n }, [checkCameraPermission, closeSideViewAndLaunchEvent])\n\n const goToScreenSharing = useCallback(() => {\n closeSideViewAndLaunchEvent('video')\n store.dispatch.screenShare.update({\n isStartingScreenShare: true,\n })\n }, [closeSideViewAndLaunchEvent])\n\n const permissions = useMemo(\n () => userInformation?.profile?.macro_permissions || {},\n [userInformation?.profile?.macro_permissions],\n )\n\n const userCapabilities = useMemo(\n () => ({\n canRecord: permissions?.settings?.permissions?.recording?.value || false,\n canShareScreen:\n janus?.current?.webRTCAdapter?.browserDetails?.browser !== 'safari' &&\n (permissions?.nethvoice_cti?.permissions?.screen_sharing?.value || false),\n canSwitchDevice: availableDevices?.length > 0,\n }),\n [\n permissions?.settings?.permissions?.recording?.value,\n permissions?.nethvoice_cti?.permissions?.screen_sharing?.value,\n availableDevices?.length,\n userInformation?.default_device?.type,\n uaType,\n ],\n )\n\n const isUrlButtonEnabled = useMemo(() => {\n const activeConversation = Object.values(conversations).find(\n (conv) => Object.keys(conv).length > 0,\n )\n const conversationData = activeConversation ? Object.values(activeConversation)[0] : null\n\n // If param url type is 'never', return false\n if (paramUrlData.openParamUrlType === 'never') {\n return false\n }\n\n if (!conversationData?.connected || conversationData?.direction !== 'in') {\n return false\n }\n\n // open param url type is set to 'button'\n if (paramUrlData.openParamUrlType === 'button') {\n if (paramUrlData.onlyQueues && conversationData?.throughQueue) {\n return true\n } else if (\n !paramUrlData.onlyQueues &&\n (isFromTrunk(conversationData.counterpartNum) || conversationData?.throughQueue)\n ) {\n return true\n }\n }\n\n return false\n }, [conversations, paramUrlData.onlyQueues, paramUrlData.openParamUrlType])\n\n useEffect(() => {\n if (userInformation && allUsersInformation) {\n const devices = getAvailableDevices(userInformation, allUsersInformation)\n setAvailableDevices(devices)\n }\n }, [userInformation, allUsersInformation])\n\n const openTranscriptionView = useCallback(() => {\n // Close SideView, collapse actions, and open TranscriptionView\n dispatch.island.toggleSideViewVisible(false)\n setTimeout(() => {\n eventDispatch('phone-island-transcription-open', {})\n }, 100)\n }, [dispatch.island])\n\n const isTranscriptionEnabled = useMemo(\n () => userInformation?.call_transcription_enabled || false,\n [userInformation?.call_transcription_enabled],\n )\n\n return {\n userInformation,\n availableDevices,\n videoInputDevices,\n isVideoCallButtonVisible,\n isUrlButtonEnabled,\n hasValidUrl: paramUrlData.hasValidUrl,\n isTranscriptionEnabled,\n ...userCapabilities,\n goToVideoCall,\n goToScreenSharing,\n closeSideViewAndLaunchEvent,\n openTranscriptionView,\n }\n}\n"],"names":["uaType","dispatch","useDispatch","userInformation","useSelector","state","currentUser","allUsersInformation","users","paramUrlData","paramUrl","videoInputDevices","store","select","mediaDevices","getState","janus","useRef","JanusLib","conversations","_j","useState","availableDevices","setAvailableDevices","_k","isVideoCallButtonVisible","setIsVideoCallButtonVisible","closeSideViewAndLaunchEvent","useCallback","viewType","island","toggleSideViewVisible","activeConversation","Object","values","find","conv","keys","length","conversationData","connected","direction","eventData","counterpartNum","counterpartName","owner","uniqueId","linkedId","throughQueue","throughTrunk","eventDispatch","setIslandView","checkCameraPermission","__awaiter","checkWebCamPermission","isWebCamAccepted","_a","sent","goToVideoCall","currentCall","updateCurrentCall","isLocalVideoEnabled","isStartingVideoCall","goToScreenSharing","screenShare","update","isStartingScreenShare","permissions","useMemo","profile","macro_permissions","userCapabilities","canRecord","_c","settings","_b","recording","value","canShareScreen","_f","_d","current","webRTCAdapter","_e","browserDetails","browser","_h","nethvoice_cti","_g","screen_sharing","canSwitchDevice","default_device","type","isUrlButtonEnabled","openParamUrlType","onlyQueues","isFromTrunk","useEffect","devices","getAvailableDevices","openTranscriptionView","setTimeout","isTranscriptionEnabled","call_transcription_enabled","__assign","hasValidUrl"],"mappings":"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"}