On this page, it will be explained the below topics:
Table of Contents | ||||
---|---|---|---|---|
|
...
CRM UI Fulfilment Status vs Database Fulfilment Status
CRM UI Fulfilment Status | Database Fulfilment Status |
---|---|
New | 1 |
Sent | 2 |
Processed | 3 |
Error | 4 |
Canceled | 5 |
Removed | 6 |
Waiting for Tracking Number | 7 |
Backorder | 8 |
Processing | 9 |
Pending Tracking Number Email | 10 |
Sent Tracking Number Email | 11 |
Fatal Shipping Error | 12 |
Fatal Tracking Error | 13 |
Reprocess | 14 |
Fulfilment Workflow
Tip |
---|
Fulfilment is created three times dailyper day |
Selecting the orders that can be fulfilled
...
Check if there were any problems last time the system ran the orders, which need to be fulfilled, if any issue is spotted the system will correct the order(s)
Remove orders with email such as "test.com"
Remove orders with Partially Refunded status
Remove old fulfillments that have been set as Reship, as order status, and have a Fatal Shipping Error as fulfilment status
Set with a Backorders status, Partially Paid orders in order to request the full remaining payment from the customer
Set the order status to Shipping for orders with Paid status, Shipping error, Reshipping and Partially refunded
Set the fulfilment tatus status New (1), in order to prepare the system for the next step which is: to assign the warehouse
Fix old processed fulfillments – the system has a list of warehouse response errors, so in some cases, the system will automatically recover those fulfillments to the queue
Update the Inventory fields: Reserved New and Reserved Sent
...
Select all fulfillments with the status New (1) and without any previously assigned warehouse, grouping by email/zip code
Check if a warehouse is available (according to the shipping countries, available quantity, distance, and priority), then orders can fit one of the below scenarios:
...
For the warehouses that have automatic stock reconciliation, the inventory is updated and just continues if this process is successful
Create packages for fulfilment with the status New (1) and with assigned warehouse
Update fulfilment status to Processing (9)
DFO is the only one that group packages, which needs to comply with the below rules:
A single package may contain products of multiple fulfilments
It is necessary to limit the weight of the package (according to each warehouse)
If the warehouse limit weight per package is not null, use this value (Kg)
If the warehouse limit weight per package is null, the packages will not be split based on weight
The system will also try to group similar SKUs in the same package
Before sending the fulfillments to the warehouse, the availability of stock will be checked between the products in the package and the warehouse’s real-time stock quantity
When the warehouse's real-time inventory is not sufficient, the system sends these orders to the backorder
Right after the shipment, each warehouse returns a response via the API, which is handled according to the documentation for each warehouse
The result of the API is updated in the system can be:
If successful, the fulfilment will be set to status Sent (2)
If successful and the warehouse provide the tracking number in the same response, the fulfilment status is set to Processed (3)
If error, the fulfilment status will be set to Error (4)
Moreover, for all cases, the processing details field is filled in when available with additional information
The inventory is also updated again
Ultimately, the system checks the processing details looking for some warehouse’s duplicate answers (security) and in the case finds one or some, it updates the fulfilment process according to the response, so to avoid future errors.
Tracking Numbers information are is received four times a day
...
If something happens during the process of sending the orders to be fulfilled to the warehouse, and they have their fulfilment status set to Processing (9), the system will recover their status to New (1) so that it resumes processing on the next shipment.
Backorder Workflow
Tip |
---|
Backorders are processed four times per day |
4.Below are some of the reasons orders get status backorders.
1.
...
Insufficient stock quantity
...
at the Warehouses.
Sometimes fulfillments sent to the warehouses , but which are reject for know reasons, such as insufficient quantity, failure, rejected and others
4.1.2.Set fulfillment status to 8 – Backorder, add it to backorders and update orders status to 26 – Backorder, in addition to including notes in order notes for orders that do not have thank you cards
4.1.3.Remove thank you card reference
4.1.4.Re-submits orders without the thank you cart (set fulfillment status to 1 – New)
4.2. Reconcile Inventory
4.2.1. are rejected because of insufficient stock quantity, system failure or rejection, and so on.
Therefore, the system will set those fulfilments with the fulfilment status Backorder (8), as well as group them to backorders and update their order status to Backorder (26), and leave a note in the order notes.
2. Reconcile the Inventory
For warehouses that have stock conciliation, the available quantity is updated.4.
3.
...
Update Pre-Sale Inventory
4.3.1.Update WarehouseQuantityReservedPreSale Update the Warehouse Quantity Reserved PreSale field by deducting future sales backorders.4.
4.
...
Process unpaid partially paid orders
4.4.1.Feed the FutureSaleBackorders Future Sale Backorders table with orders that are Partially Paid, not yet charged, with stock available for that, so that we can request payment
4.5. Fix backorders
4.5.1. In cases where .
Processing the orders that are in backorders status
In cases, we had a problem during processing, the system ensures that we will proceed correctly
...
.
Remove any
...
eventual backorders that do not have fulfillments with status fulfilment status Backorder (8
...
)
Add to backorder table fulfillments with status Backorder (8
...
) that eventually
...
is not already in backorder
...
Updates the order status to Backorder (26
...
) for
...
orders that are in fulfilment status Backorder (8
...
) and whose orders are not yet in Backorder
...
Whenever the create fulfillments process fails, recreate the reshipments
4.6. Process backorders
...
Create fulfillments
Process orders with priority first, then the others4.6.2.Get dates to process (ascending order)
4.6.3.Select all backorder for each day, by priority adding Partially Paid orders that were paid
4.6.4.Grouping rule
4.6.4.1. Select all backlog backorders
1. Grouping rule
Active: group orders by email |
---|
...
Not active: do not apply any group rule |
---|
...
Try to find a warehouse available to
...
deliver the products.
...
Remove
...
Pre-sale
...
orders
...
which have
...
already a warehouse that can deliver them.
Set fulfillments status to New (1
...
) and assign the warehouse
...
Update the inventory
...
Update quantity reserved for pre-sale
...
Checks that there is no negative value for
...
4.6.11. Remove fulfillment from backorder’s table
...
the Pre-Sale reserved quantity and the available quantity
Remove fulfilments from the backorders table
Update order status to Shipping (3
...
4.7. Create fulfillments
4.7.1. See item 1
...
)
2. Remove from queue test orders
4.8.1. Set fulfillment Set the fulfilment status to Removed (6 – Removed ) from the queue where the customer name is an Automation or Tester or something like fake4.9. a dummy one.
3. Check duplicates
4.9.1.For security reasons, check if there are any fulfillments with the same shipping reference with the status not equal to Removed (6 – Removed ) from the queue.
4
...
.
...
Assign the warehouse
4.10.1. See item 2
...
5. Process orders with stock availability of 100%
...
4.11.1. Backorders group by email and all products available to for delivery4
6.
...
Reconcile inventory
4.12.1. For warehouses that have stock conciliation, the quantity available is update
III regularly updated
50% Rule - Orders with stock availability greater than 50%
This process is responsible for processing all pending orders in a specific situation
...
and this is why it is described separately from the above.
...
5.1.
Tip |
---|
In this case, orders are splitted into more packages as long as for the main order and its upsells there is stock availability greater than 51% so then at least one package of products is processed and sent first. The rest of goods will be fulfilled once the item is back in stock. |
For example, the main order has 3 units of EarPods on it and it has 2 upsells with one unit of EarPods each. By applying the 50% Rule, this order is fulfilled ONLY if at least 3 units of EarPods are available to be shipped in the first package. Then a second package will be sent, once the rest of the items are in stock.
How the fulfilment works with orders complying with the 50% Rule
Group all backorders by order number and related upsell order.5.2.
Check the increases in the warehouses since the last time that this process runs, to avoid process orders without available stock.
...
Check if there is an available warehouse
...
5.3.1.Must have available stock
...
, which must:
have stock availability
delivery in that country
...
If the delivery country is the US, CA or MX and the warehouse is in the US or CA the system will accept it as a valid warehouse
...
Check warehouse distance
...
Confirm that inventory is available in that selected warehouse
...
If the products
...
have:
Stock availability for which there is more than 50%
...
The SKU is in the exception list and with inventory available
...
Then, the fulfilment will be sent.
Set the fulfilment status to New (1) and add a note to
...
the orders notes section about this process
Remove the order from the Future Sales Backorder if necessary
...
Update order status to Shipping (3
...
)
Update CRM inventory
...
Remove from backorder
...
...
Check for any SKU exceptions that were not sent using this current warehouse
...
. However, if it exists, the system will choose the best warehouse according to the same rules above and
...
process it with the same actions to send this
...
CRM UI Fulfilment Status
...
Database Fulfilment Status
...
New
...
1
...
Sent
...
2
...
Processed
...
3
...
Error
...
4
...
5
...
6
...
Waiting for Tracking Number
...
7
...
8
...
Processing
...
fulfilment.