2021-04-17 00:26:33 +02:00
|
|
|
<?php
|
|
|
|
namespace WapplerSystems\Meilisearch\FieldProcessor;
|
|
|
|
|
|
|
|
/***************************************************************
|
|
|
|
* Copyright notice
|
|
|
|
*
|
|
|
|
* (c) 2013-2015 Steffen Ritter <steffen.ritter@typo3.org>
|
|
|
|
* All rights reserved
|
|
|
|
*
|
|
|
|
* This script is part of the TYPO3 project. The TYPO3 project is
|
|
|
|
* free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* The GNU General Public License can be found at
|
|
|
|
* http://www.gnu.org/copyleft/gpl.html.
|
|
|
|
*
|
|
|
|
* This script is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* This copyright notice MUST APPEAR in all copies of the script!
|
|
|
|
***************************************************************/
|
|
|
|
use WapplerSystems\Meilisearch\System\Records\SystemCategory\SystemCategoryRepository;
|
|
|
|
use TYPO3\CMS\Core\Utility\GeneralUtility;
|
|
|
|
|
|
|
|
/**
|
2021-04-17 21:20:54 +02:00
|
|
|
* This Processor takes a UID of sys_category, and resolves its rootline in meilisearch notation.
|
2021-04-17 00:26:33 +02:00
|
|
|
*
|
2021-04-17 21:20:54 +02:00
|
|
|
* Format of this field corresponds to http://wiki.apache.org/meilisearch/HierarchicalFaceting
|
2021-04-17 00:26:33 +02:00
|
|
|
*
|
|
|
|
* Let's say we have a category with uid 111 which is a sub category like shown in this tree:
|
|
|
|
*
|
|
|
|
* 1
|
|
|
|
* |-10
|
|
|
|
* |-100
|
|
|
|
* |-111
|
|
|
|
*
|
|
|
|
* then we get a rootline 1/10/100/111
|
|
|
|
*
|
2021-04-17 21:20:54 +02:00
|
|
|
* In Meilisearch hierarchy notation, we get
|
2021-04-17 00:26:33 +02:00
|
|
|
*
|
|
|
|
* 0-1
|
|
|
|
* 1-1/10
|
|
|
|
* 2-1/10/100
|
|
|
|
* 3-1/10/100/11
|
|
|
|
*
|
|
|
|
* which is finally saved in a multi-value field.
|
|
|
|
*
|
|
|
|
* @author Steffen Ritter <steffen.ritter@typo3.org>
|
|
|
|
*/
|
|
|
|
class CategoryUidToHierarchy extends AbstractHierarchyProcessor implements FieldProcessor
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* @var SystemCategoryRepository
|
|
|
|
*/
|
|
|
|
protected $systemCategoryRepository;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* CategoryUidToHierarchy constructor.
|
|
|
|
*
|
|
|
|
* @param SystemCategoryRepository|null $systemCategoryRepository
|
|
|
|
*/
|
|
|
|
public function __construct(SystemCategoryRepository $systemCategoryRepository = null)
|
|
|
|
{
|
|
|
|
$this->systemCategoryRepository = $systemCategoryRepository ?? GeneralUtility::makeInstance(SystemCategoryRepository::class);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2021-04-17 21:20:54 +02:00
|
|
|
* Expects a uid ID of a category. Returns a Meilisearch hierarchy notation for the
|
2021-04-17 00:26:33 +02:00
|
|
|
* rootline of the category ID.
|
|
|
|
*
|
|
|
|
* @param array $values Array of values, an array because of multivalued fields
|
|
|
|
* @return array Modified array of values
|
|
|
|
*/
|
|
|
|
public function process(array $values)
|
|
|
|
{
|
|
|
|
$results = [];
|
|
|
|
|
|
|
|
foreach ($values as $value) {
|
|
|
|
$results = array_merge($results,
|
2021-04-17 21:20:54 +02:00
|
|
|
$this->getMeilisearchRootlineForCategoryId($value));
|
2021-04-17 00:26:33 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return $results;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2021-04-17 21:20:54 +02:00
|
|
|
* Returns a Meilisearch hierarchy notation string for rootline of given category uid.
|
2021-04-17 00:26:33 +02:00
|
|
|
*
|
2021-04-17 21:20:54 +02:00
|
|
|
* @param int $categoryId Category ID to get a rootline as Meilisearch hierarchy for
|
|
|
|
* @return array Rootline as Meilisearch hierarchy array
|
2021-04-17 00:26:33 +02:00
|
|
|
*/
|
2021-04-17 21:20:54 +02:00
|
|
|
protected function getMeilisearchRootlineForCategoryId($categoryId)
|
2021-04-17 00:26:33 +02:00
|
|
|
{
|
|
|
|
$categoryIdRootline = $this->buildCategoryIdRootline($categoryId);
|
2021-04-17 21:20:54 +02:00
|
|
|
$meilisearchRootline = $this->buildMeilisearchHierarchyFromIdRootline($categoryIdRootline);
|
2021-04-17 00:26:33 +02:00
|
|
|
|
2021-04-17 21:20:54 +02:00
|
|
|
return $meilisearchRootline;
|
2021-04-17 00:26:33 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Builds a category's rootline of parent category Ids
|
|
|
|
*
|
|
|
|
* @param int $uid The category ID to build the rootline for
|
|
|
|
* @return array Category ID rootline as array
|
|
|
|
*/
|
|
|
|
protected function buildCategoryIdRootline($uid)
|
|
|
|
{
|
|
|
|
$rootlineIds = [];
|
|
|
|
$parentCategory = intval($uid);
|
|
|
|
|
|
|
|
while ($parentCategory !== 0) {
|
|
|
|
$rootlineIds[] = $parentCategory;
|
|
|
|
$childCategory = $this->systemCategoryRepository->findOneByUid($parentCategory);
|
|
|
|
if ($childCategory === null) {
|
|
|
|
$parentCategory = 0;
|
|
|
|
} else {
|
|
|
|
$parentCategory = intval($childCategory['parent']);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
krsort($rootlineIds);
|
|
|
|
|
|
|
|
return array_values($rootlineIds);
|
|
|
|
}
|
|
|
|
}
|