A Shipment is a representation of a shipping request for an Order. Sylius can attach multiple shipments to each single Order. Shipment consists of ShipmentUnits, which are a representation of OrderItemUnits from its Order.
How is a Shipment created for an Order?¶
Read more about creating Orders where the process of assigning Shipments is clarified.
As mentioned in the beginning Sylius Order holds a collection of Shipments. In Sylius Plus edition Orders can be fulfilled partially, therefore it is possible to split the default Order’s shipment.
To do it Sylius Plus provides a UI, where you can choose which items from the initial shipments you’d like to extract to
a new split shipment and send it (providing a tracking code or not). Shipments of an Order can be split as long as
there remains one shipment in state
The Shipment State Machine¶
A Shipment that is attached to an Order will have its own state machine with the following states available:
The allowed transitions between these states are:
transitions: create: from: [cart] to: ready ship: from: [ready] to: shipped cancel: from: [ready] to: cancelled
ShippingMethod in Sylius is an entity that represents the way an order can be shipped to a customer.
How to create a ShippingMethod programmatically?¶
As usual use a factory to create a new ShippingMethod. Give it a
code, set a desired shipping calculator and set a
It also need a configuration, for instance of the amount (cost).
At the end add it to the system using a repository.
$shippingMethod = $this->container->get('sylius.factory.shipping_method')->createNew(); $shippingMethod->setCode('DHL'); $shippingMethod->setCalculator(DefaultCalculators::FLAT_RATE); $shippingMethod->setConfiguration(['channel_code' => ['amount' => 50]]); $zone = $this->container->get('sylius.repository.zone')->findOneByCode('US'); $shippingMethod->setZone($zone); $this->container->get('sylius.repository.shipping_method')->add($shippingMethod);
In order to have your shipping method available in checkout add it to a desired channel.
$channel = $this->container->get('sylius.repository.channel')->findOneByCode('channel_code'); $channel->addShippingMethod($shippingMethod);
Shipping method rules¶
The shipping method Rules restrict in what circumstances a shipping method is available. An appropriate RuleChecker (each Rule type has its own RuleChecker) may check if:
- All products belong to a certain taxon
- The order total is greater than a given amount
- The total weight is below a given number
- The total volume is below a given value
And many more similar, suitable to your needs.
The types of rules that are configured in Sylius by default are:
- Order total greater than or equal - checks if the order total is greater than or equal to a given amount
- Order total less than or equal - checks if the order total is less than or equal to a given amount
- Total weight greater than or equal - checks if the total weight of the order is greater than or equal to a given number
- Total weight less than or equal - checks if the total weight of the order is less than or equal to a given number
Sylius has an approach of Zones used also for shipping. As in each e-commerce you may be willing to ship only to certain countries for example. Therefore while configuring your ShippingMethods pay special attention to the zones you are assigning to them. You have to prepare methods for each zone, because the available methods are retrieved for the zone the customer has basing on his address.
Shipping Cost Calculators¶
The shipping cost calculators are services that are used to calculate the cost for a given shipment.
has a method
calculate() that takes object with a configuration and returns integer that is the cost of shipping for that subject.
It also has a
getType() method that works just like in the forms.
To select a proper service we have a one that decides for us - the DelegatingCalculator. Basing on the ShippingMethod assigned on the Shipment it will get its calculator type and configuration and calculate the cost properly.
$shippingCalculator = $this->container->get('sylius.shipping_calculator'); $cost = $shippingCalculator->calculate($shipment);
The already defined calculators in Sylius are described as constants in the SyliusComponentShippingCalculatorDefaultCalculators
- FlatRateCalculator - just returns the
amountfrom the ShippingMethod’s configuration.
- PerUnitRateCalculator - returns the
amountfrom the ShippingMethod’s configuration multiplied by the
Shipment complete events¶
There are two events that are triggered on the shipment