class ClientSideFilterTable
Same name in other branches
- 5.x src/Element/ClientSideFilterTable.php \Drupal\devel\Element\ClientSideFilterTable
Provides a render element for filterable table data.
Usage example:
$build['item'] = [
'#type' => 'devel_table_filter',
'#filter_label' => $this->t('Search'),
'#filter_placeholder' => $this->t('Enter element name.'),
'#filter_description' => $this->t('Enter a part of name to filter by.'),
'#header' => $headers,
'#rows' => $rows,
'#empty' => $this->t('No element found.'),
];
Plugin annotation
@RenderElement("devel_table_filter");
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements \Drupal\Component\Plugin\PluginInspectionInterface, \Drupal\Component\Plugin\DerivativeInspectionInterface
- class \Drupal\Core\Plugin\PluginBase extends \Drupal\Component\Plugin\PluginBase uses \Drupal\Core\StringTranslation\StringTranslationTrait, \Drupal\Core\DependencyInjection\DependencySerializationTrait, \Drupal\Core\Messenger\MessengerTrait
- class \Drupal\Core\Render\Element\RenderElement extends \Drupal\Core\Plugin\PluginBase implements \Drupal\Core\Render\Element\ElementInterface
- class \Drupal\devel\Element\ClientSideFilterTable extends \Drupal\Core\Render\Element\RenderElement
- class \Drupal\Core\Render\Element\RenderElement extends \Drupal\Core\Plugin\PluginBase implements \Drupal\Core\Render\Element\ElementInterface
- class \Drupal\Core\Plugin\PluginBase extends \Drupal\Component\Plugin\PluginBase uses \Drupal\Core\StringTranslation\StringTranslationTrait, \Drupal\Core\DependencyInjection\DependencySerializationTrait, \Drupal\Core\Messenger\MessengerTrait
Expanded class hierarchy of ClientSideFilterTable
1 file declares its use of ClientSideFilterTable
- DevelClientSideFilterTableTest.php in tests/
src/ Unit/ DevelClientSideFilterTableTest.php
8 #type uses of ClientSideFilterTable
- ContainerInfoController::parameterList in src/
Controller/ ContainerInfoController.php - Builds the parameters overview page.
- ContainerInfoController::serviceList in src/
Controller/ ContainerInfoController.php - Builds the services overview page.
- DevelClientSideFilterTableTest::providerPreRenderTable in tests/
src/ Unit/ DevelClientSideFilterTableTest.php - Data provider for preRenderHtmlTag test.
- DevelController::stateSystemPage in src/
Controller/ DevelController.php - Builds the state variable overview page.
- ElementInfoController::elementList in src/
Controller/ ElementInfoController.php - Builds the element overview page.
File
-
src/
Element/ ClientSideFilterTable.php, line 27
Namespace
Drupal\devel\ElementView source
class ClientSideFilterTable extends RenderElement {
/**
* {@inheritdoc}
*/
public function getInfo() {
$class = get_class($this);
return [
'#filter_label' => $this->t('Search'),
'#filter_placeholder' => $this->t('Search'),
'#filter_description' => $this->t('Search'),
'#header' => [],
'#rows' => [],
'#empty' => '',
'#sticky' => FALSE,
'#responsive' => TRUE,
'#attributes' => [],
'#pre_render' => [
[
$class,
'preRenderTable',
],
],
];
}
/**
* Pre-render callback: Assemble render array for the filterable table.
*
* @param array $element
* An associative array containing the properties of the element.
*
* @return array
* The $element with prepared render array ready for rendering.
*/
public static function preRenderTable(array $element) {
$build['#attached']['library'][] = 'devel/devel-table-filter';
$identifier = Html::getUniqueId('js-devel-table-filter');
$build['filters'] = [
'#type' => 'container',
'#weight' => -1,
'#attributes' => [
'class' => [
'table-filter',
'js-show',
],
],
];
$build['filters']['name'] = [
'#type' => 'search',
'#size' => 30,
'#title' => $element['#filter_label'],
'#placeholder' => $element['#filter_placeholder'],
'#attributes' => [
'class' => [
'table-filter-text',
],
'data-table' => ".{$identifier}",
'autocomplete' => 'off',
'title' => $element['#filter_description'],
],
];
foreach ($element['#rows'] as &$row) {
foreach ($row as &$cell) {
if (isset($cell['data']) && !empty($cell['filter'])) {
$cell['class'][] = 'table-filter-text-source';
}
}
}
$build['table'] = [
'#type' => 'table',
'#header' => $element['#header'],
'#rows' => $element['#rows'],
'#empty' => $element['#empty'],
'#sticky' => $element['#sticky'],
'#responsive' => $element['#responsive'],
'#attributes' => $element['#attributes'],
];
$build['table']['#attributes']['class'][] = $identifier;
$build['table']['#attributes']['class'][] = 'devel-table-filter';
return $build;
}
}
Members
Title Sort descending | Modifiers | Object type | Summary | Overriden Title | Overrides |
---|---|---|---|---|---|
ClientSideFilterTable::getInfo | public | function | Returns the element properties for this element. | Overrides ElementInterface::getInfo | |
ClientSideFilterTable::preRenderTable | public static | function | Pre-render callback: Assemble render array for the filterable table. | ||
PluginInspectionInterface::getPluginDefinition | public | function | Gets the definition of the plugin implementation. | 6 | |
PluginInspectionInterface::getPluginId | public | function | Gets the plugin_id of the plugin instance. | 2 | |
RenderElement::preRenderAjaxForm | public static | function | Adds Ajax information about an element to communicate with JavaScript. | ||
RenderElement::preRenderGroup | public static | function | Adds members of this group as actual elements for rendering. | ||
RenderElement::processAjaxForm | public static | function | Form element processing handler for the #ajax form property. | 1 | |
RenderElement::processGroup | public static | function | Arranges elements into groups. | ||
RenderElement::setAttributes | public static | function | Sets a form element's class attribute. | Overrides ElementInterface::setAttributes |