StyleTest.php
Same filename in this branch
Same filename in other branches
- 8.9.x core/modules/views/tests/src/Kernel/Plugin/StyleTest.php
- 8.9.x core/modules/views/tests/modules/views_test_data/src/Plugin/views/style/StyleTest.php
- 10 core/modules/ckeditor5/tests/src/FunctionalJavascript/StyleTest.php
- 10 core/modules/views/tests/src/Kernel/Plugin/StyleTest.php
- 10 core/modules/views/tests/modules/views_test_data/src/Plugin/views/style/StyleTest.php
- 11.x core/modules/ckeditor5/tests/src/FunctionalJavascript/StyleTest.php
- 11.x core/modules/views/tests/src/Kernel/Plugin/StyleTest.php
- 11.x core/modules/views/tests/modules/views_test_data/src/Plugin/views/style/StyleTest.php
Namespace
Drupal\views_test_data\Plugin\views\styleFile
-
core/
modules/ views/ tests/ modules/ views_test_data/ src/ Plugin/ views/ style/ StyleTest.php
View source
<?php
namespace Drupal\views_test_data\Plugin\views\style;
use Drupal\Core\Form\FormStateInterface;
use Drupal\views\Plugin\views\style\StylePluginBase;
/**
* Provides a general test style plugin.
*
* @ingroup views_style_plugins
*
* @ViewsStyle(
* id = "test_style",
* title = @Translation("Test style plugin"),
* help = @Translation("Provides a generic style test plugin."),
* theme = "views_view_style_test",
* register_theme = FALSE,
* display_types = {"normal", "test"}
* )
*/
class StyleTest extends StylePluginBase {
/**
* A string which will be output when the view is rendered.
*
* @var string
*/
public $output;
/**
* {@inheritdoc}
*/
protected $usesRowPlugin = TRUE;
/**
* {@inheritdoc}
*/
protected function defineOptions() {
$options = parent::defineOptions();
$options['test_option'] = [
'default' => '',
];
return $options;
}
/**
* {@inheritdoc}
*/
public function buildOptionsForm(&$form, FormStateInterface $form_state) {
parent::buildOptionsForm($form, $form_state);
$form['test_option'] = [
'#title' => $this->t('Test option'),
'#type' => 'textfield',
'#description' => $this->t('This is a textfield for test_option.'),
'#default_value' => $this->options['test_option'],
];
}
/**
* Sets the usesRowPlugin property.
*
* @param bool $status
* TRUE if this style plugin should use rows.
*/
public function setUsesRowPlugin($status) {
$this->usesRowPlugin = $status;
}
/**
* Sets the output property.
*
* @param string $output
* The string to output by this plugin.
*/
public function setOutput($output) {
$this->output = $output;
}
/**
* Returns the output property.
*
* @return string
*/
public function getOutput() {
return $this->output;
}
/**
* {@inheritdoc}
*/
public function render() {
$output = '';
if (!$this->usesRowPlugin()) {
$output = $this->getOutput();
}
else {
foreach ($this->view->result as $index => $row) {
$this->view->row_index = $index;
$output .= $this->view->rowPlugin
->render($row) . "\n";
}
}
return $output;
}
/**
* {@inheritdoc}
*/
public function calculateDependencies() {
return [
'content' => [
'StyleTest',
],
];
}
}
Classes
Title | Deprecated | Summary |
---|---|---|
StyleTest | Provides a general test style plugin. |
Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.