Compare commits

...

2 Commits

6 changed files with 234 additions and 140 deletions

View File

@ -5,7 +5,15 @@ import WizardView from '../../common/WizardView'
const NewPartSku = ({ onOk, reset, defaultValues }) => { const NewPartSku = ({ onOk, reset, defaultValues }) => {
return ( return (
<NewObjectForm type='partSku' reset={reset} defaultValues={defaultValues}> <NewObjectForm
type='partSku'
reset={reset}
defaultValues={{
overrideCost: false,
overridePrice: false,
...defaultValues
}}
>
{({ handleSubmit, submitLoading, objectData, formValid }) => { {({ handleSubmit, submitLoading, objectData, formValid }) => {
const steps = [ const steps = [
{ {
@ -28,6 +36,8 @@ const NewPartSku = ({ onOk, reset, defaultValues }) => {
costTaxRate: false, costTaxRate: false,
price: false, price: false,
priceWithTax: false, priceWithTax: false,
overrideCost: false,
overridePrice: false,
margin: false, margin: false,
amount: false, amount: false,
priceTaxRate: false, priceTaxRate: false,
@ -43,15 +53,18 @@ const NewPartSku = ({ onOk, reset, defaultValues }) => {
<ObjectInfo <ObjectInfo
type='partSku' type='partSku'
column={1} column={1}
labelWidth={100} labelWidth={120}
visibleProperties={{ visibleProperties={{
_id: false, overrideCost: true,
createdAt: false, cost: true,
updatedAt: false, costTaxRate: true,
barcode: false, costWithTax: true,
part: false, overridePrice: true,
name: false, priceMode: true,
description: false price: true,
margin: true,
priceTaxRate: true,
priceWithTax: true
}} }}
bordered={false} bordered={false}
isEditing={true} isEditing={true}
@ -90,7 +103,7 @@ const NewPartSku = ({ onOk, reset, defaultValues }) => {
_id: false, _id: false,
_reference: false _reference: false
}} }}
labelWidth={100} labelWidth={120}
bordered={false} bordered={false}
isEditing={false} isEditing={false}
objectData={objectData} objectData={objectData}

View File

@ -193,7 +193,7 @@ const PartInfo = () => {
}} }}
reset={newPartSkuOpen} reset={newPartSkuOpen}
defaultValues={{ defaultValues={{
part: partId ? { _id: partId } : undefined part: objectFormState?.objectData || undefined
}} }}
/> />
</Modal> </Modal>

View File

@ -8,7 +8,11 @@ const NewProductSku = ({ onOk, reset, defaultValues }) => {
<NewObjectForm <NewObjectForm
type='productSku' type='productSku'
reset={reset} reset={reset}
defaultValues={defaultValues} defaultValues={{
overrideCost: false,
overridePrice: false,
...defaultValues
}}
> >
{({ handleSubmit, submitLoading, objectData, formValid }) => { {({ handleSubmit, submitLoading, objectData, formValid }) => {
const steps = [ const steps = [
@ -35,6 +39,8 @@ const NewProductSku = ({ onOk, reset, defaultValues }) => {
margin: false, margin: false,
amount: false, amount: false,
priceTaxRate: false, priceTaxRate: false,
overrideCost: false,
overridePrice: false,
vendor: false, vendor: false,
parts: false parts: false
}} }}
@ -48,49 +54,18 @@ const NewProductSku = ({ onOk, reset, defaultValues }) => {
<ObjectInfo <ObjectInfo
type='productSku' type='productSku'
column={1} column={1}
labelWidth={100} labelWidth={120}
visibleProperties={{ visibleProperties={{
_id: false, overrideCost: true,
createdAt: false, cost: true,
updatedAt: false, costTaxRate: true,
barcode: false, costWithTax: true,
product: false, overridePrice: true,
name: false, priceMode: true,
description: false, price: true,
parts: false margin: true,
}} priceTaxRate: true,
bordered={false} priceWithTax: true
isEditing={true}
objectData={objectData}
/>
)
},
{
title: 'Parts',
key: 'parts',
content: (
<ObjectInfo
type='productSku'
column={1}
labelWidth={100}
visibleProperties={{
_id: false,
createdAt: false,
updatedAt: false,
barcode: false,
product: false,
name: false,
description: false,
priceMode: false,
cost: false,
costWithTax: false,
costTaxRate: false,
price: false,
priceWithTax: false,
margin: false,
amount: false,
priceTaxRate: false,
vendor: false
}} }}
bordered={false} bordered={false}
isEditing={true} isEditing={true}
@ -127,9 +102,10 @@ const NewProductSku = ({ onOk, reset, defaultValues }) => {
createdAt: false, createdAt: false,
updatedAt: false, updatedAt: false,
_id: false, _id: false,
_reference: false _reference: false,
parts: false
}} }}
labelWidth={100} labelWidth={120}
bordered={false} bordered={false}
isEditing={false} isEditing={false}
objectData={objectData} objectData={objectData}

View File

@ -197,7 +197,7 @@ const ProductInfo = () => {
}} }}
reset={newProductSkuOpen} reset={newProductSkuOpen}
defaultValues={{ defaultValues={{
product: productId ? { _id: productId } : undefined product: objectFormState?.objectData || undefined
}} }}
/> />
</Modal> </Modal>

View File

@ -75,7 +75,17 @@ export const PartSku = {
'createdAt', 'createdAt',
'updatedAt' 'updatedAt'
], ],
filters: ['_id', 'barcode', 'part', 'part._id', 'name', 'cost', 'costWithTax', 'price', 'priceWithTax'], filters: [
'_id',
'barcode',
'part',
'part._id',
'name',
'cost',
'costWithTax',
'price',
'priceWithTax'
],
sorters: [ sorters: [
'barcode', 'barcode',
'part', 'part',
@ -152,54 +162,44 @@ export const PartSku = {
type: 'text', type: 'text',
columnWidth: 200 columnWidth: 200
}, },
{
name: 'priceMode',
label: 'Price Mode',
required: false,
type: 'priceMode',
columnWidth: 150
},
{ {
name: 'overrideCost', name: 'overrideCost',
label: 'Override Cost', label: 'Override Cost',
required: false, required: true,
type: 'bool', type: 'bool',
value: (objectData) => objectData?.overrideCost ?? false,
columnWidth: 150
},
{
name: 'overridePrice',
label: 'Override Price',
required: false,
type: 'bool',
value: (objectData) => objectData?.overridePrice ?? false,
columnWidth: 150 columnWidth: 150
}, },
{ {
name: 'cost', name: 'cost',
label: 'Cost', label: 'Cost',
required: false, required: true,
type: 'number', type: 'number',
prefix: '£', prefix: '£',
min: 0, min: 0,
step: 0.01, step: 0.01,
disabled: (objectData) => !objectData?.overrideCost, visible: (objectData) => {
return objectData?.overrideCost
},
value: (objectData) => value: (objectData) =>
objectData?.overrideCost ? objectData?.cost : undefined, objectData?.overrideCost ? objectData?.cost : objectData?.part?.cost,
columnWidth: 100 columnWidth: 100
}, },
{ {
name: 'costWithTax', name: 'costWithTax',
label: 'Cost w/ Tax', label: 'Cost w/ Tax',
required: false, required: true,
readOnly: true, readOnly: true,
type: 'number', type: 'number',
prefix: '£', prefix: '£',
min: 0, min: 0,
step: 0.01, step: 0.01,
disabled: (objectData) => !objectData?.overrideCost, visible: (objectData) => {
return objectData?.overrideCost
},
value: (objectData) => { value: (objectData) => {
if (!objectData?.overrideCost) return undefined if (!objectData?.overrideCost)
return objectData?.part?.costWithTax || undefined
const cost = objectData?.cost const cost = objectData?.cost
const taxRate = objectData?.costTaxRate const taxRate = objectData?.costTaxRate
if (!cost) return 0 if (!cost) return 0
@ -215,28 +215,58 @@ export const PartSku = {
{ {
name: 'costTaxRate', name: 'costTaxRate',
label: 'Cost Tax Rate', label: 'Cost Tax Rate',
required: false, required: true,
type: 'object', type: 'object',
objectType: 'taxRate', objectType: 'taxRate',
showHyperlink: true, showHyperlink: true,
disabled: (objectData) => !objectData?.overrideCost, visible: (objectData) => {
return objectData?.overrideCost
},
value: (objectData) => value: (objectData) =>
objectData?.overrideCost ? objectData?.costTaxRate : undefined, objectData?.overrideCost
? objectData?.costTaxRate
: objectData?.part?.costTaxRate,
columnWidth: 150
},
{
name: 'overridePrice',
label: 'Override Price',
required: true,
type: 'bool',
columnWidth: 150
},
{
name: 'priceMode',
label: 'Price Mode',
required: true,
visible: (objectData) => {
return objectData?.overridePrice
},
value: (objectData) => {
return objectData?.overridePrice
? objectData?.priceMode
: objectData?.part?.priceMode
},
type: 'priceMode',
columnWidth: 150 columnWidth: 150
}, },
{ {
name: 'price', name: 'price',
label: 'Price', label: 'Price',
required: false, required: true,
type: 'number', type: 'number',
prefix: '£', prefix: '£',
min: 0, min: 0,
step: 0.1, step: 0.1,
disabled: (objectData) => !objectData?.overridePrice, fixedNumber: 2,
visible: (objectData) => {
return objectData?.overridePrice
},
readOnly: (objectData) => readOnly: (objectData) =>
objectData?.overridePrice && objectData?.priceMode == 'margin', objectData?.overridePrice && objectData?.priceMode == 'margin',
value: (objectData) => { value: (objectData) => {
if (!objectData?.overridePrice) return undefined if (!objectData?.overridePrice)
return objectData?.part?.price || undefined
const priceMode = objectData?.priceMode ?? objectData?.part?.priceMode const priceMode = objectData?.priceMode ?? objectData?.part?.priceMode
const cost = objectData?.overrideCost const cost = objectData?.overrideCost
? objectData?.cost ? objectData?.cost
@ -248,7 +278,7 @@ export const PartSku = {
margin !== null && margin !== null &&
cost != null cost != null
) { ) {
return (cost * (1 + margin / 100)).toFixed(2) || undefined return cost * (1 + margin / 100) || undefined
} }
return objectData?.price return objectData?.price
}, },
@ -257,15 +287,18 @@ export const PartSku = {
{ {
name: 'priceWithTax', name: 'priceWithTax',
label: 'Price w/ Tax', label: 'Price w/ Tax',
required: false, required: true,
readOnly: true, readOnly: true,
type: 'number', type: 'number',
prefix: '£', prefix: '£',
min: 0, min: 0,
step: 0.01, step: 0.01,
disabled: (objectData) => !objectData?.overridePrice, visible: (objectData) => {
return objectData?.overridePrice
},
value: (objectData) => { value: (objectData) => {
if (!objectData?.overridePrice) return undefined if (!objectData?.overridePrice)
return objectData.part?.priceWithTax || undefined
let price let price
const priceMode = objectData?.priceMode ?? objectData?.part?.priceMode const priceMode = objectData?.priceMode ?? objectData?.part?.priceMode
const cost = objectData?.overrideCost const cost = objectData?.overrideCost
@ -292,28 +325,51 @@ export const PartSku = {
{ {
name: 'margin', name: 'margin',
label: 'Margin', label: 'Margin',
required: false, required: true,
type: 'number', type: 'number',
disabled: (objectData) => visible: (objectData) => {
!objectData?.overridePrice || objectData?.priceMode == 'amount', return objectData?.overridePrice
},
readOnly: (objectData) => {
const priceMode = objectData?.priceMode ?? objectData?.part?.priceMode
return priceMode == 'amount'
},
suffix: '%', suffix: '%',
min: 0, min: 0,
max: 100, max: 100,
step: 0.01, step: 0.01,
value: (objectData) => value: (objectData) => {
objectData?.overridePrice ? objectData?.margin : undefined, if (!objectData?.overridePrice)
return objectData?.part?.margin || undefined
const priceMode = objectData?.priceMode ?? objectData?.part?.priceMode
const cost = objectData?.overrideCost
? objectData?.cost
: objectData?.part?.cost
if (priceMode == 'amount') {
const price = objectData?.price
if (price != null && cost != null) {
return Number(((price / cost - 1) * 100).toFixed(2)) || undefined
}
return undefined
}
return objectData?.margin ?? objectData?.part?.margin
},
columnWidth: 85 columnWidth: 85
}, },
{ {
name: 'priceTaxRate', name: 'priceTaxRate',
label: 'Price Tax Rate', label: 'Price Tax Rate',
required: false, required: true,
type: 'object', type: 'object',
objectType: 'taxRate', objectType: 'taxRate',
showHyperlink: true, showHyperlink: true,
disabled: (objectData) => !objectData?.overridePrice, visible: (objectData) => {
return objectData?.overridePrice
},
value: (objectData) => value: (objectData) =>
objectData?.overridePrice ? objectData?.priceTaxRate : undefined, objectData?.overridePrice
? objectData?.priceTaxRate
: objectData?.part?.priceTaxRate,
columnWidth: 150 columnWidth: 150
} }
] ]

View File

@ -163,54 +163,45 @@ export const ProductSku = {
type: 'text', type: 'text',
columnWidth: 200 columnWidth: 200
}, },
{
name: 'priceMode',
label: 'Price Mode',
required: false,
type: 'priceMode',
columnWidth: 150
},
{ {
name: 'overrideCost', name: 'overrideCost',
label: 'Override Cost', label: 'Override Cost',
required: false, required: true,
type: 'bool', type: 'bool',
value: (objectData) => objectData?.overrideCost ?? false,
columnWidth: 150
},
{
name: 'overridePrice',
label: 'Override Price',
required: false,
type: 'bool',
value: (objectData) => objectData?.overridePrice ?? false,
columnWidth: 150 columnWidth: 150
}, },
{ {
name: 'cost', name: 'cost',
label: 'Cost', label: 'Cost',
required: false, required: true,
type: 'number', type: 'number',
prefix: '£', prefix: '£',
min: 0, min: 0,
step: 0.01, step: 0.01,
disabled: (objectData) => !objectData?.overrideCost, visible: (objectData) => {
return objectData?.overrideCost
},
value: (objectData) => value: (objectData) =>
objectData?.overrideCost ? objectData?.cost : undefined, objectData?.overrideCost
? objectData?.cost
: objectData?.product?.cost,
columnWidth: 100 columnWidth: 100
}, },
{ {
name: 'costWithTax', name: 'costWithTax',
label: 'Cost w/ Tax', label: 'Cost w/ Tax',
required: false, required: true,
readOnly: true, readOnly: true,
type: 'number', type: 'number',
prefix: '£', prefix: '£',
min: 0, min: 0,
step: 0.01, step: 0.01,
disabled: (objectData) => !objectData?.overrideCost, visible: (objectData) => {
return objectData?.overrideCost
},
value: (objectData) => { value: (objectData) => {
if (!objectData?.overrideCost) return undefined if (!objectData?.overrideCost)
return objectData?.product?.costWithTax || undefined
const cost = objectData?.cost const cost = objectData?.cost
const taxRate = objectData?.costTaxRate const taxRate = objectData?.costTaxRate
if (!cost) return 0 if (!cost) return 0
@ -226,28 +217,58 @@ export const ProductSku = {
{ {
name: 'costTaxRate', name: 'costTaxRate',
label: 'Cost Tax Rate', label: 'Cost Tax Rate',
required: false, required: true,
type: 'object', type: 'object',
objectType: 'taxRate', objectType: 'taxRate',
showHyperlink: true, showHyperlink: true,
disabled: (objectData) => !objectData?.overrideCost, visible: (objectData) => {
return objectData?.overrideCost
},
value: (objectData) => value: (objectData) =>
objectData?.overrideCost ? objectData?.costTaxRate : undefined, objectData?.overrideCost
? objectData?.costTaxRate
: objectData?.product?.costTaxRate,
columnWidth: 150
},
{
name: 'overridePrice',
label: 'Override Price',
required: true,
type: 'bool',
columnWidth: 150
},
{
name: 'priceMode',
label: 'Price Mode',
required: true,
visible: (objectData) => {
return objectData?.overridePrice
},
value: (objectData) => {
return objectData?.overridePrice
? objectData?.priceMode
: objectData?.product?.priceMode
},
type: 'priceMode',
columnWidth: 150 columnWidth: 150
}, },
{ {
name: 'price', name: 'price',
label: 'Price', label: 'Price',
required: false, required: true,
type: 'number', type: 'number',
prefix: '£', prefix: '£',
min: 0, min: 0,
step: 0.1, step: 0.1,
disabled: (objectData) => !objectData?.overridePrice, fixedNumber: 2,
visible: (objectData) => {
return objectData?.overridePrice
},
readOnly: (objectData) => readOnly: (objectData) =>
objectData?.overridePrice && objectData?.priceMode == 'margin', objectData?.overridePrice && objectData?.priceMode == 'margin',
value: (objectData) => { value: (objectData) => {
if (!objectData?.overridePrice) return undefined if (!objectData?.overridePrice)
return objectData?.product?.price || undefined
const priceMode = const priceMode =
objectData?.priceMode ?? objectData?.product?.priceMode objectData?.priceMode ?? objectData?.product?.priceMode
const cost = objectData?.overrideCost const cost = objectData?.overrideCost
@ -260,7 +281,7 @@ export const ProductSku = {
margin !== null && margin !== null &&
cost != null cost != null
) { ) {
return (cost * (1 + margin / 100)).toFixed(2) || undefined return cost * (1 + margin / 100) || undefined
} }
return objectData?.price return objectData?.price
}, },
@ -269,15 +290,18 @@ export const ProductSku = {
{ {
name: 'priceWithTax', name: 'priceWithTax',
label: 'Price w/ Tax', label: 'Price w/ Tax',
required: false, required: true,
readOnly: true, readOnly: true,
type: 'number', type: 'number',
prefix: '£', prefix: '£',
min: 0, min: 0,
step: 0.01, step: 0.01,
disabled: (objectData) => !objectData?.overridePrice, visible: (objectData) => {
return objectData?.overridePrice
},
value: (objectData) => { value: (objectData) => {
if (!objectData?.overridePrice) return undefined if (!objectData?.overridePrice)
return objectData.product?.priceWithTax || undefined
let price let price
const priceMode = const priceMode =
objectData?.priceMode ?? objectData?.product?.priceMode objectData?.priceMode ?? objectData?.product?.priceMode
@ -305,28 +329,53 @@ export const ProductSku = {
{ {
name: 'margin', name: 'margin',
label: 'Margin', label: 'Margin',
required: false, required: true,
type: 'number', type: 'number',
disabled: (objectData) => visible: (objectData) => {
!objectData?.overridePrice || objectData?.priceMode == 'amount', return objectData?.overridePrice
},
readOnly: (objectData) => {
const priceMode =
objectData?.priceMode ?? objectData?.product?.priceMode
return priceMode == 'amount'
},
suffix: '%', suffix: '%',
min: 0, min: 0,
max: 100, max: 100,
step: 0.01, step: 0.01,
value: (objectData) => value: (objectData) => {
objectData?.overridePrice ? objectData?.margin : undefined, if (!objectData?.overridePrice)
return objectData?.product?.margin || undefined
const priceMode =
objectData?.priceMode ?? objectData?.product?.priceMode
const cost = objectData?.overrideCost
? objectData?.cost
: objectData?.product?.cost
if (priceMode == 'amount') {
const price = objectData?.price
if (price != null && cost != null) {
return Number(((price / cost - 1) * 100).toFixed(2)) || undefined
}
return undefined
}
return objectData?.margin ?? objectData?.product?.margin
},
columnWidth: 85 columnWidth: 85
}, },
{ {
name: 'priceTaxRate', name: 'priceTaxRate',
label: 'Price Tax Rate', label: 'Price Tax Rate',
required: false, required: true,
type: 'object', type: 'object',
objectType: 'taxRate', objectType: 'taxRate',
showHyperlink: true, showHyperlink: true,
disabled: (objectData) => !objectData?.overridePrice, visible: (objectData) => {
return objectData?.overridePrice
},
value: (objectData) => value: (objectData) =>
objectData?.overridePrice ? objectData?.priceTaxRate : undefined, objectData?.overridePrice
? objectData?.priceTaxRate
: objectData?.product?.priceTaxRate,
columnWidth: 150 columnWidth: 150
}, },
{ {