class IframeDefaultFormatter in Iframe 8
Same name and namespace in other branches
- 8.2 src/Plugin/Field/FieldFormatter/IframeDefaultFormatter.php \Drupal\iframe\Plugin\Field\FieldFormatter\IframeDefaultFormatter
Class IframeDefaultFormatter.
Plugin annotation
@FieldFormatter(
id = "iframe_default",
module = "iframe",
label = @Translation("Title, over iframe (default)"),
field_types = {"iframe"}
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
- class \Drupal\Core\Field\PluginSettingsBase implements DependentPluginInterface, PluginSettingsInterface
- class \Drupal\Core\Field\FormatterBase implements FormatterInterface, ContainerFactoryPluginInterface
- class \Drupal\iframe\Plugin\Field\FieldFormatter\IframeDefaultFormatter
- class \Drupal\Core\Field\FormatterBase implements FormatterInterface, ContainerFactoryPluginInterface
- class \Drupal\Core\Field\PluginSettingsBase implements DependentPluginInterface, PluginSettingsInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
Expanded class hierarchy of IframeDefaultFormatter
File
- src/
Plugin/ Field/ FieldFormatter/ IframeDefaultFormatter.php, line 23
Namespace
Drupal\iframe\Plugin\Field\FieldFormatterView source
class IframeDefaultFormatter extends FormatterBase {
/**
* {@inheritdoc}
*/
public static function defaultSettings() {
return [
'url' => '',
'title' => '',
'width' => '',
'height' => '',
'class' => '',
'frameborder' => '0',
'scrolling' => '',
'transparency' => '0',
'tokensupport' => '0',
'allowfullscreen' => '0',
] + parent::defaultSettings();
}
/**
* {@inheritdoc}
*/
public function viewElements(FieldItemListInterface $items, $langcode) {
$elements = [];
$field_settings = $this
->getFieldSettings();
$settings = $this
->getSettings();
$entity = $items
->getEntity();
\iframe_debug(3, __METHOD__, $field_settings);
\iframe_debug(3, __METHOD__, $settings);
\iframe_debug(3, __METHOD__, $entity);
// \iframe_debug(3, __METHOD__, $items->getValue());
foreach ($items as $delta => $item) {
if (empty($item->url)) {
continue;
}
if (!(property_exists($item, 'title') && $item->title !== null)) {
$item->title = '';
}
$elements[$delta] = [
'#markup' => Markup::create(self::iframeIframe($item->title, $item->url, $item)),
'#allowed_tags' => [
'iframe',
'a',
'h3',
'style',
],
];
// Tokens can be dynamic, so its not cacheable.
if (isset($settings['tokensupport']) && $settings['tokensupport']) {
$elements[$delta]['cache'] = [
'max-age' => 0,
];
}
}
return $elements;
}
/**
* Like central function form the iframe code.
*/
public static function iframeIframe($text, $path, $item) {
// \iframe_debug(0, __METHOD__, $item->toArray());
$options = [];
$options['width'] = empty($item->width) ? '100%' : $item->width;
$options['height'] = empty($item->height) ? '701' : $item->height;
// Collect all allow policies.
$allow = [];
// Collect styles, but leave it overwritable.
$style = '';
$itemName = $item
->getFieldDefinition()
->getName();
$itemParentId = $item
->getParent()
->getParent()
->getEntity()
->ID();
if (!empty($item->frameborder) && $item->frameborder > 0) {
$style .= '/*frameborder*/ border-width:2px;';
}
else {
$style .= '/*frameborder*/ border-width:0;';
}
if (!empty($item->scrolling)) {
if ($item->scrolling == 'yes') {
$style .= '/*scrolling*/ overflow:scroll;';
}
elseif ($item->scrolling == 'no') {
$style .= '/*scrolling*/ overflow:hidden;';
}
else {
// Default: auto.
$style .= '/*scrolling*/ overflow:auto;';
}
}
if (!empty($item->transparency) && $item->transparency > 0) {
$style .= '/*transparency*/ background-color:transparent;';
}
$htmlid = 'iframe-' . $itemName . '-' . $itemParentId;
if (property_exists($item, 'htmlid') && $item->htmlid !== null && !empty($item->htmlid)) {
$htmlid = $item->htmlid;
}
$htmlid = preg_replace('#[^A-Za-z0-9\\-\\_]+#', '-', $htmlid);
$options['id'] = $options['name'] = $htmlid;
// Append active class.
$options['class'] = empty($item->class) ? '' : $item->class;
// Remove all HTML and PHP tags from a tooltip.
// For best performance, we act only
// if a quick strpos() pre-check gave a suspicion
// (because strip_tags() is expensive).
$options['title'] = empty($item->title) ? '' : $item->title;
if (!empty($options['title']) && strpos($options['title'], '<') !== FALSE) {
$options['title'] = strip_tags($options['title']);
}
// Policy attribute.
if (!empty($item->allowfullscreen) && $item->allowfullscreen) {
$allow[] = 'fullscreen';
}
$allow[] = 'autoplay';
$allow[] = 'camera';
$allow[] = 'microphone';
$allow[] = 'payment';
$allow[] = 'accelerometer';
$allow[] = 'geolocation';
$allow[] = 'encrypted-media';
$allow[] = 'gyroscope';
$options['allow'] = implode(';', $allow);
if (\Drupal::moduleHandler()
->moduleExists('token')) {
// Token Support for field "url" and "title".
$tokensupport = $item
->getTokenSupport();
$tokencontext = [
'user' => \Drupal::currentUser(),
];
if (isset($GLOBALS['node'])) {
$tokencontext['node'] = $GLOBALS['node'];
}
if ($tokensupport > 0) {
$text = \Drupal::token()
->replace($text, $tokencontext);
}
if ($tokensupport > 1) {
$path = \Drupal::token()
->replace($path, $tokencontext);
}
}
$options_link = [];
$options_link['attributes'] = [];
$options_link['attributes']['title'] = $options['title'];
try {
$srcuri = Url::fromUri($path, $options_link);
$src = $srcuri
->toString();
$options['src'] = $src;
$drupal_attributes = new Attribute($options);
// Style attribute is filtered while rendering => use style block.
$output = '<div class="' . (empty($options['class']) ? '' : new HtmlEscapedText($options['class'])) . '">' . (empty($text) ? '' : '<h3 class="iframe_title">' . (isset($options['html']) && $options['html'] ? $text : new HtmlEscapedText($text)) . '</h3>') . '<style type="text/css">iframe#' . $htmlid . ' {' . $style . '}</style>' . "\n" . ' <iframe ' . $drupal_attributes
->__toString() . '>' . t('Your browser does not support iframes, but you can use the following link:') . ' ' . Link::fromTextAndUrl('Link', $srcuri)
->toString() . '</iframe>' . '</div>';
return $output;
} catch (\Exception $excep) {
watchdog_exception(__METHOD__, $excep);
return '';
}
}
}
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 | |
FormatterBase:: |
protected | property | The field definition. | |
FormatterBase:: |
protected | property | The label display setting. | |
FormatterBase:: |
protected | property |
The formatter settings. Overrides PluginSettingsBase:: |
|
FormatterBase:: |
protected | property | The view mode. | |
FormatterBase:: |
public static | function |
Creates an instance of the plugin. Overrides ContainerFactoryPluginInterface:: |
11 |
FormatterBase:: |
protected | function | Returns the value of a field setting. | |
FormatterBase:: |
protected | function | Returns the array of field settings. | |
FormatterBase:: |
public static | function |
Returns if the formatter can be used for the provided field. Overrides FormatterInterface:: |
14 |
FormatterBase:: |
public | function |
Allows formatters to load information for field values being displayed. Overrides FormatterInterface:: |
2 |
FormatterBase:: |
public | function |
Returns a form to configure settings for the formatter. Overrides FormatterInterface:: |
24 |
FormatterBase:: |
public | function |
Returns a short summary for the current formatter settings. Overrides FormatterInterface:: |
22 |
FormatterBase:: |
public | function |
Builds a renderable array for a fully themed field. Overrides FormatterInterface:: |
1 |
FormatterBase:: |
public | function |
Constructs a FormatterBase object. Overrides PluginBase:: |
11 |
IframeDefaultFormatter:: |
public static | function |
Defines the default settings for this plugin. Overrides PluginSettingsBase:: |
|
IframeDefaultFormatter:: |
public static | function | Like central function form the iframe code. | |
IframeDefaultFormatter:: |
public | function |
Builds a renderable array for a field value. Overrides FormatterInterface:: |
3 |
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. | |
PluginSettingsBase:: |
protected | property | Whether default settings have been merged into the current $settings. | |
PluginSettingsBase:: |
protected | property | The plugin settings injected by third party modules. | |
PluginSettingsBase:: |
public | function |
Calculates dependencies for the configured plugin. Overrides DependentPluginInterface:: |
6 |
PluginSettingsBase:: |
public | function |
Returns the value of a setting, or its default value if absent. Overrides PluginSettingsInterface:: |
|
PluginSettingsBase:: |
public | function |
Returns the array of settings, including defaults for missing settings. Overrides PluginSettingsInterface:: |
|
PluginSettingsBase:: |
public | function |
Gets the list of third parties that store information. Overrides ThirdPartySettingsInterface:: |
|
PluginSettingsBase:: |
public | function |
Gets the value of a third-party setting. Overrides ThirdPartySettingsInterface:: |
|
PluginSettingsBase:: |
public | function |
Gets all third-party settings of a given module. Overrides ThirdPartySettingsInterface:: |
|
PluginSettingsBase:: |
protected | function | Merges default settings values into $settings. | |
PluginSettingsBase:: |
public | function |
Informs the plugin that some configuration it depends on will be deleted. Overrides PluginSettingsInterface:: |
3 |
PluginSettingsBase:: |
public | function |
Sets the value of a setting for the plugin. Overrides PluginSettingsInterface:: |
|
PluginSettingsBase:: |
public | function |
Sets the settings for the plugin. Overrides PluginSettingsInterface:: |
|
PluginSettingsBase:: |
public | function |
Sets the value of a third-party setting. Overrides ThirdPartySettingsInterface:: |
|
PluginSettingsBase:: |
public | function |
Unsets a third-party setting. Overrides ThirdPartySettingsInterface:: |
|
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. |