interface FieldHandlerInterface in Drupal 9
Same name and namespace in other branches
- 8 core/modules/views/src/Plugin/views/field/FieldHandlerInterface.php \Drupal\views\Plugin\views\field\FieldHandlerInterface
- 10 core/modules/views/src/Plugin/views/field/FieldHandlerInterface.php \Drupal\views\Plugin\views\field\FieldHandlerInterface
Base field handler that has no options and renders an unformatted field.
Hierarchy
- interface \Drupal\Component\Plugin\PluginInspectionInterface; interface \Drupal\Component\Plugin\DerivativeInspectionInterface- interface \Drupal\views\Plugin\views\ViewsPluginInterface- interface \Drupal\views\Plugin\views\ViewsHandlerInterface- interface \Drupal\views\Plugin\views\field\FieldHandlerInterface
 
 
- interface \Drupal\views\Plugin\views\ViewsHandlerInterface
 
- interface \Drupal\views\Plugin\views\ViewsPluginInterface
Expanded class hierarchy of FieldHandlerInterface
All classes that implement FieldHandlerInterface
File
- core/modules/ views/ src/ Plugin/ views/ field/ FieldHandlerInterface.php, line 11 
Namespace
Drupal\views\Plugin\views\fieldView source
interface FieldHandlerInterface extends ViewsHandlerInterface {
  /**
   * Adds an ORDER BY clause to the query for click sort columns.
   *
   * @param string $order
   *   Either ASC or DESC
   */
  public function clickSort($order);
  /**
   * Determines if this field is click sortable.
   *
   * @return bool
   *   The value of 'click sortable' from the plugin definition, this defaults
   *   to TRUE if not set.
   */
  public function clickSortable();
  /**
   * Gets this field's label.
   */
  public function label();
  /**
   * Returns an HTML element based upon the field's element type.
   *
   * @param bool $none_supported
   *   Whether or not this HTML element is supported.
   * @param bool $default_empty
   *   Whether or not this HTML element is empty by default.
   * @param bool $inline
   *   Whether or not this HTML element is inline.
   */
  public function elementType($none_supported = FALSE, $default_empty = FALSE, $inline = FALSE);
  /**
   * Returns an HTML element for the label based upon the field's element type.
   *
   * @param bool $none_supported
   *   Whether or not this HTML element is supported.
   * @param bool $default_empty
   *   Whether or not this HTML element is empty by default.
   */
  public function elementLabelType($none_supported = FALSE, $default_empty = FALSE);
  /**
   * Returns an HTML element for the wrapper based upon the field's element type.
   *
   * @param bool $none_supported
   *   Whether or not this HTML element is supported.
   * @param bool $default_empty
   *   Whether or not this HTML element is empty by default.
   */
  public function elementWrapperType($none_supported = FALSE, $default_empty = FALSE);
  /**
   * Provides a list of elements valid for field HTML.
   *
   * This function can be overridden by fields that want more or fewer
   * elements available, though this seems like it would be an incredibly
   * rare occurrence.
   */
  public function getElements();
  /**
   * Returns the class of the field.
   *
   * @param bool $row_index
   *   The index of current row.
   */
  public function elementClasses($row_index = NULL);
  /**
   * Replaces a value with tokens from the last field.
   *
   * This function actually figures out which field was last and uses its
   * tokens so they will all be available.
   *
   * @param string $value
   *   The raw string.
   * @param bool $row_index
   *   The index of current row.
   */
  public function tokenizeValue($value, $row_index = NULL);
  /**
   * Returns the class of the field's label.
   *
   * @param bool $row_index
   *   The index of current row.
   */
  public function elementLabelClasses($row_index = NULL);
  /**
   * Returns the class of the field's wrapper.
   *
   * @param bool $row_index
   *   The index of current row.
   */
  public function elementWrapperClasses($row_index = NULL);
  /**
   * Gets the entity matching the current row and relationship.
   *
   * @param \Drupal\views\ResultRow $values
   *   An object containing all retrieved values.
   *
   * @return \Drupal\Core\Entity\EntityInterface|null
   *   Returns the entity matching the values or NULL if there is no matching
   *   entity.
   */
  public function getEntity(ResultRow $values);
  /**
   * Gets the value that's supposed to be rendered.
   *
   * This api exists so that other modules can easy set the values of the field
   * without having the need to change the render method as well.
   *
   * @param \Drupal\views\ResultRow $values
   *   An object containing all retrieved values.
   * @param string $field
   *   Optional name of the field where the value is stored.
   */
  public function getValue(ResultRow $values, $field = NULL);
  /**
   * Determines if this field will be available as an option to group the result
   * by in the style settings.
   *
   * @return bool
   *   TRUE if this field handler is groupable, otherwise FALSE.
   */
  public function useStringGroupBy();
  /**
   * Runs before any fields are rendered.
   *
   * This gives the handlers some time to set up before any handler has
   * been rendered.
   *
   * @param \Drupal\views\ResultRow[] $values
   *   An array of all ResultRow objects returned from the query.
   */
  public function preRender(&$values);
  /**
   * Renders the field.
   *
   * @param \Drupal\views\ResultRow $values
   *   The values retrieved from a single row of a view's query result.
   *
   * @return string|\Drupal\Component\Render\MarkupInterface
   *   The rendered output. If the output is safe it will be wrapped in an
   *   object that implements MarkupInterface. If it is empty or unsafe it
   *   will be a string.
   */
  public function render(ResultRow $values);
  /**
   * Runs after every field has been rendered.
   *
   * This is meant to be used mainly to deal with field handlers whose output
   * cannot be cached at row level but can be cached at display level. The
   * typical example is the row counter. For completely uncacheable field output
   * placeholders should be used.
   *
   * @param \Drupal\views\ResultRow $row
   *   An array of all ResultRow objects returned from the query.
   * @param $output
   *   The field rendered output.
   *
   * @return string[]
   *   An associative array of post-render token values keyed by placeholder.
   *
   * @see \Drupal\views\Plugin\views\field\UncacheableFieldHandlerTrait
   */
  public function postRender(ResultRow $row, $output);
  /**
   * Renders a field using advanced settings.
   *
   * This renders a field normally, then decides if render-as-link and
   * text-replacement rendering is necessary.
   *
   * @param \Drupal\views\ResultRow $values
   *   The values retrieved from a single row of a view's query result.
   *
   * @return string|\Drupal\Component\Render\MarkupInterface
   *   The advanced rendered output. If the output is safe it will be wrapped in
   *   an object that implements MarkupInterface. If it is empty or unsafe
   *   it will be a string.
   */
  public function advancedRender(ResultRow $values);
  /**
   * Checks if a field value is empty.
   *
   * @param $value
   *   The field value.
   * @param bool $empty_zero
   *   Whether or not this field is configured to consider 0 as empty.
   * @param bool $no_skip_empty
   *   Whether or not to use empty() to check the value.
   *
   * @return bool
   *   TRUE if the value is considered empty, FALSE otherwise.
   */
  public function isValueEmpty($value, $empty_zero, $no_skip_empty = TRUE);
  /**
   * Performs an advanced text render for the item.
   *
   * This is separated out as some fields may render lists, and this allows
   * each item to be handled individually.
   *
   * @param array $alter
   *   The alter array of options to use.
   *     - max_length: Maximum length of the string, the rest gets truncated.
   *     - word_boundary: Trim only on a word boundary.
   *     - ellipsis: Show an ellipsis (…) at the end of the trimmed string.
   *     - html: Make sure that the html is correct.
   *
   * @return string|\Drupal\Component\Render\MarkupInterface
   *   The rendered output. If the output is safe it will be wrapped in an
   *   object that implements MarkupInterface. If it is empty or unsafe it
   *   will be a string.
   */
  public function renderText($alter);
  /**
   * Gets the 'render' tokens to use for advanced rendering.
   *
   * This runs through all of the fields and arguments that
   * are available and gets their values. This will then be
   * used in one giant str_replace().
   *
   * @param mixed $item
   *   The item to render.
   *
   * @return array
   *   An array of available tokens
   */
  public function getRenderTokens($item);
  /**
   * Passes values to drupal_render() using $this->themeFunctions() as #theme.
   *
   * @param \Drupal\views\ResultRow $values
   *   Holds single row of a view's result set.
   *
   * @return string|\Drupal\Component\Render\MarkupInterface
   *   Returns rendered output of the given theme implementation. If the output
   *   is safe it will be wrapped in an object that implements
   *   MarkupInterface. If it is empty or unsafe it will be a string.
   */
  public function theme(ResultRow $values);
}Members
| Name   | Modifiers | Type | Description | Overrides | 
|---|---|---|---|---|
| DerivativeInspectionInterface:: | public | function | Gets the base_plugin_id of the plugin instance. | 1 | 
| DerivativeInspectionInterface:: | public | function | Gets the derivative_id of the plugin instance. | 1 | 
| FieldHandlerInterface:: | public | function | Renders a field using advanced settings. | 1 | 
| FieldHandlerInterface:: | public | function | Adds an ORDER BY clause to the query for click sort columns. | 1 | 
| FieldHandlerInterface:: | public | function | Determines if this field is click sortable. | 1 | 
| FieldHandlerInterface:: | public | function | Returns the class of the field. | 1 | 
| FieldHandlerInterface:: | public | function | Returns the class of the field's label. | 1 | 
| FieldHandlerInterface:: | public | function | Returns an HTML element for the label based upon the field's element type. | 1 | 
| FieldHandlerInterface:: | public | function | Returns an HTML element based upon the field's element type. | 1 | 
| FieldHandlerInterface:: | public | function | Returns the class of the field's wrapper. | 1 | 
| FieldHandlerInterface:: | public | function | Returns an HTML element for the wrapper based upon the field's element type. | 1 | 
| FieldHandlerInterface:: | public | function | Provides a list of elements valid for field HTML. | 1 | 
| FieldHandlerInterface:: | public | function | Gets the entity matching the current row and relationship. | 1 | 
| FieldHandlerInterface:: | public | function | Gets the 'render' tokens to use for advanced rendering. | 1 | 
| FieldHandlerInterface:: | public | function | Gets the value that's supposed to be rendered. | 1 | 
| FieldHandlerInterface:: | public | function | Checks if a field value is empty. | 1 | 
| FieldHandlerInterface:: | public | function | Gets this field's label. | 1 | 
| FieldHandlerInterface:: | public | function | Runs after every field has been rendered. | 1 | 
| FieldHandlerInterface:: | public | function | Runs before any fields are rendered. | 1 | 
| FieldHandlerInterface:: | public | function | Renders the field. | 1 | 
| FieldHandlerInterface:: | public | function | Performs an advanced text render for the item. | 1 | 
| FieldHandlerInterface:: | public | function | Passes values to drupal_render() using $this->themeFunctions() as #theme. | 1 | 
| FieldHandlerInterface:: | public | function | Replaces a value with tokens from the last field. | 1 | 
| FieldHandlerInterface:: | public | function | Determines if this field will be available as an option to group the result by in the style settings. | 1 | 
| PluginInspectionInterface:: | public | function | Gets the definition of the plugin implementation. | 4 | 
| PluginInspectionInterface:: | public | function | Gets the plugin_id of the plugin instance. | 2 | 
| ViewsHandlerInterface:: | public | function | Check whether given user has access to this handler. | 1 | 
| ViewsHandlerInterface:: | public | function | Return a string representing this handler's name in the UI. | 1 | 
| ViewsHandlerInterface:: | public | function | Provide text for the administrative summary. | 1 | 
| ViewsHandlerInterface:: | public static | function | Breaks x,y,z and x+y+z into an array. | 1 | 
| ViewsHandlerInterface:: | public | function | Determines if the handler is considered 'broken', meaning it's a placeholder used when a handler can't be found. | 1 | 
| ViewsHandlerInterface:: | public | function | Ensure the main table for this handler is in the query. This is used a lot. | 1 | 
| ViewsHandlerInterface:: | public | function | Determines the entity type used by this handler. | 1 | 
| ViewsHandlerInterface:: | public | function | Shortcut to get a handler's raw field value. | 1 | 
| ViewsHandlerInterface:: | public | function | Get the join object that should be used for this handler. | 1 | 
| ViewsHandlerInterface:: | public static | function | Fetches a handler to join one table to a primary table from the data cache. | 1 | 
| ViewsHandlerInterface:: | public | function | Run after the view is executed, before the result is cached. | 1 | 
| ViewsHandlerInterface:: | public | function | Run before the view is built. | 1 | 
| ViewsHandlerInterface:: | public | function | Sanitize the value for output. | 1 | 
| ViewsHandlerInterface:: | public | function | Called just prior to query(), this lets a handler set up any relationship it needs. | 1 | 
| ViewsHandlerInterface:: | public | function | Shortcut to display the exposed options form. | 1 | 
| ViewsPluginInterface:: | public | function | Provide a form to edit options for this plugin. | 1 | 
| ViewsPluginInterface:: | public static | function | ||
| ViewsPluginInterface:: | public | function | Clears a plugin. | 1 | 
| ViewsPluginInterface:: | public | function | Filter out stored options depending on the defined options. | 1 | 
| ViewsPluginInterface:: | public | function | Returns an array of available token replacements. | 1 | 
| ViewsPluginInterface:: | public | function | Returns the plugin provider. | 1 | 
| ViewsPluginInterface:: | public | function | Adds elements for available core tokens to a form. | 1 | 
| ViewsPluginInterface:: | public | function | Returns a string with any core tokens replaced. | 1 | 
| ViewsPluginInterface:: | public | function | Initialize the plugin. | 1 | 
| ViewsPluginInterface:: | public | function | Return the human readable name of the display. | 1 | 
| ViewsPluginInterface:: | public static | function | Moves form elements into fieldsets for presentation purposes. | 1 | 
| ViewsPluginInterface:: | public static | function | Flattens the structure of form elements. | 1 | 
| ViewsPluginInterface:: | public | function | Add anything to the query that we might need to. | 1 | 
| ViewsPluginInterface:: | public | function | Handle any special handling on the validate form. | 1 | 
| ViewsPluginInterface:: | public | function | Returns the summary of the settings in the display. | 1 | 
| ViewsPluginInterface:: | public | function | Provide a full list of possible theme templates used by this style. | 1 | 
| ViewsPluginInterface:: | public | function | Unpack options over our existing defaults, drilling down into arrays so that defaults don't get totally blown away. | 1 | 
| ViewsPluginInterface:: | public | function | Returns the usesOptions property. | 1 | 
| ViewsPluginInterface:: | public | function | Validate that the plugin is correct and can be saved. | 1 | 
| ViewsPluginInterface:: | public | function | Validate the options form. | 1 | 
