class InsertView in Insert View 8
Same name and namespace in other branches
- 2.0.x src/Plugin/Filter/InsertView.php \Drupal\insert_view\Plugin\Filter\InsertView
Provides a filter for insert view.
Plugin annotation
@Filter(
  id = "insert_view",
  module = "insert_view",
  title = @Translation("Insert View"),
  description = @Translation("Allows to embed views using the simple syntax: [view:name=display=args]"),
  type = Drupal\filter\Plugin\FilterInterface::TYPE_MARKUP_LANGUAGE,
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait- class \Drupal\filter\Plugin\FilterBase implements FilterInterface- class \Drupal\insert_view\Plugin\Filter\InsertView implements TrustedCallbackInterface
 
 
- class \Drupal\filter\Plugin\FilterBase implements FilterInterface
 
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
Expanded class hierarchy of InsertView
File
- src/Plugin/ Filter/ InsertView.php, line 21 
Namespace
Drupal\insert_view\Plugin\FilterView source
class InsertView extends FilterBase implements TrustedCallbackInterface {
  /**
   * {@inheritdoc}
   */
  public function process($text, $langcode) {
    $result = new FilterProcessResult($text);
    if (!empty($text)) {
      $match = [];
      if (preg_match_all("/\\[view:([^=\\]]+)=?([^=\\]]+)?=?([^\\]]*)?\\]/i", $text, $match)) {
        $search = $replace = [];
        foreach ($match[0] as $key => $value) {
          $view_name = $match[1][$key];
          $display_id = $match[2][$key] && !is_numeric($match[2][$key]) ? $match[2][$key] : 'default';
          $args = $match[3][$key];
          // Let's create a placeholder from the renderable array of the view.
          $view_output = $result
            ->createPlaceholder('\\Drupal\\insert_view\\Plugin\\Filter\\InsertView::build', [
            $view_name,
            $display_id,
            $args,
          ]);
          // Populate the replace statement.
          $search[] = $value;
          $replace[] = !empty($view_output) ? $view_output : '';
        }
        $text = str_replace($search, $replace, $text);
        // Add some more caching options.
        $result
          ->setProcessedText($text)
          ->addCacheTags([
          'insert_view',
        ])
          ->addCacheContexts([
          'url',
          'user.permissions',
        ]);
      }
    }
    return $result;
  }
  /**
   * @param $view_name
   * @param $display_id
   * @param $args
   *
   * @return array
   */
  public static function build($view_name, $display_id, $args) {
    $plain = '';
    $view = Views::getView($view_name);
    if (empty($view)) {
      // Return renderable array.
      return [
        '#attached' => [],
        '#markup' => $plain,
      ];
    }
    if (!$view
      ->access($display_id)) {
      // Return renderable array.
      return [
        '#attached' => [],
        '#markup' => $plain,
      ];
    }
    $current_path = \Drupal::service('path.current')
      ->getPath();
    $url_args = explode('/', $current_path);
    foreach ($url_args as $id => $arg) {
      $args = str_replace("%{$id}", $arg, $args);
    }
    $args = preg_replace(',/?(%\\d),', '', $args);
    $args = $args ? explode('/', $args) : [];
    return $view
      ->preview($display_id, $args);
  }
  /**
   * {@inheritdoc}
   */
  public function tips($long = FALSE) {
    if ($long) {
      $output = '<br />';
      $output .= '<dl>';
      $output .= '<dt>' . t('Insert view filter allows to embed views using tags. The tag syntax is relatively simple: [view:name=display=args]') . '</dt>';
      $output .= '<dt>' . t('For example [view:tracker=page=1] says, embed a view named "tracker", use the "page" display, and supply the argument "1".') . '</dt>';
      $output .= '<dt>' . t("The <em>display</em> and <em>args</em> parameters can be omitted. If the display is left empty, the view\\'s default display is used.") . '</dt>';
      $output .= '<dt>' . t('Multiple arguments are separated with slash. The <em>args</em> format is the same as used in the URL (or view preview screen).') . '</dt>';
      $output .= '</dl>';
      $output .= t('Valid examples:');
      $output .= '<dl>';
      $output .= '<dt>[view:my_view]</dt>';
      $output .= '<dt>[view:my_view=my_display]</dt>';
      $output .= '<dt>[view:my_view=my_display=arg1/arg2/arg3]</dt>';
      $output .= '<dt>[view:my_view==arg1/arg2/arg3]</dt>';
      $output .= '</dl>';
      $output .= '<br />';
      return $output;
    }
    else {
      return t('You may use [view:<em>name=display=args</em>] tags to display views.');
    }
  }
  /**
   * {@inheritdoc}
   */
  public static function trustedCallbacks() {
    return [
      'build',
    ];
  }
}Members
| Name   | Modifiers | Type | Description | Overrides | 
|---|---|---|---|---|
| DependencySerializationTrait:: | protected | property | An array of entity type IDs keyed by the property name of their storages. | |
| DependencySerializationTrait:: | protected | property | An array of service IDs keyed by property name used for serialization. | |
| DependencySerializationTrait:: | public | function | 1 | |
| DependencySerializationTrait:: | public | function | 2 | |
| FilterBase:: | public | property | The name of the provider that owns this filter. | |
| FilterBase:: | public | property | An associative array containing the configured settings of this filter. | |
| FilterBase:: | public | property | A Boolean indicating whether this filter is enabled. | |
| FilterBase:: | public | property | The weight of this filter compared to others in a filter collection. | |
| FilterBase:: | public | function | Calculates dependencies for the configured plugin. Overrides DependentPluginInterface:: | 1 | 
| FilterBase:: | public | function | Gets default configuration for this plugin. Overrides ConfigurableInterface:: | |
| FilterBase:: | public | function | Gets this plugin's configuration. Overrides ConfigurableInterface:: | |
| FilterBase:: | public | function | Returns the administrative description for this filter plugin. Overrides FilterInterface:: | |
| FilterBase:: | public | function | Returns HTML allowed by this filter's configuration. Overrides FilterInterface:: | 4 | 
| FilterBase:: | public | function | Returns the administrative label for this filter plugin. Overrides FilterInterface:: | |
| FilterBase:: | public | function | Returns the processing type of this filter plugin. Overrides FilterInterface:: | |
| FilterBase:: | public | function | Prepares the text for processing. Overrides FilterInterface:: | |
| FilterBase:: | public | function | Sets the configuration for this plugin instance. Overrides ConfigurableInterface:: | 1 | 
| FilterBase:: | public | function | Generates a filter's settings form. Overrides FilterInterface:: | 3 | 
| FilterBase:: | public | function | Constructs a \Drupal\Component\Plugin\PluginBase object. Overrides PluginBase:: | 4 | 
| FilterInterface:: | constant | HTML tag and attribute restricting filters to prevent XSS attacks. | ||
| FilterInterface:: | constant | Non-HTML markup language filters that generate HTML. | ||
| FilterInterface:: | constant | Irreversible transformation filters. | ||
| FilterInterface:: | constant | Reversible transformation filters. | ||
| InsertView:: | public static | function | ||
| InsertView:: | public | function | Performs the filter processing. Overrides FilterInterface:: | |
| InsertView:: | public | function | Generates a filter's tip. Overrides FilterBase:: | |
| InsertView:: | public static | function | Lists the trusted callbacks provided by the implementing class. Overrides TrustedCallbackInterface:: | |
| MessengerTrait:: | protected | property | The messenger. | 29 | 
| MessengerTrait:: | public | function | Gets the messenger. | 29 | 
| MessengerTrait:: | public | function | Sets the messenger. | |
| PluginBase:: | protected | property | Configuration information passed into the plugin. | 1 | 
| PluginBase:: | protected | property | The plugin implementation definition. | 1 | 
| PluginBase:: | protected | property | The plugin_id. | |
| PluginBase:: | constant | A string which is used to separate base plugin IDs from the derivative ID. | ||
| PluginBase:: | public | function | Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface:: | |
| PluginBase:: | public | function | Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface:: | |
| PluginBase:: | public | function | Gets the definition of the plugin implementation. Overrides PluginInspectionInterface:: | 3 | 
| PluginBase:: | public | function | Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface:: | |
| PluginBase:: | public | function | Determines if the plugin is configurable. | |
| StringTranslationTrait:: | protected | property | The string translation service. | 1 | 
| StringTranslationTrait:: | protected | function | Formats a string containing a count of items. | |
| StringTranslationTrait:: | protected | function | Returns the number of plurals supported by a given language. | |
| StringTranslationTrait:: | protected | function | Gets the string translation service. | |
| StringTranslationTrait:: | public | function | Sets the string translation service to use. | 2 | 
| StringTranslationTrait:: | protected | function | Translates a string to the current language or to a given language. | |
| TrustedCallbackInterface:: | constant | Untrusted callbacks throw exceptions. | ||
| TrustedCallbackInterface:: | constant | Untrusted callbacks trigger silenced E_USER_DEPRECATION errors. | ||
| TrustedCallbackInterface:: | constant | Untrusted callbacks trigger E_USER_WARNING errors. | 
