Skip to content
Snippets Groups Projects
Stats.vue 3.85 KiB
Newer Older
  • Learn to ignore specific revisions
  •     <div v-if="stats && stats.trackFavorites !== undefined" class="ui stackable two column grid">
    
    Eliot Berriot's avatar
    Eliot Berriot committed
            <h3 class="ui left aligned header">
    
              <translate translate-context="Content/About/Title/Noun">User activity</translate>
    
    Eliot Berriot's avatar
    Eliot Berriot committed
            </h3>
    
            <div v-if="stats" class="ui mini horizontal statistics">
    
              <div class="statistic">
                <div class="value">
                  <i class="green user icon"></i>
    
    Ciarán Ainsworth's avatar
    Ciarán Ainsworth committed
                  {{ stats.users.toLocaleString($store.state.ui.momentLocale) }}
    
                <div class="label"><translate translate-context="Content/About/Paragraph/Unit">users</translate></div>
    
              </div>
              <div class="statistic">
                <div class="value">
    
    Ciarán Ainsworth's avatar
    Ciarán Ainsworth committed
                  <i class="orange sound icon"></i> {{ stats.listenings.toLocaleString($store.state.ui.momentLocale) }}
    
                <div class="label"><translate translate-context="Content/About/Paragraph/Unit">tracks listened</translate></div>
    
              </div>
              <div class="statistic">
                <div class="value">
    
    Ciarán Ainsworth's avatar
    Ciarán Ainsworth committed
                  <i class="pink heart icon"></i> {{ stats.trackFavorites.toLocaleString($store.state.ui.momentLocale) }}
    
                <div class="label"><translate translate-context="Content/About/Paragraph/Unit">Tracks favorited</translate></div>
    
              </div>
            </div>
          </div>
          <div class="column">
    
    jovuit's avatar
    jovuit committed
            <h3 class="ui left aligned header"><translate translate-context="*/*/*">Library</translate></h3>
    
            <div class="ui mini horizontal statistics">
              <div class="statistic">
                <div class="value">
    
    Ciarán Ainsworth's avatar
    Ciarán Ainsworth committed
                  {{ stats.musicDuration.toLocaleString($store.state.ui.momentLocale) }}
    
                <div class="label"><translate translate-context="Content/About/Paragraph/Unit">Hours of music</translate></div>
    
              </div>
              <div class="statistic">
                <div class="value">
    
    Ciarán Ainsworth's avatar
    Ciarán Ainsworth committed
                  {{ stats.artists.toLocaleString($store.state.ui.momentLocale) }}
    
    jovuit's avatar
    jovuit committed
                <div class="label"><translate translate-context="*/*/*/Noun">Artists</translate></div>
    
              </div>
              <div class="statistic">
                <div class="value">
    
    Ciarán Ainsworth's avatar
    Ciarán Ainsworth committed
                  {{ stats.albums.toLocaleString($store.state.ui.momentLocale) }}
    
    jovuit's avatar
    jovuit committed
                <div class="label"><translate translate-context="*/*/*">Albums</translate></div>
    
              </div>
              <div class="statistic">
                <div class="value">
    
    Ciarán Ainsworth's avatar
    Ciarán Ainsworth committed
                  {{ stats.tracks.toLocaleString($store.state.ui.momentLocale) }}
    
    jovuit's avatar
    jovuit committed
                <div class="label"><translate translate-context="*/*/*/Noun">Tracks</translate></div>
    
              </div>
            </div>
          </div>
        </div>
      </div>
    </template>
    
    <script>
    
    import _ from '@/lodash'
    
    import axios from 'axios'
    import logger from '@/logging'
    
    export default {
      data () {
        return {
          stats: null
        }
      },
      created () {
        this.fetchData()
      },
      methods: {
        fetchData () {
          var self = this
          this.isLoading = true
          logger.default.debug('Fetching instance stats...')
    
          axios.get('instance/nodeinfo/2.0/').then((response) => {
    
            let d = response.data
            self.stats = {}
            self.stats.users = _.get(d, 'usage.users.total')
            self.stats.listenings = _.get(d, 'metadata.usage.listenings.total')
            self.stats.trackFavorites = _.get(d, 'metadata.usage.favorites.tracks.total')
    
    Ciarán Ainsworth's avatar
    Ciarán Ainsworth committed
            self.stats.musicDuration = Math.round(_.get(d, 'metadata.library.music.hours'))
    
            self.stats.artists = _.get(d, 'metadata.library.artists.total')
            self.stats.albums = _.get(d, 'metadata.library.albums.total')
            self.stats.tracks = _.get(d, 'metadata.library.tracks.total')
    
      }
    }
    </script>
    
    <!-- Add "scoped" attribute to limit CSS to this component only -->
    <style scoped>
    </style>