3 namespace Drupal\node\Plugin\views\area;
5 use Drupal\Core\Access\AccessManagerInterface;
7 use Drupal\views\Plugin\views\area\AreaPluginBase;
8 use Symfony\Component\DependencyInjection\ContainerInterface;
11 * Defines an area plugin to display a node/add link.
13 * @ingroup views_area_handlers
15 * @ViewsArea("node_listing_empty")
17 class ListingEmpty extends AreaPluginBase {
22 * @var \Drupal\Core\Access\AccessManagerInterface
24 protected $accessManager;
27 * Constructs a new ListingEmpty.
29 * @param array $configuration
30 * A configuration array containing information about the plugin instance.
31 * @param string $plugin_id
32 * The plugin ID for the plugin instance.
33 * @param mixed $plugin_definition
34 * The plugin implementation definition.
35 * @param \Drupal\Core\Access\AccessManagerInterface $access_manager
38 public function __construct(array $configuration, $plugin_id, $plugin_definition, AccessManagerInterface $access_manager) {
39 parent::__construct($configuration, $plugin_id, $plugin_definition);
41 $this->accessManager = $access_manager;
47 public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) {
52 $container->get('access_manager')
59 public function render($empty = FALSE) {
60 $account = \Drupal::currentUser();
61 if (!$empty || !empty($this->options['empty'])) {
66 'url' => Url::fromRoute('node.add_page'),
67 'title' => $this->t('Add content'),
70 '#access' => $this->accessManager->checkNamedRoute('node.add_page', [], $account),