CheckThemeIsAssignedObserver.php 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  1. <?php
  2. /**
  3. * Copyright © Magento, Inc. All rights reserved.
  4. * See COPYING.txt for license details.
  5. */
  6. namespace Magento\Theme\Observer;
  7. use Magento\Framework\Event\Observer as EventObserver;
  8. use Magento\Framework\Event\ObserverInterface;
  9. use Magento\Theme\Model\Theme;
  10. class CheckThemeIsAssignedObserver implements ObserverInterface
  11. {
  12. /**
  13. * @var \Magento\Theme\Model\Config\Customization
  14. */
  15. protected $themeConfig;
  16. /**
  17. * @var \Magento\Framework\Event\ManagerInterface
  18. */
  19. protected $eventDispatcher;
  20. /**
  21. * @param \Magento\Theme\Model\Config\Customization $themeConfig
  22. * @param \Magento\Framework\Event\ManagerInterface $eventDispatcher
  23. */
  24. public function __construct(
  25. \Magento\Theme\Model\Config\Customization $themeConfig,
  26. \Magento\Framework\Event\ManagerInterface $eventDispatcher
  27. ) {
  28. $this->themeConfig = $themeConfig;
  29. $this->eventDispatcher = $eventDispatcher;
  30. }
  31. /**
  32. * Check a theme, it's assigned to any of store
  33. *
  34. * @param EventObserver $observer
  35. * @return void
  36. */
  37. public function execute(EventObserver $observer)
  38. {
  39. $theme = $observer->getEvent()->getData('theme');
  40. if ($theme instanceof \Magento\Framework\View\Design\ThemeInterface) {
  41. /** @var $theme \Magento\Framework\View\Design\ThemeInterface */
  42. if ($this->themeConfig->isThemeAssignedToStore($theme)) {
  43. $this->eventDispatcher->dispatch('assigned_theme_changed', ['theme' => $theme]);
  44. }
  45. }
  46. }
  47. }