summaryrefslogtreecommitdiffstats
path: root/wp-includes/block-supports/shadow.php
diff options
context:
space:
mode:
authorDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 07:56:49 +0000
committerDaniel Baumann <daniel.baumann@progress-linux.org>2024-04-17 07:56:49 +0000
commita415c29efee45520ae252d2aa28f1083a521cd7b (patch)
treef4ade4b6668ecc0765de7e1424f7c1427ad433ff /wp-includes/block-supports/shadow.php
parentInitial commit. (diff)
downloadwordpress-a415c29efee45520ae252d2aa28f1083a521cd7b.tar.xz
wordpress-a415c29efee45520ae252d2aa28f1083a521cd7b.zip
Adding upstream version 6.4.3+dfsg1.upstream/6.4.3+dfsg1
Signed-off-by: Daniel Baumann <daniel.baumann@progress-linux.org>
Diffstat (limited to '')
-rw-r--r--wp-includes/block-supports/shadow.php82
1 files changed, 82 insertions, 0 deletions
diff --git a/wp-includes/block-supports/shadow.php b/wp-includes/block-supports/shadow.php
new file mode 100644
index 0000000..6fa05b2
--- /dev/null
+++ b/wp-includes/block-supports/shadow.php
@@ -0,0 +1,82 @@
+<?php
+/**
+ * Shadow block support flag.
+ *
+ * @package WordPress
+ * @since 6.3.0
+ */
+
+/**
+ * Registers the style and shadow block attributes for block types that support it.
+ *
+ * @since 6.3.0
+ * @access private
+ *
+ * @param WP_Block_Type $block_type Block Type.
+ */
+function wp_register_shadow_support( $block_type ) {
+ $has_shadow_support = block_has_support( $block_type, 'shadow', false );
+
+ if ( ! $has_shadow_support ) {
+ return;
+ }
+
+ if ( ! $block_type->attributes ) {
+ $block_type->attributes = array();
+ }
+
+ if ( array_key_exists( 'style', $block_type->attributes ) ) {
+ $block_type->attributes['style'] = array(
+ 'type' => 'object',
+ );
+ }
+
+ if ( array_key_exists( 'shadow', $block_type->attributes ) ) {
+ $block_type->attributes['shadow'] = array(
+ 'type' => 'string',
+ );
+ }
+}
+
+/**
+ * Add CSS classes and inline styles for shadow features to the incoming attributes array.
+ * This will be applied to the block markup in the front-end.
+ *
+ * @since 6.3.0
+ * @access private
+ *
+ * @param WP_Block_Type $block_type Block type.
+ * @param array $block_attributes Block attributes.
+ * @return array Shadow CSS classes and inline styles.
+ */
+function wp_apply_shadow_support( $block_type, $block_attributes ) {
+ $has_shadow_support = block_has_support( $block_type, 'shadow', false );
+
+ if ( ! $has_shadow_support ) {
+ return array();
+ }
+
+ $shadow_block_styles = array();
+
+ $preset_shadow = array_key_exists( 'shadow', $block_attributes ) ? "var:preset|shadow|{$block_attributes['shadow']}" : null;
+ $custom_shadow = isset( $block_attributes['style']['shadow'] ) ? $block_attributes['style']['shadow'] : null;
+ $shadow_block_styles['shadow'] = $preset_shadow ? $preset_shadow : $custom_shadow;
+
+ $attributes = array();
+ $styles = wp_style_engine_get_styles( $shadow_block_styles );
+
+ if ( ! empty( $styles['css'] ) ) {
+ $attributes['style'] = $styles['css'];
+ }
+
+ return $attributes;
+}
+
+// Register the block support.
+WP_Block_Supports::get_instance()->register(
+ 'shadow',
+ array(
+ 'register_attribute' => 'wp_register_shadow_support',
+ 'apply' => 'wp_apply_shadow_support',
+ )
+);