This plugin saves order events and allows you to display them in the order history as a timeline. It is based on state machine events.
Sylius Version | PHP Version |
---|---|
1.12 | 8.1 - 8.2 - 8.3 |
1.13 | 8.1 - 8.2 - 8.3 |
1.14 | 8.1 - 8.2 - 8.3 |
If you want to use our recipes, you can configure your composer.json by running:
composer config --no-plugins --json extra.symfony.endpoint '["https://api.github.com/repos/monsieurbiz/symfony-recipes/contents/index.json?ref=flex/master","flex://defaults"]'
Install the plugin via composer:
composer require monsieurbiz/sylius-order-history-plugin
Change your config/bundles.php
file to add this line for the plugin declaration:
<?php
return [
//..
MonsieurBiz\SyliusOrderHistoryPlugin\MonsieurBizSyliusOrderHistoryPlugin::class => ['all' => true],
];
Copy the plugin configuration files in your config
folder:
cp -Rv vendor/monsieurbiz/sylius-order-history-plugin/recipes/1.0/config/ config
In order to create dedicated tables for the plugin, don't forget to execute doctrine migration commands:
bin/console doctrine:migrations:migrate
Show any order on the Sylius backend and click on the top right History
button.
This plugin is based on the state machine events. It uses the native Winzou state machine callback system to save named order events when they are triggered.
# src/Resources/config/state_machine/checkout.yaml
winzou_state_machine:
sylius_order_checkout:
callbacks:
after:
monsieur_biz_order_history_notify_address:
on: 'address'
do: [ '@MonsieurBiz\SyliusOrderHistoryPlugin\Notifier\OrderHistoryWithAddressesDataNotifier', 'notifyEvent' ]
args: [ 'object', 'constant("MonsieurBiz\\SyliusOrderHistoryPlugin\\Entity\\OrderHistoryEventInterface::TYPE_CHECKOUT")', '"addressed"' ]
Callback dedicated notifier service / actions who add different details following context:
\MonsieurBiz\SyliusOrderHistoryPlugin\Notifier\OrderHistoryNotifier
is a basic notifier with no particular details except the given ones as parameters.\MonsieurBiz\SyliusOrderHistoryPlugin\Notifier\OrderHistoryWithAddressesDataNotifier
is a notifier dedicated to address events. It adds the billing and shipping address data.\MonsieurBiz\SyliusOrderHistoryPlugin\Notifier\ShipmentOrderHistoryNotifier
is a notifier dedicated to shipment events. It adds the shipment method name and the shipment state.\MonsieurBiz\SyliusOrderHistoryPlugin\Notifier\PaymentOrderHistoryNotifier
is a notifier dedicated to payment events. It adds the payment method name and the payment state.
- Add more details on existing events
- Add custom event in code
- Add custom event in state machine
- Add custom type and label display in history timeline
You can find a way to run the plugin without effort in the file DEVELOPMENT.md.
Then you can open an issue or a Pull Request if you want! 😘
Thank you!
This plugin is completely free and released under the MIT License.