This commit is contained in:
		
							parent
							
								
									c7f6695416
								
							
						
					
					
						commit
						02e13cb642
					
				@ -2,30 +2,31 @@
 | 
				
			|||||||
  <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 -20" to="0 0" dur="30s" />
 | 
				
			||||||
          <b>{{ serverInfo.stats.videos.toLocaleString("de-DE") }}</b> Videos |
 | 
					              <animateTransform id="animY2" attributeName="transform" type="translate" begin="animY1.end" from="0 0" to="-40 -20" dur="30s" />
 | 
				
			||||||
          Users:
 | 
					
 | 
				
			||||||
          <b>{{ serverInfo.stats.users }}</b>
 | 
					              <image :xlink:href="item.covers.cover128" :x="i * 64" y="0" width="64" height="64" v-for="(item, i) in albums" :key="item" />
 | 
				
			||||||
        </p>
 | 
					              <image :xlink:href="item.covers.cover256" :x="i * 128" y="64" width="128" v-for="(item, i) in artists" :key="item" />
 | 
				
			||||||
 | 
					              <image :xlink:href="item.covers.cover128 || item.covers.cover256" :x="i * 64" y="128" v-for="(item, i) in history" :key="item" />
 | 
				
			||||||
 | 
					            </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 +34,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 +114,9 @@ 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");
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					      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,8 @@ export default {
 | 
				
			|||||||
      serverInfo: "serverInfo",
 | 
					      serverInfo: "serverInfo",
 | 
				
			||||||
      mostListened: "tracks/mostListened",
 | 
					      mostListened: "tracks/mostListened",
 | 
				
			||||||
      mostViewed: "videos/mostViewed",
 | 
					      mostViewed: "videos/mostViewed",
 | 
				
			||||||
 | 
					      albums: ["albums/collection"],
 | 
				
			||||||
 | 
					      artists: ["artists/collection"],
 | 
				
			||||||
    }),
 | 
					    }),
 | 
				
			||||||
    historyToggleText() {
 | 
					    historyToggleText() {
 | 
				
			||||||
      return this.historyAll ? "less..." : "more...";
 | 
					      return this.historyAll ? "less..." : "more...";
 | 
				
			||||||
@ -221,4 +180,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.25;
 | 
				
			||||||
 | 
					  position: absolute;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
</style>
 | 
					</style>
 | 
				
			||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user