Failed Conditions
Pull Request — experimental/sf (#3247)
by Kiyotaka
114:07 queued 103:28
created

UpdateDateProcessor::commit()   B

Complexity

Conditions 11
Paths 9

Size

Total Lines 50

Duplication

Lines 36
Ratio 72 %

Code Coverage

Tests 18
CRAP Score 12.8905

Importance

Changes 0
Metric Value
cc 11
nc 9
nop 2
dl 36
loc 50
rs 7.3166
c 0
b 0
f 0
ccs 18
cts 24
cp 0.75
crap 12.8905

How to fix   Complexity   

Long Method

Small methods make your code easier to understand, in particular if combined with a good name. Besides, if your method is small, finding a good name is usually much easier.

For example, if you find yourself adding comments to a method's body, this is usually a good sign to extract the commented part to a new method, and use the comment as a starting point when coming up with a good name for this new method.

Commonly applied refactorings include:

1
<?php
2
3
/*
4
 * This file is part of EC-CUBE
5
 *
6
 * Copyright(c) LOCKON CO.,LTD. All Rights Reserved.
7
 *
8
 * http://www.lockon.co.jp/
9
 *
10
 * For the full copyright and license information, please view the LICENSE
11
 * file that was distributed with this source code.
12
 */
13
14
namespace Eccube\Service\PurchaseFlow\Processor;
15
16
use Eccube\Common\EccubeConfig;
17
use Eccube\Entity\ItemHolderInterface;
18
use Eccube\Entity\Master\OrderStatus;
19
use Eccube\Entity\Order;
20
use Eccube\Service\PurchaseFlow\ProcessResult;
21
use Eccube\Service\PurchaseFlow\PurchaseContext;
22
23
/**
24
 * 受注情報の日付更新.
25
 */
26
class UpdateDateProcessor extends AbstractPurchaseProcessor
27
{
28
    /**
29
     * @var EccubeConfig
30
     */
31
    protected $eccubeConfig;
32
33
    /**
34
     * UpdateDatePurchaseProcessor constructor.
35
     *
36
     * @param EccubeConfig $eccubeConfig
37
     */
38 637
    public function __construct(EccubeConfig $eccubeConfig)
39
    {
40 637
        $this->eccubeConfig = $eccubeConfig;
41
    }
42
43
    /**
44
     * {@inheritdoc}
45
     */
46 7
    public function commit(ItemHolderInterface $TargetOrder, PurchaseContext $context)
47
    {
48 7
        $dateTime = new \DateTime();
49 7
        $OriginOrder = $context->getOriginHolder();
50
51
        /* @var Order $TargetOrder */
52 7
        if (!$TargetOrder->getOrderStatus()) {
53
            return ProcessResult::success();
54
        }
55
56
        // 編集
57 7 View Code Duplication
        if ($TargetOrder->getId()) {
58
            // 発送済
59 5
            if ($TargetOrder->getOrderStatus()->getId() == OrderStatus::DELIVERED) {
60
                // 編集前と異なる場合のみ更新
61 1
                if ($TargetOrder->getOrderStatus()->getId() != $OriginOrder->getOrderStatus()->getId()) {
62 1
                    $TargetOrder->setShippingDate($dateTime);
63
                    // お届け先情報の発送日も更新する.
64 1
                    $Shippings = $TargetOrder->getShippings();
65 1
                    foreach ($Shippings as $Shipping) {
66 1
                        $Shipping->setShippingDate($dateTime);
67
                    }
68
                }
69
                // 入金済
70 4
            } elseif ($TargetOrder->getOrderStatus()->getId() == OrderStatus::PAID) {
71
                // 編集前と異なる場合のみ更新
72 1
                if ($TargetOrder->getOrderStatus()->getId() != $OriginOrder->getOrderStatus()->getId()) {
73 5
                    $TargetOrder->setPaymentDate($dateTime);
74
                }
75
            }
76
            // 新規
77
        } else {
78
            // 発送済
79 2
            if ($TargetOrder->getOrderStatus()->getId() == OrderStatus::DELIVERED) {
80
                $TargetOrder->setShippingDate($dateTime);
81
                // お届け先情報の発送日も更新する.
82
                $Shippings = $TargetOrder->getShippings();
83
                foreach ($Shippings as $Shipping) {
84
                    $Shipping->setShippingDate($dateTime);
85
                }
86
                // 入金済
87 2
            } elseif ($TargetOrder->getOrderStatus()->getId() == OrderStatus::PAID) {
88
                $TargetOrder->setPaymentDate($dateTime);
89
            }
90
            // 受注日時
91 2
            $TargetOrder->setOrderDate($dateTime);
92
        }
93
94 7
        return ProcessResult::success();
95
    }
96
}
97