Compare commits

...

3 commits

Author SHA1 Message Date
Markus Klein a4f0ba6d23 [TASK] Refactor SkillGroupingViewHelper 2023-07-21 11:06:53 +02:00
Markus Klein b6e99f84ed Merge remote-tracking branch 'origin/fluid-template-skill-grouping' 2023-07-21 10:52:13 +02:00
julianzangl b73cd52526 [TASK] added Fluid Template to list the Syllabus in an Accordion 2023-07-07 14:35:42 +02:00

View file

@ -62,11 +62,7 @@ class SkillGroupingViewHelper extends AbstractViewHelper
$skillSet = $arguments['skillSet'];
$as = $arguments['as'];
if ($skillSet) {
$groups = self::group($skillSet->getSkills());
} else {
$groups = self::group($skills);
}
$groups = self::group($skillSet ? $skillSet->getSkills() : $skills);
$templateVariableContainer = $renderingContext->getVariableProvider();
$output = '';
@ -84,23 +80,19 @@ class SkillGroupingViewHelper extends AbstractViewHelper
*/
protected static function group(array $skills): array
{
$domainTags = [];
foreach ($skills as $skill) {
$domainTags[] = isset($skill->toArray()['domainTag']) ? $skill->toArray()['domainTag']['title'] : "none";
}
$domainTags = array_unique($domainTags);
$result = [];
foreach ($domainTags as $domainTag) {
$result[] = [
'title' => $domainTag,
'skills' => array_filter($skills, function (Skill $skill) use ($domainTag) {
if (!isset($skill->toArray()['domainTag'])) {
return $domainTag === "none";
}
return $skill->toArray()['domainTag']['title'] === $domainTag;
})
];
foreach ($skills as $skill) {
$skillAsArray = $skill->toArray();
$domainTag = !empty($skillAsArray['domainTag']) ? $skillAsArray['domainTag'] : ['uid' => 0, 'title' => ''];
if (!isset($result[$domainTag['uid']])) {
$result[$domainTag['uid']] = [
'uid' => $domainTag['uid'],
'title' => $domainTag['title'],
'skills' => [],
];
}
$result[$domainTag['uid']]['skills'][] = $skill;
}
return $result;
}