[TASK] added ViewHelper for grouping skills by their domainTag

This commit is contained in:
julianzangl 2023-07-07 12:02:21 +02:00
parent ffde64c04b
commit 60931303c0
2 changed files with 44 additions and 24 deletions

View file

@ -36,7 +36,7 @@ use TYPO3Fluid\Fluid\Core\ViewHelper\Traits\CompileWithRenderStatic;
* <f:for each="{domainGroup.skills}" as="skill">
* {skill.name}<br />
* </f:for>
* </sd>
* </sd:skillGrouping>
*/
class SkillGroupingViewHelper extends AbstractViewHelper
{
@ -55,7 +55,8 @@ class SkillGroupingViewHelper extends AbstractViewHelper
array $arguments,
Closure $renderChildrenClosure,
RenderingContextInterface $renderingContext
) {
)
{
/** @var Skill[] $skills */
$skills = $arguments['skills'];
/** @var SkillSet $skillSet */
@ -84,16 +85,24 @@ class SkillGroupingViewHelper extends AbstractViewHelper
*/
protected static function group(array $skills): array
{
$result = [
/*
* [
* 'title' => 'Domain 1',
* 'skills' => [...skills]
* ]
*/
];
$domainTags = [];
foreach ($skills as $skill) {
$domainTags[] = isset($skill->toArray()['domainTag']) ? $skill->toArray()['domainTag']['title'] : "none";
}
$domainTags = array_unique($domainTags);
// todo group skills based on domainTag|title
$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;
})
];
}
return $result;
}
}

View file

@ -1,7 +1,18 @@
<html xmlns:f="http://typo3.org/ns/TYPO3/CMS/Fluid/ViewHelpers"
xmlns:sd="http://typo3.org/ns/SkillDisplay/SkilldisplayContent/ViewHelpers"
data-namespace-typo3-fluid="true">
<f:for each="{skillSets}" as="skillSet">
<f:for each="{skillSets}" as="skillSet">
<sd:skillGrouping skillSet="{skillSet}" as="domainGroup">
<b>{domainGroup.title}</b><br/>
<f:for each="{domainGroup.skills}" as="skill">
{skill.title}<br/>
</f:for>
</sd:skillGrouping>
</f:for>
<hr>
<f:for each="{skillSets}" as="skillSet">
{f:render(partial: 'VerificationBox', arguments: {
title: skillSet.name,
count: '{skillSet.skills -> f:count()}',
@ -10,5 +21,5 @@
verificationUrl: '{sd:verification.url(skillSet: skillSet.id, campaign: data.skilldisplay_campaign)}',
description: skillSet.description
})}
</f:for>
</f:for>
</html>