entityTypeManager = $entity_type_manager; $this->joinHandler = $join_handler; } /** * {@inheritdoc} */ public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) { return new static( $configuration, $plugin_id, $plugin_definition, $container->get('entity_type.manager'), $container->get('plugin.manager.views.join') ); } /** * {@inheritdoc} */ public function adminSummary() { } /** * {@inheritdoc} */ protected function operatorForm(&$form, FormStateInterface $form_state) { } /** * {@inheritdoc} */ public function canExpose() { return FALSE; } /** * {@inheritdoc} */ public function query() { /** @var \Drupal\views\Plugin\views\query\Sql $query */ $query = $this->query; $query_base_table = $this->relationship ?: $this->view->storage->get('base_table'); $entity_type = $this->entityTypeManager->getDefinition($this->getEntityType()); $keys = $entity_type->getKeys(); $definition = [ 'table' => $query_base_table, 'type' => 'LEFT', 'field' => $keys['id'], 'left_table' => $query_base_table, 'left_field' => $keys['id'], 'extra' => [ ['left_field' => $keys['revision'], 'field' => $keys['revision'], 'operator' => '>'], ], ]; $join = $this->joinHandler->createInstance('standard', $definition); $join_table_alias = $query->addTable($query_base_table, $this->relationship, $join); $query->addWhere($this->options['group'], "$join_table_alias.{$keys['id']}", NULL, 'IS NULL'); } }