diff options
author | Joas Schilling <coding@schilljs.com> | 2023-01-23 14:39:46 +0100 |
---|---|---|
committer | Joas Schilling <coding@schilljs.com> | 2023-01-23 14:47:53 +0100 |
commit | 1abd0fec734a1aef77c40c95a6f0629d05eb76a2 (patch) | |
tree | 2ae980c95b37bfd0c96c7c620ed5059ae135245a /src | |
parent | be1bb3a1ff583ddfbacca612489e85057f9e5f21 (diff) |
Add start and stop recording actions to top bar menu
Signed-off-by: Marco <marcoambrosini@icloud.com>
Signed-off-by: Joas Schilling <coding@schilljs.com>
Diffstat (limited to 'src')
-rw-r--r-- | src/components/TopBar/TopBarMenu.vue | 59 |
1 files changed, 51 insertions, 8 deletions
diff --git a/src/components/TopBar/TopBarMenu.vue b/src/components/TopBar/TopBarMenu.vue index a43b212b8..baf962b75 100644 --- a/src/components/TopBar/TopBarMenu.vue +++ b/src/components/TopBar/TopBarMenu.vue @@ -65,6 +65,25 @@ {{ t('spreed', 'Mute others') }} </NcActionButton> </template> + <!-- Call recording --> + <template v-if="canModerate"> + <NcActionButton v-if="!isRecording && isInCall" + :close-after-click="true" + @click="startRecording"> + <template #icon> + <RecordCircle :size="20" /> + </template> + {{ t('spreed', 'Start recording') }} + </NcActionButton> + <NcActionButton v-else-if="isRecording && isInCall" + :close-after-click="true" + @click="stopRecording"> + <template #icon> + <StopIcon :size="20" /> + </template> + {{ t('spreed', 'Stop recording') }} + </NcActionButton> + </template> <!-- Device settings --> <NcActionButton :close-after-click="true" @click="showSettings"> @@ -123,19 +142,24 @@ import NcActions from '@nextcloud/vue/dist/Components/NcActions.js' import NcActionSeparator from '@nextcloud/vue/dist/Components/NcActionSeparator.js' import NcActionButton from '@nextcloud/vue/dist/Components/NcActionButton.js' import { emit } from '@nextcloud/event-bus' +import { generateUrl } from '@nextcloud/router' + +import isInCall from '../../mixins/isInCall.js' +import { callParticipantCollection } from '../../utils/webrtc/index.js' +import { CALL, CONVERSATION, PARTICIPANT } from '../../constants.js' + import PromotedView from '../missingMaterialDesignIcons/PromotedView.vue' -import Cog from 'vue-material-design-icons/Cog.vue' -import DotsHorizontal from 'vue-material-design-icons/DotsHorizontal.vue' import GridView from '../missingMaterialDesignIcons/GridView.vue' -import HandBackLeft from 'vue-material-design-icons/HandBackLeft.vue' -import isInCall from '../../mixins/isInCall.js' + import Blur from 'vue-material-design-icons/Blur.vue' import BlurOff from 'vue-material-design-icons/BlurOff.vue' -import { callParticipantCollection } from '../../utils/webrtc/index.js' -import { generateUrl } from '@nextcloud/router' -import { CONVERSATION, PARTICIPANT } from '../../constants.js' -import VideoIcon from 'vue-material-design-icons/Video.vue' +import Cog from 'vue-material-design-icons/Cog.vue' +import DotsHorizontal from 'vue-material-design-icons/DotsHorizontal.vue' +import HandBackLeft from 'vue-material-design-icons/HandBackLeft.vue' import MicrophoneOff from 'vue-material-design-icons/MicrophoneOff.vue' +import RecordCircle from 'vue-material-design-icons/RecordCircle.vue' +import StopIcon from 'vue-material-design-icons/Stop.vue' +import VideoIcon from 'vue-material-design-icons/Video.vue' export default { name: 'TopBarMenu', @@ -153,6 +177,8 @@ export default { BlurOff, VideoIcon, MicrophoneOff, + RecordCircle, + StopIcon, }, mixins: [ @@ -303,6 +329,10 @@ export default { canModerate() { return this.canFullModerate || this.participantType === PARTICIPANT.TYPE.GUEST_MODERATOR }, + + isRecording() { + return this.conversation.callRecording !== CALL.RECORDING.OFF + }, }, methods: { @@ -391,6 +421,19 @@ export default { openConversationSettings() { emit('show-conversation-settings', { token: this.token }) }, + + startRecording() { + this.$store.dispatch('startCallRecording', { + token: this.token, + callRecording: CALL.RECORDING.VIDEO, + }) + }, + + stopRecording() { + this.$store.dispatch('stopCallRecording', { + token: this.token, + }) + }, }, } </script> |