diff --git a/InvenTree/InvenTree/validators.py b/InvenTree/InvenTree/validators.py
index f8199ef20b..d5fcb8822e 100644
--- a/InvenTree/InvenTree/validators.py
+++ b/InvenTree/InvenTree/validators.py
@@ -74,7 +74,7 @@ def validate_build_order_reference(value):
match = re.search(pattern, value)
if match is None:
- raise ValidationError(_('Reference must match pattern') + f" '{pattern}'")
+ raise ValidationError(_('Reference must match pattern {pattern}').format(pattern=pattern))
def validate_purchase_order_reference(value):
@@ -88,7 +88,7 @@ def validate_purchase_order_reference(value):
match = re.search(pattern, value)
if match is None:
- raise ValidationError(_('Reference must match pattern') + f" '{pattern}'")
+ raise ValidationError(_('Reference must match pattern {pattern}').format(pattern=pattern))
def validate_sales_order_reference(value):
@@ -102,7 +102,7 @@ def validate_sales_order_reference(value):
match = re.search(pattern, value)
if match is None:
- raise ValidationError(_('Reference must match pattern') + f" '{pattern}'")
+ raise ValidationError(_('Reference must match pattern {pattern}').format(pattern=pattern))
def validate_tree_name(value):
diff --git a/InvenTree/company/views.py b/InvenTree/company/views.py
index be7d326c36..7ba8e5e6bf 100644
--- a/InvenTree/company/views.py
+++ b/InvenTree/company/views.py
@@ -202,7 +202,7 @@ class CompanyImageDownloadFromURL(AjaxUpdateView):
# Check for valid response code
if not response.status_code == 200:
- form.add_error('url', f"{_('Invalid response')}: {response.status_code}")
+ form.add_error('url', _('Invalid response: {code}').format(code=response.status_code))
return
response.raw.decode_content = True
diff --git a/InvenTree/order/models.py b/InvenTree/order/models.py
index da0bae6aac..67890806c5 100644
--- a/InvenTree/order/models.py
+++ b/InvenTree/order/models.py
@@ -367,7 +367,7 @@ class PurchaseOrder(Order):
stock.save()
text = _("Received items")
- note = f"{_('Received')} {quantity} {_('items against order')} {str(self)}"
+ note = _('Received {n} items against order {name}').format(n=quantity, name=str(self))
# Add a new transaction note to the newly created stock item
stock.addTransactionNote(text, user, note)
diff --git a/InvenTree/order/views.py b/InvenTree/order/views.py
index 9c2ccfd321..2ed7e76c49 100644
--- a/InvenTree/order/views.py
+++ b/InvenTree/order/views.py
@@ -1408,7 +1408,7 @@ class SalesOrderAssignSerials(AjaxView, FormMixin):
except StockItem.DoesNotExist:
self.form.add_error(
'serials',
- _('No matching item for serial') + f" '{serial}'"
+ _('No matching item for serial {serial}').format(serial=serial)
)
continue
@@ -1418,7 +1418,7 @@ class SalesOrderAssignSerials(AjaxView, FormMixin):
if not stock_item.in_stock:
self.form.add_error(
'serials',
- f"'{serial}' " + _("is not in stock")
+ _('{serial} is not in stock').format(serial=serial)
)
continue
@@ -1426,7 +1426,7 @@ class SalesOrderAssignSerials(AjaxView, FormMixin):
if stock_item.is_allocated():
self.form.add_error(
'serials',
- f"'{serial}' " + _("already allocated to an order")
+ _('{serial} already allocated to an order').format(serial=serial)
)
continue
diff --git a/InvenTree/part/templates/part/navbar.html b/InvenTree/part/templates/part/navbar.html
index d8750a49a5..df49841e31 100644
--- a/InvenTree/part/templates/part/navbar.html
+++ b/InvenTree/part/templates/part/navbar.html
@@ -91,7 +91,7 @@
{% if part.salable and roles.sales_order.view %}
-
+
{% trans "Sale Price" %}
diff --git a/InvenTree/part/templates/part/sale_prices.html b/InvenTree/part/templates/part/sale_prices.html
index ce50c1f20d..f19d65a59a 100644
--- a/InvenTree/part/templates/part/sale_prices.html
+++ b/InvenTree/part/templates/part/sale_prices.html
@@ -2,7 +2,7 @@
{% load static %}
{% load i18n %}
-{% block menubar %}}
+{% block menubar %}
{% include 'part/navbar.html' with tab='sales-prices' %}
{% endblock %}
diff --git a/InvenTree/part/views.py b/InvenTree/part/views.py
index 5af90cb383..18bbd5b361 100644
--- a/InvenTree/part/views.py
+++ b/InvenTree/part/views.py
@@ -884,7 +884,7 @@ class PartImageDownloadFromURL(AjaxUpdateView):
# Check for valid response code
if not response.status_code == 200:
- form.add_error('url', f"{_('Invalid response')}: {response.status_code}")
+ form.add_error('url', _('Invalid response: {code}').format(code=response.status_code))
return
response.raw.decode_content = True
diff --git a/InvenTree/stock/models.py b/InvenTree/stock/models.py
index 7d9520a544..7f22b7a4ef 100644
--- a/InvenTree/stock/models.py
+++ b/InvenTree/stock/models.py
@@ -198,7 +198,7 @@ class StockItem(MPTTModel):
if add_note:
- note = f"{_('Created new stock item for')} {str(self.part)}"
+ note = _('Created new stock item for {part}').format(part=str(self.part))
# This StockItem is being saved for the first time
self.addTransactionNote(
@@ -613,7 +613,7 @@ class StockItem(MPTTModel):
item.addTransactionNote(
_("Assigned to Customer"),
user,
- notes=_("Manually assigned to customer") + " " + customer.name,
+ notes=_("Manually assigned to customer {name}").format(name=customer.name),
system=True
)
@@ -626,9 +626,9 @@ class StockItem(MPTTModel):
"""
self.addTransactionNote(
- _("Returned from customer") + f" {self.customer.name}",
+ _("Returned from customer {name}").format(name=self.customer.name),
user,
- notes=_("Returned to location") + f" {location.name}",
+ notes=_("Returned to location {loc}").format(loc=location.name),
system=True
)
@@ -789,7 +789,7 @@ class StockItem(MPTTModel):
# Add a transaction note to the other item
stock_item.addTransactionNote(
- _('Installed into stock item') + ' ' + str(self.pk),
+ _('Installed into stock item {pk}').format(str(self.pk)),
user,
notes=notes,
url=self.get_absolute_url()
@@ -797,7 +797,7 @@ class StockItem(MPTTModel):
# Add a transaction note to this item
self.addTransactionNote(
- _('Installed stock item') + ' ' + str(stock_item.pk),
+ _('Installed stock item {pk}').format(str(stock_item.pk)),
user, notes=notes,
url=stock_item.get_absolute_url()
)
@@ -821,7 +821,7 @@ class StockItem(MPTTModel):
# Add a transaction note to the parent item
self.belongs_to.addTransactionNote(
- _("Uninstalled stock item") + ' ' + str(self.pk),
+ _("Uninstalled stock item {pk}").format(pk=str(self.pk)),
user,
notes=notes,
url=self.get_absolute_url(),
@@ -840,7 +840,7 @@ class StockItem(MPTTModel):
# Add a transaction note!
self.addTransactionNote(
- _('Uninstalled into location') + ' ' + str(location),
+ _('Uninstalled into location {loc}').formaT(loc=str(location)),
user,
notes=notes,
url=url
@@ -966,7 +966,7 @@ class StockItem(MPTTModel):
if len(existing) > 0:
exists = ','.join([str(x) for x in existing])
- raise ValidationError({"serial_numbers": _("Serial numbers already exist") + ': ' + exists})
+ raise ValidationError({"serial_numbers": _("Serial numbers already exist: {exists}").format(exists=exists)})
# Create a new stock item for each unique serial number
for serial in serials:
@@ -1074,7 +1074,7 @@ class StockItem(MPTTModel):
new_stock.addTransactionNote(
_("Split from existing stock"),
user,
- f"{_('Split')} {helpers.normalize(quantity)} {_('items')}"
+ _('Split {n} items').format(n=helpers.normalize(quantity))
)
# Remove the specified quantity from THIS stock item
@@ -1131,10 +1131,10 @@ class StockItem(MPTTModel):
return True
- msg = f"{_('Moved to')} {str(location)}"
-
if self.location:
- msg += f" ({_('from')} {str(self.location)})"
+ msg = _("Moved to {loc_new} (from {loc_old})").format(loc_new=str(location), loc_old=str(self.location))
+ else:
+ msg = _('Moved to {loc_new}').format(loc_new=str(location))
self.location = location
@@ -1202,9 +1202,7 @@ class StockItem(MPTTModel):
if self.updateQuantity(count):
- n = helpers.normalize(count)
-
- text = f"{_('Counted')} {n} {_('items')}"
+ text = _('Counted {n} items').format(n=helpers.normalize(count))
self.addTransactionNote(
text,
@@ -1236,9 +1234,8 @@ class StockItem(MPTTModel):
return False
if self.updateQuantity(self.quantity + quantity):
-
- n = helpers.normalize(quantity)
- text = f"{_('Added')} {n} {_('items')}"
+
+ text = _('Added {n} items').format(n=helpers.normalize(quantity))
self.addTransactionNote(
text,
@@ -1268,8 +1265,7 @@ class StockItem(MPTTModel):
if self.updateQuantity(self.quantity - quantity):
- q = helpers.normalize(quantity)
- text = f"{_('Removed')} {q} {_('items')}"
+ text = _('Removed {n1} items').format(n1=helpers.normalize(quantity))
self.addTransactionNote(text,
user,