Merge branch '1178-listenings-stats' into 'develop'
Fx #1178: Display channel and track downloads count Closes #1178 See merge request funkwhale/funkwhale!1188
This commit is contained in:
commit
88b04886d1
|
@ -235,6 +235,7 @@ class ChannelUpdateSerializer(serializers.Serializer):
|
|||
class ChannelSerializer(serializers.ModelSerializer):
|
||||
artist = serializers.SerializerMethodField()
|
||||
actor = serializers.SerializerMethodField()
|
||||
downloads_count = serializers.SerializerMethodField()
|
||||
attributed_to = federation_serializers.APIActorSerializer()
|
||||
rss_url = serializers.CharField(source="get_rss_url")
|
||||
url = serializers.SerializerMethodField()
|
||||
|
@ -250,6 +251,7 @@ class ChannelSerializer(serializers.ModelSerializer):
|
|||
"metadata",
|
||||
"rss_url",
|
||||
"url",
|
||||
"downloads_count",
|
||||
]
|
||||
|
||||
def get_artist(self, obj):
|
||||
|
@ -264,6 +266,9 @@ class ChannelSerializer(serializers.ModelSerializer):
|
|||
def get_subscriptions_count(self, obj):
|
||||
return obj.actor.received_follows.exclude(approved=False).count()
|
||||
|
||||
def get_downloads_count(self, obj):
|
||||
return getattr(obj, "_downloads_count", None)
|
||||
|
||||
def get_actor(self, obj):
|
||||
if obj.attributed_to == actors.get_service_actor():
|
||||
return None
|
||||
|
|
|
@ -7,7 +7,7 @@ from rest_framework import viewsets
|
|||
|
||||
from django import http
|
||||
from django.db import transaction
|
||||
from django.db.models import Count, Prefetch, Q
|
||||
from django.db.models import Count, Prefetch, Q, Sum
|
||||
from django.utils import timezone
|
||||
|
||||
from funkwhale_api.common import locales
|
||||
|
@ -93,6 +93,14 @@ class ChannelViewSet(
|
|||
return serializers.ChannelUpdateSerializer
|
||||
return serializers.ChannelCreateSerializer
|
||||
|
||||
def get_queryset(self):
|
||||
queryset = super().get_queryset()
|
||||
if self.action == "retrieve":
|
||||
queryset = queryset.annotate(
|
||||
_downloads_count=Sum("artist__tracks__downloads_count")
|
||||
)
|
||||
return queryset
|
||||
|
||||
def perform_create(self, serializer):
|
||||
return serializer.save(attributed_to=self.request.user.actor)
|
||||
|
||||
|
|
|
@ -294,6 +294,7 @@ class TrackSerializer(OptionalDescriptionMixin, serializers.Serializer):
|
|||
is_local = serializers.BooleanField()
|
||||
position = serializers.IntegerField()
|
||||
disc_number = serializers.IntegerField()
|
||||
downloads_count = serializers.IntegerField()
|
||||
copyright = serializers.CharField()
|
||||
license = serializers.SerializerMethodField()
|
||||
cover = cover_field
|
||||
|
|
|
@ -213,7 +213,7 @@ def test_channel_serializer_update_podcast(factories):
|
|||
def test_channel_serializer_representation(factories, to_api_date):
|
||||
content = factories["common.Content"]()
|
||||
channel = factories["audio.Channel"](artist__description=content)
|
||||
|
||||
setattr(channel, "_downloads_count", 12)
|
||||
expected = {
|
||||
"artist": music_serializers.serialize_artist_simple(channel.artist),
|
||||
"uuid": str(channel.uuid),
|
||||
|
@ -225,6 +225,7 @@ def test_channel_serializer_representation(factories, to_api_date):
|
|||
"metadata": {},
|
||||
"rss_url": channel.get_rss_url(),
|
||||
"url": channel.actor.url,
|
||||
"downloads_count": 12,
|
||||
}
|
||||
expected["artist"]["description"] = common_serializers.ContentSerializer(
|
||||
content
|
||||
|
@ -248,6 +249,7 @@ def test_channel_serializer_external_representation(factories, to_api_date):
|
|||
"metadata": {},
|
||||
"rss_url": channel.get_rss_url(),
|
||||
"url": channel.actor.url,
|
||||
"downloads_count": None,
|
||||
}
|
||||
expected["artist"]["description"] = common_serializers.ContentSerializer(
|
||||
content
|
||||
|
|
|
@ -234,6 +234,7 @@ def test_track_serializer(factories, to_api_date):
|
|||
"tags": [],
|
||||
"attributed_to": federation_serializers.APIActorSerializer(actor).data,
|
||||
"cover": common_serializers.AttachmentSerializer(track.attachment_cover).data,
|
||||
"downloads_count": track.downloads_count,
|
||||
}
|
||||
serializer = serializers.TrackSerializer(track)
|
||||
assert serializer.data == expected
|
||||
|
|
|
@ -0,0 +1 @@
|
|||
Display channel and track downloads count (#1178)
|
|
@ -48,6 +48,14 @@
|
|||
<translate v-else translate-context="*/*/*">N/A</translate>
|
||||
</td>
|
||||
</tr>
|
||||
<tr>
|
||||
<td>
|
||||
<translate translate-context="Content/*/*">Downloads</translate>
|
||||
</td>
|
||||
<td class="right aligned">
|
||||
{{ track.downloads_count }}
|
||||
</td>
|
||||
</tr>
|
||||
</tbody>
|
||||
</table>
|
||||
|
||||
|
|
|
@ -28,7 +28,8 @@
|
|||
<translate key="2" v-else translate-context="*/*/*" :translate-params="{count: totalTracks}" :translate-n="totalTracks" translate-plural="%{ count } tracks">%{ count } track</translate>
|
||||
</template>
|
||||
<template v-if="object.attributed_to.full_username === $store.state.auth.fullUsername || $store.getters['channels/isSubscribed'](object.uuid)">
|
||||
· <translate translate-context="Content/Channel/Paragraph" translate-plural="%{ count } subscribers" :translate-n="object.subscriptions_count" :translate-params="{count: object.subscriptions_count}">%{ count } subscriber</translate>
|
||||
<br><translate translate-context="Content/Channel/Paragraph" translate-plural="%{ count } subscribers" :translate-n="object.subscriptions_count" :translate-params="{count: object.subscriptions_count}">%{ count } subscriber</translate>
|
||||
<br><translate translate-context="Content/Channel/Paragraph" translate-plural="%{ count } listenings" :translate-n="object.downloads_count" :translate-params="{count: object.downloads_count}">%{ count } listening</translate>
|
||||
</template>
|
||||
<div class="ui hidden small divider"></div>
|
||||
<a @click.stop.prevent="showSubscribeModal = true" class="ui icon small basic button">
|
||||
|
|
Loading…
Reference in New Issue