本文整理汇总了PHP中Pim\Bundle\CatalogBundle\Repository\ProductRepositoryInterface::buildByScope方法的典型用法代码示例。如果您正苦于以下问题:PHP ProductRepositoryInterface::buildByScope方法的具体用法?PHP ProductRepositoryInterface::buildByScope怎么用?PHP ProductRepositoryInterface::buildByScope使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类Pim\Bundle\CatalogBundle\Repository\ProductRepositoryInterface
的用法示例。
在下文中一共展示了ProductRepositoryInterface::buildByScope方法的1个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的PHP代码示例。
示例1: DnDBuildByChannelAndCompleteness
/**
* Get product collection by channel and completness
*/
protected function DnDBuildByChannelAndCompleteness($channel, $isComplete)
{
$scope = $channel->getCode();
if (version_compare(Version::VERSION, '1.3.0', '<')) {
$qb = $this->repository->buildByScope($scope);
$rootAlias = $qb->getRootAlias();
$complete = $isComplete ? $qb->expr()->eq('pCompleteness.ratio', '100') : $qb->expr()->lt('pCompleteness.ratio', '100');
$expression = 'pCompleteness.product = ' . $rootAlias . ' AND ' . $complete . ' AND ' . $qb->expr()->eq('pCompleteness.channel', $channel->getId());
$rootEntity = current($qb->getRootEntities());
$completenessMapping = $this->entityManager->getClassMetadata($rootEntity)->getAssociationMapping('completenesses');
$completenessClass = $completenessMapping['targetEntity'];
$qb->innerJoin($completenessClass, 'pCompleteness', 'WITH', $expression);
$treeId = $channel->getCategory()->getId();
$expression = $qb->expr()->eq('pCategory.root', $treeId);
$qb->innerJoin($rootAlias . '.categories', 'pCategory', 'WITH', $expression);
} else {
$qb = $this->repository->buildByScope($scope);
$rootAlias = current($qb->getRootAliases());
$complete = $isComplete ? $qb->expr()->eq('pCompleteness.ratio', '100') : $qb->expr()->lt('pCompleteness.ratio', '100');
$expression = 'pCompleteness.product = ' . $rootAlias . ' AND ' . $complete . ' AND ' . $qb->expr()->eq('pCompleteness.channel', $channel->getId());
$rootEntity = current($qb->getRootEntities());
$completenessMapping = $this->entityManager->getClassMetadata($rootEntity)->getAssociationMapping('completenesses');
$completenessClass = $completenessMapping['targetEntity'];
$qb->innerJoin($completenessClass, 'pCompleteness', 'WITH', $expression);
$treeId = $channel->getCategory()->getId();
$expression = $qb->expr()->eq('pCategory.root', $treeId);
$qb->innerJoin($rootAlias . '.categories', 'pCategory', 'WITH', $expression);
}
return $qb;
}