SynchronizeWebsiteAttributesOnStoreChange.php 1.4 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. <?php
  2. /**
  3. * Copyright © Magento, Inc. All rights reserved.
  4. * See COPYING.txt for license details.
  5. */
  6. namespace Magento\Catalog\Observer;
  7. use Magento\Catalog\Model\ResourceModel\Attribute\WebsiteAttributesSynchronizer;
  8. use Magento\Framework\Event\Observer;
  9. use Magento\Framework\Event\ObserverInterface;
  10. use Magento\Store\Model\Store;
  11. /**
  12. * Class SynchronizeWebsiteAttributesOnStoreChange
  13. * @package Magento\Catalog\Observer
  14. */
  15. class SynchronizeWebsiteAttributesOnStoreChange implements ObserverInterface
  16. {
  17. /**
  18. * @var WebsiteAttributesSynchronizer
  19. */
  20. private $synchronizer;
  21. /**
  22. * SynchronizeWebsiteAttributesOnStoreChange constructor.
  23. * @param WebsiteAttributesSynchronizer $synchronizer
  24. */
  25. public function __construct(WebsiteAttributesSynchronizer $synchronizer)
  26. {
  27. $this->synchronizer = $synchronizer;
  28. }
  29. /**
  30. * {@inheritdoc}
  31. */
  32. public function execute(Observer $observer)
  33. {
  34. $store = $observer->getData('data_object');
  35. if (!$store instanceof Store) {
  36. return;
  37. }
  38. if (!$store->hasDataChanges()) {
  39. return;
  40. }
  41. $isWebsiteIdChanged = $store->getOrigData('website_id') != $store->getWebsiteId();
  42. $isStoreNew = $store->isObjectNew();
  43. if ($isWebsiteIdChanged || $isStoreNew) {
  44. $this->synchronizer->scheduleSynchronization();
  45. }
  46. }
  47. }