[web-src] Add info buttons to album/artist/playlist/files pages

Adds a button to open the modal details dialog for 
album/artist/playlist/directory
This commit is contained in:
chme 2019-02-17 11:24:30 +01:00
parent dec916a7eb
commit d51f9b0722
6 changed files with 79 additions and 36 deletions

View File

@ -6,14 +6,12 @@
</template> </template>
<template slot="heading-right"> <template slot="heading-right">
<div class="buttons is-centered"> <div class="buttons is-centered">
<a class="button is-small is-light is-rounded" @click="show_album_details_modal = true">
<span class="icon"><i class="mdi mdi-dots-horizontal mdi-18px"></i></span>
</a>
<a class="button is-small is-dark is-rounded" @click="play"> <a class="button is-small is-dark is-rounded" @click="play">
<span class="icon"><i class="mdi mdi-shuffle"></i></span> <span>Shuffle</span> <span class="icon"><i class="mdi mdi-shuffle"></i></span> <span>Shuffle</span>
</a> </a>
<!--
<a class="button is-small is-dark is-rounded" @click="play">
<span class="icon"><i class="mdi mdi-play"></i></span> <span>Play</span>
</a>
-->
</div> </div>
</template> </template>
<template slot="content"> <template slot="content">
@ -26,6 +24,7 @@
</template> </template>
</list-item-track> </list-item-track>
<modal-dialog-track :show="show_details_modal" :track="selected_track" @close="show_details_modal = false" /> <modal-dialog-track :show="show_details_modal" :track="selected_track" @close="show_details_modal = false" />
<modal-dialog-album :show="show_album_details_modal" :album="album" @close="show_album_details_modal = false" />
</template> </template>
</content-with-heading> </content-with-heading>
</template> </template>
@ -35,6 +34,7 @@ import { LoadDataBeforeEnterMixin } from './mixin'
import ContentWithHeading from '@/templates/ContentWithHeading' import ContentWithHeading from '@/templates/ContentWithHeading'
import ListItemTrack from '@/components/ListItemTrack' import ListItemTrack from '@/components/ListItemTrack'
import ModalDialogTrack from '@/components/ModalDialogTrack' import ModalDialogTrack from '@/components/ModalDialogTrack'
import ModalDialogAlbum from '@/components/ModalDialogAlbum'
import webapi from '@/webapi' import webapi from '@/webapi'
const albumData = { const albumData = {
@ -54,7 +54,7 @@ const albumData = {
export default { export default {
name: 'PageAlbum', name: 'PageAlbum',
mixins: [ LoadDataBeforeEnterMixin(albumData) ], mixins: [ LoadDataBeforeEnterMixin(albumData) ],
components: { ContentWithHeading, ListItemTrack, ModalDialogTrack }, components: { ContentWithHeading, ListItemTrack, ModalDialogTrack, ModalDialogAlbum },
data () { data () {
return { return {
@ -62,7 +62,9 @@ export default {
tracks: [], tracks: [],
show_details_modal: false, show_details_modal: false,
selected_track: {} selected_track: {},
show_album_details_modal: false
} }
}, },

View File

@ -4,9 +4,14 @@
<p class="title is-4">{{ artist.name }}</p> <p class="title is-4">{{ artist.name }}</p>
</template> </template>
<template slot="heading-right"> <template slot="heading-right">
<a class="button is-small is-dark is-rounded" @click="play"> <div class="buttons is-centered">
<span class="icon"><i class="mdi mdi-shuffle"></i></span> <span>Shuffle</span> <a class="button is-small is-light is-rounded" @click="show_artist_details_modal = true">
</a> <span class="icon"><i class="mdi mdi-dots-horizontal mdi-18px"></i></span>
</a>
<a class="button is-small is-dark is-rounded" @click="play">
<span class="icon"><i class="mdi mdi-shuffle"></i></span> <span>Shuffle</span>
</a>
</div>
</template> </template>
<template slot="content"> <template slot="content">
<p class="heading has-text-centered-mobile">{{ artist.album_count }} albums | <a class="has-text-link" @click="open_tracks">{{ artist.track_count }} tracks</a></p> <p class="heading has-text-centered-mobile">{{ artist.album_count }} albums | <a class="has-text-link" @click="open_tracks">{{ artist.track_count }} tracks</a></p>
@ -18,6 +23,7 @@
</template> </template>
</list-item-album> </list-item-album>
<modal-dialog-album :show="show_details_modal" :album="selected_album" @close="show_details_modal = false" /> <modal-dialog-album :show="show_details_modal" :album="selected_album" @close="show_details_modal = false" />
<modal-dialog-artist :show="show_artist_details_modal" :artist="artist" @close="show_artist_details_modal = false" />
</template> </template>
</content-with-heading> </content-with-heading>
</template> </template>
@ -27,6 +33,7 @@ import { LoadDataBeforeEnterMixin } from './mixin'
import ContentWithHeading from '@/templates/ContentWithHeading' import ContentWithHeading from '@/templates/ContentWithHeading'
import ListItemAlbum from '@/components/ListItemAlbum' import ListItemAlbum from '@/components/ListItemAlbum'
import ModalDialogAlbum from '@/components/ModalDialogAlbum' import ModalDialogAlbum from '@/components/ModalDialogAlbum'
import ModalDialogArtist from '@/components/ModalDialogArtist'
import webapi from '@/webapi' import webapi from '@/webapi'
const artistData = { const artistData = {
@ -46,7 +53,7 @@ const artistData = {
export default { export default {
name: 'PageArtist', name: 'PageArtist',
mixins: [ LoadDataBeforeEnterMixin(artistData) ], mixins: [ LoadDataBeforeEnterMixin(artistData) ],
components: { ContentWithHeading, ListItemAlbum, ModalDialogAlbum }, components: { ContentWithHeading, ListItemAlbum, ModalDialogAlbum, ModalDialogArtist },
data () { data () {
return { return {
@ -54,7 +61,9 @@ export default {
albums: {}, albums: {},
show_details_modal: false, show_details_modal: false,
selected_album: {} selected_album: {},
show_artist_details_modal: false
} }
}, },

View File

@ -5,12 +5,17 @@
<div class="title is-4 has-text-grey has-text-weight-normal">{{ album.artist }}</div> <div class="title is-4 has-text-grey has-text-weight-normal">{{ album.artist }}</div>
</template> </template>
<template slot="heading-right"> <template slot="heading-right">
<a class="button is-small is-dark is-rounded" @click="play"> <div class="buttons is-centered">
<span class="icon"> <a class="button is-small is-light is-rounded" @click="show_album_details_modal = true">
<i class="mdi mdi-play"></i> <span class="icon"><i class="mdi mdi-dots-horizontal mdi-18px"></i></span>
</span> </a>
<span>Play</span> <a class="button is-small is-dark is-rounded" @click="play">
</a> <span class="icon">
<i class="mdi mdi-play"></i>
</span>
<span>Play</span>
</a>
</div>
</template> </template>
<template slot="content"> <template slot="content">
<p class="heading has-text-centered-mobile">{{ album.track_count }} tracks</p> <p class="heading has-text-centered-mobile">{{ album.track_count }} tracks</p>
@ -22,6 +27,7 @@
</template> </template>
</list-item-track> </list-item-track>
<modal-dialog-track :show="show_details_modal" :track="selected_track" @close="show_details_modal = false" /> <modal-dialog-track :show="show_details_modal" :track="selected_track" @close="show_details_modal = false" />
<modal-dialog-album :show="show_album_details_modal" :album="album" :media_kind="'audiobook'" @close="show_album_details_modal = false" />
</template> </template>
</content-with-heading> </content-with-heading>
</template> </template>
@ -31,6 +37,7 @@ import { LoadDataBeforeEnterMixin } from './mixin'
import ContentWithHeading from '@/templates/ContentWithHeading' import ContentWithHeading from '@/templates/ContentWithHeading'
import ListItemTrack from '@/components/ListItemTrack' import ListItemTrack from '@/components/ListItemTrack'
import ModalDialogTrack from '@/components/ModalDialogTrack' import ModalDialogTrack from '@/components/ModalDialogTrack'
import ModalDialogAlbum from '@/components/ModalDialogAlbum'
import webapi from '@/webapi' import webapi from '@/webapi'
const albumData = { const albumData = {
@ -50,7 +57,7 @@ const albumData = {
export default { export default {
name: 'PageAudiobook', name: 'PageAudiobook',
mixins: [ LoadDataBeforeEnterMixin(albumData) ], mixins: [ LoadDataBeforeEnterMixin(albumData) ],
components: { ContentWithHeading, ListItemTrack, ModalDialogTrack }, components: { ContentWithHeading, ListItemTrack, ModalDialogTrack, ModalDialogAlbum },
data () { data () {
return { return {
@ -58,7 +65,9 @@ export default {
tracks: [], tracks: [],
show_details_modal: false, show_details_modal: false,
selected_track: {} selected_track: {},
show_album_details_modal: false
} }
}, },

View File

@ -6,9 +6,14 @@
<p class="title is-7 has-text-grey">{{ current_directory }}</p> <p class="title is-7 has-text-grey">{{ current_directory }}</p>
</template> </template>
<template slot="heading-right"> <template slot="heading-right">
<a class="button is-small is-dark is-rounded" @click="play"> <div class="buttons is-centered">
<span class="icon"><i class="mdi mdi-play"></i></span> <span>Play</span> <a class="button is-small is-light is-rounded" @click="open_directory_dialog({ 'path': current_directory })">
</a> <span class="icon"><i class="mdi mdi-dots-horizontal mdi-18px"></i></span>
</a>
<a class="button is-small is-dark is-rounded" @click="play">
<span class="icon"><i class="mdi mdi-play"></i></span> <span>Play</span>
</a>
</div>
</template> </template>
<template slot="content"> <template slot="content">
<div class="media" v-if="$route.query.directory" @click="open_parent_directory()"> <div class="media" v-if="$route.query.directory" @click="open_parent_directory()">

View File

@ -4,9 +4,14 @@
<div class="title is-4">{{ playlist.name }}</div> <div class="title is-4">{{ playlist.name }}</div>
</template> </template>
<template slot="heading-right"> <template slot="heading-right">
<a class="button is-small is-dark is-rounded" @click="play"> <div class="buttons is-centered">
<span class="icon"><i class="mdi mdi-shuffle"></i></span> <span>Shuffle</span> <a class="button is-small is-light is-rounded" @click="show_playlist_details_modal = true">
</a> <span class="icon"><i class="mdi mdi-dots-horizontal mdi-18px"></i></span>
</a>
<a class="button is-small is-dark is-rounded" @click="play">
<span class="icon"><i class="mdi mdi-shuffle"></i></span> <span>Shuffle</span>
</a>
</div>
</template> </template>
<template slot="content"> <template slot="content">
<p class="heading has-text-centered-mobile">{{ tracks.length }} tracks</p> <p class="heading has-text-centered-mobile">{{ tracks.length }} tracks</p>
@ -18,6 +23,7 @@
</template> </template>
</list-item-track> </list-item-track>
<modal-dialog-track :show="show_details_modal" :track="selected_track" @close="show_details_modal = false" /> <modal-dialog-track :show="show_details_modal" :track="selected_track" @close="show_details_modal = false" />
<modal-dialog-playlist :show="show_playlist_details_modal" :playlist="playlist" @close="show_playlist_details_modal = false" />
</template> </template>
</content-with-heading> </content-with-heading>
</template> </template>
@ -27,6 +33,7 @@ import { LoadDataBeforeEnterMixin } from './mixin'
import ContentWithHeading from '@/templates/ContentWithHeading' import ContentWithHeading from '@/templates/ContentWithHeading'
import ListItemTrack from '@/components/ListItemTrack' import ListItemTrack from '@/components/ListItemTrack'
import ModalDialogTrack from '@/components/ModalDialogTrack' import ModalDialogTrack from '@/components/ModalDialogTrack'
import ModalDialogPlaylist from '@/components/ModalDialogPlaylist'
import webapi from '@/webapi' import webapi from '@/webapi'
const playlistData = { const playlistData = {
@ -46,7 +53,7 @@ const playlistData = {
export default { export default {
name: 'PagePlaylist', name: 'PagePlaylist',
mixins: [ LoadDataBeforeEnterMixin(playlistData) ], mixins: [ LoadDataBeforeEnterMixin(playlistData) ],
components: { ContentWithHeading, ListItemTrack, ModalDialogTrack }, components: { ContentWithHeading, ListItemTrack, ModalDialogTrack, ModalDialogPlaylist },
data () { data () {
return { return {
@ -54,7 +61,9 @@ export default {
tracks: [], tracks: [],
show_details_modal: false, show_details_modal: false,
selected_track: {} selected_track: {},
show_playlist_details_modal: false
} }
}, },

View File

@ -4,12 +4,17 @@
<div class="title is-4">{{ album.name }}</div> <div class="title is-4">{{ album.name }}</div>
</template> </template>
<template slot="heading-right"> <template slot="heading-right">
<a class="button is-small is-dark is-rounded" @click="play"> <div class="buttons is-centered">
<span class="icon"> <a class="button is-small is-light is-rounded" @click="show_album_details_modal = true">
<i class="mdi mdi-play"></i> <span class="icon"><i class="mdi mdi-dots-horizontal mdi-18px"></i></span>
</span> </a>
<span>Play</span> <a class="button is-small is-dark is-rounded" @click="play">
</a> <span class="icon">
<i class="mdi mdi-play"></i>
</span>
<span>Play</span>
</a>
</div>
</template> </template>
<template slot="content"> <template slot="content">
<p class="heading has-text-centered-mobile">{{ album.track_count }} tracks</p> <p class="heading has-text-centered-mobile">{{ album.track_count }} tracks</p>
@ -31,6 +36,7 @@
</template> </template>
</list-item-track> </list-item-track>
<modal-dialog-track :show="show_details_modal" :track="selected_track" @close="show_details_modal = false" @play_count_changed="reload_tracks" /> <modal-dialog-track :show="show_details_modal" :track="selected_track" @close="show_details_modal = false" @play_count_changed="reload_tracks" />
<modal-dialog-album :show="show_album_details_modal" :album="album" :media_kind="'podcast'" @close="show_album_details_modal = false" />
</template> </template>
</content-with-heading> </content-with-heading>
</template> </template>
@ -40,6 +46,7 @@ import { LoadDataBeforeEnterMixin } from './mixin'
import ContentWithHeading from '@/templates/ContentWithHeading' import ContentWithHeading from '@/templates/ContentWithHeading'
import ListItemTrack from '@/components/ListItemTrack' import ListItemTrack from '@/components/ListItemTrack'
import ModalDialogTrack from '@/components/ModalDialogTrack' import ModalDialogTrack from '@/components/ModalDialogTrack'
import ModalDialogAlbum from '@/components/ModalDialogAlbum'
import RangeSlider from 'vue-range-slider' import RangeSlider from 'vue-range-slider'
import webapi from '@/webapi' import webapi from '@/webapi'
@ -60,7 +67,7 @@ const albumData = {
export default { export default {
name: 'PagePodcast', name: 'PagePodcast',
mixins: [ LoadDataBeforeEnterMixin(albumData) ], mixins: [ LoadDataBeforeEnterMixin(albumData) ],
components: { ContentWithHeading, ListItemTrack, ModalDialogTrack, RangeSlider }, components: { ContentWithHeading, ListItemTrack, ModalDialogTrack, RangeSlider, ModalDialogAlbum },
data () { data () {
return { return {
@ -68,7 +75,9 @@ export default {
tracks: [], tracks: [],
show_details_modal: false, show_details_modal: false,
selected_track: {} selected_track: {},
show_album_details_modal: false
} }
}, },