mirror of
				https://github.com/inventree/InvenTree.git
				synced 2025-10-24 18:07:38 +00:00 
			
		
		
		
	Include location detail in build output table (#8923)
* Include location detail in build output table * Raise validation error if trying to split an in-production item
This commit is contained in:
		| @@ -1985,9 +1985,18 @@ class StockItem( | ||||
|         Returns: | ||||
|             The new StockItem object | ||||
|  | ||||
|         Raises: | ||||
|             ValidationError: If the stock item cannot be split | ||||
|  | ||||
|         - The provided quantity will be subtracted from this item and given to the new one. | ||||
|         - The new item will have a different StockItem ID, while this will remain the same. | ||||
|         """ | ||||
|         # Run initial checks to test if the stock item can actually be "split" | ||||
|  | ||||
|         # Cannot split a stock item which is in production | ||||
|         if self.is_building: | ||||
|             raise ValidationError(_('Stock item is currently in production')) | ||||
|  | ||||
|         notes = kwargs.get('notes', '') | ||||
|  | ||||
|         # Do not split a serialized part | ||||
|   | ||||
| @@ -1565,18 +1565,18 @@ class StockAdjustmentItemSerializer(serializers.Serializer): | ||||
|         help_text=_('StockItem primary key value'), | ||||
|     ) | ||||
|  | ||||
|     def validate_pk(self, pk): | ||||
|     def validate_pk(self, stock_item: StockItem) -> StockItem: | ||||
|         """Ensure the stock item is valid.""" | ||||
|         allow_out_of_stock_transfer = get_global_setting( | ||||
|             'STOCK_ALLOW_OUT_OF_STOCK_TRANSFER', backup_value=False, cache=False | ||||
|         ) | ||||
|  | ||||
|         if not allow_out_of_stock_transfer and not pk.is_in_stock( | ||||
|         if not allow_out_of_stock_transfer and not stock_item.is_in_stock( | ||||
|             check_status=False, check_quantity=False | ||||
|         ): | ||||
|             raise ValidationError(_('Stock item is not in stock')) | ||||
|  | ||||
|         return pk | ||||
|         return stock_item | ||||
|  | ||||
|     quantity = serializers.DecimalField( | ||||
|         max_digits=15, decimal_places=5, min_value=Decimal(0), required=True | ||||
|   | ||||
| @@ -667,13 +667,15 @@ export default function StockDetail() { | ||||
|   }); | ||||
|  | ||||
|   const stockActions = useMemo(() => { | ||||
|     const inStock = | ||||
|     // Can this stock item be transferred to a different location? | ||||
|     const canTransfer = | ||||
|       user.hasChangeRole(UserRoles.stock) && | ||||
|       !stockitem.sales_order && | ||||
|       !stockitem.belongs_to && | ||||
|       !stockitem.customer && | ||||
|       !stockitem.consumed_by && | ||||
|       !stockitem.is_building; | ||||
|       !stockitem.consumed_by; | ||||
|  | ||||
|     const isBuilding = stockitem.is_building; | ||||
|  | ||||
|     const serial = stockitem.serial; | ||||
|     const serialized = | ||||
| @@ -704,7 +706,7 @@ export default function StockDetail() { | ||||
|           { | ||||
|             name: t`Count`, | ||||
|             tooltip: t`Count stock`, | ||||
|             hidden: serialized || !inStock, | ||||
|             hidden: serialized || !canTransfer || isBuilding, | ||||
|             icon: ( | ||||
|               <InvenTreeIcon icon='stocktake' iconProps={{ color: 'blue' }} /> | ||||
|             ), | ||||
| @@ -715,7 +717,7 @@ export default function StockDetail() { | ||||
|           { | ||||
|             name: t`Add`, | ||||
|             tooltip: t`Add Stock`, | ||||
|             hidden: serialized || !inStock, | ||||
|             hidden: serialized || !canTransfer || isBuilding, | ||||
|             icon: <InvenTreeIcon icon='add' iconProps={{ color: 'green' }} />, | ||||
|             onClick: () => { | ||||
|               stockitem.pk && addStockItem.open(); | ||||
| @@ -724,7 +726,11 @@ export default function StockDetail() { | ||||
|           { | ||||
|             name: t`Remove`, | ||||
|             tooltip: t`Remove Stock`, | ||||
|             hidden: serialized || !inStock || stockitem.quantity <= 0, | ||||
|             hidden: | ||||
|               serialized || | ||||
|               !canTransfer || | ||||
|               isBuilding || | ||||
|               stockitem.quantity <= 0, | ||||
|             icon: <InvenTreeIcon icon='remove' iconProps={{ color: 'red' }} />, | ||||
|             onClick: () => { | ||||
|               stockitem.pk && removeStockItem.open(); | ||||
| @@ -733,7 +739,7 @@ export default function StockDetail() { | ||||
|           { | ||||
|             name: t`Transfer`, | ||||
|             tooltip: t`Transfer Stock`, | ||||
|             hidden: !inStock, | ||||
|             hidden: !canTransfer, | ||||
|             icon: ( | ||||
|               <InvenTreeIcon icon='transfer' iconProps={{ color: 'blue' }} /> | ||||
|             ), | ||||
| @@ -745,8 +751,10 @@ export default function StockDetail() { | ||||
|             name: t`Serialize`, | ||||
|             tooltip: t`Serialize stock`, | ||||
|             hidden: | ||||
|               !inStock || | ||||
|               !canTransfer || | ||||
|               isBuilding || | ||||
|               serialized || | ||||
|               stockitem?.quantity != 1 || | ||||
|               stockitem?.part_detail?.trackable != true, | ||||
|             icon: <InvenTreeIcon icon='serial' iconProps={{ color: 'blue' }} />, | ||||
|             onClick: () => { | ||||
|   | ||||
| @@ -575,6 +575,7 @@ export default function BuildOutputTable({ | ||||
|         props={{ | ||||
|           params: { | ||||
|             part_detail: true, | ||||
|             location_detail: true, | ||||
|             tests: true, | ||||
|             is_building: true, | ||||
|             build: buildId | ||||
|   | ||||
		Reference in New Issue
	
	Block a user