Diff: STRATO-apps/wordpress_03/app/wp-includes/blocks/video.php
Keine Baseline-Datei – Diff nur gegen leer.
1
-
1
+
<?php
2
+
/**
3
+
* Server-side rendering of the `core/video` block.
4
+
*
5
+
* @package WordPress
6
+
*/
7
+
8
+
/**
9
+
* Renders the `core/video` block on the server to supply the width and height attributes from the attachment metadata.
10
+
*
11
+
* @since 6.9.0
12
+
*
13
+
* @phpstan-param array{ "id"?: positive-int } $attributes
14
+
*
15
+
* @param array $attributes The block attributes.
16
+
* @param string $content The block content.
17
+
* @return string The block content with the dimensions added.
18
+
*/
19
+
function render_block_core_video( array $attributes, string $content ): string {
20
+
// if the content lacks any video tag, abort.
21
+
if ( ! str_contains( $content, '<video' ) ) {
22
+
return $content;
23
+
}
24
+
25
+
// If the 'id' attribute is not populated for a video attachment, abort.
26
+
if (
27
+
! isset( $attributes['id'] ) ||
28
+
! is_int( $attributes['id'] ) ||
29
+
$attributes['id'] <= 0
30
+
) {
31
+
return $content;
32
+
}
33
+
34
+
// If the 'id' attribute wasn't for an attachment, abort.
35
+
if ( get_post_type( $attributes['id'] ) !== 'attachment' ) {
36
+
return $content;
37
+
}
38
+
39
+
// Get the width and height metadata for the video, and abort if absent or invalid.
40
+
$metadata = wp_get_attachment_metadata( $attributes['id'] );
41
+
if (
42
+
! isset( $metadata['width'], $metadata['height'] ) ||
43
+
! ( is_int( $metadata['width'] ) && is_int( $metadata['height'] ) ) ||
44
+
! ( $metadata['width'] > 0 && $metadata['height'] > 0 )
45
+
) {
46
+
return $content;
47
+
}
48
+
49
+
// Locate the VIDEO tag to add the dimensions.
50
+
$p = new WP_HTML_Tag_Processor( $content );
51
+
if ( ! $p->next_tag( array( 'tag_name' => 'VIDEO' ) ) ) {
52
+
return $content;
53
+
}
54
+
55
+
$p->set_attribute( 'width', (string) $metadata['width'] );
56
+
$p->set_attribute( 'height', (string) $metadata['height'] );
57
+
58
+
/*
59
+
* The aspect-ratio style is needed due to an issue with the CSS spec: <https://github.com/w3c/csswg-drafts/issues/7524>.
60
+
* Note that a style rule using attr() like the following cannot currently be used:
61
+
*
62
+
* .wp-block-video video[width][height] {
63
+
* aspect-ratio: attr(width type(<number>)) / attr(height type(<number>));
64
+
* }
65
+
*
66
+
* This is because this attr() is yet only implemented in Chromium: <https://caniuse.com/css3-attr>.
67
+
*/
68
+
$style = $p->get_attribute( 'style' );
69
+
if ( ! is_string( $style ) ) {
70
+
$style = '';
71
+
}
72
+
$aspect_ratio_style = sprintf( 'aspect-ratio: %d / %d;', $metadata['width'], $metadata['height'] );
73
+
$p->set_attribute( 'style', $aspect_ratio_style . $style );
74
+
75
+
return $p->get_updated_html();
76
+
}
77
+
78
+
/**
79
+
* Registers the `core/video` block on server.
80
+
*
81
+
* @since 6.9.0
82
+
*/
83
+
function register_block_core_video(): void {
84
+
register_block_type_from_metadata(
85
+
__DIR__ . '/video',
86
+
array(
87
+
'render_callback' => 'render_block_core_video',
88
+
)
89
+
);
90
+
}
91
+
add_action( 'init', 'register_block_core_video' );
92
+