class EasyEmailHtmlRouteProvider in Easy Email 8
Same name and namespace in other branches
- 2.0.x src/EasyEmailHtmlRouteProvider.php \Drupal\easy_email\EasyEmailHtmlRouteProvider
Provides routes for Email entities.
Hierarchy
- class \Drupal\Core\Entity\Routing\DefaultHtmlRouteProvider implements EntityHandlerInterface, EntityRouteProviderInterface
- class \Drupal\Core\Entity\Routing\AdminHtmlRouteProvider
- class \Drupal\easy_email\EasyEmailHtmlRouteProvider
- class \Drupal\Core\Entity\Routing\AdminHtmlRouteProvider
Expanded class hierarchy of EasyEmailHtmlRouteProvider
See also
\Drupal\Core\Entity\Routing\AdminHtmlRouteProvider
\Drupal\Core\Entity\Routing\DefaultHtmlRouteProvider
File
- src/
EasyEmailHtmlRouteProvider.php, line 15
Namespace
Drupal\easy_emailView source
class EasyEmailHtmlRouteProvider extends AdminHtmlRouteProvider {
/**
* {@inheritdoc}
*/
public function getRoutes(EntityTypeInterface $entity_type) {
$collection = parent::getRoutes($entity_type);
$entity_type_id = $entity_type
->id();
if ($history_route = $this
->getHistoryRoute($entity_type)) {
$collection
->add("entity.{$entity_type_id}.version_history", $history_route);
}
if ($revision_route = $this
->getRevisionRoute($entity_type)) {
$collection
->add("entity.{$entity_type_id}.revision", $revision_route);
}
if ($revert_route = $this
->getRevisionRevertRoute($entity_type)) {
$collection
->add("entity.{$entity_type_id}.revision_revert", $revert_route);
}
if ($delete_route = $this
->getRevisionDeleteRoute($entity_type)) {
$collection
->add("entity.{$entity_type_id}.revision_delete", $delete_route);
}
if ($translation_route = $this
->getRevisionTranslationRevertRoute($entity_type)) {
$collection
->add("{$entity_type_id}.revision_revert_translation_confirm", $translation_route);
}
if ($settings_form_route = $this
->getSettingsFormRoute($entity_type)) {
$collection
->add("{$entity_type_id}.settings", $settings_form_route);
}
if ($preview_route = $this
->getPreviewRoute($entity_type)) {
$collection
->add("entity.{$entity_type_id}.preview", $preview_route);
}
if ($preview_plain_route = $this
->getPreviewPlainRoute($entity_type)) {
$collection
->add("entity.{$entity_type_id}.preview_plain", $preview_plain_route);
}
return $collection;
}
protected function getPreviewRoute(EntityTypeInterface $entity_type) {
if ($entity_type
->hasLinkTemplate('preview')) {
$entity_type_id = $entity_type
->id();
$route = new Route($entity_type
->getLinkTemplate('preview'));
$route
->addDefaults([
'_title' => "{$entity_type->getLabel()} preview",
'_controller' => '\\Drupal\\easy_email\\Controller\\EasyEmailController::preview',
])
->setRequirement('_entity_access', "{$entity_type_id}.view")
->setOption('parameters', [
$entity_type_id => [
'type' => 'entity:' . $entity_type_id,
],
]);
// Entity types with serial IDs can specify this in their route
// requirements, improving the matching process.
if ($this
->getEntityTypeIdKeyType($entity_type) === 'integer') {
$route
->setRequirement($entity_type_id, '\\d+');
}
return $route;
}
}
protected function getPreviewPlainRoute(EntityTypeInterface $entity_type) {
if ($entity_type
->hasLinkTemplate('preview_plain')) {
$entity_type_id = $entity_type
->id();
$route = new Route($entity_type
->getLinkTemplate('preview_plain'));
$route
->addDefaults([
'_title' => "{$entity_type->getLabel()} preview",
'_controller' => '\\Drupal\\easy_email\\Controller\\EasyEmailController::previewPlain',
])
->setRequirement('_entity_access', "{$entity_type_id}.view")
->setOption('parameters', [
$entity_type_id => [
'type' => 'entity:' . $entity_type_id,
],
]);
// Entity types with serial IDs can specify this in their route
// requirements, improving the matching process.
if ($this
->getEntityTypeIdKeyType($entity_type) === 'integer') {
$route
->setRequirement($entity_type_id, '\\d+');
}
return $route;
}
}
/**
* Gets the version history route.
*
* @param \Drupal\Core\Entity\EntityTypeInterface $entity_type
* The entity type.
*
* @return \Symfony\Component\Routing\Route|null
* The generated route, if available.
*/
protected function getHistoryRoute(EntityTypeInterface $entity_type) {
if ($entity_type
->hasLinkTemplate('version-history')) {
$route = new Route($entity_type
->getLinkTemplate('version-history'));
$route
->setDefaults([
'_title' => "{$entity_type->getLabel()} revisions",
'_controller' => '\\Drupal\\easy_email\\Controller\\EasyEmailController::revisionOverview',
])
->setRequirement('_permission', 'access email revisions')
->setOption('_admin_route', TRUE);
return $route;
}
}
/**
* Gets the revision route.
*
* @param \Drupal\Core\Entity\EntityTypeInterface $entity_type
* The entity type.
*
* @return \Symfony\Component\Routing\Route|null
* The generated route, if available.
*/
protected function getRevisionRoute(EntityTypeInterface $entity_type) {
if ($entity_type
->hasLinkTemplate('revision')) {
$route = new Route($entity_type
->getLinkTemplate('revision'));
$route
->setDefaults([
'_controller' => '\\Drupal\\easy_email\\Controller\\EasyEmailController::revisionShow',
'_title_callback' => '\\Drupal\\easy_email\\Controller\\EasyEmailController::revisionPageTitle',
])
->setRequirement('_permission', 'access email revisions')
->setOption('_admin_route', TRUE);
return $route;
}
}
/**
* Gets the revision revert route.
*
* @param \Drupal\Core\Entity\EntityTypeInterface $entity_type
* The entity type.
*
* @return \Symfony\Component\Routing\Route|null
* The generated route, if available.
*/
protected function getRevisionRevertRoute(EntityTypeInterface $entity_type) {
if ($entity_type
->hasLinkTemplate('revision_revert')) {
$route = new Route($entity_type
->getLinkTemplate('revision_revert'));
$route
->setDefaults([
'_form' => '\\Drupal\\easy_email\\Form\\EasyEmailRevisionRevertForm',
'_title' => 'Revert to earlier revision',
])
->setRequirement('_permission', 'revert all email revisions')
->setOption('_admin_route', TRUE);
return $route;
}
}
/**
* Gets the revision delete route.
*
* @param \Drupal\Core\Entity\EntityTypeInterface $entity_type
* The entity type.
*
* @return \Symfony\Component\Routing\Route|null
* The generated route, if available.
*/
protected function getRevisionDeleteRoute(EntityTypeInterface $entity_type) {
if ($entity_type
->hasLinkTemplate('revision_delete')) {
$route = new Route($entity_type
->getLinkTemplate('revision_delete'));
$route
->setDefaults([
'_form' => '\\Drupal\\easy_email\\Form\\EasyEmailRevisionDeleteForm',
'_title' => 'Delete earlier revision',
])
->setRequirement('_permission', 'delete all email revisions')
->setOption('_admin_route', TRUE);
return $route;
}
}
/**
* Gets the revision translation revert route.
*
* @param \Drupal\Core\Entity\EntityTypeInterface $entity_type
* The entity type.
*
* @return \Symfony\Component\Routing\Route|null
* The generated route, if available.
*/
protected function getRevisionTranslationRevertRoute(EntityTypeInterface $entity_type) {
if ($entity_type
->hasLinkTemplate('translation_revert')) {
$route = new Route($entity_type
->getLinkTemplate('translation_revert'));
$route
->setDefaults([
'_form' => '\\Drupal\\easy_email\\Form\\EasyEmailRevisionRevertTranslationForm',
'_title' => 'Revert to earlier revision of a translation',
])
->setRequirement('_permission', 'revert all email revisions')
->setOption('_admin_route', TRUE);
return $route;
}
}
/**
* Gets the settings form route.
*
* @param \Drupal\Core\Entity\EntityTypeInterface $entity_type
* The entity type.
*
* @return \Symfony\Component\Routing\Route|null
* The generated route, if available.
*/
protected function getSettingsFormRoute(EntityTypeInterface $entity_type) {
if (!$entity_type
->getBundleEntityType()) {
$route = new Route("/admin/structure/{$entity_type->id()}/settings");
$route
->setDefaults([
'_form' => 'Drupal\\easy_email\\Form\\EasyEmailSettingsForm',
'_title' => "{$entity_type->getLabel()} settings",
])
->setRequirement('_permission', $entity_type
->getAdminPermission())
->setOption('_admin_route', TRUE);
return $route;
}
}
}