<?php
/*
* Plugin Name : HiddenDeliveryDate
*
* Copyright (C) BraTech Co., Ltd. All Rights Reserved.
* http://www.bratech.co.jp/
*
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
namespace Plugin\HiddenDeliveryDate42\Event;
use Doctrine\ORM\EntityManagerInterface;
use Eccube\Event\EventArgs;
use Plugin\HiddenDeliveryDate42\Entity\Hiddenday;
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
class CsvImportProductExtEvent implements EventSubscriberInterface
{
private $entityManager;
public function __construct(
EntityManagerInterface $entityManager
)
{
$this->entityManager = $entityManager;
}
/**
* @return array
*/
public static function getSubscribedEvents()
{
return [
'csvimportproductext.admin.product.csv.import.product.descriptions' => 'hookAdminProductCsvImportProductDescriptions',
'csvimportproductext.admin.product.csv.import.product.check'=> 'hookAdminProductCsvImportProductCheck',
'csvimportproductext.admin.product.csv.import.product.process' => 'hookAdminProductCsvImportProductProcess',
];
}
public function hookAdminProductCsvImportProductDescriptions(EventArgs $event)
{
$header = $event->getArgument('header');
$key = $event->getArgument('key');
if($key == trans('hiddendeliverydate.common.hiddenday')){
$header['description'] = trans('hiddendeliverydate.admin.product.product_csv.hidden_delivery_date_description');
$header['required'] = false;
}
$event->setArgument('header',$header);
}
public function hookAdminProductCsvImportProductCheck(EventArgs $event)
{
$row = $event->getArgument('row');
$lineNo = $event->getArgument('lineNo');
$errors = $event->getArgument('errors');
if(isset($row[trans('hiddendeliverydate.common.hiddenday')]) && strlen($row[trans('hiddendeliverydate.common.hiddenday')]) > 0){
$hiddendays = explode(',',$row[trans('hiddendeliverydate.common.hiddenday')]);
$format_str = '%Y/%m/%d';
foreach($hiddendays as $hiddenday){
$is_date_str = strptime($hiddenday, $format_str);
if(!$is_date_str){
$message = trans('admin.common.csv_invalid_date_format', [
'%line%' => $lineNo,
'%name%' => trans('hiddendeliverydate.common.hiddenday'),
]);
$errors[] = $message;
}
list($year, $month, $day) = explode("/", $hiddenday);
if (!checkdate(intval($month), intval($day), intval($year))) {
$message = trans('admin.common.csv_invalid_not_found_target', [
'%line%' => $lineNo,
'%name%' => trans('hiddendeliverydate.common.hiddenday'),
'%target_name%' => $hiddenday,
]);
$errors[] = $message;
}
}
}
$event->setArgument('errors',$errors);
}
public function hookAdminProductCsvImportProductProcess(EventArgs $event)
{
$row = $event->getArgument('row');
$ProductClass = $event->getArgument('ProductClass');
$Product = $ProductClass->getProduct();
if(isset($row[trans('hiddendeliverydate.common.hiddenday')])){
foreach($Product->getHiddendays() as $Hiddenday){
$Product->removeHiddenday($Hiddenday);
$this->entityManager->remove($Hiddenday);
}
if($row[trans('hiddendeliverydate.common.hiddenday')] != ''){
$hiddendays = explode(',',$row[trans('hiddendeliverydate.common.hiddenday')]);
foreach($hiddendays as $hiddenday){
$hiddenDate = new \DateTime($hiddenday , new \DateTimeZone('UTC'));
$Hiddenday = new Hiddenday();
$Hiddenday->setDate($hiddenDate)
->setProduct($Product);
$Product->addHiddenday($Hiddenday);
$this->entityManager->persist($Hiddenday);
}
}
}
}
}