Add function for required build order quantity

This commit is contained in:
Oliver Walters 2021-02-17 10:27:36 +11:00
parent d2c9f759b1
commit cda97829ab
2 changed files with 63 additions and 0 deletions

View File

@ -884,6 +884,62 @@ class Part(MPTTModel):
return max(total, 0) return max(total, 0)
def requiring_build_orders(self):
"""
Return list of outstanding build orders which require this part
"""
# List of BOM that this part is required for
boms = BomItem.objects.filter(sub_part=self)
part_ids = [bom.part.pk for bom in boms]
# Now, get a list of outstanding build orders which require this part
builds = BuildModels.Build.objects.filter(
part__in=part_ids,
status__in=BuildStatus.ACTIVE_CODES
)
return builds
def required_build_order_quantity(self):
"""
Return the quantity of this part required for active build orders
"""
# List of BOM that this part is required for
boms = BomItem.objects.filter(sub_part=self)
part_ids = [bom.part.pk for bom in boms]
# Now, get a list of outstanding build orders which require this part
builds = BuildModels.Build.objects.filter(
part__in=part_ids,
status__in=BuildStatus.ACTIVE_CODES
)
quantity = 0
for build in builds:
bom_item = None
# Match BOM item to build
for bom in boms:
if bom.part == build.part:
bom_item = bom
break
if bom_item is None:
logger.warning("Found null BomItem when calculating required quantity")
continue
build_quantity = build.quantity * bom_item.quantity
quantity += build_quantity
return quantity
@property @property
def quantity_to_order(self): def quantity_to_order(self):
""" Return the quantity needing to be ordered for this part. """ """ Return the quantity needing to be ordered for this part. """

View File

@ -127,6 +127,13 @@
<td>{% include "part/stock_count.html" %}</td> <td>{% include "part/stock_count.html" %}</td>
</tr> </tr>
{% if not part.is_template %} {% if not part.is_template %}
{% if part.required_build_order_quantity > 0 %}
<tr>
<td><span class='fas fa-hand-holding'></span></td>
<td>{% trans "Required for Build Orders" %}</td>
<td>{% decimal part.required_build_order_quantity %}</td>
</tr>
{% endif %}
{% if part.build_order_allocation_count > 0 %} {% if part.build_order_allocation_count > 0 %}
<tr> <tr>
<td><span class='fas fa-dolly'></span></td> <td><span class='fas fa-dolly'></span></td>