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:
Oliver 2022-05-25 11:00:19 +10:00 committed by GitHub
parent 063375557f
commit 2378073c61
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
6 changed files with 99 additions and 9 deletions

View File

@ -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

View 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'),
),
]

View File

@ -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)

View File

@ -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,
) )

View File

@ -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):

View File

@ -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
}, },
{ {