GetAllViewHelper.php 4.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147
  1. <?php
  2. namespace Opentalent\OtTemplating\ViewHelpers\Members;
  3. use FluidTYPO3\Vhs\Traits\TemplateVariableViewHelperTrait;
  4. use Opentalent\OtTemplating\Domain\Repository\MemberRepository;
  5. use Opentalent\OtTemplating\Exception\ApiRequestException;
  6. use Psr\Log\LoggerAwareInterface;
  7. use Psr\Log\LoggerAwareTrait;
  8. use TYPO3Fluid\Fluid\Core\ViewHelper\AbstractViewHelper;
  9. /**
  10. * This view helper give access to an array named according to the 'as' variable
  11. * and which contains the members of the structure, eventually grouped by instruments
  12. *
  13. * {namespace ot=Opentalent\OtTemplating\ViewHelpers}
  14. *
  15. * <ot:members.getAll as="members"
  16. * organizationId="{settings.organizationId}">
  17. * <f:debug>{members}</f:debug>
  18. * </ot:members.getAll>
  19. *
  20. * @package Opentalent\OtTemplating\ViewHelpers
  21. */
  22. class GetAllViewHelper extends AbstractViewHelper implements LoggerAwareInterface {
  23. use LoggerAwareTrait;
  24. use TemplateVariableViewHelperTrait;
  25. /**
  26. * >> Required to prevent typo3 to escape the html output
  27. * @var boolean
  28. */
  29. protected $escapeOutput = false;
  30. /**
  31. * @var MemberRepository
  32. *
  33. */
  34. protected $memberRepository;
  35. /**
  36. * -- This method is expected by Fluid --
  37. * Declares the viewhelper's parameters
  38. */
  39. public function initializeArguments()
  40. {
  41. $this->registerArgument(
  42. 'as',
  43. 'string',
  44. 'Name of the returned array',
  45. true
  46. );
  47. $this->registerArgument(
  48. 'organizationId',
  49. 'integer',
  50. 'Id of the current structure',
  51. true
  52. );
  53. $this->registerArgument(
  54. 'groupByInstruments',
  55. 'bool',
  56. 'If true, returns an array of the form [instrument=>[members]],
  57. else the returned array is simply [members]',
  58. false,
  59. false
  60. );
  61. }
  62. /**
  63. * -- This method is expected by Fluid --
  64. * Renders the content as html
  65. *
  66. * @return string
  67. * @throws ApiRequestException
  68. */
  69. public function render()
  70. {
  71. // Get current settings
  72. $as = $this->arguments['as'];
  73. $organizationId = $this->arguments['organizationId'];
  74. $groupByInstruments = $this->arguments['groupByInstruments'];
  75. try {
  76. // Get members of the structure
  77. $collection = $this->memberRepository->findByOrganizationId($organizationId);
  78. $members = $collection->getMembers();
  79. } catch (ApiRequestException $e) {
  80. $this->logger->error(sprintf('API Error: %s', $e->getMessage()));
  81. $members = [];
  82. }
  83. // Sort by instrument (conductor first), then alphabetically by name
  84. usort($members,
  85. function($a, $b) {
  86. if ($a->getInstrument() == 'CONDUCTOR') {
  87. return -1;
  88. } else if ($b->getInstrument() == 'CONDUCTOR') {
  89. return 1;
  90. } else if ($a->getInstrument() != $b->getInstrument()) {
  91. return strcmp($a->getInstrument(), $b->getInstrument());
  92. } else {
  93. return strcmp($a->getName(), $b->getName());
  94. }
  95. }
  96. );
  97. if ($groupByInstruments && !empty($members)) {
  98. // Instruments to display in first place (next will be sorted alphabetically)
  99. $stack1 = ['CONDUCTOR' => []];
  100. $stack2 = [];
  101. foreach ($members as $member) {
  102. // If that Instrument exist in stack1: put it in this one
  103. if (array_key_exists($member->getInstrument(), $stack1)) {
  104. array_push($stack1[$member->getInstrument()], $member);
  105. } else {
  106. // Create the new array if needed in stack2, then put the member in it
  107. if (!array_key_exists($member->getInstrument(), $stack2)) {
  108. $stack2[$member->getInstrument()] = [];
  109. }
  110. array_push($stack2[$member->getInstrument()], $member);
  111. }
  112. }
  113. // remove empty instruments in stack 1
  114. $stack1 = array_filter($stack1);
  115. // sort by instrument stack2
  116. ksort($stack2);
  117. $members = array_merge($stack1, $stack2);
  118. }
  119. $variables = [$as => $members];
  120. return $this->renderChildrenWithVariables($variables);
  121. }
  122. /**
  123. * @param MemberRepository $memberRepository
  124. */
  125. public function injectMemberRepository(MemberRepository $memberRepository)
  126. {
  127. $this->memberRepository = $memberRepository;
  128. }
  129. }