diff --git a/.gitignore b/.gitignore index e4b082a..fa99085 100644 --- a/.gitignore +++ b/.gitignore @@ -11,6 +11,9 @@ areas/migrations/* news/migrations/* !news/migrations/__init__.py +quicklinks/migrations/* +!quicklinks/migrations/__init__.py + standards/migrations/* !standards/migrations/__init__.py diff --git a/digitaleagentur/__pycache__/settings.cpython-38.pyc b/digitaleagentur/__pycache__/settings.cpython-38.pyc index 6d53cfa..597bc12 100644 Binary files a/digitaleagentur/__pycache__/settings.cpython-38.pyc and b/digitaleagentur/__pycache__/settings.cpython-38.pyc differ diff --git a/digitaleagentur/__pycache__/urls.cpython-38.pyc b/digitaleagentur/__pycache__/urls.cpython-38.pyc index 7905a5b..edf28b3 100644 Binary files a/digitaleagentur/__pycache__/urls.cpython-38.pyc and b/digitaleagentur/__pycache__/urls.cpython-38.pyc differ diff --git a/digitaleagentur/settings.py b/digitaleagentur/settings.py index e9960f2..f37f049 100644 --- a/digitaleagentur/settings.py +++ b/digitaleagentur/settings.py @@ -34,6 +34,7 @@ INSTALLED_APPS = [ 'areas.apps.AreasConfig', 'orga.apps.OrgaConfig', 'tasks.apps.TasksConfig', + 'quicklinks.apps.QuicklinksConfig', 'standards.apps.StandardsConfig', 'news.apps.NewsConfig', 'crispy_forms', diff --git a/digitaleagentur/urls.py b/digitaleagentur/urls.py index 7dd686f..024d6ec 100644 --- a/digitaleagentur/urls.py +++ b/digitaleagentur/urls.py @@ -18,6 +18,7 @@ from django.contrib.auth.decorators import login_required standards orga news + quicklinkgs -> Rest ist von Django @@ -29,6 +30,7 @@ urlpatterns = [ path('dashboard/', include('users.urls'), name="dashboard"), path('areas/', include('areas.urls'), name="areas-management"), path('tasks/', include('tasks.urls'), name="tasks-management"), + path('ql/', include('quicklinks.urls'), name="ql-management"), path('standards/', include('standards.urls'), name="standards"), path('news/', include('news.urls'), name="dashboard"), path('orga/', include('orga.urls'), name="orga"), diff --git a/quicklinks/__init__.py b/quicklinks/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/quicklinks/__pycache__/__init__.cpython-38.pyc b/quicklinks/__pycache__/__init__.cpython-38.pyc new file mode 100644 index 0000000..78c6cde Binary files /dev/null and b/quicklinks/__pycache__/__init__.cpython-38.pyc differ diff --git a/quicklinks/__pycache__/admin.cpython-38.pyc b/quicklinks/__pycache__/admin.cpython-38.pyc new file mode 100644 index 0000000..1407c65 Binary files /dev/null and b/quicklinks/__pycache__/admin.cpython-38.pyc differ diff --git a/quicklinks/__pycache__/apps.cpython-38.pyc b/quicklinks/__pycache__/apps.cpython-38.pyc new file mode 100644 index 0000000..8bc1553 Binary files /dev/null and b/quicklinks/__pycache__/apps.cpython-38.pyc differ diff --git a/quicklinks/__pycache__/forms.cpython-38.pyc b/quicklinks/__pycache__/forms.cpython-38.pyc new file mode 100644 index 0000000..eb58539 Binary files /dev/null and b/quicklinks/__pycache__/forms.cpython-38.pyc differ diff --git a/quicklinks/__pycache__/models.cpython-38.pyc b/quicklinks/__pycache__/models.cpython-38.pyc new file mode 100644 index 0000000..26c7632 Binary files /dev/null and b/quicklinks/__pycache__/models.cpython-38.pyc differ diff --git a/quicklinks/__pycache__/urls.cpython-38.pyc b/quicklinks/__pycache__/urls.cpython-38.pyc new file mode 100644 index 0000000..3b929a9 Binary files /dev/null and b/quicklinks/__pycache__/urls.cpython-38.pyc differ diff --git a/quicklinks/__pycache__/views.cpython-38.pyc b/quicklinks/__pycache__/views.cpython-38.pyc new file mode 100644 index 0000000..e9b0964 Binary files /dev/null and b/quicklinks/__pycache__/views.cpython-38.pyc differ diff --git a/quicklinks/admin.py b/quicklinks/admin.py new file mode 100644 index 0000000..8c38f3f --- /dev/null +++ b/quicklinks/admin.py @@ -0,0 +1,3 @@ +from django.contrib import admin + +# Register your models here. diff --git a/quicklinks/apps.py b/quicklinks/apps.py new file mode 100644 index 0000000..a6e7ca4 --- /dev/null +++ b/quicklinks/apps.py @@ -0,0 +1,4 @@ +from django.apps import AppConfig + +class QuicklinksConfig(AppConfig): + name = 'quicklinks' diff --git a/quicklinks/forms.py b/quicklinks/forms.py new file mode 100644 index 0000000..a696478 --- /dev/null +++ b/quicklinks/forms.py @@ -0,0 +1,15 @@ +from django import forms +from django.forms import ModelForm +from .models import QuickLinks + + +class QlAddQlForm(forms.ModelForm): + + class Meta: + model =QuickLinks + labels = { + "name" : "Name", + "link" : "Weblink", + "logo" : "Logo", + } + fields = ['name', 'link', 'logo'] \ No newline at end of file diff --git a/quicklinks/migrations/__init__.py b/quicklinks/migrations/__init__.py new file mode 100644 index 0000000..e69de29 diff --git a/quicklinks/models.py b/quicklinks/models.py new file mode 100644 index 0000000..7eea489 --- /dev/null +++ b/quicklinks/models.py @@ -0,0 +1,33 @@ +from django.db import models +from users.models import Agency +from django.urls import reverse +from colorful.fields import RGBColorField +from django.contrib.auth.models import User +import datetime + +''' + +Model Quicklinks + +Verwaltet alle gespeicherten Bereiche für die Agentur. Wird eine neue erstellt, +wird dieser die Agency zugewiesen. Das Farb-Feld ist für später, damit im +Ogranigramm eine Farbe für den jeweiligen Bereich festgelegt wird. + +users speichert alle primary-Keys der User, welche diesem Bereich zugeordnet sind! + +''' +class QuickLinks(models.Model): + + # Wenn die Area gelöscht wird, wird NICHT die Agency gelöscht + agency = models.ForeignKey(Agency, on_delete=models.PROTECT) + name = models.CharField(max_length=200, blank=False) + link = models.CharField(max_length=200, blank=False) + logo = models.ImageField(default='agencymain/default.jpg', upload_to='agencymain', blank=True) + + def __str__(self): + return f'{self.name}' + + def get_absolute_url(self): + return reverse('ql-update', kwargs={'pk':self.pk}) + + diff --git a/quicklinks/templates/quicklinks/ql_add.html b/quicklinks/templates/quicklinks/ql_add.html new file mode 100644 index 0000000..e29d3f3 --- /dev/null +++ b/quicklinks/templates/quicklinks/ql_add.html @@ -0,0 +1,15 @@ +{% extends "users/base.html" %} +{% load crispy_forms_tags %} +{% block content %} +
+ Quicklinks helfen zur schnellen Verlinkung von oft genutzten Diensten. +
+ {% if perms.users.ql_management %} +| Name | +Link | +Logo | ++ |
|---|---|---|---|
| {{ql.name }} | +{{ ql.link }} | +
+ {% if perms.users.ql_management %}
+
+
+
+
+
+
+ {% endif %}
+
+ |
+