2026-06-21 18:14:54 +01:00

455 lines
11 KiB
JavaScript

import OrderItemIcon from '../../components/Icons/OrderItemIcon'
import InfoCircleIcon from '../../components/Icons/InfoCircleIcon'
import EditIcon from '../../components/Icons/EditIcon'
import BinIcon from '../../components/Icons/BinIcon'
import CheckIcon from '../../components/Icons/CheckIcon'
import XMarkIcon from '../../components/Icons/XMarkIcon'
export const OrderItem = {
name: 'orderItem',
label: 'Order Item',
prefix: 'ODI',
icon: OrderItemIcon,
actions: [
{
name: 'info',
label: 'Info',
default: true,
row: true,
icon: InfoCircleIcon,
url: (_id) => `/dashboard/inventory/orderitems/info?orderItemId=${_id}`
},
{
name: 'edit',
label: 'Edit',
type: 'button',
icon: EditIcon,
url: (_id) =>
`/dashboard/inventory/orderitems/info?orderItemId=${_id}&action=edit`,
visible: (objectData) => {
return !(objectData?._isEditing && objectData?._isEditing == true)
},
disabled: (objectData) => {
return objectData?.state?.type != 'draft'
}
},
{
name: 'cancelEdit',
label: 'Cancel Edit',
type: 'button',
icon: XMarkIcon,
url: (_id) =>
`/dashboard/inventory/orderitems/info?orderItemId=${_id}&action=cancelEdit`,
visible: (objectData) => {
return objectData?._isEditing && objectData?._isEditing == true
},
disabled: (objectData) => {
return objectData?.state?.type != 'draft'
}
},
{
name: 'finishEdit',
label: 'Finish Edit',
type: 'button',
icon: CheckIcon,
url: (_id) =>
`/dashboard/inventory/orderitems/info?orderItemId=${_id}&action=finishEdit`,
visible: (objectData) => {
return objectData?._isEditing && objectData?._isEditing == true
},
disabled: (objectData) => {
return objectData?.state?.type != 'draft'
}
},
{
name: 'delete',
label: 'Delete',
type: 'button',
icon: BinIcon,
danger: true,
url: (_id) =>
`/dashboard/inventory/orderitems/info?orderItemId=${_id}&action=delete`,
visible: (objectData) => {
return !(objectData?._isEditing && objectData?._isEditing == true)
},
disabled: (objectData) => {
return objectData?.state?.type != 'draft'
}
}
],
group: [],
filters: ['itemType', 'item', 'sku', 'order'],
sorters: ['createdAt', 'updatedAt', 'itemAmount', 'quantity'],
columns: [
'_reference',
'name',
'state',
'itemType',
'item',
'sku',
'itemAmount',
'quantity',
'totalAmount',
'taxRate',
'totalAmountWithTax',
'order',
'shipment',
'invoicedAmount',
'invoicedAmountWithTax',
'invoicedQuantity',
'invoicedAmountRemaining',
'invoicedAmountWithTaxRemaining',
'invoicedQuantityRemaining',
'orderedAt',
'receivedAt',
'createdAt',
'updatedAt'
],
properties: [
{
name: '_id',
label: 'ID',
type: 'id',
columnFixed: 'left',
objectType: 'orderItem',
columnWidth: 140,
showCopy: true
},
{
name: 'createdAt',
label: 'Created At',
type: 'dateTime',
readOnly: true,
columnWidth: 175
},
{
name: '_reference',
label: 'Reference',
type: 'reference',
columnFixed: 'left',
objectType: 'orderItem',
showCopy: true,
readOnly: true,
columnWidth: 180
},
{
name: 'updatedAt',
label: 'Updated At',
type: 'dateTime',
readOnly: true,
columnWidth: 175
},
{
name: 'name',
label: 'Name',
type: 'text',
readOnly: true,
columnWidth: 200,
columnFixed: 'left',
value: (objectData) => {
return objectData?.sku?.name ?? objectData?.item?.name
}
},
{
name: 'orderedAt',
label: 'Ordered At',
type: 'dateTime',
required: false,
readOnly: true,
columnWidth: 175
},
{
name: 'state',
label: 'State',
type: 'state',
readOnly: true,
columnWidth: 250
},
{
name: 'receivedAt',
label: 'Received At',
type: 'dateTime',
required: false,
readOnly: true,
columnWidth: 175
},
{
name: 'orderType',
label: 'Order Type',
type: 'objectType',
masterFilter: ['purchaseOrder', 'salesOrder'],
required: true
},
{
name: 'order',
label: 'Order',
type: 'object',
showHyperlink: true,
objectType: (objectData) => {
return objectData?.orderType
},
required: true,
columnWidth: 200
},
{
name: 'shipment',
label: 'Shipment',
type: 'object',
objectType: 'shipment',
showHyperlink: true,
required: false,
columnWidth: 250,
readOnly: (objectData) => {
return objectData?.state?.type != 'draft'
},
masterFilter: (objectData) => {
return {
order: objectData?.order?._id
}
}
},
{
name: 'itemType',
label: 'Item Type',
type: 'objectType',
masterFilter: ['part', 'packaging', 'filament', 'product'],
required: true,
columnWidth: 175
},
{
name: 'item',
label: 'Item',
type: 'object',
objectType: (objectData) => {
return objectData?.itemType
},
required: true,
showHyperlink: true,
columnWidth: 300
},
{
name: 'sku',
label: 'Item SKU',
type: 'object',
objectType: (objectData) => {
if (objectData?.itemType === 'filament') return 'filamentSku'
if (objectData?.itemType === 'part') return 'partSku'
if (objectData?.itemType === 'product') return 'productSku'
return undefined
},
required: true,
showHyperlink: true,
columnWidth: 300,
masterFilter: (objectData) => {
console.log(objectData)
if (objectData?.itemType === 'filament' && objectData?.item?._id) {
return { filament: objectData.item._id }
}
if (objectData?.itemType === 'part' && objectData?.item?._id) {
return { part: objectData.item._id }
}
if (objectData?.itemType === 'product' && objectData?.item?._id) {
return { product: objectData.item._id }
}
return undefined
}
},
{
name: 'syncAmount',
label: 'Sync Amount',
type: 'select',
columnWidth: 150,
options: [
{ label: 'Item Cost', value: 'itemCost' },
{ label: 'Item Price', value: 'itemPrice' },
{ label: 'None', value: null }
],
required: false
},
{
name: 'itemAmount',
label: 'Item Amount',
type: 'number',
required: true,
prefix: '£',
min: 0,
step: 0.01,
fixedNumber: 2,
readOnly: (objectData) => {
return objectData?.syncAmount != null
},
columnWidth: 150,
value: (objectData) => {
const sku = objectData?.sku
const item = objectData?.item
if (objectData?.syncAmount == 'itemCost') {
const cost =
sku && sku.overrideCost ? sku.cost : (item?.cost ?? sku?.cost)
return cost ?? objectData?.itemAmount
}
if (objectData?.syncAmount == 'itemPrice') {
if (sku && sku.overridePrice) {
return sku.price ?? objectData?.itemAmount
}
const priceMode = item?.priceMode ?? sku?.priceMode
const margin = item?.margin ?? sku?.margin
const cost = item?.cost ?? sku?.cost
if (priceMode == 'margin' && margin != null && cost != null) {
return cost * (1 + margin / 100)
}
return item?.price ?? sku?.price ?? objectData?.itemAmount
}
return objectData?.itemAmount || undefined
}
},
{
name: 'quantity',
label: 'Quantity',
type: 'number',
required: true,
columnWidth: 150
},
{
name: 'totalAmount',
label: 'Total Amount',
type: 'number',
required: true,
prefix: '£',
min: 0,
step: 0.01,
columnWidth: 150,
fixedNumber: 2,
readOnly: true,
value: (objectData) => {
if (objectData?.itemAmount && objectData?.quantity) {
return (
(objectData?.itemAmount || 0) * (objectData?.quantity || 0)
).toFixed(2)
} else {
return 0
}
}
},
{
name: 'taxRate',
label: 'Tax Rate',
type: 'object',
objectType: 'taxRate',
showHyperlink: true,
columnWidth: 150,
value: (objectData) => {
const sku = objectData?.sku
const item = objectData?.item
if (objectData?.syncAmount == 'itemCost') {
const source = sku && sku.overrideCost ? sku : item
return source?.costTaxRate ?? sku?.costTaxRate ?? objectData?.taxRate
}
if (objectData?.syncAmount == 'itemPrice') {
const source = sku && sku.overridePrice ? sku : item
return (
source?.priceTaxRate ?? sku?.priceTaxRate ?? objectData?.taxRate
)
}
return objectData?.taxRate || undefined
},
readOnly: (objectData) => {
return objectData?.syncAmount != null
}
},
{
name: 'totalAmountWithTax',
label: 'Total Amount w/ Tax',
type: 'number',
required: true,
fixedNumber: 2,
readOnly: true,
prefix: '£',
min: 0,
step: 0.01,
columnWidth: 175,
value: (objectData) => {
const totalAmount = objectData?.itemAmount * objectData?.quantity || 0
if (!totalAmount) return 0
if (objectData?.taxRate?.rateType == 'percentage') {
return (
(
totalAmount *
(1 + objectData?.taxRate?.rate / 100)
).toFixed(2) || 0
)
} else if (objectData?.taxRate?.rateType == 'amount') {
return (
(totalAmount + objectData?.taxRate?.rate).toFixed(2) || 0
)
}
return totalAmount
}
},
{
name: 'invoicedAmount',
label: 'Invoiced Amount',
type: 'number',
required: false,
readOnly: true,
prefix: '£',
fixedNumber: 2,
min: 0,
step: 0.01,
columnWidth: 150
},
{
name: 'invoicedAmountWithTax',
label: 'Invoiced Amount w/ Tax',
type: 'number',
required: false,
readOnly: true,
prefix: '£',
fixedNumber: 2,
min: 0,
step: 0.01,
columnWidth: 200
},
{
name: 'invoicedQuantity',
label: 'Invoiced Quantity',
type: 'number',
required: false,
readOnly: true,
columnWidth: 150
},
{
name: 'invoicedAmountRemaining',
label: 'Remaining Invoiced Amount',
type: 'number',
required: false,
readOnly: true,
prefix: '£',
min: 0,
step: 0.01,
columnWidth: 225,
fixedNumber: 2
},
{
name: 'invoicedAmountWithTaxRemaining',
label: 'Remaining Invoiced Amount w/ Tax',
type: 'number',
required: false,
readOnly: true,
prefix: '£',
min: 0,
fixedNumber: 2,
step: 0.01,
columnWidth: 275
},
{
name: 'invoicedQuantityRemaining',
label: 'Remaining Invoiced Quantity',
type: 'number',
required: false,
readOnly: true,
columnWidth: 225
}
]
}