You are here

GutenbergPluginConfigurableInterface.php in Gutenberg 8.2

Same filename and directory in other branches
  1. 8 src/GutenbergPluginConfigurableInterface.php

Namespace

Drupal\gutenberg

File

src/GutenbergPluginConfigurableInterface.php
View source
<?php

namespace Drupal\gutenberg;

use Drupal\Core\Form\FormStateInterface;
use Drupal\editor\Entity\Editor;

/**
 * Defines an interface for configurable Gutenberg plugins.
 *
 * This allows a Gutenberg plugin to define a settings form. These settings can
 * then be automatically passed on to the corresponding Gutenberg instance via
 * GutenbergPluginInterface::getConfig().
 */
interface GutenbergPluginConfigurableInterface extends GutenbergPluginInterface {

  /**
   * Returns a settings form to configure this Gutenberg plugin.
   *
   * If the plugin's behavior depends on extensive options and/or external data,
   * then the implementing module can choose to provide a separate, global
   * configuration page rather than per-text-editor settings. In that case, this
   * form should provide a link to the separate settings page.
   *
   * @param array $form
   *   An empty form array to be populated with a configuration form, if any.
   * @param \Drupal\Core\Form\FormStateInterface $form_state
   *   The state of the entire filter administration form.
   * @param \Drupal\editor\Entity\Editor $editor
   *   A configured text editor object.
   *
   * @return array
   *   A render array for the settings form.
   */
  public function settingsForm(array $form, FormStateInterface $form_state, Editor $editor);

}

Interfaces

Namesort descending Description
GutenbergPluginConfigurableInterface Defines an interface for configurable Gutenberg plugins.