public function MockLayoutBlockDeriver::getDerivativeDefinitions in Drupal 9
Same name and namespace in other branches
- 8 core/modules/system/tests/modules/plugin_test/src/Plugin/plugin_test/mock_block/MockLayoutBlockDeriver.php \Drupal\plugin_test\Plugin\plugin_test\mock_block\MockLayoutBlockDeriver::getDerivativeDefinitions()
Gets the definition of all derivatives of a base plugin.
Parameters
array $base_plugin_definition: The definition array of the base plugin.
Return value
array An array of full derivative definitions keyed on derivative id.
Overrides DeriverInterface::getDerivativeDefinitions
See also
getDerivativeDefinition()
1 call to MockLayoutBlockDeriver::getDerivativeDefinitions()
- MockLayoutBlockDeriver::getDerivativeDefinition in core/modules/ system/ tests/ modules/ plugin_test/ src/ Plugin/ plugin_test/ mock_block/ MockLayoutBlockDeriver.php 
- Gets the definition of a derivative plugin.
File
- core/modules/ system/ tests/ modules/ plugin_test/ src/ Plugin/ plugin_test/ mock_block/ MockLayoutBlockDeriver.php, line 27 
Class
- MockLayoutBlockDeriver
- Mock implementation of DeriverInterface for the mock layout block plugin.
Namespace
Drupal\plugin_test\Plugin\plugin_test\mock_blockCode
public function getDerivativeDefinitions($base_plugin_definition) {
  // This isn't strictly necessary, but it helps reduce clutter in
  // DerivativePluginTest::testDerivativeDecorator()'s $expected variable.
  // Since derivative definitions don't need further deriving, we remove this
  // key from the returned definitions.
  unset($base_plugin_definition['deriver']);
  $derivatives = [
    // Adding a NULL key signifies that the base plugin may also be used in
    // addition to the derivatives. In this case, we allow the administrator
    // to add a generic layout block to the page.
    NULL => $base_plugin_definition,
    // We also allow them to add a customized one. Here, we just mock the
    // customized one, but in a real implementation, this would be fetched
    // from some \Drupal::config() object.
    'foo' => [
      'label' => t('Layout Foo'),
    ] + $base_plugin_definition,
  ];
  return $derivatives;
}