Code Coverage |
||||||||||
Classes and Traits |
Functions and Methods |
Lines |
||||||||
Total | |
0.00% |
0 / 1 |
|
14.29% |
1 / 7 |
CRAP | |
67.37% |
223 / 331 |
EditController | |
0.00% |
0 / 1 |
|
14.29% |
1 / 7 |
206.28 | |
67.37% |
223 / 331 |
index | |
0.00% |
0 / 1 |
26.82 | |
85.71% |
126 / 147 |
|||
searchCustomer | |
0.00% |
0 / 1 |
20 | |
0.00% |
0 / 28 |
|||
searchCustomerById | |
0.00% |
0 / 1 |
20 | |
0.00% |
0 / 36 |
|||
searchProduct | |
0.00% |
0 / 1 |
7.32 | |
81.40% |
35 / 43 |
|||
newOrder | |
100.00% |
1 / 1 |
1 | |
100.00% |
6 / 6 |
|||
calculate | |
0.00% |
0 / 1 |
13.28 | |
88.24% |
45 / 51 |
|||
updateDate | |
0.00% |
0 / 1 |
19.11 | |
55.00% |
11 / 20 |
<?php | |
/* | |
* This file is part of EC-CUBE | |
* | |
* Copyright(c) 2000-2015 LOCKON CO.,LTD. All Rights Reserved. | |
* | |
* http://www.lockon.co.jp/ | |
* | |
* This program is free software; you can redistribute it and/or | |
* modify it under the terms of the GNU General Public License | |
* as published by the Free Software Foundation; either version 2 | |
* of the License, or (at your option) any later version. | |
* | |
* This program is distributed in the hope that it will be useful, | |
* but WITHOUT ANY WARRANTY; without even the implied warranty of | |
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
* GNU General Public License for more details. | |
* | |
* You should have received a copy of the GNU General Public License | |
* along with this program; if not, write to the Free Software | |
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | |
*/ | |
namespace Eccube\Controller\Admin\Order; | |
use Doctrine\Common\Collections\ArrayCollection; | |
use Eccube\Application; | |
use Eccube\Common\Constant; | |
use Eccube\Controller\AbstractController; | |
use Eccube\Entity\ShipmentItem; | |
use Eccube\Event\EccubeEvents; | |
use Eccube\Event\EventArgs; | |
use Symfony\Component\Form\FormError; | |
use Symfony\Component\HttpFoundation\Request; | |
use Symfony\Component\HttpKernel\Exception\NotFoundHttpException; | |
class EditController extends AbstractController | |
{ | |
public function index(Application $app, Request $request, $id = null) | |
{ | |
/* @var $softDeleteFilter \Eccube\Doctrine\Filter\SoftDeleteFilter */ | |
$softDeleteFilter = $app['orm.em']->getFilters()->getFilter('soft_delete'); | |
$softDeleteFilter->setExcludes(array( | |
'Eccube\Entity\ProductClass', | |
'Eccube\Entity\Product', | |
)); | |
$TargetOrder = null; | |
$OriginOrder = null; | |
if (is_null($id)) { | |
// 空のエンティティを作成. | |
$TargetOrder = $this->newOrder(); | |
} else { | |
$TargetOrder = $app['eccube.repository.order']->find($id); | |
if (is_null($TargetOrder)) { | |
throw new NotFoundHttpException(); | |
} | |
} | |
// 編集前の受注情報を保持 | |
$OriginOrder = clone $TargetOrder; | |
$OriginalOrderDetails = new ArrayCollection(); | |
foreach ($TargetOrder->getOrderDetails() as $OrderDetail) { | |
$OriginalOrderDetails->add($OrderDetail); | |
} | |
$builder = $app['form.factory'] | |
->createBuilder('order', $TargetOrder); | |
$event = new EventArgs( | |
array( | |
'builder' => $builder, | |
'OriginOrder' => $OriginOrder, | |
'TargetOrder' => $TargetOrder, | |
'OriginOrderDetails' => $OriginalOrderDetails, | |
), | |
$request | |
); | |
$app['eccube.event.dispatcher']->dispatch(EccubeEvents::ADMIN_ORDER_EDIT_INDEX_INITIALIZE, $event); | |
$form = $builder->getForm(); | |
if ('POST' === $request->getMethod()) { | |
$form->handleRequest($request); | |
$event = new EventArgs( | |
array( | |
'builder' => $builder, | |
'OriginOrder' => $OriginOrder, | |
'TargetOrder' => $TargetOrder, | |
'OriginOrderDetails' => $OriginalOrderDetails, | |
), | |
$request | |
); | |
$app['eccube.event.dispatcher']->dispatch(EccubeEvents::ADMIN_ORDER_EDIT_INDEX_PROGRESS, $event); | |
// 入力情報にもとづいて再計算. | |
$this->calculate($app, $TargetOrder); | |
// 登録ボタン押下 | |
switch ($request->get('mode')) { | |
case 'register': | |
log_info('受注登録開始', array($TargetOrder->getId())); | |
if ($TargetOrder->getTotal() > $app['config']['max_total_fee']) { | |
log_info('受注登録入力チェックエラー', array($TargetOrder->getId())); | |
$form['charge']->addError(new FormError('合計金額の上限を超えております。')); | |
} elseif ($form->isValid()) { | |
$BaseInfo = $app['eccube.repository.base_info']->get(); | |
// お支払い方法の更新 | |
$TargetOrder->setPaymentMethod($TargetOrder->getPayment()->getMethod()); | |
// 配送業者・お届け時間の更新 | |
$Shippings = $TargetOrder->getShippings(); | |
foreach ($Shippings as $Shipping) { | |
$Shipping->setShippingDeliveryName($Shipping->getDelivery()->getName()); | |
if (!is_null($Shipping->getDeliveryTime())) { | |
$Shipping->setShippingDeliveryTime($Shipping->getDeliveryTime()->getDeliveryTime()); | |
} else { | |
$Shipping->setShippingDeliveryTime(null); | |
} | |
} | |
// 受注日/発送日/入金日の更新. | |
$this->updateDate($app, $TargetOrder, $OriginOrder); | |
// 受注明細で削除されているものをremove | |
foreach ($OriginalOrderDetails as $OrderDetail) { | |
if (false === $TargetOrder->getOrderDetails()->contains($OrderDetail)) { | |
$app['orm.em']->remove($OrderDetail); | |
} | |
} | |
if ($BaseInfo->getOptionMultipleShipping() == Constant::ENABLED) { | |
foreach ($TargetOrder->getOrderDetails() as $OrderDetail) { | |
/** @var $OrderDetail \Eccube\Entity\OrderDetail */ | |
$OrderDetail->setOrder($TargetOrder); | |
} | |
/** @var \Eccube\Entity\Shipping $Shipping */ | |
foreach ($Shippings as $Shipping) { | |
$shipmentItems = $Shipping->getShipmentItems(); | |
/** @var \Eccube\Entity\ShipmentItem $ShipmentItem */ | |
foreach ($shipmentItems as $ShipmentItem) { | |
$ShipmentItem->setOrder($TargetOrder); | |
$ShipmentItem->setShipping($Shipping); | |
$app['orm.em']->persist($ShipmentItem); | |
} | |
$Shipping->setOrder($TargetOrder); | |
$app['orm.em']->persist($Shipping); | |
} | |
} else { | |
$NewShipmentItems = new ArrayCollection(); | |
foreach ($TargetOrder->getOrderDetails() as $OrderDetail) { | |
/** @var $OrderDetail \Eccube\Entity\OrderDetail */ | |
$OrderDetail->setOrder($TargetOrder); | |
$NewShipmentItem = new ShipmentItem(); | |
$NewShipmentItem | |
->setProduct($OrderDetail->getProduct()) | |
->setProductClass($OrderDetail->getProductClass()) | |
->setProductName($OrderDetail->getProduct()->getName()) | |
->setProductCode($OrderDetail->getProductClass()->getCode()) | |
->setClassCategoryName1($OrderDetail->getClassCategoryName1()) | |
->setClassCategoryName2($OrderDetail->getClassCategoryName2()) | |
->setClassName1($OrderDetail->getClassName1()) | |
->setClassName2($OrderDetail->getClassName2()) | |
->setPrice($OrderDetail->getPrice()) | |
->setQuantity($OrderDetail->getQuantity()) | |
->setOrder($TargetOrder); | |
$NewShipmentItems[] = $NewShipmentItem; | |
} | |
// 配送商品の更新. delete/insert. | |
$Shippings = $TargetOrder->getShippings(); | |
foreach ($Shippings as $Shipping) { | |
$ShipmentItems = $Shipping->getShipmentItems(); | |
foreach ($ShipmentItems as $ShipmentItem) { | |
$app['orm.em']->remove($ShipmentItem); | |
} | |
$ShipmentItems->clear(); | |
foreach ($NewShipmentItems as $NewShipmentItem) { | |
$NewShipmentItem->setShipping($Shipping); | |
$ShipmentItems->add($NewShipmentItem); | |
} | |
} | |
} | |
$Customer = $TargetOrder->getCustomer(); | |
if ($Customer) { | |
// 受注情報の会員情報を更新 | |
$TargetOrder->setSex($Customer->getSex()); | |
$TargetOrder->setJob($Customer->getJob()); | |
$TargetOrder->setBirth($Customer->getBirth()); | |
} | |
$app['orm.em']->persist($TargetOrder); | |
$app['orm.em']->flush(); | |
if ($Customer) { | |
// 会員の場合、購入回数、購入金額などを更新 | |
$app['eccube.repository.customer']->updateBuyData($app, $Customer, $TargetOrder->getOrderStatus()->getId()); | |
} | |
$event = new EventArgs( | |
array( | |
'form' => $form, | |
'OriginOrder' => $OriginOrder, | |
'TargetOrder' => $TargetOrder, | |
'OriginOrderDetails' => $OriginalOrderDetails, | |
'Customer' => $Customer, | |
), | |
$request | |
); | |
$app['eccube.event.dispatcher']->dispatch(EccubeEvents::ADMIN_ORDER_EDIT_INDEX_COMPLETE, $event); | |
$app->addSuccess('admin.order.save.complete', 'admin'); | |
log_info('受注登録完了', array($TargetOrder->getId())); | |
return $app->redirect($app->url('admin_order_edit', array('id' => $TargetOrder->getId()))); | |
} | |
break; | |
case 'add_delivery': | |
// お届け先情報の新規追加 | |
$form = $builder->getForm(); | |
$Shipping = new \Eccube\Entity\Shipping(); | |
$Shipping->setDelFlg(Constant::DISABLED); | |
$TargetOrder->addShipping($Shipping); | |
$Shipping->setOrder($TargetOrder); | |
$form->setData($TargetOrder); | |
break; | |
default: | |
break; | |
} | |
} | |
// 会員検索フォーム | |
$builder = $app['form.factory'] | |
->createBuilder('admin_search_customer'); | |
$event = new EventArgs( | |
array( | |
'builder' => $builder, | |
'OriginOrder' => $OriginOrder, | |
'TargetOrder' => $TargetOrder, | |
'OriginOrderDetails' => $OriginalOrderDetails, | |
), | |
$request | |
); | |
$app['eccube.event.dispatcher']->dispatch(EccubeEvents::ADMIN_ORDER_EDIT_SEARCH_CUSTOMER_INITIALIZE, $event); | |
$searchCustomerModalForm = $builder->getForm(); | |
// 商品検索フォーム | |
$builder = $app['form.factory'] | |
->createBuilder('admin_search_product'); | |
$event = new EventArgs( | |
array( | |
'builder' => $builder, | |
'OriginOrder' => $OriginOrder, | |
'TargetOrder' => $TargetOrder, | |
'OriginOrderDetails' => $OriginalOrderDetails, | |
), | |
$request | |
); | |
$app['eccube.event.dispatcher']->dispatch(EccubeEvents::ADMIN_ORDER_EDIT_SEARCH_PRODUCT_INITIALIZE, $event); | |
$searchProductModalForm = $builder->getForm(); | |
// 配送業者のお届け時間 | |
$times = array(); | |
$deliveries = $app['eccube.repository.delivery']->findAll(); | |
foreach ($deliveries as $Delivery) { | |
$deliveryTiems = $Delivery->getDeliveryTimes(); | |
foreach ($deliveryTiems as $DeliveryTime) { | |
$times[$Delivery->getId()][$DeliveryTime->getId()] = $DeliveryTime->getDeliveryTime(); | |
} | |
} | |
return $app->render('Order/edit.twig', array( | |
'form' => $form->createView(), | |
'searchCustomerModalForm' => $searchCustomerModalForm->createView(), | |
'searchProductModalForm' => $searchProductModalForm->createView(), | |
'Order' => $TargetOrder, | |
'id' => $id, | |
'shippingDeliveryTimes' => $app['serializer']->serialize($times, 'json'), | |
)); | |
} | |
/** | |
* 顧客情報を検索する. | |
* | |
* @param Application $app | |
* @param Request $request | |
* @return \Symfony\Component\HttpFoundation\JsonResponse | |
*/ | |
public function searchCustomer(Application $app, Request $request) | |
{ | |
if ($request->isXmlHttpRequest()) { | |
$app['monolog']->addDebug('search customer start.'); | |
$searchData = array( | |
'multi' => $request->get('search_word'), | |
); | |
$qb = $app['eccube.repository.customer']->getQueryBuilderBySearchData($searchData); | |
$event = new EventArgs( | |
array( | |
'qb' => $qb, | |
'data' => $searchData, | |
), | |
$request | |
); | |
$app['eccube.event.dispatcher']->dispatch(EccubeEvents::ADMIN_ORDER_EDIT_SEARCH_CUSTOMER_SEARCH, $event); | |
$Customers = $qb->getQuery()->getResult(); | |
if (empty($Customers)) { | |
$app['monolog']->addDebug('search customer not found.'); | |
} | |
$data = array(); | |
$formatTel = '%s-%s-%s'; | |
$formatName = '%s%s(%s%s)'; | |
foreach ($Customers as $Customer) { | |
$data[] = array( | |
'id' => $Customer->getId(), | |
'name' => sprintf($formatName, $Customer->getName01(), $Customer->getName02(), $Customer->getKana01(), | |
$Customer->getKana02()), | |
'tel' => sprintf($formatTel, $Customer->getTel01(), $Customer->getTel02(), $Customer->getTel03()), | |
'email' => $Customer->getEmail(), | |
); | |
} | |
$event = new EventArgs( | |
array( | |
'data' => $data, | |
'Customers' => $Customers, | |
), | |
$request | |
); | |
$app['eccube.event.dispatcher']->dispatch(EccubeEvents::ADMIN_ORDER_EDIT_SEARCH_CUSTOMER_COMPLETE, $event); | |
$data = $event->getArgument('data'); | |
return $app->json($data); | |
} | |
} | |
/** | |
* 顧客情報を検索する. | |
* | |
* @param Application $app | |
* @param Request $request | |
* @return \Symfony\Component\HttpFoundation\JsonResponse | |
*/ | |
public function searchCustomerById(Application $app, Request $request) | |
{ | |
if ($request->isXmlHttpRequest()) { | |
$app['monolog']->addDebug('search customer by id start.'); | |
/** @var $Customer \Eccube\Entity\Customer */ | |
$Customer = $app['eccube.repository.customer'] | |
->find($request->get('id')); | |
$event = new EventArgs( | |
array( | |
'Customer' => $Customer, | |
), | |
$request | |
); | |
$app['eccube.event.dispatcher']->dispatch(EccubeEvents::ADMIN_ORDER_EDIT_SEARCH_CUSTOMER_BY_ID_INITIALIZE, $event); | |
if (is_null($Customer)) { | |
$app['monolog']->addDebug('search customer by id not found.'); | |
return $app->json(array(), 404); | |
} | |
$app['monolog']->addDebug('search customer by id found.'); | |
$data = array( | |
'id' => $Customer->getId(), | |
'name01' => $Customer->getName01(), | |
'name02' => $Customer->getName02(), | |
'kana01' => $Customer->getKana01(), | |
'kana02' => $Customer->getKana02(), | |
'zip01' => $Customer->getZip01(), | |
'zip02' => $Customer->getZip02(), | |
'pref' => is_null($Customer->getPref()) ? null : $Customer->getPref()->getId(), | |
'addr01' => $Customer->getAddr01(), | |
'addr02' => $Customer->getAddr02(), | |
'email' => $Customer->getEmail(), | |
'tel01' => $Customer->getTel01(), | |
'tel02' => $Customer->getTel02(), | |
'tel03' => $Customer->getTel03(), | |
'fax01' => $Customer->getFax01(), | |
'fax02' => $Customer->getFax02(), | |
'fax03' => $Customer->getFax03(), | |
'company_name' => $Customer->getCompanyName(), | |
); | |
$event = new EventArgs( | |
array( | |
'data' => $data, | |
'Customer' => $Customer, | |
), | |
$request | |
); | |
$app['eccube.event.dispatcher']->dispatch(EccubeEvents::ADMIN_ORDER_EDIT_SEARCH_CUSTOMER_BY_ID_COMPLETE, $event); | |
$data = $event->getArgument('data'); | |
return $app->json($data); | |
} | |
} | |
public function searchProduct(Application $app, Request $request, $page_no = null) | |
{ | |
if ($request->isXmlHttpRequest()) { | |
$app['monolog']->addDebug('search product start.'); | |
$page_count = $app['config']['default_page_count']; | |
$session = $app['session']; | |
if ('POST' === $request->getMethod()) { | |
$page_no = 1; | |
$searchData = array( | |
'name' => $request->get('id'), | |
); | |
if ($categoryId = $request->get('category_id')) { | |
$Category = $app['eccube.repository.category']->find($categoryId); | |
$searchData['category_id'] = $Category; | |
} | |
$session->set('eccube.admin.order.product.search', $searchData); | |
$session->set('eccube.admin.order.product.search.page_no', $page_no); | |
} else { | |
$searchData = (array)$session->get('eccube.admin.order.product.search'); | |
if (is_null($page_no)) { | |
$page_no = intval($session->get('eccube.admin.order.product.search.page_no')); | |
} else { | |
$session->set('eccube.admin.order.product.search.page_no', $page_no); | |
} | |
} | |
$qb = $app['eccube.repository.product'] | |
->getQueryBuilderBySearchData($searchData); | |
$event = new EventArgs( | |
array( | |
'qb' => $qb, | |
'searchData' => $searchData, | |
), | |
$request | |
); | |
$app['eccube.event.dispatcher']->dispatch(EccubeEvents::ADMIN_ORDER_EDIT_SEARCH_PRODUCT_SEARCH, $event); | |
/** @var \Knp\Component\Pager\Pagination\SlidingPagination $pagination */ | |
$pagination = $app['paginator']()->paginate( | |
$qb, | |
$page_no, | |
$page_count, | |
array('wrap-queries' => true) | |
); | |
/** @var $Products \Eccube\Entity\Product[] */ | |
$Products = $pagination->getItems(); | |
if (empty($Products)) { | |
$app['monolog']->addDebug('search product not found.'); | |
} | |
$forms = array(); | |
foreach ($Products as $Product) { | |
/* @var $builder \Symfony\Component\Form\FormBuilderInterface */ | |
$builder = $app['form.factory']->createNamedBuilder('', 'add_cart', null, array( | |
'product' => $Product, | |
)); | |
$addCartForm = $builder->getForm(); | |
$forms[$Product->getId()] = $addCartForm->createView(); | |
} | |
$event = new EventArgs( | |
array( | |
'forms' => $forms, | |
'Products' => $Products, | |
'pagination' => $pagination, | |
), | |
$request | |
); | |
$app['eccube.event.dispatcher']->dispatch(EccubeEvents::ADMIN_ORDER_EDIT_SEARCH_PRODUCT_COMPLETE, $event); | |
return $app->render('Order/search_product.twig', array( | |
'forms' => $forms, | |
'Products' => $Products, | |
'pagination' => $pagination, | |
)); | |
} | |
} | |
protected function newOrder() | |
{ | |
$Order = new \Eccube\Entity\Order(); | |
$Shipping = new \Eccube\Entity\Shipping(); | |
$Shipping->setDelFlg(0); | |
$Order->addShipping($Shipping); | |
$Shipping->setOrder($Order); | |
return $Order; | |
} | |
/** | |
* フォームからの入直内容に基づいて、受注情報の再計算を行う | |
* | |
* @param $app | |
* @param $Order | |
*/ | |
protected function calculate($app, \Eccube\Entity\Order $Order) | |
{ | |
$taxtotal = 0; | |
$subtotal = 0; | |
// 受注明細データの税・小計を再計算 | |
/** @var $OrderDetails \Eccube\Entity\OrderDetail[] */ | |
$OrderDetails = $Order->getOrderDetails(); | |
foreach ($OrderDetails as $OrderDetail) { | |
// 新規登録の場合は, 入力されたproduct_id/produc_class_idから明細にセットする. | |
if (!$OrderDetail->getId()) { | |
$TaxRule = $app['eccube.repository.tax_rule']->getByRule($OrderDetail->getProduct(), | |
$OrderDetail->getProductClass()); | |
$OrderDetail->setTaxRule($TaxRule->getId()); | |
$OrderDetail->setProductName($OrderDetail->getProduct()->getName()); | |
$OrderDetail->setProductCode($OrderDetail->getProductClass()->getCode()); | |
$OrderDetail->setClassName1($OrderDetail->getProductClass()->hasClassCategory1() | |
? $OrderDetail->getProductClass()->getClassCategory1()->getClassName()->getName() | |
: null); | |
$OrderDetail->setClassName2($OrderDetail->getProductClass()->hasClassCategory2() | |
? $OrderDetail->getProductClass()->getClassCategory2()->getClassName()->getName() | |
: null); | |
$OrderDetail->setClassCategoryName1($OrderDetail->getProductClass()->hasClassCategory1() | |
? $OrderDetail->getProductClass()->getClassCategory1()->getName() | |
: null); | |
$OrderDetail->setClassCategoryName2($OrderDetail->getProductClass()->hasClassCategory2() | |
? $OrderDetail->getProductClass()->getClassCategory2()->getName() | |
: null); | |
} | |
// 税 | |
$tax = $app['eccube.service.tax_rule'] | |
->calcTax($OrderDetail->getPrice(), $OrderDetail->getTaxRate(), $OrderDetail->getTaxRule()); | |
$OrderDetail->setPriceIncTax($OrderDetail->getPrice() + $tax); | |
$taxtotal += $tax * $OrderDetail->getQuantity(); | |
// 小計 | |
$subtotal += $OrderDetail->getTotalPrice(); | |
} | |
$shippings = $Order->getShippings(); | |
/** @var \Eccube\Entity\Shipping $Shipping */ | |
foreach ($shippings as $Shipping) { | |
$shipmentItems = $Shipping->getShipmentItems(); | |
$Shipping->setDelFlg(Constant::DISABLED); | |
/** @var \Eccube\Entity\ShipmentItem $ShipmentItem */ | |
foreach ($shipmentItems as $ShipmentItem) { | |
$ShipmentItem->setProductName($ShipmentItem->getProduct()->getName()); | |
$ShipmentItem->setProductCode($ShipmentItem->getProductClass()->getCode()); | |
$ShipmentItem->setClassName1($ShipmentItem->getProductClass()->hasClassCategory1() | |
? $ShipmentItem->getProductClass()->getClassCategory1()->getClassName()->getName() | |
: null); | |
$ShipmentItem->setClassName2($ShipmentItem->getProductClass()->hasClassCategory2() | |
? $ShipmentItem->getProductClass()->getClassCategory2()->getClassName()->getName() | |
: null); | |
$ShipmentItem->setClassCategoryName1($ShipmentItem->getProductClass()->hasClassCategory1() | |
? $ShipmentItem->getProductClass()->getClassCategory1()->getName() | |
: null); | |
$ShipmentItem->setClassCategoryName2($ShipmentItem->getProductClass()->hasClassCategory2() | |
? $ShipmentItem->getProductClass()->getClassCategory2()->getName() | |
: null); | |
} | |
} | |
// 受注データの税・小計・合計を再計算 | |
$Order->setTax($taxtotal); | |
$Order->setSubtotal($subtotal); | |
$Order->setTotal($subtotal + $Order->getCharge() + $Order->getDeliveryFeeTotal() - $Order->getDiscount()); | |
// お支払い合計は、totalと同一金額(2系ではtotal - point) | |
$Order->setPaymentTotal($Order->getTotal()); | |
} | |
/** | |
* 受注ステータスに応じて, 受注日/入金日/発送日を更新する, | |
* 発送済ステータスが設定された場合は, お届け先情報の発送日も更新を行う. | |
* | |
* 編集の場合 | |
* - 受注ステータスが他のステータスから発送済へ変更された場合に発送日を更新 | |
* - 受注ステータスが他のステータスから入金済へ変更された場合に入金日を更新 | |
* | |
* 新規登録の場合 | |
* - 受注日を更新 | |
* - 受注ステータスが発送済に設定された場合に発送日を更新 | |
* - 受注ステータスが入金済に設定された場合に入金日を更新 | |
* | |
* | |
* @param $app | |
* @param $TargetOrder | |
* @param $OriginOrder | |
*/ | |
protected function updateDate($app, $TargetOrder, $OriginOrder) | |
{ | |
$dateTime = new \DateTime(); | |
// 編集 | |
if ($TargetOrder->getId()) { | |
// 発送済 | |
if ($TargetOrder->getOrderStatus()->getId() == $app['config']['order_deliv']) { | |
// 編集前と異なる場合のみ更新 | |
if ($TargetOrder->getOrderStatus()->getId() != $OriginOrder->getOrderStatus()->getId()) { | |
$TargetOrder->setCommitDate($dateTime); | |
// お届け先情報の発送日も更新する. | |
$Shippings = $TargetOrder->getShippings(); | |
foreach ($Shippings as $Shipping) { | |
$Shipping->setShippingCommitDate($dateTime); | |
} | |
} | |
// 入金済 | |
} elseif ($TargetOrder->getOrderStatus()->getId() == $app['config']['order_pre_end']) { | |
// 編集前と異なる場合のみ更新 | |
if ($TargetOrder->getOrderStatus()->getId() != $OriginOrder->getOrderStatus()->getId()) { | |
$TargetOrder->setPaymentDate($dateTime); | |
} | |
} | |
// 新規 | |
} else { | |
// 発送済 | |
if ($TargetOrder->getOrderStatus()->getId() == $app['config']['order_deliv']) { | |
$TargetOrder->setCommitDate($dateTime); | |
// お届け先情報の発送日も更新する. | |
$Shippings = $TargetOrder->getShippings(); | |
foreach ($Shippings as $Shipping) { | |
$Shipping->setShippingCommitDate($dateTime); | |
} | |
// 入金済 | |
} elseif ($TargetOrder->getOrderStatus()->getId() == $app['config']['order_pre_end']) { | |
$TargetOrder->setPaymentDate($dateTime); | |
} | |
// 受注日時 | |
$TargetOrder->setOrderDate($dateTime); | |
} | |
} | |
} |