AlkantarClanX12
Current Path : /home/thanudqk/siamfreetour.com/wp-content/plugins/generateblocks/includes/ |
Current File : /home/thanudqk/siamfreetour.com/wp-content/plugins/generateblocks/includes/functions.php |
<?php /** * Functions used throughout the plugin. * * @package GenerateBlocks */ if ( ! defined( 'ABSPATH' ) ) { exit; // Exit if accessed directly. } /** * Retrive attributes from our blocks. * * @since 0.1 * @param array $content The content of our page. * @param array $data Data used to loop through the function as needed. * @param int $depth Keep track of how deep we are in nested blocks. * * @return array */ function generateblocks_get_block_data( $content, $data = array(), $depth = 0 ) { if ( ! is_array( $content ) || empty( $content ) ) { return; } foreach ( $content as $index => $block ) { if ( ! is_object( $block ) && is_array( $block ) && isset( $block['blockName'] ) ) { if ( 'generateblocks/grid' === $block['blockName'] ) { $data['grid'][] = $block['attrs']; $depth++; $data[ 'tempGridId-' . $depth ] = $block['attrs']['uniqueId']; } if ( 'generateblocks/container' === $block['blockName'] ) { if ( isset( $block['attrs']['isGrid'] ) && $block['attrs']['isGrid'] && isset( $data[ 'tempGridId-' . $depth ] ) ) { $block['attrs']['gridId'] = $data[ 'tempGridId-' . $depth ]; } $data['container'][] = $block['attrs']; } if ( 'generateblocks/headline' === $block['blockName'] ) { if ( isset( $block['innerHTML'] ) ) { if ( strpos( trim( $block['innerHTML'] ), '<div class="gb-headline-wrapper' ) === 0 ) { $block['attrs']['hasWrapper'] = true; } } $data['headline'][] = $block['attrs']; } if ( 'generateblocks/button-container' === $block['blockName'] ) { $data['button-container'][] = $block['attrs']; } if ( 'generateblocks/button' === $block['blockName'] ) { if ( ! isset( $block['attrs']['hasUrl'] ) && isset( $block['innerHTML'] ) ) { if ( strpos( trim( $block['innerHTML'] ), '<a' ) === 0 ) { $block['attrs']['hasUrl'] = true; } } $data['button'][] = $block['attrs']; } if ( 'generateblocks/image' === $block['blockName'] ) { $data['image'][] = $block['attrs']; } if ( 'core/block' === $block['blockName'] ) { if ( isset( $block['attrs'] ) && is_array( $block['attrs'] ) ) { $atts = $block['attrs']; if ( isset( $atts['ref'] ) && ( empty( $data['reusableBlockIds'] ) || ! in_array( $atts['ref'], (array) $data['reusableBlockIds'] ) ) ) { $reusable_block = get_post( $atts['ref'] ); if ( $reusable_block && 'wp_block' === $reusable_block->post_type && 'publish' === $reusable_block->post_status ) { $reuse_data_block = parse_blocks( $reusable_block->post_content ); if ( ! empty( $reuse_data_block ) ) { $data['reusableBlockIds'][] = $atts['ref']; $data = generateblocks_get_block_data( $reuse_data_block, $data ); } } } } } if ( isset( $block['innerBlocks'] ) && ! empty( $block['innerBlocks'] ) && is_array( $block['innerBlocks'] ) ) { $data = generateblocks_get_block_data( $block['innerBlocks'], $data, $depth ); } } } return $data; } /** * Parse our content for blocks. * * @param string $content Optional content to parse. * @since 1.1 */ function generateblocks_get_parsed_content( $content = '' ) { if ( ! function_exists( 'has_blocks' ) ) { return; } if ( ! $content && has_blocks( get_the_ID() ) ) { global $post; if ( ! is_object( $post ) ) { return; } $content = $post->post_content; } $content = apply_filters( 'generateblocks_do_content', $content ); if ( ! function_exists( 'parse_blocks' ) ) { return; } $content = parse_blocks( $content ); return $content; } /** * Shorthand CSS values (padding, margin, border etc..). * * @since 0.1 * * @param int $top The first value. * @param int $right The second value. * @param int $bottom The third value. * @param int $left The fourth value. * @param string $unit The unit we're adding. * * @return string The shorthand value. */ function generateblocks_get_shorthand_css( $top, $right, $bottom, $left, $unit ) { if ( '' === $top && '' === $right && '' === $bottom && '' === $left ) { return; } $values = [ $top, $right, $bottom, $left ]; foreach ( $values as $key => $value ) { if ( $value ) { if ( is_numeric( $value ) && $unit ) { $value = floatval( $value ) . $unit; } elseif ( '0px' === $value ) { $value = '0'; } } else { $value = '0'; } $values[ $key ] = $value; } // Right === Left. if ( $values[1] === $values[3] ) { unset( $values[3] ); // Top === Bottom. if ( $values[0] === $values[2] ) { unset( $values[2] ); // Top === Right. if ( $values[0] === $values[1] ) { unset( $values[1] ); } } } return implode( ' ', $values ); } /** * Returns a list of available media queries. */ function generateblocks_get_media_queries() { return apply_filters( 'generateblocks_media_query', array( 'desktop' => '(min-width: 1025px)', 'desktop_tablet' => '(min-width: 768px)', 'tablet_only' => '(max-width: 1024px) and (min-width: 768px)', 'tablet' => '(max-width: 1024px)', 'mobile' => '(max-width: 767px)', ) ); } /** * Get our media query. * * @since 0.1 * @param string $type The media query we're getting. * * @return string */ function generateblocks_get_media_query( $type ) { $queries = generateblocks_get_media_queries(); return $queries[ $type ]; } /** * Build our list of Google fonts on this page. * * @since 0.1 * @param string $content Optional content to parse. * @return array */ function generateblocks_get_google_fonts( $content = '' ) { $content = generateblocks_get_parsed_content( $content ); if ( ! $content ) { return; } $data = generateblocks_get_block_data( $content ); $defaults = generateblocks_get_block_defaults(); $font_data = array(); if ( ! empty( $data ) ) { foreach ( $data as $name => $blockData ) { if ( 'button' === $name ) { foreach ( $blockData as $atts ) { $button_settings = wp_parse_args( $atts, $defaults['button'] ); if ( $button_settings['googleFont'] ) { $id = $atts['uniqueId']; $variants = $button_settings['googleFontVariants']; if ( $variants ) { $variants = str_replace( ' ', '', $variants ); $variants = explode( ',', $variants ); } $font_data[ $id ] = array( 'name' => $button_settings['fontFamily'] ? $button_settings['fontFamily'] : generateblocks_get_array_attribute_value( 'fontFamily', $button_settings['typography'] ), 'variants' => $variants, ); } } } if ( 'headline' === $name ) { foreach ( $blockData as $atts ) { $headline_settings = wp_parse_args( $atts, $defaults['headline'] ); if ( $headline_settings['googleFont'] ) { $id = $atts['uniqueId']; $variants = $headline_settings['googleFontVariants']; if ( $variants ) { $variants = str_replace( ' ', '', $variants ); $variants = explode( ',', $variants ); } $font_data[ $id ] = array( 'name' => $headline_settings['fontFamily'] ? $headline_settings['fontFamily'] : generateblocks_get_array_attribute_value( 'fontFamily', $headline_settings['typography'] ), 'variants' => $variants, ); } } } if ( 'container' === $name ) { foreach ( $blockData as $atts ) { $container_settings = wp_parse_args( $atts, $defaults['container'] ); if ( $container_settings['googleFont'] ) { $id = $atts['uniqueId']; $variants = $container_settings['googleFontVariants']; if ( $variants ) { $variants = str_replace( ' ', '', $variants ); $variants = explode( ',', $variants ); } $font_data[ $id ] = array( 'name' => $container_settings['fontFamily'] ? $container_settings['fontFamily'] : generateblocks_get_array_attribute_value( 'fontFamily', $container_settings['typography'] ), 'variants' => $variants, ); } } } } } $fonts = array(); foreach ( (array) $font_data as $font ) { $id = str_replace( ' ', '', strtolower( $font['name'] ) ); $fonts[ $id ]['name'] = $font['name']; if ( ! empty( $font['variants'] ) ) { foreach ( $font['variants'] as $variant ) { if ( isset( $fonts[ $id ]['variants'] ) ) { if ( in_array( $variant, (array) $fonts[ $id ]['variants'] ) ) { continue; } } $fonts[ $id ]['variants'][] = $variant; } } } return apply_filters( 'generateblocks_google_fonts', $fonts ); } /** * Build the Google Font request URI. * * @since 0.1 * * @return string The request URI to Google Fonts. */ function generateblocks_get_google_fonts_uri() { $google_fonts = generateblocks_get_google_fonts(); if ( ! $google_fonts ) { return; } $data = array(); foreach ( $google_fonts as $font ) { $variants = array(); if ( ! empty( $font['variants'] ) ) { foreach ( $font['variants'] as $variant ) { $variants[] = $variant; } } $variants = apply_filters( 'generateblocks_google_font_variants', $variants, $font['name'] ); $name = str_replace( ' ', '+', $font['name'] ); if ( $variants ) { $data[] = $name . ':' . implode( ',', $variants ); } else { $data[] = $name; } } $font_args = apply_filters( 'generateblocks_google_font_args', array( 'family' => implode( '|', $data ), 'subset' => null, 'display' => 'swap', ) ); return add_query_arg( $font_args, 'https://fonts.googleapis.com/css' ); } /** * Convert hex to RGBA * * @since 0.1 * @param string $hex The hex value. * @param int $alpha The opacity value. * * @return string The RGBA value. */ function generateblocks_hex2rgba( $hex, $alpha ) { if ( ! $hex ) { return; } if ( 1 === $alpha || ! is_numeric( $alpha ) ) { return $hex; } // Make sure we're dealing with a hex value. if ( isset( $hex[0] ) && '#' !== $hex[0] ) { return $hex; } $hex = str_replace( '#', '', $hex ); if ( strlen( $hex ) == 3 ) { // phpcs:ignore WordPress.PHP.StrictComparisons.LooseComparison $r = hexdec( substr( $hex, 0, 1 ) . substr( $hex, 0, 1 ) ); $g = hexdec( substr( $hex, 1, 1 ) . substr( $hex, 1, 1 ) ); $b = hexdec( substr( $hex, 2, 1 ) . substr( $hex, 2, 1 ) ); } else { $r = hexdec( substr( $hex, 0, 2 ) ); $g = hexdec( substr( $hex, 2, 2 ) ); $b = hexdec( substr( $hex, 4, 2 ) ); } $rgba = 'rgba(' . $r . ', ' . $g . ', ' . $b . ', ' . $alpha . ')'; return $rgba; } /** * Return old flexblocks values for old browsers. * * @since 0.1 * @param string $value The value to convert. * * @return string The old browser value. */ function generateblocks_get_vendor_prefix( $value ) { if ( 'flex-start' === $value || 'left' === $value ) { return 'start'; } if ( 'flex-end' === $value || 'right' === $value ) { return 'end'; } return $value; } /** * Return flexbox alignment values from left/right. * * @since 0.1 * @param string $value The value to convert. * * @return string The flexbox alignment value. */ function generateblocks_get_flexbox_alignment( $value ) { if ( 'left' === $value || 'top' === $value ) { return 'flex-start'; } if ( 'right' === $value || 'bottom' === $value ) { return 'flex-end'; } return $value; } /** * Return float alignment values. * * @since 1.5.0 * @param string $value The value to convert. * * @return string The float alignment value. */ function generateblocks_get_float_alignment( $value ) { $floats = [ 'floatLeft' => 'left', 'floatRight' => 'right', 'floatNone' => 'none', ]; return isset( $floats[ $value ] ) ? $floats[ $value ] : $value; } /** * Get an option from the database. * * @param string $option The option to get. * @since 0.1 */ function generateblocks_get_option( $option ) { $defaults = generateblocks_get_option_defaults(); if ( ! isset( $defaults[ $option ] ) ) { return; } $options = wp_parse_args( get_option( 'generateblocks', array() ), $defaults ); return $options[ $option ]; } /** * Checks whether a value exists, even if it's a 0. * * @param int|string $value The value to check. * @since 1.0 */ function generateblocks_has_number_value( $value ) { if ( $value || 0 === $value || '0' === $value ) { return true; } return false; } /** * Check if we have a Container background image to display. * * @since 1.5.0 * @param array $settings The block settings. */ function generateblocks_has_background_image( $settings ) { return $settings['bgImage'] || ( $settings['useDynamicData'] && '' !== $settings['dynamicContentType'] ); } /** * Get our background image URL. * * @since 1.5.0 * @param array $settings Block settings. */ function generateblocks_get_background_image_url( $settings ) { $url = ''; if ( isset( $settings['bgImage']['id'] ) ) { $image_src = wp_get_attachment_image_src( $settings['bgImage']['id'], $settings['bgImageSize'] ); if ( is_array( $image_src ) ) { $url = $image_src[0]; } else { $url = $settings['bgImage']['image']['url']; } } elseif ( isset( $settings['bgImage']['image']['url'] ) ) { $url = $settings['bgImage']['image']['url']; } return apply_filters( 'generateblocks_background_image_url', $url, $settings ); } /** * Get the background-image value for our Container block. * * @param string $type Gradient or background image. * @param array $settings Our background image settings. */ function generateblocks_get_background_image_css( $type, $settings ) { $gradient = ''; if ( $settings['gradient'] ) { $gradientColorStopOneValue = ''; $gradientColorStopTwoValue = ''; $gradientColorOneValue = generateblocks_hex2rgba( $settings['gradientColorOne'], $settings['gradientColorOneOpacity'] ); $gradientColorTwoValue = generateblocks_hex2rgba( $settings['gradientColorTwo'], $settings['gradientColorTwoOpacity'] ); if ( $settings['gradientColorOne'] && '' !== $settings['gradientColorStopOne'] ) { $gradientColorStopOneValue = ' ' . $settings['gradientColorStopOne'] . '%'; } if ( $settings['gradientColorTwo'] && '' !== $settings['gradientColorStopTwo'] ) { $gradientColorStopTwoValue = ' ' . $settings['gradientColorStopTwo'] . '%'; } $gradient = 'linear-gradient(' . $settings['gradientDirection'] . 'deg, ' . $gradientColorOneValue . $gradientColorStopOneValue . ', ' . $gradientColorTwoValue . $gradientColorStopTwoValue . ')'; } if ( 'gradient' === $type ) { return $gradient; } $backgroundImage = ''; if ( generateblocks_has_background_image( $settings ) ) { $url = generateblocks_get_background_image_url( $settings ); // Old background image overlays mixed with our gradients. if ( 'element' === $settings['bgOptions']['selector'] && ( $settings['backgroundColor'] || $settings['gradient'] ) && isset( $settings['bgOptions']['overlay'] ) && $settings['bgOptions']['overlay'] ) { if ( $settings['gradient'] ) { $backgroundImage = $gradient . ', url(' . esc_url( $url ) . ')'; } elseif ( $settings['backgroundColor'] ) { $settings['backgroundColor'] = generateblocks_hex2rgba( $settings['backgroundColor'], $settings['backgroundColorOpacity'] ); $backgroundImage = 'linear-gradient(0deg, ' . $settings['backgroundColor'] . ', ' . $settings['backgroundColor'] . '), url(' . esc_url( $url ) . ')'; } } else { $backgroundImage = 'url(' . esc_url( $url ) . ')'; if ( $settings['bgImageInline'] && 'element' !== $settings['bgOptions']['selector'] ) { $backgroundImage = 'var(--background-image)'; } } } return $backgroundImage; } /** * Build list of attributes into a string and apply contextual filter on string. * * The contextual filter is of the form `generateblocks_attr_{context}_output`. * * @since 1.2.0 * * @param string $context The context, to build filter name. * @param array $attributes Optional. Extra attributes to merge with defaults. * @param array $settings Optional. Custom data to pass to filter. * @param WP_Block $block Block instance. * @return string String of HTML attributes and values. */ function generateblocks_attr( $context, $attributes = array(), $settings = array(), $block = null ) { $attributes = generateblocks_parse_attr( $context, $attributes, $settings, $block ); $output = ''; // Cycle through attributes, build tag attribute string. foreach ( $attributes as $key => $value ) { if ( ! $value && '0' !== $value ) { continue; } if ( true === $value ) { $output .= esc_html( $key ) . ' '; } else { $output .= sprintf( '%s="%s" ', esc_html( $key ), esc_attr( $value ) ); } } $output = apply_filters( "generateblocks_attr_{$context}_output", $output, $attributes, $settings, $context, $block ); return trim( $output ); } /** * Merge array of attributes with defaults, and apply contextual filter on array. * * The contextual filter is of the form `generateblocks_attr_{context}`. * * @since 1.2.0 * * @param string $context The context, to build filter name. * @param array $attributes Optional. Extra attributes to merge with defaults. * @param array $settings Optional. Custom data to pass to filter. * @param WP_Block $block Block instance. * @return array Merged and filtered attributes. */ function generateblocks_parse_attr( $context, $attributes = array(), $settings = array(), $block = null ) { $defaults = array( 'class' => sanitize_html_class( $context ), ); $attributes = wp_parse_args( $attributes, $defaults ); // Contextual filter. return apply_filters( "generateblocks_attr_{$context}", $attributes, $settings, $context, $block ); } /** * Generate our SVG shape dividers. * * @since 1.2.0 */ function generateblocks_get_svg_shapes() { return apply_filters( 'generateblocks_svg_shapes', array( 'gb-waves' => array( 'group' => esc_attr__( 'Waves', 'generateblocks' ), 'svgs' => array( 'gb-waves-1' => array( /* translators: Shape number */ 'label' => sprintf( __( 'Wave %s', 'generateblocks' ), '1' ), 'icon' => '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 194.3" preserveAspectRatio="none"><path d="M1200 133.3l-50 8.9c-50 8.6-150 26.9-250 31.1-100 4.2-200-4.2-300-26.7S400 89.2 300 62.2C200 35.8 100 17.5 50 8.9L0 0v194.3h1200v-61z"/></svg>', ), 'gb-waves-2' => array( /* translators: Shape number */ 'label' => sprintf( __( 'Wave %s', 'generateblocks' ), '2' ), 'icon' => '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 137.6" preserveAspectRatio="none"><path d="M0 137.6h1200V21.9l-66.7 26.7c-66.7 26.7-200 80-333.3 66.7S533.3 21.9 400 4.2C266.7-13.9 133.3 31.1 66.7 53L0 75.3v62.3z"/></svg>', ), 'gb-waves-3' => array( /* translators: Shape number */ 'label' => sprintf( __( 'Wave %s', 'generateblocks' ), '3' ), 'icon' => '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 96.2" preserveAspectRatio="none"><path d="M0 96.2h1200V72.9l-50-8.9c-50-8.6-150-26.9-250-22.2C800 46.2 700 72.9 600 64 500 55.4 400 10.4 300 1.8 200-7.1 100 19.5 50 32.9L0 46.2v50z"/></svg>', ), 'gb-waves-4' => array( /* translators: Shape number */ 'label' => sprintf( __( 'Wave %s', 'generateblocks' ), '4' ), 'icon' => '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 130.3" preserveAspectRatio="none"><path d="M0 107.9l40-22.2c40-21.9 120-66.9 200-62.2 80 4.4 160 57.8 240 53.3C560 72 640 10.4 720 1.2S880 37 960 59c80 22.3 160 22.3 200 22.3h40v49H0v-22.4z"/></svg>', ), 'gb-waves-5' => array( /* translators: Shape number */ 'label' => sprintf( __( 'Wave %s', 'generateblocks' ), '5' ), 'icon' => '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 218" preserveAspectRatio="none"><path d="M0 218h1200v-31.3l-40 4.4c-40 4.8-120 13.1-200 0-80-13.6-160-48.6-240-66.7-80-17.8-160-17.8-240-8.8-80 8.6-160 26.9-240 8.8-80-17.7-160-71.1-200-97.7L0 0v218z"/></svg>', ), 'gb-waves-6' => array( /* translators: Shape number */ 'label' => sprintf( __( 'Wave %s', 'generateblocks' ), '6' ), 'icon' => '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 234" preserveAspectRatio="none"><path d="M0 0l40 40c40 40 120 120 200 115.6 80-4.8 160-93.1 240-111.2C560 26.7 640 80 720 88.9c80 8.6 160-26.4 240-13.3 80 13.6 160 75.2 200 106.7l40 31.1V234H0V0z"/></svg>', ), 'gb-waves-7' => array( /* translators: Shape number */ 'label' => sprintf( __( 'Wave %s', 'generateblocks' ), '7' ), 'icon' => '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 217.3" preserveAspectRatio="none"><path d="M1200 195.6l-25-22.2c-25-21.9-75-66.9-125-75.5-50-8.9-100 17.8-150 26.7-50 8.6-100 .2-150-13.3-50-13.1-100-31.4-150-26.7-50 4.4-100 31.1-150 26.7-50-4.8-100-39.8-150-66.7C250 18.1 200-.2 150 0 100-.2 50 18.1 25 26.7L0 35.6v181.7h1200v-21.7z"/></svg>', ), 'gb-waves-8' => array( /* translators: Shape number */ 'label' => sprintf( __( 'Wave %s', 'generateblocks' ), '8' ), 'icon' => '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 230.8" preserveAspectRatio="none"><path d="M1200 179.5l-22.2-26.7c-22.2-26.7-66.9-80-111.1-75.6-44.4 4.8-89.2 66.4-133.3 102.2-44.4 35.8-89.2 44.2-133.3 8.9-44.4-35.6-89.2-115.6-133.3-155.6-44.4-40-89.2-40-133.3-17.8C488.9 37 444.2 82 400 81.7c-44.4.2-89.2-44.8-133.3-57.8-44.4-13.6-89.2 4.8-133.3 26.7-44.5 22.2-89.2 48.9-110.9 62.2L0 126.1v104.7H1199.7l.3-51.3z"/></svg>', ), ), ), 'gb-angles' => array( 'group' => esc_attr__( 'Angles', 'generateblocks' ), 'svgs' => array( 'gb-angle-1' => array( /* translators: Shape number */ 'label' => sprintf( __( 'Angle %s', 'generateblocks' ), '1' ), 'icon' => '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 360" preserveAspectRatio="none"><path d="M1200 360H0V0l1200 348z"/></svg>', ), ), ), 'gb-curves' => array( 'group' => esc_attr__( 'Curves', 'generateblocks' ), 'svgs' => array( 'gb-curve-1' => array( /* translators: Shape number */ 'label' => sprintf( __( 'Curve %s', 'generateblocks' ), '1' ), 'icon' => '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 350" preserveAspectRatio="none"><path d="M1200 336.7V350H0V0s22.4 276.4 1200 336.7z"/></svg>', ), 'gb-curve-2' => array( /* translators: Shape number */ 'label' => sprintf( __( 'Curve %s', 'generateblocks' ), '2' ), 'icon' => '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 350" preserveAspectRatio="none"><path d="M1200 350V0C22.4 60.3 0 336.7 0 336.7V350h1200z"/></svg>', ), 'gb-curve-3' => array( /* translators: Shape number */ 'label' => sprintf( __( 'Curve %s', 'generateblocks' ), '3' ), 'icon' => '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 211.2" preserveAspectRatio="none"><path d="M600 188.4C321.1 188.4 84.3 109.5 0 0v211.2h1200V0c-84.3 109.5-321.1 188.4-600 188.4z"/></svg>', ), 'gb-curve-4' => array( /* translators: Shape number */ 'label' => sprintf( __( 'Curve %s', 'generateblocks' ), '4' ), 'icon' => '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 211.2" preserveAspectRatio="none"><path d="M1200 188.4v22.8H0v-22.8C84.3 78.9 321.1 0 600 0s515.7 78.9 600 188.4z"/></svg>', ), ), ), 'gb-triangles' => array( 'group' => esc_attr__( 'Triangles', 'generateblocks' ), 'svgs' => array( 'gb-triangle-1' => array( /* translators: Shape number */ 'label' => sprintf( __( 'Triangle %s', 'generateblocks' ), '1' ), 'icon' => '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 100" preserveAspectRatio="none"><path d="M1200 100H0V0l400 77.2L1200 0z"/></svg>', ), 'gb-triangle-2' => array( /* translators: Shape number */ 'label' => sprintf( __( 'Triangle %s', 'generateblocks' ), '2' ), 'icon' => '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 100" preserveAspectRatio="none"><path d="M1200 77.2L400 0 0 77.2V100h1200z"/></svg>', ), 'gb-triangle-3' => array( /* translators: Shape number */ 'label' => sprintf( __( 'Triangle %s', 'generateblocks' ), '3' ), 'icon' => '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 70" preserveAspectRatio="none"><path d="M1200 0v70H0V0h530l70 50 70-50z"/></svg>', ), 'gb-triangle-4' => array( /* translators: Shape number */ 'label' => sprintf( __( 'Triangle %s', 'generateblocks' ), '4' ), 'icon' => '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 70" preserveAspectRatio="none"><path d="M670 50L600 0l-70 50H0v20h1200V50z"/></svg>', ), 'gb-triangle-5' => array( /* translators: Shape number */ 'label' => sprintf( __( 'Triangle %s', 'generateblocks' ), '5' ), 'icon' => '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 50" preserveAspectRatio="none"><path d="M1200 0v50H0V0h560l40 30 40-30z"/></svg>', ), 'gb-triangle-6' => array( /* translators: Shape number */ 'label' => sprintf( __( 'Triangle %s', 'generateblocks' ), '6' ), 'icon' => '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 50" preserveAspectRatio="none"><path d="M640 30L600 0l-40 30H0v20h1200V30z"/></svg>', ), 'gb-triangle-7' => array( /* translators: Shape number */ 'label' => sprintf( __( 'Triangle %s', 'generateblocks' ), '7' ), 'icon' => '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 230" preserveAspectRatio="none"><path d="M1200 230H0V0l600 207.2L1200 0z"/></svg>', ), 'gb-triangle-8' => array( /* translators: Shape number */ 'label' => sprintf( __( 'Triangle %s', 'generateblocks' ), '8' ), 'icon' => '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 230" preserveAspectRatio="none"><path d="M1200 207.2L600 0 0 207.2V230h1200z"/></svg>', ), 'gb-triangle-9' => array( /* translators: Shape number */ 'label' => sprintf( __( 'Triangle %s', 'generateblocks' ), '9' ), 'icon' => '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 131" preserveAspectRatio="none"><path d="M1200 131H0V40l154.8 50L410 35l277 69L899 0l301 110z"/></svg>', ), 'gb-triangle-10' => array( /* translators: Shape number */ 'label' => sprintf( __( 'Triangle %s', 'generateblocks' ), '10' ), 'icon' => '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 131" preserveAspectRatio="none"><path d="M1200 0L899 110 687 6 410 75 154.8 20 0 70v61h1200z"/></svg>', ), 'gb-triangle-11' => array( /* translators: Shape number */ 'label' => sprintf( __( 'Triangle %s', 'generateblocks' ), '11' ), 'icon' => '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 176" preserveAspectRatio="none"><path d="M0 0l400 156 400-88 400 74v34H0z"/></svg>', ), 'gb-triangle-12' => array( /* translators: Shape number */ 'label' => sprintf( __( 'Triangle %s', 'generateblocks' ), '12' ), 'icon' => '<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1200 176" preserveAspectRatio="none"><path d="M0 176h1200V14L800 88 400 0 0 156z"/></svg>', ), ), ), ) ); } /** * Search an array to check if a key has a value. * * @since 1.5.0 * @param string $setting The setting to check. * @param array $data The array to search. */ function generateblocks_block_has_value( $setting, $data ) { foreach ( (array) $data as $key => $val ) { if ( isset( $val[ $setting ] ) && ( $val[ $setting ] || 0 === $val[ $setting ] ) ) { return true; } } return null; } /** * Given an array it will change keys based on the map. * * @param array $arr The array to check. * @param array $keyMap The array to map. * * @return array|false * * @since 1.5.0 */ function generateblocks_map_array_keys( $arr = array(), $keyMap = array() ) { return array_combine( array_map( function( $key ) use ( $keyMap ) { return isset( $keyMap[ $key ] ) ? $keyMap[ $key ] : $key; }, array_keys( $arr ) ), array_values( $arr ) ); } /** * Checks if the date is correctly formatted * * @param string $date The date to validate. * @param string $format The allowed format. * * @return bool */ function generateblocks_is_valid_date( $date, $format = 'Y-m-d\TH:i:s' ) { $dateTime = DateTime::createFromFormat( $format, $date ); return ( $dateTime && $dateTime->format( $format ) === $date ); } /** * Modifies the markup of images in provided content. * * @param string $content The content to modify. * @param array $attributes The block attributes. * * @since 1.5.0 */ function generateblocks_filter_images( $content, $attributes ) { // Bail early if not using WP 5.5. if ( ! function_exists( 'wp_img_tag_add_width_and_height_attr' ) ) { return $content; } if ( ! empty( $attributes['mediaId'] ) ) { // Add 'width' and 'height' attributes if applicable. if ( false === strpos( $content, ' width=' ) && false === strpos( $content, ' height=' ) ) { $content = wp_img_tag_add_width_and_height_attr( $content, '', $attributes['mediaId'] ); } // Add 'srcset' and 'sizes' attributes if applicable. if ( false === strpos( $content, ' srcset=' ) ) { $content = wp_img_tag_add_srcset_and_sizes_attr( $content, '', $attributes['mediaId'] ); } } // Add 'loading' attribute if applicable. if ( wp_lazy_loading_enabled( 'img', '' ) && false === strpos( $content, ' loading=' ) ) { $content = function_exists( 'wp_img_tag_add_loading_optimization_attrs' ) ? wp_img_tag_add_loading_optimization_attrs( $content, '' ) : wp_img_tag_add_loading_attr( $content, '' ); } return $content; } /** * Compile our CSS based on our CSS data. * * @since 1.6.0 * @param array $manual_data CSS data input directly to the function. */ function generateblocks_get_compiled_css( $manual_data = [] ) { $data = apply_filters( 'generateblocks_css_data', [] ); // Allows us to input manual data if necessary. if ( count( (array) $manual_data ) > 0 ) { $data = $manual_data; } $css = ''; if ( ! empty( $data['main'] ) ) { $css .= $data['main']; } if ( ! empty( $data['desktop'] ) ) { $css .= sprintf( '@media %1$s {%2$s}', generateblocks_get_media_query( 'desktop' ), $data['desktop'] ); } if ( ! empty( $data['tablet'] ) ) { $css .= sprintf( '@media %1$s {%2$s}', generateblocks_get_media_query( 'tablet' ), $data['tablet'] ); } if ( ! empty( $data['tablet_only'] ) ) { $css .= sprintf( '@media %1$s {%2$s}', generateblocks_get_media_query( 'tablet_only' ), $data['tablet_only'] ); } if ( ! empty( $data['mobile'] ) ) { $css .= sprintf( '@media %1$s {%2$s}', generateblocks_get_media_query( 'mobile' ), $data['mobile'] ); } return $css; } /** * This is a helper function that groups our static CSS into device-specific groups. * * @param array $existing_data An array of existing data to add to. * @param array $new_data The new data we wish to group. * * @since 1.6.0 */ function generateblocks_group_css_data( $existing_data = [], $new_data = [] ) { $existing_data = wp_parse_args( $existing_data, [ 'main' => '', 'desktop' => '', 'tablet' => '', 'tablet_only' => '', 'mobile' => '', ] ); $existing_data['main'] .= generateblocks_get_parsed_css( $new_data['main'] ); $existing_data['desktop'] .= generateblocks_get_parsed_css( $new_data['desktop'] ); $existing_data['tablet'] .= generateblocks_get_parsed_css( $new_data['tablet'] ); $existing_data['tablet_only'] .= generateblocks_get_parsed_css( $new_data['tablet_only'] ); $existing_data['mobile'] .= generateblocks_get_parsed_css( $new_data['mobile'] ); return $existing_data; } /** * Turn our CSS array into plain CSS. * * @since 1.0 * @param array $data Our CSS data. */ function generateblocks_get_parsed_css( $data ) { $output = ''; foreach ( $data as $selector => $properties ) { if ( ! count( $properties ) ) { continue; } $temporary_output = $selector . '{'; $elements_added = 0; foreach ( $properties as $key => $value ) { if ( empty( $value ) ) { continue; } $elements_added++; $temporary_output .= $value; } $temporary_output .= '}'; if ( $elements_added > 0 ) { $output .= $temporary_output; } } return $output; } /** * Build the CSS from our block attributes. * * @since 0.1 * @param string $content The content we're looking through. * @param string $store_block_id_only Store the found block IDs instead of adding CSS. * * @return string The dynamic CSS. */ function generateblocks_get_dynamic_css( $content = '', $store_block_id_only = false ) { if ( ! $content ) { $content = generateblocks_get_parsed_content(); } $data = generateblocks_get_block_data( $content ); if ( empty( $data ) ) { return; } $blocks = [ 'grid' => 'GenerateBlocks_Block_Grid', 'container' => 'GenerateBlocks_Block_Container', 'button-container' => 'GenerateBlocks_Block_Button_Container', 'button' => 'GenerateBlocks_Block_Button', 'headline' => 'GenerateBlocks_Block_Headline', 'image' => 'GenerateBlocks_Block_Image', ]; foreach ( $data as $name => $blockData ) { if ( isset( $blocks[ $name ] ) ) { if ( empty( $blockData ) ) { continue; } foreach ( $blockData as $atts ) { if ( ! isset( $atts['uniqueId'] ) ) { continue; } if ( is_callable( [ $blocks[ $name ], 'get_css_data' ] ) ) { if ( $store_block_id_only ) { $blocks[ $name ]::store_block_id( $atts['uniqueId'] ); } elseif ( ! $blocks[ $name ]::block_id_exists( $atts['uniqueId'] ) ) { generateblocks_add_to_css_data( $blocks[ $name ]::get_css_data( $atts ) ); } } } } } } /** * Print our CSS for each block. * * @since 0.1 */ function generateblocks_get_frontend_block_css() { return apply_filters( 'generateblocks_css_output', generateblocks_get_compiled_css() ); } /** * Add block CSS to our pool of generated CSS. * * @since 1.6.0 * @param array $data Our CSS data. */ function generateblocks_add_to_css_data( $data ) { add_filter( 'generateblocks_css_data', function( $css_data ) use ( $data ) { return generateblocks_group_css_data( $css_data, $data ); } ); } /** * Maybe add block CSS if it hasn't already been added for this block. * * @since 1.6.0 * @param string $content Our block content. * @param array $data Block data. */ function generateblocks_maybe_add_block_css( $content = '', $data = [] ) { $inline_style_override = apply_filters( 'generateblocks_do_inline_styles', false, [ 'content' => $content, 'data' => $data, ] ); if ( isset( $data['attributes']['uniqueId'] ) && ( ! in_array( $data['attributes']['uniqueId'], $data['block_ids'] ) || $inline_style_override ) ) { // Don't try to print CSS for the Query Loop block. if ( isset( $data['attributes']['query'] ) ) { return $content; } if ( ! GenerateBlocks_Enqueue_CSS::can_enqueue() && ! $inline_style_override ) { return $content; } $css_data = is_callable( [ $data['class_name'], 'get_css_data' ] ) ? $data['class_name']::get_css_data( $data['attributes'] ) : false; if ( ! $css_data ) { return $content; } if ( did_action( 'wp_head' ) || $inline_style_override ) { // Add inline <style> elements if we don't have access to wp_head. $grouped_css = generateblocks_group_css_data( [], $css_data ); $compiled_css = generateblocks_get_compiled_css( $grouped_css ); if ( $compiled_css ) { $content = sprintf( '<style>%s</style>', $compiled_css ) . $content; } } else { // Add our CSS to the pool of existing CSS in wp_head. generateblocks_add_to_css_data( $css_data ); } } return $content; } /** * Get our default Container block width. * * @since 1.7.0 */ function generateblocks_get_global_container_width() { return apply_filters( 'generateblocks_global_container_width', function_exists( 'generate_get_option' ) ? generate_get_option( 'container_width' ) . 'px' : generateblocks_get_option( 'container_width' ) . 'px' ); } /** * Add our Layout component CSS. * * @param object $css The CSS object to add to. * @param array $settings Block settings. * @param string $device The device we're adding to. */ function generateblocks_add_layout_css( $css, $settings, $device = '' ) { if ( ! empty( $settings['useInnerContainer'] ) ) { return; } $options = [ 'display' => 'display', 'flex-direction' => 'flexDirection', 'flex-wrap' => 'flexWrap', 'align-items' => 'alignItems', 'justify-content' => 'justifyContent', 'column-gap' => 'columnGap', 'row-gap' => 'rowGap', 'z-index' => 'zindex', 'position' => 'position', 'overflow-x' => 'overflowX', 'overflow-y' => 'overflowY', ]; foreach ( $options as $property => $option ) { $value = isset( $settings[ $option . $device ] ) ? $settings[ $option . $device ] : ''; $css->add_property( $property, $value ); } } /** * Add our Sizing component CSS. * * @param object $css The CSS object to add to. * @param array $settings Block settings. * @param string $device The device we're adding to. */ function generateblocks_add_sizing_css( $css, $settings, $device = '' ) { $options = [ 'width' => 'width', 'height' => 'height', 'min-width' => 'minWidth', 'min-height' => 'minHeight', 'max-width' => 'maxWidth', 'max-height' => 'maxHeight', ]; if ( ! empty( $settings['useInnerContainer'] ) ) { unset( $options['max-width'] ); } if ( ! empty( $settings['isGrid'] ) ) { unset( $options['width'] ); unset( $options['min-width'] ); unset( $options['max-width'] ); } foreach ( $options as $property => $option ) { $option_name = $option . $device; $value = generateblocks_get_array_attribute_value( $option_name, $settings['sizing'] ); if ( 'max-width' === $property && ! empty( $settings['useGlobalMaxWidth'] ) && ! $device ) { $value = generateblocks_get_global_container_width(); } $css->add_property( $property, $value ); } } /** * Add our Flex Child component CSS. * * @param object $css The CSS object to add to. * @param array $settings Block settings. * @param string $device The device we're adding to. */ function generateblocks_add_flex_child_css( $css, $settings, $device = '' ) { if ( ! empty( $settings['isGrid'] ) ) { return; } $options = [ 'flex-grow' => 'flexGrow', 'flex-shrink' => 'flexShrink', 'flex-basis' => 'flexBasis', 'order' => 'order', ]; foreach ( $options as $property => $option ) { $value = isset( $settings[ $option . $device ] ) ? $settings[ $option . $device ] : ''; $css->add_property( $property, $value ); } } /** * Add our Typography component CSS. * * @param object $css The CSS object to add to. * @param array $settings Block settings. * @param string $device The device we're adding to. */ function generateblocks_add_typography_css( $css, $settings, $device = '' ) { $options = [ 'font-family' => 'fontFamily', 'font-size' => 'fontSize', 'line-height' => 'lineHeight', 'letter-spacing' => 'letterSpacing', 'font-weight' => 'fontWeight', 'text-transform' => 'textTransform', 'text-align' => 'textAlign', ]; foreach ( $options as $property => $option ) { $option_name = $option . $device; $value = generateblocks_get_array_attribute_value( $option_name, $settings['typography'] ); if ( 'fontFamily' === $option && $value && $settings['fontFamilyFallback'] ) { $value .= ', ' . $settings['fontFamilyFallback']; } $css->add_property( $property, $value ); } } /** * Add our Spacing component CSS. * * @param object $css The CSS object to add to. * @param array $settings Block settings. * @param string $device The device we're adding to. */ function generateblocks_add_spacing_css( $css, $settings, $device = '' ) { $padding_values = array_map( function( $attribute ) use ( $device, $settings ) { if ( isset( $settings['useInnerContainer'] ) && $settings['useInnerContainer'] ) { return false; } return generateblocks_get_array_attribute_value( $attribute . $device, $settings['spacing'] ); }, [ 'paddingTop', 'paddingRight', 'paddingBottom', 'paddingLeft', ] ); $css->add_property( 'padding', $padding_values ); $margin_values = array_map( function( $attribute ) use ( $device, $settings ) { return generateblocks_get_array_attribute_value( $attribute . $device, $settings['spacing'] ); }, [ 'marginTop', 'marginRight', 'marginBottom', 'marginLeft', ] ); $css->add_property( 'margin', $margin_values ); } /** * Add our Borders component CSS. * * @param object $css The CSS object to add to. * @param array $settings Block settings. * @param string $device The device we're adding to. */ function generateblocks_add_border_css( $css, $settings, $device = '' ) { $border_radius_values = array_map( function( $attribute ) use ( $device, $settings ) { return generateblocks_get_array_attribute_value( $attribute . $device, $settings['borders'] ); }, [ 'borderTopLeftRadius', 'borderTopRightRadius', 'borderBottomRightRadius', 'borderBottomLeftRadius', ] ); $css->add_property( 'border-radius', $border_radius_values ); $borders = [ 'border-top' => [ 'border-top-width' => 'borderTopWidth', 'border-top-style' => 'borderTopStyle', 'border-top-color' => 'borderTopColor', ], 'border-right' => [ 'border-right-width' => 'borderRightWidth', 'border-right-style' => 'borderRightStyle', 'border-right-color' => 'borderRightColor', ], 'border-bottom' => [ 'border-bottom-width' => 'borderBottomWidth', 'border-bottom-style' => 'borderBottomStyle', 'border-bottom-color' => 'borderBottomColor', ], 'border-left' => [ 'border-left-width' => 'borderLeftWidth', 'border-left-style' => 'borderLeftStyle', 'border-left-color' => 'borderLeftColor', ], ]; $border_values = []; foreach ( $borders as $property => $values ) { foreach ( $values as $property_name => $value_name ) { $value = generateblocks_get_array_attribute_value( $value_name . $device, $settings['borders'] ); if ( $value || is_numeric( $value ) ) { $border_values[ $property ][ $property_name ] = $value; } } } if ( ! empty( $border_values ) ) { $number_of_borders = count( (array) $border_values ); $all_equal = false; if ( 4 === $number_of_borders ) { $all_values = array_map( function( $value ) { return trim( implode( ' ', array_values( $value ) ) ); }, $border_values ); $all_equal = 1 === count( array_unique( $all_values ) ); } if ( $all_equal ) { $css->add_property( 'border', trim( implode( ' ', array_values( $border_values['border-top'] ) ) ) ); } else { foreach ( $border_values as $shorthand_property => $values ) { $number_of_values = count( (array) $values ); if ( 3 === $number_of_values ) { // Use the shorthand property with all three values. $css->add_property( $shorthand_property, trim( implode( ' ', array_values( $values ) ) ) ); } else { foreach ( $values as $property => $value ) { // Use the longhand property as we don't have all three values. $css->add_property( $property, $value ); } } } } } } /** * Add border color CSS. * * @param object $css The CSS object to add to. * @param array $settings Block settings. * @param string $state The state we're adding to. */ function generateblocks_add_border_color_css( $css, $settings, $state = '' ) { $colors = [ 'border-top-color' => 'borderTopColor', 'border-right-color' => 'borderRightColor', 'border-bottom-color' => 'borderBottomColor', 'border-left-color' => 'borderLeftColor', ]; $color_values = []; foreach ( $colors as $property => $value_name ) { $value = generateblocks_get_array_attribute_value( $value_name . $state, $settings['borders'] ); if ( $value ) { $color_values[ $state ][ $property ] = $value; } } if ( isset( $color_values[ $state ] ) ) { $number_of_colors = count( (array) $color_values[ $state ] ); $all_equal = 4 === $number_of_colors && 1 === count( array_unique( $color_values[ $state ] ) ); if ( $all_equal ) { $first_color = array_values( $color_values[ $state ] )[0]; $css->add_property( 'border-color', $first_color ); } else { foreach ( $color_values[ $state ] as $property => $value ) { $css->add_property( $property, $value ); } } } } /** * Helper function to get an attribute value from an array. * * @param string $name The name of the attribute. * @param array $array The array of attribute values. */ function generateblocks_get_array_attribute_value( $name, $array ) { return isset( $array[ $name ] ) ? $array[ $name ] : ''; } /** * Return the CSS selector for a specific block. * * @param string $name The name of the block. * @param array $attributes The block attributes. */ function generateblocks_get_css_selector( $name, $attributes ) { $selector = ''; $id = $attributes['uniqueId']; if ( 'button' === $name ) { $selector = '.gb-button-' . $id; } if ( 'headline' === $name ) { $selector = '.gb-headline-' . $id; } if ( 'container' === $name ) { $selector = '.gb-container-' . $id; } return apply_filters( 'generateblocks_block_css_selector', $selector, $name, $attributes ); } /** * Determine whether we should add the :visited selector to links. * * @param string $name The block name. * @param array $attributes The block attributes. */ function generateblocks_use_visited_selector( $name, $attributes ) { $blockVersion = ! empty( $attributes['blockVersion'] ) ? $attributes['blockVersion'] : 1; $use_visited_selector = false; if ( ( 'button' === $name || 'container' === $name ) && $blockVersion < 3 ) { $use_visited_selector = true; } if ( 'headline' === $name && $blockVersion < 2 ) { $use_visited_selector = true; } return apply_filters( 'generateblocks_use_visited_selector', $use_visited_selector, $name, $attributes ); } /** * Returns the global $wp_filesystem with credentials set. * Returns null in case of any errors. * * @return WP_Filesystem_Base|null */ function generateblocks_get_wp_filesystem() { global $wp_filesystem; $success = true; // Initialize the file system if it has not been done yet. if ( ! $wp_filesystem ) { require_once ABSPATH . '/wp-admin/includes/file.php'; $constants = array( 'hostname' => 'FTP_HOST', 'username' => 'FTP_USER', 'password' => 'FTP_PASS', 'public_key' => 'FTP_PUBKEY', 'private_key' => 'FTP_PRIKEY', ); $credentials = array(); // We provide credentials based on wp-config.php constants. // Reference https://developer.wordpress.org/apis/wp-config-php/#wordpress-upgrade-constants. foreach ( $constants as $key => $constant ) { if ( defined( $constant ) ) { $credentials[ $key ] = constant( $constant ); } } $success = WP_Filesystem( $credentials ); } if ( ! $success || $wp_filesystem->errors->has_errors() ) { return null; } return $wp_filesystem; } /** * Add global defaults to our blocks. * * @since 1.7.1 * @param array $defaults The existing defaults. */ function generateblocks_with_global_defaults( $defaults ) { $display = [ 'display', 'flexDirection', 'flexWrap', 'alignItems', 'justifyContent', 'columnGap', 'rowGap', 'position', 'overflowX', 'overflowY', 'zindex', ]; $flex_child = [ 'flexGrow', 'flexShrink', 'flexBasis', 'order', ]; $spacing = [ 'marginTop', 'marginRight', 'marginBottom', 'marginLeft', 'paddingTop', 'paddingRight', 'paddingBottom', 'paddingLeft', 'borderSizeTop', 'borderSizeRight', 'borderSizeBottom', 'borderSizeLeft', 'borderRadiusTopRight', 'borderRadiusBottomRight', 'borderRadiusBottomLeft', 'borderRadiusTopLeft', ]; $options = array_merge( $display, $flex_child, $spacing ); foreach ( $options as $option ) { $defaults[ $option ] = ''; $defaults[ $option . 'Tablet' ] = ''; $defaults[ $option . 'Mobile' ] = ''; } // Spacing. $defaults['spacing'] = []; $defaults['marginUnit'] = 'px'; $defaults['paddingUnit'] = 'px'; $defaults['borderRadiusUnit'] = 'px'; // Sizing. $defaults['sizing'] = []; $defaults['useGlobalMaxWidth'] = false; // Typography. $defaults['typography'] = []; // Icons. $defaults['iconStyles'] = []; // Borders. $defaults['borders'] = []; return $defaults; } /** * Get the list of font families for our font family control. * * @since 1.8.0 * @return array List of grouped fonts. */ function generateblocks_get_font_family_list() { return apply_filters( 'generateblocks_typography_font_family_list', [ [ 'label' => __( 'System Fonts', 'generateblocks' ), 'options' => [ [ 'value' => 'Arial', 'label' => 'Arial', ], [ 'value' => 'Helvetica', 'label' => 'Helvetica', ], [ 'value' => 'Times New Roman', 'label' => 'Times New Roman', ], [ 'value' => 'Georgia', 'label' => 'Georgia', ], ], ], ] ); } /** * Transforms a string to camelCase. * * @param string $str The string to be transformed. * * @return string */ function generateblocks_to_camel_case( string $str ): string { return lcfirst( str_replace( '_', '', ucwords( $str, '_' ) ) ); } /** * Transforms a string to snake_case. * * @param string $str The string to be transformed. * * @return string */ function generateblocks_to_snake_case( string $str ): string { return strtolower( preg_replace( '/(?<!^)[A-Z0-9]/', '_$0', $str ) ); } /** * Get our script dependencies and version. * * @param string $filename The filename to use. * @param array $fallback_assets The assets to fallback to. */ function generateblocks_get_enqueue_assets( $filename = '', $fallback_assets = [ 'dependencies' => [], 'version' => '', ] ) { if ( ! $filename ) { return $fallback_assets; } $assets_file = GENERATEBLOCKS_DIR . 'dist/' . $filename . '.asset.php'; $compiled_assets = file_exists( $assets_file ) ? require $assets_file : false; $assets = isset( $compiled_assets['dependencies'] ) && isset( $compiled_assets['version'] ) ? $compiled_assets : $fallback_assets; return $assets; }