mirror of
https://github.com/SkillDisplay/TYPO3ContentElements.git
synced 2024-11-24 03:56:08 +01:00
[TASK] added ViewHelper for grouping skills by their domainTag
This commit is contained in:
parent
ffde64c04b
commit
60931303c0
2 changed files with 44 additions and 24 deletions
|
@ -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
|
||||
{
|
||||
|
@ -52,10 +52,11 @@ class SkillGroupingViewHelper extends AbstractViewHelper
|
|||
}
|
||||
|
||||
public static function renderStatic(
|
||||
array $arguments,
|
||||
Closure $renderChildrenClosure,
|
||||
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;
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,14 +1,25 @@
|
|||
<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:render(partial: 'VerificationBox', arguments: {
|
||||
title: skillSet.name,
|
||||
count: '{skillSet.skills -> f:count()}',
|
||||
detailUrl: 'https://my.skilldisplay.eu/skillset/{skillSet.id}',
|
||||
brandLogoUrl: skillSet.brand.logoPublicUrl,
|
||||
verificationUrl: '{sd:verification.url(skillSet: skillSet.id, campaign: data.skilldisplay_campaign)}',
|
||||
description: skillSet.description
|
||||
})}
|
||||
xmlns:sd="http://typo3.org/ns/SkillDisplay/SkilldisplayContent/ViewHelpers"
|
||||
data-namespace-typo3-fluid="true">
|
||||
<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()}',
|
||||
detailUrl: 'https://my.skilldisplay.eu/skillset/{skillSet.id}',
|
||||
brandLogoUrl: skillSet.brand.logoPublicUrl,
|
||||
verificationUrl: '{sd:verification.url(skillSet: skillSet.id, campaign: data.skilldisplay_campaign)}',
|
||||
description: skillSet.description
|
||||
})}
|
||||
</f:for>
|
||||
</html>
|
||||
|
|
Loading…
Reference in a new issue