diff options
| author | syuilo <Syuilotan@yahoo.co.jp> | 2021-08-14 18:36:22 +0900 |
|---|---|---|
| committer | syuilo <Syuilotan@yahoo.co.jp> | 2021-08-14 18:36:22 +0900 |
| commit | f95d5701a22757f73ddb3e56cc99153de4146be5 (patch) | |
| tree | b47eded7d8a9c9341bf0d072569356bba9f37265 /src/client | |
| parent | add sound (diff) | |
| download | sharkey-f95d5701a22757f73ddb3e56cc99153de4146be5.tar.gz sharkey-f95d5701a22757f73ddb3e56cc99153de4146be5.tar.bz2 sharkey-f95d5701a22757f73ddb3e56cc99153de4146be5.zip | |
feat(client): ジョブキューウィジェットに警報音を鳴らす設定を追加
Diffstat (limited to 'src/client')
| -rw-r--r-- | src/client/scripts/sound.ts | 26 | ||||
| -rw-r--r-- | src/client/widgets/job-queue.vue | 10 |
2 files changed, 28 insertions, 8 deletions
diff --git a/src/client/scripts/sound.ts b/src/client/scripts/sound.ts index d3422bfff2..c51fa8f215 100644 --- a/src/client/scripts/sound.ts +++ b/src/client/scripts/sound.ts @@ -2,6 +2,23 @@ import { ColdDeviceStorage } from '@client/store'; const cache = new Map<string, HTMLAudioElement>(); +export function getAudio(file: string, useCache = true): HTMLAudioElement { + let audio: HTMLAudioElement; + if (useCache && cache.has(file)) { + audio = cache.get(file); + } else { + audio = new Audio(`/static-assets/client/sounds/${file}.mp3`); + if (useCache) cache.set(file, audio); + } + return audio; +} + +export function setVolume(audio: HTMLAudioElement, volume: number): HTMLAudioElement { + const masterVolume = ColdDeviceStorage.get('sound_masterVolume'); + audio.volume = masterVolume - ((1 - volume) * masterVolume); + return audio; +} + export function play(type: string) { const sound = ColdDeviceStorage.get('sound_' + type as any); if (sound.type == null) return; @@ -12,13 +29,6 @@ export function playFile(file: string, volume: number) { const masterVolume = ColdDeviceStorage.get('sound_masterVolume'); if (masterVolume === 0) return; - let audio: HTMLAudioElement; - if (cache.has(file)) { - audio = cache.get(file); - } else { - audio = new Audio(`/static-assets/client/sounds/${file}.mp3`); - cache.set(file, audio); - } - audio.volume = masterVolume - ((1 - volume) * masterVolume); + const audio = setVolume(getAudio(file), volume); audio.play(); } diff --git a/src/client/widgets/job-queue.vue b/src/client/widgets/job-queue.vue index beb80f7faf..327d8ede6d 100644 --- a/src/client/widgets/job-queue.vue +++ b/src/client/widgets/job-queue.vue @@ -50,6 +50,7 @@ import { defineComponent, markRaw } from 'vue'; import define from './define'; import * as os from '@client/os'; import number from '@client/filters/number'; +import * as sound from '@client/scripts/sound'; const widget = define({ name: 'jobQueue', @@ -58,6 +59,10 @@ const widget = define({ type: 'boolean', default: false, }, + sound: { + type: 'boolean', + default: false, + }, }) }); @@ -79,6 +84,7 @@ export default defineComponent({ delayed: 0, }, prev: {}, + sound: sound.setVolume(sound.getAudio('syuilo/queue-jammed'), 1) }; }, created() { @@ -107,6 +113,10 @@ export default defineComponent({ this[domain].active = stats[domain].active; this[domain].waiting = stats[domain].waiting; this[domain].delayed = stats[domain].delayed; + + if (this[domain].waiting > 0 && this.props.sound && this.sound.paused) { + this.sound.play(); + } } }, |