scheduler-8.x-1.x-dev/scheduler_rules_integration/src/Plugin/RulesAction/SchedulerRulesActionBase.php

scheduler_rules_integration/src/Plugin/RulesAction/SchedulerRulesActionBase.php
<?php

namespace Drupal\scheduler_rules_integration\Plugin\RulesAction;

use Drupal\Core\Entity\EntityInterface;
use Drupal\Core\Link;
use Drupal\Core\Plugin\ContainerFactoryPluginInterface;
use Drupal\Core\Url;
use Drupal\rules\Core\RulesActionBase;
use Symfony\Component\DependencyInjection\ContainerInterface;

/**
 * Provides base class on which all Scheduler Rules actions are built.
 */
class SchedulerRulesActionBase extends RulesActionBase implements ContainerFactoryPluginInterface {

  /**
   * The entity type id.
   *
   * @var string
   */
  protected $entityTypeId;

  /**
   * The scheduler manager.
   *
   * @var \Drupal\scheduler\SchedulerManager
   */
  protected $schedulerManager;

  /**
   * Logger service object.
   *
   * @var \Psr\Log\LoggerInterface
   */
  protected $logger;

  /**
   * The Messenger service.
   *
   * @var \Drupal\Core\Messenger\MessengerInterface
   */
  protected $messenger;

  /**
   * {@inheritdoc}
   */
  public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) {
    $instance = new static($configuration, $plugin_id, $plugin_definition);
    $instance->entityTypeId = $plugin_definition['entity_type_id'];
    $instance->schedulerManager = $container->get('scheduler.manager');
    $instance->logger = $container->get('logger.channel.scheduler');
    $instance->messenger = $container->get('messenger');
    return $instance;
  }

  /**
   * Gives a warning when an entity is not enabled for Scheduler.
   *
   * This is called from actions that attempt to set or remove a Scheduler date
   * value when the entity type is not enabled for that process.
   *
   * SchedulerRulesActionsTest provides test coverage for this functionality.
   *
   * @param \Drupal\Core\Entity\EntityInterface $entity
   *   The entity object being processed by the action.
   * @param string $process
   *   The process that is not enabled, either 'publish' or 'unpublish'.
   */
  public function notEnabledWarning(EntityInterface $entity, string $process) {
    $action = $this->summary();
    $activity = ($process == 'publish') ? $this->t('scheduled publishing') : $this->t('scheduled unpublishing');
    $condition = $this->t('@bundle_label is enabled for @activity', [
      '@bundle_label' => $entity->getEntityType()->getBundleLabel(),
      '@activity' => $activity,
    ]);

    $bundle_field = $entity->getEntityType()->get('entity_keys')['bundle'];
    $type_name = $entity->$bundle_field->entity->label();
    $type_id = $entity->$bundle_field->entity->bundle();
    $url = new Url("entity.$type_id.edit_form", [$type_id => $entity->bundle()]);
    $arguments = [
      '%action' => "'$action'",
      '@activity' => $activity,
      '%type' => $type_name,
      '@group' => $entity->getEntityType()->getPluralLabel(),
      '%condition' => "'$condition'",
      '@url' => $url->toString(),
    ];
    $link = Link::fromTextAndUrl($this->t('@type settings', ['@type' => $type_name]), $url)->toString();
    $this->logger->warning('Action %action is not valid because @activity is not enabled for %type @group. Add the condition %condition to your Reaction Rule, or enable @activity via the %type settings.',
      $arguments + ['link' => $link]);

    $this->messenger->addMessage($this->t('Action %action is not valid because @activity is not enabled for %type @group. Add the condition %condition to your Reaction Rule, or enable @activity via the <a href="@url">%type</a> settings.',
      $arguments), 'warning', FALSE);
  }

}

Главная | Обратная связь

drupal hosting | друпал хостинг | it patrol .inc