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: