mirror of
https://github.com/inventree/InvenTree
synced 2024-08-30 18:33:04 +00:00
SalesOrderShipment improvements (#3058)
* Adds two new fields to SalesOrderShipment model: - Invoice number (char) - Link (URL) * Bump API version * Update API / serializer / JS - Allow entry of new fields at time of shipping * PEP fixes * Actually fix the PEP issues * Unit testing: check some more fields
This commit is contained in:
parent
063375557f
commit
2378073c61
@ -4,11 +4,14 @@ InvenTree API version information
|
|||||||
|
|
||||||
|
|
||||||
# InvenTree API version
|
# InvenTree API version
|
||||||
INVENTREE_API_VERSION = 50
|
INVENTREE_API_VERSION = 51
|
||||||
|
|
||||||
"""
|
"""
|
||||||
Increment this API version number whenever there is a significant change to the API that any clients need to know about
|
Increment this API version number whenever there is a significant change to the API that any clients need to know about
|
||||||
|
|
||||||
|
v51 -> 2022-05-24 : https://github.com/inventree/InvenTree/pull/3058
|
||||||
|
- Adds new fields to the SalesOrderShipment model
|
||||||
|
|
||||||
v50 -> 2022-05-18 : https://github.com/inventree/InvenTree/pull/2912
|
v50 -> 2022-05-18 : https://github.com/inventree/InvenTree/pull/2912
|
||||||
- Implement Attachments for manufacturer parts
|
- Implement Attachments for manufacturer parts
|
||||||
|
|
||||||
|
23
InvenTree/order/migrations/0069_auto_20220524_0508.py
Normal file
23
InvenTree/order/migrations/0069_auto_20220524_0508.py
Normal file
@ -0,0 +1,23 @@
|
|||||||
|
# Generated by Django 3.2.13 on 2022-05-24 05:08
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
('order', '0068_alter_salesorderallocation_unique_together'),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='salesordershipment',
|
||||||
|
name='invoice_number',
|
||||||
|
field=models.CharField(blank=True, help_text='Reference number for associated invoice', max_length=100, verbose_name='Invoice Number'),
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name='salesordershipment',
|
||||||
|
name='link',
|
||||||
|
field=models.URLField(blank=True, help_text='Link to external page', verbose_name='Link'),
|
||||||
|
),
|
||||||
|
]
|
@ -1202,6 +1202,20 @@ class SalesOrderShipment(models.Model):
|
|||||||
help_text=_('Shipment tracking information'),
|
help_text=_('Shipment tracking information'),
|
||||||
)
|
)
|
||||||
|
|
||||||
|
invoice_number = models.CharField(
|
||||||
|
max_length=100,
|
||||||
|
blank=True,
|
||||||
|
unique=False,
|
||||||
|
verbose_name=_('Invoice Number'),
|
||||||
|
help_text=_('Reference number for associated invoice'),
|
||||||
|
)
|
||||||
|
|
||||||
|
link = models.URLField(
|
||||||
|
blank=True,
|
||||||
|
verbose_name=_('Link'),
|
||||||
|
help_text=_('Link to external page')
|
||||||
|
)
|
||||||
|
|
||||||
def is_complete(self):
|
def is_complete(self):
|
||||||
return self.shipment_date is not None
|
return self.shipment_date is not None
|
||||||
|
|
||||||
@ -1253,6 +1267,18 @@ class SalesOrderShipment(models.Model):
|
|||||||
if tracking_number is not None:
|
if tracking_number is not None:
|
||||||
self.tracking_number = tracking_number
|
self.tracking_number = tracking_number
|
||||||
|
|
||||||
|
# Was an invoice number provided?
|
||||||
|
invoice_number = kwargs.get('invoice_number', None)
|
||||||
|
|
||||||
|
if invoice_number is not None:
|
||||||
|
self.invoice_number = invoice_number
|
||||||
|
|
||||||
|
# Was a link provided?
|
||||||
|
link = kwargs.get('link', None)
|
||||||
|
|
||||||
|
if link is not None:
|
||||||
|
self.link = link
|
||||||
|
|
||||||
self.save()
|
self.save()
|
||||||
|
|
||||||
trigger_event('salesordershipment.completed', id=self.pk)
|
trigger_event('salesordershipment.completed', id=self.pk)
|
||||||
|
@ -886,6 +886,8 @@ class SalesOrderShipmentSerializer(InvenTreeModelSerializer):
|
|||||||
'checked_by',
|
'checked_by',
|
||||||
'reference',
|
'reference',
|
||||||
'tracking_number',
|
'tracking_number',
|
||||||
|
'invoice_number',
|
||||||
|
'link',
|
||||||
'notes',
|
'notes',
|
||||||
]
|
]
|
||||||
|
|
||||||
@ -899,8 +901,10 @@ class SalesOrderShipmentCompleteSerializer(serializers.ModelSerializer):
|
|||||||
model = order.models.SalesOrderShipment
|
model = order.models.SalesOrderShipment
|
||||||
|
|
||||||
fields = [
|
fields = [
|
||||||
'tracking_number',
|
|
||||||
'shipment_date',
|
'shipment_date',
|
||||||
|
'tracking_number',
|
||||||
|
'invoice_number',
|
||||||
|
'link',
|
||||||
]
|
]
|
||||||
|
|
||||||
def validate(self, data):
|
def validate(self, data):
|
||||||
@ -928,15 +932,14 @@ class SalesOrderShipmentCompleteSerializer(serializers.ModelSerializer):
|
|||||||
request = self.context['request']
|
request = self.context['request']
|
||||||
user = request.user
|
user = request.user
|
||||||
|
|
||||||
# Extract provided tracking number (optional)
|
|
||||||
tracking_number = data.get('tracking_number', shipment.tracking_number)
|
|
||||||
|
|
||||||
# Extract shipping date (defaults to today's date)
|
# Extract shipping date (defaults to today's date)
|
||||||
shipment_date = data.get('shipment_date', datetime.now())
|
shipment_date = data.get('shipment_date', datetime.now())
|
||||||
|
|
||||||
shipment.complete_shipment(
|
shipment.complete_shipment(
|
||||||
user,
|
user,
|
||||||
tracking_number=tracking_number,
|
tracking_number=data.get('tracking_number', shipment.tracking_number),
|
||||||
|
invoice_number=data.get('invoice_number', shipment.invoice_number),
|
||||||
|
link=data.get('link', shipment.link),
|
||||||
shipment_date=shipment_date,
|
shipment_date=shipment_date,
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -1324,6 +1324,8 @@ class SalesOrderAllocateTest(OrderTest):
|
|||||||
response = self.post(
|
response = self.post(
|
||||||
url,
|
url,
|
||||||
{
|
{
|
||||||
|
'invoice_number': 'INV01234',
|
||||||
|
'link': 'http://test.com/link.html',
|
||||||
'tracking_number': 'TRK12345',
|
'tracking_number': 'TRK12345',
|
||||||
'shipment_date': '2020-12-05',
|
'shipment_date': '2020-12-05',
|
||||||
},
|
},
|
||||||
@ -1334,6 +1336,8 @@ class SalesOrderAllocateTest(OrderTest):
|
|||||||
|
|
||||||
self.assertTrue(self.shipment.is_complete())
|
self.assertTrue(self.shipment.is_complete())
|
||||||
self.assertEqual(self.shipment.tracking_number, 'TRK12345')
|
self.assertEqual(self.shipment.tracking_number, 'TRK12345')
|
||||||
|
self.assertEqual(self.shipment.invoice_number, 'INV01234')
|
||||||
|
self.assertEqual(self.shipment.link, 'http://test.com/link.html')
|
||||||
|
|
||||||
def test_sales_order_shipment_list(self):
|
def test_sales_order_shipment_list(self):
|
||||||
|
|
||||||
|
@ -55,6 +55,12 @@ function salesOrderShipmentFields(options={}) {
|
|||||||
tracking_number: {
|
tracking_number: {
|
||||||
icon: 'fa-hashtag',
|
icon: 'fa-hashtag',
|
||||||
},
|
},
|
||||||
|
invoice_number: {
|
||||||
|
icon: 'fa-dollar-sign',
|
||||||
|
},
|
||||||
|
link: {
|
||||||
|
icon: 'fa-link',
|
||||||
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
// If order is specified, hide the order field
|
// If order is specified, hide the order field
|
||||||
@ -129,11 +135,20 @@ function completeShipment(shipment_id, options={}) {
|
|||||||
method: 'POST',
|
method: 'POST',
|
||||||
title: `{% trans "Complete Shipment" %} ${shipment.reference}`,
|
title: `{% trans "Complete Shipment" %} ${shipment.reference}`,
|
||||||
fields: {
|
fields: {
|
||||||
tracking_number: {
|
|
||||||
value: shipment.tracking_number,
|
|
||||||
},
|
|
||||||
shipment_date: {
|
shipment_date: {
|
||||||
value: moment().format('YYYY-MM-DD'),
|
value: moment().format('YYYY-MM-DD'),
|
||||||
|
},
|
||||||
|
tracking_number: {
|
||||||
|
value: shipment.tracking_number,
|
||||||
|
icon: 'fa-hashtag',
|
||||||
|
},
|
||||||
|
invoice_number: {
|
||||||
|
value: shipment.invoice_number,
|
||||||
|
icon: 'fa-dollar-sign',
|
||||||
|
},
|
||||||
|
link: {
|
||||||
|
value: shipment.link,
|
||||||
|
icon: 'fa-link',
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
preFormContent: html,
|
preFormContent: html,
|
||||||
@ -2445,10 +2460,26 @@ function loadSalesOrderShipmentTable(table, options={}) {
|
|||||||
field: 'tracking_number',
|
field: 'tracking_number',
|
||||||
title: '{% trans "Tracking" %}',
|
title: '{% trans "Tracking" %}',
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
field: 'invoice_number',
|
||||||
|
title: '{% trans "Invoice" %}',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
field: 'link',
|
||||||
|
title: '{% trans "Link" %}',
|
||||||
|
formatter: function(value) {
|
||||||
|
if (value) {
|
||||||
|
return renderLink(value, value);
|
||||||
|
} else {
|
||||||
|
return '-';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
field: 'notes',
|
field: 'notes',
|
||||||
title: '{% trans "Notes" %}',
|
title: '{% trans "Notes" %}',
|
||||||
visible: false,
|
visible: false,
|
||||||
|
switchable: false,
|
||||||
// TODO: Implement 'notes' field
|
// TODO: Implement 'notes' field
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
Loading…
Reference in New Issue
Block a user