-
Notifications
You must be signed in to change notification settings - Fork 9
Expand file tree
/
Copy pathKeyGroupRelationRepository.php
More file actions
104 lines (87 loc) · 3.59 KB
/
Copy pathKeyGroupRelationRepository.php
File metadata and controls
104 lines (87 loc) · 3.59 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
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
<?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\GroupConfig\Dao as GroupConfigDao;
use Pimcore\Model\DataObject\Classificationstore\KeyConfig\Dao as KeyConfigDao;
use Pimcore\Model\DataObject\Classificationstore\KeyGroupRelation\Listing;
use function count;
/**
* @internal
*/
final readonly class KeyGroupRelationRepository implements KeyGroupRelationRepositoryInterface
{
public function __construct(
private GroupConfigRepositoryInterface $groupConfigRepository,
private SearchHelperServiceInterface $searchHelperService
) {
}
/**
* {@inheritdoc}
*/
public function getPaginatedKeyGroupRelationByStore(
int $storeId,
CollectionParametersInterface $collectionParameters,
?array $groupIds = null,
?string $searchTerm = null
): array {
$groupIds = array_map(
fn ($group) => $group->getId(),
$this->groupConfigRepository->getAllGroupsByStore($storeId, $groupIds)
);
$listing = new Listing();
$listing->setOffset($this->getOffset($collectionParameters));
$listing->setOrder('ASC');
$listing->setOrderKey('sorter');
$this->applyGroupIdsFilter($listing, $groupIds);
if ($searchTerm !== null) {
$this->applySearchTermFilter($listing, $searchTerm);
}
return $listing->getList();
}
public function getCountByStoreId(int $storeId, ?array $groupIds = null): int
{
$groupIds = array_map(
fn ($group) => $group->getId(),
$this->groupConfigRepository->getAllGroupsByStore($storeId, $groupIds)
);
$listing = new Listing();
$this->applyGroupIdsFilter($listing, $groupIds);
return $listing->count();
}
private function applySearchTermFilter(Listing $list, string $searchTerm): void
{
$searchTerms = $this->searchHelperService->getTranslatedSearchFilterTerms($searchTerm);
$searchFilterConditions = [];
foreach ($searchTerms as $term) {
$searchFilterConditions[] =
KeyConfigDao::TABLE_NAME_KEYS.'.name LIKE '.$list->quote('%'.$term.'%')
.' OR '.GroupConfigDao::TABLE_NAME_GROUPS.'.name LIKE '.$list->quote('%'.$term.'%')
.' OR '.KeyConfigDao::TABLE_NAME_KEYS.'.description LIKE '.$list->quote('%'.$term.'%');
}
$list->setResolveGroupName(true);
$list->addConditionParam(implode(' OR ', $searchFilterConditions));
}
private function applyGroupIdsFilter(Listing $list, array $groupIds): void
{
$placeholders = implode(',', array_fill(0, count($groupIds), '?'));
$list->addConditionParam('groupID IN ('. $placeholders .')', $groupIds);
}
private function getOffset(CollectionParametersInterface $collectionParameters): int
{
return ($collectionParameters->getPage() - 1) * $collectionParameters->getPageSize();
}
}