egirlskey/packages/frontend/src/pages/settings/sounds.sound.vue

51 lines
1.4 KiB
Vue
Raw Normal View History

<!--
SPDX-FileCopyrightText: syuilo and other misskey contributors
SPDX-License-Identifier: AGPL-3.0-only
-->
<template>
2023-01-06 04:40:17 +00:00
<div class="_gaps_m">
2023-01-07 06:09:46 +00:00
<MkSelect v-model="type">
<template #label>{{ i18n.ts.sound }}</template>
<option v-for="x in soundsTypes" :key="x" :value="x">{{ x == null ? i18n.ts.none : x }}</option>
2023-01-07 06:09:46 +00:00
</MkSelect>
2023-05-19 11:52:15 +00:00
<MkRange v-model="volume" :min="0" :max="1" :step="0.05" :textConverter="(v) => `${Math.floor(v * 100)}%`">
<template #label>{{ i18n.ts.volume }}</template>
2023-01-07 06:09:46 +00:00
</MkRange>
2023-01-06 00:41:14 +00:00
<div class="_buttons">
<MkButton inline @click="listen"><i class="ti ti-player-play"></i> {{ i18n.ts.listen }}</MkButton>
<MkButton inline primary @click="save"><i class="ti ti-check"></i> {{ i18n.ts.save }}</MkButton>
</div>
</div>
</template>
<script lang="ts" setup>
import { } from 'vue';
2023-01-07 06:09:46 +00:00
import MkSelect from '@/components/MkSelect.vue';
2023-01-06 00:41:14 +00:00
import MkButton from '@/components/MkButton.vue';
2023-01-07 06:09:46 +00:00
import MkRange from '@/components/MkRange.vue';
2023-09-19 07:37:43 +00:00
import { i18n } from '@/i18n.js';
import { playFile, soundsTypes } from '@/scripts/sound.js';
const props = defineProps<{
type: string;
volume: number;
}>();
const emit = defineEmits<{
(ev: 'update', result: { type: string; volume: number; }): void;
}>();
let type = $ref(props.type);
let volume = $ref(props.volume);
function listen() {
playFile(type, volume);
}
function save() {
emit('update', { type, volume });
}
</script>