當前位置: 首頁>>代碼示例>>PHP>>正文


PHP ConfigEntityBase::calculateDependencies方法代碼示例

本文整理匯總了PHP中Drupal\Core\Config\Entity\ConfigEntityBase::calculateDependencies方法的典型用法代碼示例。如果您正苦於以下問題:PHP ConfigEntityBase::calculateDependencies方法的具體用法?PHP ConfigEntityBase::calculateDependencies怎麽用?PHP ConfigEntityBase::calculateDependencies使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在Drupal\Core\Config\Entity\ConfigEntityBase的用法示例。


在下文中一共展示了ConfigEntityBase::calculateDependencies方法的15個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的PHP代碼示例。

示例1: calculateDependencies

 /**
  * {@inheritdoc}
  */
 public function calculateDependencies()
 {
     parent::calculateDependencies();
     $target_entity_type = \Drupal::entityManager()->getDefinition($this->targetEntityType);
     $this->addDependency('module', $target_entity_type->getProvider());
     return $this;
 }
開發者ID:aWEBoLabs,項目名稱:taxi,代碼行數:10,代碼來源:EntityDisplayModeBase.php

示例2: testCalculateDependenciesWithThirdPartySettings

 /**
  * @covers ::calculateDependencies
  */
 public function testCalculateDependenciesWithThirdPartySettings()
 {
     $this->entity = $this->getMockForAbstractClass('\\Drupal\\Tests\\Core\\Config\\Entity\\Fixtures\\ConfigEntityBaseWithThirdPartySettings', array(array(), $this->entityTypeId));
     $this->entity->setThirdPartySetting('test_provider', 'test', 'test');
     $this->entity->setThirdPartySetting('test_provider2', 'test', 'test');
     $this->entity->setThirdPartySetting($this->provider, 'test', 'test');
     $this->assertEquals(array('test_provider', 'test_provider2'), $this->entity->calculateDependencies()['module']);
 }
開發者ID:davidsoloman,項目名稱:drupalconsole.com,代碼行數:11,代碼來源:ConfigEntityBaseUnitTest.php

示例3: calculateDependencies

 /**
  * {@inheritdoc}
  */
 public function calculateDependencies()
 {
     parent::calculateDependencies();
     // Make sure we save any explicit module dependencies.
     if ($provider = $this->get('module')) {
         $this->addDependency('module', $provider);
     }
     return $this->dependencies;
 }
開發者ID:sojo,項目名稱:d8_friendsofsilence,代碼行數:12,代碼來源:MigrationGroup.php

示例4: calculateDependencies

 /**
  * {@inheritdoc}
  */
 public function calculateDependencies()
 {
     parent::calculateDependencies();
     if ($this->stateFrom) {
         $this->addDependency('config', ModerationState::load($this->stateFrom)->getConfigDependencyName());
     }
     if ($this->stateTo) {
         $this->addDependency('config', ModerationState::load($this->stateTo)->getConfigDependencyName());
     }
     return $this;
 }
開發者ID:eigentor,項目名稱:tommiblog,代碼行數:14,代碼來源:ModerationStateTransition.php

示例5: calculateDependencies

 /**
  * {@inheritdoc}
  */
 public function calculateDependencies()
 {
     parent::calculateDependencies();
     if (isset($this->breakpointGroup)) {
         // @todo Implement toArray() so we do not have reload the
         //   entity since this property is changed in
         //   \Drupal\responsive_image\Entity\ResponsiveImageMapping::save().
         $breakpoint_group = \Drupal::entityManager()->getStorage('breakpoint_group')->load($this->breakpointGroup);
         $this->addDependency('entity', $breakpoint_group->getConfigDependencyName());
     }
     return $this->dependencies;
 }
開發者ID:alnutile,項目名稱:drunatra,代碼行數:15,代碼來源:ResponsiveImageMapping.php

示例6: calculateDependencies

 /**
  * {@inheritdoc}
  */
 public function calculateDependencies()
 {
     parent::calculateDependencies();
     $prefix = $this->getModerationStateConfigPrefix() . '.';
     if ($this->stateFrom) {
         $this->addDependency('config', $prefix . $this->stateFrom);
     }
     if ($this->stateTo) {
         $this->addDependency('config', $prefix . $this->stateTo);
     }
     return $this;
 }
開發者ID:tedbow,項目名稱:scheduled-updates-demo,代碼行數:15,代碼來源:ModerationStateTransition.php

示例7: testCalculateDependenciesWithThirdPartySettings

 /**
  * @covers ::calculateDependencies
  * @covers ::getDependencies
  * @covers ::onDependencyRemoval
  */
 public function testCalculateDependenciesWithThirdPartySettings()
 {
     $this->entity = $this->getMockForAbstractClass('\\Drupal\\Core\\Config\\Entity\\ConfigEntityBase', array(array(), $this->entityTypeId));
     $this->entity->setThirdPartySetting('test_provider', 'test', 'test');
     $this->entity->setThirdPartySetting('test_provider2', 'test', 'test');
     $this->entity->setThirdPartySetting($this->provider, 'test', 'test');
     $this->assertEquals(array('test_provider', 'test_provider2'), $this->entity->calculateDependencies()->getDependencies()['module']);
     $changed = $this->entity->onDependencyRemoval(['module' => ['test_provider2']]);
     $this->assertTrue($changed, 'Calling onDependencyRemoval with an existing third party dependency provider returns TRUE.');
     $changed = $this->entity->onDependencyRemoval(['module' => ['test_provider3']]);
     $this->assertFalse($changed, 'Calling onDependencyRemoval with a non-existing third party dependency provider returns FALSE.');
     $this->assertEquals(array('test_provider'), $this->entity->calculateDependencies()->getDependencies()['module']);
 }
開發者ID:ddrozdik,項目名稱:dmaps,代碼行數:18,代碼來源:ConfigEntityBaseUnitTest.php

示例8: testCalculateDependenciesWithPluginBags

 /**
  * @covers ::calculateDependencies
  *
  * @dataProvider providerCalculateDependenciesWithPluginBags
  */
 public function testCalculateDependenciesWithPluginBags($definition, $expected_dependencies)
 {
     $values = array();
     $this->entity = $this->getMockBuilder('\\Drupal\\Tests\\Core\\Config\\Entity\\Fixtures\\ConfigEntityBaseWithPluginBags')->setConstructorArgs(array($values, $this->entityTypeId))->setMethods(array('getPluginBags'))->getMock();
     // Create a configurable plugin that would add a dependency.
     $instance_id = $this->randomName();
     $instance = new TestConfigurablePlugin(array(), $instance_id, $definition);
     // Create a plugin bag to contain the instance.
     $pluginBag = $this->getMockBuilder('\\Drupal\\Core\\Plugin\\DefaultPluginBag')->disableOriginalConstructor()->setMethods(array('get'))->getMock();
     $pluginBag->expects($this->atLeastOnce())->method('get')->with($instance_id)->will($this->returnValue($instance));
     $pluginBag->addInstanceId($instance_id);
     // Return the mocked plugin bag.
     $this->entity->expects($this->once())->method('getPluginBags')->will($this->returnValue(array($pluginBag)));
     $this->assertEquals($expected_dependencies, $this->entity->calculateDependencies());
 }
開發者ID:alnutile,項目名稱:drunatra,代碼行數:20,代碼來源:ConfigEntityBaseUnitTest.php

示例9: calculateDependencies

 /**
  * {@inheritdoc}
  */
 public function calculateDependencies()
 {
     parent::calculateDependencies();
     $this->addDependency('config', $this->getPage()->getConfigDependencyName());
     foreach ($this->getSelectionConditions() as $instance) {
         $this->calculatePluginDependencies($instance);
     }
     return $this->getDependencies();
 }
開發者ID:neeravbm,項目名稱:unify-d8,代碼行數:12,代碼來源:PageVariant.php

示例10: calculateDependencies

 /**
  * {@inheritdoc}
  */
 public function calculateDependencies()
 {
     parent::calculateDependencies();
     foreach ($this->test_dependencies as $type => $deps) {
         foreach ($deps as $dep) {
             $this->addDependency($type, $dep);
         }
     }
 }
開發者ID:alnutile,項目名稱:drunatra,代碼行數:12,代碼來源:ConfigTest.php

示例11: calculateDependencies

 /**
  * {@inheritdoc}
  */
 public function calculateDependencies()
 {
     parent::calculateDependencies();
     // Create a dependency on the associated FilterFormat.
     $this->addDependency('config', $this->getFilterFormat()->getConfigDependencyName());
     // @todo use EntityWithPluginCollectionInterface so configuration between
     //   config entity and dependency on provider is managed automatically.
     $definition = $this->editorPluginManager()->createInstance($this->editor)->getPluginDefinition();
     $this->addDependency('module', $definition['provider']);
     return $this->dependencies;
 }
開發者ID:nstielau,項目名稱:drops-8,代碼行數:14,代碼來源:Editor.php

示例12: calculateDependencies

 /**
  * {@inheritdoc}
  */
 public function calculateDependencies()
 {
     parent::calculateDependencies();
     // Create dependency on the bundle.
     $entity_type = \Drupal::entityManager()->getDefinition($this->target_entity_type_id);
     $bundle_config_dependency = $entity_type->getBundleConfigDependency($this->target_bundle);
     $this->addDependency($bundle_config_dependency['type'], $bundle_config_dependency['name']);
     return $this;
 }
開發者ID:systemick3,項目名稱:systemick.co.uk,代碼行數:12,代碼來源:ContentLanguageSettings.php

示例13: getDependencyData

 /**
  * Retrieves data about this index's dependencies.
  *
  * The return value is structured as follows:
  *
  * @code
  * array(
  *   'config' => array(
  *     'CONFIG_DEPENDENCY_KEY' => array(
  *       'always' => array(
  *         'processors' => array(
  *           'PROCESSOR_ID' => $processor,
  *         ),
  *         'datasources' => array(
  *           'DATASOURCE_ID_1' => $datasource_1,
  *           'DATASOURCE_ID_2' => $datasource_2,
  *         ),
  *       ),
  *       'optional' => array(
  *         'index' => array(
  *           'INDEX_ID' => $index,
  *         ),
  *         'tracker' => array(
  *           'TRACKER_ID' => $tracker,
  *         ),
  *       ),
  *     ),
  *   )
  * )
  * @endcode
  *
  * @return object[][][][][]
  *   An associative array containing the index's dependencies. The array is
  *   first keyed by the config dependency type ("module", "config", etc.) and
  *   then by the names of the config dependencies of that type which the index
  *   has. The values are associative arrays with up to two keys, "always" and
  *   "optional", specifying whether the dependency is a hard one by the plugin
  *   (or index) in question or potentially depending on the configuration. The
  *   values on this level are arrays with keys "index", "tracker",
  *   "datasources" and/or "processors" and values arrays of IDs mapped to
  *   their entities/plugins.
  */
 protected function getDependencyData()
 {
     $dependency_data = array();
     // Since calculateDependencies() will work directly on the $dependencies
     // property, we first save its original state and then restore it
     // afterwards.
     $original_dependencies = $this->dependencies;
     parent::calculateDependencies();
     foreach ($this->dependencies as $dependency_type => $list) {
         foreach ($list as $name) {
             $dependency_data[$dependency_type][$name]['always']['index'][$this->id] = $this;
         }
     }
     $this->dependencies = $original_dependencies;
     // The server needs special treatment, since it is a dependency of the index
     // itself, and not one of its plugins.
     if ($this->hasValidServer()) {
         $name = $this->getServerInstance()->getConfigDependencyName();
         $dependency_data['config'][$name]['optional']['index'][$this->id] = $this;
     }
     // All other plugins can be treated uniformly.
     $plugins = $this->getAllPlugins();
     foreach ($plugins as $plugin_type => $type_plugins) {
         foreach ($type_plugins as $plugin_id => $plugin) {
             // Largely copied from
             // \Drupal\Core\Plugin\PluginDependencyTrait::calculatePluginDependencies().
             $definition = $plugin->getPluginDefinition();
             // First, always depend on the module providing the plugin.
             $dependency_data['module'][$definition['provider']]['always'][$plugin_type][$plugin_id] = $plugin;
             // Plugins can declare additional dependencies in their definition.
             if (isset($definition['config_dependencies'])) {
                 foreach ($definition['config_dependencies'] as $dependency_type => $list) {
                     foreach ($list as $name) {
                         $dependency_data[$dependency_type][$name]['always'][$plugin_type][$plugin_id] = $plugin;
                     }
                 }
             }
             // Finally, add the dynamically-calculated dependencies of the plugin.
             foreach ($plugin->calculateDependencies() as $dependency_type => $list) {
                 foreach ($list as $name) {
                     $dependency_data[$dependency_type][$name]['optional'][$plugin_type][$plugin_id] = $plugin;
                 }
             }
         }
     }
     return $dependency_data;
 }
開發者ID:curveagency,項目名稱:intranet,代碼行數:89,代碼來源:Index.php

示例14: calculateDependencies

 /**
  * {@inheritdoc}
  */
 public function calculateDependencies()
 {
     parent::calculateDependencies();
     // Ensure that the Rules component is dependant on the module that
     // implements the component.
     $this->addDependency('module', $this->module);
     // @todo Handle dependencies of plugins that are provided by various modules
     //   here.
     return $this->dependencies;
 }
開發者ID:shahinam,項目名稱:drupal8devel,代碼行數:13,代碼來源:RulesComponent.php

示例15: calculateDependencies

 /**
  * {@inheritdoc}
  */
 public function calculateDependencies()
 {
     parent::calculateDependencies();
     // Ensure that the view is dependant on the module that implements the view.
     $this->addDependency('module', $this->module);
     // Ensure that the view is dependent on the module that provides the schema
     // for the base table.
     $schema = $this->drupalGetSchema($this->base_table);
     // @todo Entity base tables are no longer registered in hook_schema(). Once
     //   we automate the views data for entity types add the entity type
     //   type provider as a dependency. See https://drupal.org/node/1740492.
     if ($schema && $this->module != $schema['module']) {
         $this->addDependency('module', $schema['module']);
     }
     $handler_types = array();
     foreach (Views::getHandlerTypes() as $type) {
         $handler_types[] = $type['plural'];
     }
     foreach ($this->get('display') as $display) {
         // Collect all dependencies of all handlers.
         foreach ($handler_types as $handler_type) {
             if (!empty($display['display_options'][$handler_type])) {
                 foreach ($display['display_options'][$handler_type] as $handler) {
                     // Add the provider as dependency.
                     if (isset($handler['provider'])) {
                         $this->addDependency('module', $handler['provider']);
                     }
                     // Add the additional dependencies from the handler configuration.
                     if (!empty($handler['dependencies'])) {
                         $this->addDependencies($handler['dependencies']);
                     }
                 }
             }
         }
         // Collect all dependencies of plugins.
         foreach (Views::getPluginTypes('plugin') as $plugin_type) {
             if (!empty($display['display_options'][$plugin_type]['options']['dependencies'])) {
                 $this->addDependencies($display['display_options'][$plugin_type]['options']['dependencies']);
             }
         }
     }
     return $this->dependencies;
 }
開發者ID:shumer,項目名稱:blog,代碼行數:46,代碼來源:View.php


注:本文中的Drupal\Core\Config\Entity\ConfigEntityBase::calculateDependencies方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。