Skip to content
This repository has been archived by the owner on Nov 5, 2023. It is now read-only.

Commit

Permalink
Add speakBack experiment
Browse files Browse the repository at this point in the history
  • Loading branch information
curtgrimes committed Jun 24, 2020
1 parent 90271e6 commit 0084432
Show file tree
Hide file tree
Showing 2 changed files with 106 additions and 73 deletions.
176 changes: 103 additions & 73 deletions app/pages/captioner.vue
Original file line number Diff line number Diff line change
Expand Up @@ -246,91 +246,121 @@ export default {
});
sequence++;
};
RemoteEventBus.$on('sendMutationToReceivers', ({ mutation, payload }) => {
if (
this.$store.state.settings.integrations.webhooks.on &&
mutation === 'captioner/APPEND_TRANSCRIPT_STABILIZED'
) {
callWebhook({
url: this.$store.state.settings.integrations.webhooks.url,
method: this.$store.state.settings.integrations.webhooks.method,
transcript: payload ? payload.transcript : '',
});
lastWebhookEventDate = Date.now();
}
if (
mutation === 'captioner/SET_TRANSCRIPT_INTERIM' &&
Date.now() - lastWebhookEventDate >= 100
) {
RemoteEventBus.$on(
'sendMutationToReceivers',
async ({ mutation, payload }) => {
if (
this.$store.state.settings.share.roomId &&
this.$store.state.socket.isConnected &&
this.$store.state.settings.share.on
this.$store.state.settings.integrations.webhooks.on &&
mutation === 'captioner/APPEND_TRANSCRIPT_STABILIZED'
) {
this.$socket.sendObj({
action: 'mutation',
mutation,
payload,
callWebhook({
url: this.$store.state.settings.integrations.webhooks.url,
method: this.$store.state.settings.integrations.webhooks.method,
transcript: payload ? payload.transcript : '',
});
lastWebhookEventDate = Date.now();
}
}
if (
[
'captioner/APPEND_TRANSCRIPT_FINAL',
'captioner/CLEAR_TRANSCRIPT_INTERIM',
'captioner/CLEAR_TRANSCRIPT',
if (
mutation === 'captioner/SET_TRANSCRIPT_INTERIM' &&
Date.now() - lastWebhookEventDate >= 100
) {
if (
this.$store.state.settings.share.roomId &&
this.$store.state.socket.isConnected &&
this.$store.state.settings.share.on
) {
this.$socket.sendObj({
action: 'mutation',
mutation,
payload,
});
lastWebhookEventDate = Date.now();
}
}
'SET_TEXT_COLOR',
'SET_TEXT_COLOR_INTERIM',
'SET_FONT_FAMILY',
'SET_FONT_VARIANT',
'SET_TEXT_SIZE',
'SET_LINE_HEIGHT',
'SET_LETTER_SPACING',
'SET_TEXT_TRANSFORM',
'SET_SHADOW_COLOR',
'SET_SHADOW_OPACITY',
'SET_SHADOW_BLUR_RADIUS',
'SET_SHADOW_OFFSET_X',
'SET_SHADOW_OFFSET_Y',
'SET_BACKGROUND_COLOR',
'SET_BACKGROUND_OPACITY',
'SET_ALIGNMENT_HORIZONTAL',
'SET_ALIGNMENT_VERTICAL',
'SET_ALIGNMENT_PADDING',
].includes(mutation)
) {
if (
this.$store.state.settings.share.roomId &&
this.$store.state.socket.isConnected
[
'captioner/APPEND_TRANSCRIPT_FINAL',
'captioner/CLEAR_TRANSCRIPT_INTERIM',
'captioner/CLEAR_TRANSCRIPT',
'SET_TEXT_COLOR',
'SET_TEXT_COLOR_INTERIM',
'SET_FONT_FAMILY',
'SET_FONT_VARIANT',
'SET_TEXT_SIZE',
'SET_LINE_HEIGHT',
'SET_LETTER_SPACING',
'SET_TEXT_TRANSFORM',
'SET_SHADOW_COLOR',
'SET_SHADOW_OPACITY',
'SET_SHADOW_BLUR_RADIUS',
'SET_SHADOW_OFFSET_X',
'SET_SHADOW_OFFSET_Y',
'SET_BACKGROUND_COLOR',
'SET_BACKGROUND_OPACITY',
'SET_ALIGNMENT_HORIZONTAL',
'SET_ALIGNMENT_VERTICAL',
'SET_ALIGNMENT_PADDING',
].includes(mutation)
) {
this.$socket.sendObj({
action: 'mutation',
mutation,
payload,
});
if (
this.$store.state.settings.share.roomId &&
this.$store.state.socket.isConnected
) {
this.$socket.sendObj({
action: 'mutation',
mutation,
payload,
});
}
}
}
if (
[
'captioner/APPEND_TRANSCRIPT_FINAL',
'captioner/SET_CAPTIONER_OFF',
'captioner/APPEND_TRANSCRIPT_STABILIZED',
].includes(mutation) &&
this.$store.state.settings.integrations.dropbox.accessToken &&
this.$store.state.captioner.transcript.final
) {
if ('captioner/SET_CAPTIONER_OFF' === mutation) {
// immediate
this.$store.dispatch('SAVE_TO_DROPBOX');
} else {
this.saveToDropboxThrottled();
if (
[
'captioner/APPEND_TRANSCRIPT_FINAL',
'captioner/SET_CAPTIONER_OFF',
'captioner/APPEND_TRANSCRIPT_STABILIZED',
].includes(mutation) &&
this.$store.state.settings.integrations.dropbox.accessToken &&
this.$store.state.captioner.transcript.final
) {
if ('captioner/SET_CAPTIONER_OFF' === mutation) {
// immediate
this.$store.dispatch('SAVE_TO_DROPBOX');
} else {
this.saveToDropboxThrottled();
}
}
if (
[
'captioner/APPEND_TRANSCRIPT_FINAL',
// 'captioner/APPEND_TRANSCRIPT_STABILIZED',
].includes(mutation) &&
this.experiments.includes('speakBack')
) {
const voices = await new Promise((resolve) => {
let voices = speechSynthesis.getVoices();
if (voices.length) {
resolve(voices);
return;
}
speechSynthesis.onvoiceschanged = () => {
voices = speechSynthesis.getVoices();
resolve(voices);
};
});
let utterance = new SpeechSynthesisUtterance(payload.transcriptFinal);
utterance.voice = voices.find(
(voice) => voice.name === 'Google US English'
);
window.speechSynthesis.speak(utterance);
}
}
});
);
// Zoom integration
let zoomTranscriptBuffer = [];
Expand Down Expand Up @@ -665,4 +695,4 @@ export default {
}, 1000 * 30),
},
};
</script>
</script>
3 changes: 3 additions & 0 deletions app/pages/captioner/settings/experiments/index.vue
Original file line number Diff line number Diff line change
Expand Up @@ -216,6 +216,8 @@ export default {
return 'Save transcript with timings to Dropbox.';
case 'zoom':
return 'Test Zoom integration. Once enabled, go to the Zoom tab in settings.';
case 'speakBack':
return 'Speak words back using browser speech synthesis.';
default:
return '';
}
Expand All @@ -228,6 +230,7 @@ export default {
'science',
'saveTranscriptWithTimingsToDropbox',
'zoom',
'speakBack',
].includes(this.experimentName);
},
addExperiment: function({ withConfirmation }) {
Expand Down

0 comments on commit 0084432

Please sign in to comment.