getOrderDetails() public method

Get OrderDetails
public getOrderDetails ( ) : Doctrine\Common\Collections\Collection
return Doctrine\Common\Collections\Collection
 /**
  * 受注再編集用フォーム作成.
  *
  * @param Order $Order
  * @return array
  */
 public function createFormDataForEdit(Order $Order)
 {
     //受注アイテム
     $orderDetail = array();
     $OrderDetailColl = $Order->getOrderDetails();
     foreach ($OrderDetailColl as $OrderDetail) {
         $orderDetail[] = array('Product' => $OrderDetail->getProduct()->getId(), 'ProductClass' => $OrderDetail->getProductClass()->getId(), 'price' => $OrderDetail->getPrice(), 'quantity' => $OrderDetail->getQuantity(), 'tax_rate' => $OrderDetail->getTaxRate(), 'tax_rule' => $OrderDetail->getTaxRule());
     }
     //受注お届け
     $shippings = array();
     $ShippingsColl = $Order->getShippings();
     foreach ($ShippingsColl as $Shippings) {
         $deliveryTime = '';
         if (is_object($Shippings->getDeliveryTime())) {
             $deliveryTime = $Shippings->getDeliveryTime()->getId();
         }
         $shippingDeliveryDate = array('year' => null, 'month' => null, 'day' => null);
         if ($Shippings->getShippingDeliveryDate() instanceof \DateTime) {
             $shippingDeliveryDate['year'] = $Shippings->getShippingDeliveryDate()->format('Y');
             $shippingDeliveryDate['month'] = $Shippings->getShippingDeliveryDate()->format('m');
             $shippingDeliveryDate['day'] = $Shippings->getShippingDeliveryDate()->format('d');
         }
         $shippings[] = array('name' => array('name01' => $Shippings->getName01(), 'name02' => $Shippings->getName02()), 'kana' => array('kana01' => $Shippings->getKana01(), 'kana02' => $Shippings->getKana02()), 'company_name' => $Shippings->getCompanyName(), 'zip' => array('zip01' => $Shippings->getZip01(), 'zip02' => $Shippings->getZip02()), 'address' => array('pref' => $Shippings->getPref()->getId(), 'addr01' => $Shippings->getAddr01(), 'addr02' => $Shippings->getAddr02()), 'tel' => array('tel01' => $Shippings->getTel01(), 'tel02' => $Shippings->getTel02(), 'tel03' => $Shippings->getTel03()), 'fax' => array('fax01' => $Shippings->getFax01(), 'fax02' => $Shippings->getFax02(), 'fax03' => $Shippings->getFax03()), 'Delivery' => $Shippings->getDelivery()->getId(), 'DeliveryTime' => $deliveryTime, 'shipping_delivery_date' => $shippingDeliveryDate);
     }
     $Customer = $Order->getCustomer();
     $customer_id = null;
     if (is_object($Customer)) {
         $customer_id = $Customer->getId();
     }
     //受注フォーム
     $order = array('_token' => 'dummy', 'OrderStatus' => (string) $Order->getOrderStatus(), 'Customer' => (string) $customer_id, 'name' => array('name01' => $Order->getName01(), 'name02' => $Order->getName02()), 'kana' => array('kana01' => $Order->getKana01(), 'kana02' => $Order->getKana02()), 'zip' => array('zip01' => $Order->getZip01(), 'zip02' => $Order->getZip02()), 'address' => array('pref' => $Order->getPref()->getId(), 'addr01' => $Order->getAddr01(), 'addr02' => $Order->getAddr02()), 'email' => $Order->getEmail(), 'tel' => array('tel01' => $Order->getTel01(), 'tel02' => $Order->getTel02(), 'tel03' => $Order->getTel03()), 'fax' => array('fax01' => $Order->getFax01(), 'fax02' => $Order->getFax02(), 'fax03' => $Order->getFax03()), 'company_name' => $Order->getCompanyName(), 'message' => $Order->getMessage(), 'OrderDetails' => $orderDetail, 'discount' => $Order->getDiscount(), 'delivery_fee_total' => $Order->getDeliveryFeeTotal(), 'charge' => $Order->getCharge(), 'Payment' => $Order->getPayment()->getId(), 'Shippings' => $shippings, 'note' => $Order->getNote());
     return $order;
 }
 /**
  * delete product.
  *
  * @param \Eccube\Entity\Order $Order
  */
 public function deleteProduct($Order)
 {
     foreach ($Order->getOrderDetails() as $OrderDetail) {
         $Product = $OrderDetail->getProduct();
         $ProductClasses = $Product->getProductClasses();
         $Product->setDelFlg(Constant::ENABLED);
         foreach ($ProductClasses as $ProductClass) {
             $ProductClass->setDelFlg(Constant::ENABLED);
             $Product->removeProductClass($ProductClass);
             $this->app['orm.em']->persist($ProductClass);
             $this->app['orm.em']->flush($ProductClass);
         }
         $this->app['orm.em']->persist($Product);
         $this->app['orm.em']->flush($Product);
     }
 }
Beispiel #3
0
 /**
  * お届け日を取得
  *
  * @param Order $Order
  * @return array
  */
 public function getFormDeliveryDates(Order $Order)
 {
     // お届け日の設定
     $minDate = 0;
     $deliveryDateFlag = false;
     // 配送時に最大となる商品日数を取得
     foreach ($Order->getOrderDetails() as $detail) {
         $deliveryDate = $detail->getProductClass()->getDeliveryDate();
         if (!is_null($deliveryDate)) {
             if ($minDate < $deliveryDate->getValue()) {
                 $minDate = $deliveryDate->getValue();
             }
             // 配送日数が設定されている
             $deliveryDateFlag = true;
         }
     }
     // 配達最大日数期間を設定
     $deliveryDates = array();
     // 配送日数が設定されている
     if ($deliveryDateFlag) {
         $period = new \DatePeriod(new \DateTime($minDate . ' day'), new \DateInterval('P1D'), new \DateTime($minDate + $this->app['config']['deliv_date_end_max'] . ' day'));
         foreach ($period as $day) {
             $deliveryDates[$day->format('Y/m/d')] = $day->format('Y/m/d');
         }
     }
     return $deliveryDates;
 }
Beispiel #4
0
 /**
  * フォームからの入直内容に基づいて、受注情報の再計算を行う
  *
  * @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->getCalcRule()->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;
         // 小計
         $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 */
         if (!$Shipping->getId()) {
             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());
 }
Beispiel #5
0
 /**
  * 会員情報の更新
  *
  * @param $em トランザクション制御されているEntityManager
  * @param $Order 受注情報
  * @param $user ログインユーザ
  */
 public function setCustomerUpdate($em, \Eccube\Entity\Order $Order, \Eccube\Entity\Customer $user)
 {
     $orderDetails = $Order->getOrderDetails();
     // 顧客情報を更新
     $now = new \DateTime();
     $firstBuyDate = $user->getFirstBuyDate();
     if (empty($firstBuyDate)) {
         $user->setFirstBuyDate($now);
     }
     $user->setLastBuyDate($now);
     $user->setBuyTimes($user->getBuyTimes() + 1);
     $user->setBuyTotal($user->getBuyTotal() + $Order->getTotal());
 }
 /**
  * カテゴリがクーポン適用の対象か調査する.
  * 下位のカテゴリから上位のカテゴリに向けて検索する
  *
  * @param \Plugin\Coupon\Entity\CouponCoupon $Coupon
  * @param \Eccube\Entity\Order $Order
  * @return boolean
  */
 private function containsCategory(\Plugin\Coupon\Entity\CouponCoupon $Coupon, \Eccube\Entity\Order $Order)
 {
     // クーポンの対象カテゴリIDを配列にする
     $targetCategoryIds = array();
     foreach ($Coupon->getCouponDetails() as $detail) {
         $targetCategoryIds[] = $detail->getCategory()->getId();
     }
     // 受注データからカテゴリIDを取得する
     foreach ($Order->getOrderDetails() as $orderDetail) {
         foreach ($orderDetail->getProduct()->getProductCategories() as $productCategory) {
             if ($this->existsDepthCategory($targetCategoryIds, $productCategory->getCategory())) {
                 return true;
             }
         }
     }
     return false;
 }
 /**
  * 購入商品詳細情報を設定する.
  *
  * @param Order $Order
  */
 protected function renderOrderDetailData(Order $Order)
 {
     $arrOrder = array();
     // テーブルの微調整を行うための購入商品詳細情報をarrayに変換する
     // =========================================
     // 受注詳細情報
     // =========================================
     $i = 0;
     /* @var OrderDetail $OrderDetail */
     foreach ($Order->getOrderDetails() as $OrderDetail) {
         // class categoryの生成
         $classCategory = '';
         if ($OrderDetail->getClassCategoryName1()) {
             $classCategory .= ' [ ' . $OrderDetail->getClassCategoryName1();
             if ($OrderDetail->getClassCategoryName2() == '') {
                 $classCategory .= ' ]';
             } else {
                 $classCategory .= ' * ' . $OrderDetail->getClassCategoryName2() . ' ]';
             }
         }
         // 税
         $tax = $this->app['eccube.service.tax_rule']->calcTax($OrderDetail->getPrice(), $OrderDetail->getTaxRate(), $OrderDetail->getTaxRule());
         $OrderDetail->setPriceIncTax($OrderDetail->getPrice() + $tax);
         // product
         $arrOrder[$i][0] = sprintf('%s / %s / %s', $OrderDetail->getProductName(), $OrderDetail->getProductCode(), $classCategory);
         // 購入数量
         $arrOrder[$i][1] = number_format($OrderDetail->getQuantity());
         // 税込金額(単価)
         $arrOrder[$i][2] = number_format($OrderDetail->getPriceIncTax()) . self::MONETARY_UNIT;
         // 小計(商品毎)
         $arrOrder[$i][3] = number_format($OrderDetail->getTotalPrice()) . self::MONETARY_UNIT;
         ++$i;
     }
     // =========================================
     // 小計
     // =========================================
     $arrOrder[$i][0] = '';
     $arrOrder[$i][1] = '';
     $arrOrder[$i][2] = '';
     $arrOrder[$i][3] = '';
     ++$i;
     $arrOrder[$i][0] = '';
     $arrOrder[$i][1] = '';
     $arrOrder[$i][2] = '商品合計';
     $arrOrder[$i][3] = number_format($Order->getSubtotal()) . self::MONETARY_UNIT;
     ++$i;
     $arrOrder[$i][0] = '';
     $arrOrder[$i][1] = '';
     $arrOrder[$i][2] = '送料';
     $arrOrder[$i][3] = number_format($Order->getDeliveryFeeTotal()) . self::MONETARY_UNIT;
     ++$i;
     $arrOrder[$i][0] = '';
     $arrOrder[$i][1] = '';
     $arrOrder[$i][2] = '手数料';
     $arrOrder[$i][3] = number_format($Order->getCharge()) . self::MONETARY_UNIT;
     ++$i;
     $arrOrder[$i][0] = '';
     $arrOrder[$i][1] = '';
     $arrOrder[$i][2] = '値引き';
     $arrOrder[$i][3] = '- ' . number_format($Order->getDiscount()) . self::MONETARY_UNIT;
     ++$i;
     $arrOrder[$i][0] = '';
     $arrOrder[$i][1] = '';
     $arrOrder[$i][2] = '請求金額';
     $arrOrder[$i][3] = number_format($Order->getPaymentTotal()) . self::MONETARY_UNIT;
     // PDFに設定する
     $this->setFancyTable($this->labelCell, $arrOrder, $this->widthCell);
 }
 /**
  * 商品種別を取得
  *
  * @param Order $Order
  * @return array
  */
 public function getProductTypes(Order $Order)
 {
     $productTypes = array();
     foreach ($Order->getOrderDetails() as $OrderDetail) {
         /* @var $ProductClass \Eccube\Entity\ProductClass */
         $ProductClass = $OrderDetail->getProductClass();
         $productTypes[] = $ProductClass->getProductType();
     }
     return array_unique($productTypes);
 }