* @copyright Since 2007 PrestaShop SA and Contributors * @license https://opensource.org/licenses/OSL-3.0 Open Software License (OSL 3.0) */ namespace PrestaShop\PrestaShop\Adapter\Category; use Category; use PrestaShop\PrestaShop\Core\Product\Search\ProductSearchContext; use PrestaShop\PrestaShop\Core\Product\Search\ProductSearchProviderInterface; use PrestaShop\PrestaShop\Core\Product\Search\ProductSearchQuery; use PrestaShop\PrestaShop\Core\Product\Search\ProductSearchResult; use PrestaShop\PrestaShop\Core\Product\Search\SortOrderFactory; use Symfony\Contracts\Translation\TranslatorInterface; /** * Responsible of getting products for specific category. */ class CategoryProductSearchProvider implements ProductSearchProviderInterface { private $translator; private $category; private $sortOrderFactory; public function __construct( TranslatorInterface $translator, Category $category ) { $this->translator = $translator; $this->category = $category; $this->sortOrderFactory = new SortOrderFactory($this->translator); } /** * @param ProductSearchContext $context * @param ProductSearchQuery $query * @param string $type * * @return array|false|int * * @throws \PrestaShopDatabaseException */ private function getProductsOrCount( ProductSearchContext $context, ProductSearchQuery $query, $type = 'products' ) { if ($query->getSortOrder()->isRandom()) { return $this->category->getProducts( $context->getIdLang(), 1, $query->getResultsPerPage(), null, null, $type !== 'products', true, true, $query->getResultsPerPage() ); } else { return $this->category->getProducts( $context->getIdLang(), $query->getPage(), $query->getResultsPerPage(), $query->getSortOrder()->toLegacyOrderBy(), $query->getSortOrder()->toLegacyOrderWay(), $type !== 'products' ); } } /** * @param ProductSearchContext $context * @param ProductSearchQuery $query * * @return ProductSearchResult * * @throws \PrestaShopDatabaseException */ public function runQuery( ProductSearchContext $context, ProductSearchQuery $query ) { $products = $this->getProductsOrCount($context, $query, 'products'); $count = $this->getProductsOrCount($context, $query, 'count'); $result = new ProductSearchResult(); if (!empty($products)) { $result ->setProducts($products) ->setTotalProductsCount($count); $result->setAvailableSortOrders( $this->sortOrderFactory->getDefaultSortOrders() ); } return $result; } }