WIP
This commit is contained in:
BIN
db.sqlite3
BIN
db.sqlite3
Binary file not shown.
BIN
media/videos/Recover_8.mp4
Normal file
BIN
media/videos/Recover_8.mp4
Normal file
Binary file not shown.
0
video/__init__.py
Normal file
0
video/__init__.py
Normal file
7
video/admin.py
Normal file
7
video/admin.py
Normal file
@@ -0,0 +1,7 @@
|
||||
from django.contrib import admin
|
||||
from .models import Video
|
||||
|
||||
# Register your models here.
|
||||
@admin.register(Video)
|
||||
class VideoAdmin(admin.ModelAdmin):
|
||||
list_display = ("video_file",)
|
||||
6
video/apps.py
Normal file
6
video/apps.py
Normal file
@@ -0,0 +1,6 @@
|
||||
from django.apps import AppConfig
|
||||
|
||||
|
||||
class VideoConfig(AppConfig):
|
||||
default_auto_field = 'django.db.models.BigAutoField'
|
||||
name = 'video'
|
||||
23
video/migrations/0001_initial.py
Normal file
23
video/migrations/0001_initial.py
Normal file
@@ -0,0 +1,23 @@
|
||||
# Generated by Django 4.2.2 on 2023-07-14 19:24
|
||||
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
initial = True
|
||||
|
||||
dependencies = [
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.CreateModel(
|
||||
name='Video',
|
||||
fields=[
|
||||
('id', models.BigAutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')),
|
||||
('created_at', models.DateTimeField(auto_now_add=True)),
|
||||
('updated_at', models.DateTimeField(auto_now=True)),
|
||||
('video_file', models.FileField(null=True, upload_to='videos/', verbose_name='')),
|
||||
],
|
||||
),
|
||||
]
|
||||
19
video/migrations/0002_video_gender.py
Normal file
19
video/migrations/0002_video_gender.py
Normal file
@@ -0,0 +1,19 @@
|
||||
# Generated by Django 4.2.2 on 2023-07-14 19:28
|
||||
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
('video', '0001_initial'),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.AddField(
|
||||
model_name='video',
|
||||
name='gender',
|
||||
field=models.PositiveSmallIntegerField(choices=[(1, 'male'), (2, 'female'), (3, 'both')], default=1),
|
||||
preserve_default=False,
|
||||
),
|
||||
]
|
||||
0
video/migrations/__init__.py
Normal file
0
video/migrations/__init__.py
Normal file
19
video/models.py
Normal file
19
video/models.py
Normal file
@@ -0,0 +1,19 @@
|
||||
from django.db import models
|
||||
|
||||
# Create your models here.
|
||||
VIDEO_GENDER = (
|
||||
(1, "male"),
|
||||
(2, "female"),
|
||||
(3, "both"),
|
||||
)
|
||||
|
||||
class Video(models.Model):
|
||||
created_at = models.DateTimeField(auto_now_add=True)
|
||||
updated_at = models.DateTimeField(auto_now=True)
|
||||
video_file = models.FileField(upload_to='videos/', null=True, verbose_name="")
|
||||
gender = models.PositiveSmallIntegerField(
|
||||
choices=VIDEO_GENDER
|
||||
)
|
||||
|
||||
def __str__(self):
|
||||
return str(self.video_file)
|
||||
7
video/serializers.py
Normal file
7
video/serializers.py
Normal file
@@ -0,0 +1,7 @@
|
||||
from rest_framework import serializers
|
||||
from .models import *
|
||||
|
||||
class VideoSerializer(serializers.ModelSerializer):
|
||||
class Meta:
|
||||
model = Video
|
||||
fields = ('video_file',)
|
||||
3
video/tests.py
Normal file
3
video/tests.py
Normal file
@@ -0,0 +1,3 @@
|
||||
from django.test import TestCase
|
||||
|
||||
# Create your tests here.
|
||||
3
video/views.py
Normal file
3
video/views.py
Normal file
@@ -0,0 +1,3 @@
|
||||
from django.shortcuts import render
|
||||
|
||||
# Create your views here.
|
||||
@@ -39,7 +39,8 @@ INSTALLED_APPS = [
|
||||
'registered_user',
|
||||
'workout',
|
||||
'muscle',
|
||||
'scripts'
|
||||
'scripts',
|
||||
'video'
|
||||
]
|
||||
|
||||
MIDDLEWARE = [
|
||||
|
||||
@@ -4,6 +4,8 @@ from exercise.serializers import ExerciseSerializer
|
||||
from registered_user.serializers import GetRegisteredUserSerializer
|
||||
from muscle.models import ExerciseMuscle
|
||||
from equipment.models import WorkoutEquipment
|
||||
from video.models import Video
|
||||
from video.serializers import VideoSerializer
|
||||
|
||||
class WorkoutExerciseSerializer(serializers.ModelSerializer):
|
||||
exercise = ExerciseSerializer(read_only=True)
|
||||
@@ -62,10 +64,13 @@ class WorkoutSerializer(serializers.ModelSerializer):
|
||||
class WorkoutDetailSerializer(serializers.ModelSerializer):
|
||||
exercises = serializers.SerializerMethodField()
|
||||
registered_user = serializers.SerializerMethodField()
|
||||
male_videos = serializers.SerializerMethodField()
|
||||
female_videos = serializers.SerializerMethodField()
|
||||
both_videos = serializers.SerializerMethodField()
|
||||
|
||||
class Meta:
|
||||
model = Workout
|
||||
fields = ('id', 'name', 'description', 'exercises', 'registered_user')
|
||||
fields = ('id', 'name', 'description', 'exercises', 'registered_user', 'male_videos', 'female_videos', 'both_videos')
|
||||
depth = 1
|
||||
|
||||
def get_exercises(self, obj):
|
||||
@@ -77,6 +82,18 @@ class WorkoutDetailSerializer(serializers.ModelSerializer):
|
||||
objs = RegisteredUser.objects.get(pk=obj.registered_user.pk)
|
||||
data = GetRegisteredUserSerializer(objs, many=False).data
|
||||
return data
|
||||
|
||||
def get_male_videos(self, obj):
|
||||
data = Video.objects.filter(gender=1).values_list('video_file', flat=True)
|
||||
return data
|
||||
|
||||
def get_female_videos(self, obj):
|
||||
data = Video.objects.filter(gender=2).values_list('video_file', flat=True)
|
||||
return data
|
||||
|
||||
def get_both_videos(self, obj):
|
||||
data = Video.objects.filter(gender=3).values_list('video_file', flat=True)
|
||||
return data
|
||||
|
||||
class GetCompleteWorkoutSerializer(serializers.ModelSerializer):
|
||||
workout = WorkoutSerializer(many=False, read_only=True)
|
||||
|
||||
Reference in New Issue
Block a user