2020-09-12 13:49:20 +00:00
import { Registry } from "../events" ;
import { ClientGlobalControlEvents } from "../events/GlobalEvents" ;
import { ConnectionHandler } from "../ConnectionHandler" ;
import { createErrorModal , createInfoModal , createInputModal } from "../ui/elements/Modal" ;
import PermissionType from "../permission/PermissionType" ;
import { spawnQueryCreate } from "../ui/modal/ModalQuery" ;
import { openBanList } from "../ui/modal/ModalBanList" ;
import { formatMessage } from "../ui/frames/chat" ;
import { CommandResult } from "../connection/ServerConnectionDeclaration" ;
import { spawnSettingsModal } from "../ui/modal/ModalSettings" ;
2021-03-23 11:03:00 +00:00
import { spawnPermissionEditorModal } from "../ui/modal/permission/ModalController" ;
2020-11-29 13:42:02 +00:00
import { tr , tra } from "../i18n/localize" ;
2020-09-17 21:06:02 +00:00
import { spawnGlobalSettingsEditor } from "tc-shared/ui/modal/global-settings-editor/Controller" ;
import { spawnModalCssVariableEditor } from "tc-shared/ui/modal/css-editor/Controller" ;
2020-09-24 09:24:31 +00:00
import { server_connections } from "tc-shared/ConnectionManager" ;
2020-11-07 12:16:07 +00:00
import { spawnVideoSourceSelectModal } from "tc-shared/ui/modal/video-source/Controller" ;
2020-12-16 21:06:46 +00:00
import { LogCategory , logError , logWarn } from "tc-shared/log" ;
2020-11-28 14:41:44 +00:00
import { spawnEchoTestModal } from "tc-shared/ui/modal/echo-test/Controller" ;
2021-01-10 13:21:38 +00:00
import { spawnConnectModalNew } from "tc-shared/ui/modal/connect/Controller" ;
2021-03-14 18:39:08 +00:00
import { spawnBookmarkModal } from "tc-shared/ui/modal/bookmarks/Controller" ;
2021-03-18 17:25:20 +00:00
import { Sound } from "tc-shared/audio/Sounds" ;
2021-04-23 11:09:05 +00:00
import { spawnAboutModal } from "tc-shared/ui/modal/about/Controller" ;
2020-04-06 14:29:40 +00:00
2020-04-09 13:10:14 +00:00
/ *
2020-04-06 14:29:40 +00:00
function initialize_sounds ( event_registry : Registry < ClientGlobalControlEvents > ) {
{
let microphone_muted = undefined ;
event_registry . on ( "action_toggle_speaker" , event = > {
if ( microphone_muted === event . state ) return ;
if ( typeof microphone_muted !== "undefined" )
manager . play ( event . state ? Sound.MICROPHONE_MUTED : Sound.MICROPHONE_ACTIVATED ) ;
microphone_muted = event . state ;
} )
}
{
let speakers_muted = undefined ;
event_registry . on ( "action_toggle_microphone" , event = > {
if ( speakers_muted === event . state ) return ;
if ( typeof speakers_muted !== "undefined" )
manager . play ( event . state ? Sound.SOUND_MUTED : Sound.SOUND_ACTIVATED ) ;
speakers_muted = event . state ;
} )
}
}
2020-04-09 13:10:14 +00:00
export function load_default_states ( event_registry : Registry < ClientGlobalControlEvents > ) {
event_registry . fire ( "action_toggle_speaker" , { state : settings.static_global ( Settings . KEY_CONTROL_MUTE_OUTPUT , false ) } ) ;
event_registry . fire ( "action_toggle_microphone" , { state : settings.static_global ( Settings . KEY_CONTROL_MUTE_INPUT , false ) } ) ;
2020-04-06 14:29:40 +00:00
}
2020-04-09 13:10:14 +00:00
* /
2020-04-06 14:29:40 +00:00
export function initialize ( event_registry : Registry < ClientGlobalControlEvents > ) {
let current_connection_handler : ConnectionHandler | undefined ;
2020-09-24 13:51:22 +00:00
server_connections . events ( ) . on ( "notify_active_handler_changed" , event = > current_connection_handler = event . newHandler ) ;
2020-04-09 13:10:14 +00:00
//initialize_sounds(event_registry);
2020-04-06 14:29:40 +00:00
event_registry . on ( "action_open_window" , event = > {
const handle_import_error = error = > {
2021-01-10 16:36:57 +00:00
logError ( LogCategory . GENERAL , tr ( "Failed to import script: %o" ) , error ) ;
2020-04-06 14:29:40 +00:00
createErrorModal ( tr ( "Failed to load window" ) , tr ( "Failed to load the bookmark window.\nSee the console for more details." ) ) . open ( ) ;
} ;
const connection_handler = event . connection || current_connection_handler ;
switch ( event . window ) {
case "bookmark-manage" :
2021-03-14 18:39:08 +00:00
spawnBookmarkModal ( ) ;
2020-04-06 14:29:40 +00:00
break ;
case "query-manage" :
if ( ! connection_handler || ! connection_handler . connected ) {
createErrorModal ( tr ( "You have to be connected" ) , tr ( "You have to be connected!" ) ) . open ( ) ;
return ;
}
import ( "../ui/modal/ModalQueryManage" ) . catch ( error = > {
handle_import_error ( error ) ;
return undefined ;
} ) . then ( window = > {
window ? . spawnQueryManage ( connection_handler ) ;
} ) ;
break ;
case "query-create" :
if ( ! connection_handler || ! connection_handler . connected ) {
createErrorModal ( tr ( "You have to be connected" ) , tr ( "You have to be connected!" ) ) . open ( ) ;
return ;
}
if ( connection_handler . permissions . neededPermission ( PermissionType . B_CLIENT_CREATE_MODIFY_SERVERQUERY_LOGIN ) . granted ( 1 ) ) {
spawnQueryCreate ( connection_handler ) ;
} else {
createErrorModal ( tr ( "You dont have the permission" ) , tr ( "You dont have the permission to create a server query login" ) ) . open ( ) ;
connection_handler . sound . play ( Sound . ERROR_INSUFFICIENT_PERMISSIONS ) ;
}
break ;
case "ban-list" :
if ( ! connection_handler || ! connection_handler . connected ) {
createErrorModal ( tr ( "You have to be connected" ) , tr ( "You have to be connected!" ) ) . open ( ) ;
return ;
}
if ( connection_handler . permissions . neededPermission ( PermissionType . B_CLIENT_BAN_LIST ) . granted ( 1 ) ) {
openBanList ( connection_handler ) ;
} else {
createErrorModal ( tr ( "You dont have the permission" ) , tr ( "You dont have the permission to view the ban list" ) ) . open ( ) ;
connection_handler . sound . play ( Sound . ERROR_INSUFFICIENT_PERMISSIONS ) ;
}
break ;
case "permissions" :
if ( ! connection_handler || ! connection_handler . connected ) {
createErrorModal ( tr ( "You have to be connected" ) , tr ( "You have to be connected!" ) ) . open ( ) ;
return ;
}
if ( connection_handler )
2020-06-15 14:56:05 +00:00
spawnPermissionEditorModal ( connection_handler ) ;
2020-04-06 14:29:40 +00:00
else
createErrorModal ( tr ( "You have to be connected" ) , tr ( "You have to be connected!" ) ) . open ( ) ;
break ;
case "token-list" :
createErrorModal ( tr ( "Not implemented" ) , tr ( "Token list is not implemented yet!" ) ) . open ( ) ;
break ;
case "token-use" :
//FIXME: Move this out to a dedicated method
createInputModal ( tr ( "Use token" ) , tr ( "Please enter your token/privilege key" ) , message = > message . length > 0 , result = > {
if ( ! result ) return ;
if ( connection_handler . serverConnection . connected )
connection_handler . serverConnection . send_command ( "tokenuse" , {
token : result
} ) . then ( ( ) = > {
createInfoModal ( tr ( "Use token" ) , tr ( "Toke successfully used!" ) ) . open ( ) ;
} ) . catch ( error = > {
createErrorModal ( tr ( "Use token" ) , formatMessage ( tr ( "Failed to use token: {}" ) , error instanceof CommandResult ? error.message : error ) ) . open ( ) ;
} ) ;
} ) . open ( ) ;
break ;
2020-09-17 21:06:02 +00:00
case "css-variable-editor" :
spawnModalCssVariableEditor ( ) ;
break ;
2020-04-06 14:29:40 +00:00
case "settings" :
spawnSettingsModal ( ) ;
break ;
2020-09-17 21:06:02 +00:00
case "settings-registry" :
spawnGlobalSettingsEditor ( ) ;
break ;
2020-10-05 10:49:13 +00:00
case "about" :
2021-04-23 11:09:05 +00:00
spawnAboutModal ( ) ;
2020-10-05 10:49:13 +00:00
break ;
2020-11-28 14:41:44 +00:00
case "server-echo-test" :
2021-01-10 15:26:45 +00:00
const connection = event . connection || server_connections . getActiveConnectionHandler ( ) ;
2020-11-28 14:41:44 +00:00
if ( connection ) {
spawnEchoTestModal ( connection ) ;
}
break ;
2020-04-06 14:29:40 +00:00
default :
2021-01-10 16:36:57 +00:00
logWarn ( LogCategory . GENERAL , tr ( "Received open window event for an unknown window: %s" ) , event . window ) ;
2020-04-06 14:29:40 +00:00
}
} ) ;
2020-04-09 13:10:14 +00:00
event_registry . on ( "action_open_window_connect" , event = > {
2021-01-10 13:21:38 +00:00
spawnConnectModalNew ( {
2021-01-10 13:26:35 +00:00
connectInANewTab : event.newTab
2020-04-09 13:10:14 +00:00
} ) ;
} ) ;
2020-09-07 10:42:00 +00:00
event_registry . on ( "action_open_window_settings" , event = > {
spawnSettingsModal ( event . defaultCategory ) ;
} ) ;
2020-10-05 10:49:13 +00:00
event_registry . on ( "action_open_window_permissions" , event = > {
2021-01-10 15:26:45 +00:00
spawnPermissionEditorModal ( event . connection ? event.connection : server_connections.getActiveConnectionHandler ( ) , event . defaultTab ) ;
2020-10-05 10:49:13 +00:00
} ) ;
2020-11-07 12:16:07 +00:00
event_registry . on ( "action_toggle_video_broadcasting" , event = > {
if ( event . enabled ) {
2020-11-29 20:00:59 +00:00
const connection = event . connection ;
if ( ! connection . connected ) {
createErrorModal ( tr ( "You're not connected" ) , tr ( "You're not connected to any server!" ) ) . open ( ) ;
return ;
}
2020-12-11 23:16:17 +00:00
2020-12-16 21:06:46 +00:00
spawnVideoSourceSelectModal ( event . broadcastType , event . quickSelect ? { mode : "select-quick" , defaultDevice : event.defaultDevice } : { mode : "select-default" , defaultDevice : event.defaultDevice } )
2021-01-04 20:28:47 +00:00
. then ( async ( { source , config } ) = > {
2020-11-22 12:48:15 +00:00
if ( ! source ) { return ; }
2020-11-07 12:16:07 +00:00
2020-11-22 12:48:15 +00:00
try {
2020-12-12 12:19:04 +00:00
const broadcast = connection . getServerConnection ( ) . getVideoConnection ( ) . getLocalBroadcast ( event . broadcastType ) ;
if ( broadcast . getState ( ) . state === "initializing" || broadcast . getState ( ) . state === "broadcasting" ) {
2021-01-04 20:28:47 +00:00
broadcast . changeSource ( source , config ) . catch ( error = > {
2020-12-12 12:19:04 +00:00
logError ( LogCategory . VIDEO , tr ( "Failed to change broadcast source: %o" ) , event . broadcastType , error ) ;
if ( typeof error !== "string" ) {
error = tr ( "lookup the console for detail" ) ;
}
if ( event . broadcastType === "camera" ) {
createErrorModal ( tr ( "Failed to change video source" ) , tra ( "Failed to change video broadcasting source:\n{}" , error ) ) . open ( ) ;
} else {
createErrorModal ( tr ( "Failed to change screen sharing source" ) , tra ( "Failed to change screen sharing source:\n{}" , error ) ) . open ( ) ;
}
} ) ;
} else {
2021-01-04 20:28:47 +00:00
broadcast . startBroadcasting ( source , config ) . catch ( error = > {
2020-11-22 12:48:15 +00:00
logError ( LogCategory . VIDEO , tr ( "Failed to start %s broadcasting: %o" ) , event . broadcastType , error ) ;
if ( typeof error !== "string" ) {
error = tr ( "lookup the console for detail" ) ;
}
if ( event . broadcastType === "camera" ) {
createErrorModal ( tr ( "Failed to start video broadcasting" ) , tra ( "Failed to start video broadcasting:\n{}" , error ) ) . open ( ) ;
} else {
createErrorModal ( tr ( "Failed to start screen sharing" ) , tra ( "Failed to start screen sharing:\n{}" , error ) ) . open ( ) ;
}
} ) ;
2020-12-12 12:19:04 +00:00
}
2020-11-22 12:48:15 +00:00
} finally {
source . deref ( ) ;
}
} ) ;
2020-11-07 12:16:07 +00:00
} else {
2020-12-12 12:19:04 +00:00
const connection = event . connection ;
const broadcast = connection . getServerConnection ( ) . getVideoConnection ( ) . getLocalBroadcast ( event . broadcastType ) ;
broadcast . stopBroadcasting ( ) ;
2020-11-07 12:16:07 +00:00
}
} ) ;
2020-12-16 21:06:46 +00:00
event_registry . on ( "action_edit_video_broadcasting" , event = > {
const connection = event . connection ;
if ( ! connection . connected ) {
createErrorModal ( tr ( "You're not connected" ) , tr ( "You're not connected to any server!" ) ) . open ( ) ;
return ;
}
const broadcast = connection . getServerConnection ( ) . getVideoConnection ( ) . getLocalBroadcast ( event . broadcastType ) ;
if ( ! broadcast || ( broadcast . getState ( ) . state !== "broadcasting" && broadcast . getState ( ) . state !== "initializing" ) ) {
createErrorModal ( tr ( "You're not broadcasting" ) , tr ( "You're not broadcasting any video!" ) ) . open ( ) ;
return ;
}
spawnVideoSourceSelectModal ( event . broadcastType , { mode : "edit" , source : broadcast.getSource ( ) , broadcastConstraints : Object.assign ( { } , broadcast . getConstraints ( ) ) } )
2021-01-04 20:28:47 +00:00
. then ( async ( { source , config } ) = > {
2020-12-16 21:06:46 +00:00
if ( ! source ) {
return ;
}
if ( broadcast . getState ( ) . state !== "broadcasting" && broadcast . getState ( ) . state !== "initializing" ) {
createErrorModal ( tr ( "Video broadcast has ended" ) , tr ( "The video broadcast has ended.\nUpdate failed." ) ) . open ( ) ;
return ;
}
2021-01-04 20:28:47 +00:00
await broadcast . changeSource ( source , config ) ;
2020-12-16 21:06:46 +00:00
} ) . catch ( error = > {
logWarn ( LogCategory . VIDEO , tr ( "Failed to edit video broadcast: %o" ) , error ) ;
createErrorModal ( tr ( "Broadcast update failed" ) , tr ( "We failed to update the current video broadcast settings.\nThe old settings will be used." ) ) . open ( ) ;
} ) ;
} ) ;
2020-04-06 14:29:40 +00:00
}