import FilamentSkuIcon from '../../components/Icons/FilamentSkuIcon' import InfoCircleIcon from '../../components/Icons/InfoCircleIcon' import EditIcon from '../../components/Icons/EditIcon' import CheckIcon from '../../components/Icons/CheckIcon' import XMarkIcon from '../../components/Icons/XMarkIcon' import BinIcon from '../../components/Icons/BinIcon' export const FilamentSku = { name: 'filamentSku', label: 'Filament SKU', prefix: 'FSU', icon: FilamentSkuIcon, actions: [ { name: 'info', label: 'Info', default: true, row: true, icon: InfoCircleIcon, url: (_id) => `/dashboard/management/filamentskus/info?filamentSkuId=${_id}` }, { name: 'edit', label: 'Edit', row: true, icon: EditIcon, url: (_id) => `/dashboard/management/filamentskus/info?filamentSkuId=${_id}&action=edit`, visible: (objectData) => { return !(objectData?._isEditing && objectData?._isEditing == true) } }, { name: 'finishEdit', label: 'Save Edits', icon: CheckIcon, url: (_id) => `/dashboard/management/filamentskus/info?filamentSkuId=${_id}&action=finishEdit`, visible: (objectData) => { return objectData?._isEditing && objectData?._isEditing == true } }, { name: 'cancelEdit', label: 'Cancel Edits', icon: XMarkIcon, url: (_id) => `/dashboard/management/filamentskus/info?filamentSkuId=${_id}&action=cancelEdit`, visible: (objectData) => { return objectData?._isEditing && objectData?._isEditing == true } }, { type: 'divider' }, { name: 'delete', label: 'Delete', icon: BinIcon, danger: true, url: (_id) => `/dashboard/management/filamentskus/info?filamentSkuId=${_id}&action=delete` } ], url: (id) => `/dashboard/management/filamentskus/info?filamentSkuId=${id}`, columns: [ '_reference', 'name', 'filament', 'barcode', 'color', 'overrideCost', 'cost', 'costWithTax', 'createdAt', 'updatedAt' ], filters: [ '_id', 'barcode', 'filament', 'filament._id', 'name', 'color', 'cost', 'costWithTax' ], sorters: [ 'barcode', 'filament', 'name', 'color', 'cost', 'costWithTax', 'createdAt', 'updatedAt' ], group: ['filament'], properties: [ { name: '_id', label: 'ID', type: 'id', objectType: 'filamentSku', showCopy: true, readOnly: true, columnWidth: 140 }, { name: 'createdAt', label: 'Created At', type: 'dateTime', readOnly: true, columnWidth: 175 }, { name: '_reference', label: 'Reference', type: 'reference', columnFixed: 'left', objectType: 'filamentSku', showCopy: true, readOnly: true, columnWidth: 180 }, { name: 'name', label: 'Name', required: true, type: 'text', columnWidth: 200, columnFixed: 'left' }, { name: 'updatedAt', label: 'Updated At', type: 'dateTime', readOnly: true, columnWidth: 175 }, { name: 'filament', label: 'Filament', type: 'object', objectType: 'filament', required: true, showHyperlink: true, columnWidth: 200 }, { name: 'barcode', label: 'Barcode', required: false, type: 'text', columnWidth: 150 }, { name: 'description', label: 'Description', required: false, type: 'text', columnWidth: 200 }, { name: 'color', label: 'Color', required: true, type: 'color', columnWidth: 120 }, { name: 'overrideCost', label: 'Override Cost', required: false, type: 'bool', value: (objectData) => objectData?.overrideCost ?? false, columnWidth: 150 }, { name: 'cost', label: 'Cost', required: false, type: 'number', prefix: '£', min: 0, step: 0.01, disabled: (objectData) => !objectData?.overrideCost, value: (objectData) => objectData?.overrideCost ? objectData?.cost : undefined, columnWidth: 100 }, { name: 'costWithTax', label: 'Cost w/ Tax', required: false, readOnly: true, type: 'number', prefix: '£', min: 0, step: 0.01, disabled: (objectData) => !objectData?.overrideCost, value: (objectData) => { if (!objectData?.overrideCost) return undefined const cost = objectData?.cost const taxRate = objectData?.costTaxRate if (!cost) return 0 if (taxRate?.rateType == 'percentage') { return (cost * (1 + taxRate?.rate / 100)).toFixed(2) || 0 } else if (taxRate?.rateType == 'amount') { return (cost + taxRate?.rate).toFixed(2) || 0 } return cost }, columnWidth: 150 }, { name: 'costTaxRate', label: 'Cost Tax Rate', required: false, type: 'object', objectType: 'taxRate', showHyperlink: true, disabled: (objectData) => !objectData?.overrideCost, value: (objectData) => objectData?.overrideCost ? objectData?.costTaxRate : undefined, columnWidth: 150 } ] }