mirror of
https://github.com/algerkong/AlgerMusicPlayer.git
synced 2026-04-14 14:50:50 +08:00
150 lines
4.2 KiB
Vue
150 lines
4.2 KiB
Vue
<template>
|
|
<div class="layout-page">
|
|
<div id="layout-main" class="layout-main">
|
|
<title-bar v-if="isElectron" />
|
|
<div class="layout-main-page" :class="isElectron ? '' : 'pt-6'">
|
|
<!-- 侧边菜单栏 -->
|
|
<app-menu v-if="!isMobile" class="menu" :menus="menus" />
|
|
<div class="main">
|
|
<!-- 搜索栏 -->
|
|
<search-bar />
|
|
<!-- 主页面路由 -->
|
|
<div class="main-content" :native-scrollbar="false">
|
|
<router-view
|
|
v-slot="{ Component }"
|
|
class="main-page"
|
|
:class="route.meta.noScroll && !isMobile ? 'pr-3' : ''"
|
|
>
|
|
<keep-alive :include="keepAliveInclude">
|
|
<component :is="Component" />
|
|
</keep-alive>
|
|
</router-view>
|
|
</div>
|
|
<play-bottom height="5rem" />
|
|
<app-menu v-if="isMobile && !store.state.musicFull" class="menu" :menus="menus" />
|
|
</div>
|
|
</div>
|
|
<!-- 底部音乐播放 -->
|
|
<play-bar v-show="isPlay" :style="isMobile && store.state.musicFull ? 'bottom: 0;' : ''" />
|
|
<!-- 下载管理抽屉 -->
|
|
<download-drawer v-if="isElectron" />
|
|
</div>
|
|
<install-app-modal v-if="!isElectron"></install-app-modal>
|
|
<update-modal v-if="isElectron" />
|
|
<artist-drawer ref="artistDrawerRef" :show="artistDrawerShow" />
|
|
<playlist-drawer v-model="showPlaylistDrawer" :song-id="currentSongId" />
|
|
</div>
|
|
</template>
|
|
|
|
<script lang="ts" setup>
|
|
import { computed, defineAsyncComponent, nextTick, onMounted, provide, ref, watch } from 'vue';
|
|
import { useRoute } from 'vue-router';
|
|
import { useStore } from 'vuex';
|
|
|
|
import DownloadDrawer from '@/components/common/DownloadDrawer.vue';
|
|
import InstallAppModal from '@/components/common/InstallAppModal.vue';
|
|
import PlayBottom from '@/components/common/PlayBottom.vue';
|
|
import UpdateModal from '@/components/common/UpdateModal.vue';
|
|
import homeRouter from '@/router/home';
|
|
import { isElectron, isMobile } from '@/utils';
|
|
|
|
const keepAliveInclude = computed(() =>
|
|
homeRouter
|
|
.filter((item) => {
|
|
return item.meta.keepAlive;
|
|
})
|
|
.map((item) => {
|
|
return item.name.charAt(0).toUpperCase() + item.name.slice(1);
|
|
})
|
|
);
|
|
|
|
const AppMenu = defineAsyncComponent(() => import('./components/AppMenu.vue'));
|
|
const PlayBar = defineAsyncComponent(() => import('./components/PlayBar.vue'));
|
|
const SearchBar = defineAsyncComponent(() => import('./components/SearchBar.vue'));
|
|
const TitleBar = defineAsyncComponent(() => import('./components/TitleBar.vue'));
|
|
|
|
const ArtistDrawer = defineAsyncComponent(() => import('@/components/common/ArtistDrawer.vue'));
|
|
const PlaylistDrawer = defineAsyncComponent(() => import('@/components/common/PlaylistDrawer.vue'));
|
|
|
|
const store = useStore();
|
|
|
|
const isPlay = computed(() => store.state.isPlay as boolean);
|
|
const { menus } = store.state;
|
|
const route = useRoute();
|
|
|
|
onMounted(() => {
|
|
store.dispatch('initializeSettings');
|
|
store.dispatch('initializeTheme');
|
|
});
|
|
|
|
const artistDrawerRef = ref<InstanceType<typeof ArtistDrawer>>();
|
|
const artistDrawerShow = computed({
|
|
get: () => store.state.showArtistDrawer,
|
|
set: (val) => store.commit('setShowArtistDrawer', val)
|
|
});
|
|
|
|
// 监听歌手ID变化
|
|
watch(
|
|
() => store.state.currentArtistId,
|
|
(newId) => {
|
|
if (newId) {
|
|
artistDrawerShow.value = true;
|
|
nextTick(() => {
|
|
artistDrawerRef.value?.loadArtistInfo(newId);
|
|
});
|
|
}
|
|
}
|
|
);
|
|
|
|
const showPlaylistDrawer = ref(false);
|
|
const currentSongId = ref<number | undefined>();
|
|
|
|
// 提供一个方法来打开歌单抽屉
|
|
const openPlaylistDrawer = (songId: number) => {
|
|
currentSongId.value = songId;
|
|
showPlaylistDrawer.value = true;
|
|
};
|
|
|
|
// 将方法提供给全局
|
|
provide('openPlaylistDrawer', openPlaylistDrawer);
|
|
</script>
|
|
|
|
<style lang="scss" scoped>
|
|
.layout-page {
|
|
@apply w-screen h-screen overflow-hidden bg-light dark:bg-black;
|
|
}
|
|
|
|
.layout-main {
|
|
@apply w-full h-full relative text-gray-900 dark:text-white;
|
|
}
|
|
|
|
.layout-main-page {
|
|
@apply flex h-full;
|
|
}
|
|
|
|
.menu {
|
|
@apply h-full;
|
|
}
|
|
|
|
.main {
|
|
@apply overflow-hidden flex-1 flex flex-col;
|
|
}
|
|
|
|
.main-content {
|
|
@apply flex-1 overflow-hidden;
|
|
}
|
|
|
|
.main-page {
|
|
@apply h-full;
|
|
}
|
|
|
|
.mobile {
|
|
.main-content {
|
|
height: calc(100vh - 146px);
|
|
overflow: auto;
|
|
display: block;
|
|
flex: none;
|
|
}
|
|
}
|
|
</style>
|