2018-02-27 22:38:55 +01:00
|
|
|
<template>
|
|
|
|
|
<div>
|
|
|
|
|
<div v-if="stats" class="ui stackable two column grid">
|
|
|
|
|
<div class="column">
|
2018-06-30 15:28:47 +02:00
|
|
|
<h3 class="ui left aligned header">
|
2019-03-01 14:29:58 +01:00
|
|
|
<translate :translate-context="'Content/About/Title/Noun'">User activity</translate>
|
2018-06-30 15:28:47 +02:00
|
|
|
</h3>
|
2018-05-07 22:09:25 +02:00
|
|
|
<div v-if="stats" class="ui mini horizontal statistics">
|
2018-02-27 22:38:55 +01:00
|
|
|
<div class="statistic">
|
|
|
|
|
<div class="value">
|
|
|
|
|
<i class="green user icon"></i>
|
|
|
|
|
{{ stats.users }}
|
|
|
|
|
</div>
|
2019-03-01 14:29:58 +01:00
|
|
|
<div class="label"><translate :translate-context="'Content/About/Paragraph/Unit'">users</translate></div>
|
2018-02-27 22:38:55 +01:00
|
|
|
</div>
|
|
|
|
|
<div class="statistic">
|
|
|
|
|
<div class="value">
|
|
|
|
|
<i class="orange sound icon"></i> {{ stats.listenings }}
|
|
|
|
|
</div>
|
2019-03-01 14:29:58 +01:00
|
|
|
<div class="label"><translate :translate-context="'Content/About/Paragraph/Unit'">tracks listened</translate></div>
|
2018-02-27 22:38:55 +01:00
|
|
|
</div>
|
|
|
|
|
<div class="statistic">
|
|
|
|
|
<div class="value">
|
2018-05-07 22:09:25 +02:00
|
|
|
<i class="pink heart icon"></i> {{ stats.trackFavorites }}
|
2018-02-27 22:38:55 +01:00
|
|
|
</div>
|
2019-03-01 14:29:58 +01:00
|
|
|
<div class="label"><translate :translate-context="'Content/About/Paragraph/Unit'">Tracks favorited</translate></div>
|
2018-02-27 22:38:55 +01:00
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
<div class="column">
|
2019-03-01 14:29:58 +01:00
|
|
|
<h3 class="ui left aligned header"><translate :translate-context="'Content/About/Title/Noun'">Library</translate></h3>
|
2018-02-27 22:38:55 +01:00
|
|
|
<div class="ui mini horizontal statistics">
|
|
|
|
|
<div class="statistic">
|
|
|
|
|
<div class="value">
|
2018-05-07 22:09:25 +02:00
|
|
|
{{ parseInt(stats.musicDuration) }}
|
2018-02-27 22:38:55 +01:00
|
|
|
</div>
|
2019-03-01 14:29:58 +01:00
|
|
|
<div class="label"><translate :translate-context="'Content/About/Paragraph/Unit'">Hours of music</translate></div>
|
2018-02-27 22:38:55 +01:00
|
|
|
</div>
|
|
|
|
|
<div class="statistic">
|
|
|
|
|
<div class="value">
|
|
|
|
|
{{ stats.artists }}
|
|
|
|
|
</div>
|
2019-03-01 14:29:58 +01:00
|
|
|
<div class="label"><translate :translate-context="'Content/About/Paragraph/Unit'">Artists</translate></div>
|
2018-02-27 22:38:55 +01:00
|
|
|
</div>
|
|
|
|
|
<div class="statistic">
|
|
|
|
|
<div class="value">
|
|
|
|
|
{{ stats.albums }}
|
|
|
|
|
</div>
|
2019-03-01 14:29:58 +01:00
|
|
|
<div class="label"><translate :translate-context="'Content/About/Paragraph/Unit'">Albums</translate></div>
|
2018-02-27 22:38:55 +01:00
|
|
|
</div>
|
|
|
|
|
<div class="statistic">
|
|
|
|
|
<div class="value">
|
|
|
|
|
{{ stats.tracks }}
|
|
|
|
|
</div>
|
2019-03-01 14:29:58 +01:00
|
|
|
<div class="label"><translate :translate-context="'Content/About/Paragraph/Unit'">Tracks</translate></div>
|
2018-02-27 22:38:55 +01:00
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</div>
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<script>
|
2018-12-20 11:21:15 +01:00
|
|
|
import _ from '@/lodash'
|
2018-02-27 22:38:55 +01:00
|
|
|
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...')
|
2018-05-07 22:28:21 +02:00
|
|
|
axios.get('instance/nodeinfo/2.0/').then((response) => {
|
2018-05-07 22:09:25 +02:00
|
|
|
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')
|
|
|
|
|
self.stats.musicDuration = _.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')
|
2018-02-27 22:38:55 +01:00
|
|
|
self.isLoading = false
|
|
|
|
|
})
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
</script>
|
|
|
|
|
|
|
|
|
|
<!-- Add "scoped" attribute to limit CSS to this component only -->
|
|
|
|
|
<style scoped>
|
|
|
|
|
</style>
|