feat: add playlist filter to library page

This commit is contained in:
qier222 2021-04-27 00:08:00 +08:00
parent aa269cf2ca
commit 458f6dd447
No known key found for this signature in database
GPG Key ID: 9C85007ED905F14D
2 changed files with 65 additions and 8 deletions

View File

@ -0,0 +1 @@
<svg aria-hidden="true" focusable="false" data-prefix="fas" data-icon="caret-down" class="svg-inline--fa fa-caret-down fa-w-10" role="img" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 320 512"><path fill="currentColor" d="M31.3 192h257.3c17.8 0 26.7 21.5 14.1 34.1L174.1 354.8c-7.8 7.8-20.5 7.8-28.3 0L17.2 226.1C4.6 213.5 13.5 192 31.3 192z"></path></svg>

After

Width:  |  Height:  |  Size: 359 B

View File

@ -40,15 +40,22 @@
</div>
</div>
<div id="liked" class="section-two">
<div class="section-two">
<div class="tabs-row">
<div class="tabs">
<div
class="tab"
class="tab dropdown"
:class="{ active: currentTab === 'playlists' }"
@click="updateCurrentTab('playlists')"
>
{{ $t('library.playlists') }}
<span class="text">{{
{ all: '全部歌单', mine: '创建的歌单', liked: '收藏的歌单' }[
playlistFilter
]
}}</span>
<span class="icon" @click.stop="openPlaylistTabMenu"
><svg-icon icon-class="dropdown"
/></span>
</div>
<div
class="tab"
@ -84,7 +91,7 @@
<div v-show="currentTab === 'playlists'">
<div v-if="liked.playlists.length > 1">
<CoverRow
:items="liked.playlists.slice(1)"
:items="filterPlaylists.slice(1)"
type="playlist"
sub-text="creator"
:show-play-button="true"
@ -113,6 +120,17 @@
<MvRow :mvs="liked.mvs" />
</div>
</div>
<ContextMenu ref="playlistTabMenu">
<div class="item" @click="changePlaylistFilter('all')"> 全部歌单 </div>
<hr />
<div class="item" @click="changePlaylistFilter('mine')">
我创建的歌单
</div>
<div class="item" @click="changePlaylistFilter('liked')">
收藏的歌单
</div>
</ContextMenu>
</div>
</template>
@ -123,6 +141,7 @@ import { randomNum, dailyTask } from '@/utils/common';
import { isAccountLoggedIn } from '@/utils/auth';
import NProgress from 'nprogress';
import ContextMenu from '@/components/ContextMenu.vue';
import TrackList from '@/components/TrackList.vue';
import CoverRow from '@/components/CoverRow.vue';
import SvgIcon from '@/components/SvgIcon.vue';
@ -130,7 +149,7 @@ import MvRow from '@/components/MvRow.vue';
export default {
name: 'Library',
components: { SvgIcon, CoverRow, TrackList, MvRow },
components: { SvgIcon, CoverRow, TrackList, MvRow, ContextMenu },
data() {
return {
show: false,
@ -160,6 +179,19 @@ export default {
lyric[lineIndex + 2].split(']')[1],
];
},
playlistFilter() {
return this.data.libraryPlaylistFilter || 'all';
},
filterPlaylists() {
const playlists = this.liked.playlists;
const userId = this.data.user.userId;
if (this.playlistFilter === 'mine') {
return playlists.filter(p => p.creator.userId === userId);
} else if (this.playlistFilter === 'liked') {
return playlists.filter(p => p.creator.userId !== userId);
}
return playlists;
},
},
created() {
NProgress.start();
@ -199,9 +231,7 @@ export default {
return;
}
this.currentTab = tab;
document
.getElementById('liked')
.scrollIntoView({ block: 'start', behavior: 'smooth' });
window.scrollTo({ top: 375, behavior: 'smooth' });
},
goToLikedSongsList() {
this.$router.push({ path: '/library/liked-songs' });
@ -224,6 +254,13 @@ export default {
value: true,
});
},
openPlaylistTabMenu(e) {
this.$refs.playlistTabMenu.openMenu(e);
},
changePlaylistFilter(type) {
this.updateData({ key: 'libraryPlaylistFilter', value: type });
window.scrollTo({ top: 375, behavior: 'smooth' });
},
},
};
</script>
@ -358,6 +395,25 @@ h1 {
opacity: 0.88;
background-color: var(--color-secondary-bg);
}
.tab.dropdown {
display: flex;
align-items: center;
padding: 0;
overflow: hidden;
.text {
padding: 8px 3px 8px 14px;
}
.icon {
height: 100%;
display: flex;
align-items: center;
padding: 0 8px 0 3px;
.svg-icon {
height: 16px;
width: 16px;
}
}
}
}
button.add-playlist {