GetByIdViewHelper.php 2.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596
  1. <?php
  2. namespace Opentalent\OtTemplating\ViewHelpers\Events;
  3. use FluidTYPO3\Vhs\Traits\TemplateVariableViewHelperTrait;
  4. use Opentalent\OtCore\Logging\OtLogger;
  5. use Opentalent\OtCore\ViewHelpers\OtAbstractViewHelper;
  6. use Opentalent\OtCore\Domain\Model\Event;
  7. use Opentalent\OtCore\Domain\Repository\EventRepository;
  8. use Opentalent\OtCore\Exception\ApiRequestException;
  9. /**
  10. * This view helper returns the Event object matching the given id
  11. *
  12. * {namespace ot=Opentalent\OtTemplating\ViewHelpers}
  13. *
  14. * <ot:events.getById as="event"
  15. * eventId="1">
  16. * <f:debug>{event}</f:debug>
  17. * </ot:events.getById>
  18. *
  19. * @package Opentalent\OtTemplating\ViewHelpers
  20. */
  21. class GetByIdViewHelper 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 EventRepository
  30. */
  31. protected EventRepository $eventRepository;
  32. /**
  33. * -- This method is expected by Fluid --
  34. * Declares the viewhelper's parameters
  35. */
  36. public function initializeArguments()
  37. {
  38. $this->registerArgument(
  39. 'as',
  40. 'string',
  41. 'Name of the returned array',
  42. true
  43. );
  44. $this->registerArgument(
  45. 'eventId',
  46. 'integer',
  47. 'Id of the event',
  48. true
  49. );
  50. }
  51. /**
  52. * -- This method is expected by Fluid --
  53. * Renders the content as html
  54. *
  55. * @return string
  56. * @throws ApiRequestException
  57. */
  58. public function render()
  59. {
  60. $as = $this->arguments['as'];
  61. $eventId = $this->arguments['eventId'];
  62. try {
  63. $event = $this->eventRepository->findById($eventId);
  64. } catch (ApiRequestException $e) {
  65. OtLogger::error(sprintf('API Error: %s', $e->getMessage()));
  66. $event = new Event();
  67. $event->setName("<Erreur>");
  68. $event->setDescription("Une erreur s'est produite et ne permet pas l'affichage de cet évènement. Veuillez nous excusez pour la gêne occasionnée.");
  69. }
  70. if ($event === null) {
  71. $event = new Event();
  72. $event->setName("(Évènement supprimé)");
  73. }
  74. $variables = [$as => $event];
  75. return $this->renderChildrenWithVariables($variables);
  76. }
  77. /**
  78. * @param EventRepository $eventRepository
  79. */
  80. public function injectEventRepository(EventRepository $eventRepository)
  81. {
  82. $this->eventRepository = $eventRepository;
  83. }
  84. }