OtPageRepository.php 4.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168
  1. <?php
  2. namespace Opentalent\OtTemplating\Page;
  3. use FluidTYPO3\Vhs\Service\PageService;
  4. use TYPO3\CMS\Core\Database\ConnectionPool;
  5. use TYPO3\CMS\Core\Exception\SiteNotFoundException;
  6. use TYPO3\CMS\Core\Site\SiteFinder;
  7. use TYPO3\CMS\Core\Utility\GeneralUtility;
  8. use TYPO3\CMS\Extbase\Object\ObjectManager;
  9. use TYPO3\CMS\Frontend\Page\PageRepository;
  10. /**
  11. * Class OtPageRepository
  12. *
  13. * Provides some useful methods to query typo3 pages
  14. *
  15. * @package Opentalent\OtTemplating\Page
  16. */
  17. class OtPageRepository extends PageRepository
  18. {
  19. CONST templates = [
  20. 'Classic' => [
  21. 'name' => 'Classique',
  22. 'description' => "Le thème classique, simple et complet. C'est le thème par défaut.",
  23. 'picture' => 'EXT:ot_templating/Resources/Public/media/theme_classic.png'
  24. ],
  25. 'Modern' => [
  26. 'name' => 'Moderne',
  27. 'description' => '[Nouveauté 2020] Un thème moderne et intuitif.',
  28. 'picture' => 'EXT:ot_templating/Resources/Public/media/theme_modern.png'
  29. ]
  30. ];
  31. CONST defaultTemplate = 'Classic';
  32. CONST defaultPreferences = [
  33. 'themeColor' => 'lightblue',
  34. 'displayCarousel' => '1'
  35. ];
  36. /**
  37. * Returns the root page of the given page,
  38. * or the page itself if the given page is
  39. * already the rootpage of the site
  40. *
  41. * @param $pageUid
  42. *
  43. * @return array
  44. */
  45. public function getRootPageFor($pageUid) {
  46. $pageService = GeneralUtility::makeInstance(ObjectManager::class)->get(PageService::class);
  47. $rootLine = $pageService->getRootLine($pageUid);
  48. for (end($rootLine); key($rootLine)!==null; prev($rootLine)){
  49. $page = current($rootLine);
  50. if ($page['is_siteroot'] == 1) {
  51. return $page;
  52. }
  53. }
  54. return [];
  55. }
  56. /**
  57. * Recursively returns all the subpages of the given page
  58. *
  59. * @param $pageUid
  60. * @return array
  61. */
  62. public function getAllSubpagesForPage($pageUid) {
  63. $subpages = [];
  64. $queryBuilder = GeneralUtility::makeInstance(ConnectionPool::class)
  65. ->getQueryBuilderForTable('pages');
  66. $queryBuilder->getRestrictions()->removeAll();
  67. $stack = $queryBuilder
  68. ->select('*')
  69. ->from('pages')
  70. ->where($queryBuilder->expr()->eq('pid', $pageUid))
  71. ->execute()
  72. ->fetchAll();
  73. foreach ($stack as $page) {
  74. $subpages[] = $page;
  75. $children = $this->getAllSubpagesForPage($page['uid']);
  76. if (!empty($children)) {
  77. $subpages = array_merge($subpages, $children);
  78. }
  79. }
  80. return $subpages;
  81. }
  82. /**
  83. * Returns the current site template's name
  84. * @return string
  85. */
  86. public function getCurrentTemplate() {
  87. $rootPageUid = $this->getCurrentSiteRootPageId();
  88. if (!($rootPageUid >= 0)) {
  89. return self::defaultTemplate;
  90. }
  91. $rootPage = $this->getPage($rootPageUid);
  92. $templateName = $rootPage['tx_opentalent_template'];
  93. if ($templateName==='') {
  94. return self::defaultTemplate;
  95. }
  96. return $templateName;
  97. }
  98. /**
  99. * Returns the current site template's name
  100. * @return array
  101. */
  102. public function getTemplatePreferences() {
  103. $rootPageUid = $this->getCurrentSiteRootPageId();
  104. if (!($rootPageUid >= 0)) {
  105. return [];
  106. }
  107. $rootPage = $this->getPage($rootPageUid);
  108. $templatePreferences = $rootPage['tx_opentalent_template_preferences'];
  109. if ($templatePreferences==='') {
  110. return self::defaultPreferences;
  111. }
  112. return json_decode($templatePreferences, true);
  113. }
  114. /**
  115. * Returns the typo3 site matching the current request
  116. *
  117. */
  118. public function getCurrentSite() {
  119. $request = $GLOBALS['TYPO3_REQUEST'];
  120. $site = $request->getAttribute('site');
  121. return GeneralUtility::makeInstance(SiteFinder::class)
  122. ->getSiteByIdentifier($site->getIdentifier());
  123. }
  124. /**
  125. *
  126. */
  127. public function getCurrentSiteRootPageId() {
  128. $site = $this->getCurrentSite();
  129. return $site->getRootPageId();
  130. }
  131. /**
  132. *
  133. */
  134. public function getCurrentSiteRootPageUri() {
  135. $site = $this->getCurrentSite();
  136. return $site->getBase();
  137. }
  138. /**
  139. *
  140. */
  141. public function getCurrentSiteRootPage() {
  142. $uid = $this->getCurrentSiteRootPageUri();
  143. return $this->getPage($uid);
  144. }
  145. }