forked from Sylius/Sylius
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Magdalena Sadowska
committed
Jan 22, 2020
1 parent
f8537b7
commit c3c8a03
Showing
8 changed files
with
145 additions
and
8 deletions.
There are no files selected for viewing
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,8 +1,13 @@ | ||
* :doc:`/book/products/products` | ||
* :doc:`/book/products/product_reviews` | ||
* :doc:`/book/products/product_associations` | ||
* :doc:`/book/products/attributes` | ||
* :doc:`/book/products/pricing` | ||
* :doc:`/book/products/taxons` | ||
* :doc:`/book/products/inventory` | ||
* :doc:`/book/products/search` | ||
.. raw:: html | ||
|
||
<ul class="simple"> | ||
<li><p><a class="reference internal" href="products.html"><span class="doc">Products</span></a></p></li> | ||
<li><p><a class="reference internal" href="product_reviews.html"><span class="doc">Product Reviews</span></a></p></li> | ||
<li><p><a class="reference internal" href="product_associations.html"><span class="doc">Product Associations</span></a></p></li> | ||
<li><p><a class="reference internal" href="attributes.html"><span class="doc">Attributes</span></a></p></li> | ||
<li><p><a class="reference internal" href="pricing.html"><span class="doc">Pricing</span></a></p></li> | ||
<li><p><a class="reference internal" href="taxons.html"><span class="doc">Taxons</span></a></p></li> | ||
<li><p><a class="reference internal" href="inventory.html"><span class="doc">Inventory</span></a></p></li> | ||
<li><p><a class="reference internal plus-feature" href="multi_source_inventory.html"><span class="doc">Multi-Source Inventory</span></a></p></li> | ||
<li><p><a class="reference internal" href="search.html"><span class="doc">Search</span></a></p></li> | ||
</ul> |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,130 @@ | ||
.. rst-class:: plus-doc | ||
|
||
Multi-Source Inventory | ||
====================== | ||
|
||
Sylius Plus has a much more complex approach to inventory management than the open source version. Unlike the open source | ||
version, that allows to specify one stock amount value for each variant, the Sylius Plus Multi-Source Inventory gives you | ||
a possibility to create several Inventory Sources and specify different stock amounts of variants for different Inventory Sources. | ||
|
||
Admin can create multiple Inventory Sources (IS). For each IS they can choose Channels it will be available for. | ||
Let's say you have 2 channels - "DACH" and "France", and you have three magazines in Paris, in Berlin, and in Vienna, | ||
so you'd probably want the "France" channel to be fulfilled from the Parisian magazine only. | ||
|
||
The experience for the Customer is seamless, they are not aware of multiple magazines, their orders are fulfilled just | ||
like it was. As an Administrator, you will additionally see which Inventory Source was chosen for the Order's shipment | ||
to be fulfilled from. The system is prepared to be supporting shipments splitting on one order and fulfilling from multiple | ||
magazines in the near future. | ||
|
||
Inventory Source | ||
---------------- | ||
|
||
Inventory Source is the place from which a shipment of an order will be shipped from, it can be understood as a magazine, | ||
a fulfillment centre, physical store etc. | ||
|
||
Administrators can add, modify and remove Inventory Sources in the admin panel. | ||
|
||
.. image:: ../../_images/sylius_plus/inventory_sources_index.png | ||
:align: center | ||
|
||
Each IS has its own inventory management page, where you can manage stock levels of all items available int his inventory. | ||
|
||
.. image:: ../../_images/sylius_plus/inventory_source_stock_management.png | ||
:align: center | ||
|
||
In order to make a product tracked within an Inventory Source, you have to go to it's ProductVariant's Inventory tab on the edit page. | ||
|
||
.. image:: ../../_images/sylius_plus/product_variant_stock_management.png | ||
:align: center | ||
|
||
After an Order with tracked products is placed you will see from which IS its Shipment should be shipped. | ||
|
||
.. image:: ../../_images/sylius_plus/inventory_source_shipment.png | ||
:align: center | ||
|
||
InventorySourceStock on ProductVariant | ||
-------------------------------------- | ||
|
||
Each simple Product and each Product Variant of a configurable Product can have stock in the Inventory Sources available | ||
for channels the product is available in. You can specify stocks on products and then manage them also in the Inventory section, | ||
where you will see the inventory of each IS separately. | ||
|
||
``inventorySourceStock`` is a property that behaves exactly like the ``stockAmount`` field you know from open source single-source | ||
inventory, so it has both ``onHand`` and ``onHold`` values that are modified when Orders are placed and fulfilled in your shop. | ||
|
||
The tracking of a Product can be disabled. | ||
|
||
Inventory Source resolving | ||
-------------------------- | ||
|
||
The current implementation provides one main resolver, that can use multiple inventory sources filters. | ||
|
||
There are two filters provided by default: | ||
|
||
* *Sufficient*, with ``priority = 0``, that provides all inventory sources able to handle all ordered products; | ||
* *EnabledChannel*, with ``priority = 8``, that provides inventory sources enabled for the current channel; | ||
|
||
Filters always return an array of inventory sources, however resolver picks the first of them or throws an | ||
``UnresolvedInventorySource`` exception if no inventory source can be resolved. | ||
|
||
It's possible to add more inventory sources filter, with higher or lower priority. Such a service must implement Sylius\Plus\Inventory\Application\Filter\InventorySourcesFilterInterface and be registered with sylius_plus.inventory.inventory_sources_filter tag, with priority attribute set. | ||
|
||
.. note:: | ||
|
||
How to create a custom Inventory Sources Filter? Read :doc:`this Cookbook </cookbook/index>`. | ||
|
||
Inventory API | ||
------------- | ||
|
||
The synchronization of Inventory Source stock levels can be done via API: you can send an API request to Sylius with | ||
inventory stocks in a chosen IS for chosen products and get them updated. This allows for straightforward integration | ||
with your ERP & WMS systems. | ||
|
||
Sylius Plus provides a route that allows changing inventory source stock with an API call: | ||
|
||
.. code-block:: bash | ||
$ POST /api/v1/inventory-sources/{code}/update-stocks | ||
The ``code`` is a code of inventory source on which stock is to be updated. Content of the request should contain an array | ||
of updated stocks, with the product variant code and target on hand value. | ||
|
||
Example: | ||
|
||
.. code-block:: json | ||
{ | ||
"stocks": [ | ||
{ | ||
"productVariantCode": "LASER_SWORD", | ||
"onHand": 20 | ||
}, | ||
{ | ||
"productVariantCode": "LIGHT_SABRE", | ||
"onHand": 15 | ||
} | ||
] | ||
} | ||
.. warning:: | ||
|
||
To use the Sylius Plus API, you need to be authorized as an administrator with the ``ROLE_API_ACCESS`` role. | ||
Check out the :doc:`API Authorization chapter </api/authorization>`. | ||
|
||
How does Multi-Source Inventory work on examples? | ||
------------------------------------------------- | ||
|
||
.. tip:: | ||
|
||
You can see all use cases we have designed in Sylius Plus by browsing the Behat scenarios for inventory in the vendor package | ||
after installing Sylius Plus. | ||
|
||
Learn more | ||
---------- | ||
|
||
* :doc:`Order concept documentation </book/orders/orders>` | ||
* :doc:`Single Source Inventory concept documentation </book/products/inventory>` | ||
|
||
.. image:: ../../_images/sylius_plus/banner.png | ||
:align: center | ||
:target: http://sylius.com/plus/?utm_source=docs |