Skip to content

Commit

Permalink
fix(SIP): get dial-in info from signaling settings
Browse files Browse the repository at this point in the history
Signed-off-by: Maksim Sukharev <[email protected]>
  • Loading branch information
Antreesy committed Dec 2, 2024
1 parent 49f4e77 commit a24667f
Show file tree
Hide file tree
Showing 4 changed files with 44 additions and 38 deletions.
4 changes: 1 addition & 3 deletions src/components/RightSidebar/RightSidebar.vue
Original file line number Diff line number Diff line change
Expand Up @@ -68,9 +68,7 @@
<InformationOutline :size="20" />
</template>
<SetGuestUsername v-if="!getUserId" />
<SipSettings v-if="showSIPSettings"
:meeting-id="conversation.token"
:attendee-pin="conversation.attendeePin" />
<SipSettings v-if="showSIPSettings" :conversation="conversation" />
<div v-if="!getUserId" id="app-settings">
<div id="app-settings-header">
<NcButton type="tertiary" @click="showSettings">
Expand Down
70 changes: 35 additions & 35 deletions src/components/RightSidebar/SipSettings.vue
Original file line number Diff line number Diff line change
Expand Up @@ -3,52 +3,52 @@
- SPDX-License-Identifier: AGPL-3.0-or-later
-->

<script setup lang="ts">
import { computed, onBeforeUnmount, onMounted, ref } from 'vue'

import { t } from '@nextcloud/l10n'

import { EventBus } from '../../services/EventBus.ts'
import { Conversation, SignalingSettings } from '../../types/index.ts'
import { readableNumber } from '../../utils/readableNumber.ts'

const props = defineProps<{
conversation: Conversation,
}>()

const dialInInfo = ref(t('spreed', 'Loading …'))
const meetingId = computed(() => readableNumber(props.conversation.token))
const attendeePin = computed(() => readableNumber(props.conversation.attendeePin))

onMounted(() => {
EventBus.on('signaling-settings-updated', setDialInInfoFromSettings)
})
onBeforeUnmount(() => {
EventBus.off('signaling-settings-updated', setDialInInfoFromSettings)
})

/**
* @param payload emitted payload (array)
* @param payload."0" received signaling settings upon joining
*/
function setDialInInfoFromSettings([settings]: [SignalingSettings]) {
dialInInfo.value = settings.sipDialinInfo
}
</script>

<template>
<div class="sip-settings">
<h3>{{ t('spreed', 'Dial-in information') }}</h3>
<p>{{ dialInInfo }}</p>

<h3>{{ t('spreed', 'Meeting ID') }}</h3>
<p>{{ readableNumber(meetingId) }}</p>
<p>{{ meetingId }}</p>

<h3>{{ t('spreed', 'Your PIN') }}</h3>
<p>{{ readableNumber(attendeePin) }}</p>
<p>{{ attendeePin }}</p>
</div>
</template>

<script>
import { loadState } from '@nextcloud/initial-state'
import { t } from '@nextcloud/l10n'

import { readableNumber } from '../../utils/readableNumber.ts'

export default {
name: 'SipSettings',

props: {
attendeePin: {
type: String,
required: true,
},
meetingId: {
type: String,
required: true,
},
},

data() {
return {
dialInInfo: loadState('spreed', 'sip_dialin_info'),
}
},

methods: {
t,
readableNumber,
}
}
</script>

<style lang="scss" scoped>
.sip-settings {
h3 {
Expand Down
3 changes: 3 additions & 0 deletions src/types/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -55,6 +55,9 @@ export type Notification<T = Record<string, RichObject & Record<string, unknown>
actions: NotificationAction[],
}

// Signaling
export type SignalingSettings = components['schemas']['SignalingSettings']

// Conversations
export type Conversation = components['schemas']['Room']

Expand Down
5 changes: 5 additions & 0 deletions src/utils/signaling.js
Original file line number Diff line number Diff line change
Expand Up @@ -124,6 +124,7 @@ Signaling.Base.prototype.setSettings = function(settings) {
}

this.settings = settings
this._trigger('settingsUpdated', [this.settings])

if (this._pendingUpdateSettingsPromise) {
this._pendingUpdateSettingsPromise.resolve()
Expand Down Expand Up @@ -364,6 +365,8 @@ function Internal(settings) {
}.bind(this), 500)

this._joinCallAgainOnceDisconnected = false
// FIXME: Signaling.Base.prototype._trigger() isn't working yet, but we only need to emit event
EventBus.emit('signaling-settings-updated', [settings])
}

Internal.prototype = new Signaling.Base()
Expand Down Expand Up @@ -611,6 +614,8 @@ function Standalone(settings, urls) {
this.joinedUsers = {}
this.rooms = []
this.connect()
// FIXME: Signaling.Base.prototype._trigger() isn't working yet, but we only need to emit event
EventBus.emit('signaling-settings-updated', [settings])
}

Standalone.prototype = new Signaling.Base()
Expand Down

0 comments on commit a24667f

Please sign in to comment.