| Conditions | 21 |
| Paths | 126 |
| Total Lines | 134 |
| Lines | 6 |
| Ratio | 4.48 % |
| Changes | 0 | ||
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:
If many parameters/temporary variables are present:
| 1 | <?php |
||
| 122 | public function index(Request $request, Order $Order) |
||
| 123 | { |
||
| 124 | $TargetShippings = $Order->getShippings(); |
||
| 125 | |||
| 126 | // 編集前の受注情報を保持 |
||
| 127 | $OriginShippings = new ArrayCollection(); |
||
| 128 | $OriginOrderItems = []; |
||
| 129 | |||
| 130 | foreach ($TargetShippings as $key => $TargetShipping) { |
||
| 131 | $OriginShippings->add($TargetShipping); |
||
| 132 | |||
| 133 | // 編集前のお届け先のアイテム情報を保持 |
||
| 134 | $OriginOrderItems[$key] = new ArrayCollection(); |
||
| 135 | |||
| 136 | foreach ($TargetShipping->getOrderItems() as $OrderItem) { |
||
| 137 | $OriginOrderItems[$key]->add($OrderItem); |
||
| 138 | } |
||
| 139 | } |
||
| 140 | |||
| 141 | $builder = $this->formFactory->createBuilder(); |
||
| 142 | $builder |
||
| 143 | ->add('shippings', CollectionType::class, [ |
||
| 144 | 'entry_type' => ShippingType::class, |
||
| 145 | 'data' => $TargetShippings, |
||
| 146 | 'allow_add' => true, |
||
| 147 | 'allow_delete' => true, |
||
| 148 | 'prototype' => true, |
||
| 149 | ]); |
||
| 150 | |||
| 151 | // 配送先の追加フラグ |
||
| 152 | $builder |
||
| 153 | ->add('add_shipping', HiddenType::class, [ |
||
| 154 | 'mapped' => false, |
||
| 155 | ]); |
||
| 156 | |||
| 157 | // 配送先の追加フラグが立っている場合は新しいお届け先を追加 |
||
| 158 | $builder->addEventListener(FormEvents::PRE_SUBMIT, function (FormEvent $event) { |
||
| 159 | $data = $event->getData(); |
||
| 160 | if ($data['add_shipping']) { |
||
| 161 | $Shippings = $data['shippings']; |
||
| 162 | $newShipping = ['Delivery' => '']; |
||
| 163 | $Shippings[] = $newShipping; |
||
| 164 | $data['shippings'] = $Shippings; |
||
| 165 | $data['add_shipping'] = ''; |
||
| 166 | $event->setData($data); |
||
| 167 | } |
||
| 168 | }); |
||
| 169 | |||
| 170 | $form = $builder->getForm(); |
||
| 171 | |||
| 172 | $form->handleRequest($request); |
||
| 173 | |||
| 174 | if ($form->isSubmitted() && $form->isValid() && $request->get('mode') == 'register') { |
||
| 175 | log_info('出荷登録開始', [$TargetShipping->getId()]); |
||
|
|
|||
| 176 | |||
| 177 | // 削除された項目の削除 |
||
| 178 | /** @var Shipping $OriginShipping */ |
||
| 179 | foreach ($OriginShippings as $key => $OriginShipping) { |
||
| 180 | if (false === $TargetShippings->contains($OriginShipping)) { |
||
| 181 | // お届け先自体が削除された場合 |
||
| 182 | // 削除されたお届け先に紐づく明細の削除 |
||
| 183 | /** @var OrderItem $OriginOrderItem */ |
||
| 184 | foreach ($OriginOrderItems[$key] as $OriginOrderItem) { |
||
| 185 | $this->entityManager->remove($OriginOrderItem); |
||
| 186 | } |
||
| 187 | |||
| 188 | // 削除されたお届け先の削除 |
||
| 189 | $this->entityManager->remove($OriginShipping); |
||
| 190 | } else { |
||
| 191 | // お届け先は削除されていない場合 |
||
| 192 | // 削除された明細の削除 |
||
| 193 | /** @var OrderItem $OriginOrderItem */ |
||
| 194 | foreach ($OriginOrderItems[$key] as $OriginOrderItem) { |
||
| 195 | if (false === $TargetShippings[$key]->getOrderItems()->contains($OriginOrderItem)) { |
||
| 196 | $this->entityManager->remove($OriginOrderItem); |
||
| 197 | } |
||
| 198 | } |
||
| 199 | } |
||
| 200 | } |
||
| 201 | |||
| 202 | // 追加された項目の追加 |
||
| 203 | foreach ($TargetShippings as $TargetShipping) { |
||
| 204 | // 追加された明細の追加 |
||
| 205 | foreach ($TargetShipping->getOrderItems() as $OrderItem) { |
||
| 206 | $OrderItem->setShipping($TargetShipping); |
||
| 207 | $OrderItem->setOrder($Order); |
||
| 208 | } |
||
| 209 | |||
| 210 | // 追加されたお届け先の追加 |
||
| 211 | $TargetShipping->setOrder($Order); |
||
| 212 | } |
||
| 213 | |||
| 214 | try { |
||
| 215 | foreach ($TargetShippings as $TargetShipping) { |
||
| 216 | $this->entityManager->persist($TargetShipping); |
||
| 217 | } |
||
| 218 | $this->entityManager->flush(); |
||
| 219 | |||
| 220 | $this->addSuccess('admin.shipping.edit.save.complete', 'admin'); |
||
| 221 | $this->addInfo('admin.shipping.edit.save.info', 'admin'); |
||
| 222 | log_info('出荷登録完了', [$Order->getId()]); |
||
| 223 | |||
| 224 | return $this->redirectToRoute('admin_shipping_edit', ['id' => $Order->getId()]); |
||
| 225 | } catch (\Exception $e) { |
||
| 226 | log_error('出荷登録エラー', [$Order->getId(), $e]); |
||
| 227 | $this->addError('admin.flash.register_failed', 'admin'); |
||
| 228 | } |
||
| 229 | } elseif ($form->isSubmitted() && $request->get('mode') == 'register' && $form->getErrors(true)) { |
||
| 230 | $this->addError('admin.flash.register_failed', 'admin'); |
||
| 231 | } |
||
| 232 | |||
| 233 | // 商品検索フォーム |
||
| 234 | $builder = $this->formFactory |
||
| 235 | ->createBuilder(SearchProductType::class); |
||
| 236 | |||
| 237 | $searchProductModalForm = $builder->getForm(); |
||
| 238 | |||
| 239 | // 配送業者のお届け時間 |
||
| 240 | $times = []; |
||
| 241 | $deliveries = $this->deliveryRepository->findAll(); |
||
| 242 | View Code Duplication | foreach ($deliveries as $Delivery) { |
|
| 243 | $deliveryTiems = $Delivery->getDeliveryTimes(); |
||
| 244 | foreach ($deliveryTiems as $DeliveryTime) { |
||
| 245 | $times[$Delivery->getId()][$DeliveryTime->getId()] = $DeliveryTime->getDeliveryTime(); |
||
| 246 | } |
||
| 247 | } |
||
| 248 | |||
| 249 | return [ |
||
| 250 | 'form' => $form->createView(), |
||
| 251 | 'searchProductModalForm' => $searchProductModalForm->createView(), |
||
| 252 | 'Order' => $Order, |
||
| 253 | 'shippingDeliveryTimes' => $this->serializer->serialize($times, 'json'), |
||
| 254 | ]; |
||
| 255 | } |
||
| 256 | |||
| 297 |
It seems like you are relying on a variable being defined by an iteration: