StockItemCreate form now has better logic for auto-detecting the part

This commit is contained in:
Oliver Walters 2020-05-26 11:31:08 +10:00
parent 8384071ac3
commit ae4bfd07da

View File

@ -1036,6 +1036,37 @@ class StockItemCreate(AjaxCreateView):
ajax_template_name = 'modal_form.html' ajax_template_name = 'modal_form.html'
ajax_form_title = _('Create new Stock Item') ajax_form_title = _('Create new Stock Item')
def get_part(self, form=None):
"""
Attempt to get the "part" associted with this new stockitem.
- May be passed to the form as a query parameter (e.g. ?part=<id>)
- May be passed via the form field itself.
"""
# Try to extract from the URL query
part_id = self.request.GET.get('part', None)
if part_id:
try:
part = Part.objects.get(pk=part_id)
return part
except (Part.DoesNotExist, ValueError):
pass
# Try to get from the form
if form:
try:
part_id = form['part'].value()
part = Part.objects.get(pk=part_id)
return part
except (Part.DoesNotExist, ValueError):
pass
# Could not extract a part object
return None
def get_form(self): def get_form(self):
""" Get form for StockItem creation. """ Get form for StockItem creation.
Overrides the default get_form() method to intelligently limit Overrides the default get_form() method to intelligently limit
@ -1044,53 +1075,46 @@ class StockItemCreate(AjaxCreateView):
form = super().get_form() form = super().get_form()
part = None part = self.get_part(form=form)
# If the user has selected a Part, limit choices for SupplierPart if part is not None:
if form['part'].value(): sn = part.getNextSerialNumber()
part_id = form['part'].value() form.field_placeholder['serial_numbers'] = _('Next available serial number is') + ' ' + str(sn)
try: print("Placeholder:", sn)
part = Part.objects.get(id=part_id)
sn = part.getNextSerialNumber() form.rebuild_layout()
form.field_placeholder['serial_numbers'] = _('Next available serial number is') + ' ' + str(sn)
form.rebuild_layout() # Hide the 'part' field (as a valid part is selected)
form.fields['part'].widget = HiddenInput()
# Hide the 'part' field (as a valid part is selected) # trackable parts get special consideration
form.fields['part'].widget = HiddenInput() if part.trackable:
form.fields['delete_on_deplete'].widget = HiddenInput()
form.fields['delete_on_deplete'].initial = False
else:
form.fields.pop('serial_numbers')
# trackable parts get special consideration # If the part is NOT purchaseable, hide the supplier_part field
if part.trackable: if not part.purchaseable:
form.fields['delete_on_deplete'].widget = HiddenInput() form.fields['supplier_part'].widget = HiddenInput()
form.fields['delete_on_deplete'].initial = False else:
else: # Pre-select the allowable SupplierPart options
form.fields.pop('serial_numbers') parts = form.fields['supplier_part'].queryset
parts = parts.filter(part=part.id)
# If the part is NOT purchaseable, hide the supplier_part field form.fields['supplier_part'].queryset = parts
if not part.purchaseable:
form.fields['supplier_part'].widget = HiddenInput()
else:
# Pre-select the allowable SupplierPart options
parts = form.fields['supplier_part'].queryset
parts = parts.filter(part=part.id)
form.fields['supplier_part'].queryset = parts # If there is one (and only one) supplier part available, pre-select it
all_parts = parts.all()
# If there is one (and only one) supplier part available, pre-select it if len(all_parts) == 1:
all_parts = parts.all()
if len(all_parts) == 1: # TODO - This does NOT work for some reason? Ref build.views.BuildItemCreate
form.fields['supplier_part'].initial = all_parts[0].id
# TODO - This does NOT work for some reason? Ref build.views.BuildItemCreate
form.fields['supplier_part'].initial = all_parts[0].id
except Part.DoesNotExist:
pass
# Otherwise if the user has selected a SupplierPart, we know what Part they meant! # Otherwise if the user has selected a SupplierPart, we know what Part they meant!
elif form['supplier_part'].value() is not None: if form['supplier_part'].value() is not None:
pass pass
return form return form
@ -1113,27 +1137,20 @@ class StockItemCreate(AjaxCreateView):
else: else:
initials = super(StockItemCreate, self).get_initial().copy() initials = super(StockItemCreate, self).get_initial().copy()
part_id = self.request.GET.get('part', None) part = self.get_part()
loc_id = self.request.GET.get('location', None) loc_id = self.request.GET.get('location', None)
sup_part_id = self.request.GET.get('supplier_part', None) sup_part_id = self.request.GET.get('supplier_part', None)
part = None
location = None location = None
supplier_part = None supplier_part = None
# Part field has been specified if part is not None:
if part_id: # Check that the supplied part is 'valid'
try: if not part.is_template and part.active and not part.virtual:
part = Part.objects.get(pk=part_id) initials['part'] = part
initials['location'] = part.get_default_location()
# Check that the supplied part is 'valid' initials['supplier_part'] = part.default_supplier
if not part.is_template and part.active and not part.virtual:
initials['part'] = part
initials['location'] = part.get_default_location()
initials['supplier_part'] = part.default_supplier
except (ValueError, Part.DoesNotExist):
pass
# SupplierPart field has been specified # SupplierPart field has been specified
# It must match the Part, if that has been supplied # It must match the Part, if that has been supplied