class AdminController in Search API Sorts Widget 1.x
Class AdminController.
@package Drupal\search_api_sorts_widget\Controller
Hierarchy
- class \Drupal\Core\Controller\ControllerBase implements ContainerInjectionInterface uses LoggerChannelTrait, MessengerTrait, RedirectDestinationTrait, StringTranslationTrait
- class \Drupal\search_api_sorts_widget\Controller\AdminController uses \Drupal\search_api_sorts\ConfigIdEscapeTrait
Expanded class hierarchy of AdminController
File
- src/
Controller/ AdminController.php, line 20
Namespace
Drupal\search_api_sorts_widget\ControllerView source
class AdminController extends ControllerBase {
use ConfigIdEscapeTrait;
/**
* The current request object.
*
* @var \Symfony\Component\HttpFoundation\Request|null
*/
protected $currentRequest;
/**
* The Search API display manager.
*
* @var \Drupal\search_api\Display\DisplayPluginManagerInterface
*/
protected $searchApiDisplayManager;
/**
* AdminController constructor.
*
* @param \Symfony\Component\HttpFoundation\RequestStack $requestStack
* The request stack.
* @param \Drupal\search_api\Display\DisplayPluginManagerInterface $search_api_display_manager
* The Search API display manager.
*/
public function __construct(RequestStack $requestStack, DisplayPluginManagerInterface $search_api_display_manager) {
$this->currentRequest = $requestStack
->getCurrentRequest();
$this->searchApiDisplayManager = $search_api_display_manager;
}
/**
* {@inheritdoc}
*/
public static function create(ContainerInterface $container) {
return new static($container
->get('request_stack'), $container
->get('plugin.manager.search_api.display'));
}
/**
* Overview of search api displays to choose to manage sort fields for.
*/
public function displayListing(IndexInterface $search_api_index) {
$rows = [];
foreach ($this->searchApiDisplayManager
->getInstances() as $display) {
if ($display
->getIndex() instanceof IndexInterface && $search_api_index
->id() === $display
->getIndex()
->id()) {
$row = [];
$row['display'] = $display
->label();
$row['description'] = $display
->getDescription();
$search_api_display = $display
->getPluginId();
$escaped_search_api_display = $this
->getEscapedConfigId($search_api_display);
$links['configure'] = [
'title' => $this
->t('Manage sorts widget'),
'url' => Url::fromRoute('search_api_sorts_widget.search_api_display.sorts_widget', [
'search_api_index' => $search_api_index
->id(),
'search_api_display' => $escaped_search_api_display,
]),
];
$row['operations']['data'] = [
'#type' => 'operations',
'#links' => $links,
];
$rows[] = $row;
}
}
$build['table'] = [
'#type' => 'table',
'#header' => [
$this
->t('Display'),
$this
->t('Description'),
$this
->t('Operations'),
],
'#title' => $this
->t('Sorts widget configuration.'),
'#rows' => $rows,
'#empty' => $this
->t('You have no search displays defined yet. An example of a display is a views page using this index, or a search api pages page.'),
];
return $build;
}
/**
* Callback for search_api_sorts_widget edit form.
*
* Redirect the user to the ManageSortsFieldsForm.
*
* @param \Drupal\search_api_sorts_widget\Entity\SearchApiSortsWidget $search_api_sorts_widget
*
* @return \Symfony\Component\HttpFoundation\RedirectResponse
* @throws \Drupal\Component\Plugin\Exception\PluginException
* @see \Drupal\search_api_sorts\Form\ManageSortFieldsForm
*/
public function redirectEditForm(SearchApiSortsWidget $search_api_sorts_widget) {
// When accessing this page from the config_translation overview,
// a destination parameter is added, which prevents the redirect added in
// this route method.
$this->currentRequest->query
->remove('destination');
$display_id = $this
->getOriginalConfigId($search_api_sorts_widget
->getDisplayId());
/** @var \Drupal\search_api\Display\DisplayInterface $display */
$display = $this->searchApiDisplayManager
->createInstance($display_id);
return $this
->redirect('search_api_sorts_widget.search_api_display.sorts_widget', [
'search_api_index' => $display
->getIndex()
->id(),
'search_api_display' => $search_api_sorts_widget
->getDisplayId(),
]);
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
AdminController:: |
protected | property | The current request object. | |
AdminController:: |
protected | property | The Search API display manager. | |
AdminController:: |
public static | function |
Instantiates a new instance of this class. Overrides ControllerBase:: |
|
AdminController:: |
public | function | Overview of search api displays to choose to manage sort fields for. | |
AdminController:: |
public | function | Callback for search_api_sorts_widget edit form. | |
AdminController:: |
public | function | AdminController constructor. | |
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 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 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. | |
ControllerBase:: |
protected | function | Returns the state storage 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. | 27 |
MessengerTrait:: |
public | function | Gets the messenger. | 27 |
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. | 4 |
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. |