app/Customize/Repository/AdminProductListCustomizer.php line 62

Open in your IDE?
  1. <?php
  2. /*
  3.  * This file is part of EC-CUBE
  4.  *
  5.  * Copyright(c) EC-CUBE CO.,LTD. All Rights Reserved.
  6.  *
  7.  * http://www.ec-cube.co.jp/
  8.  *
  9.  * For the full copyright and license information, please view the LICENSE
  10.  * file that was distributed with this source code.
  11.  */
  12. namespace Customize\Repository;
  13. use Eccube\Doctrine\Query\WhereClause;
  14. use Eccube\Doctrine\Query\WhereCustomizer;
  15. use Eccube\Entity\Product;
  16. use Eccube\Repository\QueryKey;
  17. use Eccube\Repository\MemberRepository;
  18. use Symfony\Component\Security\Core\Security;
  19. /**
  20.  * ProductRepository
  21.  *
  22.  * This class was generated by the Doctrine ORM. Add your own custom
  23.  * repository methods below.
  24.  */
  25. class AdminProductListCustomizer extends WhereCustomizer
  26. {
  27.     protected $memberRepository;
  28.     /**
  29.      * @var Security
  30.      */
  31.     protected $security;
  32.     public function __construct(MemberRepository $memberRepositorySecurity $security) {
  33.         $this->memberRepository $memberRepository;
  34.         $this->security $security;
  35.     }
  36.     /**
  37.      * vendorで絞り込む
  38.      *
  39.      * @param array $params
  40.      * @param $queryKey
  41.      * @return OrderByClause[]
  42.      */
  43.     protected function createStatements($params$queryKey)
  44.     {
  45.         // dump($params);
  46.         // if (!empty($params['vendor_id']) && $params['vendor_id']) {
  47.         //     $Vendor = $this->memberRepository->find($params['vendor_id']);
  48.         //     dump($Vendor);
  49.         //     if ($Vendor) {
  50.         //         return [WhereClause::eq('p.vendor', ':Vendor', $Vendor)];
  51.         //         // return [WhereClause::in('p.vendor', ':Vendors', ['Vendors' => [$Vendor]])];
  52.         //     }
  53.         // }
  54.         // return [];
  55.         dump($params);
  56.         // ログインユーザーを取得
  57.         /**
  58.          * @var \Eccube\Entity\Member
  59.         */
  60.         $loginUser $this->security->getUser();
  61.         $vendors = [];
  62.         // param指定の vendor_id があれば追加
  63.         if (!empty($params['vendor_id'])) {
  64.             $Vendor $this->memberRepository->find($params['vendor_id']);
  65.             if ($Vendor) {
  66.                 $vendors[] = $Vendor;
  67.             }
  68.             if ($loginUser->getAuthority()->getId() === 0) {
  69.                 $vendors[] = $loginUser;
  70.             }
  71.         } else if ($loginUser->getAuthority()->getId() === 1) {
  72.             $vendors[] = $loginUser;
  73.         }
  74.         dump($vendors);
  75.         if (!empty($vendors)) {
  76.             // IN 句でまとめて条件化
  77.             return [WhereClause::in('p.vendor'':Vendors', ['Vendors' => $vendors])];
  78.         }
  79.         return [];
  80.     }
  81.     /**
  82.      * ProductRepository::getQueryBuilderBySearchDataForAdmin に適用する.
  83.      *
  84.      * @return string
  85.      * @see \Eccube\Repository\ProductRepository::getQueryBuilderBySearchDataForAdmin()
  86.      * @see QueryKey
  87.      */
  88.     public function getQueryKey()
  89.     {
  90.         return QueryKey::PRODUCT_SEARCH_ADMIN;
  91.     }
  92. }