GetAllViewHelper.php 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. <?php
  2. namespace Opentalent\OtTemplating\ViewHelpers\Members;
  3. use FluidTYPO3\Vhs\Traits\TemplateVariableViewHelperTrait;
  4. use Opentalent\OtCore\Domain\Repository\MemberRepository;
  5. use Opentalent\OtCore\Exception\ApiRequestException;
  6. use Opentalent\OtCore\Logging\OtLogger;
  7. use Opentalent\OtCore\ViewHelpers\OtAbstractViewHelper;
  8. /**
  9. * This view helper give access to an array named according to the 'as' variable
  10. * and which contains the members of the structure, eventually grouped by instruments
  11. *
  12. * {namespace ot=Opentalent\OtTemplating\ViewHelpers}
  13. *
  14. * <ot:members.getAll as="members"
  15. * organizationId="{settings.organizationId}">
  16. * <f:debug>{members}</f:debug>
  17. * </ot:members.getAll>
  18. *
  19. * @package Opentalent\OtTemplating\ViewHelpers
  20. */
  21. class GetAllViewHelper extends OtAbstractViewHelper {
  22. use TemplateVariableViewHelperTrait;
  23. /**
  24. * >> Required to prevent typo3 to escape the html output
  25. * @var boolean
  26. */
  27. protected $escapeOutput = false;
  28. /**
  29. * @var MemberRepository
  30. *
  31. */
  32. protected MemberRepository $memberRepository;
  33. /**
  34. * -- This method is expected by Fluid --
  35. * Declares the viewhelper's parameters
  36. */
  37. public function initializeArguments()
  38. {
  39. $this->registerArgument(
  40. 'as',
  41. 'string',
  42. 'Name of the returned array',
  43. true
  44. );
  45. $this->registerArgument(
  46. 'organizationId',
  47. 'integer',
  48. 'Id of the current structure',
  49. true
  50. );
  51. $this->registerArgument(
  52. 'groupByInstruments',
  53. 'bool',
  54. 'If true, returns an array of the form [instrument=>[members]],
  55. else the returned array is simply [members]',
  56. false,
  57. false
  58. );
  59. }
  60. /**
  61. * -- This method is expected by Fluid --
  62. * Renders the content as html
  63. *
  64. * @return string
  65. */
  66. public function render(): string
  67. {
  68. // Get current settings
  69. $as = $this->arguments['as'];
  70. $organizationId = $this->arguments['organizationId'];
  71. $groupByInstruments = $this->arguments['groupByInstruments'];
  72. if ($groupByInstruments) {
  73. $members = $this->getMembersAsGroups($organizationId);
  74. } else {
  75. $members = $this->getMembersAsSimpleList($organizationId);
  76. }
  77. $variables = [$as => $members];
  78. return $this->renderChildrenWithVariables($variables);
  79. }
  80. /**
  81. * Return the organization members as a simple array, sorted by name
  82. *
  83. * @param int $organizationId
  84. * @return array
  85. */
  86. private function getMembersAsSimpleList(int $organizationId): array
  87. {
  88. $members = $this->getMembers($organizationId);
  89. usort(
  90. $members,
  91. static function ($m1, $m2) { return strcmp($m1->getName(), $m2->getName()); }
  92. );
  93. return $members;
  94. }
  95. /**
  96. * Return the organization members as an array of the form :
  97. * [
  98. * 'Instrument 1' => [Member1, Member2, ...],
  99. * 'Instrument 2' => [Member3, ...],
  100. * ]
  101. *
  102. * Instruments keys are translated and sorted alphabetically, except for CONDUCTOR which shall appear first
  103. * Group members are sorted by name
  104. *
  105. * @param int $organizationId
  106. * @return array
  107. */
  108. private function getMembersAsGroups(int $organizationId): array
  109. {
  110. $members = $this->getMembers($organizationId);
  111. $stack = ['CONDUCTOR' => []];
  112. $conductors = [];
  113. foreach ($members as $member) {
  114. if ($member->getInstrument() === 'CONDUCTOR') {
  115. $conductors[] = $member;
  116. continue;
  117. }
  118. $instrument = ucfirst($this->translate($member->getInstrument()));
  119. if (!array_key_exists($instrument, $stack)) {
  120. $stack[$instrument] = [$member];
  121. continue;
  122. }
  123. $stack[$instrument][] = $member;
  124. }
  125. // remove empty instruments in stack 1
  126. $stack = array_filter($stack);
  127. // sort by instrument stack2
  128. ksort($stack);
  129. // sort groups by name
  130. foreach (array_values($stack) as $group) {
  131. usort(
  132. $group,
  133. static function ($m1, $m2) { return strcmp($m1->getName(), $m2->getName()); }
  134. );
  135. }
  136. // Add the conductors in first pos
  137. if ($conductors) {
  138. $stack = [ucfirst($this->translate('CONDUCTOR')) => $conductors] + $stack;
  139. }
  140. return $stack;
  141. }
  142. private function getMembers(int $organizationId): array
  143. {
  144. try {
  145. // Get members of the structure
  146. return $this->memberRepository->findByOrganizationId($organizationId)->getMembers();
  147. } catch (ApiRequestException $e) {
  148. OtLogger::error(sprintf('API Error: %s', $e->getMessage()));
  149. return [];
  150. }
  151. }
  152. /**
  153. * @param MemberRepository $memberRepository
  154. */
  155. public function injectMemberRepository(MemberRepository $memberRepository): void
  156. {
  157. $this->memberRepository = $memberRepository;
  158. }
  159. }