Service - Sell Offer Plan: Difference between revisions
(35 intermediate revisions by the same user not shown) | |||
Line 43: | Line 43: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
== | == LogicalResultsMain == | ||
[[Standard LogicalResults Per Service|LogicalResultsMain]] | |||
== LogicalResultsData == | |||
[[Standard LogicalResults Per Service|LogicalResultsData]] | |||
== LogicalAwaitingStep == | |||
== | |||
[[NPM module - izara-shared|AwaitingStep]] | |||
== FindDataMain == | |||
[[Standard FindData Per Service|FindDataMain]] | |||
== | == FindDataAwaitingStep == | ||
[[NPM module - izara-shared|AwaitingStep]] | |||
== FindDataSortedRequest == | |||
[[Standard FindData Per Service|FindDataSortedRequest]] | |||
= Graph database = | = Graph database = | ||
Line 250: | Line 83: | ||
}, | }, | ||
currencyId: { | currencyId: { | ||
immutable: true, // all added deliveryMethods must match | immutable: true, // all added deliveryMethods and sellOffers must match}, | ||
}, | }, | ||
}, | }, | ||
Line 300: | Line 133: | ||
addToCalculatedValuePerOrder: {}, // added once per order to the value after calculating delivery method price | addToCalculatedValuePerOrder: {}, // added once per order to the value after calculating delivery method price | ||
addToCalculatedValuePerUnit: {}, // added once per orderQuantity to the value after calculating delivery method price | addToCalculatedValuePerUnit: {}, // added once per orderQuantity to the value after calculating delivery method price | ||
valueType: "xx", // orderQuantity| | valueType: "xx", // orderQuantity|orderSubtotal|productAttributeId|sellOfferTermId, if set overwrites deliveryMethod defaultValueType | ||
valueId: "xx", // if set overwrites deliveryMethod defaultValueId (used for productAttributeId|sellOfferTermId) | valueId: "xx", // if set overwrites deliveryMethod defaultValueId (used for productAttributeId|sellOfferTermId) | ||
valueLanguageId: {}, // used for productAttributeId|sellOfferTermId, when finding attribute value need to set language to find | |||
accumulateValue: true // default: true, if set to false will find the largest value out of all sellOffers in the order | |||
}, | }, | ||
} | } | ||
Line 317: | Line 152: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
* if both oneTimePercentage and oneTimeAmount are set, applies oneTimePercentage first | * if both oneTimePercentage and oneTimeAmount are set, applies oneTimePercentage first | ||
* applies on to orderSubtotal + deliveryPrice | |||
==== sellOfferPlanSettings ==== | ==== sellOfferPlanSettings ==== | ||
Line 323: | Line 159: | ||
{ | { | ||
properties: { | properties: { | ||
combineWins: | combineWins: true, // true|false, default true | ||
}, | }, | ||
Line 356: | Line 169: | ||
<syntaxhighlight lang="JavaScript"> | <syntaxhighlight lang="JavaScript"> | ||
{ | { | ||
relationshipType: "{ | relationshipType: "{HAS_SELLOFFERPLAN_GRAPH_REL_TYPE}", // "has_sellOfferPlan" | ||
schema: { | schema: { | ||
elementCanBeRemoved: | elementCanBeRemoved: false, | ||
allPropertiesImmutable: true, | allPropertiesImmutable: true, | ||
restrictProperties: true, | restrictProperties: true, | ||
Line 428: | Line 241: | ||
relationshipType: "{SellOfferPlanLib.createIsDeliveryMethodGraphRelationshipType()}", // "is_deliveryMethod" | relationshipType: "{SellOfferPlanLib.createIsDeliveryMethodGraphRelationshipType()}", // "is_deliveryMethod" | ||
schema: { | schema: { | ||
elementCanBeRemoved: | elementCanBeRemoved: false, | ||
allPropertiesImmutable: true, | allPropertiesImmutable: true, | ||
restrictProperties: true, | restrictProperties: true, | ||
Line 442: | Line 255: | ||
relationshipType: "{SellOfferPlanLib.createIsUserPaymentMethodGraphRelationshipType()}", // "is_userPaymentMethod" | relationshipType: "{SellOfferPlanLib.createIsUserPaymentMethodGraphRelationshipType()}", // "is_userPaymentMethod" | ||
schema: { | schema: { | ||
elementCanBeRemoved: | elementCanBeRemoved: false, | ||
allPropertiesImmutable: true, | allPropertiesImmutable: true, | ||
restrictProperties: true, | restrictProperties: true, | ||
Line 470: | Line 283: | ||
logicalTag: "combineWins", | logicalTag: "combineWins", | ||
comparison: "true", | comparison: "true", | ||
}, | }, | ||
{ | { | ||
type: "complexFilter", | type: "complexFilter", | ||
complexFilter: { | complexFilter: { | ||
filterType: " | filterType: "managerUserPaymentMethod", | ||
// see [[Service - Payment Method | // see [[Service - Payment Method Manager|Complex Filter requests]] | ||
} | } | ||
}, | }, | ||
Line 493: | Line 294: | ||
type: "complexFilter", | type: "complexFilter", | ||
complexFilter: { | complexFilter: { | ||
filterType: " | filterType: "managerDeliveryMethod", | ||
// see [[Service - Delivery Method | // see [[Service - Delivery Method Manager|Complex Filter requests]] | ||
} | } | ||
}, | |||
... | |||
] | |||
} | |||
</syntaxhighlight> | |||
<syntaxhighlight lang="JavaScript"> | |||
{ | |||
// finds all combinations where the plan has both a deliveryMethodId and paymentMethodId from the given lists of deliveryMethodId and paymentMethodIds | |||
filterType: "planDeliveryPaymentCombination" //unique id is planDeliveryPaymentCombinationId | |||
type: "group", | |||
elements: | |||
[ | |||
{ | |||
type: "logical", | |||
logicalTag: "planDeliveryPaymentCombination", | |||
paymentMethodIds: [], | |||
deliveryMethodIds: [] | |||
}, | |||
{ | |||
//will find all PlanDeliveryPaymentCombinations for this sellOfferId | |||
type: "logical", | |||
logicalTag: "sellOfferId", | |||
comparison: "equals", | |||
value: {sellOfferId} | |||
}, | |||
{ | |||
//will find all PlanDeliveryPaymentCombinations for listed sellOfferIds | |||
type: "logical", | |||
logicalTag: "sellOfferIds", | |||
comparison: "equals", | |||
value: [] // array of sellOfferIds | |||
}, | }, | ||
... | ... | ||
Line 501: | Line 335: | ||
} | } | ||
</syntaxhighlight> | </syntaxhighlight> | ||
* planDeliveryPaymentCombinationId = {sellOfferPlanId}_{sellOfferPlanDeliveryMethodLinkId}_{sellOfferPlanPaymentMethodLinkId} | |||
== Translate Ids - userPaymentMethod and deliveryMethod to sellOfferPlan == | == Translate Ids - userPaymentMethod and deliveryMethod to sellOfferPlan == | ||
Line 512: | Line 348: | ||
Complex filter (filterType = sellOfferPlan) can find all sellOfferPlanIds that match a pricing comparison, eg minimumPrice < 100: | Complex filter (filterType = sellOfferPlan) can find all sellOfferPlanIds that match a pricing comparison, eg minimumPrice < 100: | ||
== Cart price == | == Cart price == | ||
Line 536: | Line 356: | ||
* For a range of (or all) paymentMethodIds / deliveryMethodIds, deliverToLocationIds / orderQuantity are fixed. | * For a range of (or all) paymentMethodIds / deliveryMethodIds, deliverToLocationIds / orderQuantity are fixed. | ||
== Presenting a product's price options == | == Presenting a product's price options == | ||
* For a range of (or all) paymentMethodIds / deliveryMethodIds, deliverToLocationIds / orderQuantity are fixed | * For a range of (or all) paymentMethodIds / deliveryMethodIds, deliverToLocationIds / orderQuantity are fixed | ||
* | |||
* | = Handling SellOfferPlanPrice errors = | ||
* | |||
* If a SellOfferPlanPrice has an error it's status is set to error | |||
* SellOfferPlanPrice's that are error do save into SellOfferPlanPriceRangePrice, so a SellOfferPlanPriceRange object can see all prices calculated, any requests at this level will need to filter out error prices | |||
* SellOfferPlanPrice's that are error do not save into FilteredSellOfferPlanPrice, they are ignored as they cannot be filtered effectively | |||
= Notes = | |||
* A Sell Offer Plan can link to multiple payment/delivery links, but those multiple links should not point to the same delivery/userpaymentmethod nodes, try to catch/validate this when creating new link nodes | |||
= Working documents = | = Working documents = |
Latest revision as of 09:32, 6 August 2023
Overview
A user's plan that connects a user's sell offer to any number of delivery method links and payment method links, and also to the sell offer's prices.
Each sell offer will have one plan, the plan controls the sell offer's prices, and many sell offers can point to the same plan (if they all share the same prices), so any change in price will mean a new sell offer plan.
The plan also links to delivery methods and payment methods using link nodes, so sell offers that use the same sell offer plan must offer the same delivery method and payment methods and their link settings.
Many sell offer plans can use the same delivery method links and payment method links, so if multiple sell offers have the same delivery and payment method settings but different prices, they can share the links but with separate sell offer plans + pricing.
Repository
https://bitbucket.org/izara-market-products/izara-market-products-sell-offer-plan
DynamoDB tables
Standard Config Table Per Service
Configuration tags
{
configTag: "DeliveryMethodManagerServiceName"
configKey: "DeliveryMethodManagerServiceName"
configValue: xxx // eg: "DeliveryMethodManager"
}
{
configTag: "PaymentMethodManagerServiceName"
configKey: "PaymentMethodManagerServiceName"
configValue: xxx // eg: "PaymentMethodManager"
}
{
configTag: "ProductGraphServiceName"
configKey: "ProductGraphServiceName"
configValue: xxx // eg: "ProductGraph"
}
LogicalResultsMain
LogicalResultsData
LogicalAwaitingStep
FindDataMain
FindDataAwaitingStep
FindDataSortedRequest
Graph database
Service - Products Graph
Nodes
{
nodeLabel: "{SellOfferPlanLib.SELLOFFERPLAN_GRAPH_NODE_LABEL}", // "sellOfferPlan"
schema: {
identifier: true,
restrictProperties: true,
restrictRelationships: true,
properties: {
sellOfferPlanId: {
identifier: true, // create unique id from request params and uniqueMessageId
},
userId: {
immutable: true, // a sellOfferPlan can only be used by one user (because links to their userPaymentMethods)
},
currencyId: {
immutable: true, // all added deliveryMethods and sellOffers must match},
},
},
}
}
{
nodeLabel: "{SellOfferPlanLib.SELLOFFERPLAN_DELIVERYMETHODLINK_GRAPH_NODE_LABEL}", // "sellOfferPlanDeliveryMethodLink"
schema: {
identifier: true,
restrictProperties: true,
restrictRelationships: true,
properties: {
sellOfferPlanDeliveryMethodLinkId: {
identifier: true, // create unique id from request params and uniqueMessageId
},
},
}
}
{
nodeLabel: "{SellOfferPlanLib.SELLOFFERPLAN_USERPAYMENTMETHODLINK_GRAPH_NODE_LABEL}", // "sellOfferPlanUserPaymentMethodLink"
schema: {
identifier: true,
restrictProperties: true,
restrictRelationships: true,
properties: {
sellOfferPlanUserPaymentMethodLinkId: {
identifier: true, // create unique id from request params and uniqueMessageId
},
},
}
}
Versioned data
sellOfferPlanDeliveryMethodLinkSettings
{
properties: {
addToRateTableValuePerOrder: {}, // added once per order to the value before calculating delivery method price
addToRateTableValuePerUnit: {}, // added once per orderQuantity to the value before calculating delivery method price
addToCalculatedValuePerOrder: {}, // added once per order to the value after calculating delivery method price
addToCalculatedValuePerUnit: {}, // added once per orderQuantity to the value after calculating delivery method price
valueType: "xx", // orderQuantity|orderSubtotal|productAttributeId|sellOfferTermId, if set overwrites deliveryMethod defaultValueType
valueId: "xx", // if set overwrites deliveryMethod defaultValueId (used for productAttributeId|sellOfferTermId)
valueLanguageId: {}, // used for productAttributeId|sellOfferTermId, when finding attribute value need to set language to find
accumulateValue: true // default: true, if set to false will find the largest value out of all sellOffers in the order
},
}
sellOfferPlanUserPaymentMethodLinkSettings
{
properties: {
oneTimePercentage: {}, // increase paymentMethod price by percentage
oneTimeAmount: {}, // increase paymentMethod price by set amount
},
}
- if both oneTimePercentage and oneTimeAmount are set, applies oneTimePercentage first
- applies on to orderSubtotal + deliveryPrice
sellOfferPlanSettings
{
properties: {
combineWins: true, // true|false, default true
},
}
Relationships
{
relationshipType: "{HAS_SELLOFFERPLAN_GRAPH_REL_TYPE}", // "has_sellOfferPlan"
schema: {
elementCanBeRemoved: false,
allPropertiesImmutable: true,
restrictProperties: true,
properties: {
originTimestamp: //timestamp the request to create/change this relationship was sent
},
}
}
- links a user to one of their sell offer plans
{
relationshipType: "{SellOfferPlanLib.createHasDeliveryMethodLinkGraphRelationshipType()}", // "has_deliveryMethodLink"
schema: {
elementCanBeRemoved: true,
allPropertiesImmutable: true,
restrictProperties: true,
properties: {
originTimestamp: //timestamp the request to create/change this relationship was sent
},
}
}
{
relationshipType: "{SellOfferPlanLib.createDisabledDeliveryMethodLinkGraphRelationshipType()}", // "disabled_deliveryMethodLink"
schema: {
elementCanBeRemoved: true,
allPropertiesImmutable: true,
restrictProperties: true,
properties: {
originTimestamp: //timestamp the request to create/change this relationship was sent
},
}
}
{
relationshipType: "{SellOfferPlanLib.createHasUserPaymentMethodLinkGraphRelationshipType()}", // "has_userPaymentMethodLink"
schema: {
elementCanBeRemoved: true,
allPropertiesImmutable: true,
restrictProperties: true,
properties: {
originTimestamp: //timestamp the request to create/change this relationship was sent
},
}
}
{
relationshipType: "{SellOfferPlanLib.createDisabledUserPaymentMethodLinkGraphRelationshipType()}", // "disabled_userPaymentMethodLink"
schema: {
elementCanBeRemoved: true,
allPropertiesImmutable: true,
restrictProperties: true,
properties: {
originTimestamp: //timestamp the request to create/change this relationship was sent
},
}
}
- many sell offer plans can link to one delivery method link, or one payment method link, this allows user to share settings in the link nodes across multiple sell offer plans
{
relationshipType: "{SellOfferPlanLib.createIsDeliveryMethodGraphRelationshipType()}", // "is_deliveryMethod"
schema: {
elementCanBeRemoved: false,
allPropertiesImmutable: true,
restrictProperties: true,
properties: {
originTimestamp: //timestamp the request to create/change this relationship was sent
},
}
}
{
relationshipType: "{SellOfferPlanLib.createIsUserPaymentMethodGraphRelationshipType()}", // "is_userPaymentMethod"
schema: {
elementCanBeRemoved: false,
allPropertiesImmutable: true,
restrictProperties: true,
properties: {
originTimestamp: //timestamp the request to create/change this relationship was sent
},
}
}
Complex Filter requests
{
filterType: "sellOfferPlan" //unique id is sellOfferPlanId
type: "group",
elements:
[
{
type: "logical",
logicalTag: "userId",
comparison: "equals",
value: "xx"
},
{
type: "logical",
logicalTag: "combineWins",
comparison: "true",
},
{
type: "complexFilter",
complexFilter: {
filterType: "managerUserPaymentMethod",
// see [[Service - Payment Method Manager|Complex Filter requests]]
}
},
{
type: "complexFilter",
complexFilter: {
filterType: "managerDeliveryMethod",
// see [[Service - Delivery Method Manager|Complex Filter requests]]
}
},
...
]
}
{
// finds all combinations where the plan has both a deliveryMethodId and paymentMethodId from the given lists of deliveryMethodId and paymentMethodIds
filterType: "planDeliveryPaymentCombination" //unique id is planDeliveryPaymentCombinationId
type: "group",
elements:
[
{
type: "logical",
logicalTag: "planDeliveryPaymentCombination",
paymentMethodIds: [],
deliveryMethodIds: []
},
{
//will find all PlanDeliveryPaymentCombinations for this sellOfferId
type: "logical",
logicalTag: "sellOfferId",
comparison: "equals",
value: {sellOfferId}
},
{
//will find all PlanDeliveryPaymentCombinations for listed sellOfferIds
type: "logical",
logicalTag: "sellOfferIds",
comparison: "equals",
value: [] // array of sellOfferIds
},
...
]
}
- planDeliveryPaymentCombinationId = {sellOfferPlanId}_{sellOfferPlanDeliveryMethodLinkId}_{sellOfferPlanPaymentMethodLinkId}
Translate Ids - userPaymentMethod and deliveryMethod to sellOfferPlan
- only find sellOfferPlanIds that have has_userPaymentMethodLink or has_deliveryMethodLink relationships (ignore disabled)
- bypasses link nodes (no complex filterType)
Calc pricing use cases
Complex filter
Complex filter (filterType = sellOfferPlan) can find all sellOfferPlanIds that match a pricing comparison, eg minimumPrice < 100:
Cart price
A cart has a fixed deliveryMethod and paymentMethod so no comparisons are needed across these, instead the array of sellOfferQuantities are sent to PriceCalc which returns the total price, per sellOffer price, orderQuantity, etc..
Presenting a sellOffer's price options
- For a range of (or all) paymentMethodIds / deliveryMethodIds, deliverToLocationIds / orderQuantity are fixed.
Presenting a product's price options
- For a range of (or all) paymentMethodIds / deliveryMethodIds, deliverToLocationIds / orderQuantity are fixed
Handling SellOfferPlanPrice errors
- If a SellOfferPlanPrice has an error it's status is set to error
- SellOfferPlanPrice's that are error do save into SellOfferPlanPriceRangePrice, so a SellOfferPlanPriceRange object can see all prices calculated, any requests at this level will need to filter out error prices
- SellOfferPlanPrice's that are error do not save into FilteredSellOfferPlanPrice, they are ignored as they cannot be filtered effectively
Notes
- A Sell Offer Plan can link to multiple payment/delivery links, but those multiple links should not point to the same delivery/userpaymentmethod nodes, try to catch/validate this when creating new link nodes