mirror of
https://gitlab.unicamp.br/infimecc_drupal11_modules/site_users.git
synced 2026-05-03 14:40:41 -03:00
Sobrescreve rota canônica do usuário com micro-site e move perfil para /user/{id}/profile
- RouteSubscriber redireciona entity.user.canonical ao MicrositeHomeController
- Nova rota site_users_microsite.profile em /user/{user}/profile com _entity_access
- Corrige configFactory() → config() no MicrositeContentController
- Exclui rota de settings do tema do micro-site no ThemeNegotiator
- Adiciona local task tabs para settings (módulo pai e submódulo)
Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
This commit is contained in:
@@ -7,3 +7,4 @@ dependencies:
|
||||
- drupal:user
|
||||
- drupal:node
|
||||
- site_users:site_users
|
||||
- structural_pages:structural_pages
|
||||
|
||||
@@ -0,0 +1,6 @@
|
||||
<?php
|
||||
|
||||
/**
|
||||
* @file
|
||||
* Install, update and uninstall functions for the Site Users Microsite module.
|
||||
*/
|
||||
@@ -1,4 +1,18 @@
|
||||
# Aba "Conteúdo" nas páginas de perfil de usuário.
|
||||
# Aba de configurações do submódulo na página de settings do módulo pai.
|
||||
site_users_microsite.settings_tab:
|
||||
route_name: site_users_microsite.settings
|
||||
title: 'Microsite'
|
||||
base_route: site_users.settings
|
||||
weight: 10
|
||||
|
||||
# Aba "Perfil" nas páginas do micro-site do usuário.
|
||||
site_users_microsite.profile_tab:
|
||||
route_name: site_users_microsite.profile
|
||||
title: 'Profile'
|
||||
base_route: entity.user.canonical
|
||||
weight: 5
|
||||
|
||||
# Aba "Conteúdo" nas páginas do micro-site do usuário.
|
||||
site_users_microsite.content_tab:
|
||||
route_name: site_users_microsite.content
|
||||
title: 'Content'
|
||||
|
||||
@@ -1,3 +1,16 @@
|
||||
site_users_microsite.profile:
|
||||
path: '/user/{user}/profile'
|
||||
defaults:
|
||||
_controller: '\Drupal\site_users_microsite\Controller\MicrositeHomeController::profile'
|
||||
_title_callback: '\Drupal\site_users_microsite\Controller\MicrositeHomeController::title'
|
||||
requirements:
|
||||
_entity_access: 'user.view'
|
||||
user: \d+
|
||||
options:
|
||||
parameters:
|
||||
user:
|
||||
type: entity:user
|
||||
|
||||
site_users_microsite.content:
|
||||
path: '/user/{user}/content'
|
||||
defaults:
|
||||
|
||||
@@ -3,3 +3,8 @@ services:
|
||||
class: Drupal\site_users_microsite\Theme\MicrositeThemeNegotiator
|
||||
tags:
|
||||
- { name: theme_negotiator, priority: 100 }
|
||||
|
||||
site_users_microsite.route_subscriber:
|
||||
class: Drupal\site_users_microsite\Routing\RouteSubscriber
|
||||
tags:
|
||||
- { name: event_subscriber }
|
||||
|
||||
@@ -67,8 +67,7 @@ class MicrositeContentController extends ControllerBase {
|
||||
* Retorna os tipos de conteúdo permitidos para os papéis do usuário.
|
||||
*/
|
||||
protected function getAllowedContentTypes(UserInterface $user): array {
|
||||
$role_content_types = $this->configFactory()
|
||||
->get('site_users_microsite.settings')
|
||||
$role_content_types = $this->config('site_users_microsite.settings')
|
||||
->get('role_content_types') ?? [];
|
||||
|
||||
$allowed = [];
|
||||
|
||||
@@ -0,0 +1,63 @@
|
||||
<?php
|
||||
|
||||
namespace Drupal\site_users_microsite\Controller;
|
||||
|
||||
use Drupal\Core\Controller\ControllerBase;
|
||||
use Drupal\Core\StringTranslation\TranslatableMarkup;
|
||||
use Drupal\user\UserInterface;
|
||||
|
||||
/**
|
||||
* Controller para a página inicial do micro-site do usuário.
|
||||
*
|
||||
* Carrega e exibe o nó do tipo content_page cujo autor é o usuário
|
||||
* da rota /user/{user}/home.
|
||||
*/
|
||||
class MicrositeHomeController extends ControllerBase {
|
||||
|
||||
/**
|
||||
* Página inicial do micro-site.
|
||||
*/
|
||||
public function home(UserInterface $user): array {
|
||||
$cache = [
|
||||
'tags' => ['node_list:content_page', 'user:' . $user->id()],
|
||||
'contexts' => ['route'],
|
||||
];
|
||||
|
||||
$nids = $this->entityTypeManager()->getStorage('node')
|
||||
->getQuery()
|
||||
->condition('uid', $user->id())
|
||||
->condition('type', 'content_page')
|
||||
->condition('status', 1)
|
||||
->accessCheck(TRUE)
|
||||
->range(0, 1)
|
||||
->execute();
|
||||
|
||||
if (empty($nids)) {
|
||||
return [
|
||||
'#markup' => $this->t('No content published yet.'),
|
||||
'#cache' => $cache,
|
||||
];
|
||||
}
|
||||
|
||||
$node = $this->entityTypeManager()->getStorage('node')->load(reset($nids));
|
||||
$build = $this->entityTypeManager()->getViewBuilder('node')->view($node, 'full');
|
||||
$build['#cache'] = $cache;
|
||||
|
||||
return $build;
|
||||
}
|
||||
|
||||
/**
|
||||
* Página de perfil do usuário em /user/{user}/profile.
|
||||
*/
|
||||
public function profile(UserInterface $user): array {
|
||||
return $this->entityTypeManager()->getViewBuilder('user')->view($user, 'full');
|
||||
}
|
||||
|
||||
/**
|
||||
* Callback de título para a página inicial.
|
||||
*/
|
||||
public function title(UserInterface $user): TranslatableMarkup {
|
||||
return $this->t("@name", ['@name' => $user->getDisplayName()]);
|
||||
}
|
||||
|
||||
}
|
||||
23
modules/site_users_microsite/src/Routing/RouteSubscriber.php
Normal file
23
modules/site_users_microsite/src/Routing/RouteSubscriber.php
Normal file
@@ -0,0 +1,23 @@
|
||||
<?php
|
||||
|
||||
namespace Drupal\site_users_microsite\Routing;
|
||||
|
||||
use Drupal\Core\Routing\RouteSubscriberBase;
|
||||
use Symfony\Component\Routing\RouteCollection;
|
||||
|
||||
/**
|
||||
* Sobrescreve a rota canônica do usuário para exibir o micro-site.
|
||||
*/
|
||||
class RouteSubscriber extends RouteSubscriberBase {
|
||||
|
||||
/**
|
||||
* {@inheritdoc}
|
||||
*/
|
||||
protected function alterRoutes(RouteCollection $collection): void {
|
||||
if ($route = $collection->get('entity.user.canonical')) {
|
||||
$route->setDefault('_controller', '\Drupal\site_users_microsite\Controller\MicrositeHomeController::home');
|
||||
$route->setDefault('_title_callback', '\Drupal\site_users_microsite\Controller\MicrositeHomeController::title');
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
@@ -15,8 +15,10 @@ class MicrositeThemeNegotiator implements ThemeNegotiatorInterface {
|
||||
*/
|
||||
public function applies(RouteMatchInterface $route_match): bool {
|
||||
$route_name = $route_match->getRouteName();
|
||||
return $route_name === 'entity.user.canonical'
|
||||
|| str_starts_with($route_name, 'site_users_microsite.');
|
||||
$excluded = ['site_users_microsite.settings'];
|
||||
return ($route_name === 'entity.user.canonical'
|
||||
|| str_starts_with($route_name, 'site_users_microsite.'))
|
||||
&& !in_array($route_name, $excluded);
|
||||
}
|
||||
|
||||
/**
|
||||
|
||||
Reference in New Issue
Block a user