Compare commits

..

9 Commits

Author SHA1 Message Date
Artem Anufrij
25be34d9c7 wip
All checks were successful
continuous-integration/drone/push Build is passing
2023-10-04 11:20:39 +02:00
Artem Anufrij
2abc46216d adjust banner animation for smartphones
All checks were successful
continuous-integration/drone/push Build is passing
2023-09-28 12:48:11 +02:00
Artem Anufrij
dbefc505dd adjust viewbox
All checks were successful
continuous-integration/drone/push Build is passing
2023-09-27 22:35:09 +02:00
16bdebf796 Merge pull request 'fancy-banner' (#25) from fancy-banner into main
All checks were successful
continuous-integration/drone/push Build is passing
Reviewed-on: #25
2023-09-27 22:14:40 +02:00
Artem Anufrij
a9d705298a don't reload random covers
All checks were successful
continuous-integration/drone/push Build is passing
continuous-integration/drone/pr Build is passing
2023-09-27 22:13:10 +02:00
Artem Anufrij
d0b4590664 ready to use
All checks were successful
continuous-integration/drone/push Build is passing
2023-09-27 22:10:16 +02:00
Artem Anufrij
7ebce51c2d load random covers
All checks were successful
continuous-integration/drone/push Build is passing
2023-09-27 16:51:44 +02:00
Artem Anufrij
02e13cb642 wip
All checks were successful
continuous-integration/drone/push Build is passing
2023-09-26 23:51:33 +02:00
Artem Anufrij
c7f6695416 show radio title in the palyer bar. fix #23
All checks were successful
continuous-integration/drone/push Build is passing
2023-09-26 14:57:37 +02:00
10 changed files with 91 additions and 92 deletions

View File

@@ -1,5 +1,5 @@
{ {
"backend_de": "http://localhost:31204", "backend_dev": "http://localhost:31204",
"backend_dev": "https://webplay.rocks", "backend_de": "https://webplay.rocks",
"backend": "https://webplay.rocks" "backend": "https://webplay.rocks"
} }

View File

@@ -1,6 +1,6 @@
<template> <template>
<div id="player" class="flex-column" v-show="selectedTrack._id || selectedRadio._id"> <div id="player" class="flex-column" v-show="selectedTrack._id || selectedRadio._id">
<input type="range" id="slider" min="0" max="100" step="0.1" v-model="selectedTrack.percent" @change="slideChanged" /> <input type="range" id="slider" min="0" max="100" step="0.1" v-model="selectedTrack.percent" @change="slideChanged"/>
<div id="playerBar" class="flex-row"> <div id="playerBar" class="flex-row">
<div class="flex-row grow"> <div class="flex-row grow">
<img class="cover pointer" :src="cover" :title="selectedTrack.parent.title" @click="gotoContainer" /> <img class="cover pointer" :src="cover" :title="selectedTrack.parent.title" @click="gotoContainer" />
@@ -9,6 +9,9 @@
from from
<b>{{ selectedTrack.parent.title }}</b> <b>{{ selectedTrack.parent.title }}</b>
</div> </div>
<div v-if="selectedRadio._id" class="flex-column">
<b>{{ selectedRadio.name }}</b>
</div>
</div> </div>
<div id="playerControls" class="flex-row center"> <div id="playerControls" class="flex-row center">
<button @click="switchShuffle" title="Shuffle mode" v-if="selectedTrack._id"> <button @click="switchShuffle" title="Shuffle mode" v-if="selectedTrack._id">
@@ -31,8 +34,8 @@
<img src="static/icons/media-no-repeat-dark.svg" class="small" v-show="$store.getters['player/repeatType'] == 'none'" /> <img src="static/icons/media-no-repeat-dark.svg" class="small" v-show="$store.getters['player/repeatType'] == 'none'" />
</button> </button>
</div> </div>
<div class="flex-row ma-right hideOnMobilePortrait grow right" v-show="selectedTrack.title"> <div class="flex-row ma-right hideOnMobilePortrait grow right">
{{ formatedP }}&nbsp;|&nbsp;{{ formatedD }} <span v-show="selectedTrack.title">{{ formatedP }}&nbsp;|&nbsp;{{ formatedD }}</span>
</div> </div>
</div> </div>
<audio preload="auto" ref="audioControl" type="audio/mpeg" @ended="nextTrack" @canplay="play" @playing="playing" @durationchange="durationChanged" @timeupdate="timeUpdate" src></audio> <audio preload="auto" ref="audioControl" type="audio/mpeg" @ended="nextTrack" @canplay="play" @playing="playing" @durationchange="durationChanged" @timeupdate="timeUpdate" src></audio>

View File

@@ -3,12 +3,18 @@ import axios from 'axios'
export default { export default {
checkIfInstanceIsNew(context) { checkIfInstanceIsNew(context) {
return new Promise((resolve) => { return new Promise((resolve) => {
axios.get(context.rootGetters.server + "/api/system/setup").then((res) => { axios
.get(context.rootGetters.server + "/api/system/setup")
.then((res) => {
console.log(res.status);
if (res.status == 200) { if (res.status == 200) {
resolve(true); resolve(true);
} else { } else {
resolve(false); resolve(false);
} }
})
.catch(err => {
console.log(err);
}); });
}); });
}, },

View File

@@ -176,5 +176,10 @@ export default {
resolve(); resolve();
}); });
}); });
},
loadRandomCovers(context, count) {
axios.get(context.rootGetters.server + "/api/albums/random/" + count, context.rootGetters.headers).then((res) => {
context.commit("setRandomCovers", res.data);
});
} }
} }

View File

@@ -32,5 +32,8 @@ export default {
}, },
newest(state) { newest(state) {
return state.newest; return state.newest;
},
randomCovers(state) {
return state.randomCovers;
} }
} }

View File

@@ -76,5 +76,8 @@ export default {
} }
}); });
state.newest = albums; state.newest = albums;
},
setRandomCovers(state, covers) {
state.randomCovers = covers;
} }
} }

View File

@@ -2,6 +2,7 @@ export default {
collection: [], collection: [],
newest: [], newest: [],
selectedAlbum: { tracks: [], covers: {}, share: {} }, selectedAlbum: { tracks: [], covers: {}, share: {} },
randomCovers: [],
page: 1, page: 1,
loading: false, loading: false,
eos: false eos: false

View File

@@ -10,11 +10,13 @@ export default {
load(context) { load(context) {
return new Promise((resolve, reject) => { return new Promise((resolve, reject) => {
axios.get(context.rootGetters.server + "/api/user/login", context.rootGetters.headers).then((res) => { axios.get(context.rootGetters.server + "/api/user/login", context.rootGetters.headers).then((res) => {
console.log(res.data);
context.commit("load", res.data); context.commit("load", res.data);
context.rootState["player"].shuffle = res.data.player.shuffle; context.rootState["player"].shuffle = res.data.player.shuffle;
context.rootState["player"].repeatType = res.data.player.repeat; context.rootState["player"].repeatType = res.data.player.repeat;
resolve(); resolve();
}).catch(err => { }).catch(err => {
console.log("error")
context.commit("resetToken"); context.commit("resetToken");
reject(err); reject(err);
}); });

View File

@@ -2,6 +2,17 @@
<div id="welcome" ref="welcome" @scroll="loadNextPage"> <div id="welcome" ref="welcome" @scroll="loadNextPage">
<div id="welcomeLeft" class="flex-column grow"> <div id="welcomeLeft" class="flex-column grow">
<div id="banner" class="center flex-column shadow"> <div id="banner" class="center flex-column shadow">
<div id="collage">
<svg width="100%" height="100%" viewBox="20 40 600 100">
<g>
<animateTransform id="animY1" attributeName="transform" type="translate" begin="0s; animY2.end" from="0 -140" to="-20 -60" dur="30s" />
<animateTransform id="animY2" attributeName="transform" type="translate" begin="animY1.end" from="-20 -60" to="0 -140" dur="30s" />
<image :xlink:href="item.covers.cover64" :x="Math.floor(i / 6) * 64" :y="i % 6 * 64" width="64" height="64" v-for="(item, i) in randomCovers" :key="item" />
</g>
</svg>
</div>
<div class="flex-column" style="z-index: 1;">
<h1>WebPlay</h1> <h1>WebPlay</h1>
<p> <p>
<b>{{ serverInfo.stats.tracks.toLocaleString("de-DE") }}</b> Tracks <b>{{ serverInfo.stats.tracks.toLocaleString("de-DE") }}</b> Tracks
@@ -11,21 +22,9 @@
<b>{{ serverInfo.stats.users }}</b> <b>{{ serverInfo.stats.users }}</b>
</p> </p>
</div> </div>
<MessageScreen </div>
title="First Run?" <MessageScreen title="First Run?" subtitle="You still don't have any Music or Video content on your instance" icon="sync" :commands="messageCommands" @commandClicked="messageCommand" :showCommands="$store.getters['user/isAdministrator']" v-if="serverInfo.stats.tracks == 0 && serverInfo.stats.videos == 0" />
subtitle="You still don't have any Music or Video content on your instance" <MessageScreen v-else-if="mostListened.length == 0 && mostViewed.length == 0" title="Still no history or trends" subtitle="Still no history or trends on this instance" icon="info" />
icon="sync"
:commands="messageCommands"
@commandClicked="messageCommand"
:showCommands="$store.getters['user/isAdministrator']"
v-if="serverInfo.stats.tracks == 0 && serverInfo.stats.videos == 0"
/>
<MessageScreen
v-else-if="mostListened.length == 0 && mostViewed.length == 0"
title="Still no history or trends"
subtitle="Still no history or trends on this instance"
icon="info"
/>
<template v-else> <template v-else>
<h2 class="ma-left ma-top pa-top ma4-bottom" v-if="history.length > 0"> <h2 class="ma-left ma-top pa-top ma4-bottom" v-if="history.length > 0">
Last played Last played
@@ -33,90 +32,43 @@
<template v-if="history.length > 0"> <template v-if="history.length > 0">
<div id="history" :class="{ more: historyAll == true }"> <div id="history" :class="{ more: historyAll == true }">
<template v-for="item in history"> <template v-for="item in history">
<AlbumItem <AlbumItem class="ma8" v-if="item.type == 'album'" :item="item" :key="item._id" />
class="ma8" <ArtistItem class="ma8" v-if="item.type == 'artist'" :item="item" :key="item._id" />
v-if="item.type == 'album'" <BoxItem class="ma8" v-if="item.type == 'box'" :item="item" :key="item._id" />
:item="item" <RadioItem class="ma8" v-if="item.type == 'radio'" :item="item" :key="item._id" />
:key="item._id"
/>
<ArtistItem
class="ma8"
v-if="item.type == 'artist'"
:item="item"
:key="item._id"
/>
<BoxItem
class="ma8"
v-if="item.type == 'box'"
:item="item"
:key="item._id"
/>
<RadioItem
class="ma8"
v-if="item.type == 'radio'"
:item="item"
:key="item._id"
/>
</template> </template>
</div> </div>
<span class="pa-top pa-right right" @click="toggleHistory"> <span class="pa-top pa-right right" @click="toggleHistory">
<awesome-icon <awesome-icon :icon="historyAll ? 'arrow-up' : 'arrow-down'" class="pa8-right" />{{ historyToggleText }}</span>
:icon="historyAll ? 'arrow-up' : 'arrow-down'"
class="pa8-right"
/>{{ historyToggleText }}</span
>
</template> </template>
<div id="mostUsed" class="flex-row ma"> <div id="mostUsed" class="flex-row ma">
<div id="mostListened" class="grow" v-if="mostListened.length > 0"> <div id="mostListened" class="grow" v-if="mostListened.length > 0">
<h2 class="ma-top pa-top ma4-bottom">Most listened</h2> <h2 class="ma-top pa-top ma4-bottom">Most listened</h2>
<div class="flex-column"> <div class="flex-column">
<TrackItem <TrackItem v-for="(item, i) in mostListened" :track="item" :key="i" />
v-for="(item, i) in mostListened"
:track="item"
:key="i"
/>
</div> </div>
</div> </div>
<div id="mostViewed" class="grow" v-if="mostViewed.length > 0"> <div id="mostViewed" class="grow" v-if="mostViewed.length > 0">
<h2 class="ma-top pa-top ma4-bottom">Most viewed</h2> <h2 class="ma-top pa-top ma4-bottom">Most viewed</h2>
<div id="mostViewedVideos" class="flex-row"> <div id="mostViewedVideos" class="flex-row">
<VideoItem <VideoItem v-for="(item, i) in mostViewed" :video="item" :key="i" />
v-for="(item, i) in mostViewed"
:video="item"
:key="i"
/>
</div> </div>
</div> </div>
</div> </div>
</template> </template>
</div> </div>
<div <div v-if="newestAlbums.length > 0 || newestBoxes.length > 0" id="newest" class="pa-left pa-right">
v-if="newestAlbums.length > 0 || newestBoxes.length > 0"
id="newest"
class="pa-left pa-right"
>
<template v-if="newestAlbums.length > 0"> <template v-if="newestAlbums.length > 0">
<h3>Newest Music</h3> <h3>Newest Music</h3>
<div id="newestMusic" class="flex-column pa-bottom"> <div id="newestMusic" class="flex-column pa-bottom">
<AlbumItem <AlbumItem class="ma8" v-for="item in newestAlbums" type="line" :item="item" :key="item._id" />
class="ma8"
v-for="item in newestAlbums"
type="line"
:item="item"
:key="item._id"
/>
</div> </div>
</template> </template>
<template v-if="newestBoxes.length > 0"> <template v-if="newestBoxes.length > 0">
<h3>Newest Videos</h3> <h3>Newest Videos</h3>
<div id="newestVideos" class="flex-row"> <div id="newestVideos" class="flex-row">
<BoxItem <BoxItem class="ma8 small" v-for="item in newestBoxes" :item="item" :key="item._id" />
class="ma8 small"
v-for="item in newestBoxes"
:item="item"
:key="item._id"
/>
</div> </div>
</template> </template>
</div> </div>
@@ -160,6 +112,11 @@ export default {
this.$store.dispatch("boxes/loadNewest"); this.$store.dispatch("boxes/loadNewest");
this.$store.dispatch("tracks/loadMostListened"); this.$store.dispatch("tracks/loadMostListened");
this.$store.dispatch("videos/loadMostViewed"); this.$store.dispatch("videos/loadMostViewed");
if (this.randomCovers.length == 0) {
this.$store.dispatch("albums/loadRandomCovers", 60);
this.$store.dispatch("albums/loadAlbums", true);
this.$store.dispatch("artists/loadArtists", true);
}
}, },
loadNextPage() { loadNextPage() {
this.scrollPosition = this.$refs.welcome.scrollTop; this.scrollPosition = this.$refs.welcome.scrollTop;
@@ -194,6 +151,7 @@ export default {
serverInfo: "serverInfo", serverInfo: "serverInfo",
mostListened: "tracks/mostListened", mostListened: "tracks/mostListened",
mostViewed: "videos/mostViewed", mostViewed: "videos/mostViewed",
randomCovers: ["albums/randomCovers"],
}), }),
historyToggleText() { historyToggleText() {
return this.historyAll ? "less..." : "more..."; return this.historyAll ? "less..." : "more...";
@@ -221,4 +179,17 @@ export default {
#history.more { #history.more {
max-height: initial; max-height: initial;
} }
#banner {
position: relative;
}
#collage {
bottom: 0;
top: 0;
left: 0;
right: 0;
opacity: 0.2;
position: absolute;
}
</style> </style>

View File

@@ -123,13 +123,17 @@ export default {
checkTocken() { checkTocken() {
let token = localStorage.getItem("token"); let token = localStorage.getItem("token");
if (token) { if (token) {
console.log("hello token")
this.$store.dispatch("user/setToken", token); this.$store.dispatch("user/setToken", token);
console.log("hello token; user/load")
this.$store this.$store
.dispatch("user/load") .dispatch("user/load")
.then(() => { .then(() => {
console.log("user loaded")
this.goto(); this.goto();
}) })
.catch((err) => { .catch((err) => {
console.log("user not loaded")
console.log(err); console.log(err);
this.checkIfNewBackend(); this.checkIfNewBackend();
}); });
@@ -157,6 +161,7 @@ export default {
}); });
}, },
checkIfNewBackend() { checkIfNewBackend() {
console.log("check new instance")
this.$store.dispatch("checkIfInstanceIsNew").then((res) => { this.$store.dispatch("checkIfInstanceIsNew").then((res) => {
if (res) { if (res) {
this.$router.replace("setup"); this.$router.replace("setup");