mirror of
https://github.com/inventree/InvenTree
synced 2024-08-30 18:33:04 +00:00
First pass at a part-purchase-order table
This commit is contained in:
parent
43ee4e390a
commit
6d90ded27f
@ -73,7 +73,7 @@
|
|||||||
<div class='panel-content'>
|
<div class='panel-content'>
|
||||||
<div id='po-button-bar'>
|
<div id='po-button-bar'>
|
||||||
<div class='button-toolbar container-fluid' style='float: right;'>
|
<div class='button-toolbar container-fluid' style='float: right;'>
|
||||||
{% include "filter_list.html" with id="purchaseorder" %}
|
{% include "filter_list.html" with id="partpurchaseorders" %}
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
@ -703,12 +703,10 @@
|
|||||||
});
|
});
|
||||||
|
|
||||||
onPanelLoad("purchase-orders", function() {
|
onPanelLoad("purchase-orders", function() {
|
||||||
loadPurchaseOrderTable($("#purchase-order-table"), {
|
loadPartPurchaseOrderTable(
|
||||||
url: "{% url 'api-po-list' %}",
|
"#purchase-order-table",
|
||||||
params: {
|
{{ part.pk }},
|
||||||
part: {{ part.id }},
|
);
|
||||||
},
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
|
||||||
onPanelLoad("sales-orders", function() {
|
onPanelLoad("sales-orders", function() {
|
||||||
|
@ -648,6 +648,13 @@ function loadPurchaseOrderTable(table, options) {
|
|||||||
|
|
||||||
var html = renderLink(value, `/order/purchase-order/${row.pk}/`);
|
var html = renderLink(value, `/order/purchase-order/${row.pk}/`);
|
||||||
|
|
||||||
|
html += purchaseOrderStatusDisplay(
|
||||||
|
row.status,
|
||||||
|
{
|
||||||
|
classes: 'float-right',
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
if (row.overdue) {
|
if (row.overdue) {
|
||||||
html += makeIconBadge('fa-calendar-times icon-red', '{% trans "Order is overdue" %}');
|
html += makeIconBadge('fa-calendar-times icon-red', '{% trans "Order is overdue" %}');
|
||||||
}
|
}
|
||||||
@ -672,14 +679,6 @@ function loadPurchaseOrderTable(table, options) {
|
|||||||
field: 'description',
|
field: 'description',
|
||||||
title: '{% trans "Description" %}',
|
title: '{% trans "Description" %}',
|
||||||
},
|
},
|
||||||
{
|
|
||||||
field: 'status',
|
|
||||||
title: '{% trans "Status" %}',
|
|
||||||
sortable: true,
|
|
||||||
formatter: function(value, row) {
|
|
||||||
return purchaseOrderStatusDisplay(row.status, row.status_text);
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{
|
{
|
||||||
field: 'creation_date',
|
field: 'creation_date',
|
||||||
title: '{% trans "Date" %}',
|
title: '{% trans "Date" %}',
|
||||||
|
@ -29,6 +29,7 @@
|
|||||||
loadParametricPartTable,
|
loadParametricPartTable,
|
||||||
loadPartCategoryTable,
|
loadPartCategoryTable,
|
||||||
loadPartParameterTable,
|
loadPartParameterTable,
|
||||||
|
loadPartPurchaseOrderTable,
|
||||||
loadPartTable,
|
loadPartTable,
|
||||||
loadPartTestTemplateTable,
|
loadPartTestTemplateTable,
|
||||||
loadPartVariantTable,
|
loadPartVariantTable,
|
||||||
@ -712,6 +713,135 @@ function loadPartParameterTable(table, url, options) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Construct a table showing a list of purchase orders for a given part.
|
||||||
|
*
|
||||||
|
* This requests API data from the PurchaseOrderLineItem endpoint
|
||||||
|
*/
|
||||||
|
function loadPartPurchaseOrderTable(table, part_id, options={}) {
|
||||||
|
|
||||||
|
options.params = options.params || {};
|
||||||
|
|
||||||
|
// Construct API filterset
|
||||||
|
options.params.base_part = part_id;
|
||||||
|
options.params.part_detail = true;
|
||||||
|
options.params.order_detail = true;
|
||||||
|
|
||||||
|
var filters = loadTableFilters('partpurchaseorders');
|
||||||
|
|
||||||
|
for (var key in options.params) {
|
||||||
|
filters[key] = options.params[key];
|
||||||
|
}
|
||||||
|
|
||||||
|
setupFilterList('partpurchaseorders', $(table));
|
||||||
|
|
||||||
|
$(table).inventreeTable({
|
||||||
|
url: '{% url "api-po-line-list" %}',
|
||||||
|
queryParams: filters,
|
||||||
|
name: 'partpurchaseorders',
|
||||||
|
original: options.params,
|
||||||
|
showColumns: true,
|
||||||
|
formatNoMatches: function() {
|
||||||
|
return '{% trans "No purchase orders found" %}';
|
||||||
|
},
|
||||||
|
columns: [
|
||||||
|
{
|
||||||
|
field: 'order',
|
||||||
|
title: '{% trans "Purchase Order" %}',
|
||||||
|
switchable: false,
|
||||||
|
formatter: function(value, row) {
|
||||||
|
var order = row.order_detail;
|
||||||
|
|
||||||
|
if (!order) {
|
||||||
|
return '-';
|
||||||
|
}
|
||||||
|
|
||||||
|
var ref = global_settings.PURCHASEORDER_REFERENCE_PREFIX + order.reference;
|
||||||
|
|
||||||
|
var html = renderLink(ref, `/order/po/${order.pk}/`);
|
||||||
|
|
||||||
|
html += purchaseOrderStatusDisplay(
|
||||||
|
order.status,
|
||||||
|
{
|
||||||
|
classes: 'float-right',
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
return html;
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
field: 'supplier',
|
||||||
|
title: '{% trans "Supplier" %}',
|
||||||
|
switchable: true,
|
||||||
|
formatter: function(value, row) {
|
||||||
|
|
||||||
|
if (row.supplier_part_detail && row.supplier_part_detail.supplier_detail) {
|
||||||
|
var supp = row.supplier_part_detail.supplier_detail;
|
||||||
|
var html = imageHoverIcon(supp.thumbnail || supp.image);
|
||||||
|
|
||||||
|
html += ' ' + renderLink(supp.name, `/company/${supp.pk}/`);
|
||||||
|
|
||||||
|
return html;
|
||||||
|
} else {
|
||||||
|
return '-';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
field: 'sku',
|
||||||
|
title: '{% trans "SKU" %}',
|
||||||
|
switchable: true,
|
||||||
|
formatter: function(value, row) {
|
||||||
|
if (row.supplier_part_detail) {
|
||||||
|
var supp = row.supplier_part_detail;
|
||||||
|
|
||||||
|
return renderLink(supp.SKU, `/supplier-part/${supp.pk}/`);
|
||||||
|
} else {
|
||||||
|
return '-';
|
||||||
|
}
|
||||||
|
},
|
||||||
|
},
|
||||||
|
{
|
||||||
|
field: 'mpn',
|
||||||
|
title: '{% trans "MPN" %}',
|
||||||
|
switchable: true,
|
||||||
|
formatter: function(value, row) {
|
||||||
|
if (row.supplier_part_detail && row.supplier_part_detail.manufacturer_part_detail) {
|
||||||
|
var manu = row.supplier_part_detail.manufacturer_part_detail;
|
||||||
|
return renderLink(manu.MPN, `/manufacturer-part/${manu.pk}/`);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{
|
||||||
|
field: 'quantity',
|
||||||
|
title: '{% trans "Quantity" %}',
|
||||||
|
},
|
||||||
|
{
|
||||||
|
field: 'received',
|
||||||
|
title: '{% trans "Received" %}',
|
||||||
|
switchable: true,
|
||||||
|
},
|
||||||
|
{
|
||||||
|
field: 'purchase_price',
|
||||||
|
title: '{% trans "Price" %}',
|
||||||
|
formatter: function(value, row) {
|
||||||
|
var formatter = new Intl.NumberFormat(
|
||||||
|
'en-US',
|
||||||
|
{
|
||||||
|
style: 'currency',
|
||||||
|
currency: row.purchase_price_currency,
|
||||||
|
}
|
||||||
|
);
|
||||||
|
|
||||||
|
return formatter.format(row.purchase_price);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
]
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
function loadRelatedPartsTable(table, part_id, options={}) {
|
function loadRelatedPartsTable(table, part_id, options={}) {
|
||||||
/*
|
/*
|
||||||
* Load table of "related" parts
|
* Load table of "related" parts
|
||||||
|
Loading…
Reference in New Issue
Block a user