// @flow import JitsiMeetJS, { JitsiRecordingConstants } from '../base/lib-jitsi-meet'; import { NOTIFICATION_TIMEOUT, hideNotification, showErrorNotification, showNotification } from '../notifications'; import { CLEAR_RECORDING_SESSIONS, RECORDING_SESSION_UPDATED, SET_PENDING_RECORDING_NOTIFICATION_UID, SET_STREAM_KEY } from './actionTypes'; /** * Clears the data of every recording sessions. * * @returns {{ * type: CLEAR_RECORDING_SESSIONS * }} */ export function clearRecordingSessions() { return { type: CLEAR_RECORDING_SESSIONS }; } /** * Signals that the pending recording notification should be removed from the * screen. * * @param {string} streamType - The type of the stream ({@code 'file'} or * {@code 'stream'}). * @returns {Function} */ export function hidePendingRecordingNotification(streamType: string) { return (dispatch: Function, getState: Function) => { const { pendingNotificationUids } = getState()['features/recording']; const pendingNotificationUid = pendingNotificationUids[streamType]; if (pendingNotificationUid) { dispatch(hideNotification(pendingNotificationUid)); dispatch( _setPendingRecordingNotificationUid( undefined, streamType)); } }; } /** * Sets the stream key last used by the user for later reuse. * * @param {string} streamKey - The stream key to set. * @returns {{ * type: SET_STREAM_KEY, * streamKey: string * }} */ export function setLiveStreamKey(streamKey: string) { return { type: SET_STREAM_KEY, streamKey }; } /** * Signals that the pending recording notification should be shown on the * screen. * * @param {string} streamType - The type of the stream ({@code file} or * {@code stream}). * @returns {Function} */ export function showPendingRecordingNotification(streamType: string) { return (dispatch: Function) => { const isLiveStreaming = streamType === JitsiMeetJS.constants.recording.mode.STREAM; const dialogProps = isLiveStreaming ? { descriptionKey: 'liveStreaming.pending', titleKey: 'dialog.liveStreaming' } : { descriptionKey: 'recording.pending', titleKey: 'dialog.recording' }; const showNotificationAction = showNotification({ isDismissAllowed: false, ...dialogProps }); dispatch(showNotificationAction); dispatch(_setPendingRecordingNotificationUid( showNotificationAction.uid, streamType)); }; } /** * Signals that the recording error notification should be shown. * * @param {Object} props - The Props needed to render the notification. * @returns {showErrorNotification} */ export function showRecordingError(props: Object) { return showErrorNotification(props); } /** * Signals that the stopped recording notification should be shown on the * screen for a given period. * * @param {string} streamType - The type of the stream ({@code file} or * {@code stream}). * @param {string?} participantName - The participant name stopping the recording. * @returns {showNotification} */ export function showStoppedRecordingNotification(streamType: string, participantName?: string) { const isLiveStreaming = streamType === JitsiMeetJS.constants.recording.mode.STREAM; const descriptionArguments = { name: participantName }; const dialogProps = isLiveStreaming ? { descriptionKey: participantName ? 'liveStreaming.offBy' : 'liveStreaming.off', descriptionArguments, titleKey: 'dialog.liveStreaming' } : { descriptionKey: participantName ? 'recording.offBy' : 'recording.off', descriptionArguments, titleKey: 'dialog.recording' }; return showNotification(dialogProps, NOTIFICATION_TIMEOUT); } /** * Signals that a started recording notification should be shown on the * screen for a given period. * * @param {string} streamType - The type of the stream ({@code file} or * {@code stream}). * @param {string} participantName - The participant name that started the recording. * @returns {showNotification} */ export function showStartedRecordingNotification(streamType: string, participantName: string) { const isLiveStreaming = streamType === JitsiMeetJS.constants.recording.mode.STREAM; const descriptionArguments = { name: participantName }; const dialogProps = isLiveStreaming ? { descriptionKey: 'liveStreaming.onBy', descriptionArguments, titleKey: 'dialog.liveStreaming' } : { descriptionKey: 'recording.onBy', descriptionArguments, titleKey: 'dialog.recording' }; return showNotification(dialogProps, NOTIFICATION_TIMEOUT); } /** * Updates the known state for a given recording session. * * @param {Object} session - The new state to merge with the existing state in * redux. * @returns {{ * type: RECORDING_SESSION_UPDATED, * sessionData: Object * }} */ export function updateRecordingSessionData(session: Object) { const status = session.getStatus(); const timestamp = status === JitsiRecordingConstants.status.ON ? Date.now() / 1000 : undefined; return { type: RECORDING_SESSION_UPDATED, sessionData: { error: session.getError(), id: session.getID(), initiator: session.getInitiator(), liveStreamViewURL: session.getLiveStreamViewURL(), mode: session.getMode(), status, terminator: session.getTerminator(), timestamp } }; } /** * Sets UID of the the pending streaming notification to use it when hinding * the notification is necessary, or unsets it when undefined (or no param) is * passed. * * @param {?number} uid - The UID of the notification. * @param {string} streamType - The type of the stream ({@code file} or * {@code stream}). * @returns {{ * type: SET_PENDING_RECORDING_NOTIFICATION_UID, * streamType: string, * uid: number * }} */ function _setPendingRecordingNotificationUid(uid: ?number, streamType: string) { return { type: SET_PENDING_RECORDING_NOTIFICATION_UID, streamType, uid }; }