<?php
/**
* Copyright(c) 2018 SYSTEM_KD
* Date: 2018/09/30
*/
namespace Plugin\Schedule\EventSubscriber;
use Eccube\Entity\Product;
use Eccube\Event\EccubeEvents;
use Eccube\Event\EventArgs;
use Eccube\Event\TemplateEvent;
use Plugin\Schedule\Service\ScheduleService;
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
use Symfony\Component\Form\FormBuilderInterface;
use Symfony\Component\Translation\TranslatorInterface;
/**
* [管理]商品
*
* Class AdminProductEventSubscriber
* @package Plugin\Schedule\EventSubscriber
*/
class AdminProductEventSubscriber implements EventSubscriberInterface
{
protected $scheduleService;
protected $translator;
public function __construct(
ScheduleService $scheduleService,
TranslatorInterface $translator)
{
$this->scheduleService = $scheduleService;
$this->translator = $translator;
}
/**
* 商品更新完了
*
* @param EventArgs $event
*/
public function onAdminProductEditComplete(EventArgs $event)
{
// 商品登録完了時処理
$Product = $event->getArgument('Product');
/** @var FormBuilderInterface $form */
$form = $event->getArgument('form');
$ScheduleTime = $form->get('schedule_time')->getData();
$this->scheduleService->updateScheduleTime($Product, $ScheduleTime);
}
/**
* 商品コピー完了
*
* @param EventArgs $event
*/
public function onAdminProductCopyComplete(EventArgs $event)
{
// 商品コピー完了時
/** @var Product $Product */
$Product = $event->getArgument('CopyProduct');
$scheduleTime = $Product->getScheduleTime();
if (empty($scheduleTime->getId())) {
return;
}
// 公開日時が設定されている場合
$newScheduleTime = $scheduleTime->copy();
$this->scheduleService->linkScheduleTime($Product, $newScheduleTime);
}
/**
* 商品一覧
*
* @param TemplateEvent $event
*/
public function onTemplateProductIndex(TemplateEvent $event)
{
$event->addSnippet('@Schedule/admin/Product/index_add.twig');
}
/**
* 商品登録
*
* @param TemplateEvent $event
*/
public function onTemplateProductProduct(TemplateEvent $event)
{
// 表示情報追加
$event->addSnippet('@Schedule/admin/Product/product_ex.twig');
$id = $event->getParameter('id');
$scheduleFromMsg = $this->translator->trans('schedule.time_empty');
$scheduleToMsg = $this->translator->trans('schedule.time_empty');
$scheduleType = "";
if (!is_null($id)) {
// 商品が登録状態の場合
/** @var Product $product */
$product = $event->getParameter('Product');
$scheduleMsg = $this->scheduleService->getActiveScheduleTimeToString($product);
$scheduleFromMsg = $scheduleMsg['scheduleFromMsg'];
$scheduleToMsg = $scheduleMsg['scheduleToMsg'];
$ScheduleTime = $product->getScheduleTime();
if ($ScheduleTime) {
$scheduleType = $ScheduleTime->getScheduleType();
}
}
$event->setParameter('scheduleType', $scheduleType);
$event->setParameter('scheduleFromMsg', $scheduleFromMsg);
$event->setParameter('scheduleToMsg', $scheduleToMsg);
}
/**
* 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::ADMIN_PRODUCT_EDIT_COMPLETE => ['onAdminProductEditComplete'],
// 商品コピー完了
EccubeEvents::ADMIN_PRODUCT_COPY_COMPLETE => ['onAdminProductCopyComplete'],
// 商品一覧
'@admin/Product/index.twig' => ['onTemplateProductIndex'],
// 商品詳細
'@admin/Product/product.twig' => ['onTemplateProductProduct'],
];
}
}