mirror of
https://github.com/koel/koel
synced 2025-01-04 16:58:49 +00:00
44 lines
1.5 KiB
Vue
44 lines
1.5 KiB
Vue
<template>
|
|
<div class="playback-controls flex flex-1 flex-col justify-center">
|
|
<div class="flex items-center justify-between md:justify-center gap-5 md:gap-12 px-4 md:px-0">
|
|
<LikeButton v-if="song" :song="song" class="text-base" />
|
|
<button v-else type="button" /> <!-- a placeholder to maintain the asymmetric layout -->
|
|
|
|
<FooterBtn class="text-2xl" title="Play previous song" @click.prevent="playPrev">
|
|
<Icon :icon="faStepBackward" />
|
|
</FooterBtn>
|
|
|
|
<PlayButton />
|
|
|
|
<FooterBtn class="text-2xl" title="Play next song" @click.prevent="playNext">
|
|
<Icon :icon="faStepForward" />
|
|
</FooterBtn>
|
|
|
|
<RepeatModeSwitch class="text-base" />
|
|
</div>
|
|
</div>
|
|
</template>
|
|
|
|
<script lang="ts" setup>
|
|
import { faStepBackward, faStepForward } from '@fortawesome/free-solid-svg-icons'
|
|
import { ref } from 'vue'
|
|
import { playbackService } from '@/services'
|
|
import { requireInjection } from '@/utils'
|
|
import { CurrentPlayableKey } from '@/symbols'
|
|
|
|
import RepeatModeSwitch from '@/components/ui/RepeatModeSwitch.vue'
|
|
import LikeButton from '@/components/song/SongLikeButton.vue'
|
|
import PlayButton from '@/components/ui/FooterPlayButton.vue'
|
|
import FooterBtn from '@/components/layout/app-footer/FooterButton.vue'
|
|
|
|
const song = requireInjection(CurrentPlayableKey, ref())
|
|
|
|
const playPrev = async () => await playbackService.playPrev()
|
|
const playNext = async () => await playbackService.playNext()
|
|
</script>
|
|
|
|
<style lang="postcss" scoped>
|
|
:fullscreen .playback-controls {
|
|
@apply scale-125;
|
|
}
|
|
</style>
|