mirror of
https://gitlab.com/megazordpobeda/DataRush.git
synced 2026-05-23 05:07:10 +00:00
Merge branch 'master' of gitlab.prodcontest.ru:team-15/project
This commit is contained in:
@@ -4,6 +4,7 @@ from apps.task.models import (
|
||||
CompetitionTask,
|
||||
CompetitionTaskAttachment,
|
||||
CompetitionTaskSubmission,
|
||||
CompetitionTaskCriteria
|
||||
)
|
||||
|
||||
|
||||
@@ -12,12 +13,17 @@ class CompletionAttachmentInline(admin.StackedInline):
|
||||
extra = 0
|
||||
|
||||
|
||||
class CompetitionCriteriaInline(admin.StackedInline):
|
||||
model = CompetitionTaskCriteria
|
||||
extra = 0
|
||||
|
||||
|
||||
@admin.register(CompetitionTask)
|
||||
class CompetitionTaskAdmin(admin.ModelAdmin):
|
||||
list_display = ("title", "type", "points")
|
||||
filter_horizontal = ("reviewers",)
|
||||
list_filter = ("type",)
|
||||
inlines = (CompletionAttachmentInline,)
|
||||
inlines = (CompletionAttachmentInline, CompetitionCriteriaInline,)
|
||||
|
||||
|
||||
@admin.register(CompetitionTaskSubmission)
|
||||
|
||||
@@ -2,7 +2,7 @@ from uuid import uuid4
|
||||
|
||||
from django.db import models
|
||||
from django.db.models import Count, Q
|
||||
from martor.models import MartorField
|
||||
from mdeditor.fields import MDTextField
|
||||
|
||||
from apps.competition.models import Competition
|
||||
from apps.core.models import BaseModel
|
||||
@@ -19,11 +19,15 @@ class CompetitionTask(BaseModel):
|
||||
def answer_file_upload_to(instance, filename) -> str:
|
||||
return f"tasks/{instance.id}/answer/{uuid4()}/{filename}"
|
||||
|
||||
in_competition_position = models.PositiveSmallIntegerField()
|
||||
competition = models.ForeignKey(Competition, on_delete=models.CASCADE)
|
||||
in_competition_position = models.PositiveSmallIntegerField(
|
||||
verbose_name="позиция в соревновании"
|
||||
)
|
||||
competition = models.ForeignKey(Competition, on_delete=models.CASCADE,
|
||||
verbose_name="привязанное соревнование")
|
||||
title = models.CharField(verbose_name="заголовок", max_length=50)
|
||||
description = MartorField(verbose_name="описание")
|
||||
max_attempts = models.PositiveSmallIntegerField(null=True, blank=True)
|
||||
description = MDTextField(verbose_name="описание")
|
||||
max_attempts = models.PositiveSmallIntegerField(null=True, blank=True,
|
||||
verbose_name="максимальное кол-во попыток")
|
||||
type = models.CharField(
|
||||
choices=CompetitionTaskType, max_length=8, verbose_name="тип проверки"
|
||||
)
|
||||
@@ -64,7 +68,7 @@ class CompetitionTask(BaseModel):
|
||||
),
|
||||
)
|
||||
submission_reviewers_count = models.PositiveSmallIntegerField(
|
||||
default=1, null=True, blank=True
|
||||
default=1, null=True, blank=True, verbose_name="кол-во проверяющих для зачета задачи"
|
||||
)
|
||||
|
||||
def __str__(self):
|
||||
@@ -80,10 +84,25 @@ class CompetitionTaskCriteria(BaseModel):
|
||||
CompetitionTask, on_delete=models.CASCADE, related_name="criteries"
|
||||
)
|
||||
|
||||
name = models.TextField()
|
||||
slug = models.SlugField()
|
||||
description = models.TextField()
|
||||
max_value = models.PositiveSmallIntegerField()
|
||||
name = models.TextField(
|
||||
verbose_name="название"
|
||||
)
|
||||
slug = models.SlugField(
|
||||
verbose_name="техническое название"
|
||||
)
|
||||
description = models.TextField(
|
||||
verbose_name="описание критерии"
|
||||
)
|
||||
max_value = models.PositiveSmallIntegerField(
|
||||
verbose_name="максимальное кол-во баллов"
|
||||
)
|
||||
|
||||
def __str__(self):
|
||||
return self.name
|
||||
|
||||
class Meta:
|
||||
verbose_name = "критерий"
|
||||
verbose_name_plural = "критерии"
|
||||
|
||||
|
||||
class CompetitionTaskAttachment(BaseModel):
|
||||
|
||||
Reference in New Issue
Block a user