Panel | ||||||||
---|---|---|---|---|---|---|---|---|
| ||||||||
For milestones to be calculated for an order, orchestration must take the delivery promise into account, to do so, orders must be orchestrated using a ruleset chaining instead of a ruleset. |
Table of Contents |
---|
Vocabulary
Anchor | ||||
---|---|---|---|---|
|
...
|
...
When are milestones
...
To exploit milestones during order's treatment, milestones must be used in the workflow. This allows to set milestones - considered that it has been reached - and set alerts if not reached in time.
Workflow
Info |
---|
All information regarding workflow actions can be found at Orders & workflows |
set_milestone : set the achieved milestone. If empty,
without_always_at_start
milestone is set (generally de case when initiating milestones in the graph).
For theset_milestone
action to work, the line item group must have stock location ID assigned. As a result, when placing aset_milestone
in the workflow it must be placed after assign origin actions.To make use of milestones, they must be stored for the order at each of its line_item_groups claimed transition. To do so, the action
set_milestone
has to be set in the claim transition of theline_item_groups
, if any..When recomputing, solutions with non-achieved milestones dates in the future (greater than now) will be considered as valid options. Those with dates in the past, will not be considered.
set_milestone_alert : Schedule alerts to be triggered at milestones cutoffs (plus a delay)
Notifications can be scheduled to be triggerd at the time of milestones cutoffs (plus a certain delay). When triggered, a validity check will be performed to ensure the specified milestone has not yet been reached/acheived. If already reached, notifications won't be triggered.
The time at which the notification will be triggered is the milestone cutoff of the first milestone stored in
order_delivery_promises
. Cutoffs are sorted based on the sort criteria configured for the site.
A special notification named
recompute_cutoffs_sets
can be called to recompute the cutoffs for each milestone.
Info |
---|
When recomputing cutoff sets, solutions with non-achieved milestones dates in the future (greater than now) will be considered as valid options. Those with dates in the past, will not be considered. |
When are milestones recalculated ?
All this scenarios impact the current delivery promise of the order.
Reservation change.
🤓eta_end
in the reservation changes or the reservation changes from one stock key to another.When a line item group gets claimed if
set_milestone
is set in the graph worfklow.
🤓 The currenteta_end
will be the one determined by the orchestration. The tolerance set in the ruleset chaining impacts the currenteta_end
.When an item is put or removed from a parcel. The current
eta_end
that's calculated is the one for the parcel as a whole.When the
recompute_cutoffs_sets
notification is sent by aset_milestone_alert
action.
Notifications
Milestones notifications are sent using a special rabbit queue. The project must have the following notification configured for notifications to work.
Code Block |
---|
lig_milestone_reached:
media:
rabbit:
- order_dp:lig_milestone_reached
time_type: duration
time_value: 0s |
Notification message example
...
title | Expand 🔽 |
---|
...
recalculated ?
All this scenarios impact the current delivery promise of the order.
Reservation change.
🤓eta_end
in the reservation changes or the reservation changes from one stock key to another.When a line item group gets claimed if
set_milestone
is set in the graph worfklow.
🤓 The currenteta_end
will be the one determined by the orchestration. The tolerance set in the ruleset chaining impacts the currenteta_end
.When an item is put or removed from a parcel. The current
eta_end
that's calculated is the one for the parcel as a whole.When the
recompute_cutoffs_sets
notification is sent by aset_milestone_alert
action.
Using milestones
To exploit milestones during order's treatment, milestones must be used in the workflow. This allows to set milestones - considered that it has been reached - and set alerts if not reached in time.
Minimum configuration requirements
To exploit milestones, the site must comply with the following :
Delivery promise in configured and a valid response can be recovered for delivery methods sent during order creation.
You should be able to recover a valid delivery promise response in the Delivery promise test page when sending a request containing : a basket that with all items in the order, an order price equal to the one sent for the order (order.pricing_details.price
), sales channel equal to the one sent for the order and delivery method equal to the one sent in the order.Orders are orchestrated using a ruleset chaining which enforces respect of delivery promise.
The orders workflow sets milestones for line item groups.
If your site complies with the above, milestones should be present for the order when recovering order delivery promises details this can be recovered by API through GET /orders/:id/delivery_promise/details
If you want to exploit milestones in the Store App the site must also :
Have a valid configuration in the Store App for displaying milestones in pages where they need to be displayed.
Activate milestones display at the stock location at which milestones should be displayed.
Workflow
Info |
---|
All information regarding workflow actions can be found at Orders & workflows |
set_milestone : set the achieved milestone. If empty,
without_always_at_start
milestone is set (generally de case when initiating milestones in the graph).
For theset_milestone
action to work, the line item group must have stock location ID assigned. As a result, when placing aset_milestone
in the workflow it must be placed after assign origin actions.To make use of milestones, they must be stored for the order at each of its line_item_groups claimed transition. To do so, the action
set_milestone
has to be set in the claim transition of theline_item_groups
, if any..When recomputing, solutions with non-achieved milestones dates in the future (greater than now) will be considered as valid options. Those with dates in the past, will not be considered.
set_milestone_alert : Schedule alerts to be triggered at milestones cutoffs (plus a delay)
Notifications can be scheduled to be triggerd at the time of milestones cutoffs (plus a certain delay). When triggered, a validity check will be performed to ensure the specified milestone has not yet been reached/acheived. If already reached, notifications won't be triggered.
The time at which the notification will be triggered is the milestone cutoff of the first milestone stored in
order_delivery_promises
. Cutoffs are sorted based on the sort criteria configured for the site.
A special notification named
recompute_cutoffs_sets
can be called to recompute the cutoffs for each milestone.
Info |
---|
When recomputing cutoff sets, solutions with non-achieved milestones dates in the future (greater than now) will be considered as valid options. Those with dates in the past, will not be considered. |
Notifications
Notifications can be triggered thanks to set_milestone_alert
order workflow action.
Its also possible to intercept internal delivery promise notifications sent when a milestone is reached. Milestones notifications are sent through an internal rabbit queue (order_dp:lig_milestone_reached
). To listen to messages, the site needs to have a notification configured as follows :
Code Block |
---|
lig_milestone_reached:
media:
rabbit:
- order_dp:lig_milestone_reached
time_type: duration
time_value: 0s |
Notification message example
Expand | ||
---|---|---|
| ||
|
Configuration example
Note |
---|
For the |
Workflow
Code Block | |||||||||||||||||||||||||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| |||||||||||||||||||||||||||||||||||
placed:
transitions:
|
Notifications
Code Block |
---|
lig_milestone_reached:
media:
rabbit:
- order_dp:lig_milestone_reached
time_type: duration
time_value: 0s |
Sorting cutoff sets
Multiple cutoff sets are calculated and consist of all the possible delivery options that can serve the order on time (promised delivery date + tolerance allowed by the orchestration ruleset chaining). See Vocabulary
Sorting criteria are defined to select the best options. The sorting is done in two steps:
among the cutoffs: sort all the cutoffs a given delivery route (so, for the same cost)
among the cutoffs sets: sort the best cutoffs of each delivery route.
This configuration is set on the configuration of the site (file or API):
Code Block | ||
---|---|---|
| ||
delivery_promise:
cutoffs_sets: # from v 10.1
use_sort_orders: true # if true: sorts cutoff sets using the delivery config's sort criteria. Cutoffs are sorted based on the below configuration default_sort_criteria>..>cutoffs.
sort_critera: # sort criteria to use (overrides use_sort_orders:true, but does not override criteria when specified in GET /cutoffs request)
eta_fulfilled: #in case there is no tolerance defined or tolerance is finite
cutoffs_sets: [ +cost_by_parcel, -carrier_pickup, +eta_end ] #cheapest, latest carrier pickup, fastest eta_end
cutoffs: [ -carrier_pickup, +eta_end ] #latest carrier pickup, fastest eta_end
eta_exceeded: #in case there is an infinite tolerance defined
cutoffs_sets: [ +cost_by_parcel, +eta_end ]
cutoffs: [ +eta_end, +carrier_pickup ]
default_sort_criteria: # default criteria to use when no sort orders
eta_fulfilled:
cutoffs_sets: [ +cost_by_parcel, -carrier_pickup, +eta_end ] #not used if use_sort_orders is true
cutoffs: [ -carrier_pickup, +eta_end ] #1st by latests carrier pickup, 2nd by fastests eta_end
eta_exceeded: #juste pour tolérance infinie
cutoffs_sets: [ +eta_end, +cost_by_parcel ] #not used if use_sort_orders is true
cutoffs: [ +eta_end, +carrier_pickup ] #1st by fastest eta_end, 2nd by latests carrier pickup. |
+
means ascending sorting (0, 1, 2, 3) — the smallest number or the earliest date will be selected
-
means descending sorting (3, 2, 1, 0) — the biggest number or the latest date will be selected
use_sort_orders
set to true
In this case, the cutoffs of a given delivery route will be sorted using the default_sort_criteria
for cutoffs
. After that, only the first cutoff of each delivery route will be considered. Then, the cutoff sets will be sorted following the sort option defined on the delivery configurations, in the Delivery screen in the backoffice.
use_sort_orders
set to false
In this case, the cutoffs of a given delivery route will be sorted using the sort_criteria
for cutoffs
. After that, only the first cutoff of each delivery route will be considered. Then, the cutoff sets will be sorted following the sort option defined on sort_criteria
for cutoffs_sets
.
Display the milestones on the store app
Select the pages and milestones to display
In the store app config, you need to add a delivery_promise key, with the list of pages where to display the milestones.
Pages supported:
pack
,bag
,reserve
,pack_scan
,bag_scan
Code Block | ||
---|---|---|
| ||
delivery_promise:
pack:
milestone: carrier_pickup
warning:
from: 600
to: 1800
bag:
milestone: carrier_pickup
warning:
from: 600
to: 1800
reserve:
milestone: carrier_pickup
warning:
from: 600
to: 1800 |
The warning indicates the period of time, in seconds, before the milestone, during which the remaining time will be showed as a warning, in orange. Before, the milestone is shown with no warning, and after it is shown in alert, in red.
Expand | |||||
---|---|---|---|---|---|
If the milestone is today at 17:00, and the configuration is:
|
Sorting cutoff sets
Multiple cutoff sets are calculated and consist of all the possible delivery options that can serve the order on time (promised delivery date + tolerance allowed by the orchestration ruleset chaining). See Vocabulary
Sorting criteria are defined to select the best options. The sorting is done in two steps:
among the cutoffs: sort all the cutoffs a given delivery route (so, for the same cost)
among the cutoffs sets: sort the best cutoffs of each delivery route.
This configuration is set on the configuration of the site (file or API):
Code Block | ||
---|---|---|
| ||
delivery_promise:
cutoffs_sets: # from v 10.1
use_sort_orders: true # if true: sorts cutoff sets using the delivery config's sort criteria. Cutoffs are sorted based on the below configuration default_sort_criteria>..>cutoffs.
sort_critera: # sort criteria to use (overrides use_sort_orders:true, but does not override criteria when specified in GET /cutoffs request)
eta_fulfilled: #in case there is no tolerance defined or tolerance is finite
cutoffs_sets: [ +cost_by_parcel, -carrier_pickup, +eta_end ] #cheapest, latest carrier pickup, fastest eta_end
cutoffs: [ -carrier_pickup, +eta_end ] #latest carrier pickup, fastest eta_end
eta_exceeded: #in case there is an infinite tolerance defined
cutoffs_sets: [ +cost_by_parcel, +eta_end ]
cutoffs: [ +eta_end, +carrier_pickup ]
default_sort_criteria: # default criteria to use when no sort orders
eta_fulfilled:
cutoffs_sets: [ +cost_by_parcel, -carrier_pickup, +eta_end ] #not used if use_sort_orders is true
cutoffs: [ -carrier_pickup, +eta_end ] #1st by latests carrier pickup, 2nd by fastests eta_end
eta_exceeded: #juste pour tolérance infinie
cutoffs_sets: [ +eta_end, +cost_by_parcel ] #not used if use_sort_orders is true
cutoffs: [ +eta_end, +carrier_pickup ] #1st by fastest eta_end, 2nd by latests carrier pickup. |
+
means ascending sorting (0, 1, 2, 3) — the smallest number or the earliest date will be selected
-
means descending sorting (3, 2, 1, 0) — the biggest number or the latest date will be selected
use_sort_orders
set to true
In this case, the cutoffs of a given delivery route will be sorted using the default_sort_criteria
for cutoffs
. After that, only the first cutoff of each delivery route will be considered. Then, the cutoff sets will be sorted following the sort option defined on the delivery configurations, in the Delivery screen in the backoffice.
use_sort_orders
set to false
In this case, the cutoffs of a given delivery route will be sorted using the sort_criteria
for cutoffs
. After that, only the first cutoff of each delivery route will be considered. Then, the cutoff sets will be sorted following the sort option defined on sort_criteria
for cutoffs_sets
.
Display the milestones on the store app
Select the pages and milestones to display
In the store app config, you need to add a delivery_promise key, with the list of pages where to display the milestones.
Pages supported: pack
, bag
, reserve
, pack_scan
, bag_scan
Code Block | ||
---|---|---|
| ||
delivery_promise:
pack:
milestone: carrier_pickup
warning:
from: 600
to: 1800
bag:
milestone: carrier_pickup
warning:
from: 600
to: 1800
reserve:
milestone: carrier_pickup
warning:
from: 600
to: 1800 |
The warning indicates the period of time, in seconds, before the milestone, during which the remaining time will be showed as a warning, in orange. Before, the milestone is shown with no warning, and after it is shown in alert, in red.
Expand | |||||
---|---|---|---|---|---|
If the milestone is today at 17:00, and the configuration is:
It means that the order will be displayed:
|
Pack page specific extra configuration
Info |
---|
For milestones to be displayed in the pack page, the following must be added to the store app config aswell |
Code Block |
---|
page_request_additional_fields:
pack: [parcel.cutoffs_sets] |
Turn on the display of milestone on the stock location
Your stock location must have a configuration to indicate that the milestones can be displayed.
You must configure this on the stock location (endpoint), by API (it is currently not available in the backoffice):
Code Block | ||
---|---|---|
| ||
"configurations": {
"delivery_promise": {
"milestones": true,
}
} |
Configuration example
Note |
---|
For the |
Workflow
Code Block | ||
---|---|---|
| ||
placed:
transitions:
claimed: # De placed à claimed (VI)
conditions:
actions_after:
- type: set_milestone
- type: set_milestone_alert
parameters:
milestone: packed
notifications:
- name: send_mail
delay: -300
params:
to: "tbaudon@onestock-retail.com"
claimed:
transitions:
packed: # De claimed à packed (VI)
conditions:
actions_after:
- type: set_milestone
parameters:
milestone : preparation #name depends on DP config
packed:
transitions:
dispatched: # De packed à dispatched (VI)
conditions:
actions_after:
- type: set_milestone
parameters:
milestone : carrier_pickup |
Store App
Code Block | ||
---|---|---|
| ||
delivery_promise: pack: milestone: carrier_pickup warning: from: 600 to: 1800 bag: milestone: carrier_pickup warning: from: 600 to: 1800 It means that the order will be displayed:
|
Turn on the display of milestone on the stock location
Your stock location must have a configuration to indicate that the milestones can be displayed.
...
reserve:
milestone: carrier_pickup
warning:
from: 600
to: 1800 |
Stock Locations
Code Block | ||
---|---|---|
| ||
"configurations": { "delivery_promise": { "milestonemilestones": true, } } |