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',
|
'registered_user',
|
||||||
'workout',
|
'workout',
|
||||||
'muscle',
|
'muscle',
|
||||||
'scripts'
|
'scripts',
|
||||||
|
'video'
|
||||||
]
|
]
|
||||||
|
|
||||||
MIDDLEWARE = [
|
MIDDLEWARE = [
|
||||||
|
|||||||
@@ -4,6 +4,8 @@ from exercise.serializers import ExerciseSerializer
|
|||||||
from registered_user.serializers import GetRegisteredUserSerializer
|
from registered_user.serializers import GetRegisteredUserSerializer
|
||||||
from muscle.models import ExerciseMuscle
|
from muscle.models import ExerciseMuscle
|
||||||
from equipment.models import WorkoutEquipment
|
from equipment.models import WorkoutEquipment
|
||||||
|
from video.models import Video
|
||||||
|
from video.serializers import VideoSerializer
|
||||||
|
|
||||||
class WorkoutExerciseSerializer(serializers.ModelSerializer):
|
class WorkoutExerciseSerializer(serializers.ModelSerializer):
|
||||||
exercise = ExerciseSerializer(read_only=True)
|
exercise = ExerciseSerializer(read_only=True)
|
||||||
@@ -62,10 +64,13 @@ class WorkoutSerializer(serializers.ModelSerializer):
|
|||||||
class WorkoutDetailSerializer(serializers.ModelSerializer):
|
class WorkoutDetailSerializer(serializers.ModelSerializer):
|
||||||
exercises = serializers.SerializerMethodField()
|
exercises = serializers.SerializerMethodField()
|
||||||
registered_user = serializers.SerializerMethodField()
|
registered_user = serializers.SerializerMethodField()
|
||||||
|
male_videos = serializers.SerializerMethodField()
|
||||||
|
female_videos = serializers.SerializerMethodField()
|
||||||
|
both_videos = serializers.SerializerMethodField()
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
model = Workout
|
model = Workout
|
||||||
fields = ('id', 'name', 'description', 'exercises', 'registered_user')
|
fields = ('id', 'name', 'description', 'exercises', 'registered_user', 'male_videos', 'female_videos', 'both_videos')
|
||||||
depth = 1
|
depth = 1
|
||||||
|
|
||||||
def get_exercises(self, obj):
|
def get_exercises(self, obj):
|
||||||
@@ -78,6 +83,18 @@ class WorkoutDetailSerializer(serializers.ModelSerializer):
|
|||||||
data = GetRegisteredUserSerializer(objs, many=False).data
|
data = GetRegisteredUserSerializer(objs, many=False).data
|
||||||
return 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):
|
class GetCompleteWorkoutSerializer(serializers.ModelSerializer):
|
||||||
workout = WorkoutSerializer(many=False, read_only=True)
|
workout = WorkoutSerializer(many=False, read_only=True)
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user