class FileMatcher in Linkit 8.4
Same name and namespace in other branches
- 8.5 src/Plugin/Linkit/Matcher/FileMatcher.php \Drupal\linkit\Plugin\Linkit\Matcher\FileMatcher
Plugin annotation
@Matcher(
id = "entity:file",
target_entity = "file",
label = @Translation("File"),
provider = "file"
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
- class \Drupal\linkit\MatcherBase implements ContainerFactoryPluginInterface, MatcherInterface
- class \Drupal\linkit\ConfigurableMatcherBase implements ConfigurableMatcherInterface
- class \Drupal\linkit\Plugin\Linkit\Matcher\EntityMatcher uses MatcherTokensTrait
- class \Drupal\linkit\Plugin\Linkit\Matcher\FileMatcher
- class \Drupal\linkit\Plugin\Linkit\Matcher\EntityMatcher uses MatcherTokensTrait
- class \Drupal\linkit\ConfigurableMatcherBase implements ConfigurableMatcherInterface
- class \Drupal\linkit\MatcherBase implements ContainerFactoryPluginInterface, MatcherInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
Expanded class hierarchy of FileMatcher
File
- src/
Plugin/ Linkit/ Matcher/ FileMatcher.php, line 22 - Contains \Drupal\linkit\Plugin\Linkit\Matcher\FileMatcher.
Namespace
Drupal\linkit\Plugin\Linkit\MatcherView source
class FileMatcher extends EntityMatcher {
/**
* {@inheritdoc}
*/
public function getSummary() {
$summery = parent::getSummary();
$summery[] = $this
->t('Show image dimensions: @show_image_dimensions', [
'@show_image_dimensions' => $this->configuration['images']['show_dimensions'] ? $this
->t('Yes') : $this
->t('No'),
]);
$summery[] = $this
->t('Show image thumbnail: @show_image_thumbnail', [
'@show_image_thumbnail' => $this->configuration['images']['show_thumbnail'] ? $this
->t('Yes') : $this
->t('No'),
]);
if ($this->moduleHandler
->moduleExists('image') && $this->configuration['images']['show_thumbnail']) {
$image_style = ImageStyle::load($this->configuration['images']['thumbnail_image_style']);
if (!is_null($image_style)) {
$summery[] = $this
->t('Thumbnail style: @thumbnail_style', [
'@thumbnail_style' => $image_style
->label(),
]);
}
}
return $summery;
}
/**
* {@inheritdoc}
*/
public function defaultConfiguration() {
return parent::defaultConfiguration() + [
'images' => [
'show_dimensions' => FALSE,
'show_thumbnail' => FALSE,
'thumbnail_image_style' => 'linkit_result_thumbnail',
],
];
}
/**
* {@inheritdoc}
*/
public function calculateDependencies() {
$dependencies = parent::calculateDependencies() + [
'module' => [
'file',
],
];
if ($this->configuration['images']['show_thumbnail']) {
$dependencies['module'][] = 'image';
$dependencies['config'][] = 'image.style.' . $this->configuration['images']['thumbnail_image_style'];
}
return $dependencies;
}
/**
* {@inheritdoc}
*/
public function buildConfigurationForm(array $form, FormStateInterface $form_state) {
$form = parent::buildConfigurationForm($form, $form_state);
$form['images'] = array(
'#type' => 'details',
'#title' => t('Image file settings'),
'#description' => t('Extra settings for image files in the result.'),
'#tree' => TRUE,
);
$form['images']['show_dimensions'] = [
'#title' => t('Show pixel dimensions'),
'#type' => 'checkbox',
'#default_value' => $this->configuration['images']['show_dimensions'],
];
if ($this->moduleHandler
->moduleExists('image')) {
$form['images']['show_thumbnail'] = [
'#title' => t('Show thumbnail'),
'#type' => 'checkbox',
'#default_value' => $this->configuration['images']['show_thumbnail'],
];
$form['images']['thumbnail_image_style'] = [
'#title' => t('Thumbnail image style'),
'#type' => 'select',
'#default_value' => $this->configuration['images']['thumbnail_image_style'],
'#options' => image_style_options(FALSE),
'#states' => [
'visible' => [
':input[name="images[show_thumbnail]"]' => [
'checked' => TRUE,
],
],
],
];
}
return $form;
}
/**
* {@inheritdoc}
*/
public function submitConfigurationForm(array &$form, FormStateInterface $form_state) {
parent::submitConfigurationForm($form, $form_state);
$values = $form_state
->getValue('images');
if (!$values['show_thumbnail']) {
$values['thumbnail_image_style'] = NULL;
}
$this->configuration['images'] = $values;
}
/**
* {@inheritdoc}
*/
protected function buildEntityQuery($match) {
$query = parent::buildEntityQuery($match);
$query
->condition('status', FILE_STATUS_PERMANENT);
return $query;
}
/**
* {@inheritdoc}
*/
protected function buildDescription($entity) {
$description_array = array();
$description_array[] = parent::buildDescription($entity);
/** @var \Drupal\file\FileInterface $entity */
$file = $entity
->getFileUri();
/** @var \Drupal\Core\Image\ImageInterface $image */
$image = \Drupal::service('image.factory')
->get($file);
if ($image
->isValid()) {
if ($this->configuration['images']['show_dimensions']) {
$description_array[] = $image
->getWidth() . 'x' . $image
->getHeight() . 'px';
}
if ($this->configuration['images']['show_thumbnail'] && $this->moduleHandler
->moduleExists('image')) {
$image_element = array(
'#weight' => -10,
'#theme' => 'image_style',
'#style_name' => $this->configuration['images']['thumbnail_image_style'],
'#uri' => $entity
->getFileUri(),
);
$description_array[] = (string) \Drupal::service('renderer')
->render($image_element);
}
}
$description = implode('<br />', $description_array);
return LinkitXss::descriptionFilter($description);
}
/**
* {@inheritdoc}
*
* The file entity still uses url() even though it's deprecated in the
* entity interface.
*/
protected function buildPath($entity) {
/** @var \Drupal\file\FileInterface $entity */
return file_url_transform_relative(file_create_url($entity
->getFileUri()));
}
}
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 | |
EntityMatcher:: |
protected | property | The current user. | |
EntityMatcher:: |
protected | property | The database connection. | |
EntityMatcher:: |
protected | property | The entity manager. | |
EntityMatcher:: |
protected | property | The module handler service. | |
EntityMatcher:: |
protected | property | The target entity type id | |
EntityMatcher:: |
protected | function | Builds the group string used in the match array. | |
EntityMatcher:: |
protected | function | Builds the label string used in the match array. | |
EntityMatcher:: |
public static | function |
Creates an instance of the plugin. Overrides ContainerFactoryPluginInterface:: |
|
EntityMatcher:: |
public static | function | Form element validation handler; Filters the #value property of an element. | |
EntityMatcher:: |
public | function |
Gets an array with search matches that will be presented in the autocomplete
widget. Overrides MatcherInterface:: |
|
EntityMatcher:: |
public | function |
Form validation handler. Overrides PluginFormInterface:: |
|
EntityMatcher:: |
public | function |
Constructs a \Drupal\Component\Plugin\PluginBase object. Overrides MatcherBase:: |
|
FileMatcher:: |
public | function |
Form constructor. Overrides EntityMatcher:: |
|
FileMatcher:: |
protected | function |
Builds the description string used in the match array. Overrides EntityMatcher:: |
|
FileMatcher:: |
protected | function |
Builds an EntityQuery to get entities. Overrides EntityMatcher:: |
|
FileMatcher:: |
protected | function |
The file entity still uses url() even though it's deprecated in the
entity interface. Overrides EntityMatcher:: |
|
FileMatcher:: |
public | function |
Calculates dependencies for the configured plugin. Overrides MatcherBase:: |
|
FileMatcher:: |
public | function |
Gets default configuration for this plugin. Overrides EntityMatcher:: |
|
FileMatcher:: |
public | function |
Returns the summarized configuration of the matcher. Overrides EntityMatcher:: |
|
FileMatcher:: |
public | function |
Form submission handler. Overrides EntityMatcher:: |
|
MatcherBase:: |
protected | property | The matcher ID. | |
MatcherBase:: |
protected | property | The weight of the matcher compared to others in a matcher collection. | |
MatcherBase:: |
public | function |
Gets this plugin's configuration. Overrides ConfigurablePluginInterface:: |
|
MatcherBase:: |
public | function |
Returns the matcher label. Overrides MatcherInterface:: |
|
MatcherBase:: |
public | function |
Returns the unique ID representing the matcher. Overrides MatcherInterface:: |
|
MatcherBase:: |
public | function |
Returns the weight of the matcher. Overrides MatcherInterface:: |
|
MatcherBase:: |
public | function |
Sets the configuration for this plugin instance. Overrides ConfigurablePluginInterface:: |
|
MatcherBase:: |
public | function |
Sets the weight for the matcher. Overrides MatcherInterface:: |
|
MatcherTokensTrait:: |
public | function | Gets all available tokens. | |
MatcherTokensTrait:: |
public | function | Inserts a form element with a list of available tokens. | |
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. |