Submit
Path:
~
/
home
/
contenidosenred
/
public_html
/
ondemand
/
wp-includes
/
blocks
/
File Content:
image.php
<?php /** * Server-side rendering of the `core/image` block. * * @package WordPress */ /** * Renders the `core/image` block on the server, * adding a data-id attribute to the element if core/gallery has added on pre-render. * * @since 5.9.0 * * @param array $attributes The block attributes. * @param string $content The block content. * @param WP_Block $block The block object. * * @return string The block content with the data-id attribute added. */ function render_block_core_image( $attributes, $content, $block ) { if ( false === stripos( $content, '<img' ) ) { return ''; } $p = new WP_HTML_Tag_Processor( $content ); if ( ! $p->next_tag( 'img' ) || ! $p->get_attribute( 'src' ) ) { return ''; } $has_id_binding = isset( $attributes['metadata']['bindings']['id'] ) && isset( $attributes['id'] ); // Ensure the `wp-image-id` classname on the image block supports block bindings. if ( $has_id_binding ) { // If there's a mismatch with the 'wp-image-' class and the actual id, the id was // probably overridden by block bindings. Update it to the correct value. // See https://github.com/WordPress/gutenberg/issues/62886 for why this is needed. $id = $attributes['id']; $image_classnames = $p->get_attribute( 'class' ); $class_with_binding_value = "wp-image-$id"; if ( is_string( $image_classnames ) && ! str_contains( $image_classnames, $class_with_binding_value ) ) { $image_classnames = preg_replace( '/wp-image-(\d+)/', $class_with_binding_value, $image_classnames ); $p->set_attribute( 'class', $image_classnames ); } } // For backwards compatibility, the data-id html attribute is only set for // image blocks nested in a gallery. Detect if the image is in a gallery by // checking the data-id attribute. // See the `block_core_gallery_data_id_backcompatibility` function. if ( isset( $attributes['data-id'] ) ) { // If there's a binding for the `id`, the `id` attribute is used for the // value, since `data-id` does not support block bindings. // Else the `data-id` is used for backwards compatibility, since // third parties may be filtering its value. $data_id = $has_id_binding ? $attributes['id'] : $attributes['data-id']; $p->set_attribute( 'data-id', $data_id ); } $link_destination = isset( $attributes['linkDestination'] ) ? $attributes['linkDestination'] : 'none'; $lightbox_settings = block_core_image_get_lightbox_settings( $block->parsed_block ); /* * If the lightbox is enabled and the image is not linked, adds the filter and * the JavaScript view file. */ if ( isset( $lightbox_settings ) && 'none' === $link_destination && isset( $lightbox_settings['enabled'] ) && true === $lightbox_settings['enabled'] ) { wp_enqueue_script_module( '@wordpress/block-library/image/view' ); /* * This render needs to happen in a filter with priority 15 to ensure that * it runs after the duotone filter and that duotone styles are applied to * the image in the lightbox. Lightbox has to work with any plugins that * might use filters as well. Removing this can be considered in the future * if the way the blocks are rendered changes, or if a new kind of filter is * introduced. */ add_filter( 'render_block_core/image', 'block_core_image_render_lightbox', 15, 2 ); } else { /* * Remove the filter if previously added by other Image blocks. */ remove_filter( 'render_block_core/image', 'block_core_image_render_lightbox', 15 ); } return $p->get_updated_html(); } /** * Adds the lightboxEnabled flag to the block data. * * This is used to determine whether the lightbox should be rendered or not. * * @since 6.4.0 * * @param array $block Block data. * * @return array Filtered block data. */ function block_core_image_get_lightbox_settings( $block ) { // Gets the lightbox setting from the block attributes. if ( isset( $block['attrs']['lightbox'] ) ) { $lightbox_settings = $block['attrs']['lightbox']; } if ( ! isset( $lightbox_settings ) ) { $lightbox_settings = wp_get_global_settings( array( 'lightbox' ), array( 'block_name' => 'core/image' ) ); // If not present in global settings, check the top-level global settings. // // NOTE: If no block-level settings are found, the previous call to // `wp_get_global_settings` will return the whole `theme.json` structure in // which case we can check if the "lightbox" key is present at the top-level // of the global settings and use its value. if ( isset( $lightbox_settings['lightbox'] ) ) { $lightbox_settings = wp_get_global_settings( array( 'lightbox' ) ); } } return $lightbox_settings ?? null; } /** * Adds the directives and layout needed for the lightbox behavior. * * @since 6.4.0 * * @param string $block_content Rendered block content. * @param array $block Block object. * * @return string Filtered block content. */ function block_core_image_render_lightbox( $block_content, $block ) { /* * If there's no IMG tag in the block then return the given block content * as-is. There's nothing that this code can knowingly modify to add the * lightbox behavior. */ $p = new WP_HTML_Tag_Processor( $block_content ); if ( $p->next_tag( 'figure' ) ) { $p->set_bookmark( 'figure' ); } if ( ! $p->next_tag( 'img' ) ) { return $block_content; } $alt = $p->get_attribute( 'alt' ); $img_uploaded_src = $p->get_attribute( 'src' ); $img_class_names = $p->get_attribute( 'class' ); $img_styles = $p->get_attribute( 'style' ); $img_width = 'none'; $img_height = 'none'; $aria_label = __( 'Enlarge' ); $dialog_aria_label = __( 'Enlarged image' ); if ( isset( $block['attrs']['id'] ) ) { $img_uploaded_src = wp_get_attachment_url( $block['attrs']['id'] ); $img_metadata = wp_get_attachment_metadata( $block['attrs']['id'] ); $img_width = $img_metadata['width'] ?? 'none'; $img_height = $img_metadata['height'] ?? 'none'; } // Figure. $p->seek( 'figure' ); $figure_class_names = $p->get_attribute( 'class' ); $figure_styles = $p->get_attribute( 'style' ); // Create unique id and set the image metadata in the state. $unique_image_id = uniqid(); wp_interactivity_state( 'core/image', array( 'metadata' => array( $unique_image_id => array( 'uploadedSrc' => $img_uploaded_src, 'figureClassNames' => $figure_class_names, 'figureStyles' => $figure_styles, 'imgClassNames' => $img_class_names, 'imgStyles' => $img_styles, 'targetWidth' => $img_width, 'targetHeight' => $img_height, 'scaleAttr' => $block['attrs']['scale'] ?? false, 'ariaLabel' => $dialog_aria_label, 'alt' => $alt, ), ), ) ); $p->add_class( 'wp-lightbox-container' ); $p->set_attribute( 'data-wp-interactive', 'core/image' ); $p->set_attribute( 'data-wp-context', wp_json_encode( array( 'imageId' => $unique_image_id, ), JSON_HEX_TAG | JSON_HEX_APOS | JSON_HEX_QUOT | JSON_HEX_AMP ) ); // Image. $p->next_tag( 'img' ); $p->set_attribute( 'data-wp-init', 'callbacks.setButtonStyles' ); $p->set_attribute( 'data-wp-on-async--load', 'callbacks.setButtonStyles' ); $p->set_attribute( 'data-wp-on-async-window--resize', 'callbacks.setButtonStyles' ); // Sets an event callback on the `img` because the `figure` element can also // contain a caption, and we don't want to trigger the lightbox when the // caption is clicked. $p->set_attribute( 'data-wp-on-async--click', 'actions.showLightbox' ); $p->set_attribute( 'data-wp-class--hide', 'state.isContentHidden' ); $p->set_attribute( 'data-wp-class--show', 'state.isContentVisible' ); $body_content = $p->get_updated_html(); // Adds a button alongside image in the body content. $img = null; preg_match( '/<img[^>]+>/', $body_content, $img ); $button = $img[0] . '<button class="lightbox-trigger" type="button" aria-haspopup="dialog" aria-label="' . esc_attr( $aria_label ) . '" data-wp-init="callbacks.initTriggerButton" data-wp-on-async--click="actions.showLightbox" data-wp-style--right="state.imageButtonRight" data-wp-style--top="state.imageButtonTop" > <svg xmlns="http://www.w3.org/2000/svg" width="12" height="12" fill="none" viewBox="0 0 12 12"> <path fill="#fff" d="M2 0a2 2 0 0 0-2 2v2h1.5V2a.5.5 0 0 1 .5-.5h2V0H2Zm2 10.5H2a.5.5 0 0 1-.5-.5V8H0v2a2 2 0 0 0 2 2h2v-1.5ZM8 12v-1.5h2a.5.5 0 0 0 .5-.5V8H12v2a2 2 0 0 1-2 2H8Zm2-12a2 2 0 0 1 2 2v2h-1.5V2a.5.5 0 0 0-.5-.5H8V0h2Z" /> </svg> </button>'; $body_content = preg_replace( '/<img[^>]+>/', $button, $body_content ); add_action( 'wp_footer', 'block_core_image_print_lightbox_overlay' ); return $body_content; } /** * @since 6.5.0 */ function block_core_image_print_lightbox_overlay() { $close_button_label = esc_attr__( 'Close' ); // If the current theme does NOT have a `theme.json`, or the colors are not // defined, it needs to set the background color & close button color to some // default values because it can't get them from the Global Styles. $background_color = '#fff'; $close_button_color = '#000'; if ( wp_theme_has_theme_json() ) { $global_styles_color = wp_get_global_styles( array( 'color' ) ); if ( ! empty( $global_styles_color['background'] ) ) { $background_color = esc_attr( $global_styles_color['background'] ); } if ( ! empty( $global_styles_color['text'] ) ) { $close_button_color = esc_attr( $global_styles_color['text'] ); } } echo <<<HTML <div class="wp-lightbox-overlay zoom" data-wp-interactive="core/image" data-wp-context='{}' data-wp-bind--role="state.roleAttribute" data-wp-bind--aria-label="state.currentImage.ariaLabel" data-wp-bind--aria-modal="state.ariaModal" data-wp-class--active="state.overlayEnabled" data-wp-class--show-closing-animation="state.showClosingAnimation" data-wp-watch="callbacks.setOverlayFocus" data-wp-on--keydown="actions.handleKeydown" data-wp-on-async--touchstart="actions.handleTouchStart" data-wp-on--touchmove="actions.handleTouchMove" data-wp-on-async--touchend="actions.handleTouchEnd" data-wp-on-async--click="actions.hideLightbox" data-wp-on-async-window--resize="callbacks.setOverlayStyles" data-wp-on-async-window--scroll="actions.handleScroll" data-wp-bind--style="state.overlayStyles" tabindex="-1" > <button type="button" aria-label="$close_button_label" style="fill: $close_button_color" class="close-button"> <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" width="20" height="20" aria-hidden="true" focusable="false"><path d="m13.06 12 6.47-6.47-1.06-1.06L12 10.94 5.53 4.47 4.47 5.53 10.94 12l-6.47 6.47 1.06 1.06L12 13.06l6.47 6.47 1.06-1.06L13.06 12Z"></path></svg> </button> <div class="lightbox-image-container"> <figure data-wp-bind--class="state.currentImage.figureClassNames" data-wp-bind--style="state.figureStyles"> <img data-wp-bind--alt="state.currentImage.alt" data-wp-bind--class="state.currentImage.imgClassNames" data-wp-bind--style="state.imgStyles" data-wp-bind--src="state.currentImage.currentSrc"> </figure> </div> <div class="lightbox-image-container"> <figure data-wp-bind--class="state.currentImage.figureClassNames" data-wp-bind--style="state.figureStyles"> <img data-wp-bind--alt="state.currentImage.alt" data-wp-bind--class="state.currentImage.imgClassNames" data-wp-bind--style="state.imgStyles" data-wp-bind--src="state.enlargedSrc"> </figure> </div> <div class="scrim" style="background-color: $background_color" aria-hidden="true"></div> </div> HTML; } /** * Registers the `core/image` block on server. * * @since 5.9.0 */ function register_block_core_image() { register_block_type_from_metadata( __DIR__ . '/image', array( 'render_callback' => 'render_block_core_image', ) ); } add_action( 'init', 'register_block_core_image' );
Submit
FILE
FOLDER
INFO
Name
Size
Permission
Action
archives
---
0755
audio
---
0755
avatar
---
0755
block
---
0755
button
---
0755
buttons
---
0755
calendar
---
0755
categories
---
0755
code
---
0755
column
---
0755
columns
---
0755
comment-author-name
---
0755
comment-content
---
0755
comment-date
---
0755
comment-edit-link
---
0755
comment-reply-link
---
0755
comment-template
---
0755
comments
---
0755
comments-pagination
---
0755
comments-pagination-next
---
0755
comments-pagination-numbers
---
0755
comments-pagination-previous
---
0755
comments-title
---
0755
cover
---
0755
details
---
0755
embed
---
0755
file
---
0755
footnotes
---
0755
freeform
---
0755
gallery
---
0755
group
---
0755
heading
---
0755
home-link
---
0755
html
---
0755
image
---
0755
latest-comments
---
0755
latest-posts
---
0755
legacy-widget
---
0755
list
---
0755
list-item
---
0755
loginout
---
0755
media-text
---
0755
missing
---
0755
more
---
0755
navigation
---
0755
navigation-link
---
0755
navigation-submenu
---
0755
nextpage
---
0755
page-list
---
0755
page-list-item
---
0755
paragraph
---
0755
pattern
---
0755
post-author
---
0755
post-author-biography
---
0755
post-author-name
---
0755
post-comments-form
---
0755
post-content
---
0755
post-date
---
0755
post-excerpt
---
0755
post-featured-image
---
0755
post-navigation-link
---
0755
post-template
---
0755
post-terms
---
0755
post-title
---
0755
preformatted
---
0755
pullquote
---
0755
query
---
0755
query-no-results
---
0755
query-pagination
---
0755
query-pagination-next
---
0755
query-pagination-numbers
---
0755
query-pagination-previous
---
0755
query-title
---
0755
query-total
---
0755
quote
---
0755
read-more
---
0755
rss
---
0755
search
---
0755
separator
---
0755
shortcode
---
0755
site-logo
---
0755
site-tagline
---
0755
site-title
---
0755
social-link
---
0755
social-links
---
0755
spacer
---
0755
table
---
0755
tag-cloud
---
0755
template-part
---
0755
term-description
---
0755
text-columns
---
0755
verse
---
0755
video
---
0755
widget-group
---
0755
archives.php
2994 bytes
0644
avatar.php
5745 bytes
0644
block.php
3314 bytes
0644
blocks-json.php
193945 bytes
0644
button.php
1805 bytes
0644
calendar.php
6075 bytes
0644
categories.php
4010 bytes
0644
comment-author-name.php
2133 bytes
0644
comment-content.php
2459 bytes
0644
comment-date.php
1863 bytes
0644
comment-edit-link.php
1713 bytes
0644
comment-reply-link.php
2075 bytes
0644
comment-template.php
4494 bytes
0644
comments-pagination-next.php
1924 bytes
0644
comments-pagination-numbers.php
1632 bytes
0644
comments-pagination-previous.php
1790 bytes
0644
comments-pagination.php
1199 bytes
0644
comments-title.php
2772 bytes
0644
comments.php
6767 bytes
0644
cover.php
3175 bytes
0644
file.php
1793 bytes
0644
footnotes.php
3771 bytes
0644
gallery.php
6438 bytes
0644
heading.php
1301 bytes
0644
home-link.php
5438 bytes
0644
image.php
12023 bytes
0644
index.php
5111 bytes
0644
latest-comments.php
5040 bytes
0644
latest-posts.php
8542 bytes
0644
legacy-widget.php
3997 bytes
0644
list.php
1273 bytes
0644
loginout.php
1418 bytes
0644
media-text.php
4383 bytes
0644
navigation-link.php
13913 bytes
0644
navigation-submenu.php
9943 bytes
0644
navigation.php
49620 bytes
0644
page-list-item.php
361 bytes
0644
page-list.php
13611 bytes
0644
pattern.php
1788 bytes
0644
post-author-biography.php
1524 bytes
0644
post-author-name.php
1951 bytes
0644
post-author.php
2734 bytes
0644
post-comments-form.php
2805 bytes
0644
post-content.php
2156 bytes
0644
post-date.php
3124 bytes
0644
post-excerpt.php
3447 bytes
0644
post-featured-image.php
9363 bytes
0644
post-navigation-link.php
4837 bytes
0644
post-template.php
5749 bytes
0644
post-terms.php
3640 bytes
0644
post-title.php
2138 bytes
0644
query-no-results.php
1847 bytes
0644
query-pagination-next.php
3787 bytes
0644
query-pagination-numbers.php
4770 bytes
0644
query-pagination-previous.php
3584 bytes
0644
query-pagination.php
1176 bytes
0644
query-title.php
2098 bytes
0644
query-total.php
2535 bytes
0644
query.php
5690 bytes
0644
read-more.php
1830 bytes
0644
require-dynamic-blocks.php
4163 bytes
0644
require-static-blocks.php
501 bytes
0644
rss.php
4073 bytes
0644
search.php
23016 bytes
0644
shortcode.php
735 bytes
0644
site-logo.php
6334 bytes
0644
site-tagline.php
1203 bytes
0644
site-title.php
1853 bytes
0644
social-link.php
65174 bytes
0644
tag-cloud.php
1590 bytes
0644
template-part.php
10154 bytes
0644
term-description.php
1336 bytes
0644
widget-group.php
2438 bytes
0644
N4ST4R_ID | Naxtarrr