Issue #2965973 by tedbow: Deletion of View Block used by Layout Builder
parent
3a44b43e7c
commit
ce1f1fc111
|
@ -0,0 +1,177 @@
|
||||||
|
langcode: en
|
||||||
|
status: true
|
||||||
|
dependencies:
|
||||||
|
module:
|
||||||
|
- node
|
||||||
|
- user
|
||||||
|
id: test_block_view
|
||||||
|
label: 'Test Block View'
|
||||||
|
module: views
|
||||||
|
description: ''
|
||||||
|
tag: ''
|
||||||
|
base_table: node_field_data
|
||||||
|
base_field: nid
|
||||||
|
core: 8.x
|
||||||
|
display:
|
||||||
|
default:
|
||||||
|
display_plugin: default
|
||||||
|
id: default
|
||||||
|
display_title: Master
|
||||||
|
position: 0
|
||||||
|
display_options:
|
||||||
|
access:
|
||||||
|
type: perm
|
||||||
|
options:
|
||||||
|
perm: 'access content'
|
||||||
|
cache:
|
||||||
|
type: tag
|
||||||
|
options: { }
|
||||||
|
query:
|
||||||
|
type: views_query
|
||||||
|
options:
|
||||||
|
disable_sql_rewrite: false
|
||||||
|
distinct: false
|
||||||
|
replica: false
|
||||||
|
query_comment: ''
|
||||||
|
query_tags: { }
|
||||||
|
exposed_form:
|
||||||
|
type: basic
|
||||||
|
options:
|
||||||
|
submit_button: Apply
|
||||||
|
reset_button: false
|
||||||
|
reset_button_label: Reset
|
||||||
|
exposed_sorts_label: 'Sort by'
|
||||||
|
expose_sort_order: true
|
||||||
|
sort_asc_label: Asc
|
||||||
|
sort_desc_label: Desc
|
||||||
|
pager:
|
||||||
|
type: some
|
||||||
|
options:
|
||||||
|
items_per_page: 5
|
||||||
|
offset: 0
|
||||||
|
style:
|
||||||
|
type: default
|
||||||
|
row:
|
||||||
|
type: fields
|
||||||
|
fields:
|
||||||
|
title:
|
||||||
|
id: title
|
||||||
|
table: node_field_data
|
||||||
|
field: title
|
||||||
|
settings:
|
||||||
|
link_to_entity: true
|
||||||
|
plugin_id: field
|
||||||
|
relationship: none
|
||||||
|
group_type: group
|
||||||
|
admin_label: ''
|
||||||
|
label: ''
|
||||||
|
exclude: false
|
||||||
|
alter:
|
||||||
|
alter_text: false
|
||||||
|
text: ''
|
||||||
|
make_link: false
|
||||||
|
path: ''
|
||||||
|
absolute: false
|
||||||
|
external: false
|
||||||
|
replace_spaces: false
|
||||||
|
path_case: none
|
||||||
|
trim_whitespace: false
|
||||||
|
alt: ''
|
||||||
|
rel: ''
|
||||||
|
link_class: ''
|
||||||
|
prefix: ''
|
||||||
|
suffix: ''
|
||||||
|
target: ''
|
||||||
|
nl2br: false
|
||||||
|
max_length: 0
|
||||||
|
word_boundary: true
|
||||||
|
ellipsis: true
|
||||||
|
more_link: false
|
||||||
|
more_link_text: ''
|
||||||
|
more_link_path: ''
|
||||||
|
strip_tags: false
|
||||||
|
trim: false
|
||||||
|
preserve_tags: ''
|
||||||
|
html: false
|
||||||
|
element_type: ''
|
||||||
|
element_class: ''
|
||||||
|
element_label_type: ''
|
||||||
|
element_label_class: ''
|
||||||
|
element_label_colon: true
|
||||||
|
element_wrapper_type: ''
|
||||||
|
element_wrapper_class: ''
|
||||||
|
element_default_classes: true
|
||||||
|
empty: ''
|
||||||
|
hide_empty: false
|
||||||
|
empty_zero: false
|
||||||
|
hide_alter_empty: true
|
||||||
|
click_sort_column: value
|
||||||
|
type: string
|
||||||
|
group_column: value
|
||||||
|
group_columns: { }
|
||||||
|
group_rows: true
|
||||||
|
delta_limit: 0
|
||||||
|
delta_offset: 0
|
||||||
|
delta_reversed: false
|
||||||
|
delta_first_last: false
|
||||||
|
multi_type: separator
|
||||||
|
separator: ', '
|
||||||
|
field_api_classes: false
|
||||||
|
filters:
|
||||||
|
status:
|
||||||
|
value: '1'
|
||||||
|
table: node_field_data
|
||||||
|
field: status
|
||||||
|
plugin_id: boolean
|
||||||
|
entity_type: node
|
||||||
|
entity_field: status
|
||||||
|
id: status
|
||||||
|
expose:
|
||||||
|
operator: ''
|
||||||
|
group: 1
|
||||||
|
sorts:
|
||||||
|
created:
|
||||||
|
id: created
|
||||||
|
table: node_field_data
|
||||||
|
field: created
|
||||||
|
order: DESC
|
||||||
|
entity_type: node
|
||||||
|
entity_field: created
|
||||||
|
plugin_id: date
|
||||||
|
relationship: none
|
||||||
|
group_type: group
|
||||||
|
admin_label: ''
|
||||||
|
exposed: false
|
||||||
|
expose:
|
||||||
|
label: ''
|
||||||
|
granularity: second
|
||||||
|
title: 'Test Block View'
|
||||||
|
header: { }
|
||||||
|
footer: { }
|
||||||
|
empty: { }
|
||||||
|
relationships: { }
|
||||||
|
arguments: { }
|
||||||
|
display_extenders: { }
|
||||||
|
cache_metadata:
|
||||||
|
max-age: -1
|
||||||
|
contexts:
|
||||||
|
- 'languages:language_content'
|
||||||
|
- 'languages:language_interface'
|
||||||
|
- 'user.node_grants:view'
|
||||||
|
- user.permissions
|
||||||
|
tags: { }
|
||||||
|
block_1:
|
||||||
|
display_plugin: block
|
||||||
|
id: block_1
|
||||||
|
display_title: Block
|
||||||
|
position: 1
|
||||||
|
display_options:
|
||||||
|
display_extenders: { }
|
||||||
|
cache_metadata:
|
||||||
|
max-age: -1
|
||||||
|
contexts:
|
||||||
|
- 'languages:language_content'
|
||||||
|
- 'languages:language_interface'
|
||||||
|
- 'user.node_grants:view'
|
||||||
|
- user.permissions
|
||||||
|
tags: { }
|
|
@ -0,0 +1,8 @@
|
||||||
|
name: 'Layout Builder Views Test'
|
||||||
|
type: module
|
||||||
|
description: 'Support module for testing.'
|
||||||
|
package: Testing
|
||||||
|
version: VERSION
|
||||||
|
core: 8.x
|
||||||
|
dependencies:
|
||||||
|
- views
|
|
@ -2,7 +2,9 @@
|
||||||
|
|
||||||
namespace Drupal\Tests\layout_builder\Functional;
|
namespace Drupal\Tests\layout_builder\Functional;
|
||||||
|
|
||||||
|
use Drupal\node\Entity\Node;
|
||||||
use Drupal\Tests\BrowserTestBase;
|
use Drupal\Tests\BrowserTestBase;
|
||||||
|
use Drupal\views\Entity\View;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Tests the Layout Builder UI.
|
* Tests the Layout Builder UI.
|
||||||
|
@ -15,7 +17,9 @@ class LayoutBuilderTest extends BrowserTestBase {
|
||||||
* {@inheritdoc}
|
* {@inheritdoc}
|
||||||
*/
|
*/
|
||||||
public static $modules = [
|
public static $modules = [
|
||||||
|
'views',
|
||||||
'layout_builder',
|
'layout_builder',
|
||||||
|
'layout_builder_views_test',
|
||||||
'layout_test',
|
'layout_test',
|
||||||
'block',
|
'block',
|
||||||
'node',
|
'node',
|
||||||
|
@ -349,4 +353,40 @@ class LayoutBuilderTest extends BrowserTestBase {
|
||||||
$assert_session->linkNotExists('Sticky at top of lists');
|
$assert_session->linkNotExists('Sticky at top of lists');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Tests that deleting a View block used in Layout Builder works.
|
||||||
|
*/
|
||||||
|
public function testDeletedView() {
|
||||||
|
$assert_session = $this->assertSession();
|
||||||
|
$page = $this->getSession()->getPage();
|
||||||
|
|
||||||
|
$this->drupalLogin($this->drupalCreateUser([
|
||||||
|
'configure any layout',
|
||||||
|
'administer node display',
|
||||||
|
]));
|
||||||
|
|
||||||
|
$field_ui_prefix = 'admin/structure/types/manage/bundle_with_section_field';
|
||||||
|
// Enable overrides.
|
||||||
|
$this->drupalPostForm("$field_ui_prefix/display/default", ['layout[allow_custom]' => TRUE], 'Save');
|
||||||
|
$this->drupalGet('node/1');
|
||||||
|
|
||||||
|
$assert_session->linkExists('Layout');
|
||||||
|
$this->clickLink('Layout');
|
||||||
|
$this->clickLink('Add Block');
|
||||||
|
$this->clickLink('Test Block View');
|
||||||
|
$page->pressButton('Add Block');
|
||||||
|
|
||||||
|
$assert_session->pageTextContains('Test Block View');
|
||||||
|
$assert_session->elementExists('css', '.block-views-blocktest-block-view-block-1');
|
||||||
|
$this->clickLink('Save Layout');
|
||||||
|
$assert_session->pageTextContains('Test Block View');
|
||||||
|
$assert_session->elementExists('css', '.block-views-blocktest-block-view-block-1');
|
||||||
|
|
||||||
|
View::load('test_block_view')->delete();
|
||||||
|
$this->drupalGet('node/1');
|
||||||
|
// Node can be loaded after deleting the View.
|
||||||
|
$assert_session->pageTextContains(Node::load(1)->getTitle());
|
||||||
|
$assert_session->pageTextNotContains('Test Block View');
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,6 +2,8 @@
|
||||||
|
|
||||||
namespace Drupal\views\Plugin\views\display;
|
namespace Drupal\views\Plugin\views\display;
|
||||||
|
|
||||||
|
use Drupal\Component\Plugin\Discovery\CachedDiscoveryInterface;
|
||||||
|
use Drupal\Core\Block\BlockManagerInterface;
|
||||||
use Drupal\Core\Entity\EntityManagerInterface;
|
use Drupal\Core\Entity\EntityManagerInterface;
|
||||||
use Drupal\Core\Form\FormStateInterface;
|
use Drupal\Core\Form\FormStateInterface;
|
||||||
use Drupal\views\Plugin\Block\ViewsBlock;
|
use Drupal\views\Plugin\Block\ViewsBlock;
|
||||||
|
@ -42,6 +44,13 @@ class Block extends DisplayPluginBase {
|
||||||
*/
|
*/
|
||||||
protected $entityManager;
|
protected $entityManager;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* The block manager.
|
||||||
|
*
|
||||||
|
* @var \Drupal\Core\Block\BlockManagerInterface
|
||||||
|
*/
|
||||||
|
protected $blockManager;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructs a new Block instance.
|
* Constructs a new Block instance.
|
||||||
*
|
*
|
||||||
|
@ -53,11 +62,14 @@ class Block extends DisplayPluginBase {
|
||||||
* The plugin implementation definition.
|
* The plugin implementation definition.
|
||||||
* @param \Drupal\Core\Entity\EntityManagerInterface $entity_manager
|
* @param \Drupal\Core\Entity\EntityManagerInterface $entity_manager
|
||||||
* The entity manager.
|
* The entity manager.
|
||||||
|
* @param \Drupal\Core\Block\BlockManagerInterface $block_manager
|
||||||
|
* The block manager.
|
||||||
*/
|
*/
|
||||||
public function __construct(array $configuration, $plugin_id, $plugin_definition, EntityManagerInterface $entity_manager) {
|
public function __construct(array $configuration, $plugin_id, $plugin_definition, EntityManagerInterface $entity_manager, BlockManagerInterface $block_manager) {
|
||||||
parent::__construct($configuration, $plugin_id, $plugin_definition);
|
parent::__construct($configuration, $plugin_id, $plugin_definition);
|
||||||
|
|
||||||
$this->entityManager = $entity_manager;
|
$this->entityManager = $entity_manager;
|
||||||
|
$this->blockManager = $block_manager;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -68,7 +80,8 @@ class Block extends DisplayPluginBase {
|
||||||
$configuration,
|
$configuration,
|
||||||
$plugin_id,
|
$plugin_id,
|
||||||
$plugin_definition,
|
$plugin_definition,
|
||||||
$container->get('entity.manager')
|
$container->get('entity.manager'),
|
||||||
|
$container->get('plugin.manager.block')
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -364,6 +377,9 @@ class Block extends DisplayPluginBase {
|
||||||
$block->delete();
|
$block->delete();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if ($this->blockManager instanceof CachedDiscoveryInterface) {
|
||||||
|
$this->blockManager->clearCachedDefinitions();
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue