<?php
/**
* Copyright(c) 2018 SYSTEM_KD
* Date: 2018/12/04
*/
namespace Plugin\Schedule\EventSubscriber;
use Doctrine\ORM\QueryBuilder;
use Eccube\Doctrine\Query\Queries;
use Eccube\Event\EccubeEvents;
use Eccube\Event\EventArgs;
use Plugin\Schedule\Repository\QueryKey;
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
class MyPageEventSubscriber implements EventSubscriberInterface
{
private $queries;
public function __construct(Queries $queries)
{
$this->queries = $queries;
}
public function onFrontMyPageMyPageFavoriteSearch(EventArgs $event)
{
/** @var QueryBuilder $qb */
$qb = $event->getArgument('qb');
$this->queries->customize(QueryKey::CUSTOMER_FAVORITE_PRODUCT_SEARCH, $qb, []);
}
/**
* Returns an array of event names this subscriber wants to listen to.
*
* The array keys are event names and the value can be:
*
* * The method name to call (priority defaults to 0)
* * An array composed of the method name to call and the priority
* * An array of arrays composed of the method names to call and respective
* priorities, or 0 if unset
*
* For instance:
*
* * array('eventName' => 'methodName')
* * array('eventName' => array('methodName', $priority))
* * array('eventName' => array(array('methodName1', $priority), array('methodName2'))
*
* @return array The event names to listen to
*/
public static function getSubscribedEvents()
{
return [
EccubeEvents::FRONT_MYPAGE_MYPAGE_FAVORITE_SEARCH => 'onFrontMyPageMyPageFavoriteSearch'
];
}
}