mirror of
https://github.com/kristoferssolo/FOSSDB.git
synced 2025-10-21 17:50:35 +00:00
Merge branch 'programming-language' into fossdb
This commit is contained in:
commit
bc955c1ae6
@ -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):
|
||||||
|
|||||||
@ -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()
|
||||||
|
|
||||||
|
|||||||
@ -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)
|
||||||
|
|
||||||
|
|||||||
@ -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
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
0
FOSSDB_web/apps/programming_language/__init__.py
Normal file
0
FOSSDB_web/apps/programming_language/__init__.py
Normal file
11
FOSSDB_web/apps/programming_language/admin.py
Normal file
11
FOSSDB_web/apps/programming_language/admin.py
Normal 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)
|
||||||
6
FOSSDB_web/apps/programming_language/apps.py
Normal file
6
FOSSDB_web/apps/programming_language/apps.py
Normal file
@ -0,0 +1,6 @@
|
|||||||
|
from django.apps import AppConfig
|
||||||
|
|
||||||
|
|
||||||
|
class ProgrammingLanguageConfig(AppConfig):
|
||||||
|
default_auto_field = 'django.db.models.BigAutoField'
|
||||||
|
name = 'programming_language'
|
||||||
21
FOSSDB_web/apps/programming_language/forms.py
Normal file
21
FOSSDB_web/apps/programming_language/forms.py
Normal 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,
|
||||||
|
)
|
||||||
17
FOSSDB_web/apps/programming_language/models.py
Normal file
17
FOSSDB_web/apps/programming_language/models.py
Normal 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}%"
|
||||||
3
FOSSDB_web/apps/programming_language/tests.py
Normal file
3
FOSSDB_web/apps/programming_language/tests.py
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
from django.test import TestCase
|
||||||
|
|
||||||
|
# Create your tests here.
|
||||||
3
FOSSDB_web/apps/programming_language/views.py
Normal file
3
FOSSDB_web/apps/programming_language/views.py
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
from django.shortcuts import render
|
||||||
|
|
||||||
|
# Create your views here.
|
||||||
@ -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",
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user