-
Notifications
You must be signed in to change notification settings - Fork 9
Expand file tree
/
Copy pathCollectionConfigRepository.php
More file actions
80 lines (67 loc) · 2.46 KB
/
Copy pathCollectionConfigRepository.php
File metadata and controls
80 lines (67 loc) · 2.46 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
<?php
declare(strict_types=1);
/**
* Pimcore
*
* This source file is available under two different licenses:
* - GNU General Public License version 3 (GPLv3)
* - Pimcore Commercial License (PCL)
* Full copyright and license information is available in
* LICENSE.md which is distributed with this source code.
*
* @copyright Copyright (c) Pimcore GmbH (http://www.pimcore.org)
* @license http://www.pimcore.org/license GPLv3 and PCL
*/
namespace Pimcore\Bundle\StudioBackendBundle\ClassificationStore\Repository;
use Pimcore\Bundle\StudioBackendBundle\ClassificationStore\Service\SearchHelperServiceInterface;
use Pimcore\Bundle\StudioBackendBundle\MappedParameter\CollectionParametersInterface;
use Pimcore\Model\DataObject\Classificationstore\CollectionConfig\Listing;
use function count;
/**
* @internal
*/
final class CollectionConfigRepository implements CollectionConfigRepositoryInterface
{
public function __construct(
private SearchHelperServiceInterface $searchHelperService
) {
}
/**
* {@inheritDoc}
*/
public function getPaginatedCollectionsByStore(
int $storeId,
CollectionParametersInterface $collectionParameters,
?array $collectionIds = null,
?string $searchTerm = null
): array {
$list = new Listing();
$list->setLimit($collectionParameters->getPageSize());
$list->setOffset($this->getOffset($collectionParameters));
$list->setOrder('ASC');
$list->setOrderKey('id');
$list->setCondition('storeId = ?', $storeId);
if ($collectionIds !== null) {
$this->applyCollectionIdsFilter($list, $collectionIds);
}
if ($searchTerm !== null) {
$this->searchHelperService->applySearchTermFilter($list, $searchTerm);
}
return $list->load();
}
public function getCountByStoreId(int $storeId): int
{
$list = new Listing();
$list->setCondition('storeId = ?', $storeId);
return $list->count();
}
private function applyCollectionIdsFilter(Listing $list, array $collectionIds): void
{
$placeholders = implode(',', array_fill(0, count($collectionIds), '?'));
$list->addConditionParam('id IN ('. $placeholders .')', $collectionIds);
}
private function getOffset(CollectionParametersInterface $collectionParameters): int
{
return ($collectionParameters->getPage() - 1) * $collectionParameters->getPageSize();
}
}