Update to Drupal 8.0.0-rc3. For more information, see https://www.drupal.org/node/2608078
This commit is contained in:
		
							parent
							
								
									6419a031d7
								
							
						
					
					
						commit
						4afb23bbd3
					
				
					 762 changed files with 20080 additions and 6368 deletions
				
			
		|  | @ -34,7 +34,7 @@ class HighlightCommand implements CommandInterface { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Implements \Drupal\Core\Ajax\CommandInterface::render(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function render() { | ||||
|     return array( | ||||
|  |  | |||
|  | @ -34,7 +34,7 @@ class ReplaceTitleCommand implements CommandInterface { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Implements \Drupal\Core\Ajax\CommandInterface::render(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function render() { | ||||
|     return array( | ||||
|  |  | |||
|  | @ -34,7 +34,7 @@ class ScrollTopCommand implements CommandInterface { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Implements \Drupal\Core\Ajax\CommandInterface::render(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function render() { | ||||
|     return array( | ||||
|  |  | |||
|  | @ -35,7 +35,7 @@ class ShowButtonsCommand implements CommandInterface { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Implements \Drupal\Core\Ajax\CommandInterface::render(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function render() { | ||||
|     return array( | ||||
|  |  | |||
|  | @ -17,7 +17,7 @@ use Drupal\Core\Ajax\CommandInterface; | |||
| class TriggerPreviewCommand implements CommandInterface { | ||||
| 
 | ||||
|   /** | ||||
|    * Implements \Drupal\Core\Ajax\CommandInterface::render(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function render() { | ||||
|     return array( | ||||
|  |  | |||
|  | @ -60,7 +60,7 @@ class DisplayPluginCollection extends DefaultLazyPluginCollection { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\Component\Plugin\LazyPluginCollection::clear(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function clear() { | ||||
|     foreach (array_filter($this->pluginInstances) as $display) { | ||||
|  | @ -102,7 +102,7 @@ class DisplayPluginCollection extends DefaultLazyPluginCollection { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\Component\Plugin\LazyPluginCollection::remove(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function remove($instance_id) { | ||||
|     $this->get($instance_id)->remove(); | ||||
|  |  | |||
|  | @ -37,7 +37,7 @@ abstract class RendererBase implements CacheableDependencyInterface { | |||
|   /** | ||||
|    * The type of the entity being rendered. | ||||
|    * | ||||
|    * @var string | ||||
|    * @var \Drupal\Core\Entity\EntityTypeInterface | ||||
|    */ | ||||
|   protected $entityType; | ||||
| 
 | ||||
|  |  | |||
|  | @ -27,21 +27,18 @@ class TranslationLanguageRenderer extends EntityTranslationRendererBase { | |||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function query(QueryPluginBase $query, $relationship = NULL) { | ||||
|     // There is no point in getting the language, in case the site is not
 | ||||
|     // multilingual.
 | ||||
|     if (!$this->languageManager->isMultilingual()) { | ||||
|     // In order to render in the translation language of the entity, we need
 | ||||
|     // to add the language code of the entity to the query. Skip if the site
 | ||||
|     // is not multilingual or the entity is not translatable.
 | ||||
|     if (!$this->languageManager->isMultilingual() || !$this->entityType->hasKey('langcode')) { | ||||
|       return; | ||||
|     } | ||||
|     // If the data table is defined, we use the translation language as render
 | ||||
|     // language, otherwise we fall back to the default entity language, which is
 | ||||
|     // stored in the revision table for revisionable entity types.
 | ||||
|     $langcode_key = $this->entityType->getKey('langcode'); | ||||
|     foreach (array('data_table', 'revision_table', 'base_table') as $key) { | ||||
|       if ($table = $this->entityType->get($key)) { | ||||
|         $table_alias = $query->ensureTable($table, $relationship); | ||||
|         $this->langcodeAlias = $query->addField($table_alias, $langcode_key); | ||||
|         break; | ||||
|       } | ||||
|     $storage = \Drupal::entityManager()->getStorage($this->entityType->id()); | ||||
| 
 | ||||
|     if ($table = $storage->getTableMapping()->getFieldTableName($langcode_key)) { | ||||
|       $table_alias = $query->ensureTable($table, $relationship); | ||||
|       $this->langcodeAlias = $query->addField($table_alias, $langcode_key); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|  |  | |||
|  | @ -152,13 +152,17 @@ class EntityViewsData implements EntityHandlerInterface, EntityViewsDataInterfac | |||
|       } | ||||
|     } | ||||
| 
 | ||||
|     $data[$base_table]['operations'] = array( | ||||
|       'field' => array( | ||||
|         'title' => $this->t('Operations links'), | ||||
|         'help' => $this->t('Provides links to perform entity operations.'), | ||||
|         'id' => 'entity_operations', | ||||
|       ), | ||||
|     ); | ||||
|     // Entity types must implement a list_builder in order to use Views'
 | ||||
|     // entity operations field.
 | ||||
|     if ($this->entityType->hasListBuilderClass()) { | ||||
|       $data[$base_table]['operations'] = array( | ||||
|         'field' => array( | ||||
|           'title' => $this->t('Operations links'), | ||||
|           'help' => $this->t('Provides links to perform entity operations.'), | ||||
|           'id' => 'entity_operations', | ||||
|         ), | ||||
|       ); | ||||
|     } | ||||
| 
 | ||||
|     // Setup relations to the revisions/property data.
 | ||||
|     if ($data_table) { | ||||
|  |  | |||
|  | @ -127,6 +127,14 @@ class ViewsMenuLink extends MenuLinkBase implements ContainerFactoryPluginInterf | |||
|     return $this->loadView()->display_handler->getOption('menu')['description']; | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function isExpanded() { | ||||
|     return (bool) $this->loadView()->display_handler->getOption('menu')['expanded']; | ||||
|   } | ||||
| 
 | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|  |  | |||
|  | @ -382,7 +382,10 @@ abstract class PluginBase extends ComponentPluginBase implements ContainerFactor | |||
|           assert('preg_match(\'/^[a-zA-Z_\x7f-\xff][a-zA-Z0-9_\x7f-\xff]*$/\', $key) === 1', 'Tokens need to be valid Twig variables.'); | ||||
|           $token_array = array($key => $token_array); | ||||
|         } | ||||
|         $twig_tokens[$top] = $token_array; | ||||
|         if (!isset($twig_tokens[$top])) { | ||||
|           $twig_tokens[$top] = []; | ||||
|         } | ||||
|         $twig_tokens[$top] += $token_array; | ||||
|       } | ||||
|     } | ||||
| 
 | ||||
|  |  | |||
|  | @ -67,7 +67,7 @@ class Entity extends TokenizeAreaPluginBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\area\AreaPluginBase::init(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function init(ViewExecutable $view, DisplayPluginBase $display, array &$options = NULL) { | ||||
|     parent::init($view, $display, $options); | ||||
|  |  | |||
|  | @ -128,7 +128,7 @@ class Date extends Formula implements ContainerFactoryPluginInterface { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\argument\Formula::getFormula(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function getFormula() { | ||||
|     $this->formula = $this->getDateFormat($this->argFormat); | ||||
|  |  | |||
|  | @ -27,7 +27,7 @@ class Formula extends ArgumentPluginBase { | |||
|   var $formula = NULL; | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides Drupal\views\Plugin\views\argument\ArgumentPluginBase::init(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function init(ViewExecutable $view, DisplayPluginBase $display, array &$options = NULL) { | ||||
|     parent::init($view, $display, $options); | ||||
|  |  | |||
|  | @ -30,7 +30,7 @@ use Drupal\views\ManyToOneHelper; | |||
| class ManyToOne extends ArgumentPluginBase { | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\argument\ArgumentPluginBase::init(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function init(ViewExecutable $view, DisplayPluginBase $display, array &$options = NULL) { | ||||
|     parent::init($view, $display, $options); | ||||
|  |  | |||
|  | @ -25,7 +25,7 @@ use Drupal\views\ManyToOneHelper; | |||
| class StringArgument extends ArgumentPluginBase { | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\argument\ArgumentPluginBase::init(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function init(ViewExecutable $view, DisplayPluginBase $display, array &$options = NULL) { | ||||
|     parent::init($view, $display, $options); | ||||
|  |  | |||
|  | @ -23,6 +23,9 @@ use Drupal\Core\Form\FormStateInterface; | |||
|  */ | ||||
| class Fixed extends ArgumentDefaultPluginBase implements CacheableDependencyInterface { | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected function defineOptions() { | ||||
|     $options = parent::defineOptions(); | ||||
|     $options['argument'] = array('default' => ''); | ||||
|  | @ -30,6 +33,9 @@ class Fixed extends ArgumentDefaultPluginBase implements CacheableDependencyInte | |||
|     return $options; | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function buildOptionsForm(&$form, FormStateInterface $form_state) { | ||||
|     parent::buildOptionsForm($form, $form_state); | ||||
|     $form['argument'] = array( | ||||
|  | @ -40,7 +46,7 @@ class Fixed extends ArgumentDefaultPluginBase implements CacheableDependencyInte | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Return the default argument. | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function getArgument() { | ||||
|     return $this->options['argument']; | ||||
|  |  | |||
|  | @ -74,6 +74,9 @@ class Raw extends ArgumentDefaultPluginBase implements CacheableDependencyInterf | |||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected function defineOptions() { | ||||
|     $options = parent::defineOptions(); | ||||
|     $options['index'] = array('default' => ''); | ||||
|  | @ -82,6 +85,9 @@ class Raw extends ArgumentDefaultPluginBase implements CacheableDependencyInterf | |||
|     return $options; | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function buildOptionsForm(&$form, FormStateInterface $form_state) { | ||||
|     parent::buildOptionsForm($form, $form_state); | ||||
|     $form['index'] = array( | ||||
|  | @ -102,6 +108,9 @@ class Raw extends ArgumentDefaultPluginBase implements CacheableDependencyInterf | |||
|     ); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function getArgument() { | ||||
|     $path = trim($this->currentPath->getPath($this->view->getRequest()), '/'); | ||||
|     if ($this->options['use_alias']) { | ||||
|  |  | |||
|  | @ -27,7 +27,7 @@ use Symfony\Component\HttpFoundation\Request; | |||
| class Time extends CachePluginBase { | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides Drupal\views\Plugin\Plugin::$usesOptions. | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected $usesOptions = TRUE; | ||||
| 
 | ||||
|  |  | |||
|  | @ -59,7 +59,7 @@ abstract class DisplayPluginBase extends PluginBase implements DisplayPluginInte | |||
|   protected $extenders = []; | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides Drupal\views\Plugin\Plugin::$usesOptions. | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected $usesOptions = TRUE; | ||||
| 
 | ||||
|  |  | |||
|  | @ -30,22 +30,22 @@ namespace Drupal\views\Plugin\views\display; | |||
| class EntityReference extends DisplayPluginBase { | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\DisplayPluginBase::$useAJAX. | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected $usesAJAX = FALSE; | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\DisplayPluginBase::$usesPager. | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected $usesPager = FALSE; | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\DisplayPluginBase::$usesAttachments. | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected $usesAttachments = FALSE; | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\DisplayPluginBase::defineOptions(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected function defineOptions() { | ||||
|     $options = parent::defineOptions(); | ||||
|  | @ -79,21 +79,21 @@ class EntityReference extends DisplayPluginBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\DisplayPluginBase::getType(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function getType() { | ||||
|     return 'entity_reference'; | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\DisplayPluginBase::execute(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function execute() { | ||||
|     return $this->view->render($this->display['id']); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\DisplayPluginBase::render(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function render() { | ||||
|     if (!empty($this->view->result) && $this->view->style_plugin->evenEmpty()) { | ||||
|  | @ -103,14 +103,14 @@ class EntityReference extends DisplayPluginBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\DisplayPluginBase::usesExposed(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function usesExposed() { | ||||
|     return FALSE; | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\DisplayPluginBase::query(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function query() { | ||||
|     if (!empty($this->view->live_preview)) { | ||||
|  | @ -157,7 +157,7 @@ class EntityReference extends DisplayPluginBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\DisplayPluginBase::validate(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function validate() { | ||||
|     $errors = parent::validate(); | ||||
|  |  | |||
|  | @ -45,7 +45,7 @@ class Feed extends PathPluginBase implements ResponseDisplayPluginInterface { | |||
|   protected $usesPager = FALSE; | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\DisplayPluginBase::getType(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function getType() { | ||||
|     return 'feed'; | ||||
|  | @ -89,7 +89,7 @@ class Feed extends PathPluginBase implements ResponseDisplayPluginInterface { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\PathPluginBase::preview(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function preview() { | ||||
|     $output = $this->view->render(); | ||||
|  | @ -106,7 +106,7 @@ class Feed extends PathPluginBase implements ResponseDisplayPluginInterface { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\PathPluginBase::render(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function render() { | ||||
|     $build = $this->view->style_plugin->render($this->view->result); | ||||
|  | @ -117,7 +117,7 @@ class Feed extends PathPluginBase implements ResponseDisplayPluginInterface { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\displays\DisplayPluginBase::defaultableSections(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function defaultableSections($section = NULL) { | ||||
|     $sections = parent::defaultableSections($section); | ||||
|  | @ -137,7 +137,7 @@ class Feed extends PathPluginBase implements ResponseDisplayPluginInterface { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\PathPluginBase::defineOptions(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected function defineOptions() { | ||||
|     $options = parent::defineOptions(); | ||||
|  | @ -175,7 +175,7 @@ class Feed extends PathPluginBase implements ResponseDisplayPluginInterface { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\DisplayPluginBase::optionsSummary(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function optionsSummary(&$categories, &$options) { | ||||
|     parent::optionsSummary($categories, $options); | ||||
|  | @ -218,7 +218,7 @@ class Feed extends PathPluginBase implements ResponseDisplayPluginInterface { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\PathPluginBase::buildOptionsForm(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function buildOptionsForm(&$form, FormStateInterface $form_state) { | ||||
|     // It is very important to call the parent function here.
 | ||||
|  | @ -264,7 +264,7 @@ class Feed extends PathPluginBase implements ResponseDisplayPluginInterface { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\DisplayPluginBase::submitOptionsForm(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function submitOptionsForm(&$form, FormStateInterface $form_state) { | ||||
|     parent::submitOptionsForm($form, $form_state); | ||||
|  | @ -306,7 +306,7 @@ class Feed extends PathPluginBase implements ResponseDisplayPluginInterface { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\DisplayPluginBase::usesLinkDisplay(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function usesLinkDisplay() { | ||||
|     return TRUE; | ||||
|  |  | |||
|  | @ -118,7 +118,7 @@ class Page extends PathPluginBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\PathPluginBase::defineOptions(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected function defineOptions() { | ||||
|     $options = parent::defineOptions(); | ||||
|  | @ -132,6 +132,7 @@ class Page extends PathPluginBase { | |||
|         'menu_name' => array('default' => 'main'), | ||||
|         'parent' => array('default' => ''), | ||||
|         'context' => array('default' => ''), | ||||
|         'expanded' => array('default' => FALSE), | ||||
|       ), | ||||
|     ); | ||||
|     $options['tab_options'] = array( | ||||
|  | @ -165,7 +166,7 @@ class Page extends PathPluginBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\PathPluginBase::execute(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function execute() { | ||||
|     parent::execute(); | ||||
|  | @ -186,7 +187,7 @@ class Page extends PathPluginBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\DisplayPluginBase::optionsSummary(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function optionsSummary(&$categories, &$options) { | ||||
|     parent::optionsSummary($categories, $options); | ||||
|  | @ -224,7 +225,7 @@ class Page extends PathPluginBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\callbackPluginBase::buildOptionsForm(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function buildOptionsForm(&$form, FormStateInterface $form_state) { | ||||
|     parent::buildOptionsForm($form, $form_state); | ||||
|  | @ -239,7 +240,7 @@ class Page extends PathPluginBase { | |||
|         ); | ||||
|         $menu = $this->getOption('menu'); | ||||
|         if (empty($menu)) { | ||||
|           $menu = array('type' => 'none', 'title' => '', 'weight' => 0); | ||||
|           $menu = array('type' => 'none', 'title' => '', 'weight' => 0, 'expanded' => FALSE); | ||||
|         } | ||||
|         $form['menu']['type'] = array( | ||||
|           '#prefix' => '<div class="views-left-30">', | ||||
|  | @ -293,6 +294,12 @@ class Page extends PathPluginBase { | |||
|             ), | ||||
|           ), | ||||
|         ); | ||||
|         $form['menu']['expanded'] = [ | ||||
|           '#title' => $this->t('Show as expanded'), | ||||
|           '#type' => 'checkbox', | ||||
|           '#default_value' => !empty($menu['expanded']), | ||||
|           '#description' => $this->t('If selected and this menu link has children, the menu will always appear expanded. '), | ||||
|         ]; | ||||
| 
 | ||||
|         // Only display the parent selector if Menu UI module is enabled.
 | ||||
|         $menu_parent = $menu['menu_name'] . ':' . $menu['parent']; | ||||
|  | @ -431,7 +438,7 @@ class Page extends PathPluginBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\callbackPluginBase::validateOptionsForm(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function validateOptionsForm(&$form, FormStateInterface $form_state) { | ||||
|     parent::validateOptionsForm($form, $form_state); | ||||
|  | @ -458,7 +465,7 @@ class Page extends PathPluginBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\callbackPluginBase::submitOptionsForm(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function submitOptionsForm(&$form, FormStateInterface $form_state) { | ||||
|     parent::submitOptionsForm($form, $form_state); | ||||
|  | @ -480,7 +487,7 @@ class Page extends PathPluginBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\DisplayPluginBase::validate(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function validate() { | ||||
|     $errors = parent::validate(); | ||||
|  | @ -501,7 +508,7 @@ class Page extends PathPluginBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\DisplayPluginBase::getArgumentText(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function getArgumentText() { | ||||
|     return array( | ||||
|  | @ -512,7 +519,7 @@ class Page extends PathPluginBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\DisplayPluginBase::getPagerText(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function getPagerText() { | ||||
|     return array( | ||||
|  |  | |||
|  | @ -80,7 +80,7 @@ abstract class PathPluginBase extends DisplayPluginBase implements DisplayRouter | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\DisplayPluginBase::hasPath(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function hasPath() { | ||||
|     return TRUE; | ||||
|  | @ -134,6 +134,7 @@ abstract class PathPluginBase extends DisplayPluginBase implements DisplayRouter | |||
|   protected function getRoute($view_id, $display_id) { | ||||
|     $defaults = array( | ||||
|       '_controller' => 'Drupal\views\Routing\ViewPageController::handle', | ||||
|       '_title' => $this->view->getTitle(), | ||||
|       'view_id' => $view_id, | ||||
|       'display_id' => $display_id, | ||||
|       '_view_display_show_admin_links' => $this->getOption('show_admin_links'), | ||||
|  | @ -341,7 +342,7 @@ abstract class PathPluginBase extends DisplayPluginBase implements DisplayRouter | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\DisplayPluginBase::execute(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function execute() { | ||||
|     // Prior to this being called, the $view should already be set to this
 | ||||
|  | @ -358,7 +359,7 @@ abstract class PathPluginBase extends DisplayPluginBase implements DisplayRouter | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\DisplayPluginBase::optionsSummary(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function optionsSummary(&$categories, &$options) { | ||||
|     parent::optionsSummary($categories, $options); | ||||
|  | @ -388,7 +389,7 @@ abstract class PathPluginBase extends DisplayPluginBase implements DisplayRouter | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\DisplayPluginBase::buildOptionsForm(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function buildOptionsForm(&$form, FormStateInterface $form_state) { | ||||
|     parent::buildOptionsForm($form, $form_state); | ||||
|  | @ -412,7 +413,7 @@ abstract class PathPluginBase extends DisplayPluginBase implements DisplayRouter | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\DisplayPluginBase::validateOptionsForm(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function validateOptionsForm(&$form, FormStateInterface $form_state) { | ||||
|     parent::validateOptionsForm($form, $form_state); | ||||
|  | @ -429,7 +430,7 @@ abstract class PathPluginBase extends DisplayPluginBase implements DisplayRouter | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\display\DisplayPluginBase::submitOptionsForm(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function submitOptionsForm(&$form, FormStateInterface $form_state) { | ||||
|     parent::submitOptionsForm($form, $form_state); | ||||
|  |  | |||
|  | @ -36,7 +36,7 @@ use Drupal\views\Plugin\views\PluginBase; | |||
| abstract class ExposedFormPluginBase extends PluginBase implements CacheableDependencyInterface { | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides Drupal\views\Plugin\Plugin::$usesOptions. | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected $usesOptions = TRUE; | ||||
| 
 | ||||
|  |  | |||
|  | @ -7,7 +7,9 @@ | |||
| 
 | ||||
| namespace Drupal\views\Plugin\views\field; | ||||
| 
 | ||||
| use Drupal\Component\Utility\Xss; | ||||
| use Drupal\Core\Form\FormStateInterface; | ||||
| use Drupal\views\Render\ViewsRenderPipelineMarkup; | ||||
| use Drupal\views\ResultRow; | ||||
| 
 | ||||
| /** | ||||
|  | @ -63,7 +65,7 @@ class Custom extends FieldPluginBase { | |||
|    */ | ||||
|   public function render(ResultRow $values) { | ||||
|     // Return the text, so the code never thinks the value is empty.
 | ||||
|     return $this->options['alter']['text']; | ||||
|     return ViewsRenderPipelineMarkup::create(Xss::filterAdmin($this->options['alter']['text'])); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|  |  | |||
|  | @ -107,7 +107,7 @@ abstract class FieldPluginBase extends HandlerBase implements FieldHandlerInterf | |||
|   protected $renderer; | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides Drupal\views\Plugin\views\HandlerBase::init(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function init(ViewExecutable $view, DisplayPluginBase $display, array &$options = NULL) { | ||||
|     parent::init($view, $display, $options); | ||||
|  |  | |||
|  | @ -75,7 +75,7 @@ class BooleanOperator extends FilterPluginBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\filter\FilterPluginBase::init(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function init(ViewExecutable $view, DisplayPluginBase $display, array &$options = NULL) { | ||||
|     parent::init($view, $display, $options); | ||||
|  |  | |||
|  | @ -73,7 +73,7 @@ class Bundle extends InOperator { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\filter\InOperator::init(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function init(ViewExecutable $view, DisplayPluginBase $display, array &$options = NULL) { | ||||
|     parent::init($view, $display, $options); | ||||
|  | @ -84,7 +84,7 @@ class Bundle extends InOperator { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\filter\InOperator::getValueOptions(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function getValueOptions() { | ||||
|     if (!isset($this->valueOptions)) { | ||||
|  | @ -104,7 +104,7 @@ class Bundle extends InOperator { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\filter\InOperator::query(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function query() { | ||||
|     // Make sure that the entity base table is in the query.
 | ||||
|  |  | |||
|  | @ -42,7 +42,7 @@ class InOperator extends FilterPluginBase { | |||
|   protected $valueTitle; | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\filter\FilterPluginBase::init(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function init(ViewExecutable $view, DisplayPluginBase $display, array &$options = NULL) { | ||||
|     parent::init($view, $display, $options); | ||||
|  |  | |||
|  | @ -34,7 +34,7 @@ class ManyToOne extends InOperator { | |||
|   var $helper = NULL; | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\filter\InOperator::init(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function init(ViewExecutable $view, DisplayPluginBase $display, array &$options = NULL) { | ||||
|     parent::init($view, $display, $options); | ||||
|  |  | |||
|  | @ -26,7 +26,7 @@ use Drupal\Core\Form\FormStateInterface; | |||
| class Full extends SqlBase { | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\SqlBase::defineOptions(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected function defineOptions() { | ||||
|     $options = parent::defineOptions(); | ||||
|  | @ -41,7 +41,7 @@ class Full extends SqlBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\SqlBase::buildOptionsForm(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function buildOptionsForm(&$form, FormStateInterface $form_state) { | ||||
|     parent::buildOptionsForm($form, $form_state); | ||||
|  | @ -69,7 +69,7 @@ class Full extends SqlBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\pager\PagerPluginBase::summaryTitle(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function summaryTitle() { | ||||
|     if (!empty($this->options['offset'])) { | ||||
|  |  | |||
|  | @ -37,7 +37,7 @@ class Mini extends SqlBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\pager\PagerPluginBase::summaryTitle(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function summaryTitle() { | ||||
|     if (!empty($this->options['offset'])) { | ||||
|  | @ -47,7 +47,7 @@ class Mini extends SqlBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\pager\SqlBase::query(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function query() { | ||||
|     parent::query(); | ||||
|  | @ -64,14 +64,14 @@ class Mini extends SqlBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\pager\PagerPluginBase::useCountQuery(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function useCountQuery() { | ||||
|     return FALSE; | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\pager\PagerPluginBase::postExecute(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function postExecute(&$result) { | ||||
|     // In query() one more item might have been retrieved than necessary. If so,
 | ||||
|  |  | |||
|  | @ -26,7 +26,7 @@ use Drupal\views\Plugin\views\display\DisplayPluginBase; | |||
| class None extends PagerPluginBase { | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\PluginBase::init(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function init(ViewExecutable $view, DisplayPluginBase $display, array &$options = NULL) { | ||||
|     parent::init($view, $display, $options); | ||||
|  |  | |||
|  | @ -37,7 +37,7 @@ abstract class PagerPluginBase extends PluginBase { | |||
|   var $total_items = 0; | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides Drupal\views\Plugin\Plugin::$usesOptions. | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected $usesOptions = TRUE; | ||||
| 
 | ||||
|  |  | |||
|  | @ -112,7 +112,7 @@ class Sql extends QueryPluginBase { | |||
|   protected $noDistinct; | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\PluginBase::init(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function init(ViewExecutable $view, DisplayPluginBase $display, array &$options = NULL) { | ||||
|     parent::init($view, $display, $options); | ||||
|  | @ -1687,7 +1687,7 @@ class Sql extends QueryPluginBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\query\QueryPluginBase::getDateField(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function getDateField($field) { | ||||
|     $db_type = Database::getConnection()->databaseType(); | ||||
|  | @ -1722,7 +1722,7 @@ class Sql extends QueryPluginBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\query\QueryPluginBase::setupTimezone(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function setupTimezone() { | ||||
|     $timezone = drupal_get_user_timezone(); | ||||
|  |  | |||
|  | @ -26,7 +26,7 @@ use Drupal\Core\Form\FormStateInterface; | |||
| class EntityReference extends Fields { | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\row\Fields::defineOptions(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected function defineOptions() { | ||||
|     $options = parent::defineOptions(); | ||||
|  | @ -36,7 +36,7 @@ class EntityReference extends Fields { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\row\Fields::buildOptionsForm(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function buildOptionsForm(&$form, FormStateInterface $form_state) { | ||||
|     parent::buildOptionsForm($form, $form_state); | ||||
|  |  | |||
|  | @ -131,7 +131,7 @@ class EntityRow extends RowPluginBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides Drupal\views\Plugin\views\row\RowPluginBase::defineOptions(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected function defineOptions() { | ||||
|     $options = parent::defineOptions(); | ||||
|  | @ -140,7 +140,7 @@ class EntityRow extends RowPluginBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides Drupal\views\Plugin\views\row\RowPluginBase::buildOptionsForm(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function buildOptionsForm(&$form, FormStateInterface $form_state) { | ||||
|     parent::buildOptionsForm($form, $form_state); | ||||
|  | @ -154,7 +154,7 @@ class EntityRow extends RowPluginBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides Drupal\views\Plugin\views\PluginBase::summaryTitle(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function summaryTitle() { | ||||
|     $options = \Drupal::entityManager()->getViewModeOptions($this->entityTypeId); | ||||
|  | @ -185,7 +185,7 @@ class EntityRow extends RowPluginBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides Drupal\views\Plugin\views\row\RowPluginBase::render(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function render($row) { | ||||
|     return $this->getEntityTranslationRenderer()->render($row); | ||||
|  |  | |||
|  | @ -212,6 +212,9 @@ class OpmlFields extends RowPluginBase { | |||
|    *   The index count of the row as expected by views_plugin_style::getField(). | ||||
|    * @param $field_id | ||||
|    *   The ID assigned to the required field in the display. | ||||
|    * | ||||
|    * @return string | ||||
|    *   The rendered field value. | ||||
|    */ | ||||
|   public function getField($index, $field_id) { | ||||
|     if (empty($this->view->style_plugin) || !is_object($this->view->style_plugin) || empty($field_id)) { | ||||
|  |  | |||
|  | @ -43,7 +43,7 @@ use Drupal\views\Views; | |||
| abstract class RowPluginBase extends PluginBase { | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides Drupal\views\Plugin\Plugin::$usesOptions. | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected $usesOptions = TRUE; | ||||
| 
 | ||||
|  |  | |||
|  | @ -147,8 +147,10 @@ class RssFields extends RowPluginBase { | |||
|     // @todo Views should expect and store a leading /. See:
 | ||||
|     //   https://www.drupal.org/node/2423913
 | ||||
|     $item->link = Url::fromUserInput('/' . $this->getField($row_index, $this->options['link_field']))->setAbsolute()->toString(); | ||||
| 
 | ||||
|     $field = $this->getField($row_index, $this->options['description_field']); | ||||
|     $item->description = is_array($field) ? $field : ['#markup' => $field]; | ||||
| 
 | ||||
|     $item->elements = array( | ||||
|       array('key' => 'pubDate', 'value' => $this->getField($row_index, $this->options['date_field'])), | ||||
|       array( | ||||
|  | @ -197,6 +199,11 @@ class RssFields extends RowPluginBase { | |||
|    *   The index count of the row as expected by views_plugin_style::getField(). | ||||
|    * @param $field_id | ||||
|    *   The ID assigned to the required field in the display. | ||||
|    * | ||||
|    * @return string|null|\Drupal\Component\Render\MarkupInterface | ||||
|    *   An empty string if there is no style plugin, or the field ID is empty. | ||||
|    *   NULL if the field value is empty. If neither of these conditions apply, | ||||
|    *   a MarkupInterface object containing the rendered field value. | ||||
|    */ | ||||
|   public function getField($index, $field_id) { | ||||
|     if (empty($this->view->style_plugin) || !is_object($this->view->style_plugin) || empty($field_id)) { | ||||
|  |  | |||
|  | @ -19,7 +19,7 @@ use Drupal\views\Views; | |||
| class GroupByNumeric extends SortPluginBase { | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\HandlerBase::init(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function init(ViewExecutable $view, DisplayPluginBase $display, array &$options = NULL) { | ||||
|     parent::init($view, $display, $options); | ||||
|  |  | |||
|  | @ -27,22 +27,22 @@ use Drupal\Core\Form\FormStateInterface; | |||
| class EntityReference extends StylePluginBase { | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\style\StylePluginBase::usesRowPlugin. | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected $usesRowPlugin = TRUE; | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\style\StylePluginBase::usesFields. | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected $usesFields = TRUE; | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\style\StylePluginBase::usesGrouping. | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected $usesGrouping = FALSE; | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\style\StylePluginBase\StylePluginBase::defineOptions(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected function defineOptions() { | ||||
|     $options = parent::defineOptions(); | ||||
|  | @ -52,7 +52,7 @@ class EntityReference extends StylePluginBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\style\StylePluginBase\StylePluginBase::buildOptionsForm(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function buildOptionsForm(&$form, FormStateInterface $form_state) { | ||||
|     parent::buildOptionsForm($form, $form_state); | ||||
|  | @ -70,7 +70,7 @@ class EntityReference extends StylePluginBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Plugin\views\style\StylePluginBase\StylePluginBase::render(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function render() { | ||||
|     if (!empty($this->view->live_preview)) { | ||||
|  |  | |||
|  | @ -47,7 +47,7 @@ abstract class Mapping extends StylePluginBase { | |||
|   abstract protected function defineMapping(); | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides Drupal\views\Plugin\views\style\StylePluginBase::defineOptions(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected function defineOptions() { | ||||
|     $options = parent::defineOptions(); | ||||
|  | @ -69,7 +69,7 @@ abstract class Mapping extends StylePluginBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides Drupal\views\Plugin\views\style\StylePluginBase::buildOptionsForm(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function buildOptionsForm(&$form, FormStateInterface $form_state) { | ||||
|     parent::buildOptionsForm($form, $form_state); | ||||
|  |  | |||
|  | @ -46,7 +46,7 @@ use Drupal\views\ViewExecutable; | |||
| abstract class StylePluginBase extends PluginBase { | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides Drupal\views\Plugin\Plugin::$usesOptions. | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected $usesOptions = TRUE; | ||||
| 
 | ||||
|  |  | |||
|  | @ -0,0 +1,51 @@ | |||
| <?php | ||||
| 
 | ||||
| /** | ||||
|  * @file | ||||
|  * Contains \Drupal\views\Tests\Entity\ViewNonTranslatableEntityTest. | ||||
|  */ | ||||
| 
 | ||||
| namespace Drupal\views\Tests\Entity; | ||||
| 
 | ||||
| use Drupal\language\Entity\ConfigurableLanguage; | ||||
| use Drupal\language_test\Entity\NoLanguageEntityTest; | ||||
| use Drupal\simpletest\WebTestBase; | ||||
| 
 | ||||
| /** | ||||
|  * Tests the view creation of non-translatable entities. | ||||
|  * | ||||
|  * @group views | ||||
|  */ | ||||
| class ViewNonTranslatableEntityTest extends WebTestBase { | ||||
| 
 | ||||
|   /** | ||||
|    * Modules to enable. | ||||
|    * | ||||
|    * @var array | ||||
|    */ | ||||
|   public static $modules = array( | ||||
|     'entity_test', | ||||
|     'content_translation', | ||||
|     'language_test', | ||||
|     'views_ui', | ||||
|   ); | ||||
| 
 | ||||
|   /** | ||||
|    * Tests displaying a view of non-translatable entities. | ||||
|    */ | ||||
|   public function testViewNoTranslatableEntity() { | ||||
|     // Add a new language.
 | ||||
|     ConfigurableLanguage::createFromLangcode('sr')->save(); | ||||
| 
 | ||||
|     // Create a non-translatable entity.
 | ||||
|     $no_language_entity = NoLanguageEntityTest::create(); | ||||
|     $no_language_entity->save(); | ||||
| 
 | ||||
|     // Visit the view page and assert it is displayed properly.
 | ||||
|     $this->drupalGet('no-entity-translation-view'); | ||||
|     $this->assertResponse(200); | ||||
|     $this->assertText('No Entity Translation View'); | ||||
|     $this->assertText($no_language_entity->uuid()); | ||||
|   } | ||||
| 
 | ||||
| } | ||||
|  | @ -28,7 +28,7 @@ class FieldApiDataTest extends FieldTestBase { | |||
|       'field_name' => $field_names[0], | ||||
|       'entity_type' => 'node', | ||||
|       'bundle' => 'page', | ||||
|       'label' => 'The giraffe" label' | ||||
|       'label' => 'GiraffeA" label' | ||||
|     ); | ||||
|     entity_create('field_config', $field)->save(); | ||||
| 
 | ||||
|  | @ -38,7 +38,7 @@ class FieldApiDataTest extends FieldTestBase { | |||
|       'field_name' => $field_names[0], | ||||
|       'entity_type' => 'node', | ||||
|       'bundle' => 'article', | ||||
|       'label' => 'The giraffe2" label' | ||||
|       'label' => 'GiraffeB" label' | ||||
|     ])->save(); | ||||
| 
 | ||||
|     // Now create some example nodes/users for the view result.
 | ||||
|  | @ -56,18 +56,11 @@ class FieldApiDataTest extends FieldTestBase { | |||
|    * We check data structure for both node and node revision tables. | ||||
|    */ | ||||
|   function testViewsData() { | ||||
|     $views_data = $this->container->get('views.views_data'); | ||||
|     $data = array(); | ||||
| 
 | ||||
|     // Check the table and the joins of the first field.
 | ||||
|     // Attached to node only.
 | ||||
|     $field_storage = $this->fieldStorages[0]; | ||||
|     /** @var \Drupal\Core\Entity\Sql\DefaultTableMapping $table_mapping */ | ||||
|     $table_mapping = \Drupal::entityManager()->getStorage('node')->getTableMapping(); | ||||
|     $field_storage = $this->fieldStorages[0]; | ||||
|     $current_table = $table_mapping->getDedicatedDataTableName($field_storage); | ||||
|     $revision_table = $table_mapping->getDedicatedRevisionTableName($field_storage); | ||||
|     $data[$current_table] = $views_data->get($current_table); | ||||
|     $data[$revision_table] = $views_data->get($revision_table); | ||||
|     $data = $this->getViewsData(); | ||||
| 
 | ||||
|     $this->assertTrue(isset($data[$current_table])); | ||||
|     $this->assertTrue(isset($data[$revision_table])); | ||||
|  | @ -100,10 +93,51 @@ class FieldApiDataTest extends FieldTestBase { | |||
|     $this->assertTrue(empty($data[$revision_table][$field_storage->getName()]['field']['click sortable']), 'Non-primary fields are not click sortable'); | ||||
| 
 | ||||
|     $this->assertTrue($data[$current_table][$field_storage->getName()]['help'] instanceof MarkupInterface); | ||||
|     $this->assertEqual($data[$current_table][$field_storage->getName()]['help'], 'Appears in: page, article. Also known as: Content: The giraffe2" label'); | ||||
|     $this->assertEqual($data[$current_table][$field_storage->getName()]['help'], 'Appears in: page, article. Also known as: Content: GiraffeB" label'); | ||||
| 
 | ||||
|     $this->assertTrue($data[$current_table][$field_storage->getName() . '_value']['help'] instanceof MarkupInterface); | ||||
|     $this->assertEqual($data[$current_table][$field_storage->getName() . '_value']['help'], 'Appears in: page, article. Also known as: Content: The giraffe" label (field_name_0)'); | ||||
|     $this->assertEqual($data[$current_table][$field_storage->getName() . '_value']['help'], 'Appears in: page, article. Also known as: Content: GiraffeA" label (field_name_0)'); | ||||
| 
 | ||||
|     // Since each label is only used once, views_entity_field_label() will
 | ||||
|     // return a label using alphabetical sorting.
 | ||||
|     $this->assertEqual('GiraffeA" label (field_name_0)', $data[$current_table][$field_storage->getName() . '_value']['title']); | ||||
| 
 | ||||
|     // Attach the same field to a different bundle with a different label.
 | ||||
|     $this->drupalCreateContentType(['type' => 'news']); | ||||
|     FieldConfig::create([ | ||||
|       'field_name' => $this->fieldStorages[0]->getName(), | ||||
|       'entity_type' => 'node', | ||||
|       'bundle' => 'news', | ||||
|       'label' => 'GiraffeB" label' | ||||
|     ])->save(); | ||||
|     $this->container->get('views.views_data')->clear(); | ||||
|     $data = $this->getViewsData(); | ||||
| 
 | ||||
|     // Now the 'GiraffeB" label' is used twice and therefore will be
 | ||||
|     // selected by views_entity_field_label().
 | ||||
|     $this->assertEqual('GiraffeB" label (field_name_0)', $data[$current_table][$field_storage->getName() . '_value']['title']); | ||||
|     $this->assertTrue($data[$current_table][$field_storage->getName()]['help'] instanceof MarkupInterface); | ||||
|     $this->assertEqual($data[$current_table][$field_storage->getName()]['help'], 'Appears in: page, article, news. Also known as: Content: GiraffeA" label'); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Gets the views data for the field created in setUp(). | ||||
|    * | ||||
|    * @return array | ||||
|    */ | ||||
|   protected function getViewsData() { | ||||
|     $views_data = $this->container->get('views.views_data'); | ||||
|     $data = array(); | ||||
| 
 | ||||
|     // Check the table and the joins of the first field.
 | ||||
|     // Attached to node only.
 | ||||
|     /** @var \Drupal\Core\Entity\Sql\DefaultTableMapping $table_mapping */ | ||||
|     $table_mapping = \Drupal::entityManager()->getStorage('node')->getTableMapping(); | ||||
|     $current_table = $table_mapping->getDedicatedDataTableName($this->fieldStorages[0]); | ||||
|     $revision_table = $table_mapping->getDedicatedRevisionTableName($this->fieldStorages[0]); | ||||
|     $data[$current_table] = $views_data->get($current_table); | ||||
|     $data[$revision_table] = $views_data->get($revision_table); | ||||
|     return $data; | ||||
|   } | ||||
| 
 | ||||
| } | ||||
|  |  | |||
|  | @ -35,7 +35,7 @@ class ArgumentDateTest extends ViewKernelTestBase { | |||
|   ); | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Tests\ViewKernelTestBase::viewsData(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   public function viewsData() { | ||||
|     $data = parent::viewsData(); | ||||
|  |  | |||
|  | @ -7,6 +7,9 @@ | |||
| 
 | ||||
| namespace Drupal\views\Tests\Handler; | ||||
| 
 | ||||
| use Drupal\Component\Utility\Xss; | ||||
| use Drupal\Core\Render\RenderContext; | ||||
| use Drupal\views\Plugin\views\PluginBase; | ||||
| use Drupal\views\Tests\ViewKernelTestBase; | ||||
| use Drupal\views\Views; | ||||
| 
 | ||||
|  | @ -24,18 +27,24 @@ class FieldCustomTest extends ViewKernelTestBase { | |||
|    */ | ||||
|   public static $testViews = array('test_view'); | ||||
| 
 | ||||
|   /** | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   function viewsData() { | ||||
|     $data = parent::viewsData(); | ||||
|     $data['views_test_data']['name']['field']['id'] = 'custom'; | ||||
|     return $data; | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Ensure that custom fields work and doesn't escape unnecessary markup. | ||||
|    */ | ||||
|   public function testFieldCustom() { | ||||
|     $view = Views::getView('test_view'); | ||||
|     $view->setDisplay(); | ||||
| 
 | ||||
|     // Alter the text of the field to a random string.
 | ||||
|     $random = $this->randomMachineName(); | ||||
|     $random = '<div>' . $this->randomMachineName() . '</div>'; | ||||
|     $view->displayHandlers->get('default')->overrideOption('fields', array( | ||||
|       'name' => array( | ||||
|         'id' => 'name', | ||||
|  | @ -53,4 +62,62 @@ class FieldCustomTest extends ViewKernelTestBase { | |||
|     $this->assertEqual($random, $view->style_plugin->getField(0, 'name')); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Ensure that custom fields can use tokens. | ||||
|    */ | ||||
|   public function testFieldCustomTokens() { | ||||
|     $view = Views::getView('test_view'); | ||||
|     $view->setDisplay(); | ||||
| 
 | ||||
|     $view->displayHandlers->get('default')->overrideOption('fields', [ | ||||
|       'age' => [ | ||||
|         'id' => 'age', | ||||
|         'exclude' => TRUE, | ||||
|         'table' => 'views_test_data', | ||||
|         'field' => 'age', | ||||
|       ], | ||||
|       'name' => [ | ||||
|         'id' => 'name', | ||||
|         'table' => 'views_test_data', | ||||
|         'field' => 'name', | ||||
|         'relationship' => 'none', | ||||
|         'alter' => [ | ||||
|           'text' => 'Amount of kittens: {{ age }}', | ||||
|         ], | ||||
|       ], | ||||
|     ]); | ||||
| 
 | ||||
|     /** @var \Drupal\Core\Render\RendererInterface $renderer */ | ||||
|     $renderer = \Drupal::service('renderer'); | ||||
|     $preview = $view->preview(); | ||||
|     $output = $renderer->renderRoot($preview); | ||||
| 
 | ||||
|     $expected_text = 'Amount of kittens: ' . $view->style_plugin->getField(0, 'age'); | ||||
|     $this->assertTrue(strpos((string) $output, $expected_text), 'The views token has been successfully replaced.'); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Ensure that custom field content is XSS filtered. | ||||
|    */ | ||||
|   public function testCustomFieldXss() { | ||||
|     $view = Views::getView('test_view'); | ||||
|     $view->setDisplay(); | ||||
| 
 | ||||
|     // Alter the text of the field to include XSS.
 | ||||
|     $text = '<script>alert("kittens")</script>'; | ||||
|     $view->displayHandlers->get('default')->overrideOption('fields', array( | ||||
|       'name' => array( | ||||
|         'id' => 'name', | ||||
|         'table' => 'views_test_data', | ||||
|         'field' => 'name', | ||||
|         'relationship' => 'none', | ||||
|         'alter' => array( | ||||
|           'text' => $text, | ||||
|         ), | ||||
|       ), | ||||
|     )); | ||||
|     $this->executeView($view); | ||||
|     $this->assertEqual(Xss::filter($text), $view->style_plugin->getField(0, 'name')); | ||||
|   } | ||||
| 
 | ||||
| } | ||||
|  |  | |||
|  | @ -39,7 +39,7 @@ class FieldKernelTest extends ViewKernelTestBase { | |||
|   ); | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides Drupal\views\Tests\ViewTestBase::viewsData(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected function viewsData() { | ||||
|     $data = parent::viewsData(); | ||||
|  |  | |||
|  | @ -53,7 +53,7 @@ class FieldWebTest extends HandlerTestBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Tests\ViewTestBase::viewsData(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected function viewsData() { | ||||
|     $data = parent::viewsData(); | ||||
|  |  | |||
|  | @ -33,7 +33,7 @@ class HandlerAliasTest extends ViewKernelTestBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides Drupal\views\Tests\ViewTestBase::viewsData(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected function viewsData() { | ||||
|     $data = parent::viewsData(); | ||||
|  |  | |||
|  | @ -45,7 +45,7 @@ class HandlerTest extends ViewTestBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides Drupal\views\Tests\ViewTestBase::viewsData(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected function viewsData() { | ||||
|     $data = parent::viewsData(); | ||||
|  |  | |||
|  | @ -48,9 +48,13 @@ class DisplayFeedTest extends PluginTestBase { | |||
| 
 | ||||
|     // Verify a title with HTML entities is properly escaped.
 | ||||
|     $node_title = 'This "cool" & "neat" article\'s title'; | ||||
|     $node = $this->drupalCreateNode(array( | ||||
|       'title' => $node_title | ||||
|     )); | ||||
|     $node = $this->drupalCreateNode([ | ||||
|       'title' => $node_title, | ||||
|       'body' => [0 => [ | ||||
|         'value' => 'A paragraph', | ||||
|         'format' => filter_default_format(), | ||||
|       ]], | ||||
|     ]); | ||||
| 
 | ||||
|     // Test the site name setting.
 | ||||
|     $site_name = $this->randomMachineName(); | ||||
|  | @ -60,6 +64,8 @@ class DisplayFeedTest extends PluginTestBase { | |||
|     $result = $this->xpath('//title'); | ||||
|     $this->assertEqual($result[0], $site_name, 'The site title is used for the feed title.'); | ||||
|     $this->assertEqual($result[1], $node_title, 'Node title with HTML entities displays correctly.'); | ||||
|     // Verify HTML is properly escaped in the description field.
 | ||||
|     $this->assertRaw('<p>A paragraph</p>'); | ||||
| 
 | ||||
|     $view = $this->container->get('entity.manager')->getStorage('view')->load('test_display_feed'); | ||||
|     $display = &$view->getDisplay('feed_1'); | ||||
|  | @ -101,12 +107,18 @@ class DisplayFeedTest extends PluginTestBase { | |||
|     // Verify a title with HTML entities is properly escaped.
 | ||||
|     $node_title = 'This "cool" & "neat" article\'s title'; | ||||
|     $this->drupalCreateNode(array( | ||||
|       'title' => $node_title | ||||
|       'title' => $node_title, | ||||
|       'body' => [0 => [ | ||||
|         'value' => 'A paragraph', | ||||
|         'format' => filter_default_format(), | ||||
|       ]], | ||||
|     )); | ||||
| 
 | ||||
|     $this->drupalGet('test-feed-display-fields.xml'); | ||||
|     $result = $this->xpath('//title/a'); | ||||
|     $this->assertEqual($result[0], $node_title, 'Node title with HTML entities displays correctly.'); | ||||
|     // Verify HTML is properly escaped in the description field.
 | ||||
|     $this->assertRaw('<p>A paragraph</p>'); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|  |  | |||
|  | @ -136,6 +136,8 @@ class DisplayPageTest extends ViewKernelTestBase { | |||
|     $this->assertTrue(isset($tree['system.admin']->subtree['views_view:views.test_page_display_menu.page_4'])); | ||||
|     $menu_link = $tree['system.admin']->subtree['views_view:views.test_page_display_menu.page_4']->link; | ||||
|     $this->assertEqual($menu_link->getTitle(), 'Test child (with parent)'); | ||||
|     $this->assertEqual($menu_link->isExpanded(), TRUE); | ||||
|     $this->assertEqual($menu_link->getDescription(), 'Sample description.'); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|  |  | |||
|  | @ -39,7 +39,7 @@ class FilterTest extends PluginTestBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides Drupal\views\Tests\ViewTestBase::viewsData(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected function viewsData() { | ||||
|     $data = parent::viewsData(); | ||||
|  |  | |||
|  | @ -43,6 +43,20 @@ class PluginBaseTest extends KernelTestBase { | |||
|     $this->assertIdentical($result, 'en means English'); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Test that the token replacement in views works correctly with dots. | ||||
|    */ | ||||
|   public function testViewsTokenReplaceWithDots() { | ||||
|     $text = '{{ argument.first }} comes before {{ argument.second }}'; | ||||
|     $tokens = ['{{ argument.first }}' => 'first', '{{ argument.second }}' => 'second']; | ||||
| 
 | ||||
|     $result = \Drupal::service('renderer')->executeInRenderContext(new RenderContext(), function () use ($text, $tokens) { | ||||
|       return $this->testPluginBase->viewsTokenReplace($text, $tokens); | ||||
|     }); | ||||
| 
 | ||||
|     $this->assertIdentical($result, 'first comes before second'); | ||||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Tests viewsTokenReplace without any twig tokens. | ||||
|    */ | ||||
|  |  | |||
|  | @ -30,7 +30,7 @@ abstract class RelationshipJoinTestBase extends PluginKernelTestBase { | |||
|   protected $rootUser; | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides \Drupal\views\Tests\ViewKernelTestBase::setUpFixtures(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected function setUpFixtures() { | ||||
|     $this->installEntitySchema('user'); | ||||
|  |  | |||
|  | @ -34,7 +34,7 @@ class ViewsSqlExceptionTest extends PluginTestBase { | |||
|   } | ||||
| 
 | ||||
|   /** | ||||
|    * Overrides Drupal\views\Tests\ViewTestBase::viewsData(). | ||||
|    * {@inheritdoc} | ||||
|    */ | ||||
|   protected function viewsData() { | ||||
|     $data = parent::viewsData(); | ||||
|  |  | |||
|  | @ -1855,11 +1855,11 @@ class ViewExecutable implements \Serializable { | |||
|    * @param string $display_id | ||||
|    *   (Optional) The display id. ( Used only to detail an exception. ) | ||||
|    * | ||||
|    * @throws \InvalidArgumentException | ||||
|    *   Thrown when the display plugin does not have a URL to return. | ||||
|    * | ||||
|    * @return \Drupal\Core\Url | ||||
|    *   The display handlers URL object. | ||||
|    * | ||||
|    * @throws \InvalidArgumentException | ||||
|    *   Thrown when the display plugin does not have a URL to return. | ||||
|    */ | ||||
|   public function getUrlInfo($display_id = '') { | ||||
|     $this->initDisplay(); | ||||
|  |  | |||
		Reference in a new issue
	
	 Pantheon Automation
						Pantheon Automation