fancy-banner #25
@ -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);
 | 
				
			||||||
 | 
					    });
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@ -32,5 +32,8 @@ export default {
 | 
				
			|||||||
    },
 | 
					    },
 | 
				
			||||||
    newest(state) {
 | 
					    newest(state) {
 | 
				
			||||||
        return state.newest;
 | 
					        return state.newest;
 | 
				
			||||||
 | 
					    },
 | 
				
			||||||
 | 
					    randomCovers(state) {
 | 
				
			||||||
 | 
					        return state.randomCovers;
 | 
				
			||||||
    }
 | 
					    }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@ -76,5 +76,8 @@ export default {
 | 
				
			|||||||
      }
 | 
					      }
 | 
				
			||||||
    });
 | 
					    });
 | 
				
			||||||
    state.newest = albums;
 | 
					    state.newest = albums;
 | 
				
			||||||
 | 
					  },
 | 
				
			||||||
 | 
					  setRandomCovers(state, covers) {
 | 
				
			||||||
 | 
					    state.randomCovers = covers;
 | 
				
			||||||
  }
 | 
					  }
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
@ -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
 | 
				
			||||||
 | 
				
			|||||||
@ -2,30 +2,29 @@
 | 
				
			|||||||
  <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">
 | 
				
			||||||
        <h1>WebPlay</h1>
 | 
					        <div id="collage">
 | 
				
			||||||
        <p>
 | 
					          <svg width="100%" height="100%" viewBox="20 20 700 100">
 | 
				
			||||||
          <b>{{ serverInfo.stats.tracks.toLocaleString("de-DE") }}</b> Tracks
 | 
					            <g>
 | 
				
			||||||
          and
 | 
					              <animateTransform id="animY1" attributeName="transform" type="translate" begin="0s; animY2.end" from="-40 -60" to="-10 -20" dur="30s" />
 | 
				
			||||||
          <b>{{ serverInfo.stats.videos.toLocaleString("de-DE") }}</b> Videos |
 | 
					              <animateTransform id="animY2" attributeName="transform" type="translate" begin="animY1.end" from="-10 -20" to="-40 -60" dur="30s" />
 | 
				
			||||||
          Users:
 | 
					
 | 
				
			||||||
          <b>{{ serverInfo.stats.users }}</b>
 | 
					              <image :xlink:href="item.covers.cover64" :x="Math.floor(i / 4) * 64" :y="i % 4 * 64" width="64" height="64" v-for="(item, i) in randomCovers" :key="item" />
 | 
				
			||||||
        </p>
 | 
					            </g>
 | 
				
			||||||
 | 
					          </svg>
 | 
				
			||||||
 | 
					        </div>
 | 
				
			||||||
 | 
					        <div class="flex-column" style="z-index: 1;">
 | 
				
			||||||
 | 
					          <h1>WebPlay</h1>
 | 
				
			||||||
 | 
					          <p>
 | 
				
			||||||
 | 
					            <b>{{ serverInfo.stats.tracks.toLocaleString("de-DE") }}</b> Tracks
 | 
				
			||||||
 | 
					            and
 | 
				
			||||||
 | 
					            <b>{{ serverInfo.stats.videos.toLocaleString("de-DE") }}</b> Videos |
 | 
				
			||||||
 | 
					            Users:
 | 
				
			||||||
 | 
					            <b>{{ serverInfo.stats.users }}</b>
 | 
				
			||||||
 | 
					          </p>
 | 
				
			||||||
 | 
					        </div>
 | 
				
			||||||
      </div>
 | 
					      </div>
 | 
				
			||||||
      <MessageScreen
 | 
					      <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" />
 | 
				
			||||||
        title="First Run?"
 | 
					      <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" />
 | 
				
			||||||
        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"
 | 
					 | 
				
			||||||
      />
 | 
					 | 
				
			||||||
      <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", 48);
 | 
				
			||||||
 | 
					        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>
 | 
				
			||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user