fixed crud list
fixed payments upload -a
This commit is contained in:
+26
-7
@@ -1,4 +1,4 @@
|
||||
from django.forms import ModelForm
|
||||
from django.forms import ModelForm, TextInput
|
||||
|
||||
from containers.models import Container
|
||||
|
||||
@@ -7,7 +7,12 @@ class ContainerBaseForm(ModelForm):
|
||||
class Meta:
|
||||
model = Container
|
||||
fields = '__all__'
|
||||
|
||||
widgets = {
|
||||
'number': TextInput(attrs={
|
||||
'oninput': 'validateContainerNumber(this)',
|
||||
'class': 'form-control'
|
||||
})
|
||||
}
|
||||
class ContainerReceiveForm(ContainerBaseForm):
|
||||
"""
|
||||
Form for creating a new Container instance.
|
||||
@@ -16,14 +21,28 @@ class ContainerReceiveForm(ContainerBaseForm):
|
||||
class Meta(ContainerBaseForm.Meta):
|
||||
fields = ['number', 'receive_vehicle', 'damages', 'heavy_damaged', 'position',]
|
||||
|
||||
def __init__(self, *args, preinfo=None, **kwargs):
|
||||
super().__init__(*args, **kwargs)
|
||||
|
||||
# Add form-control class to all fields
|
||||
for field in self.fields.values():
|
||||
field.widget.attrs.update({'class': 'form-control'})
|
||||
|
||||
# Checkbox specific styling
|
||||
self.fields['heavy_damaged'].widget.attrs.update({'class': 'form-check-input'})
|
||||
|
||||
# If preinfo is provided, set initial values and make fields readonly
|
||||
if preinfo:
|
||||
...
|
||||
# self.fields['preinfo'].initial = preinfo.container_number
|
||||
# self.fields['number'].initial = preinfo.number
|
||||
# self.fields['container_number'].widget.attrs['readonly'] = True
|
||||
# self.fields['number'].widget.attrs['readonly'] = True
|
||||
# self.fields['booking'].disabled = True
|
||||
# self.fields['number'].disabled = True
|
||||
|
||||
|
||||
class ContainerExpeditionForm(ContainerBaseForm):
|
||||
"""
|
||||
Form for updating an existing Container instance.
|
||||
Inherits from ContainerBaseForm.
|
||||
"""
|
||||
class Meta(ContainerBaseForm.Meta):
|
||||
fields = ['number', 'expedition_vehicle', 'position', 'line', 'container_type', 'damages', 'heavy_damaged']
|
||||
|
||||
@@ -32,4 +51,4 @@ class ContainerExpeditionForm(ContainerBaseForm):
|
||||
readonly_fields = ['number', 'position', 'line', 'container_type', 'damages', 'heavy_damaged']
|
||||
for field in readonly_fields:
|
||||
self.fields[field].widget.attrs['readonly'] = True
|
||||
self.fields[field].disabled = True
|
||||
# self.fields[field].disabled = True
|
||||
@@ -1,5 +1,7 @@
|
||||
|
||||
from django.db import models
|
||||
from common.models import LinesModel, ContainerTypeModel
|
||||
# from payments.models import ContainerTariffPeriod, AdditionalFees
|
||||
|
||||
# Create your models here.
|
||||
class Container(models.Model):
|
||||
@@ -42,6 +44,11 @@ class Container(models.Model):
|
||||
blank=True,
|
||||
null=True
|
||||
)
|
||||
preinfo = models.ForeignKey(
|
||||
'preinfo.Preinfo',
|
||||
on_delete=models.CASCADE,
|
||||
related_name='container_preinfo',
|
||||
)
|
||||
booking = models.ForeignKey(
|
||||
'booking.Booking',
|
||||
on_delete=models.CASCADE,
|
||||
@@ -61,6 +68,7 @@ class Container(models.Model):
|
||||
expedition_vehicle = models.CharField(max_length=100, blank=True, null=True)
|
||||
|
||||
|
||||
|
||||
class ContainerHistory(Container):
|
||||
operation = models.ForeignKey(
|
||||
'common.OperationModel',
|
||||
|
||||
@@ -1,11 +1,11 @@
|
||||
from booking.models import Booking
|
||||
from containers.models import Container
|
||||
|
||||
def get_container_for_booking(booking_number):
|
||||
def get_container_for_booking(booking):
|
||||
filters = {
|
||||
'expedited': False,
|
||||
}
|
||||
booking = Booking.objects.get(number=booking_number)
|
||||
# booking = Booking.objects.get(number=booking_number)
|
||||
if not booking:
|
||||
return None
|
||||
if booking.container_number:
|
||||
|
||||
+8
-4
@@ -1,14 +1,18 @@
|
||||
from django.urls import include, path
|
||||
|
||||
from containers.views.employee_views import ContainersListView, ReportContainersUnpaidListView
|
||||
from containers.views.barrier_views import ContainerReceive, ContainerExpedition, ContainerSearchView
|
||||
from containers.views.barrier_views import ContainerReceiveView, ContainerExpedition, ContainerSearchView, \
|
||||
ContainerPhotosView
|
||||
|
||||
urlpatterns = [
|
||||
path('search/', ContainerSearchView.as_view(), name='container_search'),
|
||||
path('container-search/', ContainerSearchView.as_view(), name='container_search'),
|
||||
path('container-search/', ContainerSearchView.as_view(), name='barrier_photos'),
|
||||
# path('search/', ContainerSearchView.as_view(), name='container_search'),
|
||||
path('employee/', ContainersListView.as_view(), name='employee_containers'),
|
||||
path('not-paid', ReportContainersUnpaidListView.as_view(), name='not_paid'),
|
||||
path('barrier/receive/', ContainerReceiveView.as_view(), name='container_receive'),
|
||||
path('barrier/expedition/', ContainerExpedition.as_view(), name='container_expedition'),
|
||||
path('barrier/<int:pk>/', include([
|
||||
path('receive/', ContainerReceive.as_view(), name='container_receive'),
|
||||
path('expedition/', ContainerExpedition.as_view(), name='container_expedition'),
|
||||
path('photos/', ContainerPhotosView.as_view(), name='container_photos'),
|
||||
])),
|
||||
]
|
||||
@@ -7,53 +7,69 @@ from django.views.generic import CreateView, UpdateView, FormView, ListView
|
||||
from booking.models import Booking
|
||||
from common.utils.utils import get_container_by_number
|
||||
from containers.forms import ContainerReceiveForm, ContainerExpeditionForm
|
||||
from containers.models import Container
|
||||
from containers.models import Container, ContainerPhotos
|
||||
from containers.services import get_container_for_booking
|
||||
from preinfo.models import Preinfo
|
||||
|
||||
|
||||
# Create your views here.
|
||||
class ContainerReceive(CreateView):
|
||||
class ContainerReceiveView(FormView):
|
||||
template_name = 'container-receive.html'
|
||||
model = Container
|
||||
form_class = ContainerReceiveForm
|
||||
success_url = reverse_lazy('dashboard')
|
||||
success_url = reverse_lazy('container_photos')
|
||||
|
||||
def get_context_data(self, **kwargs):
|
||||
context = super().get_context_data(**kwargs)
|
||||
pk = self.kwargs.get('pk')
|
||||
try:
|
||||
preinfo =Preinfo.objects.filter(pk=pk, received=False).first()
|
||||
except Preinfo.DoesNotExist:
|
||||
preinfo = None
|
||||
context['show_search'] = True
|
||||
|
||||
if preinfo:
|
||||
context['preinfo'] = preinfo
|
||||
context['containers'] = Container.objects.order_by('-received_on').all()[:10] # Fetch the last 10 containers
|
||||
return context
|
||||
return redirect(reverse_lazy('container_search'))
|
||||
search_number = self.request.GET.get('number')
|
||||
if search_number:
|
||||
preinfo = Preinfo.objects.filter(container_number=search_number).first()
|
||||
if preinfo:
|
||||
form = self.form_class(initial={'number': preinfo.container_number})
|
||||
context.update({
|
||||
'form': form,
|
||||
'preinfo': preinfo,
|
||||
'search_number': search_number,
|
||||
'show_search': False
|
||||
})
|
||||
else:
|
||||
context.update({
|
||||
'error': 'Preinfo for this container not found',
|
||||
'search_number': search_number
|
||||
})
|
||||
return context
|
||||
|
||||
def form_valid(self, form):
|
||||
container = form.save(commit=False)
|
||||
preinfo = Preinfo.objects.filter(container_number=self.request.POST.get('number')).first()
|
||||
preinfo.received = True
|
||||
preinfo.save()
|
||||
# Set required fields from preinfo
|
||||
container.container_type = preinfo.container_type
|
||||
container.line = preinfo.line
|
||||
container.received_by = self.request.user
|
||||
container.preinfo = preinfo
|
||||
container.save()
|
||||
|
||||
# Get the preinfo_id from the POST data
|
||||
preinfo_id = self.request.POST.get('preinfo_id')
|
||||
try:
|
||||
preinfo = Preinfo.objects.get(id=preinfo_id)
|
||||
except Preinfo.DoesNotExist:
|
||||
preinfo = None
|
||||
return redirect('container_photos', pk=container.pk)
|
||||
|
||||
# validate if data is correct, comparing user data with preinfo data
|
||||
if preinfo and preinfo.container_number == form.cleaned_data.get('number') and not preinfo.received:
|
||||
preinfo.received = True
|
||||
preinfo.save()
|
||||
def get_form(self, form_class=None):
|
||||
form = super().get_form(form_class)
|
||||
search_number = self.request.GET.get('number') # Changed from search_number
|
||||
if search_number:
|
||||
preinfo = Preinfo.objects.filter(container_number=search_number).first()
|
||||
if preinfo:
|
||||
form.initial['number'] = preinfo.container_number
|
||||
form.fields['number'].widget.readonly = True
|
||||
return form
|
||||
|
||||
form.instance.received_by = self.request.user
|
||||
form.instance.line = preinfo.line
|
||||
form.instance.container_type = preinfo.container_type
|
||||
else:
|
||||
form.add_error('number', 'Invalid data')
|
||||
|
||||
return super().form_valid(form)
|
||||
def form_invalid(self, form):
|
||||
return self.render_to_response(self.get_context_data(
|
||||
form=form,
|
||||
search_number=self.request.POST.get('number'),
|
||||
show_search=False
|
||||
))
|
||||
|
||||
|
||||
class ContainerSearchView(View):
|
||||
@@ -83,30 +99,131 @@ class ContainerSearchView(View):
|
||||
return redirect(next_url, pk=booking.pk)
|
||||
|
||||
|
||||
class ContainerExpedition(UpdateView):
|
||||
# class ContainerExpedition(UpdateView):
|
||||
# template_name = 'container-expedition.html'
|
||||
# model = Container
|
||||
# form_class = ContainerExpeditionForm
|
||||
# success_url = reverse_lazy('dashboard')
|
||||
#
|
||||
# def get_context_data(self, **kwargs):
|
||||
# context = super().get_context_data(**kwargs)
|
||||
# pk = self.kwargs.get('pk')
|
||||
# booking = Booking.objects.get(pk=pk)
|
||||
# filters = {
|
||||
# 'expedited': False,
|
||||
# }
|
||||
# if booking.container_number:
|
||||
# filters['container_number'] = booking.container_number
|
||||
# else:
|
||||
# filters['container_type'] = booking.container_type
|
||||
# filters['line'] = booking.line
|
||||
#
|
||||
# container = Container.objects.filter(**filters).order_by('received_on').first()
|
||||
# context['container'] = container
|
||||
# context['booking'] = booking
|
||||
# return context
|
||||
#
|
||||
# def form_valid(self, form):
|
||||
# booking_id = self.request.POST.get('booking_id')
|
||||
# container_id = self.request.POST.get('container_id')
|
||||
#
|
||||
# try:
|
||||
# booking = Booking.objects.get(id=booking_id)
|
||||
# container = Container.objects.get(id=container_id)
|
||||
# vehicle = form.cleaned_data['expedition_vehicle']
|
||||
# # Update container
|
||||
# container.expedited = True
|
||||
# container.expedited_on = timezone.now()
|
||||
# container.expedited_by = self.request.user
|
||||
# container.expedition_vehicle = vehicle
|
||||
# container.booking = booking
|
||||
# container.save()
|
||||
#
|
||||
# # Update booking status if needed
|
||||
# booking.container_expedited_count += 1
|
||||
# if booking.vehicles:
|
||||
# vehicles_list = booking.vehicles.split(',')
|
||||
# if vehicle in vehicles_list:
|
||||
# vehicles_list.remove(vehicle)
|
||||
# booking.vehicles = ','.join(vehicles_list)
|
||||
# if booking.container_expedited_count >= booking.container_count:
|
||||
# booking.status = 'completed' # or any other status you want to set
|
||||
# booking.save()
|
||||
#
|
||||
# return redirect(self.success_url)
|
||||
#
|
||||
# except (Booking.DoesNotExist, Container.DoesNotExist):
|
||||
# form.add_error(None, 'Invalid booking or container')
|
||||
# return self.form_invalid(form)
|
||||
#
|
||||
#
|
||||
# # try:
|
||||
# # booking = Booking.objects.get(id=booking_id)
|
||||
# # except Booking.DoesNotExist:
|
||||
# # booking = None
|
||||
# # # validate if data is correct, comparing user data with booking data
|
||||
# # if booking and booking.container_number == form.cleaned_data.get('container_number') and not booking.expedited:
|
||||
# # booking.expedited = True
|
||||
# # booking.save()
|
||||
# #
|
||||
# # form.instance.expedited_by = self.request.user
|
||||
# # form.instance.line = booking.line
|
||||
# # form.instance.container_type = booking.container_type
|
||||
# # else:
|
||||
# # form.add_error('container_number', 'Invalid data')
|
||||
#
|
||||
# # if preinfo:
|
||||
# # context['preinfo'] = preinfo
|
||||
# # context['containers'] = Container.objects.order_by('-received_on').all()[:10] # Fetch the last 10 containers
|
||||
# # return context
|
||||
# # return redirect(reverse_lazy('container_search'))
|
||||
|
||||
|
||||
class ContainerExpedition(FormView):
|
||||
template_name = 'container-expedition.html'
|
||||
model = Container
|
||||
form_class = ContainerExpeditionForm
|
||||
success_url = reverse_lazy('dashboard')
|
||||
success_url = reverse_lazy('barrier_dashboard')
|
||||
|
||||
def get_context_data(self, **kwargs):
|
||||
context = super().get_context_data(**kwargs)
|
||||
pk = self.kwargs.get('pk')
|
||||
booking = Booking.objects.get(pk=pk)
|
||||
filters = {
|
||||
'expedited': False,
|
||||
}
|
||||
if booking.container_number:
|
||||
filters['container_number'] = booking.container_number
|
||||
else:
|
||||
filters['container_type'] = booking.container_type
|
||||
filters['line'] = booking.line
|
||||
context['show_search'] = True
|
||||
|
||||
container = Container.objects.filter(**filters).order_by('received_on').first()
|
||||
context['container'] = container
|
||||
context['booking'] = booking
|
||||
search_number = self.request.GET.get('number')
|
||||
if search_number:
|
||||
booking = Booking.objects.filter(number=search_number).first()
|
||||
if booking:
|
||||
container = get_container_for_booking(booking)
|
||||
if container:
|
||||
# Initialize form with container data
|
||||
form = self.form_class(initial={
|
||||
'number': container.number,
|
||||
'position': container.position,
|
||||
'line': container.line.id,
|
||||
'container_type': container.container_type.id,
|
||||
'damages': container.damages,
|
||||
'heavy_damaged': container.heavy_damaged,
|
||||
'expedition_vehicle': container.expedition_vehicle
|
||||
})
|
||||
context.update({
|
||||
'form': form,
|
||||
'booking': booking,
|
||||
'container': container,
|
||||
'search_number': search_number,
|
||||
'show_search': False
|
||||
})
|
||||
else:
|
||||
context.update({
|
||||
'error': 'No available container found for this booking',
|
||||
'search_number': search_number
|
||||
})
|
||||
else:
|
||||
context.update({
|
||||
'error': 'Booking not found',
|
||||
'search_number': search_number
|
||||
})
|
||||
return context
|
||||
|
||||
|
||||
def form_valid(self, form):
|
||||
booking_id = self.request.POST.get('booking_id')
|
||||
container_id = self.request.POST.get('container_id')
|
||||
@@ -114,51 +231,74 @@ class ContainerExpedition(UpdateView):
|
||||
try:
|
||||
booking = Booking.objects.get(id=booking_id)
|
||||
container = Container.objects.get(id=container_id)
|
||||
vehicle = form.cleaned_data['expedition_vehicle']
|
||||
|
||||
# Update container
|
||||
container.expedited = True
|
||||
container.expedited_on = timezone.now()
|
||||
container.expedited_by = self.request.user
|
||||
container.expedition_vehicle = vehicle
|
||||
container.expedition_vehicle = form.cleaned_data['expedition_vehicle']
|
||||
container.booking = booking
|
||||
container.save()
|
||||
|
||||
# Update booking status if needed
|
||||
# Update booking
|
||||
booking.container_expedited_count += 1
|
||||
if booking.vehicles:
|
||||
vehicles_list = booking.vehicles.split(',')
|
||||
if vehicle in vehicles_list:
|
||||
vehicles_list.remove(vehicle)
|
||||
if container.expedition_vehicle in vehicles_list:
|
||||
vehicles_list.remove(container.expedition_vehicle)
|
||||
booking.vehicles = ','.join(vehicles_list)
|
||||
if booking.container_expedited_count >= booking.container_count:
|
||||
booking.status = 'completed' # or any other status you want to set
|
||||
booking.status = 'completed'
|
||||
booking.save()
|
||||
|
||||
return redirect(self.success_url)
|
||||
|
||||
except (Booking.DoesNotExist, Container.DoesNotExist):
|
||||
form.add_error(None, 'Invalid booking or container')
|
||||
return self.form_invalid(form)
|
||||
|
||||
def form_invalid(self, form):
|
||||
print("Form errors:", form.errors) # Debug print
|
||||
print("Form data:", form.data) # Debug print
|
||||
return self.render_to_response(self.get_context_data(
|
||||
form=form,
|
||||
search_number=self.request.POST.get('number'),
|
||||
show_search=False
|
||||
))
|
||||
|
||||
# try:
|
||||
# booking = Booking.objects.get(id=booking_id)
|
||||
# except Booking.DoesNotExist:
|
||||
# booking = None
|
||||
# # validate if data is correct, comparing user data with booking data
|
||||
# if booking and booking.container_number == form.cleaned_data.get('container_number') and not booking.expedited:
|
||||
# booking.expedited = True
|
||||
# booking.save()
|
||||
#
|
||||
# form.instance.expedited_by = self.request.user
|
||||
# form.instance.line = booking.line
|
||||
# form.instance.container_type = booking.container_type
|
||||
# else:
|
||||
# form.add_error('container_number', 'Invalid data')
|
||||
|
||||
# if preinfo:
|
||||
# context['preinfo'] = preinfo
|
||||
# context['containers'] = Container.objects.order_by('-received_on').all()[:10] # Fetch the last 10 containers
|
||||
# return context
|
||||
# return redirect(reverse_lazy('container_search'))
|
||||
def get_form(self, form_class=None):
|
||||
form_class = self.get_form_class()
|
||||
|
||||
if self.request.method == 'POST':
|
||||
search_number = self.request.POST.get('search_number')
|
||||
booking = Booking.objects.filter(number=search_number).first()
|
||||
if booking:
|
||||
container = get_container_for_booking(booking)
|
||||
if container:
|
||||
data = self.request.POST.copy()
|
||||
data.update({
|
||||
'number': container.number,
|
||||
'position': container.position,
|
||||
'line': container.line,
|
||||
'container_type': container.container_type,
|
||||
'damages': container.damages,
|
||||
'heavy_damaged': container.heavy_damaged,
|
||||
})
|
||||
return form_class(data)
|
||||
return form_class()
|
||||
|
||||
|
||||
|
||||
|
||||
# containers/views/barrier_views.py
|
||||
class ContainerPhotosView(View):
|
||||
template_name = 'container-photos.html'
|
||||
|
||||
def get(self, request, pk):
|
||||
container = Container.objects.get(pk=pk)
|
||||
photos = ContainerPhotos.objects.filter(container=container)
|
||||
return render(request, self.template_name, {
|
||||
'container': container,
|
||||
'photos': photos,
|
||||
'photos_count': photos.count()
|
||||
})
|
||||
@@ -1,6 +1,9 @@
|
||||
from django.shortcuts import render, redirect
|
||||
from django.views import View
|
||||
from django.views.generic import ListView
|
||||
|
||||
from common.models import CompanyModel
|
||||
from common.utils.utils import get_preinfo_by_number, get_container_by_number
|
||||
from containers.models import Container
|
||||
|
||||
|
||||
@@ -49,4 +52,30 @@ class ReportContainersUnpaidListView(ListView):
|
||||
# Add payment filter to show only unpaid containers
|
||||
queryset = queryset.filter(payment_containers__isnull=True)
|
||||
|
||||
return queryset.order_by('-expedited_on')
|
||||
return queryset.order_by('-expedited_on')
|
||||
|
||||
|
||||
class ContainerSearchView(View):
|
||||
template_name = 'barrier/container-search.html' # Single template for all searches
|
||||
|
||||
def get(self, request):
|
||||
search_type = request.GET.get('param') # container_receive or container_expedition
|
||||
return render(request, self.template_name, {'search_type': search_type})
|
||||
|
||||
def post(self, request):
|
||||
number = request.POST.get('number')
|
||||
search_type = request.POST.get('search_type')
|
||||
|
||||
if search_type == 'container_receive':
|
||||
preinfo = get_preinfo_by_number(number)
|
||||
if preinfo:
|
||||
return redirect('receive_container', pk=preinfo.pk)
|
||||
else: # container_expedition
|
||||
container = get_container_by_number(number)
|
||||
if container:
|
||||
return redirect('expedite_container', pk=container.pk)
|
||||
|
||||
return render(request, self.template_name, {
|
||||
'error': 'Not found',
|
||||
'search_type': search_type
|
||||
})
|
||||
Reference in New Issue
Block a user