Hey,
I managed to do a module and it is working as I can see, but I need an event that start on order status change. In this case I need that when the order goes to "processing" it does a call to an API and add a tracking number to the order.
I thought in using the sales_order_save_after event, check if the order as changed to "processing" and if so do the call and add the tracking number. Idk if there is a better way to do this.
But the problem is that I can't manage to get the order information, if I try to do the invoice in the backoffice it sais that the invoice can't be saved at the moment.
In the module with the event sales_order_save_after I just have
<?php namespace Custom\onStatusChange\Observer; use Magento\Framework\Event\ObserverInterface; use Magento\Framework\Event\Observer; use Magento\Framework\App\Request\DataPersistorInterface; use Magento\Framework\App\ObjectManager; class StatusChange implements ObserverInterface { /** * * @param Observer $observer * @return $this */ public function execute(Observer $observer) { $order = $observer->getEvent()->getOrder(); $incrementId = $order->getIncrementId(); $writer = new \Zend\Log\Writer\Stream(BP . '/var/log/test.log'); $logger = new \Zend\Log\Logger(); $logger->addWriter($writer); $logger->info('Inc ID:'); $logger->info($incrementId); return $this; } }
Idk what's wrong.
Can someone help me with this?
Thanks
Solved! Go to Solution.
I managed to get it to work like
etc/events.xml
<?xml version="1.0"?> <config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:framework:Event/etc/events.xsd"> <event name="sales_order_save_after"> <observer name="on_status_change" instance="Custom\onStatusChange\Observer\StatusChange"/> </event> </config>
etc/module.xml
<?xml version="1.0"?> <config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:framework:Module/etc/module.xsd"> <module name="Custom_onOrderCreate" setup_version="1.0.0" /> </config>
register.php
<?php \Magento\Framework\Component\ComponentRegistrar::register( \Magento\Framework\Component\ComponentRegistrar::MODULE, 'Custom_onOrderCreate', __DIR__ );
Observer/StatusChange.php
<?php namespace Custom\onStatusChange\Observer; use Magento\Framework\Event\ObserverInterface; use Magento\Framework\Event\Observer; use Magento\Framework\App\Request\DataPersistorInterface; use Magento\Framework\App\ObjectManager; use Magento\Framework\Message\ManagerInterface; class StatusChange implements ObserverInterface { /** * @var ObjectManagerInterface */ protected $_objectManager; protected $messageManager; /** * @param \Magento\Framework\ObjectManagerInterface $objectManager */ public function __construct( \Magento\Framework\ObjectManagerInterface $objectManager, \Magento\Quote\Model\QuoteFactory $quoteFactory, \Magento\Sales\Model\Order $order, ManagerInterface $messageManager ) { $this->_objectManager = $objectManager; $this->messageManager = $messageManager; } public function execute(Observer $observer) { $order = $observer->getEvent()->getOrder(); if ($order instanceof \Magento\Framework\Model\AbstractModel) { if($order->getState() == 'processing') { Your code... } } } }
Probably most things on Observer/StatusChange.php are not needed but for now it is like this and runs when order it's saved, hope helps someone with problems creating this.
Thanks
Hi @rui_silva1 ,
Can you please check and follow below link solution. Hope this helps you.
Thanks!
------------
Problem solved? Click Accept as Solution!
Thanks!
So in my files is missing the:
etc/di.xml
Model/Plugin/Pluginname.php ?
What should I do in the plugin file?
Just this?
<?php namespace Custom\onStatusChange\Model\Plugin; class OrderStatePlugin implements ObserverInterface { /** * @param \Magento\Sales\Api\OrderRepositoryInterface $subject * @param \Magento\Sales\Api\Data\OrderInterface $result * @return mixed * @throws \Exception */ public function afterSave( \Magento\Sales\Api\OrderRepositoryInterface $subject, $result ) { if($result->getState() == Order::STATE_COMPLETE) { ...... } return $result; } }
with the register.xml, etc/event.xml, etc/module.xml and the Observer/StatusChange.php?
What's the best way to test this?
Thanks!
I managed to get it to work like
etc/events.xml
<?xml version="1.0"?> <config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:framework:Event/etc/events.xsd"> <event name="sales_order_save_after"> <observer name="on_status_change" instance="Custom\onStatusChange\Observer\StatusChange"/> </event> </config>
etc/module.xml
<?xml version="1.0"?> <config xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="urn:magento:framework:Module/etc/module.xsd"> <module name="Custom_onOrderCreate" setup_version="1.0.0" /> </config>
register.php
<?php \Magento\Framework\Component\ComponentRegistrar::register( \Magento\Framework\Component\ComponentRegistrar::MODULE, 'Custom_onOrderCreate', __DIR__ );
Observer/StatusChange.php
<?php namespace Custom\onStatusChange\Observer; use Magento\Framework\Event\ObserverInterface; use Magento\Framework\Event\Observer; use Magento\Framework\App\Request\DataPersistorInterface; use Magento\Framework\App\ObjectManager; use Magento\Framework\Message\ManagerInterface; class StatusChange implements ObserverInterface { /** * @var ObjectManagerInterface */ protected $_objectManager; protected $messageManager; /** * @param \Magento\Framework\ObjectManagerInterface $objectManager */ public function __construct( \Magento\Framework\ObjectManagerInterface $objectManager, \Magento\Quote\Model\QuoteFactory $quoteFactory, \Magento\Sales\Model\Order $order, ManagerInterface $messageManager ) { $this->_objectManager = $objectManager; $this->messageManager = $messageManager; } public function execute(Observer $observer) { $order = $observer->getEvent()->getOrder(); if ($order instanceof \Magento\Framework\Model\AbstractModel) { if($order->getState() == 'processing') { Your code... } } } }
Probably most things on Observer/StatusChange.php are not needed but for now it is like this and runs when order it's saved, hope helps someone with problems creating this.
Thanks