List feature
+ implemented list feature + implemented category feature
This commit is contained in:
parent
5877b83424
commit
32d60f51ac
23 changed files with 210 additions and 60 deletions
|
|
@ -105,7 +105,7 @@ AUTH_PASSWORD_VALIDATORS = [
|
|||
# Internationalization
|
||||
# https://docs.djangoproject.com/en/2.1/topics/i18n/
|
||||
|
||||
LANGUAGE_CODE = 'en-us'
|
||||
LANGUAGE_CODE = 'de'
|
||||
|
||||
TIME_ZONE = 'Europe/Berlin'
|
||||
|
||||
|
|
|
|||
|
|
@ -20,6 +20,7 @@ urlpatterns = [
|
|||
path('admin/', admin.site.urls),
|
||||
path('accounts/', include('django.contrib.auth.urls')),
|
||||
path('', include('user_manager.urls')),
|
||||
path('add/', include('object_adder.urls'))
|
||||
path('add/', include('object_adder.urls')),
|
||||
path('list/', include('object_lister.urls'))
|
||||
|
||||
]
|
||||
|
|
|
|||
|
|
@ -1,10 +1,15 @@
|
|||
from django.contrib import admin
|
||||
from .models import Object
|
||||
from .models import Object, Category
|
||||
|
||||
|
||||
class ObjectAdmin(admin.ModelAdmin):
|
||||
list_display = ('title', 'ammout', 'uuid', 'img')
|
||||
|
||||
|
||||
class CategoryAdmin(admin.ModelAdmin):
|
||||
list_display = ('name', 'id')
|
||||
|
||||
|
||||
# Register your models here.
|
||||
admin.site.register(Object, ObjectAdmin)
|
||||
admin.site.register(Category, CategoryAdmin)
|
||||
|
|
|
|||
|
|
@ -1,12 +1,21 @@
|
|||
from django.forms import ModelForm, TextInput
|
||||
|
||||
from .models import Object
|
||||
from .models import Object, Category
|
||||
|
||||
|
||||
class ObjectForm(ModelForm):
|
||||
class Meta:
|
||||
model = Object
|
||||
fields = ('ammout', 'title', 'img', 'description')
|
||||
fields = ('ammout', 'title', 'img', 'description', 'category')
|
||||
widgets = {
|
||||
'title': TextInput(),
|
||||
}
|
||||
|
||||
|
||||
class CategoryForm(ModelForm):
|
||||
class Meta:
|
||||
model = Category
|
||||
fields = ['name']
|
||||
widgets = {
|
||||
'name': TextInput()
|
||||
}
|
||||
|
|
|
|||
|
|
@ -1,4 +1,4 @@
|
|||
# Generated by Django 2.1.4 on 2018-12-18 17:57
|
||||
# Generated by Django 2.1.4 on 2018-12-22 19:20
|
||||
|
||||
from django.conf import settings
|
||||
from django.db import migrations, models
|
||||
|
|
@ -18,11 +18,14 @@ class Migration(migrations.Migration):
|
|||
migrations.CreateModel(
|
||||
name='Object',
|
||||
fields=[
|
||||
('ammout', models.PositiveIntegerField(default=1)),
|
||||
('title', models.TextField(default=None, max_length=100)),
|
||||
('img', models.ImageField(blank=True, default=None, upload_to='')),
|
||||
('uuid', models.UUIDField(default=uuid.uuid4, editable=False, primary_key=True, serialize=False)),
|
||||
('inventarized_date', models.DateTimeField()),
|
||||
('description', models.TextField(max_length=500)),
|
||||
('removed_date', models.DateTimeField()),
|
||||
('user_added', models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)),
|
||||
('inventarized_date', models.DateTimeField(null=True)),
|
||||
('description', models.TextField(blank=True, max_length=500)),
|
||||
('removed_date', models.DateTimeField(blank=True, default=None, null=True)),
|
||||
('user_added', models.ForeignKey(null=True, on_delete=django.db.models.deletion.CASCADE, to=settings.AUTH_USER_MODEL)),
|
||||
],
|
||||
),
|
||||
]
|
||||
|
|
|
|||
|
|
@ -1,18 +0,0 @@
|
|||
# Generated by Django 2.1.4 on 2018-12-18 18:04
|
||||
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
('object_adder', '0001_initial'),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.AddField(
|
||||
model_name='object',
|
||||
name='img',
|
||||
field=models.ImageField(default=None, upload_to=''),
|
||||
),
|
||||
]
|
||||
|
|
@ -1,18 +0,0 @@
|
|||
# Generated by Django 2.1.4 on 2018-12-18 18:17
|
||||
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
('object_adder', '0002_object_img'),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.AddField(
|
||||
model_name='object',
|
||||
name='title',
|
||||
field=models.TextField(default=None, max_length=100),
|
||||
),
|
||||
]
|
||||
|
|
@ -14,3 +14,19 @@ class Object(models.Model):
|
|||
description = models.TextField(max_length=500, blank=True)
|
||||
removed_date = models.DateTimeField(blank=True, default=None, null=True)
|
||||
user_added = models.ForeignKey(User, on_delete=models.CASCADE, blank=False, null=True)
|
||||
category = models.ForeignKey('Category', on_delete=models.CASCADE, blank=True, default=None, null=True)
|
||||
|
||||
objects = models.Manager()
|
||||
|
||||
def __str__(self):
|
||||
return str(self.uuid)
|
||||
|
||||
|
||||
class Category(models.Model):
|
||||
name = models.TextField(blank=False, max_length=150)
|
||||
id = models.UUIDField(primary_key=True, default=uuid.uuid4, editable=False)
|
||||
|
||||
categories = models.Manager()
|
||||
|
||||
def __str__(self):
|
||||
return self.name
|
||||
|
|
|
|||
|
|
@ -3,4 +3,5 @@ from . import views
|
|||
|
||||
urlpatterns = [
|
||||
path('', views.add, name='add'),
|
||||
path('kategorie', views.category, name='category')
|
||||
]
|
||||
|
|
|
|||
|
|
@ -1,6 +1,6 @@
|
|||
from django.shortcuts import render
|
||||
from django.contrib.auth.decorators import login_required
|
||||
from .forms import ObjectForm
|
||||
from .forms import ObjectForm, CategoryForm
|
||||
from django.utils import timezone
|
||||
|
||||
|
||||
|
|
@ -24,10 +24,28 @@ def add(request):
|
|||
obj.user_added = request.user
|
||||
obj.save()
|
||||
|
||||
context = {'title': 'Objekt inventarisieren', 'form': ObjectForm,
|
||||
'obj_name': form.cleaned_data.get('title')}
|
||||
return render(request, 'object_adder/index.html', context)
|
||||
context = {'title': 'Objekt inventarisieren', 'form': ObjectForm,
|
||||
'obj_name': form.cleaned_data.get('title')}
|
||||
return render(request, 'object_adder/index.html', context)
|
||||
|
||||
else:
|
||||
context = {'title': 'Objekt inventarisieren', 'form': ObjectForm}
|
||||
return render(request, 'object_adder/index.html', context)
|
||||
|
||||
|
||||
@login_required
|
||||
def category(request):
|
||||
if request.method == 'POST':
|
||||
form = CategoryForm(request.POST)
|
||||
|
||||
if form.is_valid():
|
||||
cat = form.save()
|
||||
cat.save()
|
||||
|
||||
context = {'title': 'Neue Kategorie hinzufügen',
|
||||
'cat_name': form.cleaned_data.get('name'),
|
||||
'form': CategoryForm}
|
||||
return render(request, 'object_adder/category.html', context)
|
||||
else:
|
||||
context = {'form': CategoryForm, 'title': 'Neue Kategorie hinzufügen'}
|
||||
return render(request, 'object_adder/category.html', context)
|
||||
|
|
|
|||
0
invsystem/object_lister/__init__.py
Normal file
0
invsystem/object_lister/__init__.py
Normal file
3
invsystem/object_lister/admin.py
Normal file
3
invsystem/object_lister/admin.py
Normal file
|
|
@ -0,0 +1,3 @@
|
|||
from django.contrib import admin
|
||||
|
||||
# Register your models here.
|
||||
5
invsystem/object_lister/apps.py
Normal file
5
invsystem/object_lister/apps.py
Normal file
|
|
@ -0,0 +1,5 @@
|
|||
from django.apps import AppConfig
|
||||
|
||||
|
||||
class ObjectListerConfig(AppConfig):
|
||||
name = 'object_lister'
|
||||
0
invsystem/object_lister/migrations/__init__.py
Normal file
0
invsystem/object_lister/migrations/__init__.py
Normal file
3
invsystem/object_lister/models.py
Normal file
3
invsystem/object_lister/models.py
Normal file
|
|
@ -0,0 +1,3 @@
|
|||
from django.db import models
|
||||
|
||||
# Create your models here.
|
||||
3
invsystem/object_lister/tests.py
Normal file
3
invsystem/object_lister/tests.py
Normal file
|
|
@ -0,0 +1,3 @@
|
|||
from django.test import TestCase
|
||||
|
||||
# Create your tests here.
|
||||
6
invsystem/object_lister/urls.py
Normal file
6
invsystem/object_lister/urls.py
Normal file
|
|
@ -0,0 +1,6 @@
|
|||
from django.urls import path
|
||||
from . import views
|
||||
|
||||
urlpatterns = [
|
||||
path('', views.objlist, name='objlist'),
|
||||
]
|
||||
13
invsystem/object_lister/views.py
Normal file
13
invsystem/object_lister/views.py
Normal file
|
|
@ -0,0 +1,13 @@
|
|||
from django.shortcuts import render
|
||||
from object_adder.models import Object
|
||||
from django.contrib.auth.decorators import login_required
|
||||
|
||||
|
||||
# Create your views here.
|
||||
@login_required
|
||||
def objlist(request):
|
||||
|
||||
objects = Object.objects.all()
|
||||
|
||||
context = {'title': 'Inventar', 'objects': objects}
|
||||
return render(request, 'object_lister/index.html', context)
|
||||
|
|
@ -57,26 +57,62 @@
|
|||
}
|
||||
|
||||
|
||||
|
||||
.title-wrapper *{
|
||||
.title-wrapper * {
|
||||
vertical-align: middle;
|
||||
}
|
||||
|
||||
#id_img{
|
||||
#id_img {
|
||||
display: inline-block;
|
||||
margin-left: 1.2em;
|
||||
|
||||
}
|
||||
|
||||
.description-wrapper *{
|
||||
.description-wrapper * {
|
||||
vertical-align: middle;
|
||||
}
|
||||
|
||||
.invform *{
|
||||
.invform * {
|
||||
margin-top: 1.5em;
|
||||
}
|
||||
|
||||
#id_description{
|
||||
#id_description {
|
||||
width: 18em;
|
||||
height: 5em;
|
||||
}
|
||||
|
||||
.catform * {
|
||||
margin-top: 0.7em;
|
||||
}
|
||||
|
||||
.btnwrapper {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
}
|
||||
|
||||
.newcatlink {
|
||||
margin-left: 2em;
|
||||
}
|
||||
|
||||
.objecttable {
|
||||
border-collapse: collapse;
|
||||
width: 100%;
|
||||
margin-top: 2em;
|
||||
margin-bottom: 2em;
|
||||
}
|
||||
|
||||
.objecttable-data, .objecttable-head {
|
||||
border: 1px solid #dddddd;
|
||||
text-align: center;
|
||||
padding: 0.4em;
|
||||
}
|
||||
|
||||
.objecttable-row:nth-child(even) {
|
||||
background-color: #dddddd;
|
||||
}
|
||||
|
||||
.objecttable-row:hover {
|
||||
-webkit-box-shadow: 3px 3px 28px -3px rgba(0, 0, 0, 0.1);
|
||||
-moz-box-shadow: 3px 3px 28px -3px rgba(0, 0, 0, 0.1);
|
||||
box-shadow: 3px 3px 28px -3px rgba(0, 0, 0, 0.1);
|
||||
border-radius: 10px;
|
||||
transition: 0.1s;
|
||||
}
|
||||
|
|
@ -37,6 +37,7 @@
|
|||
<li><a href="{% url 'index' %}">Home</a></li>
|
||||
{% if user.is_authenticated %}
|
||||
<li><a href="{% url 'add' %}">Objekt inventarisieren</a></li>
|
||||
<li><a href="{% url 'objlist' %}">Inventar</a></li>
|
||||
{% endif %}
|
||||
</ul>
|
||||
{% if user.is_authenticated %}
|
||||
|
|
|
|||
27
invsystem/user_manager/templates/object_adder/category.html
Normal file
27
invsystem/user_manager/templates/object_adder/category.html
Normal file
|
|
@ -0,0 +1,27 @@
|
|||
{% extends 'bases/navbar.html' %}
|
||||
<html>
|
||||
{% block content %}
|
||||
|
||||
<body>
|
||||
<div class="container shadow">
|
||||
{% if not cat_name is None %}
|
||||
<div class="alert alert-info alert-dismissible">
|
||||
<a href="#" class="close" data-dismiss="alert" aria-label="close">×</a>
|
||||
Die Kategorie <strong>{{ cat_name }}</strong> wurde erstellt!
|
||||
</div>
|
||||
{% endif %}
|
||||
<form method="POST" class="post-form invform">
|
||||
{% csrf_token %}
|
||||
<div class="name-wrapper">
|
||||
{{ form.name.errors }}
|
||||
<label for="{{ form.name.id_for_lable }}">Kategorie:</label>
|
||||
{{ form.name }}
|
||||
</div>
|
||||
|
||||
<button type="submit" class="save btn btn-primary">Kategorie hinzufügen</button>
|
||||
</form>
|
||||
</div>
|
||||
</body>
|
||||
{% endblock %}
|
||||
|
||||
</html>
|
||||
|
|
@ -3,7 +3,7 @@
|
|||
{% block content %}
|
||||
|
||||
<body>
|
||||
<div class="container">
|
||||
<div class="container shadow">
|
||||
{% if not obj_name is None %}
|
||||
<div class="alert alert-info alert-dismissible">
|
||||
<a href="#" class="close" data-dismiss="alert" aria-label="close">×</a>
|
||||
|
|
@ -22,6 +22,11 @@
|
|||
<label for="{{ form.title.id_for_lable }}">Objekt:</label>
|
||||
{{ form.title }}
|
||||
</div>
|
||||
<div class="category-wrapper">
|
||||
{{ form.category.errors }}
|
||||
<label for="{{ form.category.id_for_lable }}">Kategorie:</label>
|
||||
{{ form.category }}
|
||||
</div>
|
||||
<div class="img-wrapper">
|
||||
{{ form.img.errors }}
|
||||
<label for="{{ form.img.id_for_lable }}">Bild:</label>
|
||||
|
|
@ -32,8 +37,10 @@
|
|||
<label for="{{ form.description.id_for_lable }}">Beschreibung:</label>
|
||||
{{ form.description }}
|
||||
</div>
|
||||
|
||||
<button type="submit" class="save btn btn-primary">inventarisieren</button>
|
||||
<div class="btnwrapper">
|
||||
<button type="submit" class="save btn btn-primary">inventarisieren</button>
|
||||
<a href="./kategorie" class="newcatlink">Neue Kategorie hinzufügen</a>
|
||||
</div>
|
||||
</form>
|
||||
</div>
|
||||
</body>
|
||||
|
|
|
|||
29
invsystem/user_manager/templates/object_lister/index.html
Normal file
29
invsystem/user_manager/templates/object_lister/index.html
Normal file
|
|
@ -0,0 +1,29 @@
|
|||
{% extends 'bases/navbar.html' %}
|
||||
<html>
|
||||
{% block content %}
|
||||
|
||||
<body>
|
||||
<div class="container shadow">
|
||||
<table class="objecttable">
|
||||
<tr class="objecttable-row">
|
||||
<th class="objecttable-head">Name</th>
|
||||
<th class="objecttable-head">Anzahl</th>
|
||||
<th class="objecttable-head">Kategorie</th>
|
||||
<th class="objecttable-head">Inventarisierungsdatum</th>
|
||||
<th class="objecttable-head">Hinzugefügt von</th>
|
||||
</tr>
|
||||
{% for object in objects %}
|
||||
<tr class="objecttable-row">
|
||||
<td class="objecttable-data">{{ object.title }}</td>
|
||||
<td class="objecttable-data">{{ object.ammout }}</td>
|
||||
<td class="objecttable-data">{{ object.category }}</td>
|
||||
<td class="objecttable-data">{{ object.inventarized_date }}</td>
|
||||
<td class="objecttable-data">{{ object.user_added }}</td>
|
||||
</tr>
|
||||
{% endfor %}
|
||||
</table>
|
||||
</div>
|
||||
</body>
|
||||
{% endblock %}
|
||||
|
||||
</html>
|
||||
Loading…
Add table
Add a link
Reference in a new issue