mirror of https://github.com/doccano/doccano.git
pythondatasetsactive-learningtext-annotationdatasetnatural-language-processingdata-labelingmachine-learningannotation-tool
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
55 lines
2.1 KiB
55 lines
2.1 KiB
import abc
|
|
|
|
from rest_framework import status
|
|
from rest_framework.permissions import IsAuthenticated
|
|
from rest_framework.response import Response
|
|
from rest_framework.views import APIView
|
|
|
|
from examples.models import Example, ExampleState
|
|
from label_types.models import LabelType, CategoryType, SpanType
|
|
from labels.models import Label, Category, Span
|
|
from projects.models import Member
|
|
from projects.permissions import IsProjectAdmin, IsProjectStaffAndReadOnly
|
|
|
|
|
|
class ProgressAPI(APIView):
|
|
permission_classes = [IsAuthenticated & (IsProjectAdmin | IsProjectStaffAndReadOnly)]
|
|
|
|
def get(self, request, *args, **kwargs):
|
|
examples = Example.objects.filter(project=self.kwargs["project_id"]).values("id")
|
|
total = examples.count()
|
|
done = ExampleState.objects.count_done(examples, user=self.request.user)
|
|
return {"total": total, "remaining": total - done}
|
|
|
|
|
|
class MemberProgressAPI(APIView):
|
|
permission_classes = [IsAuthenticated & (IsProjectAdmin | IsProjectStaffAndReadOnly)]
|
|
|
|
def get(self, request, *args, **kwargs):
|
|
examples = Example.objects.filter(project=self.kwargs["project_id"]).values("id")
|
|
members = Member.objects.filter(project=self.kwargs["project_id"])
|
|
data = ExampleState.objects.measure_member_progress(examples, members)
|
|
return Response(data=data, status=status.HTTP_200_OK)
|
|
|
|
|
|
class LabelDistribution(abc.ABC, APIView):
|
|
permission_classes = [IsAuthenticated & (IsProjectAdmin | IsProjectStaffAndReadOnly)]
|
|
model = Label
|
|
label_type = LabelType
|
|
|
|
def get(self, request, *args, **kwargs):
|
|
labels = self.label_type.objects.filter(project=self.kwargs["project_id"])
|
|
examples = Example.objects.filter(project=self.kwargs["project_id"]).values("id")
|
|
members = Member.objects.filter(project=self.kwargs["project_id"])
|
|
data = self.model.objects.calc_label_distribution(examples, members, labels)
|
|
return Response(data=data, status=status.HTTP_200_OK)
|
|
|
|
|
|
class CategoryTypeDistribution(LabelDistribution):
|
|
model = Category
|
|
label_type = CategoryType
|
|
|
|
|
|
class SpanTypeDistribution(LabelDistribution):
|
|
model = Span
|
|
label_type = SpanType
|