diff options
author | Zach van Rijn <me@zv.io> | 2021-07-21 14:54:07 -0500 |
---|---|---|
committer | Zach van Rijn <me@zv.io> | 2021-07-21 14:54:07 -0500 |
commit | 9d4123cee1867ee7199b06bdc92d40611f547ecc (patch) | |
tree | 6d864e2725242863afed1f8ba12d9c7a9bc63a69 /inc/builder/type/footer/button | |
download | blog-ng-9d4123cee1867ee7199b06bdc92d40611f547ecc.tar.gz blog-ng-9d4123cee1867ee7199b06bdc92d40611f547ecc.tar.bz2 blog-ng-9d4123cee1867ee7199b06bdc92d40611f547ecc.tar.xz blog-ng-9d4123cee1867ee7199b06bdc92d40611f547ecc.zip |
Initial unmodified import from Astra (Version: 3.6.5) @ /wp-content/themes/astra/.
Diffstat (limited to 'inc/builder/type/footer/button')
5 files changed, 214 insertions, 0 deletions
diff --git a/inc/builder/type/footer/button/assets/js/minified/customizer-preview.min.js b/inc/builder/type/footer/button/assets/js/minified/customizer-preview.min.js new file mode 100644 index 0000000..3a83881 --- /dev/null +++ b/inc/builder/type/footer/button/assets/js/minified/customizer-preview.min.js @@ -0,0 +1 @@ +jQuery,astra_builder_button_css("footer",AstraBuilderFooterButtonData.component_limit);
\ No newline at end of file diff --git a/inc/builder/type/footer/button/assets/js/unminified/customizer-preview.js b/inc/builder/type/footer/button/assets/js/unminified/customizer-preview.js new file mode 100644 index 0000000..45f32cd --- /dev/null +++ b/inc/builder/type/footer/button/assets/js/unminified/customizer-preview.js @@ -0,0 +1,15 @@ +/**
+ * This file adds some LIVE to the Customizer live preview. To leverage
+ * this, set your custom settings to 'postMessage' and then add your handling
+ * here. Your javascript should grab settings from customizer controls, and
+ * then make any necessary changes to the page using jQuery.
+ *
+ * @package Astra
+ * @since 3.0.0
+ */
+
+( function( $ ) {
+
+ astra_builder_button_css( 'footer', AstraBuilderFooterButtonData.component_limit );
+
+} )( jQuery );
diff --git a/inc/builder/type/footer/button/class-astra-footer-button-component-loader.php b/inc/builder/type/footer/button/class-astra-footer-button-component-loader.php new file mode 100644 index 0000000..eb895bf --- /dev/null +++ b/inc/builder/type/footer/button/class-astra-footer-button-component-loader.php @@ -0,0 +1,62 @@ +<?php +/** + * Button Styling Loader for Astra theme. + * + * @package Astra + * @author Brainstorm Force + * @copyright Copyright (c) 2020, Brainstorm Force + * @link https://www.brainstormforce.com + * @since Astra 3.0.0 + */ + +if ( ! defined( 'ABSPATH' ) ) { + exit; // Exit if accessed directly. +} + +/** + * Customizer Initialization + * + * @since 3.0.0 + */ +class Astra_Footer_Button_Component_Loader { + + /** + * Constructor + * + * @since 3.0.0 + */ + public function __construct() { + add_action( 'customize_preview_init', array( $this, 'preview_scripts' ), 110 ); + } + + /** + * Customizer Preview + * + * @since 3.0.0 + */ + public function preview_scripts() { + /** + * Load unminified if SCRIPT_DEBUG is true. + */ + /* Directory and Extension */ + $dir_name = ( SCRIPT_DEBUG ) ? 'unminified' : 'minified'; + $file_prefix = ( SCRIPT_DEBUG ) ? '' : '.min'; + wp_enqueue_script( 'astra-footer-button-customizer-preview-js', ASTRA_FOOTER_BUTTON_URI . '/assets/js/' . $dir_name . '/customizer-preview' . $file_prefix . '.js', array( 'customize-preview', 'astra-customizer-preview-js' ), ASTRA_THEME_VERSION, true ); + + // Localize variables for Button JS. + wp_localize_script( + 'astra-footer-button-customizer-preview-js', + 'AstraBuilderFooterButtonData', + array( + 'component_limit' => defined( 'ASTRA_EXT_VER' ) ? Astra_Builder_Helper::$component_limit : Astra_Builder_Helper::$num_of_footer_button, + 'tablet_break_point' => astra_get_tablet_breakpoint(), + 'mobile_break_point' => astra_get_mobile_breakpoint(), + ) + ); + } +} + +/** +* Kicking this off by creating the object of the class. +*/ +new Astra_Footer_Button_Component_Loader(); diff --git a/inc/builder/type/footer/button/class-astra-footer-button-component.php b/inc/builder/type/footer/button/class-astra-footer-button-component.php new file mode 100644 index 0000000..f0344f9 --- /dev/null +++ b/inc/builder/type/footer/button/class-astra-footer-button-component.php @@ -0,0 +1,46 @@ +<?php +/** + * Footer Colors for Astra theme Buttpn. + * + * @package Astra + * @author Brainstorm Force + * @copyright Copyright (c) 2020, Brainstorm Force + * @link https://www.brainstormforce.com + * @since Astra 3.0.0 + */ + +if ( ! defined( 'ABSPATH' ) ) { + exit; // Exit if accessed directly. +} + + +define( 'ASTRA_FOOTER_BUTTON_DIR', ASTRA_THEME_DIR . 'inc/builder/type/footer/button' ); +define( 'ASTRA_FOOTER_BUTTON_URI', ASTRA_THEME_URI . 'inc/builder/type/footer/button' ); + +/** + * Heading Initial Setup + * + * @since 3.0.0 + */ +class Astra_Footer_Button_Component { + + /** + * Constructor function that initializes required actions and hooks + */ + public function __construct() { + + // @codingStandardsIgnoreStart WPThemeReview.CoreFunctionality.FileInclude.FileIncludeFound + require_once ASTRA_FOOTER_BUTTON_DIR . '/class-astra-footer-button-component-loader.php'; + + // Include front end files. + if ( ! is_admin() ) { + require_once ASTRA_FOOTER_BUTTON_DIR . '/dynamic-css/dynamic.css.php'; + } + // @codingStandardsIgnoreEnd WPThemeReview.CoreFunctionality.FileInclude.FileIncludeFound + } +} + +/** + * Kicking this off by creating an object. + */ +new Astra_Footer_Button_Component(); diff --git a/inc/builder/type/footer/button/dynamic-css/dynamic.css.php b/inc/builder/type/footer/button/dynamic-css/dynamic.css.php new file mode 100644 index 0000000..03e2037 --- /dev/null +++ b/inc/builder/type/footer/button/dynamic-css/dynamic.css.php @@ -0,0 +1,90 @@ +<?php +/** + * Butons - Dynamic CSS + * + * @package Astra + * @since 3.0.0 + */ + +if ( ! defined( 'ABSPATH' ) ) { + exit; // Exit if accessed directly. +} + +/** + * Heading Colors + */ +add_filter( 'astra_dynamic_theme_css', 'astra_fb_button_dynamic_css' ); + +/** + * Dynamic CSS + * + * @param string $dynamic_css Astra Dynamic CSS. + * @param string $dynamic_css_filtered Astra Dynamic CSS Filters. + * @return String Generated dynamic CSS for Heading Colors. + * + * @since 3.0.0 + */ +function astra_fb_button_dynamic_css( $dynamic_css, $dynamic_css_filtered = '' ) { + + $dynamic_css .= Astra_Button_Component_Dynamic_CSS::astra_button_dynamic_css( 'footer' ); + $fb_button_flag = false; + for ( $index = 1; $index <= Astra_Builder_Helper::$num_of_footer_button; $index++ ) { + + if ( ! Astra_Builder_Helper::is_component_loaded( 'button-' . $index, 'footer' ) ) { + continue; + } + $fb_button_flag = true; + + $selector = '.ast-footer-button-' . $index . '[data-section="section-fb-button-' . $index . '"]'; + + $alignment = astra_get_option( 'footer-button-' . $index . '-alignment' ); + + $desktop_alignment = ( isset( $alignment['desktop'] ) ) ? $alignment['desktop'] : ''; + $tablet_alignment = ( isset( $alignment['tablet'] ) ) ? $alignment['tablet'] : ''; + $mobile_alignment = ( isset( $alignment['mobile'] ) ) ? $alignment['mobile'] : ''; + + /** + * Copyright CSS. + */ + $css_output_desktop = array( + $selector => array( + 'justify-content' => $desktop_alignment, + ), + ); + + $css_output_tablet = array( + $selector => array( + 'justify-content' => $tablet_alignment, + ), + ); + + $css_output_mobile = array( + $selector => array( + 'justify-content' => $mobile_alignment, + ), + ); + + /* Parse CSS from array() */ + $css_output = astra_parse_css( $css_output_desktop ); + $css_output .= astra_parse_css( $css_output_tablet, '', astra_get_tablet_breakpoint() ); + $css_output .= astra_parse_css( $css_output_mobile, '', astra_get_mobile_breakpoint() ); + + $dynamic_css .= $css_output; + } + if ( true === $fb_button_flag ) { + $static_css = array( + '[data-section*="section-fb-button-"] .menu-link' => array( + 'display' => 'none', + ), + '[CLASS*="ast-footer-button-"][data-section^="section-fb-button-"]' => array( + 'justify-content' => 'center', + ), + '.site-footer-focus-item[CLASS*="ast-footer-button-"]' => array( + 'display' => 'flex', + ), + ); + return astra_parse_css( $static_css ) . $dynamic_css; + } + + return $dynamic_css; +} |