2021-07-30 20:52:18 +02:00
|
|
|
from django.shortcuts import render, redirect
|
|
|
|
from django.urls import resolve, reverse
|
2021-08-07 17:37:36 +02:00
|
|
|
from django.contrib.auth import logout, login
|
2021-10-24 21:14:11 +02:00
|
|
|
from django.contrib.auth.models import User
|
2021-07-30 20:52:18 +02:00
|
|
|
from django.http import HttpResponse
|
|
|
|
from .navbar import NavBar
|
2021-08-07 17:37:36 +02:00
|
|
|
from django.contrib.auth.forms import AuthenticationForm as AuthForm
|
2021-11-09 14:50:57 +01:00
|
|
|
from django.contrib.auth.forms import PasswordChangeForm
|
|
|
|
from django.contrib.auth import update_session_auth_hash
|
2021-08-07 17:37:36 +02:00
|
|
|
from django.views import View
|
|
|
|
import django.forms as forms
|
|
|
|
from django.views.generic import TemplateView, DetailView
|
|
|
|
from django.contrib.auth.mixins import LoginRequiredMixin, PermissionRequiredMixin
|
2021-11-09 16:35:11 +01:00
|
|
|
from .models import Storage, Stock, Component, Distributor, Manufacturer, Package
|
2021-08-07 17:37:36 +02:00
|
|
|
from .qr_parser import QrCodeValidator
|
2021-08-14 00:25:19 +02:00
|
|
|
from django.core.paginator import Paginator
|
2021-10-24 21:14:11 +02:00
|
|
|
from django.core.exceptions import ValidationError
|
2021-11-11 20:51:02 +01:00
|
|
|
from django.db import IntegrityError
|
2021-11-10 19:38:39 +01:00
|
|
|
from .forms import MyTestForm, AddSubStorageForm, DeleteStockForm, EditWatermarkForm, EditStockAmountForm, AddStockForm, EditComponentForm
|
2021-10-31 20:57:28 +01:00
|
|
|
from django.db.models import Q
|
2021-11-01 22:17:20 +01:00
|
|
|
from django.db.models.functions import Lower
|
2021-10-31 20:57:28 +01:00
|
|
|
import uuid
|
2021-08-07 17:37:36 +02:00
|
|
|
|
|
|
|
class QrSearchForm(forms.Form):
|
|
|
|
my_qr_validator = QrCodeValidator()
|
|
|
|
|
|
|
|
def __init__(self, *args, **kwargs):
|
|
|
|
super().__init__(*args, **kwargs)
|
|
|
|
|
|
|
|
|
|
|
|
qr_search = forms.CharField(label='qr_search', validators=[my_qr_validator])
|
|
|
|
|
|
|
|
class BaseTemplateMixin(object):
|
|
|
|
navbar_selected = ''
|
|
|
|
base_title = ''
|
|
|
|
|
|
|
|
def get_context_data(self, **kwargs):
|
|
|
|
context = super().get_context_data(**kwargs)
|
|
|
|
base_context = {
|
|
|
|
'navbar': NavBar.get_navbar(self.navbar_selected, self.request.user),
|
|
|
|
'title': NavBar.get_brand()+' / '+ self.base_title,
|
|
|
|
'login_active': False,
|
|
|
|
}
|
|
|
|
context['base'] = base_context
|
|
|
|
return context
|
2021-07-30 20:52:18 +02:00
|
|
|
|
2021-08-07 17:37:36 +02:00
|
|
|
def post(self, request, *args, **kwargs):
|
|
|
|
data = request.POST
|
|
|
|
if 'qr_search' not in data:
|
|
|
|
super().post(request, *args, **kwargs)
|
2021-07-30 20:52:18 +02:00
|
|
|
|
2021-08-07 17:37:36 +02:00
|
|
|
print('QR',data['qr_search'])
|
|
|
|
f = QrSearchForm(data)
|
|
|
|
if f.is_valid():
|
|
|
|
return redirect(f.my_qr_validator.get_redirect_url(f.cleaned_data['qr_search']))
|
2021-07-30 20:52:18 +02:00
|
|
|
|
2021-08-07 17:37:36 +02:00
|
|
|
return self.get(request)
|
|
|
|
|
2021-11-09 14:50:57 +01:00
|
|
|
class ChangePasswordView(LoginRequiredMixin, BaseTemplateMixin, TemplateView):
|
|
|
|
template_name = 'parts/change-pw.html'
|
|
|
|
navbar_selected = 'Main'
|
|
|
|
base_title = 'Change Password'
|
|
|
|
|
|
|
|
def get_context_data(self, **kwargs):
|
|
|
|
context = super().get_context_data(**kwargs)
|
|
|
|
context['form'] = PasswordChangeForm(self.request.user)
|
|
|
|
return context
|
|
|
|
|
|
|
|
def post(self, request, *args, **kwargs):
|
|
|
|
if 'submit-change-pw' not in request.POST:
|
|
|
|
return super().post(request, *args, **kwargs)
|
|
|
|
|
|
|
|
form = PasswordChangeForm(request.user, data=request.POST)
|
|
|
|
|
|
|
|
if form.is_valid():
|
|
|
|
user = form.save()
|
|
|
|
update_session_auth_hash(request, user)
|
|
|
|
return redirect('parts-main')
|
|
|
|
else:
|
|
|
|
pass
|
|
|
|
|
|
|
|
context = self.get_context_data(**kwargs)
|
|
|
|
if form.errors:
|
|
|
|
context['form'] = form
|
|
|
|
|
|
|
|
return self.render_to_response(context)
|
|
|
|
|
|
|
|
|
2021-08-07 17:37:36 +02:00
|
|
|
class MainView(BaseTemplateMixin, TemplateView):
|
|
|
|
template_name = 'parts/main.html'
|
|
|
|
navbar_selected = 'Main'
|
|
|
|
base_title = 'Main'
|
|
|
|
|
|
|
|
def logout_view(request):
|
|
|
|
logout(request)
|
|
|
|
return redirect('parts-main')
|
|
|
|
|
|
|
|
def login_view(request):
|
2021-07-30 20:52:18 +02:00
|
|
|
base_context = {
|
2021-08-07 17:37:36 +02:00
|
|
|
'navbar': NavBar.get_navbar('Login', request.user),
|
|
|
|
'title': NavBar.get_brand()+' / '+'Login',
|
|
|
|
'login_active': True,
|
2021-07-30 20:52:18 +02:00
|
|
|
}
|
2021-08-07 17:37:36 +02:00
|
|
|
|
|
|
|
if request.user.is_authenticated:
|
|
|
|
next_param = request.GET.get('next')
|
|
|
|
if next_param is not None:
|
|
|
|
return redirect(next_param)
|
|
|
|
else:
|
|
|
|
return redirect('parts-main')
|
|
|
|
|
|
|
|
if request.method == 'POST':
|
|
|
|
form = AuthForm(data=request.POST)
|
|
|
|
if form.is_valid():
|
|
|
|
valid_user = form.get_user()
|
|
|
|
login(request, valid_user)
|
|
|
|
next_param = request.GET.get('next')
|
|
|
|
if next_param is not None:
|
|
|
|
return redirect(next_param)
|
|
|
|
else:
|
|
|
|
return redirect('parts-main')
|
|
|
|
else:
|
|
|
|
form = AuthForm()
|
|
|
|
|
|
|
|
|
2021-07-30 20:52:18 +02:00
|
|
|
context = {
|
|
|
|
'base': base_context,
|
2021-08-07 17:37:36 +02:00
|
|
|
'form': form,
|
2021-07-30 20:52:18 +02:00
|
|
|
}
|
2021-08-07 17:37:36 +02:00
|
|
|
|
|
|
|
return render(request, 'parts/login.html', context)
|
2021-07-30 20:52:18 +02:00
|
|
|
|
|
|
|
# Create your views here.
|
2021-08-07 17:37:36 +02:00
|
|
|
|
|
|
|
class ComponentView(LoginRequiredMixin, BaseTemplateMixin, TemplateView):
|
|
|
|
template_name = 'parts/components.html'
|
|
|
|
base_title = 'Components'
|
|
|
|
navbar_selected = 'Components'
|
2021-11-09 16:35:11 +01:00
|
|
|
default_page_size = 10
|
|
|
|
|
|
|
|
|
|
|
|
def get_context_data(self, **kwargs):
|
|
|
|
context = super().get_context_data(**kwargs)
|
|
|
|
|
|
|
|
comp_page_num = self.request.GET.get('comp_page', default=1)
|
|
|
|
pkg_page_num = self.request.GET.get('pkg_page', default= 1)
|
|
|
|
|
|
|
|
comp_paginator = Paginator(Component.objects.all(), self.default_page_size)
|
|
|
|
pkg_paginator = Paginator(Package.objects.all(), self.default_page_size)
|
|
|
|
|
|
|
|
context['components'] = comp_paginator.get_page(comp_page_num)
|
|
|
|
context['packages'] = pkg_paginator.get_page(pkg_page_num)
|
|
|
|
return context
|
|
|
|
|
2021-08-07 17:37:36 +02:00
|
|
|
|
|
|
|
class StockView(LoginRequiredMixin, BaseTemplateMixin, TemplateView):
|
|
|
|
template_name = 'parts/stocks.html'
|
|
|
|
base_title = 'Stocks'
|
|
|
|
navbar_selected = 'Stocks'
|
2021-08-14 00:25:19 +02:00
|
|
|
default_pagination_size = 25
|
2021-08-07 17:37:36 +02:00
|
|
|
|
|
|
|
def get_context_data(self, **kwargs):
|
|
|
|
context = super().get_context_data(**kwargs)
|
2021-08-14 00:25:19 +02:00
|
|
|
|
|
|
|
storage_page = self.request.GET.get('storage_page')
|
|
|
|
if storage_page is None:
|
|
|
|
storage_page = 1
|
|
|
|
low_stock_page = self.request.GET.get('low_stock_page')
|
|
|
|
if low_stock_page is None:
|
|
|
|
low_stock_page = 1
|
|
|
|
|
|
|
|
storage_paginator = Paginator(Storage.objects.filter(parent_storage=None), self.default_pagination_size)
|
|
|
|
low_stock_paginator = Paginator(Stock.get_under_watermark(),
|
|
|
|
self.default_pagination_size)
|
|
|
|
|
|
|
|
context['low_stocks'] = low_stock_paginator.get_page(low_stock_page)
|
|
|
|
context['storages'] = storage_paginator.get_page(storage_page)
|
2021-10-25 19:31:50 +02:00
|
|
|
add_stor_form = AddSubStorageForm()
|
|
|
|
add_stor_form.fields['responsible'].initial = self.request.user.username
|
|
|
|
context['add_storage_form'] = add_stor_form
|
2021-08-07 17:37:36 +02:00
|
|
|
return context
|
2021-10-25 19:31:50 +02:00
|
|
|
|
|
|
|
def handle_add_storage(self, request, **kwargs):
|
|
|
|
return_invalid_form = False
|
|
|
|
|
|
|
|
f = AddSubStorageForm(data=request.POST)
|
|
|
|
if f.is_valid():
|
|
|
|
new_storage_name = f.cleaned_data['storage_name']
|
|
|
|
try:
|
|
|
|
resp_user = User.objects.get(username=f.cleaned_data['responsible'])
|
|
|
|
except Exception as _:
|
|
|
|
resp_user = None
|
|
|
|
f.add_error('responsible', 'Invalid Responsible User')
|
|
|
|
return_invalid_form = True
|
|
|
|
|
|
|
|
if resp_user is not None:
|
|
|
|
try:
|
|
|
|
Storage.objects.create(name=new_storage_name, responsible=resp_user, parent_storage=None)
|
|
|
|
except ValidationError as verr:
|
|
|
|
return_invalid_form = True
|
|
|
|
f.add_error('storage_name', ' .'.join(verr.messages))
|
|
|
|
else:
|
|
|
|
return_invalid_form = True
|
|
|
|
|
|
|
|
context = self.get_context_data(**kwargs)
|
|
|
|
if return_invalid_form:
|
|
|
|
context['add_storage_form'] = f
|
|
|
|
|
|
|
|
return self.render_to_response(context)
|
2021-08-07 17:37:36 +02:00
|
|
|
|
2021-10-25 19:31:50 +02:00
|
|
|
def post(self, request, **kwargs):
|
|
|
|
if 'submit-add-storage' in request.POST:
|
|
|
|
return self.handle_add_storage(request, **kwargs)
|
2021-10-24 21:14:11 +02:00
|
|
|
|
2021-10-25 19:31:50 +02:00
|
|
|
return super().post(request, **kwargs)
|
|
|
|
|
2021-08-07 17:37:36 +02:00
|
|
|
class StockViewDetail(LoginRequiredMixin, BaseTemplateMixin, DetailView):
|
|
|
|
template_name = 'parts/stocks-detail.html'
|
|
|
|
model = Storage
|
|
|
|
pk_url_kwarg = 'uuid'
|
|
|
|
base_title = ''
|
|
|
|
navbar_selected = 'Stocks'
|
2021-08-14 00:25:19 +02:00
|
|
|
default_pagination_size = 8
|
2021-08-07 17:37:36 +02:00
|
|
|
|
|
|
|
def get_breadcrumbs(self):
|
|
|
|
crumbs = self.object.get_path_components()
|
|
|
|
# Reverse list and drop the last element of the reversed list
|
|
|
|
crumbs = crumbs[::-1][:-1]
|
|
|
|
return crumbs
|
|
|
|
|
2021-10-31 20:57:28 +01:00
|
|
|
def search_stock_queryset(self, search):
|
2021-11-01 22:17:20 +01:00
|
|
|
stocks_in_storage = Stock.objects.filter(storage=self.object).order_by(Lower('component__name'))
|
2021-10-31 20:57:28 +01:00
|
|
|
|
|
|
|
if search is None or search == '':
|
|
|
|
return stocks_in_storage
|
|
|
|
|
2021-11-10 19:38:39 +01:00
|
|
|
if search.startswith('[comp_uuid]'):
|
|
|
|
search = search.replace('[comp_uuid]', '')
|
|
|
|
|
|
|
|
|
2021-10-31 20:57:28 +01:00
|
|
|
# Check if the searhc equals a UUID
|
|
|
|
test_uuid = None
|
|
|
|
try:
|
|
|
|
test_uuid = uuid.UUID(search)
|
|
|
|
except:
|
|
|
|
pass
|
|
|
|
|
|
|
|
if test_uuid is not None:
|
2021-11-01 22:17:20 +01:00
|
|
|
stocks_in_storage = stocks_in_storage.filter(Q(component__id = test_uuid) | Q(id= test_uuid))
|
2021-10-31 20:57:28 +01:00
|
|
|
else:
|
|
|
|
stocks_in_storage = stocks_in_storage.filter(Q(component__name__contains = search) |
|
2021-11-01 22:17:20 +01:00
|
|
|
Q(component__package__name__contains = search) |
|
|
|
|
Q(component__manufacturer__name__contains = search))
|
2021-10-31 20:57:28 +01:00
|
|
|
|
|
|
|
return stocks_in_storage
|
|
|
|
|
2021-08-07 17:37:36 +02:00
|
|
|
def get_context_data(self, **kwargs):
|
|
|
|
self.base_title = 'Stocks / ' + self.object.name
|
|
|
|
context = super().get_context_data(**kwargs)
|
|
|
|
context['breadcrumbs'] = self.get_breadcrumbs()
|
2021-08-14 00:25:19 +02:00
|
|
|
|
2021-10-31 20:57:28 +01:00
|
|
|
storage_page = self.request.GET.get('storage_page', default=1)
|
2021-08-14 00:25:19 +02:00
|
|
|
storage_paginator = Paginator(Storage.objects.filter(parent_storage=self.object), self.default_pagination_size)
|
2021-10-31 20:57:28 +01:00
|
|
|
stock_search_input = self.request.GET.get('search')
|
|
|
|
|
|
|
|
componente_stock_page = self.request.GET.get('stock_page', default=1)
|
|
|
|
|
|
|
|
|
|
|
|
stock_paginator = Paginator(self.search_stock_queryset(stock_search_input), self.default_pagination_size)
|
2021-08-14 00:25:19 +02:00
|
|
|
|
|
|
|
context['storages'] = storage_paginator.get_page(storage_page)
|
2021-11-01 22:17:20 +01:00
|
|
|
stocks = stock_paginator.get_page(componente_stock_page)
|
|
|
|
context['stocks'] = stocks
|
2021-10-31 20:57:28 +01:00
|
|
|
context['stock_search'] = stock_search_input
|
2021-10-24 21:14:11 +02:00
|
|
|
add_storage_form = AddSubStorageForm()
|
|
|
|
add_storage_form.fields['responsible'].initial = self.request.user.username
|
|
|
|
context['add_storage_form'] = add_storage_form
|
2021-10-25 19:31:50 +02:00
|
|
|
context['delete_storage_error'] = None
|
2021-11-08 23:11:05 +01:00
|
|
|
context['add_stock_form'] = AddStockForm()
|
2021-11-01 22:17:20 +01:00
|
|
|
|
2021-08-07 17:37:36 +02:00
|
|
|
return context
|
2021-08-14 02:35:09 +02:00
|
|
|
|
2021-10-24 21:14:11 +02:00
|
|
|
def handle_add_storage_post(self, request, **kwargs):
|
|
|
|
f = AddSubStorageForm(data=request.POST)
|
|
|
|
if f.is_valid():
|
|
|
|
sub_name = f.cleaned_data['storage_name']
|
|
|
|
try:
|
|
|
|
user = User.objects.get(username=f.cleaned_data['responsible'])
|
|
|
|
try:
|
|
|
|
Storage.objects.create(name=sub_name, parent_storage=self.object, responsible=user)
|
|
|
|
except ValidationError as v_err:
|
|
|
|
f.add_error('storage_name', '. '.join(v_err.messages))
|
|
|
|
except:
|
|
|
|
f.add_error('responsible', 'Invalid user')
|
|
|
|
context = self.get_context_data(**kwargs)
|
|
|
|
context['add_storage_form'] = f
|
|
|
|
return self.render_to_response(context)
|
|
|
|
|
2021-10-25 19:31:50 +02:00
|
|
|
def handle_del_storage_post(self, request, **kwargs):
|
|
|
|
parent = self.object.parent_storage
|
|
|
|
try:
|
|
|
|
self.object.delete()
|
|
|
|
except:
|
|
|
|
context = self.get_context_data(**kwargs)
|
|
|
|
context['delete_storage_errors'] = ['Error deleting Storage '+str(self.object)]
|
|
|
|
return self.render_to_response(context)
|
|
|
|
|
|
|
|
if parent is None:
|
|
|
|
return redirect('parts-stocks')
|
|
|
|
else:
|
|
|
|
return redirect(reverse('parts-stocks-detail', kwargs={'uuid':parent.id}))
|
2021-11-01 22:17:20 +01:00
|
|
|
def handle_del_stock_post(self, request, **kwargs):
|
|
|
|
del_error = None
|
|
|
|
if 'stock_uuid' in request.POST:
|
|
|
|
f = DeleteStockForm(data=request.POST)
|
|
|
|
if f.is_valid():
|
|
|
|
try:
|
|
|
|
s = Stock.objects.get(id=f.cleaned_data['stock_uuid'])
|
|
|
|
print(s.storage)
|
|
|
|
print(self.object)
|
|
|
|
if s.storage == self.object:
|
|
|
|
s.delete()
|
|
|
|
else:
|
|
|
|
del_error = 'Cannot delete stock from another storage.'
|
|
|
|
except:
|
|
|
|
del_error = 'Could not find requested stock in this storage.'
|
|
|
|
|
|
|
|
context = self.get_context_data(**kwargs)
|
|
|
|
return self.render_to_response(context)
|
|
|
|
|
2021-11-07 20:36:12 +01:00
|
|
|
def handle_update_watermark(self, request, **kwargs):
|
|
|
|
edit_form = EditWatermarkForm(data=request.POST)
|
|
|
|
update_watermark_error = None
|
|
|
|
if edit_form.is_valid():
|
|
|
|
edit_form.save()
|
|
|
|
else:
|
|
|
|
pass # Todo: Handle error
|
|
|
|
|
|
|
|
context = self.get_context_data(**kwargs)
|
|
|
|
return self.render_to_response(context)
|
|
|
|
|
|
|
|
def handle_amount_change_post(self, request, increase, **kwargs):
|
|
|
|
edit_form = EditStockAmountForm(data=request.POST)
|
|
|
|
if edit_form.is_valid():
|
|
|
|
edit_form.save(increase)
|
|
|
|
|
|
|
|
context = self.get_context_data(**kwargs)
|
|
|
|
return self.render_to_response(context)
|
2021-10-25 19:31:50 +02:00
|
|
|
|
2021-11-08 23:11:05 +01:00
|
|
|
def handle_add_stock_post(self, request, **kwargs):
|
|
|
|
f = AddStockForm(data=request.POST)
|
|
|
|
error_occured = False
|
|
|
|
|
|
|
|
if f.is_valid():
|
|
|
|
try:
|
|
|
|
f.save(self.object)
|
|
|
|
except Exception as ex:
|
|
|
|
f.add_error('', str(ex))
|
|
|
|
error_occured = True
|
|
|
|
else:
|
|
|
|
error_occured = True
|
|
|
|
|
|
|
|
context = self.get_context_data(**kwargs)
|
|
|
|
if error_occured:
|
|
|
|
context['add_stock_form'] = f
|
|
|
|
return self.render_to_response(context)
|
|
|
|
|
2021-10-24 21:14:11 +02:00
|
|
|
def post(self, request, *args, **kwargs):
|
|
|
|
self.object = self.get_object()
|
|
|
|
|
|
|
|
if 'submit-add-storage' in request.POST:
|
2021-10-25 19:31:50 +02:00
|
|
|
return self.handle_add_storage_post(request, **kwargs)
|
|
|
|
elif 'submit-delete-storage' in request.POST:
|
|
|
|
return self.handle_del_storage_post(request, **kwargs)
|
2021-11-01 22:17:20 +01:00
|
|
|
elif 'submit-delete-stock' in request.POST:
|
|
|
|
return self.handle_del_stock_post(request, **kwargs)
|
2021-11-07 20:36:12 +01:00
|
|
|
elif 'submit-edit-watermark' in request.POST:
|
|
|
|
return self.handle_update_watermark(request, **kwargs)
|
|
|
|
elif 'submit-amount-reduce' in request.POST:
|
|
|
|
return self.handle_amount_change_post(request, False, **kwargs)
|
|
|
|
elif 'submit-amount-increase' in request.POST:
|
|
|
|
return self.handle_amount_change_post(request, True, **kwargs)
|
2021-11-08 23:11:05 +01:00
|
|
|
elif 'submit-add-stock' in request.POST:
|
|
|
|
return self.handle_add_stock_post(request, **kwargs)
|
|
|
|
|
2021-11-09 16:35:11 +01:00
|
|
|
return super().post(request, *args, **kwargs)
|
|
|
|
|
|
|
|
class ComponentDetailView(LoginRequiredMixin, BaseTemplateMixin, DetailView):
|
|
|
|
template_name = 'parts/components-detail.html'
|
|
|
|
model = Component
|
|
|
|
pk_url_kwarg = 'uuid'
|
|
|
|
base_title = ''
|
|
|
|
navbar_selected = 'Components'
|
|
|
|
|
|
|
|
def get_context_data(self, **kwargs):
|
|
|
|
self.base_title = 'Component / '+self.object.name
|
|
|
|
context = super().get_context_data(**kwargs)
|
|
|
|
context['component'] = self.object
|
2021-11-10 19:38:39 +01:00
|
|
|
context['edit_form'] = EditComponentForm(instance=self.object)
|
|
|
|
return context
|
2021-11-09 16:35:11 +01:00
|
|
|
|
2021-11-10 19:38:39 +01:00
|
|
|
def handle_submit_edit_post(self, request, **kwargs):
|
|
|
|
form_error = False
|
2021-11-09 18:44:28 +01:00
|
|
|
|
2021-11-10 19:38:39 +01:00
|
|
|
form = EditComponentForm(instance=self.object, data=request.POST, files=request.FILES)
|
|
|
|
if form.is_valid():
|
2021-11-11 20:51:02 +01:00
|
|
|
try:
|
|
|
|
form.save()
|
|
|
|
except IntegrityError as ie:
|
|
|
|
form.add_error('name', 'Component name, package, and manufacturer are not unique!')
|
|
|
|
form.add_error('package', 'Component name, package, and manufacturer are not unique!')
|
|
|
|
form.add_error('manufacturer', 'Component name, package, and manufacturer are not unique!')
|
|
|
|
form_error = True
|
|
|
|
self.object = self.get_object()
|
2021-11-10 19:38:39 +01:00
|
|
|
else:
|
|
|
|
form_error = True
|
2021-11-09 16:35:11 +01:00
|
|
|
|
2021-11-10 19:38:39 +01:00
|
|
|
context = self.get_context_data(**kwargs)
|
|
|
|
if form_error:
|
|
|
|
context['edit_form'] = form
|
|
|
|
return self.render_to_response(context)
|
|
|
|
|
|
|
|
def post(self, request, *args, **kwargs):
|
|
|
|
self.object = self.get_object()
|
|
|
|
if 'submit-edit-comp' in request.POST:
|
|
|
|
return self.handle_submit_edit_post(request, **kwargs)
|
|
|
|
|
|
|
|
super().post(request, *args, **kwargs)
|
2021-11-09 18:44:28 +01:00
|
|
|
|
|
|
|
class PackageDetailView(LoginRequiredMixin, BaseTemplateMixin, DetailView):
|
|
|
|
template_name = 'parts/packages-detail.html'
|
|
|
|
model = Package
|
|
|
|
pk_url_kwarg = 'uuid'
|
|
|
|
base_title = ''
|
|
|
|
navbar_selected = 'Components'
|
2021-11-09 16:35:11 +01:00
|
|
|
|
2021-11-09 18:44:28 +01:00
|
|
|
def get_context_data(self, **kwargs):
|
|
|
|
self.base_title = 'Package / '+self.object.name
|
|
|
|
context = super().get_context_data(**kwargs)
|
|
|
|
context['package'] = self.object
|
|
|
|
|
|
|
|
return context
|