class ConnectionAddController in RedHen CRM 8
Class ConnectionAddController.
@package Drupal\redhen_connection\Controller
Hierarchy
- class \Drupal\Core\Controller\ControllerBase implements ContainerInjectionInterface uses LoggerChannelTrait, MessengerTrait, LinkGeneratorTrait, RedirectDestinationTrait, UrlGeneratorTrait, StringTranslationTrait
- class \Drupal\redhen_connection\Controller\ConnectionAddController
Expanded class hierarchy of ConnectionAddController
File
- modules/
redhen_connection/ src/ Controller/ ConnectionAddController.php, line 18
Namespace
Drupal\redhen_connection\ControllerView source
class ConnectionAddController extends ControllerBase {
/**
* Initialize entity storage.
*/
public function __construct(EntityStorageInterface $storage, EntityStorageInterface $type_storage) {
$this->storage = $storage;
$this->typeStorage = $type_storage;
}
/**
* {@inheritdoc}
*/
public static function create(ContainerInterface $container) {
/** @var \Drupal\Core\Entity\EntityTypeManagerInterface $entity_type_manager */
$entity_type_manager = $container
->get('entity_type.manager');
return new static($entity_type_manager
->getStorage('redhen_connection'), $entity_type_manager
->getStorage('redhen_connection_type'));
}
/**
* Displays add links for available bundles/types for redhen_connection.
*
* @param \Symfony\Component\HttpFoundation\Request $request
* The current request object.
*
* @return array
* A render array for a list of the redhen_connection bundles/types that can
* be added or if there is only one type/bundle defined for the site,
* the function returns the add page for that bundle/type.
*/
public function add(Request $request) {
$entity = redhen_connection_get_connection_entity_from_route();
$types = $this->typeStorage
->loadMultiple();
foreach ($types as $key => $redhen_connection_type) {
$connection = $redhen_connection_type
->getEndpointEntityTypes($entity
->getEntityTypeId(), $entity
->getType());
if (empty($connection)) {
unset($types[$key]);
}
}
if ($types && count($types) == 1) {
$type = reset($types);
return $this
->addForm($request, $type, $entity);
}
if (count($types) === 0) {
return [
'#markup' => $this
->t('You have not created any %bundle types yet. @link to add a new type.', [
'%bundle' => 'Connection',
'@link' => Link::createFromRoute($this
->t('Go to the type creation page'), 'entity.redhen_connection_type.add_form'),
]),
];
}
return [
'#theme' => 'redhen_connection_content_add_list',
'#content' => $types,
'#entity' => $entity,
];
}
/**
* Provides the page title for add controller.
*
* @return string
* The page title.
*/
public function getAddTitle() {
$entity_type = redhen_connection_get_connection_entity_from_route()
->getEntityType();
return t('Select a @type Connection Type', [
'@type' => $entity_type
->getLabel(),
]);
}
/**
* Creation form for redhen_connection entities of given bundle/type.
*
* @param \Symfony\Component\HttpFoundation\Request $request
* The current request object.
* @param \Drupal\Core\Entity\EntityInterface $redhen_connection_type
* The custom bundle to add.
* @param \Drupal\Core\Entity\EntityInterface $entity
* The entity for one of the endpoints.
*
* @return array
* A form array as expected by drupal_render().
*/
public function addForm(Request $request, EntityInterface $redhen_connection_type) {
$entity = redhen_connection_get_connection_entity_from_route();
$endpoint_fields = $redhen_connection_type
->getEndpointFields($entity
->getEntityTypeId(), $entity
->getType());
if (empty($endpoint_fields)) {
// No valid endpoint fields found for the provided connection type and
// entity.
throw new NotFoundHttpException();
}
$connection_entity = $this->storage
->create([
'type' => $redhen_connection_type
->id(),
]);
// Grab the first field if we have more than one.
$field = reset($endpoint_fields);
// Set the value of the endpoint.
$connection_entity
->set($field, $entity);
return $this
->entityFormBuilder()
->getForm($connection_entity, 'default', [
'fixed_endpoint' => $field,
]);
}
/**
* Provides the page title for this controller.
*
* @param \Drupal\Core\Entity\EntityInterface $redhen_connection_type
* The custom bundle/type being added.
* @param \Drupal\Core\Entity\EntityInterface $entity
* The provided endpoint.
*
* @return string
* The page title.
*/
public function getAddFormTitle(EntityInterface $redhen_connection_type) {
$entity = redhen_connection_get_connection_entity_from_route();
return t('Create @type Connection for @entity', [
'@type' => $redhen_connection_type
->label(),
'@entity' => $entity
->label(),
]);
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ConnectionAddController:: |
public | function | Displays add links for available bundles/types for redhen_connection. | |
ConnectionAddController:: |
public | function | Creation form for redhen_connection entities of given bundle/type. | |
ConnectionAddController:: |
public static | function |
Instantiates a new instance of this class. Overrides ControllerBase:: |
|
ConnectionAddController:: |
public | function | Provides the page title for this controller. | |
ConnectionAddController:: |
public | function | Provides the page title for add controller. | |
ConnectionAddController:: |
public | function | Initialize entity storage. | |
ControllerBase:: |
protected | property | The configuration factory. | |
ControllerBase:: |
protected | property | The current user service. | 1 |
ControllerBase:: |
protected | property | The entity form builder. | |
ControllerBase:: |
protected | property | The entity manager. | |
ControllerBase:: |
protected | property | The entity type manager. | |
ControllerBase:: |
protected | property | The form builder. | 2 |
ControllerBase:: |
protected | property | The key-value storage. | 1 |
ControllerBase:: |
protected | property | The language manager. | 1 |
ControllerBase:: |
protected | property | The module handler. | 2 |
ControllerBase:: |
protected | property | The state service. | |
ControllerBase:: |
protected | function | Returns the requested cache bin. | |
ControllerBase:: |
protected | function | Retrieves a configuration object. | |
ControllerBase:: |
private | function | Returns the service container. | |
ControllerBase:: |
protected | function | Returns the current user. | 1 |
ControllerBase:: |
protected | function | Retrieves the entity form builder. | |
ControllerBase:: |
protected | function | Retrieves the entity manager service. | |
ControllerBase:: |
protected | function | Retrieves the entity type manager. | |
ControllerBase:: |
protected | function | Returns the form builder service. | 2 |
ControllerBase:: |
protected | function | Returns a key/value storage collection. | 1 |
ControllerBase:: |
protected | function | Returns the language manager service. | 1 |
ControllerBase:: |
protected | function | Returns the module handler. | 2 |
ControllerBase:: |
protected | function |
Returns a redirect response object for the specified route. Overrides UrlGeneratorTrait:: |
|
ControllerBase:: |
protected | function | Returns the state storage service. | |
LinkGeneratorTrait:: |
protected | property | The link generator. | 1 |
LinkGeneratorTrait:: |
protected | function | Returns the link generator. | |
LinkGeneratorTrait:: |
protected | function | Renders a link to a route given a route name and its parameters. | |
LinkGeneratorTrait:: |
public | function | Sets the link generator service. | |
LoggerChannelTrait:: |
protected | property | The logger channel factory service. | |
LoggerChannelTrait:: |
protected | function | Gets the logger for a specific channel. | |
LoggerChannelTrait:: |
public | function | Injects the logger channel factory. | |
MessengerTrait:: |
protected | property | The messenger. | 29 |
MessengerTrait:: |
public | function | Gets the messenger. | 29 |
MessengerTrait:: |
public | function | Sets the messenger. | |
RedirectDestinationTrait:: |
protected | property | The redirect destination service. | 1 |
RedirectDestinationTrait:: |
protected | function | Prepares a 'destination' URL query parameter for use with \Drupal\Core\Url. | |
RedirectDestinationTrait:: |
protected | function | Returns the redirect destination service. | |
RedirectDestinationTrait:: |
public | function | Sets the redirect destination service. | |
StringTranslationTrait:: |
protected | property | The string translation service. | 1 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
StringTranslationTrait:: |
protected | function | Translates a string to the current language or to a given language. | |
UrlGeneratorTrait:: |
protected | property | The url generator. | |
UrlGeneratorTrait:: |
protected | function | Returns the URL generator service. | |
UrlGeneratorTrait:: |
public | function | Sets the URL generator service. | |
UrlGeneratorTrait:: |
protected | function | Generates a URL or path for a specific route based on the given parameters. |