Skip to content
Snippets Groups Projects
Select Git revision
  • develop default protected
  • add-favorite-albums
  • 896-add-electron-support
  • dark-theme
  • webdav
  • live-streaming
  • 0.19.0
  • 0.19.0-rc2
  • 0.19.0-rc1
  • 0.18.3
  • 0.18.2
  • 0.18.1
  • 0.18
  • 0.17
  • 0.16.3
  • 0.16.2
  • 0.16.1
  • 0.16
  • 0.15
  • 0.14.2
  • 0.14.1
  • 0.14
  • 0.13
  • 0.12
  • 0.11
  • 0.10
26 results

Stats.vue

Blame
  • Forked from funkwhale / funkwhale
    7326 commits behind the upstream repository.
    Stats.vue 2.51 KiB
    <template>
      <div>
        <div v-if="stats" class="ui stackable two column grid">
          <div class="column">
            <h3 class="ui left aligned header"><i18next path="User activity"/></h3>
            <div class="ui mini horizontal statistics">
              <div class="statistic">
                <div class="value">
                  <i class="green user icon"></i>
                  {{ stats.users }}
                </div>
                <i18next tag="div" class="label" path="users"/>
              </div>
              <div class="statistic">
                <div class="value">
                  <i class="orange sound icon"></i> {{ stats.listenings }}
                </div>
                <i18next tag="div" class="label" path="tracks listened"/>
              </div>
              <div class="statistic">
                <div class="value">
                  <i class="pink heart icon"></i> {{ stats.track_favorites }}
                </div>
                <i18next tag="div" class="label" path="Tracks favorited"/>
              </div>
            </div>
          </div>
          <div class="column">
            <h3 class="ui left aligned header">Library</h3>
            <div class="ui mini horizontal statistics">
              <div class="statistic">
                <div class="value">
                  {{ parseInt(stats.music_duration) }}
                </div>
                <i18next tag="div" class="label" path="hours of music"/>
              </div>
              <div class="statistic">
                <div class="value">
                  {{ stats.artists }}
                </div>
                <i18next tag="div" class="label" path="Artists"/>
              </div>
              <div class="statistic">
                <div class="value">
                  {{ stats.albums }}
                </div>
                <i18next tag="div" class="label" path="Albums"/>
              </div>
              <div class="statistic">
                <div class="value">
                  {{ stats.tracks }}
                </div>
                <i18next tag="div" class="label" path="tracks"/>
              </div>
            </div>
          </div>
        </div>
      </div>
    </template>
    
    <script>
    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/stats/').then((response) => {
            self.stats = response.data
            self.isLoading = false
          })
        }
      }
    }
    </script>
    
    <!-- Add "scoped" attribute to limit CSS to this component only -->
    <style scoped>
    </style>