Merge branch 'programming-language' into fossdb

This commit is contained in:
Kristofers Solo 2023-04-08 13:49:39 +03:00
commit bc955c1ae6
13 changed files with 68 additions and 44 deletions

View File

@ -1,12 +1,7 @@
from django.contrib import admin from django.contrib import admin
from programming_language.admin import ProjectProgrammingLanguageInline
from .models import (HostingPlatform, ProgrammingLanguage, Project, from .models import HostingPlatform, License, Project, ProjectHostingPlatform
ProjectHostingPlatform, ProjectProgrammingLanguage, Tag)
class ProjectProgrammingLanguageInline(admin.TabularInline):
model = ProjectProgrammingLanguage
extra = 1
class ProjectHostingPlatformInline(admin.TabularInline): class ProjectHostingPlatformInline(admin.TabularInline):

View File

@ -1,7 +1,6 @@
from django import forms from django import forms
from .models import (HostingPlatform, ProgrammingLanguage, Project, from .models import HostingPlatform, Project, ProjectHostingPlatform
ProjectHostingPlatform, ProjectProgrammingLanguage)
class ProjectForm(forms.ModelForm): class ProjectForm(forms.ModelForm):
@ -23,23 +22,6 @@ class ProjectForm(forms.ModelForm):
} }
class ProgrammingLanguageForm(forms.ModelForm):
percentage = forms.IntegerField(min_value=0, max_value=100)
class Meta:
model = ProgrammingLanguage
fields = ["language", "percentage"]
ProjectProgrammingLanguageFormSet = forms.inlineformset_factory(
Project,
ProjectProgrammingLanguage,
form=ProgrammingLanguageForm,
extra=1,
can_delete=True,
)
class HostingPlatformForm(forms.ModelForm): class HostingPlatformForm(forms.ModelForm):
url = forms.URLField() url = forms.URLField()

View File

@ -3,26 +3,11 @@ import uuid
from django.conf import settings from django.conf import settings
from django.db import models from django.db import models
from license.models import License from license.models import License
from programming_language.models import ProgrammingLanguage
User = settings.AUTH_USER_MODEL User = settings.AUTH_USER_MODEL
class ProgrammingLanguage(models.Model):
language = models.CharField(max_length=100)
def __str__(self):
return self.language
class ProjectProgrammingLanguage(models.Model):
project = models.ForeignKey("Project", on_delete=models.CASCADE)
language = models.ForeignKey(ProgrammingLanguage, on_delete=models.CASCADE)
percentage = models.PositiveIntegerField(default=0)
def __str__(self):
return f"{self.project} | {self.language} | {self.percentage}%"
class HostingPlatform(models.Model): class HostingPlatform(models.Model):
hosting_platform = models.CharField(max_length=100) hosting_platform = models.CharField(max_length=100)

View File

@ -1,8 +1,8 @@
from django.contrib.auth.decorators import login_required, permission_required from django.contrib.auth.decorators import login_required, permission_required
from django.shortcuts import redirect, render from django.shortcuts import redirect, render
from programming_language.forms import ProjectProgrammingLanguageFormSet
from .forms import (ProjectForm, ProjectHostingPlatformFormSet, from .forms import ProjectForm, ProjectHostingPlatformFormSet
ProjectProgrammingLanguageFormSet)
from .models import Project from .models import Project

View File

@ -0,0 +1,11 @@
from django.contrib import admin
from .models import ProgrammingLanguage, ProjectProgrammingLanguage
class ProjectProgrammingLanguageInline(admin.TabularInline):
model = ProjectProgrammingLanguage
extra = 1
admin.site.register(ProgrammingLanguage)

View File

@ -0,0 +1,6 @@
from django.apps import AppConfig
class ProgrammingLanguageConfig(AppConfig):
default_auto_field = 'django.db.models.BigAutoField'
name = 'programming_language'

View File

@ -0,0 +1,21 @@
from django import forms
from fossdb.models import Project
from .models import ProgrammingLanguage, ProjectProgrammingLanguage
class ProgrammingLanguageForm(forms.ModelForm):
percentage = forms.IntegerField(min_value=0, max_value=100)
class Meta:
model = ProgrammingLanguage
fields = ["language", "percentage"]
ProjectProgrammingLanguageFormSet = forms.inlineformset_factory(
Project,
ProjectProgrammingLanguage,
form=ProgrammingLanguageForm,
extra=1,
can_delete=True,
)

View File

@ -0,0 +1,17 @@
from django.db import models
class ProgrammingLanguage(models.Model):
language = models.CharField(max_length=100)
def __str__(self):
return self.language
class ProjectProgrammingLanguage(models.Model):
project = models.ForeignKey("Project", on_delete=models.CASCADE)
language = models.ForeignKey(ProgrammingLanguage, on_delete=models.CASCADE)
percentage = models.PositiveIntegerField()
def __str__(self):
return f"{self.project} | {self.language} | {self.percentage}%"

View File

@ -0,0 +1,3 @@
from django.test import TestCase
# Create your tests here.

View File

@ -0,0 +1,3 @@
from django.shortcuts import render
# Create your views here.

View File

@ -39,6 +39,7 @@ INSTALLED_APPS = [
"fossdb", "fossdb",
"license", "license",
"account", "account",
"programming_language",
"django.contrib.admin", "django.contrib.admin",
"django.contrib.auth", "django.contrib.auth",
"django.contrib.contenttypes", "django.contrib.contenttypes",