OtPageRepository.php 3.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130
  1. <?php
  2. namespace Opentalent\OtTemplating\Utilities;
  3. use FluidTYPO3\Vhs\Service\PageService;
  4. use TYPO3\CMS\Core\Utility\GeneralUtility;
  5. use TYPO3\CMS\Extbase\Object\ObjectManager;
  6. use TYPO3\CMS\Frontend\Page\PageRepository;
  7. /**
  8. * Class OtPageRepository
  9. *
  10. * Provides some useful methods to query typo3 pages
  11. *
  12. * @package Opentalent\OtTemplating\Page
  13. */
  14. class OtPageRepository extends PageRepository
  15. {
  16. CONST templates = [
  17. 'Classic' => [
  18. 'name' => 'Classique',
  19. 'description' => 'Le thème classique, simple et complet.',
  20. 'picture' => 'EXT:ot_templating/Resources/Public/media/theme_classic.png'
  21. ],
  22. 'Modern' => [
  23. 'name' => 'Moderne',
  24. 'description' => '[Nouveau] Un thème moderne et intuitif.',
  25. 'picture' => 'EXT:ot_templating/Resources/Public/media/theme_modern.png'
  26. ]
  27. ];
  28. CONST defaultTemplate = 'Classic';
  29. CONST defaultPreferences = [
  30. 'themeColor' => 'lightblue',
  31. 'displayCarousel' => '1'
  32. ];
  33. /**
  34. * Returns the root page of the given page,
  35. * or the page itself if the given page is
  36. * already the rootpage of the site
  37. *
  38. * @param $pageUid
  39. *
  40. * @return array
  41. */
  42. public function getRootPageFor($pageUid) {
  43. $pageService = GeneralUtility::makeInstance(ObjectManager::class)->get(PageService::class);
  44. $rootLine = $pageService->getRootLine($pageUid);
  45. for (end($rootLine); key($rootLine)!==null; prev($rootLine)){
  46. $page = current($rootLine);
  47. if ($page['is_siteroot'] == 1) {
  48. return $page;
  49. }
  50. }
  51. return [];
  52. }
  53. /**
  54. * Recursively returns all the subpages of the given page
  55. *
  56. * @param $pageUid
  57. * @return array
  58. */
  59. public function getAllSubpagesForPage($pageUid) {
  60. $subpages = [];
  61. $stack = $this->getSubpagesForPages(
  62. [$pageUid],
  63. '*',
  64. 'sorting',
  65. '',
  66. false
  67. );
  68. foreach ($stack as $page) {
  69. $subpages[] = $page;
  70. $children = $this->getAllSubpagesForPage($page['uid']);
  71. if (!empty($children)) {
  72. $subpages = array_merge($subpages, $children);
  73. }
  74. }
  75. return $subpages;
  76. }
  77. /**
  78. * Returns the current site template's name
  79. * @param $pageUid
  80. * @return string
  81. */
  82. public function getCurrentTemplate($pageUid) {
  83. $rootPageUid = $this->getRootPageFor($pageUid)['uid'];
  84. if (!($rootPageUid >= 0)) {
  85. return '';
  86. }
  87. $rootPage = $this->getPage($rootPageUid);
  88. $templateName = $rootPage['tx_opentalent_template'];
  89. if ($templateName==='') {
  90. return self::defaultTemplate;
  91. }
  92. return $templateName;
  93. }
  94. /**
  95. * Returns the current site template's name
  96. * @param $pageUid
  97. * @return array
  98. */
  99. public function getTemplatePreferences($pageUid) {
  100. $rootPageUid = $this->getRootPageFor($pageUid)['uid'];
  101. if (!($rootPageUid >= 0)) {
  102. return [];
  103. }
  104. $rootPage = $this->getPage($rootPageUid);
  105. $templatePreferences = $rootPage['tx_opentalent_template_preferences'];
  106. if ($templatePreferences==='') {
  107. return self::defaultPreferences;
  108. }
  109. return json_decode($templatePreferences, true);
  110. }
  111. }